:root{--color-text-strong:#0f172a;--color-text-base:#475569;--color-text-muted:#94a3b8;--color-text-faint:#cbd5e1;--color-bg-page:#fafbfc;--color-bg-card:#fff;--color-bg-sidebar:#fafafa;--color-bg-hover:#0f172a0a;--color-bg-subtle:#f1f5f9;--color-border:#f1f5f9;--color-border-strong:#e2e8f0;--color-accent:#6366f1;--color-accent-hover:#4f46e5;--color-success:#00875a;--color-success-bg:#e3fcef;--color-warning:#b54708;--color-warning-bg:#fef7e6;--color-danger:#b42318;--color-danger-bg:#fee4e2;--color-info:#1e40af;--color-info-bg:#eff6ff;--color-primary:var(--color-accent);--color-primary-hover:var(--color-accent-hover);--color-text-primary:var(--color-text-strong);--color-text-secondary:var(--color-text-base);--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-md:0 4px 8px -2px #0f172a14, 0 2px 4px -2px #0f172a0a;--shadow-lg:0 12px 24px -8px #0f172a1a, 0 4px 8px -2px #0f172a0f;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--space-1:2px;--space-2:4px;--space-3:6px;--space-4:8px;--space-5:12px;--space-6:16px;--space-7:20px;--space-8:24px;--space-9:32px;--space-10:40px;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:13px;--font-size-md:14px;--font-size-lg:16px;--font-size-xl:20px;--font-size-2xl:28px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--duration-fast:.12s;--duration-base:.18s;--duration-slow:.24s;--ease-spring:cubic-bezier(.32, .72, 0, 1);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;--font-mono:ui-monospace, "SF Mono", "Cascadia Mono", "JetBrains Mono", Consolas, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font-sans);color:var(--color-text-base);background:var(--color-bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02", "cv03", "cv04", "cv11";font-size:14px;line-height:1.5}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}a{color:var(--color-accent);text-decoration:none}input,select,textarea{color:inherit;font-family:inherit}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;width:240px;padding:16px 12px 12px;display:flex}.sidebar-logo{-webkit-user-select:none;user-select:none;align-items:center;gap:9px;padding:4px 8px 18px;display:flex}.sidebar-logo-icon{color:var(--color-text-strong);flex-shrink:0}.sidebar-logo-text{color:var(--color-text-strong);letter-spacing:-.01em;font-size:14px;font-weight:600}.sidebar-scroll{flex:1;margin:0 -4px;padding:0 4px;overflow-y:auto}.sidebar-group{margin-bottom:20px}.sidebar-group-header{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:0 8px 6px;font-size:11px;font-weight:600;transition:color 80ms;display:flex}.sidebar-group-header:hover{color:var(--color-text-base)}.sidebar-group-header svg{color:var(--color-text-faint);flex-shrink:0}.sidebar-group-header:hover svg{color:var(--color-text-muted)}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--color-text-base);cursor:pointer;align-items:center;gap:8px;padding:6px 10px;font-size:13px;font-weight:450;line-height:20px;transition:background 80ms,color 80ms;display:flex;position:relative}.sidebar-nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-strong)}.sidebar-nav-item:hover svg{color:var(--color-text-base)}.sidebar-nav-item.active{color:var(--color-text-strong);font-weight:550}.sidebar-nav-item.active:before{content:"";background:var(--color-accent);border-radius:0 1px 1px 0;width:2px;position:absolute;top:6px;bottom:6px;left:-12px}.sidebar-nav-item.active svg{color:var(--color-text-strong)}.sidebar-nav-item svg{color:var(--color-text-muted);flex-shrink:0}.sidebar-nav-item-label{flex:1}.stage-pill{letter-spacing:.04em;text-transform:uppercase;border-radius:3px;flex-shrink:0;padding:2px 5px;font-size:9px;font-weight:600;line-height:1}.stage-pill.beta{color:#b54708;background:#f59e0b1f}.stage-pill.soon{color:var(--color-text-muted);background:var(--color-bg-subtle)}.sidebar-footer{color:var(--color-text-faint);margin-top:4px;padding:12px 8px 4px;font-size:10px}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;height:56px;padding:0 28px;display:flex}.topbar-title{color:var(--color-text-strong);letter-spacing:-.01em;font-size:15px;font-weight:600}.topbar-actions{align-items:center;gap:14px;margin-left:auto;display:flex}.topbar-user-name{color:var(--color-text-base);font-size:13px;font-weight:500}.topbar-user-avatar{background:var(--color-bg-subtle);width:28px;height:28px;color:var(--color-text-strong);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.topbar-logout-btn{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.topbar-logout-btn:hover{color:var(--color-text-strong);background:var(--color-bg-subtle)}.login-wrapper{background:var(--color-bg-page);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:16px;width:340px;padding:40px 32px;display:flex}.login-title{text-align:center;color:var(--color-text-strong);margin:0 0 8px;font-size:20px;font-weight:700}.login-input{border:1px solid var(--color-border);background:var(--color-bg-page);color:var(--color-text-base);border-radius:6px;outline:none;padding:10px 12px;font-size:14px}.login-input:focus{border-color:var(--color-primary)}.login-error{color:var(--color-danger);text-align:center;background:#fef2f2;border-radius:6px;padding:8px;font-size:13px}.login-btn{cursor:pointer;color:#fff;background:var(--color-primary,#2563eb);border:none;border-radius:6px;padding:10px;font-size:14px;font-weight:600}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.content{background:var(--color-bg-page);flex:1;padding:28px 32px;overflow:auto}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px;display:grid}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 20px}.kpi-card-label{color:var(--color-text-muted);margin-bottom:8px;font-size:12px;font-weight:500}.kpi-card-value{color:var(--color-text-strong);letter-spacing:-.02em;font-feature-settings:"tnum";font-size:24px;font-weight:600;line-height:1.15}.kpi-card-delta{align-items:center;gap:3px;margin-top:6px;font-size:12px;font-weight:500;display:inline-flex}.kpi-card-delta.up{color:var(--color-success)}.kpi-card-delta.down{color:var(--color-danger)}.kpi-card-delta.muted{color:var(--color-text-muted)}.filter-bar{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px 14px;display:flex}.filter-input{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-bg-card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>") no-repeat 10px center;height:32px;color:var(--color-text-strong);outline:none;padding:0 10px 0 32px;font-size:13px;transition:border-color .15s,box-shadow .15s}.filter-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f11f}.filter-input::placeholder{color:var(--color-text-faint)}.filter-select{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);height:32px;color:var(--color-text-base);background:var(--color-bg-card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 8px center;appearance:none;cursor:pointer;outline:none;padding:0 28px 0 10px;font-size:13px}.filter-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f11f}.btn{border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;height:32px;padding:0 12px;font-size:13px;font-weight:500;transition:all .1s;display:inline-flex}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:var(--color-bg-card);color:var(--color-text-base);border-color:var(--color-border-strong)}.btn-secondary:hover{background:var(--color-bg-hover);color:var(--color-text-strong)}.btn-ghost{color:var(--color-text-base)}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-strong)}.badge{border-radius:var(--radius-sm);letter-spacing:.01em;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-gray{background:var(--color-bg-subtle);color:var(--color-text-base)}.row-actions{align-items:center;gap:2px;height:100%;display:flex}.icon-btn{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--color-text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .1s;display:inline-flex}.icon-btn:hover{background:var(--color-bg-subtle);color:var(--color-text-strong)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0f172a80;justify-content:center;align-items:center;animation:.15s ease-out overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-width:480px;max-width:560px;padding:24px 28px;animation:.18s ease-out modal-in}@keyframes modal-in{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{color:var(--color-text-strong);letter-spacing:-.01em;align-items:center;gap:8px;margin-bottom:4px;font-size:16px;font-weight:600;display:flex}.modal-subtitle{color:var(--color-text-muted);margin-bottom:20px;font-size:13px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.form-group{margin-bottom:14px}.form-label{color:var(--color-text-base);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-control{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-bg-card);width:100%;height:36px;color:var(--color-text-strong);outline:none;padding:0 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f11f}textarea.form-control{resize:vertical;height:auto;min-height:76px;padding:9px 12px;line-height:1.5}select.form-control{background:var(--color-bg-card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;appearance:none;padding-right:30px}.toast{background:var(--color-text-strong);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;animation:.2s ease-out toast-in;display:flex;position:fixed;bottom:28px;right:28px}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-header{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;gap:16px;margin-bottom:16px;padding:22px 26px;display:flex}.detail-header-pnk{font-family:var(--font-mono);color:var(--color-text-base);background:var(--color-bg-subtle);border-radius:var(--radius-sm);padding:3px 8px;font-size:12px;font-weight:500}.detail-tabs{background:var(--color-bg-subtle);border-radius:var(--radius-md);gap:0;width:fit-content;margin-bottom:16px;padding:3px;display:flex}.detail-tab{border-radius:var(--radius-sm);color:var(--color-text-base);cursor:pointer;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .1s;display:flex}.detail-tab:hover{color:var(--color-text-strong)}.detail-tab.active{background:var(--color-bg-card);color:var(--color-text-strong);box-shadow:var(--shadow-xs)}.chart-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px 22px}.chart-title{color:var(--color-text-strong);align-items:center;gap:6px;margin-bottom:16px;font-size:13px;font-weight:600;display:flex}.back-link{color:var(--color-text-base);cursor:pointer;align-items:center;gap:4px;margin-bottom:14px;font-size:13px;font-weight:500;transition:color .1s;display:inline-flex}.back-link:hover{color:var(--color-text-strong)}.action-log-row{background:var(--color-bg-subtle);border-radius:var(--radius-md);align-items:center;gap:14px;padding:12px 14px;font-size:13px;display:flex}.action-log-time{color:var(--color-text-muted);min-width:130px;font-size:12px;font-family:var(--font-mono)}.action-log-op{color:var(--color-text-strong);min-width:60px;font-weight:500}.action-log-note{color:var(--color-text-base)}.comment-thread{margin-bottom:12px}.comment-bubble{background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-bottom:8px;padding:10px 12px;font-size:13px;line-height:1.5}.comment-meta{color:var(--color-text-strong);align-items:center;gap:8px;margin-bottom:4px;font-size:12px;font-weight:500;display:flex}.comment-meta-time{color:var(--color-text-muted);font-weight:400}.comment-content{color:var(--color-text-base)}.hoverable-row{transition:background-color .1s}.hoverable-row:hover{background-color:#3b82f60a}.ag-theme-quartz .ag-row:hover{background-color:#3b82f60a!important}.ag-theme-quartz .ag-row{transition:background-color .1s}.ag-theme-quartz .ag-row-selected{background-color:#eff6ff!important}.ag-theme-quartz .ag-header{background:#f8fafc;border-bottom:1px solid #e2e8f0}.ag-theme-quartz .ag-header-cell{color:#64748b;letter-spacing:.01em;font-size:12px;font-weight:500}.ag-theme-quartz .ag-header-cell-label{padding:0 2px}.ag-theme-quartz .ag-cell{align-items:center;line-height:1.5;display:flex}.ag-theme-quartz .ag-row{border-color:#f1f5f9}.ag-header-cell.col-editable .ag-header-cell-text{border-bottom:1px dashed #93c5fd;padding-bottom:1px}.ag-header-cell.col-pending{color:#bf360c!important;background-color:#ffe0b2!important}.copy-icon{color:#64748b;cursor:pointer;opacity:0;flex-shrink:0;transition:opacity .12s,color .12s}.ag-cell:hover .copy-icon{opacity:.7}.copy-icon:hover{opacity:1;color:#2563eb}.sales-dual{flex-direction:column;align-items:center;width:100%;display:flex}.sales-dual .v-line{font-family:"Consolas", "SF Mono", var(--font-mono), monospace;text-align:center;font-size:13px;font-weight:500;line-height:1.3}.sales-dual .v-line+.v-line{margin-top:2px}.sales-dual .v-empty{color:#cbd5e1!important}.sales-dual .c-gross{color:#9a5b1e}.sales-dual .c-net{color:#3d5a96}.ag-header-cell.col-sales-dual .ag-header-cell-label{justify-content:center!important}.ag-header-cell.col-sales-dual .ag-header-cell-text{flex:none!important}.ag-cell.col-sales-dual{text-align:center!important}.ag-cell.col-sales-dual .ag-cell-wrapper,.ag-cell.col-sales-dual .ag-cell-wrapper .ag-cell-value{flex:1!important;width:100%!important}.sales-dual-header{flex-direction:column;align-items:flex-start;gap:3px;width:100%;padding:2px 0;line-height:1.3;display:flex}.sales-dual-header .h-line{color:#3b4252;align-items:baseline;gap:3px;font-size:12px;font-weight:600;display:flex}.sales-dual-header .tag-gross{color:#9a5b1e;font-weight:700}.sales-dual-header .tag-net{color:#3d5a96;font-weight:700}.sales-dual-header .tag-disc{color:#6e5b8a;font-weight:700}.sales-dual-header .hdr-tip{color:#fff;cursor:help;background:#94a3b8;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;margin-left:3px;font-size:10px;font-weight:700;display:inline-flex}.toolbar-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:4px;padding:6px 14px;font-size:12px;font-weight:450;transition:all .12s;display:inline-flex}.toolbar-btn:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.toolbar-btn-primary{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 14px;font-size:12px;font-weight:500;transition:all .12s;display:inline-flex}.toolbar-btn-primary:hover{background:#2563eb}.filter-tag{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;transition:all .1s;display:inline-flex}.filter-tag .filter-tag-close{cursor:pointer;color:#93c5fd;font-size:14px;line-height:1;transition:color .1s}.filter-tag .filter-tag-close:hover{color:#2563eb}.status-bar{color:#94a3b8;background:#fafbfc;border-top:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;font-size:12px;display:flex}.filter-dropdown{color:#475569;appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") right 8px center no-repeat;border:1px solid #e2e8f0;border-radius:6px;outline:none;padding:6px 28px 6px 10px;font-size:12px;transition:border-color .12s,box-shadow .12s}.filter-dropdown:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.filter-dropdown:hover{border-color:#cbd5e1}@keyframes sales-skeleton-pulse{0%,to{opacity:.4}50%{opacity:1}}.sales-trend-skeleton{background:#e2e8f0;animation:1.5s ease-in-out infinite sales-skeleton-pulse}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sales-heat-cell{cursor:pointer}.sales-heat-cell:hover{outline-offset:-2px;filter:brightness(.85);outline:2px solid #1d4ed8}
