:root{--txt:#eef1f8;--muted:#98a1b8;--faint:#5c647e;--border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.13);--grad:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);--glow:rgba(124,77,255,.55)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;color:var(--txt);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;background:radial-gradient(900px 520px at 14% -12%,rgba(99,102,241,.2),transparent 60%),radial-gradient(820px 600px at 104% -4%,rgba(168,85,247,.14),transparent 55%),#070a12}.page{min-height:100%;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px}.app{width:100%;max-width:820px;background:linear-gradient(180deg,#151a2ed1,#0b0f1ce0);border:1px solid var(--border);border-radius:26px;overflow:hidden;box-shadow:0 40px 90px -24px #000000bf,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.top{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}.brand{font-size:16px;font-weight:600;letter-spacing:-.01em}.live{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:#8be0b8;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);padding:3px 9px;border-radius:999px}.live i{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 8px #34d399;animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;background:var(--grad);box-shadow:0 0 0 1px #ffffff1a}.logout{font-size:12.5px;color:var(--faint);cursor:pointer;background:none;border:none;font-family:inherit}.logout:hover{color:var(--muted)}.tabs{display:flex;gap:7px;padding:13px 16px;border-bottom:1px solid var(--border);overflow-x:auto}.tab{display:flex;align-items:center;gap:8px;padding:10px 15px;border-radius:13px;font-size:13.5px;font-weight:500;color:var(--muted);white-space:nowrap;cursor:pointer;border:1px solid transparent;transition:all .16s;background:none;font-family:inherit}.tab svg{width:17px;height:17px;opacity:.85}.tab:hover{color:var(--txt);background:#ffffff0a;border-color:var(--border)}.tab.on{color:#fff;background:var(--grad);border-color:transparent;box-shadow:0 8px 24px -8px var(--glow),inset 0 1px #ffffff2e}.tab.on svg{opacity:1}.body{padding:24px}.row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}label{font-size:14px;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--txt)}label svg{width:16px;height:16px;color:var(--muted)}.chip{font-size:12px;font-weight:500;color:var(--muted);background:#ffffff0a;border:1px solid var(--border);padding:4px 12px;border-radius:999px}.chip.bad{color:#f0b76b}textarea,input[type=text],input[type=password]{width:100%;background:#080b14b8;border:1px solid var(--border);border-radius:14px;color:var(--txt);padding:14px 15px;font-size:14px;line-height:1.65;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s}textarea:focus,input:focus{border-color:#8b5cf68c;box-shadow:0 0 0 3px #7c4dff29}textarea::placeholder,input::placeholder{color:var(--faint)}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:13px;letter-spacing:.01em}.meta{display:flex;align-items:center;justify-content:space-between;margin-top:10px;font-size:12.5px}.meta .seg{color:var(--faint)}.meta .opt{display:inline-flex;align-items:center;gap:5px;font-weight:500}.meta .opt svg{width:14px;height:14px}.actions{display:flex;gap:13px;margin-top:22px}.send{flex:1;height:52px;border:none;border-radius:15px;background:var(--grad);color:#fff;font-size:15px;font-weight:600;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;box-shadow:0 12px 32px -10px var(--glow),inset 0 1px #ffffff2e;transition:transform .12s,box-shadow .2s}.send:hover{box-shadow:0 16px 40px -10px var(--glow)}.send:active{transform:scale(.985)}.send:disabled{opacity:.5;cursor:not-allowed}.send svg{width:19px;height:19px}.pause{flex:0 0 152px;height:52px;border-radius:15px;background:#ffffff0a;border:1px solid var(--border2);color:var(--txt);font-size:15px;font-weight:500;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background .15s}.pause:hover{background:#ffffff14}.pause svg{width:18px;height:18px}.pause.resume{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 8px 24px -10px var(--glow)}.cancel{flex:0 0 130px;height:52px;border-radius:15px;background:#f472721a;border:1px solid rgba(244,114,114,.35);color:#f08a8a;font-size:15px;font-weight:500;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background .15s}.cancel:hover{background:#f472722e}.cancel svg{width:18px;height:18px}.status{display:flex;align-items:center;gap:14px;margin-top:20px}.stat{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);white-space:nowrap}.stat .dot{width:8px;height:8px;border-radius:50%;background:var(--faint)}.stat .dot.live{background:#8b9cf8;box-shadow:0 0 8px #8b9cf8}.track{flex:1;height:7px;background:#ffffff0d;border:1px solid var(--border);border-radius:999px;overflow:hidden}.fill{height:100%;background:var(--grad);transition:width .3s}.csvbtn{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:#8b9cf8;background:#6366f11a;border:1px solid rgba(99,102,241,.28);padding:6px 12px;border-radius:999px;cursor:pointer;font-family:inherit}.csvbtn:hover{background:#6366f12b}.csvbtn svg{width:14px;height:14px}.csvpanel{margin-top:12px;border:1px solid var(--border);border-radius:14px;padding:13px 15px;background:#080b1480}.csvhead{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--muted)}.csvhead>span{display:inline-flex;align-items:center;gap:7px;flex:1}.csvhead svg{width:15px;height:15px}.csvhead b{color:var(--txt);font-weight:600}.csvhead .clear{margin-left:auto;font-size:12px;font-weight:500;color:#f08a8a;cursor:pointer;background:none;border:none;font-family:inherit}.csvhead .clear:hover{color:#f5a9a9}.tokens{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:12px}.tklabel{font-size:12px;color:var(--faint)}.tok{font-size:11.5px;color:#c4a4f7;background:#a855f71a;border:1px solid rgba(168,85,247,.3);padding:3px 9px;border-radius:8px;cursor:pointer;font-weight:600;font-family:ui-monospace,monospace}.tok:hover{background:#a855f733}.preview{margin-top:10px;font-size:12.5px;color:var(--muted);background:#080b1480;border:1px dashed var(--border);border-radius:10px;padding:9px 12px;line-height:1.5}.preview .pl{color:#8b9cf8;font-weight:600;margin-right:6px}.tplwrap{position:relative}.tplmenu{position:absolute;right:0;top:calc(100% + 8px);z-index:50;width:300px;max-height:300px;overflow:auto;background:linear-gradient(180deg,#0d1120,#0a0d18);border:1px solid var(--border2);border-radius:14px;padding:8px;box-shadow:0 24px 60px -18px #000000bf;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.tplitem{display:flex;align-items:stretch;gap:6px;margin-bottom:4px}.tplpick{flex:1;text-align:left;background:none;border:none;border-radius:9px;padding:8px 10px;cursor:pointer;font-family:inherit;overflow:hidden}.tplpick:hover{background:#ffffff0d}.tplpick .tn{display:block;font-size:13px;font-weight:600;color:var(--txt)}.tplpick .tb{display:block;font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.tpldel{flex:0 0 auto;width:32px;border:none;background:none;color:var(--faint);border-radius:9px;cursor:pointer}.tpldel:hover{background:#f472721f;color:#f08a8a}.tpldel svg{width:15px;height:15px}.tplsave{display:flex;gap:7px;padding:8px 4px 4px;border-top:1px solid var(--border);margin-top:4px}.tplsave input{flex:1;padding:8px 11px;font-size:13px}.tplsave button{flex:0 0 auto;padding:0 13px;border-radius:10px;background:var(--grad);color:#fff;border:none;font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer}.tplsave button:disabled{opacity:.45;cursor:not-allowed}.logwrap{margin-top:22px;border:1px solid var(--border);border-radius:14px;background:#080b148c;overflow:hidden}.loghead{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--border);font-size:12.5px;font-weight:600;color:var(--muted)}.loghead svg{width:15px;height:15px}.loghead .badge{font-weight:500;font-size:11px;color:#8b9cf8;background:#6366f11f;border:1px solid rgba(99,102,241,.28);padding:2px 8px;border-radius:999px}.loghead .clear{margin-left:auto;font-size:12px;font-weight:500;color:var(--faint);cursor:pointer;background:none;border:none;font-family:inherit}.loghead .clear:hover{color:var(--muted)}.log{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;line-height:2;padding:8px 14px 11px;max-height:230px;overflow:auto}.ln{display:flex;align-items:center;gap:12px}.ln .ts{color:var(--faint)}.ln .num{flex:1;color:var(--muted)}.ln .st{font-weight:600}.st-queued{color:#8a93ab}.st-sending{color:#8b9cf8}.st-delivered,.st-sent{color:#8be0b8}.st-failed{color:#f08a8a}.st-skipped{color:#caa46a}.st-info{color:#8b9cf8}.empty{color:var(--faint);font-size:13px;padding:18px 4px}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;color:var(--muted);font-weight:500;padding:9px 10px;border-bottom:1px solid var(--border)}td{padding:9px 10px;border-bottom:1px solid var(--border);color:var(--txt)}td.muted{color:var(--muted)}.convo{border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px;background:#080b1466}.convo .who{font-weight:600;font-size:13px;margin-bottom:8px;font-family:ui-monospace,monospace}.bubbles{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.bub{max-width:80%;padding:8px 12px;border-radius:14px;font-size:13px;line-height:1.5}.bub.in{align-self:flex-start;background:#ffffff0d;border:1px solid var(--border);border-bottom-left-radius:5px}.bub.out{align-self:flex-end;background:linear-gradient(135deg,#6366f152,#a855f752);border:1px solid rgba(139,92,246,.4);border-bottom-right-radius:5px}.bub .t{font-size:10px;color:var(--faint);margin-top:3px}.replybar{display:flex;gap:8px;margin-top:6px}.replybar input{flex:1}.replybar button{flex:0 0 auto;padding:0 18px;border-radius:12px;background:var(--grad);color:#fff;border:none;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}.replybar button:disabled{opacity:.45;cursor:not-allowed}.tabcount{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:2px;border-radius:999px;background:#a855f7;color:#fff;font-size:11px;font-weight:700}.tab.on .tabcount{background:#ffffff40}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:14px 0 22px}.statcard{border:1px solid var(--border);border-radius:14px;padding:14px 16px;background:#080b1473}.statcard .k{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px}.statcard .k .d{width:7px;height:7px;border-radius:50%}.statcard .v{font-size:24px;font-weight:700;margin-top:7px;letter-spacing:-.02em}.chartwrap{border:1px solid var(--border);border-radius:14px;padding:16px 18px;background:#080b1473;margin-bottom:22px}.chartwrap .h{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:16px}.bars{display:flex;align-items:flex-end;gap:5px;height:150px}.barcol{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%}.bar{width:62%;max-width:26px;min-height:2px;border-radius:6px 6px 0 0;background:var(--grad);position:relative;transition:height .3s}.bar .dl{position:absolute;bottom:0;left:0;right:0;background:#8bdeb8d9;border-radius:0 0 6px 6px}.barlabel{font-size:9px;color:var(--faint);white-space:nowrap}.legend{display:flex;gap:18px;margin-top:14px;font-size:12px;color:var(--muted)}.legend span{display:inline-flex;align-items:center;gap:6px}.legend i{width:11px;height:11px;border-radius:3px;display:inline-block}.login{max-width:380px;margin:0 auto}.login h1{font-size:20px;font-weight:600;text-align:center;margin:0 0 4px}.login p{text-align:center;color:var(--muted);font-size:13px;margin:0 0 22px}.login label{margin:14px 0 7px}.err{color:#f08a8a;font-size:13px;margin-top:12px;text-align:center}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.toaster{position:fixed;right:20px;bottom:20px;z-index:1000;display:flex;flex-direction:column;gap:12px;max-width:340px}.toast{display:flex;align-items:flex-start;gap:12px;padding:13px 15px;border-radius:16px;background:linear-gradient(180deg,#0a0d18,#080b14);border:1px solid var(--border);box-shadow:0 20px 50px -16px #000000b3;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:relative;overflow:hidden;animation:toastIn .28s cubic-bezier(.2,.9,.3,1)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}.toast .accent{position:absolute;left:0;top:0;bottom:0;width:3px}.toast .ico{width:34px;height:34px;flex:0 0 auto;border-radius:10px;display:flex;align-items:center;justify-content:center}.toast .ico svg{width:18px;height:18px}.toast .tx{flex:1;padding-top:1px}.toast .tt{font-size:13.5px;font-weight:600;color:var(--txt)}.toast .sb{font-size:12.5px;color:var(--muted);margin-top:2px}.toast .x{color:var(--faint);cursor:pointer;font-size:17px;line-height:1;padding-left:4px}.toast .x:hover{color:var(--muted)}.toast.ok .accent{background:#34d399}.toast.ok .ico{background:#34d39921;color:#34d399}.toast.err .accent{background:#f08a8a}.toast.err .ico{background:#f08a8a21;color:#f08a8a}.toast.info .accent{background:#8b9cf8}.toast.info .ico{background:#8b9cf824;color:#8b9cf8}@media (max-width:560px){.pause{flex:0 0 56px}.pause span{display:none}.cancel{flex:0 0 56px}.cancel span{display:none}.body{padding:18px}.toaster{left:14px;right:14px;max-width:none}}.section-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;margin-top:8px}.section-title svg{width:18px;height:18px;opacity:.85}.section-title .pill,.pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;background:#7c6cf62e;color:#c4bbff;border:1px solid rgba(124,108,246,.35);margin-left:8px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width:560px){.grid2{grid-template-columns:1fr}}.kv{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px}.kv span{font-size:12px;color:#8b8ba7}.kv code{font-family:inherit;font-size:13px;word-break:break-all;cursor:pointer}.notice{padding:14px 16px;border-radius:12px;background:#7c6cf61a;border:1px solid rgba(124,108,246,.3)}.notice code{display:block}button.ghost{background:transparent;border:1px solid rgba(255,255,255,.18);color:#d7d7ea}button.mini{padding:5px 10px;font-size:12px;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#d7d7ea;margin-left:6px}button.mini svg{width:14px;height:14px}button.mini.danger{color:#f0a0a0;border-color:#f0787866;background:#f0505014}
