.sms-container{max-width:1200px;margin:0 auto;padding:1rem 2rem}.sms-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.sms-header h2{color:var(--accent);align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.sms-header p{color:var(--text2)}.sms-balance-badge{background:var(--accent);color:#fff;border-radius:12px;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex;box-shadow:0 4px 15px #0003}.sms-balance-badge svg{opacity:.8;font-size:2rem}.balance-info{flex-direction:column;display:flex}.balance-info .amt{font-size:1.5rem;font-weight:700;line-height:1}.balance-info .est{opacity:.9;font-size:.85rem}.sms-tabs{border-bottom:1px solid var(--border);gap:1rem;margin-bottom:2rem;display:flex}.sms-tabs button{color:var(--text2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.75rem 1.5rem;font-size:1rem;transition:all .2s}.sms-tabs button:hover{color:var(--text)}.sms-tabs button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.stat-card{background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--border);text-align:center;border-radius:12px;padding:1.5rem}.stat-card h3{color:var(--text2);margin-bottom:.5rem;font-size:1rem;font-weight:500}.stat-card .value{color:var(--text);font-size:2.5rem;font-weight:700}.sync-btn{background:var(--surface2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem 1rem;transition:all .2s;display:inline-flex}.sync-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.sms-compose-form{border-radius:12px;max-width:600px;padding:2rem}.recipient-types{flex-wrap:wrap;gap:1.5rem;margin-bottom:.5rem;display:flex}.recipient-types label{cursor:pointer;border:1px solid var(--border);background:var(--surface2);border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:all .2s;display:flex}.recipient-types label:has(input:checked){border-color:var(--accent);color:var(--accent);background:#4f8ef71f}.message-meta{color:var(--text2);justify-content:space-between;margin-top:.5rem;font-size:.85rem;display:flex}.send-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:1rem;padding:1rem;font-size:1.1rem;display:flex}.info-box{border-left:4px solid var(--accent3);color:var(--text);background:#f7a84f1f;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.status-badge{text-transform:capitalize;border-radius:20px;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.status-badge.sent{color:#22c55e;background:#22c55e1a}.status-badge.scheduled{color:#3b82f6;background:#3b82f61a}.status-badge.failed{color:#ef4444;background:#ef44441a}.status-badge.cancelled{color:#6b7280;background:#6b72801a}.chatbot-container{z-index:9999;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:fixed;bottom:24px;right:24px}.chatbot-fab{color:#fff;cursor:pointer;z-index:2;background:linear-gradient(135deg,#6e8efb,#a777e3);border:none;border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:absolute;bottom:0;right:0;box-shadow:0 4px 16px #6e8efb73}.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #6e8efb99}.chatbot-fab.open{background:linear-gradient(135deg,#3c3c3c,#2d2d30);box-shadow:0 4px 12px #0000004d}.chatbot-fab-pulse{background:#6e8efb66;border-radius:50%;width:100%;height:100%;animation:2s ease-out infinite pulse-ring;position:absolute}@keyframes pulse-ring{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.chatbot-window{background:var(--vsc-panel,#252526);border:1px solid var(--vsc-border,#3c3c3c);opacity:0;pointer-events:none;transform-origin:100% 100%;z-index:1;border-radius:18px;flex-direction:column;width:360px;height:520px;max-height:calc(100vh - 110px);transition:all .28s cubic-bezier(.25,.8,.25,1);display:flex;position:absolute;bottom:72px;right:0;overflow:hidden;transform:translateY(16px)scale(.96);box-shadow:0 12px 40px #0006,0 0 0 1px #ffffff0d}.chatbot-window.open{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.chatbot-header{border-bottom:1px solid var(--vsc-border,#3c3c3c);background:linear-gradient(135deg,#6e8efb26,#a777e31a);flex-shrink:0;align-items:center;gap:10px;padding:14px 16px;display:flex}.chatbot-avatar{color:#fff;background:linear-gradient(135deg,#6e8efb,#a777e3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.chatbot-title{color:var(--vsc-text,#ccc);margin:0;font-size:14px;font-weight:600}.chatbot-subtitle{color:#4caf50;align-items:center;gap:4px;margin:2px 0 0;font-size:11px;display:flex}.chatbot-subtitle:before{content:"";background:#4caf50;border-radius:50%;width:5px;height:5px;display:inline-block}.chatbot-close-btn{color:var(--vsc-muted,#888);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:background .15s,color .15s;display:flex}.chatbot-close-btn:hover{color:var(--vsc-text,#ccc);background:#ffffff14}.chatbot-messages{background:var(--vsc-bg,#1e1e1e);scroll-behavior:smooth;flex-direction:column;flex:1;gap:10px;padding:14px 12px;display:flex;overflow-y:auto}.chatbot-messages::-webkit-scrollbar{width:4px}.chatbot-messages::-webkit-scrollbar-track{background:0 0}.chatbot-messages::-webkit-scrollbar-thumb{background:var(--vsc-border,#3c3c3c);border-radius:2px}.message-row{align-items:flex-end;gap:6px;animation:.25s fadeSlideIn;display:flex}.message-row.user{flex-direction:row-reverse}.message-avatar-sm{color:#fff;background:linear-gradient(135deg,#6e8efb,#a777e3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-bottom:2px;display:flex}.message-bubble{word-wrap:break-word;border-radius:14px;max-width:78%;padding:9px 13px;font-size:13.5px;line-height:1.5}.message-bubble.user{color:#fff;background:linear-gradient(135deg,#6e8efb,#a777e3);border-bottom-right-radius:4px}.message-bubble.bot{background:var(--vsc-panel,#2d2d30);color:var(--vsc-text,#ccc);border:1px solid var(--vsc-border,#3c3c3c);border-bottom-left-radius:4px}.message-bubble.bot ul{margin:4px 0 4px 16px;padding:0}.message-bubble.bot li{margin-bottom:2px}.message-bubble.bot code{background:#ffffff14;border-radius:4px;padding:1px 5px;font-size:12px}.message-bubble.bot strong{color:#a9c5ff}.chatbot-suggestions{background:var(--vsc-bg,#1e1e1e);flex-wrap:wrap;flex-shrink:0;gap:6px;min-height:0;padding:0 12px 8px;display:flex}.suggestion-chip{color:#a9c5ff;cursor:pointer;white-space:nowrap;background:#6e8efb1f;border:1px solid #6e8efb4d;border-radius:20px;padding:4px 10px;font-size:11.5px;transition:all .15s}.suggestion-chip:hover{background:#6e8efb40;border-color:#6e8efb99}.chatbot-input-area{background:var(--vsc-panel,#252526);border-top:1px solid var(--vsc-border,#3c3c3c);flex-shrink:0;align-items:flex-end;gap:8px;padding:10px 12px;display:flex}.chatbot-input{background:var(--vsc-bg,#1e1e1e);border:1px solid var(--vsc-border,#3c3c3c);color:var(--vsc-text,#ccc);resize:none;border-radius:14px;outline:none;flex:1;max-height:80px;padding:9px 13px;font-family:inherit;font-size:13.5px;line-height:1.4;transition:border-color .2s;overflow-y:auto}.chatbot-input:focus{border-color:#6e8efb}.chatbot-send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6e8efb,#a777e3);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .2s,transform .1s;display:flex}.chatbot-send-btn:disabled{opacity:.4;cursor:not-allowed}.chatbot-send-btn:not(:disabled):hover{transform:scale(1.08)}.chatbot-send-btn:not(:disabled):active{transform:scale(.95)}.chatbot-footer-note{text-align:center;color:var(--vsc-muted,#666);background:var(--vsc-panel,#252526);flex-shrink:0;padding:4px 12px 8px;font-size:10.5px}.typing-indicator{align-items:center;gap:4px;padding:10px 14px;display:flex}.typing-indicator span{background:var(--vsc-muted,#888);border-radius:50%;width:6px;height:6px;animation:1.3s ease-in-out infinite both typing}.typing-indicator span:first-child{animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.chatbot-window{border-radius:14px 14px 0 0;width:calc(100vw - 24px);max-height:75vh;bottom:68px;right:-12px}}.tour-overlay-backdrop{z-index:9999;pointer-events:none;width:100vw;height:100vh;transition:background-color .3s;position:fixed;top:0;left:0}.tour-overlay-backdrop.active{pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#0f141999}.tour-overlay-backdrop.auto{pointer-events:none;background-color:#0000}.tour-spotlight-highlight{box-shadow:0 0 0 9999px #0f1419b3, 0 0 15px 3px var(--vsc-accent,#81d4fa);z-index:10000;pointer-events:none;border-radius:8px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute}.tour-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10001;width:340px;color:var(--vsc-text,#e2e8f0);background:#1c2433d9;border:1px solid #81d4fa40;border-radius:12px;flex-direction:column;padding:20px;transition:all .3s cubic-bezier(.25,1,.5,1);animation:.3s ease-out tourCardFadeIn;display:flex;position:absolute;box-shadow:0 10px 30px #00000080}[data-theme=light] .tour-card{color:var(--vsc-text,#1a2332);background:#ffffffe6;border:1px solid #1565c040;box-shadow:0 10px 30px #00000026}@keyframes tourCardFadeIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.tour-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.tour-card-step-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--vsc-accent,#81d4fa);background:#81d4fa26;border-radius:12px;padding:2px 8px;font-size:10px;font-weight:700}[data-theme=light] .tour-card-step-badge{color:var(--vsc-accent,#1565c0);background:#1565c01a}.tour-card-close-btn{color:var(--vsc-muted,#8892a4);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:background .2s,color .2s;display:flex}.tour-card-close-btn:hover{color:var(--vsc-text,#e2e8f0);background:#ffffff1a}.tour-card-body h3{letter-spacing:-.01em;margin:0 0 8px;font-size:16px;font-weight:600}.tour-card-body p{color:var(--vsc-muted,#8892a4);margin:0;font-size:13px;line-height:1.5}[data-theme=light] .tour-card-body p{color:#5a6578}.tour-card-footer{justify-content:space-between;align-items:center;gap:10px;margin-top:20px;display:flex}.tour-btn{cursor:pointer;border-radius:6px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.tour-btn-skip{border:1px solid var(--vsc-border,#2d3748);color:var(--vsc-muted,#8892a4);background:0 0}.tour-btn-skip:hover{color:var(--vsc-text,#e2e8f0);background:#ffffff0d}[data-theme=light] .tour-btn-skip:hover{color:var(--vsc-text,#1a2332);background:#0000000d}.tour-btn-next{background:var(--btn-primary-bg,linear-gradient(135deg, #81d4fa, #4fc3f7));color:#0f1419;border:none;box-shadow:0 2px 8px #81d4fa4d}.tour-btn-next:hover{transform:translateY(-1px);box-shadow:0 4px 12px #81d4fa73}.tour-btn-next:active{transform:translateY(0)}.tour-help-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100000;background-color:#0a0e14cc;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s fadeIn;display:flex;position:fixed;top:0;left:0}.tour-help-modal{background:var(--vsc-panel,#1c2433);border:1px solid var(--vsc-border,#2d3748);text-align:center;width:420px;max-width:90vw;color:var(--vsc-text,#e2e8f0);border-radius:16px;flex-direction:column;align-items:center;padding:28px;animation:.35s cubic-bezier(.34,1.56,.64,1) tourCardFadeIn;display:flex;box-shadow:0 15px 40px #0009}.tour-help-icon-wrapper{width:64px;height:64px;color:var(--vsc-accent,#81d4fa);background:#81d4fa26;border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;animation:2s infinite pulseIcon;display:flex}@keyframes pulseIcon{0%{box-shadow:0 0 #81d4fa66}70%{box-shadow:0 0 0 10px #81d4fa00}to{box-shadow:0 0 #81d4fa00}}.tour-help-modal h2{margin:0 0 12px;font-size:20px;font-weight:700}.tour-help-modal p{color:var(--vsc-muted,#8892a4);margin:0 0 24px;font-size:14px;line-height:1.6}.tour-help-email{color:var(--vsc-accent,#81d4fa);-webkit-user-select:all;user-select:all;background:#81d4fa1a;border:1px dashed #81d4fa4d;border-radius:4px;margin-top:6px;padding:4px 8px;font-weight:600;display:inline-block}[data-theme=light] .tour-help-email{color:var(--vsc-accent,#1565c0);background:#1565c00d;border:1px dashed #1565c033}.tour-help-actions{gap:12px;width:100%;display:flex}.tour-help-btn{cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.tour-help-btn-chatbot{background:var(--btn-primary-bg,linear-gradient(135deg, #81d4fa, #4fc3f7));color:#0f1419;border:none;box-shadow:0 4px 12px #81d4fa40}.tour-help-btn-chatbot:hover{transform:translateY(-1px);box-shadow:0 6px 16px #81d4fa66}.tour-help-btn-close{border:1px solid var(--vsc-border,#2d3748);color:var(--vsc-text,#e2e8f0);background:0 0}.tour-help-btn-close:hover{background:#ffffff0d}[data-theme=light] .tour-help-btn-close:hover{background:#0000000d}.tour-highlighted-element{outline-offset:4px;border-radius:4px;transition:outline .2s;position:relative;outline:2px solid var(--vsc-accent,#81d4fa)!important;z-index:10002!important;pointer-events:auto!important}@keyframes chatbotPulse{0%{transform:scale(1);box-shadow:0 0 #81d4fab3}70%{transform:scale(1.15);box-shadow:0 0 0 15px #81d4fa00}to{transform:scale(1);box-shadow:0 0 #81d4fa00}}.chatbot-fab.highlight-pulse{z-index:100002!important;border:2px solid var(--vsc-accent,#81d4fa)!important;animation:2s infinite chatbotPulse!important}@media (width<=768px){.tour-card{max-width:400px;animation:.3s ease-out tourCardSlideUpMobile;width:calc(100vw - 32px)!important;position:fixed!important;top:auto!important;bottom:20px!important;left:50%!important;transform:translate(-50%)!important}@keyframes tourCardSlideUpMobile{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}}:root{--vsc-bg:#0f1419;--vsc-sidebar:#151b23;--vsc-actbar:#1c2333;--vsc-panel:#1c2433;--vsc-border:#2d3748;--vsc-text:#e2e8f0;--vsc-input-bg:#1a2233;--vsc-muted:#8892a4;--vsc-accent:#81d4fa;--vsc-accent2:#4fc3f7;--accent:#81d4fa;--accent2:#4fc3f7;--saas-blue:#81d4fa;--vsc-yellow:#ffd54f;--vsc-green:#66bb6a;--vsc-orange:#ffab40;--vsc-red:#ef5350;--vsc-blue:#42a5f5;--vsc-purple:#ab47bc;--vsc-teal:#26c6da;--vsc-pink:#ec407a;--vsc-tab:#1c2433;--vsc-tab-active:#0f1419;--btn-primary-bg:linear-gradient(135deg,#81d4fa,#4fc3f7);--btn-success-bg:linear-gradient(135deg,#4fc3f7,#26c6da);--btn-danger-bg:linear-gradient(135deg,#ef5350,#e53935);--btn-warning-bg:linear-gradient(135deg,#ffd54f,#ffca28);--btn-info-bg:linear-gradient(135deg,#81d4fa,#4fc3f7)}[data-theme=light]{--vsc-bg:#f8faff;--vsc-sidebar:#e3e8f0;--vsc-actbar:#dce2ec;--vsc-panel:#fff;--vsc-border:#d1d9e6;--vsc-text:#1a2332;--vsc-input-bg:#f0f2f6;--vsc-muted:#6b7a8f;--vsc-accent:#1565c0;--vsc-accent2:#1976d2;--accent:#1565c0;--accent2:#1976d2;--saas-blue:#1565c0;--vsc-yellow:#f9a825;--vsc-green:#2e7d32;--vsc-orange:#e65100;--vsc-red:#c62828;--vsc-blue:#1565c0;--vsc-purple:#6a1b9a;--vsc-teal:#00838f;--vsc-pink:#c2185b;--vsc-tab:#fff;--vsc-tab-active:#f8faff;--btn-primary-bg:linear-gradient(135deg,#1565c0,#1976d2);--btn-success-bg:linear-gradient(135deg,#1976d2,#1565c0);--btn-danger-bg:linear-gradient(135deg,#c62828,#b71c1c);--btn-warning-bg:linear-gradient(135deg,#f9a825,#f57f17);--btn-info-bg:linear-gradient(135deg,#1565c0,#1976d2)}html,body{height:100%;margin:0}#root{background:var(--vsc-bg);height:100%;margin:0}.vsc-app{background:var(--vsc-panel);height:100%;color:var(--vsc-text);border-radius:12px;flex-direction:column;margin:6px;display:flex;overflow:hidden}.vsc-body{flex:1;min-height:0;display:flex;position:relative}.vsc-activity{background:var(--vsc-actbar);border-right:1px solid var(--vsc-border);z-index:10;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;width:48px;padding:6px 0;display:flex;position:relative}.vsc-actbtn{cursor:pointer;width:36px;height:36px;color:var(--vsc-muted);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:0;transition:all .2s;display:flex;position:relative}.vsc-actbtn:hover{color:var(--vsc-accent);background:color-mix(in srgb,var(--vsc-accent) 12%,transparent)}.vsc-actbtn.active{color:var(--vsc-accent)}.vsc-actbtn.active:before{content:"";background:var(--vsc-accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.vsc-actbtn svg{width:20px;height:20px}.vsc-actbtn-menu{margin-bottom:4px}.vsc-actbtn-menu svg{width:22px;height:22px}.vsc-actbtn[title=Dashboard] svg{color:var(--vsc-red);fill:var(--vsc-red)}.vsc-act-spacer{flex:1}.vsc-sidebar{background:var(--vsc-sidebar);border-right:1px solid var(--vsc-border);flex-direction:column;flex-shrink:0;width:160px;transition:width .2s;display:flex;overflow:hidden}.vsc-sidebar.collapsed{border-right:none;width:0;min-width:0;padding:0;overflow:hidden}.vsc-cat-btn{cursor:pointer;white-space:nowrap;text-overflow:ellipsis;text-align:left;width:100%;color:var(--vsc-text);border:none;border-bottom:1px solid var(--vsc-border);background:0 0;border-radius:0;flex-shrink:0;align-items:center;gap:10px;padding:10px 14px;font-family:inherit;font-size:13px;transition:background .15s,color .15s;display:flex;overflow:hidden}.vsc-cat-btn:hover{background:color-mix(in srgb,var(--vsc-accent) 10%,transparent);color:var(--vsc-accent)}.vsc-cat-btn.active{background:color-mix(in srgb,var(--vsc-accent) 18%,transparent);color:var(--vsc-accent);border-left:3px solid var(--vsc-accent);font-weight:600}.vsc-cat-btn svg{width:16px;height:16px;color:var(--vsc-muted);flex-shrink:0;transition:color .15s}.vsc-cat-btn:hover svg,.vsc-cat-btn.active svg{color:var(--vsc-accent)}.vsc-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:6px;display:inline-block}.vsc-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.vsc-tabbar{background:var(--vsc-sidebar);border-bottom:1px solid var(--vsc-border);flex-shrink:0;align-items:flex-end;height:35px;display:flex;overflow-x:auto}.vsc-tabbar::-webkit-scrollbar{height:0}.vsc-tab{cursor:pointer;height:35px;color:var(--vsc-muted);border-right:1px solid var(--vsc-border);white-space:nowrap;background:0 0;border-top:none;border-bottom:none;border-left:none;flex-shrink:0;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:12px;transition:color .15s,background .15s;display:flex}.vsc-tab:hover{color:var(--vsc-text);background:color-mix(in srgb,var(--vsc-accent) 5%,transparent)}.vsc-tab.active{background:var(--vsc-tab-active);color:var(--vsc-accent);border-top:2px solid var(--vsc-accent)}.vsc-tab svg{width:14px;height:14px}.vsc-breadcrumb{color:var(--vsc-muted);border-bottom:1px solid var(--vsc-border);background:var(--vsc-bg);flex-shrink:0;padding:6px 16px;font-size:11px}.vsc-content{background:var(--vsc-bg);flex:1;padding:16px;overflow:auto}.vsc-statusbar{background:linear-gradient(135deg,var(--vsc-accent),var(--vsc-purple));color:#fff;flex-shrink:0;align-items:center;gap:16px;height:22px;padding:0 12px;font-size:11px;display:flex}.vsc-sb-item{opacity:.9;align-items:center;gap:4px;display:flex}.vsc-sb-item svg{width:12px;height:12px}.vsc-notif-dot{background:var(--vsc-red);border-radius:50%;width:8px;height:8px;position:absolute;top:4px;right:4px}.vsc-h1{color:var(--vsc-text);margin:0 0 4px;font-size:18px;font-weight:700}.vsc-p{color:var(--vsc-muted);margin:0 0 14px;font-size:12px}.vsc-grid-4{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px;display:grid}.vsc-grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.vsc-grid-3{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.vsc-card{background:var(--vsc-panel);border:1px solid var(--vsc-border);border-radius:8px;padding:14px}.vsc-stat{border-left:3px solid var(--vsc-accent);padding:12px 14px}.vsc-stat:nth-child(2){border-left-color:var(--vsc-green)}.vsc-stat:nth-child(3){border-left-color:var(--vsc-yellow)}.vsc-stat:nth-child(4){border-left-color:var(--vsc-purple)}.vsc-stat-num{color:var(--vsc-text);margin:4px 0 2px;font-size:22px;font-weight:700}.vsc-stat-label{color:var(--vsc-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.vsc-stat-chg{margin-top:4px;font-size:11px}.vsc-section-title{color:var(--vsc-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;margin:0 0 10px;font-size:11px;font-weight:700;display:flex}.vsc-section-title svg{width:14px;height:14px}.vsc-table{border-collapse:collapse;width:100%;font-size:12px}.vsc-table th{text-align:left;color:var(--vsc-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--vsc-border);white-space:nowrap;padding:6px 8px;font-size:10px;font-weight:700}.vsc-table td{border-bottom:1px solid var(--vsc-border);padding:6px 8px}.vsc-table tr:hover td{background:color-mix(in srgb,var(--vsc-accent) 6%,transparent)}.vsc-table .avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:10px;font-weight:700;display:flex}.vsc-bar-wrap{background:color-mix(in srgb,var(--vsc-muted) 15%,transparent);border-radius:4px;height:6px;overflow:hidden}.vsc-bar{border-radius:4px;height:6px}.col-green{color:var(--vsc-green)}.col-blue{color:var(--vsc-accent)}.col-orange{color:var(--vsc-orange)}.col-red{color:var(--vsc-red)}.col-yellow{color:var(--vsc-yellow)}.col-purple{color:var(--vsc-purple)}.col-accent{color:var(--vsc-accent2)}.col-muted{color:var(--vsc-muted)}.col-teal{color:var(--vsc-teal)}.col-pink{color:var(--vsc-pink)}.vsc-pill{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.vsc-pill-green{background:color-mix(in srgb,var(--vsc-green) 18%,transparent);color:var(--vsc-green)}.vsc-pill-blue{background:color-mix(in srgb,var(--vsc-accent) 18%,transparent);color:var(--vsc-accent)}.vsc-pill-orange{background:color-mix(in srgb,var(--vsc-orange) 18%,transparent);color:var(--vsc-orange)}.vsc-pill-red{background:color-mix(in srgb,var(--vsc-red) 18%,transparent);color:var(--vsc-red)}.vsc-pill-gray{background:color-mix(in srgb,var(--vsc-muted) 15%,transparent);color:var(--vsc-muted)}.vsc-pill-purple{background:color-mix(in srgb,var(--vsc-purple) 18%,transparent);color:var(--vsc-purple)}.vsc-pill-teal{background:color-mix(in srgb,var(--vsc-teal) 18%,transparent);color:var(--vsc-teal)}.vsc-school-row{border-bottom:1px solid var(--vsc-border);cursor:pointer;align-items:center;gap:10px;padding:8px 0;display:flex}.vsc-school-row:last-child{border-bottom:none}.vsc-school-badge{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.vsc-school-info{flex:1;min-width:0}.vsc-school-name{font-size:12px;font-weight:500}.vsc-school-stat{text-align:right}.vsc-school-stat-val{font-size:11px;font-weight:600}.vsc-school-stat-lbl{color:var(--vsc-muted);font-size:10px}.vsc-alert{border-bottom:1px solid var(--vsc-border);align-items:flex-start;gap:8px;padding:6px 0;display:flex}.vsc-alert:last-child{border-bottom:none}.vsc-alert svg{flex-shrink:0;width:14px;height:14px;margin-top:2px}.vsc-alert-msg{font-size:12px;line-height:1.5}.vsc-activity-row td{vertical-align:middle}.vsc-filters{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.vsc-filters input,.vsc-filters select{background-color:var(--vsc-panel);border:1px solid var(--vsc-border);color:var(--vsc-text);border-radius:4px;outline:none;padding:6px 10px;font-family:inherit;font-size:12px;transition:border .15s,box-shadow .15s}.vsc-filters input:focus,.vsc-filters select:focus{border-color:var(--vsc-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--vsc-accent) 20%,transparent)}.vsc-filters input{flex:1;min-width:140px}.vsc-filters select{cursor:pointer}.vsc-btn{background:var(--vsc-accent);color:#fff;cursor:pointer;border:none;border-radius:4px;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:12px;transition:all .2s;display:inline-flex;box-shadow:0 1px 3px #00000026}.vsc-btn:hover{filter:brightness(1.1);box-shadow:0 2px 8px #0003}.vsc-btn svg{width:14px;height:14px}.vsc-analytics-tabs{border-bottom:1px solid var(--vsc-border);gap:0;margin-bottom:14px;display:flex}.vsc-analytics-tab{cursor:pointer;color:var(--vsc-muted);background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 16px;font-family:inherit;font-size:12px;transition:color .15s,border-color .15s}.vsc-analytics-tab:hover{color:var(--vsc-text)}.vsc-analytics-tab.active{color:var(--vsc-accent);border-bottom-color:var(--vsc-accent)}.vsc-analytics-tab svg{vertical-align:middle;width:14px;height:14px;margin-right:4px}@media (width<=900px){.vsc-grid-4{grid-template-columns:repeat(2,1fr)}.vsc-grid-2{grid-template-columns:1fr}.vsc-sidebar{z-index:100;border-right:1px solid var(--vsc-border);width:220px;transition:transform .2s;position:fixed;top:0;bottom:0;left:40px;transform:translate(-100%)}.vsc-sidebar.open{transform:translate(0);box-shadow:2px 0 12px #0006}.vsc-activity{width:40px}.vsc-main{position:relative}}@media (width<=520px){.vsc-grid-4,.vsc-grid-3{grid-template-columns:1fr}.vsc-activity{width:36px}.vsc-tabbar{height:30px}.vsc-tab{height:30px;padding:0 8px;font-size:11px}.vsc-filters{flex-direction:column}.vsc-filters input{width:100%;min-width:0}.vsc-content{padding:10px}.vsc-content .tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.vsc-content .tabs .tab{flex-shrink:0}.vsc-content .vsc-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.vsc-stat{padding:10px 12px}.vsc-stat-num{font-size:18px}.vsc-card{padding:10px}.vsc-h1{font-size:16px}}@media (width<=400px){.vsc-content,.vsc-card{padding:8px}}.page-header{border-bottom:1px solid var(--vsc-border)!important;background:0 0!important;margin:0!important;padding:12px 16px!important}.page-header h1{color:var(--vsc-text)!important;font-size:18px!important;font-weight:700!important}.page-header p{color:var(--vsc-muted)!important;font-size:12px!important}.card{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;border-radius:8px!important;box-shadow:0 2px 6px #00000026!important}.card-header{border-bottom:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;background:0 0!important}.card-title{color:var(--vsc-text)!important;font-size:13px!important}.btn{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;cursor:pointer!important;-webkit-user-select:none!important;user-select:none!important;border-radius:6px!important;padding:6px 14px!important;font-size:12px!important;transition:all .15s!important;box-shadow:0 1px 2px #00000014!important}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000001f!important}.btn-primary{background:var(--btn-primary-bg)!important;color:#fff!important;box-shadow:0 2px 8px color-mix(in srgb,var(--vsc-accent) 30%,transparent)!important;border-color:#0000!important}.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.12)!important;box-shadow:0 4px 12px color-mix(in srgb,var(--vsc-accent) 40%,transparent)!important}.btn-primary:active{filter:brightness(.95)!important;transform:scale(.97)!important}.btn-success{background:var(--btn-success-bg)!important;color:#fff!important;box-shadow:0 2px 8px color-mix(in srgb,var(--vsc-green) 30%,transparent)!important;border-color:#0000!important}.btn-success:hover{transform:translateY(-1px);filter:brightness(1.12)!important;box-shadow:0 4px 12px color-mix(in srgb,var(--vsc-green) 40%,transparent)!important}.btn-success:active{filter:brightness(.95)!important;transform:scale(.97)!important}.btn-danger{background:var(--btn-danger-bg)!important;color:#fff!important;box-shadow:0 2px 8px color-mix(in srgb,var(--vsc-red) 30%,transparent)!important;border-color:#0000!important}.btn-danger:hover{transform:translateY(-1px);filter:brightness(1.12)!important;box-shadow:0 4px 12px color-mix(in srgb,var(--vsc-red) 40%,transparent)!important}.btn-danger:active{filter:brightness(.9)!important;transform:scale(.97)!important}.btn-warning{background:var(--btn-warning-bg)!important;color:#1a2332!important;box-shadow:0 2px 8px color-mix(in srgb,var(--vsc-yellow) 30%,transparent)!important;border-color:#0000!important}.btn-warning:hover{transform:translateY(-1px);filter:brightness(.92)!important;box-shadow:0 4px 12px color-mix(in srgb,var(--vsc-yellow) 40%,transparent)!important}.btn-warning:active{filter:brightness(.85)!important;transform:scale(.97)!important}.btn-ghost{border-color:var(--vsc-border)!important;box-shadow:none!important;background:0 0!important}.btn-ghost:hover{transform:none;background:color-mix(in srgb,var(--vsc-accent) 8%,transparent)!important;box-shadow:none!important}.btn-ghost:active{background:color-mix(in srgb,var(--vsc-accent) 16%,transparent)!important;transform:scale(.97)!important}.btn-sm{padding:2px 8px!important;font-size:11px!important}.form-group label{font-weight:500;color:var(--vsc-text)!important;margin-bottom:4px!important;font-size:12px!important}.form-group input,.form-group select,.form-group textarea{background-color:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;border-radius:6px!important;padding:8px 12px!important;font-size:13px!important;transition:border-color .2s,box-shadow .2s!important;box-shadow:inset 0 1px 3px #0000001f!important}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--vsc-accent)!important;box-shadow:inset 0 1px 3px #0000001a,0 0 0 2px color-mix(in srgb,var(--vsc-accent) 20%,transparent)!important;outline:none!important}.stats-grid{gap:12px!important}.stat-card{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;border-left:3px solid var(--vsc-accent)!important;border-radius:8px!important;padding:16px 20px!important;box-shadow:0 2px 6px #0000001f!important}.stat-card:before{display:none!important}.stat-card .stat-value{color:var(--vsc-text)!important;font-size:22px!important;font-weight:700!important}.stat-card .stat-label{color:var(--vsc-muted)!important;text-transform:uppercase!important;letter-spacing:.05em!important;font-size:11px!important}.stat-card.orange{border-left-color:var(--vsc-orange)!important}.stat-card.green{border-left-color:var(--vsc-green)!important}.stat-card.blue{border-left-color:var(--vsc-accent)!important}.stat-card.red{border-left-color:var(--vsc-red)!important}.stat-card.purple{border-left-color:var(--vsc-purple)!important}.badge,.badge-blue{background:var(--vsc-accent)!important;color:#fff!important;border-radius:4px!important;padding:2px 8px!important;font-size:11px!important}.badge.badge-success,.badge-green{background:var(--vsc-green)!important;color:#fff!important}.badge.badge-warning,.badge-yellow{background:var(--vsc-yellow)!important;color:#1a2332!important}.badge.badge-danger,.badge-red{background:var(--vsc-red)!important;color:#fff!important}.badge.badge-purple{background:var(--vsc-purple)!important;color:#fff!important}.badge.badge-teal{background:var(--vsc-teal)!important;color:#fff!important}table{color:var(--vsc-text)!important;border-collapse:collapse!important;font-size:12px!important}table thead{background:color-mix(in srgb,var(--vsc-sidebar) 60%,transparent)!important}table th{font-weight:600;color:var(--vsc-muted)!important;text-transform:uppercase!important;letter-spacing:.05em!important;border-bottom:1px solid var(--vsc-border)!important;padding:8px 12px!important;font-size:11px!important}table td{border-bottom:1px solid var(--vsc-border)!important;padding:8px 12px!important}table tr:hover{background:color-mix(in srgb,var(--vsc-accent) 4%,transparent)!important}.modal-overlay{background:#00000080!important}.modal{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;border-radius:10px!important;box-shadow:0 8px 32px #0006!important}.modal h2{color:var(--vsc-text)!important}.modal-header{background:var(--vsc-sidebar)!important;border-bottom:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;border-radius:10px 10px 0 0!important}.modal-footer{background:var(--vsc-sidebar)!important;border-top:1px solid var(--vsc-border)!important;border-radius:0 0 10px 10px!important}.collapsible-section .section-header{background:var(--vsc-sidebar)!important;border:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;border-radius:6px!important}.collapsible-section .section-content{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;border-top:none!important;border-radius:0 0 6px 6px!important}.alert{background:var(--vsc-panel)!important;border:1px solid var(--vsc-border)!important;color:var(--vsc-text)!important;border-radius:6px!important}.alert.alert-success{border-color:var(--vsc-green)!important;background:color-mix(in srgb,var(--vsc-green) 12%,transparent)!important}.alert.alert-warning{border-color:var(--vsc-yellow)!important;background:color-mix(in srgb,var(--vsc-yellow) 12%,transparent)!important}.alert.alert-danger{border-color:var(--vsc-red)!important;background:color-mix(in srgb,var(--vsc-red) 12%,transparent)!important}.alert.alert-info{border-color:var(--vsc-accent)!important;background:color-mix(in srgb,var(--vsc-accent) 12%,transparent)!important}.flex-gap{gap:8px!important}a{font-weight:500;color:var(--vsc-accent)!important}a:hover{color:var(--vsc-accent2)!important}hr{border-color:var(--vsc-border)!important}code{background:var(--vsc-sidebar)!important;border:1px solid var(--vsc-border)!important;border-radius:4px!important;padding:1px 4px!important}pre{background:var(--vsc-sidebar)!important;border:1px solid var(--vsc-border)!important;border-radius:6px!important;padding:12px!important;overflow:auto!important}.tabs{box-shadow:none!important;background:var(--vsc-sidebar)!important;border:1px solid var(--vsc-border)!important;border-radius:6px!important}.tabs .tab.active{border-bottom-color:var(--vsc-accent)!important;color:var(--vsc-accent)!important}.tabs .tab{color:var(--vsc-muted)!important}.tabs .tab.active{background:var(--vsc-accent)!important;border-color:var(--vsc-accent)!important;color:#fff!important}.tabs .tab:hover{background:color-mix(in srgb,var(--vsc-accent) 8%,transparent)!important}select:focus,input[type=search]:focus,.search-bar input:focus,input.search-input:focus,.cell-input:focus{box-shadow:none!important;border-color:var(--vsc-accent)!important}:root .card,:root .stat-card,:root .modal{box-shadow:0 2px 8px #00000038!important}:root .form-group input,:root .form-group select,:root .form-group textarea{box-shadow:inset 0 1px 4px #00000026!important}[data-theme=light] .card{box-shadow:0 1px 4px #00000014!important}[data-theme=light] .stat-card{box-shadow:0 1px 4px #0000000f!important}[data-theme=light] .modal{box-shadow:0 8px 32px #0000001f!important}[data-theme=light] .form-group input,[data-theme=light] .form-group select,[data-theme=light] .form-group textarea{background-color:#fff!important;border-color:#d0d0d0!important;box-shadow:inset 0 1px 3px #0000000f!important}[data-theme=light] .form-group input:focus,[data-theme=light] .form-group select:focus,[data-theme=light] .form-group textarea:focus{border-color:var(--vsc-accent)!important;box-shadow:inset 0 1px 3px #0000000f,0 0 0 2px color-mix(in srgb,var(--vsc-accent) 20%,transparent)!important}.saas-card{background:var(--vsc-panel)!important;border-color:var(--vsc-border)!important;border-radius:8px!important;box-shadow:0 2px 6px #00000026!important}.saas-card-header h3{color:var(--vsc-text)!important}.stat-card-saas{background:var(--vsc-panel)!important;border-color:var(--vsc-border)!important;border-radius:8px!important;box-shadow:0 2px 6px #00000026!important}.stat-card-saas .label,.stat-card-saas .sub{color:var(--vsc-muted)!important}.status-pill.blue{background:color-mix(in srgb,var(--vsc-accent) 13%,transparent)!important;color:var(--vsc-accent)!important}.fees-trend-bar{background:var(--vsc-accent)!important}.alert-row.info{background:color-mix(in srgb,var(--vsc-accent) 10%,transparent)!important;border-color:color-mix(in srgb,var(--vsc-accent) 20%,transparent)!important}.bar-chart-val{color:var(--vsc-text)!important}.bar-chart-label{color:var(--vsc-muted)!important}[data-theme=light] .vsc-tabbar{border-bottom:1px solid #c8d0e0!important}[data-theme=light] .stat-card-saas,[data-theme=light] .saas-card{box-shadow:0 1px 4px #00000014!important}.mobile-shell{background:var(--vsc-bg,#1e1e1e);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.mobile-topbar{background:var(--vsc-title-bar,#2d2d2d);border-bottom:1px solid var(--vsc-border,#3c3c3c);height:52px;padding:0 8px;padding-top:env(safe-area-inset-top,0px);z-index:100;flex-shrink:0;align-items:center;gap:4px;display:flex;position:relative}.mobile-topbar-btn{width:40px;height:40px;color:var(--vsc-text,#ccc);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;display:flex}.mobile-topbar-btn:active{background:#ffffff1a}.mobile-topbar-title{color:var(--vsc-text,#e0e0e0);text-overflow:ellipsis;white-space:nowrap;flex:1;padding:0 4px;font-size:16px;font-weight:600;overflow:hidden}.mobile-topbar-actions{align-items:center;gap:2px;display:flex}.mobile-bottom-nav{background:var(--vsc-title-bar,#2d2d2d);border-top:1px solid var(--vsc-border,#3c3c3c);height:56px;padding-bottom:env(safe-area-inset-bottom,0px);z-index:100;flex-shrink:0;align-items:stretch;display:flex;position:relative}.mobile-bottom-tab{color:var(--vsc-muted,#888);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1px;padding:4px 0;font-size:10px;transition:color .15s;display:flex;position:relative}.mobile-bottom-tab.active{color:var(--vsc-accent,#863bff)}.mobile-bottom-tab:active{background:#ffffff0d}.mobile-bottom-tab svg{font-size:22px}.mobile-bottom-tab span{font-size:10px;line-height:1}.mobile-drawer-overlay{z-index:200;background:#00000080;animation:.2s fadeIn;position:fixed;inset:0}.mobile-drawer{background:var(--vsc-panel,#252526);z-index:201;flex-direction:column;width:85vw;max-width:320px;animation:.25s slideIn;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 12px #0000004d}.mobile-drawer-header{padding:16px;padding-top:calc(env(safe-area-inset-top,0px) + 16px);border-bottom:1px solid var(--vsc-border,#3c3c3c);align-items:center;gap:10px;display:flex}.mobile-drawer-logo{object-fit:cover;border-radius:8px;width:36px;height:36px}.mobile-drawer-school-name{color:var(--vsc-text,#e0e0e0);font-size:16px;font-weight:700}.mobile-drawer-user{border-bottom:1px solid var(--vsc-border,#3c3c3c);align-items:center;gap:10px;padding:12px 16px;display:flex}.mobile-drawer-avatar{object-fit:cover;background:var(--vsc-bg,#1e1e1e);border-radius:50%;width:36px;height:36px}.mobile-drawer-user-info{flex:1;overflow:hidden}.mobile-drawer-user-name{color:var(--vsc-text,#e0e0e0);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.mobile-drawer-user-role{color:var(--vsc-muted,#888);font-size:11px}.mobile-drawer-sections{flex:1;padding:8px 0;overflow-y:auto}.mobile-drawer-cat-btn{border:none;border-bottom:1px solid var(--vsc-border,#3c3c3c);width:100%;color:var(--vsc-text,#ccc);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:12px;padding:12px 16px;font-size:14px;transition:background .1s;display:flex}.mobile-drawer-cat-btn:active{background:#ffffff14}.mobile-drawer-cat-btn.active{color:var(--vsc-accent,#863bff);border-left:3px solid var(--vsc-accent,#863bff);background:#863bff1a}.mobile-drawer-cat-btn svg{flex-shrink:0;width:22px;font-size:18px}.mobile-drawer-logout{border-top:1px solid var(--vsc-border,#3c3c3c);padding:12px 16px;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 12px)}.mobile-drawer-logout-btn{width:100%;color:var(--vsc-red,#f44747);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:10px;font-size:14px;display:flex}.mobile-drawer-logout-btn:active{background:#f4474726}.mobile-page{-webkit-overflow-scrolling:touch;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));flex:1;overflow:hidden auto}.mobile-page-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px;display:flex}.mobile-page-title{color:var(--vsc-text,#e0e0e0);margin:0;font-size:20px;font-weight:700}.mobile-page-subtitle{color:var(--vsc-muted,#888);margin-top:2px;font-size:12px}.mobile-card{background:var(--vsc-card-bg,#2d2d2d);cursor:pointer;border:1px solid var(--vsc-border,#3c3c3c);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;transition:background .15s;display:flex}.mobile-card:active{background:var(--vsc-hover,#37373d)}.mobile-card-icon{width:40px;height:40px;color:var(--vsc-accent,#863bff);background:#863bff1f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;display:flex}.mobile-card-body{flex:1;overflow:hidden}.mobile-card-title{color:var(--vsc-text,#e0e0e0);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.mobile-card-subtitle{color:var(--vsc-muted,#888);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;overflow:hidden}.mobile-card-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;max-width:45%;display:flex;overflow:hidden}.mobile-card-value{color:var(--vsc-text,#e0e0e0);text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:14px;font-weight:600;overflow:hidden}.mobile-card-label{color:var(--vsc-muted,#888);text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:10px;overflow:hidden}.mobile-card-chevron{color:var(--vsc-muted,#555);flex-shrink:0;margin-left:4px;font-size:16px}.mobile-stat{background:var(--vsc-card-bg,#2d2d2d);border:1px solid var(--vsc-border,#3c3c3c);border-radius:10px;padding:16px}.mobile-stat-label{color:var(--vsc-muted,#888);margin-bottom:4px;font-size:11px}.mobile-stat-value{color:var(--vsc-text,#e0e0e0);font-size:22px;font-weight:700}.mobile-stat-icon{margin-bottom:8px;font-size:20px;display:block}.mobile-stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.mobile-section-title{color:var(--vsc-muted,#888);text-transform:uppercase;letter-spacing:.5px;margin:16px 0 8px;font-size:13px;font-weight:600}.mobile-search{background:var(--vsc-input-bg,#3c3c3c);border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;transition:border-color .15s;display:flex}.mobile-search:focus-within{border-color:var(--vsc-accent,#863bff)}.mobile-search input{color:var(--vsc-text,#e0e0e0);background:0 0;border:none;outline:none;flex:1;font-size:14px}.mobile-search input::placeholder{color:var(--vsc-muted,#666)}.mobile-search svg{color:var(--vsc-muted,#666);font-size:18px}.mobile-modal-overlay{z-index:300;background:#00000080;flex-direction:column;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.mobile-modal-sheet{background:var(--vsc-panel,#252526);max-height:90vh;padding-bottom:env(safe-area-inset-bottom,0px);border-radius:16px 16px 0 0;flex-direction:column;animation:.3s slideUp;display:flex}.mobile-modal-handle{background:var(--vsc-muted,#555);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:8px auto}.mobile-modal-header{flex-shrink:0;align-items:center;gap:8px;padding:4px 16px 12px;display:flex}.mobile-modal-title{color:var(--vsc-text,#e0e0e0);flex:1;font-size:17px;font-weight:700}.mobile-modal-close{width:36px;height:36px;color:var(--vsc-muted,#888);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:22px;display:flex}.mobile-modal-close:active{background:#ffffff1a}.mobile-modal-body{-webkit-overflow-scrolling:touch;padding:0 16px 16px;overflow-y:auto}.mobile-modal-full{border-radius:0;height:100vh;max-height:100vh}.mobile-fab{background:var(--vsc-accent,#863bff);color:#fff;cursor:pointer;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:80px;right:20px;box-shadow:0 4px 12px #863bff59}.mobile-fab:active{transform:scale(.92);box-shadow:0 2px 6px #863bff40}.mobile-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.mobile-empty-icon{color:var(--vsc-muted,#555);margin-bottom:12px;font-size:48px}.mobile-empty-title{color:var(--vsc-text,#ccc);margin-bottom:4px;font-size:16px;font-weight:600}.mobile-empty-text{color:var(--vsc-muted,#888);font-size:13px}.mobile-chips{-webkit-overflow-scrolling:touch;gap:6px;margin-bottom:12px;padding-bottom:4px;display:flex;overflow-x:auto}.mobile-chip{border:1px solid var(--vsc-border,#3c3c3c);background:var(--vsc-card-bg,#2d2d2d);color:var(--vsc-text,#ccc);white-space:nowrap;cursor:pointer;border-radius:16px;flex-shrink:0;padding:6px 14px;font-size:12px;transition:background .15s,border-color .15s}.mobile-chip:active{background:#863bff1f}.mobile-chip.active{border-color:var(--vsc-accent,#863bff);color:var(--vsc-accent,#863bff);background:#863bff26}.mobile-skeleton{background:linear-gradient(90deg, var(--vsc-card-bg,#2d2d2d) 25%, var(--vsc-hover,#37373d) 50%, var(--vsc-card-bg,#2d2d2d) 75%);background-size:200% 100%;border-radius:8px;height:16px;margin-bottom:8px;animation:1.5s infinite shimmer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes toastIn{0%{opacity:0;transform:translateY(80px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(80px)}}.mobile-toast-container{z-index:999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:76px;left:16px;right:16px}.mobile-toast{background:var(--vsc-panel,#323232);color:var(--vsc-text,#e0e0e0);pointer-events:auto;border:1px solid var(--vsc-border,#3c3c3c);border-radius:10px;align-items:center;gap:10px;min-height:48px;padding:12px 16px;font-size:14px;animation:.3s toastIn;display:flex;box-shadow:0 4px 20px #00000059}.mobile-toast.leaving{animation:.25s forwards toastOut}.mobile-toast svg{flex-shrink:0;font-size:20px}.mobile-toast.toast-success svg{color:#6a9955}.mobile-toast.toast-error svg{color:#f44747}.mobile-toast.toast-warning svg{color:#ce9178}.mobile-network-banner{flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;animation:.25s slideDown;display:flex}.mobile-network-banner.online{color:#fff;background:#6a9955}.mobile-network-banner.offline{color:#fff;background:#f44747}.mobile-form-group{margin-bottom:14px}.mobile-form-label{color:var(--vsc-muted,#888);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.mobile-form-input,.mobile-form-select,.mobile-form-textarea{background:var(--vsc-input-bg,#3c3c3c);border:1px solid var(--vsc-border,#3c3c3c);width:100%;color:var(--vsc-text,#e0e0e0);box-sizing:border-box;appearance:none;border-radius:10px;min-height:48px;padding:12px 14px;font-size:15px;transition:border-color .15s;display:block}.mobile-form-textarea{resize:vertical;min-height:80px}.mobile-form-input:focus,.mobile-form-select:focus,.mobile-form-textarea:focus{border-color:var(--vsc-accent,#863bff);outline:none}.mobile-form-input.error,.mobile-form-select.error,.mobile-form-textarea.error{border-color:#f44747}.mobile-form-error{color:#f44747;margin-top:4px;font-size:11px}.mobile-form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%228%22 viewBox=%220 0 12 8%22%3E%3Cpath fill=%22%23888%22 d=%22M1.41 0L6 4.58 10.59 0 12 1.41l-6 6-6-6z%22/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.mobile-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;min-width:48px;min-height:48px;padding:12px 20px;font-size:15px;font-weight:500;transition:background .15s,transform .1s,box-shadow .15s;display:inline-flex}.mobile-btn:active{transform:scale(.97)}.mobile-btn:disabled{opacity:.5;cursor:default;transform:none}.mobile-btn-primary{background:var(--vsc-accent,#863bff);color:#fff}.mobile-btn-primary:active:not(:disabled){background:color-mix(in srgb, var(--vsc-accent,#863bff) 80%, #000)}.mobile-btn-ghost{color:var(--vsc-text,#ccc);border:1px solid var(--vsc-border,#3c3c3c);background:0 0}.mobile-btn-ghost:active:not(:disabled){background:#ffffff14}.mobile-btn-danger{color:#f44747;background:0 0;border:1px solid #f447474d}.mobile-btn-danger:active:not(:disabled){background:#f447471f}.mobile-btn-success{color:#fff;background:#6a9955}.mobile-btn-sm{min-height:36px;padding:8px 14px;font-size:13px}.mobile-btn-block{width:100%;display:flex}.mobile-topbar-btn{min-width:44px;min-height:44px}.mobile-bottom-tab{min-height:48px;padding:6px 0 4px}.mobile-badge{border-radius:12px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;line-height:1.4;display:inline-flex}.mobile-badge-blue{color:var(--vsc-accent,#863bff);background:#863bff26}.mobile-badge-green{color:#6a9955;background:#6a995526}.mobile-badge-red{color:#f44747;background:#f4474726}.mobile-badge-gray{color:var(--vsc-muted,#888);background:#88888826}.mobile-badge-amber{color:#ce9178;background:#ce917826}.mobile-divider{background:var(--vsc-border,#3c3c3c);height:1px;margin:12px 0}.mobile-skeleton-card{background:var(--vsc-card-bg,#2d2d2d);border:1px solid var(--vsc-border,#3c3c3c);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;display:flex}.mobile-skeleton-card .mobile-skeleton-avatar{background:linear-gradient(90deg, var(--vsc-hover,#37373d) 25%, #ffffff0f 50%, var(--vsc-hover,#37373d) 75%);background-size:200% 100%;border-radius:10px;flex-shrink:0;width:40px;height:40px;animation:1.5s infinite shimmer}.mobile-skeleton-card .mobile-skeleton-lines{flex:1}.mobile-skeleton-card .mobile-skeleton-line{background:linear-gradient(90deg, var(--vsc-hover,#37373d) 25%, #ffffff0f 50%, var(--vsc-hover,#37373d) 75%);background-size:200% 100%;border-radius:6px;height:14px;margin-bottom:6px;animation:1.5s infinite shimmer}.mobile-skeleton-card .mobile-skeleton-line:last-child{width:60%;margin-bottom:0}.mobile-empty-action{margin-top:16px}.mobile-pull-refresh{position:relative;overflow:hidden}.mobile-enter{opacity:0;transform:translate(30px)}.mobile-enter-active{opacity:1;transition:opacity .25s,transform .25s;transform:translate(0)}.mobile-ripple{position:relative;overflow:hidden}.mobile-ripple:after{content:"";background:radial-gradient(circle at var(--x,50%) var(--y,50%), #ffffff26 0%, transparent 60%);opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0}.mobile-ripple:active:after{opacity:1;transition:opacity}.mobile-pull-indicator{text-align:center;color:var(--vsc-muted,#888);padding:12px;font-size:12px;transition:opacity .2s}@media (display-mode:standalone){.mobile-topbar{padding-top:env(safe-area-inset-top,0px)}.mobile-bottom-nav{padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-page{padding-top:max(12px, env(safe-area-inset-top,0px))}}@supports (padding-top:env(safe-area-inset-top)){.mobile-drawer-header{padding-top:calc(env(safe-area-inset-top,0px) + 16px)}.mobile-drawer-logout{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 12px)}.mobile-modal-sheet{padding-bottom:env(safe-area-inset-bottom,0px)}}[data-theme=light] .mobile-drawer-overlay{background:#00000040}[data-theme=light] .mobile-drawer{background:var(--vsc-sidebar);box-shadow:2px 0 12px #00000014}[data-theme=light] .mobile-drawer-cat-btn:active{background:color-mix(in srgb,var(--vsc-accent) 10%,transparent)}[data-theme=light] .mobile-drawer-cat-btn.active{color:var(--vsc-accent);background:color-mix(in srgb,var(--vsc-accent) 12%,transparent)}[data-theme=light] .mobile-drawer-logout-btn:active{background:color-mix(in srgb,var(--vsc-red) 12%,transparent)}[data-theme=light] .mobile-bottom-nav{background:var(--vsc-sidebar);border-top-color:var(--vsc-border)}[data-theme=light] .mobile-bottom-tab:active{background:color-mix(in srgb,var(--vsc-accent) 8%,transparent)}[data-theme=light] .mobile-search{background:var(--vsc-panel);border:1px solid var(--vsc-border)}[data-theme=light] .mobile-search input::placeholder,[data-theme=light] .mobile-search svg{color:var(--vsc-muted)}[data-theme=light] .mobile-card{background:var(--vsc-panel)}[data-theme=light] .mobile-card:active{background:var(--vsc-sidebar)}[data-theme=light] .mobile-modal-sheet{background:#fff}[data-theme=light] .mobile-modal-overlay{background:#00000040}[data-theme=light] .mobile-modal-close:active{background:color-mix(in srgb,var(--vsc-accent) 10%,transparent)}[data-theme=light] .mobile-chip{background:var(--vsc-sidebar);border-color:var(--vsc-border);color:var(--vsc-text)}[data-theme=light] .mobile-chip:active{background:color-mix(in srgb,var(--vsc-accent) 12%,transparent)}[data-theme=light] .mobile-chip.active{background:var(--vsc-accent);border-color:var(--vsc-accent);color:#fff}[data-theme=light] .mobile-fab{background:var(--vsc-accent);box-shadow:0 4px 12px color-mix(in srgb,var(--vsc-accent) 30%,transparent)}[data-theme=light] .mobile-fab:active{box-shadow:0 2px 6px color-mix(in srgb,var(--vsc-accent) 20%,transparent)}[data-theme=light] .mobile-stat{background:var(--vsc-panel);box-shadow:0 1px 3px #0000000d}[data-theme=light] .mobile-topbar{background:var(--vsc-panel);border-bottom-color:var(--vsc-border)}[data-theme=light] .mobile-topbar-btn:active{background:color-mix(in srgb,var(--vsc-accent) 10%,transparent)}[data-theme=light] .mobile-toast{color:#333;background:#fff;border-color:#e0e0e0;box-shadow:0 4px 20px #0000001f}[data-theme=light] .mobile-form-input,[data-theme=light] .mobile-form-select,[data-theme=light] .mobile-form-textarea{color:#333;background:#fff;border-color:#d0d0d0}[data-theme=light] .mobile-btn-ghost{color:#555;border-color:#d0d0d0}[data-theme=light] .mobile-btn-danger{border-color:#f447474d}[data-theme=light] .mobile-badge-gray{color:#666;background:#0000000f}[data-theme=light] .mobile-skeleton-card{background:var(--vsc-panel)}[data-theme=light] .mobile-skeleton-card .mobile-skeleton-avatar,[data-theme=light] .mobile-skeleton-card .mobile-skeleton-line{background:linear-gradient(90deg,#e8e8e8 25%,#f5f5f5 50%,#e8e8e8 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}[data-theme=light] .mobile-network-banner.online{background:#4caf50}[data-theme=light] .mobile-network-banner.offline{background:#f44336}:root{--bg:#0b0f1a;--surface:#141929;--surface2:#1c2440;--border:#2a3555;--accent:#38d9a9;--accent2:#4f8ef7;--accent3:#f7a84f;--danger:#f75c5c;--text:#e8eaf6;--text2:#8892b0;--radius:12px;--shadow:0 8px 32px #0006}[data-theme=light]{--bg:#f4f6fb;--surface:#fff;--surface2:#edf1f7;--border:#d8e0ec;--accent:#118765;--accent2:#1f6fd1;--accent3:#b85f14;--danger:#c43d3d;--text:#182033;--text2:#5e687a;--shadow:0 8px 28px #2832461f;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,sans-serif;overflow-x:hidden}h1,h2,h3{font-family:Fredoka,sans-serif}#loginPage{background:radial-gradient(ellipse at 30% 40%, #1a2a6c44 0%, transparent 60%),radial-gradient(ellipse at 80% 80%, #23414422 0%, transparent 60%),var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);width:400px;box-shadow:var(--shadow);border-radius:20px;padding:48px 40px}.login-card h1{color:var(--accent);margin-bottom:6px;font-family:Playfair Display,serif;font-size:2rem}.login-card p{color:var(--text2);margin-bottom:32px;font-size:.9rem}.school-login-page{background:linear-gradient(#183760d9,#337081b3 46%,#5d497dbd 72%,#0d083af5),linear-gradient(135deg,#2d5d94,#6fb6b0 42%,#d28092 68%,#10064a);justify-content:center;align-items:center;min-height:100vh;padding:28px;display:flex;position:relative;overflow:hidden}.school-login-page:before{content:"";opacity:.95;background:linear-gradient(145deg,#0000 0 7%,#1f164df5 7% 18%,#0000 18% 28%,#130e3ffa 28% 45%,#0000 45% 56%,#1e144ff0 56% 70%,#0000 70%),linear-gradient(#0000,#09052df2);height:30%;position:absolute;inset:auto 0 0}.school-login-page:after{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff0d,#0000 30%,#0003);position:absolute;inset:0}.school-login-shell{z-index:1;filter:drop-shadow(0 24px 48px #00000057);grid-template-columns:minmax(360px,.66fr) minmax(520px,1fr);align-items:stretch;width:min(1420px,92vw);min-height:78vh;display:grid;position:relative}.school-login-welcome{clip-path:polygon(0 0,100% 0,100% 36%,84% 50%,100% 64%,100% 100%,0 100%);background:linear-gradient(135deg,#5268d2d1,#b34490c2 48%,#ee252fdb),linear-gradient(18deg,#ffffff14 0 19%,#0000 19% 100%),linear-gradient(142deg,#0000 0 22%,#ffffff1f 22% 29%,#0000 29% 100%),linear-gradient(#4869b8,#d94a60);border-radius:18px 0 0 18px;min-height:660px;position:relative;overflow:hidden}.school-login-welcome:before{content:"";background:repeating-linear-gradient(135deg,#ffffff0f 0 2px,#0000 2px 8px),linear-gradient(120deg,#0000 0 14%,#0a185a3d 14% 22%,#0000 22% 55%,#ffffff14 55% 61%,#0000 61%),linear-gradient(#ffffff14,#00000042);position:absolute;inset:0}.school-login-welcome:after{content:"";background:linear-gradient(138deg,#0000 0 11%,#24195d80 11% 21%,#0000 21% 100%),linear-gradient(36deg,#17134a6b 0 24%,#0000 24% 100%),linear-gradient(#ffffff14,#321e5f61);height:31%;position:absolute;bottom:-1px;left:-8%;right:-8%}.school-login-welcome-inner{z-index:1;text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:48px 64px 48px 48px;display:flex;position:relative}.school-login-welcome h1{text-transform:uppercase;letter-spacing:0;margin:0;font-size:2.45rem;font-weight:900;line-height:1}.school-login-rule{background:#fff;width:128px;height:3px;margin:14px 0 44px}.school-login-side-icon{color:#fff;width:86px;height:86px;margin-bottom:70px}.school-login-socials{gap:12px;display:flex}.school-login-socials span{color:#fff;background:#2b266f6b;border:1px solid #ffffff52;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.18rem;display:inline-flex}.school-login-panel{color:#fff;background:#202020;border-radius:0 16px 16px 0;flex-direction:column;justify-content:center;align-items:center;min-height:600px;margin:24px 0 24px -1px;padding:72px 8%;display:flex;box-shadow:inset 0 1px #ffffff08}.school-login-main-icon{color:#f5f5f5;width:74px;height:74px;margin-bottom:28px}.school-login-panel h2{color:#fff;margin:0 0 8px;font-family:DM Sans,sans-serif;font-size:2.62rem;font-weight:800;line-height:1.05}.school-login-panel p{color:#777;margin:0 0 42px;font-weight:700}.school-login-form{gap:22px;width:min(620px,100%);display:grid}.school-login-field{color:#686868;background:#202020;border:1px solid #464646;border-radius:999px;align-items:center;gap:16px;height:60px;padding:0 24px;transition:border-color .2s,box-shadow .2s;display:flex}.school-login-field:focus-within{border-color:#777;box-shadow:0 0 0 4px #ffffff0a}.school-login-field svg{flex-shrink:0;width:22px;height:22px}.school-login-field input{color:#fff;width:100%;font:inherit;background:0 0;border:0;outline:0;font-size:.96rem;font-weight:800}.school-login-field input::placeholder{color:#858585}.school-login-options{justify-content:space-between;align-items:center;gap:16px;margin:8px 16px 30px;display:flex}.school-login-remember{color:#fff;cursor:pointer;align-items:center;gap:10px;font-weight:800;display:flex}.school-login-remember input{appearance:none;background:#202020;border:1px solid #4c4c4c;width:30px;height:30px}.school-login-remember input:checked{background:linear-gradient(135deg,#516ee5,#e71f39);border-color:#777}.school-login-options button{color:#686868;font:inherit;cursor:pointer;background:0 0;border:0;font-weight:800}.school-login-options button:hover,.school-login-register:hover{color:#fff}.school-login-submit{color:#fff;height:64px;font:inherit;cursor:pointer;background:#202020;border:1px solid #464646;border-radius:999px;justify-content:center;align-items:center;gap:8px;font-size:1rem;font-weight:900;transition:transform .2s,border-color .2s,background .2s;display:inline-flex;box-shadow:0 12px 24px #00000038}.school-login-submit:hover{background:#252525;border-color:#777;transform:translateY(-1px)}.school-login-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.school-login-register{color:#777;margin-top:24px;font-weight:800;text-decoration:none}.school-login-panel small{color:#565656;margin-top:34px;font-size:.94rem;font-weight:800}.login-alert{text-align:center;background:#ffffff0d;border-radius:12px;width:min(620px,100%);padding:10px 12px;margin:-24px 0 22px!important}.login-alert a{color:#fff;font-weight:900}.school-signup-shell{grid-template-columns:minmax(340px,.58fr) minmax(620px,1fr)}.school-signup-panel{padding-top:44px;padding-bottom:44px}.school-signup-panel .school-login-main-icon{margin-bottom:18px}.school-signup-panel h2{font-size:2.3rem}.school-signup-panel p{margin-bottom:26px}.school-signup-form{grid-template-columns:1fr 1fr;gap:16px;width:min(760px,100%)}.school-signup-field{height:56px}.school-signup-form .school-login-submit{grid-column:1/-1;margin-top:4px}.school-signup-success{gap:18px;width:min(620px,100%);display:grid}.school-signup-success .login-alert{margin:0!important}.form-group{margin-bottom:18px}.form-group label{color:var(--text2);letter-spacing:.04em;margin-bottom:6px;font-size:.82rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background-color:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:.92rem;transition:border .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}.btn{cursor:pointer;-webkit-user-select:none;user-select:none;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 22px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#3a7aef;transform:translateY(-1px)}.btn-primary:active{background:#2d6bd6}.btn-success{background:var(--accent2);color:#0b1a14}.btn-success:hover{background:#2ec99a}.btn-warning{background:var(--accent3);color:#1a0e00}.btn-warning:hover{filter:brightness(.92)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.92)}.btn-ghost{color:var(--text2);border:1px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent)}.btn-ghost:active{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:var(--accent);color:var(--accent)}.btn-full{justify-content:center;width:100%}.error-msg{color:var(--danger);text-align:center;margin-top:10px;font-size:.82rem}.app-layout{--sidebar-offset:240px;min-height:100vh}.app-layout.nav-collapsed{--sidebar-offset:72px}.sidebar{width:var(--sidebar-offset);background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;transition:width .2s,box-shadow .2s;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-start;gap:10px;padding:20px 16px 14px;display:flex;position:relative}.sidebar-brand img{object-fit:contain;background:#fff;border-radius:8px;flex-shrink:0;width:54px;height:54px;padding:3px;display:block}.sidebar-logo-empty{border:1px solid var(--border);background:var(--surface2);width:54px;height:54px;color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-weight:900;display:flex}.sidebar-brand-text{flex:1;min-width:0}.sidebar-brand h2{color:var(--accent);font-family:Playfair Display,serif;font-size:1.2rem}.sidebar-brand p{color:var(--text2);font-size:.72rem}.sidebar-toggle{border:1px solid var(--border);background:var(--surface2);width:32px;height:32px;color:var(--text2);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:1rem;line-height:1;transition:color .15s,border-color .15s;display:inline-flex}.sidebar-toggle:hover{color:var(--accent);border-color:var(--accent)}.sidebar-role{background:var(--surface2);color:var(--accent2);border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;margin:12px;padding:12px 16px;font-size:.78rem;display:grid}.sidebar-profile-photo{border:1px solid var(--border);background:var(--bg);cursor:pointer;width:42px;height:42px;color:var(--text2);border-radius:8px;grid-row:1/span 2;justify-content:center;align-items:center;font-weight:800;display:flex;position:relative;overflow:hidden}.sidebar-profile-photo img{object-fit:cover;width:100%;height:100%;display:block}.sidebar-profile-photo small{background:var(--accent);color:#fff;border-radius:6px 0 7px;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;bottom:0;right:0}.sidebar-profile-photo small svg{width:13px;height:13px}.sidebar-role-name{font-weight:600;display:block}.sidebar-role-detail{color:var(--text2);margin-top:2px;font-size:.7rem;line-height:1.35;display:block}.platform-side-monitor{background:linear-gradient(135deg,#4f8ef71f,#38d9a914);border:1px solid #4f8ef759;border-radius:8px;gap:2px;margin:0 12px 12px;padding:10px 12px;display:grid}.platform-side-monitor span{text-transform:uppercase;letter-spacing:.06em;color:var(--text2);font-size:.68rem;font-weight:800}.platform-side-monitor strong{color:var(--text);font-size:1rem}.platform-side-monitor small{color:var(--text2);font-size:.72rem}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{color:var(--text2);cursor:pointer;border-left:3px solid #0000;align-items:center;gap:12px;padding:11px 20px;font-size:.88rem;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--surface2);color:var(--accent);border-left-color:var(--accent)}.nav-item .icon{color:currentColor;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-item .icon svg{width:20px;height:20px}.nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border);gap:10px;padding:16px 20px;display:grid}.sidebar-footer-short{display:none}.sidebar-footer-label{white-space:nowrap}.main{margin-left:var(--sidebar-offset);width:calc(100% - var(--sidebar-offset));box-sizing:border-box;min-width:0;min-height:100vh;padding:28px 32px;transition:margin-left .2s,width .2s}@media (width>=861px){.sidebar.sidebar-collapsed{z-index:110;box-shadow:4px 0 24px #00000059}.sidebar.sidebar-collapsed .sidebar-brand{flex-direction:column;align-items:center;padding:16px 10px}.sidebar.sidebar-collapsed .sidebar-brand img,.sidebar.sidebar-collapsed .sidebar-logo-empty{width:40px;height:40px;margin:0}.sidebar.sidebar-collapsed .sidebar-brand-text,.sidebar.sidebar-collapsed .sidebar-role-detail,.sidebar.sidebar-collapsed .nav-label,.sidebar.sidebar-collapsed .sidebar-footer-label,.sidebar.sidebar-collapsed .theme-toggle .sidebar-footer-label{display:none}.sidebar.sidebar-collapsed .sidebar-toggle{width:100%;margin:4px 0 0}.sidebar.sidebar-collapsed .sidebar-role{text-align:center;grid-template-columns:1fr;justify-items:center;margin:8px;padding:10px 6px}.sidebar.sidebar-collapsed .sidebar-role-name{text-overflow:ellipsis;white-space:nowrap;font-size:.65rem;overflow:hidden}.sidebar.sidebar-collapsed .platform-side-monitor{text-align:center;margin:8px;padding:8px 4px}.sidebar.sidebar-collapsed .platform-side-monitor span,.sidebar.sidebar-collapsed .platform-side-monitor small{display:none}.sidebar.sidebar-collapsed .nav-item{border-left:none;border-right:3px solid #0000;justify-content:center;padding:12px 10px}.sidebar.sidebar-collapsed .nav-item.active{border-left:none;border-right-color:var(--accent)}.sidebar.sidebar-collapsed .sidebar-footer{padding:12px 8px}.sidebar.sidebar-collapsed .theme-toggle{justify-content:center;padding:9px}.sidebar.sidebar-collapsed .theme-toggle-track{margin:0 auto}.sidebar.sidebar-collapsed .sidebar-footer .btn-full{justify-content:center;padding:9px}.sidebar.sidebar-collapsed .sidebar-footer-short{justify-content:center;align-items:center;display:inline-flex}}.notification-box{background:var(--surface2);border:1px solid var(--border);border-radius:8px;gap:6px;padding:10px;display:grid}.notification-box strong{color:var(--accent2);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}.notification-box>span{color:var(--text2);font-size:.75rem}.notification-item{text-align:left;border:1px solid var(--border);color:var(--text);cursor:pointer;font:inherit;background:0 0;border-radius:7px;gap:2px;padding:7px;display:grid}.notification-item.unread{border-color:var(--accent2);background:#38d9a914}.notification-item.urgent{border-color:var(--danger);background:#f75c5c1a}.notif-severity{color:var(--danger);text-transform:uppercase;margin-left:6px;font-size:.65rem;font-weight:800}.notification-item b{font-size:.76rem}.notification-item small{color:var(--text2);font-size:.68rem;line-height:1.25}.theme-toggle{background:var(--surface2);width:100%;color:var(--text);border:1px solid var(--border);font:inherit;cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;font-size:.84rem;font-weight:700;display:flex}.theme-toggle-track{background:var(--bg);border:1px solid var(--border);border-radius:999px;align-items:center;width:42px;height:22px;padding:2px;transition:background .2s;display:flex}.theme-toggle-thumb{background:var(--accent);border-radius:50%;width:16px;height:16px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}[data-theme=light] .theme-toggle-thumb{background:var(--accent2);transform:translate(18px)}.top-alert-bar{z-index:30;background:linear-gradient(to bottom,var(--bg),#0b0f1adb);justify-content:flex-end;margin:-8px 0 12px;padding:8px 0;display:flex;position:sticky;top:0}[data-theme=light] .top-alert-bar{background:linear-gradient(to bottom,var(--bg),#f4f6fbdb)}.notif-bell{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--text);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:relative}.notif-bell svg{width:22px;height:22px}.notif-count{background:var(--danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:.72rem;font-weight:800;display:inline-flex;position:absolute;top:-5px;right:-4px}.notif-dropdown{background:var(--surface);border:1px solid var(--border);width:min(420px,92vw);max-height:65vh;box-shadow:var(--shadow);z-index:40;border-radius:10px;gap:8px;padding:10px;display:grid;position:absolute;top:56px;right:0;overflow:auto}.notif-title{text-transform:uppercase;color:var(--accent2);font-size:.8rem;font-weight:800}.notif-empty{color:var(--text2);padding:4px 0;font-size:.8rem}.page-header{margin-bottom:28px}.page-header--toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.page-header h1{font-family:Playfair Display,serif;font-size:1.8rem}.page-header p{color:var(--text2);margin-top:4px;font-size:.88rem}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:.12;border-radius:50%;width:80px;height:80px;position:absolute;top:-20px;right:-20px}.stat-card.blue:before{background:var(--accent)}.stat-card.green:before{background:var(--accent2)}.stat-card.orange:before{background:var(--accent3)}.stat-card.red:before{background:var(--danger)}.stat-card .label{color:var(--text2);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;font-size:.75rem}.stat-card .value{font-size:2rem;font-weight:700;line-height:1}.stat-card .sub{color:var(--text2);margin-top:6px;font-size:.76rem}.stat-card.blue .value{color:var(--accent)}.stat-card.green .value{color:var(--accent2)}.stat-card.orange .value{color:var(--accent3)}.stat-card.red .value{color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;overflow-x:auto}.card+.card,.card+form.card,form.card+.card,.collapsible-section+.collapsible-section,.collapsible-section+form.card,form.card+.collapsible-section{margin-top:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-header h3{font-size:1rem;font-weight:600}.collapsible-section{padding:0;overflow:visible}.collapsible-section.is-collapsed .collapsible-header{margin-bottom:0}.collapsible-header{width:100%;color:inherit;text-align:left;cursor:pointer;border-radius:var(--radius);background:0 0;border:0;justify-content:space-between;align-items:center;gap:12px;margin:0;padding:20px 24px;display:flex}.collapsible-header:hover{background:var(--surface2)}.collapsible-header-text{flex:1;min-width:0}.collapsible-header h3{margin:0;font-size:1rem;font-weight:600}.collapsible-summary{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:.82rem;font-weight:400;display:block;overflow:hidden}.collapsible-chevron{color:var(--text2);text-align:center;flex-shrink:0;width:1.25rem;font-size:.7rem}.collapsible-body{padding:0 24px 24px}.collapsible-body>.stats-grid:first-child{margin-top:0;margin-bottom:0}.dashboard-table-wrap{overscroll-behavior:contain;border:1px solid var(--border);border-radius:8px;max-height:min(65vh,560px);overflow:auto}.dashboard-table-wrap table{min-width:640px;margin:0}.dashboard-toolbar{flex-wrap:wrap;gap:8px;margin-left:auto;display:flex}.page-header .dashboard-toolbar .btn{padding:6px 12px;font-size:.8rem}table{border-collapse:collapse;width:100%;font-size:.875rem}:is(.card:has(>table),.card:has(.data-table),.scores-table-wrapper,.report-display:has(table),.sms-campaigns){overscroll-behavior:contain;max-height:72vh;overflow:auto}.scores-table,.report-table,.broadsheet-table,.data-table{min-width:780px}.card:has(>table) table{min-width:780px}.card:has(.data-table) table{min-width:780px}thead th{text-align:left;color:var(--text2);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border);padding:10px 14px;font-size:.75rem}tbody tr{border-bottom:1px solid var(--border);transition:background .15s}tbody tr:hover{background:var(--surface2)}tbody td{vertical-align:middle;padding:11px 14px}.badge{border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.badge-remove{color:inherit;font:inherit;cursor:pointer;background:0 0;border:0;margin-left:8px;font-weight:900;line-height:1}.badge-green{color:var(--accent2);background:#1a3a2d}.badge-blue{color:var(--accent);background:#1a2a4a}.badge-orange{color:var(--accent3);background:#3a2a10}.badge-red{color:var(--danger);background:#3a1a1a}.badge-gray{background:var(--surface2);color:var(--text2)}[data-theme=light] .badge-green{color:#07684c;background:#dff5ec}[data-theme=light] .badge-blue{color:#174f9b;background:#e2ecfb}[data-theme=light] .badge-orange{color:#984a0d;background:#fff0dc}[data-theme=light] .badge-red{color:#a62b2b;background:#fde6e6}.modal-overlay{z-index:999;background:#000000b3;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1px solid var(--border);width:500px;max-width:95vw;max-height:90vh;box-shadow:var(--shadow);border-radius:16px;padding:32px;overflow-y:auto}.modal h2{margin-bottom:20px;font-family:Playfair Display,serif;font-size:1.4rem}.modal-footer{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.two-col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:8px;gap:6px;margin-bottom:20px;padding:6px;display:flex;overflow:auto hidden;box-shadow:0 4px 18px #0000001f}.tab{cursor:pointer;color:var(--text2);white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:7px;padding:9px 16px;font-size:.84rem;font-weight:800;transition:all .2s}.tab:hover{background:var(--surface2);color:var(--text)}.tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.search-bar{gap:10px;margin-bottom:18px;display:flex}.search-bar input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:9px 14px;font-family:inherit}.search-bar input:focus{border-color:var(--accent)}.timetable{border-collapse:collapse;width:100%;font-size:.8rem}.timetable th{background:var(--surface2);border:1px solid var(--border);text-align:center;padding:10px}.timetable td{border:1px solid var(--border);text-align:center;min-height:48px;padding:8px}.timetable-scroll{max-width:100%;overflow-x:auto}.timetable-scroll .timetable{min-width:980px}.tt-slot{background:var(--surface2);cursor:default;border-radius:6px;padding:4px 6px;font-size:.72rem}.tt-slot.math{color:var(--accent);background:#1a2a4a}.tt-slot.english{color:var(--accent2);background:#1a3a2d}.tt-slot.science{color:var(--accent3);background:#3a2a10}.tt-slot.history{color:#c084fc;background:#2a1a3a}.tt-slot.pe{color:#67e8f9;background:#1a3a3a}.tt-slot.art{color:#f9a8d4;background:#3a1a2a}.tt-slot.ict{color:#fde68a;background:#3a3a1a}.tt-slot.break{background:var(--surface);color:var(--text2);font-style:italic}.tt-span-col{vertical-align:middle;background:var(--surface);width:54px;padding:6px 4px}.tt-vertical{writing-mode:vertical-rl;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;color:var(--text2);font-size:.68rem;font-weight:700;display:inline-block;transform:rotate(180deg)}.timetable th{white-space:nowrap}.timetable td{min-width:110px}.teacher-schedule-card{padding-bottom:0}.teacher-schedule-list{margin:0;padding:0 16px 8px;list-style:none}.teacher-schedule-day{border-bottom:1px solid var(--border);align-items:flex-start;gap:14px;padding:14px 0;display:flex}.teacher-schedule-day:last-child{border-bottom:none}.teacher-schedule-day-name{text-transform:capitalize;min-width:88px;color:var(--accent);flex-shrink:0;font-size:.95rem;font-weight:800}.teacher-schedule-day-body{flex:1;min-width:0}.teacher-schedule-summary{margin:0;font-size:.95rem;line-height:1.5}.teacher-schedule-summary strong{color:var(--text);margin-right:4px}.teacher-schedule-actions{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.teacher-week-grid{gap:14px;padding:0 16px 16px;display:grid}.teacher-day-card{border:1px solid var(--border);background:var(--surface2);border-radius:10px;overflow:hidden}.teacher-day-card-head{background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;font-size:.95rem;font-weight:800}.teacher-lesson-rows{gap:0;display:grid}.teacher-lesson-row{border-top:1px solid var(--border);grid-template-columns:72px 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.teacher-lesson-row:first-child{border-top:none}.teacher-lesson-period{color:var(--accent);font-size:.85rem;font-weight:800;line-height:1.3}.teacher-lesson-period small{color:var(--text2);margin-top:2px;font-size:.72rem;font-weight:500;display:block}.teacher-lesson-subject{font-size:.95rem;font-weight:700}.teacher-lesson-class{color:var(--text2);margin-top:2px;font-size:.82rem}.teacher-schedule-legend{color:var(--text2);border-top:1px solid var(--border);margin-top:4px;padding:12px 16px 16px;font-size:.8rem;line-height:1.5}.tt-mine-badge{background:var(--accent);color:#fff;border-radius:4px;margin-left:4px;padding:1px 5px;font-size:.6rem;display:inline-block}.att-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.att-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:14px;display:flex}.att-card .name{font-size:.88rem;font-weight:500}.att-card .idx{color:var(--text2);font-size:.72rem}.att-toggle{gap:6px;display:flex}.att-btn{cursor:pointer;border:none;border-radius:6px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:all .15s}.att-btn.present{color:var(--accent2);background:#1a3a2d}.att-btn.present.sel{background:var(--accent2);color:#0b1a14}.att-btn.absent{color:var(--danger);background:#3a1a1a}.att-btn.absent.sel{background:var(--danger);color:#fff}.att-report-table{font-size:.75rem}.att-report-table th{white-space:nowrap}.att-dot-P{background:var(--accent2);color:#0b1a14;border-radius:4px;padding:1px 5px;font-size:.7rem;font-weight:700;display:inline-block}.att-dot-A{background:var(--danger);color:#fff;border-radius:4px;padding:1px 5px;font-size:.7rem;font-weight:700;display:inline-block}.att-dot-empty{color:var(--border)}.progress-bar{background:var(--surface2);border-radius:3px;height:6px;margin-top:8px}.progress-fill{background:var(--accent2);border-radius:3px;height:100%;transition:width .5s}.grade-cell{font-weight:700}.grade-A{color:var(--accent2)}.grade-B{color:var(--accent)}.grade-C,.grade-D{color:var(--accent3)}.grade-F{color:var(--danger)}.loader{color:var(--text2);justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#toast{background:var(--surface2);border:1px solid var(--accent2);color:var(--accent2);z-index:9999;opacity:0;border-radius:10px;padding:12px 22px;font-size:.88rem;transition:all .3s;position:fixed;bottom:28px;right:28px;transform:translateY(80px)}#toast.show{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.hidden{display:none!important}.flex-gap{flex-wrap:wrap;gap:10px;display:flex}.mt-16{margin-top:16px}.text-small{color:var(--text2);font-size:.78rem}.avatar{background:var(--surface2);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:inline-flex}.teacher-thumb{object-fit:cover;border:1px solid var(--border);background:var(--bg);border-radius:6px;width:38px;height:44px;display:block}.teacher-name-cell{align-items:center;gap:10px;display:flex}.teacher-thumb-sm{object-fit:cover;border:1px solid var(--border);background:var(--bg);border-radius:50%;flex-shrink:0;width:32px;height:32px}.teacher-thumb-placeholder{background:var(--surface2);color:var(--text2);justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:inline-flex}.teacher-assignment-cell{text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.teachers-table-card .dashboard-table-wrap{max-height:min(70vh,640px)}.teachers-table{min-width:520px}.sidebar-footer-short svg{width:18px;height:18px}.teacher-photo-preview{object-fit:cover;border:1px solid var(--border);background:var(--bg);border-radius:8px;width:86px!important;height:104px!important}.attendance-entry-table th:nth-child(3),.attendance-entry-table th:nth-child(4),.attendance-entry-table td:nth-child(3),.attendance-entry-table td:nth-child(4){text-align:center;width:92px}.attendance-entry-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent2);cursor:pointer}.cell-input,.cell-select{background:var(--bg);border:1px solid var(--border);width:100%;min-width:96px;color:var(--text);border-radius:6px;padding:7px 9px;font-family:inherit}.settings-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.settings-wide{grid-column:1/-1}.settings-term{border:1px solid var(--border);background:var(--surface2);border-radius:8px;margin-bottom:14px;padding:14px}.settings-term strong{color:var(--accent);margin-bottom:12px;display:block}.wide-modal{width:min(980px,96vw)}.receipt-modal{width:min(720px,96vw)}.receipt-card{color:#111;background:#fff;border-bottom:3px solid #111;border-left:3px dashed #111;padding:16px 18px 26px;font-family:Times New Roman,serif}.receipt-title{text-align:center;justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.receipt-title img{object-fit:contain;width:42px;height:42px}.receipt-title h3{color:#fff;text-transform:uppercase;background:#111;padding:2px 5px;font-size:1rem;display:inline}.receipt-row{justify-content:space-between;align-items:center;margin:12px 0;font-weight:700;display:flex}.receipt-row span{color:#fff;background:#111;padding:2px 5px;font-style:italic}.receipt-card p{border-bottom:2px dotted #111;padding:7px 0;font-weight:700}.receipt-card table{color:#111;margin-top:12px;font-size:.9rem}.receipt-card th,.receipt-card td{color:#111;text-transform:uppercase;border:2px solid #111;padding:5px 8px}.receipt-sign{justify-content:space-between;margin-top:30px;font-weight:700;display:flex}.finance-print{color:#111;background:#fff;padding:18px}.finance-stats{grid-template-columns:repeat(3,1fr)}.fee-summary-box{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;gap:8px;margin:10px 0 16px;padding:12px;display:grid}.flag-list{gap:16px;display:grid}.flag-card p{line-height:1.45}.focus-card{outline:2px solid var(--accent3);box-shadow:0 0 0 4px #f7a84f2e}.flag-followups{gap:8px;margin-top:14px;display:grid}.flag-followup{background:var(--surface2);border:1px solid var(--border);border-radius:8px;gap:3px;padding:10px;display:grid}.flag-followup span{color:var(--text)}.flag-followup em{color:var(--accent2);text-transform:uppercase;font-size:.74rem;font-style:normal;font-weight:800}.lesson-material-form{margin-bottom:20px}.lesson-review-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.lesson-review-actions input{background:var(--bg);border:1px solid var(--border);min-width:160px;color:var(--text);border-radius:6px;flex:1;padding:7px 9px;font-family:inherit}.privilege-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-top:8px;display:grid}.privilege-check{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:9px 10px;color:var(--text)!important;letter-spacing:0!important;display:flex!important}.privilege-check input{width:16px;height:16px;accent-color:var(--accent2);flex-shrink:0}.role-checkbox{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:.9rem;display:flex}.role-checkbox input{width:16px;height:16px;accent-color:var(--accent2);cursor:pointer;flex-shrink:0}.ops-form{margin-bottom:20px}.ops-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px 16px;display:grid}.ops-grid .form-group{margin-bottom:0}.ops-search{border-radius:8px;width:min(320px,100%);background-color:var(--bg)!important;border:1px solid var(--border)!important;color:var(--text)!important;padding-top:10px!important;padding-bottom:10px!important}.btn-xs{border-radius:6px!important;padding:6px 10px!important;font-size:.75rem!important}.exam-attendance-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent2);cursor:pointer}.id-card-sheet{grid-template-columns:repeat(auto-fill,minmax(344px,1fr));align-items:start;gap:20px;display:grid}.id-card-pair{flex-direction:column;align-items:center;gap:12px;display:flex}.ic{color:#161a22;background:#fff;border-radius:9px;width:86mm;height:54mm;font-family:Arial,Helvetica,sans-serif;position:relative;overflow:hidden;box-shadow:0 10px 26px #0000002e}.ic-front{background:linear-gradient(90deg,#12837614,#ffffffb8 42%,#eeb2471f),#fff;border:1px solid #cfd6df;flex-direction:column;display:flex}.ic-front:after{content:"";clip-path:polygon(28% 0,100% 0,100% 100%,0 100%);pointer-events:none;background:linear-gradient(#1045541a,#eeb2472e);width:36%;height:100%;position:absolute;top:0;right:0}.ic-top{z-index:1;grid-template-columns:19mm 1fr;align-items:center;gap:3mm;padding:3.1mm 4mm 1.6mm;display:grid;position:relative}.ic-logo{color:#104554;text-align:center;background:#ffffffe0;border:1.2px solid #128376;border-radius:4px;justify-content:center;align-items:center;width:16mm;height:16mm;font-size:10px;font-weight:900;line-height:1.05;display:flex;overflow:hidden}.ic-logo img{object-fit:contain;width:100%;height:100%;padding:1mm}.ic-school{text-transform:uppercase;color:#104554;min-width:0}.ic-school strong{letter-spacing:0;font-size:10.4px;font-weight:900;line-height:1.1;display:block}.ic-school span{color:#55606b;margin-top:1mm;font-size:6.3px;font-weight:700;line-height:1.15;display:block}.ic-title{color:#fff;text-align:center;text-transform:uppercase;letter-spacing:.4px;background:#26323f;border-radius:999px;align-self:center;min-width:45mm;margin:.2mm 0 2mm;padding:1.2mm 7mm;font-size:8.4px;font-weight:900;box-shadow:0 1px #eeb247cc}.ic-main{z-index:1;flex:1;grid-template-columns:1fr 24mm;align-items:start;gap:3.5mm;padding:0 4mm 2mm;display:grid;position:relative}.ic-details{gap:1.7mm;min-width:0;padding-top:1mm;display:grid}.ic-row{grid-template-columns:21mm 1fr;align-items:baseline;gap:2mm;min-width:0;display:grid}.ic-label{color:#128376;text-transform:uppercase;font-size:7px;font-weight:900;line-height:1.05}.ic-value{color:#1d2430;text-transform:uppercase;word-break:break-word;font-size:8px;font-weight:800;line-height:1.08}.ic-row:first-child .ic-value{color:#101820;font-size:9.5px}.ic-photo{color:#104554;background:#eef3f6;border:1.2px solid #128376;justify-content:center;align-items:center;width:24mm;height:29mm;font-size:24px;font-weight:900;display:flex;overflow:hidden}.ic-photo img{object-fit:cover;width:100%;height:100%}.ic-front-footer{z-index:1;color:#fff;background:#104554;grid-template-columns:1fr 32mm;align-items:stretch;height:8.5mm;display:grid;position:relative}.ic-signature{background:linear-gradient(90deg,#104554,#128376);align-items:center;gap:3mm;padding:0 4mm;display:flex}.ic-signature span{text-transform:uppercase;font-size:6.4px;font-weight:900}.ic-signature b{color:#0000;border-bottom:1.4px solid #ffffffe6;min-width:22mm;height:4.5mm;font-size:0;display:block}.ic-number{color:#16202a;text-align:center;background:#eeb247;flex-direction:column;justify-content:center;align-items:center;display:flex}.ic-number span{text-transform:uppercase;font-size:5.8px;font-weight:900;line-height:1}.ic-number strong{white-space:nowrap;font-size:10px;font-weight:900;line-height:1.1}.ic-back{background:#f8fafb;border:1px solid #cfd6df}.ic-back-band{background:#26323f;height:10mm}.ic-back-body{grid-template-rows:1fr auto 12mm;grid-template-columns:1fr 37mm;gap:2.2mm 4mm;height:44mm;padding:3.2mm 4mm 3mm;display:grid}.ic-back-copy{color:#1d2430;min-width:0;font-size:7.2px;line-height:1.13}.ic-back-copy p{text-align:justify;margin:0 0 1.8mm}.ic-back-copy strong,.ic-back-copy span{line-height:1.1;display:block}.ic-return{text-transform:uppercase;font-weight:900;text-decoration:underline}.ic-issuer{text-align:center;color:#26323f;background:#fff;border:1px solid #9aa6b2;flex-direction:column;justify-content:center;align-items:center;padding:2mm;display:flex}.ic-issuer span{font-size:7px;font-style:italic;font-weight:700}.ic-issuer strong{text-transform:uppercase;font-size:7.5px;line-height:1.08}.ic-issuer small{color:#66717c;font-size:6px}.ic-dates{text-align:center;text-transform:uppercase;grid-column:2;grid-template-columns:1fr 1fr;gap:3mm;display:grid}.ic-dates span{color:#26323f;border-bottom:1px solid #26323f;font-size:5.8px;font-weight:900;display:block}.ic-dates strong{color:#1d2430;margin-top:.8mm;font-size:7px;display:block}.ic-barcode{background:repeating-linear-gradient(90deg,#101820 0 1px,#fff 1px 2px,#101820 2px 4px,#fff 4px 6px,#101820 6px 7px,#fff 7px 10px);grid-column:2;justify-content:center;align-items:flex-end;height:11mm;padding-bottom:.8mm;display:flex;overflow:hidden}.ic-barcode span{color:#101820;background:#ffffffd1;padding:0 1mm;font-family:monospace;font-size:5.4px;font-weight:900}.reset-auth-page{padding:18px}.reset-auth-panel{border-radius:18px;width:min(560px,94vw);min-height:auto;margin:0;padding:54px 42px}.reset-auth-panel form{gap:18px;width:min(420px,100%);display:grid}@media (width<=1100px){.main{padding:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.card{overflow-x:auto}table{min-width:720px}.att-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.report-sheet{max-width:100%;overflow-x:auto}.report-star-border{min-width:820px}.school-login-shell{grid-template-columns:1fr;width:min(720px,94vw)}.school-signup-shell{grid-template-columns:1fr;width:min(760px,94vw)}.school-login-welcome{clip-path:none;border-radius:18px 18px 0 0;min-height:280px}.school-login-welcome-inner{padding:42px}.school-login-side-icon{margin-bottom:34px}.school-login-panel{border-radius:0 0 18px 18px;min-height:auto;margin:0;padding:48px 38px}.school-signup-panel{padding:42px 34px}}@media (width<=860px){.app-layout{--sidebar-offset:0;display:block}.sidebar-toggle{display:none}.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;height:auto;position:static}.sidebar-brand{padding:16px 18px 10px}.sidebar-brand h2{font-size:1.1rem}.sidebar-role{margin:10px 12px;padding:10px 14px}.sidebar-nav{scroll-snap-type:x proximity;gap:6px;padding:8px 12px 12px;display:flex;overflow-x:auto}.nav-item{scroll-snap-align:start;border-bottom:3px solid #0000;border-left:none;border-radius:8px;flex:none;padding:9px 12px}.nav-item.active{border-left-color:#0000;border-bottom-color:var(--accent)}.nav-item .icon{width:auto}.sidebar-footer{border-top:1px solid var(--border);padding:10px 12px 14px}.theme-toggle{max-width:260px}.main{width:100%;margin-left:0;padding:22px 16px}.page-header{margin-bottom:20px}.page-header h1{font-size:1.55rem}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stat-card{padding:16px}.stat-card .value{font-size:1.55rem}.search-bar{flex-direction:column}.search-bar .btn{justify-content:center;width:100%}.flex-gap{gap:8px}.flex-gap>.form-group{min-width:calc(50% - 8px)}.tabs{max-width:100%;overflow-x:auto}.tab{white-space:nowrap;padding:7px 14px}.modal{width:calc(100vw - 28px);max-height:86vh;padding:22px}.two-col,.settings-grid{grid-template-columns:1fr}.login-card{border-radius:14px;width:min(400px,100vw - 32px);padding:36px 26px}.school-login-page{padding:14px}.school-login-shell{width:100%}.school-login-welcome{min-height:230px}.school-login-welcome h1{font-size:1.8rem}.school-login-rule{margin-bottom:24px}.school-login-side-icon{width:62px;height:62px;margin-bottom:26px}.school-login-socials span{width:40px;height:40px}.school-login-panel{padding:38px 20px}.school-login-panel h2{font-size:2rem}.school-login-panel p{margin-bottom:28px}.school-login-options{flex-direction:column;align-items:flex-start;margin:0 4px 18px}.school-login-submit{width:100%}.school-signup-form{grid-template-columns:1fr}.school-signup-form .school-login-submit{grid-column:auto}}@media (width<=768px){body{font-size:16px}}@media (width<=560px){body{font-size:15px}.main{padding:18px 12px}.sidebar-brand{justify-content:space-between;align-items:center;gap:12px;display:flex}.sidebar-brand img,.sidebar-logo-empty{width:38px;height:38px;margin:0}.sidebar-brand p{display:none}.sidebar-role{font-size:.74rem}.nav-item{gap:7px;padding:8px 10px;font-size:.78rem}.nav-item .icon{font-size:1rem}.btn{justify-content:center;width:100%;padding:10px 14px}.stats-grid{grid-template-columns:1fr}.card{border-radius:10px;padding:16px}.card-header{flex-direction:column;align-items:flex-start;gap:10px}.card-header .btn{width:100%}.form-group input,.form-group select,.form-group textarea{font-size:16px}.flex-gap{flex-direction:column;align-items:stretch!important}.flex-gap>.form-group{width:100%;min-width:100%}.att-card{flex-direction:column;align-items:flex-start;gap:12px}.att-toggle{width:100%}.att-btn{flex:1}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}#toast{text-align:center;bottom:16px;left:12px;right:12px}.report-sheet{margin:0 -4px 24px;padding:8px}.report-star-border{min-width:760px;padding:12px}}.report-sheet{color:#111;background:#fff;border-radius:0;max-width:210mm;margin:0 auto 32px;padding:10px;font-family:Arial,Helvetica,sans-serif}.report-star-border{background:linear-gradient(#ffffffeb,#ffffffeb);border:8px dotted #0b6da5;padding:12px 14px 16px;position:relative}.report-header{text-align:center;grid-template-columns:120px 1fr 120px;align-items:center;gap:18px;display:grid}.report-logo-slot{justify-content:center;align-items:center;width:94px;height:94px;margin:auto;display:flex}.report-logo-img{object-fit:contain;width:94px;height:94px;margin:auto}.report-logo-img.seal{border-radius:50%}.report-photo-frame{color:#777;text-transform:uppercase;text-align:center;background:#fff;border:2px solid #111;justify-content:center;align-items:center;width:94px;height:108px;margin:auto;font-size:.68rem;font-weight:800;display:flex;overflow:hidden}.report-photo-frame img{object-fit:cover;width:100%;height:100%;display:block}.report-logo{color:#0b6da5;background:#f5d04c;border:4px solid #0b6da5;justify-content:center;align-items:center;width:94px;height:94px;margin:auto;font-weight:800;display:flex}.report-logo.shield{border-radius:18px 18px 34px 34px}.report-logo.seal{border-radius:50%}.report-title h2{color:#0b6da5;text-transform:uppercase;letter-spacing:1px;text-shadow:1px 1px #d7e8f5;margin:4px 0;font-family:Georgia,serif;font-size:1.65rem}.report-kicker{color:#c6252a;text-transform:uppercase;font-size:1.05rem;font-weight:800}.report-motto{letter-spacing:3px;text-transform:uppercase;font-size:.76rem;font-weight:800}.report-contact{color:#c6252a;margin-top:8px;font-weight:700}.report-email{color:#0b6da5;text-transform:uppercase;margin-top:4px;font-weight:800}.report-term-row{text-transform:uppercase;grid-template-columns:170px 1fr;align-items:end;margin:10px 0 4px;font-weight:800;display:grid}.report-term-row strong{color:#c6252a;font-size:1.1rem}.report-term-row span{text-align:center;color:#0b6da5;font-size:1.55rem;text-decoration:underline}.report-meta-grid{text-transform:uppercase;grid-template-columns:1.25fr .9fr;gap:16px;font-size:.92rem;font-weight:700;display:grid}.report-meta-grid p{margin:5px 0}.report-date-box{border:2px solid #111}.report-date-box p{border-bottom:2px solid #111;margin:0;padding:7px 10px}.report-date-box p:last-child{border-bottom:none}.report-strip{text-transform:uppercase;border:2px solid #111;grid-template-columns:1fr 1fr 1fr 1.4fr;margin:8px 0 0;font-size:.92rem;font-weight:800;display:grid}.report-strip span{text-align:center;border-right:2px solid #111;padding:6px 10px}.report-strip span:last-child{border-right:none}.report-main-table,.report-info-table,.report-grade-table{border-collapse:collapse;color:#111;width:100%;font-size:.78rem}.report-main-table th,.report-main-table td,.report-info-table th,.report-info-table td,.report-grade-table th,.report-grade-table td{color:#111;border:2px solid #111;padding:4px 6px}.report-main-table th{text-transform:uppercase;text-align:center;background:#e8f4ff;font-weight:900}.report-main-table td{text-align:center;background:#fffde8}.report-main-table td:first-child{text-align:left;text-transform:uppercase;background:#fff;font-weight:800}.report-total-row td{text-transform:uppercase;font-weight:900;background:#f7f7f7!important}.report-lower-grid{grid-template-columns:1.1fr 1fr;gap:0;margin-top:18px;display:grid}.report-info-table th{text-align:left;text-transform:uppercase;background:#fff;width:42%}.report-info-table td{text-align:center;text-transform:uppercase;background:#fffde8;font-weight:800}.report-info-table .arrears{color:#c6252a;font-size:1rem}.report-footer-grid{grid-template-columns:1fr 230px;align-items:start;gap:16px;margin-top:16px;display:grid}.report-grade-table{font-size:.74rem}.report-grade-table th{color:#c6252a;text-transform:uppercase;background:#fff}.report-grade-table td:first-child,.report-grade-table td:nth-child(2),.report-grade-table td:nth-child(3){text-align:center;font-weight:800}.report-stamp{text-align:center;text-transform:uppercase;color:#c6252a;border:2px solid #111;min-height:118px;padding:10px;font-weight:800}.stamp-box{color:#245a9b;background:#f2f2f2;border:1px solid #bbb;margin-top:10px;padding:18px 8px;font-family:Georgia,serif;font-style:italic}.report-slogan{text-align:left;color:#c6252a;text-transform:uppercase;letter-spacing:5px;margin-top:14px;font-style:italic;font-weight:900}@media print{@page{size:A4 portrait;margin:6mm}html,body,#root{width:198mm;min-height:auto;overflow:visible!important}body{color:#111!important;background:#fff!important}body *{visibility:hidden!important}.main{margin:0;padding:0}.app-layout{min-height:auto;display:block}.print-area,.print-area *{visibility:visible!important}.print-area{color:#111!important;width:100%!important;box-shadow:none!important;background:#fff!important;border:none!important;padding:0!important;position:absolute!important;top:0!important;left:0!important}.print-area .card{color:#111!important;background:#fff!important;border:1px solid #ccc!important}.print-area table{color:#111;font-size:11px}.print-area th,.print-area td{padding:6px 8px;color:#111!important;border:1px solid #ccc!important}.badge{border:1px solid #999;color:#111!important;background:#fff!important}.report-sheet{break-inside:avoid;page-break-inside:avoid;page-break-after:always;width:186mm;max-width:none;margin:0 auto;padding:0;overflow:visible}.report-sheet:last-child{page-break-after:auto}.report-star-border{border-width:4px;border-color:#0b6da5;width:100%;padding:9px 10px 11px;min-width:0!important}.report-logo-slot,.report-logo-img{width:76px;height:76px}.report-photo-frame{border-width:1px;width:76px;height:88px;font-size:9px}.report-header{grid-template-columns:86px 1fr 86px;gap:10px}.report-title h2{text-shadow:none;letter-spacing:.4px;margin:2px 0;font-size:22px;line-height:1.08}.report-kicker{font-size:14px}.report-motto{letter-spacing:1px;font-size:10px}.report-contact,.report-email{margin-top:2px;font-size:10px}.report-term-row{grid-template-columns:126px 1fr;margin:5px 0 4px}.report-term-row strong{font-size:14px}.report-term-row span{font-size:17px}.report-meta-grid{gap:12px;font-size:11px}.report-meta-grid p{margin:4px 0}.report-date-box p{padding:5px 7px}.report-strip{margin-top:6px;font-size:10.5px}.report-strip span{padding:5px 6px}.report-main-table,.report-info-table,.report-grade-table{table-layout:fixed;font-size:9.8px;line-height:1.18;min-width:0!important}.report-main-table th,.report-main-table td,.report-info-table th,.report-info-table td{padding:3.5px 4px}.report-main-table th:nth-child(9),.report-main-table td:nth-child(9){display:table-cell}.report-main-table th:first-child,.report-main-table td:first-child{width:19%}.report-main-table th:nth-child(2),.report-main-table td:nth-child(2),.report-main-table th:nth-child(3),.report-main-table td:nth-child(3),.report-main-table th:nth-child(4),.report-main-table td:nth-child(4),.report-main-table th:nth-child(5),.report-main-table td:nth-child(5){width:9%}.report-main-table th:nth-child(6),.report-main-table td:nth-child(6){width:11%}.report-main-table th:nth-child(7),.report-main-table td:nth-child(7){width:7%}.report-main-table th:nth-child(8),.report-main-table td:nth-child(8){word-break:break-word;width:18%}.report-main-table th:nth-child(9),.report-main-table td:nth-child(9){width:9%}.report-lower-grid{margin-top:7px}.report-footer-grid{grid-template-columns:1fr 210px;gap:12px;margin-top:8px;display:grid}.report-stamp{min-height:82px;padding:7px;font-size:10px}.stamp-box{margin-top:6px;padding:10px 4px}.report-slogan{letter-spacing:2px;margin-top:7px;font-size:10px}.receipt-modal,.wide-modal{width:auto;max-width:none;box-shadow:none;border:none;padding:0}.receipt-card{width:180mm;margin:0 auto}.finance-print{padding:0}.finance-stats{display:none}.id-card-sheet{grid-template-columns:repeat(2,86mm);align-items:start;gap:5mm;padding:0!important;display:grid!important}.id-card-pair{break-inside:avoid;gap:3mm}.ic{box-shadow:none;-webkit-print-color-adjust:exact;print-color-adjust:exact;overflow:hidden}}select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238892b0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:16px;background-color:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:.92rem;transition:border-color .2s,box-shadow .2s,background-color .2s;padding-right:40px!important}select:hover{border-color:var(--text3,#a0aec0);background-color:color-mix(in srgb, var(--accent) 3%, transparent)}select:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);border-color:var(--accent)!important}select option{background:var(--surface);color:var(--text)}[data-theme=light] select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235e687a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}input[type=search],.search-bar input,input.search-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238892b0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-position:14px;background-repeat:no-repeat;background-size:16px;transition:border-color .2s,box-shadow .2s,background-color .2s;padding-left:40px!important}input[type=search]:focus,.search-bar input:focus,input.search-input:focus{box-shadow:0 0 0 3px #4f8ef740;border-color:var(--accent)!important}[data-theme=light] input[type=search],[data-theme=light] .search-bar input,[data-theme=light] input.search-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235e687a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E")}.cell-select{background-position:right 8px center!important;background-size:12px!important;padding-right:28px!important}.cell-input{transition:border-color .2s,box-shadow .2s}.cell-input:focus{box-shadow:0 0 0 2px #4f8ef726;border-color:var(--accent)!important}:root{--saas-green:#1d9e75;--saas-purple:#534ab7;--saas-amber:#e5a017;--saas-red:#d64545;--saas-blue:#3b82f6}.saas-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.saas-page-header h1{margin:0}.saas-page-header p{color:var(--text2);margin:4px 0 0}.stats-grid-4{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}@media (width<=900px){.stats-grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=520px){.stats-grid-4{grid-template-columns:1fr}}.stat-card-saas{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.stat-card-saas .label{text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin-bottom:6px;font-size:.72rem}.stat-card-saas .value{font-size:1.85rem;font-weight:700;line-height:1.1}.stat-card-saas .sub{color:var(--text2);margin-top:6px;font-size:.76rem}.stat-card-saas.green .value{color:var(--saas-green)}.stat-card-saas.blue .value{color:var(--saas-blue)}.stat-card-saas.amber .value{color:var(--saas-amber)}.stat-card-saas.red .value{color:var(--saas-red)}.saas-two-col{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=860px){.saas-two-col{grid-template-columns:1fr}}.saas-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.saas-card+.saas-card{margin-top:0}.saas-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.saas-card-header h3{margin:0;font-size:1rem;font-weight:600}.status-pill{text-transform:capitalize;border-radius:999px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.status-pill.green{color:var(--saas-green);background:#1d9e7526}.status-pill.amber{color:var(--saas-amber);background:#e5a01726}.status-pill.red{color:var(--saas-red);background:#d6454526}.status-pill.blue{color:var(--saas-blue);background:#3b82f626}.status-pill.gray{color:var(--text2);background:#80808026}.status-pill.purple{color:var(--saas-purple);background:#534ab726}.saas-toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.saas-toggle-row:last-child{border-bottom:none}.saas-toggle{flex-shrink:0;width:44px;height:24px;position:relative}.saas-toggle input{opacity:0;width:0;height:0;position:absolute}.saas-toggle-track{cursor:pointer;background:#888;border-radius:999px;width:44px;height:24px;transition:background .2s;display:block}.saas-toggle input:checked+.saas-toggle-track{background:var(--saas-green)}.saas-toggle-thumb{pointer-events:none;background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px}.saas-toggle input:checked~.saas-toggle-thumb{transform:translate(20px)}.bar-chart{align-items:flex-end;gap:10px;height:180px;padding:12px 0 8px;display:flex}.bar-chart-col{flex-direction:column;flex:1;align-items:center;gap:6px;min-width:0;display:flex}.bar-chart-bar-wrap{justify-content:center;align-items:flex-end;width:100%;height:140px;display:flex}.bar-chart-bar{border-radius:4px 4px 0 0;width:70%;max-width:48px;min-height:4px;transition:height .3s}.bar-chart-bar.ok{background:var(--saas-green)}.bar-chart-bar.warn{background:var(--saas-amber)}.bar-chart-label{color:var(--text2);text-align:center;word-break:break-word;font-size:.68rem}.bar-chart-val{font-size:.72rem;font-weight:600}.donut-wrap{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.donut-svg{flex-shrink:0;width:140px;height:140px}.donut-legend{flex:1;min-width:180px}.donut-legend-row{align-items:center;gap:8px;margin-bottom:8px;font-size:.82rem;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.fees-trend{align-items:flex-end;gap:8px;height:120px;padding-top:8px;display:flex}.fees-trend-bar{background:linear-gradient(180deg, var(--saas-blue), #3b82f666);border-radius:3px 3px 0 0;flex:1;min-height:4px}.fees-trend-label{color:var(--text2);text-align:center;margin-top:4px;font-size:.65rem}.audit-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.audit-row.compact{padding:10px 0}.audit-icon{color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.75rem;font-weight:700;display:flex}.audit-icon.purple{background:var(--saas-purple)}.audit-icon.green{background:var(--saas-green)}.audit-icon.red{background:var(--saas-red)}.audit-icon.blue{background:var(--saas-blue)}.audit-icon.amber{background:var(--saas-amber)}.audit-body{flex:1;min-width:0}.audit-body strong{margin-bottom:2px;font-size:.88rem;display:block}.audit-meta{color:var(--text2);font-size:.74rem}.audit-toolbar{grid-template-columns:minmax(260px,1fr) 190px 170px;align-items:center;gap:10px;display:grid}.audit-search{min-width:0}.audit-toolbar input,.audit-toolbar select{background-color:var(--surface);border:1px solid var(--border);height:42px;color:var(--text);border-radius:8px}@media (width<=760px){.audit-toolbar{grid-template-columns:1fr;width:100%}}.alert-row{border-radius:8px;align-items:flex-start;gap:8px;margin-bottom:8px;padding:10px 14px;font-size:.84rem;display:flex}.alert-row.warn{background:#e5a0171f;border:1px solid #e5a0174d}.alert-row.info{background:#3b82f61a;border:1px solid #3b82f640}.platform-badge{color:var(--saas-purple);background:#534ab71f;border-radius:999px;align-items:center;gap:6px;margin-bottom:8px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.platform-console{gap:20px;display:grid}.platform-header{margin-bottom:0}.platform-monitor-grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);align-items:start;gap:20px;display:grid}.school-list{gap:8px;display:grid}.school-row-card{text-align:left;width:100%;color:var(--text);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;transition:border-color .15s,background .15s,transform .15s;display:grid}.school-row-card:hover{border-color:var(--accent);background:var(--surface2);transform:translateY(-1px)}.school-row-main{gap:3px;min-width:0;display:grid}.school-row-main strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.school-row-main small,.school-row-side small{color:var(--text2);font-size:.75rem}.school-row-side{justify-items:end;gap:6px;display:grid}.school-avatar.large{background:var(--saas-purple);width:58px;height:58px;font-size:1rem}.school-profile-head{align-items:center;gap:14px;margin-bottom:18px;display:flex}.school-profile-head h2{margin:0 0 4px}.school-profile-head p{color:var(--text2);font-size:.86rem}.school-profile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.school-info-tile{border:1px solid var(--border);background:var(--surface2);border-radius:8px;gap:4px;padding:12px;display:grid}.school-info-tile span{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:800}.school-info-tile strong{overflow-wrap:anywhere;font-size:.94rem}.school-view-modal{width:min(720px,95vw)}.platform-alerts{margin-top:0}.platform-status-stack{gap:10px;display:grid}.platform-status-stack div,.platform-credit-list div{border:1px solid var(--border);background:var(--surface2);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.platform-status-stack span,.platform-credit-list span{color:var(--text2);font-size:.82rem}.platform-status-stack strong,.platform-credit-list strong{font-size:1.1rem}.platform-credit-list{gap:8px;max-height:360px;display:grid;overflow:auto}@media (width<=960px){.platform-monitor-grid{grid-template-columns:1fr}}@media (width<=620px){.school-row-card{grid-template-columns:auto minmax(0,1fr)}.school-row-side{grid-column:1/-1;grid-auto-flow:column;justify-content:space-between;justify-items:start}.school-profile-grid{grid-template-columns:1fr}}.saas-table th{text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.saas-table tbody tr:nth-child(2n){background:#8080800a}.school-avatar{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.82rem;font-weight:700;display:flex}.btn-micro{border:1px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:6px;padding:4px 10px;font-size:.74rem}.btn-micro:hover{border-color:var(--saas-red);color:var(--saas-red)}.term-filter select{min-width:160px}.grade-band-fail{color:var(--saas-red);font-weight:600}.settings-saas-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}@media (width<=860px){.settings-saas-grid{grid-template-columns:1fr}}.logo-upload-row{align-items:center;gap:14px;margin-bottom:14px;display:flex}.logo-preview{object-fit:cover;border:1px solid var(--border);background:var(--bg);border-radius:8px;width:56px;height:56px}.settings-logo-upload{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:16px}.settings-logo-upload .logo-preview{object-fit:contain;background:#fff;width:80px;height:80px}.logo-preview-empty{color:var(--text2);text-transform:uppercase;text-align:center;justify-content:center;align-items:center;font-size:.76rem;font-weight:800;display:flex;background:var(--bg)!important}.danger-zone{border-color:#d6454559!important}.danger-zone h3{color:var(--saas-red)}
