/* ── GD UI Kit — Shared component styles ──
 * Reusable micro-components used across all GD projects.
 */

/* ── Notion-style inputs ──
 * Merged from TCA + NTE. NTE version is superset (hover, select, dark).
 */
.notion-input {
    border-radius: 8px;
    border: 1px solid var(--border-input);
    padding: 8px 12px;
    background: var(--bg-input);
    color: var(--text-input);
    font-size: 0.875rem;
    outline: none;
    transition: border-color 150ms, box-shadow 150ms, background 150ms;
    -webkit-appearance: none;
    appearance: none;
}
.notion-input::placeholder { color: var(--placeholder); }
.notion-input:hover { border-color: var(--text-muted); }
.notion-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-border);
}

/* Error state */
.notion-input.is-error { border-color: var(--status-error-text); }
.notion-input.is-error:focus {
    border-color: var(--status-error-text);
    box-shadow: 0 0 0 3px var(--status-error-border);
}

select.notion-input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 32px;
}

.dark .notion-input {
    background-color: var(--bg-input);
    border-color: var(--border-input);
    color: var(--text-input);
}
.dark .notion-input:hover { border-color: var(--scrollbar-thumb-hover); }
.dark .notion-input option {
    background-color: var(--bg-surface);
    color: var(--text-input);
}

/* ── HTMX loading indicator ── */
.htmx-indicator { opacity: 0; transition: opacity 200ms ease-in; }
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator { opacity: 1; }

/* ── Alpine.js cloak ── */
[x-cloak] { display: none !important; }

/* ── Scrollbar — compact variant (TCA) ── */
.compact-scrollbar::-webkit-scrollbar { width: 4px; height: 4px; }
.compact-scrollbar::-webkit-scrollbar-track { background: transparent; }
.compact-scrollbar::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 10px; }
.compact-scrollbar::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }

/* ── Scrollbar — custom variant (NTE) ── */
.custom-scroll::-webkit-scrollbar { width: 5px; }
.custom-scroll::-webkit-scrollbar-track { background: transparent; }
.custom-scroll::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }
.custom-scroll::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }

/* ── Seek bar (audio player range input) ── */
.seek-bar {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    border-radius: 3px;
    background: var(--border-input);
    outline: none;
    cursor: pointer;
}
.seek-bar::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--accent-text);
    border: 2px solid var(--bg-surface);
    cursor: pointer;
    box-shadow: 0 0 6px var(--shadow-accent);
}
.seek-bar::-moz-range-thumb {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--accent-text);
    border: 2px solid var(--bg-surface);
    cursor: pointer;
}
.seek-bar::-webkit-slider-runnable-track { border-radius: 3px; }
