/* api-builder.css — tool-specific styles */

.api-main {
    max-width: 960px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* ── URL bar ───────────────────────────────────────────────────────────────── */
.url-bar {
    display: flex;
    gap: 0.5rem;
    align-items: stretch;
}

.method-select {
    padding: 0.7rem 0.6rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-main);
    font-size: 0.95rem;
    font-weight: 700;
    background: var(--color-surface);
    color: var(--color-primary);
    cursor: pointer;
    flex-shrink: 0;
}

.url-input {
    flex: 1;
    padding: 0.7rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: 0.95rem;
    background: var(--color-surface);
    color: var(--color-text);
    min-width: 0;
    transition: border-color 0.2s;
}

.url-input:focus { outline: none; border-color: var(--color-primary); }

.send-btn {
    flex-shrink: 0;
    padding: 0.7rem 1.4rem;
}

/* ── Cards ─────────────────────────────────────────────────────────────────── */
.section-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.section-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 1rem;
    background: #f0f4fa;
    border-bottom: 1px solid var(--color-border);
    flex-wrap: wrap;
}

.section-title {
    font-weight: 700;
    font-size: 0.88rem;
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    flex: 1;
}

/* ── Tabs ───────────────────────────────────────────────────────────────────── */
.section-tabs, .resp-tabs {
    display: flex;
    background: #f0f4fa;
    border-bottom: 1px solid var(--color-border);
}

.section-tab, .resp-tab {
    padding: 0.55rem 1rem;
    border: none;
    border-bottom: 2px solid transparent;
    background: transparent;
    font-family: var(--font-main);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}

.section-tab.active, .resp-tab.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.tab-pane { display: none; padding: 0.85rem 1rem; }
.tab-pane.active { display: block; }

/* ── Key-value rows ────────────────────────────────────────────────────────── */
.kv-list {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    margin-bottom: 0.5rem;
}

.kv-row {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 0.4rem;
    align-items: center;
}

.kv-row input {
    padding: 0.45rem 0.6rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: 0.85rem;
    background: var(--color-bg);
    color: var(--color-text);
    width: 100%;
    transition: border-color 0.2s;
}

.kv-row input:focus { outline: none; border-color: var(--color-primary); }

.kv-row input.kv-desc {
    font-family: var(--font-main);
}

.kv-remove {
    padding: 0.4rem 0.55rem;
    border: none;
    background: #f5e0e0;
    color: #c00;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.85rem;
    line-height: 1;
    transition: background 0.15s;
}

.kv-remove:hover { background: #f5c6c6; }

.add-row-btn {
    background: none;
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-sm);
    padding: 0.35rem 0.75rem;
    font-family: var(--font-main);
    font-size: 0.85rem;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s;
    width: 100%;
    text-align: left;
}

.add-row-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Body ───────────────────────────────────────────────────────────────────── */
.body-type-row, .auth-type-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
}

.radio-label {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.9rem;
    cursor: pointer;
}

.radio-label input { accent-color: var(--color-primary); }

.body-textarea {
    width: 100%;
    min-height: 140px;
    padding: 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.88rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
    resize: vertical;
    box-sizing: border-box;
    transition: border-color 0.2s;
}

.body-textarea:focus { outline: none; border-color: var(--color-primary); }

.body-error {
    margin-top: 0.4rem;
    padding: 0.45rem 0.7rem;
    background: #fff0f0;
    border: 1px solid #f5c2c2;
    border-radius: var(--radius-sm);
    color: #c00;
    font-size: 0.85rem;
}

.body-error.hidden { display: none; }

/* ── Auth fields ────────────────────────────────────────────────────────────── */
.auth-field-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 480px;
}

.auth-field-group label {
    font-size: 0.88rem;
    font-weight: 600;
}

.auth-field-group input {
    padding: 0.55rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: 0.9rem;
    background: var(--color-bg);
    color: var(--color-text);
    width: 100%;
    transition: border-color 0.2s;
}

.auth-field-group input:focus { outline: none; border-color: var(--color-primary); }

/* ── Code blocks ────────────────────────────────────────────────────────────── */
.code-block {
    margin: 0;
    padding: 0.9rem 1rem;
    background: #1e1e2e;
    color: #cdd6f4;
    border-radius: 0;
    font-family: var(--font-mono);
    font-size: 0.85rem;
    line-height: 1.6;
    overflow-x: auto;
    white-space: pre;
    max-height: 380px;
    overflow-y: auto;
}

/* ── Status / time badges ───────────────────────────────────────────────────── */
.status-badge {
    font-size: 0.82rem;
    font-weight: 700;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
}

.status-2xx { background: #d4edda; color: #155724; }
.status-3xx { background: #d1ecf1; color: #0c5460; }
.status-4xx { background: #fff3cd; color: #856404; }
.status-5xx { background: #f8d7da; color: #721c24; }

.time-badge {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

/* ── Snippet tabs ───────────────────────────────────────────────────────────── */
.snippet-tabs {
    display: flex;
    gap: 0.3rem;
}

.snippet-tab {
    padding: 0.25rem 0.65rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    font-family: var(--font-main);
    font-size: 0.82rem;
    cursor: pointer;
    color: var(--color-text-muted);
    transition: background 0.15s;
}

.snippet-tab.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* ── Copy button ────────────────────────────────────────────────────────────── */
.copy-btn {
    padding: 0.3rem 0.8rem;
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--font-main);
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 0.2s;
    flex-shrink: 0;
}

.copy-btn:hover { background: var(--color-primary-dk); }
.copy-btn.copied { background: #28a745; }

/* ── Extractor ──────────────────────────────────────────────────────────────── */
.extractor-row {
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--color-border);
}

/* ── Loading spinner ────────────────────────────────────────────────────────── */
.send-btn.loading {
    opacity: 0.7;
    cursor: not-allowed;
}

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .url-bar { flex-wrap: wrap; }
    .url-input { width: 100%; }
    .send-btn { width: 100%; }
    .kv-row { grid-template-columns: 1fr auto; }
    .kv-row input:first-child { grid-column: 1 / -1; }
}
