.app-shell{display:flex;min-height:100vh;background:var(--vw-bg)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--vw-sidebar-width);background:var(--vw-sidebar-bg);display:flex;flex-direction:column;z-index:100;transition:width var(--vw-transition-slow);overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem 1.25rem 1.25rem;min-height:64px}.sidebar-logo{display:flex;align-items:center;gap:.75rem;min-width:0}.logo-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--vw-sidebar-accent),#818cf8);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-text{font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.02em;white-space:nowrap;transition:opacity var(--vw-transition-slow)}.sidebar-collapse-btn{width:28px;height:28px;border-radius:6px;border:none;background:#ffffff0f;color:var(--vw-sidebar-text);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--vw-transition)}.sidebar-collapse-btn:hover{background:#ffffff1f;color:#fff}.sidebar-nav{flex:1;padding:.5rem .75rem;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:0}.nav-section-label{display:block;font-size:.65rem;font-weight:600;color:#94a3b880;text-transform:uppercase;letter-spacing:.08em;padding:1.25rem .75rem .5rem;white-space:nowrap;transition:opacity var(--vw-transition-slow)}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.55rem .75rem;border-radius:8px;color:var(--vw-sidebar-text);text-decoration:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--vw-transition);white-space:nowrap;position:relative}.nav-item:hover{background:var(--vw-sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--vw-sidebar-active-bg);color:var(--vw-sidebar-text-active)}.nav-item.active .nav-icon{color:var(--vw-sidebar-accent)}.nav-item.active:before{content:"";position:absolute;left:-.75rem;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--vw-sidebar-accent);border-radius:0 3px 3px 0}.nav-icon{flex-shrink:0;transition:color var(--vw-transition)}.nav-label{transition:opacity var(--vw-transition-slow)}.sidebar-footer{padding:.75rem;border-top:1px solid rgba(255,255,255,.06)}.sidebar-collapsed .sidebar{width:var(--vw-sidebar-collapsed)}.sidebar-collapsed .logo-text,.sidebar-collapsed .nav-section-label,.sidebar-collapsed .nav-label{opacity:0;pointer-events:none}.sidebar-collapsed .sidebar-header{justify-content:center;padding:1.25rem .5rem}.sidebar-collapsed .sidebar-collapse-btn{display:none}.sidebar-collapsed .sidebar-nav{padding:.5rem}.sidebar-collapsed .nav-item{justify-content:center;padding:.65rem}.sidebar-collapsed .nav-item.active:before{left:-.5rem}.sidebar-collapsed .sidebar-footer{padding:.5rem}.sidebar-collapsed .main-area{margin-left:var(--vw-sidebar-collapsed)}.main-area{flex:1;margin-left:var(--vw-sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--vw-transition-slow)}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;height:var(--vw-topbar-height);padding:0 1.5rem;background:#ffffffd9;border-bottom:1px solid var(--vw-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:var(--vw-radius-sm);color:var(--vw-text-secondary);margin-right:.5rem}.mobile-menu-btn:hover{background:var(--vw-surface-hover)}.topbar-spacer{flex:1}.topbar-icon-btn{color:var(--vw-text-secondary)!important}.topbar-icon-btn:hover{color:var(--vw-text)!important}.user-menu-trigger{display:flex;align-items:center;gap:.65rem;padding:.35rem .5rem .35rem .35rem;border-radius:var(--vw-radius);border:1px solid transparent;background:transparent;cursor:pointer;transition:all var(--vw-transition);font-family:var(--vw-font)}.user-menu-trigger:hover{background:var(--vw-surface-hover);border-color:var(--vw-border)}.user-avatar{width:34px;height:34px;border-radius:var(--vw-radius);background:linear-gradient(135deg,var(--vw-accent),#818cf8);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.03em}.user-info{display:flex;flex-direction:column;text-align:left;min-width:0}.user-name{font-size:.825rem;font-weight:600;color:var(--vw-text);line-height:1.2}.user-role{font-size:.7rem;color:var(--vw-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.main-content{flex:1;padding:1.75rem 2rem 3rem;max-width:1400px;width:100%;margin:0 auto}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99;opacity:0;transition:opacity var(--vw-transition-slow)}.mobile-overlay.visible{display:block;opacity:1}.notif-wrapper{position:relative}.notif-panel{position:absolute;top:100%;right:0;width:360px;max-height:480px;background:var(--vw-surface, #fff);border-radius:var(--vw-radius-lg, 12px);box-shadow:0 8px 32px #00000026;z-index:100;display:flex;flex-direction:column;overflow:hidden}.notif-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--vw-border, #e5e7eb);font-weight:700;font-size:.9rem}.notif-panel-list{flex:1;overflow-y:auto;max-height:360px}.notif-item{display:flex;gap:10px;padding:10px 16px;border-bottom:1px solid var(--vw-surface-alt, #f3f4f6);cursor:pointer;transition:background .15s ease}.notif-item:hover{background:var(--vw-surface-alt, #f9fafb)}.notif-item.unread{background:#3b82f60a;border-left:3px solid var(--vw-accent, #3b82f6)}.notif-content{flex:1;display:flex;flex-direction:column;gap:2px}.notif-title{font-weight:600;font-size:.8rem;color:var(--vw-text, #1f2937)}.notif-msg{font-size:.75rem;color:var(--vw-text-secondary, #6b7280);line-height:1.3}.notif-time{font-size:.65rem;color:var(--vw-text-muted, #9ca3af)}.notif-empty{text-align:center;padding:32px;color:var(--vw-text-secondary, #6b7280);font-size:.85rem}.notif-panel-footer{padding:10px 16px;border-top:1px solid var(--vw-border, #e5e7eb);text-align:center}.notif-panel-footer a{font-size:.8rem;color:var(--vw-accent, #3b82f6);text-decoration:none;font-weight:600}.notif-panel-footer a:hover{text-decoration:underline}@media(max-width:1024px){.user-info{display:none}}@media(max-width:768px){.sidebar{transform:translate(-100%);box-shadow:none;transition:transform var(--vw-transition-slow)}.mobile-overlay.visible~.app-shell .sidebar{transform:translate(0);box-shadow:var(--vw-shadow-lg)}.main-area{margin-left:0!important}.mobile-menu-btn{display:flex}.sidebar-collapse-btn{display:none}.main-content{padding:1.25rem 1rem 2rem}}:root{--vw-brand: #0f172a;--vw-brand-light: #1e293b;--vw-primary: #6366f1;--vw-accent: #6366f1;--vw-accent-hover: #4f46e5;--vw-accent-soft: #eef2ff;--vw-accent-muted: #c7d2fe;--vw-bg: #f8fafc;--vw-surface: #ffffff;--vw-surface-alt: #f8fafc;--vw-surface-hover: #f1f5f9;--vw-surface-active: #e2e8f0;--vw-border: #e2e8f0;--vw-border-strong: #cbd5e1;--vw-text: #0f172a;--vw-text-secondary: #64748b;--vw-text-muted: #94a3b8;--vw-success: #10b981;--vw-success-soft: #ecfdf5;--vw-warning: #f59e0b;--vw-warning-soft: #fffbeb;--vw-error: #ef4444;--vw-error-soft: #fef2f2;--vw-info: #3b82f6;--vw-info-soft: #eff6ff;--vw-radius-sm: 6px;--vw-radius: 10px;--vw-radius-lg: 14px;--vw-radius-xl: 20px;--vw-radius-full: 9999px;--vw-shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--vw-shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--vw-shadow: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--vw-shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--vw-shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--vw-transition: .15s cubic-bezier(.4, 0, .2, 1);--vw-transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--vw-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--vw-font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--vw-sidebar-width: 260px;--vw-sidebar-collapsed: 68px;--vw-sidebar-bg: #0f172a;--vw-sidebar-text: #94a3b8;--vw-sidebar-text-active: #ffffff;--vw-sidebar-accent: #6366f1;--vw-sidebar-hover: rgba(255, 255, 255, .06);--vw-sidebar-active-bg: rgba(99, 102, 241, .15);--vw-topbar-height: 64px;--vw-topbar-bg: #ffffff}*,*:before,*:after{box-sizing:border-box}html,body{height:100%;margin:0;padding:0;font-family:var(--vw-font);color:var(--vw-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"cv02","cv03","cv04","cv11"}body{background:var(--vw-bg)}#root{height:100%}h1,h2,h3,h4,h5,h6{letter-spacing:-.025em;font-weight:700;color:var(--vw-text);line-height:1.25}p{line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--vw-border-strong);border-radius:var(--vw-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--vw-text-muted)}.vw-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:40px;padding:0 1.25rem;font-family:var(--vw-font);font-size:.875rem;font-weight:600;border-radius:var(--vw-radius);border:none;cursor:pointer;transition:all var(--vw-transition);white-space:nowrap}.vw-btn:disabled{opacity:.5;cursor:not-allowed}.vw-btn-primary{background:var(--vw-accent);color:#fff;box-shadow:0 1px 3px #6366f14d}.vw-btn-primary:hover:not(:disabled){background:var(--vw-accent-hover);box-shadow:0 4px 14px #6366f159;transform:translateY(-1px)}.vw-btn-secondary{background:var(--vw-surface);color:var(--vw-text);border:1px solid var(--vw-border)}.vw-btn-secondary:hover:not(:disabled){background:var(--vw-surface-hover);border-color:var(--vw-border-strong)}.vw-card{background:var(--vw-surface);border:1px solid var(--vw-border);border-radius:var(--vw-radius-lg);box-shadow:var(--vw-shadow-xs);transition:box-shadow var(--vw-transition),border-color var(--vw-transition)}.vw-card-hover:hover{box-shadow:var(--vw-shadow);border-color:var(--vw-border-strong)}.vw-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.vw-page-header h1{font-size:1.5rem;margin:0}.vw-page-header p{font-size:.875rem;color:var(--vw-text-secondary);margin:.25rem 0 0}.vw-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:var(--vw-radius-full);letter-spacing:.01em}.vw-badge--success{background:var(--vw-success-soft);color:#059669}.vw-badge--warning{background:var(--vw-warning-soft);color:#d97706}.vw-badge--error{background:var(--vw-error-soft);color:#dc2626}.vw-badge--info{background:var(--vw-info-soft);color:#2563eb}.vw-badge--neutral{background:#f1f5f9;color:var(--vw-text-secondary)}@keyframes vw-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.vw-skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 37%,#f1f5f9 63%);background-size:200% 100%;animation:vw-shimmer 1.5s infinite;border-radius:var(--vw-radius-sm)}@keyframes vw-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.vw-animate-in{animation:vw-fadeIn .35s cubic-bezier(.4,0,.2,1) both}::selection{background:var(--vw-accent-muted);color:var(--vw-text)}:focus-visible{outline:2px solid var(--vw-accent);outline-offset:2px}
