:root{color-scheme:light;--bg: #f6f7f9;--panel: #ffffff;--text: #17202a;--muted: #667085;--line: #d8dee8;--accent: #11766d;--accent-2: #2458a6;--danger: #b42318;--ok: #067647;--shadow: 0 12px 32px rgba(22, 34, 51, .08)}*{box-sizing:border-box}#app{min-height:100vh}html,body{margin:0;padding:0}html{background:var(--bg)}body{min-height:100vh;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea{font:inherit}header{border-bottom:1px solid var(--line);background:#fff}.wrap{width:min(1220px,calc(100vw - 32px));margin:0 auto}.topbar{min-height:68px;padding:16px 0;display:flex;align-items:center;justify-content:space-between;gap:20px}h1{margin:0;font-size:22px;font-weight:720}.sub{margin-top:4px;color:var(--muted);font-size:13px}h2,h3,p{margin:0}main{padding:28px 0 40px}.grid{display:grid;grid-template-columns:260px minmax(0,1fr) 300px;gap:20px;align-items:start}.admin-layout{width:min(1180px,calc(100vw - 32px));margin:24px auto 40px;display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;align-items:start}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:18px}.panel h2{padding:18px 18px 10px;font-size:16px;letter-spacing:0}.provider-list{padding:0 10px 12px;display:grid;gap:6px}.provider-btn{width:100%;min-height:44px;border:1px solid transparent;background:transparent;border-radius:6px;padding:9px 10px;text-align:left;cursor:pointer;color:var(--text);display:flex;justify-content:space-between;gap:12px;align-items:center}.provider-btn:hover{background:#f0f4f8}.provider-btn.active{background:#e8f4f2;border-color:#8ccbc4}.provider-btn strong{display:block;font-size:14px}.provider-btn span{color:var(--muted);font-size:12px}.count{color:var(--accent-2);font-size:12px;white-space:nowrap;font-style:normal}.form{padding:0 18px 18px;display:grid;gap:14px}label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:620}textarea,input{width:100%;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--text);padding:11px 12px;outline:none;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:13px}input{min-height:42px}textarea{min-height:76px;resize:vertical}textarea:focus,input:focus{border-color:#6bb5ad;box-shadow:0 0 0 3px #11766d1f}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}button,a.action{border:0;border-radius:6px;background:var(--accent);color:#fff;min-height:40px;padding:0 14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:14px}button.secondary,a.secondary{background:#e9eef5;color:#223043}.text-link{border:none;width:fit-content;padding:0;min-height:auto;background:transparent;color:var(--accent-2);font-weight:700}.state-indicators{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-items:center}button.danger{background:#fce8e6;color:var(--danger)}button.compact{min-height:32px;padding:0 10px;font-size:12px}.help-text{color:var(--muted);font-size:12px;line-height:1.5;margin-top:2px}.help-text code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;background:#2458a614;border-radius:4px;padding:1px 4px}.notice-warn{margin:0 18px 10px;border:1px solid #f2c97d;background:#fff8e8;border-radius:6px;padding:11px 12px;color:#6b4810;font-size:13px;line-height:1.6;display:flex;align-items:center;justify-content:space-between;gap:12px}.status{min-height:22px;font-size:13px;color:var(--muted);padding:0 18px}.status.ok{color:var(--ok)}.status.err{color:var(--danger)}.result{border-top:1px solid var(--line);padding:18px;display:none;gap:12px}.result.show{display:grid}.result strong{font-size:14px}.token-box{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.token{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;overflow-wrap:anywhere;white-space:pre-wrap;background:#f3f6fa;border:1px solid var(--line);border-radius:6px;padding:11px 12px;min-height:42px;font-size:12px}.callout{margin-top:16px;padding:14px 16px;border:1px solid #bad7d3;background:#edf8f6;border-radius:8px;color:#174d47;font-size:13px;line-height:1.55}.callout code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;background:#2458a614;border-radius:4px;padding:1px 4px}.guide{padding:0 18px 18px;display:grid;grid-template-columns:minmax(260px,1fr) minmax(300px,1.1fr);gap:16px;align-items:start}.steps{margin:0;padding-left:22px;color:#344054;line-height:1.7;font-size:13px}.guide-hint{margin-top:12px;color:var(--muted);font-size:13px;line-height:1.55}.shot{border:1px solid #cbd5e1;border-radius:8px;overflow:hidden;background:#eef2f7}.shot img{width:100%;display:block;background:#fff;cursor:zoom-in}.shot.has-image .mock-shot{display:none}.browser{height:30px;background:#d9e2ec;display:flex;align-items:center;gap:6px;padding:0 10px}.dot{width:9px;height:9px;border-radius:50%;background:#94a3b8}.screen{display:grid;grid-template-columns:38% 62%;min-height:210px;background:#fff}.site{padding:18px;border-right:1px solid var(--line);background:#f8fafc}.site-title{width:70%;height:18px;border-radius:4px;background:#2458a6;margin-bottom:18px}.site-line{height:9px;border-radius:999px;background:#d0d8e4;margin:10px 0}.devtools{padding:14px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:11px;color:#1f2937}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:10px}.tab{border-radius:4px;background:#e9eef5;padding:4px 7px}.tab.active{background:#d7f0ed;color:#0f5f58}.storage-row{display:grid;grid-template-columns:120px 1fr;gap:8px;padding:6px;border-bottom:1px solid #eef2f7}.storage-row.mark{background:#fff7d6;outline:1px solid #e5b80b}.model-note{padding:0 18px 10px;color:var(--muted);font-size:13px;line-height:1.55}.model-note code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;background:#2458a614;border-radius:4px;padding:1px 4px}.models{padding:0 18px 18px;display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid #cbd5e1;border-radius:999px;padding:6px 9px;background:#f8fafc;color:#344054;font-size:12px;display:inline-grid;gap:2px;cursor:pointer;position:relative}.chip:hover{border-color:#8ccbc4;background:#edf8f6}.chip:after{content:"点击复制";position:absolute;left:50%;bottom:calc(100% + 7px);transform:translate(-50%);white-space:nowrap;background:#17202a;color:#fff;border-radius:4px;padding:4px 6px;font-size:11px;opacity:0;pointer-events:none;transition:opacity .12s ease}.chip:hover:after{opacity:1}.chip small{color:var(--muted);font-size:10px}.endpoint-list{padding:0 10px 12px;display:grid;gap:6px}.endpoint{border:1px solid var(--line);border-radius:6px;background:#f8fafc;padding:9px 10px;display:grid;grid-template-columns:1fr auto auto;gap:6px 8px;font-size:12px;align-items:center}.endpoint strong{color:#223043;grid-column:1 / -1}.endpoint code{overflow-wrap:anywhere;background:transparent;padding:0;min-width:0}.endpoint button{border:1px solid #cbd5e1;border-radius:5px;background:#fff;color:#223043;min-height:32px;padding:0 10px;cursor:pointer;white-space:nowrap;font-size:12px}.endpoint button.primary-mini{border-color:#8ccbc4;background:#edf8f6;color:#0f5f58}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c121cc7;display:none;align-items:center;justify-content:center;padding:28px;z-index:20}.lightbox.show{display:flex}.lightbox img{max-width:min(1120px,96vw);max-height:90vh;border-radius:8px;background:#fff;box-shadow:0 24px 70px #00000059}.lightbox button{position:absolute;top:18px;right:18px;width:38px;height:38px;border:0;border-radius:50%;background:#fff;color:#17202a;font-size:22px;line-height:1;cursor:pointer}.modal-example{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c121c9e;display:none;align-items:center;justify-content:center;padding:28px;z-index:21}.modal-example.show{display:flex}.modal-panel{width:min(760px,96vw);max-height:86vh;overflow:auto;background:#fff;border-radius:8px;box-shadow:0 24px 70px #00000047;border:1px solid var(--line)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-head strong{font-size:16px}.modal-head button{width:34px;height:34px;border:0;border-radius:50%;background:#eef2f7;color:#17202a;font-size:20px;cursor:pointer}.modal-body{padding:18px;display:grid;gap:12px}.modal-panel header{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}.register-modal p{margin:0;color:var(--muted);line-height:1.6;padding:16px 18px}.register-modal .link{width:fit-content;margin:0 18px 18px}.modal-panel .icon{width:34px;height:34px;border:0;border-radius:50%;background:#eef2f7;color:#17202a;font-size:20px;cursor:pointer;padding:0}.login-page{min-height:calc(100vh - 1px);display:grid;place-items:center;padding:28px 16px}.login-card{width:min(460px,100%);display:grid;gap:14px}.login-card p{color:var(--muted);font-size:13px;line-height:1.6}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;background:#eef2f7;border-radius:8px}.segmented button{background:transparent;color:#344054}.segmented button.active{background:#fff;color:var(--text);box-shadow:0 1px 4px #10182814}.state{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.state span{padding:6px 8px;border:1px solid var(--line);border-radius:6px;color:var(--muted);font-size:12px}.state span.on{color:var(--ok);border-color:#8ed7b1;background:#effaf3}.state span.warn,.state-indicators span.warn{color:var(--danger);border-color:#f6a29a;background:#fff1f0}.top{min-height:72px;padding:16px max(22px,calc((100vw - 1240px)/2));background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px}.top h1{font-size:22px}.top p{margin-top:4px;color:var(--muted);font-size:13px}.admin-create{display:grid;gap:14px}.admin-users{display:grid;gap:12px}.empty{color:var(--muted);font-size:13px;padding:12px;background:#f8fafc;border:1px solid var(--line);border-radius:8px}.user-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:8px;background:#f8fafc}.user-row strong,.user-row code{display:block}.user-row code{margin-top:5px;color:#344054;font-size:12px;overflow-wrap:anywhere}.account-meta{display:inline-flex;margin-top:7px;color:var(--muted);font-size:12px}.account-meta.active{color:var(--ok)}.account-meta.expired,.account-meta.disabled{color:var(--danger)}.mini-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.admin-logs{grid-column:1 / -1;display:grid;gap:12px}.log-filters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto auto;gap:10px}.log-row{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:12px;display:grid;gap:8px}.log-main,.log-grid,.pager{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.log-main .ok{color:var(--ok)}.log-main .err{color:var(--danger)}.log-main small{color:var(--muted)}.log-grid{color:var(--muted);font-size:12px}.log-row code,.log-row pre{margin:0;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;overflow-wrap:anywhere;white-space:pre-wrap}.log-row code{padding:8px 10px;border-radius:6px;background:#fff;border:1px solid var(--line)}.log-row pre{color:var(--danger);background:#fff1f0;border:1px solid #fac5c0;border-radius:6px;padding:8px 10px}.pager{justify-content:flex-end;color:var(--muted);font-size:13px}.inline-check{grid-template-columns:auto 1fr;align-items:center;color:var(--text)}.inline-check input{width:18px;min-height:18px}.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}@media(max-width:900px){.grid,.guide,.admin-layout,.log-filters{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column;padding:16px 0}.token-box{grid-template-columns:1fr}}@media(max-width:640px){.top{align-items:flex-start;flex-direction:column}}
