@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--bg-elevated:#fff;--bg-surface:#e5e7eb;--card-bg:#fff;--card-border:#e5e7eb;--card-hover-bg:#fafafa;--card-shadow:0 1px 3px #0000000a, 0 1px 2px #00000005;--card-shadow-hover:0 4px 12px #0000000f, 0 1px 3px #0000000a;--brand-primary:#dc2626;--brand-secondary:#b91c1c;--brand-tertiary:#ef4444;--brand-light:#fca5a5;--brand-bg:#dc26260f;--brand-border:#dc262624;--brand-gradient:linear-gradient(135deg, #dc2626, #b91c1c);--brand-gradient-hover:linear-gradient(135deg, #ef4444, #dc2626);--brand-gradient-accent:linear-gradient(135deg, #dc2626, #ef4444);--brand-glow:#dc26261f;--brand-glow-strong:#dc262633;--accent-emerald:#059669;--accent-emerald-bg:#05966912;--accent-emerald-border:#05966929;--accent-emerald-glow:#05966926;--accent-amber:#d97706;--accent-amber-bg:#d9770612;--accent-amber-border:#d9770629;--accent-rose:#e11d48;--accent-rose-bg:#e11d4812;--accent-rose-border:#e11d4829;--accent-cyan:#0891b2;--accent-cyan-bg:#0891b212;--accent-cyan-border:#0891b229;--accent-blue:#2563eb;--accent-blue-bg:#2563eb12;--accent-blue-border:#2563eb29;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#64748b;--text-muted:#94a3b8;--text-inverse:#fff;--border-subtle:#f1f5f9;--border-default:#e2e8f0;--border-strong:#cbd5e1;--glass-bg:#00000004;--glass-bg-hover:#00000008;--glass-bg-active:#0000000d;--glass-border:var(--card-border);--glass-border-hover:var(--border-strong);--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 2px 8px #0000000f, 0 1px 2px #00000008;--shadow-lg:0 8px 24px #00000014, 0 2px 4px #00000008;--shadow-xl:0 16px 40px #0000001a, 0 4px 8px #0000000a;--shadow-glow:0 0 24px var(--brand-glow);--shadow-glow-emerald:0 0 24px var(--accent-emerald-glow);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:14px;--radius-2xl:16px;--radius-full:9999px;--transition-fast:.1s ease;--transition-base:.15s ease;--transition-slow:.25s ease;--transition-spring:.25s ease;--z-sidebar:100;--z-header:90;--z-dropdown:200;--z-modal-backdrop:300;--z-modal:310;--z-toast:400}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background:var(--bg-secondary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;overflow-x:hidden}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#0000001a}::-webkit-scrollbar-thumb:hover{background:#0000002e}::selection{background:var(--brand-primary);color:#fff}h1,h2,h3,h4,h5,h6{letter-spacing:-.01em;color:var(--text-primary);font-weight:600;line-height:1.3}h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}h2{font-size:1.25rem;font-weight:700}h3{font-size:1.1rem}h4{font-size:.95rem}h5{font-size:.875rem}p{color:var(--text-secondary);line-height:1.6}a{color:var(--brand-primary);transition:opacity var(--transition-fast);text-decoration:none}a:hover{opacity:.8}.app-layout{background:var(--bg-secondary);min-height:100vh;display:flex}.main-area{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;display:flex}.main-content{padding:28px 32px;padding-top:calc(var(--header-height) + 28px);flex:1;width:100%;max-width:1440px;margin:0 auto}.sidebar{width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--border-default);height:100vh;z-index:var(--z-sidebar);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;min-height:64px;padding:20px;display:flex}.sidebar-logo-icon{border-radius:var(--radius-md);flex-shrink:0;width:36px;height:36px;overflow:hidden}.sidebar-logo-icon img{object-fit:cover;width:100%;height:100%}.sidebar-logo-text{flex-direction:column;display:flex}.sidebar-logo-text h2{color:var(--text-primary);font-size:.95rem;font-weight:700;line-height:1.3}.sidebar-logo-text span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:16px 12px 6px;font-size:.65rem;font-weight:600}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:9px 12px;font-size:.85rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-link.active{background:var(--brand-bg);color:var(--brand-primary);font-weight:600}.sidebar-link.active:before{content:"";background:var(--brand-primary);border-radius:var(--radius-full);width:3px;height:20px;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.sidebar-link svg{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar-link.active svg{opacity:1}.sidebar-link .badge{background:var(--brand-bg);color:var(--brand-primary);border-radius:var(--radius-full);margin-left:auto;padding:1px 7px;font-size:.65rem;font-weight:600}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:12px 14px}.sidebar-user{border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;align-items:center;gap:10px;padding:8px 10px;display:flex}.sidebar-user:hover{background:var(--bg-tertiary)}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--brand-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);font-size:.68rem}.header{top:0;left:var(--sidebar-width);height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-default);z-index:var(--z-header);transition:left var(--transition-base);background:#f9fafbd9;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:fixed;right:0}.header-left{align-items:center;gap:12px;display:flex}.header-title{letter-spacing:-.01em;font-size:1.05rem;font-weight:700}.header-subtitle{color:var(--text-muted);font-size:.75rem;font-weight:400}.header-right{align-items:center;gap:8px;display:flex}.header-search{z-index:50;position:relative}.header-search>svg:first-child{width:15px;height:15px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header-search input{border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--bg-primary);width:220px;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:8px 34px 8px 36px;font-family:inherit;font-size:.82rem}.header-search input::placeholder{color:var(--text-muted)}.header-search input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-glow);width:280px}.header-search-results{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-width:320px;box-shadow:var(--shadow-lg);z-index:200;animation:.12s dropdownFade;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.header-search-results--mobile{top:var(--header-height);border-radius:0 0 var(--radius-lg) var(--radius-lg);min-width:unset;position:fixed;left:0;right:0}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.header-search-result{text-align:left;border:none;border-bottom:1px solid var(--border-subtle);cursor:pointer;background:0 0;align-items:center;gap:10px;width:100%;padding:10px 14px;font-family:inherit;transition:background .1s;display:flex}.header-search-result:last-child{border-bottom:none}.header-search-result:hover{background:var(--bg-tertiary)}.header-search-result-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.header-search-result-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.header-search-result-main{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.header-search-result-sub{color:var(--text-muted);text-transform:capitalize;font-size:.7rem}.header-search-empty{color:var(--text-muted);text-align:center;padding:16px;font-size:.82rem}.header-search-mobile-btn{display:none}.header-search-overlay{z-index:50;-webkit-backdrop-filter:blur(12px);background:#f9fafbfa;flex-wrap:wrap;align-items:center;gap:10px;padding:0 16px;animation:.12s dropdownFade;display:flex;position:absolute;inset:0}.header-search-overlay-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0;font-family:inherit;font-size:.88rem}.header-search-overlay-input::placeholder{color:var(--text-muted)}.header-search-overlay-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:6px 8px;font-family:inherit;font-size:.75rem;transition:background .1s;display:flex}.header-search-overlay-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header-icon-btn{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-primary);width:36px;height:36px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.header-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-strong)}.header-notif-badge{background:var(--brand-primary);color:#fff;border-radius:var(--radius-full);border:2px solid var(--bg-primary);justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-3px;right:-3px}.header-notif-wrap{z-index:50;position:relative}.header-notif-panel{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:340px;box-shadow:var(--shadow-lg);z-index:200;animation:.12s dropdownFade;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.header-notif-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.header-notif-title{color:var(--text-primary);font-size:.85rem;font-weight:700}.header-notif-mark-read{color:var(--brand-primary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.72rem;font-weight:600}.header-notif-mark-read:hover{opacity:.7}.header-notif-list{max-height:360px;overflow-y:auto}.header-notif-item{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:flex-start;gap:10px;padding:12px 16px;transition:background .1s;display:flex;position:relative}.header-notif-item:last-child{border-bottom:none}.header-notif-item:hover{background:var(--bg-tertiary)}.header-notif-item--unread{background:#dc262605}.header-notif-item--critical{border-left:3px solid var(--accent-rose)}.header-notif-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-top:1px;display:flex}.header-notif-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.header-notif-item-title{color:var(--text-primary);font-size:.8rem;font-weight:600;line-height:1.35}.header-notif-item-sub{color:var(--text-muted);font-size:.7rem}.header-notif-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.header-notif-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px 20px;display:flex}.header-notif-empty p{color:var(--text-primary);margin-bottom:4px;font-size:.88rem;font-weight:600}.header-notif-empty span{color:var(--text-muted);font-size:.75rem}.header-notif-footer{border-top:1px solid var(--border-subtle);text-align:center;padding:10px 16px}.header-notif-footer-btn{cursor:pointer;color:var(--brand-primary);background:0 0;border:none;font-family:inherit;font-size:.75rem;font-weight:600}.header-notif-footer-btn:hover{opacity:.7}.glass-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:20px;position:relative}.glass-card:hover{border-color:var(--border-strong);box-shadow:var(--card-shadow-hover)}.glass-card.no-hover:hover{border-color:var(--card-border);box-shadow:none}.glass-card.interactive{cursor:pointer}.glass-card.interactive:hover{border-color:var(--brand-border)}.stat-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:20px;position:relative}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--card-shadow-hover)}.stat-card .stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:14px;display:flex}.stat-card .stat-icon.brand{background:var(--brand-bg);color:var(--brand-primary)}.stat-card .stat-icon.emerald{background:var(--accent-emerald-bg);color:var(--accent-emerald)}.stat-card .stat-icon.amber{background:var(--accent-amber-bg);color:var(--accent-amber)}.stat-card .stat-icon.rose{background:var(--accent-rose-bg);color:var(--accent-rose)}.stat-card .stat-icon.cyan{background:var(--accent-cyan-bg);color:var(--accent-cyan)}.stat-card .stat-icon.blue{background:var(--accent-blue-bg);color:var(--accent-blue)}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:.75rem;font-weight:500}.stat-card .stat-value{color:var(--text-primary);letter-spacing:-.02em;font-size:1.5rem;font-weight:700;line-height:1.2}.stat-card .stat-change{border-radius:var(--radius-full);align-items:center;gap:4px;margin-top:8px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.stat-card .stat-change.positive{background:var(--accent-emerald-bg);color:var(--accent-emerald)}.stat-card .stat-change.negative{background:var(--accent-rose-bg);color:var(--accent-rose)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:.82rem;font-weight:600;text-decoration:none;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--brand-primary);color:#fff;border:none}.btn-primary:hover{background:var(--brand-secondary)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-strong)}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:8px 10px}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:var(--accent-rose-bg);color:var(--accent-rose);border-color:var(--accent-rose-border)}.btn-danger:hover{background:#e11d481f}.btn-success{background:var(--accent-emerald-bg);color:var(--accent-emerald);border-color:var(--accent-emerald-border)}.btn-success:hover{background:#0596691f}.btn-sm{padding:5px 12px;font-size:.78rem}.btn-lg{border-radius:var(--radius-lg);padding:12px 24px;font-size:.9rem}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.btn-icon.sm{width:30px;height:30px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.form-group{margin-bottom:16px}.form-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:.75rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-primary);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-family:inherit;font-size:.85rem}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-glow)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{color:var(--text-primary);background:#fff}.form-textarea{resize:vertical;min-height:100px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.table-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border-default);white-space:nowrap;padding:10px 16px;font-size:.72rem;font-weight:600}tbody tr{border-bottom:1px solid var(--border-subtle);transition:background 80ms}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-secondary)}tbody td{color:var(--text-secondary);white-space:nowrap;padding:10px 16px;font-size:.84rem}tbody td:first-child{color:var(--text-primary);font-weight:500}.badge{border-radius:var(--radius-full);letter-spacing:.01em;border:1px solid #0000;align-items:center;gap:5px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge:before{content:"";border-radius:var(--radius-full);width:5px;height:5px}.badge-planning{background:var(--accent-blue-bg);color:var(--accent-blue);border-color:var(--accent-blue-border)}.badge-planning:before{background:var(--accent-blue)}.badge-in-progress,.badge-in_progress{background:var(--accent-amber-bg);color:var(--accent-amber);border-color:var(--accent-amber-border)}.badge-in-progress:before,.badge-in_progress:before{background:var(--accent-amber)}.badge-completed{background:var(--accent-emerald-bg);color:var(--accent-emerald);border-color:var(--accent-emerald-border)}.badge-completed:before{background:var(--accent-emerald)}.badge-on-hold,.badge-on_hold{background:var(--bg-tertiary);color:var(--text-tertiary);border-color:var(--border-default)}.badge-on-hold:before,.badge-on_hold:before{background:var(--text-muted)}.badge-review{color:#8b5cf6;background:#8b5cf612;border-color:#8b5cf629}.badge-review:before{background:#8b5cf6}.badge-cancelled{background:var(--accent-rose-bg);color:var(--accent-rose);border-color:var(--accent-rose-border)}.badge-cancelled:before{background:var(--accent-rose)}.badge-overdue{background:var(--accent-rose-bg);color:var(--accent-rose);border-color:var(--accent-rose-border)}.badge-overdue:before{background:var(--accent-rose)}.badge-pending{background:var(--bg-tertiary);color:var(--text-tertiary);border-color:var(--border-default)}.badge-pending:before{background:var(--text-muted)}.badge-active{background:var(--brand-bg);color:var(--brand-primary);border-color:var(--brand-border)}.badge-active:before{background:var(--brand-primary)}.badge-critical{background:var(--brand-bg);color:var(--brand-primary);border-color:var(--brand-border)}.badge-critical:before{background:var(--brand-primary)}.badge-high{background:var(--accent-amber-bg);color:var(--accent-amber);border-color:var(--accent-amber-border)}.badge-high:before{background:var(--accent-amber)}.badge-medium{background:var(--accent-blue-bg);color:var(--accent-blue);border-color:var(--accent-blue-border)}.badge-medium:before{background:var(--accent-blue)}.badge-low{background:var(--accent-emerald-bg);color:var(--accent-emerald);border-color:var(--accent-emerald-border)}.badge-low:before{background:var(--accent-emerald)}.badge-company{background:var(--brand-bg);color:var(--brand-primary);border-color:var(--brand-border)}.badge-company:before{background:var(--brand-primary)}.badge-personal{background:var(--accent-cyan-bg);color:var(--accent-cyan);border-color:var(--accent-cyan-border)}.badge-personal:before{background:var(--accent-cyan)}.progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--brand-primary);height:100%;transition:width var(--transition-slow);position:relative}.progress-bar-fill:after{display:none}.progress-bar.emerald .progress-bar-fill{background:var(--accent-emerald)}.progress-bar.amber .progress-bar-fill{background:var(--accent-amber)}.progress-bar.rose .progress-bar-fill{background:var(--accent-rose)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);background:#0f172a66;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-xl);flex-direction:column;animation:.2s modalIn;display:flex;overflow:hidden}.modal form{flex-direction:column;flex:1;min-height:0;display:flex}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:1.05rem}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.modal.lg{max-width:760px}.modal.xl{max-width:920px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tabs{border-bottom:1px solid var(--border-default);gap:0;margin-bottom:24px;display:flex;overflow-x:auto}.tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-family:inherit;font-size:.82rem;font-weight:500}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary);font-weight:600}.avatar{border-radius:var(--radius-full);color:#fff;background:var(--brand-primary);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:600;display:flex}.avatar.sm{width:26px;height:26px;font-size:.6rem}.avatar.lg{width:44px;height:44px;font-size:.9rem}.avatar.xl{width:56px;height:56px;font-size:1.2rem}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--bg-primary);margin-left:-6px}.avatar-group .avatar:first-child{margin-left:0}.avatar-group .avatar-more{background:var(--bg-tertiary);color:var(--text-secondary);font-size:.65rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state svg{width:48px;height:48px;color:var(--text-muted);opacity:.4;margin-bottom:16px}.empty-state h3{margin-bottom:6px;font-size:1rem;font-weight:600}.empty-state p{color:var(--text-muted);max-width:320px;margin-bottom:16px;font-size:.82rem}.toast-container{z-index:var(--z-toast);flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-width:300px;box-shadow:var(--shadow-lg);align-items:center;gap:10px;padding:12px 16px;animation:.2s slideInRight;display:flex}.toast.success{border-left:3px solid var(--accent-emerald)}.toast.error{border-left:3px solid var(--brand-primary)}.toast.warning{border-left:3px solid var(--accent-amber)}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header-left h1{margin-bottom:2px}.page-header-left p{font-size:.85rem}.page-header-actions{gap:10px;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.filter-bar .form-select,.filter-bar .form-input{width:auto;min-width:150px;padding:7px 12px;font-size:.78rem}.filter-bar .form-select{padding-right:32px}.chart-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:20px;position:relative}.chart-card h4{margin-bottom:2px}.chart-subtitle{color:var(--text-muted);margin-bottom:16px;font-size:.78rem}.login-page{background:var(--bg-secondary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-page:before{display:none}.login-container{z-index:1;width:100%;max-width:400px;padding:20px;position:relative}.login-card{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:40px 36px}.login-card:before{display:none}.login-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.login-logo-icon{border-radius:var(--radius-md);width:44px;height:44px;overflow:hidden}.login-logo-icon img{object-fit:cover;width:100%;height:100%}.login-logo h1{color:var(--text-primary);font-size:1.4rem}.login-logo h1 span{color:var(--brand-primary)}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px;font-size:.85rem}.login-card .form-group{margin-bottom:16px}.login-card .btn-primary{border-radius:var(--radius-md);width:100%;margin-top:4px;padding:11px;font-size:.88rem}.login-footer{text-align:center;color:var(--text-muted);margin-top:20px;font-size:.75rem}.confirm-dialog{text-align:center;padding:12px 0}.confirm-dialog svg{width:40px;height:40px;color:var(--brand-primary);margin-bottom:12px}.confirm-dialog h3{margin-bottom:6px}.confirm-dialog p{margin-bottom:20px;font-size:.85rem}.confirm-dialog .btn-group{justify-content:center;gap:10px;display:flex}.budget-bar{align-items:center;gap:12px;display:flex}.budget-bar-track{background:var(--bg-tertiary);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.budget-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.budget-bar-fill.safe{background:var(--accent-emerald)}.budget-bar-fill.warning{background:var(--accent-amber)}.budget-bar-fill.danger{background:var(--brand-primary)}.budget-bar-label{color:var(--text-secondary);text-align:right;min-width:36px;font-size:.78rem;font-weight:600}.activity-feed{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid var(--border-subtle);gap:14px;padding:12px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot-wrapper{flex-direction:column;align-items:center;gap:4px;padding-top:4px;display:flex}.activity-dot{border-radius:var(--radius-full);background:var(--brand-primary);flex-shrink:0;width:7px;height:7px}.activity-line{background:var(--border-subtle);flex:1;width:2px}.activity-content{flex:1}.activity-text{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.activity-text strong{color:var(--text-primary);font-weight:600}.activity-time{color:var(--text-muted);margin-top:3px;font-size:.72rem}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-surface) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.8s infinite skeletonPulse}@keyframes skeletonPulse{0%{background-position:200% 0}to{background-position:-200% 0}}.recharts-default-tooltip{background:var(--bg-primary)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-md)!important;padding:10px 14px!important}.recharts-tooltip-label{color:var(--text-primary)!important;margin-bottom:4px!important;font-weight:600!important}.recharts-tooltip-item{color:var(--text-secondary)!important;font-size:.82rem!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}.flex-1{flex:1}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-muted{color:var(--text-muted)}.font-mono{font-family:JetBrains Mono,monospace}.font-bold{font-weight:700}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@media print{.no-print{display:none!important}}@media (width<=1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{display:none}.main-area{margin-left:0}.header{padding:0 16px;left:0}.main-content{padding:16px;padding-top:calc(var(--header-height) + 16px)}.grid-2,.grid-3,.grid-4,.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .form-select,.filter-bar .form-input{width:100%}.header-search{display:none}.header-search-mobile-btn{display:flex}.header-title{font-size:.95rem}.header-subtitle{display:none}}
