:root{--phi: 1.618;--phi2: 1.272;--fs-base: 14px;--sp-base: 8px;--fs-2xs: calc(var(--fs-base) / var(--phi) / var(--phi2));--fs-xs: calc(var(--fs-base) / var(--phi));--fs-sm: calc(var(--fs-base) / var(--phi2));--fs-md: calc(var(--fs-base) * var(--phi2));--fs-lg: calc(var(--fs-base) * var(--phi));--fs-xl: calc(var(--fs-base) * var(--phi) * var(--phi2));--fs-2xl: calc(var(--fs-base) * var(--phi) * var(--phi));--sp-2xs: calc(var(--sp-base) / var(--phi) / var(--phi2));--sp-xs: calc(var(--sp-base) / var(--phi));--sp-sm: calc(var(--sp-base) / var(--phi2));--sp-md: var(--sp-base);--sp-lg: calc(var(--sp-base) * var(--phi2));--sp-xl: calc(var(--sp-base) * var(--phi));--sp-2xl: calc(var(--sp-base) * var(--phi) * var(--phi2));--sp-3xl: calc(var(--sp-base) * var(--phi) * var(--phi));--sp-4xl: calc(var(--sp-base) * var(--phi) * var(--phi) * var(--phi2));--sp-5xl: calc(var(--sp-base) * var(--phi) * var(--phi) * var(--phi));--radius-sm: calc(var(--sp-base) / var(--phi));--radius-md: var(--sp-base);--radius: calc(var(--sp-base) * var(--phi));--ico-glyph: var(--sp-3xl);--ico-box: var(--sp-5xl);--lh: 1.5;--lh-loose: var(--phi);--lh-tight: var(--phi2);--bg: #f7f8fa;--card: #ffffff;--surface: #ffffff;--surface-2: #eef1f7;--input-bg: #ffffff;--border: #e4e8f0;--border-soft: rgba(208, 215, 228, .6);--border-strong: #d3dae6;--text: #1e2230;--text-soft: #3a4154;--muted: #6b7280;--primary: #4f46e5;--primary-d: #4338ca;--danger: #dc2626;--success: #16a34a;--warn: #d97706;--ring: rgba(79, 70, 229, .45);--brand: #5b5bf0;--brand-2: #a855f7;--brand-3: #fb8a34;--gradient-brand: linear-gradient(135deg, #5b5bf0 0%, #a855f7 100%);--gradient-sun: linear-gradient(135deg, #f59e0b 0%, #f97316 100%);--shadow-soft: 0 1px 2px rgba(30, 41, 90, .04), 0 2px 6px -2px rgba(30, 41, 90, .08);--shadow-soft-lg: 0 1px 3px rgba(30, 41, 90, .06), 0 8px 20px -8px rgba(30, 41, 90, .14);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:var(--fs-base);line-height:var(--lh);font-feature-settings:"rlig" 1,"calt" 1}:root[data-theme=dark]{--bg: #0f1117;--card: #171a21;--surface: #171a21;--surface-2: #20242e;--input-bg: #10131a;--border: #272b35;--border-soft: rgba(255, 255, 255, .08);--border-strong: #353b48;--text: #e6e8ee;--text-soft: #c3c8d4;--muted: #8a93a4;--primary: #6d6bf5;--primary-d: #5b5bf0;--danger: #f04444;--success: #22c55e;--warn: #f59e0b;--ring: rgba(124, 124, 247, .5);--shadow-soft: 0 1px 2px rgba(0, 0, 0, .4), 0 2px 6px -2px rgba(0, 0, 0, .5);--shadow-soft-lg: 0 1px 3px rgba(0, 0, 0, .45), 0 10px 26px -8px rgba(0, 0, 0, .62)}:root[data-theme=dark] .sidebar{background:#12151cb8}:root[data-theme=dark] .nav-collapse{background:#ffffff0a}:root[data-theme=dark] .nav-foot{background:#ffffff0d}:root[data-theme=dark] th{background:#1c2028eb}:root[data-theme=dark] tbody tr:nth-child(2n){background:#ffffff06}:root[data-theme=dark] tbody tr:hover{background:#7c7cf71f}:root[data-theme=dark] .alert-warn{background:#d977061f;color:#fbbf24;border-color:#d9770661}:root[data-theme=dark] .stat-ico{background:var(--surface-2);color:var(--muted)}:root[data-theme=dark] .stat-card.tone-brand .stat-ico{background:#6366f12e;color:#a5b4fc}:root[data-theme=dark] .stat-card.tone-amber .stat-ico{background:#f59e0b29;color:#fbbf24}:root[data-theme=dark] .stat-card.tone-emerald .stat-ico{background:#10b98129;color:#34d399}:root[data-theme=dark] .stat-card.tone-sky .stat-ico{background:#0ea5e929;color:#38bdf8}:root[data-theme=dark] .stat-card.tone-violet .stat-ico{background:#8b5cf62e;color:#c4b5fd}:root[data-theme=dark] .stat-card.tone-rose .stat-ico{background:#f43f5e29;color:#fb7185}:root[data-theme=dark] .stat-card.tone-gray .stat-ico{background:#272b35;color:#94a3b8}:root[data-theme=dark] .ui-debug-panel{background:#171a21f7}:root[data-theme=dark] .ui-debug-num{background:var(--input-bg)}:root[data-theme=dark] .ui-debug-chip:hover{background:var(--surface)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit}::selection{background:#5b5bf038}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#6b72804d;border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#6b72808c;background-clip:padding-box;border:2px solid transparent}.app-shell{display:flex;min-height:100vh}.sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;background:#ffffffc7;backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-right:1px solid var(--border-soft);transition:width .18s ease}.brand{display:flex;align-items:center;gap:var(--sp-lg);height:48px;padding:0 var(--sp-2xl);border-bottom:1px solid var(--border-soft);font-size:inherit}.brand-logo{display:flex;align-items:center;justify-content:center;width:var(--ico-box);height:var(--ico-box);border-radius:var(--radius);background:var(--gradient-brand);color:#fff;box-shadow:inset 0 0 0 1px #fff3,var(--shadow-soft);flex-shrink:0}.brand-logo svg{width:var(--ico-glyph);height:var(--ico-glyph)}.brand-text{display:flex;flex-direction:column;line-height:var(--lh-tight);min-width:0}.brand-name{font-size:var(--fs-base);font-weight:700;letter-spacing:-.01em;color:var(--text)}.brand-ver{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.nav{flex:1;overflow-y:auto;padding:var(--sp-2xl) var(--sp-lg);display:flex;flex-direction:column;gap:var(--sp-3xl)}.nav-group{display:flex;flex-direction:column;gap:var(--sp-xs)}.nav-group-label{padding:0 var(--sp-lg);font-size:var(--fs-sm);font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#6b7280cc;margin-bottom:var(--sp-2xs)}.nav-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--sp-2xs)}.nav-item{position:relative;display:flex;align-items:center;gap:var(--sp-lg);width:100%;padding:var(--sp-lg) var(--sp-xl);border:none;border-radius:var(--radius-md);background:none;color:var(--muted);font-weight:500;font-size:var(--fs-base);text-align:left;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.nav-item svg{width:var(--ico-glyph);height:var(--ico-glyph);flex-shrink:0;transition:transform .15s}.nav-item:hover{background:#6366f112;color:var(--text)}.nav-item:hover svg{transform:scale(1.08)}.nav-item.active{background:linear-gradient(90deg,rgba(91,91,240,.12),rgba(91,91,240,.03) 60%,transparent);color:var(--text);font-weight:600;box-shadow:var(--shadow-soft)}.nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 4px 4px 0;background:var(--gradient-brand)}.nav-item.active svg{color:var(--brand)}.nav-spacer{flex:1}.nav-collapse{display:flex;align-items:center;justify-content:center;gap:var(--sp-md);margin:0 var(--sp-lg) var(--sp-md);padding:var(--sp-md);border:1px solid var(--border-soft);border-radius:var(--radius-md);background:#eef1f78c;color:var(--muted);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:background .15s,color .15s}.nav-collapse:hover{background:#6366f114;color:var(--text)}.nav-collapse svg{width:var(--ico-glyph);height:var(--ico-glyph);flex-shrink:0}.nav-foot{display:flex;align-items:center;gap:var(--sp-lg);margin:var(--sp-lg);padding:var(--sp-lg) var(--sp-xl);border-radius:var(--radius-md);background:#eef1f7b3;font-size:var(--fs-sm);color:var(--muted)}.nav-foot .dot{width:7px;height:7px;border-radius:999px;background:#10b981;box-shadow:0 0 6px #10b98199;flex-shrink:0}.sidebar.collapsed{width:55px}.sidebar.collapsed .brand{justify-content:center;padding:0;gap:0}.sidebar.collapsed .brand-text{display:none}.sidebar.collapsed .nav{padding:var(--sp-2xl) var(--sp-md)}.sidebar.collapsed .nav-group-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--sp-lg) 0;gap:0}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-collapse span{display:none}.sidebar.collapsed .nav-foot{justify-content:center;padding:var(--sp-lg) 0}.sidebar.collapsed .nav-foot span:last-child{display:none}.main{flex:1;min-width:0;padding:var(--sp-4xl) var(--sp-5xl);overflow:auto;max-height:100vh}.main>*{animation:page-in .22s cubic-bezier(.22,1,.36,1)}@keyframes page-in{0%{opacity:0;transform:translateY(4px)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.page-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:var(--sp-2xl);margin-bottom:var(--sp-4xl)}.page-title{font-size:var(--fs-lg);font-weight:800;margin:0;letter-spacing:-.02em}.page-sub{color:var(--muted);margin:var(--sp-sm) 0 0;font-size:var(--fs-sm);line-height:var(--lh-loose)}.page-head-main{display:flex;align-items:center;gap:var(--sp-xl);min-width:0}.page-icon{display:flex;align-items:center;justify-content:center;width:calc(var(--ico-box) * var(--phi2));height:calc(var(--ico-box) * var(--phi2));border-radius:var(--radius);background:var(--primary);color:#fff;box-shadow:inset 0 0 0 1px #ffffff2e,var(--shadow-soft);flex-shrink:0}.page-icon svg{width:var(--sp-4xl);height:var(--sp-4xl)}.page-head-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-md);flex-shrink:0;margin-left:auto}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:var(--sp-3xl)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:var(--sp-xl);margin-bottom:var(--sp-4xl)}.split-cols{display:grid;gap:var(--sp-4xl);grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start}.split-cols-wide{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr)}.stat-card{position:relative;overflow:hidden;padding:var(--sp-2xl) var(--sp-3xl);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft-lg);border-color:var(--border-strong)}.stat-card .stat-label{color:var(--muted);font-size:var(--fs-sm);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.stat-card .stat-value{font-size:var(--fs-lg);font-weight:800;margin-top:var(--sp-sm);letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums;line-height:1.1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-lg)}.stat-ico{display:flex;align-items:center;justify-content:center;width:var(--ico-box);height:var(--ico-box);border-radius:var(--radius-md);flex-shrink:0;background:var(--surface-2);color:var(--muted);transition:transform .18s ease}.stat-ico svg{width:var(--ico-glyph);height:var(--ico-glyph)}.stat-card:hover .stat-ico{transform:scale(1.06)}.stat-card.tone-brand .stat-ico{background:#e0e7ff;color:#4338ca}.stat-card.tone-amber .stat-ico{background:#fef3c7;color:#b45309}.stat-card.tone-emerald .stat-ico{background:#d1fae5;color:#047857}.stat-card.tone-sky .stat-ico{background:#e0f2fe;color:#0369a1}.stat-card.tone-violet .stat-ico{background:#ede9fe;color:#6d28d9}.stat-card.tone-rose .stat-ico{background:#ffe4e6;color:#be123c}.stat-card.tone-gray .stat-ico{background:#eef1f7;color:#64748b}.contact-cell{display:flex;flex-direction:column;gap:2px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--fs-sm);line-height:var(--lh)}.contact-main{color:var(--text);word-break:break-all}.copyable{cursor:pointer;border-radius:var(--radius-sm);margin:-1px -4px;padding:1px 4px;transition:background .12s,color .12s}.copyable:hover{background:#5b5bf01a;color:var(--primary)}.copyable:active{background:#5b5bf033}.copyable.muted:hover{color:var(--primary)}.copyable-empty,.copyable-empty:hover{cursor:default;background:none;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-sm);border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:var(--radius-md);padding:var(--sp-md) var(--sp-2xl);cursor:pointer;font-weight:600;font-size:var(--fs-base);line-height:1.2;white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s,transform .05s,filter .15s}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--ring)}.btn-primary{background:var(--primary);border-color:transparent;color:#fff;box-shadow:var(--shadow-soft)}.btn-primary:hover{background:var(--primary-d);box-shadow:var(--shadow-soft-lg)}.btn-danger{background:var(--danger);border-color:transparent;color:#fff;box-shadow:var(--shadow-soft)}.btn-danger:hover{filter:brightness(.95)}.btn-brand{background:var(--gradient-brand);border-color:transparent;color:#fff;box-shadow:var(--shadow-soft)}.btn-brand:hover{filter:brightness(1.07);box-shadow:var(--shadow-soft-lg)}.btn-sm{padding:var(--sp-sm) var(--sp-lg);font-size:calc(var(--fs-base) - 1px);font-weight:600;border-radius:var(--radius-sm)}.toolbar{display:flex;gap:var(--sp-lg);align-items:center;flex-wrap:wrap;margin-bottom:var(--sp-2xl)}.toolbar .spacer{flex:1}.toolbar-group{display:flex;align-items:center;gap:var(--sp-lg);flex-wrap:wrap}.toolbar-sep{width:1px;align-self:stretch;min-height:22px;background:var(--border);flex-shrink:0}.orders-subbar{margin-top:calc(-1 * var(--sp-lg));padding:var(--sp-md) var(--sp-lg);background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);font-size:var(--fs-sm);row-gap:var(--sp-md)}.orders-subbar input[type=date]{font-variant-numeric:tabular-nums}.menu-caret{font-size:var(--fs-xs);line-height:1;opacity:.65;margin-left:1px}.menu-layer{position:fixed;inset:0;z-index:80}.menu-pop{position:fixed;z-index:81;min-width:172px;max-width:264px;padding:var(--sp-sm);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft-lg);display:flex;flex-direction:column;gap:1px;animation:menu-in .13s cubic-bezier(.22,1,.36,1)}@keyframes menu-in{0%{opacity:0;transform:translateY(-4px)}}.menu-item{display:flex;align-items:center;gap:var(--sp-md);width:100%;border:none;background:none;color:var(--text);font-size:var(--fs-base);font-weight:500;text-align:left;white-space:nowrap;padding:var(--sp-md) var(--sp-lg);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s,color .12s}.menu-item:hover:not(:disabled){background:#6366f11a;color:var(--primary)}.menu-item:disabled{opacity:.5;cursor:not-allowed}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover:not(:disabled){background:#dc26261a;color:var(--danger)}.menu-divider{height:1px;background:var(--border);margin:var(--sp-sm) var(--sp-md)}.input,.select,.textarea{border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-md) var(--sp-lg);font-size:var(--fs-base);width:100%;background:var(--input-bg);color:var(--text);transition:border-color .15s,box-shadow .15s}.input::placeholder,.textarea::placeholder{color:#6b7280b3}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.field{margin-bottom:var(--sp-2xl)}.label{display:block;font-size:var(--fs-sm);font-weight:600;margin-bottom:var(--sp-sm);color:var(--text-soft)}input[type=checkbox]{appearance:none;-webkit-appearance:none;margin:0;flex:none;box-sizing:border-box;width:19px;height:19px;border:1.5px solid var(--border-strong);border-radius:calc(var(--radius-md) + 1px);background:var(--input-bg);display:inline-grid;place-content:center;cursor:pointer;vertical-align:middle;transition:background-color .15s,border-color .15s,box-shadow .15s,transform .1s}input[type=checkbox]:before{content:"";width:11px;height:11px;transform:scale(0);transform-origin:center;transition:transform .12s ease-in-out;box-shadow:inset 1em 1em #fff;clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%)}input[type=checkbox]:hover{border-color:var(--brand)}input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}input[type=checkbox]:checked{background:var(--brand);border-color:var(--brand)}input[type=checkbox]:checked:before{transform:scale(1)}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-soft)}table{width:100%;border-collapse:collapse;font-size:var(--fs-base)}th,td{text-align:left;padding:var(--sp-lg) var(--sp-xl);border-bottom:1px solid var(--border);white-space:nowrap}th{background:#eef1f7d9;color:var(--muted);font-weight:600;font-size:var(--fs-sm);letter-spacing:.05em;text-transform:uppercase;position:sticky;top:0;z-index:1;box-shadow:inset 0 -1px 0 var(--border);border-bottom:none}tbody tr{transition:background .1s ease}tbody tr:nth-child(2n){background:#0f172a04}tbody tr:hover{background:#6366f10f}tbody tr:last-child td{border-bottom:none}td.actions{display:flex;align-items:center;gap:var(--sp-sm);flex-wrap:nowrap}td.actions>button{min-width:calc(var(--sp-base) * 7.5);flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:var(--sp-2xs) var(--sp-lg);border-radius:999px;font-size:var(--fs-sm);font-weight:600;line-height:1.4;box-shadow:inset 0 0 0 1px #0000000a}.badge.pending{background:#dbeafe;color:#1e40af;box-shadow:inset 0 0 0 1px #1e40af26}.badge.active{background:#dcfce7;color:#166534;box-shadow:inset 0 0 0 1px #16653426}.badge.token_expired{background:#fef3c7;color:#92400e;box-shadow:inset 0 0 0 1px #92400e26}.badge.banned{background:#fee2e2;color:#991b1b;box-shadow:inset 0 0 0 1px #991b1b26}.badge.paused,.badge.gray{background:#e5e7eb;color:#374151;box-shadow:inset 0 0 0 1px #3741511f}.badge.sky{background:#e0f2fe;color:#075985;box-shadow:inset 0 0 0 1px #0369a126}.badge.rose{background:#ffe4e6;color:#9f1239;box-shadow:inset 0 0 0 1px #9f123929}.badge.violet{background:#ede9fe;color:#5b21b6;box-shadow:inset 0 0 0 1px #5b21b626}.badge.after{background:#ffedd5;color:#9a3412;box-shadow:inset 0 0 0 1px #9a341233}.chip{display:inline-flex;align-items:center;gap:3px;padding:1px var(--sp-sm);border-radius:var(--radius-sm);font-size:var(--fs-xs);line-height:1.5;font-weight:500;background:var(--surface-2);color:var(--muted);white-space:nowrap}.chip-balance{background:#e0f2fe;color:#0369a1}.chip-warn{background:#fef3c7;color:#92400e}.chip-danger{background:#fee2e2;color:#991b1b}.chip-ok{background:#dcfce7;color:#166534}.chip-group{background:#ede9fe;color:#5b21b6}.modal-overlay{position:fixed;inset:0;background:#0f111780;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--sp-3xl);animation:overlay-in .15s ease}@keyframes overlay-in{0%{opacity:0}}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:576px;max-height:86vh;overflow:auto;box-shadow:0 24px 64px -12px #0f172a5c;animation:modal-in .18s cubic-bezier(.22,1,.36,1)}.modal.modal-lg{max-width:760px}.modal.modal-xl{max-width:1040px}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(.98)}}.modal-head{padding:var(--sp-xl) var(--sp-3xl);border-bottom:1px solid var(--border);font-weight:700;font-size:var(--fs-md);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:var(--sp-3xl)}.modal-foot{padding:var(--sp-xl) var(--sp-3xl);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--sp-lg)}.toast-wrap{position:fixed;top:var(--sp-2xl);right:var(--sp-2xl);display:flex;flex-direction:column;gap:var(--sp-lg);z-index:100}.toast{background:#111827f5;color:#fff;padding:var(--sp-lg) var(--sp-2xl) var(--sp-lg) var(--sp-xl);border-radius:var(--radius-md);border-left:4px solid #64748b;box-shadow:0 12px 30px -8px #00000059;font-size:var(--fs-base);max-width:340px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:toast-in .2s cubic-bezier(.22,1,.36,1)}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}}.toast.success{border-left-color:#22c55e}.toast.error{border-left-color:#ef4444}.toast.info{border-left-color:#6366f1}.muted{color:var(--muted)}.alert-warn{margin-top:var(--sp-xl);padding:var(--sp-lg) var(--sp-xl);border:1px solid rgba(217,119,6,.4);border-radius:var(--radius-md);background:#fff7ed;color:#92400e;font-size:var(--fs-sm);line-height:var(--lh-loose)}.warn-text{color:var(--warn);font-weight:600}.row{display:flex;gap:var(--sp-lg);align-items:center}.empty{text-align:center;color:var(--muted);padding:var(--sp-5xl) 0;font-size:var(--fs-sm)}.log-panel{background:#0b1020;color:#c8d1e0;border-radius:var(--radius);padding:var(--sp-2xl);height:288px;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--fs-sm);line-height:1.8;box-shadow:inset 0 0 0 1px #ffffff0d}.log-line .lv{font-weight:700}.log-line .success{color:#4ade80}.log-line .error{color:#f87171}.log-line .info{color:#93c5fd}.log-line .warn{color:#fbbf24}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:currentColor;border-radius:50%;display:inline-block;animation:spin .7s linear infinite}.btn .spinner{border-color:#fff6;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.progress{height:var(--sp-md);background:var(--surface-2);border-radius:999px;overflow:hidden}.progress>div{height:100%;background:var(--primary);transition:width .2s}.prod-cell{display:flex;align-items:center;gap:var(--sp-lg);max-width:322px}.prod-img{width:48px;height:48px;border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--border);background:var(--surface-2);flex-shrink:0}.prod-img.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:var(--fs-md)}.prod-meta{min-width:0}.prod-name{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.prod-sku{font-size:var(--fs-sm);color:var(--muted);max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prod-cell.clickable{cursor:pointer;border-radius:var(--radius-md);transition:background .12s ease}.prod-cell.clickable:hover{background:var(--surface-2)}.prod-cell.clickable:hover .prod-name{text-decoration:underline;color:var(--primary)}.orders-pager{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-md);flex-wrap:wrap;margin-top:var(--sp-md);padding:var(--sp-sm) var(--sp-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface)}.pager-controls{display:flex;align-items:center;gap:var(--sp-sm);flex-wrap:wrap}.od-section{margin-top:var(--sp-lg)}.od-section:first-child{margin-top:0}.od-section-title{font-size:var(--fs-sm);font-weight:600;color:var(--muted);margin-bottom:var(--sp-sm);padding-bottom:var(--sp-2xs);border-bottom:1px solid var(--border)}.od-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-xs) var(--sp-lg)}.od-row{display:flex;gap:var(--sp-sm);font-size:var(--fs-base);line-height:1.6}.od-row .od-key{color:var(--muted);flex-shrink:0;min-width:64px}.od-row .od-val{color:var(--text);word-break:break-all;font-variant-numeric:tabular-nums}.od-item{display:flex;align-items:flex-start;gap:var(--sp-md);padding:var(--sp-sm) 0;border-bottom:1px dashed var(--border)}.od-item:last-child{border-bottom:none}.od-item-name{font-weight:500;line-height:1.4}.od-item-sub{font-size:var(--fs-sm);color:var(--muted);margin-top:var(--sp-2xs)}.od-item-amt{margin-left:auto;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.od-raw{margin-top:var(--sp-lg)}.od-raw summary{cursor:pointer;color:var(--muted);font-size:var(--fs-sm)}.od-raw pre{margin-top:var(--sp-sm);max-height:280px;overflow:auto;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-md);font-size:var(--fs-sm);line-height:1.5;white-space:pre-wrap;word-break:break-all}.ui-debug-fab{position:fixed;right:18px;bottom:18px;z-index:190;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;border-radius:12px;background:var(--primary);color:#fff;cursor:pointer;box-shadow:0 6px 18px -6px #4f46e599,inset 0 0 0 1px #ffffff2e;transition:transform .12s ease,filter .15s ease}.ui-debug-fab:hover{transform:translateY(-1px);filter:brightness(1.06)}.ui-debug-fab:active{transform:scale(.95)}.ui-debug-fab svg{width:20px;height:20px}.ui-debug-panel{position:fixed;z-index:200;width:280px;background:#fffffff5;backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);border:1px solid var(--border-strong);border-radius:14px;box-shadow:0 18px 48px -16px #0f172a6b;font-size:12px;color:var(--text);overflow:hidden;user-select:none}.ui-debug-head{display:flex;align-items:center;gap:8px;padding:9px 10px 9px 12px;background:var(--gradient-brand);color:#fff;cursor:grab;touch-action:none}.ui-debug-head:active{cursor:grabbing}.ui-debug-title{font-weight:700;font-size:12.5px;letter-spacing:.01em;flex:1}.ui-debug-drag{opacity:.75;font-size:13px;line-height:1}.ui-debug-x{border:none;background:#ffffff2e;color:#fff;width:20px;height:20px;border-radius:6px;cursor:pointer;font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .12s}.ui-debug-x:hover{background:#ffffff57}.ui-debug-body{padding:12px;display:flex;flex-direction:column;gap:12px}.ui-debug-knob{display:flex;flex-direction:column;gap:5px}.ui-debug-knob-top{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--text-soft)}.ui-debug-knob-top>span:first-child{flex:1}.ui-debug-num{width:56px;border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:12px;text-align:right;background:#fff;color:var(--text)}.ui-debug-num:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--ring)}.ui-debug-unit{width:16px;color:var(--muted)}.ui-debug-range{width:100%;accent-color:var(--primary);cursor:pointer}.ui-debug-presets{display:flex;flex-wrap:wrap;gap:6px;padding-top:2px;border-top:1px dashed var(--border)}.ui-debug-chip{border:1px solid var(--border);background:var(--surface-2);color:var(--text-soft);border-radius:999px;padding:3px 10px;font-size:11.5px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ui-debug-chip:hover{border-color:var(--border-strong);background:#fff}.ui-debug-chip.on{background:var(--primary);border-color:transparent;color:#fff}.ui-debug-readout{color:var(--muted);font-size:11px;line-height:1.6}.ui-debug-section{display:flex;flex-direction:column;gap:12px;padding-top:12px;margin-top:2px;border-top:1px solid var(--border)}.ui-debug-section-title{font-weight:700;font-size:11.5px;color:var(--text-soft);letter-spacing:.02em}.auth{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--sp-4xl);background:radial-gradient(circle at 12% 0%,rgba(91,91,240,.16),transparent 24rem),radial-gradient(circle at 88% 12%,rgba(168,85,247,.14),transparent 24rem),var(--bg)}.auth-card{width:100%;max-width:408px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft-lg);padding:var(--sp-5xl) var(--sp-4xl)}.auth-brand{display:flex;align-items:center;gap:var(--sp-lg);margin-bottom:var(--sp-2xl)}.auth-card .page-title,.auth-card .input{margin-bottom:var(--sp-xs)}.user-foot{justify-content:space-between}.user-foot-meta{display:flex;flex-direction:column;min-width:0;gap:1px}.user-foot-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-foot-logout{border:none;background:none;padding:0;color:var(--danger);cursor:pointer;font-size:var(--fs-sm);text-align:left}.user-foot-logout:hover{text-decoration:underline}.sidebar.collapsed .user-foot-meta{display:none}@media(max-width:760px){.app-shell{flex-direction:column}.sidebar{width:100%!important;height:auto;position:sticky;top:0;z-index:20;flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--sp-sm) var(--sp-md);padding:var(--sp-md) var(--sp-lg);border-right:none;border-bottom:1px solid var(--border-soft)}.sidebar .brand{flex:0 1 auto;min-width:0;margin:0;padding:0}.sidebar .brand-ver{display:none}.sidebar .nav{order:5;flex:0 0 100%;width:100%;flex-direction:row;flex-wrap:wrap;overflow:visible;gap:var(--sp-2xs) var(--sp-sm);padding:var(--sp-sm) 0 0}.nav-group{flex-direction:row;align-items:center;gap:var(--sp-2xs)}.nav-group-label{display:none}.nav-list{flex-direction:row;gap:var(--sp-2xs)}.nav-item{padding:var(--sp-sm) var(--sp-lg);white-space:nowrap}.theme-toggle{order:2;margin:0 0 0 auto;padding:var(--sp-sm)}.theme-toggle .nav-label,.sidebar-toggle{display:none}.nav-foot.user-foot{order:3;margin:0;padding:var(--sp-sm) var(--sp-md);flex:0 1 auto;min-width:0;max-width:52%}.main{padding:var(--sp-2xl) var(--sp-lg);max-height:none;overflow:visible}.page-head{margin-bottom:var(--sp-2xl)}.page-head-actions{margin-left:0;width:100%}.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-lg);margin-bottom:var(--sp-2xl)}.split-cols,.split-cols-wide{grid-template-columns:1fr;gap:var(--sp-2xl)}.toolbar{gap:var(--sp-md)}.toolbar-group{width:100%;gap:var(--sp-md)}.toolbar .spacer,.toolbar-sep{display:none}.toolbar .input,.toolbar .select{width:100%!important;flex:1 1 9rem}.modal-overlay{padding:var(--sp-lg);align-items:flex-start}.modal,.modal.modal-lg,.modal.modal-xl{max-width:100%;margin-top:var(--sp-2xl)}.modal-head,.modal-body,.modal-foot{padding-left:var(--sp-xl);padding-right:var(--sp-xl)}}
