@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap";:root{--primary-50:#faf5ff;--primary-100:#f3e8ff;--primary-200:#e9d5ff;--primary-300:#d8b4fe;--primary-400:#c084fc;--primary-500:#a855f7;--primary-600:#9333ea;--primary-700:#7e22ce;--primary-800:#6b21a8;--primary-900:#581c87;--accent-400:#e879f9;--accent-500:#d946ef;--accent-600:#c026d3;--surface-0:#09090b;--surface-50:#0f0f13;--surface-100:#18181b;--surface-200:#1e1e24;--surface-300:#27272a;--surface-400:#3f3f46;--surface-500:#52525b;--surface-600:#71717a;--surface-700:#a1a1aa;--surface-800:#d4d4d8;--surface-900:#e4e4e7;--surface-950:#fafafa;--success-500:#22c55e;--success-600:#16a34a;--warning-500:#f59e0b;--warning-600:#d97706;--danger-500:#ef4444;--danger-600:#dc2626;--info-500:#3b82f6;--info-600:#2563eb;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;--font-display:"Plus Jakarta Sans",var(--font-sans);--text-xs:.75rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.0625rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--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-2xl:1.25rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 6px -1px rgba(0,0,0,.4),0 2px 4px -2px rgba(0,0,0,.3);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.5),0 4px 6px -4px rgba(0,0,0,.4);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.5),0 8px 10px -6px rgba(0,0,0,.4);--shadow-glow:0 0 20px rgba(168,85,247,.15);--shadow-glow-strong:0 0 30px rgba(168,85,247,.3);--glass-bg:rgba(24,24,27,.75);--glass-border:rgba(63,63,70,.5);--glass-blur:12px;--ease-out:cubic-bezier(.16,1,.3,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--header-height:56px;--bottom-nav-height:68px;--sidebar-width:260px;--max-content-width:1200px;--safe-area-bottom:env(safe-area-inset-bottom,0px)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--surface-900);background-color:var(--surface-0);min-height:100dvh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface-100)}::-webkit-scrollbar-thumb{background:var(--surface-400);border-radius:var(--radius-full)}::-moz-selection{background:var(--primary-600);color:#fff}::selection{background:var(--primary-600);color:#fff}a{color:var(--primary-400);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--primary-300)}img{max-width:100%;height:auto;display:block}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:var(--leading-tight);color:var(--surface-950)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--surface-700);line-height:var(--leading-relaxed)}.glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.gradient-primary{background:linear-gradient(135deg,var(--primary-600),var(--accent-500))}.gradient-dark{background:linear-gradient(180deg,var(--surface-50) 0,var(--surface-0) 100%)}.page-container{padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-4));max-width:var(--max-content-width);margin:0 auto}.page-header{margin-bottom:var(--space-6)}.page-title{font-size:var(--text-2xl);font-weight:800;background:linear-gradient(135deg,var(--surface-950),var(--primary-300));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:var(--text-sm);color:var(--surface-600);margin-top:var(--space-2);max-width:48rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.animate-scale-in{animation:scaleIn var(--duration-normal) var(--ease-out) both}.skeleton{background:var(--surface-200);border-radius:var(--radius-md);animation:skeleton-pulse 2s ease-in-out infinite}.stagger-children>*{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}@media(min-width:640px){:root{--text-base:1rem}.page-container{padding:var(--space-6);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-6))}.page-header{margin-bottom:var(--space-8)}}@media(min-width:1024px){.page-container{padding-left:calc(var(--sidebar-width) + var(--space-8));padding-bottom:var(--space-8)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;line-height:1;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);min-height:48px;white-space:nowrap;-moz-user-select:none;user-select:none;-webkit-user-select:none;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--accent-500));color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg),var(--shadow-glow-strong);transform:translateY(-1px)}.btn-secondary{background:var(--surface-200);color:var(--surface-900);border:1px solid var(--surface-300)}.btn-secondary:hover:not(:disabled){background:var(--surface-300)}.btn-danger{background:linear-gradient(135deg,var(--danger-600),var(--danger-500));color:#fff}.btn-ghost{background:transparent;color:var(--surface-700)}.btn-ghost:hover:not(:disabled){background:var(--surface-200);color:var(--surface-900)}.btn-sm{min-height:36px;padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{min-height:56px;padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.btn-block{width:100%}.btn-icon{min-height:44px;min-width:44px;padding:var(--space-2);border-radius:var(--radius-xl)}.btn .spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin .6s linear infinite}.card{background:var(--surface-100);border:1px solid var(--surface-300);border-radius:var(--radius-xl);padding:var(--space-4);transition:all var(--duration-normal) var(--ease-out)}.card:hover{border-color:var(--surface-400)}.card-glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-4)}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow);border-color:var(--primary-700)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--surface-800);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);color:var(--surface-950);background:var(--surface-100);border:1px solid var(--surface-300);border-radius:var(--radius-lg);min-height:48px;transition:all var(--duration-fast) var(--ease-out);outline:none}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #a855f726}.form-input::-moz-placeholder{color:var(--surface-500)}.form-input::placeholder{color:var(--surface-500)}.form-input:disabled{color:var(--surface-500);background:var(--surface-50);border-color:var(--surface-200);cursor:not-allowed;opacity:.7}.form-input.error{border-color:var(--danger-500)}.form-error{font-size:var(--text-xs);color:var(--danger-500);margin-top:var(--space-1)}.form-select{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);color:var(--surface-950);background:var(--surface-100);border:1px solid var(--surface-300);border-radius:var(--radius-lg);min-height:48px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2371717a' viewBox='0 0 16 16'%3E%3Cpath d='m4.646 6.354 3 3a.5.5 0 0 0 .708 0l3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;outline:none;transition:all var(--duration-fast) var(--ease-out)}.form-select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #a855f726}textarea.form-input{min-height:100px;resize:vertical}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);line-height:1}.badge-success{background:#22c55e26;color:var(--success-500)}.badge-warning{background:#f59e0b26;color:var(--warning-500)}.badge-danger{background:#ef444426;color:var(--danger-500)}.badge-info{background:#3b82f626;color:var(--info-500)}.badge-primary{background:#a855f726;color:var(--primary-400)}.badge-neutral{background:var(--surface-200);color:var(--surface-700)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn var(--duration-fast) var(--ease-out)}.modal-content{background:var(--surface-100);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp var(--duration-normal) var(--ease-out);padding:var(--space-6);padding-bottom:calc(var(--space-6) + var(--safe-area-bottom))}.modal-handle{width:36px;height:4px;background:var(--surface-400);border-radius:var(--radius-full);margin:0 auto var(--space-4)}.modal-title{font-size:var(--text-xl);font-weight:700;color:var(--surface-950);margin-bottom:var(--space-4)}@media(min-width:640px){.modal-overlay{align-items:center}.modal-content{border-radius:var(--radius-2xl);max-height:80vh}}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);display:flex;align-items:center;padding:0 var(--space-4);z-index:50;background:#09090bd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--surface-200)}.app-header-title{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;background:linear-gradient(135deg,#c026d3,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header-brand{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.app-brand-mark{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.app-brand-mark svg{width:100%;height:100%}.app-brand-copy{min-width:0}.app-header-meta{margin-top:2px;font-size:11px;color:var(--surface-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header-actions{display:flex;align-items:center;gap:var(--space-2)}.app-role-chip{display:flex;align-items:center;gap:6px}.app-role-dot{width:8px;height:8px;border-radius:999px;background:var(--success-500);box-shadow:0 0 0 4px #22c55e14}.header-menu{position:relative}.header-menu-trigger{min-height:40px;padding-inline:var(--space-3);border-radius:var(--radius-full);border:1px solid var(--surface-300);background:#18181be6;color:var(--surface-900)}.header-menu-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:220px;padding:var(--space-2);border-radius:var(--radius-xl);border:1px solid var(--surface-300);background:#18181bf5;box-shadow:var(--shadow-xl);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.header-menu-section{display:flex;flex-direction:column;gap:2px}.header-menu-label{padding:var(--space-2) var(--space-3) var(--space-1);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--surface-600)}.header-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;min-height:44px;padding:0 var(--space-3);border:none;border-radius:var(--radius-lg);background:none;color:var(--surface-800);text-decoration:none;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.header-menu-item.active,.header-menu-item:hover{background:#a855f71f;color:var(--surface-950)}.header-menu-item.danger:hover{background:#ef444424;color:#fecaca}.header-menu-divider{height:1px;margin:var(--space-2) 0;background:var(--surface-300)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);justify-content:space-around;z-index:50;background:#09090beb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--surface-200)}.bottom-nav,.bottom-nav-item{display:flex;align-items:center}.bottom-nav-item{flex-direction:column;gap:2px;padding:var(--space-2);color:var(--surface-600);font-size:10px;font-weight:500;text-decoration:none;transition:color var(--duration-fast) var(--ease-out);min-width:56px;cursor:pointer;background:none;border:none}.bottom-nav-item.active{color:var(--primary-400)}.bottom-nav-item svg{width:22px;height:22px}.sidebar{display:none;position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--surface-50);border-right:1px solid var(--surface-200);padding:var(--space-4);overflow-y:auto;z-index:40}.sidebar-panel{padding:var(--space-4);margin-bottom:var(--space-4);border-radius:var(--radius-xl);background:radial-gradient(circle at top right,rgba(217,119,6,.22),transparent 40%),linear-gradient(180deg,#a855f729,#18181beb);border:1px solid rgba(168,85,247,.18)}.sidebar-kicker{margin-bottom:6px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--surface-600)}.sidebar-title{margin-bottom:6px;font-family:var(--font-display);font-size:var(--text-lg);color:var(--surface-950)}.sidebar-copy{font-size:var(--text-xs);color:var(--surface-700);line-height:1.6}.sidebar-nav{gap:var(--space-4)}.sidebar-group,.sidebar-nav{display:flex;flex-direction:column}.sidebar-group-label{padding:0 var(--space-4);margin-bottom:var(--space-2);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--surface-600)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--surface-700);font-size:var(--text-sm);font-weight:500;text-decoration:none;transition:all var(--duration-fast) var(--ease-out);margin-bottom:var(--space-1)}.sidebar-item:hover{background:var(--surface-200);color:var(--surface-900)}.sidebar-item.active{background:#a855f71a;color:var(--primary-400)}.sidebar-item svg{width:20px;height:20px;flex-shrink:0}@media(min-width:1024px){.sidebar{display:block}.bottom-nav{display:none}}.panel-section{position:relative;overflow:hidden}.panel-section-compact{padding:14px}.panel-section:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,rgba(217,119,6,.75),rgba(168,85,247,.2),transparent 70%)}.panel-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:14px}.panel-section-compact .panel-section-head{margin-bottom:10px;gap:10px}.panel-eyebrow{margin-bottom:6px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--warning-500)}.panel-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--surface-950)}.panel-copy{margin-top:4px;font-size:var(--text-xs);color:var(--surface-600)}.compact-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.dashboard-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:16px}.panel-section-compact .dashboard-filter-grid{margin-top:10px;gap:8px}.dashboard-period-panel{padding:12px}.dashboard-period-head{align-items:center;margin-bottom:8px;flex-wrap:nowrap}.dashboard-period-presets{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;background:var(--surface-200);border:1px solid var(--surface-300)}.dashboard-preset-btn{border:none;background:transparent;color:var(--surface-700);font-family:var(--font-sans);font-size:11px;font-weight:700;line-height:1;padding:8px 10px;border-radius:999px;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.dashboard-preset-btn:hover{color:var(--surface-950)}.dashboard-preset-btn.active{background:#a855f729;color:var(--primary-400);box-shadow:inset 0 0 0 1px #a855f73d}.dashboard-summary-grid{gap:8px}.dashboard-summary-grid .card{padding:12px}.dashboard-summary-grid .summary-card-label{margin-bottom:6px;font-size:11px;color:var(--surface-600)}.dashboard-summary-grid .summary-card-value{font-size:var(--text-base);line-height:1.15}.dashboard-chart-wrap{height:160px}.dashboard-panel-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;min-width:0}.dashboard-panel-meta .panel-eyebrow{margin-bottom:0;flex-shrink:0}.dashboard-title-chip{display:inline-flex;align-items:center;min-height:22px;padding:3px 7px;border-radius:999px;background:#ffffff0a;border:1px solid hsla(0,0%,100%,.08);color:var(--surface-950);font-size:11px;font-weight:500;line-height:1;margin-left:auto;flex-shrink:0}.dashboard-split-grid{display:grid;grid-template-columns:1fr;gap:12px}.dashboard-list-item-compact{gap:10px;padding:6px 0}.dashboard-list-item-compact .badge{font-size:10px;padding:4px 8px}@media(max-width:389px){.dashboard-filter-grid{grid-template-columns:1fr}.dashboard-period-head{align-items:flex-start;flex-wrap:wrap}.dashboard-period-presets{width:100%;justify-content:space-between}.dashboard-preset-btn{flex:1;text-align:center;padding:8px 6px}.products-page-header{align-items:stretch}.products-page-header .btn{align-self:flex-start}.products-page-actions{flex-wrap:wrap;justify-content:flex-end}}@media(min-width:640px){.dashboard-chart-wrap{height:176px}.dashboard-split-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.search-bar{position:relative;width:100%}.search-bar input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) 44px;font-family:var(--font-sans);font-size:var(--text-base);color:var(--surface-950);background:var(--surface-100);border:1px solid var(--surface-300);border-radius:var(--radius-xl);min-height:48px;outline:none;transition:all var(--duration-fast) var(--ease-out)}.search-bar input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #a855f71a}.search-bar .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--surface-500)}.toast-container{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;flex-direction:column;pointer-events:none}.toast{height:var(--header-height);padding:0 var(--space-4);border-radius:0;font-size:var(--text-xs);font-weight:600;animation:fadeInDown var(--duration-normal) var(--ease-out);pointer-events:auto;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.toast-success{color:#1a1a1a}.toast-error,.toast-success{background:#fffffff7}.toast-error{color:#b91c1c}.toast-info{background:#fffffff7;color:#1a1a1a}@keyframes fadeInDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-4);text-align:center}.empty-state svg{width:64px;height:64px;color:var(--surface-400);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--surface-700);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--text-sm);color:var(--surface-500);max-width:280px}.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.products-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.products-filter-bar{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.products-search-bar{position:relative;display:flex;align-items:center}.products-search-bar .search-icon{position:absolute;left:12px;width:16px;height:16px;color:var(--surface-400);pointer-events:none}.products-search-bar input{width:100%;min-height:42px;padding:0 12px 0 38px;border:1px solid var(--surface-200);border-radius:var(--radius-md);background:var(--surface-100);color:var(--text-primary);font-size:var(--text-sm);transition:border-color .15s}.products-search-bar input:focus{outline:none;border-color:var(--primary)}.products-filter-selects{display:grid;grid-template-columns:1fr 1fr;gap:8px}.products-filter-selects .form-select{min-height:40px;font-size:var(--text-sm)}.product-grid-compact{gap:10px}.product-card{background:linear-gradient(180deg,hsla(0,0%,100%,.01),transparent 28%),var(--surface-100)}.product-card-media{aspect-ratio:.92;background:radial-gradient(circle at top,rgba(217,119,6,.15),transparent 35%),var(--surface-200);display:flex;align-items:center;justify-content:center;overflow:hidden}.product-card-body{padding:10px}.product-card-title{margin-bottom:4px;font-size:var(--text-sm);font-weight:700;color:var(--surface-950);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card-code{margin-top:1px;margin-bottom:8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--surface-500)}.product-card-meta{display:flex;justify-content:space-between;align-items:center;gap:6px}.product-card-category{font-size:11px;color:var(--surface-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card-stats{display:flex;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid rgba(63,63,70,.55);font-size:11px;gap:8px}.product-card-skeleton{overflow:hidden;padding:0}.product-card-skeleton-media{height:128px;margin-bottom:0}.products-page-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.products-stock-list{display:flex;flex-direction:column;gap:8px}.products-stock-item{background:var(--surface-50);border:1px solid var(--surface-200);border-radius:var(--radius-xl);overflow:hidden}.products-stock-item-header{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s ease}.products-stock-item-header:active{background:#a855f70f}.products-stock-item-thumb{width:36px;height:36px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--surface-100)}.products-stock-item-info{flex:1;min-width:0}.products-stock-item-name{font-size:var(--text-sm);font-weight:600;color:var(--surface-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.products-stock-item-meta{display:flex;gap:8px;font-size:11px;color:var(--surface-500);margin-top:2px}.products-stock-item-pending{color:var(--primary-500);font-weight:600}.products-stock-item-chevron{flex-shrink:0;color:var(--surface-400);transition:transform .2s ease}.products-stock-item-chevron-open{transform:rotate(180deg)}.products-stock-variants{border-top:1px solid var(--surface-200);padding:4px 0}.products-stock-variant-row{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 8px 58px;cursor:pointer;transition:background .12s ease}.products-stock-variant-row:active{background:#a855f714}.products-stock-variant-name{font-size:var(--text-sm);color:var(--surface-800)}.products-stock-variant-side{position:relative;display:flex;align-items:center;gap:6px}.product-stock-badge-sm{padding:3px 8px;border-radius:var(--radius-md);min-width:unset}.product-stock-badge-sm strong{font-size:13px}.product-detail-header{display:flex;flex-direction:column;gap:8px;position:relative;z-index:20}.product-detail-back{align-self:flex-start}.product-detail-head-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.product-detail-main{display:flex;align-items:flex-start;gap:12px;min-width:0;flex:1}.product-detail-copy{min-width:0;display:flex;flex-direction:column}.product-detail-thumb{width:84px;aspect-ratio:1/1;border-radius:var(--radius-xl);overflow:hidden;background:var(--surface-200);flex-shrink:0;display:flex;align-items:center;justify-content:center}.product-detail-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.product-detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.product-detail-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.product-detail-menu{margin-left:auto;z-index:30}.product-detail-menu-trigger{min-width:40px;min-height:40px;padding-inline:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.product-detail-menu-trigger svg{color:var(--surface-800)}.product-detail-description{padding:0;margin-bottom:12px;border-top:1px solid var(--surface-200);border-bottom:1px solid var(--surface-200)}.product-detail-description-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer}.product-detail-description-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--surface-500)}.product-detail-description-chevron{transition:transform .2s ease;color:var(--surface-400)}.product-detail-description-chevron-open{transform:rotate(180deg)}.product-detail-description-text{font-size:var(--text-sm);color:var(--surface-700);padding-bottom:10px;line-height:1.5}.product-variants-section{margin-top:4px}.product-variants-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.product-variants-title{display:flex;align-items:center;gap:8px;margin:6px 0 0;font-size:var(--text-lg);color:var(--surface-950)}.product-variants-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.product-stock-mode-banner{display:flex;flex-direction:column;gap:10px;margin-bottom:10px;padding:12px 14px;border:1px solid rgba(168,85,247,.28);border-radius:var(--radius-xl);background:#a855f714;color:var(--surface-900)}.product-stock-mode-banner>div:first-child{display:flex;flex-direction:column;gap:4px}.product-stock-mode-banner strong{font-size:var(--text-sm);display:block}.product-stock-mode-banner>div:first-child>span{font-size:var(--text-xs);color:var(--surface-400);display:block}.product-stock-pending-summary{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid rgba(168,85,247,.18)}.product-stock-pending-summary .btn-primary{color:#fff}.product-stock-pending-count{font-size:var(--text-xs);font-weight:600;color:var(--primary-400);margin-right:auto}.product-stock-pending-badge{position:absolute;top:-6px;right:-6px;min-width:22px;height:20px;padding:0 5px;border-radius:999px;background:var(--primary-500);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 1px 4px #00000026;z-index:2}.product-variant-list{display:flex;flex-direction:column;gap:8px}.product-variant-card{display:flex;gap:10px;align-items:center;padding:12px}.product-variant-card-selectable{cursor:pointer;border-color:#a855f738;box-shadow:0 0 0 1px #a855f714}.product-variant-card-selectable .product-stock-badge,.product-variant-card-selectable .product-variant-content,.product-variant-card-selectable .product-variant-thumb{transition:transform .14s ease,border-color .14s ease,background .14s ease,opacity .14s ease}.product-variant-card-selectable:active,.product-variant-card-selectable:hover{border-color:#a855f761;background:#a855f70d}.product-variant-card-selectable:active .product-variant-thumb,.product-variant-card-selectable:hover .product-variant-thumb{transform:scale(1.02)}.product-variant-card-selectable:active{transform:scale(.995)}.product-variant-thumb{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--surface-200);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.product-variant-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.product-variant-name{font-weight:600;color:var(--surface-950);font-size:15px;line-height:1.1}.product-variant-sku{margin-top:4px;font-size:12px;color:var(--surface-600)}.product-variant-price{margin-top:8px}.product-variant-side{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-left:auto;flex-shrink:0}.product-stock-badge{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;min-width:52px;min-height:40px;padding:5px 8px;border-radius:12px;border:1px solid transparent;line-height:1;flex-shrink:0}.product-stock-badge strong{font-size:14px;font-weight:800}.product-stock-badge small{margin-top:2px;font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.product-stock-badge-success{background:#22c55e24;border-color:#22c55e3d;color:var(--success-500)}.product-stock-badge-warning{background:#f59e0b24;border-color:#f59e0b3d;color:var(--warning-500)}.product-stock-badge-danger{background:#ef444424;border-color:#ef44443d;color:var(--danger-500)}.product-variant-menu{display:inline-flex;flex-shrink:0}.product-variant-pick-indicator{min-width:54px;padding:8px 10px;border-radius:999px;background:#a855f71f;border:1px solid rgba(168,85,247,.24);color:var(--primary-400);font-size:11px;font-weight:600;letter-spacing:.03em;text-align:center}.product-variant-menu-trigger{min-width:32px;min-height:32px;padding-inline:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.product-variant-menu-trigger svg{color:var(--surface-800)}.product-action-sheet{max-width:420px}.product-action-sheet-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.product-action-sheet-delete{min-width:40px;min-height:40px;padding-inline:0;border-radius:var(--radius-full);color:var(--danger-500)}.product-action-sheet-delete:hover{background:#ef44441f;color:var(--danger-500)}.product-action-sheet-meta{display:flex;flex-direction:column;gap:4px;margin-top:8px;margin-bottom:14px;font-size:var(--text-sm);color:var(--surface-600)}.product-action-sheet-product{color:var(--surface-950);font-weight:600}.product-action-sheet-actions{display:flex;flex-direction:column;gap:8px}.product-stock-inline-stepper{display:grid;grid-template-columns:48px 1fr 48px;gap:8px;align-items:center;margin-bottom:8px}.product-stock-inline-input{text-align:center;font-size:var(--text-lg);font-weight:700}.product-stock-inline-helper{margin-bottom:12px;font-size:var(--text-xs);color:var(--surface-600)}.product-variant-bulk-note{display:flex;flex-direction:column;gap:4px;margin-bottom:14px;padding:12px;border-radius:var(--radius-xl);border:1px solid rgba(63,63,70,.65);background:#27272aa6}.product-variant-bulk-note strong{font-size:var(--text-sm);color:var(--surface-900)}.product-variant-bulk-note span{font-size:var(--text-xs);color:var(--surface-600)}@media(min-width:640px){.product-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-4)}}@media(min-width:1024px){.product-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:389px){.product-detail-main{width:100%;align-items:flex-start}.product-detail-thumb{width:72px}.product-detail-actions,.product-variants-actions{width:100%}.product-detail-menu{margin-left:0}.product-detail-actions .btn,.product-variants-actions .btn{flex:1}.product-variant-card{padding:12px}.product-variant-name{font-size:14px}}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.summary-grid-compact{gap:10px}.summary-grid-rich .card{background:radial-gradient(circle at top right,rgba(217,119,6,.12),transparent 35%),linear-gradient(180deg,hsla(0,0%,100%,.02),transparent),var(--surface-100)}.summary-card-kicker{margin-bottom:8px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--surface-600)}.summary-grid-compact .card{padding:14px}.summary-grid-compact .summary-card-kicker{margin-bottom:6px}.summary-grid-compact .summary-card-label{margin-bottom:4px;font-size:var(--text-xs)}.summary-grid-compact .summary-card-value{font-size:var(--text-lg)}.dashboard-list-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--surface-200)}.dashboard-list-item:last-child{border-bottom:none;padding-bottom:0}.summary-card-label{margin-bottom:6px;font-size:var(--text-sm);color:var(--surface-700)}.summary-card-value{font-size:var(--text-xl);font-weight:800;color:var(--surface-950)}@media(min-width:640px){.summary-grid{grid-template-columns:repeat(4,1fr)}}.qty-stepper{display:flex;align-items:center;gap:0;border:1px solid var(--surface-300);border-radius:var(--radius-lg);overflow:hidden}.qty-stepper button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--surface-200);border:none;color:var(--surface-900);font-size:var(--text-lg);cursor:pointer;transition:background var(--duration-fast)}.qty-stepper button:hover{background:var(--surface-300)}.qty-stepper input{width:56px;height:44px;text-align:center;border:none;background:var(--surface-100);color:var(--surface-950);font-family:var(--font-sans);font-size:var(--text-base);font-weight:600;outline:none}.spacer-header{height:var(--header-height)}.divider{height:1px;margin:var(--space-4) 0}.chip,.divider{background:var(--surface-200)}.chip{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);color:var(--surface-700);border:1px solid var(--surface-300);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.chip.active{background:#a855f726;color:var(--primary-400);border-color:var(--primary-700)}.chip:hover{border-color:var(--surface-400)}.price{font-family:var(--font-display);font-weight:700;color:var(--primary-400)}.price-sm{font-size:var(--text-sm)}.price-lg{font-size:var(--text-xl)}.stock-in{color:var(--success-500)}.stock-low{color:var(--warning-500)}.stock-out{color:var(--danger-500)}.image-upload{position:relative;width:100%;aspect-ratio:1;border:2px dashed var(--surface-300);border-radius:var(--radius-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);overflow:hidden;background:var(--surface-100)}.image-upload:hover{border-color:var(--primary-500);background:#a855f70d}.image-upload img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.image-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}.image-upload-icon{width:32px;height:32px;color:var(--surface-500);margin-bottom:var(--space-2)}.image-upload-text{font-size:var(--text-xs);color:var(--surface-500)}.fab-add{position:fixed;bottom:calc(84px + var(--safe-area-bottom, 0px));right:20px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #a855f766,0 2px 6px #0003;z-index:50;text-decoration:none;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.fab-add:active{transform:scale(.92)}.fab-add:hover{box-shadow:0 6px 20px #a855f780,0 3px 8px #00000040;transform:translateY(-2px)}.catalog-variant-divider{display:flex;align-items:center;gap:14px;margin:14px 0 6px}.catalog-variant-divider:after,.catalog-variant-divider:before{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--surface-300),transparent)}.catalog-variant-divider span{font-size:var(--text-sm);font-weight:700;color:var(--surface-950);letter-spacing:.02em;white-space:nowrap}.app-loading{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#09090b;z-index:9999}.app-loading-content{display:flex;flex-direction:column;align-items:center;gap:16px}.app-loading-spinner{width:36px;height:36px;border:3px solid hsla(0,0%,100%,.1);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.app-loading-text{color:#fff9;font-size:14px;margin:0}@keyframes spin{to{transform:rotate(1turn)}}.error-page[data-v-6907de39]{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--surface-0)}.error-content[data-v-6907de39]{text-align:center;max-width:320px}.error-code[data-v-6907de39]{font-size:64px;font-weight:900;color:var(--surface-300);line-height:1;margin-bottom:8px}.error-title[data-v-6907de39]{font-size:var(--text-xl);font-weight:700;color:var(--surface-950);margin-bottom:8px}.error-desc[data-v-6907de39]{font-size:var(--text-sm);color:var(--surface-600);margin-bottom:24px}
