:root{--bg:#FDFDF9;--card:#FFFFFF;--surface:#F4F6FB;--line:#DAE1ED;--fg:#0F172B;--muted:#898989;--primary:#222A76;--primary-ink:#ffffff;--primary-soft:#E8EAF6;--primary-on-dark:#8EA2FF;--brand:#254FAD;--code-bg:#0e1116;--code-bg2:#0b0d11;--code-line:#222834;--code-fg:#d8dde4;--code-muted:#8a93a3;--fixture:#894B00;--live:#22C55E;--high:#22C55E;--moderate:#E88050;--low:#DC3545;--green:#39B54A;--radius:16px;--radius-sm:12px;--shadow:0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-sm:0 1px 2px rgba(0,0,0,.06);--track-bg:#EAEDF4;--chip-off-bg:#E8EAF6;--live-bg:#DAFAC1;--overlay-bg:rgba(253,253,249,.6);--sb-thumb:rgba(124,132,156,.45);--sb-thumb-hover:rgba(124,132,156,.78)}[data-theme=dark]{--bg:#0E1015;--card:#171B27;--surface:#0A0C12;--line:#232938;--fg:#EEF1FA;--muted:#8590A8;--primary:#4A5FC4;--primary-ink:#ffffff;--primary-soft:rgba(74,95,196,.16);--primary-on-dark:#8EA2FF;--brand:#8EA2FF;--fixture:#c9952b;--live:#22C55E;--high:#22C55E;--moderate:#E88050;--low:#FF6B7A;--green:#39B54A;--shadow:0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-sm:0 1px 2px rgba(0,0,0,.3);--track-bg:#232938;--chip-off-bg:#232938;--live-bg:rgba(57,181,74,.18);--overlay-bg:rgba(10,12,18,.6)}*{box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:var(--sb-thumb) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-corner{background:transparent}::-webkit-scrollbar-thumb{background:var(--sb-thumb);border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--sb-thumb-hover);background-clip:padding-box}html,body{margin:0;height:100%}body{font-family:Figtree,ui-sans-serif,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased}#app{width:100%;height:100vh;padding:14px 22px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.muted{color:var(--muted);font-size:13px}h2{margin:6px 0 4px;font-size:18px;font-weight:700}h3{margin:4px 0;font-size:15px;font-weight:700}h4{margin:8px 0 4px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}.app-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:9px}.app-logo{height:26px;width:auto;display:block;flex:0 0 auto}.app-title{flex:1;text-align:center;margin:0;font-size:23px;font-weight:800;letter-spacing:-.01em;background:linear-gradient(90deg,var(--primary),var(--brand));-webkit-background-clip:text;background-clip:text;color:transparent}.lang-btn{background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:999px;padding:8px 16px;cursor:pointer;font-weight:600;min-width:48px;box-shadow:var(--shadow-sm)}.lang-btn:hover{border-color:var(--primary);color:var(--primary)}.app-actions{display:flex;align-items:center;gap:8px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:999px;cursor:pointer;box-shadow:var(--shadow-sm);padding:0}.icon-btn:hover{border-color:var(--primary);color:var(--primary)}.tabbar{display:flex;gap:4px;margin-bottom:-13px;position:relative;z-index:2}.tab{background:transparent;color:var(--muted);border:1px solid transparent;border-bottom:none;border-radius:12px 12px 0 0;padding:9px 18px 12px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s,color .15s}.tab:hover:not(.active){color:var(--fg);background:var(--surface)}.tab.active{background:var(--card);color:var(--fg);border-color:var(--line);box-shadow:0 -3px 8px #16140f0d}.content{background:var(--card);border:1px solid var(--line);border-radius:0 14px 14px;padding:16px 18px;display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow:auto;box-shadow:var(--shadow)}.tab-pane{display:contents}.tab-e2e{margin-left:18px;color:var(--primary);position:relative}.tab-e2e:before{content:"";position:absolute;left:-10px;top:16%;bottom:16%;width:2px;border-radius:2px;background:color-mix(in srgb,var(--muted) 55%,transparent)}.tab-e2e.active{background:var(--primary);color:#fff;border-color:var(--primary)}.e2e-tab{display:flex;flex-direction:column;gap:12px}.e2e-tab .integration-grid{align-items:stretch}.e2e-tab .integration-left .stage{flex:1 1 0;min-height:280px}.e2e-tab .integration-right{gap:12px}.e2e-tab .calllog{flex:none;height:200px}.e2e-tab .integration-right .result-pane{flex:0 0 auto}.pane-title-row{display:flex;align-items:baseline;gap:10px}.pane-sub{font-size:12px;font-weight:500;letter-spacing:normal;text-transform:none;color:var(--muted)}.stream-feed .calllog-row{grid-template-columns:minmax(120px,auto) 1fr;align-items:start}.stream-feed .cl-path{white-space:normal;overflow:visible;text-overflow:clip}.stream-feed .cl-method{white-space:nowrap}.e2e-results{display:flex;flex-direction:column;gap:14px}.e2e-interp{max-height:520px}@media (max-width: 1000px){.e2e-results{grid-template-columns:1fr}}.row-label{font-weight:700;font-size:14px;margin-right:4px}.ctl-label{font-size:13px;color:var(--muted)}.window-note{font-size:12px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 11px;white-space:nowrap}.slider-ctl{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 12px;cursor:pointer}.slider-ctl .ctl-label{font-weight:600;color:var(--fg)}.slider-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:96px;height:4px;border-radius:999px;background:var(--line);outline:none;cursor:pointer}.slider-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;border:2px solid var(--card);box-shadow:var(--shadow-sm)}.slider-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;border:2px solid var(--card)}.slider-range:disabled{opacity:.5;cursor:not-allowed}.slider-val{font-family:ui-monospace,monospace;font-size:12px;font-weight:700;color:var(--primary);min-width:30px;text-align:right}button[disabled]{opacity:.45;cursor:not-allowed}.flow-diagram{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:8px 12px;box-shadow:var(--shadow-sm)}.flow-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.flow-skill-link{margin-left:auto;font-size:11px;padding:4px 12px;text-decoration:none}.flow-ctx-btn{font-size:11px;padding:4px 12px}.flow-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--muted)}.flow-hint{font-size:11px;color:var(--muted)}.flow-steps{display:flex;align-items:stretch;gap:6px;overflow-x:auto;padding-bottom:2px}.flow-step{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:5px 10px;cursor:pointer;white-space:nowrap;flex:0 0 auto;font-family:inherit;text-align:left}.flow-step:hover{border-color:var(--primary)}.flow-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 auto;border-radius:50%;background:var(--primary);color:var(--primary-ink);font-size:11px;font-weight:700}.flow-step-main{display:flex;flex-direction:column;line-height:1.25}.flow-label{font-size:12px;font-weight:700;color:var(--fg)}.flow-call{font-family:ui-monospace,monospace;font-size:10px;color:var(--muted)}.flow-arrow{display:flex;align-items:center;color:var(--muted);flex:0 0 auto}.flow-note{font-size:11px;color:var(--muted);margin-top:6px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.field{background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:12px;padding:9px 11px;box-shadow:var(--shadow-sm)}.field:focus{outline:none;border-color:var(--primary)}select.field{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:30px;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1.5L6 6.5L11 1.5' fill='none' stroke='%23898989' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 10px center}select.field:hover{border-color:var(--primary)}select.field option{background:var(--card);color:var(--fg)}.btn-primary{background:var(--primary);color:var(--primary-ink);border:0;border-radius:999px;padding:10px 18px;cursor:pointer;font-weight:700;box-shadow:0 1px 2px #222a762e}.btn-primary:hover:not([disabled]){filter:brightness(1.05)}.btn-secondary{background:var(--card);color:var(--primary);border:1px solid var(--primary);border-radius:999px;padding:10px 18px;cursor:pointer;font-weight:600;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not([disabled]){background:var(--primary-soft)}.status{font-size:13px;color:var(--fg)}.integration-tab{flex:1 1 auto;display:flex;flex-direction:column;gap:12px;min-height:0}.cred-panel{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border:1px solid transparent;border-radius:9px;transition:border-color .2s,box-shadow .2s,background .2s}.cred-panel.cred-valid{border-color:var(--live);background:color-mix(in srgb,var(--live) 10%,transparent);box-shadow:0 0 0 1px var(--live),0 0 11px -3px var(--live)}.cred-panel.cred-invalid{border-color:var(--low);background:color-mix(in srgb,var(--low) 8%,transparent);animation:cred-pulse 1.8s ease-in-out infinite}@keyframes cred-pulse{0%,to{box-shadow:0 0 0 1px var(--low)}50%{box-shadow:0 0 0 1px var(--low),0 0 16px -1px var(--low)}}@media (prefers-reduced-motion: reduce){.cred-panel.cred-invalid{animation:none;box-shadow:0 0 0 1px var(--low)}}.cred-panel.cred-checking{border-color:var(--muted)}.cred-title{font-weight:700;font-size:12px;color:var(--muted);margin-right:2px;white-space:nowrap}.cred-input{padding:5px 9px;font-size:12px;max-width:130px}.cred-key-wrap{position:relative;display:inline-flex;align-items:center}.cred-key-wrap .cred-input{padding-right:26px}.cred-eye{position:absolute;right:4px;display:inline-flex;align-items:center;background:transparent;border:0;padding:2px;color:var(--muted);cursor:pointer}.cred-eye:hover{color:var(--primary)}.cred-btn{padding:6px 12px;font-size:12px}.cred-status{font-size:12px;font-weight:600;white-space:nowrap}.cred-panel.cred-invalid .cred-status{color:var(--low)}.cred-panel.cred-checking .cred-status{color:var(--muted)}.cred-info{display:inline-flex;align-items:center;gap:5px}.cred-info .cred-info-ic{display:inline-flex}.cred-info:hover{color:var(--primary);border-color:var(--primary)}.integration-grid{flex:1;min-height:0;display:grid;grid-template-columns:1.05fr .95fr;gap:16px;align-items:stretch}.integration-left,.integration-right{display:flex;flex-direction:column;gap:10px;min-height:0}.stage{position:relative;flex:0 0 auto;height:40vh;min-height:220px;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#14171d,#05070b);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}.video-wrap{position:relative;height:100%;max-width:100%}.stage-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#9aa3b2;pointer-events:none}.stage-icon{color:#3a4150}.stage-hint{font-size:13px}.stage-loading{background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.18);border-top-color:var(--primary);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-dots:after{content:"";animation:dots 1.2s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.preview{display:block;height:100%;width:100%;object-fit:cover;transition:opacity .25s ease}.face-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.result-pane{border:1px solid var(--line);border-radius:16px;padding:12px;flex:0 0 auto;background:var(--card);box-shadow:var(--shadow-sm)}.pane-title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px;font-weight:700}.tel-panel{border:1px solid var(--line);border-radius:16px;padding:12px;background:var(--surface);box-shadow:var(--shadow-sm)}.tel-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.tel-title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-right:auto;font-weight:700}.tel-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--green);color:#fff}.tel-badge-off{background:var(--chip-off-bg);color:var(--muted)}.tel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;font-family:ui-monospace,monospace;font-size:11px}.tel-col-title{font-family:Figtree,system-ui,sans-serif;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:4px;font-weight:700}.tel-row{display:flex;justify-content:space-between;gap:8px;padding:1px 0}.tel-key{color:var(--muted)}.tel-val{color:var(--fg)}.tel-green{color:var(--green)}.tel-red{color:#d8493a}.tel-blue{color:var(--brand)}.tel-energy{height:5px;background:var(--track-bg);border-radius:4px;overflow:hidden;margin-top:10px}.tel-energy-fill{height:100%;width:0%;background:var(--primary)}.tel-counters{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted);margin-top:8px}.calllog{border:1px solid var(--code-line);border-radius:16px;padding:12px;background:var(--code-bg2);flex:1;min-height:0;display:flex;flex-direction:column}.calllog-title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--code-muted);margin-bottom:4px;font-weight:700}.calllog-hint{font-size:11px;color:var(--code-muted);margin-bottom:8px;line-height:1.4}.calllog-list{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0;overflow:auto;font-family:ui-monospace,monospace;font-size:12px}.calllog-row{display:grid;grid-template-columns:60px 46px 1fr auto auto 22px;gap:8px;align-items:center;padding:3px 0;border-bottom:1px solid #1a1d24}.cl-ms{color:var(--code-muted);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.calllog-row.clickable{cursor:pointer;border-radius:6px;transition:background-color .12s ease}.calllog-row.clickable:hover{background:#ffffff0f}.calllog-row.clickable .cl-path{text-decoration:underline;text-decoration-color:#fff3;text-underline-offset:2px}.cl-open{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:6px;color:var(--primary-on-dark);opacity:.75}.calllog-row.clickable:hover .cl-open{opacity:1;background:#ffffff14}.calllog-row.example{opacity:.78}.calllog-row.example:hover{opacity:1}.st-example,.cl-time{color:var(--code-muted)}.cl-method{color:var(--primary-on-dark);font-weight:700}.cl-path{color:var(--code-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cl-status{font-weight:700;text-align:right;color:var(--code-fg)}.st-ok{color:#3ddc84}.st-warn{color:#f0b449}.st-error{color:#ff6b6b}.st-fixture{color:#e0b057}.result-box{max-width:720px}.hci-card{border:1px solid var(--line);border-radius:16px;padding:16px;max-width:720px;background:var(--card);box-shadow:var(--shadow-sm)}.hci-card-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;margin-bottom:10px}.hci-row{display:grid;grid-template-columns:200px 50px 80px 1fr;align-items:center;gap:10px;margin:7px 0}.hci-label{font-size:13px;font-weight:600}.hci-value{font-family:ui-monospace,monospace;text-align:right;font-weight:800;font-size:16px}.hci-band{font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.hci-bar{height:8px;background:var(--track-bg);border-radius:6px;overflow:hidden}.hci-fill{height:100%}.band-high{background:var(--high)}.band-moderate{background:var(--moderate)}.band-low{background:var(--low)}.band-text-high{color:var(--high)}.band-text-moderate{color:var(--moderate)}.band-text-low{color:var(--low)}.badge{font-size:11px;padding:3px 10px;border-radius:999px;font-weight:700}.badge-fixture{background:var(--primary-soft);color:var(--fixture)}.badge-live{background:var(--live-bg);color:var(--live)}.call-box{margin:8px 0 0}.retr-step{border:1px solid var(--line);border-radius:16px;padding:14px 16px;margin-bottom:14px;background:var(--card);box-shadow:var(--shadow-sm)}.step-head{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px;margin-bottom:12px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:13px;font-weight:700}.step-body{margin-top:12px}.step-sub{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px;font-weight:700}.retr-grid{display:grid;grid-template-columns:minmax(260px,.85fr) 1.15fr;gap:18px;align-items:start}.retr-col{min-width:0}.retr-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px}.retr-filters .field[type=date]{padding:6px 9px;font-size:12px}.chip-btn{padding:5px 12px;font-size:12px}.chip-btn.active{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}.filter-note{font-size:11px;margin-bottom:8px}.session-list{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto;padding-right:4px}.session-item{display:flex;justify-content:space-between;align-items:center;gap:10px;text-align:left;background:var(--surface);color:var(--fg);border:1px solid var(--line);border-radius:12px;padding:10px 12px;cursor:pointer;width:100%}.session-item:hover{border-color:var(--primary)}.session-item.active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary) inset;background:var(--primary-soft)}.si-id{font-weight:700;font-family:ui-monospace,monospace}.detail{min-height:60px}.detail-placeholder{padding:24px;text-align:center;border:1px dashed var(--line);border-radius:12px;color:var(--muted)}.detail-head{font-weight:700;font-size:15px;margin-bottom:12px}.interp-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.interp-note-chip{font-size:11px;font-weight:500;color:var(--muted);background:var(--primary-soft);border:1px solid var(--line);border-radius:999px;padding:3px 10px}.detail-grid{display:grid;grid-template-columns:minmax(320px,.9fr) 1.1fr;gap:18px;align-items:start}.interpretation-text{font-size:13.5px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:12px;padding:4px 16px;max-height:520px;overflow:auto}.md h4,.md h5,.md h6{margin:14px 0 6px;font-size:14px;color:var(--fg)}.md p{margin:8px 0;line-height:1.6;color:var(--fg)}.md ul{margin:8px 0;padding-left:20px}.md li{margin:3px 0;line-height:1.5}.md strong{color:var(--primary)}.interp-progress{display:flex;align-items:center;gap:10px;padding:10px 0}.spinner-sm{width:18px;height:18px;border-width:2px}.call-trace{display:grid;grid-template-columns:1fr 1fr;gap:12px}.call-trace-vertical{grid-template-columns:1fr}.retr-launch-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.retr-launch-row .detail-head{margin-bottom:0}.retr-launch-row>.btn-primary{flex:0 0 auto}.retr-launch-hint{margin:6px 0 0}.interp-note-line{margin-top:8px}.call-col-head{display:flex;align-items:center;gap:8px}.call-ms-chip{font-size:11px;font-family:ui-monospace,monospace;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:2px 8px}.interp-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:18px;align-items:stretch}.interp-grid>.interpretation-text{height:560px;max-height:560px}.interp-call{display:flex;flex-direction:column;gap:8px;height:560px}.interp-call .call-trace-vertical{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px}.interp-call .call-trace-vertical .call-col:last-child{flex:1;min-height:0;display:flex;flex-direction:column}.interp-call .call-trace-vertical .call-col:last-child .code{flex:1;max-height:none}.interp-note{font-size:12px;color:var(--muted);background:var(--primary-soft);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:8px;padding:7px 10px;margin-bottom:10px}.code{background:var(--code-bg2);border:1px solid var(--code-line);border-radius:10px;padding:10px;color:var(--code-fg);font-family:ui-monospace,monospace;font-size:11px;overflow:auto;max-height:340px;white-space:pre-wrap;word-break:break-word}.file-field{padding:7px 9px;font-size:12px;max-width:220px}.call-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#0f111b80;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:24px}.call-modal{width:min(720px,94vw);max-height:88vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:20px 22px;display:flex;flex-direction:column;gap:14px;box-shadow:0 24px 70px #16140f47}.call-modal-head{display:flex;align-items:center;gap:10px}.call-modal-head .cl-method{color:var(--primary);font-weight:800;font-family:ui-monospace,monospace}.call-modal-path{font-weight:700;font-family:ui-monospace,monospace;font-size:14px}.call-modal-ms{font-size:11px;font-family:ui-monospace,monospace;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:2px 8px}.call-modal-note{margin-left:auto;font-size:12px;color:var(--muted)}.call-modal-close{background:transparent;border:0;color:var(--muted);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:8px}.call-modal-close:hover{color:var(--fg);background:var(--surface)}.call-modal-explain{margin:0;font-size:13px;line-height:1.5;color:var(--fg);background:var(--primary-soft);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:8px;padding:10px 12px}.credhelp{width:min(560px,94vw)}.credhelp .call-modal-head{justify-content:space-between}.credhelp-intro{margin:0;font-size:13px;color:var(--muted)}.credhelp-row{display:flex;flex-direction:column;gap:3px;padding:10px 12px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:8px}.credhelp-term{font-weight:800;font-family:ui-monospace,monospace;font-size:13px;color:var(--primary)}.credhelp-desc{margin:0;font-size:13px;line-height:1.5;color:var(--fg)}.credhelp-foot{margin:0;font-size:12px;line-height:1.5;color:var(--muted)}.credhelp-prod{border-top:1px solid var(--line);padding-top:10px}.call-modal-section{display:flex;flex-direction:column;gap:6px}.call-modal-section .code{max-height:300px}.call-modal-actions{display:flex;gap:10px;flex-wrap:wrap}.copy-btn{font-size:13px;padding:8px 14px}.copy-btn.copied{color:var(--live);border-color:var(--live);background:var(--live-bg)}.snippet{display:flex;flex-direction:column;gap:8px}.snippet-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.snippet-tabs{display:inline-flex;gap:4px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px}.snippet-tab{background:transparent;border:0;border-radius:999px;padding:5px 14px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit}.snippet-tab:hover{color:var(--fg)}.snippet-tab.active{background:var(--primary);color:var(--primary-ink)}.snippet .copy-btn{font-size:12px;padding:6px 12px}.gate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.gate-modal{width:min(380px,90vw);background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px 26px;display:flex;flex-direction:column;gap:12px;box-shadow:0 24px 70px #16140f2e;text-align:center}.gate-title{margin:0;font-size:22px;font-weight:800;letter-spacing:-.02em}.gate-label{font-size:12px;font-weight:600;color:var(--muted);text-align:left;margin:4px 0 -6px}.gate-input{background:var(--surface);color:var(--fg);border:1px solid var(--line);border-radius:12px;padding:11px 12px;font-size:15px}.gate-input:focus{outline:none;border-color:var(--primary)}.gate-submit{width:100%;padding:11px}.gate-error{color:var(--low);font-size:13px;min-height:16px}@media (max-width: 1000px){.integration-grid,.detail-grid,.call-trace{grid-template-columns:1fr}#app{height:auto;overflow:auto}}.kpn-tour.driver-popover{background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px #16140f47;max-width:340px;padding:18px 18px 14px}.kpn-tour .driver-popover-arrow{display:none}.kpn-tour .driver-popover-title{color:var(--fg);font-size:15px;font-weight:800}.kpn-tour .driver-popover-description{color:var(--muted);font-size:13px;line-height:1.55}.kpn-tour .driver-popover-description b{color:var(--fg)}.kpn-tour .driver-popover-description code{font-family:ui-monospace,monospace;font-size:12px;color:var(--fg);background:var(--surface);border:1px solid var(--line);border-radius:5px;padding:1px 5px}.kpn-tour .driver-popover-close-btn{color:var(--muted)}.kpn-tour .driver-popover-close-btn:hover{color:var(--fg)}.kpn-tour .driver-popover-footer{gap:8px;align-items:center}.kpn-tour .driver-popover-progress-text{color:var(--muted);font-size:11px;font-family:ui-monospace,monospace}.kpn-tour .driver-popover-footer button{text-shadow:none;border-radius:8px;font-weight:600;font-size:13px;padding:6px 12px}.kpn-tour .driver-popover-prev-btn{background:var(--surface);color:var(--fg);border:1px solid var(--line)}.kpn-tour .driver-popover-next-btn{background:var(--primary);color:#fff;border:1px solid var(--primary)}.kpn-tour .driver-popover-next-btn:hover{filter:brightness(1.06)}.kpn-tour-skip{margin-right:auto;background:transparent;border:0;color:var(--muted);font-size:12px;text-decoration:underline;cursor:pointer;padding:0}.kpn-tour-skip:hover{color:var(--fg)}.driver-active .driver-overlay,.driver-active *{pointer-events:none}.driver-active .driver-active-element,.driver-active .driver-active-element *,.driver-popover,.driver-popover *{pointer-events:auto}@keyframes animate-fade-in{0%{opacity:0}to{opacity:1}}.driver-fade .driver-overlay{animation:animate-fade-in .2s ease-in-out}.driver-fade .driver-popover{animation:animate-fade-in .2s}.driver-popover{all:unset;box-sizing:border-box;color:#2d2d2d;margin:0;padding:15px;border-radius:5px;min-width:250px;max-width:300px;box-shadow:0 1px 10px #0006;z-index:1000000000;position:fixed;top:0;right:0;background-color:#fff}.driver-popover *{font-family:Helvetica Neue,Inter,ui-sans-serif,"Apple Color Emoji",Helvetica,Arial,sans-serif}.driver-popover-title{font:19px/normal sans-serif;font-weight:700;display:block;position:relative;line-height:1.5;zoom:1;margin:0}.driver-popover-close-btn{all:unset;position:absolute;top:0;right:0;width:32px;height:28px;cursor:pointer;font-size:18px;font-weight:500;color:#d2d2d2;z-index:1;text-align:center;transition:color;transition-duration:.2s}.driver-popover-close-btn:hover,.driver-popover-close-btn:focus{color:#2d2d2d}.driver-popover-title[style*=block]+.driver-popover-description{margin-top:5px}.driver-popover-description{margin-bottom:0;font:14px/normal sans-serif;line-height:1.5;font-weight:400;zoom:1}.driver-popover-footer{margin-top:15px;text-align:right;zoom:1;display:flex;align-items:center;justify-content:space-between}.driver-popover-progress-text{font-size:13px;font-weight:400;color:#727272;zoom:1}.driver-popover-footer button{all:unset;display:inline-block;box-sizing:border-box;padding:3px 7px;text-decoration:none;text-shadow:1px 1px 0 #fff;background-color:#fff;color:#2d2d2d;font:12px/normal sans-serif;cursor:pointer;outline:0;zoom:1;line-height:1.3;border:1px solid #ccc;border-radius:3px}.driver-popover-footer .driver-popover-btn-disabled{opacity:.5;pointer-events:none}:not(body):has(>.driver-active-element){overflow:hidden!important}.driver-no-interaction,.driver-no-interaction *{pointer-events:none!important}.driver-popover-footer button:hover,.driver-popover-footer button:focus{background-color:#f7f7f7}.driver-popover-navigation-btns{display:flex;flex-grow:1;justify-content:flex-end}.driver-popover-navigation-btns button+button{margin-left:4px}.driver-popover-arrow{content:"";position:absolute;border:5px solid #fff}.driver-popover-arrow-side-over{display:none}.driver-popover-arrow-side-left{left:100%;border-right-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-right{right:100%;border-left-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-top{top:100%;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.driver-popover-arrow-side-bottom{bottom:100%;border-left-color:transparent;border-top-color:transparent;border-right-color:transparent}.driver-popover-arrow-side-center{display:none}.driver-popover-arrow-side-left.driver-popover-arrow-align-start,.driver-popover-arrow-side-right.driver-popover-arrow-align-start{top:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-start,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-start{left:15px}.driver-popover-arrow-align-end.driver-popover-arrow-side-left,.driver-popover-arrow-align-end.driver-popover-arrow-side-right{bottom:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-end,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-end{right:15px}.driver-popover-arrow-side-left.driver-popover-arrow-align-center,.driver-popover-arrow-side-right.driver-popover-arrow-align-center{top:50%;margin-top:-5px}.driver-popover-arrow-side-top.driver-popover-arrow-align-center,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-center{left:50%;margin-left:-5px}.driver-popover-arrow-none{display:none}
