:root{--color-primary: #667eea;--color-primary-dark: #764ba2;--color-primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--color-success: #10b981;--color-success-light: #d1fae5;--color-error: #ef4444;--color-error-light: #fee2e2;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-bg: #f5f7fa;--color-bg-white: #ffffff;--color-text: #333333;--color-text-secondary: #666666;--color-text-muted: #999999;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--sidebar-width: 240px;--sidebar-collapsed-width: 60px;--sidebar-bg: var(--color-primary-gradient);--topbar-height: 60px;--mobile-nav-height: 64px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 16px;--font-lg: 20px;--font-xl: 24px;--font-2xl: 28px;--font-3xl: 32px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-sidebar: 1000;--z-topbar: 900;--z-mobile-nav: 1000;--z-modal: 2000;--z-toast: 3000}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;background:#f5f7fa}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{font-family:inherit}a{color:inherit;text-decoration:none}input,textarea,select{font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.card-header{font-size:18px;font-weight:600;margin-bottom:16px;color:#333}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f5f7fa;color:#333;border:1px solid #e0e0e0}.btn-secondary:hover:not(:disabled){background:#e8ecf0}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.table thead{background:#f5f7fa}.table th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;letter-spacing:.5px}.table td{padding:12px 16px;border-top:1px solid #e0e0e0;font-size:14px}.table tbody tr:hover{background:#f9fafb}.spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.alert-success{background:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.alert-warning{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.alert-info{background:#dbeafe;border:1px solid #93c5fd;color:#1e3a8a}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:toast-slide-in .3s ease-out;background:#fff;border-left:4px solid}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-info{border-left-color:#667eea}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-weight:700;font-size:16px}.toast-success .toast-icon{background:#d1fae5;color:#065f46}.toast-error .toast-icon{background:#fee2e2;color:#991b1b}.toast-warning .toast-icon{background:#fef3c7;color:#92400e}.toast-info .toast-icon{background:#eef2ff;color:#3730a3}.toast-message{flex:1;font-size:14px;color:#333;line-height:1.5}.toast-close{background:none;border:none;font-size:24px;line-height:1;color:#999;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.toast-close:hover{color:#333}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.toast-container{inset:auto 20px 20px;max-width:none}}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--color-primary-gradient);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;overflow-y:auto;z-index:var(--z-sidebar);transition:width var(--transition-slow)}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar-logo{font-size:24px;font-weight:700;margin:0;color:#fff}.sidebar-nav{padding:8px 0;flex:1;overflow-y:auto}.nav-group{margin-bottom:4px}.nav-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 20px;background:none;border:none;color:#ffffff80;cursor:pointer;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;transition:color var(--transition-fast)}.nav-group-header:hover{color:#fffc}.nav-group-label{flex:1;text-align:left}.nav-group-items{padding:2px 0}.sidebar-item{display:flex;align-items:center;padding:10px 20px;color:#ffffffbf;text-decoration:none;transition:all var(--transition-fast);position:relative;gap:12px;font-size:14px}.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-item.active{background:#ffffff26;color:#fff;border-left:3px solid #fff;padding-left:17px}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:20px;flex-shrink:0}.sidebar-label{flex:1;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-badge{background:#ff4757;color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;min-width:20px;text-align:center;flex-shrink:0}.sidebar::-webkit-scrollbar,.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track,.sidebar-nav::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb,.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover,.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(min-width:768px)and (max-width:1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar-logo{font-size:16px;text-align:center}.sidebar-header{padding:16px 8px}.nav-group-header{padding:6px 8px;justify-content:center}.nav-group-label,.nav-group-header svg{display:none}.sidebar-item{padding:12px;justify-content:center;gap:0}.sidebar-item.active{padding-left:9px}.sidebar-label,.sidebar-badge{display:none}.sidebar-icon{width:auto}}@media(max-width:767px){.sidebar{display:none}}.topbar{height:60px;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:999}.topbar-content{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 30px}.topbar-left{flex:1}.topbar-org-name{font-size:20px;font-weight:600;color:#333;margin:0}.topbar-right{display:flex;align-items:center;gap:20px}.user-menu-container{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f5f7fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease}.user-menu-trigger:hover{background:#e8ecf0}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-name{font-size:14px;font-weight:500;color:#333}.user-arrow{font-size:10px;color:#666}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden}.user-menu-header{padding:16px;background:#f5f7fa}.user-menu-name{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.user-menu-email{font-size:13px;color:#666;margin-bottom:4px}.user-menu-role{font-size:12px;color:#999;text-transform:capitalize}.user-menu-divider{height:1px;background:#e0e0e0}.user-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:background .2s ease}.user-menu-item:hover{background:#f5f7fa}.user-menu-item span{font-size:16px}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-height);background:var(--color-bg-white);border-top:1px solid var(--color-border);z-index:var(--z-mobile-nav);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0)}@media(max-width:767px){.mobile-nav{display:flex;align-items:center;justify-content:space-around}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;color:var(--color-text-muted);text-decoration:none;background:none;border:none;cursor:pointer;font-size:10px;font-weight:500;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-nav-item.active{color:var(--color-primary)}.mobile-nav-item:active{transform:scale(.95)}.mobile-drawer-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:calc(var(--z-mobile-nav) + 1)}.mobile-drawer{display:none;position:fixed;bottom:var(--mobile-nav-height);left:0;right:0;max-height:70vh;background:var(--color-bg-white);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);z-index:calc(var(--z-mobile-nav) + 2);overflow-y:auto;animation:slideUp .25s ease;padding-bottom:env(safe-area-inset-bottom,0)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:767px){.mobile-drawer-overlay,.mobile-drawer{display:block}}.mobile-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-light)}.mobile-drawer-header h3{margin:0;font-size:var(--font-md);font-weight:600}.drawer-close{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:4px;display:flex;align-items:center}.mobile-drawer-items{padding:8px 0}.mobile-drawer-item{display:flex;align-items:center;gap:14px;padding:14px 20px;color:var(--color-text);text-decoration:none;transition:background var(--transition-fast)}.mobile-drawer-item:active{background:var(--color-bg)}.mobile-drawer-item.active{color:var(--color-primary);background:#667eea08}.drawer-item-icon{display:flex;align-items:center;color:var(--color-text-muted)}.mobile-drawer-item.active .drawer-item-icon{color:var(--color-primary)}.drawer-item-label{flex:1;font-size:var(--font-base);font-weight:500}.drawer-item-badge{background:var(--color-error);color:#fff;padding:2px 8px;border-radius:12px;font-size:var(--font-xs);font-weight:600}.dashboard-container{display:flex;height:100vh;overflow:hidden;background:var(--color-bg)}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;overflow:hidden;transition:margin-left var(--transition-slow)}.content-area{flex:1;overflow-y:auto;padding:24px}.content-area::-webkit-scrollbar{width:8px}.content-area::-webkit-scrollbar-track{background:var(--color-bg)}.content-area::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.content-area::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(min-width:768px)and (max-width:1024px){.main-content{margin-left:var(--sidebar-collapsed-width)}.content-area{padding:20px}}@media(max-width:767px){.main-content{margin-left:0}.content-area{padding:16px;padding-bottom:calc(var(--mobile-nav-height) + 16px)}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 20px}.loading-spinner-fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:fixed;inset:0;background:#fffffff2;z-index:9999}.spinner{border-radius:50%;border-style:solid;border-color:#e0e0e0;border-top-color:#667eea;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-md{width:40px;height:40px;border-width:4px}.spinner-lg{width:60px;height:60px;border-width:6px}.loading-message{font-size:14px;color:#666;margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:40px 20px}.error-boundary-content{max-width:600px;text-align:center}.error-boundary-content h2{font-size:24px;font-weight:700;color:#ef4444;margin:0 0 16px}.error-message{font-size:16px;color:#666;margin:0 0 24px;line-height:1.6}.error-actions{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.error-details{margin-top:24px;text-align:left;background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;padding:16px}.error-details summary{cursor:pointer;font-weight:600;color:#666;margin-bottom:12px}.error-details pre{font-size:12px;color:#ef4444;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}@media(max-width:768px){.error-actions{flex-direction:column}.error-actions button{width:100%}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
