:root{--bg: #0c0c0c;--panel: #111111;--panel-hi: #161616;--border: #242424;--border-hi: #3a3a3a;--text: #e6e6e6;--text-dim: #b5b5b5;--muted: #6a6a6a;--accent: #f2f2f2;--accent-hi:#ffffff;--on-accent:#000000;--accent-soft:#1c1c1c;--error: #ff5a5a;--ok: #5fbf6a;--mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;--sans: -apple-system, "Inter", "Helvetica Neue", "PingFang SC", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--sans);font-size:13px;line-height:1.45;min-height:100vh;-webkit-font-smoothing:antialiased}button{font-family:inherit}::selection{background:var(--accent);color:var(--on-accent)}.layout{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .18s ease}.layout.is-collapsed .sidebar{width:56px}.brand{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text);white-space:nowrap;overflow:hidden}.brand-mark{color:var(--accent);font-size:14px;line-height:1;flex-shrink:0}.brand-text{flex:1;overflow:hidden;text-overflow:ellipsis}.brand-collapse{background:transparent;border:1px solid transparent;color:var(--muted);cursor:pointer;width:22px;height:22px;padding:0;font-family:var(--mono);font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:0;transition:color .1s ease,border-color .1s ease}.brand-collapse:hover{color:var(--text);border-color:var(--border)}.layout.is-collapsed .brand{padding:14px 0;justify-content:center}.layout.is-collapsed .brand-text,.layout.is-collapsed .brand-mark{display:none}.layout.is-collapsed .brand-collapse{width:28px;height:28px}.side-nav{display:flex;flex-direction:column;padding:8px 0;flex:1}.side-link{display:flex;align-items:center;gap:12px;padding:8px 16px;color:var(--text-dim);text-decoration:none;font-family:var(--sans);font-size:13px;border-left:2px solid transparent;white-space:nowrap;overflow:hidden}.side-glyph{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--muted);width:22px;flex-shrink:0;text-align:center;letter-spacing:.05em}.layout.is-collapsed .side-label{display:none}.layout.is-collapsed .side-link{padding:8px 0;justify-content:center;gap:0}.side-link:hover{color:var(--text);background:var(--panel-hi)}.side-link.active{color:var(--text);border-left-color:var(--accent);background:var(--panel-hi)}.side-link.active .side-glyph{color:var(--accent)}.content{flex:1;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--panel);border-bottom:1px solid var(--border);min-height:44px}.topbar-title{display:flex;align-items:center;gap:12px}.topbar-title h1{margin:0;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text)}.area-tag{font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.18em;background:var(--accent);color:var(--on-accent);padding:3px 8px;border:1px solid var(--accent)}.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-tag{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid var(--border);font-family:var(--mono);font-size:11px;color:var(--text-dim)}.topbar-tag .glyph{font-family:var(--mono);font-size:9px;font-weight:700;color:var(--muted);letter-spacing:.14em}.topbar-btn{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:4px 12px;border-radius:0;font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;transition:color .1s ease,border-color .1s ease}.topbar-btn:hover{color:var(--text);border-color:var(--border-hi)}.page-body{padding:24px;max-width:1300px;margin:0 auto}form{background:var(--panel);padding:18px;border-radius:0;border:1px solid var(--border)}label{display:block;margin-bottom:14px;font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.checkbox-label{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:normal;font-size:13px;color:var(--text-dim);cursor:pointer;font-family:var(--sans)}.checkbox-label input[type=checkbox]{width:auto;margin:0;accent-color:var(--accent)}textarea,input[type=text],input[type=password],input[type=number],select{display:block;width:100%;margin-top:6px;padding:7px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:0;font-size:13px;text-transform:none;letter-spacing:normal;font-family:var(--mono);outline:none;transition:border-color .1s ease}textarea:focus,input:focus,select:focus{border-color:var(--border-hi)}textarea{resize:vertical;min-height:60px;line-height:1.5}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}button.primary,.btn{background:var(--accent);color:var(--on-accent);border:1px solid var(--accent);padding:8px 22px;border-radius:0;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;margin-top:8px;transition:background .1s ease}button.primary:hover,.btn:hover{background:var(--accent-hi);border-color:var(--accent-hi)}button.primary:disabled,.btn:disabled{opacity:.4;cursor:wait}.btn-sm{padding:4px 10px;font-size:10px;margin-top:0}.btn-outline{background:transparent;color:var(--text-dim);border-color:var(--border)}.btn-outline:hover{color:var(--text);border-color:var(--border-hi);background:transparent}.btn-danger{background:transparent;color:var(--error);border-color:var(--error)}.btn-danger:hover{background:var(--error);color:var(--bg);border-color:var(--error)}.picker{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:6px 14px;border-radius:0;cursor:pointer;margin-top:6px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.picker:hover{border-color:var(--border-hi);color:var(--text)}.files{display:inline-block;margin-left:10px;color:var(--muted);font-size:11px;text-transform:none;font-family:var(--mono)}table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:0;font-family:var(--mono);font-size:11px;margin-bottom:16px}th,td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--border)}th:first-child,td:first-child{text-align:left}th{color:var(--muted);font-weight:700;text-transform:uppercase;font-size:9px;letter-spacing:.14em;background:var(--panel-hi)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--panel-hi)}.badge{display:inline-block;padding:2px 8px;border-radius:0;font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;border:1px solid}.badge-active{color:var(--ok);border-color:var(--ok);background:transparent}.badge-disabled{color:var(--muted);border-color:var(--border);background:transparent}.cost-cell{color:var(--accent)}.model-tag{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:2px 8px;border-radius:0;font-family:var(--mono);font-size:10px}.sub-row{background:var(--bg)}.sub-row td{font-size:10px;color:var(--muted);padding:6px 12px}.toggle-btn{cursor:pointer;user-select:none;color:var(--accent);font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em}.overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:100}.modal{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:24px;width:460px;max-width:92vw}.modal h3{margin-bottom:16px;font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em}.modal input{width:100%;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:0;color:var(--text);font-family:var(--mono);font-size:13px;margin-bottom:14px;outline:none}.modal input:focus{border-color:var(--border-hi)}.modal .actions{display:flex;gap:8px;justify-content:flex-end}.key-display{background:var(--bg);border:1px solid var(--border);border-radius:0;padding:12px;font-family:var(--mono);font-size:11px;word-break:break-all;margin-bottom:14px;color:var(--accent)}.key-display .copy-row{display:flex;gap:8px;margin-top:10px}.tabs{display:flex;border-bottom:1px solid var(--border);background:var(--panel);padding:0 16px;margin-bottom:16px}.tab{background:none;border:none;color:var(--muted);padding:10px 18px;cursor:pointer;font-family:var(--mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--text-dim)}.tab.active{color:var(--text);border-bottom-color:var(--accent)}.results{margin-top:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.result-card{background:var(--panel);border:1px solid var(--border);border-radius:0;overflow:hidden;display:flex;flex-direction:column}.result-card img{width:100%;display:block;background:#000;transition:opacity .2s}.result-actions{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border);justify-content:stretch}.result-actions a,.result-actions button{flex:1;background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:5px 10px;border-radius:0;cursor:pointer;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;text-align:center;text-decoration:none}.result-actions a:hover,.result-actions button:hover{border-color:var(--border-hi);color:var(--text)}.error-box{background:transparent;border:1px solid var(--error);border-left:3px solid var(--error);color:var(--error);padding:10px 14px;border-radius:0;margin-top:12px;font-family:var(--mono);font-size:11px;white-space:pre-wrap;word-break:break-all;grid-column:1 / -1}.spinner{display:inline-block;width:12px;height:12px;border:1px solid var(--border-hi);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:32px;max-width:440px;width:100%;position:relative}.login-card h1{font-family:var(--mono);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;margin-bottom:8px}.login-card p{color:var(--muted);margin:0 0 20px;line-height:1.5;font-size:12px}.login-card label{display:block;margin-bottom:16px}.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:24px}.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:14px 16px}.stat-card .label{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}.stat-card .value{font-family:var(--mono);font-size:22px;font-weight:600;margin-top:6px;color:var(--text)}.stat-card.cost .value{color:var(--accent)}.section-header{display:flex;justify-content:space-between;align-items:center;margin:20px 0 8px}.section-header h2{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;margin:0;color:var(--text-dim)}.chart-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.chart-controls label{display:flex;align-items:center;gap:8px;margin-bottom:0;font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}.chart-controls select{width:auto;margin:0;padding:5px 10px;font-family:var(--mono);font-size:11px}.chart-box{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:14px 16px;margin-bottom:20px;position:relative}.chart-svg{width:100%;height:240px;display:block}.chart-svg .bar{fill:var(--accent)}.chart-svg .bar:hover{filter:brightness(1.15)}.chart-svg .grid{stroke:var(--border);stroke-width:1}.chart-svg .axis{fill:var(--muted);font-size:10px;font-family:var(--mono)}.chart-legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:10px;font-family:var(--mono);font-size:10px;color:var(--muted)}.chart-legend .item{display:inline-flex;align-items:center;gap:6px}.chart-legend .swatch{display:inline-block;width:10px;height:10px}.chat{display:flex;flex-direction:column;gap:12px}.chat-controls{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;background:var(--panel);border:1px solid var(--border);border-radius:0;padding:12px 16px}.chat-controls label{margin-bottom:0;flex:0 0 auto}.chat-controls .chat-system{flex:1 1 280px}.chat-messages{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:16px;min-height:320px;max-height:60vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.chat-empty{color:var(--muted);text-align:center;padding:60px 0;font-size:12px;font-family:var(--mono)}.chat-bubble{display:flex;flex-direction:column;gap:4px;max-width:90%}.chat-bubble.chat-user{align-self:flex-end;align-items:flex-end}.chat-bubble.chat-assistant{align-self:flex-start}.chat-role{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.18em}.chat-content{background:transparent;border:1px solid var(--border);border-radius:0;padding:10px 14px;line-height:1.55;white-space:pre-wrap;word-break:break-word;font-size:13px;color:var(--text)}.chat-bubble.chat-user .chat-content{background:var(--text);color:var(--bg);border-color:var(--text)}.chat-input{display:flex;flex-direction:column;gap:8px;background:var(--panel);border:1px solid var(--border);border-radius:0;padding:12px}.chat-input textarea{margin:0}.chat-actions{display:flex;justify-content:flex-end}.chat-actions button.primary{margin:0}.usage{display:flex;flex-direction:column;gap:24px}.usage-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.usage-card{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:14px 16px}.usage-card .label{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}.usage-card .value{font-family:var(--mono);font-size:22px;font-weight:600;margin-top:6px;color:var(--text)}.usage-card.accent .value{color:var(--accent)}.usage-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.usage-section-header h2{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;margin:0;color:var(--text-dim)}.usage-section-header select{width:auto;margin:0;font-size:11px;padding:4px 8px}.usage-chart{background:var(--panel);border:1px solid var(--border);border-radius:0;padding:12px;height:160px}.usage-chart svg{width:100%;height:100%}.usage-table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:0;font-family:var(--mono);font-size:11px}.usage-table th,.usage-table td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--border)}.usage-table th:first-child,.usage-table td:first-child{text-align:left}.usage-table th{color:var(--muted);font-weight:700;text-transform:uppercase;font-size:10px;letter-spacing:.6px}.usage-table tr:last-child td{border-bottom:none}.usage-row-err td{color:var(--error)}.image-progress{position:relative;margin-top:16px;height:22px;border:1px solid var(--border);background:var(--panel);overflow:hidden}.image-progress-bar{position:absolute;inset:0 auto 0 0;background:var(--accent);transition:width .18s linear}.image-progress-tick{position:absolute;top:0;bottom:0;width:1px;background:var(--bg);pointer-events:none}.image-progress-label{position:relative;font-family:var(--mono);font-size:10px;color:var(--text);mix-blend-mode:difference;text-transform:uppercase;letter-spacing:.14em;display:flex;align-items:center;justify-content:center;height:100%;pointer-events:none}.img-history{margin-top:28px}.img-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.img-history-header h2{margin:0;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-dim)}.img-history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.img-history-item{display:flex;gap:14px;background:var(--panel);border:1px solid var(--border);padding:10px 12px}.img-history-thumbs{display:flex;gap:6px;flex-shrink:0}.img-history-thumbs a,.img-history-missing{display:block;width:64px;height:64px;border:1px solid var(--border);background:#000}.img-history-thumbs img{width:100%;height:100%;object-fit:cover;display:block}.img-history-missing{color:var(--muted);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:18px}.img-history-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.img-history-prompt{font-size:13px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.img-history-meta{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.img-history-actions{display:flex;gap:6px;margin-top:auto}.img-history-actions .picker{margin-top:0}.img-history-actions .btn-danger{color:var(--error);border-color:var(--error)}.img-history-actions .btn-danger:hover{background:var(--error);color:var(--bg)}.img-history-item .drag-handle{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:18px;align-self:stretch;color:var(--muted);font-family:var(--mono);font-size:14px;line-height:1;letter-spacing:-2px;cursor:grab;user-select:none}.img-history-item .drag-handle:hover{color:var(--text)}.img-history-item .drag-handle:active{cursor:grabbing}.img-history-item.dragging{opacity:.4}.img-history-item.drag-over{border-color:var(--accent)}.img-history-item .img-history-prompt{cursor:text}.chat-history-rename{font-size:13px;color:var(--text);background:var(--bg);border:1px solid var(--accent);padding:2px 6px;margin:0;font-family:inherit;width:100%}.ref-thumbs{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 16px}.ref-thumb{position:relative;width:80px;height:80px;border:1px solid var(--border);background:#000}.ref-thumb img{width:100%;height:100%;object-fit:cover;display:block}.ref-thumb-remove{position:absolute;top:0;right:0;width:20px;height:20px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-top:none;border-right:none;font-family:var(--mono);font-size:14px;line-height:1;cursor:pointer;padding:0}.ref-thumb-remove:hover{background:var(--error);color:var(--bg)}.form-banner{font-family:var(--mono);font-size:11px;color:var(--text-dim);background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--accent);padding:8px 12px;margin-bottom:12px;line-height:1.5}.form-banner strong{color:var(--text);font-weight:700}.topbar-tag,.topbar-btn{height:26px;box-sizing:border-box;padding-top:0;padding-bottom:0;line-height:24px}.theme-cycle{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:80px}.theme-swatch{display:inline-block;width:10px;height:10px;border:1px solid var(--border-hi)}.lang-toggle{min-width:50px;display:inline-flex;align-items:center;justify-content:center}.file-picker{display:inline-flex;align-items:center;gap:10px;margin-top:4px}.file-picker-native{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.file-picker-status{font-family:var(--mono);font-size:11px;color:var(--muted)}
