@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;450;500;600;700;800&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap";:root{--primary-50: #e6f7ff;--primary-100: #b3e7ff;--primary-200: #80d4ff;--primary-300: #4dc1ff;--primary-400: #26b3ff;--primary-500: #00A1F6;--primary-600: #0091de;--primary-700: #007ec2;--primary-800: #006aa3;--primary-900: #004d75;--accent-50: #faf5ff;--accent-100: #f3e8ff;--accent-200: #e9d5ff;--accent-300: #d8b4fe;--accent-400: #c084fc;--accent-500: #a855f7;--accent-600: #9333ea;--accent-700: #7c3aed;--neutral-25: #fafaf9;--neutral-50: #f8f8f7;--neutral-100: #f3f2f1;--neutral-200: #e8e6e3;--neutral-300: #d6d3cf;--neutral-400: #a8a29e;--neutral-500: #78716c;--neutral-600: #57534e;--neutral-700: #44403c;--neutral-800: #292524;--neutral-900: #1c1917;--success-25: #f0fdf4;--success-50: #ecfdf5;--success-100: #d1fae5;--success-200: #a7f3d0;--success-300: #6ee7b7;--success-400: #34d399;--success-500: #10b981;--success-600: #059669;--success-700: #047857;--warning-25: #fffbeb;--warning-50: #fef3c7;--warning-100: #fde68a;--warning-200: #fcd34d;--warning-300: #fbbf24;--warning-400: #f59e0b;--warning-500: #d97706;--warning-600: #b45309;--warning-700: #92400e;--error-25: #fef2f2;--error-50: #fee2e2;--error-100: #fecaca;--error-200: #fca5a5;--error-300: #f87171;--error-400: #ef4444;--error-500: #dc2626;--error-600: #b91c1c;--error-700: #991b1b;--info-50: #eff6ff;--info-100: #dbeafe;--info-500: #3b82f6;--info-600: #2563eb;--info-700: #1d4ed8;--bg-primary: #ffffff;--bg-secondary: var(--neutral-50);--bg-tertiary: var(--neutral-100);--bg-dark: var(--neutral-900);--bg-hover: rgba(0, 0, 0, .02);--surface-primary: var(--bg-primary);--surface-secondary: var(--bg-secondary);--surface-hover: var(--bg-hover);--surface-disabled: var(--neutral-100);--border-subtle: var(--neutral-200);--border-default: var(--neutral-300);--border-hover: var(--neutral-400);--border-primary: var(--neutral-200);--border-secondary: var(--neutral-300);--border-tertiary: var(--neutral-400);--text-primary: var(--neutral-900);--text-secondary: var(--neutral-700);--text-tertiary: var(--neutral-600);--text-quaternary: var(--neutral-500);--text-placeholder: var(--neutral-400);--text-disabled: var(--neutral-300);--text-white: #ffffff;--text-on-primary: #ffffff;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .06), 0 4px 6px -2px rgba(0, 0, 0, .03);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 10px 10px -5px rgba(0, 0, 0, .02);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-3xl: 0 35px 60px -15px rgba(0, 0, 0, .2);--shadow-primary: 0 4px 14px -2px rgba(0, 161, 246, .25);--shadow-primary-lg: 0 10px 25px -3px rgba(0, 161, 246, .3);--focus-ring: 0 0 0 3px var(--primary-100), 0 1px 2px rgba(0, 0, 0, .04);--focus-ring-error: 0 0 0 3px var(--error-100), 0 1px 2px rgba(0, 0, 0, .04);--focus-ring-success: 0 0 0 3px var(--success-100), 0 1px 2px rgba(0, 0, 0, .04);--btn-shadow: 0 1px 2px rgba(0, 0, 0, .05), inset 0 1px 0 rgba(255, 255, 255, .1);--btn-shadow-hover: 0 4px 8px rgba(0, 161, 246, .2), inset 0 1px 0 rgba(255, 255, 255, .15);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Plus Jakarta Sans", var(--font-family);--text-xs: .75rem;--text-sm: .875rem;--text-md: .9375rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-display-sm: clamp(1.5rem, 3vw, 2rem);--text-display-md: clamp(2rem, 4vw, 2.5rem);--text-display-lg: clamp(2.5rem, 5vw, 3.5rem);--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--tracking-tighter: -.03em;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .02em;--tracking-wider: .04em;--tracking-widest: .08em;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-none: 0;--radius-xs: .25rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--duration-instant: 50ms;--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--duration-slower: .5s;--transition-fast: var(--duration-fast) var(--ease-out);--transition-base: var(--duration-normal) var(--ease-out);--transition-slow: var(--duration-slow) var(--ease-out);--transition-slower: var(--duration-slower) var(--ease-out);--transition-bounce: var(--duration-normal) var(--ease-bounce);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--sidebar-width: 280px;--sidebar-width-collapsed: 80px;--navbar-height: 72px;--container-max: 1280px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-weight:var(--font-regular);font-size:var(--text-md);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--text-primary);margin:0}h1{font-size:var(--text-4xl);letter-spacing:var(--tracking-tight);font-weight:800}h2{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight)}h3{font-size:var(--text-2xl);letter-spacing:-.01em}h4{font-size:var(--text-xl);font-weight:var(--font-semibold)}h5{font-size:var(--text-lg);font-weight:var(--font-semibold)}h6{font-size:var(--text-base);font-weight:var(--font-semibold)}.section-label{font-size:11px;font-weight:var(--font-semibold);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--text-quaternary)}.display-text{font-family:var(--font-display);font-weight:800;letter-spacing:var(--tracking-tighter);line-height:var(--leading-none)}p{margin:0;color:var(--text-tertiary)}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}::selection{background:var(--primary-100);color:var(--primary-900)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 18px;font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1.43;border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:transform var(--duration-instant) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out);text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary{background:linear-gradient(180deg,var(--primary-500) 0%,var(--primary-600) 100%);color:var(--text-white);border-color:var(--primary-600);box-shadow:var(--btn-shadow),0 1px 3px #00a1f633}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,var(--primary-400) 0%,var(--primary-500) 100%);border-color:var(--primary-500);box-shadow:var(--btn-shadow-hover);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background:var(--primary-600);box-shadow:inset 0 2px 4px #0000001a;transform:translateY(0) scale(.98)}.btn-secondary{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-default);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-hover);color:var(--text-primary);box-shadow:var(--shadow-sm)}.btn-secondary:active:not(:disabled){background:var(--neutral-100);box-shadow:inset 0 1px 2px #0000000f}.btn-success{background:linear-gradient(180deg,var(--success-500) 0%,var(--success-600) 100%);color:var(--text-white);border-color:var(--success-600);box-shadow:var(--shadow-xs),0 1px 3px #10b98133}.btn-success:hover:not(:disabled){background:linear-gradient(180deg,var(--success-400) 0%,var(--success-500) 100%);box-shadow:0 4px 12px #10b98140;transform:translateY(-1px)}.btn-success:active:not(:disabled){background:var(--success-600);transform:translateY(0) scale(.98)}.btn-danger{background:linear-gradient(180deg,var(--error-500) 0%,var(--error-600) 100%);color:var(--text-white);border-color:var(--error-600);box-shadow:var(--shadow-xs),0 1px 3px #dc262633}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,var(--error-400) 0%,var(--error-500) 100%);box-shadow:0 4px 12px #dc262640;transform:translateY(-1px)}.btn-danger:active:not(:disabled){background:var(--error-600);transform:translateY(0) scale(.98)}.btn-ghost{background:transparent;color:var(--text-tertiary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--neutral-100);color:var(--text-secondary)}.btn-ghost:active:not(:disabled){background:var(--neutral-200)}.btn-outline{background:transparent;color:var(--primary-600);border-color:var(--primary-300)}.btn-outline:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-400)}.btn-sm{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-md)}.btn-lg{padding:12px 20px;font-size:var(--text-base)}.btn-xl{padding:14px 28px;font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-icon{padding:10px;width:40px;height:40px}.btn-icon.btn-sm{padding:6px;width:32px;height:32px}@media (max-width: 768px){.btn{min-height:44px;padding:10px 16px}.btn-sm{min-height:36px;padding:6px 12px}.btn-icon{min-width:44px;min-height:44px}.btn-icon.btn-sm{min-width:36px;min-height:36px}}@media (hover: none) and (pointer: coarse){.btn:hover:not(:disabled){transform:none}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary:hover:not(:disabled){transform:none;background:linear-gradient(180deg,var(--primary-500) 0%,var(--primary-600) 100%);box-shadow:var(--btn-shadow)}.btn-primary:active:not(:disabled){background:var(--primary-600);transform:scale(.98)}.btn-secondary:hover:not(:disabled){background:var(--bg-primary);border-color:var(--border-default);box-shadow:var(--shadow-xs)}.btn-secondary:active:not(:disabled){background:var(--bg-secondary);border-color:var(--border-hover)}}.form-group{margin-bottom:var(--space-5)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-field+.form-field{margin-top:var(--space-5)}.form-label{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.form-label-required{color:var(--error-500)}.form-label-optional{font-weight:var(--font-regular);color:var(--text-quaternary);font-size:var(--text-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-regular);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.form-input:hover:not(:focus):not(:disabled),.form-select:hover:not(:focus):not(:disabled),.form-textarea:hover:not(:focus):not(:disabled){border-color:var(--border-hover)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--focus-ring);background:var(--bg-primary)}.form-input::placeholder{color:var(--text-placeholder)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--surface-disabled);color:var(--text-disabled);cursor:not-allowed;border-color:var(--border-subtle)}.form-input--error,.form-input.error{border-color:var(--error-500);background:var(--error-25)}.form-input--error:focus,.form-input.error:focus{box-shadow:var(--focus-ring-error)}.form-input--success,.form-input.success{border-color:var(--success-500)}.form-input--success:focus,.form-input.success:focus{box-shadow:var(--focus-ring-success)}.form-textarea{resize:vertical;min-height:100px}.form-hint{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-quaternary);display:flex;align-items:center;gap:var(--space-1)}.form-error{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--error-600);display:flex;align-items:center;gap:var(--space-1);animation:shakeError .3s ease-in-out}@keyframes shakeError{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.form-char-count{font-size:var(--text-xs);color:var(--text-quaternary);text-align:right;margin-top:var(--space-1)}.form-char-count--warning{color:var(--warning-600)}.form-char-count--error{color:var(--error-600)}@media (max-width: 768px){.form-input,.form-select,.form-textarea{min-height:44px;padding:12px 14px;font-size:16px}.form-label{font-size:var(--text-xs)}.form-group{margin-bottom:var(--space-4)}.form-field+.form-field{margin-top:var(--space-4)}}@media (max-width: 480px){.form-input,.form-select,.form-textarea{padding:12px}}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 10px;font-size:11px;font-weight:var(--font-medium);line-height:1.5;border-radius:var(--radius-full);white-space:nowrap;border:1px solid transparent}.badge:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.badge-primary{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}.badge-primary:before{background:var(--primary-500)}.badge-success{background:var(--success-50);color:var(--success-700);border-color:var(--success-200)}.badge-success:before{background:var(--success-500)}.badge-warning{background:var(--warning-50);color:var(--warning-700);border-color:var(--warning-200)}.badge-warning:before{background:var(--warning-500);animation:pulse-dot 2s ease-in-out infinite}.badge-error{background:var(--error-50);color:var(--error-700);border-color:var(--error-200)}.badge-error:before{background:var(--error-500)}.badge-info{background:var(--info-50);color:var(--info-700);border-color:var(--info-100)}.badge-info:before{background:var(--info-500)}.badge-neutral{background:var(--neutral-100);color:var(--neutral-600);border-color:var(--neutral-200)}.badge-neutral:before{background:var(--neutral-400)}.badge-accent{background:var(--accent-50);color:var(--accent-700);border-color:var(--accent-200)}.badge-accent:before{background:var(--accent-500)}.badge-purple{background:#f3e8ff;color:#7c3aed;border-color:#ddd6fe}.badge-purple:before{background:#8b5cf6}.badge-no-dot:before{display:none}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.badge-sm{padding:2px 8px;font-size:10px}.badge-sm:before{width:5px;height:5px}.badge-lg{padding:4px 12px;font-size:var(--text-xs)}.badge-lg:before{width:7px;height:7px}.badge-solid.badge-primary{background:var(--primary-500);color:#fff;border-color:var(--primary-600)}.badge-solid.badge-primary:before{background:#ffffff80}.badge-solid.badge-success{background:var(--success-500);color:#fff;border-color:var(--success-600)}.badge-solid.badge-success:before{background:#ffffff80}.badge-solid.badge-error{background:var(--error-500);color:#fff;border-color:var(--error-600)}.badge-solid.badge-error:before{background:#ffffff80}.card{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 1px 2px #00000008,0 1px 3px #00000005;transition:box-shadow var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.card-shadow{box-shadow:var(--shadow-sm)}.card-interactive{cursor:pointer}.card-interactive:hover{border-color:var(--border-default);box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -1px #0000000a;transform:translateY(-2px)}.card-interactive:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.card-elevated{box-shadow:var(--shadow-md);border-color:transparent}.card-elevated:hover{box-shadow:var(--shadow-lg)}.card-accent{border-left:3px solid var(--primary-500)}.card-accent-success{border-left:3px solid var(--success-500)}.card-accent-warning{border-left:3px solid var(--warning-500)}.card-accent-error{border-left:3px solid var(--error-500)}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);background:var(--surface-primary)}.card-body{padding:var(--space-5)}.card-body.p-0{padding:0}.card-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-subtle);background:var(--surface-secondary)}.card-section{padding:var(--space-5)}.card-section+.card-section{border-top:1px solid var(--border-subtle)}.card-ghost{background:transparent;border:none;box-shadow:none}.card-outline{background:transparent;box-shadow:none;border:1px solid var(--border-default)}.table-container{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);background:var(--surface-primary)}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--text-sm)}.table th{padding:var(--space-3) var(--space-5);text-align:left;font-size:11px;font-weight:var(--font-semibold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-quaternary);background:var(--surface-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;position:sticky;top:0;z-index:1}.table td{padding:var(--space-4) var(--space-5);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.table tbody tr{transition:background var(--duration-fast) var(--ease-out)}.table tbody tr:hover{background:var(--surface-hover)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr.selected{background:var(--primary-50)}.table tbody tr.selected:hover{background:var(--primary-100)}.table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table th.sortable:hover{background:var(--neutral-200)}.table--sticky-col td:first-child,.table--sticky-col th:first-child{position:sticky;left:0;background:inherit;box-shadow:2px 0 4px #00000008;z-index:2}.table-compact th,.table-compact td{padding:var(--space-2) var(--space-4)}.td-primary{font-weight:var(--font-medium);color:var(--text-primary)}.td-mono{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:13px}.td-truncate{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-container{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--neutral-300) transparent}.table-container::-webkit-scrollbar{height:6px}.table-container::-webkit-scrollbar-track{background:transparent}.table-container::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}.table-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}@media (max-width: 768px){.table th{padding:var(--space-2) var(--space-3);font-size:10px}.table td{padding:var(--space-3);font-size:var(--text-xs)}.table-compact th,.table-compact td{padding:var(--space-2)}.td-truncate{max-width:120px}}@media (max-width: 480px){.table th{padding:var(--space-2);font-size:9px}.table td{padding:var(--space-2);font-size:11px}.td-truncate{max-width:80px}}.avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--primary-100);color:var(--primary-700);font-weight:var(--font-semibold);font-size:var(--text-sm);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--text-md)}.avatar-xl{width:64px;height:64px;font-size:var(--text-xl)}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.avatar-status{position:relative}.avatar-status:after{content:"";position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--bg-primary);background:var(--success-500)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#101828b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal);animation:fadeIn var(--transition-fast) ease}.modal-content{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:calc(100vh - var(--space-8));overflow:hidden;animation:modalSlideIn var(--transition-base) ease}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-primary)}.modal-header h2{font-size:var(--text-lg);font-weight:var(--font-semibold)}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-primary);background:var(--bg-secondary)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-quaternary{color:var(--text-quaternary)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.m-0{margin:0}.m-4{margin:var(--space-4)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.hidden{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes toastEnter{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.animate-fadeIn{animation:fadeIn var(--duration-normal) var(--ease-out) both;opacity:1}.animate-slideUp{animation:slideUp var(--duration-normal) var(--ease-out) both;opacity:1}.animate-slideDown{animation:slideDown var(--duration-normal) var(--ease-out) both;opacity:1}.animate-scaleIn{animation:scaleIn var(--duration-normal) var(--ease-out) both;opacity:1}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.page-enter{animation:pageEnter var(--duration-normal) var(--ease-out)}.stagger-item{opacity:0;transform:translateY(8px);animation:staggerIn var(--duration-normal) var(--ease-out) forwards}.stagger-item:nth-child(1){animation-delay:0ms}.stagger-item:nth-child(2){animation-delay:50ms}.stagger-item:nth-child(3){animation-delay:.1s}.stagger-item:nth-child(4){animation-delay:.15s}.stagger-item:nth-child(5){animation-delay:.2s}.stagger-item:nth-child(6){animation-delay:.25s}.delay-75{animation-delay:75ms}.delay-100{animation-delay:.1s}.delay-150{animation-delay:.15s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.skeleton{background:linear-gradient(90deg,var(--neutral-100) 0%,var(--neutral-200) 50%,var(--neutral-100) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:1em;margin-bottom:.5em;border-radius:var(--radius-xs)}.skeleton-text:last-child{width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-avatar-sm{width:32px;height:32px;border-radius:var(--radius-full)}.skeleton-avatar-lg{width:48px;height:48px;border-radius:var(--radius-full)}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-button{height:40px;width:100px;border-radius:var(--radius-md)}.skeleton-badge{height:22px;width:80px;border-radius:var(--radius-full)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center;max-width:400px;margin:0 auto}.empty-state-icon{width:72px;height:72px;margin-bottom:var(--space-6);color:var(--text-quaternary);animation:float 3s ease-in-out infinite}.empty-state-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-6);line-height:1.6}.empty-state-action{margin-top:var(--space-2)}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 10px 40px -10px #00000026,0 4px 12px #0000000f;animation:toastEnter var(--duration-normal) var(--ease-spring);max-width:400px}.toast-success{border-left:3px solid var(--success-500)}.toast-error{border-left:3px solid var(--error-500)}.toast-warning{border-left:3px solid var(--warning-500)}.toast-info{border-left:3px solid var(--primary-500)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:2px}.toast-message{font-size:var(--text-sm);color:var(--text-tertiary)}.toast-close{flex-shrink:0;width:20px;height:20px;color:var(--text-quaternary);cursor:pointer;transition:color var(--duration-fast) var(--ease-out)}.toast-close:hover{color:var(--text-secondary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}*{scrollbar-width:thin;scrollbar-color:var(--neutral-300) transparent}@media (max-width: 1280px){:root{--sidebar-width: 260px}}@media (max-width: 1024px){.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--navbar-height: 64px}.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}.container{padding:0 var(--space-4)}.hidden-mobile{display:none!important}}@media (max-width: 480px){.container{padding:0 var(--space-3)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.skeleton{animation:none;background:var(--neutral-200)}}.skip-link{position:absolute;top:-100%;left:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--surface-primary);border:2px solid var(--primary-500);border-radius:var(--radius-md);font-weight:var(--font-medium);color:var(--primary-700);z-index:9999;transition:top var(--duration-fast) var(--ease-out)}.skip-link:focus{top:var(--space-4)}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.export-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap}.export-btn:disabled,.export-btn-disabled{opacity:.6;cursor:not-allowed}.export-btn-loading{cursor:wait}.export-btn-sm{padding:.375rem .75rem;font-size:.8rem}.export-btn-md{padding:.5rem 1rem;font-size:.875rem}.export-btn-lg{padding:.75rem 1.25rem;font-size:1rem}.export-btn-primary{background:var(--primary-color, #3b82f6);color:#fff}.export-btn-primary:hover:not(:disabled){background:var(--primary-dark, #2563eb)}.export-btn-outline{background:transparent;border:1px solid var(--border-color, #e5e7eb);color:var(--text-primary, #374151)}.export-btn-outline:hover:not(:disabled){background:var(--bg-secondary, #f9fafb);border-color:var(--primary-color, #3b82f6);color:var(--primary-color, #3b82f6)}.export-btn-icon{padding:.5rem;background:transparent;border:1px solid var(--border-color, #e5e7eb);color:var(--text-secondary, #6b7280);border-radius:6px}.export-btn-icon:hover:not(:disabled){background:var(--bg-secondary, #f9fafb);color:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6)}.export-btn-success{background:var(--success-color, #10b981)!important;border-color:var(--success-color, #10b981)!important;color:#fff!important}.export-btn-error{background:var(--error-color, #ef4444)!important;border-color:var(--error-color, #ef4444)!important;color:#fff!important}.export-btn .spin{animation:export-spin 1s linear infinite}@keyframes export-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary, #f1f5f9) 25%,var(--color-bg-secondary, #e2e8f0) 50%,var(--color-bg-tertiary, #f1f5f9) 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm, 4px)}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{display:block;border-radius:var(--radius-sm, 4px)}.skeleton-text-group{display:flex;flex-direction:column}.skeleton-avatar{border-radius:50%;flex-shrink:0}.skeleton-card{display:flex;flex-direction:column;background:var(--color-bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);border:1px solid var(--color-border, #e2e8f0);overflow:hidden}.skeleton-card-image{border-radius:0}.skeleton-card-content{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.skeleton-stat{background:var(--color-bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);border:1px solid var(--color-border, #e2e8f0);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.skeleton-stat-header{display:flex;align-items:center;gap:.75rem}.skeleton-stat-icon{border-radius:var(--radius-md, 8px)}.skeleton-table{width:100%;border-collapse:collapse}.skeleton-table th,.skeleton-table td{padding:.75rem 1rem;text-align:left}.skeleton-table thead th{border-bottom:1px solid var(--color-border, #e2e8f0)}.skeleton-table-row td{border-bottom:1px solid var(--color-border-light, #f1f5f9)}.skeleton-list-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid var(--color-border-light, #f1f5f9)}.skeleton-list-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.skeleton-dashboard{display:flex;flex-direction:column;gap:2rem;padding:1rem}.skeleton-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.skeleton-dashboard-content{display:flex;flex-direction:column;gap:2rem}.skeleton-section{display:flex;flex-direction:column;gap:1rem}.skeleton-form{display:flex;flex-direction:column;gap:1.5rem;max-width:600px}.skeleton-form-field{display:flex;flex-direction:column;gap:.5rem}.skeleton-form-actions{display:flex;gap:1rem;margin-top:1rem}.skeleton-pulse{animation:skeletonPulse 1.5s ease-in-out infinite}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-page{padding:2rem;min-height:100vh;animation:skeletonFadeIn .2s ease-out}@keyframes skeletonFadeIn{0%{opacity:0}to{opacity:1}}.skeleton-page-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.skeleton-page-content{display:flex;flex-direction:column;gap:1.5rem}.skeleton-page-main{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}@media (max-width: 768px){.skeleton-stats-grid{grid-template-columns:repeat(2,1fr)}.skeleton-stat,.skeleton-page{padding:1rem}}@media (max-width: 480px){.skeleton-stats-grid{grid-template-columns:1fr}}.app{min-height:100vh}.auth-loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#fff;z-index:9999}.auth-loading-spinner{width:40px;height:40px;border:3px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;animation:auth-spin .8s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.command-palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;z-index:9999;animation:fadeIn .15s ease-out}.command-palette{width:100%;max-width:640px;background:var(--bg-primary, white);border-radius:16px;box-shadow:0 25px 80px #00000059;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.command-search{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.command-search .search-icon{color:var(--text-secondary, #6b7280);flex-shrink:0}.command-input{flex:1;border:none;background:none;font-size:1rem;color:var(--text-primary, #111827);outline:none}.command-input::placeholder{color:var(--text-tertiary, #9ca3af)}.command-search .loading-icon{color:var(--primary-color, #6366f1);animation:spin 1s linear infinite;flex-shrink:0}.command-shortcuts{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-tertiary, #9ca3af)}.command-shortcuts kbd{background:var(--bg-secondary, #f3f4f6);padding:.125rem .375rem;border-radius:4px;font-family:inherit;font-size:.6875rem;border:1px solid var(--border-color, #e5e7eb)}.command-results{max-height:400px;overflow-y:auto;padding:.5rem}.command-results::-webkit-scrollbar{width:6px}.command-results::-webkit-scrollbar-thumb{background:var(--border-color, #e5e7eb);border-radius:3px}.result-category{padding:.5rem .75rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary, #9ca3af);margin-top:.5rem}.result-category:first-child{margin-top:0}.result-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border:none;background:none;border-radius:10px;cursor:pointer;text-align:left;transition:all .15s}.result-item:hover,.result-item.selected{background:var(--primary-50, rgba(99, 102, 241, .08))}.result-item.selected{background:var(--primary-100, rgba(99, 102, 241, .12))}.result-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-secondary, #f3f4f6);display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #6b7280);flex-shrink:0;transition:all .15s}.result-item.selected .result-icon,.result-item:hover .result-icon{background:var(--primary-color, #6366f1);color:#fff}.result-content{flex:1;min-width:0}.result-label{display:block;font-size:.9375rem;font-weight:500;color:var(--text-primary, #111827);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-description{display:block;font-size:.8125rem;color:var(--text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.125rem}.result-arrow{color:var(--text-tertiary, #9ca3af);opacity:0;transition:all .15s;flex-shrink:0}.result-item.selected .result-arrow,.result-item:hover .result-arrow{opacity:1;color:var(--primary-color, #6366f1)}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-tertiary, #9ca3af);text-align:center}.no-results svg{margin-bottom:.75rem;opacity:.5}.no-results p{font-size:.875rem;margin:0}.command-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f9fafb)}.footer-hint{display:flex;align-items:center;justify-content:center;gap:.375rem;font-size:.75rem;color:var(--text-tertiary, #9ca3af)}.footer-hint kbd{background:var(--bg-primary, white);padding:.125rem .375rem;border-radius:4px;font-family:inherit;font-size:.6875rem;border:1px solid var(--border-color, #e5e7eb);margin:0 .125rem}@media (max-width: 768px){.command-palette-overlay{padding:0;align-items:flex-end}.command-palette{max-width:100%;border-radius:20px 20px 0 0;max-height:80vh}.command-search{padding:1rem}.command-shortcuts{display:none}.command-results{max-height:calc(80vh - 140px)}.result-item{padding:.625rem .75rem}.result-icon{width:32px;height:32px}.footer-hint{font-size:.6875rem}}@media (max-width: 480px){.result-label{font-size:.875rem}.result-description{font-size:.75rem}}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background:var(--bg-primary);border-bottom:1px solid var(--border-primary);z-index:var(--z-fixed)}.navbar-container{display:flex;align-items:center;height:100%;padding:0 var(--space-6);gap:var(--space-4)}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.mobile-menu-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.navbar-logo{display:flex;align-items:center;flex-shrink:0}.logo-image{height:32px;width:auto;object-fit:contain}.navbar-search{flex:1;max-width:480px;position:relative;display:flex;align-items:center;padding:10px 80px 10px 42px;background:var(--bg-secondary);border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.navbar-search:hover{border-color:var(--border-secondary);background:var(--bg-primary)}.navbar-search:focus{outline:none;background:var(--bg-primary);border-color:var(--primary-300);box-shadow:var(--focus-ring)}.search-icon{position:absolute;left:14px;color:var(--text-placeholder);pointer-events:none;width:20px;height:20px}.search-placeholder{font-size:var(--text-sm);font-weight:var(--font-regular);color:var(--text-placeholder);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-input{width:100%;padding:10px 80px 10px 42px;font-size:var(--text-sm);font-weight:var(--font-regular);background:var(--bg-secondary);border:1px solid transparent;border-radius:var(--radius-lg);color:var(--text-primary);transition:all var(--transition-fast)}.search-input:hover{border-color:var(--border-secondary)}.search-input:focus{outline:none;background:var(--bg-primary);border-color:var(--primary-300);box-shadow:var(--focus-ring)}.search-shortcut{position:absolute;right:12px;display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-family:var(--font-family);font-weight:var(--font-medium);background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-quaternary)}.navbar-right{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.refresh-mainframe-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.refresh-mainframe-btn:hover{background:var(--bg-secondary);color:var(--primary-600)}.refresh-mainframe-btn:active{transform:scale(.95)}.refresh-mainframe-btn.refreshing svg{animation:spin .6s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.role-badge{display:flex;align-items:center;gap:var(--space-2);padding:6px 12px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary-700);background:var(--primary-50);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.role-badge:hover{background:var(--primary-100)}.role-dot{width:8px;height:8px;background:var(--primary-500);border-radius:var(--radius-full);flex-shrink:0}.navbar-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.navbar-icon-btn:hover{background:var(--bg-secondary);color:var(--text-secondary)}.navbar-icon-btn svg{width:20px;height:20px}.notification-badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:var(--font-semibold);color:var(--text-white);background:var(--error-500);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary)}.navbar-dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:320px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:dropdownSlideIn var(--transition-fast) ease}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-backdrop{display:none}.navbar-icon-btn.active{background:var(--primary-50);color:var(--primary-600)}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-primary)}.dropdown-header h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.mark-all-read{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary-600);background:none;border:none;cursor:pointer;padding:0}.mark-all-read:hover{color:var(--primary-700)}.notifications-menu{width:380px;max-width:calc(100vw - 32px)}.notifications-list{max-height:360px;overflow-y:auto}.notification-item{display:flex;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-primary);cursor:pointer;transition:background var(--transition-fast)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--bg-secondary)}.notification-item.unread{background:var(--primary-25, #F9FAFF)}.notification-item.unread:hover{background:var(--primary-50)}.notification-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-tertiary);flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:2px}.notification-message{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:var(--text-xs);color:var(--text-quaternary)}.dropdown-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-primary);text-align:center;background:var(--bg-secondary)}.view-all-btn{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-600);background:none;border:none;cursor:pointer;padding:0}.view-all-btn:hover{color:var(--primary-700)}.user-menu-btn{display:flex;align-items:center;gap:var(--space-2);padding:6px 10px 6px 6px;background:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.user-menu-btn:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.user-menu-btn.active{background:var(--primary-50);border-color:var(--primary-200)}.user-avatar{width:32px;height:32px;background:var(--primary-100);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--primary-700);font-size:var(--text-sm);font-weight:var(--font-semibold)}.user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chevron{color:var(--text-quaternary);transition:transform var(--transition-fast);flex-shrink:0}.chevron.rotated{transform:rotate(180deg)}.user-dropdown{width:280px}.user-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-primary)}.user-avatar-lg{width:44px;height:44px;background:var(--primary-100);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--primary-700);font-weight:var(--font-semibold);font-size:var(--text-md);flex-shrink:0}.user-details{flex:1;min-width:0}.user-fullname{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:var(--text-sm);color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-divider{height:1px;background:var(--border-primary);margin:var(--space-2) 0}.dropdown-section{padding:var(--space-2) 0}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:10px var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-tertiary);background:none;border:none;cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.dropdown-item:hover{background:var(--bg-secondary);color:var(--text-secondary)}.dropdown-item:focus-visible{outline:none;background:var(--primary-50);color:var(--primary-700)}.dropdown-item svg{width:18px;height:18px;color:var(--text-quaternary)}.dropdown-item.danger{color:var(--error-600)}.dropdown-item.danger:hover{background:var(--error-50)}.dropdown-item.danger svg{color:var(--error-500)}@media (max-width: 1024px){.navbar-container{padding:0 var(--space-4)}.navbar-search{max-width:320px}.search-shortcut,.user-name{display:none}}@media (max-width: 768px){.mobile-menu-btn{display:flex}.navbar-container{padding:0 var(--space-4);gap:var(--space-3)}.navbar-search,.role-badge .role-text{display:none}.role-badge{padding:6px 10px}.user-menu-btn{padding:4px;border:none;background:transparent}.user-menu-btn:hover{background:var(--bg-secondary)}.user-menu-btn.active{background:var(--primary-50)}.chevron{display:none}.dropdown-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9998;animation:backdropFadeIn .2s ease}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.dropdown-menu.notifications-menu,.dropdown-menu.user-dropdown{position:fixed!important;top:auto!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;max-width:100%!important;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-height:80vh;z-index:9999!important;animation:bottomSheetSlideUp .3s var(--ease-out)}@keyframes bottomSheetSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.dropdown-menu{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.dropdown-menu:before{content:"";display:block;width:36px;height:4px;background:var(--border-secondary);border-radius:var(--radius-full);margin:var(--space-3) auto var(--space-2)}}@media (max-width: 480px){.logo-image{height:28px}.role-badge{display:none}.navbar-right{gap:var(--space-1)}}.sidebar{position:fixed;top:var(--navbar-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--border-subtle);z-index:var(--z-sticky);overflow:hidden;display:flex;flex-direction:column;transition:width var(--duration-slow) var(--ease-in-out)}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sidebar-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-mobile-header{display:none;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);flex-shrink:0;background:var(--bg-primary)}.sidebar-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:var(--tracking-tight)}.sidebar-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--neutral-100);border-radius:var(--radius-md);color:var(--text-quaternary);cursor:pointer;transition:all var(--transition-fast)}.sidebar-close:hover{background:var(--error-50);color:var(--error-500)}.sidebar-search{padding:var(--space-3) var(--space-3) var(--space-2);flex-shrink:0}.sidebar.collapsed .sidebar-search{padding:var(--space-2);display:flex;justify-content:center}.search-wrapper{position:relative;display:flex;align-items:center;background:var(--neutral-50);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.sidebar.collapsed .search-wrapper{background:transparent;border:none;width:100%;justify-content:center;padding:8px 0;cursor:pointer;border-radius:var(--radius-md)}.sidebar.collapsed .search-wrapper:hover{background:var(--neutral-100)}.search-wrapper:focus-within{background:var(--bg-primary);border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.search-icon{position:absolute;left:12px;color:var(--text-placeholder);pointer-events:none}.sidebar.collapsed .search-icon{position:static;color:var(--text-quaternary);width:20px;height:20px}.search-input{width:100%;padding:9px 12px 9px 38px;border:none;background:transparent;font-size:var(--text-sm);color:var(--text-primary);outline:none;font-family:var(--font-family)}.search-input::placeholder{color:var(--text-placeholder)}.sidebar.collapsed .search-input{display:none}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-1) var(--space-2);scrollbar-width:thin;scrollbar-color:var(--neutral-300) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background-color:var(--neutral-300);border-radius:4px}.sidebar-nav::-webkit-scrollbar-track{background-color:transparent}.nav-section{margin-bottom:0}.dashboard-section .nav-icon{display:none}.dashboard-section .nav-link,.dashboard-section .nav-link:link,.dashboard-section .nav-link:visited{font-weight:var(--font-semibold);color:var(--text-primary);padding:8px 12px}.dashboard-section .nav-link:hover{color:var(--text-primary)}.dashboard-section .nav-link.active{color:var(--primary-700);background:var(--primary-50)}.dashboard-section .nav-link.active:before{display:none}.sidebar.collapsed .dashboard-section .nav-icon{display:block}.sidebar.collapsed .dashboard-section .nav-link{font-weight:var(--font-medium)}.nav-section-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:16px 12px 5px;margin-bottom:0;font-size:12.5px;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--neutral-400);background:transparent;border:none;border-radius:0;cursor:pointer;transition:color var(--transition-fast);text-align:left;white-space:nowrap;position:relative}.section-icon{display:none;flex-shrink:0;color:var(--text-quaternary);width:20px;height:20px;transition:color var(--transition-fast)}.nav-section-header:hover{color:var(--text-tertiary)}.nav-section-header.active{color:var(--primary-600)}.section-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section-arrow{flex-shrink:0;color:var(--neutral-400);width:18px;height:18px;stroke-width:2.5;transition:color var(--transition-fast);margin-left:auto}.nav-section-header:hover .section-arrow{color:var(--neutral-400)}.nav-section-header.active .section-arrow{color:var(--primary-400)}.sidebar.collapsed .nav-section-header{justify-content:center;padding:10px;text-transform:none;font-size:var(--text-sm);letter-spacing:0;border-radius:var(--radius-md)}.sidebar.collapsed .nav-section-header:hover{background:var(--neutral-50)}.sidebar.collapsed .nav-section-header.active{background:var(--primary-50)}.sidebar.collapsed .section-icon{display:block;width:22px;height:22px}.sidebar.collapsed .nav-section-header.active .section-icon{color:var(--primary-600)}.sidebar.collapsed .section-label,.sidebar.collapsed .section-arrow{display:none}.nav-list-nested{padding-left:8px;margin-top:2px;margin-left:12px;margin-bottom:var(--space-2);border-left:1px solid var(--border-subtle)}.sidebar.collapsed .nav-list-nested{display:none}.nav-list-nested .nav-link{padding:7px 10px;font-size:var(--text-sm);border-radius:var(--radius-sm);color:var(--text-tertiary)}.nav-list-nested .nav-link:hover{background:var(--neutral-50);color:var(--text-primary)}.nav-list-nested .nav-link.active{background:var(--primary-50);color:var(--primary-700);font-weight:var(--font-medium);border-left:none}.nav-list-nested .nav-link.active:before{display:none}.nav-list-nested .nav-link.active .nav-icon{color:var(--primary-600)}.nav-list-nested .nav-icon{width:17px;height:17px;color:var(--neutral-400)}.nav-list-nested .nav-link:hover .nav-icon{color:var(--text-quaternary)}.nav-group-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--text-placeholder);padding:10px 10px 4px;font-weight:var(--font-semibold)}.nav-divider{height:1px;background:var(--border-subtle);margin:var(--space-2) var(--space-3)}.nav-link-primary{position:relative;background:var(--primary-50)!important;border:1px solid var(--primary-100)}.nav-link-primary:hover{background:var(--primary-100)!important;border-color:var(--primary-200)}.nav-link-primary .nav-icon{color:var(--primary-600)!important}.nav-link-primary .nav-label{color:var(--primary-700);font-weight:var(--font-medium)}.nav-link-primary:after{content:"+";position:absolute;right:10px;top:50%;transform:translateY(-50%);width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--primary-500);color:var(--text-white);font-size:13px;font-weight:var(--font-bold);border-radius:var(--radius-xs)}.nav-list{list-style:none;padding:0;margin:0}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:8px 10px;margin-bottom:2px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative;white-space:nowrap}.sidebar.collapsed .nav-link{justify-content:center;padding:10px}.nav-link:hover{background:var(--neutral-50);color:var(--text-primary)}.nav-link.active{background:var(--primary-50);color:var(--primary-700);font-weight:var(--font-semibold)}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--primary-500);border-radius:0 3px 3px 0}.sidebar.collapsed .nav-link.active:before{display:none}.nav-icon{flex-shrink:0;width:20px;height:20px;color:var(--text-quaternary);transition:color var(--transition-fast)}.sidebar.collapsed .nav-icon{width:22px;height:22px}.nav-link:hover .nav-icon{color:var(--text-tertiary)}.nav-link.active .nav-icon{color:var(--primary-600)}.nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-label{display:none}.sidebar-footer-section{margin-top:auto;border-top:1px solid var(--border-subtle);background:var(--neutral-25)}.sidebar-collapse-toggle{display:flex;justify-content:flex-end;padding:var(--space-2) var(--space-3)}.sidebar.collapsed .sidebar-collapse-toggle{justify-content:center}.collapse-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-quaternary);cursor:pointer;transition:all var(--transition-fast)}.collapse-btn:hover{background:var(--neutral-100);border-color:var(--border-default);color:var(--text-tertiary)}.sidebar.collapsed .nav-link,.sidebar.collapsed .nav-section-header{position:relative}.sidebar.collapsed .nav-link:after,.sidebar.collapsed .nav-section-header:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);padding:5px 10px;background:var(--neutral-800);color:var(--text-white);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);box-shadow:var(--shadow-md);visibility:hidden}.sidebar.collapsed .nav-link[data-tooltip=""]:after,.sidebar.collapsed .nav-section-header[data-tooltip=""]:after{display:none}.sidebar.collapsed .nav-link:hover:after,.sidebar.collapsed .nav-section-header:hover:after{opacity:1;visibility:visible}.sidebar.collapsed .nav-link:before,.sidebar.collapsed .nav-section-header:before{content:"";position:absolute;left:calc(100% + 5px);top:50%;transform:translateY(-50%);border:4px solid transparent;border-right-color:var(--neutral-800);opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);visibility:hidden}.sidebar.collapsed .nav-link[data-tooltip=""]:before,.sidebar.collapsed .nav-section-header[data-tooltip=""]:before{display:none}.sidebar.collapsed .nav-link:hover:before,.sidebar.collapsed .nav-section-header:hover:before{opacity:1;visibility:visible}@media (max-width: 1024px){.sidebar{width:var(--sidebar-width-collapsed)}.nav-label,.section-label,.section-arrow,.nav-divider{display:none}.section-icon{display:block;width:22px;height:22px}.dashboard-section .nav-icon{display:block}.sidebar-nav{padding:var(--space-1)}.nav-section-header{justify-content:center;padding:10px;text-transform:none;font-size:var(--text-sm);letter-spacing:0;border-radius:var(--radius-md)}.nav-section-header:hover{background:var(--neutral-50)}.nav-section-header.active{background:var(--primary-50)}.nav-link{justify-content:center;padding:10px}.nav-list-nested{margin-left:0;padding-left:0;border-left:none}.nav-list-nested .nav-link{justify-content:center;padding:10px}.nav-icon,.section-icon{width:22px;height:22px}.search-input{display:none}.search-wrapper{background:transparent;border:none;width:100%;justify-content:center;padding:8px 0}.search-icon{position:static;color:var(--text-quaternary);width:20px;height:20px}.nav-link:after,.nav-section-header:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);padding:6px 12px;background:var(--neutral-800);color:var(--text-white);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);box-shadow:var(--shadow-lg)}.nav-link:hover:after,.nav-section-header:hover:after{opacity:1;visibility:visible}.nav-link-primary{background:transparent!important;border:none!important}.nav-link-primary:after{display:none}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:calc(100vw - 60px);z-index:9999;transform:translate(-100%);box-shadow:var(--shadow-2xl);border-right:none;display:flex}.sidebar.sidebar-open{transform:translate(0);width:300px}.sidebar.collapsed{width:300px}.sidebar-mobile-header{display:flex}.section-icon,.dashboard-section .nav-icon{display:none!important}.sidebar.collapsed .nav-label,.sidebar.collapsed .section-label,.sidebar.collapsed .section-arrow,.sidebar.collapsed .search-input,.sidebar.collapsed .nav-list-nested{display:flex}.sidebar.collapsed .nav-list-nested{display:block}.nav-label,.section-label,.section-arrow{display:flex}.section-arrow{display:block}.nav-section-header{padding:16px 16px 5px;text-transform:uppercase;font-size:12.5px;letter-spacing:.05em;border-radius:0}.nav-section-header:hover{background:transparent}.nav-link{justify-content:flex-start;padding:10px 16px}.sidebar.collapsed .nav-link,.sidebar.collapsed .nav-section-header{justify-content:flex-start}.sidebar.collapsed .nav-link{padding:10px 16px}.sidebar.collapsed .nav-section-header{padding:16px 16px 5px}.nav-list-nested{margin-left:14px;padding-left:10px;border-left:1px solid var(--border-subtle)}.search-input{display:block}.search-icon{position:absolute}.search-wrapper{justify-content:flex-start;padding:0;background:var(--neutral-50)}.nav-link:after,.nav-link:before,.sidebar.collapsed .nav-link:after,.sidebar.collapsed .nav-link:before{display:none!important}.sidebar-collapse-toggle{display:none}}.session-timeout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal, 1000);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.session-timeout-modal{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-8);max-width:420px;width:100%;text-align:center;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.session-timeout-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto var(--space-5);background:var(--warning-100);color:var(--warning-600);border-radius:var(--radius-full);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.session-timeout-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.session-timeout-message{font-size:var(--text-md);color:var(--text-secondary);margin-bottom:var(--space-2)}.session-timeout-message strong{color:var(--warning-600);font-weight:var(--font-bold);font-variant-numeric:tabular-nums}.session-timeout-submessage{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-6)}.session-timeout-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5)}.session-timeout-extend{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-md)}.session-timeout-logout{width:100%;padding:var(--space-3) var(--space-4)}.session-timeout-security-note{font-size:var(--text-xs);color:var(--text-quaternary);margin:0}@media (max-width: 480px){.session-timeout-modal{padding:var(--space-6);margin:var(--space-4)}.session-timeout-icon{width:64px;height:64px}.session-timeout-icon svg{width:36px;height:36px}.session-timeout-title{font-size:var(--text-lg)}.session-timeout-message{font-size:var(--text-sm)}}.pwa-install-prompt{position:fixed;left:1rem;right:1rem;z-index:9998;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:var(--color-bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 25px 50px -12px rgba(0, 0, 0, .25));border:1px solid var(--color-border, #e2e8f0);animation:slideUp .3s ease-out}.pwa-prompt-bottom{bottom:1rem}.pwa-prompt-top{top:1rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pwa-prompt-content{display:flex;align-items:center;gap:1rem;flex:1}.pwa-prompt-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-light, #e0f2fe);color:var(--color-primary, #00A1F6);border-radius:var(--radius-md, 8px);flex-shrink:0}.pwa-prompt-text{display:flex;flex-direction:column;gap:.125rem}.pwa-prompt-text strong{font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #1e293b)}.pwa-prompt-text span{font-size:.8125rem;color:var(--color-text-secondary, #64748b)}.pwa-prompt-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.pwa-prompt-btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;border-radius:var(--radius-md, 8px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.pwa-prompt-btn-primary{background:var(--color-primary, #00A1F6);color:#fff}.pwa-prompt-btn-primary:hover{background:var(--color-primary-hover, #0091e0)}.pwa-prompt-btn-dismiss{width:36px;height:36px;padding:0;background:transparent;color:var(--color-text-tertiary, #94a3b8)}.pwa-prompt-btn-dismiss:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary, #64748b)}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:10000;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.8125rem;font-weight:500;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.offline-indicator.offline{background:var(--color-warning, #f59e0b);color:#fff}.offline-indicator.online{background:var(--color-success, #22c55e);color:#fff;animation:slideDown .3s ease-out,fadeOut .3s ease-out 2.5s forwards}@keyframes fadeOut{to{opacity:0;transform:translateY(-100%)}}.update-prompt{position:fixed;bottom:1rem;right:1rem;z-index:9998;display:flex;flex-direction:column;gap:.75rem;padding:1rem;min-width:280px;background:var(--color-bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 25px 50px -12px rgba(0, 0, 0, .25));border:1px solid var(--color-border, #e2e8f0);animation:slideUp .3s ease-out}.update-prompt-content{display:flex;align-items:center;gap:.75rem}.update-icon{color:var(--color-primary, #00A1F6);animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.update-text{display:flex;flex-direction:column;gap:.125rem}.update-text strong{font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #1e293b)}.update-text span{font-size:.8125rem;color:var(--color-text-secondary, #64748b)}.update-actions{display:flex;gap:.5rem}.update-btn{flex:1;padding:.5rem 1rem;border-radius:var(--radius-md, 8px);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.update-btn-primary{background:var(--color-primary, #00A1F6);color:#fff}.update-btn-primary:hover{background:var(--color-primary-hover, #0091e0)}.update-btn-dismiss{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary, #64748b)}.update-btn-dismiss:hover{background:var(--color-bg-secondary, #e2e8f0)}@media (max-width: 480px){.pwa-install-prompt{flex-direction:column;align-items:stretch;left:.5rem;right:.5rem;bottom:.5rem}.pwa-prompt-actions{justify-content:stretch}.pwa-prompt-btn-primary{flex:1}.update-prompt{left:.5rem;right:.5rem;min-width:unset}}.loading-bar-container{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;background:transparent;overflow:hidden}.loading-bar{height:100%;background:linear-gradient(90deg,var(--primary-400) 0%,var(--primary-500) 50%,var(--primary-400) 100%);background-size:200% 100%;animation:loadingBarShimmer 1.5s ease-in-out infinite;transition:width .2s ease-out;border-radius:0 2px 2px 0;box-shadow:0 0 10px var(--primary-400)}@keyframes loadingBarShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-bar-container:after{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(to right,transparent,rgba(255,255,255,.3),transparent);animation:loadingBarGlare 2s ease-in-out infinite}@keyframes loadingBarGlare{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);z-index:10001;padding:.75rem 1.5rem;background:var(--color-primary, #00A1F6);color:#fff;font-weight:600;font-size:.875rem;text-decoration:none;border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-lg);transition:top .2s ease}.skip-link:focus{top:1rem;outline:none}.main-layout{min-height:100vh;background:var(--bg-secondary)}.main-content{margin-top:var(--navbar-height);margin-left:var(--sidebar-width);min-height:calc(100vh - var(--navbar-height));padding:var(--space-6);transition:margin-left var(--transition-slow)}.page-wrapper{max-width:1400px;margin:0 auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:calc(var(--z-modal) + 5);animation:overlayFadeIn var(--transition-fast) ease;cursor:pointer}@keyframes overlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-content{flex:1}.page-header-content h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:-.02em}.page-header-content p{font-size:var(--text-sm);color:var(--text-tertiary);margin:0}.page-header-actions{display:flex;gap:var(--space-3);flex-shrink:0}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-quaternary);margin-bottom:var(--space-4)}.breadcrumb-item{color:var(--text-quaternary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb-item:hover{color:var(--primary-600)}.breadcrumb-item.active{color:var(--text-secondary);font-weight:var(--font-medium)}.breadcrumb-separator{color:var(--text-disabled)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center}.empty-state-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-full);color:var(--text-quaternary);margin-bottom:var(--space-6)}.empty-state h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);color:var(--text-tertiary);max-width:400px;margin-bottom:var(--space-6)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--text-tertiary)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-fast)}.stat-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.stat-card-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);border-radius:var(--radius-lg)}.stat-card-badge{padding:4px 10px;font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full)}.stat-card-badge.positive{background:var(--success-50);color:var(--success-700)}.stat-card-badge.negative{background:var(--error-50);color:var(--error-700)}.stat-card-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:-.02em}.stat-card-label{font-size:var(--text-sm);color:var(--text-tertiary)}.content-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden}.content-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-primary)}.content-card-title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary)}.content-card-body{padding:var(--space-6)}.content-card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.tab{flex:1;padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-tertiary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab:hover{color:var(--text-secondary)}.tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-xs)}.filter-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);margin-bottom:var(--space-5);flex-wrap:wrap}.filter-bar .search-box{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid transparent;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.filter-bar .search-box:focus-within{background:var(--bg-primary);border-color:var(--primary-300);box-shadow:var(--focus-ring)}.filter-bar .search-box input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--text-primary);outline:none}.filter-bar .search-box input::placeholder{color:var(--text-placeholder)}.filter-bar .filter-divider{width:1px;height:24px;background:var(--border-primary)}@media (max-width: 1024px){.main-content{margin-left:var(--sidebar-width-collapsed)}.stats-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.main-content{margin-left:0;padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0))}.sidebar-overlay{display:block}.page-header{flex-direction:column;gap:var(--space-4)}.page-header-content h1{font-size:var(--text-xl)}.page-header-actions{width:100%}.page-header-actions .btn{flex:1;justify-content:center}.stats-row{grid-template-columns:1fr}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex:none;min-width:100px}.filter-bar{flex-direction:column;gap:var(--space-3)}.filter-bar .search-box{width:100%}.filter-bar .filter-divider{display:none}.content-card-header{flex-direction:column;gap:var(--space-3);align-items:stretch}}@media (max-width: 480px){.main-content{padding:var(--space-3)}.page-header-content h1{font-size:var(--text-lg)}.content-card-body,.stat-card{padding:var(--space-4)}.stat-card-value{font-size:var(--text-2xl)}}.toast-container{position:fixed;z-index:9999;pointer-events:none;display:flex;flex-direction:column;gap:.75rem;padding:1rem;max-height:100vh;overflow:hidden}.toast-top-right{top:0;right:0}.toast-top-left{top:0;left:0}.toast-top-center{top:0;left:50%;transform:translate(-50%)}.toast-bottom-right{bottom:0;right:0;flex-direction:column-reverse}.toast-bottom-left{bottom:0;left:0;flex-direction:column-reverse}.toast-bottom-center{bottom:0;left:50%;transform:translate(-50%);flex-direction:column-reverse}.toast-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radius-lg, 12px);background:var(--color-bg-primary, #ffffff);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));border:1px solid var(--color-border, #e2e8f0);pointer-events:auto;min-width:320px;max-width:420px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-success{border-left:4px solid var(--color-success, #22c55e)}.toast-success .toast-icon{color:var(--color-success, #22c55e)}.toast-error{border-left:4px solid var(--color-danger, #ef4444)}.toast-error .toast-icon{color:var(--color-danger, #ef4444)}.toast-warning{border-left:4px solid var(--color-warning, #f59e0b)}.toast-warning .toast-icon{color:var(--color-warning, #f59e0b)}.toast-info{border-left:4px solid var(--color-primary, #00A1F6)}.toast-info .toast-icon{color:var(--color-primary, #00A1F6)}.toast-icon{flex-shrink:0;margin-top:2px}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:.9375rem;color:var(--color-text-primary, #1e293b);margin-bottom:.25rem}.toast-message{font-size:.875rem;color:var(--color-text-secondary, #64748b);line-height:1.5}.toast-dismiss{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-md, 8px);color:var(--color-text-tertiary, #94a3b8);cursor:pointer;transition:all .2s ease;margin:-4px -4px -4px 0}.toast-dismiss:hover{background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary, #64748b)}.toast-enter{animation:toastSlideIn .3s ease-out forwards}.toast-exit{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-top-left .toast-enter,.toast-bottom-left .toast-enter{animation:toastSlideInLeft .3s ease-out forwards}.toast-top-left .toast-exit,.toast-bottom-left .toast-exit{animation:toastSlideOutLeft .3s ease-in forwards}@keyframes toastSlideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-100%)}}.toast-top-center .toast-enter,.toast-bottom-center .toast-enter{animation:toastSlideInCenter .3s ease-out forwards}.toast-top-center .toast-exit,.toast-bottom-center .toast-exit{animation:toastSlideOutCenter .3s ease-in forwards}@keyframes toastSlideInCenter{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOutCenter{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media (max-width: 480px){.toast-container{left:0;right:0;padding:.5rem}.toast-top-center,.toast-bottom-center{transform:none}.toast-item{min-width:unset;max-width:unset;width:100%}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.error-boundary-content{max-width:600px;width:100%;background:#fff;padding:3rem;border-radius:16px;box-shadow:0 10px 40px #0000001a;text-align:center}.error-icon{display:inline-flex;align-items:center;justify-content:center;width:120px;height:120px;margin-bottom:1.5rem;background:#fef2f2;border-radius:50%;color:#dc2626}.error-boundary-content h1{margin:0 0 1rem;font-size:2rem;font-weight:700;color:#1e293b}.error-message{margin:0 0 2rem;font-size:1.125rem;color:#64748b;line-height:1.6}.error-details{margin-bottom:2rem;text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.error-details summary{padding:.75rem 1rem;cursor:pointer;font-weight:500;color:#475569;background:#f1f5f9;border-bottom:1px solid #e2e8f0}.error-details summary:hover{background:#e2e8f0}.error-details pre{margin:0;padding:1rem;font-size:.75rem;line-height:1.5;color:#334155;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-details strong{color:#dc2626}.error-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-actions .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none}.error-actions .btn-primary{background:#3b82f6;color:#fff}.error-actions .btn-primary:hover{background:#2563eb}.error-actions .btn-secondary{background:#64748b;color:#fff}.error-actions .btn-secondary:hover{background:#475569}.error-actions .btn-outline{background:transparent;color:#64748b;border:2px solid #e2e8f0}.error-actions .btn-outline:hover{background:#f8fafc;border-color:#cbd5e1}.error-id{margin-top:2rem;font-size:.875rem;color:#94a3b8;font-family:monospace}@media (max-width: 640px){.error-boundary{padding:1rem}.error-boundary-content{padding:2rem 1.5rem}.error-icon{width:100px;height:100px}.error-icon svg{width:48px;height:48px}.error-boundary-content h1{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-actions .btn{width:100%;justify-content:center}}
