*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--surface: #1a1a2e;--surface2: #252540;--border: #2a2a4a;--text: #e2e8f0;--muted: #94a3b8;--accent: #7c3aed;--accent2: #2563eb;--success: #059669;--danger: #dc2626;--warn: #f59e0b;--sidebar-w: 220px;--sidebar-collapsed: 56px}body{background:var(--bg);color:var(--text);font-family:system-ui,sans-serif;font-size:14px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s;flex-shrink:0}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 12px;border-bottom:1px solid var(--border);min-height:56px}.logo{font-weight:700;font-size:15px;color:var(--accent);white-space:nowrap;overflow:hidden}.collapse-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:4px;border-radius:4px}.collapse-btn:hover{color:var(--text);background:var(--surface2)}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;text-decoration:none;color:var(--muted);transition:all .15s;white-space:nowrap;overflow:hidden}.nav-item:hover{color:var(--text);background:var(--surface2)}.nav-item.active{color:var(--accent);background:#7c3aed1f;border-right:3px solid var(--accent)}.nav-icon{font-size:18px;flex-shrink:0}.nav-label{font-size:13px}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.user-info{display:flex;align-items:center;gap:8px;margin-bottom:8px;overflow:hidden}.user-name{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:2px}.logout-btn{width:100%;padding:7px;background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:6px;cursor:pointer;font-size:12px}.logout-btn:hover{color:var(--danger);border-color:var(--danger)}.main-content{flex:1;overflow-y:auto;background:var(--bg)}.role-badge{display:inline-block;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:600}.role-badge.admin{background:#7c3aed33;color:#a78bfa}.role-badge.user{background:#2563eb33;color:#93c5fd}.page{padding:28px 32px;width:100%;box-sizing:border-box}.page-title{font-size:22px;font-weight:700;margin-bottom:24px}.page-loading{padding:40px;text-align:center;color:var(--muted)}.section-title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-top:3px solid;border-radius:10px;padding:16px}.stat-label{font-size:12px;color:var(--muted);margin-bottom:6px}.stat-value{font-size:24px;font-weight:700}.stat-sub{font-size:11px;color:var(--muted);margin-top:4px}.cabinet-section{margin-bottom:32px}.charts{display:flex;flex-direction:column;gap:24px}.chart-block{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.chart-title{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--muted)}.filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.select{padding:8px 12px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;font-size:13px;cursor:pointer}.select:focus{outline:none;border-color:var(--accent)}.tab-btn{padding:8px 20px;background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:8px;cursor:pointer;font-size:13px}.tab-btn:hover{color:var(--text)}.tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sku-info{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.sku-badge{background:var(--surface2);border:1px solid var(--border);padding:4px 10px;border-radius:20px;font-size:12px}.table-wrap{overflow-x:auto;border-radius:10px;border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:12px 16px;background:var(--surface);color:var(--muted);font-weight:600;font-size:12px;text-align:left;border-bottom:1px solid var(--border)}.data-table td{padding:11px 16px;border-bottom:1px solid var(--border);color:var(--text)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface2)}.sku-code{font-family:monospace;color:var(--accent);font-size:13px}.empty-row{text-align:center;color:var(--muted);padding:32px!important}.db-section{margin-bottom:32px}.cabinet-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:24px}.cabinet-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.cabinet-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cabinet-name{font-weight:600}.cabinet-url{font-size:12px;margin-bottom:14px}.link{color:var(--accent2);text-decoration:none}.link:hover{text-decoration:underline}.no-url{color:var(--muted)}.cabinet-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sync-result{font-size:12px}.sync-result.success{color:var(--success)}.sync-result.error{color:var(--danger)}.search-input{padding:8px 14px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;font-size:13px;min-width:280px}.search-input:focus{outline:none;border-color:var(--accent)}.field-hint{font-size:11px;color:var(--muted);margin-top:4px}.btn-primary{padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:9px 18px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px}.btn-sm{padding:4px 10px;background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:6px;cursor:pointer;font-size:12px}.btn-sm:hover{color:var(--text)}.btn-danger-sm{padding:4px 8px;background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;cursor:pointer}.btn-danger-sm:hover{color:var(--danger);border-color:var(--danger)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:12px;color:var(--muted);font-weight:500}.field input,.field select{padding:9px 12px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;font-size:13px}.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}.error-msg{color:var(--danger);font-size:12px;margin-bottom:12px;padding:8px 12px;background:#dc26261a;border-radius:6px}.form-block{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-box{width:360px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px}.login-logo{font-size:48px;text-align:center;margin-bottom:12px}.login-title{text-align:center;font-size:20px;font-weight:700;margin-bottom:28px}.login-form{display:flex;flex-direction:column}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;width:480px;max-width:95vw}.modal-title{font-size:16px;font-weight:600;margin-bottom:20px}.modal-actions{display:flex;gap:10px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-icon{font-size:48px;margin-bottom:16px}
