@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--color-primary:#0f172a;--color-accent:#0369a1;--color-accent-hover:#0284c7;--color-border:#e2e8f0;--color-background:#f8fafc;--color-text:#020617;--color-muted:#475569;--shadow-sm:0 1px 2px #0f172a0f;--shadow-md:0 4px 16px #0f172a14;--shadow-lg:0 12px 32px #0f172a1f;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--font-heading:"Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-body:"Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-family:var(--font-body);color:var(--color-text);background:var(--color-background);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{min-height:100vh;margin:0}h1,h2,h3{font-family:var(--font-heading);letter-spacing:-.02em;color:var(--color-primary)}code{font-family:var(--font-mono);color:var(--color-primary);background:#0369a114;border-radius:10px;padding:.12rem .4rem;font-size:.9em}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.shell{max-width:1120px;margin:0 auto;padding:24px 16px 64px}.topbar{z-index:20;border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;margin:-24px -16px 20px;padding:12px 16px;position:sticky;top:0}.topbar-inner{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:12px 16px;max-width:1120px;margin:0 auto;display:grid}.topbar-brand{justify-self:start;min-width:0}.topbar-nav{flex-wrap:wrap;justify-content:center;justify-self:center}.topbar-user-cluster{flex-direction:column;justify-self:end;align-items:flex-end;gap:8px;min-width:0;display:flex}.topbar-stats{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px 14px;display:flex}.topbar-stat{white-space:nowrap;background:#0369a114;border:1px solid #0369a124;border-radius:999px;align-items:baseline;gap:6px;padding:4px 10px;font-size:12px;line-height:1.2;display:inline-flex}.topbar-stat-label{color:var(--color-muted);font-weight:600}.topbar-stat-value{font-variant-numeric:tabular-nums;color:var(--color-accent);font-weight:800}.brand{align-items:center;gap:12px;min-width:0;display:flex}.brand-text{min-width:0}.logo{border:1px solid var(--color-border);width:36px;height:36px;box-shadow:var(--shadow-sm);object-fit:contain;background:#fff;border-radius:10px;flex-shrink:0;display:block}.brand h1{margin:0;font-size:17px;font-weight:700;line-height:1.25}.brand-tagline{color:var(--color-muted);white-space:nowrap;text-overflow:ellipsis;margin:2px 0 0;font-size:12px;overflow:hidden}.app-nav{flex-wrap:wrap;gap:4px;display:flex}.nav-link{cursor:pointer;color:var(--color-muted);background:0 0;border:1px solid #0000;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .18s,color .18s,border-color .18s}.nav-link:hover{color:var(--color-primary);background:#0f172a0a}.nav-link.on{color:var(--color-accent);background:#0369a114;border-color:#0369a133}.user-bar{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.user-name{color:var(--color-primary);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:13px;font-weight:600;overflow:hidden}@media (width<=900px){.topbar-inner{grid-template-columns:1fr;justify-items:stretch}.topbar-brand{order:1;justify-self:start}.topbar-user-cluster{order:2;align-items:flex-end}.topbar-nav{order:3;justify-self:center}.topbar-stats,.user-bar{justify-content:flex-end}}@media (width<=520px){.topbar-stats{flex-direction:column;align-items:stretch}.topbar-stat{white-space:normal;justify-content:space-between}}.row{justify-content:space-between;align-items:center;gap:12px;display:flex}.card{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);background:#fff;padding:18px}.grid{grid-template-columns:repeat(12,1fr);gap:12px;display:grid}.col-6{grid-column:span 6}.col-12{grid-column:span 12}@media (width<=820px){.col-6{grid-column:span 12}}label{color:#111827b3;gap:6px;font-size:12px;display:grid}input{border:1px solid var(--color-border);background:#fff;border-radius:12px;outline:none;padding:10px 12px;font-size:14px;transition:box-shadow .2s,border-color .2s,background .2s}input:focus{border-color:#0369a173;box-shadow:0 0 0 3px #0369a11f}.btn{border:1px solid var(--color-border);cursor:pointer;box-shadow:var(--shadow-sm);color:var(--color-primary);background:#fff;border-radius:12px;padding:10px 14px;font-weight:600;transition:transform .16s,box-shadow .2s,background .2s,border-color .2s}.btn:hover{box-shadow:var(--shadow-md);background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:var(--shadow-sm)}.btn.primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-outline{box-shadow:none;background:0 0;border-color:#cbd5e1}.btn-outline:hover{background:#0f172a0a}.pre{color:#ffffffe6;border-radius:var(--radius-md);background:#111827eb;padding:12px;font-size:12px;overflow:auto}.table{gap:6px;display:grid}.thead,.trow{grid-template-columns:86px minmax(180px,1.6fr) minmax(160px,1fr) 110px 140px;align-items:center;gap:10px;padding:10px;display:grid}.table-leads .thead,.table-leads .trow{grid-template-columns:36px minmax(56px,72px) minmax(56px,72px) minmax(120px,1fr) minmax(100px,1.15fr) minmax(72px,.85fr) minmax(56px,.65fr) minmax(110px,1fr) minmax(108px,120px)}.thead{color:#111827b3;border-bottom:1px solid #0f172a14;font-weight:600}.trow{box-shadow:var(--shadow-sm);background:#ffffff8c;border:1px solid #ffffff59;border-radius:14px;transition:box-shadow .2s,transform .16s,background .2s}.trow:hover{box-shadow:var(--shadow-md);background:#ffffffd1;transform:translateY(-1px)}.table-plan-billing .thead,.table-plan-billing .trow{grid-template-columns:minmax(140px,1.5fr) 92px 72px 72px 72px 100px}@media (width<=980px){.thead{display:none}.trow{grid-template-columns:1fr;gap:8px}.trow>div{grid-template-columns:92px 1fr;align-items:center;gap:10px;display:grid}.trow>div:before{color:#1118278c;font-size:12px;font-weight:600}.trow>div:first-child:before{content:"ID"}.trow>div:nth-child(2):before{content:"公司"}.trow>div:nth-child(3):before{content:"手机号"}.trow>div:nth-child(4):before{content:"状态"}.trow>div:nth-child(5):before{content:"操作"}.table-leads .trow>div.cell-check{justify-content:flex-start}.table-leads .trow>div.cell-check:before{display:none}.table-leads .trow>div:first-child:before{content:""}.table-leads .trow>div:nth-child(2):before{content:"序号"}.table-leads .trow>div:nth-child(3):before{content:"ID"}.table-leads .trow>div:nth-child(4):before{content:"时间"}.table-leads .trow>div:nth-child(5):before{content:"公司名称"}.table-leads .trow>div:nth-child(6):before{content:"关键词"}.table-leads .trow>div:nth-child(7):before{content:"姓名"}.table-leads .trow>div:nth-child(8):before{content:"手机号"}.table-leads .trow>div:nth-child(9):before{content:"操作"}.table-plan-billing .trow>div:first-child:before{content:"名称"}.table-plan-billing .trow>div:nth-child(2):before{content:"价格"}.table-plan-billing .trow>div:nth-child(3):before{content:"周期"}.table-plan-billing .trow>div:nth-child(4):before{content:"日上限"}.table-plan-billing .trow>div:nth-child(5):before{content:"赠送点数"}.table-plan-billing .trow>div:nth-child(6):before{content:"操作"}}.plan-desc-block{white-space:pre-wrap;color:#111827c7;background:#7c3aed0f;border:1px solid #7c3aed1f;border-radius:10px;margin-top:8px;padding:10px 12px;font-size:12px;line-height:1.5}.muted{color:#1118278c;font-size:12px}.error{color:#7f1d1df2;border-radius:var(--radius-md);white-space:pre-wrap;background:#fef2f2cc;border:1px solid #ef444438;margin-top:1rem;padding:12px}.kpis{grid-template-columns:repeat(12,1fr);gap:12px;display:grid}.kpi{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#ffffff8c;border:1px solid #ffffff59;grid-column:span 4;padding:14px 14px 12px}.kpi-title{color:#11182799;font-size:12px;font-weight:700}.kpi-value{font-family:var(--font-heading);letter-spacing:-.02em;margin-top:6px;font-size:28px;font-weight:700}.kpi-sub{color:#1118278c;margin-top:4px;font-size:12px}@media (width<=980px){.kpi{grid-column:span 12}}.filters{grid-template-columns:1.4fr 1fr;align-items:end;gap:12px;display:grid}@media (width<=980px){.filters{grid-template-columns:1fr}}.seg{justify-content:flex-end;gap:8px;display:flex}.seg-btn{border:1px solid var(--color-border);cursor:pointer;background:#fff;border-radius:999px;padding:10px 12px;font-weight:700;transition:box-shadow .2s,background .2s,border-color .2s}.seg-btn:hover{box-shadow:var(--shadow-sm);background:#f8fafc}.seg-btn.on{color:var(--color-accent);background:#0369a11a;border-color:#0369a140}.leads-toolbar{flex-wrap:wrap;align-items:end;gap:10px;display:flex}.leads-toolbar-card{border:1px solid var(--color-border);background:#f8fafc;border-radius:14px;padding:12px}.leads-list-card{border:1px solid var(--color-border);background:#fff;border-radius:14px;padding:10px}.leads-toolbar__search{flex:420px;align-items:end;gap:8px;min-width:320px;display:flex}.leads-toolbar__search label{flex:auto}.leads-toolbar__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.leads-toolbar__meta{margin-top:10px}@media (width<=980px){.leads-toolbar{align-items:stretch}.leads-toolbar__search{flex-basis:100%;min-width:100%}}.badge{border:1px solid var(--color-border);background:#fff;border-radius:999px;align-items:center;padding:6px 10px;font-size:12px;font-weight:800;display:inline-flex}.badge.good{background:#10b9811f;border-color:#10b98140}.badge.warn{background:#f973161f;border-color:#f9731638}.mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.good{color:#10b981f2}.bad{color:#ef4444eb}.list{gap:10px;display:grid}.list-item{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);background:#fff;padding:12px}.empty{border-radius:var(--radius-lg);background:#fff6;border:1px dashed #0369a140;margin-top:12px;padding:18px}.empty-title{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:700}.pager{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.pager-page-size{border:1px solid var(--color-border);color:var(--color-primary);cursor:pointer;background:#fff;border-radius:10px;outline:none;min-width:92px;padding:8px 10px;font-size:14px;font-weight:600;transition:border-color .2s,box-shadow .2s}.pager-page-size:focus{border-color:#0369a173;box-shadow:0 0 0 3px #0369a11f}.contact-page .contact-qr-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-top:20px;display:grid}.contact-qr-card{border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);background:#ffffffa6;border:1px solid #0f172a14;padding:16px}.contact-qr-title{color:#111827e0;margin-bottom:12px;font-size:15px;font-weight:700}.contact-qr-img{object-fit:contain;background:#fff;border:1px solid #0f172a0f;border-radius:12px;width:200px;height:200px;margin:0 auto;display:block}.contact-qr-hint{margin-top:12px;font-size:13px;line-height:1.45}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.export-menu{display:inline-block;position:relative}.export-menu__summary{cursor:pointer;appearance:none;justify-content:center;align-items:center;margin:0;list-style:none;display:inline-flex}.export-menu__summary::-webkit-details-marker{display:none}.export-menu__summary:after{content:"▾";opacity:.75;margin-left:6px;font-size:.75em}.export-menu__panel{z-index:30;border:1px solid var(--color-border);min-width:168px;box-shadow:var(--shadow-md);background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);left:0}.export-menu__item{box-sizing:border-box;text-align:left;width:100%;font:inherit;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:10px;padding:10px 12px;font-weight:600;transition:background .16s;display:block}.export-menu__item:hover{background:#0f172a0f}.toast{color:#ffffffeb;box-shadow:var(--shadow-lg);background:#111827eb;border:1px solid #ffffff24;border-radius:14px;max-width:min(420px,100vw - 36px);padding:12px 14px;position:fixed;bottom:18px;right:18px}.login-page{place-items:center;min-height:100vh;padding:24px 16px;display:grid}.login-shell{width:100%;max-width:520px}.login-brand{align-items:center;gap:14px;display:flex}.login-brand .logo{width:44px;height:44px}.login-title{font-family:var(--font-heading);letter-spacing:-.02em;color:#111827eb;font-weight:900}.login-card{margin-top:18px}.login-card-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px 16px;display:flex}.login-card-title{margin:0;font-size:1.25rem}.login-card-hint{font-size:12px}.login-card-fields{margin-top:14px}.login-actions{margin-top:22px}.login-btn-primary{box-sizing:border-box;width:100%;display:block}.chat-shell{grid-template-columns:minmax(220px,300px) minmax(0,1fr);align-items:stretch;gap:16px;min-height:min(420px,65vh);margin-top:14px;display:grid}@media (width<=860px){.chat-shell{grid-template-columns:1fr}}.chat-customer-panel{border:1px solid var(--color-border);background:#ffffff8c;border-radius:14px;flex-direction:column;min-width:0;padding:12px;display:flex}.chat-customer-list{flex-direction:column;gap:8px;max-height:min(60vh,520px);display:flex;overflow-y:auto}.chat-customer-item{text-align:left;border:1px solid var(--color-border);cursor:pointer;background:#ffffffbf;border-radius:12px;width:100%;padding:10px 12px;transition:box-shadow .15s,border-color .15s;display:block}.chat-customer-item:hover{box-shadow:var(--shadow-sm)}.chat-customer-item.on{box-shadow:var(--shadow-sm);background:#0ea5e914;border-color:#0ea5e973}.chat-customer-id{word-break:break-all;color:#111827d9;font-size:11px;line-height:1.35}.chat-customer-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:12px;line-height:1.35;display:-webkit-box;overflow:hidden}.chat-customer-meta{color:#1118278c;justify-content:space-between;gap:8px;margin-top:8px;font-size:11px;display:flex}.chat-detail-panel{border:1px solid var(--color-border);background:#ffffff8c;border-radius:14px;min-width:0;padding:14px 16px}.chat-detail-placeholder{text-align:center;place-items:center;min-height:280px;padding:24px;display:grid}.chat-thread{flex-direction:column;gap:12px;max-height:min(65vh,640px);margin-top:8px;padding:4px 2px 8px;display:flex;overflow-y:auto}.chat-msg-row{justify-content:flex-start;width:100%;display:flex}.chat-msg-block{align-items:flex-start;gap:10px;min-width:0;max-width:100%;display:flex}.chat-msg-tag{border:1px solid #0000;border-radius:8px;flex-shrink:0;margin-top:10px;padding:4px 9px;font-size:11px;font-weight:800}.chat-msg-tag.in{color:#1e40aff2;background:#3b82f624;border-color:#3b82f647}.chat-msg-tag.out{color:#581c87f2;background:#7c3aed24;border-color:#7c3aed47}.chat-msg-body{flex:1;min-width:0}.chat-bubble{word-break:break-word;white-space:pre-wrap;border-radius:14px;max-width:min(100%,560px);padding:10px 14px;line-height:1.5}.chat-bubble.in{background:#fffffff2;border:1px solid #0ea5e933}.chat-bubble.out{background:#0ea5e914;border:1px solid #0ea5e940}.chat-bubble.out.failed{background:#ef444414;border-color:#ef444480}.chat-msg-meta{margin-top:5px;padding:0 2px;font-size:11px;font-weight:600}
