@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";.import-overlay{z-index:1000;background:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.import-modal{background:var(--bg-surface);border-radius:var(--radius-lg);flex-direction:column;width:min(720px,94vw);max-height:88vh;animation:.35s forwards slideUpFade;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.import-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.import-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:700}.import-close-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.import-close-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.import-stepper{gap:var(--space-xs);padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--border-default);background:var(--bg-elevated);display:flex}.import-step{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-base);flex:1;font-size:.813rem;font-weight:500;display:flex}.import-step.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.import-step.completed{color:var(--color-positive)}.import-step-number{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.import-step.active .import-step-number{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.import-step.completed .import-step-number{background:var(--color-positive);color:#fff;border-color:var(--color-positive)}.import-body{padding:var(--space-xl);flex:1;overflow-y:auto}.import-dropzone{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--bg-elevated)}.import-dropzone:hover,.import-dropzone.dragging{border-color:var(--accent-primary);background:var(--accent-primary-soft)}.import-dropzone-icon{width:56px;height:56px;margin:0 auto var(--space-md);background:var(--accent-primary-soft);color:var(--accent-primary);border-radius:50%;justify-content:center;align-items:center;display:flex}.import-dropzone h3{color:var(--text-primary);margin:0 0 var(--space-xs);font-size:1rem;font-weight:600}.import-dropzone p{color:var(--text-muted);margin:0;font-size:.857rem}.import-file-info{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-positive-soft);border-radius:var(--radius-md);margin-top:var(--space-md);display:flex}.import-file-info span{color:var(--color-positive);font-size:.857rem;font-weight:600}.import-mapping-grid{gap:var(--space-md);display:grid}.import-mapping-row{align-items:center;gap:var(--space-md);grid-template-columns:1fr auto 1fr;display:grid}.import-mapping-label{color:var(--text-primary);align-items:center;gap:var(--space-xs);font-size:.857rem;font-weight:600;display:flex}.import-mapping-label .required{color:var(--color-negative);font-size:.75rem}.import-mapping-arrow{color:var(--text-muted);font-size:1.2rem}.import-mapping-select{border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);width:100%;color:var(--input-text);font-size:.857rem;font-family:var(--font-sans);transition:border-color var(--transition-fast);outline:none;padding:8px 12px}.import-mapping-select:focus{border-color:var(--input-border-focus);box-shadow:var(--focus-ring)}.import-mapping-select.unmapped{border-color:var(--color-warning);background:var(--color-warning-soft)}.import-defaults{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-default)}.import-defaults h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-md);font-size:.857rem;font-weight:600}.import-defaults-row{align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.import-defaults-row label{color:var(--text-primary);min-width:180px;font-size:.857rem}.import-preview-table{border-collapse:collapse;width:100%;font-size:.813rem}.import-preview-table th{background:var(--table-header-bg);color:var(--text-secondary);text-align:left;border-bottom:2px solid var(--border-default);text-transform:uppercase;letter-spacing:.03em;padding:8px 12px;font-size:.75rem;font-weight:600}.import-preview-table td{border-bottom:1px solid var(--border-default);color:var(--text-primary);padding:8px 12px}.import-preview-table tr:nth-child(2n){background:var(--table-row-alt)}.import-summary{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.import-summary-card{padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-md);text-align:center;border:1px solid var(--border-default)}.import-summary-card .value{color:var(--accent-primary);font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.import-summary-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.75rem}.import-new-products{padding:var(--space-md);border-radius:var(--radius-md);background:var(--color-warning-soft);margin-bottom:var(--space-lg);border:1px solid #f59e0b4d}.import-new-products h4{margin:0 0 var(--space-sm);color:var(--color-warning);font-size:.857rem;font-weight:600}.import-new-products p{color:var(--text-secondary);margin:0;font-size:.813rem}.import-new-products-tags{margin-top:var(--space-sm);flex-wrap:wrap;gap:6px;display:flex}.import-new-products-tags span{background:var(--color-warning);color:#fff;border-radius:100px;padding:2px 10px;font-size:.75rem;font-weight:600}.import-progress-container{padding:var(--space-2xl) 0;text-align:center}.import-progress-bar{background:var(--bg-elevated);width:100%;height:8px;margin:var(--space-lg) 0;border-radius:100px;overflow:hidden}.import-progress-fill{background:linear-gradient(90deg, var(--accent-primary), var(--color-positive));border-radius:100px;height:100%;transition:width .4s}.import-progress-text{color:var(--text-secondary);font-size:.857rem}.import-progress-text strong{color:var(--text-primary)}.import-result{text-align:center;padding:var(--space-xl) 0}.import-result-icon{width:64px;height:64px;margin:0 auto var(--space-lg);border-radius:50%;justify-content:center;align-items:center;display:flex}.import-result-icon.success{background:var(--color-positive-soft);color:var(--color-positive)}.import-result-icon.error{background:var(--color-negative-soft);color:var(--color-negative)}.import-result h3{color:var(--text-primary);margin:0 0 var(--space-sm);font-size:1.25rem;font-weight:700}.import-result p{color:var(--text-secondary);margin:0;font-size:.929rem}.import-footer{padding:var(--space-md) var(--space-xl);border-top:1px solid var(--border-default);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.import-btn{border-radius:var(--radius-sm);font-size:.857rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;padding:10px 24px}.import-btn.primary{background:var(--accent-primary);color:#fff}.import-btn.primary:hover:not(:disabled){background:var(--accent-primary-hover)}.import-btn.primary:disabled{opacity:.5;cursor:not-allowed}.import-btn.secondary{border:1px solid var(--border-default);color:var(--text-secondary);background:0 0}.import-btn.secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}:root{--bg-base:#fafafa;--bg-surface:#fff;--bg-elevated:#f5f5f5;--bg-overlay:#0006;--text-primary:#1a1a2e;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-inverse:#fff;--border-default:#e5e7eb;--border-hover:#d1d5db;--border-active:#3b82f6;--accent-primary:#3b82f6;--accent-primary-hover:#2563eb;--accent-primary-soft:#3b82f614;--color-positive:#10b981;--color-positive-soft:#10b9811a;--color-negative:#ef4444;--color-negative-soft:#ef44441a;--color-warning:#f59e0b;--color-warning-soft:#f59e0b1a;--chart-blue:#3b82f6;--chart-blue-soft:#3b82f626;--chart-green:#10b981;--chart-green-soft:#10b98126;--chart-amber:#f59e0b;--chart-amber-soft:#f59e0b26;--chart-red:#ef4444;--chart-red-soft:#ef444426;--chart-violet:#8b5cf6;--chart-violet-soft:#8b5cf626;--chart-cyan:#06b6d4;--chart-cyan-soft:#06b6d426;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 1px 3px #0000000f;--shadow-lg:0 4px 12px #00000014;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--sidebar-width:240px;--sidebar-bg:#fff;--sidebar-border:#e5e7eb;--sidebar-item-hover:#f3f4f6;--sidebar-item-active:#3b82f614;--sidebar-text:#6b7280;--sidebar-text-active:#3b82f6;--topbar-height:64px;--topbar-bg:#fff;--topbar-glass-bg:#ffffffbf;--topbar-border:#e5e7eb80;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--focus-ring:0 0 0 2px #3b82f666;--input-bg:#fff;--input-border:#d1d5db;--input-border-focus:#3b82f6;--input-text:#1a1a2e;--input-placeholder:#9ca3af;--table-header-bg:#f9fafb;--table-row-alt:#fafafa;--table-row-hover:#f3f4f6}[data-theme=dark]{--bg-base:#0f1117;--bg-surface:#1a1d27;--bg-elevated:#232733;--bg-overlay:#0009;--text-primary:#e8e8ed;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-inverse:#0f1117;--border-default:#2d3141;--border-hover:#3d4255;--border-active:#60a5fa;--accent-primary:#60a5fa;--accent-primary-hover:#93c5fd;--accent-primary-soft:#60a5fa1a;--color-positive:#34d399;--color-positive-soft:#34d3991a;--color-negative:#f87171;--color-negative-soft:#f871711a;--color-warning:#fbbf24;--color-warning-soft:#fbbf241a;--shadow-sm:none;--shadow-md:none;--shadow-lg:0 4px 16px #0000004d;--sidebar-bg:#1a1d27;--sidebar-border:#2d3141;--sidebar-item-hover:#232733;--sidebar-item-active:#60a5fa1a;--sidebar-text:#9ca3af;--sidebar-text-active:#60a5fa;--topbar-bg:#1a1d27;--topbar-glass-bg:#1a1d27bf;--topbar-border:#2d314180;--input-bg:#232733;--input-border:#3d4255;--input-border-focus:#60a5fa;--input-text:#e8e8ed;--input-placeholder:#6b7280;--table-header-bg:#232733;--table-row-alt:#1e2130;--table-row-hover:#282c3a}*,: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:14px}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-base);transition:background-color var(--transition-slow), color var(--transition-slow);min-height:100vh;font-weight:400;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}ul,ol{list-style:none}img,svg{max-width:100%;display:block}table{border-collapse:collapse;width:100%}::selection{background:var(--accent-primary);color:var(--text-inverse)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-hover);border:2px solid var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{box-shadow:var(--focus-ring);outline:none}.text-mono{font-family:var(--font-mono)}.text-sm{font-size:.857rem;line-height:1.4}.text-xs{font-size:.786rem;line-height:1.3}.text-lg{font-size:1.143rem;font-weight:600}.text-xl{font-size:1.5rem;font-weight:700}.text-2xl{letter-spacing:-.02em;font-size:2rem;font-weight:700}.text-secondary{color:var(--text-secondary)}.app-shell{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:calc(var(--topbar-height) + var(--space-md)) 1fr;grid-template-areas:"sidebar topbar""sidebar main";min-height:100vh;display:grid}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:var(--space-md) 0;width:var(--sidebar-width);z-index:50;height:100vh;transition:background-color var(--transition-slow), border-color var(--transition-slow);flex-direction:column;grid-area:sidebar;display:flex;position:fixed;top:0;left:0}.sidebar-brand{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);margin-bottom:var(--space-lg);display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:var(--accent-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-brand-name{color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:700;overflow:hidden}.sidebar-nav{padding:0 var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:var(--space-md) var(--space-md) var(--space-xs);font-size:.714rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);font-size:.929rem;font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--sidebar-item-active);color:var(--sidebar-text-active);font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent-primary);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link.disabled{opacity:.35;pointer-events:none}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-dropdown-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;font-size:.929rem;font-weight:500;display:flex}.sidebar-dropdown-btn:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-dropdown-btn .btn-content{align-items:center;gap:var(--space-sm);display:flex}.sidebar-dropdown-btn .chevron{opacity:.5;transition:transform .2s}.sidebar-dropdown-btn.open .chevron{transform:rotate(180deg)}.sidebar-dropdown-content{flex-direction:column;gap:2px;margin-top:2px;padding-left:28px;display:flex;overflow:hidden}.sidebar-dropdown-item{align-items:center;gap:var(--space-sm);padding:6px var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);font-size:.857rem;font-weight:500;text-decoration:none;display:flex}.sidebar-dropdown-item:hover{color:var(--text-primary);background:var(--sidebar-item-hover)}.sidebar-dropdown-item.active{color:var(--accent-primary);font-weight:600}.sidebar-dropdown-item svg{width:14px;height:14px}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--sidebar-border);flex-direction:column;gap:2px;display:flex}.sidebar-footer-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);width:100%;font-size:.857rem;font-weight:500;display:flex}.sidebar-footer-btn:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-footer-btn svg{width:16px;height:16px}.topbar{background:var(--topbar-glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--topbar-border);border-radius:var(--radius-lg);padding:0 var(--space-xl);top:var(--space-md);left:calc(var(--sidebar-width) + var(--space-lg));right:var(--space-lg);height:var(--topbar-height);z-index:40;transition:all var(--transition-slow);grid-area:topbar;justify-content:space-between;align-items:center;display:flex;position:fixed;box-shadow:0 4px 20px #0000000d}.topbar-left{align-items:center;gap:var(--space-md);display:flex}.topbar-title{color:var(--text-primary);letter-spacing:-.01em;font-size:1.143rem;font-weight:700}.topbar-right{align-items:center;gap:var(--space-md);display:flex}.topbar-user{align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.857rem;font-weight:500;display:flex}.topbar-avatar{background:var(--accent-primary-soft);width:32px;height:32px;color:var(--accent-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.857rem;font-weight:600;display:flex}.main-content{padding:var(--space-xl);min-height:calc(100vh - var(--topbar-height));grid-area:main;max-width:1400px}.page-grid{gap:var(--space-lg);display:grid}.kpi-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.chart-grid-2{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=1024px){.chart-grid-2{grid-template-columns:1fr}}@media (width<=768px){.app-shell{grid-template-columns:1fr;grid-template-areas:"topbar""main"}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.topbar{left:var(--space-sm);right:var(--space-sm);top:var(--space-sm);border-radius:var(--radius-md);padding:0 var(--space-md)}.main-content{padding:var(--space-md);margin-left:0}.kpi-grid{grid-template-columns:repeat(2,1fr)}}.card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);transition:background-color var(--transition-slow), border-color var(--transition-slow), box-shadow var(--transition-fast)}.card:hover{border-color:var(--border-hover)}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.857rem;font-weight:600}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--kpi-accent,var(--accent-primary));opacity:0;height:2px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.kpi-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.kpi-card.selected{box-shadow:0 0 0 1px var(--kpi-accent), var(--shadow-md);border-color:var(--kpi-accent);z-index:10;transform:scale(1.01)}.kpi-card.selected:hover{transform:scale(1.01)translateY(-1px)}.kpi-card:hover:before,.kpi-card.selected:before{opacity:1}.kpi-card-header{justify-content:space-between;align-items:center;display:flex}.kpi-card-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.786rem;font-weight:600}.kpi-card-icon{border-radius:var(--radius-sm);background:var(--kpi-accent-soft,var(--accent-primary-soft));width:36px;height:36px;color:var(--kpi-accent,var(--accent-primary));justify-content:center;align-items:center;display:flex}.kpi-card-icon svg{width:18px;height:18px}.kpi-card-value{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;font-size:1.714rem;font-weight:700;line-height:1.2}.kpi-card-delta{border-radius:100px;align-items:center;gap:4px;padding:2px 8px;font-size:.786rem;font-weight:600;display:inline-flex}.kpi-card-delta.positive{color:var(--color-positive);background:var(--color-positive-soft)}.kpi-card-delta.negative{color:var(--color-negative);background:var(--color-negative-soft)}.kpi-card-delta svg{width:12px;height:12px}.kpi-card-footer{color:var(--text-muted);font-size:.786rem}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap;font-size:.857rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-primary-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--sidebar-item-hover);border-color:var(--border-hover)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-icon{padding:var(--space-sm)}.btn svg{width:16px;height:16px}.btn:disabled{opacity:.5;pointer-events:none}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-label{color:var(--text-secondary);font-size:.857rem;font-weight:500}.input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--input-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px;font-size:.929rem}.input::placeholder{color:var(--input-placeholder)}.input:focus{border-color:var(--input-border-focus);box-shadow:var(--focus-ring)}.input-error{border-color:var(--color-negative)}.input-error-text{color:var(--color-negative);font-size:.786rem}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:100px;align-items:center;gap:4px;padding:2px 10px;font-size:.714rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-primary-soft);color:var(--accent-primary)}.badge-green{background:var(--color-positive-soft);color:var(--color-positive)}.badge-red{background:var(--color-negative-soft);color:var(--color-negative)}.badge-amber{background:var(--color-warning-soft);color:var(--color-warning)}.data-table-wrapper{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:var(--table-header-bg)}.data-table th{padding:var(--space-sm) var(--space-md);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-default);white-space:nowrap;font-size:.714rem;font-weight:600}.data-table td{padding:var(--space-sm) var(--space-md);color:var(--text-primary);border-bottom:1px solid var(--border-default);font-size:.857rem}.data-table tbody tr:nth-child(2n){background:var(--table-row-alt)}.data-table tbody tr:hover{background:var(--table-row-hover)}.data-table tbody tr.no-hover-row:hover{background:inherit}.data-table tbody tr:last-child td{border-bottom:none}.spinner{border:2.5px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-overlay{justify-content:center;align-items:center;width:100%;min-height:200px;display:flex}.empty-state{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-2xl);text-align:center;color:var(--text-muted);flex-direction:column;display:flex}.empty-state svg{opacity:.4;width:48px;height:48px}.empty-state-title{color:var(--text-secondary);font-size:1rem;font-weight:600}.empty-state-text{max-width:320px;font-size:.857rem}.period-selector{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:2px;display:flex}.period-btn{color:var(--text-secondary);transition:all var(--transition-fast);border-radius:4px;padding:6px 12px;font-size:.786rem;font-weight:500}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm);font-weight:600}.filter-bar{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);flex-wrap:wrap;display:flex}.filter-select{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);padding:6px 12px;font-size:.857rem;font-weight:500}.filter-select:focus{border-color:var(--input-border-focus)}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-2xl);gap:var(--space-lg);flex-direction:column;width:100%;max-width:400px;display:flex}.login-header{text-align:center;align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.login-logo{border-radius:var(--radius-md);background:var(--accent-primary);color:#fff;width:48px;height:48px;margin-bottom:var(--space-sm);justify-content:center;align-items:center;display:flex}.login-logo svg{width:24px;height:24px}.login-title{color:var(--text-primary);font-size:1.286rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.857rem}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.login-btn{background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);width:100%;transition:background var(--transition-fast);padding:12px;font-size:.929rem;font-weight:600}.login-btn:hover{background:var(--accent-primary-hover)}.login-btn:disabled{opacity:.6;pointer-events:none}.login-error{background:var(--color-negative-soft);color:var(--color-negative);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;font-size:.857rem;font-weight:500}.pagination{padding:var(--space-md);justify-content:space-between;align-items:center;display:flex}.pagination-info{color:var(--text-muted);font-size:.786rem}.pagination-controls{align-items:center;gap:var(--space-xs);display:flex}.pagination-btn{border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:6px 10px;font-size:.786rem;font-weight:500}.pagination-btn:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary)}.pagination-btn:disabled{opacity:.3;cursor:default}.ranking-bar-wrapper{align-items:center;gap:var(--space-sm);display:flex}.ranking-bar{background:var(--bg-elevated);border-radius:3px;flex:1;height:6px;overflow:hidden}.ranking-bar-fill{background:var(--accent-primary);height:100%;transition:width var(--transition-slow);border-radius:3px}.ranking-pct{font-family:var(--font-mono);color:var(--text-muted);text-align:right;min-width:40px;font-size:.714rem;font-weight:500}.chart-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);transition:background-color var(--transition-slow), border-color var(--transition-slow)}.chart-card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-md);font-size:.857rem;font-weight:600}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pageTurnWipe{0%{opacity:0;filter:blur(3px);transform:scale(.99)}to{opacity:1;filter:blur();transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease both}.animate-slide-in{animation:slideIn var(--transition-slow) ease both}.animate-table-page{animation:.5s cubic-bezier(.16,1,.3,1) both pageTurnWipe}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.expansion-container{opacity:0;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.16,1,.3,1),opacity .4s;display:grid}.expansion-container.expanded{opacity:1;grid-template-rows:1fr}.expansion-container.expanded .expansion-content{animation:.5s cubic-bezier(.16,1,.3,1) forwards slideDownFade}.expansion-content{min-height:0;overflow:hidden}.animate-number{animation:.4s cubic-bezier(.16,1,.3,1) forwards slideUpFade;display:inline-block}.kpi-card:first-child{animation-delay:0s}.kpi-card:nth-child(2){animation-delay:50ms}.kpi-card:nth-child(3){animation-delay:.1s}.kpi-card:nth-child(4){animation-delay:.15s}.kpi-card:nth-child(5){animation-delay:.2s}.audit-header{justify-content:space-between;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex}.audit-header h2{color:var(--text-primary);margin:0 0 4px;font-size:1.15rem;font-weight:700}.audit-header p{color:var(--text-muted);margin:0;font-size:.857rem}.audit-actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.badge-positive{background:var(--color-positive-soft);color:var(--color-positive)}.badge-warning{background:var(--color-warning-soft);color:var(--color-warning)}.badge-error{background:var(--color-negative-soft);color:var(--color-negative)}.badge-secondary{background:var(--bg-elevated);color:var(--text-secondary)}.table-card{padding:0;overflow:hidden}.table-card .table-wrapper{overflow-x:auto}.table-card .alert{margin:var(--space-md) var(--space-lg) 0}.alert{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.857rem;font-weight:500;display:flex}.alert-error{background:var(--color-negative-soft);color:var(--color-negative)}.text-positive{color:var(--color-positive)}.text-negative,.text-error{color:var(--color-negative)}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.857rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.15rem}.text-xl{font-size:1.25rem}.text-mono,.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.inline{vertical-align:middle;display:inline}.mr-xs{margin-right:4px}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.py-xl{padding-top:var(--space-xl);padding-bottom:var(--space-xl)}.mx-auto{margin-left:auto;margin-right:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.spin{animation:.8s linear infinite spin}.kpi-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.786rem;font-weight:600}.kpi-value{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;font-size:1.5rem;font-weight:700;line-height:1.2}.kpi-trend{color:var(--text-muted);margin-top:2px;font-size:.75rem}.settings-modules-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.settings-module-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-md);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.settings-module-card:before{content:"";background:var(--border-default);height:3px;transition:background var(--transition-base);position:absolute;top:0;left:0;right:0}.settings-module-card.active:before{background:var(--module-accent,var(--accent-primary))}.settings-module-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.settings-module-card.active{border-color:var(--module-accent,var(--accent-primary))}.settings-module-header{justify-content:space-between;align-items:center;display:flex}.settings-module-icon{border-radius:var(--radius-md);width:44px;height:44px;transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.settings-module-body{flex:1}.settings-module-name{color:var(--text-primary);margin:0 0 var(--space-xs);font-size:1rem;font-weight:700}.settings-module-desc{color:var(--text-secondary);margin:0;font-size:.857rem;line-height:1.5}.settings-module-footer{align-items:center;gap:var(--space-sm);display:flex}.settings-toggle{cursor:pointer;color:var(--text-muted);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:0}.settings-toggle:hover{color:var(--text-secondary)}.settings-toggle.on{color:var(--module-accent,var(--accent-primary))}.settings-info-banner{align-items:flex-start;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--accent-primary-soft);border:1px solid var(--accent-primary);border-radius:var(--radius-md);color:var(--accent-primary);font-size:.857rem;line-height:1.5;display:flex}.settings-info-banner svg{flex-shrink:0;margin-top:2px}.settings-save-bar{bottom:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:20;justify-content:space-between;align-items:center;display:flex;position:sticky}.settings-save-hint{color:var(--color-warning);font-size:.857rem;font-weight:600}.settings-toast{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-positive-soft);color:var(--color-positive);border-radius:var(--radius-sm);animation:fadeIn var(--transition-slow) ease both;font-size:.857rem;font-weight:500;display:flex}.addons-product-group{padding:0;overflow:hidden}.addons-product-header{padding:var(--space-md) var(--space-lg);cursor:pointer;width:100%;transition:background var(--transition-fast);color:var(--text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;font-family:inherit;display:flex}.addons-product-header:hover{background:var(--table-row-hover)}.addons-product-info{align-items:center;gap:var(--space-sm);display:flex}.addons-product-emoji{background:var(--bg-elevated);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;font-size:1.5rem;display:flex}.addons-product-name{font-size:.929rem;font-weight:700}.addons-product-body{border-top:1px solid var(--border-default)}.addons-product-body .data-table th:first-child,.addons-product-body .data-table td:first-child{padding-left:var(--space-lg)}.addons-product-body .data-table th:last-child,.addons-product-body .data-table td:last-child{padding-right:var(--space-lg)}.addons-unassigned-chip{border-radius:var(--radius-sm);border:1px dashed var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:.786rem;font-weight:500;display:inline-flex}.addons-unassigned-chip:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-primary-soft)}.addons-selected-product{align-items:center;gap:var(--space-sm);background:var(--accent-primary-soft);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);color:var(--accent-primary);padding:10px 14px;font-size:.929rem;font-weight:600;display:flex}.addons-selected-product span:first-child{font-size:1.25rem}.addons-modal-overlay{background:var(--bg-overlay);z-index:100;padding:var(--space-lg);justify-content:center;align-items:center;animation:.15s both fadeIn;display:flex;position:fixed;inset:0}.addons-modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;animation:.2s cubic-bezier(.16,1,.3,1) both slideUpFade;overflow-y:auto;box-shadow:0 16px 48px #0003}.addons-modal--sm{max-width:380px}.addons-modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.addons-modal-header h3{color:var(--text-primary);align-items:center;margin:0;font-size:1rem;font-weight:700;display:flex}.addons-modal-body{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.addons-modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-default);background:var(--bg-elevated);border-radius:0 0 var(--radius-lg) var(--radius-lg);display:flex}.period-wrapper{position:relative}.period-selector{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-default);align-items:center;gap:2px;padding:3px;display:flex}.period-btn{border-radius:calc(var(--radius-sm) - 2px);font-size:.786rem;font-weight:500;font-family:var(--font-sans);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:5px 12px}.period-btn:hover{color:var(--text-primary);background:var(--bg-surface)}.period-btn.active{background:var(--bg-surface);color:var(--accent-primary);font-weight:600;box-shadow:0 1px 3px #0000000f}.period-btn-calendar{justify-content:center;align-items:center;padding:5px 8px;display:flex}.period-btn-calendar.active{color:var(--accent-primary)}.calendar-dropdown{z-index:100;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-md);width:300px;animation:.15s ease-out calendarSlideIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 6px -1px #00000012,0 10px 15px -3px #00000014,0 20px 40px -4px #0000000a}@keyframes calendarSlideIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes calendarSlideOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-6px)scale(.97)}}.calendar-dropdown.closing{animation:.15s ease-in forwards calendarSlideOut}.calendar-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.calendar-month-label{color:var(--text-primary);text-transform:capitalize;font-size:.929rem;font-weight:600}.calendar-nav-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.calendar-nav-btn:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--border-default);color:var(--text-primary)}.calendar-nav-btn:disabled{opacity:.3;cursor:not-allowed}.calendar-hint{text-align:center;color:var(--accent-primary);margin-bottom:var(--space-xs);min-height:20px;padding:4px 0;font-size:.714rem;font-weight:500}.calendar-day-labels{grid-template-columns:repeat(7,1fr);gap:0;margin-bottom:4px;display:grid}.calendar-day-labels span{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;padding:4px 0;font-size:.714rem;font-weight:600}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-day{aspect-ratio:1;width:100%;font-size:.786rem;font-weight:500;font-family:var(--font-mono);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .1s;display:flex;position:relative}.calendar-day:hover:not(.disabled):not(.outside){background:var(--accent-primary-soft);color:var(--accent-primary)}.calendar-day.outside{color:var(--text-muted);opacity:.4}.calendar-day.today{color:var(--accent-primary);font-weight:700}.calendar-day.today:after{content:"";background:var(--accent-primary);border-radius:50%;width:4px;height:4px;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.calendar-day.disabled{color:var(--text-muted);opacity:.25;cursor:not-allowed}.calendar-day.in-range{background:var(--accent-primary-soft);border-radius:0}.calendar-day.range-start{background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-weight:700}.calendar-day.range-start:after{display:none}.calendar-day.range-end{background:var(--accent-primary);color:#fff;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-weight:700}.calendar-day.range-end:after{display:none}.calendar-day.range-start.range-end{border-radius:var(--radius-sm)}.calendar-day.selecting{background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);box-shadow:0 0 0 2px var(--accent-primary-soft);font-weight:700}.calendar-footer{gap:var(--space-xs);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-default);display:flex}.calendar-quick-btn{border-radius:var(--radius-sm);font-size:.714rem;font-weight:500;font-family:var(--font-sans);color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border-default);cursor:pointer;transition:all var(--transition-fast);flex:1;padding:5px 10px}.calendar-quick-btn:hover{background:var(--accent-primary-soft);color:var(--accent-primary);border-color:var(--accent-primary)}.calendar-quick-btn.cancel{color:var(--color-negative);border-color:var(--color-negative-soft)}.calendar-quick-btn.cancel:hover{background:var(--color-negative-soft);border-color:var(--color-negative)}[data-theme=dark] .calendar-dropdown{box-shadow:0 4px 6px -1px #0000004d,0 10px 15px -3px #00000040}[data-theme=dark] .calendar-day.in-range{background:#3b82f626}
