:root{--font-sans: "Plus Jakarta Sans", "PingFang SC", "Microsoft YaHei", "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--c-bg: #f8f9fb;--c-surface: #ffffff;--c-border: #e5e7eb;--c-border-2: #f3f4f6;--c-text-1: #111827;--c-text-2: #374151;--c-text-3: #6b7280;--c-text-4: #9ca3af;--c-blue: #2563eb;--c-blue-soft: #eff6ff;--c-purple: #7c3aed;--c-purple-soft:#f5f3ff;--c-orange: #ea580c;--c-orange-soft:#fff7ed;--c-green: #16a34a;--c-green-soft: #f0fdf4;--c-red: #dc2626;--c-red-soft: #fef2f2;--sidebar-bg: #eef4ff;--sidebar-border: #d4e1f9;--sidebar-text: #4b6285;--sidebar-text-active: #1d4ed8;--sidebar-hover: #dfeaff;--sidebar-active: #dbeafe;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--c-text-1);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code,.mono,.ant-typography code{font-family:var(--font-mono)!important}.app-layout{display:flex;height:100vh;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.app-content{flex:1;overflow-y:auto;padding:24px 28px;background:var(--c-bg)}.app-footer{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:44px;background:var(--c-surface);border-top:1px solid var(--c-border);flex-shrink:0}.sidebar{background:linear-gradient(175deg,#d6e6ff,#e2edff 30%,#edf4ff,#f3f7ff);border-right:1px solid #c8d9f5;box-shadow:inset -1px 0 #fff9;display:flex;flex-direction:column;height:100vh;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden;flex-shrink:0}.sidebar::-webkit-scrollbar{width:0}.sidebar-logo{height:56px;display:flex;align-items:center;padding:0 16px;gap:10px;border-bottom:1px solid rgba(100,150,220,.2);flex-shrink:0}.sidebar-logo-icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #3b82f659}.sidebar-logo-text{overflow:hidden}.sidebar-logo-title{color:#1e3a5f;font-size:13px;font-weight:700;letter-spacing:-.3px;line-height:16px;white-space:nowrap}.sidebar-logo-sub{color:#7a96c2;font-size:10px;letter-spacing:.3px;line-height:14px;white-space:nowrap}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 8px}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:#7a96c2;padding:10px 12px 4px;-webkit-user-select:none;user-select:none}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background .12s,color .12s;color:var(--sidebar-text);position:relative;margin-bottom:1px;-webkit-user-select:none;user-select:none;white-space:nowrap}.nav-item:hover{background:var(--sidebar-hover);color:var(--c-text-1)}.nav-item.active{background:var(--sidebar-active);color:var(--sidebar-text-active)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:#3b82f6;border-radius:0 2px 2px 0}.nav-item.collapsed{justify-content:center;padding:9px 0}.nav-item-label{font-size:13px;font-weight:500;letter-spacing:-.1px}.nav-item.active .nav-item-label{font-weight:600}.sidebar-group-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;border-radius:var(--radius-md);padding:6px 12px;transition:background .12s,color .12s;color:#7a96c2;-webkit-user-select:none;user-select:none}.sidebar-group-header:hover{background:var(--sidebar-hover);color:#4b6285}.sidebar-group-header-open{color:#4b6285}.sidebar-group-chevron{transition:transform .18s cubic-bezier(.4,0,.2,1);flex-shrink:0}.sidebar-footer{height:46px;display:flex;align-items:center;padding:0 16px;border-top:1px solid rgba(100,150,220,.2);cursor:pointer;color:#7a96c2;transition:color .15s;flex-shrink:0;justify-content:space-between}.sidebar-footer:hover{color:#4b6285}.sidebar-footer.collapsed{justify-content:center;padding:0}.app-header{height:56px;background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;z-index:100}.header-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-brand-school{width:26px;height:26px;border-radius:7px;background:#1e3a5f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-divider{color:#d1d5db;font-size:14px;line-height:1;-webkit-user-select:none;user-select:none}.header-iam-badge{display:flex;align-items:center;gap:4px;background:var(--c-green-soft);border:1px solid #bbf7d0;border-radius:20px;padding:2px 8px}.header-search{flex:1;max-width:380px}.header-right{display:flex;align-items:center;gap:8px;margin-left:auto}.header-balance{display:flex;align-items:center;gap:6px;border-radius:var(--radius-md);padding:5px 12px;cursor:pointer;border:1px solid var(--c-border);background:var(--c-surface);transition:background .15s}.header-balance:hover{background:var(--c-bg)}.header-divider-v{width:1px;height:20px;background:var(--c-border)}.header-user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);transition:background .12s}.header-user:hover{background:var(--c-bg)}.page-header{margin-bottom:22px}.page-title{font-size:20px!important;font-weight:700!important;letter-spacing:-.5px;color:var(--c-text-1)!important;margin:0!important;line-height:1.3!important}.page-subtitle{font-size:13px;color:var(--c-text-3);margin-top:3px}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px 22px;height:100%;position:relative;overflow:hidden;transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-card-accent{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card-label{font-size:11px;font-weight:600;color:var(--c-text-3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}.stat-card-value{font-size:30px;font-weight:700;letter-spacing:-1.5px;color:var(--c-text-1);line-height:1}.stat-card-unit{font-size:13px;font-weight:400;color:var(--c-text-4);margin-left:4px}.stat-card-trend{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600;margin-top:10px}.stat-card-icon{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}.status-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}@keyframes pulse-blue{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.status-dot-pulse{animation:pulse-blue 1.4s ease infinite}.type-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:5px;white-space:nowrap}.resource-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px;height:100%;transition:box-shadow .18s,border-color .18s,transform .18s;cursor:default}.resource-card:hover{box-shadow:var(--shadow-md);border-color:#d1d5db;transform:translateY(-1px)}.resource-card.unavailable{opacity:.55}.panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--c-border-2)}.panel-title{font-size:14px;font-weight:600;color:var(--c-text-1)}.panel-body{padding:20px}.quick-action{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.quick-action:hover{border-color:var(--c-blue);box-shadow:0 0 0 3px #2563eb14;transform:translateY(-1px)}.ant-card{border-radius:var(--radius-lg)!important;border-color:var(--c-border)!important;box-shadow:none!important}.ant-card-head{border-bottom-color:var(--c-border-2)!important;padding:0 20px!important;min-height:48px!important}.ant-card-head-title{font-size:14px!important;font-weight:600!important}.ant-card-body{padding:20px!important}.ant-table-thead>tr>th{background:var(--c-bg)!important;font-size:12px!important;font-weight:600!important;color:var(--c-text-3)!important;letter-spacing:.3px!important;border-bottom-color:var(--c-border)!important}.ant-table-tbody>tr>td{border-bottom-color:var(--c-border-2)!important}.ant-table-tbody>tr:hover>td{background:var(--c-bg)!important}.ant-table{border-radius:var(--radius-lg)!important}.ant-progress-inner{background:var(--c-border-2)!important}.ant-tabs-tab{font-size:13px!important}.ant-tabs-tab.ant-tabs-tab-active .ant-tabs-tab-btn{font-weight:600!important}.ant-modal-content{border-radius:var(--radius-lg)!important}.ant-btn{font-weight:500!important;border-radius:var(--radius-md)!important}.ant-input,.ant-select-selector,.ant-picker{border-radius:var(--radius-md)!important}.ant-tag{border-radius:5px!important}.recharts-tooltip-wrapper .recharts-default-tooltip{border-radius:var(--radius-md)!important;border-color:var(--c-border)!important;box-shadow:var(--shadow-md)!important;font-family:var(--font-sans)!important;font-size:12px!important}
