@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";
:root{--bg:#0a0b0e;--surface:#111318;--surface2:#181c24;--border:#1e2430;--accent:#00c9a7;--accent2:#7b5cf0;--accent3:#f0b429;--text:#e8eaf0;--text-secondary:#9099b0;--muted:#5a6478;--danger:#ff4d6d;--claude:#cc785c;--openai:#10a37f;--gemini:#4285f4;--radius:14px;--radius-sm:8px;--shadow:0 4px 24px #0000004d;--grid-color:#00c9a706}[data-theme=light]{--bg:#f0f4f8;--surface:#fff;--surface2:#f7f9fc;--border:#dde3ed;--accent:#00a88c;--accent2:#6344d1;--accent3:#d4960a;--text:#0f1623;--text-secondary:#4a5568;--muted:#8492a6;--danger:#e53e5a;--claude:#b5643c;--openai:#0e8f70;--gemini:#2b63c7;--shadow:0 4px 24px #00000014;--grid-color:#00a88c0a}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;transition:background .25s,color .25s;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(var(--grid-color) 1px, transparent 1px), linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);background-size:40px 40px;transition:none;position:fixed;inset:0}.wrap{z-index:1;max-width:880px;margin:0 auto;padding:0 20px 80px;position:relative}.header{border-bottom:1px solid var(--border);align-items:center;gap:14px;margin-bottom:28px;padding:20px 0 16px;transition:border-color .25s;display:flex}.header-logo-img{flex-shrink:0;width:auto;height:36px;display:block}:root .header-logo-img{filter:brightness(0)invert()}[data-theme=light] .header-logo-img{filter:none}.header-divider{background:var(--border);flex-shrink:0;width:1px;height:28px}.header-subtitle{color:var(--muted);white-space:nowrap;font-family:DM Mono,monospace;font-size:11px}.header-right{align-items:center;gap:10px;margin-left:auto;display:flex}.header-badge{color:var(--accent);white-space:nowrap;background:#00c9a71a;border:1px solid #00c9a733;border-radius:100px;padding:4px 12px;font-family:DM Mono,monospace;font-size:11px;transition:background .25s,color .25s}.theme-toggle{border:1px solid var(--border);background:var(--surface2);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:#00c9a70f}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:20px 22px;transition:border-color .2s,background .25s}.panel--accent{border-color:#00c9a733}.panel--success{background:color-mix(in srgb, var(--surface) 97%, var(--accent) 3%);border-color:#00c9a74d}.panel-title{color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;align-items:center;gap:8px;margin-bottom:14px;font-family:DM Mono,monospace;font-size:10px;font-weight:500;display:flex}.panel-title:after{content:"";background:var(--border);flex:1;height:1px}.steps{align-items:center;margin-bottom:28px;display:flex}.step{align-items:center;gap:7px;display:flex}.step-num{border:1.5px solid var(--border);width:26px;height:26px;color:var(--muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:11px;transition:all .3s;display:flex}.step.active .step-num{border-color:var(--accent);color:var(--accent);background:#00c9a71a;box-shadow:0 0 12px #00c9a726}.step.done .step-num{border-color:var(--accent);background:var(--accent);color:#fff}.step-label{color:var(--muted);white-space:nowrap;font-size:11px}.step.active .step-label{color:var(--text)}.step-line{background:var(--border);flex:1;min-width:16px;height:1px;margin:0 10px}.provider-tabs{gap:8px;margin-bottom:16px;display:flex}.provider-tab{border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:12px 10px;transition:all .2s;display:flex;position:relative}.provider-tab:hover{border-color:var(--muted)}.provider-tab.active-claude{border-color:var(--claude);background:color-mix(in srgb, var(--surface2) 92%, var(--claude) 8%)}.provider-tab.active-openai{border-color:var(--openai);background:color-mix(in srgb, var(--surface2) 92%, var(--openai) 8%)}.provider-tab.active-gemini{border-color:var(--gemini);background:color-mix(in srgb, var(--surface2) 92%, var(--gemini) 8%)}.provider-tab-icon{font-size:22px;line-height:1}.provider-tab-name{color:var(--text);font-family:Syne,sans-serif;font-size:12px;font-weight:700}.provider-tab-sub{color:var(--muted);font-family:DM Mono,monospace;font-size:9px}.provider-tab-check{border:1.5px solid var(--border);width:16px;height:16px;color:var(--muted);border-radius:50%;justify-content:center;align-items:center;font-size:9px;transition:all .2s;display:flex;position:absolute;top:7px;right:7px}.provider-tab.active-claude .provider-tab-check{background:var(--claude);border-color:var(--claude);color:#fff}.provider-tab.active-openai .provider-tab-check{background:var(--openai);border-color:var(--openai);color:#fff}.provider-tab.active-gemini .provider-tab-check{background:var(--gemini);border-color:var(--gemini);color:#fff}.key-area{align-items:stretch;gap:8px;display:flex}.key-input-wrap{flex-direction:column;flex:1;gap:5px;display:flex}.key-label{color:var(--muted);justify-content:space-between;align-items:center;font-family:DM Mono,monospace;font-size:10px;display:flex}.key-label a{color:var(--accent3);font-size:10px;text-decoration:none}.key-label a:hover{text-decoration:underline}.key-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);letter-spacing:.3px;width:100%;padding:10px 12px;font-family:DM Mono,monospace;font-size:12px;transition:border-color .2s,background .25s}.key-input:focus{border-color:var(--accent);outline:none}.key-input.valid{border-color:#00c9a799}.key-input.invalid{border-color:#ff4d6d99}.validate-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;color:var(--muted);white-space:nowrap;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:76px;padding:0 16px;font-family:DM Mono,monospace;font-size:10px;transition:all .2s;display:flex}.validate-btn:hover{border-color:var(--muted);color:var(--text)}.validate-btn.validating{border-color:var(--accent3);color:var(--accent3)}.validate-btn.v-ok{border-color:var(--accent);color:var(--accent);background:#00c9a70f}.validate-btn.v-fail{border-color:var(--danger);color:var(--danger);background:#ff4d6d0f}.validate-btn-icon{font-size:18px}.validate-btn-text{font-size:9px}.model-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.model-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:7px;flex:1;min-width:160px;padding:7px 10px;font-family:DM Mono,monospace;font-size:11px;transition:background .25s,border-color .2s}.model-select:focus{border-color:var(--accent);outline:none}.model-note{color:var(--muted);font-family:DM Mono,monospace;font-size:10px}.key-status{color:var(--muted);align-items:center;gap:6px;min-height:14px;margin-top:8px;font-family:DM Mono,monospace;font-size:10px;display:flex}.key-status.ok{color:var(--accent)}.key-status.fail{color:var(--danger)}.key-status.checking{color:var(--accent3)}.status-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.key-status.checking .status-dot{animation:1s infinite blink}.drop-zone{border:1.5px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);box-shadow:var(--shadow);padding:48px 28px;transition:all .25s;position:relative;overflow:hidden}.drop-zone:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#00c9a70f 0%,#0000 70%);position:absolute;inset:0}.drop-zone.drag-over{border-color:var(--accent);background:color-mix(in srgb, var(--surface) 97%, var(--accent) 3%)}.drop-zone:hover{border-color:#00c9a766}.drop-zone-icon{margin-bottom:14px;font-size:38px;transition:transform .25s;display:block}.drop-zone:hover .drop-zone-icon,.drop-zone.drag-over .drop-zone-icon{transform:translateY(-3px)}.drop-zone h3{color:var(--text);margin-bottom:6px;font-family:Syne,sans-serif;font-size:17px;font-weight:700}.drop-zone p{color:var(--muted);margin-bottom:18px;font-size:12px}.file-tags{justify-content:center;gap:6px;display:flex}.file-tag{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:4px;padding:3px 8px;font-family:DM Mono,monospace;font-size:9px}.file-card-inner{align-items:center;gap:12px;display:flex}.file-icon{background:linear-gradient(135deg,#00c9a724,#7b5cf024);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.file-meta{flex:1}.file-name{color:var(--text);font-size:13px;font-weight:500}.file-stats{color:var(--muted);margin-top:3px;font-family:DM Mono,monospace;font-size:10px}.file-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 8px;font-size:16px;transition:all .2s}.file-remove:hover{color:var(--danger);background:#ff4d6d14}.map-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.map-row{flex-direction:column;gap:5px;display:flex}.map-label{color:var(--muted);font-family:DM Mono,monospace;font-size:10px}.map-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:7px 9px;font-family:DM Sans,sans-serif;font-size:11px;transition:border-color .2s,background .25s}.map-select:focus{border-color:var(--accent);outline:none}.map-select.ok{border-color:#00c9a780}.settings-row{flex-wrap:wrap;align-items:flex-end;gap:14px;display:flex}.setting-item{flex-direction:column;gap:5px;display:flex}.setting-label{color:var(--muted);font-family:DM Mono,monospace;font-size:10px}.setting-input,.setting-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;min-width:130px;padding:7px 10px;font-family:DM Sans,sans-serif;font-size:11px;transition:background .25s,border-color .2s}.setting-input:focus,.setting-select:focus{border-color:var(--accent);outline:none}.gen-btn{background:linear-gradient(135deg, var(--accent), #00967e);color:#fff;cursor:pointer;letter-spacing:.3px;border:none;border-radius:12px;width:100%;margin-bottom:16px;padding:16px;font-family:Syne,sans-serif;font-size:15px;font-weight:700;transition:all .2s;position:relative;overflow:hidden}.gen-btn:before{content:"";opacity:0;background:linear-gradient(135deg,#ffffff24 0%,#0000 60%);transition:opacity .2s;position:absolute;inset:0}.gen-btn:hover:before{opacity:1}.gen-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #00c9a740}.gen-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.progress-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.progress-title{color:var(--text);font-family:Syne,sans-serif;font-size:14px;font-weight:700}.progress-count{color:var(--accent);font-family:DM Mono,monospace;font-size:11px}.progress-track{background:var(--surface2);border-radius:3px;height:5px;margin-bottom:14px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:3px;height:100%;transition:width .35s}.log-wrap{flex-direction:column;gap:4px;max-height:200px;display:flex;overflow-y:auto}.log-wrap::-webkit-scrollbar{width:3px}.log-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.log-row{background:var(--surface2);color:var(--text);border-radius:6px;align-items:center;gap:8px;padding:7px 10px;font-family:DM Mono,monospace;font-size:10px;transition:background .25s;animation:.15s fadeUp;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:none}}.log-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.log-dot.proc{background:var(--accent3);animation:1s infinite blink}.log-dot.ok{background:var(--accent)}.log-dot.err{background:var(--danger)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.log-text{color:var(--text);flex:1}.log-badge{border:1px solid var(--border);text-transform:uppercase;border-radius:3px;padding:2px 6px;font-size:9px}.log-badge.proc{color:var(--accent3);border-color:#f0b42966}.log-badge.ok{color:var(--accent);border-color:#00c9a766}.log-badge.err{color:var(--danger);border-color:#ff4d6d66}.results-header{align-items:center;gap:14px;margin-bottom:18px;display:flex}.results-icon{background:#00c9a71a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.results-title{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:700}.results-sub{color:var(--muted);margin-top:3px;font-size:11px}.stats-row{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:16px;display:grid}.stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;transition:background .25s}.stat-value{color:var(--accent);margin-bottom:2px;font-family:Syne,sans-serif;font-size:22px;font-weight:800}.stat-label{color:var(--muted);font-size:10px}.download-btn{background:var(--surface2);width:100%;color:var(--text);border:1.5px solid var(--border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px 18px;font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex}.download-btn:hover{border-color:var(--accent);color:var(--accent);background:#00c9a70d}.error-msg{border-radius:var(--radius-sm);color:var(--danger);background:#ff4d6d12;border:1px solid #ff4d6d40;align-items:center;gap:8px;margin-bottom:12px;padding:11px 15px;font-size:12px;display:flex}.help-note{color:var(--muted);margin-top:8px;font-size:10px;line-height:1.65}@media (max-width:650px){.provider-tabs{flex-direction:column}.provider-tab{width:100%;min-width:unset}.map-grid,.stats-row{grid-template-columns:1fr}.key-area{flex-direction:column}.header-badge{display:none}.wrap{padding:0 15px 40px}.settings-row{flex-direction:column;align-items:stretch}.setting-item{width:100%}}
