*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
:root,[data-theme="light"]{
  --font-sans:'Geist','SF Pro Text',-apple-system,sans-serif;
  --font-display:'Geist','SF Pro Display',-apple-system,sans-serif;
  --font-serif:'Instrument Serif',Georgia,serif;
  --font-mono:'Geist Mono','SF Mono',ui-monospace,monospace;
  --bg:#fafaf9;--surface:#ffffff;--surface-2:#f5f5f4;--surface-3:#e7e5e4;--surface-4:#d6d3d1;
  --ink:#0c0a09;--ink-2:#44403c;--ink-3:#78716c;--ink-4:#a8a29e;--ink-5:#d6d3d1;
  --line:rgba(0,0,0,0.06);--line-2:rgba(0,0,0,0.09);--line-strong:rgba(0,0,0,0.14);
  --fill:rgba(0,0,0,0.04);--fill-2:rgba(0,0,0,0.06);--fill-3:rgba(0,0,0,0.09);
  --glass:rgba(255,255,255,0.72);--glass-strong:rgba(250,250,249,0.88);
  --accent:#3730a3;--accent-hover:#312e81;--accent-soft:rgba(55,48,163,0.08);--accent-softer:rgba(55,48,163,0.04);--accent-ink:#3730a3;
  --ok:#047857;--ok-soft:rgba(4,120,87,0.1);--warn:#b45309;--warn-soft:rgba(180,83,9,0.1);
  --danger:#b91c1c;--danger-soft:rgba(185,28,28,0.08);--info:#1e40af;--info-soft:rgba(30,64,175,0.08);
  --muted:#57534e;--muted-soft:rgba(87,83,78,0.08);
  --wa:#128c7e;--wa-soft:rgba(18,140,126,0.1);--fb:#1877f2;--fb-soft:rgba(24,119,242,0.1);--ig:#c13584;--ig-soft:rgba(193,53,132,0.1);
  --rail:#18181b;--rail-ink:rgba(255,255,255,0.42);--rail-ink-hover:rgba(255,255,255,0.92);--rail-active:rgba(255,255,255,0.1);
  --r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-2xl:20px;--r-full:999px;--rail-w:56px;
  --shadow-xs:0 1px 2px rgba(0,0,0,0.04);--shadow-sm:0 1px 3px rgba(0,0,0,0.04),0 1px 2px rgba(0,0,0,0.03);
  --shadow-md:0 4px 12px rgba(0,0,0,0.06),0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg:0 12px 32px rgba(0,0,0,0.1),0 4px 8px rgba(0,0,0,0.05);
  --shadow-xl:0 24px 56px rgba(0,0,0,0.14),0 6px 12px rgba(0,0,0,0.06);
  --ease:cubic-bezier(0.22,1,0.36,1);--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --blur:saturate(160%) blur(16px);
}
[data-theme="dark"]{
  --bg:#09090b;--surface:#18181b;--surface-2:#27272a;--surface-3:#3f3f46;--surface-4:#52525b;
  --ink:#fafaf9;--ink-2:#e7e5e4;--ink-3:#a8a29e;--ink-4:#78716c;--ink-5:#57534e;
  --line:rgba(255,255,255,0.06);--line-2:rgba(255,255,255,0.09);--line-strong:rgba(255,255,255,0.14);
  --fill:rgba(255,255,255,0.05);--fill-2:rgba(255,255,255,0.08);--fill-3:rgba(255,255,255,0.12);
  --glass:rgba(24,24,27,0.72);--glass-strong:rgba(9,9,11,0.88);
  --accent:#818cf8;--accent-hover:#a5b4fc;--accent-soft:rgba(129,140,248,0.14);--accent-softer:rgba(129,140,248,0.07);--accent-ink:#a5b4fc;
  --ok:#34d399;--ok-soft:rgba(52,211,153,0.14);--warn:#fbbf24;--warn-soft:rgba(251,191,36,0.14);
  --danger:#f87171;--danger-soft:rgba(248,113,113,0.12);--info:#60a5fa;--info-soft:rgba(96,165,250,0.12);
  --muted:#a8a29e;--muted-soft:rgba(168,162,158,0.12);
  --wa:#25d366;--wa-soft:rgba(37,211,102,0.14);--fb:#4d94ff;--fb-soft:rgba(77,148,255,0.14);--ig:#e569a8;--ig-soft:rgba(229,105,168,0.14);
  --rail:#050505;--shadow-xs:0 1px 2px rgba(0,0,0,0.3);--shadow-sm:0 1px 3px rgba(0,0,0,0.3),0 1px 2px rgba(0,0,0,0.2);
  --shadow-md:0 4px 12px rgba(0,0,0,0.4),0 2px 4px rgba(0,0,0,0.25);
  --shadow-lg:0 12px 32px rgba(0,0,0,0.5),0 4px 8px rgba(0,0,0,0.3);
  --shadow-xl:0 24px 56px rgba(0,0,0,0.6),0 6px 12px rgba(0,0,0,0.4);
}
body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:'ss01','cv11';letter-spacing:-0.005em;transition:background .3s var(--ease),color .3s var(--ease)}
::-webkit-scrollbar{width:0;height:0}
::selection{background:var(--accent-soft);color:var(--accent-ink)}
svg{display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}
input,textarea{-webkit-appearance:none}
.mono{font-family:var(--font-mono);font-size:.92em;letter-spacing:-.02em}
.eyebrow{font-size:10px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.09em}
.hide{display:none!important}
.theme-tog{width:38px;height:22px;border-radius:var(--r-full);background:var(--fill-2);border:.5px solid var(--line);position:relative;flex-shrink:0;display:flex;align-items:center;transition:background .2s var(--ease)}
.theme-tog-k{position:absolute;width:16px;height:16px;border-radius:50%;background:var(--surface);left:3px;transition:transform .3s var(--ease-spring);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);font-size:8px;color:var(--ink-3);line-height:1}
[data-theme="dark"] .theme-tog-k{transform:translateX(16px)}
#login{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg);position:relative;overflow:hidden}
#login::before{content:'';position:absolute;inset:0;background:radial-gradient(800px 600px at 85% 15%,var(--accent-softer),transparent 60%),radial-gradient(600px 400px at 10% 90%,var(--ok-soft),transparent 60%);pointer-events:none}
#login::after{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at center,black 0,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,black 0,transparent 75%);pointer-events:none;opacity:.5}
.login-card{width:380px;background:var(--surface);border:.5px solid var(--line-2);border-radius:var(--r-2xl);padding:36px 36px 32px;box-shadow:var(--shadow-xl);position:relative;z-index:1}
.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:32px}
.login-mark{width:44px;height:44px;border-radius:var(--r-lg);background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:22px;font-style:italic;box-shadow:var(--shadow-sm)}
.login-title{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.02em}
.login-sub{font-size:11px;color:var(--ink-4);margin-top:3px;font-family:var(--font-mono)}
.field{margin-bottom:14px}
.field label{display:block;font-size:10px;font-weight:600;color:var(--ink-3);letter-spacing:.08em;margin-bottom:7px;text-transform:uppercase}
.input{width:100%;height:42px;padding:0 14px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-md);color:var(--ink);font-size:14px;outline:none;transition:all .15s var(--ease)}
.input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.input::placeholder{color:var(--ink-5)}
.input-sm{height:32px;font-size:13px;padding:0 10px;border-radius:var(--r-sm)}
.input-sm:focus{box-shadow:0 0 0 2px var(--accent-soft)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:500;background:var(--fill);color:var(--ink);border:.5px solid var(--line-2);transition:all .15s var(--ease);white-space:nowrap}
.btn:hover{background:var(--fill-2);border-color:var(--line-strong)}
.btn:active{transform:translateY(.5px)}
.btn-sm{padding:5px 11px;font-size:11.5px}
.btn-primary{background:var(--ink);color:var(--bg);border-color:transparent}
.btn-primary:hover{background:var(--ink-2)}
.btn-accent{background:var(--accent);color:#fff;border-color:transparent}
.btn-accent:hover{background:var(--accent-hover)}
.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:transparent}
.btn-danger:hover{filter:brightness(.95)}
.btn-block{width:100%;height:44px;font-size:14px;font-weight:600;margin-top:8px}
.login-err{color:var(--danger);font-size:12px;text-align:center;margin-top:12px;min-height:16px;font-weight:500}
#app{display:none;height:100vh}
#app.on{display:flex}
.rail{width:var(--rail-w);flex-shrink:0;background:var(--rail);display:flex;flex-direction:column;align-items:center;padding:14px 0 12px;gap:2px}
.rail-btn{width:40px;height:40px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--rail-ink);position:relative;transition:all .15s var(--ease)}
.rail-btn:hover{color:var(--rail-ink-hover);background:var(--rail-active)}
.rail-btn.on{color:#fff;background:var(--rail-active)}
.rail-btn.on::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 2px 2px 0;background:#fff}
.rail-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.rail-tip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--ink);color:var(--bg);font-size:11px;font-weight:500;padding:5px 9px;border-radius:var(--r-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s var(--ease);z-index:200}
.rail-btn:hover .rail-tip{opacity:1}
.rail-gap{flex:1}
.rail-logout{width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--rail-ink);transition:all .15s var(--ease)}
.rail-logout:hover{color:var(--danger);background:rgba(239,68,68,0.12)}
.rail-logout svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.topbar{height:52px;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:.5px solid var(--line);display:flex;align-items:center;padding:0 22px;gap:12px;flex-shrink:0}
.topbar-title{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.015em}
.topbar-badge{padding:3px 10px;background:var(--fill-2);border-radius:var(--r-full);font-size:11px;color:var(--ink-3);font-family:var(--font-mono);font-weight:500}
.page{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.dash{flex:1;overflow-y:auto;padding:28px 32px}
.dash-head{margin-bottom:28px;display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:12px}
.dash-head h1{font-family:var(--font-serif);font-size:34px;font-weight:400;letter-spacing:-.02em;line-height:1}
.dash-head h1 em{font-style:italic;color:var(--ink-3)}
.dash-head .sub{font-size:13px;color:var(--ink-3)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;transition:all .2s var(--ease);position:relative;overflow:hidden}
.stat::after{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--stat-color,var(--ink-4));transform:scaleY(0);transform-origin:center;transition:transform .25s var(--ease-out)}
.stat:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.stat:hover::after{transform:scaleY(1)}
.stat-label{font-size:10px;font-weight:600;color:var(--ink-4);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.stat-num{font-family:var(--font-display);font-size:28px;font-weight:600;line-height:1;letter-spacing:-.03em;color:var(--ink)}
.stat.accent{--stat-color:var(--accent)}.stat.ok{--stat-color:var(--ok)}.stat.warn{--stat-color:var(--warn)}.stat.danger{--stat-color:var(--danger)}.stat.info{--stat-color:var(--info)}
.hint-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);padding:20px 24px;display:flex;gap:24px;flex-wrap:wrap}
.hint-item{flex:1;min-width:200px}
.hint-item h4{font-size:12px;font-weight:600;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.hint-item p{font-size:12px;color:var(--ink-3);line-height:1.6}
.hint-dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.conv{display:flex;flex:1;min-height:0;overflow:hidden}
.filter-panel{width:212px;flex-shrink:0;background:var(--surface);border-right:.5px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.filter-head{padding:16px 16px 12px;display:flex;align-items:center;gap:10px;border-bottom:.5px solid var(--line);flex-shrink:0}
.filter-head-icon{width:24px;height:24px;border-radius:var(--r-sm);background:var(--accent-soft);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.filter-head-icon svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.filter-head h3{font-size:13px;font-weight:600;letter-spacing:-.01em}
.filter-body{flex:1;overflow-y:auto;padding:6px 0 16px}
.filter-section{padding:14px 16px 6px;font-size:9.5px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.1em}
.filter-row{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 16px;cursor:pointer;font-size:12.5px;color:var(--ink-2);position:relative;transition:all .12s var(--ease)}
.filter-row:hover{color:var(--ink);background:var(--fill)}
.filter-row.on{color:var(--accent-ink);background:var(--accent-softer);font-weight:500}
.filter-row.on::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--accent);border-radius:0 2px 2px 0}
.filter-icon{width:22px;height:22px;border-radius:var(--r-sm);background:var(--fill);color:var(--ink-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s var(--ease)}
.filter-icon svg{width:11px;height:11px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.filter-row.on .filter-icon{background:var(--accent-soft);color:var(--accent-ink)}
.filter-label{flex:1}
.saved-filter{display:flex;align-items:center;gap:8px;padding:6px 8px 6px 16px;cursor:pointer;font-size:12.5px;color:var(--ink-2);position:relative;transition:all .12s var(--ease)}
.saved-filter:hover{color:var(--ink);background:var(--fill)}
.saved-filter.on{color:var(--accent-ink);background:var(--accent-softer);font-weight:500}
.saved-filter.on::before{content:'';position:absolute;left:0;top:5px;bottom:5px;width:2px;background:var(--accent);border-radius:0 2px 2px 0}
.saved-dot{width:5px;height:5px;border-radius:50%;background:var(--ink-5);flex-shrink:0}
.saved-filter.on .saved-dot{background:var(--accent)}
.saved-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.saved-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}
.saved-filter:hover .saved-actions{opacity:1}
.saved-btn{width:20px;height:20px;border-radius:var(--r-xs);color:var(--ink-4);display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .12s var(--ease)}
.saved-btn:hover{background:var(--fill-2);color:var(--ink)}
.saved-btn.danger:hover{color:var(--danger)}
.filter-add{display:flex;align-items:center;gap:7px;padding:7px 12px;margin:4px 10px 2px;border-radius:var(--r-sm);border:1px dashed var(--line-strong);color:var(--accent-ink);font-size:12px;font-weight:500;transition:all .15s var(--ease)}
.filter-add:hover{border-color:var(--accent);background:var(--accent-softer)}
.filter-add-plus{font-size:14px;line-height:1;opacity:.7}
.filter-divider{height:.5px;background:var(--line);margin:8px 0}
.tag-row{display:flex;align-items:center;gap:8px;padding:5px 14px 5px 16px;cursor:pointer;font-size:12px;color:var(--ink-2);transition:all .12s var(--ease)}
.tag-row:hover{color:var(--ink);background:var(--fill)}
.tag-row.on{color:var(--accent-ink);font-weight:500}
.tag-row-dot{width:5px;height:5px;border-radius:50%;background:var(--ink-5);flex-shrink:0}
.tag-row.on .tag-row-dot{background:var(--accent)}
.filter-empty{font-size:11px;color:var(--ink-4);padding:4px 16px;font-style:italic}
.contact-col{width:300px;flex-shrink:0;background:var(--bg);border-right:.5px solid var(--line);display:flex;flex-direction:column;min-height:0;overflow:hidden}
.contact-head{padding:14px;border-bottom:.5px solid var(--line);flex-shrink:0;display:flex;flex-direction:column;gap:10px}
.contact-head h3{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.015em}
.contact-search{width:100%;height:34px;padding:0 12px 0 34px;background:var(--fill);border:.5px solid transparent;border-radius:var(--r-md);color:var(--ink);font-size:13px;outline:none;transition:all .15s var(--ease)}
.contact-search:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.contact-search::placeholder{color:var(--ink-4)}
.search-wrap{position:relative}
.search-wrap::before{content:'';position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;pointer-events:none}
.contact-list{flex:1;overflow-y:auto;min-height:0}
.contact{display:flex;align-items:center;gap:11px;padding:12px 14px;cursor:pointer;border-bottom:.5px solid var(--line);transition:background .1s var(--ease);position:relative}
.contact:hover{background:var(--fill)}
.contact.sel{background:var(--accent-softer)}
.contact.sel::after{content:'';position:absolute;left:0;top:10px;bottom:10px;width:2.5px;background:var(--accent);border-radius:0 2px 2px 0}
.avatar{border-radius:var(--r-full);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:12.5px;letter-spacing:-.01em;position:relative}
.avatar-sm{width:32px;height:32px;font-size:12px}
.avatar-md{width:36px;height:36px}
.avatar-lg{width:40px;height:40px;font-size:14px}
.avatar.fb{background:linear-gradient(135deg,#0084ff,#0057b8)}
.avatar.ig{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}
.avatar.wa{background:linear-gradient(135deg,#25d366,#128c7e)}
.contact-info{flex:1;min-width:0}
.contact-id{font-family:var(--font-mono);font-size:12.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}
.contact-preview{font-size:11.5px;color:var(--ink-4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:3px;min-height:16px}
.contact-meta{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.contact-time{font-size:10.5px;color:var(--ink-4);font-family:var(--font-mono)}
.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0;box-shadow:0 0 0 2px var(--bg)}
.manual-tag{display:inline-block;padding:2px 7px;border-radius:var(--r-full);font-size:9.5px;font-weight:600;background:var(--warn-soft);color:var(--warn);letter-spacing:.03em;text-transform:uppercase}
.list-loading{text-align:center;padding:24px;color:var(--ink-4);font-size:12px}
.list-end{text-align:center;padding:16px;color:var(--ink-4);font-size:10.5px;font-family:var(--font-mono);letter-spacing:.1em}
.spill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--r-full);font-size:10px;font-weight:600;letter-spacing:.02em;vertical-align:middle}
.spill::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.spill.paid,.sbadge.paid{background:var(--ok-soft);color:var(--ok)}.spill.paid::before,.sbadge.paid::before{background:var(--ok)}
.spill.pending,.sbadge.pending{background:var(--warn-soft);color:var(--warn)}.spill.pending::before,.sbadge.pending::before{background:var(--warn)}
.spill.shipped,.sbadge.shipped{background:var(--info-soft);color:var(--info)}.spill.shipped::before,.sbadge.shipped::before{background:var(--info)}
.spill.expired,.sbadge.expired{background:var(--muted-soft);color:var(--muted)}.spill.expired::before,.sbadge.expired::before{background:var(--muted)}
.spill.reminded_1,.spill.reminded_2,.sbadge.reminded_1,.sbadge.reminded_2{background:var(--warn-soft);color:var(--warn)}
.spill.reminded_1::before,.spill.reminded_2::before,.sbadge.reminded_1::before,.sbadge.reminded_2::before{background:var(--warn)}
.spill.check,.sbadge.check{background:rgba(124,58,237,0.12);color:#7c3aed}
.spill.check::before,.sbadge.check::before{background:#7c3aed}
[data-theme="dark"] .spill.check,[data-theme="dark"] .sbadge.check{background:rgba(167,139,250,0.18);color:#c4b5fd}
[data-theme="dark"] .spill.check::before,[data-theme="dark"] .sbadge.check::before{background:#c4b5fd}
.review-section{padding:16px 18px;border-bottom:.5px solid var(--line)}
.order-review-card{background:var(--accent-softer);border:.5px solid var(--accent-soft);border-radius:var(--r-lg);padding:14px}
.order-review-title{font-size:10px;font-weight:700;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.09em;display:flex;align-items:center;gap:6px;margin-bottom:12px}
.order-review-title::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:orpulse 2s infinite}
@keyframes orpulse{0%,100%{opacity:1}50%{opacity:.4}}
.review-field-label{font-size:9.5px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}
.review-row-3{display:grid;grid-template-columns:1fr 46px 62px;gap:6px;margin-bottom:8px}
.review-input{width:100%;height:30px;padding:0 9px;background:var(--surface);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:12px;outline:none;transition:all .15s var(--ease);font-family:var(--font-mono)}
.review-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.review-method{width:100%;height:30px;padding:0 24px 0 9px;background:var(--surface);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:11px;outline:none;margin-bottom:10px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' 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 7px center;background-size:11px}
.review-btns{display:flex;gap:7px;margin-top:2px}
.review-confirm{flex:1;height:32px;border-radius:var(--r-sm);background:var(--ok);color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .15s var(--ease)}
.review-confirm:hover{filter:brightness(1.1)}
.review-confirm:active{transform:translateY(.5px)}
.review-cancel{height:32px;padding:0 12px;border-radius:var(--r-sm);background:var(--fill);color:var(--ink-3);font-size:12px;font-weight:500;border:.5px solid var(--line-2);cursor:pointer;transition:all .15s var(--ease)}
.review-cancel:hover{background:var(--fill-2);color:var(--ink)}
.history-section{padding:16px 18px;border-bottom:.5px solid var(--line)}
.history-section h4{font-size:10px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.history-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:var(--fill);border-radius:var(--r-sm);margin-bottom:5px;cursor:pointer;transition:background .1s}
.history-item:hover{background:var(--fill-2)}
.history-item:last-child{margin-bottom:0}
.history-code{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--ok);letter-spacing:.02em}
.history-method{font-size:10px;color:var(--ink-4);font-family:var(--font-mono)}
.history-empty{font-size:11px;color:var(--ink-4);padding:4px 2px;font-style:italic}
.chat{flex:1;display:flex;background:var(--bg);overflow:hidden;min-width:0}
.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:14px}
.chat-empty-icon{width:56px;height:56px;border-radius:var(--r-xl);background:var(--fill);display:flex;align-items:center;justify-content:center}
.chat-empty-icon svg{width:24px;height:24px;fill:none;stroke:var(--ink-4);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.chat-empty p{font-size:13px;color:var(--ink-3);font-weight:500}
.chat-empty .hint{font-size:11.5px;color:var(--ink-4)}
.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.chat-head{background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:.5px solid var(--line);padding:11px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:12px}
.chat-head-left{display:flex;align-items:center;gap:12px;min-width:0}
.chat-head-info{min-width:0}
.chat-uid{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chat-status{font-size:11px;color:var(--ink-3);margin-top:3px;display:flex;align-items:center;gap:6px;font-weight:500}
.chat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.chat-dot.active{background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft)}
.chat-dot.paused{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}
.agent-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:var(--r-full);font-size:11px;font-weight:600}
.agent-pill.ai{background:var(--ok-soft);color:var(--ok)}
.agent-pill.human{background:var(--accent-soft);color:var(--accent-ink)}
.messages{flex:1;overflow-y:auto;padding:20px 20px 12px;display:flex;flex-direction:column;gap:6px;min-height:0;transition:opacity .15s var(--ease);background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:28px 28px}
.messages.loading{opacity:.3;pointer-events:none}
.message{max-width:68%;display:flex;flex-direction:column}
.msg-in{align-self:flex-start}
.msg-out{align-self:flex-end}
.bubble{padding:10px 14px;border-radius:var(--r-lg);font-size:13.5px;line-height:1.5;word-break:break-word;white-space:pre-wrap;letter-spacing:-.005em}
.msg-in .bubble{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-xs);border:.5px solid var(--line);border-bottom-left-radius:5px}
.msg-out .bubble{background:var(--ink);color:var(--bg);border-bottom-right-radius:5px}
.msg-out.manual .bubble{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);color:#fff}
.msg-out.failed{opacity:.65}
.msg-out.failed .bubble{background:var(--surface-2)!important;color:var(--ink-3)!important;border:.5px solid var(--danger-soft)!important}
.fail-label{color:var(--danger);font-weight:600;font-size:10px;display:inline-flex;align-items:center;gap:3px}
.fail-label::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--danger);display:inline-block}
.msg-time{font-size:10px;color:var(--ink-4);font-family:var(--font-mono);margin-top:5px;display:flex;align-items:center;gap:5px}
.msg-out .msg-time{justify-content:flex-end}
.bubble img.msg-img{max-width:240px;max-height:220px;border-radius:var(--r-md);display:block;object-fit:cover;cursor:pointer}
.bubble:has(img.msg-img){padding:4px!important;background:transparent!important;box-shadow:none!important;border:none!important}
.bubble:has(img.msg-img) img.msg-img{border-radius:var(--r-lg)}
.composer{background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-top:.5px solid var(--line);padding:12px 16px;display:flex;align-items:flex-end;gap:8px;flex-shrink:0}
.composer-input{flex:1;padding:10px 14px;background:var(--surface);border:.5px solid var(--line-2);border-radius:var(--r-lg);color:var(--ink);font-size:14px;outline:none;resize:none;max-height:120px;min-height:40px;line-height:1.5;transition:all .15s var(--ease)}
.composer-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.composer-input::placeholder{color:var(--ink-4)}
.composer-send{width:40px;height:40px;border-radius:var(--r-full);background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s var(--ease-spring)}
.composer-send:hover{background:var(--accent);transform:scale(1.05)}
.composer-send:active{transform:scale(.95)}
.composer-send svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.composer-img{width:36px;height:36px;border-radius:var(--r-md);background:var(--fill);color:var(--ink-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s var(--ease)}
.composer-img:hover{background:var(--fill-2);color:var(--accent-ink)}
.composer-img svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.composer-wrap{display:flex;flex-direction:column;flex:1;gap:6px}
.img-preview-strip{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0 2px}
.img-preview-strip:empty{display:none}
.img-preview-item{position:relative;display:inline-flex;flex-shrink:0}
.img-preview-item img{width:64px;height:64px;border-radius:var(--r-md);object-fit:cover;display:block;box-shadow:var(--shadow-sm);border:.5px solid var(--line)}
.img-preview-x{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:var(--ink);color:var(--bg);font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .12s var(--ease);line-height:1;box-shadow:var(--shadow-sm)}
.img-preview-x:hover{background:var(--danger)}
.img-preview-count{position:absolute;bottom:4px;left:4px;background:rgba(0,0,0,0.55);color:#fff;font-size:9.5px;font-weight:600;font-family:var(--font-mono);padding:1px 5px;border-radius:var(--r-xs);pointer-events:none}
.drag-overlay{position:absolute;inset:0;z-index:100;background:rgba(55,48,163,0.07);border:2px dashed var(--accent);border-radius:var(--r-lg);display:none;align-items:center;justify-content:center;pointer-events:none}
.drag-overlay.active{display:flex}
.drag-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--accent-ink)}
.drag-overlay-inner svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;opacity:.7}
.drag-overlay-inner span{font-size:13px;font-weight:600}
.assign{display:flex;align-items:center;gap:8px;flex-shrink:0}
.assign-label{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:.02em}
.assign-select{height:30px;padding:0 28px 0 11px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:12px;outline:none;font-weight:500;min-width:140px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' 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 8px center;background-size:12px;appearance:none;-webkit-appearance:none;cursor:pointer}
.assign-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.assign-select.human{background-color:var(--accent-softer);color:var(--accent-ink);border-color:var(--accent-soft)}
.info-panel{width:260px;flex-shrink:0;background:var(--surface);border-left:.5px solid var(--line);display:flex;flex-direction:column;overflow-y:auto}
.info-section{padding:18px;border-bottom:.5px solid var(--line)}
.info-section h4{font-size:10px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.info-input{width:100%;height:32px;padding:0 11px;background:var(--fill);border:.5px solid transparent;border-radius:var(--r-sm);color:var(--ink);font-size:12px;outline:none;transition:all .15s var(--ease)}
.info-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.info-input::placeholder{color:var(--ink-4)}
.tags-row{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;min-height:4px}
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-full);font-size:11px;font-weight:500;background:var(--tag-bg);color:var(--tag-fg)}
.tag-x{opacity:.4;font-size:12px;line-height:1;transition:opacity .12s;margin-right:-2px}
.tag-x:hover{opacity:1;color:var(--danger)}
.tag-c0{--tag-bg:rgba(55,48,163,0.1);--tag-fg:#3730a3}
.tag-c1{--tag-bg:rgba(4,120,87,0.1);--tag-fg:#047857}
.tag-c2{--tag-bg:rgba(180,83,9,0.1);--tag-fg:#b45309}
.tag-c3{--tag-bg:rgba(185,28,28,0.1);--tag-fg:#b91c1c}
.tag-c4{--tag-bg:rgba(124,58,237,0.1);--tag-fg:#7c3aed}
.tag-c5{--tag-bg:rgba(15,118,110,0.1);--tag-fg:#0f766e}
.tag-c6{--tag-bg:rgba(194,65,12,0.1);--tag-fg:#c2410c}
.tag-c7{--tag-bg:rgba(3,105,161,0.1);--tag-fg:#0369a1}
.tag-c8{--tag-bg:rgba(190,18,60,0.1);--tag-fg:#be123c}
.tag-c9{--tag-bg:rgba(79,70,229,0.1);--tag-fg:#4f46e5}
[data-theme="dark"] .tag-c0{--tag-bg:rgba(129,140,248,0.16);--tag-fg:#a5b4fc}
[data-theme="dark"] .tag-c1{--tag-bg:rgba(52,211,153,0.16);--tag-fg:#6ee7b7}
[data-theme="dark"] .tag-c2{--tag-bg:rgba(251,191,36,0.16);--tag-fg:#fcd34d}
[data-theme="dark"] .tag-c3{--tag-bg:rgba(248,113,113,0.16);--tag-fg:#fca5a5}
[data-theme="dark"] .tag-c4{--tag-bg:rgba(167,139,250,0.16);--tag-fg:#c4b5fd}
[data-theme="dark"] .tag-c5{--tag-bg:rgba(45,212,191,0.16);--tag-fg:#5eead4}
[data-theme="dark"] .tag-c6{--tag-bg:rgba(251,146,60,0.16);--tag-fg:#fdba74}
[data-theme="dark"] .tag-c7{--tag-bg:rgba(56,189,248,0.16);--tag-fg:#7dd3fc}
[data-theme="dark"] .tag-c8{--tag-bg:rgba(244,114,182,0.16);--tag-fg:#f9a8d4}
[data-theme="dark"] .tag-c9{--tag-bg:rgba(129,140,248,0.16);--tag-fg:#a5b4fc}
.cf-item{margin-bottom:12px}
.cf-item:last-child{margin-bottom:0}
.cf-key{font-size:10px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.cf-del{opacity:.3;font-size:12px;color:var(--danger);padding:2px 4px;transition:opacity .12s;border-radius:var(--r-xs)}
.cf-del:hover{opacity:1;background:var(--danger-soft)}
.cf-val{width:100%;padding:9px 11px;background:var(--fill);border:.5px solid transparent;border-radius:var(--r-sm);color:var(--ink);font-size:12px;outline:none;resize:vertical;min-height:56px;line-height:1.5;font-family:inherit;transition:all .15s var(--ease)}
.cf-val:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.cf-add-row{display:flex;gap:6px;margin-top:10px}
.orders{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.ord-tabs{display:flex;gap:2px;padding:14px 22px;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:.5px solid var(--line);flex-shrink:0;align-items:center}
.ord-tab{padding:7px 14px;border-radius:var(--r-full);font-size:12px;font-weight:500;color:var(--ink-3);transition:all .15s var(--ease)}
.ord-tab:hover{color:var(--ink);background:var(--fill)}
.ord-tab.on{background:var(--ink);color:var(--bg);font-weight:600}
.ord-tab.check-tab.on{background:#7c3aed;color:#fff}
.ord-scroll{flex:1;overflow-y:auto;padding:22px}
.table-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs)}
table{width:100%;border-collapse:collapse}
th{padding:12px 16px;text-align:left;font-size:10px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.09em;border-bottom:.5px solid var(--line);background:var(--surface-2)}
td{padding:13px 16px;border-bottom:.5px solid var(--line);vertical-align:middle;font-size:12.5px;color:var(--ink)}
tr:last-child td{border-bottom:none}
.ord-row{transition:background .1s var(--ease)}
.ord-row:hover td{background:var(--fill)}
.sbadge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:600}
.sbadge::before{content:'';width:5px;height:5px;border-radius:50%}
.platform-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--r-full);font-size:10px;font-weight:600;letter-spacing:.02em}
.platform-tag.wa{background:var(--wa-soft);color:var(--wa)}
.platform-tag.fb{background:var(--fb-soft);color:var(--fb)}
.platform-tag.ig{background:var(--ig-soft);color:var(--ig)}
.pag{display:flex;align-items:center;padding:13px 16px;border-top:.5px solid var(--line);gap:8px;background:var(--surface-2)}
.pag-info{font-size:11px;color:var(--ink-4);font-family:var(--font-mono);flex:1}
.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;padding:28px}
.agent-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-xs);transition:all .2s var(--ease)}
.agent-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--line-2)}
.agent-card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.agent-av{width:42px;height:42px;border-radius:var(--r-full);background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:600;flex-shrink:0;box-shadow:var(--shadow-sm)}
.agent-info{flex:1;min-width:0}
.agent-name{font-size:14px;font-weight:600;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agent-user{font-size:11.5px;color:var(--ink-4);font-family:var(--font-mono);margin-top:2px}
.agent-status{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:var(--r-full)}
.agent-status.on{background:var(--ok-soft);color:var(--ok)}
.agent-status.off{background:var(--danger-soft);color:var(--danger)}
.agent-status-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.agent-actions{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:.5px solid var(--line)}
.agent-add{background:var(--surface);border:1.5px dashed var(--line-strong);border-radius:var(--r-lg);padding:36px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transition:all .2s var(--ease);color:var(--ink-4)}
.agent-add:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-softer)}
.agent-add svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.agent-add span{font-size:13px;font-weight:500}
.empty{text-align:center;padding:56px 20px}
.empty-i{width:46px;height:46px;border-radius:var(--r-md);background:var(--fill);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.empty-i svg{width:20px;height:20px;fill:none;stroke:var(--ink-4);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.empty p{font-size:13px;color:var(--ink-4);font-weight:500}
.spin{text-align:center;padding:40px;color:var(--ink-4);font-size:12.5px}
.toast{position:fixed;bottom:28px;right:28px;padding:11px 18px;background:var(--ink);color:var(--bg);border-radius:var(--r-md);font-size:13px;font-weight:500;opacity:0;transform:translateY(8px) scale(.96);transition:all .25s var(--ease-spring);pointer-events:none;z-index:9999;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-lg)}
.toast.on{opacity:1;transform:translateY(0) scale(1)}
.toast-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--ok)}
.toast.err .toast-dot{background:var(--danger)}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-xl);padding:28px;width:380px;box-shadow:var(--shadow-xl);position:relative;animation:slideIn .25s var(--ease-out)}
.modal.wide{width:440px;max-height:84vh;overflow-y:auto}
.modal h3{font-family:var(--font-display);font-size:17px;font-weight:600;margin-bottom:20px;letter-spacing:-.02em}
.modal-btns{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}
.modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;background:var(--fill);color:var(--ink-3);display:flex;align-items:center;justify-content:center;transition:all .12s var(--ease)}
.modal-close:hover{background:var(--fill-2);color:var(--ink)}
.modal-close svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}
.fc-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}
.fc-type,.fc-val{height:34px;padding:0 11px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:12px;outline:none;transition:all .15s var(--ease)}
.fc-type{min-width:120px;cursor:pointer}
.fc-val{flex:1}
.fc-val:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.fc-rm{width:30px;height:34px;color:var(--ink-4);font-size:14px;border-radius:var(--r-sm);transition:all .12s var(--ease);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-rm:hover{background:var(--danger-soft);color:var(--danger)}
select{height:30px;padding:0 26px 0 10px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:11.5px;outline:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' 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 7px center;background-size:11px;appearance:none;-webkit-appearance:none}
select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.check-row{display:flex;align-items:center;gap:10px;padding:4px 0}
.check-row input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.check-row label{font-size:13px;color:var(--ink);cursor:pointer}
.modal-err{color:var(--danger);font-size:12px;min-height:16px;margin-top:10px;font-weight:500}

/* =====================================================
   工具箱面板 & OXXO Modal
   ===================================================== */

.tools-overlay{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,0.18);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .15s var(--ease)}
.tools-panel{position:fixed;left:calc(var(--rail-w) + 10px);bottom:70px;width:280px;background:var(--surface);border:.5px solid var(--line-2);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:401;animation:slideInLeft .2s var(--ease-out);overflow:hidden}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-8px) scale(.97)}to{opacity:1;transform:translateX(0) scale(1)}}
.tools-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:.5px solid var(--line)}
.tools-panel-title{font-size:12px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em}
.tools-panel-close{width:24px;height:24px;border-radius:50%;background:var(--fill);color:var(--ink-3);display:flex;align-items:center;justify-content:center;transition:all .12s var(--ease)}
.tools-panel-close:hover{background:var(--fill-2);color:var(--ink)}
.tools-panel-close svg{width:12px;height:12px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round}
.tools-panel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}
.tool-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px 14px;background:var(--fill);border:.5px solid var(--line);border-radius:var(--r-lg);cursor:pointer;transition:all .15s var(--ease);text-align:center}
.tool-card:hover{background:var(--accent-softer);border-color:var(--accent-soft);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.tool-card-icon{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tool-card-icon svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.tool-icon-oxxo{background:rgba(227,6,19,0.1);color:#e30613}
.tool-icon-ads{background:linear-gradient(135deg,var(--accent),var(--accent-hover));box-shadow:0 6px 20px var(--accent-soft)}
.tool-icon-ads svg{stroke:#fff;width:22px;height:22px}
.tool-card-name{font-size:12.5px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.tool-card-desc{font-size:11px;color:var(--ink-4);line-height:1.3}
.rail-btn.tools-open{background:var(--rail-active);color:#fff}
.oxxo-modal{width:440px!important;max-height:88vh;overflow-y:auto}
.oxxo-modal-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.oxxo-logo-icon{width:44px;height:44px;border-radius:var(--r-lg);background:linear-gradient(135deg,#e30613,#c00510);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 20px rgba(227,6,19,.25)}
.oxxo-logo-icon svg{width:22px;height:22px;stroke:#fff}
.oxxo-modal-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-.02em}
.oxxo-modal-sub{font-size:12px;color:var(--ink-4);margin-top:3px;font-family:var(--font-mono)}
.oxxo-divider{height:.5px;background:var(--line);margin:20px 0}
.oxxo-result-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.oxxo-success-icon{width:36px;height:36px;border-radius:50%;background:var(--ok);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}
.oxxo-info-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.oxxo-info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--fill);border-radius:var(--r-md)}
.oxxo-info-label{font-size:12px;color:var(--ink-3);font-weight:500}
.oxxo-info-val{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--ink)}
.oxxo-screenshot-wrap{background:var(--fill);border-radius:var(--r-lg);border:.5px solid var(--line-2);overflow:hidden;margin-bottom:14px;min-height:80px;display:flex;align-items:center;justify-content:center}
.oxxo-screenshot-loading{padding:24px;text-align:center;color:var(--ink-4);font-size:12.5px;display:flex;flex-direction:column;align-items:center;gap:10px}
.oxxo-spinner{width:22px;height:22px;border:2.5px solid var(--fill-2);border-top-color:var(--danger);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.oxxo-actions{display:flex;gap:10px}

/* =====================================================
   订单审核页面
   ===================================================== */
.orderreview-wrap{flex:1;overflow:hidden;display:flex;flex-direction:column;height:100%}
.orderreview-frame{flex:1;border:none;width:100%;height:100%;background:transparent}
.orderreview-wrap iframe{display:block}
.rv-wrap{display:flex;flex:1;overflow:hidden;height:100%}
.rv-side{width:160px;flex-shrink:0;background:var(--surface);border-right:.5px solid var(--line);padding:12px 0;display:flex;flex-direction:column;gap:2px}
.rv-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}
.rv-nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-md);font-size:12.5px;font-weight:500;color:var(--ink-4);cursor:pointer;transition:all .12s var(--ease);user-select:none}
.rv-nav-item svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.rv-nav-item:hover{background:var(--fill);color:var(--ink-2)}
.rv-nav-item.on{background:var(--accent-soft);color:var(--accent-ink)}
.rv-main{flex:1;overflow-y:auto;padding:24px 28px 48px;background:var(--bg)}
.rv-tab-content{display:none}
.rv-tab-content.active{display:block}
.rv-page-head{margin-bottom:20px}
.rv-page-head h2{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.02em}
.rv-page-head p{font-size:12.5px;color:var(--ink-4);margin-top:4px}
.rv-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);margin-bottom:14px;overflow:hidden}
.rv-card-head{padding:11px 18px;border-bottom:.5px solid var(--line);display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em}
.rv-field-row{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:.5px solid var(--line);font-size:13px;color:var(--ink-2);gap:12px}
.rv-field-row:last-child{border-bottom:none}
.rv-input{height:30px;padding:0 10px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:12.5px;outline:none;font-family:inherit;transition:all .12s var(--ease)}
.rv-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.rv-select{height:30px;padding:0 26px 0 10px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);font-size:12.5px;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;font-family:inherit;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' 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 7px center;background-size:11px}
.rv-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.rv-textarea{width:100%;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-md);color:var(--ink);font-size:12px;font-family:var(--font-mono);padding:10px 12px;outline:none;resize:vertical;line-height:1.6;transition:all .12s var(--ease)}
.rv-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.rv-stat{background:var(--fill);border:.5px solid var(--line);border-radius:var(--r-md);padding:10px 12px;text-align:center}
.rv-stat-num{font-size:18px;font-weight:700;font-family:var(--font-mono);color:var(--ink);line-height:1.2}
.rv-stat-label{font-size:10.5px;color:var(--ink-4);margin-top:3px}
.rv-pill{padding:4px 12px;border-radius:var(--r-full);border:.5px solid var(--line-2);font-size:12px;color:var(--ink-3);cursor:pointer;transition:all .12s var(--ease);user-select:none}
.rv-pill:hover{background:var(--fill);color:var(--ink-2)}
.rv-pill.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink)}
.rv-th{padding:9px 16px;text-align:left;font-size:10px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em;border-bottom:.5px solid var(--line);background:var(--surface-2)}
.rv-td{padding:11px 16px;border-bottom:.5px solid var(--line);font-size:12.5px;color:var(--ink-2);vertical-align:middle}
.rv-tr:last-child .rv-td{border-bottom:none}
.rv-tr:hover .rv-td{background:var(--fill);color:var(--ink)}
.rv-toggle{display:flex;align-items:center;cursor:pointer}
.rv-toggle input{display:none}
.rv-toggle-track{width:36px;height:20px;background:var(--fill-2);border:.5px solid var(--line-2);border-radius:10px;position:relative;transition:all .15s var(--ease);flex-shrink:0}
.rv-toggle-track::after{content:'';position:absolute;width:14px;height:14px;background:var(--ink-4);border-radius:7px;top:2px;left:2px;transition:left .15s var(--ease),background .15s var(--ease)}
.rv-toggle input:checked + .rv-toggle-track{background:var(--accent-soft);border-color:var(--accent)}
.rv-toggle input:checked + .rv-toggle-track::after{left:18px;background:var(--accent)}


/* ======================== Ads Console ========================= */

/* ── 全屏覆盖层 ── */
.ads-overlay{position:fixed;inset:0;z-index:300;background:var(--bg);display:none;flex-direction:column;overflow:hidden;font-size:13px;-webkit-text-size-adjust:100%;text-size-adjust:100%}
.ads-overlay.on{display:flex}
.ads-panel{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}

/* ── Topbar ── */
.ads-topbar{background:var(--bg);border-bottom:.5px solid var(--line);height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:10;flex-shrink:0}
.ads-topbar-left{display:flex;align-items:center;gap:10px}
.ads-topbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ads-logo-mark{width:22px;height:22px;border-radius:6px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
.ads-title{font-size:15px;font-weight:600;letter-spacing:-.015em;font-family:var(--font-display)}
.ads-back{width:30px;height:30px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--ink-3);transition:all .12s var(--ease);border:.5px solid var(--line)}
.ads-back:hover{background:var(--fill-2);color:var(--ink)}
.ads-back svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ads-store-select{background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);padding:5px 10px;font-size:12.5px;color:var(--ink-3);outline:none;cursor:pointer;font-family:inherit}
.ads-store-select:hover{color:var(--ink)}

/* ── Period tabs ── */
.ads-period-tabs{display:flex;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm);padding:2px;gap:1px}
.ads-period-btn{border:none;background:transparent;padding:4px 9px;font-size:11.5px;font-weight:500;color:var(--ink-4);border-radius:4px;cursor:pointer;transition:all .12s var(--ease);white-space:nowrap;font-family:inherit}
.ads-period-btn:hover{color:var(--ink-2)}
.ads-period-btn.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-xs)}
.ads-custom-date{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--fill);border:.5px solid var(--line-2);border-radius:var(--r-sm)}
@keyframes ads-spin{to{transform:rotate(360deg)}}
.ads-spinning svg{animation:ads-spin .8s linear infinite}

/* ── Content area ── */
.ads-content{padding:16px 20px 48px;display:flex;flex-direction:column;gap:10px;max-width:1600px;margin:0 auto;width:100%}

/* ── AI card ── */
.ads-ai-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);padding:14px 18px;position:relative;overflow:hidden}
.ads-ai-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5}
.ads-ai-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.ads-ai-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:ads-glow 2s ease-in-out infinite}
@keyframes ads-glow{0%,100%{box-shadow:0 0 0 0 var(--accent-soft)}50%{box-shadow:0 0 0 4px transparent}}
.ads-ai-title{font-size:13px;font-weight:600;color:var(--ink)}
.ads-ai-status{font-size:11px;color:var(--ink-4);margin-left:auto;font-family:var(--font-mono)}
.ads-ai-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
@media(max-width:700px){.ads-ai-grid{grid-template-columns:1fr}}
.ads-ai-block{background:var(--fill);border:.5px solid var(--line);border-radius:var(--r-md);padding:11px 13px;min-height:80px}
.ads-ai-block-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);margin-bottom:5px;display:flex;align-items:center;gap:5px}
.ads-ai-block-text{font-size:13px;line-height:1.6;color:var(--ink-3)}

/* ── Metrics ── */
.ads-metrics-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
@media(max-width:1000px){.ads-metrics-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.ads-metrics-grid{grid-template-columns:repeat(2,1fr)}}
.ads-metric-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;transition:border-color .12s}
.ads-metric-card:hover{border-color:var(--line-strong)}
.ads-highlight{border-color:var(--accent-soft);background:linear-gradient(135deg,var(--surface),var(--accent-softer))}
.ads-metric-label{font-size:11px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.ads-metric-val{font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.5px;font-family:var(--font-mono)}
.ads-highlight .ads-metric-val{color:var(--accent-ink)}
.ads-metric-delta{font-size:11px;margin-top:5px;font-family:var(--font-mono);color:var(--ink-4)}
.ads-metric-delta.up{color:var(--ok)}
.ads-metric-delta.down{color:var(--danger)}

/* ── Chart cards ── */
.ads-charts-row{display:grid;grid-template-columns:3fr 2fr;gap:10px;align-items:stretch}
@media(max-width:800px){.ads-charts-row{grid-template-columns:1fr}}

/*
 * 关键修复：
 * 1. 容器固定高度，用 flexbox 让 canvas 填满剩余空间
 * 2. canvas 不设 height 属性，完全由 CSS 驱动
 * 3. maintainAspectRatio: false 已在 JS 中设置
 * JS 中不再动态修改容器高度
 */
.ads-chart-card{
  background:var(--surface);
  border:.5px solid var(--line);
  border-radius:var(--r-lg);
  padding:16px 18px;
  height:300px;           /* 固定高度，JS 不再改它 */
  display:flex;
  flex-direction:column;
}
.ads-chart-card canvas{
  flex:1;                 /* 撑满容器剩余高度 */
  min-height:0 !important;
  width:100% !important;
}
.ads-chart-card > div[id$="-empty"]{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink-4);
  font-size:12px;
}

.ads-card-title{font-size:11px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}
#ads-store-chart{display:block;margin:0 auto}

/* ── Table extras ── */
.ads-pause-btn{width:24px;height:24px;border-radius:var(--r-sm);background:transparent;border:.5px solid var(--line);color:var(--ink-4);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .12s var(--ease)}
.ads-pause-btn:hover{background:var(--warn-soft);color:var(--warn);border-color:transparent}
.ads-pause-btn:disabled{opacity:.35;cursor:not-allowed}
.ads-copy-btn{width:20px;height:20px;border-radius:4px;background:transparent;border:none;color:var(--ink-5);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s,color .1s,background .1s}
tr:hover .ads-copy-btn{opacity:1}
.ads-copy-btn:hover{background:var(--accent-soft);color:var(--accent-ink)}

.table-wrap{overflow:auto;max-height:400px;scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}
.table-wrap::-webkit-scrollbar{width:5px;height:5px}
.table-wrap::-webkit-scrollbar-track{background:transparent}
.table-wrap::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px}
.table-wrap::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}