:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#dbeafe;--color-primary-dark:#1e3a8a;--color-accent:#f59e0b;--color-accent-hover:#d97706;--color-accent-light:#fef3c7;--color-success:#10b981;--color-success-light:#d1fae5;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-danger:#ef4444;--color-danger-light:#fee2e2;--color-info:#3b82f6;--color-info-light:#dbeafe;--color-bg:#f8fafc;--color-bg-card:#fff;--color-bg-sidebar:#1e293b;--color-bg-hover:#f1f5f9;--color-bg-active:#e2e8f0;--color-bg-input:#fff;--color-bg-header:#fff;--color-border:#e2e8f0;--color-border-focus:#2563eb;--color-border-light:#f1f5f9;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-inverse:#fff;--color-text-link:#2563eb;--sidebar-text:#cbd5e1;--sidebar-text-active:#fff;--sidebar-hover:#ffffff14;--sidebar-active:#2563eb40;--sidebar-width:260px;--font-heading:"Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-sans:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000000a;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.2s cubic-bezier(.4,0,.2,1);--transition-slow:.3s cubic-bezier(.4,0,.2,1);--z-dropdown:50;--z-sticky:100;--z-modal:200;--z-toast:300}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:16px}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:var(--leading-normal);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.02em}a{color:var(--color-text-link);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg-sidebar);color:var(--sidebar-text);z-index:var(--z-sticky);transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar__logo{padding:var(--space-6);align-items:center;gap:var(--space-3);border-bottom:1px solid #ffffff14;display:flex}.sidebar__logo h1{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--sidebar-text-active);letter-spacing:-.025em}.sidebar__nav{padding:var(--space-4)var(--space-3);flex:1;overflow-y:auto}.sidebar__section-title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);padding:var(--space-4)var(--space-3)var(--space-2)}.sidebar__link{align-items:center;gap:var(--space-3);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);text-decoration:none;display:flex}.sidebar__link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar__link--active{background:var(--sidebar-active);color:var(--sidebar-text-active)}.sidebar__icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar__link--active .sidebar__icon,.sidebar__link:hover .sidebar__icon{opacity:1}.main-content{margin-left:var(--sidebar-width);min-width:0;max-width:calc(100vw - var(--sidebar-width));height:100vh;transition:margin-left var(--transition-normal);flex:1;overflow:hidden auto}.main-header{background:var(--color-bg-header);border-bottom:1px solid var(--color-border);padding:var(--space-4)var(--space-8);z-index:var(--z-sticky);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.main-header__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text)}.main-header__actions{align-items:center;gap:var(--space-3);display:flex}.page-content{padding:var(--space-8)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base);overflow:visible}.card:hover{box-shadow:var(--shadow-md)}.card__header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card__title{font-size:var(--text-base);font-weight:var(--font-semibold)}.card__body{padding:var(--space-6)}.kpi-grid{gap:var(--space-6);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card__label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--font-medium);margin-bottom:var(--space-2)}.kpi-card__value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-tight)}.kpi-card__trend{font-size:var(--text-sm);margin-top:var(--space-2);align-items:center;gap:var(--space-1);display:flex}.kpi-card__trend--up{color:var(--color-success)}.kpi-card__trend--down{color:var(--color-danger)}.dashboard-grid{gap:var(--space-6);margin-bottom:var(--space-8);grid-template-columns:1fr 1fr;display:grid}.dashboard-grid--3col{grid-template-columns:repeat(3,1fr)}.dashboard-grid__full{grid-column:1/-1}.stat-row{padding:var(--space-3)0;border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.stat-row:last-child{border-bottom:none}.stat-row__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-row__value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);font-variant-numeric:tabular-nums}.leaderboard{margin:0;padding:0;list-style:none}.leaderboard__item{align-items:center;gap:var(--space-3);padding:var(--space-3)0;border-bottom:1px solid var(--color-border-light);display:flex}.leaderboard__item:last-child{border-bottom:none}.leaderboard__rank{border-radius:var(--radius-full);background:var(--color-primary-light);width:24px;height:24px;color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.leaderboard__item:first-child .leaderboard__rank{color:#92400e;background:#fef3c7}.leaderboard__item:nth-child(2) .leaderboard__rank{color:#475569;background:#e2e8f0}.leaderboard__item:nth-child(3) .leaderboard__rank{color:#9a3412;background:#fed7aa}.leaderboard__name{font-size:var(--text-sm);font-weight:var(--font-medium);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.leaderboard__count{font-weight:var(--font-bold);font-size:var(--text-sm);color:var(--color-text);font-variant-numeric:tabular-nums}.chart-container{width:100%;min-height:220px}.dist-grid{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.dist-grid th{text-align:left;padding:var(--space-2)var(--space-3);font-weight:var(--font-semibold);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.dist-grid td{padding:var(--space-2)var(--space-3);border-bottom:1px solid var(--color-border-light);font-variant-numeric:tabular-nums}.dist-grid tr:last-child td{border-bottom:none}.dist-grid td:first-child{font-weight:var(--font-medium);text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.funnel-step{align-items:center;gap:var(--space-3);padding:var(--space-2)0;display:flex}.funnel-step__bar-wrap{background:var(--color-bg-hover);border-radius:var(--radius-md);flex:1;height:28px;position:relative;overflow:hidden}.funnel-step__bar{border-radius:var(--radius-md);height:100%;padding-left:var(--space-3);align-items:center;transition:width .8s cubic-bezier(.22,1,.36,1);display:flex}.funnel-step__bar-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:#fff;white-space:nowrap}.funnel-step__label{width:140px;font-size:var(--text-sm);font-weight:var(--font-medium);text-align:right;flex-shrink:0}.funnel-step__count{text-align:right;width:50px;font-size:var(--text-sm);font-weight:var(--font-bold);font-variant-numeric:tabular-nums}.funnel-step__dropoff{width:60px;font-size:var(--text-xs);color:var(--color-danger);text-align:right}.recharts-cartesian-axis-tick-value{font-family:var(--font-sans)!important;fill:var(--color-text-secondary)!important;font-size:11px!important}.recharts-tooltip-wrapper{font-family:var(--font-sans)!important}.recharts-default-tooltip{background:var(--color-bg-card)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;padding:var(--space-2)var(--space-3)!important}@media (max-width:900px){.dashboard-grid,.dashboard-grid--3col{grid-template-columns:1fr}}.period-tabs{align-items:center;gap:var(--space-1);flex-wrap:wrap;display:flex}.period-tab{padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;display:inline-flex}.period-tab:hover{background:var(--color-bg-hover);color:var(--color-text);border-color:var(--color-text-muted)}.period-tab--active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.period-tab--active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);white-space:nowrap;line-height:var(--leading-normal);border:1px solid #0000;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn--secondary{background:var(--color-bg-card);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-bg-hover)}.btn--danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn--danger:hover:not(:disabled){background:#dc2626}.btn--ghost{color:var(--color-text-secondary);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text)}.btn--sm{padding:var(--space-1)var(--space-3);font-size:var(--text-xs)}.btn--lg{padding:var(--space-3)var(--space-6);font-size:var(--text-base)}.btn--icon{padding:var(--space-2)}.form-group{margin-bottom:var(--space-5)}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);margin-bottom:var(--space-1);display:block}.form-label--required:after{content:" *";color:var(--color-danger)}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.form-error{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1)}.input{width:100%;padding:var(--space-3)var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-input);color:var(--color-text);font-size:var(--text-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);line-height:var(--leading-normal);outline:none}.input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #2563eb1a}.input:disabled,.input[readonly]{background:var(--color-bg-hover);color:var(--color-text-muted);cursor:not-allowed;opacity:.7}.input--error{border-color:var(--color-danger)}.input--error:focus{box-shadow:0 0 0 3px var(--color-danger-light)}textarea.input{resize:vertical;min-height:80px}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3)center;cursor:pointer;padding-right:2.5rem}select.input:hover:not(:disabled){border-color:var(--color-text-muted)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);white-space:nowrap;display:inline-flex}.badge--success{background:var(--color-success-light);color:#065f46}.badge--warning{background:var(--color-warning-light);color:#92400e}.badge--danger{background:var(--color-danger-light);color:#991b1b}.badge--info{background:var(--color-info-light);color:#1e40af}.badge--neutral{background:var(--color-bg-active);color:var(--color-text-secondary)}.badge__dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge--success .badge__dot{background:var(--color-success)}.badge--warning .badge__dot{background:var(--color-warning)}.badge--danger .badge__dot{background:var(--color-danger)}.badge--info .badge__dot{background:var(--color-info)}.table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);overflow:auto visible}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{text-align:left;padding:var(--space-3)var(--space-4);background:var(--color-bg-hover);font-weight:var(--font-semibold);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;z-index:1;position:sticky;top:0}.table td{padding:var(--space-3)var(--space-4);border-bottom:1px solid var(--color-border-light);color:var(--color-text);vertical-align:middle;white-space:nowrap;text-overflow:ellipsis;position:relative;overflow:hidden}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#2563eb05}.table tr.table__row--selected td{background:var(--color-primary-light)}.col-resize-handle{cursor:col-resize;z-index:2;width:6px;transition:background var(--transition-fast);background:0 0;position:absolute;top:0;bottom:0;right:0}.col-resize-handle:after{content:"";width:2px;transition:background var(--transition-fast);background:0 0;border-radius:1px;position:absolute;top:25%;bottom:25%;right:2px}.col-resize-handle:hover:after{background:var(--color-primary)}.col-resize-handle:active:after{background:var(--color-primary);top:0;bottom:0}.table th{text-overflow:ellipsis;overflow:hidden}.tag{align-items:center;gap:var(--space-1);padding:3px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);background:var(--color-primary-light);color:var(--color-primary-dark);transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.01em;display:inline-flex}.tag--secondary{background:var(--color-bg-active);color:var(--color-text-secondary)}.tag--success{background:var(--color-success-light);color:#065f46}.tag--warning{background:var(--color-warning-light);color:#92400e}.tag--removable{cursor:pointer;padding-right:var(--space-2)}.tag--removable:hover{background:var(--color-danger-light);color:var(--color-danger)}.tag__remove{opacity:.6;margin-left:var(--space-1);transition:opacity var(--transition-fast);align-items:center;font-size:14px;line-height:1;display:inline-flex}.tag__remove:hover{opacity:1}.tag-list{gap:var(--space-2);flex-wrap:wrap;display:flex}.tag-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-md);min-height:48px;padding:var(--space-2);gap:var(--space-1);transition:all var(--transition-fast);flex-wrap:wrap;align-items:center;display:flex}.tag-dropzone--active{border-color:var(--color-primary);background:var(--color-primary-light)}.tag-dropzone__label{font-size:var(--text-xs);color:var(--color-text-muted);padding:var(--space-1)var(--space-2)}.empty-state{text-align:center;padding:var(--space-16)var(--space-8)}.empty-state__icon{margin-bottom:var(--space-4);opacity:.3;font-size:3rem}.empty-state__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);max-width:400px;margin-inline:auto}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-width:480px;animation:slideIn var(--transition-slow)ease-out;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.audit-trail{border-left:2px solid var(--color-border);padding-left:var(--space-4);margin-top:var(--space-4);min-width:0;overflow:hidden}.audit-entry{padding-bottom:var(--space-4);min-width:0;position:relative;overflow:hidden}.audit-entry:before{content:"";left:calc(-1*var(--space-4) - 5px);background:var(--color-border);border:2px solid var(--color-bg-card);border-radius:50%;width:8px;height:8px;position:absolute;top:4px}.audit-entry__header{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-1)}.audit-entry__body{font-size:var(--text-sm);color:var(--color-text-secondary);word-break:break-all;overflow-wrap:anywhere}.audit-entry__change{display:inline}.audit-entry__old{color:var(--color-danger);text-decoration:line-through}.audit-entry__new{color:var(--color-success);font-weight:var(--font-medium);word-break:break-all;overflow-wrap:anywhere}.tabs{border-bottom:1px solid var(--color-border);align-items:center;gap:0;display:flex;overflow-x:auto}.tab{padding:var(--space-3)var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000}.tab:hover{color:var(--color-text);background:var(--color-bg-hover)}.tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab--add{color:var(--color-text-muted);font-size:var(--text-lg);padding:var(--space-2)var(--space-3)}.sidebar{transition:width var(--transition-slow),transform var(--transition-slow)}.sidebar--collapsed{width:64px}.sidebar--collapsed .sidebar__logo{padding:var(--space-3);justify-content:center}.sidebar--collapsed .sidebar__nav{padding:var(--space-2)}.sidebar--collapsed .sidebar__link{padding:var(--space-2);justify-content:center}.sidebar--collapsed .sidebar__icon{width:24px;height:24px}.sidebar--collapsed .sidebar__section-title{text-align:center;padding:var(--space-2)0}.sidebar--collapsed~.main-content{max-width:calc(100vw - 64px);margin-left:64px}.filter-bar{align-items:center;gap:var(--space-3);padding:var(--space-4)var(--space-6);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.filter-bar__group{align-items:center;gap:var(--space-2);display:flex}.filter-bar__group label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.filter-bar__search{flex:1;min-width:200px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);animation:fadeIn var(--transition-fast)ease-out;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:640px;max-height:85vh;animation:scaleIn var(--transition-base)ease-out;overflow-y:auto}.modal__header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal__title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.modal__close{font-size:var(--text-xl);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);transition:color var(--transition-fast);background:0 0;border:none;line-height:1}.modal__close:hover{color:var(--color-text)}.modal__body{padding:var(--space-6)}.modal__footer{padding:var(--space-4)var(--space-6);border-top:1px solid var(--color-border);justify-content:flex-end;gap:var(--space-3);display:flex}.detail-grid{gap:var(--space-6);grid-template-columns:1fr 380px;align-items:start;display:grid}.detail-grid-2col{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.detail-grid>*{min-width:0}@media (max-width:1100px){.detail-grid{grid-template-columns:1fr}}.detail-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);min-width:0;overflow:hidden}.detail-section__title{font-size:var(--text-base);font-weight:var(--font-semibold);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);color:var(--color-text);letter-spacing:-.01em}.detail-field{margin-bottom:var(--space-5)}.detail-field__label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-2)}.product-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.product-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);background:var(--color-bg);transition:border-color var(--transition-fast)}.product-card:hover{border-color:var(--color-primary)}.product-card__name{font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-2)}.product-card__fields{gap:var(--space-2);display:flex}.product-card__fields .input{padding:var(--space-1)var(--space-2);font-size:var(--text-xs)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-hover)25%,var(--color-bg-active)50%,var(--color-bg-hover)75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton--text{width:80%;height:14px;margin-bottom:var(--space-2)}.skeleton--badge{border-radius:var(--radius-full);width:80px;height:22px}.skeleton--row{width:100%;height:48px;margin-bottom:var(--space-1)}.infinite-scroll-sentinel{padding:var(--space-6);color:var(--color-text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.checkbox{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.col-picker{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);min-width:260px;max-height:400px;overflow-y:auto}.col-picker__item{align-items:center;gap:var(--space-2);padding:var(--space-1)var(--space-2);font-size:var(--text-sm);cursor:grab;border-radius:var(--radius-sm);transition:background var(--transition-fast);-webkit-user-select:none;user-select:none;display:flex}.col-picker__item:hover{background:var(--color-bg-hover)}.col-picker__grip{color:var(--color-text-muted);cursor:grab;flex-shrink:0}.col-picker__label{-webkit-user-select:none;user-select:none;color:var(--color-text);flex:1}.mass-update-panel{align-items:center;gap:var(--space-4);padding:var(--space-3)var(--space-6);background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-lg);margin-bottom:var(--space-4);animation:scaleIn var(--transition-base)ease-out;display:flex}.mass-update-panel__count{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary-dark);white-space:nowrap}.table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table th.sortable:hover{background:var(--color-bg-active)}.sort-indicator{margin-left:var(--space-1);opacity:.4;font-size:var(--text-xs);display:inline-block}.sort-indicator--active{opacity:1;color:var(--color-primary)}.action-bar{padding:var(--space-4)0;margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);z-index:20;background:var(--color-bg);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.action-bar__left,.action-bar__right{align-items:center;gap:var(--space-3);display:flex}.show-mobile{display:none!important}@media (max-width:768px){.hide-mobile{display:none!important}.show-mobile{display:flex!important}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar--collapsed{width:64px}.main-content,.sidebar--collapsed~.main-content{max-width:100vw;margin-left:0}.main-header{padding:var(--space-3)var(--space-4)}.page-content{padding:var(--space-4)}.kpi-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.kpi-card{padding:var(--space-4)}.kpi-card__value{font-size:var(--text-2xl)}.filter-bar{padding:var(--space-3);flex-direction:column;align-items:stretch}.filter-bar__search{min-width:0}.action-bar{gap:var(--space-2);padding:var(--space-3)0;flex-wrap:wrap}.action-bar__left,.action-bar__right{gap:var(--space-2);flex-wrap:wrap}.mass-update-panel{align-items:stretch;gap:var(--space-3);padding:var(--space-3);flex-direction:column}.detail-section{padding:var(--space-4)}.detail-section__title{font-size:var(--text-sm)}.table thead{display:none}.table,.table tbody{width:100%;display:block}.table tr{padding:var(--space-3)var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-1);flex-direction:column;display:flex;position:relative}.table tr:last-child{border-bottom:none}.table td{padding:var(--space-1)0;white-space:normal;text-overflow:unset;border-bottom:none;align-items:center;display:flex;overflow:visible}.table td:before{content:attr(data-label);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;min-width:100px;margin-right:var(--space-2);flex-shrink:0}.table td[data-label=""]{top:var(--space-3);right:var(--space-3);position:absolute}.table td[data-label=""]:before,.col-resize-handle,.col-picker{display:none}.toast-container{top:auto;bottom:var(--space-4);left:var(--space-4);right:var(--space-4)}.toast{min-width:auto;max-width:100%}.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.btn{min-height:40px}.btn--sm{min-height:36px}.input{min-height:44px;font-size:16px}select.input{min-height:44px}.checkbox{width:20px;height:20px}.empty-state{padding:var(--space-8)var(--space-4)}.detail-grid-2col{gap:var(--space-3);grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width:480px){.kpi-grid{grid-template-columns:1fr}.modal{border-radius:0;width:100%;max-width:100%;height:100dvh;max-height:100dvh}.modal__header,.modal__body{padding:var(--space-4)}.modal__footer{padding:var(--space-3)var(--space-4)}.page-content{padding:var(--space-3)}.detail-section{padding:var(--space-3);border-radius:var(--radius-md)}.detail-grid{gap:var(--space-4)}.card__header{padding:var(--space-3)var(--space-4)}.card__body{padding:var(--space-4)}.action-bar{flex-direction:column}.action-bar__left,.action-bar__right{width:100%}.kpi-card__value{font-size:var(--text-xl)}.product-grid{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-base)ease-out}.animate-scale-in{animation:scaleIn var(--transition-base)ease-out}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.inline-select{min-width:120px;position:relative}.inline-select__input{border:1px solid var(--color-border-focus);border-radius:var(--radius-md);background:var(--color-bg-card);width:100%;font-size:var(--text-xs);color:var(--color-text);outline:none;padding:4px 8px;box-shadow:0 0 0 2px #2563eb1a}.inline-select__input::placeholder{color:var(--color-text-muted)}.inline-select__menu{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);max-height:200px;padding:var(--space-1)0;margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.inline-select__menu--portal{z-index:9999;margin-top:0;top:auto;right:auto}.inline-select__option{width:100%;padding:5px var(--space-3);text-align:left;font-size:var(--text-xs);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;background:0 0;border:none;display:block}.inline-select__option:hover,.inline-select__option--highlighted{background:var(--color-bg-hover)}.inline-select__option--selected{color:var(--color-primary);font-weight:var(--font-medium)}.inline-select__empty{padding:6px var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);text-align:center}.custom-select__trigger{width:100%;padding:var(--space-2)var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);text-align:left;justify-content:space-between;align-items:center;gap:var(--space-2);min-height:38px;display:flex}.custom-select__trigger:hover{border-color:var(--color-border-focus)}.custom-select__trigger:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #2563eb26}.custom-select__value{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.custom-select__arrow{opacity:.5;flex-shrink:0;font-size:10px}.custom-select__dropdown{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow:hidden}.custom-select__search{width:100%;padding:var(--space-2)var(--space-3);border:none;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-hover);font-size:var(--text-sm);color:var(--color-text);outline:none}.custom-select__search::placeholder{color:var(--color-text-muted)}.custom-select__menu{max-height:220px;padding:var(--space-1)0;overflow-y:auto}.custom-select__option{width:100%;padding:6px var(--space-3);text-align:left;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;background:0 0;border:none;display:block}.custom-select__option:hover,.custom-select__option--highlighted{background:var(--color-bg-hover)}.custom-select__option--selected{color:var(--color-primary);font-weight:var(--font-medium)}.custom-select__empty{padding:8px var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}.doc-layout{min-height:calc(100vh - 60px);display:flex}.doc-sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border);width:220px;padding:var(--space-4)0;flex-shrink:0;height:calc(100vh - 60px);position:sticky;top:60px;overflow-y:auto}.doc-sidebar__header{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4)var(--space-4);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-2);display:flex}.doc-sidebar__nav{padding:0 var(--space-2);flex-direction:column;gap:2px;display:flex}.doc-sidebar__link{padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);justify-content:space-between;align-items:center;text-decoration:none;display:flex}.doc-sidebar__link:hover{background:var(--color-bg-hover);color:var(--color-text)}.doc-sidebar__link--active{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-medium)}.doc-content{flex:1;min-width:0;overflow-x:hidden}.doc-content .page-content{max-width:960px}.doc-welcome{text-align:center;padding:var(--space-12)0 var(--space-8)}.doc-welcome__icon{color:var(--color-primary);opacity:.7;margin-bottom:var(--space-4)}.doc-welcome h1{font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.doc-welcome__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);max-width:480px;margin:0 auto}.doc-cards{gap:var(--space-4);margin-top:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.doc-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);color:var(--color-text);transition:all var(--transition-base);text-decoration:none;display:block;position:relative}.doc-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.doc-card__title{font-size:var(--text-base);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.doc-card__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.doc-card__arrow{top:var(--space-6);right:var(--space-6);color:var(--color-primary);font-size:var(--text-lg);opacity:0;transition:all var(--transition-base);position:absolute;transform:translate(-4px)}.doc-card:hover .doc-card__arrow{opacity:1;transform:translate(0)}.doc-page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.doc-page-subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.doc-section{margin-bottom:var(--space-10);padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border-light)}.doc-section:last-child{border-bottom:none}.doc-section h2{font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-6);padding-bottom:var(--space-2);border-bottom:2px solid var(--color-primary);display:inline-block}.doc-section h3{font-size:var(--text-base);font-weight:var(--font-semibold);margin:var(--space-6)0 var(--space-3);color:var(--color-text-secondary)}.doc-mermaid-wrapper{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-4);overflow-x:auto}.doc-mermaid-wrapper .mermaid{justify-content:center;display:flex}.doc-mermaid-wrapper .mermaid svg{max-width:100%;height:auto}.doc-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);overflow:hidden}.doc-table-wrapper .table th{position:static}.doc-table-wrapper .table td{white-space:normal}.doc-row-editable td{background:#2563eb0a}.doc-cell-yes{color:var(--color-success);font-weight:var(--font-semibold)}.doc-cell-hidden{color:var(--color-text-muted);font-style:italic}.doc-rules{padding-left:var(--space-6);list-style-type:disc}.doc-rules li{margin-bottom:var(--space-3);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text)}.doc-rules li strong{color:var(--color-text)}.doc-rules li code{background:var(--color-bg-hover);padding:1px var(--space-1);font-size:var(--text-xs);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--color-primary)}.doc-legend{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}@media (max-width:768px){.doc-layout{flex-direction:column}.doc-sidebar{border-right:none;border-bottom:1px solid var(--color-border);width:100%;height:auto;position:static}.doc-sidebar__nav{padding:0 var(--space-3);gap:var(--space-1);flex-direction:row;overflow-x:auto}.doc-sidebar__link{white-space:nowrap}.doc-content .page-content{padding:var(--space-4)}}
