*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-soft: #dbeafe;--success: #16a34a;--success-soft: #dcfce7;--danger: #dc2626;--danger-soft: #fee2e2;--warning: #d97706;--warning-soft: #fef3c7;--info: #0ea5e9;--info-soft: #e0f2fe;--bg: #f8fafc;--surface: #ffffff;--surface-muted: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--text-subtle: #94a3b8;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 8px 22px rgba(15,23,42,.1);--focus-ring: rgba(37, 99, 235, .32);--badge-green-bg: #dcfce7;--badge-green-text: #15803d;--badge-red-bg: #fee2e2;--badge-red-text: #b91c1c;--badge-yellow-bg: #fef9c3;--badge-yellow-text: #b45309;--badge-gray-bg: #f1f5f9;--badge-gray-text: #64748b;--badge-blue-bg: #dbeafe;--badge-blue-text: #1d4ed8;--skeleton-start: #e2e8f0;--skeleton-middle: #f1f5f9;--skeleton-end: #e2e8f0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--text-xs: .72rem;--text-sm: .84rem;--text-md: .95rem;--text-lg: 1.1rem;--text-xl: 1.35rem}[data-theme=dark]{--primary: #3b82f6;--primary-dark: #2563eb;--primary-soft: rgba(59, 130, 246, .18);--success: #22c55e;--success-soft: rgba(34, 197, 94, .18);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .2);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .2);--info: #38bdf8;--info-soft: rgba(56, 189, 248, .2);--bg: #020617;--surface: #0f172a;--surface-muted: #1e293b;--border: #334155;--text: #e2e8f0;--text-muted: #94a3b8;--text-subtle: #64748b;--shadow: 0 1px 2px rgba(2, 6, 23, .45), 0 8px 20px rgba(2, 6, 23, .35);--shadow-lg: 0 16px 28px rgba(2, 6, 23, .45);--focus-ring: rgba(59, 130, 246, .4);--badge-green-bg: rgba(34, 197, 94, .2);--badge-green-text: #86efac;--badge-red-bg: rgba(239, 68, 68, .24);--badge-red-text: #fca5a5;--badge-yellow-bg: rgba(245, 158, 11, .24);--badge-yellow-text: #fcd34d;--badge-gray-bg: rgba(148, 163, 184, .2);--badge-gray-text: #cbd5e1;--badge-blue-bg: rgba(59, 130, 246, .24);--badge-blue-text: #bfdbfe;--skeleton-start: #1e293b;--skeleton-middle: #334155;--skeleton-end: #1e293b}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:16px}#root{min-height:100%;display:flex;flex-direction:column}button{cursor:pointer;border:none;background:none;font:inherit}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--primary);outline-offset:2px;box-shadow:0 0 0 2px var(--focus-ring)}input,textarea,select{font:inherit;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;width:100%;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--primary)}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;transition:background .15s,opacity .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.btn:disabled{opacity:.5;pointer-events:none}.btn-full{width:100%}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card-muted{background:var(--surface-muted);box-shadow:none;border:1px solid var(--border)}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:600}.badge-green{background:var(--badge-green-bg);color:var(--badge-green-text)}.badge-red{background:var(--badge-red-bg);color:var(--badge-red-text)}.badge-yellow{background:var(--badge-yellow-bg);color:var(--badge-yellow-text)}.badge-gray{background:var(--badge-gray-bg);color:var(--badge-gray-text)}.badge-blue{background:var(--badge-blue-bg);color:var(--badge-blue-text)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.form-error{color:var(--danger);font-size:.8rem;margin-top:4px}.form-help{font-size:var(--text-xs);color:var(--text-muted)}.page{flex:1;padding:16px 16px 80px;max-width:600px;margin:0 auto;width:100%}.page-title{font-size:1.3rem;font-weight:700;margin-bottom:16px}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:-8px;margin-bottom:16px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-3)}.section-title{font-size:var(--text-sm);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.stack-sm{display:flex;flex-direction:column;gap:var(--space-2)}.row{display:flex;align-items:center;gap:var(--space-2)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2);margin-bottom:var(--space-3)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-2);min-height:84px}.stat-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:600;margin-bottom:2px}.stat-value{font-size:var(--text-lg);font-weight:800;line-height:1.2}.stat-note{font-size:var(--text-xs);color:var(--text-subtle);margin-top:2px}.chip-row{display:flex;align-items:center;gap:var(--space-2);overflow-x:auto;padding-bottom:2px;margin-bottom:var(--space-3)}.filter-chip{white-space:nowrap;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:999px;font-size:var(--text-xs);font-weight:700;padding:6px 10px}.filter-chip.active{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.sticky-action{position:sticky;bottom:72px;z-index:20;margin-bottom:var(--space-3)}.list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.list-card-content{padding:12px 14px}.list-title{font-weight:700;font-size:var(--text-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.22;max-height:2.44em}.list-title-compact{white-space:nowrap;display:block;overflow:hidden;text-overflow:ellipsis}.list-meta{color:var(--text-muted);font-size:var(--text-xs);margin-top:2px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:stretch;height:calc(62px + env(safe-area-inset-bottom));z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav a{display:flex;flex:1 1 0;min-width:0;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:.66rem;font-weight:600;color:var(--text-muted);padding:6px 8px 4px;border-radius:8px;transition:color .15s}.bottom-nav a.active,.bottom-nav a:hover{color:var(--primary)}.bottom-nav-label{display:block;width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.price-current{font-size:1.5rem;font-weight:700;color:var(--text)}.price-original{font-size:.9rem;color:var(--text-muted);text-decoration:line-through}.price-discount{font-size:.8rem;font-weight:700;color:var(--success)}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 16px;color:var(--text-muted)}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state .empty-title{margin-top:8px;font-weight:700;color:var(--text)}.empty-state .empty-copy{margin-top:4px;font-size:var(--text-sm)}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--skeleton-start) 0%,var(--skeleton-middle) 50%,var(--skeleton-end) 100%);background-size:200% 100%;animation:pulse 1.2s linear infinite}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.search-group-header{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;cursor:pointer;-webkit-user-select:none;user-select:none}.search-group-main{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.search-group-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.icon-button{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0;transition:color .15s,background .15s}.icon-button:hover{background:var(--surface-muted)}.admin-stat-card{width:100%;text-align:left;cursor:pointer;transition:border-color .15s,transform .15s}.admin-stat-card:hover{border-color:var(--primary);transform:translateY(-1px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617a3;z-index:220;display:flex;align-items:flex-end;justify-content:center;padding:12px}.modal-card{width:min(680px,100%);max-height:min(86vh,860px);overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:14px}@media(max-width:430px){.search-group-header{flex-wrap:wrap}.search-group-actions{width:100%;justify-content:flex-end;padding-left:54px}.modal-backdrop{padding:8px}.modal-card{max-height:90vh;padding:12px;border-radius:14px}}@media(max-width:360px){.bottom-nav a{font-size:.62rem;padding-inline:5px}}
