@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#f4f6fa;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f7f9fd;--bg-sidebar:#1c3a6b;--bg-input:#f4f6fa;--bg-modal:#fff;--primary:#1c3a6b;--accent-primary:#1c3a6b;--accent-primary-hover:#163060;--accent-secondary:#c9a84c;--accent-gradient:linear-gradient(135deg,#1c3a6b 0%,#2a5298 100%);--accent-gradient-hover:linear-gradient(135deg,#163060 0%,#1e3f7a 100%);--gold:#c9a84c;--gold-light:#c9a84c26;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#a0aec0;--text-accent:#1c3a6b;--status-success:#38a169;--status-warning:#d69e2e;--status-danger:#e53e3e;--status-info:#2b6cb0;--status-purple:#6b4faf;--border-color:#e2e8f0;--border-light:#0000000d;--shadow-sm:0 1px 3px #1c3a6b0f;--shadow-md:0 2px 8px #1c3a6b14;--shadow-lg:0 4px 20px #1c3a6b1f;--shadow-glow:0 0 0 3px #1c3a6b1f;--sidebar-width:260px;--header-height:64px;--border-radius:12px;--border-radius-sm:8px;--border-radius-lg:16px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s cubic-bezier(.4,0,.2,1);--surface-alt:#f0f4fa}[data-theme=dark]{--bg-primary:#080e1c;--bg-secondary:#0f1729;--bg-card:#111e36;--bg-card-hover:#162440;--bg-sidebar:#0d1f3c;--bg-input:#111e36;--bg-modal:#0f1729;--primary:#4a90d9;--accent-primary:#4a90d9;--accent-primary-hover:#6ba8e5;--accent-secondary:#c9a84c;--accent-gradient:linear-gradient(135deg,#1c3a6b 0%,#2a5298 100%);--accent-gradient-hover:linear-gradient(135deg,#2a5298 0%,#4a90d9 100%);--gold:#d4af5a;--gold-light:#c9a84c1f;--text-primary:#edf2f7;--text-secondary:#94a3b8;--text-muted:#4a5568;--text-accent:#6ba8e5;--status-success:#48bb78;--status-warning:#ecc94b;--status-danger:#fc8181;--status-info:#63b3ed;--status-purple:#9f7aea;--border-color:#1c2e4a;--border-light:#ffffff0d;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--shadow-glow:0 0 0 3px #4a90d926}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:clip}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);padding-top:var(--header-height);flex:1;min-height:100vh}.page-content{padding:28px 32px;animation:.4s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{width:var(--sidebar-width);z-index:100;transition:transform var(--transition-slow);background:linear-gradient(#1c3a6b 0%,#162e58 60%,#112348 100%);border-right:1px solid #ffffff0f;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 24px #00000026}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:14px;padding:22px 24px;display:flex}.sidebar-brand .brand-icon{color:#0d1f3c;letter-spacing:-1px;background:linear-gradient(135deg,#c9a84c 0%,#e8c96a 100%);border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;font-weight:800;display:flex;box-shadow:0 4px 12px #c9a84c66}.sidebar-brand .brand-text{flex-direction:column;display:flex}.sidebar-brand .brand-name{color:#fff;letter-spacing:-.3px;font-size:17px;font-weight:700}.sidebar-brand .brand-sub{color:#fff6;text-transform:uppercase;letter-spacing:1.5px;margin-top:1px;font-size:10px}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:6px}.nav-section-title{color:#ffffff80;text-transform:uppercase;letter-spacing:1.8px;padding:14px 14px 8px;font-size:10px;font-weight:600}.nav-item{color:#ffffffd9;cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin-bottom:2px;padding:10px 14px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:#ffffffe6;background:#ffffff0f}.nav-item.active{color:#fff;background:linear-gradient(135deg,#c9a84c1f 0%,#4a90d914 100%)}.nav-item.active:before{content:"";background:linear-gradient(#c9a84c,#e8c96a);border-radius:0 4px 4px 0;width:3px;height:22px;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 8px #c9a84c80}.nav-item .nav-icon{opacity:.7;justify-content:center;align-items:center;width:20px;height:20px;transition:opacity .2s;display:flex}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}.nav-item.active .nav-icon{color:#c9a84c}.nav-item .nav-badge{color:#fff;text-align:center;background:linear-gradient(135deg,#c9a84c,#e8c96a);border-radius:10px;min-width:20px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:700;box-shadow:0 2px 6px #1c3a6b26;color:#0d1f3c!important}.nav-item .nav-arrow{opacity:0;margin-left:auto;transition:all .2s;transform:translate(-4px)}.nav-item:hover .nav-arrow{opacity:.4;transform:translate(0)}.nav-item.active .nav-arrow{opacity:1;color:#4880ff;transform:translate(0)}.header{top:0;left:var(--sidebar-width);height:var(--header-height);background:var(--bg-secondary);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:90;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:fixed;right:0}.header-left{align-items:center;gap:16px;display:flex}.header-title{color:var(--text-primary);font-size:18px;font-weight:600}.header-search{position:relative}.header-search input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius);width:320px;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:8px 16px 8px 40px;font-family:Inter,sans-serif;font-size:13px}.header-search input::placeholder{color:var(--text-muted)}.header-search input:focus{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.header-search .search-icon{color:var(--text-muted);font-size:14px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.header-right{align-items:center;gap:8px;display:flex}.header-btn{width:38px;height:38px;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex;position:relative}.header-btn:hover{background:var(--bg-card);color:var(--text-primary)}.header-btn .badge-dot{background:var(--status-danger);border:2px solid var(--bg-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.header-user{border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:10px;margin-left:4px;padding:4px 12px 4px 4px;display:flex}.header-user:hover{background:var(--bg-card)}.header-user .avatar{background:var(--accent-gradient);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.header-user .user-info{flex-direction:column;display:flex}.header-user .user-name{color:var(--text-primary);font-size:13px;font-weight:600}.header-user .user-role{color:var(--text-muted);font-size:11px}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-header-left h1{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700}.page-header-left p{color:var(--text-secondary);margin-top:4px;font-size:14px}.btn{border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,sans-serif;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px #1c3a6b4d}.btn-primary:hover{background:var(--accent-gradient-hover);transform:translateY(-1px);box-shadow:0 4px 16px #1c3a6b66}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-danger{color:var(--status-danger);background:#f8717126}.btn-danger:hover{background:#f8717140}.btn-sm{padding:6px 14px;font-size:12px}.btn-icon{border-radius:var(--border-radius-sm);background:var(--bg-card);border:1px solid var(--border-color);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0;display:flex}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);padding:24px}.card:hover{box-shadow:var(--shadow-glow);border-color:#1c3a6b26}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:600}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);padding:22px;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:0;height:3px;transition:opacity var(--transition-normal);background:linear-gradient(90deg,#1c3a6b,#c9a84c);position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-glow);border-color:#1c3a6b26;transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.stat-card-icon.revenue{color:var(--accent-primary-hover);background:#1c3a6b1f}.stat-card-icon.projects{color:var(--status-info);background:#38bdf826}.stat-card-icon.customers{color:var(--status-success);background:#34d39926}.stat-card-icon.quotations{color:var(--status-warning);background:#fbbf2426}.stat-card .stat-trend{border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;font-weight:600;display:flex}.stat-trend.up{color:var(--status-success);background:#34d3991a}.stat-trend.down{color:var(--status-danger);background:#f871711a}.stat-card .stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:700}.stat-card .stat-label{color:var(--text-secondary);margin-top:2px;font-size:13px}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-light);white-space:nowrap;padding:14px 16px;font-size:13px}.data-table tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#1c3a6b0a}.data-table td.primary{color:var(--text-primary);font-weight:500}.data-table td.accent{color:var(--text-accent);font-weight:600}.data-table td.amount{font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:600}.badge{white-space:nowrap;border-radius:6px;align-items:center;gap:5px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.badge.success{color:var(--status-success);background:#34d3991f}.badge.warning{color:var(--status-warning);background:#fbbf241f}.badge.danger{color:var(--status-danger);background:#f871711f}.badge.info{color:var(--status-info);background:#38bdf81f}.badge.purple{color:var(--status-purple);background:#a78bfa1f}.badge.muted{color:var(--text-muted);background:#64748b1f}.progress-bar{background:var(--bg-primary);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar .progress-fill{background:var(--accent-gradient);border-radius:3px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.progress-bar .progress-fill.success{background:var(--status-success)}.progress-bar .progress-fill.warning{background:var(--status-warning)}.chart-bar-container{align-items:flex-end;gap:8px;height:200px;padding-top:12px;display:flex}.chart-bar-group{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;height:100%;display:flex}.chart-bar-wrapper{align-items:flex-end;gap:3px;height:100%;display:flex}.chart-bar{width:16px;transition:height .8s cubic-bezier(.4,0,.2,1),opacity var(--transition-fast);cursor:pointer;border-radius:4px 4px 0 0;position:relative}.chart-bar.revenue{background:var(--accent-primary)}.chart-bar.expense{background:#1c3a6b40}.chart-bar:hover{opacity:.8}.chart-bar-label{color:var(--text-muted);font-size:11px;font-weight:500}.donut-chart{border-radius:50%;justify-content:center;align-items:center;width:180px;height:180px;display:flex;position:relative}.donut-center{background:var(--bg-card);z-index:2;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:absolute}.donut-center .donut-value{color:var(--text-primary);font-size:26px;font-weight:700}.donut-center .donut-label{color:var(--text-muted);font-size:11px}.chart-legend{flex-direction:column;gap:10px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.legend-count{color:var(--text-primary);margin-left:auto;font-weight:600}.activity-list{flex-direction:column;gap:2px;display:flex}.activity-item{border-radius:var(--border-radius-sm);transition:background var(--transition-fast);align-items:flex-start;gap:14px;padding:12px;display:flex}.activity-item:hover{background:#ffffff05}.activity-icon{background:var(--bg-primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.activity-content{flex:1;min-width:0}.activity-content .activity-action{color:var(--text-primary);font-size:13px;font-weight:600}.activity-content .activity-detail{color:var(--text-secondary);margin-top:1px;font-size:12px}.activity-content .activity-meta{color:var(--text-muted);margin-top:4px;font-size:11px}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:14px}.form-input:focus,.form-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #1c3a6b14}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' 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;background-size:16px;padding-right:40px}.form-row{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-modal);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);width:100%;max-width:560px;max-height:85vh;box-shadow:var(--shadow-lg);animation:.3s cubic-bezier(.4,0,.2,1) modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{color:var(--text-primary);font-size:16px;font-weight:700}.modal-close{width:32px;height:32px;color:var(--text-muted);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{background:var(--bg-card);color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.tabs{background:var(--bg-primary);border-radius:var(--border-radius-sm);gap:2px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:6px;padding:8px 18px;font-family:Inter,sans-serif;font-size:13px;font-weight:500}.tab:hover{color:var(--text-secondary)}.tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-bar .search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);min-width:240px;color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;flex:1;padding:9px 14px 9px 38px;font-family:Inter,sans-serif;font-size:13px}.filter-bar .search-input:focus{border-color:var(--accent-primary)}.filter-bar .search-input::placeholder{color:var(--text-muted)}.filter-bar .filter-select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' 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 10px center;background-repeat:no-repeat;background-size:14px;outline:none;padding:9px 36px 9px 14px;font-family:Inter,sans-serif;font-size:13px}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.grid-2-1{grid-template-columns:2fr 1fr;gap:20px;display:grid}.grid-1-1{grid-template-columns:1fr 1fr;gap:20px;display:grid}.warehouse-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.warehouse-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);cursor:pointer;padding:18px}.warehouse-card:hover{border-color:#1c3a6b40;transform:translateY(-2px)}.warehouse-card.active{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.warehouse-card .wh-icon{margin-bottom:10px;font-size:28px}.warehouse-card .wh-name{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.warehouse-card .wh-address{color:var(--text-muted);margin-bottom:12px;font-size:12px}.warehouse-card .wh-stats{justify-content:space-between;display:flex}.warehouse-card .wh-stat{flex-direction:column;display:flex}.warehouse-card .wh-stat-value{color:var(--text-primary);font-size:16px;font-weight:700}.warehouse-card .wh-stat-label{color:var(--text-muted);font-size:11px}.finance-summary{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.finance-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:20px;position:relative;overflow:hidden}.finance-card:after{content:"";height:3px;position:absolute;bottom:0;left:0;right:0}.finance-card.income:after{background:var(--status-success)}.finance-card.expense:after{background:var(--status-danger)}.finance-card.receivable:after{background:var(--status-info)}.finance-card.payable:after{background:var(--status-warning)}.finance-card .fc-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px}.finance-card .fc-value{color:var(--text-primary);font-size:22px;font-weight:700}.finance-card .fc-sub{color:var(--text-muted);margin-top:6px;font-size:12px}.dept-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.dept-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);cursor:pointer;align-items:center;gap:14px;padding:18px;display:flex}.dept-card:hover{box-shadow:var(--shadow-glow);border-color:#1c3a6b26}.dept-card .dept-icon{background:#1c3a6b14;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.dept-card .dept-info{flex:1}.dept-card .dept-name{color:var(--text-primary);font-size:14px;font-weight:600}.dept-card .dept-count{color:var(--text-muted);margin-top:2px;font-size:12px}.dept-card .dept-head{color:var(--text-secondary);margin-top:2px;font-size:12px}.report-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.report-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);padding:24px}.report-card:hover{box-shadow:var(--shadow-glow);border-color:#1c3a6b26}.report-card .report-icon{margin-bottom:14px;font-size:32px}.report-card .report-title{color:var(--text-primary);margin-bottom:6px;font-size:16px;font-weight:600}.report-card .report-desc{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.5}.report-metrics{border-top:1px solid var(--border-light);gap:20px;padding-top:14px;display:flex}.report-metric{flex-direction:column;display:flex}.report-metric .rm-value{color:var(--text-primary);font-size:18px;font-weight:700}.report-metric .rm-label{color:var(--text-muted);margin-top:2px;font-size:11px}.empty-state{text-align:center;flex-direction:column;align-items:center;padding:48px 24px;display:flex}.empty-state .empty-icon{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state .empty-title{color:var(--text-primary);margin-bottom:6px;font-size:16px;font-weight:600}.empty-state .empty-text{color:var(--text-muted);font-size:13px}.pipeline{align-items:center;gap:0;padding:16px 0;display:flex;overflow-x:auto}.pipeline-step{flex:1;align-items:center;gap:0;min-width:0;display:flex}.pipeline-node{cursor:pointer;transition:all var(--transition-fast);flex-direction:column;flex-shrink:0;align-items:center;gap:6px;min-width:90px;display:flex}.pipeline-dot{border:2px solid var(--border-color);background:var(--bg-card);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-normal);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.pipeline-node.active .pipeline-dot{background:var(--accent-gradient);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 16px #1c3a6b59}.pipeline-node.completed .pipeline-dot{background:var(--status-success);border-color:var(--status-success);color:#fff}.pipeline-label{color:var(--text-muted);text-align:center;white-space:nowrap;font-size:11px;font-weight:500}.pipeline-node.active .pipeline-label{color:var(--accent-primary-hover);font-weight:600}.pipeline-node.completed .pipeline-label{color:var(--status-success)}.pipeline-line{background:var(--border-color);flex:1;min-width:16px;height:2px;margin:0 -4px 20px}.pipeline-line.completed{background:var(--status-success)}.project-tabs{background:var(--bg-secondary);border-radius:var(--border-radius);border:1px solid var(--border-color);gap:4px;margin-bottom:24px;padding:6px;display:flex;overflow-x:auto}.project-tab{color:var(--text-muted);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;display:flex}.project-tab:hover{color:var(--text-secondary);background:#ffffff08}.project-tab.active{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px #1c3a6b40}.project-tab .tab-count{background:#ffffff26;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.project-tab:not(.active) .tab-count{background:var(--bg-card);color:var(--text-muted)}.settlement-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}.settlement-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px;position:relative;overflow:hidden}.settlement-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.settlement-card.side-a:before{background:var(--status-success)}.settlement-card.side-b:before{background:var(--status-danger)}.settlement-card h3{align-items:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:600;display:flex}.settlement-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.settlement-row:last-child{border-bottom:none}.settlement-row .label{color:var(--text-secondary)}.settlement-row .value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.settlement-row.total{border-top:1px solid var(--border-color);padding-top:12px;font-size:15px;font-weight:700}.settlement-profit{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);text-align:center;padding:28px;position:relative;overflow:hidden}.settlement-profit .profit-value{letter-spacing:-1px;font-size:36px;font-weight:800}.settlement-profit .profit-label{color:var(--text-secondary);margin-top:4px;font-size:14px}.settlement-profit .profit-rate{border-radius:20px;align-items:center;gap:6px;margin-top:12px;padding:4px 14px;font-size:13px;font-weight:600;display:inline-flex}.mobile-menu-btn{width:40px;height:40px;color:var(--text-primary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:none}.mobile-menu-btn:hover{background:var(--bg-card)}.sidebar-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;animation:.2s fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}@media (max-width:1280px){.stats-grid,.warehouse-grid,.finance-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width:1024px){.grid-2-1,.grid-1-1{grid-template-columns:1fr}.dept-grid{grid-template-columns:repeat(2,1fr)}.settlement-grid{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{z-index:999;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{width:100%!important;margin-left:0!important}.header{padding:0 16px;left:0}.mobile-menu-btn{display:flex}.header-search,.header-right .user-info{display:none}.page-content{padding:16px!important}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.grid-2,.grid-1-1,.grid-3{grid-template-columns:1fr}.warehouse-grid,.finance-summary{grid-template-columns:1fr 1fr}.report-grid,.dept-grid,.settlement-grid,.form-row{grid-template-columns:1fr}.dashboard-grid{grid-template-columns:1fr!important}.data-table{font-size:13px}.data-table th,.data-table td{padding:10px 12px}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header-right{flex-wrap:wrap;gap:8px;display:flex}.filter-bar{gap:8px}.filter-bar .search-input{width:100%;min-width:0}.tabs{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.project-tabs{padding:4px}.project-tab{padding:6px 12px;font-size:11px}.modal{max-height:90vh;margin:8px;max-width:calc(100vw - 16px)!important}.modal-body{padding:16px}.modal-header{padding:14px 16px}.modal-footer{flex-wrap:wrap;padding:12px 16px}.kpi-grid{grid-template-columns:1fr 1fr!important;gap:12px!important}}.pipeline-stepper{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;justify-content:center;align-items:flex-start;gap:0;padding:28px 24px;display:flex;overflow-x:auto}.pipeline-step{flex-direction:column;flex:1;align-items:center;min-width:100px;transition:all .2s;display:flex;position:relative}.pipeline-step:hover{transform:translateY(-2px)}.pipeline-step-icon{background:var(--bg-secondary);border:2px solid var(--border-light);z-index:2;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;transition:all .25s;display:flex;position:relative}.pipeline-step.active .pipeline-step-icon{background:var(--accent-gradient);border-color:var(--accent-primary);box-shadow:0 0 20px #1c3a6b59}.pipeline-step.has-data .pipeline-step-icon{border-color:var(--accent-secondary)}.pipeline-step-label{color:var(--text-muted);text-align:center;margin-top:8px;font-size:12px;font-weight:500}.pipeline-step.active .pipeline-step-label{color:var(--text-accent);font-weight:600}.pipeline-step-count{color:var(--text-primary);margin-top:4px;font-size:18px;font-weight:700}.pipeline-step.active .pipeline-step-count{color:var(--accent-primary)}.pipeline-connector{background:var(--border-light);z-index:1;width:calc(100% - 60px);height:2px;position:absolute;top:24px;left:calc(50% + 30px)}.quotation-category-card{padding:0!important}.quotation-category-card .card-header{border-bottom:1px solid var(--border-color);border-radius:var(--border-radius)var(--border-radius)0 0;margin-bottom:0;padding:12px 16px}.quotation-detail-table{font-size:12px!important}.quotation-detail-table th{letter-spacing:.5px;background:var(--bg-input);white-space:nowrap;text-align:center;padding:8px 6px!important;font-size:10px!important}.quotation-detail-table td{vertical-align:middle;white-space:normal;padding:4px!important}.quotation-detail-table tbody tr:hover{background:#1c3a6b26}.form-input-compact{height:28px;border-radius:4px!important;min-height:auto!important;padding:4px 6px!important;font-size:12px!important}.form-input-compact:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #1c3a6b26}select.form-input-compact{padding-right:20px!important}.quotation-detail-table input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quotation-detail-table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quotation-detail-table input[type=number]{appearance:textfield;text-align:right}.quotation-summary-grid{max-width:600px;margin-left:auto}.quotation-summary-row{border-bottom:1px solid var(--border-light);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.quotation-summary-row:last-child{border-bottom:none}.quotation-summary-value{font-variant-numeric:tabular-nums;color:var(--text-primary);text-align:right;min-width:120px;font-weight:600}.quotation-summary-subtotal{color:var(--text-primary);border-bottom:2px solid var(--border-color);padding:10px 0;font-weight:600}.quotation-summary-grand{color:var(--accent-primary);border-bottom:none;padding:12px 0 4px;font-size:16px;font-weight:700}.quotation-summary-grand .quotation-summary-value{color:var(--accent-primary);font-size:18px}.btn-ghost{color:var(--text-secondary);cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);background:0 0;border:none;padding:6px 10px;font-family:Inter,sans-serif;font-size:13px;font-weight:500}.btn-ghost:hover{background:var(--bg-input);color:var(--text-primary)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:var(--border-radius-lg,12px);flex-direction:column;width:90%;animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{margin:0;font-size:16px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tree-sidebar{font-size:13px}.tree-node{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;align-items:center;gap:4px;padding:5px 10px;transition:background .1s;display:flex}.tree-node:hover{background:var(--bg-input)}.tree-root{text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-top:4px;padding-left:8px;font-size:12px;font-weight:700}.tree-sub{color:var(--text-primary);padding-left:18px;font-size:12px;font-weight:600}.tree-leaf{color:var(--text-secondary);padding-left:32px;font-size:12px}.tree-leaf:hover{color:var(--text-primary);background:#1c3a6b26}.tree-leaf-added{opacity:.45;cursor:default}.tree-leaf-added:hover{background:0 0}.tree-arrow{text-align:center;width:14px;color:var(--text-secondary);flex-shrink:0;font-size:10px}.tree-icon{text-align:center;flex-shrink:0;width:16px;font-size:12px}.tree-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.tree-price{color:var(--accent-primary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:10px;font-weight:600}.tree-count{background:var(--bg-input);color:var(--text-secondary);border-radius:8px;flex-shrink:0;padding:1px 5px;font-size:10px}.tree-thumb{object-fit:cover;border:1px solid var(--border-light,#e0e0e0);border-radius:4px;flex-shrink:0;width:22px;height:22px}.tree-leaf-selected{border-left:3px solid var(--accent-primary);padding-left:29px;background:#1c3a6b1f!important}.btn-tree-add{cursor:pointer;color:var(--accent-primary);opacity:.6;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:16px;line-height:1;transition:all .15s;display:none}.btn-tree-add:hover{opacity:1;transform:scale(1.2)}.tree-sub:hover .btn-tree-add{display:inline-block}.tree-select-bar{border-top:1px solid var(--border-color);background:var(--surface-alt,#f0f4ff);justify-content:space-between;align-items:center;padding:8px 12px;animation:.15s slideUp;display:flex}.btn-warning{color:#fff;cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);background:#f59e0b;border:none;padding:4px 8px;font-family:Inter,sans-serif;font-size:12px;font-weight:600}.btn-warning:hover{background:#d97706}.btn-success{color:#fff;cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);background:#10b981;border:none;font-weight:600}.btn-success:hover{background:#059669}.btn-info{color:#fff;cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);background:#0ea5e9;border:none;font-weight:600}.btn-info:hover{background:#0284c7}.btn-purple{color:#fff;cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);background:#8b5cf6;border:none;font-weight:600}.btn-purple:hover{background:#7c3aed}.quick-add-input{transition:all .2s;border-style:dashed!important;border-color:var(--accent-primary)!important;background:0 0!important}.quick-add-input:focus{background:var(--bg-card)!important;border-style:solid!important;box-shadow:0 0 0 3px #1c3a6b1a!important}.quick-add-input::placeholder{color:var(--accent-primary);opacity:.4;font-style:italic}.quick-add-dropdown{background:var(--bg-card);border:1px solid var(--border-color);z-index:50;border-radius:8px;max-height:280px;margin-bottom:4px;animation:.1s slideUp;position:absolute;bottom:100%;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 24px #00000026}.quick-add-option{cursor:pointer;border-bottom:1px solid var(--border-light);align-items:center;gap:8px;padding:8px 12px;transition:background .1s;display:flex}.quick-add-option:last-child{border-bottom:none}.quick-add-option:hover,.quick-add-option-active{background:#1c3a6b14}.quick-add-type{flex-shrink:0;font-size:14px}.quick-add-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.quick-add-sub{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.quick-add-price{color:var(--accent-primary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px;font-weight:600}.quotation-subcategory-card{border:1px solid var(--border-light);border-radius:8px;margin-bottom:12px;overflow:hidden}.subcategory-header{background:var(--surface-alt,#f8fafc);border-bottom:1px solid var(--border-light);align-items:center;gap:8px;padding:8px 12px;display:flex}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skip-to-content{background:var(--accent-primary);color:#fff;z-index:9999;padding:8px 16px;font-size:14px;transition:top .2s;position:absolute;top:-50px;left:0}.skip-to-content:focus{top:0}@media (max-width:480px){.stats-grid{gap:8px;grid-template-columns:1fr!important}.stat-card{padding:14px}.stat-card .stat-value{font-size:18px}.kpi-grid,.warehouse-grid,.finance-summary{grid-template-columns:1fr!important}.page-content{padding:12px!important}.page-header-left h1{font-size:18px}.header-title{font-size:15px}.btn{padding:8px 14px;font-size:12px}.filter-bar .filter-select{width:100%}}.quotation-layout{gap:16px;min-height:calc(100vh - 80px);display:flex;position:relative}.quotation-page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.quotation-tree-wrapper{width:300px;min-width:300px;max-height:calc(100vh - var(--header-height) - 16px);top:calc(var(--header-height) + 12px);position:sticky}.quotation-tree-wrapper .quotation-tree-sidebar{height:100%;max-height:calc(100vh - var(--header-height) - 16px)}.quotation-tree-toggle,.quotation-tree-overlay{display:none}.quotation-tree-close{display:none!important}.quotation-sticky-bar{top:var(--header-height);z-index:50;background:var(--bg-primary);border-bottom:1px solid var(--border-light);margin:0 -4px;padding:12px 4px 4px;position:sticky}.quotation-category-tabs{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px;display:flex}.subcategory-image-thumb{border:2px dashed var(--border-color);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:border-color .2s;display:flex;overflow:hidden}.subcategory-image-thumb:hover{border-color:var(--accent-primary)}.subcategory-image-thumb img{object-fit:cover;width:100%;height:100%}.subcategory-image-thumb .placeholder{opacity:.3;font-size:18px}.quotation-list-desktop{display:block}.quotation-list-mobile{display:none}.quotation-mobile-card{border-bottom:1px solid var(--border-color);cursor:pointer;padding:14px;transition:background .15s}.quotation-mobile-card:hover{background:var(--bg-card-hover)}.quotation-mobile-card:last-child{border-bottom:none}@media (max-width:768px){.quotation-layout{flex-direction:column;gap:0}.quotation-tree-wrapper{z-index:1001;width:300px;min-width:300px;height:100vh;max-height:100vh;transition:left .3s;position:fixed;top:0;left:-320px}.quotation-tree-wrapper.open{left:0}.quotation-tree-wrapper .quotation-tree-sidebar{border-radius:0;height:100vh;max-height:100vh}.quotation-tree-toggle{z-index:100;border-radius:50px;padding:10px 18px;font-size:13px;display:inline-flex;position:fixed;bottom:16px;left:16px;box-shadow:0 4px 16px #00000040}.quotation-tree-overlay{z-index:1000;background:#0006;display:block;position:fixed;inset:0}.quotation-tree-close{display:inline-flex!important}.quotation-list-desktop{display:none}.quotation-list-mobile{display:block}.quotation-detail-table{min-width:800px}.quotation-summary-grid{max-width:100%!important}.quotation-category-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:6px;padding-bottom:4px;overflow-x:auto}.quotation-category-tabs .btn{white-space:nowrap;flex-shrink:0;padding:8px 14px}}@media (max-width:480px){.quotation-page-header{flex-direction:column;align-items:stretch}.quotation-page-header>div{justify-content:flex-end}}.journal-timeline{flex-direction:column;gap:16px;display:flex}.journal-entry-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:10px;padding:16px 20px;transition:box-shadow .2s;position:relative}.journal-entry-card:hover{box-shadow:0 2px 12px #00000014}.journal-entry-card:before{content:"";background:linear-gradient(180deg,var(--accent-primary),var(--accent-secondary,#6366f1));border-radius:2px;width:3px;position:absolute;top:16px;bottom:16px;left:-1px}.journal-entry-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.journal-ai-summary{border-left:3px solid var(--accent-primary);color:var(--text-primary);background:#6366f10d;border-radius:6px;margin-bottom:8px;padding:10px 14px;font-size:13px;line-height:1.6}.journal-raw-input{margin-top:8px}.commitment-board{grid-template-columns:repeat(3,1fr);gap:16px;min-height:300px;display:grid}.commitment-column{background:var(--bg-secondary,#f8fafc);border-radius:10px;flex-direction:column;padding:12px;display:flex}.commitment-column-pending{border-top:3px solid #f59e0b}.commitment-column-committed{border-top:3px solid #3b82f6}.commitment-column-done{border-top:3px solid #10b981}.commitment-column-header{color:var(--text-primary);justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 4px;font-size:13px;font-weight:700;display:flex}.commitment-column-body{flex-direction:column;flex:1;gap:8px;display:flex}.commitment-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:8px;padding:10px 12px;transition:all .15s}.commitment-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.commitment-overdue{background:#ef44440a;border-color:#ef444466}.commitment-overdue:before{content:"";background:#ef4444;border-radius:8px 0 0 8px;width:3px;position:absolute;top:0;bottom:0;left:0}@media (max-width:768px){.commitment-board{grid-template-columns:1fr;gap:12px}}.budget-lock-bar{background:var(--bg-card);border:1px solid var(--border-light);border-radius:10px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.variance-stat{background:var(--bg-secondary,#f8fafc);border-radius:8px;flex-direction:column;gap:2px;padding:8px 16px;display:flex}.variance-progress-bar{background:var(--bg-input);border-radius:3px;flex:1;min-width:50px;height:6px;overflow:hidden}.variance-progress-fill{border-radius:3px;height:100%;transition:width .3s}.variance-status-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.profitability-widget{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:4px;display:grid}.profitability-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:10px;padding:16px;transition:box-shadow .2s}.profitability-card:hover{box-shadow:0 2px 12px #0000000f}@media (max-width:768px){.profitability-widget{grid-template-columns:repeat(2,1fr)}.budget-lock-bar{flex-direction:column;gap:12px}}
