/* docs-runner.css — shared response panel + inline runnable snippets +
   editable playground. Opted into by any page that loads /docs-runner.js. */

.docs-resp {
    margin-top: 0.7rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}
.docs-resp.docs-resp-error { border-color: rgba(239, 68, 68, 0.5); }
.docs-resp-step {
    display: flex; align-items: center; flex-wrap: wrap; gap: 0.4rem;
    padding: 0.5rem 0.75rem;
    background: rgba(34, 197, 94, 0.08);
    border-bottom: 1px solid var(--border);
    color: var(--text);
    font: 500 0.78rem var(--sans, inherit);
}
.docs-resp-step i { color: #22c55e; }
.docs-resp-step code {
    font: 600 0.74rem var(--mono);
    background: var(--surface);
    border: 1px solid var(--border);
    padding: 0.05rem 0.4rem;
    border-radius: 5px;
}
.docs-resp-step.docs-resp-step-err {
    background: rgba(239, 68, 68, 0.1);
}
.docs-resp-step.docs-resp-step-err i { color: #ef4444; }
.docs-resp-meta {
    display: flex; align-items: center; gap: 0.45rem;
    padding: 0.55rem 0.75rem;
    background: var(--bg-2);
    border-bottom: 1px solid var(--border);
}
.docs-resp-label {
    color: var(--text-dim, #94a3b8);
    font: 600 0.72rem var(--sans, inherit);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-right: 0.25rem;
}
.docs-pill {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.2rem 0.55rem; border-radius: 999px;
    font: 600 0.74rem var(--mono);
    border: 1px solid var(--border);
}
.docs-pill-ok { background: rgba(34, 197, 94, 0.13); color: #86efac; border-color: rgba(34, 197, 94, 0.32); }
.docs-pill-err { background: rgba(239, 68, 68, 0.13); color: #fca5a5; border-color: rgba(239, 68, 68, 0.32); }
.docs-pill-time { background: var(--surface); color: var(--text); }
.docs-pill-method { background: var(--surface); color: var(--text); }
.docs-resp-actions { margin-left: auto; display: inline-flex; gap: 0.3rem; }
.docs-icon-btn {
    background: transparent;
    color: var(--text-dim, #94a3b8);
    border: 1px solid transparent;
    border-radius: 7px;
    min-width: 32px; height: 32px;
    padding: 0 0.5rem;
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    gap: 0.4rem;
    font: 600 0.76rem var(--sans, inherit);
    transition: color 0.12s, border-color 0.12s, background 0.12s;
}
.docs-icon-btn i { font-size: 0.78rem; }
@media (max-width: 560px) { .docs-icon-btn { min-width: 38px; height: 38px; } }
.docs-icon-btn:hover { color: var(--text-strong); border-color: var(--border); background: var(--surface); }
.docs-icon-btn:focus-visible { outline: 2px solid var(--text-strong); outline-offset: 1px; }
.docs-icon-btn.is-active { color: var(--text-strong); border-color: var(--indigo); background: rgba(255, 255, 255, 0.06); }
.docs-resp pre { margin: 0; padding: 0.9rem 1.1rem; background: var(--bg); border: none; border-radius: 0; overflow-x: auto; }
.docs-resp pre code { color: #e2e8f0; font-family: var(--mono); font-size: 0.82rem; line-height: 1.6; background: transparent; padding: 0; border: none; }
.jk-key { color: #e5e5e5; }
.jk-str { color: #86efac; }
.jk-num { color: #fcd34d; }
.jk-kw  { color: #cccccc; }

/* Inline per-snippet action cluster (Copy + Run, top-right of <pre>) */
.docs-runnable { position: relative; margin: 0.85rem 0 1.25rem; }
.docs-runnable pre { margin: 0; padding-top: 2.6rem; }
.docs-runnable-actions {
    position: absolute; top: 0.5rem; right: 0.55rem;
    display: inline-flex; align-items: center; gap: 0.3rem;
    z-index: 1;
}
.docs-run-inline {
    display: inline-flex; align-items: center; gap: 0.35rem;
    background: rgba(255, 255, 255, 0.06);
    color: var(--text);
    border: 1px solid var(--border-strong);
    border-radius: 7px;
    padding: 0.3rem 0.7rem;
    font: 600 0.74rem var(--sans, inherit);
    line-height: 1;
    cursor: pointer;
    backdrop-filter: blur(4px);
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.docs-run-inline:hover:not(:disabled) { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.docs-run-inline:focus-visible { outline: 2px solid var(--text-strong); outline-offset: 2px; }
.docs-run-inline:disabled { opacity: 0.7; cursor: progress; }
.docs-run-inline i { font-size: 0.72rem; }
.docs-run-inline-ghost {
    background: rgba(5, 5, 5, 0.55);
    color: var(--text-dim, #94a3b8);
    border-color: var(--border);
}
.docs-run-inline-ghost:hover:not(:disabled) {
    background: var(--surface);
    color: var(--text-strong);
    border-color: var(--border-strong);
}
.docs-run-inline-ghost.is-active {
    background: rgba(34, 197, 94, 0.12);
    color: #86efac;
    border-color: rgba(34, 197, 94, 0.4);
}
@media (max-width: 560px) {
    .docs-runnable-actions { top: 0.4rem; right: 0.4rem; gap: 0.25rem; }
    .docs-run-inline { padding: 0.35rem 0.55rem; font-size: 0.72rem; }
    .docs-runnable pre { padding-top: 2.8rem; }
}

/* Docs playground (editable code runner) */
.docs-playground {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 0;
    margin: 0 0 1.75rem;
    overflow: hidden;
}
.docs-pg-toolbar {
    display: flex; align-items: center; justify-content: space-between;
    gap: 0.5rem;
    padding: 0.6rem 0.75rem;
    background: var(--bg-2);
    border-bottom: 1px solid var(--border);
}
.docs-pg-tabs { display: inline-flex; gap: 2px; }
.docs-pg-tabs button {
    border: 1px solid transparent;
    background: transparent;
    color: var(--text);
    padding: 0.4rem 0.85rem;
    border-radius: 7px;
    font: 600 0.78rem var(--sans, inherit);
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 0.4rem;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.docs-pg-tabs button i { font-size: 0.85rem; opacity: 0.85; }
.docs-pg-tabs button:hover { color: var(--text-strong); background: var(--surface); }
.docs-pg-tabs button.active, .docs-pg-tabs button[aria-selected="true"] {
    background: var(--accent);
    color: var(--accent-ink);
    border-color: var(--accent);
}
.docs-pg-tabs button.active i { opacity: 1; color: var(--accent-ink); }
.docs-pg-tabs button:focus-visible { outline: 2px solid var(--text-strong); outline-offset: 2px; }
.docs-pg-toolbar-actions { display: inline-flex; align-items: center; gap: 0.3rem; }

.docs-pg-settings {
    background: rgba(255, 255, 255, 0.04);
    border-top: 1px dashed var(--border);
    border-bottom: 1px solid var(--border);
    padding: 0.7rem 0.95rem;
    display: none;
}
.docs-pg-settings.is-open { display: block; }
.docs-pg-keylabel { display: flex; flex-direction: column; gap: 0.25rem; max-width: 540px; }
.docs-pg-keylabel > span { color: var(--text-strong); font: 600 0.72rem var(--sans, inherit); display: inline-flex; align-items: center; gap: 0.4rem; }
.docs-pg-keylabel > span code { font-family: var(--mono); font-size: 0.72rem; color: var(--text); background: rgba(255, 255, 255, 0.06); padding: 0.05rem 0.35rem; border-radius: 4px; border: none; }
.docs-pg-keylabel > span em { color: var(--text-dim, #94a3b8); font-style: normal; font-weight: 400; font-size: 0.72rem; }
.docs-pg-attrib {
    display: inline-flex; align-items: center; gap: 0.4rem;
    font: 500 0.74rem var(--sans, system-ui, sans-serif);
    color: #15803d;
    background: rgba(34, 197, 94, 0.10);
    border: 1px solid rgba(34, 197, 94, 0.30);
    border-radius: 999px;
    padding: 0.2rem 0.6rem;
    margin-right: 0.25rem;
}
.docs-pg-attrib i { color: #16a34a; }
.docs-pg-attrib strong { font-weight: 700; }
.docs-pg-keylabel input {
    background: var(--bg); color: var(--text-strong);
    border: 1px solid var(--border); border-radius: 7px;
    padding: 0.45rem 0.7rem;
    font: 500 0.82rem var(--mono); width: 100%; box-sizing: border-box;
}
.docs-pg-keylabel input:focus { outline: none; border-color: var(--indigo); box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.18); }

.docs-pg-editor-wrap {
    position: relative;
    background: var(--bg);
    display: flex;
    align-items: stretch;
}
.docs-pg-gutter {
    flex: 0 0 auto;
    width: 2.6rem;
    box-sizing: border-box;
    padding: 0.95rem 0.55rem 0.95rem 0.6rem;
    text-align: right;
    color: var(--text-faint, #4b5563);
    font: 500 0.78rem var(--mono);
    line-height: 1.6;
    background: var(--bg);
    border-right: 1px solid var(--border);
    user-select: none;
    overflow: hidden;
    white-space: pre;
    pointer-events: none;
}
.docs-pg-editor {
    flex: 1 1 auto;
    width: 100%;
    min-height: 200px;
    max-height: 560px;
    box-sizing: border-box;
    background: var(--bg);
    color: #e2e8f0;
    border: none;
    padding: 0.95rem 1.05rem;
    font: 500 0.85rem var(--mono);
    line-height: 1.6;
    resize: none;
    outline: none;
    white-space: pre;
    tab-size: 4;
    -moz-tab-size: 4;
    display: block;
    caret-color: var(--text-strong);
}
.docs-pg-editor::placeholder { color: var(--text-faint, #4b5563); }
.docs-pg-editor:focus { box-shadow: inset 2px 0 0 var(--indigo); }

.docs-pg-footer {
    display: flex; align-items: center; gap: 0.6rem;
    padding: 0.55rem 0.75rem;
    background: var(--bg-2);
    border-top: 1px solid var(--border);
}
.docs-pg-hint {
    color: var(--text-dim, #94a3b8);
    font: 500 0.72rem var(--sans, inherit);
    display: inline-flex; align-items: center; gap: 0.45rem;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.docs-pg-hint kbd {
    font-family: var(--mono);
    font-size: 0.7rem;
    background: var(--surface);
    color: var(--text-strong);
    border: 1px solid var(--border);
    border-bottom-width: 2px;
    border-radius: 5px;
    padding: 0.05rem 0.4rem;
}
.docs-pg-footer-actions { display: inline-flex; align-items: center; gap: 0.4rem; flex-shrink: 0; }
.docs-pg-run {
    display: inline-flex; align-items: center; gap: 0.45rem;
    background: var(--accent);
    color: var(--accent-ink);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    padding: 0.5rem 1rem;
    font: 800 0.78rem var(--sans, inherit);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}
.docs-pg-run:hover:not(:disabled) { background: transparent; color: var(--accent); }
.docs-pg-run:focus-visible { outline: 2px solid var(--text-strong); outline-offset: 2px; }
.docs-pg-run:disabled { opacity: 0.7; cursor: progress; }

.docs-pg-empty {
    padding: 1.5rem 1.2rem;
    text-align: center;
    color: var(--text-dim, #94a3b8);
    font: 500 0.82rem var(--sans, inherit);
    display: flex; flex-direction: column; gap: 0.45rem; align-items: center;
}
.docs-pg-empty i { font-size: 1.15rem; color: var(--text-faint, #4b5563); }
.docs-playground .docs-resp { margin: 0; border: none; border-top: 1px solid var(--border); border-radius: 0; }

@media (max-width: 560px) {
    .docs-pg-toolbar { flex-wrap: wrap; }
    .docs-pg-tabs { flex: 1 1 100%; justify-content: stretch; }
    .docs-pg-tabs button { flex: 1; justify-content: center; }
    .docs-pg-footer { flex-wrap: wrap; }
    .docs-pg-hint { flex: 1 1 100%; white-space: normal; }
    .docs-pg-footer-actions { width: 100%; justify-content: flex-end; }
}
