*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f1a;--bg-secondary: #16213e;--bg-tertiary: #1a1a2e;--bg-input: #12132a;--border: #2a2a4a;--border-focus: #4a9eff;--text: #e4e4e4;--text-dim: #8888aa;--text-muted: #555577;--accent: #4a9eff;--accent-hover: #6ab0ff;--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--redirect: #a855f7;--method-get: #22c55e;--method-post: #3b82f6;--method-put: #f59e0b;--method-patch: #a855f7;--method-delete: #ef4444}body{background:var(--bg-primary);color:var(--text);font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100vh;overflow:hidden}#app{height:100%}.harbor-api{display:flex;flex-direction:column;width:100vw;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);flex-shrink:0}.header-brand{display:flex;align-items:center;gap:10px}.brand-icon{font-size:22px}.brand-text{font-size:16px;font-weight:700;letter-spacing:1.5px;background:linear-gradient(135deg,var(--accent),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.brand-badge{font-size:10px;padding:2px 8px;border-radius:10px;background:#4a9eff26;color:var(--accent);border:1px solid rgba(74,158,255,.3);font-weight:500}.header-actions{display:flex;gap:8px}.btn{background:#ffffff0d;border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn:hover{background:#ffffff1a;border-color:var(--accent)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:#ffffff0d;border-color:var(--border)}.btn-sm{padding:4px 10px;font-size:11px}.tab-bar{display:flex;align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border);padding:0 8px;flex-shrink:0;overflow-x:auto}.tabs-scroll{display:flex;flex:1;overflow-x:auto;gap:2px}.tabs-scroll::-webkit-scrollbar{height:0}.tab{display:flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:inherit}.tab:hover{color:var(--text);background:#ffffff08}.tab.active{color:var(--text);border-bottom-color:var(--accent);background:#4a9eff0d}.tab-method{font-size:10px;font-weight:700;letter-spacing:.5px}.tab-name{font-family:SF Mono,Monaco,monospace;font-size:11px}.tab-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.tab-close:hover{color:var(--error)}.tab-add{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:8px 14px;font-size:12px;font-family:inherit;white-space:nowrap}.tab-add:hover{color:var(--accent)}.main-content{display:flex;flex:1;overflow:hidden}.panels{display:flex;flex-direction:column;flex:1;overflow:hidden}.url-bar{display:flex;align-items:center;gap:0;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.method-select{background:var(--bg-input);border:1px solid var(--border);border-right:none;border-radius:8px 0 0 8px;padding:10px 12px;color:var(--method-get);font-size:13px;font-weight:700;font-family:SF Mono,Monaco,monospace;cursor:pointer;min-width:110px}.method-select:focus{outline:none;border-color:var(--border-focus)}.method-select option{background:var(--bg-primary);color:var(--text)}.url-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-left:none;border-right:none;padding:10px 14px;color:var(--text);font-size:14px;font-family:SF Mono,Monaco,monospace}.url-input:focus{outline:none;border-color:var(--border-focus)}.url-input::placeholder{color:var(--text-muted)}.send-btn{background:var(--accent);border:1px solid var(--accent);border-radius:0 8px 8px 0;padding:10px 24px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:6px}.send-btn:hover:not(:disabled){filter:brightness(1.15)}.send-btn:disabled{opacity:.7;cursor:not-allowed}.send-btn.loading{background:var(--accent-hover)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.section-tabs{display:flex;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 16px}.section-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-dim);padding:10px 16px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;font-family:inherit}.section-tab:hover{color:var(--text)}.section-tab.active{color:var(--text);border-bottom-color:var(--accent)}.badge{background:#4a9eff33;color:var(--accent);font-size:10px;padding:1px 6px;border-radius:10px;font-weight:600}.section-content{flex:1;overflow-y:auto;min-height:120px;max-height:300px}.kv-editor{padding:12px 16px}.kv-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.kv-row.disabled{opacity:.4}.kv-toggle{background:none;border:1px solid var(--border);color:var(--text-muted);width:26px;height:26px;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kv-toggle.on{color:var(--success);border-color:var(--success)}.kv-key,.kv-value{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text);font-size:12px;font-family:SF Mono,Monaco,monospace}.kv-key:focus,.kv-value:focus{outline:none;border-color:var(--border-focus)}.kv-key::placeholder,.kv-value::placeholder{color:var(--text-muted)}.kv-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:4px;flex-shrink:0}.kv-remove:hover{color:var(--error)}.kv-add{background:none;border:1px dashed var(--border);border-radius:4px;color:var(--text-dim);padding:6px 12px;font-size:11px;cursor:pointer;width:100%;margin-top:4px;font-family:inherit}.kv-add:hover{border-color:var(--accent);color:var(--accent)}.body-section{display:flex;flex-direction:column;height:100%}.body-type-selector{padding:8px 16px;border-bottom:1px solid var(--border)}.body-type-select,.auth-type-select{background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text);font-size:12px;cursor:pointer}.body-type-select option,.auth-type-select option{background:var(--bg-primary)}.body-editor{flex:1;min-height:150px}.codemirror-container{height:100%;min-height:150px}.auth-section{padding:12px 16px}.auth-type-selector{margin-bottom:12px}.auth-input-row{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.auth-input{background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--text);font-size:13px;font-family:SF Mono,Monaco,monospace}.auth-input:focus{outline:none;border-color:var(--border-focus)}.response-area{display:flex;flex-direction:column;flex:1;overflow:hidden;border-top:1px solid var(--border)}.empty-response{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:40px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}.empty-title{font-size:18px;font-weight:600;color:var(--text-dim);margin-bottom:8px}.empty-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:16px}.empty-hint{display:flex;align-items:center;gap:4px;color:var(--text-muted);font-size:12px}.empty-hint kbd{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:11px;font-family:SF Mono,Monaco,monospace}.response-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.response-status-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.status-badge{font-size:13px;font-weight:700;padding:4px 12px;border-radius:6px;font-family:SF Mono,Monaco,monospace}.status-success{background:#22c55e26;color:var(--success)}.status-redirect{background:#a855f726;color:var(--redirect)}.status-client-error{background:#f59e0b26;color:var(--warning)}.status-server-error,.status-error{background:#ef444426;color:var(--error)}.response-meta{display:flex;gap:16px}.meta-item{font-size:12px;color:var(--text-dim)}.response-tabs{display:flex;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 16px}.response-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-dim);padding:8px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;font-family:inherit}.response-tab:hover{color:var(--text)}.response-tab.active{color:var(--text);border-bottom-color:var(--accent)}.response-content{flex:1;overflow:hidden}.response-body{height:100%}.response-editor{height:100%;min-height:200px}.response-headers{padding:12px;overflow-y:auto;height:100%}.headers-table{width:100%;border-collapse:collapse;font-size:12px}.headers-table th{text-align:left;padding:8px 12px;color:var(--text-dim);font-size:10px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border)}.headers-table td{padding:8px 12px;border-bottom:1px solid rgba(42,42,74,.5)}.header-key{color:var(--accent);font-family:SF Mono,Monaco,monospace;font-weight:500}.header-value{color:var(--text);font-family:SF Mono,Monaco,monospace;word-break:break-all}.response-raw{padding:12px;overflow:auto;height:100%}.raw-output{font-family:SF Mono,Monaco,monospace;font-size:12px;color:var(--text);white-space:pre-wrap;word-break:break-all}.timing-chart{border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.timing-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px}.timing-title{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.timing-stats{display:flex;gap:16px}.timing-stat{display:flex;align-items:center;gap:6px}.stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.stat-value{font-size:12px;font-weight:600;color:var(--accent);font-family:SF Mono,Monaco,monospace}.stat-value.min{color:var(--success)}.stat-value.max{color:var(--warning)}.timing-canvas-wrapper{padding:0 16px 8px;height:80px}.timing-canvas{width:100%;height:100%}.sidebar{width:280px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.sidebar-header h3{font-size:13px;font-weight:600}.sidebar-content{flex:1;overflow-y:auto;padding:8px 0}.sidebar-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px}.history-item{display:flex;flex-direction:column;gap:4px;width:100%;padding:10px 16px;background:none;border:none;border-bottom:1px solid rgba(42,42,74,.3);cursor:pointer;text-align:left;transition:background .15s;font-family:inherit;color:var(--text)}.history-item:hover{background:#4a9eff0d}.history-top{display:flex;align-items:center;justify-content:space-between}.history-method{font-size:10px;font-weight:700;font-family:SF Mono,Monaco,monospace}.history-status{font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px}.history-url{font-size:11px;color:var(--text-dim);font-family:SF Mono,Monaco,monospace}.history-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted)}.env-selector{padding:8px 16px}.env-select{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text);font-size:13px;cursor:pointer}.env-select option{background:var(--bg-primary)}.env-variables{padding:8px 16px}.env-vars-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.env-vars-title{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.env-var-row{display:flex;gap:6px;margin-bottom:6px}.env-var-key{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:6px 8px;color:var(--accent);font-size:11px;font-family:SF Mono,Monaco,monospace;font-weight:600}.env-var-value{flex:2;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:6px 8px;color:var(--text);font-size:11px;font-family:SF Mono,Monaco,monospace}.env-var-key:focus,.env-var-value:focus{outline:none;border-color:var(--border-focus)}.env-hint{font-size:10px;color:var(--text-muted);margin-top:8px;line-height:1.5}.env-hint code{background:var(--bg-input);padding:1px 4px;border-radius:3px;font-size:10px;color:var(--accent)}.app-footer{display:flex;justify-content:center;padding:8px 16px;border-top:1px solid var(--border);background:var(--bg-tertiary);flex-shrink:0}.footer-credit{font-size:11px;color:var(--text-muted)}.footer-credit a{color:var(--accent);text-decoration:none}.footer-credit a:hover{text-decoration:underline}.footer-tech{color:var(--text-muted);font-style:italic}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.request-panel{display:flex;flex-direction:column;background:var(--bg-primary)}
