:root{--bg: #eaeef6;--surface: #ffffff;--surface-2: #f4f7fc;--surface-3: #eef2f9;--line: #e4e9f2;--line-strong: #d4dbe8;--text: #141b2e;--text-soft: #586079;--text-mute: #8089a0;--brand: #1f9b8e;--brand-2: #1a7393;--brand-3: #155f7d;--brand-ink: #0c4a47;--brand-tint: #e8f6f3;--brand-tint-2: #e9f1fb;--accent: #6c5ce7;--ink: #0a0f1d;--ink-1: #0d1426;--ink-2: #121b30;--ink-3: #1a2540;--ink-line: #25324f;--ink-line-2: #324164;--ink-text: #d4ddf0;--ink-soft: #97a4c4;--ink-mute: #65739a;--code-bg: #060a14;--ok: #34d399;--ok-deep: #0f9b6e;--warn: #fbbf24;--danger: #fb7185;--danger-deep: #e11d48;--cyan: #38bdf8;--violet: #a78bfa;--r-xs: 8px;--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--r-xl: 24px;--sh-1: 0 1px 2px rgba(16, 24, 44, .06), 0 2px 6px rgba(16, 24, 44, .05);--sh-2: 0 4px 10px -4px rgba(16, 24, 44, .12), 0 12px 28px -12px rgba(16, 24, 44, .2);--sh-3: 0 8px 18px -8px rgba(16, 24, 44, .18), 0 28px 60px -24px rgba(8, 14, 30, .45);--sh-ink: 0 10px 24px -10px rgba(0, 0, 0, .5), 0 30px 70px -30px rgba(0, 0, 0, .7);--focus: 0 0 0 3px rgba(31, 155, 142, .35);--mono: "SFMono-Regular", "JetBrains Mono", "Cascadia Code", "Consolas", ui-monospace, monospace;--sans: "Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;--num: "tnum" 1, "lnum" 1}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--text);background:radial-gradient(140% 110% at 12% -10%,#1d2c4d,#0a0f1d 58%) fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.006em}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit}:focus-visible{outline:none;box-shadow:var(--focus);border-radius:6px}.tnum{font-variant-numeric:tabular-nums;font-feature-settings:var(--num)}::selection{background:#1f9b8e40}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:16px;padding:16px clamp(16px,4vw,40px);color:#eaf0ff}.brand{display:flex;align-items:center;gap:11px;font-weight:750;letter-spacing:-.02em;font-size:18px}.brand .logo{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:linear-gradient(150deg,var(--brand),var(--brand-3));color:#eafffb;box-shadow:0 10px 22px -8px #1a7393d9,inset 0 1px #ffffff40}.brand small{display:block;font-size:11px;font-weight:500;color:var(--ink-soft);letter-spacing:0;margin-top:1px}.demo-badge{font-size:11px;font-weight:650;color:#ffdfa6;background:#fbbf2421;border:1px solid rgba(251,191,36,.42);padding:6px 12px;border-radius:999px;white-space:nowrap;letter-spacing:-.01em}.tabs{margin-left:auto;display:flex;gap:4px;background:#ffffff0e;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.09);box-shadow:inset 0 1px 1px #0003}.tabs button{display:flex;align-items:center;gap:7px;color:#a6b3d4;font-size:13px;font-weight:650;padding:8px 16px;border-radius:999px;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.tabs button:hover{color:#e7edff}.tabs button.active{background:linear-gradient(150deg,var(--brand),var(--brand-3));color:#fff;box-shadow:0 6px 14px -6px #1a7393cc,inset 0 1px #fff3}.stage{flex:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(384px,452px);gap:clamp(16px,2.4vw,32px);padding:0 clamp(16px,4vw,40px) 36px;align-items:start}.stage.single{grid-template-columns:minmax(0,1080px);justify-content:center}.app-col{display:flex;justify-content:center}.phone{width:100%;max-width:416px;height:min(80vh,772px);background:var(--surface);border-radius:38px;padding:0;box-shadow:var(--sh-3),0 0 0 10px #ffffff09,0 0 0 11px #ffffff0f,inset 0 0 0 1px #141b2e0f;overflow:hidden;display:flex;flex-direction:column;position:relative}.phone-notch{position:absolute;top:10px;left:50%;transform:translate(-50%);width:116px;height:24px;background:#080d18;border-radius:999px;z-index:5}.phone-notch:after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:#1c2740;box-shadow:inset 0 0 0 1.5px #2f3c5c}.auth{flex:1;display:flex;flex-direction:column;justify-content:center;padding:44px 28px 36px;text-align:center;background:radial-gradient(120% 60% at 50% -5%,#edfbf7,#fff 58%);position:relative}.auth:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 30% at 50% 8%,rgba(31,155,142,.1),transparent 70%);pointer-events:none}.auth .ghost-badge{width:68px;height:68px;margin:0 auto 20px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(150deg,var(--brand),var(--brand-3));color:#eafffb;box-shadow:0 18px 34px -12px #1a7393b3,inset 0 1px #ffffff4d;position:relative}.auth .ghost-badge:after{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:26px;border:1.5px solid rgba(31,155,142,.22)}.auth h1{font-size:25px;margin:0 0 7px;letter-spacing:-.03em;font-weight:800}.auth .sub{color:var(--text-soft);font-size:13.5px;line-height:1.65;margin:0 0 28px;position:relative}.field{text-align:left;margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:650;color:var(--text-soft);margin-bottom:7px;letter-spacing:-.01em}.field input{width:100%;padding:13px 14px;border:1.5px solid var(--line-strong);border-radius:12px;font-size:15px;color:var(--text);background:var(--surface-2);transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.field input::placeholder{color:var(--text-mute)}.field input:hover{border-color:#c2cbdc}.field input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:var(--focus)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:13px;font-size:15px;font-weight:700;letter-spacing:-.01em;color:#fff;background:linear-gradient(150deg,var(--brand),var(--brand-3));box-shadow:0 12px 24px -12px #1a7393d9,inset 0 1px #ffffff38;transition:transform .14s ease,box-shadow .18s ease,opacity .18s ease,filter .18s ease}.btn:hover{transform:translateY(-1.5px);box-shadow:0 18px 30px -14px #1a7393e6,inset 0 1px #ffffff38;filter:saturate(1.05)}.btn:active{transform:translateY(0);box-shadow:0 8px 16px -10px #1a7393d9}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none;filter:grayscale(.2)}.btn:focus-visible{box-shadow:var(--focus),0 12px 24px -12px #1a7393d9}.btn.ghost{background:var(--surface-2);color:var(--text);border:1.5px solid var(--line-strong);box-shadow:none}.btn.ghost:hover{background:var(--surface-3);border-color:#c2cbdc;box-shadow:var(--sh-1)}.btn.danger{background:linear-gradient(150deg,#f43f5e,var(--danger-deep));box-shadow:0 12px 24px -12px #e11d48bf,inset 0 1px #ffffff38}.btn.danger:hover{box-shadow:0 18px 30px -14px #e11d48cc,inset 0 1px #ffffff38}.auth .switch{margin-top:18px;font-size:13px;color:var(--text-soft)}.auth .switch button{color:var(--brand-2);font-weight:700;padding:2px 4px;border-radius:6px}.auth .switch button:hover{text-decoration:underline}.auth .pledge{margin-top:26px;display:grid;gap:9px;text-align:left;padding:14px;background:linear-gradient(180deg,var(--brand-tint),#fff);border:1px solid #d8ebe6;border-radius:var(--r-md)}.pledge .row{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:550;color:var(--brand-ink)}.pledge .row svg{color:var(--brand);flex-shrink:0}.chat{flex:1;display:flex;flex-direction:column;min-height:0}.chat-head{display:flex;align-items:center;gap:12px;padding:34px 16px 13px;border-bottom:1px solid var(--line);background:#fff;position:relative;z-index:2}.chat-head .ava{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(150deg,var(--brand-tint),var(--brand-tint-2));color:var(--brand-2);box-shadow:inset 0 0 0 1px #1f9b8e24}.chat-head .who{line-height:1.3}.chat-head .who strong{font-size:15px;font-weight:700;letter-spacing:-.01em}.chat-head .who span{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--brand);font-weight:650}.chat-head .who span:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px #34d3992e;animation:pulse 2.4s ease-in-out infinite}.chat-head .end-btn{margin-left:auto;font-size:12px;font-weight:700;color:var(--danger-deep);background:#fb71851a;border:1px solid rgba(251,113,133,.32);padding:8px 13px;border-radius:999px;display:flex;align-items:center;gap:5px;transition:background .16s ease,transform .12s ease,box-shadow .16s ease}.chat-head .end-btn:hover{background:#fb71852e;box-shadow:0 6px 14px -8px #e11d4880}.chat-head .end-btn:active{transform:scale(.97)}.msgs{flex:1;overflow-y:auto;padding:18px 14px 10px;display:flex;flex-direction:column;gap:12px;background:linear-gradient(180deg,#f8fafd,#eef2f9);scroll-behavior:smooth}.msgs::-webkit-scrollbar{width:7px}.msgs::-webkit-scrollbar-thumb{background:#d3dae8;border-radius:999px}.session-banner{align-self:center;display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);padding:8px 13px 8px 9px;border-radius:999px;box-shadow:var(--sh-1);margin-bottom:4px}.session-banner .sb-icon{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--brand-tint);color:var(--brand)}.session-banner .sb-text{display:flex;align-items:baseline;gap:8px;line-height:1}.session-banner .sb-text b{font-size:11.5px;color:var(--text);font-weight:650}.session-banner .sb-id{font-family:var(--mono);font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums}.row-user{align-self:flex-end;max-width:80%;display:flex;flex-direction:column;align-items:flex-end;gap:3px}.row-ai{align-self:flex-start;max-width:84%;display:flex;gap:8px;align-items:flex-end}.ai-ava{width:28px;height:28px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(150deg,var(--brand-tint),var(--brand-tint-2));color:var(--brand-2);box-shadow:inset 0 0 0 1px #1f9b8e1f}.ai-stack{display:flex;flex-direction:column;gap:3px;min-width:0}.bubble{padding:11px 14px;border-radius:18px;font-size:14px;line-height:1.52;word-break:break-word;animation:pop .24s cubic-bezier(.22,1,.36,1)}.bubble.user{background:linear-gradient(150deg,var(--brand),var(--brand-3));color:#fff;border-bottom-right-radius:6px;box-shadow:0 8px 16px -10px #1a7393b3,inset 0 1px #ffffff26}.bubble.ai{background:#fff;color:var(--text);border:1px solid var(--line);border-bottom-left-radius:6px;box-shadow:var(--sh-1)}.mask-detail{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.22)}.bubble .mask-tag{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:650;color:#fff5dd;background:#fbbf2447;border:1px solid rgba(251,191,36,.45);padding:2px 8px;border-radius:999px}.mask-diff{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:7px;font-family:var(--mono);font-size:10.5px}.mask-diff .md-from{color:#ffd9d2;text-decoration:line-through;text-decoration-color:#ffd9d28c;word-break:break-all}.mask-diff .md-arrow{color:#ffffffb3;flex-shrink:0}.mask-diff .md-to{color:#d6fff4;font-weight:600;word-break:break-all}.msg-time{font-size:10px;color:var(--text-mute);font-variant-numeric:tabular-nums;padding:0 4px}.ai-meta{display:flex;align-items:center;gap:8px;padding-left:4px}.ai-tag{font-size:10px;color:var(--text-mute);background:var(--surface-3);border:1px solid var(--line);padding:1px 7px;border-radius:999px}.typing{background:#fff;border:1px solid var(--line);border-radius:18px 18px 18px 6px;padding:14px 16px;display:flex;gap:4px;box-shadow:var(--sh-1)}.typing i{width:7px;height:7px;border-radius:50%;background:var(--brand);opacity:.5;animation:blink 1.2s infinite ease-in-out}.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}.composer{display:flex;align-items:flex-end;gap:9px;padding:11px 12px;border-top:1px solid var(--line);background:#fff}.composer textarea{flex:1;resize:none;border:1.5px solid var(--line-strong);border-radius:20px;padding:11px 15px;font-size:14px;line-height:1.45;max-height:96px;background:var(--surface-2);color:var(--text);transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.composer textarea::placeholder{color:var(--text-mute)}.composer textarea:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:var(--focus)}.composer .send{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,var(--brand),var(--brand-3));flex-shrink:0;box-shadow:0 8px 16px -8px #1a7393b3,inset 0 1px #fff3;transition:transform .14s ease,box-shadow .16s ease,opacity .16s ease}.composer .send svg{transform:translate(1px)}.composer .send:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.composer .send:not(:disabled):hover{transform:scale(1.07) translateY(-1px);box-shadow:0 12px 22px -10px #1a7393cc}.composer .send:not(:disabled):active{transform:scale(.96)}.pii-hint{font-size:11px;padding:8px 16px;display:flex;align-items:center;gap:7px;border-top:1px solid var(--line);background:var(--surface-2);color:var(--text-soft);transition:background .2s ease,color .2s ease}.pii-hint svg{color:var(--brand);flex-shrink:0}.pii-hint.active{background:#fff7e6;color:#8a5a08;border-top-color:#f6e2b6}.pii-hint.active svg{color:#c97e0a}.pii-hint.active b{font-weight:700}.session-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;text-align:center;color:var(--text-soft);background:radial-gradient(120% 60% at 50% 0%,#f2faf8,#fff 60%)}.session-empty .big{width:74px;height:74px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(150deg,var(--brand-tint),var(--brand-tint-2));color:var(--brand-2);box-shadow:0 16px 30px -16px #1a739380,inset 0 0 0 1px #1f9b8e1f}.session-empty .big.ended{background:linear-gradient(150deg,#ffe9ec,#ffeef1);color:var(--danger-deep);box-shadow:0 16px 30px -16px #e11d4866,inset 0 0 0 1px #fb718533}.session-empty h3{margin:2px 0 0;color:var(--text);font-size:17.5px;font-weight:750;letter-spacing:-.02em}.session-empty p{margin:0;font-size:13px;line-height:1.65;max-width:272px}.session-empty .start-btn{width:auto;padding:13px 24px;margin-top:2px}.empty-assure{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--brand-ink);background:var(--brand-tint);border:1px solid #d8ebe6;padding:7px 13px;border-radius:999px}.empty-assure svg{color:var(--brand)}.inspector{background:linear-gradient(180deg,var(--ink-1),var(--ink));border:1px solid var(--ink-line);border-radius:var(--r-lg);box-shadow:var(--sh-ink);overflow:hidden;display:flex;flex-direction:column;height:min(80vh,772px);position:sticky;top:12px;color:var(--ink-text)}.insp-head{padding:15px 17px;border-bottom:1px solid var(--ink-line);background:linear-gradient(180deg,var(--ink-3),var(--ink-1));display:flex;align-items:center;gap:11px}.insp-head .ic{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;color:var(--cyan);background:#38bdf81a;border:1px solid rgba(56,189,248,.22)}.insp-head h2{font-size:14px;margin:0;letter-spacing:-.015em;color:#eaf1ff;font-weight:700}.insp-head small{display:block;font-size:10.5px;color:var(--ink-mute);font-weight:500;margin-top:1px}.insp-body{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:13px}.insp-body::-webkit-scrollbar{width:8px}.insp-body::-webkit-scrollbar-thumb{background:var(--ink-line-2);border-radius:999px}.insp-section-title{font-size:10.5px;font-weight:750;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-mute);display:flex;align-items:center;gap:7px;margin-bottom:-4px}.insp-section-title svg{color:var(--ink-soft)}.card{background:var(--ink-2);border:1px solid var(--ink-line);border-radius:var(--r-md);padding:13px;box-shadow:inset 0 1px #ffffff06}.id-card{transition:border-color .3s ease,box-shadow .3s ease}.id-card.linked{border-color:#34d39947;box-shadow:inset 0 0 0 1px #34d39914,0 0 26px -16px #34d39980}.id-card.broken{border-color:#fb718552;box-shadow:inset 0 0 0 1px #fb718514,0 0 26px -16px #fb71858c}.id-flow{display:flex;align-items:stretch;gap:6px}.id-node{flex:1;background:var(--ink-3);border:1px solid var(--ink-line);border-radius:var(--r-sm);padding:10px 8px 9px;text-align:center;position:relative;min-width:0}.id-node .label{font-size:9px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-weight:600}.id-node .val{font-family:var(--mono);font-size:11px;font-weight:600;word-break:break-all;font-variant-numeric:tabular-nums}.id-node .id-pin{position:absolute;top:-7px;right:7px;font-size:8px;font-weight:700;letter-spacing:.04em;padding:1px 6px;border-radius:999px;text-transform:uppercase}.id-node.user{border-color:#fbbf244d}.id-node.user .val{color:var(--warn)}.id-node.user .id-pin{background:#fbbf2429;color:#ffdf9b;border:1px solid rgba(251,191,36,.35)}.id-node.sess{border-color:#38bdf847}.id-node.sess .val{color:var(--cyan)}.id-node.sess .id-pin{background:#38bdf824;color:#b6e6ff;border:1px solid rgba(56,189,248,.35)}.id-arrow{width:54px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;position:relative}.id-arrow-line{position:absolute;top:50%;left:4px;right:4px;height:2px;transform:translateY(-9px);border-radius:999px}.id-arrow.linked .id-arrow-line{background:linear-gradient(90deg,#fbbf2480,#34d399cc)}.id-arrow.broken .id-arrow-line{background:repeating-linear-gradient(90deg,rgba(251,113,133,.6) 0 4px,transparent 4px 8px)}.id-arrow-glyph{font-size:17px;line-height:1;z-index:1;position:relative}.id-arrow.linked .id-arrow-glyph{color:var(--ok)}.id-arrow.broken .id-arrow-glyph{color:var(--danger);animation:shake .5s ease}.id-arrow-cap{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.id-arrow.linked .id-arrow-cap{color:var(--ok)}.id-arrow.broken .id-arrow-cap{color:var(--danger)}.no-userid{margin-top:11px;font-size:10.5px;color:#b8f5dd;background:#34d39917;border:1px dashed rgba(52,211,153,.42);border-radius:var(--r-xs);padding:7px 10px;display:flex;align-items:center;gap:7px;line-height:1.4}.no-userid svg{flex-shrink:0;color:var(--ok)}.no-userid b{color:#d6fff0;font-weight:700}.no-userid.danger{color:#ffd0d8;background:#fb718517;border-color:#fb718573}.no-userid.danger svg{color:var(--danger)}.no-userid.danger b{color:#ffe1e6}.ttl{margin-top:12px}.ttl-top{display:flex;justify-content:space-between;align-items:baseline;font-size:10.5px;color:var(--ink-mute);margin-bottom:6px}.ttl-top b{color:var(--warn);font-family:var(--mono);font-size:12px;font-variant-numeric:tabular-nums}.ttl-track{height:8px;background:var(--ink-3);border-radius:999px;overflow:hidden;box-shadow:inset 0 1px 2px #0006}.ttl-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--ok),var(--warn));transition:width .25s linear;box-shadow:0 0 10px -1px #34d39999}.ttl-fill.low{background:linear-gradient(90deg,var(--warn),var(--danger));box-shadow:0 0 10px -1px #fb7185b3}.payload{font-family:var(--mono);font-size:11px;line-height:1.65;background:var(--code-bg);border:1px solid var(--ink-line);border-radius:var(--r-sm);padding:11px 12px;overflow-x:auto;white-space:pre;font-variant-numeric:tabular-nums}.payload .k{color:var(--cyan)}.payload .s{color:#7ee2b8}.payload .muted{color:var(--ink-mute)}.payload .hl{background:#34d39929;color:#d6fff0;padding:0 3px;border-radius:4px;font-weight:600}.payload-note{display:flex;align-items:center;gap:6px;margin-bottom:9px;font-size:10px;font-weight:650;color:#b8f5dd}.payload-note .chip{background:#34d39924;border:1px solid rgba(52,211,153,.4);color:#d6fff0;padding:2px 8px;border-radius:999px;letter-spacing:.02em}.call-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-text);padding:8px 0;border-bottom:1px solid var(--ink-line)}.call-row:last-child{border-bottom:none}.call-row:first-child{padding-top:4px}.call-row .badge-ok{font-size:9.5px;font-weight:600;color:#b8f5dd;background:#34d3991a;border:1px solid rgba(52,211,153,.4);border-radius:999px;padding:2px 7px;white-space:nowrap}.call-row .call-sess{font-family:var(--mono);font-size:10.5px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.call-row .tok{margin-left:auto;font-family:var(--mono);color:var(--ink-mute);font-variant-numeric:tabular-nums}.log{display:flex;flex-direction:column}.log-row{display:flex;gap:10px;padding:8px 4px;border-radius:var(--r-xs);animation:slideIn .28s cubic-bezier(.22,1,.36,1);border-bottom:1px solid rgba(37,50,79,.5)}.log-row:last-child{border-bottom:none}.log-row .dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0;box-shadow:0 0 0 3px #ffffff08}.log-row.session-open .dot,.log-row.redis-set .dot{background:var(--cyan);box-shadow:0 0 8px -1px var(--cyan)}.log-row.openai-call .dot{background:var(--violet);box-shadow:0 0 8px -1px var(--violet)}.log-row.mask .dot{background:var(--warn);box-shadow:0 0 8px -1px var(--warn)}.log-row.redis-purge .dot,.log-row.account-wipe .dot{background:var(--danger);box-shadow:0 0 8px -1px var(--danger)}.log-row .body{min-width:0;flex:1}.log-row .body .t{font-size:11.5px;line-height:1.45;color:var(--ink-text)}.log-row .body .lvl{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.03em;padding:0 1px}.log-row.session-open .lvl,.log-row.redis-set .lvl{color:var(--cyan)}.log-row.openai-call .lvl{color:var(--violet)}.log-row.mask .lvl{color:var(--warn)}.log-row.redis-purge .lvl,.log-row.account-wipe .lvl{color:var(--danger)}.log-row .body .d{font-size:10px;color:var(--ink-mute);font-family:var(--mono);word-break:break-all;margin-top:3px;line-height:1.4}.log-row .time{margin-left:auto;font-size:9.5px;color:var(--ink-mute);flex-shrink:0;font-family:var(--mono);font-variant-numeric:tabular-nums;padding-top:1px}.empty-state{font-size:11.5px;color:var(--ink-mute);text-align:center;padding:20px 10px;line-height:1.6}.purge-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#080b168c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:20;animation:flashOut 1.6s ease forwards;pointer-events:none}.purge-flash .pf-card{background:linear-gradient(180deg,var(--ink-3),var(--ink-2));border:1px solid var(--danger);border-radius:var(--r-lg);padding:20px 24px;text-align:center;color:var(--ink-text);box-shadow:0 0 60px -8px #f43f5ea6;animation:pfPop .5s cubic-bezier(.22,1,.36,1)}.purge-flash .pf-icon{width:50px;height:50px;margin:0 auto 10px;border-radius:15px;display:grid;place-items:center;color:var(--danger);background:#f43f5e24;border:1px solid rgba(244,63,94,.4)}.purge-flash .pf-card strong{display:block;font-size:15px;font-weight:750;color:#fff}.purge-flash .pf-card>span{font-size:11.5px;color:var(--ink-soft)}.pf-states{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:12px}.pf-states span{font-size:10px;font-weight:650;padding:3px 9px;border-radius:999px;font-family:var(--mono)}.pf-before{color:#ffd9a6;background:#fbbf241f;border:1px solid rgba(251,191,36,.35);text-decoration:line-through;opacity:.7}.pf-after{color:#d6fff0;background:#34d39924;border:1px solid rgba(52,211,153,.42)}.admin{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--sh-3);padding:clamp(20px,3vw,36px);width:100%;border:1px solid rgba(255,255,255,.6)}.admin-head{display:flex;align-items:center;gap:13px;margin-bottom:24px}.admin-head .ic{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(150deg,var(--brand-tint-2),var(--brand-tint));color:var(--brand-2);box-shadow:inset 0 0 0 1px #1f9b8e1f}.admin-head h2{margin:0;font-size:20px;font-weight:800;letter-spacing:-.025em}.admin-head p{margin:3px 0 0;font-size:12.5px;color:var(--text-soft)}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(154px,1fr));gap:14px;margin-bottom:24px}.kpi{background:linear-gradient(180deg,#fff,var(--surface-2));border:1px solid var(--line);border-radius:var(--r-md);padding:16px;box-shadow:var(--sh-1);transition:transform .18s ease,box-shadow .18s ease}.kpi:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}.kpi .label{font-size:12px;color:var(--text-soft);display:flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:550}.kpi .kpi-ic{display:grid;place-items:center;width:28px;height:28px;border-radius:9px;background:var(--brand-tint);color:var(--brand-2);flex-shrink:0}.kpi .val{font-size:27px;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums;line-height:1}.kpi .val small{font-size:13px;font-weight:650;color:var(--text-mute);margin-left:3px}.kpi .delta{display:inline-flex;align-items:center;gap:4px;margin-top:10px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.kpi .delta span{font-weight:500;color:var(--text-mute);margin-left:2px}.kpi .delta.up{color:var(--ok-deep);background:#0f9b6e1a}.kpi .delta.flat{color:var(--text-soft);background:var(--surface-3)}.panel{border:1px solid var(--line);border-radius:var(--r-md);padding:20px;margin-bottom:18px;background:linear-gradient(180deg,#fff,#fcfdff)}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.panel h3{margin:0 0 4px;font-size:15px;font-weight:750;letter-spacing:-.01em}.panel .desc{margin:0;font-size:12px;color:var(--text-soft)}.panel-pill{font-size:11px;font-weight:650;color:var(--brand-ink);background:var(--brand-tint);border:1px solid #d8ebe6;padding:5px 11px;border-radius:999px;white-space:nowrap;font-variant-numeric:tabular-nums}.chart-wrap{position:relative}.chart-grid{position:absolute;top:0;right:0;bottom:26px;left:0;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.chart-grid span{height:1px;background:var(--line)}.chart{display:flex;align-items:flex-end;gap:10px;height:168px;position:relative}.chart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:9px;height:100%;justify-content:flex-end}.chart .bar-track{width:100%;flex:1;display:flex;align-items:flex-end;justify-content:center}.chart .bar{width:100%;max-width:34px;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,var(--brand),var(--brand-3));position:relative;transition:height .4s cubic-bezier(.22,1,.36,1),filter .18s ease;box-shadow:0 6px 14px -8px #1a739399,inset 0 1px #ffffff40;min-height:4px}.chart .bar.peak{background:linear-gradient(180deg,#28b9a9,var(--brand-2))}.chart .bar:hover{filter:brightness(1.07) saturate(1.1)}.chart .bar:hover:after{content:attr(data-val);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;font-size:10px;font-weight:600;padding:4px 8px;border-radius:7px;white-space:nowrap;box-shadow:var(--sh-2);font-variant-numeric:tabular-nums;z-index:2}.chart .bar:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--ink);z-index:2}.chart .lab{font-size:11px;color:var(--text-soft);font-weight:550}.privacy-callout{display:flex;gap:14px;background:linear-gradient(135deg,var(--brand-tint),var(--brand-tint-2));border:1px solid #d3ece6;border-radius:var(--r-md);padding:17px 19px;margin-bottom:18px;position:relative;overflow:hidden}.privacy-callout:before{content:"";position:absolute;top:-40%;right:-10%;width:180px;height:180px;background:radial-gradient(circle,rgba(31,155,142,.12),transparent 70%);pointer-events:none}.privacy-callout .ic{display:grid;place-items:center;width:44px;height:44px;border-radius:13px;background:#fff;color:var(--brand);flex-shrink:0;box-shadow:var(--sh-1)}.privacy-callout h4{margin:0 0 5px;font-size:13.5px;font-weight:750;color:var(--brand-ink)}.privacy-callout p{margin:0;font-size:12px;line-height:1.65;color:#2f5751}.linkage-table{width:100%;border-collapse:collapse;font-size:12.5px}.linkage-table th,.linkage-table td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--line)}.linkage-table thead th{font-size:10.5px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;font-weight:700;border-bottom-color:var(--line-strong)}.linkage-table tbody tr{transition:background .14s ease}.linkage-table tbody tr:hover{background:var(--surface-2)}.linkage-table td.col-sess{font-family:var(--mono);font-size:12px;color:var(--text);font-variant-numeric:tabular-nums}.linkage-table td.col-tok{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.linkage-table td.redacted{font-family:var(--mono);color:var(--text-mute)}.redacted-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-family:var(--sans);font-weight:600;color:#9b5560;background:#fdeef0;border:1px solid #f6d6dc;padding:3px 9px;border-radius:999px;letter-spacing:.04em}.tag-pill{display:inline-block;font-size:11.5px;color:var(--brand-ink);background:var(--brand-tint);border:1px solid #dcefe9;padding:2px 9px;border-radius:999px}.danger-zone{border:1.5px dashed #f3c2cb;border-radius:var(--r-md);padding:17px 19px;background:linear-gradient(135deg,#fff5f6,#fff8f9);display:flex;align-items:center;gap:15px;flex-wrap:wrap}.danger-zone .dz-ic{display:grid;place-items:center;width:46px;height:46px;border-radius:13px;background:#fff0f2;color:var(--danger-deep);flex-shrink:0;box-shadow:var(--sh-1)}.danger-zone .txt{flex:1;min-width:200px}.danger-zone h4{margin:0 0 3px;font-size:13.5px;font-weight:750;color:#b42334}.danger-zone p{margin:0;font-size:12px;line-height:1.55;color:#9b5560}.danger-zone .btn{width:auto;padding:11px 18px;font-size:13px}.insp-toggle,.inspector.as-drawer,.drawer-back,.insp-head .insp-close{display:none}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c189e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:80;padding:20px;animation:fadeIn .22s ease}.modal{background:#fff;border-radius:var(--r-xl);max-width:384px;width:100%;padding:28px;text-align:center;box-shadow:var(--sh-3);animation:pfPop .34s cubic-bezier(.22,1,.36,1)}.modal .ic{width:58px;height:58px;margin:0 auto 16px;border-radius:17px;display:grid;place-items:center;background:#fff0f2;color:var(--danger-deep);box-shadow:inset 0 0 0 1px #fb718533}.modal h3{margin:0 0 9px;font-size:18px;font-weight:750;letter-spacing:-.02em}.modal p{margin:0 0 22px;font-size:13.5px;color:var(--text-soft);line-height:1.6}.modal .actions{display:flex;gap:10px}.modal .actions .btn{width:auto;flex:1}.wipe{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 50% 40%,var(--ink-1),var(--ink));z-index:90;display:grid;place-items:center;color:var(--ink-text);animation:fadeIn .25s ease}.wipe .wbox{text-align:center}.wipe .wbox>svg{color:var(--danger)}.wipe .scan{width:240px;height:5px;border-radius:999px;background:var(--ink-3);overflow:hidden;margin:18px auto 0;box-shadow:inset 0 1px 2px #00000080}.wipe .scan i{display:block;height:100%;width:40%;background:linear-gradient(90deg,transparent,var(--danger),transparent);animation:scan 1s linear infinite}.wipe strong{display:block;margin-top:16px;font-size:16px;font-weight:750;color:#fff}.wipe span{font-size:12.5px;color:var(--ink-mute);font-family:var(--mono)}@keyframes pop{0%{transform:scale(.96) translateY(5px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@keyframes pfPop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes blink{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #34d3992e}50%{box-shadow:0 0 0 5px #34d3990f}}@keyframes slideIn{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}@keyframes flashOut{0%{opacity:0}12%{opacity:1}to{opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scan{0%{transform:translate(-280px)}to{transform:translate(280px)}}@media(max-width:980px){.stage{grid-template-columns:minmax(0,1fr)}.stage>.inspector:not(.as-drawer){display:none}.inspector.as-drawer{display:flex;position:fixed;inset:auto 0 0 0;height:84vh;border-radius:var(--r-xl) var(--r-xl) 0 0;z-index:70;transform:translateY(100%);transition:transform .34s cubic-bezier(.22,1,.36,1);box-shadow:0 -24px 60px -12px #0000008c}.inspector.as-drawer:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;border-radius:999px;background:var(--ink-line-2);z-index:3}.inspector.as-drawer .insp-head{padding-top:20px}.inspector.as-drawer.open{transform:translateY(0)}.inspector.as-drawer:not(.open){pointer-events:none}.insp-toggle{display:inline-flex;align-items:center;gap:9px;position:fixed;right:16px;bottom:18px;z-index:60;padding:13px 18px;border-radius:999px;color:#fff;background:linear-gradient(150deg,var(--ink-3),var(--ink-1));border:1px solid var(--ink-line-2);box-shadow:var(--sh-3);font-size:13px;font-weight:700}.insp-toggle .pip{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 4px #34d39933;animation:pulse 2.4s ease-in-out infinite}.drawer-back{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0508128c;z-index:65;animation:fadeIn .2s ease}.insp-head .insp-close{display:grid;place-items:center;margin-left:auto;width:30px;height:30px;border-radius:9px;color:var(--ink-soft);background:#ffffff0a;border:1px solid var(--ink-line)}.insp-head .insp-close:hover{color:#fff;background:#ffffff14}}@media(min-width:561px)and (max-width:980px){.stage{padding-bottom:92px}}@media(max-width:560px){.topbar{flex-wrap:wrap;gap:10px;padding:14px 16px}.tabs{margin-left:0;order:3;width:100%;justify-content:center}.demo-badge{margin-left:auto}.stage{padding:0 0 84px}.stage.single{padding:0 12px 84px}.app-col{padding:0}.phone{max-width:none;height:calc(100dvh - 156px);min-height:520px;border-radius:0;box-shadow:none;padding:0}.phone-notch{display:none}.chat-head{padding-top:16px}.admin{border-radius:var(--r-lg) var(--r-lg) 0 0;padding:20px 16px}.kpis{grid-template-columns:repeat(2,1fr);gap:10px}.kpi .val{font-size:23px}.mask-diff{font-size:9.5px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
