:root{--brand-primary: #E80033;--brand-primary-hover: #CF002D;--brand-primary-active: #A30024;--brand-primary-light: #FFF1F4;--brand-secondary: #4C4546;--brand-secondary-hover: #3A3334;--sidebar-bg: #2D2526;--sidebar-hover: #3A3132;--sidebar-active: rgba(232, 0, 51, .12);--sidebar-text: rgba(255, 255, 255, .6);--sidebar-text-hover: rgba(255, 255, 255, .9);--sidebar-text-active: #FFFFFF;--sidebar-border: rgba(255, 255, 255, .08);--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--success: #16A34A;--success-light: #DCFCE7;--success-dark: #15803D;--warning: #D97706;--warning-light: #FEF3C7;--warning-dark: #B45309;--danger: #DC2626;--danger-light: #FEE2E2;--danger-dark: #B91C1C;--info: #2563EB;--info-light: #DBEAFE;--info-dark: #1D4ED8;--scope-platform: #E80033;--scope-platform-bg: #FFF1F4;--scope-tenant: #2563EB;--scope-tenant-bg: #DBEAFE;--scope-org: #D97706;--scope-org-bg: #FEF3C7;--scope-project: #16A34A;--scope-project-bg: #DCFCE7;--scope-system: #7C3AED;--scope-system-bg: #F3E8FF;--scope-custom: #EA580C;--scope-custom-bg: #FFF7ED;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Cascadia Code", "Fira Code", "Consolas", monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 13px;--text-md: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-4xl: 32px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 14px;--radius-2xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .04), 0 2px 4px rgba(0, 0, 0, .03);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .12);--shadow-primary: 0 4px 14px rgba(232, 0, 51, .25);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--content-max-width: 1200px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--gray-50);color:var(--gray-800);overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh}.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background:#fff;border-bottom:1px solid var(--gray-200);z-index:50;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:var(--space-3)}.topbar-logo{width:32px;height:32px;border-radius:var(--radius-md);background:var(--brand-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--text-base);letter-spacing:-.5px}.topbar-brand{font-size:17px;font-weight:700;color:var(--gray-900);letter-spacing:-.3px}.mode-switcher{display:flex;background:var(--gray-100);border-radius:var(--radius-md);padding:3px}.mode-switcher button{padding:6px 16px;border-radius:6px;border:none;cursor:pointer;font-size:var(--text-base);font-weight:500;font-family:var(--font-sans);background:transparent;color:var(--gray-500);transition:all var(--transition-base)}.mode-switcher button.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:var(--brand-primary);font-weight:600}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.role-select{padding:6px 12px;border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-sans);cursor:pointer;background:#fff;transition:border-color var(--transition-base);color:var(--gray-700)}.role-select:hover{border-color:var(--gray-400)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gray-200),var(--gray-300));display:flex;align-items:center;justify-content:center;font-size:var(--text-md);cursor:pointer}.mid{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;background:var(--sidebar-bg);overflow-y:auto;flex-shrink:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar-mode-label{padding:var(--space-5) var(--space-5) var(--space-2);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1.5px;color:var(--gray-400);font-weight:700}.nav-section-title{padding:var(--space-2) var(--space-5);font-size:9px;text-transform:uppercase;letter-spacing:1.8px;color:var(--gray-500);font-weight:700;opacity:.6}.nav-section-title:first-of-type{padding-top:var(--space-3)}.nav-item{display:flex;align-items:center;padding:7px var(--space-5);color:var(--sidebar-text);font-size:var(--text-base);cursor:pointer;border-left:3px solid transparent;transition:all var(--transition-fast);letter-spacing:-.1px;text-decoration:none}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-hover)}.nav-item.active{background:var(--sidebar-active);border-left-color:var(--brand-primary);color:var(--sidebar-text-active);font-weight:600}.nav-item .icon{width:22px;text-align:center;font-size:15px;margin-right:var(--space-2)}.nav-item .nav-badge{margin-left:auto;font-size:10px;color:var(--gray-500)}.nav-item .toggle-arrow{margin-left:auto;font-size:10px;color:var(--gray-500);transition:transform var(--transition-base)}.nav-children{overflow:hidden;max-height:0;transition:max-height .25s ease}.nav-children.open{max-height:800px}.nav-children .nav-item{padding-left:44px;font-size:var(--text-sm)}.ct{flex:1;overflow-y:auto;padding:28px 32px 56px;background:var(--gray-50)}.ct::-webkit-scrollbar{width:6px}.ct::-webkit-scrollbar-track{background:transparent}.ct::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.breadcrumb{font-size:var(--text-base);color:var(--gray-500);margin-bottom:var(--space-5);display:flex;align-items:center;gap:6px}.breadcrumb strong{color:var(--gray-900)}.perm-denied-alert{background:var(--brand-primary-light);border:1px solid #FECACA;border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);margin-bottom:var(--space-5);display:none;align-items:center;gap:var(--space-3);font-size:var(--text-base);color:var(--danger-dark);animation:slideDown .3s ease}.perm-denied-alert.visible{display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.perm-denied-alert .role-tag{color:var(--brand-primary);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-sans);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;line-height:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:6px 12px;font-size:var(--text-sm);border-radius:var(--radius-sm)}.btn-md{padding:9px 18px;font-size:var(--text-base)}.btn-lg{padding:12px 24px;font-size:var(--text-md);border-radius:var(--radius-lg)}.btn-primary{background:var(--brand-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-primary-hover);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:var(--success-dark)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-dark)}.btn-outline{background:transparent;border:1.5px solid var(--gray-300);color:var(--gray-700)}.btn-outline:hover:not(:disabled){border-color:var(--brand-primary);color:var(--brand-primary)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.2px;line-height:1.5}.badge-platform{background:var(--scope-platform-bg);color:var(--scope-platform)}.badge-tenant{background:var(--scope-tenant-bg);color:var(--scope-tenant)}.badge-org{background:var(--scope-org-bg);color:var(--scope-org)}.badge-project{background:var(--scope-project-bg);color:var(--scope-project)}.badge-system{background:var(--scope-system-bg);color:var(--scope-system)}.badge-custom{background:var(--scope-custom-bg);color:var(--scope-custom)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-default{background:var(--gray-100);color:var(--gray-600)}.badge-dark{background:var(--gray-800);color:#fff}.table-wrap{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff}.table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-base)}.data-table thead th{background:var(--gray-50);padding:var(--space-3) var(--space-4);text-align:left;font-weight:600;font-size:var(--text-sm);color:var(--gray-600);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--gray-200)}.data-table thead th.center{text-align:center}.data-table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--gray-100);color:var(--gray-700)}.data-table tbody td.center{text-align:center}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tbody tr:last-child td{border-bottom:none}.action-btn{background:none;border:none;cursor:pointer;font-size:var(--text-sm);font-weight:600;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.action-btn-edit{color:var(--info)}.action-btn-edit:hover{background:var(--info-light);color:var(--info-dark)}.action-btn-delete{color:var(--danger)}.action-btn-delete:hover{background:var(--danger-light);color:var(--danger-dark)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-top:1px solid var(--gray-100)}.pagination-info{font-size:var(--text-sm);color:var(--gray-500)}.pagination-pages{display:flex;gap:var(--space-1)}.page-btn{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-size:var(--text-sm);font-weight:500;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--gray-600)}.page-btn:hover{border-color:var(--brand-primary);color:var(--brand-primary)}.page-btn.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-base);font-weight:500;color:var(--gray-700);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{width:100%;padding:9px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-sans);background:#fff;color:var(--gray-800);transition:all var(--transition-base);outline:none}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--gray-400)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px #e8003314}.form-input.error,.form-select.error{border-color:var(--danger);box-shadow:0 0 0 3px #dc262614}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.form-hint{font-size:var(--text-sm);color:var(--gray-500);margin-top:var(--space-1)}.form-error{font-size:var(--text-sm);color:var(--danger);margin-top:var(--space-1)}.form-textarea{min-height:80px;resize:vertical}.alert{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-base);display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);border-left:4px solid}.alert-icon{font-size:var(--text-lg);flex-shrink:0;margin-top:1px}.alert-content{flex:1}.alert-title{font-weight:600;margin-bottom:var(--space-1)}.alert-info{background:var(--info-light);border-left-color:var(--info);color:var(--info-dark)}.alert-success{background:var(--success-light);border-left-color:var(--success);color:var(--success-dark)}.alert-warning{background:var(--warning-light);border-left-color:var(--warning);color:var(--warning-dark)}.alert-danger{background:var(--danger-light);border-left-color:var(--danger);color:var(--danger-dark)}.modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1000}.modal-overlay.active{display:flex}.modal{background:#fff;border-radius:var(--radius-2xl);padding:var(--space-8);width:520px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--space-5)}.modal-body{margin-bottom:var(--space-6);color:var(--gray-600);font-size:var(--text-md);line-height:1.6}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-5);border-top:1px solid var(--gray-100)}.toast-container{position:fixed;top:70px;right:var(--space-5);z-index:2000;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:500;color:#fff;box-shadow:var(--shadow-lg);animation:toastSlide .3s ease;min-width:260px;pointer-events:auto}@keyframes toastSlide{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-success{background:linear-gradient(135deg,#22c55e,var(--success))}.toast-info{background:linear-gradient(135deg,#3b82f6,var(--info))}.toast-warning{background:linear-gradient(135deg,#f59e0b,var(--warning))}.toast-danger{background:linear-gradient(135deg,#ef4444,var(--danger))}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.stat-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card[data-color=red]:before{background:var(--brand-primary)}.stat-card[data-color=green]:before{background:var(--success)}.stat-card[data-color=blue]:before{background:var(--info)}.stat-card[data-color=amber]:before{background:var(--warning)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.kpi-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--space-4);transition:all var(--transition-base);border:1px solid transparent}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--gray-200)}.kpi-icon{font-size:26px;width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-100),var(--gray-200));flex-shrink:0}.kpi-body{min-width:0}.kpi-num{font-size:28px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px;line-height:1;display:flex;align-items:baseline;gap:var(--space-2)}.kpi-label{font-size:var(--text-sm);color:var(--gray-500);font-weight:500;display:flex;align-items:center;gap:var(--space-2)}.kpi-trend{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);font-weight:600}.kpi-trend.up{background:var(--success-light);color:var(--success)}.kpi-trend.down{background:var(--danger-light);color:var(--danger)}.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-bottom:var(--space-5)}.chart-card{background:#fff;border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.chart-card h4{font-size:var(--text-base);font-weight:600;color:var(--gray-600);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.3px}.line-chart{height:140px;display:flex;align-items:flex-end;gap:2px;padding:var(--space-4) 0;position:relative}.line-chart:before{content:"";position:absolute;bottom:16px;left:0;right:0;height:1px;background:var(--gray-200)}.chart-point{flex:1;background:var(--info);border-radius:3px 3px 0 0;opacity:.7;transition:opacity var(--transition-fast);min-width:4px}.chart-point:hover{opacity:1}.chart-legend{display:flex;gap:var(--space-4);margin-top:var(--space-3);font-size:var(--text-xs);color:var(--gray-500)}.chart-legend-dot{width:8px;height:8px;border-radius:2px;display:inline-block;margin-right:4px}.donut-wrap{display:flex;flex-direction:column;align-items:center;padding:var(--space-3) 0}.donut{width:130px;height:130px;border-radius:50%;background:conic-gradient(var(--brand-primary) 0deg 108deg,var(--success) 108deg 216deg,var(--warning) 216deg 288deg,var(--info) 288deg 360deg);display:flex;align-items:center;justify-content:center}.donut-hole{width:80px;height:80px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-pct{font-size:22px;font-weight:800;color:var(--gray-900);line-height:1}.donut-lbl{font-size:var(--text-xs);color:var(--gray-500)}.donut-legend{display:flex;gap:var(--space-4);flex-wrap:wrap;justify-content:center;margin-top:var(--space-4);font-size:var(--text-xs);color:var(--gray-500)}.section-card{background:#fff;border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.section-card h4{font-size:var(--text-base);font-weight:600;color:var(--gray-600);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.3px}.greeting-banner{background:#fff;border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);margin-bottom:var(--space-5);display:flex;justify-content:space-between;align-items:center}.greeting-banner h2{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);margin-bottom:2px}.greeting-banner p{font-size:var(--text-md);color:var(--gray-500)}.af-item{padding:10px 0;border-bottom:1px solid var(--gray-100);font-size:var(--text-base);display:flex;justify-content:space-between;align-items:center}.af-item:last-child{border-bottom:none}.af-text{color:var(--gray-700);flex:1;min-width:0}.af-time{color:var(--gray-400);font-size:var(--text-xs);white-space:nowrap;margin-left:var(--space-3)}.ql-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.ql-item{padding:var(--space-4) var(--space-3);border-radius:var(--radius-lg);text-align:center;cursor:pointer;border:1px solid var(--gray-200);transition:all var(--transition-base);font-size:var(--text-sm);font-weight:500;color:var(--gray-700)}.ql-item:hover{background:var(--brand-primary-light);border-color:#e8003333;transform:translateY(-1px)}.ql-item.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.ql-icon{font-size:22px;margin-bottom:6px}.ql-lock{display:none;font-size:9px;color:var(--warning);margin-top:4px;font-weight:600}.ql-item.disabled .ql-lock{display:block}.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.tabs-bar{display:flex;border-bottom:2px solid var(--gray-200);gap:var(--space-1);background:#fff;margin-bottom:var(--space-5)}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-md);font-weight:500;color:var(--gray-500);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-base)}.tab-btn:hover{color:var(--gray-700)}.tab-btn.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary);font-weight:600}.tab-panel{display:none}.tab-panel.active{display:block}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);gap:var(--space-3)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--space-3)}.search-input{width:220px;padding:7px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);font-size:var(--text-base);outline:none;background:var(--gray-50);transition:all var(--transition-base)}.search-input:focus{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #e800330f}.filter-select{padding:7px 12px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);font-size:var(--text-base);background:#fff;cursor:pointer;outline:none}.role-header-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);margin-bottom:var(--space-5);display:flex;justify-content:space-between;align-items:flex-start}.role-header-name{font-size:var(--text-3xl);font-weight:800;display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.role-header-desc{font-size:var(--text-md);color:var(--gray-500);line-height:1.5;margin-bottom:var(--space-3)}.role-header-meta{display:flex;gap:var(--space-5);flex-wrap:wrap;font-size:var(--text-sm);color:var(--gray-500)}.role-header-actions{display:flex;gap:var(--space-3)}.mini-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.mini-stat-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);text-align:center}.mini-stat-num{font-size:var(--text-4xl);font-weight:800;color:var(--gray-900)}.mini-stat-label{font-size:var(--text-sm);color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.member-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;font-family:var(--font-mono);flex-shrink:0}.member-name-cell{display:flex;align-items:center;gap:var(--space-3)}.filter-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.filter-input{flex:1;padding:9px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-base);outline:none;transition:all var(--transition-base)}.filter-input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px #e8003314}.toggle-switch{position:relative;width:44px;height:24px;display:inline-block}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--gray-300);border-radius:var(--radius-full);transition:var(--transition-base)}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-base);box-shadow:var(--shadow-xs)}.toggle-switch input:checked+.toggle-slider{background:var(--brand-primary)}.toggle-switch input:checked+.toggle-slider:after{transform:translate(20px)}.settings-form{background:#fff;border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);max-width:640px}.toggle-group{display:flex;align-items:center;gap:var(--space-3)}.toggle-label{font-size:var(--text-base);color:var(--gray-700)}.form-actions{display:flex;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--gray-200)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--gray-400)}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-600);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--text-md);color:var(--gray-500)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.page-title{font-size:var(--text-3xl);font-weight:800;color:var(--gray-900)}.wizard-container{max-width:720px;background:#fff;border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-sm)}.wizard-stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--gray-200)}.wizard-step{display:flex;align-items:center;gap:var(--space-2);position:relative}.wizard-step-number{width:32px;height:32px;border-radius:50%;background:var(--gray-200);color:var(--gray-500);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;transition:all var(--transition-base)}.wizard-step.active .wizard-step-number{background:var(--brand-primary);color:#fff}.wizard-step.completed .wizard-step-number{background:var(--success);color:#fff}.wizard-step-label{font-size:var(--text-sm);font-weight:500;color:var(--gray-500)}.wizard-step.active .wizard-step-label{color:var(--gray-900);font-weight:600}.wizard-step.completed .wizard-step-label{color:var(--success)}.wizard-step-line{width:40px;height:2px;background:var(--gray-200);margin:0 var(--space-3)}.wizard-step.completed+.wizard-step .wizard-step-line,.wizard-step.completed .wizard-step-line{background:var(--success)}.wizard-content{margin-bottom:var(--space-6)}.wizard-actions{display:flex;justify-content:space-between;padding-top:var(--space-5);border-top:1px solid var(--gray-200)}.settings-form-container{max-width:720px}.settings-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-5);overflow:hidden}.settings-section-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--gray-100)}.settings-section-title{font-size:var(--text-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--space-1)}.settings-section-desc{font-size:var(--text-sm);color:var(--gray-500)}.settings-section-body{padding:var(--space-5) var(--space-6)}.progress-bar-wrap{display:flex;align-items:center;gap:var(--space-3)}.progress-bar{flex:1;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar-label{font-size:var(--text-sm);font-weight:600;color:var(--gray-600);min-width:40px;text-align:right}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:1}}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-title{height:24px;width:200px;margin-bottom:12px}.skeleton-card{height:100px;border-radius:var(--radius-lg)}.skeleton-row{height:48px;margin-bottom:4px}.sidebar-search{padding:var(--space-2) var(--space-4)}.sidebar-search-input{width:100%;padding:6px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fffc;font-size:var(--text-sm);outline:none;transition:all var(--transition-base)}.sidebar-search-input::placeholder{color:#ffffff4d}.sidebar-search-input:focus{background:#ffffff1f;border-color:#fff3}.confirm-dialog-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1001}.confirm-dialog-overlay.active{display:flex}.confirm-dialog{background:#fff;border-radius:var(--radius-2xl);padding:var(--space-8);width:400px;max-width:90vw;box-shadow:var(--shadow-xl);text-align:center}.confirm-dialog-icon{font-size:48px;margin-bottom:var(--space-4)}.confirm-dialog-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--space-2)}.confirm-dialog-desc{font-size:var(--text-md);color:var(--gray-500);margin-bottom:var(--space-6);line-height:1.5}.confirm-dialog-actions{display:flex;gap:var(--space-3);justify-content:center}.scope-indicator{display:flex;align-items:center;gap:var(--space-2);padding:4px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;border:1px solid}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.animate-in{animation:fadeInUp .4s ease both}.animate-fade{animation:fadeIn .3s ease both}.animate-slide-left{animation:slideInLeft .4s ease both}.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.delay-6{animation-delay:.3s}.delay-7{animation-delay:.35s}.delay-8{animation-delay:.4s}.kpi-grid>.kpi-card{animation:fadeInUp .4s ease both}.kpi-grid>.kpi-card:nth-child(1){animation-delay:.05s}.kpi-grid>.kpi-card:nth-child(2){animation-delay:.1s}.kpi-grid>.kpi-card:nth-child(3){animation-delay:.15s}.kpi-grid>.kpi-card:nth-child(4){animation-delay:.2s}.stat-grid>.stat-card{animation:fadeInUp .4s ease both}.stat-grid>.stat-card:nth-child(1){animation-delay:.05s}.stat-grid>.stat-card:nth-child(2){animation-delay:.1s}.stat-grid>.stat-card:nth-child(3){animation-delay:.15s}.stat-grid>.stat-card:nth-child(4){animation-delay:.2s}.chart-row>.chart-card{animation:fadeInUp .45s ease both}.chart-row>.chart-card:nth-child(1){animation-delay:.2s}.chart-row>.chart-card:nth-child(2){animation-delay:.28s}.bottom-row>.section-card{animation:fadeInUp .45s ease both}.bottom-row>.section-card:nth-child(1){animation-delay:.3s}.bottom-row>.section-card:nth-child(2){animation-delay:.38s}.greeting-banner{animation:fadeInUp .4s ease both}.table-wrap{animation:fadeInUp .4s ease .1s both}.data-table tbody tr{animation:fadeIn .3s ease both}.data-table tbody tr:nth-child(1){animation-delay:.05s}.data-table tbody tr:nth-child(2){animation-delay:.08s}.data-table tbody tr:nth-child(3){animation-delay:.11s}.data-table tbody tr:nth-child(4){animation-delay:.14s}.data-table tbody tr:nth-child(5){animation-delay:.17s}.data-table tbody tr:nth-child(6){animation-delay:.2s}.data-table tbody tr:nth-child(7){animation-delay:.23s}.data-table tbody tr:nth-child(8){animation-delay:.26s}.data-table tbody tr:nth-child(9){animation-delay:.29s}.data-table tbody tr:nth-child(10){animation-delay:.32s}.page-header{animation:fadeInUp .35s ease both}.breadcrumb{animation:fadeIn .3s ease both}.role-header-card{animation:fadeInUp .4s ease both}.tabs-bar{animation:fadeIn .3s ease .1s both}.mini-stat-grid>.mini-stat-card{animation:fadeInUp .4s ease both}.mini-stat-grid>.mini-stat-card:nth-child(1){animation-delay:.05s}.mini-stat-grid>.mini-stat-card:nth-child(2){animation-delay:.1s}.mini-stat-grid>.mini-stat-card:nth-child(3){animation-delay:.15s}.settings-form{animation:fadeInUp .4s ease .1s both}.settings-section{animation:fadeInUp .4s ease both}.settings-section:nth-child(1){animation-delay:.05s}.settings-section:nth-child(2){animation-delay:.12s}.settings-section:nth-child(3){animation-delay:.19s}.wizard-container{animation:fadeInUp .45s ease .05s both}.modal{animation:modalIn .3s cubic-bezier(.34,1.56,.64,1) both}.toast.exiting{animation:toastOut .25s ease both}.chart-point{transform-origin:bottom;animation:barGrow .5s ease both}@keyframes barGrow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.line-chart>.chart-point:nth-child(1){animation-delay:.3s}.line-chart>.chart-point:nth-child(2){animation-delay:.32s}.line-chart>.chart-point:nth-child(3){animation-delay:.34s}.line-chart>.chart-point:nth-child(4){animation-delay:.36s}.line-chart>.chart-point:nth-child(5){animation-delay:.38s}.line-chart>.chart-point:nth-child(6){animation-delay:.4s}.line-chart>.chart-point:nth-child(7){animation-delay:.42s}.line-chart>.chart-point:nth-child(8){animation-delay:.44s}.line-chart>.chart-point:nth-child(9){animation-delay:.46s}.line-chart>.chart-point:nth-child(10){animation-delay:.48s}.line-chart>.chart-point:nth-child(11){animation-delay:.5s}.line-chart>.chart-point:nth-child(12){animation-delay:.52s}.line-chart>.chart-point:nth-child(13){animation-delay:.54s}.line-chart>.chart-point:nth-child(14){animation-delay:.56s}.line-chart>.chart-point:nth-child(15){animation-delay:.58s}.line-chart>.chart-point:nth-child(16){animation-delay:.6s}.line-chart>.chart-point:nth-child(17){animation-delay:.62s}.line-chart>.chart-point:nth-child(18){animation-delay:.64s}.line-chart>.chart-point:nth-child(19){animation-delay:.66s}.line-chart>.chart-point:nth-child(20){animation-delay:.68s}.line-chart>.chart-point:nth-child(21){animation-delay:.7s}.line-chart>.chart-point:nth-child(22){animation-delay:.72s}.line-chart>.chart-point:nth-child(23){animation-delay:.74s}.line-chart>.chart-point:nth-child(24){animation-delay:.76s}.donut{animation:donutSpin .8s ease .3s both}@keyframes donutSpin{0%{transform:rotate(-90deg) scale(.8);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0ms!important;transition-duration:.01ms!important}}.skip-to-content{position:absolute;top:-100%;left:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--brand-primary);color:#fff;font-weight:600;font-size:var(--text-md);border-radius:0 0 var(--radius-md) var(--radius-md);z-index:9999;text-decoration:none;transition:top var(--transition-fast)}.skip-to-content:focus{top:0}:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}.btn:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px;box-shadow:0 0 0 4px #e8003326}.nav-item:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:-2px;background:var(--sidebar-hover)}.form-input:focus-visible,.form-select:focus-visible,.form-textarea:focus-visible{outline:none}.page-btn:focus-visible{outline:2px solid var(--brand-primary);outline-offset:1px}.action-btn:focus-visible{outline:2px solid var(--info);outline-offset:1px;border-radius:var(--radius-sm)}.tab-btn:focus-visible{outline:2px solid var(--brand-primary);outline-offset:-2px}.ql-item:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.search-input:focus-visible,.filter-select:focus-visible,.filter-input:focus-visible{outline:none}.sidebar-search-input:focus-visible{outline:none}.role-select:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.mode-switcher button:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.toggle-switch input:focus-visible+.toggle-slider{outline:2px solid var(--brand-primary);outline-offset:2px}.qc-dropdown{display:none;position:fixed;min-width:200px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;z-index:100;padding:var(--space-2) 0;animation:fadeInUp .2s ease both}.qc-dropdown.open{display:block}.qc-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-md);color:var(--gray-700);text-decoration:none;transition:background var(--transition-fast);cursor:pointer}.qc-item:hover{background:var(--gray-50)}.qc-icon{font-size:18px;width:24px;text-align:center}.bulk-action-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--info-light);border-radius:var(--radius-md);margin-bottom:var(--space-3);animation:fadeInUp .25s ease both;font-size:var(--text-base);color:var(--info-dark)}.bulk-action-bar .bulk-count{font-weight:700}.bulk-action-bar .bulk-actions{margin-left:auto;display:flex;gap:var(--space-2)}.row-checkbox{width:16px;height:16px;accent-color:var(--brand-primary);cursor:pointer}.row-checkbox:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.perm-hidden{display:none!important}.perm-disabled{opacity:.4;pointer-events:none;cursor:not-allowed}.perm-disabled button,.perm-disabled a{pointer-events:none;cursor:not-allowed}@media(max-width:1100px){.kpi-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}.chart-row,.bottom-row{grid-template-columns:1fr}.ct{padding:var(--space-5)}.mini-stat-grid{grid-template-columns:repeat(2,1fr)}.wizard-stepper{flex-wrap:wrap;gap:var(--space-2)}.wizard-step-line{width:20px}.settings-form-container{max-width:100%}}@media(max-width:768px){.sidebar{display:none}.kpi-grid,.stat-grid{grid-template-columns:1fr 1fr}.ql-grid{grid-template-columns:repeat(2,1fr)}.wizard-container{padding:var(--space-5)}.wizard-step-label{display:none}.wizard-step-line{width:24px}}
