.judy-toggle-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50%;bottom:24px;box-shadow:0 4px 20px rgba(99,102,241,.4);cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:all .3s ease;width:56px;z-index:9999}.judy-toggle-btn:hover{box-shadow:0 6px 25px rgba(99,102,241,.5);transform:scale(1.1)}.judy-toggle-btn svg{color:#fff;height:24px;width:24px}.judy-badge{background:#10b981;border-radius:10px;box-shadow:0 2px 8px rgba(16,185,129,.4);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;position:absolute;right:-8px;top:-8px}.judy-chat-window{animation:slideUp .3s ease;background:#343541;border-radius:16px;bottom:96px;box-shadow:0 10px 40px rgba(0,0,0,.3);display:flex;flex-direction:column;height:520px;overflow:hidden;position:fixed;right:24px;width:380px;z-index:9998}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.judy-header{background:#202123;border-bottom:1px solid #444654;justify-content:space-between;padding:16px}.judy-header,.judy-header-info{align-items:center;display:flex}.judy-header-info{gap:12px}.judy-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.judy-name{color:#ececf1;font-size:16px;font-weight:600}.judy-status{color:#8e8ea0;font-size:12px}.judy-header-actions{display:flex;gap:8px}.judy-header-actions button{background:transparent;border:none;border-radius:6px;cursor:pointer;padding:8px;transition:background .2s}.judy-header-actions button:hover{background:#444654}.judy-header-actions svg{color:#8e8ea0;height:18px;width:18px}.judy-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:16px}.judy-messages::-webkit-scrollbar{width:6px}.judy-messages::-webkit-scrollbar-track{background:transparent}.judy-messages::-webkit-scrollbar-thumb{background:#444654;border-radius:3px}.judy-message{display:flex;gap:12px;max-width:90%}.judy-message.user{align-self:flex-end;flex-direction:row-reverse}.judy-message.assistant{align-self:flex-start}.judy-message-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.judy-message-content{border-radius:12px;font-size:14px;line-height:1.5;padding:12px 16px;white-space:pre-wrap;word-break:break-word}.judy-message.user .judy-message-content{background:#6366f1;border-bottom-right-radius:4px;color:#fff}.judy-message.assistant .judy-message-content{background:#444654;border-bottom-left-radius:4px;color:#ececf1}.judy-typing{display:flex;gap:4px;padding:16px 20px!important}.judy-typing span{animation:typing 1.4s ease-in-out infinite;background:#8e8ea0;border-radius:50%;height:8px;width:8px}.judy-typing span:nth-child(2){animation-delay:.2s}.judy-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.judy-input-form{background:#202123;border-top:1px solid #444654;display:flex;gap:12px;padding:16px}.judy-input-form input{background:#40414f;border:1px solid #565869;border-radius:8px;color:#ececf1;flex:1 1;font-size:14px;outline:none;padding:12px 16px;transition:border-color .2s}.judy-input-form input::placeholder{color:#8e8ea0}.judy-input-form input:focus{border-color:#6366f1}.judy-input-form input:disabled{opacity:.6}.judy-input-form button{align-items:center;background:#6366f1;border:none;border-radius:8px;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.judy-input-form button:hover:not(:disabled){background:#5558e3}.judy-input-form button:disabled{cursor:not-allowed;opacity:.5}.judy-input-form button svg{color:#fff;height:20px;width:20px}@media (max-width:480px){.judy-chat-window{bottom:88px;height:calc(100vh - 140px);right:16px;width:calc(100vw - 32px)}.judy-toggle-btn{bottom:16px;right:16px}}.role-management{padding:20px}.management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.management-header h3{margin:0}.roles-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.role-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:15px}.role-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.role-card-header h4{color:#333;margin:0}.role-actions{display:flex;gap:5px}.role-description{font-size:14px;margin:0}.btn-primary{background:#007bff;border-radius:4px;font-size:14px;padding:10px 20px}.btn-primary:hover{background:#0056b3}.btn-primary:disabled{background:#ccc}.btn-secondary{background:#6c757d;border-radius:4px;font-size:14px;padding:10px 20px}.btn-secondary:hover{background:#545b62}.error-message{background:#f8d7da;border-radius:4px;color:#721c24;margin-bottom:15px;padding:10px 15px}.btn-icon{background:none;font-size:16px;padding:5px 8px}.btn-icon:hover{background:#e9ecef}.btn-icon.danger:hover{background:#f8d7da}.no-data{background:#fff;border-radius:8px;grid-column:1/-1;padding:40px}.modal-content{border-radius:8px;max-width:450px;padding:25px;width:90%}.modal-content h3{margin:0 0 20px}.form-group{margin-bottom:15px}.form-group label{color:#333;margin-bottom:5px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#007bff;outline:none}.form-group textarea{resize:vertical}.modal-actions{gap:10px;margin-top:20px;padding-top:15px}.loading{color:#666;padding:40px;text-align:center}.recharts-tooltip-wrapper{outline:none}.recharts-legend-wrapper{padding-top:10px!important}.executive-home{display:flex;height:calc(100vh - 60px);overflow:hidden}.executive-content{background:#f8fafc;flex:1 1;overflow-y:auto;padding:24px}.content-header{border-bottom:1px solid #e2e8f0;margin-bottom:24px;padding-bottom:16px}.content-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 4px}.content-header p{color:#64748b;font-size:.9rem}.content-section{border:1px solid #e2e8f0;box-shadow:0 1px 3px rgba(0,0,0,.08)}.content-section h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0 0 8px}.content-section>p{color:#64748b;font-size:.9rem}.placeholder-content{background:#f8fafc;border:1px dashed #e2e8f0;border-radius:8px;color:#94a3b8;padding:48px}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.dashboard-card{border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:all .2s ease}.dashboard-card.clickable:hover{border-color:#1565c0;box-shadow:0 4px 12px rgba(21,101,192,.12)}.dashboard-card h4{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 8px}.dashboard-card p{color:#64748b;font-size:.85rem;line-height:1.5}.communications-home{display:flex;height:calc(100vh - 60px);overflow:hidden}.communications-content{background:#f5f5f5;flex:1 1;overflow-y:auto;padding:20px}.content-header{margin-bottom:20px}.content-header h2{color:#333;margin:0 0 5px}.content-header p{color:#666;margin:0}.content-section{border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:20px}.content-section h3{margin:0 0 10px}.content-section>p{color:#666;margin:0 0 20px}.placeholder-content{background:#f9f9f9;border-radius:4px;color:#999;padding:40px;text-align:center}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:20px}.dashboard-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:20px;transition:transform .2s,box-shadow .2s}.dashboard-card.clickable{cursor:pointer}.dashboard-card.clickable:hover{box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.dashboard-card h4{color:#333;margin:0 0 10px}.dashboard-card p{color:#666;font-size:14px;margin:0}.menu-page{background:linear-gradient(135deg,#f5f7fa,#e4e8eb);min-height:100vh}.menu-navbar{align-items:center;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.08);display:flex;justify-content:space-between;padding:16px 32px}.menu-navbar h1{color:#1976d2;font-size:1.5rem;margin:0}.menu-navbar .brand-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#1976d2,#42a5f5);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.menu-navbar .navbar-subtitle{border-left:2px solid #e0e0e0;color:#666;font-size:.9rem;margin-left:.5rem;padding-left:1rem}.menu-container{margin:0 auto;max-width:1200px;padding:40px 24px}.menu-header{margin-bottom:32px;text-align:center}.menu-header h2{color:#333;font-size:2rem;margin:0 0 8px}.menu-subtitle{color:#666;font-size:1.1rem;margin:0}.role-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px}.role-tab{background:#fff;border:2px solid #1976d2;border-radius:24px;color:#1976d2;cursor:pointer;font-weight:600;padding:10px 24px;transition:all .2s ease}.role-tab:hover{background:#e3f2fd}.role-tab.active{background:#1976d2;color:#fff}.menu-section{margin-bottom:40px}.menu-section-header{margin-bottom:24px;text-align:center}.menu-section-header h3{color:#1976d2;font-size:1.5rem;margin:0 0 4px}.menu-section-header p{color:#666;margin:0}.menu-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.menu-card{align-items:flex-start;background:#fff;border:2px solid transparent;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;display:flex;gap:16px;padding:20px;position:relative;transition:all .2s ease}.menu-card:hover:not(.disabled){border-color:#1976d2;box-shadow:0 8px 24px rgba(0,0,0,.12);transform:translateY(-2px)}.menu-card:focus{border-color:#1976d2;outline:none}.menu-card.disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.menu-card-icon{flex-shrink:0;font-size:2rem}.menu-card-content{flex:1 1;min-width:0}.menu-card-content h4{color:#333;font-size:1.1rem;margin:0 0 4px}.menu-card-content p{color:#666;font-size:.85rem;margin:0}.external-icon{color:#999;font-size:.9rem;position:absolute;right:12px;top:12px}.coming-soon{background:#ff9800;border-radius:10px;color:#fff;font-size:.65rem;font-weight:600;padding:2px 8px;position:absolute;right:8px;text-transform:uppercase;top:8px}.quick-access{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);margin-top:48px;padding:24px;text-align:center}.quick-access h4{color:#666;font-weight:500;margin:0 0 16px}.quick-access-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.quick-btn{align-items:center;background:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 24px;transition:background .2s}.quick-btn:hover{background:#1565c0}@media (max-width:768px){.menu-container{padding:24px 16px}.menu-header h2{font-size:1.5rem}.menu-grid{grid-template-columns:1fr}.role-tabs{padding:0 16px}.quick-access-buttons{flex-direction:column}.quick-btn{justify-content:center;width:100%}}@media (max-width:480px){.menu-navbar{flex-direction:column;gap:12px;padding:12px 16px}.navbar-user{flex-direction:column;gap:8px;text-align:center}}.division-home{background:linear-gradient(135deg,#f5f7fa,#e4e9f2);min-height:100vh}.division-navbar{align-items:center;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.1);display:flex;justify-content:space-between;padding:1rem 2rem;position:sticky;top:0;z-index:100}.division-navbar .navbar-left{align-items:center;display:flex;gap:1rem}.division-navbar h1{color:#1a365d;font-size:1.5rem;margin:0}.division-navbar .brand-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#1976d2,#42a5f5);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.division-navbar .navbar-subtitle{border-left:2px solid #e2e8f0;color:#718096;font-size:.9rem;padding-left:1rem}.division-navbar .navbar-user{align-items:center;display:flex;gap:1rem}.division-navbar .navbar-roles{display:flex;gap:.25rem}.role-badge-small{background:#e2e8f0;border-radius:4px;color:#4a5568;padding:.2rem .5rem}.role-badge-small.more{background:#cbd5e0}.btn-back{background:transparent;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.btn-back:hover{background:#f7fafc;border-color:#cbd5e0}.btn-secondary{background:#edf2f7;border:none;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s}.btn-secondary:hover{background:#e2e8f0}.btn-logout{background:#e53e3e;border:none;font-size:.85rem;padding:.5rem 1rem}.btn-logout:hover{background:#c53030}.btn-primary{background:#3182ce;border:none;border-radius:6px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary:hover{background:#2c5282}.division-container{margin:0 auto;max-width:1400px;padding:2rem}.division-header{margin-bottom:2rem;text-align:center}.division-header h2{color:#1a365d;font-size:2rem;margin-bottom:.5rem}.division-subtitle{color:#718096;font-size:1rem}.division-header.submenu-header{align-items:center;background:#fff;border-left:4px solid #3182ce;border-left:4px solid var(--division-color,#3182ce);border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);display:flex;gap:1.5rem;justify-content:flex-start;padding:1.5rem 2rem;text-align:left}.division-header-icon{align-items:center;background:#ebf8ff;background:var(--division-color-light,#ebf8ff);border-radius:12px;display:flex;font-size:3rem;height:80px;justify-content:center;width:80px}.division-header-text h2{font-size:1.75rem;margin:0 0 .25rem}.division-header-text .division-subtitle{margin:0}.division-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.division-card{background:#fff;border:2px solid transparent;border-radius:16px;box-shadow:0 4px 15px rgba(0,0,0,.08);cursor:pointer;display:flex;flex-direction:column;min-height:200px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.division-card.accessible{border-color:#3182ce;border-color:var(--division-color,#3182ce)}.division-card.accessible:hover{box-shadow:0 8px 25px rgba(0,0,0,.15);transform:translateY(-5px)}.division-card.accessible:before{background:#3182ce;background:var(--division-color,#3182ce);content:"";height:4px;left:0;position:absolute;right:0;top:0}.division-card.disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.division-card-icon{align-items:center;border-radius:12px;display:flex;font-size:2.5rem;height:60px;justify-content:center;margin-bottom:1rem;width:60px}.division-card-icon,.division-card.accessible .division-card-icon{background:#f0f5ff;background:var(--division-color-light,#f0f5ff)}.division-card.disabled .division-card-icon{background:#e2e8f0;filter:grayscale(100%)}.division-card-content h3{color:#1a365d;font-size:1.25rem;margin:0 0 .5rem}.division-card.disabled .division-card-content h3{color:#718096}.division-card-content p{color:#718096;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.division-card-submenus{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.submenu-tag{background:#edf2f7;border-radius:4px;color:#4a5568;font-size:.75rem;padding:.25rem .5rem}.division-card.accessible .submenu-tag{background:#ebf8ff;background:var(--division-color-light,#ebf8ff);color:#3182ce;color:var(--division-color,#3182ce)}.submenu-tag.more{background:#e2e8f0;color:#718096}.division-card-overlay{align-items:center;background:hsla(0,0%,100%,.7);bottom:0;display:flex;flex-direction:column;gap:.5rem;justify-content:center;left:0;position:absolute;right:0;top:0}.lock-icon{font-size:2rem;opacity:.5}.division-card-overlay span:last-child{color:#718096;font-size:.9rem;font-weight:500}.submenu-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:2rem}.submenu-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.06);cursor:pointer;display:flex;gap:1rem;padding:1.5rem;position:relative;transition:all .3s ease}.submenu-card.accessible,.submenu-card.accessible:hover{border-color:#3182ce;border-color:var(--division-color,#3182ce)}.submenu-card.accessible:hover{box-shadow:0 4px 15px rgba(0,0,0,.1);transform:translateX(5px)}.submenu-card.disabled{background:#f7fafc;cursor:not-allowed;opacity:.5}.submenu-card-icon{align-items:center;background:#f0f5ff;background:var(--division-color-light,#f0f5ff);border-radius:10px;display:flex;flex-shrink:0;font-size:1.75rem;height:50px;justify-content:center;width:50px}.submenu-card.disabled .submenu-card-icon{background:#e2e8f0;filter:grayscale(100%)}.submenu-card-content{flex:1 1}.submenu-card-content h3{color:#1a365d;font-size:1.1rem;margin:0 0 .25rem}.submenu-card.disabled .submenu-card-content h3{color:#718096}.submenu-card-content p{color:#718096;font-size:.85rem;margin:0}.submenu-card-arrow{color:#3182ce;color:var(--division-color,#3182ce);font-size:1.25rem;opacity:0;transition:opacity .2s,transform .2s}.submenu-card.accessible:hover .submenu-card-arrow{opacity:1;transform:translateX(3px)}.submenu-card-overlay{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.no-access-message{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);margin-top:2rem;padding:3rem;text-align:center}.no-access-icon{display:block;font-size:3rem;margin-bottom:1rem}.no-access-message h3{color:#1a365d;margin:0 0 .5rem}.no-access-message p{color:#718096;margin-bottom:1.5rem}.error-message{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);padding:3rem}.error-message h2{color:#c53030;margin-bottom:.5rem}.error-message p{color:#718096;margin-bottom:1.5rem}.admin-tools-section{border-top:1px solid #e2e8f0;margin-top:3rem;padding-top:2rem}.admin-tools-section h3{color:#1a365d;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.admin-tools-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.admin-tool-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;gap:1rem;padding:1.25rem 1.5rem;transition:all .2s ease}.admin-tool-card:hover{border-color:#7c3aed;box-shadow:0 8px 25px rgba(124,58,237,.15);transform:translateY(-2px)}.admin-tool-icon{flex-shrink:0;font-size:2rem}.admin-tool-content h4{color:#1a365d;font-size:1rem;font-weight:600;margin:0 0 4px}.admin-tool-content p{color:#718096;font-size:.875rem;margin:0}@media (max-width:768px){.division-navbar{flex-direction:column;gap:1rem;padding:1rem}.division-navbar .navbar-left,.division-navbar .navbar-user{flex-wrap:wrap;justify-content:center;width:100%}.division-container{padding:1rem}.division-grid,.submenu-grid{grid-template-columns:1fr}.division-header.submenu-header{flex-direction:column;text-align:center}.admin-tools-grid{grid-template-columns:1fr}}.school-management-page{height:100%;margin:0 auto;max-width:1400px;overflow-y:auto;padding:24px}.school-management-page .page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.school-management-page .header-left h2{color:#1a1a2e;font-size:24px;font-weight:600;margin:0 0 8px}.school-management-page .page-description{color:#6b7280;font-size:14px;margin:0}.school-management-page .btn-primary{background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.school-management-page .btn-primary:hover:not(:disabled){box-shadow:0 4px 12px rgba(124,58,237,.3);transform:translateY(-1px)}.school-management-page .btn-secondary{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.school-management-page .btn-secondary:hover:not(:disabled){background:#e5e7eb}.school-management-page .message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:16px;padding:12px 16px}.school-management-page .message.success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.school-management-page .message.error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.school-management-page .filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.school-management-page .filter-group{flex:1 1;max-width:300px;min-width:200px}.school-management-page .filter-input,.school-management-page .filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 14px;transition:all .2s;width:100%}.school-management-page .filter-input:focus,.school-management-page .filter-select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.1);outline:none}.school-management-page .filter-results{color:#6b7280;font-size:14px;margin-left:auto}.school-management-page .error-state,.school-management-page .loading-state{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.school-management-page .loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#7c3aed;height:40px;width:40px}.school-management-page .error-icon{font-size:48px;margin-bottom:16px}.school-management-page .schools-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.school-management-page .no-data{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:60px 20px}.school-management-page .no-data .empty-icon{font-size:64px;margin-bottom:16px}.school-management-page .no-data p{color:#6b7280;margin-bottom:20px}.school-management-page .school-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s}.school-management-page .school-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.08);transform:translateY(-2px)}.school-management-page .school-card-header{align-items:flex-start;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-bottom:1px solid #e5e7eb;display:flex;gap:12px;padding:20px}.school-management-page .school-icon{flex-shrink:0;font-size:32px}.school-management-page .school-info{flex:1 1;min-width:0}.school-management-page .school-info h3{color:#1a1a2e;font-size:16px;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.school-management-page .school-code{background:#e5e7eb;border-radius:4px;color:#6b7280;font-size:12px;font-weight:500;padding:2px 8px}.school-management-page .status-badge{border-radius:20px;flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.05em;padding:4px 10px;text-transform:uppercase}.school-management-page .status-active{background:#d1fae5;color:#065f46}.school-management-page .status-inactive{background:#fef3c7;color:#92400e}.school-management-page .school-card-body{padding:16px 20px}.school-management-page .school-detail{align-items:flex-start;color:#4b5563;display:flex;font-size:13px;gap:10px;margin-bottom:10px}.school-management-page .school-detail:last-child{margin-bottom:0}.school-management-page .detail-icon{flex-shrink:0}.school-management-page .school-detail a{color:#7c3aed;text-decoration:none}.school-management-page .school-detail a:hover{text-decoration:underline}.school-management-page .school-card-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:8px;padding:12px 20px}.school-management-page .action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:500;gap:6px;justify-content:center;padding:8px 12px;transition:all .2s}.school-management-page .edit-btn{background:#f5f3ff;color:#6d28d9}.school-management-page .edit-btn:hover{background:#ede9fe}.school-management-page .delete-btn{background:#fef2f2;color:#dc2626}.school-management-page .delete-btn:hover{background:#fee2e2}.school-management-page .modal-overlay{align-items:center;background:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.school-management-page .school-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:100%}.school-management-page .modal-header{align-items:center;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.school-management-page .modal-header h3{color:#1a1a2e;font-size:18px;font-weight:600;margin:0}.school-management-page .modal-close{align-items:center;background:#e5e7eb;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.school-management-page .modal-close:hover{background:#d1d5db;color:#374151}.school-management-page .modal-body{flex:1 1;overflow-y:auto;padding:24px}.school-management-page .form-section{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding-bottom:20px}.school-management-page .form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.school-management-page .form-section h4{color:#374151;font-size:14px;font-weight:600;letter-spacing:.05em;margin:0 0 16px;text-transform:uppercase}.school-management-page .form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.school-management-page .form-row.three-col{grid-template-columns:2fr 1fr 1fr}.school-management-page .form-group{margin-bottom:16px}.school-management-page .form-group label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:6px}.school-management-page .form-input,.school-management-page .form-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 12px;transition:all .2s;width:100%}.school-management-page .form-input:focus,.school-management-page .form-select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.1);outline:none}.school-management-page .modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}@media (max-width:768px){.school-management-page .page-header{flex-direction:column;gap:16px}.school-management-page .filters-bar{flex-direction:column}.school-management-page .filter-group{max-width:none}.school-management-page .form-row,.school-management-page .form-row.three-col,.school-management-page .schools-grid{grid-template-columns:1fr}.school-management-page .school-modal{max-height:95vh}}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.-bottom-20{bottom:-5rem}.-left-40{left:-10rem}.-right-20{right:-5rem}.-top-40{top:-10rem}.left-0{left:0}.left-1\/4{left:25%}.left-4{left:1rem}.right-0{right:0}.right-4{right:1rem}.top-1\/2{top:50%}.top-4{top:1rem}.z-10{z-index:10}.z-50{z-index:50}.col-span-2{grid-column:span 2/span 2}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-5{margin-left:1.25rem;margin-right:1.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-3{margin-bottom:.75rem;margin-top:.75rem}.my-8{margin-bottom:2rem;margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-12{margin-left:3rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-24{height:6rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-72{height:18rem}.h-8{height:2rem}.h-80{height:20rem}.h-9{height:2.25rem}.h-96{height:24rem}.max-h-40{max-height:10rem}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-24{width:6rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-96{width:24rem}.w-full{width:100%}.min-w-\[180px\]{min-width:180px}.min-w-\[200px\]{min-width:200px}.min-w-\[220px\]{min-width:220px}.min-w-\[320px\]{min-width:320px}.min-w-\[36px\]{min-width:36px}.max-w-7xl{max-width:80rem}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.origin-left{transform-origin:left}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.-translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-full{--tw-translate-y:-100%}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x:100%}.translate-y-0{--tw-translate-y:0px}.translate-y-0,.translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-full{--tw-translate-y:100%}.rotate-180{--tw-rotate:180deg}.rotate-180,.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize{resize:both}.appearance-none{appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.25rem*var(--tw-space-y-reverse));margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-bottom-width:calc(1px*var(--tw-divide-y-reverse));border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)))}.divide-slate-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:#f1f5f9;border-color:rgb(241 245 249/var(--tw-divide-opacity,1))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-amber-100\/80{border-color:hsla(48,96%,89%,.8)}.border-amber-200{--tw-border-opacity:1;border-color:#fde68a;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-blue-100\/80{border-color:rgba(219,234,254,.8)}.border-blue-500{--tw-border-opacity:1;border-color:#3b82f6;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-cyan-100\/80{border-color:rgba(207,250,254,.8)}.border-gray-100{--tw-border-opacity:1;border-color:#f3f4f6;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:#e5e7eb;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:#fecaca;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-slate-100{--tw-border-opacity:1;border-color:#f1f5f9;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.border-slate-200{--tw-border-opacity:1;border-color:#e2e8f0;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.border-slate-200\/60{border-color:rgba(226,232,240,.6)}.border-slate-300{--tw-border-opacity:1;border-color:#cbd5e1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-white{--tw-border-opacity:1;border-color:#fff;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.border-t-transparent{border-top-color:transparent}.bg-amber-50{--tw-bg-opacity:1;background-color:#fffbeb;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-blue-100{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-50\/40{background-color:rgba(239,246,255,.4)}.bg-blue-500{--tw-bg-opacity:1;background-color:#3b82f6;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-emerald-50{--tw-bg-opacity:1;background-color:#ecfdf5;background-color:rgb(236 253 245/var(--tw-bg-opacity,1))}.bg-emerald-500{--tw-bg-opacity:1;background-color:#10b981;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-primary-400\/20{background-color:rgba(96,165,250,.2)}.bg-primary-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-purple-50{--tw-bg-opacity:1;background-color:#faf5ff;background-color:rgb(250 245 255/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:#dc2626;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-slate-100{--tw-bg-opacity:1;background-color:#f1f5f9;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-400{--tw-bg-opacity:1;background-color:#94a3b8;background-color:rgb(148 163 184/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:#f8fafc;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-50\/50{background-color:rgba(248,250,252,.5)}.bg-slate-50\/60{background-color:rgba(248,250,252,.6)}.bg-slate-50\/80{background-color:rgba(248,250,252,.8)}.bg-slate-800{--tw-bg-opacity:1;background-color:#1e293b;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.bg-slate-900\/60{background-color:rgba(15,23,42,.6)}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:hsla(0,0%,100%,.1)}.bg-white\/20{background-color:hsla(0,0%,100%,.2)}.bg-white\/40{background-color:hsla(0,0%,100%,.4)}.bg-white\/95{background-color:hsla(0,0%,100%,.95)}.bg-\[url\(\'data\:image\/svg\+xml\;base64\2c PHN2ZyB3aWR0aD0iNjAiIGhlaWdodD0iNjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI\+PGRlZnM\+PHBhdHRlcm4gaWQ9ImciIHdpZHRoPSI2MCIgaGVpZ2h0PSI2MCIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSI\+PHBhdGggZD0iTTAgMGg2MHY2MEgweiIgZmlsbD0ibm9uZSIvPjxwYXRoIGQ9Ik0zMCAwdjYwTTAgMzBoNjAiIHN0cm9rZT0icmdiYSgyNTUsMjU1LDI1NSwwLjAzKSIgc3Ryb2tlLXdpZHRoPSIxIi8\+PC9wYXR0ZXJuPjwvZGVmcz48cmVjdCBmaWxsPSJ1cmwoI2cpIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIi8\+PC9zdmc\+\'\)\]{background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjAiIGhlaWdodD0iNjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PHBhdHRlcm4gaWQ9ImEiIHdpZHRoPSI2MCIgaGVpZ2h0PSI2MCIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHBhdGggZD0iTTAgMGg2MHY2MEgweiIgZmlsbD0ibm9uZSIvPjxwYXRoIGQ9Ik0zMCAwdjYwTTAgMzBoNjAiIHN0cm9rZT0icmdiYSgyNTUsMjU1LDI1NSwwLjAzKSIvPjwvcGF0dGVybj48L2RlZnM+PHJlY3QgZmlsbD0idXJsKCNhKSIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIvPjwvc3ZnPg==)}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-\[\#0d1b3e\]{--tw-gradient-from:#0d1b3e var(--tw-gradient-from-position);--tw-gradient-to:rgba(13,27,62,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-50{--tw-gradient-from:#fffbeb var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,251,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-500{--tw-gradient-from:#f59e0b var(--tw-gradient-from-position);--tw-gradient-to:rgba(245,158,11,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-50{--tw-gradient-from:#ecfeff var(--tw-gradient-from-position);--tw-gradient-to:rgba(236,254,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from:#10b981 var(--tw-gradient-from-position);--tw-gradient-to:rgba(16,185,129,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-50{--tw-gradient-from:#f9fafb var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-500{--tw-gradient-from:#22c55e var(--tw-gradient-from-position);--tw-gradient-to:rgba(34,197,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-primary-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-primary-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-500{--tw-gradient-from:#ef4444 var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,68,68,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-400{--tw-gradient-from:#94a3b8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(148,163,184,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from:#f8fafc var(--tw-gradient-from-position);--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-violet-500{--tw-gradient-from:#8b5cf6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(139,92,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-\[\#162d6b\]{--tw-gradient-to:rgba(22,45,107,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#162d6b var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-primary-700{--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1d4ed8 var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-\[\#1e40af\]{--tw-gradient-to:#1e40af var(--tw-gradient-to-position)}.to-amber-600{--tw-gradient-to:#d97706 var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-emerald-600{--tw-gradient-to:#059669 var(--tw-gradient-to-position)}.to-gray-100{--tw-gradient-to:#f3f4f6 var(--tw-gradient-to-position)}.to-orange-600{--tw-gradient-to:#ea580c var(--tw-gradient-to-position)}.to-primary-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.to-red-600{--tw-gradient-to:#dc2626 var(--tw-gradient-to-position)}.to-rose-600{--tw-gradient-to:#e11d48 var(--tw-gradient-to-position)}.to-slate-500{--tw-gradient-to:#64748b var(--tw-gradient-to-position)}.to-violet-600{--tw-gradient-to:#7c3aed var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-12{padding-left:3rem;padding-right:3rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-16{padding-bottom:4rem;padding-top:4rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-3\.5{padding-bottom:.875rem;padding-top:.875rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.py-7{padding-bottom:1.75rem;padding-top:1.75rem}.pb-2{padding-bottom:.5rem}.pl-12{padding-left:3rem}.pl-4{padding-left:1rem}.pr-10{padding-right:2.5rem}.pr-12{padding-right:3rem}.pr-4{padding-right:1rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-feature-settings:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-400{--tw-text-opacity:1;color:#fbbf24;color:rgb(251 191 36/var(--tw-text-opacity,1))}.text-amber-700{--tw-text-opacity:1;color:#b45309;color:rgb(180 83 9/var(--tw-text-opacity,1))}.text-amber-800{--tw-text-opacity:1;color:#92400e;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-blue-200\/70{color:rgba(191,219,254,.7)}.text-blue-300{--tw-text-opacity:1;color:#93c5fd;color:rgb(147 197 253/var(--tw-text-opacity,1))}.text-blue-400{--tw-text-opacity:1;color:#60a5fa;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:#3b82f6;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-cyan-400{--tw-text-opacity:1;color:#22d3ee;color:rgb(34 211 238/var(--tw-text-opacity,1))}.text-cyan-700{--tw-text-opacity:1;color:#0e7490;color:rgb(14 116 144/var(--tw-text-opacity,1))}.text-emerald-600{--tw-text-opacity:1;color:#059669;color:rgb(5 150 105/var(--tw-text-opacity,1))}.text-emerald-700{--tw-text-opacity:1;color:#047857;color:rgb(4 120 87/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-primary-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-primary-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-purple-700{--tw-text-opacity:1;color:#7e22ce;color:rgb(126 34 206/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:#f87171;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-slate-400{--tw-text-opacity:1;color:#94a3b8;color:rgb(148 163 184/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:#64748b;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:#475569;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:#334155;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-800{--tw-text-opacity:1;color:#1e293b;color:rgb(30 41 59/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/70{color:hsla(0,0%,100%,.7)}.text-white\/80{color:hsla(0,0%,100%,.8)}.placeholder-gray-400::placeholder{--tw-placeholder-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-40{opacity:.4}.opacity-75{opacity:.75}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-2xl,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.shadow-blue-500\/20{--tw-shadow-color:rgba(59,130,246,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-500\/30{--tw-shadow-color:rgba(59,130,246,.3);--tw-shadow:var(--tw-shadow-colored)}.shadow-emerald-500\/30{--tw-shadow-color:rgba(16,185,129,.3);--tw-shadow:var(--tw-shadow-colored)}.shadow-primary-500\/30{--tw-shadow-color:rgba(59,130,246,.3);--tw-shadow:var(--tw-shadow-colored)}.shadow-slate-200\/50{--tw-shadow-color:rgba(226,232,240,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-slate-400\/30{--tw-shadow-color:rgba(148,163,184,.3);--tw-shadow:var(--tw-shadow-colored)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.blur-3xl{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-3xl{--tw-blur:blur(64px)}.grayscale{--tw-grayscale:grayscale(100%)}.filter,.grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px)}.backdrop-blur,.backdrop-blur-sm{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150,.transition-transform{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:1200px;padding:20px}.auth-container{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);display:flex;justify-content:center;min-height:100vh}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.2);max-width:400px;padding:40px;width:100%}.auth-card h1{color:#1976d2;margin-bottom:8px;text-align:center}.auth-card .brand-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#1976d2,#42a5f5);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin-bottom:4px}.auth-card .portal-name{color:#666;font-size:1rem;font-weight:500;letter-spacing:2px;margin-bottom:20px;text-align:center;text-transform:uppercase}.auth-card h2{color:#666;font-size:1.1rem;font-weight:400;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:6px}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#1976d2;outline:none}.btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:background-color .2s,transform .1s;width:100%}.btn:active{transform:scale(.98)}.btn-primary{background-color:#1976d2;color:#fff}.btn-primary:hover{background-color:#1565c0}.btn-primary:disabled{background-color:#90caf9;cursor:not-allowed}.btn-link{background:none;border:none;color:#1976d2;cursor:pointer;display:block;font-size:14px;margin-top:16px;text-align:center;text-decoration:underline}.btn-link:hover{color:#0d47a1}.error-message{background-color:#ffebee;color:#c62828}.error-message,.success-message{border-radius:8px;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.success-message{background-color:#e8f5e9;color:#2e7d32}.home-container{background-color:#f5f5f5;min-height:100vh}.navbar{background:linear-gradient(135deg,#1565c0,#0d47a1);box-shadow:0 2px 12px rgba(0,0,0,.15);height:60px;justify-content:space-between;padding:0 24px}.navbar,.navbar-left{align-items:center;display:flex}.navbar-left{gap:16px}.btn-menu{background:hsla(0,0%,100%,.1);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.2rem;line-height:1;padding:8px 10px;transition:background .2s}.btn-menu:hover{background:hsla(0,0%,100%,.2)}.navbar h1{color:#fff;font-size:1.25rem;margin:0}.navbar .brand-title{color:#fff;font-size:1.15rem;font-weight:600;letter-spacing:-.01em}.navbar .navbar-subtitle{border-left:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.7);font-size:.8rem;font-weight:500;padding-left:16px}.env-badge,.navbar .navbar-subtitle{letter-spacing:.05em;text-transform:uppercase}.env-badge{border-radius:4px;font-size:.65rem;font-weight:600;margin-left:12px;padding:3px 8px}.env-badge.env-local,.env-badge.env-prod,.env-badge.env-uat{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.85)}.navbar-user{align-items:center;display:flex;gap:12px}.navbar-user>span{color:hsla(0,0%,100%,.9);font-size:.85rem;font-weight:500}.role-badge-small{background:hsla(0,0%,100%,.15);font-size:.7rem;letter-spacing:.03em;padding:4px 10px;text-transform:uppercase}.navbar-avatar-wrapper{position:relative}.navbar-avatar{align-items:center;background:hsla(0,0%,100%,.2);border:2px solid hsla(0,0%,100%,.4);border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:700;height:36px;justify-content:center;letter-spacing:.02em;transition:all .2s;width:36px}.navbar-avatar:hover{background:hsla(0,0%,100%,.3);border-color:hsla(0,0%,100%,.6);transform:scale(1.05)}.navbar-avatar-dropdown{animation:avatarDropdownIn .15s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.15),0 2px 8px rgba(0,0,0,.08);min-width:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:9999}@keyframes avatarDropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.navbar-avatar-dropdown-header{align-items:center;display:flex;gap:12px;padding:16px}.navbar-avatar-lg{align-items:center;background:linear-gradient(135deg,#1565c0,#0d47a1);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.95rem;font-weight:700;height:42px;justify-content:center;width:42px}.navbar-avatar-info{display:flex;flex-direction:column;min-width:0}.navbar-avatar-name{color:#1a1a1a;font-size:.9rem;font-weight:600}.navbar-avatar-email,.navbar-avatar-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-avatar-email{color:#888;font-size:.75rem}.navbar-avatar-dropdown-divider{background:#eee;height:1px;margin:0}.navbar-avatar-dropdown-item{align-items:center;background:transparent;border:none;color:#555;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:10px;padding:12px 16px;text-align:left;transition:all .15s;width:100%}.navbar-avatar-dropdown-item:hover{background:#f5f5f5;color:#d32f2f}.navbar-avatar-dropdown-item svg{flex-shrink:0;opacity:.6}.navbar-avatar-dropdown-item:hover svg{opacity:1}.btn-logout{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:6px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 14px;transition:all .2s}.btn-logout:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.3)}.dashboard{padding:40px}.welcome-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin:0 auto;max-width:600px;padding:40px;text-align:center}.welcome-card h2{color:#1976d2;margin-bottom:16px}.welcome-card p{color:#666;font-size:1.1rem}.role-badge{background-color:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-block;font-size:14px;margin:4px;padding:4px 12px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-left:auto;margin-right:auto;margin-top:40px;max-width:800px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);padding:24px;text-align:center}.stat-card h3{color:#1976d2;font-size:2rem;margin-bottom:8px}.stat-card p{color:#666}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.version-footer{background:transparent;bottom:0;font-size:12px;left:0;padding:8px 16px;pointer-events:none;position:fixed;right:0;text-align:center;z-index:1000}.auth-container~.version-footer,.version-footer{color:hsla(0,0%,100%,.7)}.home-container~.version-footer{color:rgba(0,0,0,.4)}.welcome-card .role-indicator{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-top:12px;padding:6px 16px;text-transform:uppercase}.admin-welcome .role-indicator{background:#e3f2fd;color:#1565c0}.course-admin-welcome .role-indicator{background:#e0f7fa;color:#00838f}.principal-welcome .role-indicator{background:#f3e5f5;color:#7b1fa2}.parent-welcome .role-indicator{background:#e8f5e9;color:#2e7d32}.student-welcome .role-indicator{background:#fff3e0;color:#ef6c00}.program-welcome .role-indicator{background:#e0f7fa;color:#00838f}.admin-actions,.parent-actions,.principal-actions,.program-actions,.student-actions{margin:40px auto 0;max-width:800px;padding:0 20px}.admin-actions h3,.parent-actions h3,.principal-actions h3,.program-actions h3,.student-actions h3{color:#333;margin-bottom:20px}.action-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.action-btn{background:#fff;border:2px solid #e0e0e0;border-radius:12px;color:#555;font-size:14px;font-weight:500;padding:16px 20px}.action-btn:hover:not(:disabled){background:#f5f9ff;border-color:#1976d2;color:#1976d2}.action-btn:disabled{cursor:not-allowed;opacity:.6}.navbar-roles{display:flex;gap:6px;margin-left:12px}.role-badge-small{background:hsla(0,0%,100%,.2);border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;padding:3px 10px}.program-layout{display:flex;gap:24px;margin:0 auto;max-width:1400px;padding:20px}.program-sidebar{flex-shrink:0;width:400px}.program-main{flex:1 1;min-width:0}.history-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);overflow:hidden}.history-list-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:16px 20px}.history-list-header h3{color:#333;font-size:1.1rem;margin:0 0 12px}.history-filter{display:flex;gap:8px}.history-filter select{background:#fff;border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;padding:8px 12px}.history-list{max-height:500px;overflow-y:auto}.history-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:14px 20px;transition:background-color .15s}.history-item:hover{background-color:#f5f9ff}.history-item.selected{background-color:#e3f2fd;border-left:3px solid #1976d2}.history-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:6px}.history-item-title{align-items:center;color:#333;display:flex;font-size:.95rem;font-weight:500;gap:6px}.history-item-title.has-file{color:#1976d2;cursor:pointer}.history-item-title.has-file:hover{color:#1565c0;text-decoration:underline}.file-icon{font-size:.85rem}.history-item-type{border-radius:10px;font-size:.7rem;font-weight:500;padding:3px 8px;text-transform:uppercase}.history-item-type.transcript{background:#e8f5e9;color:#2e7d32}.history-item-type.testresult{background:#fff3e0;color:#ef6c00}.history-item-type.document{background:#e3f2fd;color:#1565c0}.history-item-type.certificate{background:#f3e5f5;color:#7b1fa2}.history-item-type.other{background:#f5f5f5;color:#666}.history-item-meta{color:#666;display:flex;font-size:.8rem;gap:16px}.history-item-student{color:#555;font-weight:500}.history-empty{color:#888}.history-empty,.history-loading{padding:40px 20px;text-align:center}.history-loading{color:#666}.file-drop-zone{background:#fafafa;border:2px dashed #ccc;border-radius:12px;cursor:pointer;margin:16px;padding:24px;text-align:center;transition:all .2s}.file-drop-zone:hover:not(.disabled){background:#f5f9ff;border-color:#1976d2}.file-drop-zone.dragging{background:#e3f2fd;border-color:#1976d2;border-style:solid}.file-drop-zone.disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.drop-zone-content{pointer-events:none}.drop-zone-icon{font-size:2.5rem;margin-bottom:8px}.drop-zone-content p{color:#666;margin:4px 0}.drop-zone-hint{color:#888!important;font-size:.85rem}.drop-zone-formats{color:#aaa!important;font-size:.75rem;margin-top:8px!important}.upload-message{border-radius:8px;font-size:.9rem;margin:12px 16px;padding:10px 16px}.upload-message.success{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.upload-message.error{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.upload-progress{color:#1976d2;font-size:.9rem;padding:8px;text-align:center}.parent-dashboard{max-width:1400px}.parent-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:280px 1fr;margin-top:24px}.parent-sidebar{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:20px}.parent-sidebar h3{border-bottom:2px solid #e91e63;color:#333;font-size:1.1rem;margin:0 0 16px;padding-bottom:12px}.parent-main{gap:24px}.parent-main,.student-list{display:flex;flex-direction:column}.student-list{gap:8px;max-height:400px;overflow-y:auto}.student-item{background:#f8f9fa;border:2px solid transparent;border-radius:8px;cursor:pointer;padding:12px;transition:all .2s ease}.student-item:hover{background:#fce4ec;border-color:#f48fb1}.student-item.selected{background:#fce4ec;border-color:#e91e63}.student-name{color:#333;font-size:.95rem;font-weight:500}.student-relationship{color:#666;font-size:.8rem;margin-top:4px;text-transform:capitalize}.list-empty,.list-error,.list-loading{color:#666;font-size:.9rem;padding:20px;text-align:center}.list-empty small{color:#999;display:block;margin-top:8px}.child-details-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:24px}.child-details-card h3{border-bottom:2px solid #e91e63;color:#333;margin:0 0 16px;padding-bottom:12px}.child-details-card p{color:#555;margin:8px 0}.sidebar-section{margin-bottom:24px}.sidebar-section:last-child{margin-bottom:0}.sidebar-actions{display:flex;flex-direction:column;gap:8px}.sidebar-action-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#333;cursor:pointer;font-size:.9rem;padding:10px 16px;text-align:left;transition:all .2s ease;width:100%}.sidebar-action-btn:hover:not(:disabled){background:#fce4ec;border-color:#f48fb1;color:#c2185b}.sidebar-action-btn:disabled{cursor:not-allowed;opacity:.6}.sidebar-action-btn.program:hover:not(:disabled){background:#e3f2fd;border-color:#64b5f6;color:#1565c0}.program-sidebar .sidebar-section{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:16px}.program-sidebar .sidebar-section h3{border-bottom:2px solid #1976d2;color:#333;font-size:1rem;margin:0 0 12px;padding-bottom:8px}.resizable-splitter{display:flex;height:calc(100vh - 60px);overflow:hidden;width:100%}.resizable-left{display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden;position:relative}.resizable-left .app-sidebar{height:100%;max-width:none;min-width:0;min-width:auto;overflow-x:hidden;overflow-y:auto;width:100%}.resizable-divider{align-items:center;background:linear-gradient(180deg,#1565c0,#0d47a1);cursor:col-resize;display:flex;flex-shrink:0;justify-content:center;min-width:8px;position:relative;transition:all .15s;width:8px;z-index:100}.resizable-divider.dragging,.resizable-divider:hover{background:#1976d2;width:10px}.divider-handle{background:hsla(0,0%,100%,.4);border-radius:2px;height:60px;transition:all .15s;width:4px}.resizable-divider.dragging .divider-handle,.resizable-divider:hover .divider-handle{background:hsla(0,0%,100%,.8);height:80px}.resizable-right{display:flex;flex:1 1;flex-direction:column;height:100%;min-width:300px;overflow:hidden}.dashboard-layout{display:flex;min-height:calc(100vh - 60px)}.app-sidebar{background:linear-gradient(180deg,#1565c0,#0d47a1);box-shadow:4px 0 20px rgba(0,0,0,.15);color:#fff;display:flex;flex-direction:column;max-width:320px;min-width:260px;overflow-y:auto;width:280px}.sidebar-header{border-bottom:1px solid hsla(0,0%,100%,.1);padding:20px 16px}.sidebar-title{align-items:center;color:#fff;display:flex;font-size:1.1rem;font-weight:600;gap:10px;letter-spacing:.02em;margin-bottom:16px}.sidebar-title-icon{flex-shrink:0;height:20px;opacity:.85;width:20px}.sidebar-title span{opacity:.95}.sidebar-stats{display:flex;gap:10px}.sidebar-stat{align-items:center;background:hsla(0,0%,100%,.1);border-radius:8px;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:12px 10px;transition:background .2s ease}.sidebar-stat:hover{background:hsla(0,0%,100%,.15)}.sidebar-stat-value{color:#fff;font-size:1.25rem;font-weight:700;line-height:1}.sidebar-stat-label{font-size:.65rem;font-weight:500;letter-spacing:.05em;margin-top:4px;opacity:.6;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.15);border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.25)}.sidebar-footer{border-top:1px solid hsla(0,0%,100%,.1);padding:12px}.sidebar-logout-btn{align-items:center;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;color:hsla(0,0%,100%,.8);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;justify-content:center;padding:10px 14px;transition:all .15s ease;width:100%}.sidebar-logout-btn:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.2);color:#fff}.sidebar-logout-btn svg{height:18px;width:18px}.sidebar-version{font-size:.7rem;opacity:.4}.sidebar-menu-section{margin-bottom:4px}.sidebar-section-title{color:hsla(0,0%,100%,.4);font-size:.65rem;font-weight:600;letter-spacing:.08em;padding:12px 14px 6px;text-transform:uppercase}.sidebar-item{align-items:center;background:transparent;border:none;border-radius:8px;color:hsla(0,0%,100%,.7);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;margin:2px 0;padding:10px 14px;text-align:left;transition:all .15s ease;width:100%}.sidebar-item:hover:not(.disabled){background:hsla(0,0%,100%,.1);color:#fff}.sidebar-item.active{background:hsla(0,0%,100%,.15);color:#fff;font-weight:600}.sidebar-item.disabled{cursor:not-allowed;opacity:.4}.sidebar-item-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;margin-right:10px;opacity:.8;width:20px}.sidebar-item-icon svg{height:100%;width:100%}.sidebar-item.active .sidebar-item-icon,.sidebar-item:hover:not(.disabled) .sidebar-item-icon{opacity:1}.sidebar-item-label{flex:1 1}.sidebar-submenu{display:flex;flex-direction:column}.sidebar-submenu-toggle{position:relative}.sidebar-submenu-arrow{font-size:.65rem;margin-left:8px;opacity:.5;transition:transform .2s ease}.sidebar-submenu.open .sidebar-submenu-arrow{transform:rotate(180deg)}.sidebar-submenu-items{border-left:1px solid hsla(0,0%,100%,.15);margin-bottom:2px;margin-left:30px;margin-top:2px;padding-left:12px}.sidebar-subitem{border-radius:6px;font-size:.8rem;margin:1px 0;padding:8px 12px}.sidebar-subitem .sidebar-item-icon{height:16px;margin-right:8px;width:16px}.dashboard-content{background:#f8fafc;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.dashboard-empty{align-items:center;color:#64748b;display:flex;font-size:1rem;height:100%;justify-content:center;padding:40px}.dashboard-empty .empty-state{max-width:400px;text-align:center}.dashboard-empty .empty-icon{font-size:3rem;margin-bottom:16px;opacity:.7}.dashboard-empty .empty-state h3{color:#333;font-size:1.3rem;margin:0 0 12px}.dashboard-empty .empty-state p{color:#666;margin:0 0 16px}.dashboard-empty .empty-options{list-style:none;margin:0;padding:0;text-align:left}.dashboard-empty .empty-options li{border-bottom:1px solid #eee;padding:8px 0}.dashboard-empty .empty-options li:last-child{border-bottom:none}.editor-full{display:flex;flex-direction:column;height:100%}.sidebar-filter{padding:8px 16px}.sidebar-select{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.3);border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 12px;width:100%}.sidebar-select option{background:#1565c0;color:#fff}.sidebar-select:focus{background:hsla(0,0%,100%,.15);border-color:#fff;outline:none}.sidebar-history-list{margin:8px 0;max-height:300px;overflow-y:auto}.sidebar-history-item{border-bottom:1px solid hsla(0,0%,100%,.1);cursor:pointer;padding:10px 16px;transition:background .15s}.sidebar-history-item:hover{background:hsla(0,0%,100%,.1)}.sidebar-history-item.active{background:hsla(0,0%,100%,.2)}.sidebar-history-title{color:#fff;display:block;font-size:.9rem;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-history-title .file-icon{margin-right:6px}.sidebar-history-type{background:hsla(0,0%,100%,.2);border-radius:10px;color:#fff;font-size:.7rem;padding:2px 8px;text-transform:uppercase}.sidebar-history-actions{align-items:center;display:flex;gap:6px}.permissions-btn{background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;opacity:.6;padding:2px 4px;transition:opacity .15s,background .15s}.permissions-btn:hover{background:hsla(0,0%,100%,.15);opacity:1}.sidebar-history-item:hover .permissions-btn{opacity:.8}.permissions-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.3);max-width:380px;overflow:hidden;width:100%}.modal-header{background:#1976d2;color:#fff;padding:16px 20px}.modal-header h3{font-size:1.1rem;margin:0}.modal-close{background:transparent;color:#fff;font-size:1.5rem;opacity:.8}.modal-close:hover{opacity:1}.modal-body{padding:20px}.modal-subtitle{color:#666;font-size:.9rem;margin-bottom:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permissions-grid{display:flex;flex-direction:column;gap:12px}.permissions-header{border-bottom:1px solid #eee;color:#666;font-size:.85rem;font-weight:600;padding-bottom:8px;text-align:center}.permissions-header,.permissions-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:80px 1fr 1fr}.permissions-row{align-items:center}.role-label{color:#333;font-weight:500}.checkbox-wrapper{cursor:pointer;display:flex;justify-content:center}.checkbox-wrapper input{accent-color:#1976d2;cursor:pointer;height:18px;width:18px}.modal-footer{background:#f5f5f5;border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.modal-footer .btn-secondary{background:#e0e0e0;border:none;border-radius:6px;color:#333;cursor:pointer;font-weight:500;padding:8px 16px}.modal-footer .btn-secondary:hover{background:#d0d0d0}.modal-footer .btn-primary{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px}.modal-footer .btn-primary:hover{background:#1565c0}.modal-footer .btn-primary:disabled,.modal-footer .btn-secondary:disabled{cursor:not-allowed;opacity:.6}.sidebar-empty,.sidebar-error,.sidebar-loading{color:hsla(0,0%,100%,.7);font-size:.9rem;padding:16px;text-align:center}.app-sidebar .file-drop-zone{background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.4);margin:8px 12px;padding:16px}.app-sidebar .file-drop-zone:hover:not(.disabled){background:hsla(0,0%,100%,.1);border-color:#fff}.app-sidebar .file-drop-zone.dragging{background:hsla(0,0%,100%,.15);border-color:#fff}.app-sidebar .drop-zone-content p{color:hsla(0,0%,100%,.9)}.app-sidebar .drop-zone-hint{color:hsla(0,0%,100%,.6)!important}.app-sidebar .upload-message{font-size:.85rem;margin:8px 12px}.app-sidebar .upload-progress{color:#fff;font-size:.85rem;padding:8px;text-align:center}.sidebar-section-subtitle{color:hsla(0,0%,100%,.6);font-size:.75rem;letter-spacing:.5px;padding:8px 16px 4px;text-transform:uppercase}.sidebar-course-add{padding:0 12px 8px}.sidebar-program-courses{margin:4px 0;max-height:250px;overflow-y:auto}.sidebar-program-course-item{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.1);display:flex;gap:8px;padding:8px 12px;transition:background .15s}.sidebar-program-course-item:hover{background:hsla(0,0%,100%,.1)}.course-order-controls{display:flex;flex-direction:column;gap:2px}.order-btn{background:hsla(0,0%,100%,.15);border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:.65rem;padding:2px 4px;transition:background .15s}.order-btn:hover:not(:disabled){background:hsla(0,0%,100%,.3)}.order-btn:disabled{cursor:not-allowed;opacity:.3}.course-info{flex:1 1;min-width:0}.course-info .course-title{color:#fff;display:block;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-status-select{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:4px;color:#fff;cursor:pointer;font-size:.7rem;margin-top:4px;padding:2px 6px}.course-status-select option{background:#2c3e50;color:#fff}.remove-course-btn{background:transparent;border:none;border-radius:4px;color:hsla(0,0%,100%,.6);cursor:pointer;font-size:1.2rem;padding:2px 6px;transition:color .15s,background .15s}.remove-course-btn:hover{background:hsla(0,0%,100%,.1);color:#ff6b6b}.sidebar-programs-list{border-top:1px solid hsla(0,0%,100%,.1);margin:4px 0;max-height:200px;overflow-y:auto;padding-top:8px}.sidebar-program-item{align-items:center;background:hsla(0,0%,100%,.05);border-radius:6px;cursor:pointer;display:flex;gap:8px;margin:4px 8px;padding:10px 12px;transition:background .15s,transform .1s}.sidebar-program-item:hover{background:hsla(0,0%,100%,.12)}.sidebar-program-item.active{background:rgba(25,118,210,.3);border-left:3px solid #1976d2}.program-item-active-indicator{align-items:center;color:#4caf50;display:flex;font-size:.75rem;font-weight:700;height:18px;justify-content:center;min-width:18px;width:18px}.program-item-info{flex:1 1;min-width:0}.program-item-name{color:#fff;display:block;font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.program-item-year{color:hsla(0,0%,100%,.6);display:block;font-size:.7rem;margin-top:2px}.program-item-count{background:hsla(0,0%,100%,.1);border-radius:10px;color:hsla(0,0%,100%,.5);font-size:.7rem;padding:2px 8px;white-space:nowrap}.sidebar-new-program-btn{background:linear-gradient(135deg,#1976d2,#1565c0);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:8px;padding:10px 12px;transition:all .15s;width:100%}.sidebar-new-program-btn:hover{background:linear-gradient(135deg,#1565c0,#0d47a1);transform:translateY(-1px)}.create-program-content{margin:0 auto;max-width:1200px;padding:24px}.program-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.program-header-left{flex:1 1}.program-header-right{align-items:center;display:flex;gap:16px}.program-header-right .header-message{border-radius:4px;font-size:.875rem;padding:6px 12px}.program-header-right .header-message.success{background:#e8f5e9;color:#2e7d32}.program-header-right .header-message.error{background:#ffebee;color:#c62828}.save-program-btn{font-size:1rem;font-weight:600;padding:10px 24px}.content-tabs-bar{background:#1e2a38;border-bottom:1px solid #2c3e50;display:flex;min-height:40px;overflow-x:auto;padding:0 8px;scrollbar-width:thin}.content-tabs-bar::-webkit-scrollbar{height:4px}.content-tabs-bar::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.2);border-radius:2px}.content-tab{align-items:center;background:transparent;border:none;border-bottom:2px solid transparent;color:hsla(0,0%,100%,.7);cursor:pointer;display:flex;font-size:.875rem;gap:8px;padding:8px 12px;transition:all .15s;white-space:nowrap}.content-tab:hover{background:hsla(0,0%,100%,.05);color:#fff}.content-tab.active{background:hsla(0,0%,100%,.1);border-bottom-color:#1976d2;color:#fff}.content-tab-icon{font-size:1rem}.content-tab-title{max-width:150px;overflow:hidden;text-overflow:ellipsis}.content-tab-close{background:transparent;border:none;border-radius:4px;color:hsla(0,0%,100%,.5);cursor:pointer;font-size:1rem;line-height:1;padding:2px 6px;transition:all .15s}.content-tab-close:hover{background:hsla(0,0%,100%,.2);color:#fff}.content-tabs-content{flex:1 1;overflow:hidden;position:relative}.content-tab-panel{display:none;height:100%;overflow:auto}.content-tab-panel.active{display:block}.history-content{padding:24px}.history-content h2{color:#1976d2;margin-bottom:8px}.program-header h2{align-items:center;color:#1976d2;display:flex;gap:12px;margin-bottom:4px}.program-active-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;padding:4px 10px}.program-active-badge.active{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.program-active-badge.inactive{background:#fff3e0;border:1px solid #ffcc80;color:#e65100}.set-active-btn{margin-right:8px}.program-subtitle{color:#666;font-size:1rem}.program-placeholder{padding:60px 40px}.program-placeholder,.program-setup-form{background:#f8f9fa;border:2px dashed #ddd;border-radius:12px;text-align:center}.program-setup-form{margin:40px auto;max-width:500px;padding:40px}.program-setup-form h3{color:#333;margin-bottom:8px}.program-setup-form p{color:#666;margin-bottom:24px}.setup-form-fields{display:flex;flex-direction:column;gap:16px;text-align:left}.setup-form-fields .form-group{display:flex;flex-direction:column;gap:6px}.setup-form-fields label{color:#555;font-size:13px;font-weight:500}.setup-form-fields .form-select{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px}.saved-programs-section{border-top:1px solid #ddd;margin-top:24px;padding-top:24px;text-align:left}.saved-programs-section h4{color:#555;font-size:14px;margin-bottom:12px}.saved-programs-list{display:flex;flex-direction:column;gap:8px}.saved-program-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:all .15s ease}.saved-program-item:hover{background:#e3f2fd;border-color:#1976d2}.sidebar-info{background:#f5f5f5;border-radius:6px;margin-bottom:12px;padding:12px}.info-row{display:flex;font-size:13px;justify-content:space-between;padding:4px 0}.info-label{color:#666}.info-value{color:#333;font-weight:500}.info-value.active{color:#2e7d32}.sidebar-hint{color:#666;font-size:13px;padding:12px;text-align:center}.placeholder-icon{font-size:3rem;margin-bottom:16px}.program-placeholder h3{color:#333;margin-bottom:8px}.program-placeholder p{color:#666;margin:0 auto;max-width:400px}.program-loading{padding:60px 40px;text-align:center}.loading-spinner{margin:0 auto 16px}.program-form{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08)}.form-section{border-bottom:1px solid #eee;padding:20px 24px}.form-section h3{border-bottom:2px solid #1976d2;color:#333;display:inline-block;font-size:1rem;margin-bottom:16px;padding-bottom:8px}.form-input{border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;padding:10px 14px;transition:border-color .2s;width:100%}.form-input:focus{border-color:#1976d2;outline:none}.form-textarea{border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:.95rem;padding:10px 14px;resize:vertical;transition:border-color .2s;width:100%}.form-textarea:focus{border-color:#1976d2;outline:none}.no-courses-message{background:#f8f9fa;border-radius:8px;padding:24px;text-align:center}.no-courses-message p{color:#666;margin-bottom:8px}.no-courses-message .hint{color:#999;font-size:.85rem}.program-courses-table{overflow-x:auto}.program-courses-table table{border-collapse:collapse;width:100%}.program-courses-table td,.program-courses-table th{border-bottom:1px solid #eee;padding:12px;text-align:left}.program-courses-table th{background:#f8f9fa;color:#555;font-size:.85rem;font-weight:600;text-transform:uppercase}.program-courses-table tr:hover{background:#f8f9fa}.status-badge{border-radius:12px;font-size:.75rem;padding:4px 10px;text-transform:uppercase}.status-badge.status-planned{background:#e3f2fd;color:#1976d2}.status-badge.status-in-progress{background:#fff3e0;color:#f57c00}.status-badge.status-completed{background:#e8f5e9;color:#388e3c}.status-badge.status-dropped{background:#ffebee;color:#c62828}.btn-icon{padding:4px 8px;transition:background .15s}.btn-icon:hover{background:#f0f0f0}.form-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.form-actions .btn-primary{padding:10px 24px;width:auto}.form-actions .btn-secondary{background:#f0f0f0;color:#333;padding:10px 24px;width:auto}.form-actions .btn-secondary:hover{background:#e0e0e0}.template-section{padding:20px 24px}.template-section .section-description{color:#666;font-size:.9rem;line-height:1.5;margin-bottom:16px}.template-section .template-selector{min-height:450px}.create-program-content.with-templates{max-width:1400px}.content-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-left:auto;margin-right:auto;margin-top:24px;max-width:800px;padding:24px}.content-section h3{border-bottom:2px solid #1976d2;color:#333;margin-bottom:16px;padding-bottom:12px}.user-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-top:24px;overflow:hidden}.user-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.user-list-header h3{color:#333;margin:0}.user-list-header-right{align-items:center;display:flex;gap:16px}.btn-add-user{align-items:center;background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:background .2s}.btn-add-user:hover{background:#43a047}.user-count{background:#e3f2fd;border-radius:20px;color:#1565c0;font-size:.85rem;font-weight:500;padding:4px 12px}.user-list{overflow-x:auto}.user-table{border-collapse:collapse;width:100%}.user-table td,.user-table th{border-bottom:1px solid #eee;padding:14px 20px;text-align:left}.user-table th{background:#f8f9fa;color:#555;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.user-table tr:hover{background:#f5f9ff}.user-table tr.inactive-row{background:#fafafa;opacity:.7}.user-name{color:#1976d2;cursor:pointer;font-weight:500}.user-name:hover{text-decoration:underline}.user-email{color:#666}.status-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:500;padding:4px 12px;text-transform:capitalize}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.btn-edit,.btn-status{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;padding:6px 12px;transition:all .2s}.btn-edit{background:#e3f2fd;color:#1565c0}.btn-edit:hover{background:#bbdefb}.btn-status.activate{background:#e8f5e9;color:#2e7d32}.btn-status.activate:hover{background:#c8e6c9}.btn-status.deactivate{background:#ffebee;color:#c62828}.btn-status.deactivate:hover{background:#ffcdd2}.btn-edit:disabled,.btn-status:disabled{cursor:not-allowed;opacity:.5}.content-error,.content-loading{background:#fff;border-radius:12px;color:#666;margin-top:24px;padding:40px;text-align:center}.content-error{background:#ffebee;color:#c62828}.modal-overlay{align-items:center;background:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#333;font-size:1.3rem;margin:0}.modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.8rem;height:32px;line-height:1;padding:0;width:32px}.modal-close:hover{color:#333}.modal-error,.modal-loading{color:#666;padding:40px;text-align:center}.modal-error{color:#c62828}.user-edit-form{padding:24px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.form-row,.user-edit-form .form-group{margin-bottom:16px}.user-edit-form .form-group label{color:#555;display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.user-edit-form .form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:10px 14px;transition:border-color .2s;width:100%}.user-edit-form .form-group input:focus{border-color:#1976d2;outline:none}.form-error{background:#ffebee;border-radius:8px;color:#c62828;margin-bottom:16px;padding:12px;text-align:center}.form-info{background:#f5f5f5;margin-top:16px;padding:16px}.form-info p{color:#555;margin:4px 0}.password-note{color:#888!important;font-size:.9rem;margin-top:8px!important}.roles-section{background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;margin-top:20px;padding:16px}.roles-section h4{color:#1565c0;font-size:1rem;margin:0 0 12px}.current-roles{margin-bottom:12px}.no-roles{color:#666;font-style:italic;margin:0}.role-tags{display:flex;flex-wrap:wrap;gap:8px}.role-tag{background:#1976d2;border-radius:20px;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:6px 12px}.role-remove-btn,.role-tag{align-items:center;color:#fff}.role-remove-btn{background:hsla(0,0%,100%,.3);border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:18px;justify-content:center;line-height:1;transition:background .2s;width:18px}.role-remove-btn:hover{background:hsla(0,0%,100%,.5)}.role-remove-btn:disabled{cursor:not-allowed;opacity:.5}.add-role-section{align-items:center;display:flex;gap:8px}.role-select{background:#fff;border:2px solid #90caf9;border-radius:8px;flex:1 1;font-size:14px;padding:8px 12px}.role-select:focus{border-color:#1976d2;outline:none}.btn-add-role{background:#4caf50;color:#fff;font-size:14px;padding:8px 16px;width:auto}.btn-add-role:hover{background:#43a047}.btn-add-role:disabled{background:#bdbdbd;cursor:not-allowed}.modal-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.btn-secondary{background:#f5f5f5;border:1px solid #ddd;color:#555}.btn-secondary:hover{background:#eee}.role-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden}.role-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.role-list-header h3{color:#333;font-size:1.2rem;margin:0}.role-list-header .header-actions{align-items:center;display:flex;gap:16px}.role-count{color:#666;font-size:.9rem}.btn-add{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s;width:auto}.btn-add:hover{background:#43a047}.role-table{border-collapse:collapse;width:100%}.role-table th{background:#f0f0f0;border-bottom:1px solid #ddd;color:#555;font-weight:600;padding:14px 20px;text-align:left}.role-table td{border-bottom:1px solid #eee;padding:14px 20px}.role-table tr:hover{background:#f8f9fa}.role-table .inactive-row{background:#f5f5f5;opacity:.7}.role-name{color:#1976d2;cursor:pointer;font-weight:500}.role-name:hover{text-decoration:underline}.role-description{color:#666;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-danger{background:#f44336;border:none}.btn-danger:hover{background:#d32f2f}.btn-danger:disabled{background:#bdbdbd;cursor:not-allowed}.no-data{color:#999;font-style:italic;padding:40px!important;text-align:center}.role-edit-modal{max-width:500px}.role-edit-form{padding:24px}.role-edit-form .form-group{margin-bottom:20px}.role-edit-form .form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.role-edit-form .form-group input,.role-edit-form .form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 14px;transition:border-color .2s;width:100%}.role-edit-form .form-group input:focus,.role-edit-form .form-group textarea:focus{border-color:#1976d2;outline:none}.role-edit-form .form-group textarea{min-height:80px;resize:vertical}.info-note{color:#888!important;font-size:.9rem;margin-top:8px!important}.icon-btn{background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:1.2rem;opacity:.8;padding:6px 8px;transition:background .2s,transform .1s}.icon-btn:hover{background:rgba(0,0,0,.05);opacity:1;transform:scale(1.1)}.icon-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.icon-btn.icon-edit:hover{background:rgba(25,118,210,.1)}.icon-btn.icon-danger:hover{background:rgba(244,67,54,.1)}.icon-btn.icon-success:hover{background:rgba(76,175,80,.1)}.icon-btn.icon-warning:hover{background:rgba(255,152,0,.1)}.actions-cell{align-items:center;gap:4px}.course-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden}.course-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.course-list-header h3{color:#333;font-size:1.2rem;margin:0}.course-count{color:#666;font-size:.9rem}.course-table{border-collapse:collapse;width:100%}.course-table th{background:#f0f0f0;border-bottom:1px solid #ddd;color:#555;font-weight:600;padding:14px 16px;text-align:left}.course-table td{border-bottom:1px solid #eee;padding:14px 16px}.course-table tr:hover{background:#f8f9fa}.course-table .inactive-row{background:#f5f5f5;opacity:.7}.course-code{color:#1976d2;cursor:pointer;font-weight:600}.course-code:hover{text-decoration:underline}.course-title{font-weight:500}.course-level,.course-subject{color:#666}.course-price{color:#2e7d32;font-weight:500}.course-edit-modal{max-width:600px}.course-edit-form{padding:24px}.course-edit-form .form-group{margin-bottom:16px}.course-edit-form .form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.course-edit-form .form-group input,.course-edit-form .form-group select,.course-edit-form .form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:10px 14px;transition:border-color .2s;width:100%}.course-edit-form .form-group input:focus,.course-edit-form .form-group select:focus,.course-edit-form .form-group textarea:focus{border-color:#1976d2;outline:none}.course-edit-form .form-group textarea{min-height:70px;resize:vertical}.course-edit-form .form-group select{background:#fff;cursor:pointer}.version-display{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;font-size:15px;gap:10px;height:42px;padding:10px 14px}.version-number{color:#1976d2;font-size:16px;font-weight:600}.version-status{color:#666;font-size:13px}.version-status.active{color:#2e7d32}.version-status.inactive{color:#c62828}.btn-warning{background-color:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.btn-warning:hover{background-color:#f57c00}.btn-warning:disabled{background-color:#ffcc80;cursor:not-allowed}.resources-layout{display:flex;gap:0;height:calc(100vh - 100px)}.resources-sidebar{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;min-width:280px;width:280px}.resources-editor{background:#fafafa;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.history-with-editor{display:flex;gap:0;height:calc(100vh - 100px)}.history-dashboard{background:#f8f9fa;border-right:1px solid #e0e0e0;min-width:300px;overflow-y:auto;padding:20px;width:300px}.history-dashboard .welcome-card{margin-bottom:0}.history-editor{background:#fafafa;flex:1 1;overflow:hidden}.file-browser,.history-editor{display:flex;flex-direction:column}.file-browser{height:100%}.file-browser-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px}.file-browser-header h4{color:#333;font-size:14px;margin:0}.file-list{flex:1 1;overflow-y:auto;padding:8px}.file-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:10px 12px;transition:background-color .15s;-webkit-user-select:none;user-select:none}.file-item:hover{background-color:#e3f2fd}.file-item.selected{background-color:#bbdefb}.file-item .file-icon{flex-shrink:0;font-size:24px}.file-item .file-info{flex:1 1;min-width:0}.file-item .file-name{color:#333;display:block;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item .file-meta{color:#888;display:block;font-size:11px;margin-top:2px}.file-browser-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:12px 16px;text-align:center}.file-browser-footer small{color:#888;font-size:12px}.empty-files{color:#888;padding:40px 20px;text-align:center}.tabbed-editor{display:flex;flex-direction:column;height:100%}.tabbed-editor-empty{align-items:center;background:#fafafa;display:flex;height:100%;justify-content:center}.empty-message{color:#888}.empty-message .empty-icon{display:block;font-size:64px;margin-bottom:16px;opacity:.5}.empty-message h3{color:#666;margin:0 0 8px}.empty-message p{font-size:14px;margin:0}.editor-tabs{background:#e0e0e0;display:flex;flex-shrink:0;overflow-x:auto;padding:4px 4px 0}.editor-tab{align-items:center;background:#f5f5f5;border:1px solid #ddd;border-bottom:none;border-radius:6px 6px 0 0;color:#666;cursor:pointer;display:flex;font-size:13px;gap:8px;margin-right:2px;max-width:200px;min-width:120px;padding:8px 12px;transition:background-color .15s}.editor-tab:hover{background:#fff}.editor-tab.active{background:#fff;border-color:#ccc;color:#333}.editor-tab .tab-icon{flex-shrink:0;font-size:16px}.editor-tab .tab-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-tab .tab-modified{color:#ff9800;font-size:18px;font-weight:700;margin-left:-4px}.editor-tab .tab-close{background:none;border:none;border-radius:3px;color:#888;cursor:pointer;flex-shrink:0;font-size:16px;line-height:1;padding:2px 4px}.editor-tab .tab-close:hover{background:#e0e0e0;color:#333}.editor-tab .tab-split-indicator{color:#1976d2;font-size:12px;margin-left:4px}.editor-tab.split-active{border-bottom:2px solid #ff9800}.tab-context-menu{animation:contextMenuFadeIn .15s ease;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,.15);min-width:180px;padding:4px 0;position:fixed;z-index:1000}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:8px 16px;transition:background .15s}.context-menu-item:hover{background:#f0f0f0}.context-menu-item .context-icon{color:#666;font-size:12px;text-align:center;width:16px}.context-menu-divider{background:#e0e0e0;height:1px;margin:4px 0}.editor-content-wrapper{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.editor-content-wrapper.split{flex-direction:row}.editor-content-wrapper.split .editor-content{flex:1 1;overflow:hidden}.editor-content-wrapper.split .split-panel{background:#fff;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.editor-splitter-container{display:flex;flex:1 1;height:100%;overflow:hidden}.editor-splitter-left,.editor-splitter-right{display:flex;flex-direction:column;height:100%;overflow:hidden}.editor-splitter-divider{background:linear-gradient(180deg,#1976d2,#1565c0);cursor:col-resize;flex-shrink:0;min-width:6px;transition:width .15s,background .15s;width:6px}.editor-splitter-divider.dragging,.editor-splitter-divider:hover{background:#2196f3;width:8px}.split-panel-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#555;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 12px}.split-panel-header .tab-icon{font-size:14px}.split-close-btn{background:none;border:none;border-radius:3px;color:#888;cursor:pointer;font-size:16px;margin-left:auto;padding:2px 6px}.split-close-btn:hover{background:#e0e0e0;color:#333}.tab-splitter-container{display:flex;flex:1 1;height:100%;overflow:hidden}.tab-splitter-left,.tab-splitter-right{display:flex;flex-direction:column;height:100%;overflow:hidden}.tab-splitter-left .content-tab-panel,.tab-splitter-right .content-tab-panel{flex:1 1;overflow:auto}.tab-splitter-divider{background:linear-gradient(180deg,#1976d2,#1565c0);cursor:col-resize;flex-shrink:0;min-width:6px;transition:width .15s,background .15s;width:6px}.tab-splitter-divider.dragging,.tab-splitter-divider:hover{background:#2196f3;width:8px}.tab-splitter-right .split-panel-header{align-items:center;background:#f0f4f8;border-bottom:1px solid #e0e0e0;color:#555;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 12px}.split-panel-icon{font-size:14px}.split-panel-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-content{background:#fff;flex:1 1;overflow:hidden}.editor-content,.editor-loading{display:flex;flex-direction:column}.editor-loading{align-items:center;color:#888;height:100%;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#1976d2;height:40px;margin-bottom:16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.editor-toolbar-actions{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 16px}.editor-toolbar-actions .file-name{color:#333;font-weight:500}.editor-toolbar-actions .modified-indicator{color:#ff9800;font-style:italic}.editor-toolbar-actions .toolbar-buttons{display:flex;gap:8px}.btn-sm,.editor-error{font-size:13px}.editor-error{background:#ffebee;color:#c62828;padding:8px 16px}.rich-text-editor{display:flex;flex-direction:column;height:100%}.rich-text-editor .quill{display:flex;flex:1 1;flex-direction:column}.rich-text-editor .ql-container{flex:1 1;font-size:15px;overflow-y:auto}.rich-text-editor .ql-editor{min-height:300px}.spreadsheet-editor{display:flex;flex-direction:column;height:100%}.spreadsheet-container{flex:1 1;overflow:auto;padding:16px}.spreadsheet-container .Spreadsheet{width:100%}.spreadsheet-container .Spreadsheet__cell{border:1px solid #e0e0e0;min-width:80px;padding:6px 8px}.spreadsheet-container .Spreadsheet__header{background:#f5f5f5;font-weight:500}.pdf-viewer{display:flex;flex-direction:column;height:100%}.pdf-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px 16px}.pdf-info .file-name{color:#333;font-weight:500}.pdf-controls{align-items:center;display:flex;gap:16px}.page-controls,.zoom-controls{align-items:center;display:flex;gap:8px}.page-controls button,.zoom-controls button{background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px}.page-controls button:hover,.zoom-controls button:hover{background:#d0d0d0}.page-controls button:disabled{cursor:not-allowed;opacity:.5}.page-indicator{color:#666;font-size:13px;min-width:120px;text-align:center}.pdf-container{background:#e0e0e0;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.pdf-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px}.image-error .error-message,.pdf-error .error-message{align-items:center;display:flex;flex-direction:column;gap:12px;padding:40px}.error-message .error-icon{font-size:48px}.image-viewer{display:flex;flex-direction:column;height:100%}.image-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 16px}.image-toolbar .file-name{color:#333;font-weight:500}.image-controls{display:flex;gap:16px}.rotation-controls{display:flex;gap:8px}.rotation-controls button{background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px}.rotation-controls button:hover{background:#d0d0d0}.image-container{align-items:center;background:#e0e0e0;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.image-container img{box-shadow:0 4px 20px rgba(0,0,0,.2);max-height:100%;max-width:100%;object-fit:contain}.image-loading{flex-direction:column}.image-loading,.unsupported-file{align-items:center;display:flex;height:100%;justify-content:center}.unsupported-file{color:#888;font-size:16px}.online-users-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;max-height:400px;overflow:hidden}.online-users-header{align-items:center;background:#fafafa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.online-users-header h3{align-items:center;color:#333;display:flex;font-size:16px;gap:10px;margin:0}.status-dot{border-radius:50%;height:10px;width:10px}.status-dot.online{background:#4caf50;box-shadow:0 0 8px rgba(76,175,80,.5)}.status-dot.offline{background:#9e9e9e}.btn-retry{background:none;border:1px solid #1976d2;border-radius:4px;color:#1976d2;cursor:pointer;font-size:12px;padding:4px 12px}.btn-retry:hover{background:#e3f2fd}.connection-error{background:#ffebee;color:#c62828;font-size:13px;padding:12px 20px}.no-users-online{color:#666;padding:40px 20px;text-align:center}.online-users-list{flex:1 1;overflow-y:auto}.online-user-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:12px;padding:12px 20px;transition:background .2s}.online-user-item:hover{background:#f5f5f5}.online-user-item:last-child{border-bottom:none}.online-user-item .user-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.online-user-item .user-info{display:flex;flex:1 1;flex-direction:column}.online-user-item .user-name{color:#333;font-weight:500}.online-user-item .user-role{color:#666;font-size:12px}.user-actions{display:flex;gap:8px}.btn-call{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:transform .2s,box-shadow .2s;width:36px}.btn-call:hover{transform:scale(1.1)}.btn-call.audio{background:#4caf50;color:#fff}.btn-call.audio:hover{box-shadow:0 4px 12px rgba(76,175,80,.4)}.btn-call.video{background:#1976d2;color:#fff}.btn-call.video:hover{box-shadow:0 4px 12px rgba(25,118,210,.4)}.video-call-overlay{align-items:center;background:rgba(0,0,0,.9);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.video-call-container{background:#1a1a1a;display:flex;flex-direction:column;height:100%;width:100%}.video-call-header{align-items:center;background:rgba(0,0,0,.5);display:flex;justify-content:space-between;left:0;padding:16px 24px;position:absolute;right:0;top:0;z-index:10}.peer-info{display:flex;flex-direction:column}.peer-name{color:#fff;font-size:18px;font-weight:600}.call-status{color:hsla(0,0%,100%,.7);font-size:14px}.btn-close-call{background:hsla(0,0%,100%,.2);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:18px;height:40px;transition:background .2s;width:40px}.btn-close-call:hover{background:hsla(0,0%,100%,.3)}.video-call-content{align-items:center;display:flex;flex:1 1;justify-content:center;position:relative}.call-ended-prompt,.calling-prompt,.incoming-call-prompt{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;text-align:center}.avatar-large,.caller-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:50%;color:#fff;display:flex;font-size:40px;font-weight:600;height:120px;justify-content:center;width:120px}.caller-avatar.pulse{animation:pulse 2s ease-in-out infinite}.call-ended-prompt h3,.calling-prompt h3,.incoming-call-prompt h3{font-size:24px;margin:0}.call-ended-prompt p,.calling-prompt p,.incoming-call-prompt p{color:hsla(0,0%,100%,.7);margin:0}.incoming-call-actions{display:flex;gap:24px;margin-top:24px}.btn-accept,.btn-reject{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-size:14px;gap:8px;padding:16px 24px;transition:transform .2s,box-shadow .2s}.btn-accept span,.btn-reject span{align-items:center;border-radius:50%;display:flex;font-size:24px;height:50px;justify-content:center;width:50px}.btn-reject{background:#c62828;color:#fff}.btn-reject:hover{box-shadow:0 4px 20px rgba(198,40,40,.4);transform:scale(1.05)}.btn-reject span{background:hsla(0,0%,100%,.2)}.btn-accept{background:#4caf50;color:#fff}.btn-accept:hover{box-shadow:0 4px 20px rgba(76,175,80,.4);transform:scale(1.05)}.btn-accept span{background:hsla(0,0%,100%,.2)}.btn-cancel-call{background:#c62828;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;margin-top:24px;padding:12px 32px;transition:background .2s}.btn-cancel-call:hover{background:#b71c1c}.video-streams{height:100%;position:relative;width:100%}.remote-video-container{align-items:center;background:#000;display:flex;height:100%;justify-content:center;width:100%}.remote-video{height:100%;object-fit:contain;width:100%}.remote-video-container .video-placeholder,.remote-video-container.video-off .remote-video{display:none}.remote-video-container.video-off .video-placeholder{align-items:center;display:flex;justify-content:center}.peer-muted-indicator{background:rgba(0,0,0,.7);border-radius:8px;color:#fff;font-size:14px;padding:8px 16px;position:absolute;right:24px;top:80px}.local-video-container{background:#333;border-radius:12px;bottom:100px;box-shadow:0 4px 20px rgba(0,0,0,.4);height:150px;overflow:hidden;position:absolute;right:24px;width:200px}.local-video{height:100%;object-fit:cover;transform:scaleX(-1);width:100%}.local-video-container.video-off .local-video{display:none}.video-placeholder-small{align-items:center;color:#fff;display:none;font-size:14px;height:100%;justify-content:center;width:100%}.local-video-container.video-off .video-placeholder-small{display:flex}.video-call-controls{background:rgba(0,0,0,.7);border-radius:50px;bottom:24px;display:flex;gap:16px;left:50%;padding:16px 24px;position:absolute;transform:translateX(-50%);z-index:10}.control-btn{align-items:center;background:hsla(0,0%,100%,.2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;transition:background .2s,transform .2s;width:56px}.control-btn:hover{background:hsla(0,0%,100%,.3);transform:scale(1.1)}.control-btn.disabled{background:#c62828}.control-btn.end-call{background:#c62828;transform:rotate(135deg)}.control-btn.end-call:hover{background:#b71c1c}.call-error-message{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;text-align:center}.call-error-message p{color:#ef5350;font-size:16px}@media (max-width:768px){.local-video-container{bottom:120px;height:90px;right:16px;width:120px}.video-call-controls{gap:12px;padding:12px 16px}.control-btn{font-size:20px;height:48px;width:48px}}.video-section-page{max-width:800px;padding:40px}.video-section-page h3{color:#333;font-size:24px;margin-bottom:8px}.video-section-page .section-description{color:#666;margin-bottom:24px}.video-section{margin-top:24px}.video-section h3{color:#333;font-size:18px;margin-bottom:8px}.video-section .section-description{color:#666;font-size:14px;margin-bottom:16px}.active-call-indicator{align-items:center;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s}.active-call-indicator:hover{background:linear-gradient(135deg,#43a047,#2e7d32)}.call-pulse{animation:callPulse 1.5s ease-in-out infinite;background:#fff;border-radius:50%;height:12px;width:12px}@keyframes callPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.btn-focus-call{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.4);border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-left:auto;padding:4px 12px}.btn-focus-call:hover{background:hsla(0,0%,100%,.3)}.btn-call:disabled{cursor:not-allowed;opacity:.5}.btn-call:disabled:hover{box-shadow:none;transform:none}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h3{margin:0}.quick-actions{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:24px;padding:20px}.quick-actions h3{margin-bottom:16px}.recent-assignments{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:20px}.recent-assignments h3{color:#333;margin-bottom:16px}.assignments-section,.user-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:20px}.user-section h3{color:#333;margin-bottom:8px}.section-description{color:#666;font-size:.9rem;margin-bottom:20px}.actions-cell{display:flex;gap:8px}.btn-small{font-size:.85rem;padding:6px 12px;width:auto}.btn-secondary{background-color:#757575;color:#fff}.btn-secondary:hover{background-color:#616161}.btn-danger{background-color:#d32f2f;color:#fff}.btn-danger:hover{background-color:#c62828}.empty-message{color:#666;font-style:italic;padding:40px 20px;text-align:center}.stat-card{cursor:pointer;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}.routing-form-list{background:#fff;border-radius:12px;padding:20px}.routing-form-list .section-header h3{color:#333;margin-bottom:8px}.routing-form-list .tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:8px;margin-bottom:20px;padding-bottom:0}.routing-form-list .tab{background:transparent;border:none;border-bottom:2px solid transparent;color:#666;cursor:pointer;font-size:.95rem;margin-bottom:-2px;padding:12px 24px;transition:all .2s}.routing-form-list .tab:hover{color:#1976d2}.routing-form-list .tab.active{border-bottom-color:#1976d2;color:#1976d2;font-weight:500}.template-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px;overflow:hidden}.template-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:background .2s}.template-header:hover{background:#f0f0f0}.template-info h4{color:#333;margin:0 0 4px}.template-description{color:#666;font-size:.9rem;margin-bottom:8px}.template-meta{align-items:center;display:flex;gap:12px}.step-count{color:#888;font-size:.85rem}.template-actions{align-items:center;display:flex;gap:8px}.expand-icon{color:#888;font-size:.8rem;margin-left:8px}.template-steps{background:#fff;border-top:1px solid #e0e0e0;padding:0 16px 16px}.template-steps h5{color:#666;margin:12px 0 8px}.step-list{margin:0;padding-left:20px}.step-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.step-item:last-child{border-bottom:none}.step-info{display:flex;flex-direction:column}.step-info strong{color:#333}.step-role{color:#888;font-size:.85rem}.step-days{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:.85rem;padding:2px 8px}.data-table{border-collapse:collapse;margin-top:16px;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e0e0e0;padding:12px;text-align:left}.data-table th{background:#f5f5f5;color:#555;font-weight:600}.data-table tr:hover{background:#f8f9fa}.progress-cell{display:flex;flex-direction:column;gap:4px}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;overflow:hidden;width:100px}.progress-fill{background:linear-gradient(90deg,#4caf50,#8bc34a);height:100%;transition:width .3s}.progress-text{color:#666;font-size:.8rem}.status-active,.status-completed{background:#e8f5e9;color:#2e7d32}.status-in-progress,.status-progress{background:#fff3e0;color:#ef6c00}.status-draft{background:#e3f2fd;color:#1565c0}.status-pending{background:#f5f5f5;color:#757575}.status-inactive{background:#fafafa;color:#9e9e9e}.modal-large{max-height:90vh;max-width:800px;overflow-y:auto}.form-section{border-bottom:1px solid #e0e0e0;margin-bottom:24px;padding-bottom:16px}.form-section:last-child{border-bottom:none}.form-section h4{color:#333;margin-bottom:16px}.section-header-inline{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.section-hint{color:#666;font-size:.9rem;margin-bottom:16px}.steps-editor{display:flex;flex-direction:column;gap:16px}.step-editor-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:16px;padding:16px}.step-number{align-items:center;background:#1976d2;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.step-fields{flex:1 1}.step-row{display:flex;gap:12px;margin-bottom:12px}.step-row .form-group{flex:1 1;margin-bottom:0}.form-group-small{max-width:80px}.step-options{margin-top:8px}.checkbox-label{align-items:center;color:#555;display:flex;font-size:.9rem;gap:8px}.step-actions{display:flex;flex-direction:column;gap:4px}.btn-icon{background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:1rem;height:32px;padding:0;transition:background .2s;width:32px}.btn-icon:hover{background:#e0e0e0}.btn-icon:disabled{cursor:not-allowed;opacity:.3}.btn-icon.btn-danger:hover{background:#ffebee}.student-routing-form{background:#fff;border-radius:12px;padding:24px}.form-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.form-header-info h3{color:#333;margin:0 0 8px}.student-info{color:#666;margin-bottom:8px}.form-meta{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.date-info{color:#888;font-size:.85rem}.form-notes{background:#fff3e0;border-left:4px solid #ff9800;border-radius:8px;margin-bottom:24px;padding:12px 16px}.steps-timeline h4{color:#333;margin-bottom:16px}.timeline{position:relative}.timeline-step{display:flex;gap:16px;padding-bottom:24px}.timeline-step:last-child{padding-bottom:0}.step-indicator{flex-direction:column;flex-shrink:0}.step-circle,.step-indicator{align-items:center;display:flex}.step-circle{background:#e0e0e0;border-radius:50%;color:#666;font-weight:700;height:32px;justify-content:center;transition:all .3s;width:32px}.step-completed .step-circle{background:#4caf50;color:#fff}.step-in-progress .step-circle{animation:pulse 2s infinite;background:#ff9800;color:#fff}@keyframes pulse{0%,to{box-shadow:0 0 0 0 rgba(255,152,0,.4)}50%{box-shadow:0 0 0 8px rgba(255,152,0,0)}}.step-line{background:#e0e0e0;flex:1 1;margin-top:4px;min-height:20px;width:2px}.step-completed .step-line{background:#4caf50}.step-content{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;flex:1 1;padding:16px}.step-in-progress .step-content{background:#fff8e1;border-color:#ff9800}.step-completed .step-content{background:#f1f8e9;border-color:#4caf50}.step-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.step-header h5{color:#333;margin:0}.step-status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:4px 12px}.step-description{color:#666;margin-bottom:12px}.step-details{display:flex;flex-wrap:wrap;font-size:.9rem;gap:16px;margin-bottom:8px}.assigned-role,.due-date{color:#555}.signoff-info{background:#e8f5e9;border-radius:6px;color:#2e7d32;padding:8px 12px}.signoff-info,.step-notes{font-size:.9rem;margin-top:8px}.step-notes{color:#666;font-style:italic}.signoff-action{display:flex;flex-direction:column;gap:8px;margin-top:12px}.signoff-action textarea{border:1px solid #ddd;border-radius:6px;font-size:.9rem;padding:8px 12px;resize:vertical}.completion-banner{align-items:center;background:linear-gradient(135deg,#4caf50,#8bc34a);border-radius:12px;color:#fff;display:flex;gap:16px;margin-top:24px;padding:20px}.completion-banner span:first-child{font-size:2rem}.completion-banner strong{font-size:1.2rem}.completion-banner p{margin:4px 0 0;opacity:.9}.task-list .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.task-summary{display:flex;gap:12px}.task-count{border-radius:12px;font-size:.9rem;font-weight:500;padding:4px 12px}.task-count.pending{background:#fff3e0;color:#ef6c00}.task-count.overdue{background:#ffebee;color:#c62828}.filter-bar{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;gap:12px;margin-bottom:16px;padding:12px}.filter-bar label{color:#666;font-size:.9rem}.filter-bar select{border:1px solid #ddd;border-radius:6px;padding:6px 12px}.task-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.task-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:16px;transition:all .2s}.task-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}.task-card.overdue{background:#fff8f8;border-color:#ef5350}.task-card.due-soon{background:#fffbf5;border-color:#ff9800}.task-card.completed{background:#f5f5f5;opacity:.7}.task-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.task-card-header h4{color:#333;margin:0}.task-description{color:#666;font-size:.9rem;margin-bottom:12px}.task-details{display:flex;flex-wrap:wrap;font-size:.85rem;gap:12px;margin-bottom:12px}.assigned-role,.student-name{color:#555}.due-date-info{color:#666;font-size:.9rem;margin-bottom:12px}.due-date-info.overdue{color:#c62828}.due-date-info.due-soon{color:#ef6c00}.overdue-label{background:#c62828;border-radius:4px;color:#fff;font-size:.75rem;font-weight:700;margin-left:8px;padding:2px 8px}.task-actions{display:flex;gap:8px}.quick-actions{margin-top:24px}.quick-actions h3{color:#333;margin-bottom:12px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px}.action-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.95rem;padding:12px 20px;transition:all .2s}.action-btn:hover{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.info-section{background:#f8f9fa;border-radius:8px;margin-top:24px;padding:16px}.info-section h3{color:#333;margin-bottom:12px}.info-section ul{color:#555;margin:0;padding-left:20px}.info-section li{padding:4px 0}.action-bar{margin-bottom:16px}.stat-card.clickable{cursor:pointer}.stat-card.stat-warning{background:#fff8e1;border-color:#ff9800}.stat-card.stat-warning h3{color:#ef6c00}.empty-state{color:#666;padding:40px 20px;text-align:center}.empty-state p{margin-bottom:16px}.form-info{background:#e3f2fd;border-radius:8px;color:#1565c0;margin:16px 0;padding:12px 16px}.form-info p{font-size:.9rem;margin:0}.form-group-inline,.form-group-inline label{align-items:center;display:flex;gap:8px}.form-group-inline label{cursor:pointer}.btn-sm{font-size:.85rem;padding:6px 12px}.btn-view{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer}.btn-view:hover{background:#1565c0}.hover\:-translate-y-0\.5:hover{--tw-translate-y:-0.125rem}.hover\:-translate-y-0\.5:hover,.hover\:scale-\[1\.02\]:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-\[1\.02\]:hover{--tw-scale-x:1.02;--tw-scale-y:1.02}.hover\:border-slate-300:hover{--tw-border-opacity:1;border-color:#cbd5e1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:#b91c1c;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:#f1f5f9;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-200:hover{--tw-bg-opacity:1;background-color:#e2e8f0;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:#f8fafc;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.hover\:bg-slate-50\/50:hover{background-color:rgba(248,250,252,.5)}.hover\:bg-white\/20:hover{background-color:hsla(0,0%,100%,.2)}.hover\:bg-white\/60:hover{background-color:hsla(0,0%,100%,.6)}.hover\:from-blue-700:hover,.hover\:from-primary-700:hover{--tw-gradient-from:#1d4ed8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-blue-600:hover{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.hover\:to-primary-800:hover{--tw-gradient-to:#1e40af var(--tw-gradient-to-position)}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.hover\:text-blue-900:hover{--tw-text-opacity:1;color:#1e3a8a;color:rgb(30 58 138/var(--tw-text-opacity,1))}.hover\:text-emerald-900:hover{--tw-text-opacity:1;color:#064e3b;color:rgb(6 78 59/var(--tw-text-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-primary-700:hover{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:text-purple-900:hover{--tw-text-opacity:1;color:#581c87;color:rgb(88 28 135/var(--tw-text-opacity,1))}.hover\:text-red-600:hover{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.hover\:text-slate-600:hover{--tw-text-opacity:1;color:#475569;color:rgb(71 85 105/var(--tw-text-opacity,1))}.hover\:text-slate-700:hover{--tw-text-opacity:1;color:#334155;color:rgb(51 65 85/var(--tw-text-opacity,1))}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-md:hover,.hover\:shadow-xl:hover{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.hover\:shadow-blue-500\/40:hover{--tw-shadow-color:rgba(59,130,246,.4);--tw-shadow:var(--tw-shadow-colored)}.focus\:border-transparent:focus{border-color:transparent}.focus\:bg-white:focus{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-amber-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(245 158 11/var(--tw-ring-opacity,1))}.focus\:ring-blue-500:focus,.focus\:ring-primary-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.disabled\:transform-none:disabled{transform:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-70:disabled{opacity:.7}.disabled\:hover\:bg-transparent:hover:disabled{background-color:transparent}.disabled\:hover\:text-slate-500:hover:disabled{--tw-text-opacity:1;color:#64748b;color:rgb(100 116 139/var(--tw-text-opacity,1))}.group:hover .group-hover\:scale-\[1\.02\]{--tw-scale-x:1.02;--tw-scale-y:1.02;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:640px){.sm\:flex{display:flex}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}}@media (min-width:768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:w-1\/2{width:50%}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}}
/*# sourceMappingURL=main.00d7ff1b.css.map*/