@import"https://fonts.googleapis.com/css2?family=Amiri:wght@400;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Lato:wght@300;400;500;600;700&display=swap";.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:400px}.toast{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;min-width:280px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:.75rem}.toast-icon{font-size:1.2rem;font-weight:700}.toast-message{font-size:.95rem}.toast-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;margin-left:1rem;opacity:.7;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-success{background-color:#d4edda;border-left:4px solid #28a745;color:#155724}.toast-success .toast-close{color:#155724}.toast-error{background-color:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.toast-error .toast-close{color:#721c24}.toast-warning{background-color:#fff3cd;border-left:4px solid #ffc107;color:#856404}.toast-warning .toast-close{color:#856404}.toast-info{background-color:#d1ecf1;border-left:4px solid #17a2b8;color:#0c5460}.toast-info .toast-close{color:#0c5460}@media(max-width:480px){.toast-container{left:1rem;right:1rem;max-width:none}.toast{min-width:auto}}.notification-bell-container{padding:0 16px;margin-bottom:4px}.notification-bell-button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:10px;color:#ffffffb3;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.notification-bell-button:hover{background:#ffffff1a;color:#fff;transform:translate(4px)}.notification-bell-button.has-unread{color:#fff}.notification-bell-icon{font-size:20px;position:relative;flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center}.notification-bell-icon svg{width:20px;height:20px;fill:currentColor}.notification-badge{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 4px #ef444466}.notification-bell-label{flex:1}.notification-dropdown-wrapper{position:relative}.notification-dropdown{position:absolute;left:100%;top:0;margin-left:8px;width:340px;max-height:440px;background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:0 20px 40px #00000026,0 0 0 1px #0000000d;display:flex;flex-direction:column;z-index:1100;overflow:hidden;animation:notificationDropdownIn .15s ease-out}@keyframes notificationDropdownIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.notification-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-light, #e2e8f0)}.notification-dropdown-header h3{font-size:15px;font-weight:600;color:var(--text-primary, #1e293b);margin:0}.notification-dropdown-mark-all{background:none;border:none;color:var(--primary-blue, #3D81DE);font-size:13px;font-weight:500;cursor:pointer;padding:2px 4px;border-radius:4px;font-family:inherit}.notification-dropdown-mark-all:hover{text-decoration:underline}.notification-dropdown-list{flex:1;overflow-y:auto;max-height:320px}.notification-dropdown-item{display:flex;gap:10px;padding:12px 16px;cursor:pointer;transition:background .15s ease;border-bottom:1px solid var(--border-light, #e2e8f0);align-items:flex-start}.notification-dropdown-item:last-child{border-bottom:none}.notification-dropdown-item.notification-high-priority{background:#fef2f2;border-left:3px solid #ef4444}.notification-dropdown-item:hover{background:var(--bg-gray-50, #f8f9fa)}.notification-dropdown-item .notification-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.notification-dropdown-item-content{flex:1;min-width:0}.notification-dropdown-item-title{font-size:13px;font-weight:500;color:var(--text-primary, #1e293b);margin:0 0 2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-dropdown-item-time{font-size:11px;color:var(--text-muted, #94a3b8)}.notification-dropdown-footer{padding:10px 16px;border-top:1px solid var(--border-light, #e2e8f0);text-align:center}.notification-dropdown-view-all{background:none;border:none;color:var(--primary-blue, #3D81DE);font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:4px;font-family:inherit}.notification-dropdown-view-all:hover{text-decoration:underline}.notification-dropdown-empty{padding:32px 16px;text-align:center;color:var(--text-muted, #94a3b8);font-size:14px}.notification-inbox{max-width:800px;margin:0 auto}.notification-inbox-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.notification-inbox-header h1{font-size:2rem;font-weight:700;color:var(--text-primary, #1e293b);margin:0}.notification-inbox-actions{display:flex;gap:.5rem}.notification-inbox-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-light, #e2e8f0)}.notification-filter-tab{padding:.75rem 1.5rem;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary, #64748b);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;font-family:inherit}.notification-filter-tab:hover{color:var(--primary-blue, #3D81DE)}.notification-filter-tab.active{color:var(--primary-blue, #3D81DE);border-bottom-color:var(--primary-blue, #3D81DE)}.notification-inbox-list{display:flex;flex-direction:column;gap:0}.notification-inbox-item{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:#fff;border:1px solid var(--border-light, #e2e8f0);border-bottom:none;cursor:pointer;transition:background .15s ease}.notification-inbox-item:first-child{border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0}.notification-inbox-item:last-child{border-bottom:1px solid var(--border-light, #e2e8f0);border-radius:0 0 var(--radius-lg, 12px) var(--radius-lg, 12px)}.notification-inbox-item:only-child{border-bottom:1px solid var(--border-light, #e2e8f0);border-radius:var(--radius-lg, 12px)}.notification-inbox-item:hover{background:var(--bg-gray-50, #f8f9fa)}.notification-inbox-item.unread{background:#f0f7ff;border-left:3px solid var(--primary-blue, #3D81DE)}.notification-inbox-item.unread:hover{background:#e6f0fb}.notification-inbox-type-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}.notification-inbox-item-content{flex:1;min-width:0}.notification-inbox-item-title{font-size:15px;font-weight:400;color:var(--text-primary, #1e293b);margin:0 0 4px;line-height:1.4}.notification-inbox-item.unread .notification-inbox-item-title{font-weight:600}.notification-inbox-item-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted, #94a3b8)}.notification-inbox-item-type-label{font-weight:500;font-size:12px;padding:1px 6px;border-radius:4px;background:var(--bg-gray-100, #f1f3f5)}.notification-inbox-item-dismiss{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted, #94a3b8);cursor:pointer;border-radius:4px;font-size:16px;transition:all .15s ease;font-family:inherit}.notification-inbox-item-dismiss:hover{background:var(--bg-gray-200, #e9ecef);color:var(--text-primary, #1e293b)}.notification-inbox-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem 0}.notification-inbox-pagination span{font-size:14px;color:var(--text-secondary, #64748b)}.notification-inbox-empty{text-align:center;padding:60px 20px;color:var(--text-muted, #94a3b8)}.notification-inbox-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.notification-inbox-empty h3{font-size:18px;font-weight:600;color:var(--text-secondary, #64748b);margin:0 0 8px}.notification-inbox-empty p{font-size:14px;margin:0}.notification-page-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid var(--border-light, #e2e8f0)}.notification-page-tab{padding:.75rem 1.5rem;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary, #64748b);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;font-family:inherit}.notification-page-tab:hover{color:var(--primary-blue, #3D81DE)}.notification-page-tab.active{color:var(--primary-blue, #3D81DE);border-bottom-color:var(--primary-blue, #3D81DE)}.notification-inbox-sub-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.notification-settings-content{max-width:700px}.notification-settings-desc{font-size:.9rem;color:var(--text-secondary, #64748b);margin:0 0 1.5rem}.notif-group{margin-bottom:28px}.notif-group:last-of-type{margin-bottom:0}.notif-group-title{font-size:1.05rem;font-weight:600;color:#1f2937;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.notif-group-items{display:flex;flex-direction:column;gap:0}.notif-row{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 0;border-bottom:1px solid #f3f4f6;gap:16px}.notif-row:last-child{border-bottom:none}.notif-row-info{flex:1;min-width:0}.notif-row-label{font-weight:500;color:#374151;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.notif-lock{font-size:.85rem}.notif-required-badge{font-size:.7rem;font-weight:600;color:#92400e;background:#fef3c7;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.02em}.notif-row-desc{font-size:.84rem;color:#6b7280;margin-top:3px}.notif-reminder-days{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:.84rem;color:#374151}.notif-select{padding:4px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:.84rem;width:56px;text-align:center}.notif-row-toggles{display:flex;gap:14px;flex-shrink:0;padding-top:2px}.notif-toggle-col{display:flex;flex-direction:column;align-items:center;gap:4px}.notif-toggle-label{font-size:.72rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.notif-switch{position:relative;width:40px;height:22px;flex-shrink:0}.notif-switch input{opacity:0;width:0;height:0}.notif-slider{position:absolute;cursor:pointer;inset:0;background-color:#d1d5db;transition:.25s;border-radius:22px}.notif-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;transition:.25s;border-radius:50%}.notif-switch input:checked+.notif-slider{background-color:#2563eb}.notif-switch input:disabled+.notif-slider{opacity:.5;cursor:not-allowed}.notif-switch input:checked+.notif-slider:before{transform:translate(18px)}.notif-actions{margin-top:28px;padding-top:20px;border-top:1px solid #e5e7eb}@media(max-width:768px){.notification-dropdown{position:fixed;left:16px;right:16px;top:80px;width:auto;margin-left:0;max-height:60vh}.notification-inbox-header{flex-direction:column;align-items:flex-start}.notification-inbox-item{padding:12px 14px}.notif-row{flex-direction:column;gap:10px}.notif-row-toggles{align-self:flex-start}.notification-inbox-sub-actions{flex-direction:column;align-items:stretch}.notification-inbox-filters{margin-bottom:0}}@media(max-width:480px){.notification-bell-label{display:none}.notification-dropdown{left:8px;right:8px;top:70px}.notification-inbox-actions{flex-wrap:wrap}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(180deg,#0c1a2c,#1a2942);display:flex;flex-direction:column;z-index:1000;box-shadow:4px 0 20px #0000001a}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#3d81de,#7eabe9);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 12px #3d81de4d}.logo-text{font-size:24px;font-weight:700;color:#fff;margin:0;letter-spacing:-.02em}.sidebar-user{padding:20px;display:flex;align-items:center;gap:12px;background:#ffffff0d;margin:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.user-avatar{width:48px;height:48px;background:linear-gradient(135deg,#3d81de,#7eabe9);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#fff;text-transform:uppercase;box-shadow:0 4px 12px #3d81de33}.user-details{flex:1;min-width:0}.user-name{font-size:15px;font-weight:600;color:#fff;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:#fff9;text-transform:capitalize}.sidebar-nav{flex:1;padding:8px 16px;overflow-y:auto}.nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:4px;background:transparent;border:none;border-radius:10px;color:#ffffffb3;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.nav-item:hover{background:#ffffff1a;color:#fff;transform:translate(4px)}.nav-item.active{background:linear-gradient(135deg,#3d81de,#5a95e5);color:#fff;box-shadow:0 4px 12px #3d81de4d}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:20px;transition:transform .2s ease}.nav-label{flex:1}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.logout-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#fca5a5;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#ef444433;color:#fecaca;border-color:#ef444480}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar-hamburger{position:fixed;top:16px;left:16px;z-index:1100;width:44px;height:44px;background:var(--bg-navy, #0C1A2C);color:#fff;border:none;border-radius:var(--radius-md, 8px);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0,0,0,.1))}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999}.sidebar-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:#ffffffb3;cursor:pointer;padding:4px;border-radius:6px}.sidebar-close:hover{color:#fff;background:#ffffff1a}.sidebar.sidebar-mobile{transform:translate(-100%);transition:transform .3s ease}.sidebar.sidebar-mobile.sidebar-open{transform:translate(0)}@media(max-width:1024px){.sidebar.sidebar-mobile{width:280px}}@media(max-width:768px){.logo-text{font-size:20px}.user-name{font-size:14px}.nav-item{font-size:14px;padding:10px 12px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-navy) 0%,var(--bg-navy-light) 100%);padding:2rem}.login-box{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:3rem;width:100%;max-width:450px;border:1px solid var(--border-light)}.login-home-link{display:inline-flex;align-items:center;gap:.3rem;margin-bottom:1.25rem;padding:.3rem .75rem;color:#fff;background:var(--accent-blue, #3b82f6);border:none;border-radius:6px;text-decoration:none;font-size:.8rem;font-weight:500;transition:opacity .2s}.login-home-link:hover{opacity:.85}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-header p{color:var(--text-secondary);font-size:.9375rem}.login-form{margin-bottom:2rem}.login-footer{border-top:1px solid var(--border-light);padding-top:1.5rem;text-align:center}.quick-login-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.quick-login-btn{padding:.5rem .875rem;border:none;border-radius:var(--radius-md);color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s}.quick-login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.quick-login-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.login-box{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.landing-page{min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden;background:linear-gradient(135deg,#0d1f2d,#1a3a52,#0d1f2d);color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 3rem;background:#0000004d;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-logo{display:flex;align-items:center;gap:.75rem}.nav-logo img{height:50px;width:auto}.nav-logo span{font-size:1.5rem;font-weight:700;color:#d4af37}.login-btn{background:linear-gradient(135deg,#d4af37,#f4e4ba,#d4af37);color:#0d1f2d;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:700;border-radius:25px;cursor:pointer;transition:all .3s ease}.login-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #d4af3766}.hero-section{text-align:center;padding:4rem 2rem 6rem;background:radial-gradient(ellipse at center,rgba(212,175,55,.1) 0%,transparent 70%)}.hero-content{max-width:800px;margin:0 auto}.hero-logo{width:180px;height:auto;margin-bottom:1rem}.hero-content h1{font-size:3.5rem;color:#d4af37;margin-bottom:.25rem;text-shadow:0 0 30px rgba(212,175,55,.3)}.hero-content .arabic{font-family:Amiri,Traditional Arabic,serif;font-size:2.5rem;color:#f4e4ba;margin-bottom:1.5rem}.decorative-line{width:100px;height:3px;background:linear-gradient(90deg,transparent,#D4AF37,transparent);margin:1.5rem auto}.decorative-line.light{background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}.tagline{font-size:1.25rem;color:#ccc;max-width:600px;margin:0 auto 2rem;line-height:1.6}.cta-btn{background:linear-gradient(135deg,#d4af37,#f4e4ba,#d4af37);color:#0d1f2d;border:none;padding:1rem 3rem;font-size:1.2rem;font-weight:700;border-radius:30px;cursor:pointer;transition:all .3s ease}.cta-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px #d4af3766}.landing-page .section-header{text-align:center;margin-bottom:3rem}.landing-page .section-header h2{font-size:2.5rem;color:#d4af37;margin-bottom:.5rem}.landing-page .section-header p{color:#aaa;font-size:1.1rem}.features-section{padding:5rem 3rem;background:#0003}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1400px;margin:0 auto}.feature-card{background:linear-gradient(145deg,#1a3a52cc,#0d1f2de6);border:1px solid rgba(212,175,55,.2);border-radius:15px;padding:2rem;text-align:center;transition:all .3s ease}.feature-card:hover{transform:translateY(-5px);border-color:#d4af3780;box-shadow:0 10px 40px #d4af371a}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#d4af37;font-size:1.3rem;margin-bottom:.75rem}.feature-card p{color:#bbb;font-size:.95rem;line-height:1.5}.calendar-section{padding:5rem 3rem}.calendar-mockup{max-width:900px;margin:0 auto;background:linear-gradient(145deg,#1a3a52e6,#0d1f2df2);border:1px solid rgba(212,175,55,.3);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#0000004d;border-bottom:1px solid rgba(212,175,55,.2)}.calendar-header h4{color:#d4af37;font-size:1.3rem;margin:0}.calendar-views{display:flex;gap:.5rem}.calendar-views span{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:#888}.calendar-views span.active{background:linear-gradient(135deg,#d4af37,#f4e4ba);color:#0d1f2d;font-weight:700}.calendar-views span:hover:not(.active){color:#d4af37}.calendar-day{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.calendar-block{border-radius:12px;padding:1.25rem}.calendar-block h5{margin:0 0 1rem;font-size:1rem;display:flex;align-items:center;gap:.5rem;color:#1f2937}.calendar-block.quizzes{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.calendar-block.assignments{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-left:4px solid #3b82f6}.calendar-block.schedule{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-left:4px solid #10b981}.calendar-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;margin-bottom:.25rem;font-size:.9rem;color:#1f2937;border-bottom:1px solid rgba(0,0,0,.05)}.calendar-item:last-child{margin-bottom:0;border-bottom:none}.calendar-item .class-name{color:#6b7280;font-size:.75rem}.more-features-section{padding:5rem 3rem;background:#0003}.features-mini-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}.feature-mini{text-align:center;padding:1.5rem 1rem;background:#1a3a5280;border:1px solid rgba(212,175,55,.1);border-radius:12px;transition:all .3s ease}.feature-mini:hover{border-color:#d4af374d;transform:translateY(-3px)}.feature-mini-icon{font-size:2rem;margin-bottom:.75rem}.feature-mini h4{color:#d4af37;font-size:.95rem;margin:0 0 .25rem}.feature-mini p{color:#888;font-size:.8rem;margin:0}.cta-section{padding:5rem 3rem;text-align:center;background:radial-gradient(ellipse at center,rgba(212,175,55,.05) 0%,transparent 70%)}.cta-section h3{font-size:2rem;color:#d4af37;margin-bottom:1rem}.cta-section>p{color:#aaa;max-width:600px;margin:0 auto 2rem;line-height:1.6}.contact-info{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;margin-top:2rem}.contact-item{text-align:center}.contact-item span{display:block;color:#888;font-size:.9rem;margin-bottom:.25rem}.contact-item strong{color:#d4af37;font-size:1.1rem}.landing-footer{text-align:center;padding:3rem 2rem;background:#0006;border-top:1px solid rgba(212,175,55,.2)}.footer-logo{width:80px;height:auto;margin-bottom:1rem}.footer-name{color:#d4af37;font-size:1.2rem;margin:0 0 .25rem}.footer-tagline{color:#888;font-size:.9rem;margin:0}.footer-copyright{color:#666;font-size:.8rem;margin:.5rem 0 0}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#ccc;text-decoration:none;font-size:1rem;cursor:pointer;transition:color .3s ease;background:none;border:none;font-family:inherit;padding:0}.nav-link:hover{color:#d4af37}.nav-home-link{color:#d4af37!important;font-weight:600;position:relative;padding-bottom:2px}.nav-home-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:#d4af37;border-radius:1px}.features-dropdown{position:relative}.features-dropdown .nav-link{display:flex;align-items:center;gap:.3rem}.features-dropdown .nav-link:after{content:"";display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;margin-left:4px;transition:transform .2s ease}.features-dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#0d1f2dfa;border:1px solid rgba(212,175,55,.3);border-radius:10px;padding:.5rem 0;min-width:220px;opacity:0;visibility:hidden;transition:all .25s ease;box-shadow:0 10px 30px #0006;margin-top:.5rem;z-index:200}.features-dropdown:hover .features-dropdown-menu{opacity:1;visibility:visible}.features-dropdown:hover .nav-link:after{transform:rotate(180deg)}.features-dropdown-item{display:block;padding:.7rem 1.25rem;color:#ccc;text-decoration:none;font-size:.95rem;transition:all .2s ease;white-space:nowrap}.features-dropdown-item:hover{color:#d4af37;background:#d4af371a}.landing-footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1.25rem}.landing-footer-links a{color:#aaa;text-decoration:none;font-size:.9rem;transition:color .3s ease}.landing-footer-links a:hover{color:#d4af37}@media(max-width:1024px){.features-mini-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.landing-nav{padding:1rem 1.5rem}.nav-logo img{height:40px}.nav-logo span{font-size:1.2rem}.hero-content h1{font-size:2.5rem}.hero-content .arabic{font-size:1.8rem}.hero-logo{width:140px}.landing-page .section-header h2{font-size:1.8rem}.features-section,.calendar-section,.more-features-section,.cta-section{padding:3rem 1.5rem}.features-grid,.calendar-day{grid-template-columns:1fr}.contact-info{gap:2rem}.nav-links{gap:1rem}.landing-footer-links{gap:1.5rem}}@media(max-width:480px){.landing-page{font-size:14px}.landing-nav{padding:.5rem .75rem}.nav-logo img{height:35px}.nav-logo span{font-size:1rem}.login-btn{padding:.4rem 1rem;font-size:.85rem}.hero-section{padding:1.5rem .75rem 2rem}.hero-content h1{font-size:1.6rem}.hero-content .arabic{font-size:1.3rem}.hero-logo{width:100px}.tagline{font-size:.9rem;padding:0 .25rem;line-height:1.4}.cta-btn{padding:.6rem 1.5rem;font-size:.9rem}.landing-page .section-header{margin-bottom:1.5rem}.landing-page .section-header h2{font-size:1.3rem}.landing-page .section-header p{font-size:.85rem;padding:0 .25rem}.features-section,.calendar-section,.more-features-section,.cta-section{padding:1.5rem .75rem}.features-grid{gap:1rem}.feature-card{padding:1rem}.feature-icon{font-size:2rem}.feature-card h3{font-size:1rem}.feature-card p{font-size:.8rem}.calendar-mockup{border-radius:12px}.calendar-header{padding:.75rem;flex-direction:column;gap:.5rem}.calendar-header h4{font-size:1rem}.calendar-views span{padding:.3rem .6rem;font-size:.8rem}.calendar-day{padding:.75rem;gap:1rem}.calendar-block{padding:.75rem;border-radius:8px}.calendar-block h5{font-size:.85rem;margin-bottom:.5rem}.calendar-item{flex-direction:column;align-items:flex-start;gap:.15rem;font-size:.8rem;padding:.3rem 0}.features-mini-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.feature-mini{padding:.75rem .5rem}.feature-mini-icon{font-size:1.5rem;margin-bottom:.5rem}.feature-mini h4{font-size:.8rem}.feature-mini p{font-size:.7rem}.cta-section h3{font-size:1.3rem}.cta-section>p{font-size:.85rem}.contact-info{flex-direction:column;gap:1rem}.contact-item span{font-size:.8rem}.contact-item strong{font-size:.95rem}.landing-footer{padding:2rem 1rem}.footer-logo{width:60px}.footer-name{font-size:1rem}.footer-tagline{font-size:.8rem}.nav-links{gap:.75rem}.nav-link{font-size:.85rem}.features-dropdown-menu{left:auto;right:0;transform:none;min-width:180px}.features-dropdown-item{font-size:.85rem;padding:.6rem 1rem}.landing-footer-links{flex-direction:column;gap:.75rem;align-items:center}}.feature-detail-page{min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden;background:linear-gradient(135deg,#0d1f2d,#1a3a52,#0d1f2d);color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.feature-detail-hero{text-align:center;padding:5rem 2rem 3rem;background:radial-gradient(ellipse at center,rgba(212,175,55,.08) 0%,transparent 70%)}.feature-detail-hero h1{font-size:3rem;color:#d4af37;margin-bottom:1rem;text-shadow:0 0 30px rgba(212,175,55,.3)}.feature-detail-hero p{color:#aaa;font-size:1.15rem;max-width:650px;margin:0 auto;line-height:1.6}.feature-detail-sections{max-width:900px;margin:0 auto;padding:2rem 2rem 4rem}.feature-detail-section{background:linear-gradient(145deg,#1a3a52b3,#0d1f2dcc);border:1px solid rgba(212,175,55,.15);border-radius:15px;padding:2.5rem;margin-bottom:2rem;transition:border-color .3s ease}.feature-detail-section:hover{border-color:#d4af3766}.feature-detail-section .section-number{display:inline-block;width:36px;height:36px;line-height:36px;text-align:center;background:linear-gradient(135deg,#d4af37,#f4e4ba);color:#0d1f2d;border-radius:50%;font-weight:700;font-size:1rem;margin-bottom:1rem}.feature-detail-section h2{color:#d4af37;font-size:1.5rem;margin:0 0 1rem}.feature-detail-section p{color:#bbb;line-height:1.7;font-size:1.05rem;margin:0}.feature-detail-cta{text-align:center;padding:3rem 2rem 5rem}.feature-detail-cta h3{color:#d4af37;font-size:1.8rem;margin-bottom:1rem}.feature-detail-cta p{color:#aaa;font-size:1.05rem;margin-bottom:.5rem}.feature-detail-cta a{color:#d4af37;text-decoration:none;font-weight:700}.feature-detail-cta a:hover{text-decoration:underline}.info-page{min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden;background:linear-gradient(135deg,#0d1f2d,#1a3a52,#0d1f2d);color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.info-page-hero{text-align:center;padding:5rem 2rem 3rem;background:radial-gradient(ellipse at center,rgba(212,175,55,.08) 0%,transparent 70%)}.info-page-hero h1{font-size:3rem;color:#d4af37;margin-bottom:.5rem;text-shadow:0 0 30px rgba(212,175,55,.3)}.info-page-hero p{color:#aaa;font-size:1.15rem}.info-page-content{max-width:850px;margin:0 auto;padding:2rem 2rem 4rem}.info-page-content section{background:linear-gradient(145deg,#1a3a52b3,#0d1f2dcc);border:1px solid rgba(212,175,55,.15);border-radius:15px;padding:2.5rem;margin-bottom:2rem;transition:border-color .3s ease}.info-page-content section:hover{border-color:#d4af3766}.info-page-content h2{color:#d4af37;font-size:1.5rem;margin:0 0 1rem}.info-page-content h3{color:#f4e4ba;font-size:1.2rem;margin:1.5rem 0 .75rem}.info-page-content p{color:#bbb;line-height:1.7;font-size:1.05rem;margin:0 0 .75rem}.info-page-content ul{color:#bbb;line-height:1.7;padding-left:1.5rem;margin:.5rem 0}.info-page-content li{margin-bottom:.4rem}.info-page-content a{color:#d4af37;text-decoration:none}.info-page-content a:hover{text-decoration:underline}.info-page-content .contact-grid{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1rem}.info-page-content .contact-grid .contact-item{text-align:left}.info-page-content .contact-grid .contact-item span{display:block;color:#888;font-size:.9rem;margin-bottom:.25rem}.info-page-content .contact-grid .contact-item strong{color:#d4af37;font-size:1.05rem}.terms-section-number{display:inline-block;color:#d4af37;font-weight:700;margin-right:.5rem}@media(max-width:768px){.feature-detail-hero h1,.info-page-hero h1{font-size:2.2rem}.feature-detail-section,.info-page-content section{padding:1.75rem}}@media(max-width:480px){.feature-detail-hero,.info-page-hero{padding:3rem 1rem 2rem}.feature-detail-hero h1,.info-page-hero h1{font-size:1.6rem}.feature-detail-hero p,.info-page-hero p{font-size:.95rem}.feature-detail-sections,.info-page-content{padding:1rem .75rem 2rem}.feature-detail-section,.info-page-content section{padding:1.25rem;border-radius:10px}.feature-detail-section h2,.info-page-content h2{font-size:1.2rem}.feature-detail-section p,.info-page-content p{font-size:.9rem}.feature-detail-cta h3{font-size:1.3rem}.info-page-content .contact-grid{flex-direction:column;gap:1rem}}.fa-container{max-width:720px;margin:0 auto 2rem;padding:2rem;background:linear-gradient(145deg,#141428,#1a1a2e);border:1px solid rgba(212,168,67,.15);border-radius:16px;overflow:hidden;position:relative}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px) scaleX(.3)}to{opacity:1;transform:translate(0) scaleX(1)}}@keyframes growBar{0%{height:0}to{height:var(--bar-height)}}@keyframes fillCell{0%{background-color:#ffffff0a}to{background-color:#22c55e}}@keyframes pulseGlow{0%,to{box-shadow:0 0 4px #3d81de66}50%{box-shadow:0 0 16px #3d81decc,0 0 32px #3d81de4d}}@keyframes drawLine{0%{stroke-dashoffset:500}to{stroke-dashoffset:0}}@keyframes flowDots{0%{transform:translate(0);opacity:0}15%{opacity:1}85%{opacity:1}to{transform:translate(calc(100% + 8px));opacity:0}}@keyframes pointFadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes areaReveal{0%{opacity:0}to{opacity:1}}.fa-pipeline-label{text-align:center;color:#ffffff59;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.5rem;opacity:0}.fa-visible .fa-pipeline-label{animation:fadeSlideIn .5s ease forwards}.fa-pipeline-row{display:flex;align-items:center;justify-content:center;gap:0}.fa-pipeline-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 1rem;background:#ffffff0a;border:1px solid rgba(212,168,67,.2);border-radius:12px;min-width:110px;opacity:0}.fa-visible .fa-pipeline-card--1{animation:fadeSlideIn .6s ease .1s forwards,float 3s ease-in-out .8s infinite}.fa-visible .fa-pipeline-card--2{animation:fadeSlideIn .6s ease .35s forwards,float 3s ease-in-out 1.2s infinite}.fa-visible .fa-pipeline-card--3{animation:fadeSlideIn .6s ease .6s forwards,float 3s ease-in-out 1.6s infinite}.fa-pipeline-icon{display:flex;align-items:center;justify-content:center}.fa-pipeline-card-label{color:#ffffffb3;font-size:.75rem;white-space:nowrap}.fa-pipeline-arrow{position:relative;width:60px;height:2px;margin:0 4px;flex-shrink:0}.fa-pipeline-arrow-line{position:absolute;top:0;left:0;width:100%;height:100%;background:#d4a84333;border-radius:1px}.fa-pipeline-dot{position:absolute;top:50%;left:0;width:6px;height:6px;margin-top:-3px;border-radius:50%;background:#d4a843;opacity:0}.fa-visible .fa-pipeline-dot{animation:flowDots 1.8s ease-in-out infinite}.fa-visible .fa-pipeline-dot--1{animation-delay:.8s}.fa-visible .fa-pipeline-dot--2{animation-delay:1.4s}.fa-visible .fa-pipeline-dot--3{animation-delay:2s}.fa-calendar{padding:1.5rem}.fa-cal-header{text-align:center;color:#d4a843;font-size:1.1rem;font-weight:600;margin-bottom:1rem;opacity:0}.fa-visible .fa-cal-header{animation:fadeSlideIn .5s ease .1s forwards}.fa-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.fa-cal-day-name{text-align:center;color:#fff6;font-size:.7rem;text-transform:uppercase;padding:6px 0;letter-spacing:1px}.fa-cal-cell{display:flex;flex-direction:column;align-items:center;padding:6px 4px 5px;background:#ffffff08;border-radius:6px;min-height:52px;gap:4px;transition:background .2s ease}.fa-cal-cell--has-event{background:#ffffff0f}.fa-cal-cell--empty{background:transparent}.fa-cal-date{color:#ffffff80;font-size:.75rem;line-height:1}.fa-cal-cell--has-event .fa-cal-date{color:#fffc}.fa-cal-dots{display:flex;gap:3px;opacity:0}.fa-visible .fa-cal-dots{animation:fadeSlideIn .4s ease calc(.3s + var(--cell-delay, 0s)) forwards}.fa-cal-dot{width:7px;height:7px;border-radius:50%}.fa-cal-dot--blue{background:#3d81de}.fa-cal-dot--purple{background:#8b5cf6}.fa-cal-dot--green{background:#22c55e}.fa-cal-legend{display:flex;justify-content:center;gap:1.25rem;margin-top:1rem;opacity:0}.fa-visible .fa-cal-legend{animation:fadeSlideIn .5s ease 1s forwards}.fa-cal-legend-item{display:flex;align-items:center;gap:4px;color:#ffffff80;font-size:.65rem}.fa-cal-legend-dot{width:8px;height:8px;border-radius:2px}.fa-cal-legend-dot--blue{background:#3d81deb3}.fa-cal-legend-dot--purple{background:#8b5cf6b3}.fa-cal-legend-dot--green{background:#22c55eb3}.fa-hifz-title{text-align:center;color:#ffffff59;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.25rem;opacity:0}.fa-visible .fa-hifz-title{animation:fadeSlideIn .5s ease forwards}.fa-hifz-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;max-width:420px;margin:0 auto}.fa-hifz-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;position:relative;transition:background-color .3s ease}.fa-hifz-cell-num{font-size:.8rem;font-weight:600;color:#ffffffb3;position:relative;z-index:1}.fa-hifz-cell--not-started{background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.fa-hifz-cell--not-started .fa-hifz-cell-num{color:#ffffff4d}.fa-hifz-cell--memorized{background:#ffffff0a;border:1px solid rgba(34,197,94,.3)}.fa-visible .fa-hifz-cell--memorized{animation:fillCell .4s ease var(--cell-delay) forwards}.fa-hifz-cell--memorized .fa-hifz-cell-num{color:#fff}.fa-hifz-cell--current{background:#3d81de40;border:1px solid rgba(61,129,222,.5)}.fa-visible .fa-hifz-cell--current{animation:pulseGlow 2s ease-in-out 1.2s infinite}.fa-hifz-cell--current .fa-hifz-cell-num{color:#3d81de;font-weight:700}.fa-hifz-legend{display:flex;justify-content:center;gap:1.25rem;margin-top:1.25rem;opacity:0}.fa-visible .fa-hifz-legend{animation:fadeSlideIn .5s ease 2s forwards}.fa-hifz-legend-item{display:flex;align-items:center;gap:5px;color:#ffffff80;font-size:.7rem}.fa-hifz-legend-dot{width:10px;height:10px;border-radius:4px}.fa-hifz-legend-dot--memorized{background:#22c55e}.fa-hifz-legend-dot--current{background:#3d81de80;border:1px solid rgba(61,129,222,.8)}.fa-hifz-legend-dot--not-started{background:#ffffff0f;border:1px solid rgba(255,255,255,.12)}.fa-reports-row{display:flex;gap:1.5rem}.fa-reports-panel{flex:1;min-width:0}.fa-reports-panel-title{color:#fff6;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.75rem;text-align:center;opacity:0}.fa-visible .fa-reports-panel-title{animation:fadeSlideIn .4s ease .1s forwards}.fa-reports-bar-chart{display:flex;align-items:flex-end;justify-content:center;gap:10px;height:140px;padding:0 8px}.fa-reports-bar-col{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.fa-reports-bar-track{width:100%;height:120px;display:flex;align-items:flex-end;justify-content:center}.fa-reports-bar{width:100%;max-width:32px;height:0;background:var(--bar-color);border-radius:4px 4px 0 0;opacity:.85}.fa-visible .fa-reports-bar{animation:growBar .6s ease var(--bar-delay) forwards}.fa-reports-bar-label{color:#ffffff80;font-size:.7rem;font-weight:600}.fa-reports-line-chart{height:140px;display:flex;flex-direction:column;position:relative}.fa-reports-svg{flex:1;width:100%}.fa-reports-line{stroke-dasharray:500;stroke-dashoffset:500}.fa-visible .fa-reports-line{animation:drawLine 1.2s ease .4s forwards}.fa-reports-area{opacity:0}.fa-visible .fa-reports-area{animation:areaReveal .8s ease 1s forwards}.fa-reports-point{opacity:0;transform-origin:center;transform-box:fill-box}.fa-visible .fa-reports-point{animation:pointFadeIn .3s ease var(--point-delay) forwards}.fa-reports-x-labels{display:flex;justify-content:space-between;padding:4px 5px 0}.fa-reports-x-labels span{color:#ffffff59;font-size:.55rem}@media(max-width:768px){.fa-container{margin:0 auto 1.5rem;padding:1.25rem;border-radius:12px}.fa-pipeline-row{flex-direction:column;gap:0}.fa-pipeline-arrow{width:2px;height:40px;margin:4px 0}.fa-pipeline-arrow-line{width:100%;height:100%}.fa-pipeline-dot{left:50%;top:0;margin-left:-3px;margin-top:0}.fa-visible .fa-pipeline-dot{animation:flowDotsVertical 1.8s ease-in-out infinite}.fa-pipeline-card{min-width:140px}.fa-cal-cell{min-height:42px;padding:4px 3px}.fa-cal-date{font-size:.65rem}.fa-cal-dot{width:6px;height:6px}.fa-cal-legend{flex-wrap:wrap;gap:.75rem}.fa-hifz-grid{gap:4px}.fa-hifz-cell-num{font-size:.65rem}.fa-hifz-legend{flex-wrap:wrap;gap:.75rem}.fa-reports-row{flex-direction:column;gap:1.5rem}.fa-reports-bar-chart{height:120px}.fa-reports-bar-track{height:100px}.fa-reports-line-chart{height:120px}}@media(max-width:480px){.fa-container{padding:1rem;margin:0 .5rem 1rem;border-radius:10px}.fa-pipeline-card{padding:.75rem;min-width:100px}.fa-pipeline-icon svg{width:30px;height:30px}.fa-pipeline-card-label{font-size:.65rem}.fa-hifz-grid{gap:3px}.fa-hifz-cell-num{font-size:.55rem}}@keyframes flowDotsVertical{0%{transform:translateY(0);opacity:0}15%{opacity:1}85%{opacity:1}to{transform:translateY(calc(100% + 8px));opacity:0}}@media(prefers-reduced-motion:reduce){.fa-pipeline-card,.fa-pipeline-label,.fa-cal-header,.fa-cal-dots,.fa-cal-legend,.fa-hifz-title,.fa-hifz-cell--memorized,.fa-hifz-cell--current,.fa-hifz-legend,.fa-reports-panel-title,.fa-reports-bar,.fa-reports-line,.fa-reports-area,.fa-reports-point{animation:none!important;opacity:1!important;transform:none!important}.fa-pipeline-dot{animation:none!important;opacity:0!important}.fa-hifz-cell--memorized{background-color:#22c55e!important}.fa-hifz-cell--current{box-shadow:0 0 8px #3d81de80!important}.fa-reports-bar{height:var(--bar-height)!important}.fa-reports-line{stroke-dashoffset:0!important}.fa-reports-area{opacity:1!important}}.admissions-shell{min-height:100vh;background:var(--bg-light, #f5f6f8);display:flex;flex-direction:column}.admissions-header{background:var(--brand-primary, #3949ab);color:#fff;padding:1rem 2rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 4px #00000014}.admissions-header__logo{height:40px;width:auto;border-radius:4px;background:#fff;padding:4px}.admissions-header__title{font-size:1.25rem;font-weight:600;margin:0;flex:1}.admissions-header__logout{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.4rem .9rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.admissions-header__logout:hover{background:#ffffff40}.admissions-main{flex:1;padding:3rem 2rem;display:flex;flex-direction:column;align-items:center}.admissions-main__title{font-size:2rem;font-weight:600;color:var(--text-primary, #222);margin:0 0 2rem;text-align:center}.admissions-choice{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:800px;width:100%}@media(max-width:720px){.admissions-choice{grid-template-columns:1fr}}.admissions-card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:2rem;display:flex;flex-direction:column}.admissions-card__title{font-size:1.25rem;font-weight:600;color:var(--text-primary, #222);margin:0 0 1rem}.admissions-card__body{color:var(--text-secondary, #555);font-size:.95rem;line-height:1.5;flex:1;margin-bottom:1.5rem}.admissions-card__action{align-self:flex-end;background:none;border:none;color:var(--brand-primary, #3949ab);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-decoration:none;cursor:pointer;text-transform:uppercase;padding:.5rem 0}.admissions-card__action:hover{text-decoration:underline}.admissions-form-card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:2rem;width:100%;max-width:480px}.admissions-form-card__title{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary, #222)}.admissions-form-card__sub{color:var(--text-secondary, #555);font-size:.95rem;margin:0 0 1.5rem}.admissions-form-group{margin-bottom:1.25rem}.admissions-form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.4rem;color:var(--text-primary, #222)}.admissions-form-group .required{color:#dc3545;margin-left:2px}.admissions-form-group input[type=text],.admissions-form-group input[type=email]{width:100%;padding:.6rem .75rem;font-size:1rem;border:1px solid var(--border-light, #d1d5db);border-radius:4px;box-sizing:border-box}.admissions-form-group input:focus{outline:none;border-color:var(--brand-primary, #3949ab);box-shadow:0 0 0 2px #3949ab26}.admissions-form-error{color:#dc3545;font-size:.8125rem;margin-top:.25rem}.admissions-form-actions{display:flex;align-items:center;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.admissions-form-actions__primary{background:none;border:none;color:var(--brand-primary, #3949ab);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;padding:.5rem 1rem}.admissions-form-actions__primary:hover:not(:disabled){background:#3949ab0d;border-radius:4px}.admissions-form-actions__primary:disabled{opacity:.5;cursor:not-allowed}.admissions-form-card__back{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light, #d1d5db)}.admissions-form-card__back a{color:var(--brand-primary, #3949ab);text-decoration:none;font-size:.95rem;font-weight:500}.admissions-form-card__back a:hover{text-decoration:underline}.admissions-confirmation{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:2.5rem;width:100%;max-width:560px;text-align:center}.admissions-confirmation__title{font-size:1.75rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #222)}.admissions-confirmation__body{color:var(--text-secondary, #555);font-size:1rem;line-height:1.55;margin:0 0 1.5rem}.admissions-confirmation__cta{background:none;border:none;color:var(--brand-primary, #3949ab);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;padding:.5rem 1rem;text-decoration:none}.admissions-confirmation__cta:hover{text-decoration:underline}.admissions-loading,.admissions-not-found{text-align:center;padding:4rem 2rem;color:var(--text-secondary, #555)}.admissions-not-found__title{font-size:1.5rem;color:var(--text-primary, #222);margin:0 0 .5rem}.admissions-home{width:100%;max-width:960px}.admissions-welcome-card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:2rem;margin-bottom:2rem}.admissions-welcome-card__title{font-size:1.25rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #222)}.admissions-welcome-card__body{color:var(--text-primary, #444);font-size:.95rem;line-height:1.55;white-space:pre-wrap;margin:0}.admissions-school-year-card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:1.5rem 2rem}.admissions-school-year-card__header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-light, #e5e7eb);padding-bottom:1rem;margin-bottom:1rem}.admissions-school-year-card__title{font-size:1.125rem;font-weight:600;margin:0;color:var(--text-primary, #222)}.admissions-school-year-card__action{background:#fff;border:1px solid var(--border-light, #d1d5db);border-radius:4px;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:var(--text-primary, #222);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:background .15s,border-color .15s}.admissions-school-year-card__action:hover:not(:disabled){background:var(--bg-light, #f5f6f8);border-color:var(--brand-primary, #3949ab)}.admissions-school-year-card__action:disabled{opacity:.5;cursor:not-allowed}.admissions-application-list{list-style:none;margin:0;padding:0}.admissions-application-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-light, #f0f1f3);cursor:pointer;transition:background .15s}.admissions-application-item:hover{background:var(--bg-light, #f9fafb)}.admissions-application-item:last-child{border-bottom:none}.admissions-application-item__name{font-weight:500;color:var(--text-primary, #222)}.admissions-application-item__meta{display:flex;gap:1rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.admissions-application-item__status{text-transform:capitalize;padding:.125rem .5rem;border-radius:999px;background:var(--bg-light, #e5e7eb);font-size:.75rem;font-weight:500}.admissions-application-item__status.draft{background:#fff3cd;color:#92400e}.admissions-application-item__status.submitted,.admissions-application-item__status.under_review{background:#cfe2ff;color:#084298}.admissions-application-item__status.approved{background:#d4edda;color:#14532d}.admissions-application-item__status.rejected,.admissions-application-item__status.waitlisted,.admissions-application-item__status.withdrawn{background:#f8d7da;color:#842029}.admissions-empty-applications{color:var(--text-secondary, #6b7280);font-size:.95rem;text-align:center;padding:1rem 0}.admissions-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.admissions-modal{background:#fff;border-radius:8px;width:100%;max-width:720px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 32px #0003}.admissions-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light, #e5e7eb)}.admissions-modal__title{font-size:1.25rem;font-weight:600;margin:0}.admissions-modal__close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-secondary, #6b7280);cursor:pointer;padding:.25rem .5rem}.admissions-modal__close:hover:not(:disabled){color:var(--text-primary, #222)}.admissions-modal__body{padding:1.5rem;overflow-y:auto}.admissions-modal__hint{color:var(--text-secondary, #6b7280);font-size:.9rem;margin:0 0 1.5rem}.admissions-modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light, #e5e7eb)}.admissions-modal__cancel{background:none;border:none;color:var(--text-secondary, #6b7280);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;padding:.5rem 1rem}.admissions-modal__cancel:hover:not(:disabled){color:var(--text-primary, #222)}.admissions-modal select{width:100%;padding:.6rem .75rem;font-size:1rem;border:1px solid var(--border-light, #d1d5db);border-radius:4px;background:#fff;box-sizing:border-box}.admissions-wizard{width:100%;max-width:960px}.admissions-wizard__breadcrumb{font-size:1.25rem;font-weight:600;color:var(--text-primary, #222);margin:0 0 1rem;padding:0 1.5rem}.admissions-wizard__card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;padding:2rem}.admissions-stepper{list-style:none;margin:0;padding:0;position:relative}.admissions-stepper:before{content:"";position:absolute;left:18px;top:18px;bottom:18px;width:2px;background:var(--border-light, #e5e7eb)}.admissions-stepper__item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 0;position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.admissions-stepper__item--locked{cursor:default}.admissions-stepper__bullet{width:36px;height:36px;border-radius:50%;background:var(--bg-light, #e5e7eb);color:var(--text-secondary, #6b7280);display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;z-index:1;flex-shrink:0;transition:background .15s,color .15s}.admissions-stepper__item--active .admissions-stepper__bullet{background:var(--brand-primary, #3949ab);color:#fff}.admissions-stepper__item--complete .admissions-stepper__bullet{background:#d4edda;color:#14532d}.admissions-stepper__title{font-size:1rem;color:var(--text-secondary, #6b7280);flex:1;padding-top:.5rem;font-weight:500}.admissions-stepper__item--active .admissions-stepper__title{color:var(--brand-primary, #3949ab);font-weight:600}.admissions-stepper__item--complete .admissions-stepper__title{color:var(--text-primary, #222)}.admissions-stepper__body{flex:1;padding-top:.5rem}.admissions-stepper__body p{color:var(--text-primary, #444);font-size:.95rem;line-height:1.55;white-space:pre-wrap;margin:0 0 1.5rem}.admissions-stepper__actions{display:flex;justify-content:flex-end;gap:1rem}.admissions-stepper__action{background:none;border:none;color:var(--brand-primary, #3949ab);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;padding:.5rem 1rem;border-radius:4px}.admissions-stepper__action:hover:not(:disabled){background:#3949ab14}.admissions-stepper__action:disabled{opacity:.5;cursor:not-allowed}.admissions-stepper__action--ghost{color:var(--text-secondary, #6b7280)}.admissions-stepper__placeholder{background:var(--bg-light, #f5f6f8);border:1px dashed var(--border-light, #d1d5db);border-radius:6px;padding:1.5rem;color:var(--text-secondary, #6b7280);text-align:center;font-size:.95rem;margin-top:.5rem}.dashboard-container{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.dashboard-header p{color:var(--text-secondary);font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-blue-light) 0%,var(--primary-blue) 100%);border-radius:12px;box-shadow:0 4px 12px #3d81de33}.stat-content h3{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.stat-content p{color:var(--text-secondary);font-size:.875rem;margin:0}.section{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);margin-bottom:2rem;border:1px solid var(--border-light)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.schools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.school-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.school-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-blue)}.school-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.school-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.school-details{margin:1rem 0}.school-details p{margin:.5rem 0;font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.school-stats{display:flex;gap:2rem;margin:1rem 0;padding-top:1rem;border-top:1px solid var(--border-light)}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-blue)}.stat-label{font-size:.75rem;color:var(--text-muted)}.school-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.form-card{background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.form-card h3{margin-bottom:1rem;color:var(--text-primary)}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background-color:var(--bg-gray-50)}.data-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-light)}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light)}.data-table tbody tr:hover{background-color:var(--bg-gray-50)}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-blue-light) 0%,var(--primary-blue) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;box-shadow:0 2px 8px #3d81de33}.classes-grid{display:flex;flex-direction:column;gap:1rem}.class-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1rem;transition:all .2s;box-shadow:var(--shadow-sm)}.class-card:hover{border-color:var(--primary-blue);box-shadow:var(--shadow-md)}.class-card.selected{border-color:var(--primary-blue);background-color:#e0f2fe;box-shadow:var(--shadow-lg)}.class-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem}.class-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.class-code{font-size:.75rem;padding:.25rem .5rem;background-color:var(--bg-gray-100);color:var(--text-primary);border-radius:4px;font-weight:500}.class-body p{margin:.5rem 0;font-size:.875rem;color:var(--text-secondary)}.class-footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.categories-container{display:flex;flex-direction:column;gap:1rem}.category-section{background:transparent;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:2rem}.category-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:linear-gradient(135deg,var(--primary-blue) 0%,#2563eb 100%);color:#fff;cursor:pointer;transition:all .2s;border-radius:var(--radius-md);margin-bottom:1rem}.category-header:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.category-header h3{color:#fff;margin:0}.category-header .class-count{color:#fffc}.category-header.uncategorized{background:linear-gradient(135deg,#64748b,#475569)}.category-header.uncategorized:hover{background:linear-gradient(135deg,#475569,#334155)}.category-info{display:flex;align-items:center;gap:.75rem}.category-info h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.class-count{font-size:.875rem;color:var(--text-secondary)}.expand-icon{font-size:.75rem;color:#fff;transition:transform .2s;display:inline-block}.category-actions{display:flex;gap:.5rem}.category-actions .btn-small{background:#fff!important;border:none!important;color:var(--primary-blue)!important;padding:.4rem .85rem;font-size:.8rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001a}.category-actions .btn-small:hover{background:#f0f0f0!important;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.category-actions .btn-danger{color:#dc2626!important}.category-actions .btn-danger:hover{background:#fee2e2!important}.category-classes{padding:0}.empty-category{color:var(--text-secondary);font-style:italic;padding:1rem;margin:0;background:var(--bg-gray-50);border-radius:var(--radius-md)}.class-card-new{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1rem;width:100%}.class-card-top{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--bg-gray-50);border-bottom:1px solid var(--border-light);gap:1rem;flex-wrap:wrap}.class-info{flex-shrink:0}.class-info h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.class-meta{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary)}.class-all-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .85rem;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap}.action-btn:hover{background:var(--bg-gray-100);border-color:var(--primary-blue);color:var(--primary-blue)}.action-icon{font-size:.95rem}.action-label{font-weight:500}.icon-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;color:var(--text-secondary)}.icon-btn:hover{background:var(--bg-gray-100);border-color:var(--primary-blue);color:var(--primary-blue)}.icon-btn.danger:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.icon-btn svg{flex-shrink:0}.class-card-body{padding:1rem 1.25rem}.class-details{display:flex;flex-wrap:wrap;gap:1.5rem}.detail-item{font-size:.875rem;color:var(--text-secondary)}.detail-item strong{color:var(--text-primary)}@media(max-width:768px){.class-card-top{flex-direction:column;align-items:flex-start}.class-all-actions{width:100%}.action-label{display:none}}.tab{padding:.75rem 1.5rem;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;font-family:inherit}.filters-bar{margin-bottom:1.5rem;padding:1rem;background-color:var(--bg-gray-50);border-radius:var(--radius-md);display:flex;gap:1rem;align-items:center;border:1px solid var(--border-light)}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{margin:0;font-size:.875rem;color:var(--text-primary);font-weight:500}.filter-select{padding:.5rem;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.875rem;min-width:200px;background:#fff;transition:border-color .2s ease}.filter-select:focus{outline:none;border-color:var(--primary-blue)}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.schools-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:start;gap:1rem}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}.table-container{font-size:.75rem}.data-table th,.data-table td{padding:.5rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.item-type-badge{display:inline-block;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.item-type-badge.assignment{background-color:#dbeafe;color:#1e40af}.item-type-badge.quiz{background-color:#fce7f3;color:#9d174d}.assignment-title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.assignment-title-row h3{margin:0}.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem}.action-card{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-family:inherit;font-size:.875rem}.action-card:hover{background:#fff;border-color:var(--primary-blue);box-shadow:var(--shadow-sm)}.assignments-preview{display:flex;flex-direction:column;gap:.75rem}.assignment-preview-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.assignment-preview-card:hover{background:#fff;border-color:var(--primary-blue);box-shadow:var(--shadow-sm)}.assignment-info h3{font-size:1rem;font-weight:600;margin:0 0 .25rem}.assignment-info .class-name{font-size:.875rem;color:var(--text-secondary);margin:0}.assignment-meta{display:flex;align-items:center;gap:1rem;text-align:right}.assignment-meta .due-date{font-size:.875rem;color:var(--text-secondary)}.assignment-meta .due-date.overdue{color:var(--status-danger);font-weight:500}.assignment-meta .points{font-size:.875rem;font-weight:600;color:var(--text-primary)}.grades-preview{display:flex;flex-direction:column;gap:.75rem}.grade-preview-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md)}.grade-info h3{font-size:1rem;font-weight:600;margin:0 0 .25rem}.grade-info .class-name{font-size:.875rem;color:var(--text-secondary);margin:0}.grade-value{text-align:right}.grade-value .grade-score{display:block;font-size:1.125rem;font-weight:700;color:var(--primary-blue)}.grade-value .grade-percentage{font-size:.875rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}.text-danger{color:var(--status-danger)!important}.btn-link{background:none;border:none;color:var(--primary-blue);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;font-family:inherit}.report-container .data-table{table-layout:fixed}.report-container .data-table th:nth-child(1),.report-container .data-table td:nth-child(1){width:40%}.report-container .data-table th:nth-child(2),.report-container .data-table td:nth-child(2){width:20%}.report-container .data-table th:nth-child(3),.report-container .data-table td:nth-child(3){width:20%}.report-container .data-table th:nth-child(4),.report-container .data-table td:nth-child(4){width:20%}.admin-dash-layout{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;align-items:start}.admin-dash-main{display:flex;flex-direction:column;gap:1.5rem;min-width:0}.admin-dash-sidebar{display:flex;flex-direction:column;gap:1.5rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.admin-stat-card{border-radius:var(--radius-md);padding:1rem 1.25rem;transition:transform .15s ease,box-shadow .15s ease}.admin-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.admin-stat-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.admin-stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.admin-widget-card{background:#fff;border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--border-light)}.admin-widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.admin-widget-header h3{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin:0}.admin-empty-text{color:var(--text-muted);font-size:.875rem;font-style:italic;padding:.5rem 0}.admin-attendance-list{display:flex;flex-direction:column;gap:.75rem}.admin-attendance-row{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.admin-attendance-class{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:0 0 auto;max-width:140px}.admin-attendance-counts{display:flex;gap:.5rem;flex-shrink:0}.admin-count-present{color:#16a34a;font-size:.8125rem;font-weight:500}.admin-count-absent{color:#dc2626;font-size:.8125rem;font-weight:500}.admin-count-late{color:#d97706;font-size:.8125rem;font-weight:500}.admin-attendance-bar-wrap{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0}.admin-attendance-bar-track{flex:1;height:6px;background:var(--bg-gray-200);border-radius:3px;overflow:hidden;position:relative}.admin-attendance-bar{position:absolute;left:0;top:0;bottom:0;background:#16a34a;border-radius:3px;transition:width .3s ease}.admin-attendance-pct{font-size:.8125rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.admin-notification-list{display:flex;flex-direction:column;gap:.5rem}.admin-notification-item{display:flex;align-items:center;gap:.625rem;padding:.5rem 0;border-bottom:1px solid var(--bg-gray-100);font-size:.875rem}.admin-notification-item:last-child{border-bottom:none}.admin-notif-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;background:var(--bg-gray-100);color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.admin-notif-badge--grade_posted{background:#dbeafe;color:#1e40af}.admin-notif-badge--assignment_published{background:#dcfce7;color:#166534}.admin-notif-badge--quiz_published{background:#fce7f3;color:#9d174d}.admin-notif-badge--due_date_reminder{background:#fef3c7;color:#92400e}.admin-notif-badge--attendance_digest{background:#fef9c3;color:#854d0e}.admin-notif-badge--welcome{background:#e0e7ff;color:#3730a3}.admin-notif-subject{flex:1;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-notif-time{color:var(--text-muted);font-size:.8125rem;white-space:nowrap;flex-shrink:0}.admin-notif-recipient{font-size:.75rem;color:var(--text-muted, #9ca3af);flex-shrink:0;white-space:nowrap}.admin-sub-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.admin-sub-row>.admin-widget-card:only-child{grid-column:1 / -1}.admin-due-list{display:flex;flex-direction:column;gap:.625rem}.admin-due-item{padding:.5rem 0;border-bottom:1px solid var(--bg-gray-100)}.admin-due-item:last-child{border-bottom:none}.admin-due-info{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.admin-due-title{font-size:.875rem;font-weight:500;color:var(--text-primary)}.admin-due-meta{display:flex;gap:.75rem;font-size:.8125rem;color:var(--text-secondary)}.admin-due-date{font-weight:500}.admin-hifz-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.admin-hifz-stat{text-align:center;padding:.75rem .5rem;background:var(--bg-gray-50);border-radius:var(--radius-md)}.admin-hifz-num{display:block;font-size:1.5rem;font-weight:700;color:var(--primary-blue);line-height:1.2}.admin-hifz-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.admin-tuition-summary{display:flex;gap:2rem;margin-bottom:1rem}.admin-tuition-stat{text-align:center;flex:1;padding:.75rem;background:var(--bg-gray-50);border-radius:var(--radius-md)}.admin-tuition-num{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.admin-tuition-amount{color:var(--primary-blue)}.admin-tuition-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.admin-tuition-payments-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.admin-tuition-payments{border-top:1px solid var(--border-light);padding-top:.75rem}.admin-payment-row{display:flex;align-items:center;gap:.75rem;padding:.375rem 0;font-size:.875rem}.admin-payment-payer{flex:1;color:var(--text-primary);font-weight:500}.admin-payment-amount{font-weight:600;color:#16a34a}.admin-payment-date{color:var(--text-muted);font-size:.8125rem}.admin-quick-actions-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.admin-quick-actions{display:flex;flex-direction:column;gap:.5rem}.admin-action-btn{display:block;width:100%;padding:.75rem 1rem;background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:500;color:var(--text-primary);cursor:pointer;text-align:left;transition:all .15s ease}.admin-action-btn:hover{background:#fff;border-color:var(--primary-blue);color:var(--primary-blue);box-shadow:var(--shadow-sm)}.mini-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.mini-cal-title{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.mini-cal-nav{background:none;border:1px solid var(--border-light);border-radius:var(--radius-sm);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.125rem;color:var(--text-secondary);transition:all .15s ease;font-family:inherit;line-height:1}.mini-cal-nav:hover{background:var(--bg-gray-100);border-color:var(--primary-blue);color:var(--primary-blue)}.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;text-align:center}.mini-cal-dow{font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:.25rem 0 .5rem}.mini-cal-cell{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.3rem 0;min-height:32px}.mini-cal-day-num{font-size:.8125rem;font-weight:400;color:var(--text-primary);line-height:1}.mini-cal-today .mini-cal-day-num{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--primary-blue);color:#fff;font-weight:600}.mini-cal-semester{background:#eff6ff}.mini-cal-semester:not(.mini-cal-semester+.mini-cal-semester){border-top-left-radius:4px;border-bottom-left-radius:4px}.mini-cal-dot{display:block;width:4px;height:4px;border-radius:50%;background:#dc2626;margin-top:2px}.mini-cal-upcoming{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.mini-cal-upcoming-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.mini-cal-event-item{display:flex;gap:.5rem;padding:.3rem 0;font-size:.8125rem}.mini-cal-event-date{color:var(--primary-blue);font-weight:600;white-space:nowrap;flex-shrink:0;min-width:3.5rem}.mini-cal-event-name{color:var(--text-primary)}@media(max-width:1100px){.admin-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.admin-dash-layout{grid-template-columns:1fr}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-sub-row{grid-template-columns:1fr}.admin-attendance-row{flex-wrap:wrap}.admin-attendance-class{max-width:none;flex-basis:100%}}@media(max-width:480px){.admin-stats-grid{grid-template-columns:1fr}.admin-notification-item{flex-wrap:wrap;gap:.375rem}.admin-notif-subject{flex-basis:100%;order:3}}.teacher-dash-layout{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;align-items:start;margin-top:1.5rem}.teacher-dash-main{display:flex;flex-direction:column;gap:1.5rem;min-width:0}.teacher-dash-sidebar{display:flex;flex-direction:column;gap:1.5rem}.teacher-section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.teacher-hifz-roster{display:flex;flex-direction:column;gap:0}.teacher-hifz-row{display:flex;align-items:center;gap:1rem;padding:.75rem .5rem;border-bottom:1px solid var(--bg-gray-100);cursor:pointer;transition:background-color .15s ease}.teacher-hifz-row:last-child{border-bottom:none}.teacher-hifz-row:hover{background-color:var(--bg-gray-50)}.teacher-hifz-name{flex:0 0 180px;font-weight:500;color:var(--text-primary);font-size:.875rem;display:flex;align-items:center;gap:.5rem}.teacher-hifz-coverage-badge{display:inline-block;padding:.1rem .4rem;border-radius:8px;font-size:.6875rem;font-weight:600;background:#e0e7ff;color:#3730a3;white-space:nowrap}.teacher-hifz-tracks{display:flex;gap:.375rem;flex-shrink:0}.teacher-hifz-track-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;background:var(--bg-gray-100);color:var(--text-secondary)}.teacher-hifz-track-badge.track-hifz{background:#dbeafe;color:#1e40af}.teacher-hifz-track-badge.track-nazirah{background:#dcfce7;color:#166534}.teacher-hifz-track-badge.track-qaidah{background:#fef3c7;color:#92400e}.teacher-hifz-entries{display:flex;flex-wrap:wrap;gap:.25rem;flex:1;min-width:0}.teacher-hifz-entry-dot{display:inline-block;padding:.1rem .4rem;border-radius:8px;font-size:.6875rem;font-weight:500;white-space:nowrap}.teacher-hifz-entry-dot.logged{background:#dcfce7;color:#166534}.teacher-hifz-entry-dot.missing{background:#fef2f2;color:#991b1b}.teacher-hifz-status{flex-shrink:0;display:inline-block;padding:.2rem .625rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.teacher-hifz-status.complete{background:#dcfce7;color:#166534}.teacher-hifz-status.partial{background:#fffbeb;color:#92400e}.teacher-hifz-status.missing{background:#fef2f2;color:#991b1b}.teacher-quick-actions{display:flex;gap:.75rem;flex-wrap:wrap}.teacher-quick-actions .admin-action-btn{flex:0 0 auto;width:auto;display:inline-block}.teacher-schedule-list{display:flex;flex-direction:column;gap:0}.teacher-schedule-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 0;border-bottom:1px solid var(--bg-gray-100);cursor:pointer;transition:background-color .15s ease}.teacher-schedule-item:last-child{border-bottom:none}.teacher-schedule-item:hover{background-color:var(--bg-gray-50)}.teacher-schedule-time{flex-shrink:0;font-size:.8125rem;font-weight:600;color:var(--primary-blue);min-width:6rem;white-space:nowrap}.teacher-schedule-details{flex:1;min-width:0}.teacher-schedule-class{font-size:.875rem;font-weight:500;color:var(--text-primary)}.teacher-schedule-meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--text-secondary)}.teacher-attendance-badge{flex-shrink:0;display:inline-block;padding:.2rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;white-space:nowrap}.teacher-attendance-badge.taken{background:#dcfce7;color:#166534}.teacher-attendance-badge.pending{background:#fef3c7;color:#92400e}@media(max-width:900px){.teacher-dash-layout{grid-template-columns:1fr}}@media(max-width:768px){.teacher-hifz-row{flex-wrap:wrap;gap:.5rem}.teacher-hifz-name{flex:1 1 100%}.teacher-hifz-entries{flex-basis:100%}}.parent-dash-layout{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;align-items:start;margin-top:1.5rem}.parent-dash-main{display:flex;flex-direction:column;gap:1.5rem;min-width:0}.parent-dash-sidebar{display:flex;flex-direction:column;gap:1.5rem}.parent-grades-list{display:flex;flex-direction:column;gap:0}.parent-grade-row{display:flex;align-items:center;justify-content:space-between;padding:.625rem 0;border-bottom:1px solid var(--bg-gray-100)}.parent-grade-row:last-child{border-bottom:none}.parent-grade-info{display:flex;align-items:center;gap:.5rem;min-width:0}.parent-grade-title{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.parent-grade-score{display:flex;align-items:baseline;gap:.5rem;flex-shrink:0}.parent-grade-points{font-size:.9375rem;font-weight:700}.parent-grade-pct{font-size:.8125rem;font-weight:500;opacity:.75}.parent-attendance-rate{text-align:center;padding:1.25rem 0 1rem}.parent-attendance-pct{display:block;font-size:2.5rem;font-weight:700;color:var(--primary-blue);line-height:1.1}.parent-attendance-label{display:block;font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.parent-attendance-breakdown{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-light)}.parent-att-stat{text-align:center}.parent-att-count{display:block;font-size:1.25rem;font-weight:700;line-height:1.2}.parent-att-label{display:block;font-size:.6875rem;color:var(--text-secondary);margin-top:.125rem}@media(max-width:900px){.parent-dash-layout{grid-template-columns:1fr}}@media(max-width:480px){.parent-attendance-breakdown{grid-template-columns:repeat(2,1fr)}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#e9ecef 25%,#f1f3f5,#e9ecef 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm, 6px)}.skeleton-text{height:16px;margin-bottom:8px;width:100%}.skeleton-title{height:24px;margin-bottom:12px;width:60%}.skeleton-card{height:120px;border-radius:var(--radius-lg, 12px)}.skeleton-circle{border-radius:50%;width:40px;height:40px}.skeleton-rect{height:40px;width:100%}.skeleton-dashboard{padding:0}.skeleton-header{margin-bottom:24px}.skeleton-stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.skeleton-stat-card{background:#fff;border-radius:var(--radius-lg, 12px);padding:20px;border:1px solid var(--border-light, #e2e8f0);display:flex;flex-direction:column;gap:8px}.skeleton-content-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.skeleton-card-large{background:#fff;border-radius:var(--radius-lg, 12px);padding:24px;border:1px solid var(--border-light, #e2e8f0)}.skeleton-class-detail{padding:0}.skeleton-tabs{display:flex;gap:8px;margin:20px 0}.skeleton-table{display:flex;flex-direction:column;gap:2px}.skeleton-gradebook{padding:0}.skeleton-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.skeleton-toolbar-actions{display:flex;gap:8px}.skeleton-category-cards{display:flex;flex-direction:column;gap:20px}.skeleton-category-card{background:#fff;border-radius:var(--radius-lg, 12px);padding:24px;border:1px solid var(--border-light, #e2e8f0);display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.skeleton-content-row{grid-template-columns:1fr}.skeleton-stats-row{grid-template-columns:repeat(2,1fr)}}.child-selector{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--card-bg, #fff);border-radius:8px;border:1px solid var(--border-light);margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.child-selector label{font-weight:500;color:var(--text-secondary);margin:0}.child-selector select{flex:1;max-width:300px;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem;cursor:pointer}.child-selector select:focus{outline:none;border-color:var(--primary-color)}.child-selector.loading,.child-selector.empty{color:var(--text-muted);font-style:italic}@media(max-width:768px){.child-selector{flex-direction:column;align-items:flex-start;gap:.5rem}.child-selector select{width:100%;max-width:none}}.school-detail-container{max-width:1200px;margin:0 auto}.detail-header{margin-bottom:2rem}.btn-back{background:#fff;border:1px solid var(--border-light);color:var(--text-secondary);font-size:.9375rem;font-weight:500;cursor:pointer;margin-bottom:1rem;padding:.5rem 1rem;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s;border-radius:var(--radius-md)}.btn-back:hover{color:var(--primary-blue);background:var(--bg-gray-50);transform:translate(-4px)}.header-content h1{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.school-subtitle{color:var(--text-secondary);font-size:1rem}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.info-card{background:#fff;padding:1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.5rem;border:1px solid var(--border-light)}.info-card strong{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.info-card span{font-size:.9375rem;color:var(--text-primary)}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-light)}.tab{padding:.75rem 1.5rem;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.tab:hover{color:var(--primary-blue)}.tab.active{color:var(--primary-blue);border-bottom-color:var(--primary-blue)}.tab-content{background:#fff;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-card);border:1px solid var(--border-light)}.tab-content h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.overview-tab .stats-grid{margin-bottom:3rem}.recent-classes{display:grid;gap:1rem}.class-item{padding:1rem;border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all .2s}.class-item:hover{border-color:var(--primary-blue);background-color:var(--bg-gray-50)}.class-item h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.class-item p{margin:.25rem 0;font-size:.875rem;color:var(--text-secondary)}.users-tab .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.classes-tab .classes-grid{margin-top:1.5rem}.edit-school-section .form-group{margin-bottom:1rem}.edit-school-section .form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.edit-school-section .form-group input[type=text],.edit-school-section .form-group input[type=email],.edit-school-section .form-group input[type=number]{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:var(--radius-md, 6px);font-size:.9375rem;transition:border-color .2s;box-sizing:border-box}.edit-school-section .form-group input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3b82f61a}.email-tab .section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.email-tab .section-header h2{margin:0}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.btn-secondary{background:#fff;border:1px solid var(--border-color, #d1d5db);color:var(--text-primary, #374151);padding:.625rem 1.25rem;border-radius:var(--radius-md, 6px);cursor:pointer;font-weight:500;transition:all .2s}.btn-secondary:hover{background:var(--bg-gray-50, #f9fafb);border-color:var(--border-dark, #9ca3af)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:#dc3545;border:none;color:#fff;padding:.625rem 1.25rem;border-radius:var(--radius-md, 6px);cursor:pointer;font-weight:500;transition:all .2s}.btn-danger:hover{background:#c82333}code{background:var(--bg-gray-100, #f3f4f6);padding:.125rem .375rem;border-radius:4px;font-family:monospace;font-size:.875rem}@media(max-width:768px){.header-content h1{font-size:1.75rem}.info-cards{grid-template-columns:repeat(2,1fr)}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}.tab-content{padding:1.5rem}.email-tab .form-row,.edit-school-section .form-row{grid-template-columns:1fr!important}}@media(max-width:480px){.info-cards{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;overflow-y:auto;width:600px;max-width:95vw}.modal-small{width:400px}.modal-medium{width:550px}.modal-large{width:700px}.modal-form{padding:20px}.modal-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-form .form-group{margin-bottom:1rem}.modal-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500}.modal-form .form-group input,.modal-form .form-group select,.modal-form .form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.modal-form .form-group input:focus,.modal-form .form-group select:focus,.modal-form .form-group textarea:focus{outline:none;border-color:var(--primary, #4a90d9);box-shadow:0 0 0 2px #4a90d91a}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:16px 20px;border-top:1px solid #e0e0e0;margin-top:1rem}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.25rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.modal-close:hover{color:#333}.modal-body{padding:20px}.days-selector{display:flex;gap:8px;flex-wrap:wrap}.day-btn{width:40px;height:40px;border:2px solid #e5e7eb;border-radius:50%;background:#fff;cursor:pointer;font-size:13px;font-weight:500;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.day-btn:hover{border-color:#3b82f6;color:#3b82f6}.day-btn.selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.day-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-switch{position:relative;width:44px;height:24px;background:var(--bg-gray-200, #d1d5db);border:none;border-radius:12px;cursor:pointer;transition:background .2s;padding:0;flex-shrink:0}.toggle-switch.active{background:var(--success-green, #16a34a)}.toggle-switch.active:after{transform:translate(20px)}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.am-toolbar{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.75rem}.am-toolbar-left{display:flex;align-items:flex-end;gap:.75rem}.am-toolbar .form-group{margin:0;min-width:200px}.am-toolbar .form-group label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.03em}.am-toolbar .form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--border-gray);border-radius:var(--radius-md);font-size:.9375rem;background:#fff}.dropdown-menu-container{position:relative;display:inline-flex}.dropdown-trigger{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:none;border:1px solid transparent;border-radius:50%;cursor:pointer;color:var(--text-secondary);font-size:1.25rem;font-family:inherit;line-height:1;transition:all .15s}.dropdown-trigger:hover{background:#dbeafe;border-color:#3b82f6;color:#3b82f6}.dropdown-trigger-gear{color:var(--text-secondary)}.dropdown-trigger-gear:hover{color:var(--primary-blue)}.dropdown-trigger-gear svg{width:18px;height:18px}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:180px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001a,0 1px 3px #0000000f;z-index:100;padding:4px 0;animation:dropdown-fade .12s ease-out}.dropdown-menu-left{right:auto;left:0}@keyframes dropdown-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:block;width:100%;padding:.5rem .875rem;background:none;border:none;text-align:left;font-size:.875rem;font-family:inherit;color:var(--text-primary);cursor:pointer;transition:background .1s;white-space:nowrap}.dropdown-item:hover{background:var(--bg-gray-50)}.dropdown-item.danger{color:#dc2626}.dropdown-item.danger:hover{background:#fef2f2}.dropdown-divider{height:1px;margin:4px 0;background:var(--border-light)}.am-tabs{display:flex;flex-wrap:wrap;gap:0;margin-bottom:1.75rem;border-bottom:2px solid var(--border-light);align-items:stretch}.am-tab{padding:.7rem 1.25rem;background:none;border:none;font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;font-family:inherit;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:.5rem}.am-tab:hover{color:var(--primary-blue)}.am-tab.active{color:var(--primary-blue);border-bottom-color:var(--primary-blue);font-weight:600}.am-tab .tab-badge{display:inline-block;font-size:.7rem;padding:.1rem .45rem;border-radius:10px;font-weight:600}.am-tab .tab-badge.active-badge{background:#dcfce7;color:#166534}.am-tab .tab-badge.count-badge{background:var(--bg-gray-200);color:var(--text-secondary)}.am-tab-add-semester{color:var(--primary-blue)!important;font-weight:500;font-size:.85rem!important;opacity:.7;border-bottom:3px solid transparent!important;padding:.7rem .85rem!important}.am-tab-add-semester:hover{opacity:1;background:#f0f7ff;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.am-tab-add-semester .am-tab-name{font-size:.85rem}.am-tab-semester{flex-direction:column;align-items:flex-start;justify-content:center;gap:.15rem;padding:.55rem 1.1rem}.am-tab-name{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:500;line-height:1.2}.am-tab.active .am-tab-name{font-weight:600}.am-tab-dates{font-size:.72rem;color:var(--text-muted);font-weight:400;line-height:1.2}.am-tab.active .am-tab-dates{color:var(--text-secondary)}.am-tab-menu{display:inline-flex;align-items:center;margin-left:.25rem}.am-tab-menu .dropdown-trigger{width:28px;height:28px;font-size:1.25rem;color:var(--text-secondary);border:1px solid var(--border-gray);border-radius:50%;background:#00000008}.am-tab-menu .dropdown-trigger:hover{background:#dbeafe;color:#3b82f6;border-color:#3b82f6}.am-setup-prompt{text-align:center;padding:3rem 2rem;background:#fff;border:2px dashed var(--border-gray);border-radius:var(--radius-lg);margin-bottom:2rem}.am-setup-prompt h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem}.am-setup-prompt p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9375rem}.am-classes-toolbar{display:flex;justify-content:flex-end;margin-bottom:1rem}.btn-sm{padding:.4rem .85rem!important;font-size:.85rem!important}.categories-container{display:flex;flex-direction:column;gap:1.5rem}.am-category-section{margin-bottom:0}.am-category-header{display:flex;justify-content:space-between;align-items:center;padding:.55rem .75rem;cursor:pointer;background:#f1f5f9;border-left:3px solid #94a3b8;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:.75rem;transition:all .15s}.am-category-header:hover{background:#e8eef5;border-left-color:var(--primary-blue)}.am-category-header .cat-left{display:flex;align-items:center;gap:.6rem}.am-category-header .cat-left h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.am-category-header .cat-left .expand-icon{font-size:.6rem;color:var(--text-muted);transition:transform .2s;display:inline-block}.am-category-header .cat-left .expand-icon.expanded{transform:rotate(90deg)}.am-category-header .cat-count{font-size:.8rem;color:var(--text-muted);font-weight:400}.am-category-header .cat-right{display:flex;gap:.5rem}.am-category-header .cat-right .dropdown-menu-container{opacity:1}.am-category-header.uncategorized .cat-left h3{color:var(--text-secondary);font-style:italic}.am-category-body{padding:0 0 .5rem}.am-category-empty{color:var(--text-muted);font-style:italic;padding:.75rem 0;margin:0;font-size:.875rem}.class-card-clean{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:.875rem 1rem;cursor:pointer;transition:all .15s;margin-bottom:.5rem}.class-card-clean:hover{border-color:var(--primary-blue);box-shadow:0 1px 4px #0000000f}.class-card-main{display:flex;justify-content:space-between;align-items:center;gap:1rem}.class-card-info h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary);line-height:1.3}.class-card-info .class-meta{margin:.2rem 0 0;font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.class-code-tag{font-size:.7rem;font-weight:600;padding:.1rem .4rem;background:var(--bg-gray-100);border-radius:3px;color:var(--text-secondary);margin-right:.2rem}.meta-separator{color:var(--text-muted);font-size:.6rem}.class-card-actions{display:flex;align-items:center;gap:.25rem;opacity:1;flex-shrink:0}.class-action-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .15s}.class-action-icon:hover{background:var(--bg-gray-50);border-color:var(--border-light);color:var(--primary-blue)}.class-card-details{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-light);display:flex;gap:.75rem;flex-wrap:wrap}.detail-tag{font-size:.75rem;color:var(--text-muted);padding:.15rem .5rem;background:var(--bg-gray-50);border-radius:3px}.am-courses-section{margin-bottom:.5rem}.am-courses-section-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .15rem}.am-courses-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.am-courses-panel-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.am-courses-table-wrap{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:visible}.am-courses-table{width:100%;border-collapse:collapse;font-size:.875rem}.am-courses-table thead{background:var(--bg-gray-50)}.am-courses-table th{padding:.6rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border-light)}.am-courses-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border-light);color:var(--text-primary)}.am-courses-table tbody tr:last-child td{border-bottom:none}.am-courses-table tbody tr:hover{background:var(--bg-gray-50)}.am-course-code-cell{font-size:.8rem;font-weight:600;padding:.15rem .45rem;background:var(--bg-gray-100);border-radius:3px;color:var(--text-primary)}.am-course-name-cell{font-weight:500}.am-course-cat-cell{color:var(--text-secondary);font-size:.85rem}.am-course-schedule-cell{font-size:.85rem;color:var(--text-secondary)}.am-course-count-cell{font-size:.85rem;color:var(--text-muted)}.am-course-action-cell{text-align:right;width:48px}.am-holidays-panel-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.am-holidays-table-wrap{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:visible}.modal-content.modal-wizard{width:750px}.am-wizard-course-list{display:flex;flex-direction:column;gap:1rem;max-height:50vh;overflow-y:auto;padding:.5rem 0}.am-wizard-course{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1rem;transition:border-color .2s}.am-wizard-course.selected{border-color:var(--primary-blue);background:#f0f7ff}.am-wizard-course-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.am-wizard-course-header input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-blue)}.am-wizard-course-header .course-label{font-weight:600;flex:1}.am-wizard-course-header .no-prev{font-size:.8rem;color:var(--text-muted);font-style:italic}.am-wizard-course-fields{margin-left:2rem;display:flex;flex-direction:column;gap:.75rem}.am-wizard-course-fields .form-group{margin:0}.am-wizard-course-fields .form-group label{font-size:.8rem;font-weight:500}.am-wizard-course-fields .form-group select,.am-wizard-course-fields .form-group input{padding:.4rem .6rem;font-size:.875rem}.am-wizard-carryover{margin-top:.5rem;padding:.75rem;background:var(--bg-gray-50);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.am-wizard-carryover-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;color:var(--text-secondary)}.am-wizard-carryover-options{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.75rem;padding-left:1.5rem}.am-wizard-carryover-options label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;cursor:pointer;color:var(--text-secondary)}.am-empty-welcome{text-align:center;padding:4rem 2rem;max-width:500px;margin:2rem auto}.am-empty-welcome .welcome-icon{font-size:3rem;margin-bottom:1rem}.am-empty-welcome h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:.75rem}.am-empty-welcome p{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}@media(max-width:768px){.am-toolbar{flex-direction:column;align-items:stretch}.am-toolbar-left{flex-wrap:wrap}.am-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.am-courses-table-wrap,.am-holidays-table-wrap{overflow-x:auto}.modal-content.modal-wizard{width:95vw}.class-card-main{flex-wrap:wrap}}.ai-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1100}.ai-modal{background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgba(0, 0, 0, .1));width:720px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.ai-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0);flex-shrink:0}.ai-modal-header h2{font-size:1.2rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.ai-modal-resource-name{font-size:.825rem;color:var(--text-secondary, #64748b);margin-top:.2rem}.ai-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted, #94a3b8);cursor:pointer;padding:.25rem;line-height:1;transition:color .15s ease;flex-shrink:0}.ai-modal-close:hover{color:var(--text-primary, #1f2937)}.ai-modal-warning{padding:.65rem 1.5rem;background:#fef3c7;color:#92400e;font-size:.85rem;border-bottom:1px solid #fde68a;flex-shrink:0}.ai-step-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-gray-50, #f8f9fa);border-bottom:1px solid var(--border-color, #e2e8f0);flex-shrink:0}.ai-step{font-size:.8rem;font-weight:500;color:var(--text-muted, #94a3b8);padding:.25rem .65rem;border-radius:12px;transition:all .2s ease}.ai-step.active{color:var(--primary-blue, #3D81DE);background:#e8f0fe;font-weight:600}.ai-step.done{color:#10b981}.ai-step-arrow{color:var(--text-muted, #94a3b8);font-size:.75rem}.ai-modal-body{padding:1.5rem;overflow-y:auto;flex:1;position:relative}.ai-mode-selection{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.ai-mode-card{border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);padding:1.25rem;cursor:pointer;text-align:center;transition:all .15s ease}.ai-mode-card:hover{border-color:var(--primary-blue, #3D81DE);box-shadow:0 2px 8px #3d81de1f;transform:translateY(-2px)}.ai-mode-icon{margin-bottom:.75rem}.ai-mode-card h3{font-size:.95rem;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:.4rem}.ai-mode-card p{font-size:.8rem;color:var(--text-secondary, #64748b);line-height:1.45;margin:0}.ai-config-form{max-width:560px;margin:0 auto}.ai-form-group{margin-bottom:1rem}.ai-form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-primary, #1f2937);margin-bottom:.35rem}.ai-form-group input[type=text],.ai-form-group input[type=number],.ai-form-group input[type=date],.ai-form-group input[type=datetime-local],.ai-form-group select,.ai-form-group textarea{width:100%;padding:.5rem .7rem;font-size:.875rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);background:#fff;color:var(--text-primary, #1f2937);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.ai-form-group input:focus,.ai-form-group select:focus,.ai-form-group textarea:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 2px #3d81de26}.ai-form-group textarea{resize:vertical;min-height:80px}.ai-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.ai-form-hint{font-size:.78rem;color:var(--text-muted, #94a3b8);margin:4px 0 .75rem}.ai-toggle-group{display:flex;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);overflow:hidden}.ai-toggle-btn{flex:1;padding:.5rem .75rem;font-size:.85rem;font-weight:500;border:none;background:#fff;color:var(--text-secondary, #64748b);cursor:pointer;transition:all .15s ease}.ai-toggle-btn:not(:last-child){border-right:1px solid var(--border-color, #e2e8f0)}.ai-toggle-btn.active{background:var(--primary-blue, #3D81DE);color:#fff}.ai-toggle-btn:hover:not(.active){background:var(--bg-gray-50, #f8f9fa)}.ai-form-actions{display:flex;justify-content:space-between;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-color, #e2e8f0)}.ai-loading-overlay{position:absolute;inset:0;background:#ffffffeb;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:0 0 var(--radius-lg, 12px) var(--radius-lg, 12px)}.ai-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color, #e2e8f0);border-top-color:var(--primary-blue, #3D81DE);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.ai-loading-overlay p{font-size:.95rem;color:var(--text-primary, #1f2937);font-weight:500}.ai-loading-hint{font-size:.8rem!important;color:var(--text-muted, #94a3b8)!important;font-weight:400!important;margin-top:.25rem}.ai-result-section h3{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:.5rem}.ai-result-title{font-size:1rem;font-weight:600;color:var(--primary-blue, #3D81DE);margin-bottom:.25rem}.ai-result-description{font-size:.875rem;color:var(--text-secondary, #64748b);margin-bottom:1rem;line-height:1.5}.ai-questions-preview{max-height:350px;overflow-y:auto;margin-bottom:1rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);padding:.75rem}.ai-question-item{padding:.6rem 0;border-bottom:1px solid var(--border-color, #e2e8f0)}.ai-question-item:last-child{border-bottom:none}.ai-question-header{font-size:.875rem;color:var(--text-primary, #1f2937);margin-bottom:.35rem;line-height:1.4}.ai-question-points{font-size:.75rem;color:var(--text-muted, #94a3b8);margin-left:.5rem}.ai-question-options{list-style:none;margin:.35rem 0 0 1rem;padding:0}.ai-question-options li{font-size:.825rem;color:var(--text-secondary, #64748b);padding:.15rem 0}.ai-question-options li.correct{color:#10b981;font-weight:500}.ai-correct-badge{display:inline-block;font-size:.7rem;background:#d1fae5;color:#065f46;padding:.1rem .4rem;border-radius:4px;margin-left:.4rem;font-weight:600}.ai-question-explanation{font-size:.78rem;color:var(--text-muted, #94a3b8);font-style:italic;margin-top:.2rem;margin-left:1rem}.ai-question-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}.ai-edit-question-input{width:100%;padding:.4rem .6rem;font-size:.85rem;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;background:#fff;font-family:inherit;color:var(--text-primary, #1f2937);margin-bottom:.4rem}.ai-edit-question-input:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 1px #3d81de26}.ai-edit-options{display:flex;flex-direction:column;gap:.3rem;margin-left:.5rem}.ai-edit-option-row{display:flex;align-items:center;gap:.4rem}.ai-edit-option-radio{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:var(--text-secondary, #64748b);cursor:pointer;white-space:nowrap;min-width:36px}.ai-edit-option-radio.correct{color:#10b981;font-weight:600}.ai-edit-option-radio input[type=radio]{width:14px;height:14px;cursor:pointer;accent-color:#10b981}.ai-edit-option-input{flex:1;padding:.3rem .5rem;font-size:.825rem;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;background:#fff;font-family:inherit;color:var(--text-primary, #1f2937)}.ai-edit-option-input:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 1px #3d81de26}.ai-success-banner{display:flex;gap:.75rem;align-items:flex-start;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md, 8px);padding:1rem 1.25rem;margin-bottom:1rem}.ai-success-banner h3{font-size:.95rem;color:#065f46;margin-bottom:.25rem}.ai-success-banner p{font-size:.825rem;color:#047857;margin:0}.ai-skipped-dates{font-size:.78rem!important;color:#92400e!important;margin-top:.25rem!important}.ai-result-actions{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #e2e8f0)}.ai-plans-table{max-height:350px;overflow-y:auto;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);margin-bottom:.5rem}.ai-plans-table table{width:100%;border-collapse:collapse}.ai-plans-table thead{position:sticky;top:0;z-index:1}.ai-plans-table th{background:var(--bg-gray-50, #f8f9fa);font-size:.78rem;font-weight:600;color:var(--text-secondary, #64748b);text-align:left;padding:.5rem .6rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.ai-plans-table td{padding:.35rem .4rem;border-bottom:1px solid var(--border-color, #e2e8f0);vertical-align:top}.ai-plan-date-input,.ai-plan-topic-input,.ai-plan-desc-input{width:100%;padding:.35rem .5rem;font-size:.825rem;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;background:#fff;font-family:inherit;color:var(--text-primary, #1f2937)}.ai-plan-date-input:focus,.ai-plan-topic-input:focus,.ai-plan-desc-input:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 1px #3d81de26}.ai-plan-desc-input{resize:vertical;min-height:40px}.ai-plan-remove-btn{background:none;border:none;font-size:1.2rem;color:var(--text-muted, #94a3b8);cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:color .15s ease,background .15s ease}.ai-plan-remove-btn:hover{color:var(--error, #ef4444);background:#fef2f2}.ai-empty-plans{text-align:center;padding:1.5rem;color:var(--text-muted, #94a3b8);font-size:.9rem}.ai-raw-response{background:var(--bg-gray-50, #f8f9fa);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);padding:.75rem;font-size:.8rem;font-family:monospace;max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.ai-btn-back{padding:.5rem 1rem;font-size:.85rem;font-weight:500;color:var(--text-secondary, #64748b);background:#fff;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease}.ai-btn-back:hover{background:var(--bg-gray-50, #f8f9fa);border-color:var(--border-gray, #cbd5e1)}.ai-btn-back:disabled{opacity:.5;cursor:not-allowed}.ai-btn-generate{padding:.5rem 1.5rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--primary-blue, #3D81DE);border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.ai-btn-generate:hover{background:var(--primary-hover, #2a5ba8)}.ai-btn-generate:disabled{opacity:.6;cursor:not-allowed}.ai-btn-download{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#dc2626;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.ai-btn-download:hover{background:#b91c1c}.ai-btn-download-alt{background:#1a3a52}.ai-btn-download-alt:hover{background:#15304a}.ai-btn-navigate{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.ai-btn-navigate:hover{background:#059669}.ai-btn-commit{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#f59e0b;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.ai-btn-commit:hover{background:#d97706}.ai-btn-commit:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.ai-modal{width:98vw;max-height:95vh}.ai-mode-selection,.ai-form-row{grid-template-columns:1fr}.ai-plans-table{max-height:250px}.ai-step-indicator{font-size:.75rem;gap:.3rem}}@media(max-width:480px){.ai-modal-header,.ai-modal-body{padding:1rem}.ai-questions-preview{max-height:250px}}.class-ai-tab{padding:.5rem 0}.class-ai-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.class-ai-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 .25rem}.class-ai-header p{font-size:.85rem;color:var(--text-secondary, #64748b);margin:0}.class-ai-generate-btn{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--primary-blue, #3D81DE);border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;white-space:nowrap;transition:background-color .15s ease}.class-ai-generate-btn:hover{background:var(--primary-hover, #2a5ba8)}.class-ai-limits{display:flex;gap:1rem;font-size:.78rem;color:var(--text-muted, #94a3b8);margin-bottom:.75rem}.class-ai-filter{margin-bottom:1rem}.class-ai-toggle-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary, #64748b);cursor:pointer}.class-ai-toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.class-ai-filter-hint{font-size:.78rem;color:var(--text-muted, #94a3b8);margin-left:.25rem}.class-ai-resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.class-ai-resource-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease;background:#fff}.class-ai-resource-card:hover{border-color:var(--primary-blue, #3D81DE);box-shadow:0 1px 4px #3d81de1a}.class-ai-resource-card.selected{border-color:var(--primary-blue, #3D81DE);background:#f0f6ff;box-shadow:0 0 0 1px var(--primary-blue, #3D81DE)}.class-ai-resource-icon{flex-shrink:0}.class-ai-resource-info{flex:1;min-width:0}.class-ai-resource-info h4{font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937);margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.class-ai-resource-meta{display:flex;gap:.5rem;font-size:.75rem;color:var(--text-muted, #94a3b8)}.class-ai-resource-meta span:not(:last-child):after{content:"·";margin-left:.5rem}.class-ai-resource-check{flex-shrink:0}.class-ai-loading{text-align:center;padding:2rem;color:var(--text-muted, #94a3b8);font-size:.9rem}.class-ai-empty{text-align:center;padding:2rem;color:var(--text-muted, #94a3b8)}.class-ai-empty p{font-size:.9rem;margin-bottom:.75rem}.class-ai-show-all-btn{padding:.4rem 1rem;font-size:.825rem;color:var(--primary-blue, #3D81DE);background:#fff;border:1px solid var(--primary-blue, #3D81DE);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease}.class-ai-show-all-btn:hover{background:#f0f6ff}.class-ai-unavailable{text-align:center;padding:3rem 2rem}.class-ai-unavailable h3{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:.75rem 0 .35rem}.class-ai-unavailable p{font-size:.875rem;color:var(--text-secondary, #64748b);margin:0}.class-ai-history{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-color, #e2e8f0)}.class-ai-history h3{font-size:.95rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 .75rem}.class-ai-history-list{display:flex;flex-direction:column;gap:.4rem}.class-ai-history-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .85rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease;background:#fff}.class-ai-history-item:hover{border-color:var(--primary-blue, #3D81DE);background:#f8faff}.class-ai-history-info{display:flex;align-items:center;gap:.5rem;min-width:0}.class-ai-history-title{font-size:.85rem;color:var(--text-primary, #1f2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}.class-ai-history-badge{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.class-ai-history-badge.quiz{background:#e8f0fe;color:#1e40af}.class-ai-history-badge.assignment{background:#d1fae5;color:#065f46}.class-ai-history-badge.lesson{background:#fef3c7;color:#92400e}.class-ai-history-status{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.class-ai-history-status.processing{background:#fef3c7;color:#92400e}.class-ai-history-status.failed{background:#fee2e2;color:#991b1b}.class-ai-history-date{font-size:.78rem;color:var(--text-muted, #94a3b8);white-space:nowrap;flex-shrink:0}@media(max-width:768px){.class-ai-header{flex-direction:column;gap:.75rem}.class-ai-resource-grid{grid-template-columns:1fr}}.discussions-container{padding:0}.discussions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.discussions-header h2{font-size:var(--font-3xl);font-weight:var(--weight-bold);color:var(--text-primary);margin:0}.discussions-header-actions{display:flex;align-items:center;gap:.75rem}.disc-create-form{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}.disc-create-form h3{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text-primary);margin:0 0 1.25rem}.disc-form-group{margin-bottom:1rem}.disc-form-group label{display:block;font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-primary);margin-bottom:.375rem}.disc-form-group input,.disc-form-group textarea{width:100%;padding:.625rem .75rem;font-size:var(--font-base);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-primary);transition:border-color var(--transition-fast)}.disc-form-group input:focus,.disc-form-group textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.disc-form-group textarea{min-height:100px;resize:vertical}.disc-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.25rem}.disc-btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;font-size:var(--font-base);font-weight:var(--weight-medium);font-family:inherit;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.disc-btn-primary{background:var(--primary-blue);color:var(--text-white)}.disc-btn-primary:hover{background:var(--primary-hover)}.disc-btn-primary:disabled{opacity:.55;cursor:not-allowed}.disc-btn-secondary{background:var(--bg-gray-100);color:var(--text-secondary);border:1px solid var(--border-light)}.disc-btn-secondary:hover{background:var(--bg-gray-200)}.disc-btn-small{padding:.3rem .625rem;font-size:var(--font-xs)}.discussion-list{display:flex;flex-direction:column;gap:0;background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.disc-list-header{display:grid;grid-template-columns:1fr 80px 120px;align-items:center;padding:.75rem 1.25rem;background:var(--bg-gray-50);border-bottom:1px solid var(--border-light);font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.disc-list-header span:not(:first-child){text-align:center}.discussion-row{display:grid;grid-template-columns:1fr 80px 120px;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--bg-gray-100);cursor:pointer;transition:background var(--transition-fast);position:relative}.discussion-row:last-child{border-bottom:none}.discussion-row:hover{background:var(--bg-gray-50)}.discussion-row.pinned{background:#f0f7ff;border-left:3px solid var(--primary-blue)}.discussion-row.pinned:hover{background:#e5f0ff}.disc-topic-col{display:flex;gap:.875rem;align-items:flex-start;min-width:0}.disc-avatar{flex-shrink:0;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-white);background:var(--primary-blue);text-transform:uppercase}.disc-avatar.teacher-avatar{background:#1e40af}.disc-avatar.student-avatar{background:#059669}.disc-avatar.admin-avatar{background:#7c3aed}.disc-topic-info{flex:1;min-width:0}.disc-topic-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.disc-topic-title{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--primary-blue);margin:0;line-height:1.3;word-break:break-word}.disc-topic-title:hover{text-decoration:underline}.disc-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.625rem;font-weight:var(--weight-semibold);padding:.125rem .4375rem;border-radius:10px;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.disc-badge-pin{background:#dbeafe;color:#1e40af}.disc-badge-lock{background:#fef3c7;color:#92400e}.disc-topic-preview{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;margin:.25rem 0 .375rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.disc-topic-meta{display:flex;align-items:center;gap:.5rem;font-size:var(--font-xs);color:var(--text-muted);flex-wrap:wrap}.disc-topic-author{font-weight:var(--weight-medium);color:var(--text-secondary)}.disc-role-badge{display:inline-block;font-size:10px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.04em;padding:.0625rem .3125rem;border-radius:4px;background:var(--bg-gray-200);color:var(--text-secondary);line-height:1.5}.disc-role-badge.teacher{background:#dbeafe;color:#1e40af}.disc-role-badge.student{background:#dcfce7;color:#166534}.disc-meta-dot{width:3px;height:3px;background:var(--text-muted);border-radius:50%;flex-shrink:0}.disc-comments-col{text-align:center;font-size:var(--font-base);font-weight:var(--weight-semibold);color:var(--text-primary)}.disc-comments-col .disc-comments-label{display:block;font-size:10px;font-weight:var(--weight-normal);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.125rem}.disc-activity-col{text-align:center;font-size:var(--font-xs);color:var(--text-muted);line-height:1.5}.disc-activity-col .disc-activity-date{display:block;font-weight:var(--weight-medium);color:var(--text-secondary)}.disc-row-actions{position:absolute;top:.75rem;right:.75rem;opacity:0;transition:opacity var(--transition-fast)}.discussion-row:hover .disc-row-actions{opacity:1}.disc-menu-trigger{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:var(--font-xl);cursor:pointer;transition:all var(--transition-fast);line-height:1}.disc-menu-trigger:hover{background:var(--bg-gray-200);border-color:var(--border-light);color:var(--text-secondary)}.disc-dropdown-container{position:relative;display:inline-flex}.disc-dropdown-menu{position:absolute;top:100%;right:0;min-width:140px;background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001a,0 1px 3px #0000000f;z-index:var(--z-dropdown);padding:4px 0;animation:disc-dropdown-fade .12s ease-out}@keyframes disc-dropdown-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.disc-dropdown-item{display:block;width:100%;padding:.5rem .875rem;border:none;background:none;text-align:left;font-size:var(--font-sm);font-family:inherit;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.disc-dropdown-item:hover{background:var(--bg-gray-50)}.disc-dropdown-item.danger{color:#dc2626}.disc-dropdown-item.danger:hover{background:#fef2f2}.disc-dropdown-divider{height:1px;margin:4px 0;background:var(--border-light)}.disc-inline-edit{grid-column:1 / -1;padding:.25rem 0}.discussion-detail{animation:fadeIn .25s ease}.disc-detail-nav{margin-bottom:1.25rem}.disc-back-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.4375rem .75rem;font-size:var(--font-sm);font-weight:var(--weight-medium);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.disc-back-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue);background:#f0f7ff}.disc-topic-card{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.disc-topic-card-header{display:flex;gap:1rem;align-items:flex-start}.disc-detail-avatar{flex-shrink:0;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--text-white);background:var(--primary-blue);text-transform:uppercase}.disc-detail-avatar.teacher-avatar{background:#1e40af}.disc-detail-avatar.student-avatar{background:#059669}.disc-topic-card-content{flex:1;min-width:0}.disc-detail-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.375rem}.disc-detail-title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--text-primary);margin:0;line-height:1.3}.disc-detail-author-row{display:flex;align-items:center;gap:.5rem;font-size:var(--font-sm);color:var(--text-secondary);flex-wrap:wrap}.disc-detail-author-name{font-weight:var(--weight-semibold);color:var(--text-primary)}.disc-detail-body{margin-top:1rem;font-size:var(--font-md);color:var(--text-primary);line-height:1.7;white-space:pre-wrap;word-break:break-word}.disc-comments-section{margin-top:0}.disc-comments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.disc-comments-title{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text-primary);margin:0}.disc-sort-select{padding:.375rem .625rem;font-size:var(--font-sm);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition-fast)}.disc-sort-select:focus{outline:none;border-color:var(--primary-blue)}.disc-comment-list{display:flex;flex-direction:column;gap:0;background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.disc-comment{padding:1rem 1.25rem;border-bottom:1px solid var(--bg-gray-100);transition:background var(--transition-fast)}.disc-comment:last-child{border-bottom:none}.disc-comment:hover{background:var(--bg-gray-50)}.disc-comment-layout{display:flex;gap:.875rem;align-items:flex-start}.disc-comment-avatar{flex-shrink:0;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:var(--weight-bold);color:var(--text-white);background:var(--primary-blue);text-transform:uppercase}.disc-comment-avatar.teacher-avatar{background:#1e40af}.disc-comment-avatar.student-avatar{background:#059669}.disc-comment-content{flex:1;min-width:0}.disc-comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3125rem;gap:.5rem}.disc-comment-author-info{display:flex;align-items:center;gap:.4375rem;font-size:var(--font-sm);flex-wrap:wrap}.disc-comment-author{font-weight:var(--weight-semibold);color:var(--text-primary)}.disc-comment-time{color:var(--text-muted);font-size:var(--font-xs)}.disc-comment-edited{font-size:var(--font-xs);color:var(--text-muted);font-style:italic}.disc-comment-actions{display:flex;gap:.125rem;opacity:0;transition:opacity var(--transition-fast)}.disc-comment:hover .disc-comment-actions{opacity:1}.disc-comment-action-btn{display:inline-flex;align-items:center;gap:.1875rem;padding:.25rem .5rem;font-size:var(--font-xs);font-weight:var(--weight-medium);font-family:inherit;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.disc-comment-action-btn:hover{background:var(--bg-gray-200);color:var(--primary-blue)}.disc-comment-action-btn.danger:hover{color:#dc2626;background:#fef2f2}.disc-reply-thread-bar{display:flex;justify-content:flex-start;margin-bottom:1.25rem}.disc-quoted-parent{background:var(--bg-gray-50);border-left:3px solid var(--primary-blue);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:.5rem .75rem;margin-bottom:.5rem;font-size:var(--font-sm)}.disc-quoted-header{font-weight:var(--weight-semibold);color:var(--primary-blue);margin-bottom:.25rem;font-size:var(--font-xs)}.disc-quoted-body{color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word}.disc-comment-body{font-size:var(--font-base);color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.disc-show-more-btn{display:inline;padding:0;margin:0;border:none;background:none;color:var(--primary-blue);font-size:var(--font-sm);font-weight:var(--weight-medium);font-family:inherit;cursor:pointer;transition:color var(--transition-fast)}.disc-show-more-btn:hover{color:var(--primary-hover);text-decoration:underline}.disc-comment-deleted{color:var(--text-muted);font-style:italic;font-size:var(--font-base);padding:.25rem 0}.disc-comment-deleted-layout{display:flex;gap:.875rem;align-items:center}.disc-comment-deleted-avatar{flex-shrink:0;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:var(--weight-bold);background:var(--bg-gray-200);color:var(--text-muted)}.disc-replies{margin-left:2.875rem;border-left:2px solid var(--bg-gray-200)}.disc-replies .disc-comment{padding-left:1rem}.disc-replies .disc-comment-avatar{width:28px;height:28px;font-size:10px}.disc-replies .disc-replies{margin-left:1.75rem}.disc-add-comment-area{margin-top:1.25rem}.disc-comment-form{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm)}.disc-comment-form-label{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--text-primary);margin-bottom:.5rem}.disc-comment-form textarea{width:100%;min-height:80px;padding:.625rem .75rem;font-size:var(--font-base);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);resize:vertical;color:var(--text-primary);transition:border-color var(--transition-fast)}.disc-comment-form textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.disc-comment-form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.625rem}.disc-reply-form{margin-top:.625rem;margin-left:2.875rem;padding:.75rem;background:var(--bg-gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md)}.disc-reply-form textarea{width:100%;min-height:60px;padding:.5rem .625rem;font-size:var(--font-sm);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-sm);resize:vertical;color:var(--text-primary);transition:border-color var(--transition-fast);background:var(--card-bg)}.disc-reply-form textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.disc-reply-form-actions{display:flex;justify-content:flex-end;gap:.375rem;margin-top:.5rem}.disc-edit-form{margin-top:.375rem}.disc-edit-form textarea{width:100%;min-height:60px;padding:.5rem .625rem;font-size:var(--font-base);font-family:inherit;border:1px solid var(--primary-blue);border-radius:var(--radius-sm);resize:vertical;color:var(--text-primary);background:var(--card-bg)}.disc-edit-form textarea:focus{outline:none;box-shadow:0 0 0 3px #3d81de1a}.disc-edit-form-actions{display:flex;justify-content:flex-end;gap:.375rem;margin-top:.5rem}.disc-locked-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef9c3;border:1px solid #fde68a;border-radius:var(--radius-md);font-size:var(--font-sm);color:#854d0e;margin-top:1.25rem}.disc-locked-banner svg{flex-shrink:0}.disc-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-muted);background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.disc-empty-icon{font-size:2.5rem;margin-bottom:.75rem;display:block;opacity:.5}.disc-empty-text{font-size:var(--font-md);color:var(--text-secondary)}.disc-empty-subtext{font-size:var(--font-sm);color:var(--text-muted);margin-top:.375rem}.disc-loading{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:3rem;color:var(--text-muted);font-size:var(--font-md)}.disc-loading-spinner{width:20px;height:20px;border:2px solid var(--border-light);border-top-color:var(--primary-blue);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.discussions-header{flex-direction:column;align-items:flex-start;gap:.75rem}.disc-list-header{display:none}.discussion-row{display:flex;flex-direction:column;gap:.625rem;padding:.875rem 1rem}.disc-comments-col,.disc-activity-col{text-align:left}.disc-topic-mobile-stats{display:flex;gap:1rem;font-size:var(--font-xs);color:var(--text-muted)}.disc-row-actions,.disc-comment-actions{opacity:1}.disc-topic-card{padding:1rem}.disc-topic-card-header{flex-direction:column;gap:.75rem}.disc-detail-title{font-size:var(--font-xl)}.disc-replies{margin-left:1.5rem}.disc-replies .disc-replies{margin-left:1rem}.disc-reply-form{margin-left:1.5rem}.disc-comment-layout{gap:.625rem}.disc-comments-header{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.disc-avatar,.disc-detail-avatar{width:32px;height:32px;font-size:var(--font-xs)}.disc-comment-avatar{width:28px;height:28px;font-size:10px}.disc-topic-title{font-size:var(--font-base)}.disc-topic-preview{-webkit-line-clamp:1}}.cr-container{padding:0}.cr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.cr-header h2{font-size:var(--font-3xl);font-weight:var(--weight-bold);color:var(--text-primary);margin:0}.cr-header-actions{display:flex;align-items:center;gap:.75rem}.cr-btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;font-size:var(--font-base);font-weight:var(--weight-medium);font-family:inherit;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.cr-btn-primary{background:var(--primary-blue);color:var(--text-white)}.cr-btn-primary:hover{background:var(--primary-hover)}.cr-btn-primary:disabled{opacity:.55;cursor:not-allowed}.cr-btn-secondary{background:var(--bg-gray-100);color:var(--text-secondary);border:1px solid var(--border-light)}.cr-btn-secondary:hover{background:var(--bg-gray-200)}.cr-btn-danger{background:transparent;color:#dc2626;border:1px solid #fecaca}.cr-btn-danger:hover{background:#fef2f2}.cr-btn-small{padding:.3rem .625rem;font-size:var(--font-xs)}.cr-groups{display:flex;flex-direction:column;gap:1.5rem}.cr-group-title{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text-primary);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid var(--bg-gray-200)}.cr-resource-list{display:flex;flex-direction:column;gap:0;background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.cr-resource-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--bg-gray-100);transition:background var(--transition-fast);gap:1rem}.cr-resource-row:last-child{border-bottom:none}.cr-resource-row:hover{background:var(--bg-gray-50)}.cr-resource-info{display:flex;gap:.875rem;align-items:flex-start;flex:1;min-width:0}.cr-resource-icon{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:var(--weight-bold);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;text-transform:uppercase}.cr-resource-details{flex:1;min-width:0}.cr-resource-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.cr-resource-title{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--text-primary);word-break:break-word}.cr-badge{display:inline-flex;align-items:center;font-size:.625rem;font-weight:var(--weight-semibold);padding:.125rem .4375rem;border-radius:10px;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.cr-badge-shared{background:#dbeafe;color:#1e40af}.cr-resource-description{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;margin:.25rem 0 .375rem;word-break:break-word}.cr-resource-meta{display:flex;align-items:center;gap:.5rem;font-size:var(--font-xs);color:var(--text-muted);flex-wrap:wrap}.cr-meta-dot{width:3px;height:3px;background:var(--text-muted);border-radius:50%;flex-shrink:0}.cr-resource-actions{display:flex;gap:.375rem;flex-shrink:0}.cr-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 1000);padding:1rem}.cr-modal{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.cr-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light)}.cr-modal-header h3{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text-primary);margin:0}.cr-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition-fast)}.cr-modal-close:hover{color:var(--text-primary)}.cr-modal-body{padding:1.5rem}.cr-modal-footer{display:flex;gap:.5rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border-light)}.cr-form-group{margin-bottom:1rem}.cr-form-group label{display:block;font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-primary);margin-bottom:.375rem}.cr-form-group input[type=text],.cr-form-group textarea,.cr-form-group select{width:100%;padding:.625rem .75rem;font-size:var(--font-base);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-primary);transition:border-color var(--transition-fast)}.cr-form-group input[type=text]:focus,.cr-form-group textarea:focus,.cr-form-group select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.cr-form-group textarea{min-height:80px;resize:vertical}.cr-form-group input[type=file]{font-size:var(--font-sm);color:var(--text-secondary)}.cr-checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer;font-weight:var(--weight-normal)!important}.cr-checkbox-label input[type=checkbox]{width:auto}.cr-helper-text{display:block;font-size:var(--font-xs);color:var(--text-muted);margin-top:.25rem;line-height:1.4}.cr-category-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.cr-category-item{padding:.5rem 0;border-bottom:1px solid var(--bg-gray-100)}.cr-category-item:last-child{border-bottom:none}.cr-category-display-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.cr-category-name{font-size:var(--font-base);font-weight:var(--weight-medium);color:var(--text-primary)}.cr-category-actions{display:flex;gap:.375rem}.cr-category-edit-row{display:flex;gap:.5rem;align-items:center}.cr-category-edit-row input{flex:1;padding:.375rem .625rem;font-size:var(--font-sm);font-family:inherit;border:1px solid var(--primary-blue);border-radius:var(--radius-sm);color:var(--text-primary)}.cr-category-edit-row input:focus{outline:none;box-shadow:0 0 0 3px #3d81de1a}.cr-category-add{display:flex;gap:.5rem;align-items:center;margin-top:.75rem}.cr-category-add input{flex:1;padding:.5rem .75rem;font-size:var(--font-base);font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast)}.cr-category-add input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.cr-category-empty{font-size:var(--font-sm);color:var(--text-muted);text-align:center;padding:1rem 0;margin:0}.cr-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-muted);background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.cr-empty-icon{font-size:2.5rem;margin-bottom:.75rem;display:block;opacity:.5}.cr-empty-text{font-size:var(--font-md);color:var(--text-secondary);margin:0}.cr-empty-subtext{font-size:var(--font-sm);color:var(--text-muted);margin-top:.375rem}.cr-loading{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:3rem;color:var(--text-muted);font-size:var(--font-md)}.cr-loading-spinner{width:20px;height:20px;border:2px solid var(--border-light);border-top-color:var(--primary-blue);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.cr-header,.cr-resource-row{flex-direction:column;align-items:flex-start;gap:.75rem}.cr-resource-actions{width:100%;justify-content:flex-start}.cr-category-display-row{flex-direction:column;align-items:flex-start;gap:.5rem}.cr-category-add{flex-direction:column}.cr-category-add input{width:100%}}.reports-container{max-width:1400px;margin:0 auto;padding:0 1rem}.reports-header{margin-bottom:1.5rem}.reports-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary, #1f2937);margin-bottom:.35rem}.reports-header p{color:var(--text-secondary, #64748b);font-size:.95rem}.reports-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color, #e5e7eb);margin-bottom:1.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.reports-tab{padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;color:var(--text-muted, #6b7280);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;white-space:nowrap;transition:color .15s ease,border-color .15s ease}.reports-tab:hover{color:var(--text-primary, #1f2937)}.reports-tab.active{color:var(--primary-blue, #3b82f6);border-bottom-color:var(--primary-blue, #3b82f6);font-weight:600}.reports-stats-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.reports-stat-card{flex:1;min-width:150px;background:var(--card-bg, white);border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color, #e5e7eb);transition:transform .15s ease,box-shadow .15s ease}.reports-stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.reports-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary, #1f2937);line-height:1.2}.reports-stat-label{font-size:.85rem;color:var(--text-muted, #6b7280);margin-top:.25rem}.reports-stat-sublabel{font-size:.75rem;color:var(--text-muted, #9ca3af);margin-top:.15rem}.reports-stat-card.accent-green .reports-stat-value{color:#16a34a}.reports-stat-card.accent-blue .reports-stat-value{color:#2563eb}.reports-stat-card.accent-amber .reports-stat-value{color:#d97706}.reports-stat-card.accent-red .reports-stat-value{color:#dc2626}.chart-card{background:var(--card-bg, white);border-radius:var(--radius-lg, 12px);box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color, #e5e7eb);margin-bottom:1.5rem;overflow:hidden}.chart-card-header{padding:1rem 1.25rem .5rem}.chart-card-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.chart-card-subtitle{font-size:.82rem;color:var(--text-muted, #6b7280);margin:.2rem 0 0}.chart-card-body{padding:1rem 1.25rem 1.25rem}.chart-empty-state{display:flex;align-items:center;justify-content:center;min-height:120px;padding:2rem;color:#6c757d;font-style:italic}.chart-empty-state p{color:var(--text-muted, #6c757d);font-size:.9rem;font-style:italic;margin:0}.chart-tooltip{background:var(--card-bg, white);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:.6rem .85rem;box-shadow:0 4px 12px #0000001f}.chart-tooltip-label{font-size:.8rem;color:var(--text-muted, #6b7280);margin:0 0 .15rem}.chart-tooltip-value{font-size:.95rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem;margin-bottom:1.5rem}.charts-grid .chart-card{margin-bottom:0}.grade-a{color:#22c55e}.grade-b{color:#3b82f6}.grade-c{color:#f59e0b}.grade-d{color:#f97316}.grade-f{color:#ef4444}.grade-pill{display:inline-flex;align-items:center;justify-content:center;min-width:36px;padding:.25rem .6rem;border-radius:20px;font-size:.85rem;font-weight:700;letter-spacing:.02em}.grade-pill.grade-pill-a{background:#dcfce7;color:#166534}.grade-pill.grade-pill-b{background:#dbeafe;color:#1e40af}.grade-pill.grade-pill-c{background:#fef3c7;color:#92400e}.grade-pill.grade-pill-d{background:#fed7aa;color:#9a3412}.grade-pill.grade-pill-f{background:#fee2e2;color:#991b1b}.ai-narrative{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;padding:1.5rem;border-left:4px solid #3b82f6;margin-bottom:1.5rem}.ai-narrative-title{font-size:.9rem;font-weight:600;color:#1e40af;margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}.ai-narrative-text{font-size:.95rem;line-height:1.6;color:#1e3a5f;margin:0;white-space:pre-line}.class-report-card{background:var(--card-bg, white);border-radius:var(--radius-lg, 12px);box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color, #e5e7eb);margin-bottom:1.25rem;overflow:hidden}.class-report-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary, #f9fafb);border-bottom:1px solid var(--border-color, #e5e7eb);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.class-report-card-header:hover{background:#f1f5f9}.class-report-card-header h3{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.class-report-card-header .class-grade{font-size:.9rem;font-weight:600}.class-report-card-body{padding:1.25rem}.category-breakdown-table{width:100%;border-collapse:collapse;font-size:.875rem;margin-bottom:1rem}.category-breakdown-table th{padding:.6rem .75rem;text-align:left;font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted, #6b7280);border-bottom:2px solid var(--border-color, #e5e7eb)}.category-breakdown-table td{padding:.6rem .75rem;border-bottom:1px solid #f3f4f6;color:var(--text-primary, #374151)}.category-breakdown-table tbody tr:last-child td{border-bottom:none}.category-breakdown-table tbody tr:hover{background:var(--bg-secondary, #f9fafb)}.category-breakdown-table .text-right{text-align:right}.category-breakdown-table .text-center{text-align:center}.category-breakdown-table .font-semibold{font-weight:600}.student-table{width:100%;border-collapse:collapse;font-size:.875rem}.student-table th{padding:.75rem 1rem;text-align:left;font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted, #6b7280);background:var(--bg-secondary, #f9fafb);border-bottom:2px solid var(--border-color, #e5e7eb);white-space:nowrap}.student-table td{padding:.65rem 1rem;border-bottom:1px solid #f3f4f6;color:var(--text-primary, #374151);vertical-align:middle}.student-row{transition:background-color .15s ease;cursor:pointer}.student-row:hover{background:#f0f9ff}.student-row:active{background:#e0f2fe}.student-name-cell{font-weight:500;color:var(--text-primary, #1f2937)}.student-drill-down{color:var(--primary-blue, #3b82f6);font-size:.8rem;font-weight:500;opacity:0;transition:opacity .15s ease}.student-row:hover .student-drill-down{opacity:1}.btn-pdf-export{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;color:#dc2626;background:#fff;border:1px solid #fca5a5;border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn-pdf-export:hover{background:#fef2f2;border-color:#f87171;color:#b91c1c}.btn-pdf-export:active{background:#fee2e2}.btn-pdf-export:disabled{opacity:.5;cursor:not-allowed}.btn-pdf-export .pdf-icon{font-size:1rem}.hifz-progress-container{padding:.5rem 0}.hifz-juz-grid{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:1rem}.hifz-juz-segment{width:30px;height:30px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;cursor:default;position:relative;transition:transform .1s ease,box-shadow .1s ease}.hifz-juz-segment:hover{transform:scale(1.15);box-shadow:0 2px 8px #00000026;z-index:2}.hifz-juz-segment.not-started{background:#e5e7eb;color:#9ca3af}.hifz-juz-segment.in-progress{background:#fbbf24;color:#92400e}.hifz-juz-segment.awaiting-test{background:#f97316;color:#fff}.hifz-juz-segment.memorized{background:#10b981;color:#fff}.hifz-juz-segment.current-juz{box-shadow:0 0 0 2px #1f2937,0 0 0 4px #fbbf2466}.current-juz-indicator{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:5px solid #1f2937}.hifz-juz-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1f2937;color:#fff;font-size:.72rem;font-weight:500;padding:.3rem .6rem;border-radius:4px;white-space:nowrap;z-index:10;pointer-events:none}.hifz-juz-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #1f2937}.hifz-legend{display:flex;flex-wrap:wrap;gap:1rem;padding-top:.5rem}.hifz-legend-item{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary, #64748b)}.hifz-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.attendance-pie-wrapper{position:relative}.attendance-pie-center-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);text-align:center;pointer-events:none}.attendance-pie-rate{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary, #1f2937);line-height:1.2}.attendance-pie-rate-label{display:block;font-size:.72rem;color:var(--text-muted, #6b7280);text-transform:uppercase;letter-spacing:.04em}.attendance-pie-legend{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.attendance-pie-legend-item{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--text-secondary, #64748b)}.attendance-pie-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.report-section{margin-bottom:2rem}.report-section-title{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.reports-filter-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--card-bg, white);border-radius:var(--radius-lg, 12px);box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color, #e5e7eb)}.reports-filter-bar label{font-size:.85rem;font-weight:500;color:var(--text-secondary, #64748b);white-space:nowrap}.reports-filter-bar select,.reports-filter-bar input{padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:var(--card-bg, white);color:var(--text-primary, #1f2937);min-width:180px}.reports-filter-bar select:focus,.reports-filter-bar input:focus{outline:none;border-color:var(--primary-blue, #3b82f6);box-shadow:0 0 0 2px #3b82f626}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted, #6b7280)}.reports-loading-spinner{width:36px;height:36px;border:3px solid var(--border-color, #e5e7eb);border-top-color:var(--primary-blue, #3b82f6);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.reports-loading p{font-size:.9rem}.reports-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:#dc2626;text-align:center}.reports-error p{font-size:.9rem;margin-bottom:1rem}.reports-error button{padding:.5rem 1rem;font-size:.85rem;background:#fff;border:1px solid #fca5a5;border-radius:6px;color:#dc2626;cursor:pointer}.reports-error button:hover{background:#fef2f2}.report-printable-area{background:#fff}.pdf-only-header{display:none}@media(max-width:768px){.reports-container{padding:0 .5rem}.reports-header h1{font-size:1.4rem}.reports-stats-row{gap:.75rem}.reports-stat-card{min-width:120px;padding:1rem}.reports-stat-value{font-size:1.35rem}.reports-stat-label{font-size:.78rem}.charts-grid{grid-template-columns:1fr}.reports-tabs{gap:0}.reports-tab{padding:.6rem .85rem;font-size:.82rem}.reports-filter-bar{flex-direction:column;align-items:stretch}.reports-filter-bar select,.reports-filter-bar input{min-width:unset;width:100%}.chart-card-body{padding:.75rem}.student-table{font-size:.8rem}.student-table th,.student-table td{padding:.5rem .6rem}.category-breakdown-table th,.category-breakdown-table td{padding:.45rem .5rem;font-size:.8rem}.ai-narrative{padding:1rem}.ai-narrative-text{font-size:.88rem}.btn-pdf-export{padding:.45rem .85rem;font-size:.8rem}.hifz-juz-segment{width:26px;height:26px;font-size:.62rem}.hifz-legend{gap:.6rem}.hifz-legend-item{font-size:.72rem}}@media(max-width:480px){.reports-stats-row{flex-direction:column}.reports-stat-card{min-width:unset}.hifz-juz-segment{width:24px;height:24px;font-size:.58rem}}.advanced-metrics-section{background:var(--card-bg, white);border-radius:var(--radius-lg, 12px);box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color, #e5e7eb);margin-bottom:1.5rem;overflow:hidden}.advanced-metrics-toggle{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--bg-secondary, #f9fafb);transition:background-color .15s ease}.advanced-metrics-toggle:hover{background:#f1f5f9}.advanced-metrics-toggle-title{font-size:.95rem;font-weight:600;color:var(--text-primary, #1f2937)}.advanced-metrics-toggle-chevron{font-size:.82rem;color:#9ca3af}.advanced-metrics-body{padding:1.25rem}.advanced-metrics-block{margin-bottom:1.25rem}.advanced-metrics-block:last-child{margin-bottom:0}.advanced-metrics-block-title{font-size:.9rem;font-weight:600;color:var(--text-primary, #374151);margin:0 0 .75rem;padding-bottom:.35rem;border-bottom:1px solid #f3f4f6}.advanced-metrics-cards-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.momentum-card{flex:1;min-width:220px;background:var(--card-bg, white);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.momentum-card-header{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted, #6b7280);padding:.65rem 1rem;background:var(--bg-secondary, #f9fafb);border-bottom:1px solid var(--border-color, #e5e7eb)}.momentum-card-body{padding:1rem}.momentum-values{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.momentum-half{display:flex;flex-direction:column;align-items:center;gap:.15rem}.momentum-half-label{font-size:.72rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}.momentum-half-value{font-size:1.15rem;font-weight:700;color:var(--text-primary, #1f2937)}.momentum-arrow{font-size:1.5rem;font-weight:700}.momentum-delta{text-align:center;font-size:.85rem;font-weight:600}.consistency-label-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:12px;font-size:.78rem;font-weight:600}.consistency-badge-green{background:#dcfce7;color:#166534}.consistency-badge-blue{background:#dbeafe;color:#1e40af}.consistency-badge-yellow{background:#fef3c7;color:#92400e}.consistency-badge-red{background:#fee2e2;color:#991b1b}.attendance-impact-callout{background:#fefce8;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem}.attendance-impact-title{font-size:.85rem;font-weight:600;color:#92400e;margin-bottom:.35rem}.attendance-impact-text{font-size:.88rem;color:#78350f;line-height:1.5;margin:0}.comparison-bars-wrapper{display:flex;flex-direction:column;gap:1rem}.comparison-bar-row{display:flex;gap:1rem;align-items:flex-start}.comparison-bar-label{width:130px;flex-shrink:0;display:flex;flex-direction:column;gap:.1rem}.comparison-bar-class-name{font-size:.85rem;font-weight:600;color:#1f2937;line-height:1.25}.comparison-bar-rank{font-size:.72rem;color:#9ca3af}.comparison-bar-bars{flex:1;display:flex;align-items:center;gap:.75rem}.comparison-bar-pair{flex:1;display:flex;flex-direction:column;gap:.35rem}.comparison-bar-item{display:flex;align-items:center;gap:.5rem}.comparison-bar-tag{width:28px;flex-shrink:0;font-size:.68rem;font-weight:600;color:#6b7280;text-transform:uppercase}.comparison-bar-track{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.comparison-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.comparison-bar-pct{width:48px;flex-shrink:0;font-size:.8rem;font-weight:600;color:#1f2937;text-align:right}.comparison-bar-delta{width:52px;flex-shrink:0;font-size:.9rem;font-weight:700;text-align:right}.class-analytics-expanded{padding:1.5rem;background:#f8fafc;border-top:1px solid var(--border-color, #e5e7eb)}.hifz-metric-card{flex:1;min-width:220px;background:var(--card-bg, white);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.quality-score-bar{display:flex;width:100%;height:8px;border-radius:4px;overflow:hidden;background:#f3f4f6;margin-top:.75rem}.quality-score-segment{height:100%;transition:width .3s ease}.quality-score-segment:first-child{border-radius:4px 0 0 4px}.quality-score-segment:last-child{border-radius:0 4px 4px 0}.class-row-expandable{cursor:pointer;transition:background-color .15s ease}.class-row-expandable:hover{background:#f0f9ff}.expand-indicator{font-size:.75rem;color:#9ca3af;transition:transform .15s ease}@media(max-width:768px){.advanced-metrics-cards-row{flex-direction:column}.momentum-card,.hifz-metric-card{min-width:unset}.comparison-bar-row{flex-direction:column;gap:.35rem}.comparison-bar-label,.comparison-bar-delta{width:auto}}.attendance-bar-wrapper{padding:.25rem 0}.attendance-bar-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.attendance-bar-rate{font-size:1.5rem;font-weight:700;line-height:1}.attendance-bar-total{font-size:.8rem;color:#6b7280}.attendance-bar-track{display:flex;width:100%;height:12px;border-radius:6px;overflow:hidden;background:#f3f4f6}.attendance-bar-segment{height:100%;transition:width .3s ease}.attendance-bar-segment:first-child{border-radius:6px 0 0 6px}.attendance-bar-segment:last-child{border-radius:0 6px 6px 0}.attendance-bar-segment:only-child{border-radius:6px}.attendance-bar-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.attendance-bar-legend-item{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:#4b5563}.attendance-bar-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-bars-wrapper{display:flex;flex-direction:column;gap:.75rem;padding:.25rem 0}.category-bar-row{display:flex;align-items:center;gap:.75rem}.category-bar-label{width:120px;flex-shrink:0;display:flex;flex-direction:column}.category-bar-name{font-size:.85rem;font-weight:600;color:#1f2937;line-height:1.2}.category-bar-weight{font-size:.7rem;color:#9ca3af}.category-bar-track{flex:1;height:10px;background:#f3f4f6;border-radius:5px;overflow:hidden}.category-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.category-bar-value{width:75px;flex-shrink:0;display:flex;align-items:baseline;gap:.35rem;justify-content:flex-end}.category-bar-pct{font-size:.85rem;font-weight:600;color:#1f2937}.category-bar-letter{font-size:.75rem;font-weight:700}.student-drill-down-panel{padding:1.5rem;background:var(--bg-secondary, #f9fafb);border-top:2px solid var(--primary-blue, #3b82f6)}.teacher-category-bars{display:flex;flex-direction:column;gap:.75rem}.teacher-category-bar-row{display:flex;align-items:center;gap:.75rem}.teacher-category-bar-label{min-width:140px;flex-shrink:0}.teacher-category-bar-name{font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937)}.teacher-category-bar-weight{font-size:.75rem;color:var(--text-muted, #6b7280);margin-left:.35rem}.teacher-category-bar-track{flex:1;height:20px;background:#e5e7eb;border-radius:10px;overflow:hidden}.teacher-category-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:10px;transition:width .4s ease;min-width:2px}.teacher-category-bar-value{min-width:48px;text-align:right;font-size:.85rem;font-weight:600;color:var(--text-primary, #1f2937);flex-shrink:0}@media(max-width:768px){.student-drill-down-panel{padding:1rem}.teacher-category-bar-label{min-width:100px}.teacher-category-bar-name{font-size:.8rem}}.teacher-report-section{background:var(--card-bg, white);border-radius:8px;padding:1.25rem;margin-bottom:1rem;border:1px solid var(--border-color, #e5e7eb)}.teacher-report-section .reports-stats-row{margin-bottom:0}.teacher-report-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #6b7280);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.accounting-container{padding:2rem;max-width:1400px;margin:0 auto}.stripe-section{margin-bottom:2rem}.stripe-status-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.status-indicator{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.status-indicator.connected{color:var(--success-color)}.status-indicator.not-connected{color:var(--warning-color)}.status-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem}.status-indicator.connected .status-icon{background:#10b9811a}.status-indicator.not-connected .status-icon{background:#f59e0b1a}.status-details{margin-bottom:1rem}.status-details p{margin:.5rem 0;color:var(--text-secondary)}.stripe-description{color:var(--text-muted);margin-bottom:1rem}.alert{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1.5rem}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--text-primary)}.alert strong{color:var(--warning-color)}.alert ul{margin:.5rem 0 0 1.5rem;padding:0}.alert li{margin:.25rem 0;color:var(--text-secondary)}.payers-section{margin-bottom:2rem}.section-header{margin-bottom:1rem}.section-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.section-subtitle{color:var(--text-muted);font-size:.875rem;margin:.25rem 0 0}.table-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{background:var(--bg-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.billing-months-preview{font-size:.875rem;color:var(--text-secondary)}.action-buttons{display:flex;gap:.5rem}.btn-sm{padding:.375rem .625rem;font-size:.875rem}.badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.badge-success{background:#10b9811a;color:var(--success-color)}.badge-warning{background:#f59e0b1a;color:var(--warning-color)}.badge-error{background:#ef44441a;color:var(--error-color)}.badge-secondary{background:var(--bg-secondary);color:var(--text-secondary)}.badge-parent{background:#6366f11a;color:#6366f1}.badge-student{background:#10b9811a;color:var(--success-color)}.modal{background:var(--card-bg);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-large{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-description{color:var(--text-muted);margin:0 0 1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.tuition-form{display:flex;flex-direction:column;gap:1rem}.tuition-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.tuition-row label{flex:1;font-weight:500}.input-group{display:flex;align-items:center;border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.input-prefix{padding:.5rem .75rem;background:var(--bg-secondary);color:var(--text-muted);border-right:1px solid var(--border-color)}.input-group input{border:none;padding:.5rem .75rem;width:100px;outline:none;background:var(--card-bg);color:var(--text-primary)}.months-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.month-checkbox{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:background .2s}.month-checkbox:hover{background:var(--bg-tertiary)}.month-checkbox input{width:18px;height:18px;cursor:pointer}.month-checkbox span{font-size:.875rem}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary)}.modal-body h4{font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.modal-body .data-table{font-size:.875rem}.modal-body .data-table th,.modal-body .data-table td{padding:.625rem .75rem}@media(max-width:768px){.accounting-container{padding:1rem}.months-grid{grid-template-columns:repeat(2,1fr)}.data-table{font-size:.875rem}.data-table th,.data-table td{padding:.625rem .5rem}.action-buttons{flex-direction:column}}.resource-center{max-width:1400px;margin:0 auto;padding:0 1rem}.resource-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.resource-header-left h1{font-size:1.75rem;font-weight:700;color:var(--text-primary, #1f2937);margin-bottom:.25rem}.resource-header-left p{color:var(--text-secondary, #64748b);font-size:.95rem}.resource-header-actions{display:flex;gap:.75rem;align-items:center;flex-shrink:0}.resource-upload-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;color:#fff;background:var(--primary-blue, #3D81DE);border:none;border-radius:var(--radius-md, 8px);cursor:pointer;white-space:nowrap;transition:background-color .15s ease,transform .1s ease}.resource-upload-btn:hover{background:var(--primary-hover, #2a5ba8)}.resource-upload-btn:active{transform:scale(.97)}.resource-manage-categories-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500;color:var(--text-secondary, #64748b);background:var(--card-bg, white);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);cursor:pointer;white-space:nowrap;transition:all .15s ease}.resource-manage-categories-btn:hover{color:var(--primary-blue, #3D81DE);border-color:var(--primary-blue, #3D81DE);background:#f0f7ff}.resource-category-tabs{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.25rem;scrollbar-width:thin}.resource-category-tabs::-webkit-scrollbar{height:4px}.resource-category-tabs::-webkit-scrollbar-track{background:transparent}.resource-category-tabs::-webkit-scrollbar-thumb{background:var(--border-color, #e2e8f0);border-radius:4px}.resource-category-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.85rem;font-weight:500;color:var(--text-secondary, #64748b);background:var(--card-bg, white);border:1px solid var(--border-color, #e2e8f0);border-radius:20px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.resource-category-tab:hover{color:var(--primary-blue, #3D81DE);border-color:var(--primary-blue, #3D81DE);background:#f0f7ff}.resource-category-tab.active{color:#fff;background:var(--primary-blue, #3D81DE);border-color:var(--primary-blue, #3D81DE)}.resource-category-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;font-size:.75rem;font-weight:600;border-radius:10px;background:#00000014}.resource-category-tab.active .resource-category-tab-count{background:#ffffff40}.category-manage-section{background:var(--card-bg, white);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-lg, 12px);padding:1.25rem;margin-bottom:1.5rem}.category-manage-section h3{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 1rem}.category-manage-form{margin-bottom:1rem}.category-manage-form-row{display:flex;gap:.75rem;align-items:flex-start;flex-wrap:wrap}.category-manage-field{flex:1;min-width:150px}.category-manage-field-desc{flex:2}.category-manage-field-order{flex:0 0 80px;min-width:80px}.category-manage-field input{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);background:#fff;color:var(--text-primary, #1f2937);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.category-manage-field input:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 2px #3d81de26}.category-manage-actions{display:flex;gap:.5rem;align-items:center;padding-top:1px}.category-manage-list{display:flex;flex-direction:column;gap:.5rem}.category-manage-item{display:flex;justify-content:space-between;align-items:center;padding:.65rem .85rem;background:var(--bg-gray-50, #f8f9fa);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px)}.category-manage-item-info{display:flex;align-items:center;gap:.75rem;min-width:0;flex:1}.category-manage-item-name{font-size:.9rem;font-weight:600;color:var(--text-primary, #1f2937);white-space:nowrap}.category-manage-item-desc{font-size:.8rem;color:var(--text-muted, #94a3b8);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.category-manage-item-count{font-size:.75rem;color:var(--text-muted, #94a3b8);white-space:nowrap;flex-shrink:0}.category-manage-item-actions{display:flex;gap:.5rem;flex-shrink:0;margin-left:.75rem}.category-manage-edit-btn,.category-manage-delete-btn{padding:.3rem .65rem;font-size:.8rem;font-weight:500;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease;border:1px solid transparent}.category-manage-edit-btn{color:var(--primary-blue, #3D81DE);background:#f0f7ff;border-color:#c5ddf7}.category-manage-edit-btn:hover{background:#dbeafe;border-color:var(--primary-blue, #3D81DE)}.category-manage-delete-btn{color:var(--error, #ef4444);background:#fef2f2;border-color:#fecaca}.category-manage-delete-btn:hover{background:#fee2e2;border-color:var(--error, #ef4444)}.category-manage-delete-btn:disabled{opacity:.5;cursor:not-allowed}.category-manage-empty{font-size:.85rem;color:var(--text-muted, #94a3b8);text-align:center;padding:.75rem}.resource-search-bar{position:relative;margin-bottom:1.25rem}.resource-search-input{width:100%;padding:.6rem 2.5rem .6rem .85rem;font-size:.9rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);background:var(--card-bg, white);color:var(--text-primary, #1f2937);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.resource-search-input:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 2px #3d81de26}.resource-search-input::placeholder{color:var(--text-muted, #94a3b8)}.resource-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;color:var(--text-muted, #94a3b8);cursor:pointer;padding:.25rem;line-height:1;transition:color .15s ease}.resource-search-clear:hover{color:var(--text-primary, #1f2937)}.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.resource-card{background:var(--card-bg, white);border-radius:var(--radius-lg, 12px);border:1px solid var(--border-color, #e2e8f0);box-shadow:var(--shadow-sm, 0 1px 2px 0 rgba(0, 0, 0, .05));padding:1.25rem;display:flex;flex-direction:column;transition:box-shadow .15s ease,transform .15s ease}.resource-card:hover{box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));transform:translateY(-1px)}.resource-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.resource-card-title-row{display:flex;align-items:flex-start;gap:.6rem;flex:1;min-width:0}.resource-card-icon{flex-shrink:0;margin-top:2px}.resource-card-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0;line-height:1.35;word-break:break-word}.resource-card-header-actions{display:flex;gap:.25rem;flex-shrink:0;margin-left:.5rem}.resource-edit-btn{flex-shrink:0;padding:.35rem;background:none;border:none;color:var(--text-muted, #94a3b8);cursor:pointer;border-radius:var(--radius-sm, 6px);transition:color .15s ease,background-color .15s ease}.resource-edit-btn:hover{color:var(--primary-blue, #3D81DE);background:#f0f7ff}.resource-delete-btn{flex-shrink:0;padding:.35rem;background:none;border:none;color:var(--text-muted, #94a3b8);cursor:pointer;border-radius:var(--radius-sm, 6px);transition:color .15s ease,background-color .15s ease;margin-left:0}.resource-delete-btn:hover{color:var(--error, #ef4444);background:#fef2f2}.resource-card-description{font-size:.875rem;color:var(--text-secondary, #64748b);line-height:1.5;margin:0 0 .75rem;flex:1}.resource-card-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;align-items:center}.resource-meta-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;color:var(--primary-blue, #3D81DE);background:#eff6ff;border:1px solid #c5ddf7;border-radius:12px}.resource-meta-item{font-size:.8rem;color:var(--text-muted, #94a3b8);display:inline-flex;align-items:center}.resource-meta-item:not(:last-child):after{content:"";display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--text-muted, #94a3b8);margin-left:.5rem}.resource-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color, #e2e8f0);margin-top:auto}.resource-card-info{display:flex;flex-direction:column;gap:.1rem}.resource-uploaded-date{font-size:.8rem;color:var(--text-muted, #94a3b8)}.resource-uploaded-by{font-size:.75rem;color:var(--text-muted, #94a3b8)}.resource-card-actions{display:flex;gap:.5rem;align-items:center}.resource-download-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.85rem;font-weight:500;color:var(--primary-blue, #3D81DE);background:#f0f7ff;border:1px solid #c5ddf7;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease}.resource-download-btn:hover{background:#dbeafe;border-color:var(--primary-blue, #3D81DE);color:var(--primary-hover, #2a5ba8)}.resource-download-btn:active{transform:scale(.97)}.resource-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted, #94a3b8)}.resource-loading-spinner{width:36px;height:36px;border:3px solid var(--border-color, #e2e8f0);border-top-color:var(--primary-blue, #3D81DE);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.resource-loading p{font-size:.9rem}.resource-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.resource-empty-icon{margin-bottom:1.25rem;opacity:.6}.resource-empty-state h3{font-size:1.15rem;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:.5rem}.resource-empty-state p{font-size:.9rem;color:var(--text-muted, #94a3b8);margin-bottom:1.25rem;max-width:360px}.resource-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.resource-modal{background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgba(0, 0, 0, .1));width:520px;max-width:95vw;max-height:90vh;overflow-y:auto}.resource-modal-small{width:420px}.resource-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.resource-modal-header h2{font-size:1.2rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.resource-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted, #94a3b8);cursor:pointer;padding:.25rem;line-height:1;transition:color .15s ease}.resource-modal-close:hover{color:var(--text-primary, #1f2937)}.resource-modal-body{padding:1.5rem}.resource-modal-body p{font-size:.95rem;color:var(--text-secondary, #64748b);line-height:1.5}.resource-modal-form{padding:1.5rem}.resource-form-group{margin-bottom:1.15rem}.resource-form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937);margin-bottom:.4rem}.resource-form-group input[type=text],.resource-form-group textarea,.resource-form-group select{width:100%;padding:.55rem .75rem;font-size:.9rem;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);background:#fff;color:var(--text-primary, #1f2937);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.resource-form-group input[type=text]:focus,.resource-form-group textarea:focus,.resource-form-group select:focus{outline:none;border-color:var(--primary-blue, #3D81DE);box-shadow:0 0 0 2px #3d81de26}.resource-form-group textarea{resize:vertical;min-height:70px}.resource-file-input{width:100%;padding:.5rem;font-size:.875rem;border:1px dashed var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);background:var(--bg-gray-50, #f8f9fa);cursor:pointer}.resource-file-input:hover{border-color:var(--primary-blue, #3D81DE)}.resource-file-name{display:block;font-size:.8rem;color:var(--text-secondary, #64748b);margin-top:.35rem}.resource-form-error{display:block;font-size:.8rem;color:var(--error, #ef4444);margin-top:.3rem}.resource-form-hint{display:block;font-size:.8rem;color:var(--text-muted, #94a3b8);margin-top:.3rem;font-style:italic}.resource-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--border-color, #e2e8f0)}.resource-btn-cancel{padding:.55rem 1.15rem;font-size:.875rem;font-weight:500;color:var(--text-secondary, #64748b);background:#fff;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all .15s ease}.resource-btn-cancel:hover{background:var(--bg-gray-50, #f8f9fa);border-color:var(--border-gray, #cbd5e1)}.resource-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.resource-btn-submit{padding:.55rem 1.25rem;font-size:.875rem;font-weight:600;color:#fff;background:var(--primary-blue, #3D81DE);border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.resource-btn-submit:hover{background:var(--primary-hover, #2a5ba8)}.resource-btn-submit:disabled{opacity:.6;cursor:not-allowed}.resource-btn-delete{padding:.55rem 1.25rem;font-size:.875rem;font-weight:600;color:#fff;background:var(--error, #ef4444);border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:background-color .15s ease}.resource-btn-delete:hover{background:#dc2626}.resource-btn-delete:disabled{opacity:.6;cursor:not-allowed}@media(max-width:1024px){.resource-grid{grid-template-columns:repeat(2,1fr)}.category-manage-item-desc{max-width:180px}}@media(max-width:768px){.resource-center{padding:0 .5rem}.resource-header{flex-direction:column;gap:.75rem}.resource-header-actions{flex-wrap:wrap}.resource-header-left h1{font-size:1.4rem}.resource-grid{grid-template-columns:1fr}.resource-category-tabs{gap:.35rem}.resource-category-tab{padding:.35rem .75rem;font-size:.8rem}.category-manage-form-row{flex-direction:column;gap:.5rem}.category-manage-field-order{flex:1}.category-manage-item{flex-direction:column;align-items:flex-start;gap:.5rem}.category-manage-item-actions{margin-left:0}.category-manage-item-desc{max-width:100%}}@media(max-width:480px){.resource-modal{max-width:98vw}.resource-modal-header,.resource-modal-form,.resource-modal-body{padding:1rem}}.absence-excuses-page{max-width:900px;margin:0 auto}.absence-excuses-page .page-header{margin-bottom:1.5rem}.absence-excuses-page .page-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.absence-excuses-page .page-header p{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.excuse-tabs{display:flex;gap:2px;background:var(--bg-gray-100);border-radius:var(--radius-lg);padding:4px;margin-bottom:1.5rem}.excuse-tab{flex:1;padding:10px 16px;border:none;background:transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px}.excuse-tab:hover{color:var(--text-primary);background:#ffffff80}.excuse-tab.active{color:var(--primary-blue);background:#fff;font-weight:600;box-shadow:var(--shadow-sm)}.excuse-tab .tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--error);color:#fff;font-size:.7rem;font-weight:700}.excuse-card-list{display:flex;flex-direction:column;gap:10px}.excuse-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px 20px;transition:box-shadow .15s}.excuse-card:hover{box-shadow:var(--shadow-md)}.excuse-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.excuse-card-header h3{font-size:.95rem;font-weight:600;margin:0;color:var(--text-primary)}.excuse-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.excuse-card-meta span{display:inline-flex;align-items:center;gap:4px}.excuse-card-reason{font-size:.875rem;color:var(--text-primary);background:var(--bg-gray-50);padding:10px 14px;border-radius:var(--radius-md);margin-top:8px;line-height:1.5;border-left:3px solid var(--border-gray)}.excuse-card-admin-notes{font-size:.8rem;color:var(--text-secondary);margin-top:6px;font-style:italic}.excuse-status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:capitalize;letter-spacing:.02em}.excuse-status.pending{background:#fef9c3;color:#854d0e}.excuse-status.approved{background:#dcfce7;color:#166534}.excuse-status.denied,.excuse-status.absent{background:#fee2e2;color:#991b1b}.excuse-status.late{background:#fef9c3;color:#854d0e}.excuse-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:600;letter-spacing:.02em}.excuse-type-badge.acknowledgment{background:#dbeafe;color:#1e40af}.excuse-type-badge.pre_excuse{background:#ede9fe;color:#5b21b6}.excuse-form{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.excuse-form-section{padding:24px}.excuse-form-section+.excuse-form-section{border-top:1px solid var(--border-light)}.excuse-form-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:14px}.excuse-student-chips{display:flex;flex-wrap:wrap;gap:10px}.excuse-student-chip{position:relative;display:flex;align-items:center;gap:10px;padding:10px 18px;border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none;background:#fff}.excuse-student-chip:hover{border-color:var(--border-gray);background:var(--bg-gray-50)}.excuse-student-chip.selected{border-color:var(--primary-blue);background:#eff6ff}.excuse-student-chip input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.excuse-student-chip-check{width:20px;height:20px;border-radius:6px;border:2px solid var(--border-gray);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;font-size:.7rem;color:transparent;background:#fff}.excuse-student-chip.selected .excuse-student-chip-check{background:var(--primary-blue);border-color:var(--primary-blue);color:#fff}.excuse-student-chip-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap}.excuse-student-chip.selected .excuse-student-chip-name{color:var(--primary-blue-dark);font-weight:600}.excuse-date-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.excuse-field-group{display:flex;flex-direction:column;gap:6px}.excuse-field-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.excuse-field-hint{font-size:.75rem;color:var(--text-muted);font-weight:400;text-transform:none;letter-spacing:0}.excuse-form input[type=date],.excuse-form textarea{width:100%;padding:10px 14px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;color:var(--text-primary);background:#fff;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.excuse-form input[type=date]{height:42px;cursor:pointer}.excuse-form textarea{resize:vertical;min-height:100px;line-height:1.5}.excuse-form input[type=date]:focus,.excuse-form textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.excuse-form-footer{padding:20px 24px;background:var(--bg-gray-50);border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}.excuse-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.excuse-btn:disabled{opacity:.5;cursor:not-allowed}.excuse-btn-primary{background:var(--primary-blue);color:#fff}.excuse-btn-primary:hover:not(:disabled){background:var(--primary-blue-dark)}.excuse-btn-success{background:var(--success);color:#fff}.excuse-btn-success:hover:not(:disabled){background:#059669}.excuse-btn-danger{background:var(--error);color:#fff}.excuse-btn-danger:hover:not(:disabled){background:#dc2626}.excuse-btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-gray)}.excuse-btn-secondary:hover:not(:disabled){background:var(--bg-gray-50)}.excuse-btn-sm{padding:6px 14px;font-size:.8rem}.excuse-btn-lg{padding:12px 28px;font-size:.95rem}.excuse-card-actions{display:flex;gap:8px;margin-top:12px}.excuse-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;align-items:center}.excuse-filters select,.excuse-filters input{padding:8px 12px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;background:#fff;color:var(--text-primary);transition:border-color .15s}.excuse-filters select:focus,.excuse-filters input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.excuse-empty{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:.9rem}.excuse-empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}.acknowledge-inline-form{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);display:flex;gap:8px;align-items:flex-end}.acknowledge-inline-form textarea{flex:1;padding:10px 12px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;resize:none;height:42px;transition:border-color .15s}.acknowledge-inline-form textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.excuse-review-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.excuse-review-modal{background:#fff;border-radius:var(--radius-lg);padding:24px;width:480px;max-width:90vw;box-shadow:var(--shadow-xl)}.excuse-review-modal h2{font-size:1.1rem;font-weight:700;margin:0 0 16px;color:var(--text-primary)}.excuse-review-modal .form-group{margin-bottom:14px}.excuse-review-modal label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;color:var(--text-secondary)}.excuse-review-modal textarea{width:100%;padding:10px 12px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;resize:vertical;min-height:70px;box-sizing:border-box;transition:border-color .15s}.excuse-review-modal textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.excuse-review-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light)}.excuse-success-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);color:#166534;font-size:.875rem;font-weight:500}.excuse-success-banner-text{flex:1}.excuse-success-dismiss{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#166534;padding:0 4px;line-height:1;opacity:.6;transition:opacity .15s}.excuse-success-dismiss:hover{opacity:1}.excuse-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-secondary);font-size:.9rem}@media(max-width:600px){.excuse-date-row{grid-template-columns:1fr}.excuse-student-chips{flex-direction:column}.excuse-student-chip{width:100%}.excuse-tabs{flex-direction:column;gap:2px}}.ai-usage-log-page{padding:24px;max-width:1200px;margin:0 auto}.ai-usage-log-header h1{margin:0 0 4px;font-size:1.5rem;color:#1a3a52}.ai-usage-log-subtitle{color:#666;margin:0 0 20px;font-size:.9rem}.ai-usage-log-filters{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.ai-usage-log-filters .filter-group{display:flex;flex-direction:column;gap:4px}.ai-usage-log-filters .filter-group label{font-size:.8rem;font-weight:600;color:#555}.ai-usage-log-filters .filter-group select{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:.85rem;min-width:160px}.ai-usage-log-loading,.ai-usage-log-empty{text-align:center;padding:40px;color:#888;font-size:.95rem}.ai-usage-log-table-wrapper{overflow-x:auto}.ai-usage-log-table{width:100%;border-collapse:collapse;font-size:.85rem}.ai-usage-log-table thead th{background:#f5f7fa;padding:10px 12px;text-align:left;font-weight:600;color:#444;border-bottom:2px solid #e0e0e0;white-space:nowrap}.ai-usage-log-table tbody tr{border-bottom:1px solid #eee}.ai-usage-log-table tbody tr:hover{background:#f9fbfd}.ai-usage-log-table tbody td{padding:10px 12px;vertical-align:top}.log-date{white-space:nowrap;color:#555;font-size:.82rem}.log-pages{white-space:nowrap;text-align:center}.log-prompt{max-width:250px;color:#555}.log-no-prompt{color:#bbb}.log-type-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.78rem;font-weight:500;white-space:nowrap}.log-type-badge.type-pdf_quiz,.log-type-badge.type-pdf_assignment{background:#e8f4fd;color:#1a6fb5}.log-type-badge.type-in_house_quiz,.log-type-badge.type-in_house_assignment{background:#e8fde8;color:#2d8a2d}.log-type-badge.type-lesson_plan{background:#fdf3e8;color:#b56a1a}.ai-usage-log-count{margin-top:12px;text-align:right;color:#888;font-size:.82rem}@media(max-width:768px){.ai-usage-log-page{padding:16px}.ai-usage-log-filters{flex-direction:column}.ai-usage-log-filters .filter-group select{min-width:unset;width:100%}}.csv-import-container{max-width:800px;margin:0 auto;padding:24px}.csv-import-container h1{font-size:24px;font-weight:700;margin-bottom:8px;color:#1a1a2e}.csv-import-container .page-subtitle{color:#666;margin-bottom:32px;font-size:15px}.wizard-steps{display:flex;justify-content:space-between;margin-bottom:32px;position:relative}.wizard-steps:before{content:"";position:absolute;top:18px;left:10%;right:10%;height:2px;background:#e0e0e0;z-index:0}.wizard-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;z-index:1}.step-number{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;border:2px solid #e0e0e0;background:#fff;color:#999;margin-bottom:8px;transition:all .25s ease}.step-number.active{border-color:#1a73e8;background:#1a73e8;color:#fff}.step-number.completed{border-color:#34a853;background:#34a853;color:#fff}.step-label{font-size:12px;color:#999;text-align:center;white-space:nowrap;transition:color .25s ease}.wizard-step .step-label.active{color:#1a73e8;font-weight:600}.wizard-step .step-label.completed{color:#34a853}.wizard-content{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a;min-height:300px}.wizard-content h2{font-size:18px;font-weight:600;margin-bottom:4px;color:#1a1a2e}.wizard-content .step-description{color:#666;font-size:14px;margin-bottom:24px}.import-type-options{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.import-type-card{border:2px solid #e0e0e0;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;background:#fff;text-align:left}.import-type-card:hover{border-color:#90caf9;background:#fafbff}.import-type-card.selected{border-color:#1a73e8;background:#f0f7ff}.import-type-card .type-icon{font-size:28px;margin-bottom:8px}.import-type-card .type-name{font-weight:600;font-size:15px;color:#1a1a2e;margin-bottom:4px}.import-type-card .type-desc{font-size:13px;color:#666;line-height:1.4}.template-download-row{display:flex;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;background:#f8f9fa;border-radius:8px}.template-download-row span{font-size:14px;color:#555}.btn-template{padding:8px 16px;border:1px solid #1a73e8;background:#fff;color:#1a73e8;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.btn-template:hover{background:#e8f0fe}.upload-area{border:2px dashed #d0d0d0;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s ease;background:#fafafa}.upload-area:hover,.upload-area.dragover{border-color:#1a73e8;background:#f0f7ff}.upload-area .upload-icon{font-size:40px;margin-bottom:12px}.upload-area .upload-text{font-size:15px;color:#333;margin-bottom:4px}.upload-area .upload-hint{font-size:13px;color:#999}.selected-file{display:flex;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;background:#f0f7ff;border:1px solid #d0e3ff;border-radius:8px}.selected-file .file-icon{font-size:24px}.selected-file .file-info{flex:1}.selected-file .file-name{font-weight:600;color:#1a1a2e;font-size:14px}.selected-file .file-size{font-size:12px;color:#666}.selected-file .btn-remove-file{padding:4px 8px;border:none;background:transparent;color:#999;cursor:pointer;font-size:18px;line-height:1;border-radius:4px}.selected-file .btn-remove-file:hover{background:#fee;color:#ea4335}.upload-error{margin-top:12px;padding:10px 14px;background:#fff5f5;border:1px solid #fecaca;border-radius:8px;color:#c0392b;font-size:14px}.validation-status{text-align:center;padding:32px}.validation-status .status-icon{font-size:36px;margin-bottom:12px}.validation-status .status-text{font-size:16px;font-weight:500;color:#333}.validation-success{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f0faf0;border:1px solid #c8e6c9;border-radius:8px;margin-bottom:20px;color:#2e7d32;font-size:14px}.preview-section h3{font-size:15px;font-weight:600;margin-bottom:12px;color:#333}.preview-table-wrapper{overflow-x:auto;margin-bottom:16px}.preview-table{width:100%;border-collapse:collapse;font-size:13px}.preview-table th{background:#f8f9fa;padding:10px 12px;text-align:left;border-bottom:2px solid #e0e0e0;font-weight:600;color:#555;white-space:nowrap}.preview-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0;color:#333}.preview-table tr:hover{background:#fafbff}.preview-note{font-size:13px;color:#888;font-style:italic}.warning-list{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:16px;margin:16px 0}.warning-list h4{font-size:14px;font-weight:600;color:#92400e;margin-bottom:8px}.warning-list ul{list-style:none;padding:0;margin:0}.warning-list li{font-size:13px;color:#78350f;padding:4px 0 4px 20px;position:relative}.warning-list li:before{content:"!";position:absolute;left:0;top:4px;width:14px;height:14px;background:#f59e0b;color:#fff;font-size:10px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.error-list{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:16px;margin:16px 0}.error-list h4{font-size:14px;font-weight:600;color:#991b1b;margin-bottom:8px}.error-list ul{list-style:none;padding:0;margin:0;max-height:300px;overflow-y:auto}.error-list li{font-size:13px;color:#7f1d1d;padding:6px 0;border-bottom:1px solid #fee2e2}.error-list li:last-child{border-bottom:none}.error-row-num{font-weight:600;margin-right:6px}.error-field{color:#991b1b;font-weight:500;margin-right:4px}.process-summary{background:#f8f9fa;border-radius:8px;padding:20px 24px;margin-bottom:24px}.process-summary .summary-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}.process-summary .summary-label{color:#666}.process-summary .summary-value{font-weight:600;color:#1a1a2e}.process-progress{text-align:center;padding:32px}.process-progress .progress-bar-outer{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin:16px 0 8px}.process-progress .progress-bar-inner{height:100%;background:#1a73e8;border-radius:4px;transition:width .3s ease}.process-progress .progress-text{font-size:14px;color:#666}.result-summary{text-align:center;padding:32px 16px}.result-summary .result-icon{font-size:48px;margin-bottom:16px}.result-summary .result-title{font-size:20px;font-weight:700;margin-bottom:8px}.result-summary .result-detail{font-size:15px;color:#666;margin-bottom:4px}.result-success{color:#34a853}.result-partial{color:#f9a825}.result-errors{color:#ea4335}.error-table-section{margin-top:24px}.error-table-section h3{font-size:15px;font-weight:600;margin-bottom:12px;color:#333}.error-table{width:100%;border-collapse:collapse;font-size:13px}.error-table th{background:#fff5f5;padding:10px 12px;text-align:left;border-bottom:2px solid #fecaca;font-weight:600;color:#991b1b}.error-table td{padding:8px 12px;border-bottom:1px solid #fee2e2;color:#333}.wizard-actions{display:flex;justify-content:space-between;margin-top:24px;padding-top:16px;border-top:1px solid #f0f0f0}.wizard-actions .btn-back{padding:6px 16px;border:1px solid #d0d0d0;background:#fff;color:#555;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.wizard-actions .btn-back:hover{background:#f5f5f5}.wizard-actions .btn-next,.wizard-actions .btn-upload,.wizard-actions .btn-import{padding:6px 18px;border:none;background:#1a73e8;color:#fff;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:background .2s}.wizard-actions .btn-next:hover,.wizard-actions .btn-upload:hover,.wizard-actions .btn-import:hover{background:#1557b0}.wizard-actions .btn-next:disabled,.wizard-actions .btn-upload:disabled,.wizard-actions .btn-import:disabled{background:silver;cursor:not-allowed}.wizard-actions .btn-import{background:#34a853}.wizard-actions .btn-import:hover{background:#2d8f47}.wizard-actions .btn-restart{padding:6px 18px;border:1px solid #1a73e8;background:#fff;color:#1a73e8;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.wizard-actions .btn-restart:hover{background:#e8f0fe}.import-history-section{margin-top:40px}.history-toggle{display:flex;align-items:center;gap:8px;padding:12px 0;border:none;background:transparent;cursor:pointer;font-size:15px;font-weight:600;color:#1a73e8;width:100%;text-align:left}.history-toggle:hover{color:#1557b0}.history-toggle .toggle-arrow{font-size:12px;transition:transform .2s}.history-toggle .toggle-arrow.open{transform:rotate(90deg)}.history-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:13px;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.history-table th{background:#f8f9fa;padding:10px 12px;text-align:left;border-bottom:2px solid #e0e0e0;font-weight:600;color:#555}.history-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0;color:#333}.history-table tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.status-badge.completed{background:#e8f5e9;color:#2e7d32}.status-badge.failed{background:#ffebee;color:#c62828}.status-badge.processing{background:#e3f2fd;color:#1565c0}.status-badge.pending,.status-badge.validated{background:#fff8e1;color:#f57f17}.csv-spinner{display:inline-block;width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#1a73e8;border-radius:50%;animation:csv-spin .8s linear infinite;margin-bottom:12px}@keyframes csv-spin{to{transform:rotate(360deg)}}.confirm-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-dialog{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:90%;box-shadow:0 4px 20px #00000026}.confirm-dialog h3{margin-bottom:8px;font-size:16px;color:#1a1a2e}.confirm-dialog p{color:#666;font-size:14px;margin-bottom:20px}.confirm-dialog .confirm-actions{display:flex;justify-content:flex-end;gap:12px}.confirm-dialog .btn-cancel{padding:8px 16px;border:1px solid #d0d0d0;background:#fff;color:#555;border-radius:6px;cursor:pointer;font-size:14px}.confirm-dialog .btn-confirm{padding:8px 16px;border:none;background:#34a853;color:#fff;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600}.confirm-dialog .btn-confirm:hover{background:#2d8f47}.empty-history{text-align:center;padding:24px;color:#999;font-size:14px}@media(max-width:640px){.csv-import-container{padding:16px}.import-type-options{grid-template-columns:1fr}.wizard-content{padding:20px}.step-label{font-size:10px}.upload-area{padding:32px 16px}.wizard-actions{flex-direction:column;gap:10px}.wizard-actions .btn-back,.wizard-actions .btn-next,.wizard-actions .btn-upload,.wizard-actions .btn-import,.wizard-actions .btn-restart{width:100%;text-align:center}}.gradebook-page{width:100%;max-width:100%;padding:20px;box-sizing:border-box}.gradebook-categories{display:flex;flex-direction:column;gap:1.5rem}.category-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-light);overflow:hidden}.category-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-light)}.category-card-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .15s ease}.category-card-header.clickable:hover{opacity:.9}.header-left{display:flex;align-items:center;gap:.5rem}.expand-icon{display:inline-block;font-size:.75rem;transition:transform .2s ease;opacity:.8}.expand-icon.expanded{transform:rotate(90deg)}.category-card.collapsed .category-card-header{border-bottom:none}.category-card-header h3{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.category-card-header{background:#f8fafc;border-bottom:1px solid #e2e8f0}.category-card-header.clickable:hover{background:#f1f5f9}.category-card.collapsed .category-card-header{border-bottom:none;background:#f8fafc}.expand-icon{color:#64748b}.category-weight-badge{background:#e0e7ff;color:#3730a3;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;font-weight:600}.overall-grades-card .category-card-header{background:#eef2ff;border-bottom:1px solid #c7d2fe}.overall-grades-card .category-card-header h3{color:#3730a3}.category-card-body{padding:0}.category-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.category-table{width:100%;border-collapse:collapse;font-size:.875rem}.category-table thead{background:#fafbfc}.category-table th{padding:.625rem .875rem;text-align:left;font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.025em;color:#6b7280;border-bottom:1px solid #e5e7eb;white-space:nowrap}.category-table td{padding:.625rem .875rem;border-bottom:1px solid #f3f4f6;vertical-align:middle;color:#374151}.category-table tbody tr:hover{background:#fafbfc}.category-table tbody tr:last-child td{border-bottom:none}.category-table .totals-row{background:#f9fafb;border-top:2px solid #e5e7eb}.category-table .totals-row td{padding:.75rem .875rem;font-weight:600;color:#1f2937;border-bottom:none}.category-table .totals-row:hover{background:#f9fafb}.clickable-row{cursor:pointer;transition:background-color .1s ease}.clickable-row:hover{background:#f0f9ff!important}.empty-category{padding:2rem 1.5rem;text-align:center}.empty-category p{margin:0;color:#9ca3af;font-size:.9rem;font-style:italic}.empty-cell{color:#d1d5db;font-weight:300}.student-name-col{min-width:160px;font-weight:500;color:#1f2937}.item-name-col{min-width:180px;font-weight:500;color:#1f2937}.points-col{width:70px;text-align:center;color:#6b7280}.due-col{width:90px;text-align:center;color:#9ca3af;font-size:.8rem}.grade-col{width:90px;text-align:center}.details-col{min-width:100px}.student-grade-col{min-width:90px;text-align:center}.avg-col{width:70px;text-align:center;background:#fafbfc;font-weight:600;color:#374151}.actions-col{width:70px;text-align:center}.grade-value{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:500}.grade-value.grade-a{background:#d1fae5;color:#065f46}.grade-value.grade-b{background:#dbeafe;color:#1e40af}.grade-value.grade-c{background:#fef3c7;color:#92400e}.grade-value.grade-d{background:#fed7aa;color:#9a3412}.grade-value.grade-f{background:#fee2e2;color:#991b1b}.pending-grade{color:#b45309;font-style:italic;font-size:.8rem}.attendance-breakdown{display:flex;gap:.4rem;font-size:.8rem;font-weight:500}.att-present{color:#16a34a}.att-late{color:#ca8a04}.att-excused{color:#7c3aed}.category-average-row{background:#fafbfc!important}.category-average-row td{border-top:1px solid #e5e7eb;font-weight:600;color:#374151}.adj-btn{padding:.35rem .75rem;font-size:.8rem;border:1px solid #cbd5e1;border-radius:4px;background:#fff;color:#64748b;cursor:pointer;transition:all .15s ease}.adj-btn:hover{background:#f1f5f9;border-color:#94a3b8}.adj-btn.has-adj{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.adj-btn.has-adj:hover{background:#bfdbfe}.overall-grades-card{border:1px solid #c7d2fe}.weighted-breakdown-table .breakdown-col{min-width:110px;text-align:center;vertical-align:middle}.breakdown-header{display:flex;flex-direction:column;gap:1px}.breakdown-header .cat-name{font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.02em;color:#6b7280}.breakdown-header .cat-weight{font-weight:600;font-size:.7rem;color:#3730a3}.breakdown-cell{display:flex;flex-direction:column;align-items:center;gap:1px}.breakdown-score{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:3px;color:#1f2937}.breakdown-calc{font-size:.7rem;color:#9ca3af}.breakdown-calc strong{color:#6b7280}.adjustment-badge{font-size:.65rem;padding:1px 3px;border-radius:3px;font-weight:600}.adjustment-badge.positive{background:#dcfce7;color:#166534}.adjustment-badge.negative{background:#fef2f2;color:#b91c1c}.final-grade-col{min-width:90px;text-align:center;background:#fafbfc}.final-grade-col .final-grade{font-size:1rem}.no-data{color:#d1d5db}.dashboard-container.gradebook-page{max-width:100%}.gradebook-controls{width:100%;box-sizing:border-box;margin-bottom:0}.gradebook-container{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-light);width:100%;box-sizing:border-box;overflow:hidden}.gradebook-scroll{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 300px);width:100%;-webkit-overflow-scrolling:touch;padding-bottom:4px}.gradebook-scroll::-webkit-scrollbar{height:16px;width:16px}.gradebook-scroll::-webkit-scrollbar-track{background:#e2e8f0;border-radius:8px}.gradebook-scroll::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:8px;border:3px solid #e2e8f0;min-width:50px}.gradebook-scroll::-webkit-scrollbar-thumb:hover{background:#1d4ed8}.gradebook-table{width:max-content;border-collapse:separate;border-spacing:0}.gradebook-table thead{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-dark) 100%);color:#fff;position:sticky;top:0;z-index:20}.gradebook-table th,.gradebook-table td{padding:10px 12px;text-align:center;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light)}.gradebook-table th:last-child,.gradebook-table td:last-child{border-right:none}.item-column{text-align:left!important;min-width:220px;max-width:280px;white-space:nowrap;font-weight:600}.sticky-column{position:sticky;left:0;background:#fff;z-index:10;box-shadow:2px 0 4px #00000014}.gradebook-table thead .sticky-column{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-dark) 100%);z-index:25}.student-header-column{min-width:100px;max-width:140px}.student-header{display:flex;flex-direction:column;gap:2px}.student-name{font-weight:600;font-size:12px;white-space:normal;word-wrap:break-word;line-height:1.3}.category-header-row{background:#f1f5f9!important}.category-header{text-align:left!important;font-weight:700;font-size:13px;color:#1e40af;padding:10px 12px!important;background:#f1f5f9!important;border-bottom:2px solid #cbd5e1!important}.category-weight{font-weight:500;font-size:11px;color:#64748b;margin-left:8px}.item-row{transition:background-color .15s ease}.item-row:hover{background-color:#f8fafc}.item-row.manual-row:hover{background-color:#faf5ff}.item-label{text-align:left!important;background:#fff}.item-info{display:flex;flex-direction:column;gap:2px}.item-title{font-weight:500;font-size:13px;color:#1f2937}.item-meta{font-size:11px;color:#6b7280}.item-due{color:#9ca3af}.student-grade-row{background:#f0f9ff!important;border-top:2px solid #3b82f6!important}.student-grade-label{text-align:left!important;background:#f0f9ff!important;font-weight:700;color:#1e40af}.student-grade-cell{background:#f0f9ff;font-weight:600}.class-average{background:#dbeafe!important;color:#1e40af}.average-column{min-width:80px;background:#f9fafb;font-weight:600;color:#374151}.grade-cell{font-size:13px;line-height:1.3;position:relative;min-width:80px}.grade-percentage{font-size:10px;opacity:.75;margin-top:1px}.grade-a{background:#d1fae5;color:#065f46}.grade-b{background:#dbeafe;color:#1e40af}.grade-c{background:#fef3c7;color:#92400e}.grade-d{background:#fed7aa;color:#9a3412}.grade-f{background:#fee2e2;color:#991b1b}.pending{background:#fef3c7;color:#92400e;font-style:italic}.no-submission{background:#f9fafb;color:#9ca3af}.grade-legend{display:flex;flex-wrap:wrap;gap:20px;padding:10px 0}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:24px;height:24px;border-radius:4px;border:1px solid #e5e7eb}.attendance-cell{padding:8px!important}.attendance-row td{background:#10b9810d}.assignment-row td{background:#3b82f608}.quiz-row td{background:#8b5cf60d}.manual-row td{background:#8b5cf608}.empty-row td{background:#fafafa}@media(max-width:768px){.gradebook-page{padding:10px}.item-column{min-width:160px}.student-header-column{min-width:80px}.gradebook-table th,.gradebook-table td{padding:6px 8px;font-size:12px}.student-name{font-size:11px}.grade-cell{min-width:60px;font-size:11px}}.student-column{text-align:left!important;min-width:200px;max-width:250px;white-space:nowrap}.assignment-column{min-width:130px}.assignment-header{display:flex;flex-direction:column;gap:4px;padding:4px 0}.assignment-title{font-weight:600;font-size:13px;white-space:normal;word-wrap:break-word;line-height:1.3}.assignment-info{font-size:12px;opacity:.9}.assignment-average{font-size:11px;opacity:.8;font-style:italic}.quiz-column{background:#8b5cf61a}.quiz-badge{color:#a78bfa;font-weight:500}.attempt-count{font-size:10px;opacity:.7;margin-top:2px}.attendance-column{min-width:100px;background:#10b9811a}.attendance-rate{font-weight:600;font-size:14px}.attendance-details{display:flex;justify-content:center;gap:4px;margin-top:4px;font-size:10px;font-weight:500}.att-present{color:#059669}.att-late{color:#d97706}.att-absent{color:#dc2626}.att-excused{color:#6366f1}.manual-column{background:#8b5cf614}.manual-column:hover{background:#8b5cf626}.header-right{display:flex;align-items:center;gap:.75rem}.btn-add-item{padding:.35rem .75rem;font-size:.8rem;font-weight:500;border:1px solid #c7d2fe;border-radius:6px;background:#fff;color:#4f46e5;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn-add-item:hover{background:#eef2ff;border-color:#a5b4fc}.manual-category-card{border:1px solid #c7d2fe}.manual-category-card .category-card-header{background:#f5f3ff}.manual-category-card .category-card-header.clickable:hover{background:#ede9fe}.item-title-link{color:#4f46e5;cursor:pointer;text-decoration:none;transition:color .15s ease}.item-title-link:hover{color:#3730a3;text-decoration:underline}.inline-grade-cell{padding:.25rem!important}.inline-grade-cell.saving{opacity:.6}.inline-grade-wrapper{display:flex;align-items:center;justify-content:center;gap:2px;position:relative}.inline-grade-input{width:50px;padding:.3rem .25rem;font-size:.85rem;text-align:center;border:1px solid #e5e7eb;border-radius:4px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.inline-grade-input:focus{outline:none;border-color:#a5b4fc;box-shadow:0 0 0 2px #6366f11a}.inline-grade-input:hover:not(:focus):not(:disabled){border-color:#c7d2fe}.inline-grade-input:disabled{background:#f9fafb;cursor:not-allowed}.inline-grade-input::placeholder{color:#d1d5db}.inline-grade-input::-webkit-outer-spin-button,.inline-grade-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.inline-grade-input[type=number]{-moz-appearance:textfield}.inline-grade-max{font-size:.75rem;color:#9ca3af;white-space:nowrap}.saving-indicator{position:absolute;right:-16px;font-size:.7rem;color:#6366f1;animation:gradebook-pulse 1s infinite}@keyframes gradebook-pulse{0%,to{opacity:1}50%{opacity:.4}}.btn-sm{padding:.4rem .8rem;font-size:.8rem}.empty-category .btn-secondary{margin-top:.75rem}.manual-badge{display:inline-block;margin-left:.5rem;padding:.15rem .4rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:#f3e8ff;color:#7c3aed;border-radius:4px;vertical-align:middle}.manual-item-row{background:#8b5cf605}.manual-item-row:hover{background:#8b5cf60f!important}.delete-manual-item-btn{margin-left:.5rem;padding:.15rem .5rem;font-size:.75rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #fca5a5;border-radius:4px;cursor:pointer;transition:all .15s ease}.delete-manual-item-btn:hover{background:#fef2f2;border-color:#dc2626;color:#b91c1c}.delete-manual-item-btn:active{background:#fee2e2}.clickable-grade-cell{cursor:pointer;transition:background-color .15s ease;position:relative}.clickable-grade-cell:hover{background:#3b82f614!important}.clickable-grade-cell:active{background:#3b82f626!important}.clickable-grade-cell:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--primary-blue);opacity:0;transition:opacity .15s ease}.clickable-grade-cell:hover:after{opacity:.5}.modal-small{max-width:420px;width:95%}.adjustment-indicator{display:inline-block;margin-left:.35rem;padding:.1rem .3rem;font-size:.7rem;font-weight:600;border-radius:3px;vertical-align:middle}.adjustment-indicator.positive{background:#dcfce7;color:#16a34a}.adjustment-indicator.negative{background:#fef2f2;color:#dc2626}.gradebook-category-filter{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid var(--border-light);border-radius:var(--radius-lg);flex-wrap:wrap}.category-filter-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.category-filter-pills{display:flex;flex-wrap:wrap;gap:.375rem}.category-filter-pill{display:inline-flex;align-items:center;padding:.3rem .7rem;font-size:.78rem;font-weight:500;line-height:1.3;border:1px solid var(--border-gray);border-radius:999px;background:#fff;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.category-filter-pill:hover{border-color:var(--primary-blue-light);color:var(--primary-blue);background:#f0f7ff}.category-filter-pill.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.category-filter-pill.active:hover{background:var(--primary-blue-dark);border-color:var(--primary-blue-dark);color:#fff}@media(max-width:768px){.gradebook-category-filter{padding:.5rem .75rem;gap:.5rem}.category-filter-pill{padding:.25rem .55rem;font-size:.72rem}}.no-categories-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-lg);padding:1.5rem}.no-categories-content h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#92400e}.no-categories-content p{margin:0 0 1rem;font-size:.9rem;color:#78716c;line-height:1.5}.no-categories-actions{display:flex;gap:.75rem;flex-wrap:wrap}.no-categories-actions .btn-primary,.no-categories-actions .btn-secondary{padding:.5rem 1.25rem;font-size:.9rem}.juz-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:.5rem;margin:1rem 0}@media(max-width:768px){.juz-grid{grid-template-columns:repeat(6,1fr)}}@media(max-width:480px){.juz-grid{grid-template-columns:repeat(5,1fr)}}.juz-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md, 6px);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:2px solid transparent}.juz-cell:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.juz-cell.not-started{background:var(--bg-gray-100, #f3f4f6);color:var(--text-muted, #9ca3af);border-color:var(--border-light, #e5e7eb)}.juz-cell.memorizing{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#f59e0b}.juz-cell.awaiting-test{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#9a3412;border-color:#f97316}.juz-cell.in-sabaq-para{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-color:#3b82f6}.juz-cell.in-daur{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border-color:#22c55e}.juz-cell.memorized{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#10b981}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1.5rem}.quick-link-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-lg, 8px);text-decoration:none;color:var(--text-primary, #1f2937);transition:all .2s;cursor:pointer}.quick-link-card:hover{border-color:var(--primary-blue, #3b82f6);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-link-icon{font-size:2rem;margin-bottom:.75rem}.quick-link-title{font-weight:600;margin-bottom:.25rem}.quick-link-description{font-size:.875rem;color:var(--text-secondary, #6b7280);text-align:center}.unresolved-list{display:flex;flex-direction:column;gap:.75rem}.unresolved-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md, 6px)}.unresolved-info{display:flex;flex-direction:column;gap:.25rem}.unresolved-teacher{font-weight:600;color:var(--text-primary, #1f2937)}.unresolved-date{font-size:.875rem;color:var(--text-secondary, #6b7280)}.unresolved-reason{font-size:.875rem;color:#b91c1c}.teacher-toggle{display:flex;align-items:center;gap:.5rem}.toggle-switch{position:relative;width:48px;height:24px;background:var(--bg-gray-200, #e5e7eb);border-radius:12px;cursor:pointer;transition:background .2s}.toggle-switch.active{background:var(--primary-blue, #3b82f6)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch.active:after{transform:translate(24px)}.student-assignment-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-md, 6px);margin-bottom:.5rem}.student-assignment-info{display:flex;align-items:center;gap:1rem}.student-assignment-details h4{margin:0 0 .25rem;font-size:1rem}.student-assignment-details p{margin:0;font-size:.875rem;color:var(--text-secondary, #6b7280)}.coverage-card{background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-lg, 8px);padding:1.25rem;margin-bottom:1rem}.coverage-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-light, #e5e7eb)}.coverage-card-header h3{margin:0;font-size:1.125rem}.coverage-students-list{display:flex;flex-direction:column;gap:.5rem}.coverage-student-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-gray-50, #f9fafb);border-radius:var(--radius-md, 6px)}.hifz-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-gray-50, #f9fafb);border-radius:var(--radius-md, 6px);border:1px solid var(--border-light, #e5e7eb)}.hifz-filter-group{display:flex;align-items:center;gap:.5rem}.hifz-filter-group label{font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937)}.hifz-filter-group select{padding:.5rem;border:1px solid var(--border-gray, #d1d5db);border-radius:var(--radius-sm, 4px);font-size:.875rem;min-width:150px;background:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.5rem}.pagination button{padding:.5rem 1rem;border:1px solid var(--border-light, #e5e7eb);background:#fff;border-radius:var(--radius-md, 6px);cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){border-color:var(--primary-blue, #3b82f6);color:var(--primary-blue, #3b82f6)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination .page-info{padding:.5rem 1rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.alert{padding:1rem;border-radius:var(--radius-md, 6px);margin-bottom:1rem}.bulk-actions{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-gray-50, #f9fafb);border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-md, 6px);margin-bottom:1rem}.bulk-actions .selected-count{font-weight:500;color:var(--text-primary, #1f2937)}.data-table input[type=checkbox]{width:18px;height:18px;cursor:pointer}.juz-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--bg-gray-50, #f9fafb);border-radius:var(--radius-md, 6px)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.not-started{background:var(--bg-gray-100, #f3f4f6);border:1px solid var(--border-light, #e5e7eb)}.legend-color.memorizing{background:#fde68a}.legend-color.awaiting-test{background:#fed7aa}.legend-color.in-sabaq-para{background:#bfdbfe}.legend-color.in-daur{background:#bbf7d0}.legend-color.memorized{background:#a7f3d0}.hifz-table-container{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 1px 3px #0000000d}.hifz-student-table{width:100%;border-collapse:collapse}.hifz-student-table thead{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.hifz-student-table th{padding:1rem 1.25rem;text-align:left;font-weight:600;font-size:.8125rem;color:#475569;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0}.hifz-student-table tbody tr{transition:background-color .15s ease}.hifz-student-table tbody tr:hover{background-color:#f8fafc}.hifz-student-table tbody tr:not(:last-child){border-bottom:1px solid #f1f5f9}.hifz-student-table td{padding:1rem 1.25rem;vertical-align:middle}.hifz-student-cell-clickable{cursor:pointer;background:#f8fafc;transition:all .15s ease;border-radius:8px}.hifz-student-cell-clickable:hover{background:#dbeafe}.hifz-student-cell-clickable:hover .hifz-student-name{color:#1d4ed8}.hifz-student-cell{display:flex;align-items:center;gap:.875rem}.hifz-student-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.hifz-student-name-wrapper{display:flex;flex-direction:column;gap:.125rem}.hifz-student-name{font-weight:600;color:#1e40af;transition:color .15s ease}.hifz-method-badge{display:inline-block;font-size:.6875rem;font-weight:500;padding:.0625rem .375rem;border-radius:4px;width:fit-content}.hifz-method-badge-free{background:#f3e8ff;color:#7c3aed}.hifz-track-badges{display:flex;flex-wrap:wrap;gap:.375rem}.hifz-track-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.hifz-track-badge-empty{background:#f1f5f9;color:#94a3b8;border:1px dashed #cbd5e1}.hifz-track-badge-hifz{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border:1px solid #86efac}.hifz-track-badge-nazirah{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid #93c5fd}.hifz-track-badge-qaidah{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d}.hifz-teacher-name{font-weight:500;color:#1f2937}.hifz-unassigned-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.hifz-action-buttons{display:flex;gap:.5rem;flex-wrap:nowrap}.hifz-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;min-width:5.5rem;border-radius:6px;font-size:.8125rem;font-weight:500;border:none;cursor:pointer;transition:all .15s ease;white-space:nowrap}.hifz-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 1px 2px #3b82f64d}.hifz-btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 4px #3b82f666}.hifz-btn-secondary{background:#fff;color:#475569;border:1px solid #e2e8f0}.hifz-btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.hifz-btn-danger{background:#fff;color:#dc2626;border:1px solid #fecaca}.hifz-btn-danger:hover{background:#fef2f2;border-color:#f87171}.hifz-edit-profile-form{padding:.5rem 0}.hifz-section-title{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#1f2937}.hifz-section-description{margin:0 0 1rem;font-size:.875rem;color:#64748b}.hifz-track-section{margin-bottom:1.5rem;padding:1.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.hifz-track-toggle-group{display:flex;gap:.75rem}.hifz-track-toggle{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem;border-radius:10px;border:2px solid #e2e8f0;background:#fff;cursor:pointer;transition:all .2s ease;position:relative}.hifz-track-toggle:hover{border-color:#94a3b8;background:#f8fafc}.hifz-track-toggle.active{border-color:#22c55e;background:linear-gradient(135deg,#dcfce7,#f0fdf4);box-shadow:0 0 0 3px #22c55e26}.hifz-track-toggle-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;margin-bottom:.5rem;background:#e2e8f0;color:transparent;transition:all .2s ease}.hifz-track-toggle.active .hifz-track-toggle-icon{background:#22c55e;color:#fff}.hifz-track-toggle-label{font-weight:600;font-size:.9375rem;color:#1f2937;margin-bottom:.125rem}.hifz-track-toggle-desc{font-size:.75rem;color:#64748b}.hifz-track-toggle.active .hifz-track-toggle-label{color:#166534}.hifz-track-toggle.active .hifz-track-toggle-desc{color:#15803d}.hifz-position-section{margin-bottom:1.5rem;padding:1.25rem;border-radius:12px;border:1px solid}.hifz-position-hifz{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.hifz-position-nazirah{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.hifz-position-grid{display:grid;grid-template-columns:80px 1fr 80px;gap:1rem;align-items:end}@media(max-width:600px){.hifz-position-grid{grid-template-columns:1fr}}.hifz-form-group{display:flex;flex-direction:column;gap:.375rem}.hifz-form-group label{font-size:.8125rem;font-weight:500;color:#475569}.hifz-select{padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;background:#fff;color:#1f2937;transition:border-color .15s ease,box-shadow .15s ease}.hifz-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.hifz-select:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.hifz-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.25rem;margin-top:.5rem;border-top:1px solid #e2e8f0}.hifz-modal-footer .hifz-btn{padding:.625rem 1.25rem}.hifz-modal-footer .hifz-btn-primary:disabled{opacity:.6;cursor:not-allowed}.hifz-add-student-form{padding:.5rem 0}.hifz-student-selection-section{margin-top:1.5rem;padding:1.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.hifz-student-selection-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.hifz-student-search-inline{width:200px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:border-color .15s ease,box-shadow .15s ease}.hifz-student-search-inline:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.hifz-student-cards-container{max-height:320px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:10px;background:#fff;padding:.75rem}.hifz-student-cards-loading,.hifz-student-cards-empty{padding:2rem;text-align:center;color:#64748b;font-size:.875rem}.hifz-student-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.625rem}.hifz-student-card{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .15s ease;text-align:left}.hifz-student-card:hover{border-color:#94a3b8;background:#fff}.hifz-student-card.active{border-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 0 0 2px #22c55e26}.hifz-student-card-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;flex-shrink:0}.hifz-student-card.active .hifz-student-card-avatar{background:linear-gradient(135deg,#22c55e,#16a34a)}.hifz-student-card-name{flex:1;font-weight:500;font-size:.8125rem;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hifz-student-card.active .hifz-student-card-name{color:#166534}.hifz-student-card-check{width:20px;height:20px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;color:transparent;flex-shrink:0;transition:all .15s ease}.hifz-student-card.active .hifz-student-card-check{background:#22c55e;color:#fff}.hifz-assign-form{padding:.5rem 0}.hifz-assign-student-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:10px;margin-bottom:1.5rem}.hifz-assign-student-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.hifz-assign-student-name{font-weight:600;font-size:1.0625rem;color:#1f2937}.hifz-assign-current-teacher{font-size:.875rem;color:#64748b;margin-top:.125rem}.hifz-teacher-section{padding:1.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.hifz-teacher-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.hifz-teacher-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s ease;text-align:left}.hifz-teacher-card:hover{border-color:#94a3b8;background:#fafafa}.hifz-teacher-card.active{border-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 0 0 3px #22c55e26}.hifz-teacher-card-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.hifz-teacher-card.active .hifz-teacher-card-avatar{background:linear-gradient(135deg,#22c55e,#16a34a)}.hifz-teacher-card-info{flex:1;min-width:0}.hifz-teacher-card-name{font-weight:600;font-size:.9375rem;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hifz-teacher-card.active .hifz-teacher-card-name{color:#166534}.hifz-teacher-card-count{font-size:.8125rem;color:#64748b;margin-top:.125rem}.hifz-teacher-card.active .hifz-teacher-card-count{color:#15803d}.hifz-teacher-card-check{width:24px;height:24px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:transparent;flex-shrink:0;transition:all .2s ease}.hifz-teacher-card.active .hifz-teacher-card-check{background:#22c55e;color:#fff}.hifz-no-teachers{text-align:center;color:#64748b;font-size:.875rem;padding:2rem}.hifz-remove-confirm{padding:1.5rem;text-align:center}.hifz-remove-warning-icon{width:56px;height:56px;margin:0 auto 1rem;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center}.hifz-remove-warning-icon span{font-size:1.75rem;font-weight:700;color:#dc2626}.hifz-remove-message{font-size:1rem;color:#1f2937;margin-bottom:.75rem}.hifz-remove-message strong{color:#111827}.hifz-remove-note{font-size:.875rem;color:#6b7280;background:#f9fafb;padding:.75rem;border-radius:6px;margin-top:.5rem}.teacher-attendance-list{display:flex;flex-direction:column;gap:.5rem}.teacher-attendance-card{background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-md, 6px);overflow:hidden}.teacher-attendance-row{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem}.teacher-entry-breakdown{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem .75rem;border-top:1px solid var(--border-light, #e5e7eb);background:var(--bg-secondary, #f9fafb)}.entry-type-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:10px;font-size:.75rem;font-weight:600;background:#eef2ff;color:#4338ca}.entry-type-badge.entry-type-zero{background:#f3f4f6;color:#9ca3af}.teacher-att-name{flex:1;font-weight:600;color:var(--text-primary, #1f2937);min-width:0}.teacher-att-status{flex-shrink:0}.att-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.att-confirmed{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.att-late{background:#fef3c7;color:#92400e;border:1px solid #fde68a;cursor:help}.att-not-confirmed{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.teacher-att-students,.teacher-att-entries{font-size:.875rem;color:var(--text-secondary, #6b7280);white-space:nowrap}@media(max-width:640px){.teacher-attendance-row{flex-wrap:wrap;gap:.5rem}.teacher-att-name{width:100%}.teacher-entry-breakdown{gap:.375rem}.entry-type-badge{font-size:.6875rem}}.hifz-date-picker-wrapper{display:flex;align-items:center}.hifz-date-input{padding:.5rem .75rem;border:1px solid var(--border-gray, #d1d5db);border-radius:var(--radius-md, 6px);font-size:.875rem;background:#fff;color:var(--text-primary, #1f2937);cursor:pointer}.hifz-date-input:focus{outline:none;border-color:var(--primary-blue, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.hifz-empty-state{padding:2rem;text-align:center;color:var(--text-secondary, #6b7280);background:var(--bg-gray-50, #f9fafb);border-radius:var(--radius-md, 6px);border:1px dashed var(--border-light, #e5e7eb)}.hifz-empty-state p{margin:0;font-size:.9375rem}.hifz-view-all-link{font-size:.875rem;font-weight:500;color:var(--primary-blue, #3b82f6);text-decoration:none;transition:color .15s ease}.hifz-view-all-link:hover{color:#1d4ed8;text-decoration:underline}.testing-banner{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fbbf24;border-radius:var(--radius-md, 6px);padding:1rem 1.25rem}.testing-banner-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.testing-banner-icon{font-size:1.5rem;line-height:1;flex-shrink:0}.testing-banner-title{font-weight:600;font-size:1rem;color:#92400e}.testing-banner-subtitle{font-size:.8125rem;color:#a16207;margin-top:.125rem;line-height:1.4}.readiness-badge{display:inline-block;padding:.125rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600;margin-left:.5rem}.readiness-badge.ready{background:#d1fae5;color:#065f46}.readiness-badge.not_ready{background:#fee2e2;color:#991b1b}.testing-banner-actions{display:flex;gap:.5rem;flex-wrap:wrap}.testing-btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem;transition:opacity .15s}.testing-btn:disabled{opacity:.6;cursor:not-allowed}.testing-btn-ready{background:#10b981;color:#fff}.testing-btn-ready:hover:not(:disabled){background:#059669}.testing-btn-complete{background:#3b82f6;color:#fff}.testing-btn-complete:hover:not(:disabled){background:#2563eb}.testing-btn-not-ready{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.testing-btn-not-ready:hover:not(:disabled){background:#e5e7eb}.testing-form{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.testing-form-row{display:flex;gap:1rem;align-items:flex-start;margin-bottom:.75rem}.testing-form-row .rating-group{flex:1 1 0%;border-left:2px solid var(--border-gray, #e5e7eb);padding-left:1rem}.testing-form-row .result-group{flex:0 0 auto}.testing-form .form-group{margin-bottom:.75rem}.testing-form-actions{display:flex;gap:.5rem;margin-top:.75rem}.pass-fail-toggle{display:flex;gap:.5rem}.toggle-btn{padding:.5rem 1.5rem;border:2px solid var(--border-gray, #d1d5db);background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.toggle-btn.active.pass{background:#d1fae5;border-color:#10b981;color:#065f46}.toggle-btn.active.fail{background:#fee2e2;border-color:#dc2626;color:#991b1b}.rating-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.rating-btn{padding:.5rem 1rem;border:2px solid var(--border-gray, #d1d5db);background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.rating-btn:hover{border-color:var(--primary-blue, #3b82f6)}.rating-btn.active.perfect{background:#d1fae5;border-color:#10b981;color:#065f46}.rating-btn.active.good{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.rating-btn.active.acceptable{background:#fef3c7;border-color:#f59e0b;color:#92400e}.rating-btn.active.poor{background:#fee2e2;border-color:#dc2626;color:#991b1b}.juz-skip-section{border-top:1px solid #e5e7eb;padding-top:.625rem;margin-top:.75rem}.juz-skip-toggle{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.8125rem;text-decoration:underline;padding:0}.juz-skip-toggle:hover{color:#374151}.juz-skip-form{margin-top:.625rem;display:flex;flex-direction:column;gap:.5rem}.juz-skip-form .form-group{margin-bottom:0}.juz-skip-form select{width:100%}.juz-action-btn{width:100%;padding:.75rem 1rem;font-size:.9375rem;border-radius:8px;cursor:pointer;font-weight:500;text-align:center}.juz-action-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.testing-banner-actions,.testing-form-row{flex-direction:column}.testing-form-row .rating-group{border-left:none;padding-left:0;border-top:2px solid var(--border-gray, #e5e7eb);padding-top:.75rem}.rating-buttons{flex-wrap:wrap}.rating-btn{flex:1;min-width:0;text-align:center}}.weekly-page-title{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1e293b);margin:0 0 1rem}.weekly-page-subtitle{display:block;font-size:.8125rem;font-weight:400;color:var(--text-secondary, #64748b);margin-top:.125rem}.weekly-header-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;border-bottom:1px solid #e5e7eb}.weekly-header-bar-left{display:flex;align-items:center;gap:.75rem;min-width:0}.weekly-header-back{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:10px;background:#f3f4f6;cursor:pointer;color:#4b5563;flex-shrink:0;transition:background .15s,color .15s;padding:0;line-height:0}.weekly-header-back:hover{background:#e5e7eb;color:#111827}.weekly-header-avatar{width:44px;height:44px;border-radius:50%;background:#16a34a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0;text-transform:uppercase}.weekly-header-bar-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.weekly-header-bar-name{font-size:1.125rem;font-weight:700;color:#1f2937;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weekly-header-bar-track{font-size:.8125rem;color:#6b7280;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weekly-header-bar-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.weekly-header-bar-nav{display:flex;align-items:center;gap:0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.weekly-header-nav-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:36px;border:none;background:transparent;cursor:pointer;font-size:1.25rem;color:#6b7280;transition:background .15s,color .15s;flex-shrink:0}.weekly-header-nav-arrow:hover{background:#f3f4f6;color:#1f2937}.weekly-header-nav-range{padding:.375rem .75rem;font-size:.875rem;font-weight:600;color:#1f2937;cursor:pointer;white-space:nowrap;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb;transition:color .15s}.weekly-header-nav-range:hover{color:#3b82f6}.weekly-header-edit-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.weekly-header-edit-btn:hover{background:#2563eb}.weekly-nav{display:flex;align-items:center;justify-content:center;gap:0;border:1px solid #e5e7eb;border-radius:10px;background:#fff;margin-bottom:1.25rem;overflow:hidden}.weekly-nav-arrow{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;cursor:pointer;font-size:1.5rem;color:#6b7280;transition:background .15s,color .15s;flex-shrink:0}.weekly-nav-arrow:hover{background:#f3f4f6;color:#1f2937}.weekly-nav-range{flex:1;text-align:center;padding:.5rem 1rem;font-size:.9375rem;font-weight:600;color:#1f2937;cursor:pointer;white-space:nowrap;transition:color .15s}.weekly-nav-range:hover{color:#3b82f6}.weekly-unified-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.testing-banners-container{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem;border-bottom:1px solid #e5e7eb}.weekly-stats-bar{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;padding:1rem;border-bottom:1px solid #e5e7eb}.weekly-stat-card{display:flex;flex-direction:column;align-items:center;padding:.75rem .25rem;border-radius:10px;border:1px solid transparent;transition:box-shadow .15s,transform .15s}.weekly-stat-card:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.weekly-stat-value{font-size:1.375rem;font-weight:700;line-height:1;margin-bottom:.25rem}.weekly-stat-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.weekly-stat-days{background:#f1f5f9;border-color:#e2e8f0}.weekly-stat-days .weekly-stat-value{color:#475569}.weekly-stat-days .weekly-stat-label{color:#64748b}.weekly-stat-pass{background:#f0fdf4;border-color:#bbf7d0}.weekly-stat-pass .weekly-stat-value{color:#16a34a}.weekly-stat-pass .weekly-stat-label{color:#15803d}.weekly-stat-fail{background:#fef2f2;border-color:#fecaca}.weekly-stat-fail .weekly-stat-value{color:#dc2626}.weekly-stat-fail .weekly-stat-label{color:#b91c1c}.weekly-stat-memorized{background:#eef2ff;border-color:#c7d2fe}.weekly-stat-memorized .weekly-stat-value{color:#4f46e5}.weekly-stat-memorized .weekly-stat-label{color:#4338ca}.weekly-stat-perfect{background:#f0fdfa;border-color:#99f6e4}.weekly-stat-perfect .weekly-stat-value{color:#0d9488}.weekly-stat-perfect .weekly-stat-label{color:#0f766e}.weekly-stat-good{background:#f0f9ff;border-color:#bae6fd}.weekly-stat-good .weekly-stat-value{color:#0284c7}.weekly-stat-good .weekly-stat-label{color:#0369a1}.weekly-stat-acceptable{background:#fffbeb;border-color:#fde68a}.weekly-stat-acceptable .weekly-stat-value{color:#d97706}.weekly-stat-acceptable .weekly-stat-label{color:#b45309}.weekly-stat-poor{background:#fff1f2;border-color:#fecdd3}.weekly-stat-poor .weekly-stat-value{color:#e11d48}.weekly-stat-poor .weekly-stat-label{color:#be123c}.weekly-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.weekly-grid-table{width:100%;border-collapse:collapse;min-width:800px;background:#fff}.weekly-grid-table thead{background:#f9fafb}.weekly-grid-day-header{padding:.375rem .5rem;text-align:center;vertical-align:middle;border-bottom:1px solid #e5e7eb;border-right:1px solid #f3f4f6;min-width:100px}.weekly-grid-day-header:last-child{border-right:none}.weekly-grid-day-today{background:#22c55e0d}.weekly-col-day{display:block;font-size:.625rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.125rem}.weekly-col-num{display:inline-flex;align-items:center;justify-content:center;font-size:.9375rem;font-weight:700;color:#1f2937;width:26px;height:26px;border-radius:50%;line-height:1}.weekly-col-num-today{background:#22c55e;color:#fff}.weekly-today-label{display:block;font-size:.5625rem;font-weight:700;color:#22c55e;text-transform:uppercase;letter-spacing:.06em;margin-top:.125rem}.weekly-att-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-top:.25rem}.weekly-att-present{background:#22c55e}.weekly-att-absent{background:#ef4444}.weekly-att-late{background:#f59e0b}.weekly-att-excused{background:#3b82f6}.weekly-cell-type-label{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem;font-size:.8125rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.02em}.weekly-type-dot{position:relative;width:8px;height:8px;border-radius:50%;flex-shrink:0}.weekly-type-dot:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:4px}.weekly-dot-new{background:#22c55e}.weekly-dot-new:before{background:#22c55e26}.weekly-dot-revision{background:#3b82f6}.weekly-dot-revision:before{background:#3b82f626}.weekly-grid-cell{padding:.75rem;vertical-align:top;height:180px;border-right:1px solid #f3f4f6;border-bottom:1px solid #e5e7eb}.weekly-grid-row{height:auto}.weekly-grid-cell:last-child{border-right:none}.weekly-grid-cell-today{background:#22c55e0d}.weekly-grid-row:last-child .weekly-grid-cell{border-bottom:none}.weekly-cell-entries{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.weekly-entry-card{padding:.5rem .625rem;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;transition:opacity .15s,transform .1s;min-height:36px}.weekly-entry-card:hover{opacity:.85;transform:scale(1.02)}.weekly-entry-pass{background:#dcfce7;border-left:3px solid #22c55e}.weekly-entry-fail{background:#fee2e2;border-left:3px solid #ef4444}.weekly-entry-pending{background:#f3f4f6;border-left:3px solid #9ca3af}.weekly-entry-revision-pass{background:#dbeafe;border-left:3px solid #3b82f6}.weekly-entry-revision-fail{background:#fee2e2;border-left:3px solid #ef4444}.weekly-entry-revision-pending{background:#eff6ff;border-left:3px solid #93c5fd}.weekly-entry-label{font-size:.8125rem;font-weight:500;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.weekly-entry-badges{display:flex;flex-wrap:wrap;gap:.1875rem}.weekly-entry-badge{display:inline-block;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.125rem .375rem;border-radius:3px;width:fit-content}.weekly-badge-pass{background:#166534;color:#fff}.weekly-badge-fail{background:#991b1b;color:#fff}.weekly-badge-revision-pass{background:#1d4ed8;color:#fff}.weekly-badge-revision-fail{background:#991b1b;color:#fff}.weekly-badge-perfect{background:#0d9488;color:#fff}.weekly-badge-good{background:#0284c7;color:#fff}.weekly-badge-acceptable{background:#d97706;color:#fff}.weekly-badge-poor{background:#e11d48;color:#fff}.weekly-cell-add{width:100%;padding:.25rem 0;border:1px dashed #d1d5db;background:transparent;border-radius:4px;font-size:.875rem;color:#9ca3af;cursor:pointer;transition:all .15s}.weekly-cell-add:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.weekly-legend{display:flex;justify-content:center;gap:.75rem;padding:.875rem 1rem;border-top:1px solid #e5e7eb}.weekly-legend-pill{font-size:.75rem;font-weight:600;padding:.3rem .875rem;border-radius:20px}.weekly-legend-pass{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.weekly-legend-revision{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.weekly-legend-fail{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.weekly-legend-pending{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.weekly-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:.75rem;overflow:hidden}.weekly-section-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;border:none;background:transparent;cursor:pointer;transition:background .15s;font-family:inherit}.weekly-section-toggle:hover{background:#f9fafb}.weekly-section-title{font-size:1.0625rem;font-weight:600;color:#1f2937}.weekly-section-arrow{font-size:.75rem;color:#9ca3af}.weekly-section-body{padding:0 1.25rem 1.25rem}.weekly-juz-summary{margin-left:.75rem;font-size:.8125rem;font-weight:400;color:#6b7280}.weekly-juz-grid-compact{display:grid;grid-template-columns:repeat(15,1fr);gap:3px;margin-bottom:.5rem}@media(max-width:768px){.weekly-juz-grid-compact{grid-template-columns:repeat(10,1fr)}}.weekly-juz-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-weight:600;font-size:.625rem;cursor:default;max-width:32px}.weekly-juz-not-started{background:#f3f4f6;color:#9ca3af}.weekly-juz-in-progress{background:#fef3c7;color:#92400e}.weekly-juz-awaiting-test{background:#fed7aa;color:#9a3412}.weekly-juz-memorized{background:#d1fae5;color:#065f46}.weekly-juz-legend{display:flex;flex-wrap:wrap;gap:1rem;font-size:.6875rem;color:#6b7280}.weekly-juz-legend-item{display:flex;align-items:center;gap:.25rem}.weekly-juz-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.weekly-juz-legend-dot.weekly-juz-not-started{background:#f3f4f6;border:1px solid #d1d5db}.weekly-juz-legend-dot.weekly-juz-in-progress{background:#fde68a}.weekly-juz-legend-dot.weekly-juz-awaiting-test{background:#fdba74}.weekly-juz-legend-dot.weekly-juz-memorized{background:#a7f3d0}@media(max-width:768px){.weekly-header-bar{flex-direction:column;align-items:stretch;gap:.75rem}.weekly-header-bar-right{justify-content:space-between;width:100%}.weekly-stats-bar{grid-template-columns:repeat(4,1fr)}.weekly-grid-table{min-width:800px}}@media(max-width:480px){.weekly-header-bar{padding:.625rem .75rem}.weekly-header-bar-right{flex-direction:column;align-items:stretch;gap:.5rem}.weekly-header-bar-nav{justify-content:center}.weekly-header-edit-btn{text-align:center}.weekly-header-bar-name{font-size:1rem}.weekly-stats-bar{grid-template-columns:repeat(2,1fr)}.weekly-header-nav-range{font-size:.8125rem}}.weekly-grid-day-holiday{background:#f8f5e6}.weekly-holiday-label{display:block;font-size:.65rem;color:#b8860b;font-weight:600;text-transform:uppercase;letter-spacing:.02em;margin-top:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.weekly-grid-cell-holiday{background:#fdf8e8!important;opacity:.85}.form-container{max-width:900px;margin:0 auto;padding:20px}.form-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.form-header h1{margin:0;font-size:1.35rem;font-weight:700;color:var(--text-primary)}.form{background:#fff;border-radius:8px}.form-section{background:#fff;border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.form-section h2{margin-top:0;margin-bottom:20px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{margin:0;border:none;padding:0}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:6px;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group input[type=date],.form-group input[type=file],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:14px;transition:border-color .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc2626}.form-help{display:block;font-size:12px;color:var(--gray-500, #6b7280);margin-top:4px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.checkbox-group label{display:flex;align-items:center;cursor:pointer;font-weight:400}.checkbox-group input[type=checkbox]{width:auto;margin-right:8px;cursor:pointer}.error-message{display:block;color:#dc2626;font-size:12px;margin-top:4px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid var(--gray-200, #e5e7eb);margin-top:24px}.btn-primary,.btn-secondary,.btn-danger,.btn-small,.btn-link{padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-size:14px}.btn-primary{background:var(--primary-color, #4f46e5);color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--gray-700, #374151);border:1px solid var(--gray-300, #d1d5db)}.btn-secondary:hover:not(:disabled){background:var(--gray-50, #f9fafb)}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-small{padding:6px 12px;font-size:13px}.btn-link{background:transparent;color:var(--primary-color, #4f46e5);padding:0}.btn-large{padding:14px 28px;font-size:16px}.question-box{background:var(--gray-50, #f9fafb);border:1px solid var(--gray-200, #e5e7eb);border-radius:8px;padding:20px;margin-bottom:20px}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.question-header h3{margin:0;font-size:1.1rem}.btn-danger-small{background:#dc2626;color:#fff;padding:6px 12px;border-radius:6px;border:none;cursor:pointer;font-size:13px}.btn-danger-small:hover{background:#b91c1c}.quiz-timer{position:sticky;top:0;background:var(--primary-color, #4f46e5);color:#fff;padding:12px;text-align:center;font-weight:600;z-index:100;box-shadow:0 2px 4px #0000001a}.quiz-timer.timer-warning{background:#dc2626;animation:form-pulse 1s infinite}@keyframes form-pulse{0%,to{opacity:1}50%{opacity:.8}}.quiz-form{max-width:800px;margin:0 auto}.question-card{margin-bottom:24px}.question-text{font-size:1.1rem;font-weight:500;margin-bottom:16px;color:var(--gray-900, #111827)}.question-points{background:var(--primary-color, #4f46e5);color:#fff;padding:4px 12px;border-radius:12px;font-size:13px}.options-list{display:flex;flex-direction:column;gap:12px}.option-label{display:flex;align-items:center;padding:12px;border:2px solid var(--gray-200, #e5e7eb);border-radius:8px;cursor:pointer;transition:all .2s}.option-label:hover{background:var(--gray-50, #f9fafb);border-color:var(--primary-color, #4f46e5)}.option-label input[type=radio]{margin-right:12px;width:18px;height:18px;cursor:pointer}.answer-textarea{width:100%;min-height:120px;padding:12px;border:1px solid var(--gray-300, #d1d5db);border-radius:8px;font-size:14px;resize:vertical;font-family:inherit}.quiz-progress{text-align:center;margin-bottom:20px;font-size:1.1rem;font-weight:500;color:var(--gray-700, #374151)}.question-review{margin-bottom:20px;border-left:4px solid var(--gray-300, #d1d5db)}.question-review.correct{border-left-color:#10b981;background:#f0fdf4}.question-review.incorrect{border-left-color:#dc2626;background:#fef2f2}.question-review.manual{border-left-color:#f59e0b;background:#fffbeb}.question-review-header{display:flex;justify-content:space-between;align-items:center}.badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.answer-section{margin-top:16px;padding:12px;background:#fff;border-radius:6px}.answer-row{margin-bottom:8px}.answer-row strong{display:block;margin-bottom:4px}.text-danger{color:#dc2626}.text-success{color:#10b981}.grade-input-group{display:flex;align-items:center;gap:16px}.grade-input-group input{flex:1}.grade-display{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--gray-100, #f3f4f6);border-radius:6px}.percentage{font-size:1.2rem;font-weight:600;color:var(--primary-color, #4f46e5)}.letter-grade{font-size:1.2rem;font-weight:700;color:var(--gray-900, #111827)}.quick-feedback{margin-top:16px;padding:16px;background:var(--gray-50, #f9fafb);border-radius:8px}.template-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.grade-display-large{text-align:center;padding:30px;background:var(--primary-color, #4f46e5);color:#fff;border-radius:12px;margin-bottom:20px}.grade-score{font-size:3rem;font-weight:700}.grade-percentage{font-size:1.5rem;margin-top:8px;opacity:.9}.feedback-box{padding:16px;background:var(--gray-50, #f9fafb);border-radius:8px;margin-top:8px;white-space:pre-wrap}.graded-date{margin-top:16px;font-size:14px;color:var(--gray-600, #4b5563)}.attendance-row{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--gray-200, #e5e7eb)}.attendance-row:last-child{border-bottom:none}.student-info strong{display:block;margin-bottom:4px}.student-info small{color:var(--gray-500, #6b7280)}.attendance-buttons{display:flex;gap:8px}.attendance-btn{padding:8px 16px;border:2px solid var(--gray-200, #e5e7eb);background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;font-size:13px;font-weight:500}.attendance-btn:hover{background:var(--gray-50, #f9fafb)}.attendance-btn.active{font-weight:600}.attendance-btn.active.present{background:#d1fae5;border-color:#10b981;color:#065f46}.attendance-btn.active.absent{background:#fee2e2;border-color:#dc2626;color:#991b1b}.attendance-btn.active.late{background:#fef3c7;border-color:#f59e0b;color:#92400e}.attendance-btn.active.excused{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.attendance-btn.active.not-taken{background:#f3f4f6;border-color:#9ca3af;color:#4b5563}.status-not-taken{background:#f3f4f6;color:#4b5563}.quick-actions-row{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-200, #e5e7eb)}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:20px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item strong{color:var(--gray-600, #4b5563);font-size:13px}.info-item span{color:var(--gray-900, #111827);font-size:15px}.instructions-box{padding:16px;background:var(--gray-50, #f9fafb);border-left:4px solid var(--primary-color, #4f46e5);border-radius:4px;margin-top:8px;white-space:pre-wrap}.content-box{padding:16px;background:var(--gray-50, #f9fafb);border-radius:8px;margin-top:8px;white-space:pre-wrap;font-family:inherit}.grade-feedback{border-left:4px solid #10b981}.feedback-section{margin-top:20px}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-warning{background:#fef3c7;border:1px solid #f59e0b;color:#92400e}.alert-danger,.alert-error{background:#fee2e2;border:1px solid #dc2626;color:#991b1b}.alert-success{background:#d1fae5;border:1px solid #10b981;color:#065f46}.alert-info{background:#dbeafe;border:1px solid #3b82f6;color:#1e40af}.file-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:28px 16px;border:2px dashed var(--border-gray);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;background:var(--bg-gray-50)}.file-drop-zone:hover{border-color:var(--primary-blue);background:#f0f6ff}.file-drop-zone-icon{font-size:1.75rem;color:var(--text-muted)}.file-drop-zone-label{font-size:.875rem;font-weight:600;color:var(--primary-blue)}.file-drop-zone-hint{font-size:.75rem;color:var(--text-muted)}.attachment-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-gray-100);border:1px solid var(--border-light);border-radius:20px;font-size:.8rem;color:var(--text-primary)}.attachment-chip-icon{color:var(--text-muted);font-size:.9rem}.attachment-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:0;line-height:1;transition:all .15s}.attachment-chip-remove:hover{background:var(--bg-gray-200);color:var(--error)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-light)}.toggle-row:last-child{border-bottom:none}.toggle-row-text{display:flex;flex-direction:column;gap:2px}.toggle-row-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.toggle-row-desc{font-size:.75rem;color:var(--text-secondary)}.form-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.form-toggle input{display:none}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-gray-200);border-radius:12px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #00000026}.form-toggle input:checked+.toggle-slider{background:var(--primary-blue)}.form-toggle input:checked+.toggle-slider:before{transform:translate(20px)}.quiz-type-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px}.quiz-type-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 16px;border:2px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;cursor:pointer;text-align:center;transition:all .15s}.quiz-type-card:hover{border-color:var(--primary-blue-light);background:#f8fbff}.quiz-type-card.selected{border-color:var(--primary-blue);background:#f0f6ff}.quiz-type-card input[type=radio]{position:absolute;opacity:0;width:0;height:0}.quiz-type-card-icon{font-size:1.5rem}.quiz-type-card-title{font-weight:700;font-size:.9rem;color:var(--text-primary)}.quiz-type-card-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.question-card-editor{border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;background:#fff;transition:border-color .15s}.question-card-editor.has-error{border-color:var(--error);background:#fff8f8}.question-card-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.question-card-editor-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary)}.question-error-banner{display:flex;flex-direction:column;gap:2px;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);color:#991b1b;font-size:.8rem;margin-bottom:14px}.option-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.option-row input[type=radio],.option-row input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.option-text-input{flex:1;padding:8px 12px;border:1px solid var(--border-gray);border-radius:var(--radius-sm);font-size:.875rem;transition:border-color .15s;font-family:inherit}.option-text-input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.option-text-input:disabled{background:var(--bg-gray-50);color:var(--text-secondary)}.btn-icon-danger{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff;color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:all .15s;flex-shrink:0;padding:0}.btn-icon-danger:hover{background:#fef2f2;border-color:#fecaca;color:var(--error)}.btn-add-question{width:100%;padding:14px;border:2px dashed var(--border-gray);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-add-question:hover{border-color:var(--primary-blue);color:var(--primary-blue);background:#f8fbff}.options-section-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.short-answer-note{font-size:.8rem;color:var(--text-muted);font-style:italic;padding:8px 0}@media(max-width:768px){.form-container{padding:10px}.form-section{padding:16px}.form-row{grid-template-columns:1fr}.attendance-buttons{flex-wrap:wrap}.attendance-btn{font-size:12px;padding:6px 12px}.quiz-type-selector{grid-template-columns:1fr}.toggle-row{gap:12px}}.hil-container{max-width:680px;margin:0 auto;padding:1.5rem 1rem}.hil-loading{text-align:center;padding:3rem 0;color:#6b7280}.hil-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.hil-title{margin:0;font-size:1.375rem;font-weight:700;color:#1f2937}.hil-back-link{font-size:.8125rem;color:#6b7280;text-decoration:none}.hil-back-link:hover{color:#374151;text-decoration:underline}.hil-empty{text-align:center;padding:3rem 1rem}.hil-empty-icon{width:56px;height:56px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#d1fae5;color:#065f46;font-size:1.5rem;font-weight:700}.hil-empty-title{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#1f2937}.hil-empty-text{margin:0 0 1.25rem;color:#6b7280;font-size:.875rem}.hil-empty-link{display:inline-block;padding:.5rem 1.25rem;background:#2563eb;color:#fff;border-radius:8px;text-decoration:none;font-size:.875rem;font-weight:500}.hil-empty-link:hover{background:#1d4ed8}.hil-records{display:flex;flex-direction:column;gap:.75rem}.hil-date-card{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff}.hil-date-card.hil-escalated{border-color:#fbbf24}.hil-date-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.hil-escalated .hil-date-header{background:#fffbeb;border-bottom-color:#fde68a}.hil-date{font-weight:600;font-size:.9375rem;color:#1f2937}.hil-count{font-size:.8125rem;color:#6b7280}.hil-late-badge{margin-left:auto;padding:.125rem .5rem;border-radius:12px;background:#fef3c7;color:#92400e;font-size:.6875rem;font-weight:600}.hil-students{padding:.25rem 0}.hil-student-row{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem}.hil-student-row+.hil-student-row{border-top:1px solid #f3f4f6}.hil-student-name{font-size:.875rem;color:#374151;font-weight:500}.hil-log-btn{padding:.375rem .875rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s}.hil-log-btn:hover{background:#1d4ed8}@media(max-width:480px){.hil-container{padding:1rem .75rem}.hil-title{font-size:1.125rem}}.rubric-builder{padding:0}.rubric-builder-header{margin-bottom:20px}.rubric-criteria{display:flex;flex-direction:column;gap:16px}.criterion-card{background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:12px;padding:20px}.criterion-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.criterion-header-fields{flex:1;display:flex;flex-direction:column;gap:10px}.criterion-title-row{display:flex;gap:12px;align-items:center}.criterion-title-row input{flex:1;padding:8px 12px;border:1px solid var(--border-gray, #d1d5db);border-radius:6px;font-size:14px;font-weight:600;font-family:inherit}.criterion-title-row input:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.criterion-points-input{width:80px!important;text-align:center;flex:none!important}.criterion-desc-input{width:100%;padding:8px 12px;border:1px solid var(--border-gray, #d1d5db);border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;min-height:36px}.criterion-desc-input:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.criterion-levels{display:flex;flex-direction:column;gap:8px;margin-top:12px}.criterion-levels-label{font-size:.75rem;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.level-card-edit{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid var(--border-light, #e5e7eb);border-radius:8px;background:var(--bg-gray-50, #f9fafb)}.level-card-edit .level-fields{flex:1;display:flex;flex-direction:column;gap:6px}.level-card-edit .level-title-row{display:flex;gap:10px;align-items:center}.level-card-edit .level-title-row input[type=text]{flex:1;padding:6px 10px;border:1px solid var(--border-gray, #d1d5db);border-radius:4px;font-size:13px;font-family:inherit}.level-card-edit .level-title-row input[type=number]{width:70px;padding:6px 10px;border:1px solid var(--border-gray, #d1d5db);border-radius:4px;font-size:13px;text-align:center;font-family:inherit}.level-card-edit input:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.level-card-edit textarea{width:100%;padding:6px 10px;border:1px solid var(--border-gray, #d1d5db);border-radius:4px;font-size:12px;font-family:inherit;resize:vertical;min-height:32px}.level-card-edit textarea:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.level-order-btns{display:flex;flex-direction:column;gap:2px}.level-order-btn{background:none;border:1px solid var(--border-light, #e5e7eb);border-radius:4px;cursor:pointer;padding:2px 6px;font-size:11px;color:var(--text-secondary, #6b7280);transition:all .15s;line-height:1}.level-order-btn:hover:not(:disabled){background:var(--bg-gray-100, #f3f4f6);border-color:var(--primary-blue, #3d81de);color:var(--primary-blue, #3d81de)}.level-order-btn:disabled{opacity:.3;cursor:not-allowed}.add-criterion-btn,.add-level-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:2px dashed var(--border-gray, #d1d5db);border-radius:8px;background:none;cursor:pointer;color:var(--text-secondary, #6b7280);width:100%;justify-content:center;font-size:13px;font-weight:500;font-family:inherit;transition:all .15s}.add-criterion-btn:hover,.add-level-btn:hover{border-color:var(--primary-blue, #3d81de);color:var(--primary-blue, #3d81de);background:#f8fbff}.add-level-btn{padding:8px 12px;font-size:12px}.remove-btn{background:none;border:1px solid transparent;color:var(--text-muted, #9ca3af);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:16px;line-height:1;transition:all .15s;flex-shrink:0}.remove-btn:hover{background:#fff5f5;border-color:#fecaca;color:#ea4335}.rubric-shared-toggle{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:var(--bg-gray-50, #f9fafb);border-radius:8px}.rubric-shared-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-primary, #111827)}.rubric-shared-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.rubric-shared-hint{font-size:12px;color:var(--text-muted, #9ca3af)}.rubric-error{color:#dc2626;font-size:12px;margin-top:4px}.rubric-field-error input,.rubric-field-error textarea{border-color:#dc2626!important}.rubric-builder-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid var(--border-light, #e5e7eb);margin-top:20px}.rubric-scorer{padding:0}.rubric-total{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--bg-gray-50, #f8f9fa);border:1px solid var(--border-light, #e5e7eb);border-radius:8px;font-weight:600;font-size:16px;margin-bottom:16px}.rubric-total-label{color:var(--text-secondary, #6b7280)}.rubric-total-value{font-size:20px;color:var(--primary-color, #4f46e5)}.rubric-scorer-criteria{display:flex;flex-direction:column;gap:20px}.scorer-criterion{background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:12px;padding:20px}.scorer-criterion-header{margin-bottom:12px}.scorer-criterion-header h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--text-primary, #111827)}.scorer-criterion-header p{margin:0;font-size:13px;color:var(--text-secondary, #6b7280)}.scorer-criterion-header .points-label{font-size:12px;font-weight:600;color:var(--text-muted, #9ca3af);margin-top:4px}.scorer-levels{display:flex;flex-direction:column;gap:8px}.level-card{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border:2px solid var(--border-light, #e5e7eb);border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.level-card:hover{border-color:var(--primary-blue, #3d81de);background:#f8fbff}.level-card.selected{border-color:var(--primary-blue, #3d81de);background:#eef4fd}.level-card.read-only{cursor:default}.level-card.read-only:hover{border-color:var(--border-light, #e5e7eb);background:#fff}.level-card.read-only.scored{border-color:var(--primary-blue, #3d81de);background:#eef4fd}.level-radio{margin-top:2px;width:18px;height:18px;flex-shrink:0;accent-color:var(--primary-blue, #3d81de)}.level-card-content{flex:1;min-width:0}.level-card-title{font-weight:600;font-size:14px;color:var(--text-primary, #111827);margin-bottom:2px}.level-card-description{font-size:13px;color:var(--text-secondary, #6b7280);line-height:1.4}.level-points{font-weight:700;font-size:18px;min-width:50px;text-align:center;color:var(--text-primary, #111827);flex-shrink:0;padding-top:2px}.level-points-unit{font-size:11px;font-weight:500;color:var(--text-muted, #9ca3af);display:block}.scorer-override{margin-top:10px;display:flex;align-items:center;gap:8px}.scorer-override label{font-size:12px;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.scorer-override input{width:80px;padding:6px 10px;border:1px solid var(--border-gray, #d1d5db);border-radius:4px;font-size:14px;text-align:center;font-family:inherit}.scorer-override input:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.scorer-feedback{margin-top:10px}.scorer-feedback textarea{width:100%;padding:8px 12px;border:1px solid var(--border-gray, #d1d5db);border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;min-height:40px}.scorer-feedback textarea:focus{outline:none;border-color:var(--primary-blue, #3d81de);box-shadow:0 0 0 3px #3d81de1a}.scorer-feedback textarea::placeholder{color:var(--text-muted, #9ca3af)}.rubric-scorer-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light, #e5e7eb)}.rubric-viewer{padding:0}.rubric-viewer-header{margin-bottom:16px}.rubric-viewer-header h3{margin:0 0 4px;font-size:1.1rem;font-weight:700;color:var(--text-primary, #111827)}.rubric-viewer-criteria{display:flex;flex-direction:column;gap:16px}.viewer-criterion{background:#fff;border:1px solid var(--border-light, #e5e7eb);border-radius:12px;padding:16px 20px}.viewer-criterion-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.viewer-criterion-header h4{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary, #111827)}.viewer-criterion-score{font-weight:700;font-size:15px;color:var(--primary-color, #4f46e5);white-space:nowrap}.viewer-criterion-desc{font-size:13px;color:var(--text-secondary, #6b7280);margin-bottom:10px}.viewer-levels{display:flex;flex-direction:column;gap:6px}.viewer-feedback{margin-top:10px;padding:10px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;font-size:13px;color:#92400e}.viewer-feedback strong{display:block;margin-bottom:2px;font-size:11px;text-transform:uppercase;letter-spacing:.04em}.rubric-empty{text-align:center;padding:24px;color:var(--text-muted, #9ca3af);font-size:14px}@media(max-width:768px){.criterion-title-row{flex-direction:column;align-items:stretch}.criterion-points-input{width:100%!important}.level-card-edit .level-title-row{flex-direction:column;align-items:stretch}.level-card-edit .level-title-row input[type=number]{width:100%}.rubric-total{flex-direction:column;gap:4px;text-align:center}.level-card{flex-direction:column;gap:8px}.level-points{text-align:left;min-width:auto}.scorer-override{flex-direction:column;align-items:flex-start}}.calendar-page,.calendar-container{padding:20px}.calendar-container .calendar-header{margin-bottom:20px}.calendar-container .calendar-header h1{margin:0 0 5px;font-size:1.75rem}.calendar-container .calendar-header p{color:var(--text-muted, #6c757d);margin:0}.calendar-controls{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:20px;padding:15px 20px;background:var(--bg-secondary, #f8f9fa);border-radius:8px;flex-wrap:wrap}.view-controls{display:flex;gap:0}.nav-controls{display:flex;align-items:center;gap:10px}.filter-controls select{padding:8px 12px;border:1px solid var(--border-color, #dee2e6);border-radius:6px;background:#fff;font-size:14px;min-width:150px}.date-header{text-align:center;margin-bottom:20px;font-size:1.5rem;color:var(--text-primary, #212529)}.event-section{padding:20px;border-radius:10px;margin-bottom:15px;background:var(--card-bg, #fff);border:1px solid var(--border-color, #dee2e6)}.event-section h3{margin:0 0 15px;font-size:1.1rem;color:var(--text-primary, #212529)}.event-card{padding:15px;background:var(--bg-secondary, #f8f9fa);border-radius:8px;margin-bottom:10px}.event-card.schedule{background:#f0fdf4;border-left:4px solid #86efac}.event-card.assignment{background:#eff6ff;border-left:4px solid #93c5fd}.event-card.quiz{background:#f5f3ff;border-left:4px solid #a78bfa}.event-card .event-time{font-size:.85rem;color:var(--text-muted, #6c757d);margin-bottom:5px}.event-card .event-details{display:flex;flex-direction:column;gap:4px}.event-card .event-details strong{color:var(--text-primary, #212529)}.event-card .event-details .class-name,.event-card .event-details .room,.event-card .event-details .points{font-size:.85rem;color:var(--text-muted, #6c757d)}.event-card .lesson-plan{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color, #dee2e6);font-size:.9rem}.week-view .week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.week-view .week-day{background:var(--card-bg, #fff);border:1px solid var(--border-color, #dee2e6);border-radius:8px;min-height:200px;cursor:pointer;transition:all .2s;overflow:hidden}.week-view .week-day:hover{box-shadow:0 2px 8px #0000001a}.week-view .week-day.today{border:2px solid var(--primary-color, #0d6efd)}.week-view .day-header{background:var(--bg-secondary, #f8f9fa);padding:10px;text-align:center}.week-view .week-day.today .day-header{background:var(--primary-color, #0d6efd);color:#fff}.week-view .day-name{display:block;font-size:12px;font-weight:600;text-transform:uppercase}.week-view .day-number{display:block;font-size:18px;font-weight:700}.week-view .day-events{padding:8px;display:flex;flex-direction:column;gap:5px}.mini-event{padding:5px 8px;border-radius:4px;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-event.schedule{background:#86efac;color:#166534}.mini-event.assignment{background:#93c5fd;color:#1e40af}.mini-event.quiz{background:#a78bfa;color:#5b21b6}.month-view .month-header{text-align:center;margin-bottom:20px;font-size:1.5rem}.month-view .month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-color, #dee2e6);border:1px solid var(--border-color, #dee2e6);border-radius:8px;overflow:hidden}.month-view .month-day-header{background:var(--bg-tertiary, #495057);color:#fff;padding:12px;text-align:center;font-weight:600;font-size:12px}.month-view .month-day{background:var(--card-bg, #fff);min-height:80px;padding:8px;cursor:pointer;transition:background .2s}.month-view .month-day:hover{background:var(--bg-secondary, #f8f9fa)}.month-view .month-day.empty{background:var(--bg-secondary, #f1f3f4)}.month-view .month-day.today{background:#e7f1ff}.month-view .month-day .day-number{font-weight:600;font-size:14px;margin-bottom:5px}.month-view .month-day.today .day-number{background:var(--primary-color, #0d6efd);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.month-view .event-counts{display:flex;flex-wrap:wrap;gap:3px}.month-view .count{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600}.month-view .count.schedule{background:#86efac;color:#166534}.month-view .count.assignment{background:#93c5fd;color:#1e40af}.month-view .count.quiz{background:#a78bfa;color:#5b21b6}@media(max-width:992px){.week-view .week-grid{grid-template-columns:repeat(4,1fr)}.week-view .week-day:nth-child(n+5){display:none}.calendar-controls{flex-direction:column;align-items:stretch}.view-controls,.nav-controls,.filter-controls{justify-content:center}}@media(max-width:768px){.week-view .week-grid{grid-template-columns:1fr}.week-view .week-day:nth-child(n+5){display:block}.week-view .week-day{min-height:auto}.month-view .month-day{min-height:60px;padding:5px}}.calendar-filters{display:flex;align-items:center;gap:20px;margin-bottom:20px;flex-wrap:wrap;background:#f8f9fa;padding:15px 20px;border-radius:8px}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-weight:500;color:#495057}.filter-group select{padding:8px 12px;border:1px solid #dee2e6;border-radius:6px;background:#fff;font-size:14px;min-width:150px}.view-toggle{display:flex;gap:0;margin-left:auto}.view-btn{padding:8px 16px;border:1px solid #dee2e6;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.view-btn:first-child{border-radius:6px 0 0 6px}.view-btn:last-child{border-radius:0 6px 6px 0}.view-btn:not(:first-child){border-left:none}.view-btn.active{background:#0d6efd;color:#fff;border-color:#0d6efd}.view-btn:hover:not(.active){background:#e9ecef}.today-btn{padding:8px 16px;background:#198754;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.today-btn:hover{background:#157347}.calendar-legend{display:flex;align-items:center;gap:20px;margin-bottom:20px;padding:10px 15px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.legend-label{font-weight:600;color:#495057}.legend-item{display:flex;align-items:center;gap:6px;font-size:14px}.legend-dot{width:12px;height:12px;border-radius:3px}.legend-dot.quiz{background:#a78bfa}.legend-dot.assignment{background:#93c5fd}.legend-dot.schedule{background:#86efac}.legend-dot.holiday{background:#fecaca}.calendar-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.loading,.error{padding:40px;text-align:center;font-size:16px;color:#6c757d}.error{color:#dc3545}.day-view{padding:20px}.day-view-header{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:25px}.day-view-header h2{margin:0;font-size:1.5rem;color:#212529}.nav-btn{width:36px;height:36px;border:1px solid #dee2e6;background:#fff;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}.nav-btn:hover{background:#e9ecef}.day-sections{display:flex;flex-direction:column;gap:20px}.calendar-section{padding:20px;border-radius:10px}.calendar-section h3{margin:0 0 15px;font-size:1.1rem;display:flex;align-items:center;gap:8px}.quizzes-section{background:#f5f3ff;border:1px solid #a78bfa}.quizzes-section h3{color:#5b21b6}.assignments-section{background:#eff6ff;border:1px solid #93c5fd}.assignments-section h3{color:#1e40af}.schedule-section{background:#f0fdf4;border:1px solid #86efac}.schedule-section h3{color:#166534}.no-items{color:#6c757d;font-style:italic;margin:0}.event-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.event-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.event-item:hover{transform:translate(5px);box-shadow:0 2px 4px #0000001a}.event-title{font-weight:500;color:#212529}.event-class{font-size:13px;color:#6c757d}.schedule-item{padding:15px;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.schedule-item:hover{transform:translate(5px);box-shadow:0 2px 4px #0000001a}.schedule-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.schedule-class{font-weight:600;font-size:1rem;color:#212529}.schedule-time{font-size:13px;color:#6c757d}.schedule-topic{font-size:14px;color:#495057}.schedule-topic.no-agenda{color:#adb5bd;font-style:italic}.add-agenda-btn{padding:4px 10px;background:#198754;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background .2s}.add-agenda-btn:hover{background:#157347}.week-view{padding:20px}.week-view-header{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:20px}.week-view-header h2{margin:0;font-size:1.3rem}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.week-day{background:#f8f9fa;border-radius:8px;min-height:200px;cursor:pointer;transition:all .2s;overflow:hidden}.week-day:hover{background:#e9ecef}.week-day.today{border:2px solid #0d6efd}.week-day-header{background:#dee2e6;padding:10px;text-align:center}.week-day.today .week-day-header{background:#0d6efd;color:#fff}.week-day-name{display:block;font-size:12px;font-weight:600;text-transform:uppercase}.week-day-number{display:block;font-size:18px;font-weight:700}.week-day-content{padding:8px;display:flex;flex-direction:column;gap:5px}.week-event{padding:5px 8px;border-radius:4px;font-size:11px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-event.quiz{background:#a78bfa;color:#5b21b6}.week-event.assignment{background:#93c5fd;color:#1e40af}.week-event.schedule{background:#86efac;color:#166534}.week-topic{display:block;font-size:10px;opacity:.8;margin-top:2px}.month-view{padding:20px}.month-view-header{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:20px}.month-view-header h2{margin:0;font-size:1.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#dee2e6;border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.calendar-day-header{background:#495057;color:#fff;padding:12px;text-align:center;font-weight:600;font-size:12px}.calendar-day{background:#fff;min-height:100px;padding:8px;cursor:pointer;transition:background .2s}.calendar-day:hover{background:#f8f9fa}.calendar-day.other-month{background:#f1f3f4}.calendar-day.other-month .day-number{color:#adb5bd}.calendar-day.today{background:#e7f1ff}.calendar-day.today .day-number{background:#0d6efd;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.day-number{font-weight:600;font-size:14px;color:#212529;margin-bottom:5px}.day-counts{display:flex;flex-direction:column;gap:3px}.count-badge{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600}.count-badge.quiz{background:#a78bfa;color:#5b21b6}.count-badge.assignment{background:#93c5fd;color:#1e40af}.count-badge.schedule{background:#86efac;color:#166534}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:25px;position:relative}.modal-close{position:absolute;top:15px;right:15px;width:30px;height:30px;border:none;background:#f1f3f4;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:#dee2e6}.modal-content h2{margin:0 0 5px;font-size:1.4rem;color:#212529;padding-right:40px}.modal-subtitle{color:#6c757d;font-size:14px;margin:0 0 20px}.lesson-details h3{font-size:14px;color:#6c757d;margin:15px 0 5px;text-transform:uppercase;letter-spacing:.5px}.lesson-details p{margin:0;color:#212529;line-height:1.5}.lesson-description{background:#f8f9fa;padding:12px;border-radius:6px;white-space:pre-wrap}.no-lesson-plan{text-align:center;padding:20px}.no-lesson-plan p{color:#6c757d;margin-bottom:15px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:15px;border-top:1px solid #dee2e6}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:500;color:#495057;margin-bottom:5px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0d6efd}.form-group textarea{resize:vertical;min-height:100px}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:#0d6efd;color:#fff}.btn-primary:hover{background:#0b5ed7}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5c636a}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#bb2d3b}@media(max-width:992px){.week-grid{grid-template-columns:repeat(4,1fr)}.week-day:nth-child(n+5){display:none}}@media(max-width:768px){.calendar-filters{flex-direction:column;align-items:stretch}.view-toggle{margin-left:0;justify-content:center}.filter-group{justify-content:space-between}.filter-group select{flex:1}.week-grid{grid-template-columns:1fr}.week-day:nth-child(n+5){display:block}.week-day{min-height:auto}.calendar-day{min-height:80px;padding:5px}.day-number{font-size:12px}.count-badge{font-size:9px;padding:1px 4px}.day-view-header h2,.week-view-header h2,.month-view-header h2{font-size:1.1rem}}@media(max-width:480px){.calendar-page{padding:10px}.calendar-legend{flex-wrap:wrap;gap:10px}.legend-label{width:100%}.calendar-section{padding:15px}.event-item,.schedule-main{flex-direction:column;align-items:flex-start;gap:5px}.modal-content{padding:20px}}.tuition-container{padding:2rem;max-width:800px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.page-header p{color:var(--text-muted);margin:0}.payer-info-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.payer-details h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600}.payer-details p{margin:0;color:var(--text-muted);font-size:.875rem}.tuition-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.btn-link{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.875rem;padding:0}.btn-link:hover{text-decoration:underline}.children-cards{display:flex;flex-direction:column;gap:.75rem}.child-card{display:flex;justify-content:space-between;align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:1rem 1.25rem}.child-info h4{margin:0;font-size:1rem;font-weight:600}.child-username{margin:.25rem 0 0;font-size:.875rem;color:var(--text-muted)}.child-tuition{text-align:right}.tuition-amount{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.tuition-label{font-size:.875rem;color:var(--text-muted)}.billing-months-display{display:flex;flex-wrap:wrap;gap:.5rem}.month-tag{background:var(--primary-color);color:#fff;padding:.375rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.invoices-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.invoice-card{display:flex;align-items:flex-start;gap:1rem;background:var(--card-bg);border:2px solid var(--border-color);border-radius:10px;padding:1rem 1.25rem;cursor:pointer;transition:border-color .2s,background .2s}.invoice-card:hover{background:var(--bg-secondary)}.invoice-card.selected{border-color:var(--primary-color);background:#6366f10d}.invoice-checkbox{padding-top:.25rem}.invoice-checkbox input{width:20px;height:20px;cursor:pointer}.invoice-details{flex:1}.invoice-details h4{margin:0 0 .75rem;font-size:1rem;font-weight:600}.invoice-breakdown{display:flex;flex-direction:column;gap:.375rem}.line-item{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary)}.invoice-total{font-size:1.25rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.payment-summary{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.summary-row{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.9375rem;color:var(--text-secondary)}.summary-row.total{margin-bottom:1.25rem;padding-top:.75rem;border-top:1px solid var(--border-color);font-size:1.125rem;color:var(--text-primary);font-weight:600}.total-amount{font-size:1.5rem;color:var(--primary-color)}.btn-pay{width:100%;padding:1rem;font-size:1.125rem;font-weight:600}.no-dues{text-align:center;padding:3rem 2rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px}.no-dues-icon{width:64px;height:64px;border-radius:50%;background:#10b9811a;color:var(--success-color);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}.no-dues p{margin:0;font-size:1.125rem;color:var(--text-secondary)}.payment-history{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.payment-item:last-child{border-bottom:none}.payment-info{display:flex;align-items:center;gap:1rem}.payment-date{font-size:.9375rem;color:var(--text-primary)}.payment-status{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-completed{background:#10b9811a;color:var(--success-color)}.status-pending{background:#f59e0b1a;color:var(--warning-color)}.status-failed{background:#ef44441a;color:var(--error-color)}.payment-amount{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.btn{padding:.625rem 1.25rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.empty-state{text-align:center;color:var(--text-muted);padding:2rem}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted)}.tp-upcoming-hint{display:flex;align-items:center;justify-content:space-between;background:var(--card-bg);border:1px dashed var(--border-color);border-radius:10px;padding:1rem 1.25rem}.tp-upcoming-hint p{margin:0;font-size:.9375rem;color:var(--text-secondary)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.tp-upcoming-card{border-style:dashed;opacity:.9}.tp-upcoming-card.selected{border-style:solid;opacity:1}.tp-upcoming-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.tp-upcoming-header h4{margin:0;font-size:1rem;font-weight:600}.tp-upcoming-label{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:#6366f11a;color:var(--primary-color)}@media(max-width:640px){.tuition-container{padding:1rem}.invoice-card{flex-wrap:wrap}.invoice-total{width:100%;text-align:right;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}}.messaging-container{display:flex;height:calc(100vh - 96px);background:var(--bg-gray-50);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-light);box-shadow:var(--shadow-card)}.thread-list{width:340px;min-width:340px;background:#fff;display:flex;flex-direction:column;border-right:1px solid var(--border-light)}.thread-list-header{padding:20px;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:12px}.thread-list-header-row{display:flex;align-items:center;justify-content:space-between}.thread-list-header h2{margin:0;font-size:20px;font-weight:700;color:var(--text-primary)}.thread-new-btn{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #3d81de40;transition:all .2s ease;white-space:nowrap}.thread-new-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3d81de59}.thread-search{position:relative}.thread-search input{width:100%;padding:10px 14px 10px 38px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;background:var(--bg-gray-50);color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease}.thread-search input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a;background:#fff}.thread-search input::placeholder{color:var(--text-muted)}.thread-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px;pointer-events:none}.thread-items{flex:1;overflow-y:auto}.thread-item{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid var(--bg-gray-100)}.thread-item:hover{background:var(--bg-gray-50)}.thread-item.active{background:#3d81de14;border-left:3px solid var(--primary-blue);padding-left:17px}.thread-item.unread{background:#3d81de0a}.thread-avatar{width:44px;height:44px;min-width:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;color:#fff;text-transform:uppercase;background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);box-shadow:0 2px 6px #3d81de33}.thread-avatar.group{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 2px 6px #8b5cf633}.thread-info{flex:1;min-width:0}.thread-info-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.thread-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}.thread-item.unread .thread-name{font-weight:700}.thread-time{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.thread-item.unread .thread-time{color:var(--primary-blue);font-weight:600}.thread-preview-row{display:flex;align-items:center;gap:8px}.thread-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;line-height:1.4}.thread-item.unread .thread-preview{color:var(--text-primary);font-weight:500}.thread-unread-badge{width:10px;height:10px;min-width:10px;border-radius:50%;background:var(--primary-blue);flex-shrink:0}.thread-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted)}.thread-list-empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}.thread-list-empty p{font-size:15px;margin-bottom:4px}.thread-list-empty .hint{font-size:13px;color:var(--text-muted)}.thread-list-loading{display:flex;align-items:center;justify-content:center;padding:60px 20px}.thread-view{flex:1;display:flex;flex-direction:column;background:var(--bg-gray-50);min-width:0}.thread-view-header{padding:16px 24px;background:#fff;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:12px;min-height:64px}.thread-view-back{display:none;background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background-color .15s ease}.thread-view-back:hover{background:var(--bg-gray-100);color:var(--text-primary)}.thread-view-header-info{flex:1;min-width:0}.thread-view-header-info h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread-view-header-info .participants{font-size:13px;color:var(--text-muted);margin-top:2px}.thread-view-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted);padding:40px}.thread-view-empty-icon{font-size:56px;margin-bottom:16px;opacity:.3}.thread-view-empty h3{font-size:18px;color:var(--text-secondary);margin-bottom:8px}.thread-view-empty p{font-size:14px;color:var(--text-muted)}.messages-area{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:4px}.messages-loading{flex:1;display:flex;align-items:center;justify-content:center}.messages-date-divider{display:flex;align-items:center;gap:12px;margin:16px 0 8px}.messages-date-divider:before,.messages-date-divider:after{content:"";flex:1;height:1px;background:var(--border-light)}.messages-date-divider span{font-size:12px;color:var(--text-muted);font-weight:500;white-space:nowrap}.message{display:flex;flex-direction:column;max-width:70%;margin-bottom:2px}.message-own{align-self:flex-end;align-items:flex-end}.message-other{align-self:flex-start;align-items:flex-start}.message-sender{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:3px;padding:0 12px}.message-bubble{padding:10px 16px;border-radius:18px;font-size:14px;line-height:1.5;word-wrap:break-word;word-break:break-word}.message-own .message-bubble{background:linear-gradient(135deg,var(--primary-blue) 0%,#4a8ee0 100%);color:#fff;border-bottom-right-radius:6px}.message-other .message-bubble{background:#fff;color:var(--text-primary);border:1px solid var(--border-light);border-bottom-left-radius:6px}.message-time{font-size:11px;color:var(--text-muted);margin-top:3px;padding:0 12px}.compose-area{padding:16px 24px;background:#fff;border-top:1px solid var(--border-light);display:flex;align-items:flex-end;gap:12px}.compose-area textarea{flex:1;padding:12px 16px;border:1px solid var(--border-light);border-radius:var(--radius-lg);font-size:14px;font-family:inherit;resize:none;min-height:44px;max-height:120px;line-height:1.4;color:var(--text-primary);background:var(--bg-gray-50);transition:border-color .2s ease,box-shadow .2s ease}.compose-area textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a;background:#fff}.compose-area textarea::placeholder{color:var(--text-muted)}.compose-send-btn{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);color:#fff;border:none;width:44px;height:44px;min-width:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;box-shadow:0 2px 8px #3d81de40;transition:all .2s ease}.compose-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #3d81de59}.compose-send-btn:disabled{opacity:.4;cursor:not-allowed}.new-thread-form{display:flex;flex-direction:column;gap:16px}.new-thread-field{display:flex;flex-direction:column;gap:6px}.new-thread-field label{font-size:14px;font-weight:600;color:var(--text-primary)}.new-thread-field .field-hint{font-size:12px;color:var(--text-muted);font-weight:400}.recipient-search{position:relative}.recipient-search input{width:100%;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);transition:border-color .2s ease}.recipient-search input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.recipient-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:200px;overflow-y:auto;z-index:10}.recipient-option{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background-color .15s ease;font-size:14px;border:none;background:none;width:100%;text-align:left;color:var(--text-primary)}.recipient-option:hover{background:var(--bg-gray-50)}.recipient-option-avatar{width:32px;height:32px;min-width:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;text-transform:uppercase}.recipient-option-info{flex:1;min-width:0}.recipient-option-name{font-weight:500}.recipient-option-meta{display:flex;align-items:center;gap:.5rem;font-size:12px;color:var(--text-muted)}.recipient-option-role{text-transform:capitalize}.recipient-option-email{opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipient-no-results{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.selected-recipients{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.selected-recipient-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:#3d81de1a;color:var(--primary-blue);border-radius:20px;font-size:13px;font-weight:500}.selected-recipient-chip button{background:none;border:none;color:var(--primary-blue);font-size:16px;cursor:pointer;padding:0;line-height:1;display:flex;align-items:center;opacity:.7;transition:opacity .15s ease}.selected-recipient-chip button:hover{opacity:1}.new-thread-field textarea{width:100%;padding:12px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;font-family:inherit;resize:vertical;min-height:100px;color:var(--text-primary);line-height:1.5;transition:border-color .2s ease}.new-thread-field textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3d81de1a}.new-thread-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.new-thread-actions .btn-cancel{background:#fff;color:var(--text-secondary);border:1px solid var(--border-light);padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.new-thread-actions .btn-cancel:hover{background:var(--bg-gray-50);border-color:var(--border-gray)}.new-thread-actions .btn-send{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);color:#fff;border:none;padding:10px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #3d81de40;transition:all .2s ease}.new-thread-actions .btn-send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3d81de59}.new-thread-actions .btn-send:disabled{opacity:.5;cursor:not-allowed}.recipient-loading{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.messaging-page-header{margin-bottom:20px}.messaging-page-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0}@media(max-width:768px){.messaging-container{height:calc(100vh - 80px);border-radius:0;border:none;box-shadow:none}.messaging-container.mobile-thread-view .thread-list,.messaging-container.mobile-list-view .thread-view{display:none}.thread-list{width:100%;min-width:0;border-right:none}.thread-view-back{display:flex}.thread-name{max-width:calc(100vw - 200px)}.message{max-width:85%}.compose-area{padding:12px 16px}.messages-area{padding:16px}.thread-view-header{padding:12px 16px}}@media(max-width:480px){.messaging-container{height:calc(100vh - 60px)}.thread-list-header{padding:16px}.thread-item{padding:12px 16px}.thread-avatar{width:38px;height:38px;min-width:38px;font-size:13px}}:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-xs: 12px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 16px;--font-xl: 18px;--font-2xl: 20px;--font-3xl: 24px;--font-4xl: 32px;--weight-light: 300;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-sidebar: 300;--z-overlay: 400;--z-modal: 500;--z-toast: 600;--z-tooltip: 700;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 280px;--sidebar-width-tablet: 240px;--sidebar-width-mobile: 70px;--navbar-height: 60px;--content-max-width: 1400px}:root{--primary-blue: #3D81DE;--primary-blue-light: #7EABE9;--primary-blue-dark: #2a5ba8;--primary-color: #3D81DE;--primary-hover: #2a5ba8;--bg-navy: #0C1A2C;--bg-navy-light: #1a2942;--bg-white: #ffffff;--bg-gray-50: #f8f9fa;--bg-gray-100: #f1f3f5;--bg-gray-200: #e9ecef;--bg-secondary: #f1f3f5;--bg-tertiary: #e9ecef;--card-bg: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-white: #ffffff;--border-light: #e2e8f0;--border-gray: #cbd5e1;--border-color: #e2e8f0;--success: #10b981;--success-color: #10b981;--warning: #f59e0b;--warning-color: #f59e0b;--error: #ef4444;--error-color: #ef4444;--info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-card: -10px 20px 50px rgba(140, 140, 140, .05);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-gray-50);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;min-height:100vh;background:var(--bg-gray-50)}.main-content{flex:1;margin-left:280px;min-height:100vh;background:var(--bg-gray-50);padding:32px;transition:margin-left .3s ease;overflow-x:hidden;max-width:calc(100vw - 280px);box-sizing:border-box}.main-content-full{flex:1;min-height:100vh;background:var(--bg-gray-50);padding:0}.loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:18px;color:var(--text-secondary);font-weight:500}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:40px;text-align:center}.error-page h1{font-size:72px;font-weight:700;color:var(--primary-blue);margin-bottom:16px}.error-page p{font-size:18px;color:var(--text-secondary)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:16px}.empty-state-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:40px}.empty-state-page h2{font-size:24px;color:var(--text-primary);margin-bottom:12px}.empty-state-page p{font-size:16px;color:var(--text-secondary);margin-bottom:24px}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:32px;font-weight:700}h2{font-size:24px}h3{font-size:20px}p{line-height:1.66}a{color:var(--primary-blue);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-blue-dark)}.card{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);border:1px solid var(--border-light);transition:all .2s ease}.card:hover{box-shadow:var(--shadow-lg)}.section{margin-bottom:24px}button{font-family:Lato,sans-serif;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue-light) 100%);color:#fff;padding:12px 24px;border-radius:var(--radius-md);font-size:15px;font-weight:600;box-shadow:0 4px 12px #3d81de4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #3d81de66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text-primary);padding:12px 24px;border-radius:var(--radius-md);border:1px solid var(--border-gray);font-size:15px;font-weight:500}.btn-secondary:hover:not(:disabled){background:var(--bg-gray-50);border-color:var(--primary-blue)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:12px 24px;border-radius:var(--radius-md);font-size:15px;font-weight:600}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-small{padding:4px 12px;font-size:13px;border-radius:var(--radius-sm)}.btn-large{padding:16px 32px;font-size:16px}.btn-back{background:#fff;color:var(--text-secondary);padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--border-light);font-size:14px;display:flex;align-items:center;gap:8px;margin-bottom:16px}.btn-back:hover{background:var(--bg-gray-50);color:var(--primary-blue)}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.status-pending{background:#fef3c7;color:#92400e}.status-graded,.status-present{background:#d1fae5;color:#065f46}.status-absent{background:#fee2e2;color:#991b1b}.status-late{background:#fed7aa;color:#9a3412}.status-excused{background:#dbeafe;color:#1e40af}.status-draft{background:var(--bg-gray-200);color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger,.text-error{color:var(--error)}.text-info{color:var(--info)}@media(max-width:1024px){.main-content{margin-left:0;padding:72px 20px 20px;max-width:100vw}.main-content-full{padding:0}h1{font-size:28px}h2{font-size:22px}}@media(max-width:480px){.main-content{padding:72px 16px 16px}h1{font-size:24px}h2{font-size:20px}.card{padding:16px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{width:36px;height:36px;border:3px solid var(--border-color, #e2e8f0);border-top-color:var(--primary-blue, #3b82f6);border-radius:50%;animation:spin .8s linear infinite}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-gray-100)}::-webkit-scrollbar-thumb{background:var(--border-gray);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
