:root{--bg: #F1F4F9;--surface: #FFFFFF;--surface-2: #F8FAFC;--border: #E5E9F0;--border-strong: #D4DAE4;--text: #0F172A;--text-muted: #64748B;--text-faint: #94A3B8;--sidebar-bg: #1E293B;--sidebar-bg-active: #0F172A;--sidebar-text: #CBD5E1;--sidebar-text-muted: #64748B;--sidebar-text-active: #FFFFFF;--sidebar-accent: #2563EB;--sidebar-border: #334155;--primary: #2563EB;--primary-hover: #1D4ED8;--primary-soft: #EFF6FF;--success: #10B981;--success-soft: #ECFDF5;--warning: #F59E0B;--warning-soft: #FFFBEB;--orange: #F97316;--orange-soft: #FFF7ED;--danger: #EF4444;--danger-soft: #FEF2F2;--info: #3B82F6;--info-soft: #EFF6FF;--neutral: #64748B;--neutral-soft: #F1F5F9;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, .08), 0 4px 6px -4px rgba(15, 23, 42, .06);--shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, .1), 0 8px 10px -6px rgba(15, 23, 42, .06);--row-h: 48px;--row-py: 12px;--row-fs: 14px}[data-density=compact]{--row-h: 36px;--row-py: 6px;--row-fs: 13px}[data-theme=dark]{--bg: #0B1220;--surface: #111827;--surface-2: #0F172A;--border: #1F2937;--border-strong: #334155;--text: #F1F5F9;--text-muted: #94A3B8;--text-faint: #64748B;--sidebar-bg: #0B1220;--sidebar-bg-active: #1E293B;--sidebar-text: #CBD5E1;--sidebar-text-muted: #64748B;--sidebar-text-active: #FFFFFF;--sidebar-border: #1F2937;--primary-soft: rgba(37, 99, 235, .15);--success-soft: rgba(16, 185, 129, .15);--warning-soft: rgba(245, 158, 11, .15);--orange-soft: rgba(249, 115, 22, .15);--danger-soft: rgba(239, 68, 68, .15);--info-soft: rgba(59, 130, 246, .15);--neutral-soft: rgba(100, 116, 139, .15)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button,input,select,textarea{font-family:inherit;color:inherit}button{cursor:pointer;border:none;background:none;padding:0}.app{display:grid;grid-template-columns:240px minmax(0,1fr);grid-template-rows:64px 1fr;grid-template-areas:"sidebar header" "sidebar main";min-height:100vh;height:100vh}.app.collapsed{grid-template-columns:72px 1fr}.sidebar{grid-area:sidebar;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--sidebar-border)}.sidebar-brand{height:64px;display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-brand-logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0;letter-spacing:-.02em}.sidebar-brand-text{font-weight:700;font-size:15px;color:#fff;letter-spacing:-.01em;white-space:nowrap}.sidebar-brand-sub{font-size:11px;color:var(--sidebar-text-muted);margin-top:-2px}.app.collapsed .sidebar-brand-text,.app.collapsed .sidebar-brand-sub{display:none}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 0 16px}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.sidebar-section{margin-bottom:4px}.sidebar-section-title{padding:12px 20px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-text-muted)}.app.collapsed .sidebar-section-title{padding:12px 0 4px;text-align:center;font-size:9px}.sidebar-group{margin-bottom:2px}.sidebar-group-head{display:flex;align-items:center;gap:10px;padding:9px 16px;margin:0 8px;border-radius:6px;cursor:pointer;color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:all .15s}.sidebar-group-head:hover{background:#ffffff0d;color:#fff}.sidebar-group-head.open{color:#fff}.sidebar-group-head.active-group{background:var(--primary);color:#fff;font-weight:600}.sidebar-group-head.active-group:hover{background:var(--primary)}.sidebar-group-icon{width:18px;height:18px;flex-shrink:0;opacity:.9}.sidebar-group-label{flex:1}.sidebar-chev{width:14px;height:14px;transition:transform .2s;opacity:.6}.sidebar-group.open .sidebar-chev{transform:rotate(90deg)}.app.collapsed .sidebar-group-label,.app.collapsed .sidebar-chev{display:none}.app.collapsed .sidebar-group-head{justify-content:center;padding:9px 0}.sidebar-children{padding:2px 0 6px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:7px 16px 7px 46px;margin:0 8px;border-radius:6px;color:var(--sidebar-text);font-size:13px;cursor:pointer;transition:all .15s;position:relative}.sidebar-item:before{content:"";position:absolute;left:24px;top:50%;width:4px;height:4px;border-radius:50%;background:#475569;transform:translateY(-50%)}.sidebar-item:hover{background:#ffffff0d;color:#fff}.sidebar-item:hover:before{background:#94a3b8}.sidebar-item.active{background:var(--primary);color:#fff;font-weight:600}.sidebar-item.active:before{background:#fff}.app.collapsed .sidebar-children{display:none}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px;flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#60a5fa,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;font-weight:600;font-size:13px}.sidebar-user-role{color:var(--sidebar-text-muted);font-size:11px}.app.collapsed .sidebar-user-info{display:none}.header{grid-area:header;background:var(--surface);border-bottom:1px solid var(--border);display:grid;grid-template-columns:minmax(220px,280px) minmax(320px,1fr) auto;align-items:center;column-gap:16px;padding:0 20px;height:56px;position:sticky;top:0;z-index:10;min-width:0}.header>*{min-width:0}.header-left{display:flex;align-items:center;gap:12px;min-width:0;overflow:hidden}.header-title-wrap{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.header-title,.header-breadcrumb{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-title{font-size:17px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.header-breadcrumb{font-size:11.5px;color:var(--text-muted);display:block}.header-breadcrumb>span,.header-breadcrumb>.sep{display:inline}.header-breadcrumb .sep{opacity:.5;margin:0 6px}.icon-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s;position:relative;flex:0 0 auto}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn svg{width:18px;height:18px}.header-center{display:flex;justify-content:center;min-width:0}.header-search{display:flex;align-items:center;gap:10px;height:38px;width:100%;max-width:520px;padding:0 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text-muted);cursor:pointer;transition:all .15s;box-sizing:border-box}.header-search:hover{border-color:var(--border-strong)}.header-search svg{width:16px;height:16px;flex:0 0 auto}.header-search-text{flex:1;font-size:13px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kbd{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border-radius:4px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-size:11px;font-family:JetBrains Mono,monospace;flex:0 0 auto}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:4px;white-space:nowrap}@media (max-width: 1280px){.header{grid-template-columns:minmax(180px,240px) minmax(280px,1fr) auto}.tenant-switch span:not(.tenant-dot){display:none}.tenant-switch{padding:0 10px}}@media (max-width: 1100px){.quick-add-btn span{display:none}}@media (max-width: 980px){.header{grid-template-columns:minmax(140px,200px) auto}.header-center{display:none}}@media (max-width: 720px){.header{grid-template-columns:1fr auto;padding:0 12px}.header-breadcrumb{display:none}.header-title{font-size:15px}}.tenant-switch{display:flex;align-items:center;gap:8px;height:36px;padding:0 12px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:13px;font-weight:500;transition:all .15s}.tenant-switch:hover{border-color:var(--border-strong)}.tenant-dot{width:8px;height:8px;border-radius:50%;background:var(--primary)}.quick-add-btn{display:flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:8px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;transition:all .15s}.quick-add-btn:hover{background:var(--primary-hover)}.quick-add-btn svg{width:14px;height:14px}.notif-badge{position:absolute;top:6px;right:6px;width:16px;height:16px;border-radius:50%;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}.main{grid-area:main;overflow:auto;padding:24px;min-width:0}.subnav{grid-column:2;background:#cbd5e1;border-bottom:1px solid #94A3B8;display:flex;align-items:center;flex-wrap:wrap;row-gap:0;column-gap:4px;padding:0 24px;min-height:46px;position:sticky;top:64px;z-index:9}[data-theme=dark] .subnav{background:#0f172a;border-bottom-color:#334155}.subnav-tab{position:relative;padding:0 14px;height:40px;display:inline-flex;align-items:center;font-size:12px;font-weight:500;color:#334155;white-space:nowrap;transition:all .12s;border-bottom:3px solid transparent}[data-theme=dark] .subnav-tab{color:#94a3b8}.subnav-tab:hover{color:var(--text)}.subnav-tab.active{color:var(--primary);font-weight:700;border-bottom-color:var(--primary);background:var(--surface)}.app.has-subnav{grid-template-rows:64px 44px 1fr;grid-template-areas:"sidebar header" "sidebar subnav" "sidebar main"}.app.has-subnav .subnav{grid-area:subnav}.page-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;min-width:0}.tabs{display:flex;align-items:center;gap:4px;padding:0 20px;border-bottom:1px solid var(--border);background:var(--surface)}.tab{padding:14px 16px;font-size:14px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}.tabs{overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.filters{padding:20px;border-bottom:1px solid var(--border);background:var(--surface)}.filter-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}@media (max-width: 1100px){.filter-row{grid-template-columns:repeat(2,minmax(0,1fr))}}.filter-row+.filter-row{margin-top:14px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:12px;font-weight:500;color:var(--text-muted)}.input,.select{height:36px;padding:0 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:13px;transition:all .15s;width:100%}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.input::placeholder{color:var(--text-faint)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 5L6 8L9 5' stroke='%2364748B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.date-range{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}.date-range .sep{color:var(--text-muted)}.filter-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border-radius:var(--radius);font-size:13px;font-weight:500;transition:all .15s;border:1px solid transparent;white-space:nowrap}.btn svg{width:14px;height:14px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-ghost{color:var(--text);border-color:var(--border);background:var(--surface)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-subtle{color:var(--text-muted)}.btn-subtle:hover{background:var(--surface-2);color:var(--text)}.table-toolbar{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.table-meta{font-size:13px;color:var(--text-muted)}.table-meta b{color:var(--text);font-weight:600}.table-wrap{background:var(--surface);overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:var(--row-fs)}table.data thead th{background:var(--surface-2);padding:var(--row-py) 16px;text-align:left;font-weight:600;font-size:12px;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;text-transform:none;letter-spacing:0}table.data thead th:first-child{padding-left:20px;width:36px}table.data thead th.num{text-align:right}table.data tbody td{padding:var(--row-py) 16px;border-bottom:1px solid var(--border);color:var(--text);height:var(--row-h);vertical-align:middle;white-space:nowrap}table.data tbody td:first-child{padding-left:20px}table.data tbody td.num{text-align:right;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}table.data tbody tr{transition:background .12s}table.data tbody tr:hover{background:var(--surface-2);cursor:pointer}table.data tbody tr.selected{background:var(--primary-soft)}table.data tbody tr:last-child td{border-bottom:none}.link{color:var(--primary);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.checkbox{width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;background:var(--surface);vertical-align:middle}.checkbox.checked{background:var(--primary);border-color:var(--primary);color:#fff}.checkbox svg{width:10px;height:10px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap;line-height:1.4}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.badge-info{background:var(--info-soft);color:var(--info)}.badge-success{background:var(--success-soft);color:var(--success)}.badge-warning{background:var(--warning-soft);color:#b45309}.badge-orange{background:var(--orange-soft);color:#c2410c}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-neutral{background:var(--neutral-soft);color:var(--neutral)}.badge-primary{background:var(--primary-soft);color:var(--primary)}[data-theme=dark] .badge-warning{color:#fcd34d}[data-theme=dark] .badge-orange{color:#fdba74}.pagination{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:var(--surface);border-top:1px solid var(--border)}.pagi-controls{display:flex;align-items:center;gap:4px}.pagi-btn{width:32px;height:32px;border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.pagi-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.pagi-btn.active{background:var(--primary);color:#fff}.pagi-btn:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease-out}[data-theme=dark] .modal-backdrop{background:#000000a6}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:1280px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);background:var(--surface)}.modal-title-wrap{display:flex;align-items:center;gap:12px}.modal-title{font-size:18px;font-weight:700;letter-spacing:-.01em}.modal-sub{font-size:13px;color:var(--text-muted)}.modal-head-actions{display:flex;align-items:center;gap:8px}.modal-body{overflow-y:auto;padding:24px;flex:1}.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px 32px;padding:20px 24px;background:var(--surface-2);border-radius:var(--radius-lg);border:1px solid var(--border)}.detail-row{display:flex;align-items:baseline;gap:12px}.detail-label{font-size:12.5px;color:var(--text-muted);font-weight:500;min-width:72px;flex-shrink:0}.detail-value{font-size:13.5px;color:var(--text);font-weight:500}.section-head{display:flex;align-items:center;justify-content:space-between;margin:24px 0 12px}.section-title{font-size:14px;font-weight:700;letter-spacing:-.01em}.totals-bar{display:flex;align-items:center;justify-content:flex-end;gap:32px;padding:14px 20px;background:var(--surface-2);border-top:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);font-size:13px}.totals-bar .label{color:var(--text-muted);margin-right:8px}.totals-bar .val{font-weight:600;font-variant-numeric:tabular-nums}.totals-bar .grand{font-size:16px;font-weight:700;color:var(--primary)}.kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi{padding:14px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.kpi-label{font-size:12px;color:var(--text-muted);margin-bottom:6px}.kpi-value{font-size:20px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-value.primary{color:var(--primary)}.kpi-value.success{color:var(--success)}.kpi-value.orange{color:#c2410c}[data-theme=dark] .kpi-value.orange{color:#fdba74}.subtabs{display:flex;gap:2px;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;width:fit-content}.subtab{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-muted);border-radius:6px;transition:all .15s}.subtab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);font-weight:600}.modal-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-2);gap:12px}.modal-foot-left{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:16px}.modal-foot-left b{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}.modal-foot-right{display:flex;gap:8px}.form-section-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text);margin:0 0 12px;letter-spacing:-.01em}.form-section-title .sec-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:6px;background:var(--primary-soft);color:var(--primary);font-size:11px;font-weight:700}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px 16px;padding:18px 20px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg)}.form-field{display:flex;flex-direction:column;gap:6px;min-width:0}.form-field.col-2{grid-column:span 2}.form-field.col-4{grid-column:span 4}.form-label{font-size:12px;color:var(--text-muted);font-weight:500}.form-label .req{color:var(--danger);margin-left:2px}.form-field .input,.form-field .select,.form-field textarea{width:100%}.form-field textarea{min-height:68px;padding:10px 12px;font:inherit;font-size:13px;border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--surface);color:var(--text);resize:vertical}.form-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.input-with-btn{display:flex;gap:6px}.input-with-btn .input,.input-with-btn .select{flex:1}.input-with-btn .icon-btn{width:36px;height:36px;flex-shrink:0;border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted)}.input-with-btn .icon-btn:hover{background:var(--surface-2);color:var(--text)}.line-table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface)}table.line-items{width:100%;border-collapse:collapse;font-size:13px}table.line-items thead th{background:var(--surface-2);color:var(--text-muted);font-weight:600;font-size:12px;text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}table.line-items thead th.num{text-align:right}table.line-items tbody td{padding:6px 8px;border-bottom:1px solid var(--border);vertical-align:middle}table.line-items tbody tr:last-child td{border-bottom:none}table.line-items input.cell,table.line-items select.cell{width:100%;height:32px;padding:0 8px;border:1px solid transparent;border-radius:6px;background:transparent;font:inherit;font-size:13px;color:var(--text)}table.line-items input.cell:hover,table.line-items select.cell:hover{border-color:var(--border-strong);background:var(--surface)}table.line-items input.cell:focus,table.line-items select.cell:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft);background:var(--surface)}table.line-items td.num input.cell{text-align:right;font-variant-numeric:tabular-nums}table.line-items td.readonly{text-align:right;font-variant-numeric:tabular-nums;padding:0 12px;color:var(--text);font-weight:500}table.line-items .row-del{width:28px;height:28px;border-radius:6px;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center}table.line-items .row-del:hover{background:var(--danger-soft);color:var(--danger)}.line-add-row{padding:10px 12px;background:var(--surface-2);border-top:1px solid var(--border);display:flex;justify-content:flex-start}.line-add-row .btn-add{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;color:var(--primary);background:transparent;border:1px dashed var(--primary);border-radius:6px}.line-add-row .btn-add:hover{background:var(--primary-soft)}.ps-popover{position:absolute;top:calc(100% + 4px);left:0;min-width:380px;max-width:520px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:50;overflow:hidden}.ps-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:12px;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border)}.ps-list{max-height:240px;overflow-y:auto}.ps-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--border);gap:12px}.ps-item:last-child{border-bottom:none}.ps-item:hover{background:var(--primary-soft)}.ps-item-main{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.ps-code{font-size:12px;color:var(--primary);font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}.ps-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ps-spec{font-size:12px;color:var(--text-muted);flex-shrink:0}.ps-price{font-size:12px;color:var(--text);font-variant-numeric:tabular-nums;flex-shrink:0}.ps-empty{padding:14px 12px;text-align:center}.ps-foot{padding:8px;background:var(--surface-2);border-top:1px solid var(--border)}.ps-new-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;color:var(--primary);background:transparent;border:1px dashed var(--primary);border-radius:6px}.ps-new-btn:hover{background:var(--primary-soft)}.dash-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}@media (max-width: 1100px){.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.stat-card{padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-icon svg{width:20px;height:20px}.stat-icon.blue{background:var(--info-soft);color:var(--info)}.stat-icon.green{background:var(--success-soft);color:var(--success)}.stat-icon.orange{background:var(--orange-soft);color:#c2410c}.stat-icon.purple{background:#8b5cf61f;color:#7c3aed}.stat-label{font-size:13px;color:var(--text-muted)}.stat-value{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:4px 0;font-variant-numeric:tabular-nums}.stat-trend{font-size:12px;display:inline-flex;align-items:center;gap:4px;color:var(--success);font-weight:600}.stat-trend.down{color:var(--danger)}.panel-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:16px;margin-bottom:20px}@media (max-width: 1100px){.panel-grid{grid-template-columns:minmax(0,1fr)}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.panel-title{font-size:14px;font-weight:700;letter-spacing:-.01em}.panel-body{padding:16px 20px}.chart-mock{height:240px;display:flex;align-items:flex-end;gap:8px;padding:20px}.chart-bar{flex:1;background:linear-gradient(180deg,var(--primary),#60A5FA);border-radius:6px 6px 0 0;position:relative;min-height:8%;opacity:.9;transition:opacity .2s}.chart-bar:hover{opacity:1}.chart-bar:after{content:attr(data-label);position:absolute;bottom:-22px;left:50%;transform:translate(-50%);font-size:11px;color:var(--text-muted)}.activity-list{display:flex;flex-direction:column}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.activity-content{flex:1;font-size:13px}.activity-time{font-size:11.5px;color:var(--text-muted);margin-top:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}.empty-icon{width:64px;height:64px;border-radius:16px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:20px}.empty-icon svg{width:32px;height:32px}.empty-title{font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.empty-desc{font-size:14px;color:var(--text-muted);max-width:420px}.toggle-group{display:inline-flex;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px}.toggle-opt{padding:5px 10px;font-size:12px;font-weight:500;color:var(--text-muted);border-radius:5px;transition:all .12s;display:inline-flex;align-items:center;gap:4px}.toggle-opt.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);font-weight:600}.toggle-opt svg{width:12px;height:12px}.main::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:10px}.main::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:5px;border:2px solid var(--bg)}[data-theme=dark] .main::-webkit-scrollbar-thumb,[data-theme=dark] .modal-body::-webkit-scrollbar-thumb{background:#334155;border-color:var(--bg)}@media (max-width: 768px){.app{grid-template-columns:0 1fr!important}.sidebar{position:fixed;left:-260px;top:0;bottom:0;width:240px;z-index:100;transition:left .2s ease;box-shadow:2px 0 8px #00000026}.app:not(.collapsed) .sidebar{left:0}.app:not(.collapsed):before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.page-card{padding:10px!important}.table-wrap,.data{overflow-x:auto!important;-webkit-overflow-scrolling:touch}table.data,table.table{min-width:700px}div[style*="grid-template-columns: repeat(5"],div[style*="grid-template-columns: repeat(4"],div[style*="grid-template-columns: repeat(3"],div[style*="grid-template-columns: repeat(7"],div[style*="grid-template-columns: repeat(6"]{grid-template-columns:1fr 1fr!important}.modal{width:95vw!important;max-width:95vw!important}.header-breadcrumb,.header-center{display:none!important}}@media (max-width: 480px){div[style*="grid-template-columns: repeat(5"],div[style*="grid-template-columns: repeat(4"],div[style*="grid-template-columns: repeat(3"],div[style*="grid-template-columns: repeat(7"],div[style*="grid-template-columns: repeat(6"]{grid-template-columns:1fr!important}.page-card{padding:8px!important}table.data,table.table{font-size:11px!important}}@media print{.sidebar,.header,.subnav,button{display:none!important}.main{padding:0!important}.page-card{box-shadow:none!important;border:1px solid #ccc!important}}
