@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&family=DM+Mono:wght@400;500&display=swap";:root,[data-theme=dark]{--bg0: #0a1311;--bg1: #0f1a17;--bg2: #13201d;--bg3: #182824;--bg4: #1e2e29;--border: rgba(255, 255, 255, .08);--border-hi: rgba(255, 255, 255, .14);--border-strong: rgba(255, 255, 255, .2);--text0: #E8EDEB;--text1: #9FAEA9;--text2: #6B7976;--text-disabled: #4A534F;--green: #128C7E;--green-dim: #0E7A6E;--green-dark: #0B6559;--green-glow: rgba(18, 140, 126, .22);--green-bg: rgba(18, 140, 126, .1);--green-border: rgba(18, 140, 126, .32);--blue: #60A5FA;--blue-bg: rgba(96, 165, 250, .1);--blue-border: rgba(96, 165, 250, .28);--amber: #F59E0B;--amber-bg: rgba(245, 158, 11, .1);--amber-border: rgba(245, 158, 11, .28);--red: #EF4444;--red-bg: rgba(239, 68, 68, .1);--red-border: rgba(239, 68, 68, .28);--purple: #A78BFA;--purple-bg: rgba(167, 139, 250, .1);--purple-border: rgba(167, 139, 250, .28);--chat-me-bg: #128C7E;--chat-me-text: #FFFFFF;--chat-them-bg: #1F2A28;--chat-them-text: #E8EDEB;--chat-timestamp: #6B7976;--shadow-sm: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.2);--shadow-md: 0 4px 8px rgba(0,0,0,.4), 0 2px 4px rgba(0,0,0,.3);--shadow-lg: 0 12px 24px rgba(0,0,0,.5), 0 4px 8px rgba(0,0,0,.3);--shadow-xl: 0 24px 48px rgba(0,0,0,.6);--scrollbar: rgba(255,255,255,.1)}[data-theme=light]{--bg0: #F7F8F7;--bg1: #F1F3F2;--bg2: #FFFFFF;--bg3: #F7F8F7;--bg4: #FFFFFF;--border: rgba(15, 32, 28, .08);--border-hi: rgba(15, 32, 28, .14);--border-strong: rgba(15, 32, 28, .22);--text0: #0F201C;--text1: #556661;--text2: #7A8B86;--text-disabled: #B0BDB9;--green: #128C7E;--green-dim: #0E7A6E;--green-dark: #0B6559;--green-glow: rgba(18, 140, 126, .15);--green-bg: rgba(18, 140, 126, .07);--green-border: rgba(18, 140, 126, .28);--blue: #2563EB;--blue-bg: rgba(37, 99, 235, .06);--blue-border: rgba(37, 99, 235, .22);--amber: #D97706;--amber-bg: rgba(217, 119, 6, .07);--amber-border: rgba(217, 119, 6, .24);--red: #DC2626;--red-bg: rgba(220, 38, 38, .06);--red-border: rgba(220, 38, 38, .22);--purple: #7C3AED;--purple-bg: rgba(124, 58, 237, .06);--purple-border: rgba(124, 58, 237, .22);--chat-me-bg: #128C7E;--chat-me-text: #FFFFFF;--chat-them-bg: #F1F3F2;--chat-them-text: #0F201C;--chat-timestamp: #7A8B86;--shadow-sm: 0 1px 3px rgba(15,32,28,.06), 0 1px 2px rgba(15,32,28,.04);--shadow-md: 0 4px 8px rgba(15,32,28,.06), 0 2px 4px rgba(15,32,28,.04);--shadow-lg: 0 12px 24px rgba(15,32,28,.08), 0 4px 8px rgba(15,32,28,.06);--shadow-xl: 0 24px 48px rgba(15,32,28,.12);--scrollbar: rgba(15,32,28,.15)}:root{--r: 8px;--r-sm: 6px;--r-lg: 10px;--r-xl: 14px;--r-full: 999px;--font: "DM Sans", -apple-system, BlinkMacSystemFont, "PingFang SC", "Segoe UI", sans-serif;--mono: "DM Mono", "SFMono-Regular", ui-monospace, "JetBrains Mono", Consolas, monospace;--t: .15s cubic-bezier(.4, 0, .2, 1);--t-slow: .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font);font-size:14px;line-height:1.5;color:var(--text0);background:var(--bg0);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01";transition:background var(--t-slow),color var(--t-slow)}a{color:var(--green);text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--bg1);border-right:1px solid var(--border);padding:16px 0;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:20}.logo-area{padding:0 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);margin-bottom:12px}.logo-mark{width:28px;height:28px;border-radius:var(--r-sm);background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-weight:600;font-size:13px}.logo-text{font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--text0);flex:1}.logo-ver{font-family:var(--mono);font-size:10px;padding:2px 6px;background:var(--green-bg);color:var(--green);border-radius:var(--r-sm);letter-spacing:.04em;font-weight:500}.nav-group-label{font-size:10.5px;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.1em;padding:14px 16px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13px;color:var(--text1);cursor:pointer;position:relative;transition:all var(--t);border:0;background:transparent;width:100%;text-align:left;font-family:inherit;line-height:1.4}.nav-item:hover{color:var(--text0);background:var(--bg2)}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.75}.nav-item.active svg{opacity:1}.nav-count{margin-left:auto;font-family:var(--mono);font-size:10.5px;background:var(--green-bg);color:var(--green);padding:1px 7px;border-radius:var(--r-full);font-weight:500;min-width:20px;text-align:center}.user-block{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg1);display:flex;align-items:center;gap:10px}.user-email{font-size:12px;color:var(--text0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.ws-pill{display:inline-flex;align-items:center;gap:5px;background:var(--green-bg);border:1px solid var(--green-border);border-radius:var(--r-full);padding:3px 10px;font-size:11px;color:var(--green);font-weight:500;white-space:nowrap}.ws-pill-dot,.ws-status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.topbar{height:56px;background:var(--bg0);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}.breadcrumb-sep{color:var(--text-disabled)}.breadcrumb-current{color:var(--text0);font-weight:500}.topbar-actions{display:flex;align-items:center;gap:12px}.theme-toggle{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);padding:2px}.theme-toggle button{font-family:inherit;font-size:12px;padding:4px 10px;border:0;background:transparent;color:var(--text1);cursor:pointer;border-radius:4px;transition:all var(--t);display:inline-flex;align-items:center;gap:5px}.theme-toggle button.active{background:var(--bg3);color:var(--text0);box-shadow:var(--shadow-sm)}.page{padding:24px;max-width:100%;animation:pageIn .35s cubic-bezier(.4,0,.2,1)}@keyframes pageIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:600;letter-spacing:-.02em;margin:0;color:var(--text0);line-height:1.2}.page.chat-page{padding:16px 24px 24px;height:calc(100vh - 56px);display:flex;flex-direction:column}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color var(--t)}.card:hover{border-color:var(--border-hi)}.card-header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);gap:12px}.card-title{font-size:14px;font-weight:600;margin:0;color:var(--text0)}.card-meta{font-size:11.5px;color:var(--text2);display:flex;align-items:center;gap:8px}.card-link{font-size:11.5px;font-weight:500;color:var(--green);cursor:pointer;transition:opacity var(--t)}.card-link:hover{opacity:.75}.card-body{padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;padding:8px 14px;border:1px solid var(--border-hi);border-radius:var(--r-sm);background:var(--bg2);color:var(--text0);cursor:pointer;transition:all var(--t);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--bg3);border-color:var(--border-strong)}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:2px solid var(--green);outline-offset:2px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--green);border-color:var(--green);color:#fff;font-weight:500}.btn-primary:hover{background:var(--green-dim);border-color:var(--green-dim);box-shadow:0 2px 10px var(--green-glow)}.btn-primary:active{background:var(--green-dark);border-color:var(--green-dark)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text1)}.btn-ghost:hover{background:var(--bg2);color:var(--text0)}.btn-outline{background:transparent;border-color:var(--border-hi);color:var(--text0);display:inline-flex;align-items:center;gap:6px}.btn-outline:hover{background:var(--bg2)}.btn-danger{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.btn-danger:hover{background:var(--red);border-color:var(--red);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-sm.danger{color:var(--red);border-color:var(--red-border);background:transparent}.btn-sm.danger:hover{background:var(--red);color:#fff;border-color:var(--red)}.btn-lg{padding:10px 18px;font-size:14px}.btn-full{width:100%;justify-content:center}.badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:500;padding:2px 7px;border-radius:var(--r-sm);border:1px solid transparent;white-space:nowrap;line-height:1.4;letter-spacing:.01em}.badge:before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-success{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.badge-success:before{background:var(--green)}.badge-info{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.badge-info:before{background:var(--blue)}.badge-warning{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.badge-warning:before{background:var(--amber)}.badge-danger{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.badge-danger:before{background:var(--red)}.badge-purple{background:var(--purple-bg);color:var(--purple);border-color:var(--purple-border)}.badge-purple:before{background:var(--purple)}.badge-muted,.badge-default{background:var(--bg3);color:var(--text1);border-color:var(--border)}.badge-muted:before,.badge-default:before{background:var(--text2)}.badge.pulse:before,.badge-success:before{animation:pulse-dot 2s ease-in-out infinite}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.table thead{background:var(--bg1)}.table th{font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;white-space:nowrap}.table td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text0)}.table tbody tr{transition:background var(--t)}.table tbody tr:hover{background:var(--bg1)}.table tbody tr:last-child td{border-bottom:0}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:500;color:var(--text1)}.form-actions{margin-top:16px;display:flex;gap:8px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border)}.input,input[type=text].input,input[type=number].input,input[type=email].input,input[type=password].input,select.input,textarea.input{font-family:inherit;font-size:13px;line-height:1.4;padding:8px 11px;background:var(--bg1);color:var(--text0);border:1px solid var(--border-hi);border-radius:var(--r-sm);transition:all var(--t);width:100%}.input::placeholder,textarea.input::placeholder{color:var(--text2)}.input:hover{border-color:var(--border-strong)}.input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow);background:var(--bg2)}.input:disabled{opacity:.5;cursor:not-allowed}textarea.input{resize:vertical;min-height:72px;font-family:inherit}.metrics{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:16px;margin-bottom:20px}.metric{position:relative;padding:18px 20px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all var(--t-slow)}.metric:hover{border-color:var(--border-hi);transform:translateY(-1px);box-shadow:var(--shadow-md)}.metric-label{font-size:11px;color:var(--text1);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px;font-weight:500}.metric-value{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--text0);letter-spacing:-.02em;line-height:1;margin:0}.metric-sub{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:12px;color:var(--text2)}.metric-accent,.metric.metric-primary{background:linear-gradient(135deg,var(--green-bg) 0%,transparent 70%),var(--bg2);border-color:var(--green-border)}.metric-accent .metric-value,.metric.metric-primary .metric-value{color:var(--green);font-size:34px}.metric-accent:before,.metric.metric-primary:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--green) 0%,transparent 80%)}.metric-value.color-green{color:var(--green)}.metric-value.color-blue{color:var(--blue)}.metric-value.color-red{color:var(--red)}.metric-value.color-amber{color:var(--amber)}.pbar{width:100%;height:4px;background:var(--bg3);border-radius:var(--r-full);overflow:hidden;position:relative}.pbar.tall{height:6px}.pbar-fill{height:100%;border-radius:var(--r-full);transition:width var(--t-slow);background:var(--green)}.pbar-fill.pbar-green{background:var(--green)}.big-bar{height:8px;background:var(--bg3);border-radius:var(--r-full);overflow:hidden;position:relative}.big-bar-fill{height:100%;background:var(--green);border-radius:var(--r-full);transition:width var(--t-slow)}.big-bar-pct{position:absolute;right:0;top:-18px;font-size:11px;color:var(--text2)}.bar-label{font-size:11px;color:var(--text1);min-width:48px;text-align:right;font-family:var(--mono)}.inline-pbar{display:inline-flex;align-items:center;gap:8px}.chat-layout{display:grid;grid-template-columns:320px 1fr;gap:0;flex:1;min-height:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.chat-conv-list{border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg1);min-height:0}.chat-conv-header{padding:14px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.chat-conv-item{padding:12px 14px;display:grid;grid-template-columns:36px 1fr auto;gap:10px;cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--t);position:relative}.chat-conv-item:hover,.chat-conv-item.active{background:var(--bg2)}.chat-conv-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--green)}.chat-conv-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--green-dim),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;letter-spacing:.02em}.chat-conv-main{min-width:0;display:flex;flex-direction:column;gap:3px}.chat-conv-top{display:flex;align-items:baseline;gap:8px;justify-content:space-between}.chat-conv-number{font-size:13px;font-weight:500;color:var(--text0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-conv-time{font-size:10.5px;color:var(--text2);font-family:var(--mono);flex-shrink:0}.chat-conv-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-conv-preview{font-size:11.5px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-conv-badge{background:var(--green);color:#fff;font-size:10px;font-weight:600;min-width:18px;height:18px;border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);padding:0 5px;line-height:1;flex-shrink:0}.chat-detail{display:flex;flex-direction:column;background:var(--bg0);min-height:0;min-width:0}.chat-detail-header{padding:10px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;background:var(--bg2)}.chat-detail-header .chat-conv-avatar{width:40px;height:40px;font-size:13px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text2);font-size:13px;gap:10px;padding:40px;text-align:center}.chat-messages{flex:1;overflow-y:auto;padding:20px 20px 12px;display:flex;flex-direction:column;gap:10px;align-items:flex-start;min-height:0}.chat-bubble{max-width:72%;padding:8px 12px;border-radius:var(--r-lg);font-size:13.5px;line-height:1.45;word-break:break-word;display:flex;flex-direction:column;gap:3px;position:relative}.chat-bubble.received{align-self:flex-start;background:var(--chat-them-bg);color:var(--chat-them-text);border-top-left-radius:var(--r-sm)}.chat-bubble.sent{align-self:flex-end;background:var(--chat-me-bg);color:var(--chat-me-text);border-top-right-radius:var(--r-sm);margin-left:auto}.chat-bubble-body{font-size:13.5px;line-height:1.45;color:inherit;word-break:break-word}.chat-bubble-meta{font-size:10.5px;color:var(--chat-timestamp);font-family:var(--mono);display:flex;align-items:center;gap:4px;margin-top:2px}.chat-bubble.sent .chat-bubble-meta{color:#ffffffb8;justify-content:flex-end}.chat-bubble-status{display:inline-flex;align-items:center;gap:2px;letter-spacing:-1px}.chat-bubble-status.status-read{color:#7ed7ff}.chat-media{margin-top:4px;border-radius:var(--r-sm);overflow:hidden;max-width:260px}.chat-media-image img,.chat-media-image{max-width:260px;max-height:200px;border-radius:var(--r-sm);cursor:zoom-in;display:block;transition:transform var(--t)}.chat-media-image:hover{transform:scale(1.02)}.chat-media-video video{max-width:260px;max-height:200px;border-radius:var(--r-sm);display:block}.chat-media-audio audio{width:240px;display:block}.chat-media-doc{padding:10px 12px;background:#00000026;border-radius:var(--r-sm);display:flex;align-items:center;gap:8px;font-size:12.5px;color:inherit}.chat-media-caption{margin-top:4px;font-size:12.5px;opacity:.88}.chat-reply{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg2);display:flex;gap:10px;align-items:flex-end}.chat-reply textarea,.chat-reply .input{flex:1;min-height:38px;max-height:120px;resize:none;border-radius:var(--r-lg)}.chat-window-pill{padding:3px 10px;background:var(--green-bg);color:var(--green);font-size:11px;font-weight:500;border-radius:var(--r-full);border:1px solid var(--green-border);display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.chat-window-pill:before{content:"";width:5px;height:5px;background:currentColor;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:lightboxIn .18s ease}@keyframes lightboxIn{0%{opacity:0}to{opacity:1}}.lightbox-overlay img{max-width:90vw;max-height:90vh;border-radius:var(--r);box-shadow:var(--shadow-xl)}.lightbox-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:var(--r-full);background:#ffffff1f;color:#fff;border:0;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t)}.lightbox-close:hover{background:#ffffff38}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9998;display:flex;align-items:center;justify-content:center;padding:20px;animation:lightboxIn .18s ease}.modal-content{background:var(--bg4);border:1px solid var(--border-hi);border-radius:var(--r-lg);min-width:480px;max-width:90vw;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:modalIn .22s cubic-bezier(.4,0,.2,1)}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:12px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.modal-title{font-size:14.5px;font-weight:600;margin:0;color:var(--text0)}.pricing-card-mine{margin:18px 0 20px;background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:var(--r);overflow:hidden;transition:box-shadow var(--t-slow)}.pricing-card-mine:hover{box-shadow:var(--shadow-md)}.pricing-card-header{padding:12px 18px;display:flex;align-items:baseline;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);background:var(--green-bg)}.pricing-card-title{font-size:13.5px;font-weight:600;color:var(--text0);display:flex;align-items:center;gap:8px}.pricing-card-title:before{content:"$";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--green);color:#fff;font-family:var(--mono);font-weight:600;font-size:11px;border-radius:var(--r-sm)}.pricing-card-sub{font-size:11px;color:var(--text2);letter-spacing:.02em}.pricing-card-body{padding:0}.pricing-card-body table{margin:0}.pricing-mine-table th{background:var(--bg1)}.pricing-card-footer{padding:10px 18px;background:var(--bg1);border-top:1px solid var(--border);font-size:11.5px;color:var(--text1);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;line-height:1.7}.pricing-card-footer strong{color:var(--text0)}.alert{padding:10px 14px;border:1px solid;border-radius:var(--r-sm);font-size:13px;line-height:1.5}.alert-success{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.alert-info{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.alert-warning{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.alert-danger{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.api-method-get,.api-method-post{font-family:var(--mono);font-size:11px;font-weight:600;padding:2px 7px;border-radius:3px;letter-spacing:.04em}.api-method-get{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}.api-method-post{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.log-stream{max-height:420px;overflow-y:auto;padding:8px 0}.log-item{padding:6px 14px;display:grid;grid-template-columns:auto 80px 1fr auto;gap:10px;align-items:center;border-bottom:1px solid var(--border);font-size:12px;transition:background var(--t)}.log-item:hover{background:var(--bg1)}.log-dot{width:7px;height:7px;border-radius:50%;background:var(--text2)}.log-dot.green{background:var(--green)}.log-dot.red{background:var(--red)}.log-dot.amber{background:var(--amber)}.log-time{font-family:var(--mono);color:var(--text2);font-size:11px}.log-to{font-family:var(--mono);color:var(--text0)}.phone-row{padding:10px 14px;display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;border-bottom:1px solid var(--border);transition:background var(--t)}.phone-row:hover{background:var(--bg1)}.phone-num{font-family:var(--mono);color:var(--text0)}.mono{font-family:var(--mono)}.small{font-size:12px}.dim,.muted{color:var(--text2)}.color-green{color:var(--green)}.color-blue{color:var(--blue)}.color-red{color:var(--red)}.color-amber{color:var(--amber)}.link{color:var(--green);cursor:pointer;font-weight:500;transition:opacity var(--t)}.link:hover{opacity:.75;text-decoration:underline;text-underline-offset:2px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.empty-state{padding:40px 20px;text-align:center;color:var(--text2);font-size:13px;line-height:1.7}.empty-state:before{content:"○";display:block;font-size:24px;color:var(--text-disabled);margin-bottom:8px}.loading-tip{padding:20px;text-align:center;color:var(--text2);font-size:12.5px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 20%,var(--green-bg) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,var(--green-bg) 0%,transparent 60%),var(--bg0);padding:20px}.login-card{width:420px;max-width:100%;background:var(--bg2);border:1px solid var(--border-hi);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-lg)}@media (max-width: 960px){.app{grid-template-columns:64px 1fr}.sidebar{padding:12px 0}.logo-text,.logo-ver,.nav-group-label,.nav-item span,.user-email,.user-role{display:none}.nav-item{justify-content:center;padding:10px}.nav-item.active:before{display:none}.user-block{justify-content:center}.metrics{grid-template-columns:1fr 1fr}.chat-layout{grid-template-columns:260px 1fr}}@media (max-width: 640px){.page{padding:16px}.page-title{font-size:18px}.metrics,.chat-layout,.form-grid{grid-template-columns:1fr}}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{position:relative;background:var(--bg1);border-right:1px solid var(--border);height:100vh;position:sticky;top:0;overflow-y:auto;display:flex;flex-direction:column;padding:0;width:auto!important}.sidebar-logo{padding:14px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo .logo-mark{width:28px;height:28px;border-radius:var(--r-sm);background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.sidebar-logo .logo-mark svg{width:14px;height:14px;color:#fff;fill:#fff}.sidebar-logo .logo-mark svg path{fill:#fff!important}.sidebar-logo .logo-text{font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--text0);flex:1}.sidebar-logo .logo-version{font-family:var(--mono);font-size:10px;padding:2px 6px;background:var(--green-bg);color:var(--green);border-radius:var(--r-sm);letter-spacing:.04em;font-weight:500}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-section{margin-bottom:4px}.nav-section-label{font-size:10.5px;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.1em;padding:12px 16px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13px;color:var(--text1);cursor:pointer;position:relative;transition:all var(--t);text-decoration:none;line-height:1.4}.nav-item:hover{color:var(--text0);background:var(--bg2);text-decoration:none}.nav-item.active{color:var(--green);background:var(--green-bg);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--green);border-radius:0 2px 2px 0}.nav-icon{width:16px;height:16px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;opacity:.75}.nav-icon svg{width:16px;height:16px}.nav-item.active .nav-icon{opacity:1}.nav-label{flex:1}.nav-badge{font-family:var(--mono);font-size:10px;color:#fff;padding:1px 6px;border-radius:var(--r-full);font-weight:600;min-width:18px;text-align:center;line-height:1.4}.sidebar-footer{flex-shrink:0;padding:12px;border-top:1px solid var(--border);background:var(--bg1)}.user-row{display:flex;align-items:center;gap:10px;padding:4px}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--green-dim),var(--green));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0;letter-spacing:.02em}.user-info{flex:1;min-width:0}.user-name{font-size:12.5px;color:var(--text0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.user-role{font-size:10.5px;color:var(--text2)}.ws-status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pulse-dot 2s ease-in-out infinite}.ws-status-dot.offline{background:var(--red);animation:none;opacity:.7}.main-area{display:flex;flex-direction:column;min-width:0;min-height:100vh}.topbar{height:52px;flex-shrink:0;background:var(--bg0);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-crumb{font-size:13px;color:var(--text2);font-weight:500}.topbar-sep{color:var(--text-disabled);font-size:13px}.topbar-title{font-size:13px;color:var(--text0);font-weight:500}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.page-content{flex:1;min-width:0;overflow-x:auto}.app{display:contents}.chat-messages{flex:1;overflow-y:auto;padding:20px 24px 16px;display:flex;flex-direction:column;gap:8px;align-items:stretch;min-height:0;background:var(--bg0)}.chat-msg{display:flex;max-width:72%;margin-bottom:2px}.chat-msg-inbound{align-self:flex-start;margin-right:auto}.chat-msg-outbound{align-self:flex-end;margin-left:auto;justify-content:flex-end}.chat-bubble{max-width:100%;padding:8px 12px;border-radius:var(--r-lg);font-size:13.5px;line-height:1.45;word-break:break-word;display:flex;flex-direction:column;gap:4px;position:relative;min-width:60px}.chat-msg-inbound .chat-bubble{background:var(--chat-them-bg);color:var(--chat-them-text);border-top-left-radius:var(--r-sm)}.chat-msg-outbound .chat-bubble{background:var(--chat-me-bg);color:var(--chat-me-text);border-top-right-radius:var(--r-sm)}.chat-bubble-body{font-size:13.5px;line-height:1.45;color:inherit;word-break:break-word;white-space:pre-wrap;overflow-wrap:anywhere}.chat-bubble-meta{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--chat-timestamp);font-family:var(--mono);margin-top:2px;white-space:nowrap}.chat-msg-outbound .chat-bubble-meta{color:#ffffffb8;justify-content:flex-end}.chat-msg-inbound .chat-bubble-meta{justify-content:flex-start}.chat-bubble-status{display:inline-flex;align-items:center;gap:2px;letter-spacing:-.5px;font-size:10px}.chat-bubble-status.status-read{color:#9edfff}.chat-bubble-status.status-failed{color:#ffb3b3}.chat-media{margin:2px 0;border-radius:var(--r-sm);overflow:hidden}.chat-media-image img{max-width:240px;max-height:200px;border-radius:var(--r-sm);cursor:zoom-in;display:block;transition:transform var(--t)}.chat-media-image img:hover{transform:scale(1.02)}.chat-media-video video{max-width:240px;max-height:180px;border-radius:var(--r-sm);display:block;background:#000}.chat-media-audio{min-width:240px}.chat-media-audio audio{width:100%;display:block}.chat-media-doc{padding:10px 12px;background:#0000002e;border-radius:var(--r-sm);display:flex;align-items:center;gap:8px;font-size:12.5px;color:inherit;min-width:200px}.chat-msg-inbound .chat-media-doc{background:#ffffff0a}.chat-media-caption{margin-top:4px;font-size:12.5px;opacity:.88;line-height:1.4}.btn-full{width:100%;justify-content:center;font-size:12.5px;padding:7px 10px}.btn-full svg{width:13px;height:13px;flex-shrink:0}.sidebar-footer .btn{font-size:12px;padding:7px 10px;line-height:1.2;gap:6px;display:inline-flex;align-items:center;justify-content:center}.sidebar-footer .btn svg{width:14px;height:14px;flex-shrink:0;display:inline-block}.sidebar svg{max-width:16px;max-height:16px;flex-shrink:0}.sidebar-logo .logo-mark svg{max-width:14px;max-height:14px}.sidebar{display:flex;flex-direction:column}.sidebar-nav{flex:1 1 auto;overflow-y:auto;min-height:0}.sidebar-footer{flex-shrink:0;position:sticky;bottom:0;background:var(--bg1);border-top:1px solid var(--border);padding:10px 12px;z-index:2}.sidebar-footer .btn-full{margin-top:8px;padding:6px 10px;font-size:12px;gap:6px}.chat-msg{max-width:60%}@media (max-width: 1200px){.chat-msg{max-width:70%}}@media (max-width: 900px){.chat-msg{max-width:80%}}.chat-messages{padding:20px 24px 16px 20px}.chat-conv-item.selected{background:var(--bg2);position:relative}.chat-conv-item.selected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--green)}.chat-conv-item.selected .chat-conv-number{color:var(--green);font-weight:600}.chat-conv-item.unread .chat-conv-number{font-weight:600;color:var(--text0)}.chat-conv-item.unread .chat-conv-preview{color:var(--text1);font-weight:500}.page-header .btn-ghost{border:1px solid var(--border-hi);background:var(--bg2);padding:6px 12px}.page-header .btn-ghost:hover{background:var(--bg3);border-color:var(--border-strong);color:var(--text0)}.topbar{padding:0 20px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px;padding-right:4px}.topbar-right .ws-pill{border:1px solid var(--green-border)}.chat-conv-list{min-width:0}.chat-conv-item{padding:11px 14px;gap:11px;transition:all var(--t)}.chat-conv-avatar{width:36px;height:36px;font-size:11.5px;letter-spacing:.02em;background:linear-gradient(135deg,var(--green-dim),var(--green))}.chat-conv-bottom{position:relative;min-height:16px}.chat-detail-header{padding:12px 18px;background:var(--bg2);border-bottom:1px solid var(--border);gap:12px}.chat-reply{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg2);gap:10px;display:flex;align-items:flex-end}.chat-reply .input{flex:1;border-radius:var(--r-lg);padding:8px 14px;resize:none;min-height:38px}.chat-reply .btn-primary{padding:8px 16px;font-size:13px;border-radius:var(--r-lg)}.chat-msg-outbound .chat-media-audio audio{filter:invert(0)}.chat-media-image img:hover{transform:scale(1.015);opacity:.95}.page.chat-page{padding:16px 20px;height:calc(100vh - 52px);display:flex;flex-direction:column;gap:12px;overflow:hidden}.page.chat-page .page-header{flex-shrink:0;margin-bottom:0}.page.chat-page .chat-layout{flex:1;min-height:0;height:auto}.page-subtitle{font-size:12.5px;color:var(--text2);margin:4px 0 0;line-height:1.5}.metrics{grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:20px}.metric-accent{display:none}.pricing-mine-table td.mono{white-space:nowrap}.chat-bubble-body{padding-right:40px}.chat-bubble-body:only-child{padding-right:0}[data-theme=light] .page{background:var(--bg0)}.theme-toggle-btn{width:30px;height:30px;border-radius:var(--r-sm);background:var(--bg2);border:1px solid var(--border-hi);color:var(--text1);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--t);flex-shrink:0}.theme-toggle-btn:hover{background:var(--bg3);border-color:var(--border-strong);color:var(--green);transform:scale(1.05)}.theme-toggle-btn:active{transform:scale(.95)}.theme-toggle-btn svg{display:block;transition:transform var(--t-slow)}.theme-toggle-btn:hover svg{transform:rotate(12deg)}.chat-bubble{min-width:80px}.chat-bubble-meta{align-self:flex-end;margin-top:4px}[data-theme=light] body{background:var(--bg0)}[data-theme=light] .nav-item svg{opacity:.65}[data-theme=light] .nav-item:hover svg,[data-theme=light] .nav-item.active svg{opacity:1}[data-theme=light] .table tbody tr:hover{background:var(--bg1)}[data-theme=light] .metric.metric-primary{background:linear-gradient(135deg,var(--green-bg) 0%,transparent 80%),var(--bg2);border:1px solid var(--green-border);box-shadow:var(--shadow-sm)}[data-theme=light] .chat-msg-inbound .chat-bubble{border:1px solid var(--border)}[data-theme=light] .pricing-card-header{background:var(--green-bg);border-bottom:1px solid var(--green-border)}[data-theme=light] .sidebar{background:var(--bg1);box-shadow:1px 0 3px #0f201c0a}[data-theme=light] .card:hover,[data-theme=light] .metric:hover{box-shadow:var(--shadow-md)}[data-theme=light] .ws-pill{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green)}[data-theme=light] .badge-muted,[data-theme=light] .badge-default{color:var(--text1);background:var(--bg1)}.chat-conv-item{position:relative}.chat-conv-crm-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:var(--r-full);background:var(--bg3);border:1px solid var(--border-hi);color:var(--text1);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);opacity:0;padding:0;line-height:1;z-index:2}.chat-conv-item:hover .chat-conv-crm-btn{opacity:1}.chat-conv-crm-btn:hover{background:var(--green);border-color:var(--green);color:#fff;transform:translateY(-50%) scale(1.1)}.chat-conv-crm-btn.in-crm{opacity:.6;background:transparent;border-color:var(--border);color:var(--text2)}.chat-conv-item:hover .chat-conv-crm-btn.in-crm{opacity:1;color:var(--green);border-color:var(--green-border);background:var(--green-bg);transform:translateY(-50%)}.chat-conv-item .chat-conv-badge{margin-right:24px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 60% 50% at 30% 20%,var(--green-bg) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 70% 80%,var(--green-bg) 0%,transparent 70%),var(--bg0);padding:20px;position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 0%,rgba(18,140,126,.06) 0%,transparent 40%);pointer-events:none}.login-card{width:420px;max-width:100%;background:var(--bg2);border:1px solid var(--border-hi);border-radius:var(--r-lg);padding:32px 32px 28px;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:loginIn .4s cubic-bezier(.4,0,.2,1)}@keyframes loginIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px}.login-logo .logo-mark{width:36px;height:36px;border-radius:var(--r);background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 12px var(--green-glow)}.login-logo .logo-mark svg{width:18px;height:18px}.login-logo .logo-mark svg path{fill:#fff!important}.login-title{font-size:20px;font-weight:600;letter-spacing:-.02em;color:var(--text0)}.login-sub{font-size:13px;color:var(--text1);margin:0 0 24px;line-height:1.5}.login-error{padding:10px 14px;background:var(--red-bg);color:var(--red);border:1px solid var(--red-border);border-radius:var(--r-sm);font-size:12.5px;line-height:1.6}.login-hint{font-size:11.5px;color:var(--text2);margin:0;text-align:center;letter-spacing:.02em}.login-card .form-group label{font-size:12px;color:var(--text1);font-weight:500;margin-bottom:5px;display:block}.login-card .input{padding:10px 12px;font-size:14px}.login-card .btn-lg{font-size:14px;font-weight:500;letter-spacing:.02em;padding:11px}.phone-row.unassigned{border-left:3px solid var(--amber);background:var(--amber-bg)}.phone-row.unassigned .phone-num:after{content:" ⚠ 未分配";color:var(--amber);font-size:11px;font-weight:500;font-family:var(--font);margin-left:6px}
