*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#007c82;--primary-dark:#005f64;--primary-light:#e0f4f5;--secondary:#f0a500;--danger:#e74c3c;--success:#27ae60;--warning:#f39c12;--gray:#95a5a6;--light:#f5f6fa;--dark:#2c3e50;--sidebar-width:250px;--font-sans:"Plus Jakarta Sans","Inter","Segoe UI",Tahoma,Geneva,Verdana,system-ui,-apple-system,sans-serif;--font-display:"Plus Jakarta Sans","Inter","Segoe UI",system-ui,sans-serif;--font-mono:"JetBrains Mono","SF Mono",Consolas,"Liberation Mono",Menlo,monospace}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-feature-settings:"cv11","ss01","ss03";background:radial-gradient(1200px 600px at -10% -10%,#0d948814,#0000 60%),radial-gradient(900px 500px at 110% 110%,#0891b212,#0000 60%),linear-gradient(180deg,#eef4f6,#f3f7f9);background-attachment:fixed;color:#0f172a;font-family:Plus Jakarta Sans,Inter,Segoe UI,Tahoma,Geneva,Verdana,system-ui,-apple-system,sans-serif;font-family:var(--font-sans);letter-spacing:-.005em}h1,h2,h3,h4,h5,h6{font-family:Plus Jakarta Sans,Inter,Segoe UI,system-ui,sans-serif;font-family:var(--font-display);font-weight:700;letter-spacing:-.02em}button,input,select,textarea{font-family:inherit}.mono,[class*=-num],code,kbd,pre,samp{font-feature-settings:"zero","ss02";font-family:JetBrains Mono,SF Mono,Consolas,Liberation Mono,Menlo,monospace!important;font-family:var(--font-mono)!important}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer}button,input,select,textarea{outline:none}.container{margin:0 auto;max-width:1200px;padding:0 20px}.form-error-box{background:#fdecea;border:1px solid #fcc;border-radius:8px;color:#e74c3c;font-size:13px;margin-bottom:14px}.subject-checkboxes{border:1px solid #ddd;border-radius:8px;display:flex;flex-wrap:wrap;max-height:150px;overflow-y:auto;padding:8px}.checkbox-label{background:#f5f5f5;border-radius:6px;color:#444;font-size:13px;gap:6px;padding:4px 8px;white-space:nowrap}.checkbox-label:hover{background:var(--primary-light)}.checkbox-label input{cursor:pointer}:root{--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}body,html{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-overflow-scrolling:touch;max-width:100vw;overflow-x:clip}body,html{touch-action:pan-y}#root{max-width:100vw;min-height:100vh;overflow-x:clip}button,input,select,textarea{font-size:16px}@media (max-width:760px){body,html{font-size:15px}.app-layout,.layout,.main-layout{display:block!important;padding-bottom:env(safe-area-inset-bottom,0);padding-bottom:var(--safe-bottom);padding-top:env(safe-area-inset-top,0);padding-top:var(--safe-top)}.sidebar,aside.sidebar{backface-visibility:hidden;bottom:0;box-shadow:none;left:0!important;max-width:320px;overflow-y:auto;position:fixed!important;top:0;transform:translate3d(-100%,0,0)!important;transition:transform .18s cubic-bezier(.2,.8,.2,1)!important;width:82%!important;will-change:transform;z-index:999}.layout.mobile-sidebar-open .sidebar,.sidebar.mobile-open,.sidebar.open,aside.sidebar.open{box-shadow:0 0 40px #0003;transform:translateZ(0)!important}.layout.sidebar-closed .sidebar{transform:translate3d(-100%,0,0)!important}.layout.sidebar-closed.mobile-sidebar-open .sidebar{transform:translateZ(0)!important}.sidebar-overlay{background:#00000073;inset:0;opacity:0;pointer-events:none;position:fixed;transition:opacity .15s linear;will-change:opacity;z-index:998}.sidebar-overlay.show{opacity:1;pointer-events:auto}.content,.main-content,.page-content{box-sizing:border-box;margin-left:0!important;max-width:100vw!important;overflow-x:clip;padding:calc(12px + env(safe-area-inset-top, 0px)) 12px 12px!important;padding-top:calc(12px + var(--safe-top))!important;touch-action:pan-y;width:100%!important}.layout{max-width:100vw;overflow-x:clip;touch-action:pan-y}.topbar{box-sizing:border-box;max-width:100vw}.ann-grid,.att-overview,.dashboard,.leader-cols,.lr-list,.req-page{box-sizing:border-box;max-width:100%!important}.stats-grid{max-width:100%!important;overflow:visible!important}.data-table-wrap,.enr-table-wrap,.table-scroll{-webkit-overflow-scrolling:touch;max-width:100%!important;overflow-x:auto}.topbar,header.topbar{padding:8px 12px!important;position:sticky;top:0;z-index:50}.topbar-title{font-size:1.05rem!important}.page-header,.page-header-row{flex-wrap:wrap;gap:10px}.page-header h1,.page-header h2{font-size:1.3rem!important}.ann-grid,.att-overview-grid,.dept-grid,.form-row,.grid,.hr-decision-grid,.hr-disc-grid,.leader-cols,.stats-grid{grid-template-columns:1fr!important}.stat-card{padding:14px!important}.stat-value{font-size:1.6rem!important}.data-table-wrap,table{-webkit-overflow-scrolling:touch;display:block;max-width:100%;overflow-x:auto}.data-table td,.data-table th{font-size:.85rem!important;padding:10px 8px!important}.modal-overlay{align-items:flex-end!important;padding:0!important}.Modal,.chat-modal,.modal,.modal-box{border-radius:16px 16px 0 0!important;height:92vh;max-height:92vh;max-width:100%!important;width:100%!important}.btn,a.btn,button{min-height:42px}.btn-sm{min-height:36px}.form-field input,.form-field select,.form-field textarea,.form-input,input,select,textarea{box-sizing:border-box;min-height:42px;width:100%}.att-filters,.att-toolbar,.filters,.toolbar{flex-wrap:wrap!important;gap:8px!important}.picker-popover{left:8px!important;right:8px;width:auto!important}.gif-grid{grid-template-columns:repeat(2,1fr)!important}.lr-card{flex-wrap:wrap;gap:8px!important;padding:12px!important}.lr-card-mid,.lr-card-right{width:100%}.lr-steps{gap:4px!important;padding:10px 0!important}.lr-step{min-width:50px!important}.lr-step-icon{font-size:.78rem!important;height:30px!important;width:30px!important}.lr-step-label{font-size:.6rem!important}.dash-card{padding:14px!important}.dash-att-modal{height:90vh;width:100%!important}.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-menu-toggle{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;color:#0f172a;cursor:pointer;display:inline-flex!important;height:40px;justify-content:center;width:40px}}@media (min-width:761px){.mobile-menu-toggle,.mobile-only{display:none!important}}@media (display-mode:standalone){body{user-select:none;-webkit-user-select:none}.topbar{padding-top:calc(10px + env(safe-area-inset-top, 0px))!important;padding-top:calc(10px + var(--safe-top))!important}}@media (max-width:380px){.stat-value{font-size:1.4rem!important}.page-header h1,.page-header h2{font-size:1.15rem!important}}.cw-fab{align-items:center;background:#007c82;border:none;border-radius:50%;bottom:28px;box-shadow:0 4px 20px #007c8273;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:28px;transition:transform .2s,box-shadow .2s;width:56px;z-index:900}.cw-fab:hover{box-shadow:0 6px 28px #007c828c;transform:scale(1.08)}.cw-fab-badge{align-items:center;background:#ef4444;border:2px solid #fff;border-radius:99px;color:#fff;display:flex;font-size:.65rem;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 4px;position:absolute;right:-3px;top:-3px}.cw-panel{animation:cwSlideUp .2s ease;background:#fff;border-radius:18px;bottom:96px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;height:540px;overflow:hidden;position:fixed;right:28px;width:360px;z-index:901}@keyframes cwSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cw-panel-header{align-items:center;background:#007c82;color:#fff;display:flex;flex-shrink:0;gap:8px;padding:12px 14px}.cw-header-title{flex:1 1;font-size:.95rem;font-weight:700}.cw-header-actions{display:flex;gap:4px;margin-left:auto;margin-right:4px}.cw-header-actions button{align-items:center;background:#ffffff26;border:none;border-radius:7px;color:#fff;cursor:pointer;display:flex;padding:5px 7px;transition:background .15s}.cw-header-actions button:hover{background:#ffffff40}.cw-close{background:#ffffff26;border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.85rem;line-height:1;padding:4px 8px;transition:background .15s}.cw-close:hover{background:#ffffff4d}.cw-back{align-items:center;background:#ffffff26;border:none;border-radius:7px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;padding:5px 7px}.cw-back:hover{background:#ffffff40}.cw-header-avatar{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:30px;justify-content:center;width:30px}.cw-header-info{flex:1 1;min-width:0}.cw-header-name{display:block;font-size:.88rem;font-weight:700}.cw-header-sub{font-size:.72rem;opacity:.8}.cw-call-trigger{align-items:center;background:#ffffff26;border:none;border-radius:7px;color:#fff;cursor:pointer;display:flex;padding:5px 7px}.cw-call-trigger:hover{background:#ffffff40}.cw-conv-list{flex:1 1;overflow-y:auto;padding:6px 0}.cw-empty{color:#9ca3af;font-size:.82rem;line-height:1.5;padding:24px 16px;text-align:center}.cw-conv-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:9px 14px;transition:background .12s}.cw-conv-item:hover{background:#f9fafb}.cw-conv-av-wrap{flex-shrink:0;position:relative}.cw-conv-av{align-items:center;background:#007c82;border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:700;height:40px;justify-content:center;width:40px}.cw-conv-av.sm{font-size:.88rem;height:34px;width:34px}.cw-dot{background:#10b981;border:2px solid #fff;border-radius:50%;bottom:0;height:10px;position:absolute;right:0;width:10px}.cw-dot.static{flex-shrink:0;margin-left:auto;position:static}.cw-conv-info{flex:1 1;min-width:0}.cw-conv-row{align-items:center;display:flex;justify-content:space-between}.cw-conv-name{color:#111827;font-size:.88rem;font-weight:600}.cw-conv-name.unread{color:#000;font-weight:800}.cw-conv-time{color:#9ca3af;font-size:.7rem}.cw-conv-last{color:#6b7280;font-size:.78rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cw-conv-last.unread{color:#111827;font-weight:600}.cw-unread{align-items:center;background:#007c82;border-radius:99px;color:#fff;display:flex;flex-shrink:0;font-size:.68rem;font-weight:700;height:17px;justify-content:center;min-width:17px;padding:0 4px}.cw-messages{background:#f0f2f5;display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:10px 12px}.cw-date-sep{align-items:center;display:flex;justify-content:center;margin:8px 0}.cw-date-sep span{background:#e5e7eb;border-radius:99px;color:#6b7280;font-size:.7rem;padding:2px 10px}.cw-msg{align-items:flex-start;display:flex;flex-direction:column;margin:1px 0}.cw-msg.mine{align-items:flex-end}.cw-msg-sender{color:#007c82;font-size:.68rem;font-weight:600;margin-bottom:1px;padding-left:10px}.cw-bubble{background:#fff;border-radius:14px 14px 14px 4px;box-shadow:0 1px 2px #00000012;color:#111827;font-size:.85rem;max-width:75%;padding:7px 10px;word-break:break-word}.cw-bubble.mine{background:#007c82;border-radius:14px 14px 4px 14px;color:#fff}.cw-bubble.deleted{background:#f3f4f6;color:#9ca3af;font-style:italic}.cw-deleted{font-size:.8rem}.cw-img{border-radius:8px;display:block;max-height:160px;max-width:180px}.cw-file-link{color:inherit;font-size:.82rem;text-decoration:none}.cw-file-link:hover{text-decoration:underline}.cw-msg-meta{align-items:center;display:flex;gap:4px;justify-content:flex-end;margin-top:2px}.cw-msg-time{color:#0000004d;font-size:.65rem}.cw-bubble.mine .cw-msg-time{color:#fff9}.cw-del-btn{background:none;border:none;color:#00000040;cursor:pointer;font-size:.65rem;opacity:0;padding:0;transition:opacity .12s}.cw-bubble:hover .cw-del-btn{opacity:1}.cw-bubble.mine .cw-del-btn,.cw-read-tick{color:#ffffff80}.cw-read-tick{font-size:.65rem;letter-spacing:-2px}.cw-read-tick.read{color:#60a5fa;font-weight:700;letter-spacing:-3px}.cw-typing{align-items:center;color:#6b7280;display:flex;font-size:.75rem;gap:6px;padding:2px 0}.cw-dots{display:inline-flex;gap:2px;margin-left:2px}.cw-dots span{animation:cwBounce 1.2s infinite;background:#9ca3af;border-radius:50%;height:4px;width:4px}.cw-dots span:nth-child(2){animation-delay:.2s}.cw-dots span:nth-child(3){animation-delay:.4s}@keyframes cwBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.cw-emoji-grid{grid-gap:1px;background:#fff;border-top:1px solid #f0f2f5;display:grid;flex-shrink:0;gap:1px;grid-template-columns:repeat(9,1fr);padding:8px}.cw-emoji-btn{background:none;border:none;border-radius:5px;cursor:pointer;font-size:1.2rem;line-height:1;padding:3px;transition:background .1s}.cw-emoji-btn:hover{background:#f0f2f5}.cw-input{background:#fff;border-top:1px solid #e5e7eb;gap:6px;padding:8px 10px}.cw-icon-btn,.cw-input{align-items:center;display:flex;flex-shrink:0}.cw-icon-btn{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:1rem;padding:4px;transition:background .12s}.cw-icon-btn:hover{background:#f0f2f5}.cw-text-input{background:#f9fafb;border:1px solid #e5e7eb;border-radius:18px;flex:1 1;font-family:inherit;font-size:.85rem;outline:none;padding:7px 12px;transition:border-color .15s}.cw-text-input:focus{background:#fff;border-color:#007c82}.cw-send{align-items:center;background:#007c82;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:34px;justify-content:center;transition:background .15s;width:34px}.cw-send:hover:not(:disabled){background:#006368}.cw-send:disabled{background:#d1d5db;cursor:not-allowed}.cw-subpanel{animation:cwSlideUp .15s ease;background:#fff;border-radius:18px;display:flex;flex-direction:column;inset:0;position:absolute;z-index:10}.cw-subpanel-header{align-items:center;background:#007c82;border-radius:18px 18px 0 0;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;justify-content:space-between;padding:12px 14px}.cw-subpanel-header button{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:3px 8px}.cw-search{border:1px solid #e5e7eb;border-radius:18px;box-sizing:border-box;font-size:.85rem;margin:10px 12px 4px;outline:none;padding:7px 12px;width:calc(100% - 24px)}.cw-search:focus{border-color:#007c82}.cw-user-list{flex:1 1;overflow-y:auto}.cw-user-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:background .12s}.cw-user-item:hover{background:#f9fafb}.cw-user-item.sel{background:#e0f2f4}.cw-ui-name{color:#111827;font-size:.88rem;font-weight:500}.cw-ui-role{color:#9ca3af;font-size:.72rem}.cw-group-footer{align-items:center;border-top:1px solid #f0f2f5;color:#6b7280;display:flex;flex-shrink:0;font-size:.82rem;justify-content:space-between;padding:10px 12px}.cw-create-btn{background:#007c82;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;padding:6px 16px}.cw-create-btn:disabled{background:#d1d5db;cursor:not-allowed}.cw-toasts{bottom:100px;display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:28px;z-index:950}.cw-toast{align-items:center;animation:cwToastIn .25s ease;background:#fff;border-left:3px solid #007c82;border-radius:12px;box-shadow:0 4px 20px #00000026;cursor:pointer;display:flex;gap:10px;max-width:320px;min-width:260px;padding:10px 12px;pointer-events:all}@keyframes cwToastIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.cw-toast:hover{box-shadow:0 6px 24px #0000002e}.cw-toast-avatar{align-items:center;background:#007c82;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:34px;justify-content:center;width:34px}.cw-toast-body{flex:1 1;min-width:0}.cw-toast-name{color:#111827;font-size:.82rem;font-weight:700}.cw-toast-msg{color:#6b7280;font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cw-toast-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:.8rem;padding:2px 4px}.cw-toast-close:hover{color:#374151}.cw-call-overlay{background:#000000a6;inset:0;justify-content:center;position:fixed;z-index:2000}.cw-call-box,.cw-call-overlay{align-items:center;display:flex}.cw-call-box{background:linear-gradient(135deg,#007c82,#005a5e);border-radius:22px;box-shadow:0 20px 60px #0006;flex-direction:column;gap:14px;min-width:260px;padding:36px 44px}.cw-call-avatar{align-items:center;background:#fff3;border:3px solid #ffffff59;border-radius:50%;color:#fff;display:flex;font-size:1.8rem;font-weight:700;height:72px;justify-content:center;width:72px}.cw-call-name{color:#fff;font-size:1.1rem;font-weight:700}.cw-call-status{color:#ffffffbf;font-size:.85rem}.cw-call-btns{display:flex;gap:18px;margin-top:6px}.cw-call-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:52px;justify-content:center;transition:transform .15s;width:52px}.cw-call-btn:hover{transform:scale(1.1)}.cw-call-btn.accept{background:#10b981}.cw-call-btn.reject{background:#ef4444}.cw-conv-list::-webkit-scrollbar,.cw-messages::-webkit-scrollbar,.cw-user-list::-webkit-scrollbar{width:4px}.cw-conv-list::-webkit-scrollbar-thumb,.cw-messages::-webkit-scrollbar-thumb,.cw-user-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:99px}.layout{display:flex;min-height:100vh}.sidebar{background:radial-gradient(1200px 600px at -10% -10%,#14b8a62e,#0000 60%),radial-gradient(900px 500px at 110% 110%,#22d3ee1f,#0000 55%),linear-gradient(180deg,#061b1d,#0a2a2e 55%,#0f3a3f);border-right:1px solid #ffffff0f;bottom:0;box-shadow:0 0 24px #0000002e;color:#e2f3f4;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .3s ease;width:var(--sidebar-width);z-index:100}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:6px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff29}.layout.sidebar-closed .sidebar{transform:translateX(-100%)}.layout.sidebar-closed .main-content{margin-left:0}.sidebar-header{align-items:center;display:flex;gap:12px;padding:20px 18px 18px;position:relative}.sidebar-header:after{background:linear-gradient(90deg,#0000,#ffffff1f,#0000);bottom:0;content:"";height:1px;left:18px;position:absolute;right:18px}.sidebar-logo{background:linear-gradient(135deg,#ffffff1f,#ffffff0a);border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 12px #00000040;flex-shrink:0;height:42px;padding:6px;width:42px}.sidebar-title{display:flex;flex-direction:column;min-width:0}.school-name{color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.01em;line-height:1.35}.school-name2{color:#e2f3f49e;font-size:10.5px;line-height:1.35}.sidebar-nav{flex:1 1;gap:14px;padding:14px 10px 8px}.nav-group,.sidebar-nav{display:flex;flex-direction:column}.nav-group{gap:1px}.nav-group-label{color:#e2f3f461;font-size:10px;font-weight:700;letter-spacing:.12em;padding:6px 14px;text-transform:uppercase}.nav-item{align-items:center;border-radius:10px;color:#e2f3f4b8;display:flex;font-size:13.5px;gap:12px;padding:9px 12px;position:relative;text-decoration:none;transition:background .18s ease,color .18s ease,transform .18s ease}.nav-item:before{background:#5eead4;border-radius:3px;content:"";height:0;left:4px;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:height .18s ease,opacity .18s ease;width:3px}.nav-item:hover{background:#ffffff0f;color:#fff;transform:translateX(2px)}.nav-item:hover .nav-icon{color:#5eead4}.nav-item.active{background:linear-gradient(90deg,#5eead42e,#5eead40a);box-shadow:inset 0 1px 0 #ffffff0f;color:#fff;font-weight:600}.nav-item.active:before{height:18px;opacity:1}.nav-item.active .nav-icon{color:#5eead4}.nav-icon{align-items:center;color:#e2f3f4c7;display:flex;flex-shrink:0;height:22px;justify-content:center;transition:color .18s ease;width:22px}.nav-icon svg{height:18px;width:18px}.nav-label{flex:1 1;font-size:13px}.nav-badge{align-items:center;background:#f43f5e;border-radius:999px;box-shadow:0 2px 6px #f43f5e73;color:#fff;display:inline-flex;font-size:10px;font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 6px}.sidebar-footer{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:12px;margin:8px 10px 12px;padding:12px}.sidebar-footer,.user-info{align-items:center;display:flex;gap:10px}.user-info{flex:1 1;min-width:0}.user-avatar{align-items:center;background:linear-gradient(135deg,#14b8a6,#0e7490);border:2px solid #ffffff1f;border-radius:50%;box-shadow:0 4px 12px #0d948859;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{color:#fff;font-size:13px;font-weight:600}.user-name,.user-role{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#e2f3f49e;font-size:11px;text-transform:capitalize}.logout-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff0f;border-radius:9px;color:#e2f3f4b3;display:flex;flex-shrink:0;height:34px;justify-content:center;transition:all .2s;width:34px}.logout-btn:hover{background:#f43f5e2e;border-color:#f43f5e66;color:#fda4af}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left .3s ease}.topbar{backdrop-filter:saturate(160%) blur(8px);-webkit-backdrop-filter:saturate(160%) blur(8px);background:#ffffffd9;border-bottom:1px solid #eef2f6;gap:14px;height:60px;padding:0 24px;position:sticky;top:0;z-index:50}.menu-toggle,.topbar{align-items:center;display:flex}.menu-toggle{background:#f1f5f9;border:1px solid #0000;border-radius:9px;color:#475569;cursor:pointer;padding:8px;transition:all .18s ease}.menu-toggle:hover{background:#e2e8f0;color:#0f172a}.topbar-title{color:#0f172a;font-size:15px;font-weight:700;letter-spacing:-.005em}.user-avatar-wrap{cursor:pointer;flex-shrink:0;position:relative}.user-avatar-wrap:hover .avatar-edit-icon{opacity:1}.avatar-edit-icon{align-items:center;background:#007c82;border:2px solid #1a2332;border-radius:50%;bottom:-2px;color:#fff;display:flex;height:18px;justify-content:center;opacity:0;position:absolute;right:-2px;transition:opacity .15s;width:18px}.user-avatar-img{border:2px solid #ffffff4d;border-radius:50%;flex-shrink:0;height:36px;object-fit:cover;width:36px}.user-dept{color:#ffffff80;display:block;font-size:10px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-content{display:flex;flex:1 1;justify-content:center;padding:24px}.page-container{max-width:1400px;width:100%}.notif-bell{align-items:center;background:#f8fafc;border:1px solid #eef2f6;border-radius:10px;color:#475569;cursor:pointer;display:flex;margin-left:4px;padding:8px;position:relative;transition:all .18s ease}.notif-bell:hover{background:#f1f5f9;border-color:#e2e8f0;color:#0f172a;transform:translateY(-1px)}.notif-count{align-items:center;background:linear-gradient(135deg,#f43f5e,#dc2626);border:2px solid #fff;border-radius:99px;box-shadow:0 2px 6px #dc262666;color:#fff;display:flex;font-size:.62rem;font-weight:800;height:17px;justify-content:center;line-height:1;min-width:17px;padding:0 4px;position:absolute;right:-3px;top:-3px}.lang-toggle-wrap{display:inline-flex;margin-right:4px;position:relative}.lang-toggle-btn{align-items:center;background:#f1f5f9;border:1px solid #eef2f6;border-radius:10px;color:#0d9488;cursor:pointer;display:inline-flex;font-size:11px;font-weight:700;gap:4px;letter-spacing:.04em;padding:6px 9px 6px 11px;transition:all .15s ease}.lang-toggle-btn:hover{background:#e0f2f4;border-color:#c7e8eb}.lang-toggle-current{font-weight:800}.lang-dropdown-overlay{inset:0;position:fixed;z-index:99}.lang-dropdown{animation:lang-fade-in .14s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 30px #0000001f;min-width:150px;overflow:hidden;position:absolute;right:0;top:calc(100% + 6px);z-index:100}@keyframes lang-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lang-dropdown-item{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:flex;font-size:.78rem;font-weight:700;gap:10px;letter-spacing:.04em;padding:9px 14px;text-align:left;width:100%}.lang-dropdown-item:hover{background:#f1f5f9;color:#0f172a}.lang-dropdown-item.active{background:#e0f2f4;color:#0d9488}.lang-dropdown-name{color:inherit;font-size:.8rem;font-weight:500;letter-spacing:0;opacity:.85;text-transform:none}.topbar-title-short{display:none}@media (max-width:760px){.sidebar-header{gap:10px;padding:14px 14px 10px!important}.sidebar-logo{height:38px!important;width:38px!important}.sidebar-title .school-name{font-size:.78rem!important;line-height:1.2}.sidebar-title .school-name2{font-size:.7rem!important;line-height:1.2}.sidebar-nav{gap:8px!important;padding:8px!important}.nav-group-label{font-size:9px!important;padding:4px 10px 2px!important}.nav-item{border-radius:9px!important;font-size:.86rem!important;gap:10px!important;padding:9px 10px!important}.nav-icon{height:20px!important;width:20px!important}.nav-icon svg{height:17px!important;width:17px!important}.nav-label{font-size:.86rem!important}.nav-badge{font-size:.62rem!important;min-width:14px;padding:1px 6px!important}.sidebar-footer{padding:10px!important}.user-info{gap:8px;padding:8px!important}}@media (max-width:380px){.nav-item{gap:9px!important;padding:8px 10px!important}.nav-item,.nav-label{font-size:.8rem!important}.nav-icon{height:18px!important;width:18px!important}.nav-icon svg{height:15px!important;width:15px!important}.sidebar-title .school-name{font-size:.72rem!important}.sidebar-title .school-name2{font-size:.66rem!important}}.sidebar-close-btn{align-items:center;background:#ffffff1f;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;height:36px;justify-content:center;position:absolute;right:10px;top:10px;transition:background .15s,transform .15s;width:36px;z-index:5}.sidebar-close-btn:hover{background:#ffffff38;transform:rotate(90deg)}@media (max-width:760px){.sidebar-close-btn{display:inline-flex}.topbar{align-items:center;background:linear-gradient(135deg,#007c82,#0891b2 60%,#0d9488)!important;border-bottom:none!important;box-shadow:0 4px 16px #007c822e!important;color:#fff;gap:4px;padding:10px 12px!important}.topbar .menu-toggle{align-items:center;background:#0000!important;border:none!important;border-radius:50%;color:#fff!important;display:inline-flex;height:40px;justify-content:center;width:40px}.topbar .menu-toggle:hover{background:#ffffff2e!important}.topbar-title{align-items:center;color:#fff!important;display:flex!important;flex:1 1;font-size:1.05rem!important;font-weight:800!important;justify-content:center;letter-spacing:.04em;margin:0 6px;text-shadow:0 1px 2px #0000001f}.topbar-title-full{display:none}.topbar-title-short{display:inline}.lang-toggle-btn{background:#0000!important;border:none!important;color:#fff!important;font-size:12px;padding:6px 8px}.lang-toggle-btn:hover{background:#ffffff2e!important}.notif-bell{align-items:center;background:#0000!important;border:none!important;border-radius:50%;color:#fff!important;display:inline-flex;flex-shrink:0;height:40px;justify-content:center;padding:0;width:40px}.notif-bell:hover{background:#ffffff2e!important;transform:none}.notif-bell svg{height:20px;width:20px}.notif-bell .notif-count{background:#ef4444;border:2px solid #007c82;color:#fff}.notif-dropdown{color:#0f172a;left:8px;margin-left:auto;max-width:360px;right:8px;width:auto}.topbar>div:last-child{align-items:center;gap:2px!important}}@media (max-width:380px){.topbar{padding:8px!important}.topbar-title{font-size:.95rem!important}.lang-toggle-btn{font-size:11px;padding:5px 6px}.notif-bell{height:36px;width:36px}.notif-bell svg{height:18px;width:18px}.topbar .menu-toggle{height:36px;width:36px}}.notif-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #00000026;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:300px;z-index:100}.notif-header{border-bottom:1px solid #f3f4f6;color:#111827;font-size:.88rem;font-weight:700;padding:12px 16px}.notif-empty{color:#9ca3af;font-size:.85rem;padding:20px;text-align:center}.notif-item{align-items:center;color:#374151;cursor:pointer;display:flex;gap:10px;padding:10px 16px;text-decoration:none;transition:background .1s}.notif-item:hover{background:#f9fafb}.notif-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:1.1rem;height:36px;justify-content:center;width:36px}.notif-text{color:#111827;font-size:.84rem}.notif-sub{color:#9ca3af;font-size:.72rem;margin-top:1px}.login-page-v2{align-items:center;background:radial-gradient(circle at 20% 0,#0891b22e,#0000 45%),radial-gradient(circle at 80% 100%,#0d948833,#0000 50%),linear-gradient(135deg,#0f172a,#134e5e 50%,#0e7490);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px 16px;position:relative}.login-bg-orbs{inset:0;pointer-events:none;position:absolute}.login-bg-orbs .orb{animation:orbDrift 18s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.55;position:absolute}.orb-1{background:#14b8a6;height:380px;left:-100px;top:-120px;width:380px}.orb-2{animation-delay:-4s;animation-duration:22s;background:#0891b2;bottom:-160px;height:460px;right:-140px;width:460px}.orb-3{animation-delay:-10s;animation-duration:26s;background:#6366f1;height:280px;left:60%;opacity:.35;top:40%;width:280px}@keyframes orbDrift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,-30px) scale(1.05)}66%{transform:translate(-30px,40px) scale(.96)}}.login-shell{align-items:center;display:flex;flex-direction:column;gap:20px;max-width:420px;position:relative;width:100%;z-index:1}.login-brand{color:#fff;margin-bottom:4px;text-align:center}.login-logo-wrap{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff24;border:1px solid #ffffff38;border-radius:22px;box-shadow:0 8px 32px #00000040;display:inline-flex;height:72px;justify-content:center;margin-bottom:14px;width:72px}.login-logo-wrap img{filter:drop-shadow(0 2px 6px rgba(0,0,0,.2));height:44px;width:44px}.login-brand-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;letter-spacing:-.01em;margin:0;text-shadow:0 2px 12px #0000002e}.login-brand-sub{font-size:.85rem;letter-spacing:.01em;margin:4px 0 0;opacity:.85}.login-card-v2{-webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);background:#fffffff5;border:1px solid #ffffff80;border-radius:22px;box-shadow:0 24px 60px #00000047,0 0 0 1px #ffffff14;padding:28px 26px 24px;position:relative;width:100%}.login-lang-switch{background:#f1f5f9;border-radius:8px;display:flex;gap:1px;padding:2px;position:absolute;right:14px;top:14px}.login-lang-switch button{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 8px;transition:all .15s}.login-lang-switch button.active{background:#fff;box-shadow:0 1px 3px #00000014;color:#0d9488}.login-card-head{margin-bottom:22px;padding-right:80px}.login-card-head h2{color:#0f172a;font-family:var(--font-display);font-size:1.45rem;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}.login-card-head p{color:#64748b;font-size:.86rem;margin:0}.login-error-v2{align-items:center;animation:errShake .35s;background:linear-gradient(135deg,#fef2f2,#fff1f2);border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.84rem;gap:8px;margin-bottom:16px;padding:10px 12px}@keyframes errShake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.login-form-v2{display:flex;flex-direction:column;gap:12px}.login-input-wrap{align-items:center;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;display:flex;gap:10px;padding:0 12px;transition:border-color .15s,background .15s,box-shadow .15s}.login-input-wrap:focus-within{background:#fff;border-color:#0d9488;box-shadow:0 0 0 4px #0d94881f}.login-input-icon{color:#94a3b8;display:inline-flex;flex-shrink:0}.login-input-wrap:focus-within .login-input-icon{color:#0d9488}.login-input-wrap input{background:#0000;border:none;color:#0f172a;flex:1 1;font-family:inherit;font-size:.95rem;outline:none;padding:13px 0}.login-input-wrap input::placeholder{color:#94a3b8}.login-pwd-toggle{background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:inline-flex;padding:4px;transition:color .15s,background .15s}.login-pwd-toggle:hover{background:#0d948814;color:#0d9488}.login-submit-v2{align-items:center;background:linear-gradient(135deg,#0d9488,#0891b2);border:none;border-radius:12px;box-shadow:0 6px 18px #0d94885c,inset 0 1px 0 #fff3;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:700;gap:8px;justify-content:center;letter-spacing:.01em;margin-top:6px;padding:13px 18px;transition:transform .12s,box-shadow .15s}.login-submit-v2:hover:not(:disabled){box-shadow:0 10px 24px #0d948870;transform:translateY(-1px)}.login-submit-v2:active:not(:disabled){transform:translateY(0)}.login-submit-v2:disabled{cursor:not-allowed;opacity:.7}.login-submit-v2 svg{transition:transform .15s}.login-submit-v2:hover svg{transform:translateX(3px)}.login-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff52;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.login-divider-v2{align-items:center;display:flex;gap:12px;margin:18px 0 14px}.login-divider-v2:after,.login-divider-v2:before{background:linear-gradient(90deg,#0000,#e2e8f0,#0000);content:"";flex:1 1;height:1px}.login-divider-v2 span{color:#94a3b8;font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.login-ms-v2{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;color:#1f2937;cursor:pointer;display:inline-flex;font-size:.92rem;font-weight:600;gap:10px;justify-content:center;padding:12px 18px;transition:border-color .15s,background .15s,transform .12s;width:100%}.login-ms-v2:hover{background:#f0f9ff;border-color:#0078d4;transform:translateY(-1px)}.login-footer{color:#ffffff8c;font-size:.74rem;letter-spacing:.04em;margin:4px 0 0;text-align:center}@media (max-width:480px){.login-page-v2{padding:20px 14px}.login-shell{gap:16px}.login-logo-wrap{border-radius:18px;height:64px;width:64px}.login-logo-wrap img{height:38px;width:38px}.login-brand-title{font-size:1.3rem}.login-card-v2{border-radius:18px;padding:24px 20px 20px}.login-card-head h2{font-size:1.25rem}}@media (display-mode:standalone){.login-page-v2{padding-bottom:calc(24px + env(safe-area-inset-bottom));padding-top:calc(24px + env(safe-area-inset-top))}}.login-page{display:flex;min-height:100vh}.login-left{align-items:center;background:linear-gradient(135deg,#005f64,#007c82 50%,#009ba3);color:#fff;display:flex;flex:1 1;justify-content:center;padding:40px}.dashboard{padding-bottom:32px}.dash-loading{display:flex;justify-content:center;padding:80px}.att-item-clickable{border-radius:8px;margin:-4px -8px;padding:4px 8px;transition:background .12s,transform .12s}.att-item-clickable:hover{background:#f1f5f9;transform:translateX(2px)}.dash-att-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.dash-att-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-height:80vh;overflow:hidden;width:min(560px,92vw)}.dash-att-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:10px;padding:16px 20px}.dash-att-modal-body{overflow-y:auto;padding:12px 20px 20px}.dash-att-table{border-collapse:collapse;font-size:.88rem;width:100%}.dash-att-table td,.dash-att-table th{border-bottom:1px solid #f1f5f9;padding:9px 10px;text-align:left}.dash-att-table th{color:#64748b;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.dash-att-table tbody tr:hover{background:#f8fafc}.dash-welcome{margin-bottom:28px}.dash-welcome h1{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#0f766e,#007c82 35%,#0891b2);-webkit-background-clip:text;background-clip:text;display:inline-flex;font-family:var(--font-display);font-size:30px;font-weight:800;gap:10px;letter-spacing:-.025em}.dash-welcome .wave{-webkit-text-fill-color:initial;animation:wave 2.4s ease-in-out infinite;display:inline-block;transform-origin:70% 70%}.dash-welcome p{color:#6b7280;font-size:13.5px;font-weight:500;margin-top:6px}@keyframes wave{0%,to{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-8deg)}45%{transform:rotate(14deg)}60%{transform:rotate(-4deg)}75%{transform:rotate(10deg)}}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.stat-card{align-items:center;animation:cardIn .5s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1px solid #0f172a0d;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 4px 16px #0f172a0f;display:flex;gap:14px;overflow:hidden;padding:18px 20px;position:relative;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,border-color .25s}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stat-card:before{background:linear-gradient(135deg,#0000 60%,#007c82 200%);background:linear-gradient(135deg,#0000 60%,var(--card-color,#007c82) 200%);content:"";inset:0;opacity:.06;pointer-events:none;position:absolute;transition:opacity .25s}.stat-card:hover{border-color:#0f172a14;box-shadow:0 4px 14px #0f172a0f,0 14px 40px #0f172a1a;transform:translateY(-3px)}.stat-card:hover:before{opacity:.12}.stat-icon-wrap{align-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 18%,#fff) 0,color-mix(in srgb,var(--card-color) 8%,#fff) 100%);border-radius:14px;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--card-color) 22%,#0000);display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.stat-icon{font-size:26px;line-height:1}.stat-info{flex:1 1;min-width:0}.stat-value{font-feature-settings:"tnum";color:var(--card-color);font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.1}.stat-label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.005em;margin-top:4px}.stat-glow{background:radial-gradient(circle,color-mix(in srgb,var(--card-color) 18%,#0000),#0000 70%);border-radius:50%;bottom:-30px;filter:blur(8px);height:120px;pointer-events:none;position:absolute;right:-30px;width:120px}.dash-notify-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.dash-notify-card{align-items:center;background:color-mix(in srgb,var(--nc) 8%,#fff);border:1.5px solid color-mix(in srgb,var(--nc) 35%,#0000);border-radius:12px;color:#1f2937;display:flex;font-size:.88rem;font-weight:500;gap:10px;padding:12px 18px;text-decoration:none;transition:transform .2s,box-shadow .2s}.dash-notify-card:hover{box-shadow:0 6px 18px color-mix(in srgb,var(--nc) 18%,#0000);transform:translateY(-1px)}.dash-notify-card b{color:var(--nc);font-weight:800}.dash-notify-icon{font-size:1.25rem}.dash-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.dash-card{background:#fff;border:1px solid #0f172a0d;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0d;padding:22px;transition:box-shadow .25s,transform .25s}.dash-card:hover{box-shadow:0 2px 6px #0f172a0d,0 12px 32px #0f172a14}.dash-card-wide{grid-column:1/-1}.dash-card-head{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:14px}.dash-card-title{align-items:center;color:#0f172a;display:flex;font-family:var(--font-display);font-size:15.5px;font-weight:700;gap:8px;letter-spacing:-.01em;margin:0}.ttl-emoji{font-size:1.05em}.dash-empty{font-size:13px;padding:24px 12px}.dash-empty,.dash-loading-text{color:#9ca3af;font-weight:500;text-align:center}.dash-loading-text{padding:28px}.dash-link{color:var(--primary);font-size:.78rem;font-weight:700;text-decoration:none;transition:color .2s}.dash-link:hover{color:var(--primary-dark)}.filter-pills{display:flex;flex-wrap:wrap;gap:4px}.filter-pills .pill{background:#fff;border:1px solid #e5e7eb;border-radius:999px;color:#6b7280;cursor:pointer;font-size:.74rem;font-weight:600;padding:5px 12px;transition:all .15s}.filter-pills .pill:hover{background:#f0fafb;border-color:#007c82;color:#007c82}.filter-pills .pill.active{background:linear-gradient(135deg,#007c82,#0891b2);border-color:#007c82;box-shadow:0 2px 8px #007c8240;color:#fff}.ticket-list{gap:4px;max-height:320px;overflow-y:auto;padding-right:4px}.ticket-list::-webkit-scrollbar{width:6px}.ticket-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.ticket-list::-webkit-scrollbar-track{background:#0000}.ticket-row{border-bottom:1px solid #f3f4f6;border-radius:10px;padding:11px 12px;transition:background .15s}.ticket-row:hover{background:#fafbfc}.ticket-meta{align-items:center;gap:6px;margin-bottom:4px}.ticket-num{color:#9ca3af;font-family:var(--font-mono);font-weight:500}.ticket-dept,.ticket-status{font-size:.7rem;padding:2px 8px}.ticket-dept{font-weight:600}.ticket-title{font-size:.9rem;line-height:1.35}.ticket-foot{color:#9ca3af;font-size:.72rem;margin-top:3px}.my-ticket-row{align-items:center;border-bottom:1px solid #f3f4f6;border-radius:10px;color:inherit;display:flex;gap:8px;padding:9px 11px;text-decoration:none;transition:background .15s}.my-ticket-row:hover{background:#f9fafb}.my-ticket-row .ticket-num{min-width:75px}.my-ticket-row .ticket-status{min-width:60px;text-align:center}.ticket-title-inline{color:#111827;flex:1 1;font-size:.84rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-date{color:#9ca3af;font-family:var(--font-mono);font-size:.7rem}.announcement-item{border-bottom:1px solid #f5f5f5;padding:11px 0}.announcement-item:last-child{border-bottom:none}.ann-title{color:#1f2937;font-size:14px;font-weight:600}.ann-meta{color:#9ca3af;font-size:12px;margin-top:4px}.att-item{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;padding:10px 0}.att-item:last-child{border-bottom:none}.att-badge{border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.005em;padding:5px 12px}.att-present{background:#e8f8ee;color:var(--success)}.att-absent{background:#fdecea;color:var(--danger)}.att-late{background:#fff4e0;color:var(--warning)}.att-excused{background:#e8f0fe;color:#3d82f4}.att-count{font-feature-settings:"tnum";color:#1f2937;font-family:var(--font-display);font-size:16px;font-weight:800}.enroll-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:14px}.enroll-cell{background:linear-gradient(135deg,#f0fafb,#e0f2f4);border:1px solid #007c821a;border-radius:12px;padding:14px 12px;text-align:center}.enroll-num{font-feature-settings:"tnum";color:#007c82;font-family:var(--font-display);font-size:1.6rem;font-weight:800;line-height:1}.enroll-label{color:#475569;font-size:.74rem;font-weight:700;letter-spacing:.005em;margin-top:6px}.enroll-summary{color:#374151;display:flex;flex-wrap:wrap;font-size:.84rem;font-weight:500;gap:16px}.enroll-summary b{font-weight:800}.leader-controls{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.leader-totals{color:#6b7280;display:flex;font-size:.78rem;gap:14px;margin-right:6px}.leader-totals b{color:#111827;font-weight:700}.leader-nav{background:#f3f4f6;border:none;border-radius:8px;color:#374151;cursor:pointer;font-size:1rem;padding:4px 12px;transition:background .15s,color .15s}.leader-nav:hover:not(:disabled){background:#007c82;color:#fff}.leader-nav:disabled{cursor:not-allowed;opacity:.4}.leader-month{color:#1f2937;font-size:.86rem;font-weight:700;min-width:130px;text-align:center;text-transform:capitalize}.leader-cols{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.leader-col-title{font-size:.82rem;font-weight:800;gap:6px;letter-spacing:.005em;margin-bottom:10px}.leader-col-title,.leader-row{align-items:center;display:flex}.leader-row{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;gap:10px;margin-bottom:6px;padding:10px 12px;transition:transform .15s,box-shadow .15s}.leader-row[data-top=true]{background:var(--accent-bg);border-color:var(--accent-border);box-shadow:0 2px 10px color-mix(in srgb,var(--accent) 15%,#0000)}.leader-row:hover{transform:translateX(2px)}.leader-medal{font-size:1.35rem;min-width:30px}.leader-avatar{align-items:center;background:var(--accent-bg);border-radius:50%;box-shadow:inset 0 0 0 1px var(--accent-border);color:var(--accent);display:flex;flex-shrink:0;font-size:.92rem;font-weight:800;height:36px;justify-content:center;width:36px}.leader-info{flex:1 1;min-width:0}.leader-name{color:#111827;font-size:.86rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leader-meta{color:#9ca3af;font-size:.72rem}.leader-stat{text-align:right}.leader-stat-val{color:var(--accent);font-family:var(--font-display);font-size:.92rem;font-weight:800}.leader-stat-label{color:#9ca3af;font-size:.7rem}.leader-no-rating{color:#9ca3af;font-size:.78rem}.leader-stars{color:#f59e0b;font-size:.92rem}.leader-stars-num{color:#6b7280;font-family:var(--font-mono);font-size:.74rem;margin-left:4px}@media (max-width:1100px){.leader-cols{grid-template-columns:1fr}}@media (max-width:768px){.stats-grid{grid-template-columns:1fr 1fr}.dash-grid{grid-template-columns:1fr}.dash-welcome h1,.stat-value{font-size:24px}.leader-totals{display:none}}@media (max-width:480px){.dashboard{max-width:100%!important;padding:0!important}.dash-welcome{margin-bottom:16px;padding:0 2px}.dash-welcome h1{font-size:1.25rem!important;line-height:1.2;word-break:break-word}.dash-welcome p{font-size:.78rem}.stats-grid{gap:10px!important;grid-template-columns:1fr 1fr!important;margin-bottom:16px}.stat-card{gap:8px!important;min-width:0;overflow:hidden;padding:12px!important}.stat-icon-wrap{flex-shrink:0;height:38px!important;width:38px!important}.stat-icon{font-size:18px!important}.stat-info{flex:1 1;min-width:0;overflow:hidden}.stat-value{font-size:1.05rem!important}.stat-label{font-size:.7rem!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-grid{gap:12px}.dash-card{border-radius:12px;padding:14px!important}.dash-card-title{font-size:.95rem!important}}@media (max-width:360px){.stats-grid{grid-template-columns:1fr!important}.stat-card{padding:12px 14px!important}}.page-header{flex-wrap:wrap;gap:14px;justify-content:space-between;margin-bottom:26px;padding:4px 2px}.page-header,.page-header-left{align-items:center;display:flex}.page-header-left{gap:16px}.page-icon{align-items:center;background:linear-gradient(135deg,#e0f2f4,#cffafe);border-radius:14px;box-shadow:inset 0 0 0 1px #007c822e,0 4px 12px #007c821a;color:#007c82;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.page-icon svg{height:26px;width:26px}.page-title{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#0f766e,#007c82 50%,#0891b2);-webkit-background-clip:text;background-clip:text;color:#0f172a;display:inline-flex;font-family:var(--font-display);font-size:28px;font-weight:800;gap:10px;letter-spacing:-.025em}.page-subtitle{color:#64748b;font-size:13.5px;font-weight:500;margin-top:6px}.page-action{align-items:center;display:flex;gap:10px}@media (max-width:700px){.page-title{font-size:22px}}.data-table-wrap{background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 8px 24px #0f172a0d;overflow:hidden}.table-toolbar{align-items:center;background:linear-gradient(180deg,#fff,#fafbfc);border-bottom:1px solid #f1f5f9;display:flex;gap:14px;padding:16px 20px}.table-search{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#0f172a;flex:1 1;font-family:inherit;font-size:.88rem;font-weight:500;max-width:320px;padding:10px 14px;transition:all .18s}.table-search::placeholder{color:#94a3b8;font-weight:400}.table-search:hover{border-color:#cbd5e1}.table-search:focus{border-color:var(--primary);box-shadow:0 0 0 4px #007c821f;outline:none}.table-count{font-feature-settings:"tnum";background:#f1f5f9;border-radius:999px;color:#64748b;font-size:.78rem;font-weight:600;margin-left:auto;padding:5px 12px}.table-scroll{overflow-x:auto}.data-table{border-collapse:initial;border-spacing:0;width:100%}.data-table thead th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;color:#475569;font-size:.72rem;font-weight:800;letter-spacing:.06em;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table thead th:first-child{padding-left:22px}.data-table thead th:last-child{padding-right:22px}.data-table tbody td{border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:.9rem;font-weight:500;padding:13px 16px;vertical-align:middle}.data-table tbody td:first-child{padding-left:22px}.data-table tbody td:last-child{padding-right:22px}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover td{background:#f0fafb}.data-table tbody tr:last-child td{border-bottom:none}.empty-row{color:#94a3b8!important;font-size:.92rem;font-weight:500;padding:56px 16px!important;text-align:center!important}.table-loading{align-items:center;background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a;color:#64748b;display:flex;flex-direction:column;font-weight:500;gap:14px;justify-content:center;padding:80px}.spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top:3px solid var(--primary);height:38px;width:38px}@keyframes spin{to{transform:rotate(1turn)}}.modal-overlay{animation:fadeIn .2s ease;background:#00000080}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .2s ease;border-radius:12px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:90vh}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{max-width:420px}.modal-md{max-width:580px}.modal-lg{max-width:800px}.modal-header{border-bottom:1px solid #eee;padding:18px 20px}.modal-header h2{color:var(--dark);font-size:17px;font-weight:600}.modal-close{background:#f5f5f5;border-radius:50%;color:#666;font-size:13px;height:30px;transition:background .2s;width:30px}.modal-close:hover{background:#ffe0e0;color:var(--danger)}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.form-field{margin-bottom:18px}.form-label{color:#1e293b;display:block;font-family:var(--font-display);font-size:.84rem;font-weight:700;letter-spacing:-.005em;padding-bottom:8px}.required{color:var(--danger);margin-left:3px}.form-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-sizing:border-box;color:#0f172a;display:block;font-family:inherit;font-size:.92rem;font-weight:500;padding:10px 14px;transition:all .18s;width:100%}.form-input::placeholder{color:#94a3b8;font-weight:400}.form-input:hover{border-color:#cbd5e1}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #007c821f;outline:none}select.form-input{cursor:pointer}.form-textarea{line-height:1.5;min-height:96px;resize:vertical}.form-error{color:var(--danger);display:block;font-size:.78rem;font-weight:500;margin-top:6px}.form-error-box{background:#fee2e2;border:1px solid #fca5a5;border-radius:10px;color:#b91c1c;font-size:.85rem;font-weight:500;margin-bottom:12px;padding:10px 14px}.form-row{grid-gap:16px 14px;display:grid;gap:16px 14px;grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid #f1f5f9;display:flex;gap:10px;justify-content:flex-end;margin-top:16px;padding-top:16px}.btn{align-items:center;border:none;border-radius:10px;display:inline-flex;font-family:inherit;font-size:.9rem;font-weight:700;gap:8px;letter-spacing:-.005em;padding:10px 22px;transition:all .2s cubic-bezier(.2,.8,.2,1)}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,#007c82,#0891b2);box-shadow:0 4px 12px #007c8240}.btn-primary:hover:not(:disabled){box-shadow:0 6px 18px #007c8259;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5}.btn-secondary{background:#f1f5f9;color:#475569}.btn-secondary:hover{background:#e2e8f0;color:#0f172a}.btn-danger{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 12px #dc262638;color:#fff}.btn-danger:hover{box-shadow:0 6px 18px #dc262652;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 4px 12px #05966938;color:#fff}.btn-success:hover{box-shadow:0 6px 18px #05966952;transform:translateY(-1px)}.btn-sm{border-radius:8px;font-size:.78rem;font-weight:600;padding:7px 12px}.btn-spinner{animation:spin .8s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}.subject-checkboxes{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-top:6px}.checkbox-label{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;display:flex;font-size:.86rem;font-weight:500;gap:8px;padding:8px 12px;transition:all .15s}.checkbox-label:hover{background:#f0fafb;border-color:#007c82}.checkbox-label input[type=checkbox]{accent-color:#007c82}.checkbox-label:has(input:checked){background:#f0fafb;border-color:#007c82;color:#007c82;font-weight:700}.cls-page{margin:0 auto;max-width:1300px;padding:28px}.cls-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:22px}.cls-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f766e,#007c82 50%,#0891b2);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.025em;margin:0}.cls-count{font-feature-settings:"tnum";background:#f1f5f9;border-radius:999px;color:#64748b;font-size:.84rem;font-weight:600;padding:5px 12px}.cls-tabs{border-bottom:1px solid #e2e8f0;display:flex;gap:4px;margin-bottom:22px}.cls-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:var(--font-display);font-size:.92rem;font-weight:700;letter-spacing:-.005em;margin-bottom:-1px;padding:11px 22px;transition:all .15s}.cls-tab:hover{color:#0f172a}.cls-tab.active{border-bottom-color:#007c82;color:#007c82}.cls-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.cls-card{background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a;cursor:pointer;overflow:hidden;padding:18px 16px;position:relative;text-align:center;transition:all .25s cubic-bezier(.2,.8,.2,1)}.cls-card:before{background:linear-gradient(90deg,#0000,#007c82 50%,#0000);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .25s}.cls-card:hover{border-color:#007c82;box-shadow:0 4px 14px #0f172a0f,0 12px 32px #007c8226;transform:translateY(-3px)}.cls-card:hover:before{opacity:1}.cls-card-name{color:#0f172a;font-family:var(--font-display);font-size:1rem;font-weight:800;letter-spacing:-.012em;margin-bottom:6px}.cls-card-count{font-feature-settings:"tnum";color:#475569;font-family:var(--font-display);font-size:.92rem;font-weight:700;margin-bottom:10px}.cls-card-bar{background:#f1f5f9;border-radius:999px;height:6px;margin-bottom:10px;overflow:hidden}.cls-card-fill{border-radius:999px;box-shadow:0 0 6px currentColor;height:100%;opacity:.9;transition:width .35s cubic-bezier(.2,.8,.2,1)}.cls-card-meta{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.cls-badge{border-radius:999px;display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.01em;padding:3px 10px;white-space:nowrap}.cls-badge.green{background:#d1fae5;color:#047857}.cls-badge.orange{background:#fef3c7;color:#b45309}.cls-badge.gray{background:#f1f5f9;color:#64748b}.cls-badge.red{background:#fee2e2;color:#b91c1c}.cls-badge.purple{background:#ede9fe;color:#6d28d9}.cls-back-btn{align-items:center;background:#f1f5f9;border:none;border-radius:12px;color:#475569;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s cubic-bezier(.2,.8,.2,1);width:40px}.cls-back-btn:hover{background:#e2e8f0;color:#0f172a;transform:translateX(-2px)}.cls-table-wrap{background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 8px 24px #0f172a0d;overflow-x:auto}.cls-table{border-collapse:initial;border-spacing:0;font-size:.9rem;width:100%}.cls-table th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;color:#475569;font-size:.72rem;font-weight:800;letter-spacing:.06em;padding:13px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.cls-table td{border-bottom:1px solid #f1f5f9;color:#0f172a;padding:12px;vertical-align:middle}.cls-table tr{transition:background .15s}.cls-table tr:hover td{background:#f0fafb}.cls-table tr.cls-row-out td{background:#fef2f2;color:#94a3b8;text-decoration:line-through}.cls-table tr.cls-row-out .cls-badge{text-decoration:none}@media (max-width:700px){.cls-page{padding:16px}.cls-header h2{font-size:22px}.cls-grid{grid-template-columns:repeat(2,1fr)}}.att-overview{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000d;margin-bottom:18px;padding:18px 20px}.att-overview-title{color:#0f172a;font-size:.96rem;font-weight:700;margin-bottom:12px}.att-overview-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}@media (max-width:720px){.att-overview-grid{grid-template-columns:1fr}}.att-overview-card{border:1.5px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:border-color .15s,box-shadow .15s}.att-overview-card:hover{border-color:var(--c);box-shadow:0 4px 12px color-mix(in srgb,var(--c) 18%,#0000)}.att-overview-head{align-items:center;cursor:pointer;display:flex;gap:10px;padding:12px 14px;-webkit-user-select:none;user-select:none}.att-overview-badge{background:color-mix(in srgb,var(--c) 14%,#fff);border:1px solid color-mix(in srgb,var(--c) 30%,#0000);border-radius:99px;color:var(--c);font-size:.78rem;font-weight:700;padding:4px 10px}.att-overview-count{font-feature-settings:"tnum";color:var(--c);font-size:1.15rem;font-weight:800;margin-left:auto}.att-overview-list{border-top:1px solid #f1f5f9;max-height:260px;overflow-y:auto}.att-overview-item{grid-gap:10px;align-items:center;border-bottom:1px solid #f8fafc;display:grid;font-size:.85rem;gap:10px;grid-template-columns:32px 1fr auto;padding:8px 14px}.att-overview-item:last-child{border-bottom:none}.att-overview-num{color:#94a3b8;font-size:.78rem}.att-overview-name{color:#0f172a;font-weight:600}.att-overview-class{color:#64748b;font-size:.78rem}.att-back-btn{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;height:34px;justify-content:center;margin-right:8px;transition:background .12s,border-color .12s,color .12s;width:34px}.att-back-btn:hover{background:#e0f2f4;border-color:#007c82;color:#007c82}.att-filters{display:flex;gap:20px;margin-bottom:20px}.att-filters .form-field{margin:0;min-width:200px}.att-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.att-toolbar{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:14px 20px}.att-info{color:#555;font-size:14px;font-weight:600}.att-bulk{align-items:center;color:#888;display:flex;font-size:13px;gap:8px}.att-list{max-height:520px;overflow-y:auto}.att-row{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;gap:12px;padding:10px 20px}.att-row:hover{background:#fafafa}.att-num{color:#aaa;flex-shrink:0;font-size:13px;width:28px}.att-name{align-items:center;color:#333;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px}.att-stno{color:#aaa;font-size:12px}.att-statuses{display:flex;flex-wrap:wrap;gap:6px}.att-status-btn{background:#0000;border:1px solid #ddd;border:1px solid var(--status-color,#ddd);border-radius:20px;color:#666;font-size:12px;font-weight:600;padding:5px 12px;transition:all .15s}.att-status-btn.active{background:var(--status-color);color:#fff}.att-status-btn:hover:not(.active){background:color-mix(in srgb,var(--status-color) 15%,#fff)}.att-save-row{align-items:center;border-top:1px solid #f0f0f0;display:flex;gap:14px;justify-content:flex-end;padding:16px 20px}.att-saved{color:var(--success);font-size:14px;font-weight:600}.ttb{display:flex;flex-direction:column;gap:16px}.ttb-tabs{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:6px;padding-bottom:0}.ttb-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:10px 18px}.ttb-tab:hover{color:#1e40af}.ttb-tab.active{border-bottom-color:#1e40af;color:#1e40af}.ttb-conflict-badge{background:#fee2e2;border-radius:6px;color:#b91c1c;font-size:13px;font-weight:600;margin-left:auto;padding:6px 12px}.ttb-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:20px}.ttb-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.ttb-form input,.ttb-form select,.ttb-toolbar select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.ttb-hint{color:#64748b;font-size:13px}.ttb-req-toolbar{align-items:center;display:flex;gap:14px;margin-bottom:16px}.ttb-req-class-name{color:#1e40af;font-size:18px;font-weight:700}.ttb-add-btn{align-items:center;box-shadow:0 2px 8px #1e40af40;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:10px 18px!important}.ttb-add-btn:hover{box-shadow:0 4px 12px #1e40af59}.ttb-class-buttons{border-bottom:2px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;padding-bottom:14px}.ttb-class-btn{align-items:center;background:#fff;border:1.5px solid #cbd5e1;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:7px 14px;transition:all .12s}.ttb-class-btn:hover{background:#eff6ff;border-color:#1e40af}.ttb-class-btn.active{background:#1e40af;border-color:#1e40af;color:#fff}.ttb-cb-badge{background:#f59e0b;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:1px 7px}.ttb-class-btn.active .ttb-cb-badge{background:#fef3c7;color:#92400e}.ttb-form{background:#f8fafc;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:12px}.ttb-form>*{flex:1 1;min-width:140px}.ttb-form button{flex:0 0 auto}.ttb-table{border-collapse:collapse;width:100%}.ttb-table td,.ttb-table th{border-bottom:1px solid #e5e7eb;font-size:14px;padding:10px 12px;text-align:center}.ttb-table th{background:#f8fafc;color:#374151;font-weight:600}.ttb-empty{color:#94a3b8;padding:30px!important;text-align:center!important}.ttb-empty-state{align-items:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;color:#475569;display:flex;flex-direction:column;gap:4px;padding:40px 20px;text-align:center}.ttb-del{background:#fee2e2;border:none;border-radius:4px;color:#b91c1c;cursor:pointer;font-size:16px;height:26px;width:26px}.ttb-del:hover{background:#fca5a5}.ttb-edit{background:#dbeafe;border:none;border-radius:4px;color:#1e40af;cursor:pointer;font-size:14px;height:26px;margin-right:4px;width:26px}.ttb-edit:hover{background:#93c5fd}.ttb-grid{border-collapse:collapse;max-width:700px;width:100%}.ttb-grid td,.ttb-grid th{border:1px solid #e5e7eb;font-size:14px;padding:12px;text-align:center}.ttb-grid th{background:#f1f5f9;font-weight:600}.ttb-ln{background:#f8fafc;font-weight:600;width:60px}.ttb-cell{cursor:pointer;font-size:18px;font-weight:600;-webkit-user-select:none;user-select:none}.ttb-cell.ok{background:#dcfce7;color:#16a34a}.ttb-cell.blocked{background:#fee2e2;color:#dc2626}.ttb-cell:hover{filter:brightness(.92)}.ttb-gen-toolbar{flex-wrap:wrap;gap:10px;margin-bottom:16px}.ttb-check,.ttb-gen-toolbar{align-items:center;display:flex}.ttb-check{color:#374151;font-size:14px;gap:6px}.ttb-class-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.ttb-class-card{align-items:center;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:12px;transition:all .15s}.ttb-class-card:hover{border-color:#93c5fd}.ttb-class-card.sel{background:#eff6ff;border-color:#1e40af}.ttb-cc-name{color:#111827;font-weight:600}.ttb-cc-meta{color:#64748b;font-size:12px}.ttb-result{background:#f0f9ff;border-left:3px solid #0284c7;border-radius:6px;font-size:14px;margin-top:16px;padding:14px}.ttb-failed{color:#b45309;font-size:13px;margin:8px 0 0 18px}.ttb-mode{border:1px solid #d1d5db;border-radius:6px;display:flex;overflow:hidden}.ttb-mode button{background:#fff;border:none;border-right:1px solid #d1d5db;cursor:pointer;font-size:14px;padding:8px 16px}.ttb-mode button:last-child{border-right:none}.ttb-mode button.on{background:#1e40af;color:#fff}.ttb-view{max-width:none}.ttb-vcell{height:80px;min-width:140px;padding:6px!important;vertical-align:top}.ttb-vcell.filled{background:#eff6ff}.ttb-vcell.conflict{background:#fee2e2!important}.ttb-vs{color:#111827;font-size:13px;font-weight:600}.ttb-vc,.ttb-vr,.ttb-vt{color:#64748b;font-size:11px;margin-top:2px}.ttb-vcontent{border-radius:4px;cursor:grab;padding:4px}.ttb-vcontent:active{cursor:grabbing}.ttb-vcontent:hover{background:#1e40af14}.ttb-vcell.droptarget{background:#fef3c7!important;outline:2px dashed #f59e0b}.ttb-hint-msg{animation:ttb-fadein .2s;background:#dbeafe;border-radius:6px;color:#1e40af;font-size:13px;font-weight:500;padding:6px 12px}@keyframes ttb-fadein{0%{opacity:0}to{opacity:1}}.btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px}.btn:hover{background:#f8fafc}.btn-primary{background:#1e40af;border-color:#1e40af}.btn-primary:hover{background:#1e3a8a}.btn-primary:disabled{background:#94a3b8}.ttb-master-wrap{border:1px solid #cbd5e1;border-radius:6px;max-height:75vh;max-width:100%;overflow:auto}.ttb-master{border-collapse:collapse;font-size:9px}.ttb-master td,.ttb-master th{border:1px solid #cbd5e1;padding:0;text-align:center;vertical-align:middle}.ttb-master thead th{background:#f1f5f9;font-weight:600;padding:3px 1px;position:sticky;top:0;z-index:2}.ttb-master-day{border-bottom:2px solid #64748b!important;font-size:10px}.ttb-master-lh{color:#475569;font-size:9px;font-weight:500;max-width:26px;min-width:26px}.ttb-master-corner{background:#1e40af!important;color:#fff;font-size:11px;font-weight:700;z-index:4!important}.ttb-master-cls,.ttb-master-corner{left:0;max-width:64px;min-width:64px;position:sticky}.ttb-master-cls{background:#f8fafc;border-right:2px solid #64748b!important;font-size:10px;font-weight:600;overflow:hidden;padding:2px 6px!important;text-align:left!important;text-overflow:ellipsis;white-space:nowrap;z-index:1}.ttb-master-cell{cursor:pointer;height:30px;max-width:26px;min-width:26px;width:26px}@media (min-width:1400px){.ttb-master-cell,.ttb-master-lh{max-width:32px;min-width:32px;width:32px}.ttb-master{font-size:10px}}.ttb-master-cell.conflict{outline:2px solid #dc2626;outline-offset:-2px}.ttb-master-cell.empty-clickable:hover{background:#dbeafe;cursor:cell}.ttb-modal-bg{align-items:center;background:#0f172a8c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.ttb-modal{background:#fff;border-radius:10px;box-shadow:0 10px 40px #00000040;max-width:440px;min-width:360px}.ttb-modal-head{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;font-size:16px;padding:14px 18px}.ttb-modal-x{background:none;border:none;color:#64748b;cursor:pointer;font-size:24px;line-height:1;margin-left:auto}.ttb-modal-body{display:flex;flex-direction:column;gap:6px;padding:16px 18px}.ttb-modal-body label{color:#374151;font-size:13px;font-weight:500;margin-top:6px}.ttb-modal-body select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.ttb-modal-meta{background:#f1f5f9;border-radius:6px;color:#475569;font-size:13px;margin-bottom:6px;padding:8px 12px}.ttb-modal-foot{border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end;padding:12px 18px}.ttb-modal.asc{animation:ttb-modal-in .18s ease-out;border-radius:14px;box-shadow:0 25px 60px #0f172a47;max-width:95vw;overflow:hidden;padding:0;width:560px}@keyframes ttb-modal-in{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.ttb-modal-head.asc{align-items:center;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;font-size:16px;font-weight:600;letter-spacing:.2px;padding:18px 24px}.ttb-modal-head.asc .ttb-modal-x{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:22px;height:28px;justify-content:center;opacity:.85;transition:background .15s;width:28px}.ttb-modal-head.asc .ttb-modal-x:hover{background:#ffffff2e;opacity:1}.ttb-modal-body.asc{background:#fff;display:flex;flex-direction:column;gap:14px;padding:20px 24px}.asc-row{gap:14px;padding:0}.asc-icon,.asc-row{align-items:center;border:none;display:flex}.asc-icon{background:#eff6ff;border-radius:10px;color:#1e40af;flex-shrink:0;font-size:18px;height:38px;justify-content:center;width:38px}.asc-field{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0}.asc-field.narrow{flex:0 0 150px}.asc-field label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.asc-field input,.asc-field select{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#0f172a;font-size:14px;padding:9px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.asc-field input:focus,.asc-field select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f;outline:none}.asc-field input:disabled,.asc-field select:disabled{background:#f8fafc;color:#475569;cursor:not-allowed}.asc-slot-info{background:#f0f9ff;border-left:3px solid #0284c7;border-radius:8px;color:#0369a1;font-size:13px;font-weight:500;margin:8px 0 0;padding:10px 14px}.ttb-modal-foot.asc{align-items:center;background:#f8fafc;border-top:1px solid #e5e7eb;display:flex;gap:10px;padding:14px 24px}.ttb-modal-foot.asc .btn{border-radius:8px;font-weight:600;padding:9px 22px}.asc-help{align-items:center;background:#fff;border:1.5px solid #cbd5e1;border-radius:50%;color:#64748b;cursor:help;display:flex;font-size:14px;font-weight:700;height:30px;justify-content:center;transition:all .15s;width:30px}.asc-help:hover{border-color:#3b82f6;color:#3b82f6}.ttb-div-big-btn{align-items:center;background:#eff6ff!important;border:1.5px dashed #93c5fd!important;border-radius:8px!important;color:#1e40af!important;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:10px 16px!important;transition:all .15s}.ttb-div-big-btn:hover{background:#1e40af!important;border-color:#1e40af!important;border-style:solid!important;color:#fff!important}.ttb-div-modal-bg{z-index:1100!important}.ttb-div-modal{max-width:96vw;width:900px!important}.ttb-div-body{padding:0!important}.ttb-div-two-col{display:grid;grid-template-columns:1fr 1fr;min-height:440px}.ttb-div-left{border-right:1px solid #e5e7eb;gap:10px;overflow-y:auto}.ttb-div-left,.ttb-div-right{display:flex;flex-direction:column;max-height:70vh;padding:16px 20px}.ttb-div-right{background:#fafbfc;overflow:hidden}.ttb-div-info{background:#f0f9ff;border-left:3px solid #0284c7;border-radius:6px;color:#0369a1;font-size:13px;line-height:1.5;padding:10px 14px}.ttb-div-empty{color:#94a3b8;font-size:14px;padding:30px;text-align:center}.ttb-div-section{margin-top:4px}.ttb-div-section-title{color:#64748b;font-size:11px;font-weight:700;letter-spacing:.5px;margin:10px 0 6px;text-transform:uppercase}.ttb-div-chips{display:flex;flex-wrap:wrap;gap:8px}.ttb-div-chip{align-items:center;background:#dcfce7;border:1.5px solid #86efac;border-radius:8px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 4px 6px 12px;transition:all .12s}.ttb-div-chip:hover{background:#bbf7d0;transform:translateY(-1px)}.ttb-div-chip.active{background:#1e40af;border-color:#1e40af}.ttb-div-chip.active .ttb-div-chip-badge,.ttb-div-chip.active .ttb-div-chip-name{color:#fff}.ttb-div-chip-name{color:#166534;font-weight:600}.ttb-div-chip-badge{background:#fff;border-radius:10px;color:#166534;font-size:11px;font-weight:700;min-width:18px;padding:1px 7px;text-align:center}.ttb-div-chip.active .ttb-div-chip-badge{background:#bfdbfe;color:#1e40af}.ttb-div-chip-del{background:none;border:none;color:#dc2626;cursor:pointer;font-size:16px;line-height:1;padding:0 6px}.ttb-div-chip.active .ttb-div-chip-del{color:#fca5a5}.ttb-div-chip-del:hover{color:#991b1b}.ttb-div-add{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:6px;margin-top:auto;padding-top:12px}.ttb-div-add input{border:1.5px solid #e2e8f0;border-radius:6px;flex:1 1;font-size:12px;min-width:0;padding:7px 10px}.ttb-div-add input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f;outline:none}.ttb-div-right-head{align-items:center;border-bottom:1px solid #e5e7eb;color:#374151;display:flex;font-size:13px;margin-bottom:10px;padding-bottom:10px}.ttb-div-count{background:#1e40af;border-radius:10px;color:#fff;font-size:12px;font-weight:700;margin-left:auto;padding:3px 10px}.ttb-div-students{display:flex;flex:1 1;flex-direction:column;gap:3px;overflow-y:auto;padding-right:4px}.ttb-div-student{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:7px 10px;transition:all .1s}.ttb-div-student:hover{background:#eff6ff;border-color:#93c5fd}.ttb-div-student.on{background:#dbeafe;border-color:#3b82f6}.ttb-div-st-name{color:#111827;flex:1 1}.ttb-div-st-meta{color:#64748b;font-size:14px}.ttb-div-right-foot{border-top:1px solid #e5e7eb;display:flex;gap:8px;margin-top:10px;padding-top:10px}.ttb-div-right-foot .btn{flex:1 1;font-size:12px;padding:8px}.ttb-div-right-foot .btn-primary{flex:2 1}.ttb-master-cell.droptarget{background:#fef3c7!important;outline:2px dashed #f59e0b;outline-offset:-2px}.ttb-master-content{cursor:grab;line-height:1.1;padding:2px 1px}.ttb-master-content:active{cursor:grabbing}.ttb-mc-subj{color:#111827;font-size:10px;font-weight:700}.ttb-mc-tea{color:#475569;font-size:9px}.ttb-master tbody td:nth-child(10),.ttb-master tbody td:nth-child(18),.ttb-master tbody td:nth-child(26),.ttb-master tbody td:nth-child(34),.ttb-master thead tr:nth-child(2) th:nth-child(17),.ttb-master thead tr:nth-child(2) th:nth-child(25),.ttb-master thead tr:nth-child(2) th:nth-child(33),.ttb-master thead tr:nth-child(2) th:nth-child(9){border-left:2px solid #64748b}@media print{.ttb-conflict-badge,.ttb-tabs,.ttb-toolbar{display:none}.ttb-section{box-shadow:none;padding:0}}.ann-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.ann-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:18px}.ann-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.ann-role{border-radius:20px;font-size:11px;font-weight:700;padding:3px 10px;text-transform:uppercase}.ann-all{background:#e8f0fe;color:#3d82f4}.ann-student{background:#e8f8ee;color:#27ae60}.ann-teacher{background:#fff4e0;color:#f39c12}.ann-parent{background:#fdecea;color:#e74c3c}.ann-card-title{color:#222;font-size:16px;font-weight:700;margin-bottom:8px}.ann-card-content{color:#555;font-size:13.5px;line-height:1.5;white-space:pre-wrap}.ann-card-footer{border-top:1px solid #f0f0f0;color:#aaa;display:flex;font-size:12px;justify-content:space-between;margin-top:12px;padding-top:10px}.req-page{max-width:1180px;padding:28px 32px}.req-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.req-header h2{color:#111827;font-size:1.4rem;font-weight:700;margin:0 0 2px}.req-count{color:#9ca3af;font-size:.82rem}.req-header-modern{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #eef2f6;border-radius:16px;box-shadow:0 1px 2px #0f172a0a;margin-bottom:22px;padding:22px 26px}.req-header-text h2{color:#0f172a;font-size:1.55rem;font-weight:800;letter-spacing:-.01em;margin:0 0 4px}.req-subtitle{color:#64748b;font-size:.88rem;margin:0}.req-header-stat{align-items:flex-end;background:linear-gradient(135deg,#ecfeff,#cffafe);border:1px solid #a5f3fc;border-radius:12px;display:flex;flex-direction:column;padding:10px 18px}.req-header-stat-num{color:#0e7490;font-size:1.6rem;font-weight:800;line-height:1}.req-header-stat-lbl{color:#0e7490;font-size:.72rem;font-weight:600;letter-spacing:.05em;margin-top:4px;text-transform:uppercase}.req-filters{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.req-filters select{background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:7px 10px}.filter-check,.req-filters select{color:#374151;cursor:pointer;font-size:.85rem}.filter-check{align-items:center;display:flex;gap:5px}.req-loading{color:#6b7280;padding:32px;text-align:center}.req-back-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;padding:6px 8px}.req-back-btn:hover{background:#e5e7eb}.dept-cards-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.dept-req-card{--dept-color:#0d9488;--dept-soft:#ccfbf1;--dept-tint:#f0fdfa;align-items:flex-start;background:#fff;border:1px solid #eef2f6;border-radius:16px;box-shadow:0 1px 2px #0f172a08;cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:20px 22px 20px 26px;position:relative;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.dept-req-card:hover{border-color:var(--dept-color);box-shadow:0 10px 24px -10px color-mix(in srgb,var(--dept-color) 45%,#0000),0 4px 8px #0f172a0a;transform:translateY(-3px)}.dept-req-accent{background:var(--dept-color);border-radius:4px 0 0 4px;bottom:0;left:0;opacity:.85;position:absolute;top:0;width:4px}.dept-req-icon{align-items:center;background:var(--dept-tint);border-radius:12px;color:var(--dept-color);display:flex;flex-shrink:0;height:48px;justify-content:center;transition:background .18s ease;width:48px}.dept-req-card:hover .dept-req-icon{background:var(--dept-soft)}.dept-req-info{flex:1 1;min-width:0}.dept-req-name{color:#0f172a;font-size:1rem;font-weight:700;letter-spacing:-.005em}.dept-req-desc{color:#64748b;font-size:.78rem;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dept-req-pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.dept-pill{align-items:center;background:#f1f5f9;border-radius:999px;color:#64748b;display:inline-flex;font-size:.72rem;font-weight:600;gap:5px;padding:3px 9px;white-space:nowrap}.dept-pill-req.on{background:var(--dept-tint);color:var(--dept-color)}.dept-pill-dot{background:#cbd5e1;border-radius:50%;height:6px;width:6px}.dept-pill-req.on .dept-pill-dot{background:var(--dept-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--dept-color) 18%,#0000)}.dept-req-arrow{align-items:center;align-self:center;color:#cbd5e1;display:flex;flex-shrink:0;justify-content:center;transition:transform .18s ease,color .18s ease}.dept-req-card:hover .dept-req-arrow{color:var(--dept-color);transform:translateX(3px)}.req-empty{color:#9ca3af;font-size:.95rem;padding:48px;text-align:center}.ticket-list{display:flex;flex-direction:column;gap:8px}.ticket-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;padding:14px 16px;transition:box-shadow .15s,border-color .15s}.ticket-card:hover{border-color:#007c82;box-shadow:0 4px 14px #00000014}.ticket-card.sla-breach{border-left:3px solid #ef4444}.ticket-top{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:5px}.ticket-num{color:#6b7280;font-family:monospace;font-size:.72rem;font-weight:700}.ticket-dept{background:#e0f2f4;color:#007c82}.ticket-dept,.ticket-status{border-radius:99px;font-size:.72rem;font-weight:700;padding:2px 9px}.ticket-title{color:#111827;font-size:.92rem;font-weight:600;margin-bottom:5px}.ticket-meta{color:#9ca3af;display:flex;flex-wrap:wrap;font-size:.75rem;gap:12px}.sla-badge{border-radius:99px;font-size:.7rem;font-weight:700;padding:2px 8px}.sla-badge.breached{background:#fee2e2;color:#dc2626}.sla-badge.warning{background:#fef3c7;color:#d97706}.live-timer{color:#0369a1;font-family:monospace;font-weight:700}.btn-primary{font-weight:600;transition:background .15s}.btn-primary.sm{font-size:.82rem;padding:6px 14px}.btn-cancel{background:#f3f4f6;border:none;border-radius:8px;color:#374151;cursor:pointer;font-size:.88rem;padding:8px 18px}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #00000038;max-height:92vh;max-width:540px;overflow-y:auto;width:100%}.modal.modal-xl{max-width:860px}.modal-hdr{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:18px 22px 14px}.modal-hdr h3{color:#111827;font-size:1.05rem;margin:0}.modal-hdr button{background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;font-size:1.1rem;padding:2px 6px}.modal-body{display:flex;flex-direction:column;gap:10px;padding:18px 22px}.modal-body label{color:#374151;font-size:.83rem;font-weight:600;margin-bottom:-4px}.modal-body input,.modal-body select,.modal-body textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:.88rem;padding:8px 11px;width:100%}.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{border-color:#007c82;outline:none}.modal-body textarea{resize:vertical}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:6px}.it-fields{background:#f0fafb;border:1px solid #b2e0e2;border-radius:10px;display:flex;flex-direction:column;gap:8px;padding:14px 16px}.it-fields-title{color:#007c82;font-size:.82rem;font-weight:700;margin-bottom:2px}.it-fields label{color:#374151;font-size:.82rem;font-weight:600}.it-fields input,.it-fields select,.it-fields textarea{border:1px solid #d1d5db;border-radius:7px;box-sizing:border-box;font-family:inherit;font-size:.85rem;padding:7px 10px;width:100%}.priority-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.priority-opt{border:1.5px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:8px 10px;text-align:center;transition:border-color .15s}.priority-opt input{display:none}.priority-opt span{font-size:.82rem;font-weight:700}.priority-opt small{color:#9ca3af;font-size:.7rem}.priority-opt.sel{background:#e0f2f4;border-color:#007c82}.detail-hdr{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;gap:12px;justify-content:space-between;padding:16px 20px 10px}.detail-hdr-left{flex:1 1}.detail-hdr-left h3{color:#111827;font-size:1rem;margin:4px 0 0}.detail-hdr-right{align-items:center;display:flex;flex-shrink:0;gap:10px}.ticket-status.lg{font-size:.8rem;padding:4px 12px}.btn-close-x{background:#f3f4f6;border:none;border-radius:7px;color:#374151;cursor:pointer;font-size:.85rem;padding:5px 10px}.detail-actions{align-items:center;background:#f9fafb;border-bottom:1px solid #f0f2f5;display:flex;flex-wrap:wrap;gap:8px;padding:10px 20px}.act-btn{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.82rem;font-weight:600;padding:7px 14px;transition:opacity .15s}.act-btn.start{background:#0369a1}.act-btn.resolve{background:#059669}.act-btn.assign{background:#7c3aed}.act-btn.rate{background:#d97706}.act-btn:hover{opacity:.88}.detail-timer{background:#e0f2fe;border-radius:8px;color:#0369a1;font-size:.82rem;font-weight:600;padding:5px 12px}.detail-timer.done{background:#d1fae5;color:#059669}.detail-rating-display{align-items:center;display:flex;gap:8px}.rating-note{color:#6b7280;font-size:.8rem;font-style:italic}.detail-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:2px;padding:0 20px}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:.85rem;font-weight:500;padding:10px 14px}.tab-btn.active{border-bottom-color:#007c82;color:#007c82;font-weight:700}.detail-body{max-height:360px;overflow-y:auto;padding:18px 20px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.info-left,.info-right{display:flex;flex-direction:column;gap:12px}.info-section{grid-gap:4px 12px;align-items:start;display:grid;gap:4px 12px;grid-template-columns:auto 1fr}.info-section label{color:#9ca3af;font-size:.78rem;font-weight:600;padding-top:1px;text-transform:uppercase;white-space:nowrap}.info-section span{color:#111827;font-size:.88rem}.it-section{background:#f0fafb;border:1px solid #b2e0e2;border-radius:8px;padding:10px 12px}.section-title{color:#007c82;font-size:.78rem;font-weight:700;grid-column:1/-1;margin-bottom:6px;text-transform:uppercase}.mono{background:#f3f4f6;border-radius:4px;font-size:.85rem;padding:2px 6px}.error-text,.mono{font-family:monospace}.error-text{background:#fee2e2;border-radius:6px;color:#dc2626;font-size:.8rem;padding:4px 8px;white-space:pre-wrap}.desc-box,.resolution-box{border-radius:8px;padding:12px 14px}.desc-box{background:#f9fafb;border:1px solid #e5e7eb}.resolution-box{background:#ecfdf5;border:1px solid #6ee7b7;border-left:3px solid #059669}.desc-box p,.resolution-box p{color:#374151;font-size:.88rem;margin:6px 0 0;white-space:pre-wrap}.text-red{color:#dc2626!important}.comments-wrap{gap:12px}.comments-list,.comments-wrap{display:flex;flex-direction:column}.comments-list{gap:8px;max-height:200px;overflow-y:auto}.comment-item{background:#f9fafb;border-radius:8px;font-size:.85rem;padding:10px 12px}.comment-item.internal{background:#fef3c7;border-left:3px solid #f59e0b}.comment-meta{align-items:center;display:flex;gap:8px;margin-bottom:4px}.comment-meta strong{color:#111827;font-size:.82rem}.comment-time{color:#9ca3af;font-size:.72rem;margin-left:auto}.internal-tag{background:#f59e0b;border-radius:99px;color:#fff;font-size:.68rem;font-weight:700;padding:1px 6px}.comment-item p{color:#374151;margin:0}.empty-note{color:#9ca3af;font-size:.85rem;padding:16px 0;text-align:center}.comment-form textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:.87rem;padding:8px 11px;resize:vertical;width:100%}.comment-form-footer{align-items:center;display:flex;justify-content:space-between;margin-top:8px}.internal-chk{align-items:center;color:#92400e;cursor:pointer;display:flex;font-size:.82rem;gap:5px}.audit-list{display:flex;flex-direction:column;gap:0}.audit-item{border-bottom:1px solid #f3f4f6;display:flex;gap:12px;padding:8px 0}.audit-dot{background:#007c82;border-radius:50%;flex-shrink:0;height:8px;margin-top:5px;width:8px}.audit-content{align-items:center;display:flex;flex-wrap:wrap;font-size:.8rem;gap:4px 10px}.audit-user{color:#111827;font-weight:700}.audit-action{color:#007c82;font-weight:600}.audit-change{color:#6b7280;font-style:italic}.audit-note{color:#374151;flex-basis:100%}.audit-time{color:#9ca3af;font-size:.72rem;margin-left:auto}.sub-panel{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;gap:10px;margin:0 20px 20px;padding:16px}.sub-panel-hdr{align-items:center;display:flex;justify-content:space-between}.sub-panel-hdr h4{color:#111827;font-size:.9rem;margin:0}.sub-panel-hdr button{background:#e5e7eb;border:none;border-radius:6px;cursor:pointer;padding:2px 8px}.sub-panel label{color:#374151;font-size:.82rem;font-weight:600}.sub-panel input,.sub-panel select,.sub-panel textarea{border:1px solid #d1d5db;border-radius:7px;box-sizing:border-box;font-family:inherit;font-size:.87rem;padding:7px 10px;width:100%}.stars{display:flex;gap:4px}.star{background:none;border:none;color:#d1d5db;cursor:pointer;font-size:1.8rem;line-height:1;padding:0;transition:color .1s}.star.filled{color:#f59e0b}.rate-section{align-items:center;display:flex;flex-direction:column;gap:8px;padding:8px 0}.rate-section p{color:#374151;font-size:.88rem;margin:0}.rate-labels{color:#9ca3af;display:flex;font-size:.72rem;justify-content:space-between;width:100%}@media (max-width:760px){.req-page{padding:0}.req-header-modern{border-radius:14px!important;gap:10px;margin-bottom:12px;padding:14px 16px!important}.req-header-text h2{font-size:1.15rem!important;line-height:1.15}.req-subtitle{font-size:.78rem;line-height:1.3;margin-top:2px}.req-header-stat{border-radius:12px!important;flex-shrink:0;min-width:76px;padding:10px 14px!important}.req-header-stat-num{font-size:1.3rem!important}.req-header-stat-lbl{font-size:.6rem!important;line-height:1.1}.dept-cards-grid{gap:10px!important}.dept-req-card{border-radius:14px!important;gap:12px!important;padding:12px!important}.dept-req-icon{border-radius:10px!important;height:42px!important;min-width:42px;width:42px!important}.dept-req-icon svg{height:20px!important;width:20px!important}.dept-req-name{font-size:.95rem!important}.dept-req-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:.76rem!important;line-height:1.3;overflow:hidden;white-space:normal!important}.dept-req-pills{flex-wrap:wrap;gap:5px!important;margin-top:6px!important}.dept-pill{font-size:.7rem!important;padding:3px 8px!important}.dept-req-arrow{display:none!important}.dept-req-accent{width:4px!important}.req-actions,.req-filters,.req-toolbar{flex-wrap:wrap!important;gap:8px!important}.req-filters>*,.req-toolbar>*{flex:1 1 auto;min-width:130px}.ticket-card,.ticket-row{flex-wrap:wrap!important;gap:8px!important;padding:12px!important}.modal.req-modal,.req-detail-modal{border-radius:0!important;height:100vh;max-height:100vh;max-width:100%!important;width:100%!important}.req-tabs,.tabs-row{-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;overflow-x:auto;white-space:nowrap}}@media (max-width:380px){.req-header-text h2{font-size:1.05rem!important}.req-header-stat-num{font-size:1.15rem!important}.dept-req-icon{height:38px!important;min-width:38px;width:38px!important}.dept-req-name{font-size:.9rem!important}}.lr-list{display:flex;flex-direction:column;gap:8px}.lr-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:box-shadow .15s,border-color .15s}.lr-card:hover{border-color:#007c82;box-shadow:0 4px 14px #00000014}.lr-card-left{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.lr-card-name{color:#111827;font-size:.88rem;font-weight:600}.lr-card-sub{color:#9ca3af;font-size:.74rem;margin-top:2px}.lr-pulse-dot{animation:lr-pulse 1.4s ease-in-out infinite;background:#d97706;border-radius:50%;display:inline-block;height:8px;width:8px}@keyframes lr-pulse{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.lr-waiting-tag{color:#d97706;font-weight:700}.lr-card-mid{align-items:center;display:flex;flex-direction:column;gap:3px;min-width:160px}.lr-dates{color:#374151;font-size:.78rem;font-weight:500}.lr-days{color:#9ca3af;font-size:.72rem}.lr-card-right{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.lr-steps{gap:0;justify-content:center;margin-bottom:20px;padding:16px 0 10px}.lr-step,.lr-steps{align-items:center;display:flex}.lr-step{flex-direction:column;gap:5px;min-width:70px}.lr-step-icon{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:50%;color:#9ca3af;display:flex;font-size:1rem;font-weight:700;height:36px;justify-content:center;width:36px}.lr-step.done .lr-step-icon{background:#d1fae5;border-color:#059669;color:#059669}.lr-step.active .lr-step-icon{animation:pulse 2s infinite;background:#e0f2f4;border-color:#007c82;color:#007c82}.lr-step.rejected .lr-step-icon{background:#fee2e2;border-color:#dc2626;color:#dc2626}.lr-step.pending .lr-step-icon{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af}.lr-step-label{color:#9ca3af;font-size:.68rem;font-weight:600;white-space:nowrap}.lr-step.done .lr-step-label{color:#059669}.lr-step.active .lr-step-label{color:#007c82}.lr-step.rejected .lr-step-label{color:#dc2626}.lr-step-line{background:#e5e7eb;flex:1 1;height:2px;margin-bottom:20px;min-width:24px}.lr-step-line.done{background:#059669}@keyframes pulse{0%,to{box-shadow:0 0 0 0 #007c824d}50%{box-shadow:0 0 0 6px #007c8200}}.lr-detail-grid{grid-gap:10px 16px;display:grid;gap:10px 16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.lr-detail-section{display:flex;flex-direction:column;gap:3px}.lr-detail-label{color:#9ca3af;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.lr-detail-val{color:#111827;font-size:.88rem}.lr-history{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.lr-history-item{align-items:flex-start;border-radius:8px;display:flex;font-size:.84rem;gap:10px;padding:10px 12px}.lr-history-item.approved{background:#f0fdf4;border:1px solid #6ee7b7}.lr-history-item.rejected{background:#fff1f2;border:1px solid #fca5a5}.lr-history-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.7rem;font-weight:700;height:22px;justify-content:center;width:22px}.lr-history-item.approved .lr-history-icon{background:#059669;color:#fff}.lr-history-item.rejected .lr-history-icon{background:#dc2626;color:#fff}.lr-history-date{color:#9ca3af;font-size:.72rem;margin-left:auto;white-space:nowrap}.lr-action-panel{background:#f0fafb;border:1px solid #b2e0e2;border-radius:10px;display:flex;flex-direction:column;gap:10px;margin-top:10px;padding:16px}.lr-action-title{color:#007c82;font-size:.85rem;font-weight:700}.lr-final-summary{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;display:flex;font-size:.85rem;gap:10px;padding:10px 14px}.hr-panel-v2{background:linear-gradient(180deg,#f0fafb,#fff);border:1px solid #007c822e;border-radius:14px;box-shadow:0 4px 18px #007c820f;display:flex;flex-direction:column;gap:14px;margin-top:14px;padding:18px 20px}.hr-panel-header{align-items:center;border-bottom:1px solid #d1f5f7;display:flex;gap:12px;padding-bottom:12px}.hr-panel-title{color:#007c82;font-family:var(--font-display);font-size:1.05rem;font-weight:800;letter-spacing:-.012em}.hr-panel-sub{color:#475569;font-size:.78rem;margin-top:1px}.hr-block{display:flex;flex-direction:column;gap:8px}.hr-block-label{color:#1e293b;font-family:var(--font-display);font-size:.86rem;font-weight:700;letter-spacing:-.005em}.hr-required{color:#dc2626;margin-left:4px}.hr-decision-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.hr-decision-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:14px 16px;position:relative;transition:all .2s cubic-bezier(.2,.8,.2,1)}.hr-decision-card:hover{border-color:#007c82;border-color:var(--c,#007c82);transform:translateY(-1px)}.hr-decision-card.sel{background:color-mix(in srgb,var(--c) 8%,#fff);border-color:var(--c);box-shadow:0 0 0 4px color-mix(in srgb,var(--c) 14%,#0000),0 4px 14px color-mix(in srgb,var(--c) 22%,#0000)}.hr-decision-name{color:#0f172a;font-family:var(--font-display);font-size:.96rem;font-weight:800}.hr-decision-card.sel .hr-decision-name{color:var(--c)}.hr-decision-desc{color:#64748b;font-size:.74rem}.hr-decision-check{align-items:center;background:var(--c);border-radius:50%;color:#fff;display:flex;font-size:.78rem;font-weight:800;height:22px;justify-content:center;position:absolute;right:10px;top:10px;width:22px}.hr-disc-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.hr-disc-target{color:#64748b;font-size:.74rem;font-weight:700;letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.hr-disc-pills{display:flex;flex-wrap:wrap;gap:5px}.hr-disc-pill{background:#fff;border:1.5px solid #e2e8f0;border-radius:999px;color:#475569;cursor:pointer;font-size:.76rem;font-weight:700;padding:6px 11px;transition:all .15s}.hr-disc-pill:hover{border-color:#94a3b8;border-color:var(--c,#94a3b8)}.hr-disc-pill.sel{background:color-mix(in srgb,var(--c) 14%,#fff);border-color:var(--c);box-shadow:0 0 0 3px color-mix(in srgb,var(--c) 18%,#0000);color:var(--c)}.hr-note-input{border:1.5px solid #e2e8f0;border-radius:10px;box-sizing:border-box;color:#0f172a;font-family:inherit;font-size:.9rem;min-height:70px;padding:10px 12px;resize:vertical;transition:all .15s;width:100%}.hr-note-input:focus{border-color:#007c82;box-shadow:0 0 0 4px #007c821f;outline:none}.hr-note-input::placeholder{color:#94a3b8}.hr-preview{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:12px;padding:12px 14px}.hr-preview-title{color:#92400e;font-family:var(--font-display);font-size:.78rem;font-weight:800;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}.hr-preview-row{color:#475569;display:flex;font-size:.86rem;justify-content:space-between;padding:3px 0}.hr-preview-note{border-top:1px dashed #fcd34d;color:#78350f;font-size:.84rem;font-style:italic;margin-top:6px;padding-top:6px}.hr-action-row{border-top:1px solid #d1f5f7;display:flex;gap:10px;justify-content:flex-end;padding-top:8px}.hr-send-btn{background:linear-gradient(135deg,#059669,#10b981)!important;box-shadow:0 4px 14px #0596694d!important}.hr-send-btn:hover:not(:disabled){box-shadow:0 6px 20px #05966966!important}.hr-send-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:600px){.hr-decision-grid,.hr-disc-grid{grid-template-columns:1fr}}.proc-page{max-width:1200px;padding:24px}.proc-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.proc-header h2{color:#111827;font-size:1.4rem;font-weight:700;margin:0 0 2px}.proc-count{color:#9ca3af;font-size:.82rem}.proc-filters{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.proc-filters select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:.85rem;padding:7px 10px}.proc-list{display:flex;flex-direction:column;gap:8px}.proc-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;padding:14px 16px;transition:box-shadow .15s,border-color .15s}.proc-card:hover{border-color:#007c82;box-shadow:0 4px 14px #00000014}.proc-card-top{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.proc-num{color:#6b7280;font-family:monospace}.proc-num,.proc-type{font-size:.72rem;font-weight:700}.proc-type{border-radius:99px;padding:2px 9px}.proc-type.purchase{background:#fef3c7;color:#d97706}.proc-type.warehouse{background:#e0f2f4;color:#007c82}.proc-status{border-radius:99px;font-size:.72rem;font-weight:700;padding:2px 9px}.proc-card-dept{color:#111827;font-size:.85rem;font-weight:600;margin-bottom:4px}.proc-card-meta{color:#9ca3af;display:flex;flex-wrap:wrap;font-size:.75rem;gap:12px}.roadmap{display:flex;flex-direction:column;gap:0;padding:8px 0}.roadmap-step{display:flex;gap:14px;min-height:48px}.roadmap-step:last-child .roadmap-line{display:none}.roadmap-line-wrap{flex-direction:column}.roadmap-dot,.roadmap-line-wrap{align-items:center;display:flex;flex-shrink:0;width:32px}.roadmap-dot{background:#fff;border:2.5px solid #e5e7eb;border-radius:50%;color:#9ca3af;font-size:.75rem;font-weight:700;height:32px;justify-content:center;transition:all .3s;z-index:1}.roadmap-dot.done{background:#059669;border-color:#059669;color:#fff;font-size:.85rem}.roadmap-dot.active{animation:roadmap-pulse 2s infinite;border-color:#007c82;box-shadow:0 0 0 4px #007c8226;color:#007c82}.roadmap-dot.rejected{background:#dc2626;border-color:#dc2626;color:#fff}.roadmap-icon{font-size:.9rem}@keyframes roadmap-pulse{0%,to{box-shadow:0 0 0 4px #007c8226}50%{box-shadow:0 0 0 8px #007c8200}}.roadmap-line{background:#e5e7eb;flex:1 1;margin:2px 0;min-height:16px;width:2.5px}.roadmap-line.done{background:#059669}.roadmap-content{flex:1 1;padding:4px 0 14px}.roadmap-label{color:#111827;font-size:.85rem;font-weight:700}.roadmap-step.done .roadmap-label{color:#059669}.roadmap-step.active .roadmap-label{color:#007c82}.roadmap-step.rejected .roadmap-label{color:#dc2626}.roadmap-desc{color:#6b7280;font-size:.75rem;margin-top:1px}.roadmap-step.done .roadmap-desc{color:#059669}.roadmap-date{color:#9ca3af;font-size:.7rem;margin-top:2px}.roadmap-note{background:#f9fafb;border-left:3px solid #007c82;border-radius:6px;color:#374151;font-size:.75rem;margin-top:4px;padding:4px 8px}.mini-track{gap:0;margin-top:8px}.mini-dot,.mini-track{align-items:center;display:flex}.mini-dot{background:#f3f4f6;border-radius:50%;flex-shrink:0;font-size:.65rem;height:22px;justify-content:center;opacity:.4;transition:all .2s;width:22px}.mini-dot.done{background:#d1fae5;opacity:1}.mini-dot.rej{background:#fee2e2;opacity:1}.mini-line{background:#e5e7eb;flex:1 1;height:2px}.mini-line.done{background:#059669}.items-table{border-collapse:collapse;font-size:.85rem;margin:12px 0;width:100%}.items-table th{background:#f3f4f6;border-bottom:2px solid #e5e7eb;color:#374151;font-size:.78rem;font-weight:700;padding:8px 10px;text-align:left}.items-table td{border-bottom:1px solid #f3f4f6;color:#111827;padding:8px 10px}.items-table tr:hover td{background:#f9fafb}.item-row{grid-gap:6px;align-items:end;display:grid;gap:6px;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr 1.5fr 36px;margin-bottom:6px}.item-row input{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:.82rem;padding:6px 8px;width:100%}.item-row input:focus{border-color:#007c82;outline:none}.item-remove{background:none;border:none;border-radius:4px;color:#dc2626;cursor:pointer;font-size:1.1rem;padding:4px}.item-remove:hover{background:#fee2e2}.item-add{background:none;border:1px dashed #007c82;border-radius:6px;color:#007c82;cursor:pointer;font-size:.82rem;font-weight:600;padding:6px 14px}.item-add:hover{background:#e0f2f4}.timer-wrap{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.delivery-timer{align-items:center;background:#e0f2fe;border-radius:6px;color:#0369a1;display:inline-flex;font-family:monospace;font-size:.78rem;font-weight:700;gap:4px;padding:4px 10px}.delivery-timer.done{background:#d1fae5;color:#059669}.delivery-timer.overdue{animation:overdue-blink 1.5s infinite;background:#fee2e2;color:#dc2626}@keyframes overdue-blink{0%,to{opacity:1}50%{opacity:.7}}.deadline-badge{background:#f3f4f6;border-radius:6px;color:#6b7280;font-size:.7rem;font-weight:700;padding:2px 8px}.deadline-badge.late{background:#fee2e2;color:#dc2626}.deadline-badge.ok{background:#d1fae5;color:#059669}.proc-detail-grid{grid-gap:8px 16px;display:grid;font-size:.85rem;gap:8px 16px;grid-template-columns:1fr 1fr}.proc-detail-grid label{color:#9ca3af;font-size:.75rem;font-weight:600;text-transform:uppercase}.proc-detail-grid span{color:#111827}.new-req-page{margin:0 auto;max-width:860px;padding:28px}.new-req-header{align-items:center;display:flex;gap:14px;margin-bottom:28px}.new-req-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.025em;margin:0}.new-req-header p{color:#64748b;font-size:.9rem;font-weight:500;margin:3px 0 0}.new-req-back{align-items:center;background:#f1f5f9;border:none;border-radius:12px;color:#475569;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s cubic-bezier(.2,.8,.2,1);width:40px}.new-req-back:hover{background:#e2e8f0;color:#0f172a;transform:translateX(-2px)}.dept-grid{display:flex;flex-direction:column;gap:12px}.dept-card{align-items:center;background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a;cursor:pointer;display:flex;gap:18px;padding:18px 22px;transition:all .25s cubic-bezier(.2,.8,.2,1)}.dept-card:hover{border-color:var(--dept-color);box-shadow:0 4px 14px #0f172a0f,0 12px 32px color-mix(in srgb,var(--dept-color) 18%,#0000);transform:translateY(-2px)}.dept-card-icon{align-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--dept-color) 16%,#fff) 0,color-mix(in srgb,var(--dept-color) 6%,#fff) 100%);border-radius:14px;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--dept-color) 22%,#0000);color:var(--dept-color);display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.dept-card-info{flex:1 1;min-width:0}.dept-card-name{color:#0f172a;font-family:var(--font-display);font-size:1.02rem;font-weight:800;letter-spacing:-.012em;margin-bottom:2px}.dept-card-desc{color:#64748b;font-size:.83rem;font-weight:500}.dept-card-stats{color:#64748b;display:flex;flex-shrink:0;font-size:.74rem;font-weight:600;gap:8px}.dept-card-stats span{font-feature-settings:"tnum";background:#f1f5f9;border-radius:999px;padding:4px 10px}.dept-card-arrow{color:#cbd5e1;flex-shrink:0;transition:all .2s}.dept-card:hover .dept-card-arrow{color:var(--dept-color);transform:translateX(3px)}.new-req-form{background:#fff;border:1px solid #0f172a0f;border-radius:18px;box-shadow:0 1px 3px #0f172a0a,0 8px 28px #0f172a0f;display:flex;flex-direction:column;gap:18px;padding:30px}.nrf-label{color:#1e293b;font-family:var(--font-display);font-size:.84rem;font-weight:700;letter-spacing:-.005em;margin-bottom:-8px}.nrf-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-sizing:border-box;color:#0f172a;font-family:inherit;font-size:.92rem;font-weight:500;padding:11px 14px;transition:all .18s;width:100%}.nrf-input::placeholder{color:#94a3b8;font-weight:400}.nrf-input:hover{border-color:#cbd5e1}.nrf-input:focus{border-color:#007c82;box-shadow:0 0 0 4px #007c821f;outline:none}textarea.nrf-input{line-height:1.5;min-height:96px;resize:vertical}select.nrf-input{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;cursor:pointer;padding-right:38px}.nrf-type-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px 14px;transition:all .2s cubic-bezier(.2,.8,.2,1)}.nrf-type-card:hover{box-shadow:0 4px 10px color-mix(in srgb,#007c82 15%,#0000);box-shadow:0 4px 10px color-mix(in srgb,var(--sel-color,#007c82) 15%,#0000);transform:translateY(-1px)}.nrf-type-card.sel,.nrf-type-card:hover{border-color:#007c82;border-color:var(--sel-color,#007c82)}.nrf-type-card.sel{background:linear-gradient(135deg,color-mix(in srgb,#007c82 10%,#fff),color-mix(in srgb,#007c82 4%,#fff));background:linear-gradient(135deg,color-mix(in srgb,var(--sel-color,#007c82) 10%,#fff) 0,color-mix(in srgb,var(--sel-color,#007c82) 4%,#fff) 100%);box-shadow:0 0 0 3px color-mix(in srgb,#007c82 14%,#0000);box-shadow:0 0 0 3px color-mix(in srgb,var(--sel-color,#007c82) 14%,#0000)}.nrf-type-card.small{align-items:center;padding:10px 18px}.nrf-type-icon{color:#64748b;transition:color .2s}.nrf-type-card.sel .nrf-type-icon,.nrf-type-card:hover .nrf-type-icon{color:#007c82;color:var(--sel-color,#007c82)}.nrf-type-name{color:#1e293b;font-family:var(--font-display);font-size:.84rem;font-weight:700;letter-spacing:-.005em}.nrf-type-card.sel .nrf-type-name{color:#007c82;color:var(--sel-color,#007c82)}.nrf-type-desc{color:#94a3b8;font-size:.7rem;font-weight:500}.nrf-extra-fields{background:linear-gradient(135deg,color-mix(in srgb,#007c82 6%,#fff),color-mix(in srgb,#007c82 2%,#fff));background:linear-gradient(135deg,color-mix(in srgb,var(--accent,#007c82) 6%,#fff) 0,color-mix(in srgb,var(--accent,#007c82) 2%,#fff) 100%);border:1px solid color-mix(in srgb,#007c82 22%,#0000);border:1px solid color-mix(in srgb,var(--accent,#007c82) 22%,#0000);border-radius:14px;display:flex;flex-direction:column;gap:12px;overflow:hidden;padding:18px 20px;position:relative}.nrf-extra-fields:before{background:#007c82;background:var(--accent,#007c82);bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nrf-extra-title{color:#007c82;color:var(--accent,#007c82);font-family:var(--font-display);font-size:.84rem;font-weight:800;letter-spacing:.06em;margin-bottom:2px;text-transform:uppercase}.nrf-extra-fields .nrf-input{background:#fff;border-color:#e2e8f0}.nrf-extra-fields .nrf-input:focus{border-color:#007c82;border-color:var(--accent,#007c82);box-shadow:0 0 0 4px color-mix(in srgb,#007c82 12%,#0000);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent,#007c82) 12%,#0000)}.nrf-priority-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.nrf-priority-opt{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:14px 12px;text-align:center;transition:all .2s cubic-bezier(.2,.8,.2,1)}.nrf-priority-opt:hover{box-shadow:0 4px 14px #0f172a14;transform:translateY(-2px)}.nrf-priority-opt input{display:none}.nrf-priority-opt span{font-family:var(--font-display);font-size:.9rem!important;letter-spacing:-.005em}.nrf-priority-opt small{font-feature-settings:"tnum";color:#94a3b8;font-family:var(--font-mono);font-size:.72rem;font-weight:600}.nrf-priority-opt.sel{background:linear-gradient(135deg,#e0f2f4,#cffafe);border-color:#007c82;box-shadow:0 0 0 3px #007c8224,0 4px 12px #007c821f}.nrf-actions{border-top:1px solid #f1f5f9;display:flex;gap:10px;justify-content:flex-end;margin-top:4px;padding-top:8px}.nrf-btn-cancel{background:#f1f5f9;border:none;border-radius:10px;color:#475569;cursor:pointer;font-size:.9rem;font-weight:600;padding:11px 22px;transition:all .15s}.nrf-btn-cancel:hover{background:#e2e8f0;color:#0f172a}.nrf-btn-submit{background:linear-gradient(135deg,#1e40af,#2563eb);border:none;border-radius:10px;box-shadow:0 4px 12px #1e40af40;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;letter-spacing:-.005em;padding:11px 28px;transition:all .2s cubic-bezier(.2,.8,.2,1)}.nrf-btn-submit:hover:not(:disabled){box-shadow:0 6px 18px #1e40af59;transform:translateY(-1px)}.nrf-btn-submit:disabled{cursor:not-allowed;opacity:.5}.pub-warning{align-items:flex-start;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;border-radius:10px;color:#78350f;display:flex;font-size:.86rem;font-weight:500;gap:10px;line-height:1.5;padding:12px 14px}.pub-warning-icon{flex-shrink:0;font-size:1.1rem;line-height:1.3}.pub-file-drop{align-items:center;background:#fafbfc;border:2px dashed #cbd5e1;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:22px;text-align:center;transition:all .2s cubic-bezier(.2,.8,.2,1)}.pub-file-drop:hover{background:#f5f3ff;border-color:#7c3aed;transform:translateY(-1px)}.pub-file-icon{align-items:center;background:linear-gradient(135deg,#ede9fe,#f5f3ff);border-radius:12px;box-shadow:inset 0 0 0 1px #7c3aed2e;color:#7c3aed;display:flex;height:44px;justify-content:center;width:44px}.pub-file-text{color:#1e293b;font-family:var(--font-display);font-size:.88rem;font-weight:700;letter-spacing:-.005em}.pub-file-uploaded{color:#059669}.pub-file-uploaded small{color:#64748b;font-family:var(--font-mono);font-size:.74rem;font-weight:500;margin-left:4px}.pub-file-formats{color:#94a3b8;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.02em}.adm-cats{display:flex;flex-direction:column;gap:12px}.adm-cat-card{align-items:center;background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a;cursor:pointer;display:flex;gap:18px;padding:18px 22px;transition:all .25s cubic-bezier(.2,.8,.2,1)}.adm-cat-card:hover{border-color:#dc2626;box-shadow:0 4px 14px #0f172a0f,0 12px 32px #dc26262e;transform:translateY(-2px)}.adm-cat-icon{align-items:center;background:linear-gradient(135deg,#fee2e2,#fef2f2);border-radius:14px;box-shadow:inset 0 0 0 1px #dc26262e;color:#dc2626;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.adm-cat-info{flex:1 1}.adm-cat-name{color:#0f172a;font-family:var(--font-display);font-size:1.02rem;font-weight:800;letter-spacing:-.012em}.adm-cat-desc{color:#64748b;font-size:.83rem;font-weight:500;margin-top:2px}.adm-form{background:#fff;border:1px solid #0f172a0f;border-radius:18px;box-shadow:0 1px 3px #0f172a0a,0 8px 28px #0f172a0f;display:flex;flex-direction:column;gap:18px;padding:28px}.adm-section{background:linear-gradient(180deg,#fafbfc,#fff);border:1px solid #f1f5f9;border-radius:14px;padding:18px 20px}.adm-section-title{align-items:center;color:#0f172a;display:flex;font-family:var(--font-display);font-size:.96rem;font-weight:800;gap:10px;letter-spacing:-.012em;margin-bottom:14px}.adm-inline-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#475569;cursor:pointer;font-size:.82rem;font-weight:600;padding:5px 10px}.adm-label{color:#475569;display:block;font-size:.8rem;font-weight:700;letter-spacing:-.005em;margin-bottom:5px}.adm-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-sizing:border-box;color:#0f172a;font-family:inherit;font-size:.9rem;font-weight:500;padding:10px 12px;transition:all .18s;width:100%}.adm-input::placeholder{color:#94a3b8;font-weight:400}.adm-input:hover{border-color:#cbd5e1}.adm-input:focus{border-color:#dc2626;box-shadow:0 0 0 4px #dc26261f;outline:none}.adm-row2{grid-gap:12px;grid-template-columns:1fr 1fr}.adm-row2,.adm-row3{display:grid;gap:12px}.adm-row3{grid-gap:12px;grid-template-columns:1fr 1fr 1fr;margin-bottom:10px}.adm-grade-grid{display:flex;flex-wrap:wrap;gap:8px}.adm-grade-opt{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;font-size:.86rem;font-weight:600;padding:8px 16px;transition:all .18s cubic-bezier(.2,.8,.2,1);white-space:nowrap}.adm-grade-opt:hover{border-color:#fca5a5;transform:translateY(-1px)}.adm-grade-opt.sel{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#dc2626;box-shadow:0 0 0 3px #dc262624;color:#dc2626;font-weight:700}.adm-school-grid,.adm-status-grid{display:flex;flex-wrap:wrap;gap:8px}.adm-file{background:#fafbfc;border:1.5px dashed #cbd5e1;border-radius:10px;box-sizing:border-box;color:#64748b;cursor:pointer;font-size:.84rem;padding:8px;transition:all .18s;width:100%}.adm-file:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.adm-add-parent{background:none;border:1.5px dashed #dc2626;border-radius:10px;color:#dc2626;cursor:pointer;font-size:.86rem;font-weight:700;margin-top:8px;padding:10px 18px;transition:all .18s}.adm-add-parent:hover{background:#fef2f2;transform:translateY(-1px)}.adm-parent2-block{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:inset 0 1px 3px #0f172a08;margin-top:10px;padding:14px}.adm-remove-btn{background:#fee2e2;border:none;border-radius:8px;color:#b91c1c;cursor:pointer;font-size:.78rem;font-weight:700;padding:5px 12px;transition:all .15s}.adm-remove-btn:hover{background:#fca5a5;transform:translateY(-1px)}@media (max-width:700px){.new-req-page{padding:16px}.new-req-header h2{font-size:22px}.adm-form,.new-req-form{border-radius:14px;padding:18px}.nrf-priority-grid{grid-template-columns:repeat(2,1fr)}.adm-row2,.adm-row3{grid-template-columns:1fr}}.enr-page{margin:0 auto;max-width:1500px;padding:28px}.enr-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:22px}.enr-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f766e,#007c82 50%,#0891b2);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.025em;margin:0}.enr-loading{color:#9ca3af;font-weight:500;padding:60px;text-align:center}.enr-main-tabs{background:#f1f5f9;border-radius:12px;display:inline-flex;gap:4px;margin-bottom:18px;padding:5px}.enr-main-tab{align-items:center;background:#0000;border:none;border-radius:9px;color:#64748b;cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:700;gap:8px;letter-spacing:-.005em;padding:10px 22px;transition:all .2s cubic-bezier(.2,.8,.2,1)}.enr-main-tab:hover{color:#0f172a}.enr-main-tab.active{background:#fff;box-shadow:0 1px 2px #0f172a0f,0 4px 12px #007c8226;color:#007c82}.enr-pending-badge{background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:999px;box-shadow:0 2px 6px #dc26264d;color:#fff;font-size:.7rem;font-weight:800;padding:2px 8px}.enr-tabs{border-bottom:1px solid #e2e8f0;display:flex;gap:4px;margin-bottom:18px}.enr-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:var(--font-display);font-size:.9rem;font-weight:700;letter-spacing:-.005em;margin-bottom:-1px;padding:11px 22px;transition:all .15s}.enr-tab:hover{color:#0f172a}.enr-tab.active{border-bottom-color:#007c82;color:#007c82}.enr-table-wrap{background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 8px 24px #0f172a0d;overflow-x:auto}.enr-stats-table{font-feature-settings:"tnum";border-collapse:initial;border-spacing:0;font-family:var(--font-sans);font-size:.84rem;width:100%}.enr-stats-table thead th{font-weight:700;letter-spacing:.01em;overflow:hidden;padding:11px 8px;text-overflow:ellipsis;white-space:nowrap}.th-grade{background:linear-gradient(180deg,#fff,#f8fafc);border-right:1px solid #e2e8f0;color:#0f172a;font-size:.78rem;font-weight:800;letter-spacing:.02em;padding-left:18px!important;text-align:left;width:130px}.th-grade,.th-group{text-transform:uppercase}.th-group{font-size:.74rem;letter-spacing:.06em;text-align:center}.th-group.continuing{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}.th-group.new-std{background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff}.th-group.total{background:linear-gradient(135deg,#047857,#059669);color:#fff}.th-sub{font-size:.7rem;font-weight:700;letter-spacing:.025em;padding:8px 6px;text-align:center}.th-sub.continuing{background:#eff6ff;border-bottom:2px solid #93c5fd;color:#1e40af}.th-sub.new-std{background:#fffbeb;border-bottom:2px solid #fcd34d;color:#92400e}.th-sub.total{background:#ecfdf5;border-bottom:2px solid #6ee7b7;color:#065f46}.th-avail{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left:1px solid #fca5a5;color:#991b1b;font-size:.72rem;font-weight:800;letter-spacing:.04em;text-align:center;text-transform:uppercase;width:80px}.enr-stats-table tbody td{border-bottom:1px solid #f1f5f9;font-size:.88rem;font-weight:600;padding:11px 8px;text-align:center;transition:background .12s}.stats-row{cursor:pointer}.stats-row:hover td{background:#f0fafb!important}.stats-row:hover .td-grade{background:#cffafe!important;color:#0e7490}.td-grade{background:#fafbfc;border-right:1px solid #f1f5f9;color:#0f172a;font-family:var(--font-display);font-size:.92rem;font-weight:700;padding-left:18px!important;text-align:left!important}.td-cont{color:#1e40af}.td-cont.hi{background:#eff6ff;color:#1d4ed8;font-size:.95rem;font-weight:800}.td-new{color:#92400e}.td-new.hi{background:#fffbeb;color:#b45309;font-size:.95rem;font-weight:800}.td-total{color:#065f46;font-weight:700}.td-avail{background:#f0fdf4;border-left:1px solid #f1f5f9;color:#059669;font-family:var(--font-display);font-size:1rem;font-weight:800}.td-avail.low{background:#fffbeb;color:#d97706}.td-avail.full{background:#fef2f2;color:#dc2626}.stats-total-row td{background:linear-gradient(180deg,#f8fafc,#f1f5f9)!important;border-bottom:none;border-top:2px solid #0f766e;font-size:.95rem;padding:13px 8px!important;text-align:center!important;vertical-align:middle}.stats-total-row .td-grade{color:#0f172a;font-family:var(--font-display);font-weight:800;padding-left:18px!important;text-align:left!important}.stats-row td:empty:before,.stats-total-row td:empty:before{color:#cbd5e1;content:"–";font-weight:400}.enr-pending-bar{align-items:center;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:14px;box-shadow:0 1px 3px #d9770614;color:#92400e;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:12px;margin-bottom:16px;padding:14px 20px;transition:all .2s}.enr-pending-bar:hover{background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 4px 12px #d977062e;transform:translateY(-1px)}.enr-pending-bar b{color:#b45309;font-weight:800}.enr-pending-action{color:#d97706;font-size:.85rem;font-weight:700;margin-left:auto}.enr-table{border-collapse:collapse;font-size:.88rem;width:100%}.enr-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-size:.75rem;font-weight:800;letter-spacing:.05em;padding:12px 10px;text-align:left;text-transform:uppercase;white-space:nowrap}.enr-table td{border-bottom:1px solid #f1f5f9;color:#0f172a;padding:10px}.enr-table tr:hover td{background:#f9fafb}.enr-table tr.row-out td{background:#fef2f2;color:#9ca3af;text-decoration:line-through}.enr-table tr.row-out .enr-badge,.enr-table tr.row-out .enr-status-sel,.enr-table tr.row-out .enr-type-badge{text-decoration:none}.enr-num{color:#94a3b8;font-family:var(--font-mono);font-weight:700;text-align:center}.enr-name{font-weight:600}.enr-grade{color:#0e7490;font-family:var(--font-display);font-weight:700;text-align:center;white-space:nowrap}.enr-date{color:#64748b;font-size:.82rem}.enr-status-sel{border:1px solid #0000;border-radius:999px;cursor:pointer;font-size:.74rem;font-weight:700;padding:4px 10px;transition:all .15s}.enr-status-sel.active{background:#d1fae5;color:#047857}.enr-status-sel.out{background:#fee2e2;color:#b91c1c}.enr-status-sel:hover{transform:translateY(-1px)}.enr-badge{border-radius:999px;display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.01em;padding:3px 10px;text-align:center;white-space:nowrap}.enr-badge.green{background:#d1fae5;color:#047857}.enr-badge.gray{background:#f1f5f9;color:#64748b}.enr-badge.red{background:#fee2e2;color:#b91c1c}.enr-badge.purple{background:#ede9fe;color:#6d28d9}.enr-type-badge{border-radius:6px;display:inline-block;font-size:.7rem;font-weight:800;letter-spacing:.02em;padding:3px 9px}.enr-type-badge.continuing{background:#dbeafe;color:#1e40af}.enr-type-badge.new{background:#fef3c7;color:#92400e}.enr-sign-btn{background:linear-gradient(135deg,#007c82,#0891b2);border:none;border-radius:8px;box-shadow:0 2px 6px #007c8240;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;padding:6px 14px;transition:all .15s}.enr-sign-btn:hover{box-shadow:0 4px 14px #007c8259;transform:translateY(-1px)}.enr-pay-sel{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#334155;cursor:pointer;font-size:.83rem;font-weight:600;padding:4px 10px;transition:border-color .15s}.enr-pay-sel:hover{border-color:#007c82}.enr-pay-sel:disabled{cursor:not-allowed;opacity:.5}.enr-back-btn{align-items:center;background:#f1f5f9;border:none;border-radius:10px;color:#475569;cursor:pointer;display:flex;padding:8px 10px;transition:all .15s}.enr-back-btn:hover{background:#e2e8f0;color:#0f172a}.adm-reject-btn{background:#fee2e2;border:none;border-radius:8px;color:#b91c1c;cursor:pointer;font-size:.78rem;font-weight:700;padding:6px 14px;transition:all .15s}.adm-reject-btn:hover{background:#fca5a5;transform:translateY(-1px)}.adm-new-btn{align-items:center;background:linear-gradient(135deg,#007c82,#0891b2);border:none;border-radius:10px;box-shadow:0 4px 12px #007c8240;color:#fff;cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:700;gap:6px;letter-spacing:-.005em;padding:10px 18px;transition:all .2s cubic-bezier(.2,.8,.2,1)}.adm-new-btn:hover{box-shadow:0 8px 22px #007c8259;transform:translateY(-2px)}.adm-table thead th{background:linear-gradient(180deg,#f8fafc,#f1f5f9)!important;border-bottom:2px solid #e2e8f0!important;color:#475569!important;font-size:.72rem!important;letter-spacing:.06em;padding:13px 10px!important;text-transform:uppercase}.adm-table tbody tr{transition:background .15s}.adm-table tbody tr:hover td{background:#f0fafb}.adm-table tbody td{font-size:.88rem;padding:13px 10px!important;vertical-align:middle}.adm-table .enr-num{color:#64748b;font-family:var(--font-mono);font-size:.78rem;font-weight:600;letter-spacing:.02em}.adm-table .enr-name{color:#0f172a;font-size:.92rem;font-weight:700}.adm-table .enr-grade{color:#0e7490;font-family:var(--font-display);font-size:.95rem;font-weight:800}.adm-phone{font-feature-settings:"tnum";color:#475569;font-family:var(--font-mono);font-size:.83rem;letter-spacing:-.005em}.sign-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.sign-modal{background:#fff;border:1px solid #0f172a0f;border-radius:18px;box-shadow:0 25px 80px #0f172a47;max-width:540px;padding:24px 28px;width:100%}.sign-modal-hdr{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.sign-modal-hdr h3{color:#0f172a;font-family:var(--font-display);font-size:1.1rem;font-weight:800;letter-spacing:-.015em;margin:0}.sign-modal-hdr button{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:all .15s;width:32px}.sign-modal-hdr button:hover{background:#e2e8f0;color:#0f172a}.sign-modal-desc{color:#475569;font-size:.9rem;margin:0 0 16px}.sign-grade-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.sign-grade-opt{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px 10px;position:relative;transition:all .18s cubic-bezier(.2,.8,.2,1)}.sign-grade-opt:hover:not(.full){background:#f0fafb;border-color:#007c82;box-shadow:0 4px 12px #007c8226;transform:translateY(-2px)}.sign-grade-opt.sel{background:linear-gradient(135deg,#e0f2f4,#cffafe);border-color:#007c82;box-shadow:0 0 0 3px #007c8226}.sign-grade-opt.full{background:#f8fafc;cursor:not-allowed;opacity:.45}.sign-grade-name{color:#0f172a;font-family:var(--font-display);font-size:.92rem;font-weight:800}.sign-grade-opt.sel .sign-grade-name{color:#007c82}.sign-grade-count{color:#64748b;font-size:.74rem;font-weight:600}.sign-grade-full{background:#dc2626;border-radius:4px;color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.04em;padding:2px 6px;position:absolute;right:6px;top:6px}@media (max-width:900px){.enr-page{padding:16px}.enr-header h2{font-size:22px}.enr-stats-table{font-size:.78rem}.enr-stats-table thead th{font-size:.66rem;padding:8px 4px}.enr-stats-table tbody td{font-size:.82rem;padding:8px 4px}.td-grade,.th-grade{padding-left:10px!important;width:90px!important}}.chat-root{background:#f0f2f5;border-radius:12px;box-shadow:0 2px 16px #00000014;display:flex;height:calc(100vh - 60px);margin:-24px;overflow:hidden}.chat-back-btn{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;height:38px;justify-content:center;margin-right:4px;transition:background .15s;width:38px}.chat-back-btn:hover{background:#ffffff26}.chat-sidebar{background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;min-width:260px;width:320px}.chat-sidebar-header{align-items:center;border-bottom:1px solid #f0f2f5;display:flex;justify-content:space-between;padding:16px 18px 12px}.chat-sidebar-header h3{color:#111827;font-size:1.1rem;font-weight:700;margin:0}.chat-header-btns{display:flex;gap:6px}.chat-header-btns button{align-items:center;background:#f0f2f5;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;padding:6px 8px;transition:background .15s}.chat-header-btns button:hover{background:#e5e7eb}.chat-conv-list{flex:1 1;overflow-y:auto;padding:8px 0}.chat-empty{color:#9ca3af;font-size:.85rem;padding:20px;text-align:center}.chat-conv-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:10px 16px;transition:background .12s}.chat-conv-item:hover{background:#f9fafb}.chat-conv-item.active{background:#e0f2f4}.conv-avatar-wrap{flex-shrink:0;position:relative}.conv-avatar{align-items:center;background:#007c82;border-radius:50%;color:#fff;display:flex;font-size:1.1rem;font-weight:700;height:44px;justify-content:center;width:44px}.conv-avatar.lg{font-size:1rem;height:40px;width:40px}.conv-avatar.sm{flex-shrink:0;font-size:.9rem;height:36px;width:36px}.online-dot{background:#10b981;border:2px solid #fff;border-radius:50%;bottom:1px;height:11px;position:absolute;right:1px;width:11px}.online-dot.static{margin-left:auto;position:static}.conv-info{flex:1 1;min-width:0}.conv-top{align-items:center;display:flex;justify-content:space-between}.conv-name{color:#111827;font-size:.9rem;font-weight:600}.conv-time{color:#9ca3af;font-size:.72rem}.conv-last{align-items:center;display:flex;justify-content:space-between;margin-top:2px}.conv-last-msg{color:#6b7280;font-size:.8rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{align-items:center;background:#007c82;border-radius:99px;color:#fff;display:flex;font-size:.7rem;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px}.chat-main{background:#f0f2f5;min-width:0}.chat-main,.chat-welcome{display:flex;flex:1 1;flex-direction:column}.chat-welcome{align-items:center;color:#9ca3af;gap:16px;justify-content:center}.chat-conv-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;padding:12px 18px}.conv-header-name{color:#111827;font-size:.95rem;font-weight:700}.conv-header-sub{color:#9ca3af;font-size:.78rem}.chat-call-btns{display:flex;gap:8px;margin-left:auto}.chat-call-btns button{align-items:center;background:#f0f2f5;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;padding:8px;transition:background .15s}.chat-call-btns button:hover{background:#e0f2f4;color:#007c82}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:16px 20px}.chat-loading{color:#9ca3af;font-size:.85rem;padding:8px;text-align:center}.load-more-btn{align-self:center;background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#007c82;cursor:pointer;font-size:.8rem;margin-bottom:8px;padding:6px 16px}.load-more-btn:hover{background:#e0f2f4}.date-divider{align-items:center;display:flex;justify-content:center;margin:12px 0}.date-divider span{background:#e5e7eb;border-radius:99px;color:#6b7280;font-size:.75rem;padding:3px 12px}.msg-wrap{align-items:flex-start;display:flex;flex-direction:column;margin:2px 0}.msg-wrap.mine{align-items:flex-end}.msg-sender-name{color:#007c82;font-size:.72rem;font-weight:600;margin-bottom:2px;padding-left:12px}.msg-bubble{background:#fff;border-radius:16px 16px 16px 4px;box-shadow:0 1px 3px #00000012;color:#111827;font-size:.9rem;max-width:65%;padding:8px 12px;position:relative;word-break:break-word}.msg-bubble.mine{background:#007c82;border-radius:16px 16px 4px 16px;color:#fff}.msg-bubble.deleted{background:#f3f4f6;color:#9ca3af;font-style:italic}.deleted-text{font-size:.85rem}.msg-image-wrap{display:inline-block;line-height:0;position:relative}.msg-image{background:#f1f5f9;border-radius:10px;cursor:zoom-in;display:block;max-height:240px;max-width:260px;transition:transform .18s ease,box-shadow .18s ease}.msg-image:hover{box-shadow:0 6px 18px #0000002e;transform:scale(1.02)}.msg-image.is-gif{outline:2px solid #7c3aed73;outline-offset:-2px}.msg-gif-badge{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172ac7;border-radius:99px;color:#fff;font-size:.62rem;font-weight:800;left:8px;letter-spacing:.06em;padding:2px 7px;pointer-events:none;position:absolute;text-transform:uppercase;top:8px}@keyframes msg-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.msg-bubble{animation:msg-fade-in .22s ease-out}.msg-lightbox-overlay{align-items:center;animation:msg-fade-in .18s ease-out;background:#000000d9;cursor:zoom-out;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.msg-lightbox-img{border-radius:8px;box-shadow:0 20px 60px #0009;max-height:92vh;max-width:92vw}.msg-lightbox-close{align-items:center;background:#ffffff1f;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:38px;justify-content:center;position:absolute;right:18px;top:18px;width:38px}.msg-lightbox-close:hover{background:#ffffff38}.msg-file{align-items:center;color:inherit;display:flex;font-size:.85rem;gap:6px;text-decoration:none}.msg-file:hover{text-decoration:underline}.msg-meta{align-items:center;display:flex;gap:6px;justify-content:flex-end;margin-top:3px}.msg-time{color:#00000059;font-size:.68rem}.msg-bubble.mine .msg-time{color:#ffffffa6}.msg-delete-btn{background:none;border:none;color:#0000004d;cursor:pointer;font-size:.7rem;opacity:0;padding:0 2px;transition:opacity .15s}.msg-bubble:hover .msg-delete-btn{opacity:1}.msg-bubble.mine .msg-delete-btn{color:#fff9}.typing-indicator{align-items:center;color:#6b7280;display:flex;font-size:.8rem;gap:8px;padding:4px 0}.typing-dots{display:flex;gap:3px}.typing-dots span{animation:bounce 1.2s infinite;background:#9ca3af;border-radius:50%;height:5px;width:5px}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}}.chat-input-bar{background:#fff;border-top:1px solid #e5e7eb;gap:8px;padding:12px 16px;position:relative}.chat-input-bar,.icon-btn{align-items:center;display:flex;flex-shrink:0}.icon-btn{background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:1.1rem;padding:6px;transition:background .12s}.icon-btn:hover{background:#f0f2f5}.chat-text-input{background:#f9fafb;border:1px solid #e5e7eb;border-radius:22px;flex:1 1;font-family:inherit;font-size:.9rem;outline:none;padding:8px 14px;transition:border-color .15s}.chat-text-input:focus{background:#fff;border-color:#007c82}.send-btn{align-items:center;background:#007c82;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:background .15s,transform .1s;width:38px}.send-btn:hover:not(:disabled){background:#006368;transform:scale(1.05)}.send-btn:disabled{background:#d1d5db;cursor:not-allowed}.picker-popover{background:#fff;border:1px solid #e5e7eb;border-radius:14px;bottom:65px;box-shadow:0 12px 32px #00000029;display:flex;flex-direction:column;gap:8px;left:16px;padding:10px;position:absolute;width:340px;z-index:100}.picker-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:4px;padding-bottom:6px}.picker-tab{background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;flex:1 1;font-size:.82rem;font-weight:700;padding:7px 10px;transition:all .12s}.picker-tab:hover{background:#f1f5f9;color:#0f172a}.picker-tab.active{background:linear-gradient(135deg,#007c82,#0891b2);color:#fff}.picker-search{border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:.86rem;outline:none;padding:7px 10px;width:100%}.picker-search:focus{border-color:#007c82;box-shadow:0 0 0 3px #007c821f}.emoji-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(9,1fr);max-height:250px;overflow-y:auto}.emoji-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:1.3rem;line-height:1;padding:4px;transition:background .1s,transform .1s}.emoji-btn:hover{background:#f0f2f5;transform:scale(1.15)}.gif-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(3,1fr);max-height:290px;overflow-y:auto}.gif-thumb{background:#f1f5f9;border-radius:7px;cursor:pointer;height:90px;object-fit:cover;transition:transform .12s,box-shadow .12s;width:100%}.gif-thumb:hover{box-shadow:0 4px 12px #0000002e;transform:scale(1.04)}.gif-loading{font-size:.85rem;grid-column:1/-1;padding:30px}.gif-loading,.picker-credit{color:#94a3b8;text-align:center}.picker-credit{font-size:.66rem;font-weight:700;letter-spacing:.04em;margin-top:2px;text-transform:uppercase}.chat-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:420px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #f0f2f5;display:flex;justify-content:space-between;padding:16px 20px}.modal-header h3{color:#111827;font-size:1rem;margin:0}.modal-header button{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:1.1rem}.modal-search{border:1px solid #e5e7eb;border-radius:22px;box-sizing:border-box;font-size:.88rem;margin:12px 16px 4px;outline:none;padding:8px 14px;width:calc(100% - 32px)}.modal-search:focus{border-color:#007c82}.user-list{flex:1 1;overflow-y:auto;padding:8px 0}.user-list-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:10px 16px;transition:background .12s}.user-list-item:hover{background:#f9fafb}.user-list-item.selected{background:#e0f2f4}.user-item-name{color:#111827;font-size:.9rem;font-weight:500}.user-item-role{color:#9ca3af;font-size:.75rem}.check-mark{color:#007c82;font-weight:700;margin-left:auto}.modal-footer-btns{align-items:center;border-top:1px solid #f0f2f5;color:#6b7280;display:flex;font-size:.85rem;justify-content:space-between;padding:12px 16px}.btn-primary{background:#007c82;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.88rem;font-weight:500;padding:8px 18px}.btn-primary:hover{background:#006368}.btn-primary:disabled{background:#d1d5db;cursor:not-allowed}.call-overlay{background:#000000b3;inset:0;justify-content:center;position:fixed;z-index:2000}.call-box,.call-overlay{align-items:center;display:flex}.call-box{background:linear-gradient(135deg,#007c82,#005f63);border-radius:24px;box-shadow:0 20px 60px #0006;flex-direction:column;gap:16px;min-width:280px;padding:40px 48px}.call-avatar{align-items:center;background:#fff3;border:3px solid #fff6;border-radius:50%;display:flex;font-size:2rem;height:80px;justify-content:center;width:80px}.call-avatar,.call-name{color:#fff;font-weight:700}.call-name{font-size:1.2rem}.call-status{color:#ffffffbf;font-size:.88rem}.call-actions{display:flex;gap:20px;margin-top:8px}.call-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:56px;justify-content:center;transition:transform .15s,filter .15s;width:56px}.call-btn:hover{transform:scale(1.1)}.call-btn.accept{background:#10b981}.call-btn.reject{background:#ef4444}.chat-conv-list::-webkit-scrollbar,.chat-messages::-webkit-scrollbar,.user-list::-webkit-scrollbar{width:5px}.chat-conv-list::-webkit-scrollbar-track,.chat-messages::-webkit-scrollbar-track{background:#0000}.chat-conv-list::-webkit-scrollbar-thumb,.chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:99px}@media (max-width:760px){.chat-root{background:#efeae2;border-radius:0;box-shadow:none;height:calc(100vh - 50px);margin:-14px}.chat-root.chat-conv-active{height:100vh!important;inset:0!important;margin:0!important;position:fixed!important;z-index:200}body:has(.chat-root.chat-conv-active) .topbar{display:none!important}.chat-sidebar{background:#fff;border-right:none;flex:1 1 auto;height:100%!important;max-height:none!important;min-width:0!important;width:100%!important}.chat-main,.chat-root.chat-conv-active .chat-sidebar{display:none!important}.chat-root.chat-conv-active .chat-main{display:flex!important}.chat-conv-header{background:linear-gradient(180deg,#00867d,#007c82);border-bottom:none;box-shadow:0 2px 6px #00000026;padding:10px 12px}.chat-conv-header .conv-header-name{color:#fff}.chat-conv-header .conv-header-sub{color:#ffffffc7}.chat-conv-header .conv-avatar{background:#fff3;color:#fff}.chat-conv-header .online-dot{border-color:#00867d}.chat-call-btns button{background:#0000;border-radius:50%;color:#fff;height:38px;justify-content:center;width:38px}.chat-call-btns button:hover{background:#ffffff26;color:#fff}.chat-back-btn{display:inline-flex}.chat-main,.chat-messages{background:#efeae2}.chat-messages{padding:12px 10px}.msg-bubble{background:#fff;border-radius:8px;box-shadow:0 1px .5px #00000021;max-width:78%;padding:6px 10px 8px}.msg-bubble.mine{background:#d9fdd3;border-radius:8px;color:#111b21}.msg-wrap{margin:1px 0}.chat-conv-item{padding:12px 16px}.conv-avatar{font-size:1.2rem;height:50px;width:50px}.conv-name{font-size:.95rem}.conv-last-msg{font-size:.84rem;max-width:calc(100vw - 140px)}.chat-sidebar-header{background:linear-gradient(180deg,#00867d,#007c82);border-bottom:none;box-shadow:0 2px 6px #0000001f;padding:12px 14px}.chat-sidebar-header h3{color:#fff}.chat-header-btns button{background:#0000;border-radius:50%;color:#fff;height:36px;justify-content:center;width:36px}.chat-header-btns button:hover{background:#ffffff26;color:#fff}.chat-input-bar{background:#f0f2f5;border-top:none;gap:4px;padding:8px}.chat-text-input{background:#fff;border:none!important;border-radius:24px!important;padding:10px 16px!important}.send-btn{background:#00867d!important;border-radius:50%!important;box-shadow:0 2px 4px #0000001a;color:#fff;height:44px;width:44px}.icon-btn{background:#0000;border-radius:50%;color:#54656f;height:40px;width:40px}.icon-btn:hover{background:#0000000d}.picker-popover{bottom:60px!important;left:8px!important;max-height:50vh;position:fixed!important;right:8px!important;width:auto!important}.chat-welcome{display:none}}@media (max-width:380px){.chat-conv-item{gap:10px;padding:10px 12px}.conv-avatar{height:46px;width:46px}.msg-bubble{max-width:84%}}.an-page{margin:0 auto;max-width:1400px;padding:24px}.an-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:14px;padding:80px}.an-error{background:#fee2e2;border-radius:12px;color:#b91c1c;font-weight:500;margin:20px;padding:14px}.an-stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:22px}.an-stat{align-items:center;background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 4px 12px #0f172a0d;display:flex;gap:14px;overflow:hidden;padding:16px 18px;position:relative;transition:all .25s cubic-bezier(.2,.8,.2,1)}.an-stat:before{background:var(--c);bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.an-stat:hover{box-shadow:0 8px 22px #0f172a1a;transform:translateY(-2px)}.an-stat-icon{align-items:center;background:color-mix(in srgb,var(--c) 14%,#fff);border-radius:12px;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--c) 22%,#0000);display:flex;font-size:1.5rem;height:46px;justify-content:center;width:46px}.an-stat-info{flex:1 1;min-width:0}.an-stat-value{font-feature-settings:"tnum";color:#0f172a;font-family:var(--font-display);font-size:1.65rem;font-weight:800;letter-spacing:-.025em;line-height:1}.an-stat-label{color:#64748b;font-size:.78rem;font-weight:600;margin-top:4px}.an-stat-sub{color:#94a3b8;font-size:.72rem;margin-top:2px}.an-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.an-card{background:#fff;border:1px solid #0f172a0f;border-radius:16px;box-shadow:0 1px 3px #0f172a0a,0 8px 24px #0f172a0d;padding:18px 20px}.an-card-wide{grid-column:1/-1}.an-card-title{align-items:center;color:#0f172a;display:flex;font-family:var(--font-display);font-size:.95rem;font-weight:800;gap:8px;letter-spacing:-.012em;margin:0 0 14px}.an-bar-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:130px 1fr 56px;padding:5px 0}.an-bar-label{color:#475569;font-size:.82rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.an-bar-track{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.an-bar-fill{border-radius:999px;box-shadow:0 0 6px currentColor;height:100%;opacity:.92;transition:width .35s cubic-bezier(.2,.8,.2,1)}.an-bar-value{font-feature-settings:"tnum";color:#0f172a;font-family:var(--font-display);font-size:.92rem;font-weight:800;text-align:right}.an-section-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:10px 0}.an-section-row:last-child{border-bottom:none}.an-section-label{color:#1e293b;font-size:.88rem;font-weight:600}.an-section-meta{color:#64748b;font-size:.74rem;margin-top:2px}.an-section-num{font-feature-settings:"tnum";color:#007c82;font-family:var(--font-display);font-size:1.4rem;font-weight:800}.an-dept-row{border-bottom:1px solid #f1f5f9;padding:10px 0}.an-dept-row:last-child{border-bottom:none}.an-dept-name{color:#1e293b;font-size:.86rem;font-weight:700;margin-bottom:6px}.an-dept-bar{background:#f1f5f9;border-radius:999px;height:6px;margin-bottom:6px;overflow:hidden}.an-dept-fill{background:linear-gradient(90deg,#0891b2,#007c82);border-radius:999px;height:100%;transition:width .35s}.an-dept-stats{font-feature-settings:"tnum";color:#64748b;display:flex;font-size:.74rem;gap:12px}.an-spark{display:block;height:60px;width:100%}.an-trend-rows{display:flex;flex-direction:column;gap:4px;margin-top:10px}.an-trend-row{font-feature-settings:"tnum";border-bottom:1px dashed #e2e8f0;color:#475569;display:flex;font-size:.8rem;gap:12px;padding:6px 0}.an-trend-row:last-child{border-bottom:none}.an-trend-month{color:#0f172a;font-family:var(--font-mono);font-weight:600;min-width:75px}.an-perf-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:10px;padding:8px 0}.an-perf-row:last-child{border-bottom:none}.an-perf-rank{font-size:1.2rem;min-width:26px}.an-perf-info{flex:1 1;min-width:0}.an-perf-name{color:#0f172a;font-size:.88rem;font-weight:700}.an-perf-pos{color:#64748b;font-size:.72rem}.an-perf-stats{font-feature-settings:"tnum";color:#475569;font-size:.78rem;text-align:right}.an-subj-row{grid-gap:10px;align-items:center;border-bottom:1px solid #f1f5f9;display:grid;gap:10px;grid-template-columns:1fr 56px 56px;padding:7px 0}.an-subj-row:last-child{border-bottom:none}.an-subj-name{color:#1e293b;font-size:.84rem;font-weight:600}.an-subj-avg{font-feature-settings:"tnum";font-family:var(--font-display);font-size:1rem;font-weight:800;text-align:right}.an-subj-count{font-feature-settings:"tnum";color:#94a3b8;font-size:.74rem;text-align:right}
/*# sourceMappingURL=main.800c29b2.css.map*/