/* ================================================================
   BUTTON COMPONENT
   4 variants × 7 states × 3 sizes
   Budget: < 4KB minified
   ================================================================ */

/* ── BASE ─────────────────────────────────────────────────────── */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--btn-icon-gap);
    border-radius: var(--btn-radius);
    font-family: var(--font-primary);
    font-weight: var(--weight-semibold);
    white-space: nowrap;
    text-decoration: none;
    cursor: pointer;
    position: relative;
    border: 1px solid transparent;
    transition: var(--btn-transition);
    -webkit-user-select: none;
    user-select: none;
}

/* ── SIZES ────────────────────────────────────────────────────── */

.btn--sm {
    height: var(--btn-height-sm);
    padding: 0 var(--btn-padding-x-sm);
    font-size: var(--btn-text-sm);
}
.btn--md {
    height: var(--btn-height-md);
    padding: 0 var(--btn-padding-x-md);
    font-size: var(--btn-text-md);
}
.btn--lg {
    height: var(--btn-height-lg);
    padding: 0 var(--btn-padding-x-lg);
    font-size: var(--btn-text-lg);
}

/* ── INNER STRUCTURE ──────────────────────────────────────────── */

.btn__content {
    display: inline-flex;
    align-items: center;
    gap: var(--btn-icon-gap);
}
.btn__icon {
    display: inline-flex;
    flex-shrink: 0;
}
.btn__icon svg {
    width: 1em;
    height: 1em;
}
.btn__spinner {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
}
.btn--sm .btn__spinner svg { width: 14px; height: 14px; }
.btn--md .btn__spinner svg { width: 16px; height: 16px; }
.btn--lg .btn__spinner svg { width: 18px; height: 18px; }

@keyframes spin { to { transform: rotate(360deg); } }
.btn__spinner svg { animation: spin 800ms linear infinite; }

/* ── LOADING STATE ────────────────────────────────────────────── */

.btn[data-loading="true"] {
    cursor: wait;
    pointer-events: none;
}
.btn[data-loading="true"] .btn__content {
    visibility: hidden;
}
.btn[data-loading="true"] .btn__spinner {
    opacity: 1;
}

/* ── DISABLED STATE (shared) ──────────────────────────────────── */

.btn:disabled,
.btn[aria-disabled="true"] {
    cursor: not-allowed;
    pointer-events: none;
    box-shadow: none;
    transform: none;
}

/* ── PRIMARY ──────────────────────────────────────────────────── */

.btn--primary {
    background: var(--accent-primary);
    color: var(--accent-primary-fg);
}
.btn--primary:hover {
    background: var(--accent-primary-hover);
    box-shadow: var(--accent-shadow-sm);
    transform: translateY(-1px);
}
.btn--primary:active {
    background: var(--accent-primary-active);
    box-shadow: none;
    transform: translateY(0);
}
.btn--primary:focus-visible {
    outline: 2px solid var(--border-focus);
    outline-offset: 2px;
}
.btn--primary:disabled,
.btn--primary[aria-disabled="true"] {
    background: var(--accent-alpha-30);
    color: var(--text-disabled);
}
.btn--primary[data-success="true"] {
    background: var(--success);
    color: var(--success-fg);
}

/* ── SECONDARY ────────────────────────────────────────────────── */

.btn--secondary {
    background: transparent;
    color: var(--text-primary);
    border-color: var(--border-default);
}
.btn--secondary:hover {
    background: var(--bg-hover);
    border-color: var(--border-strong);
    transform: translateY(-1px);
}
.btn--secondary:active {
    background: var(--bg-active);
    border-color: var(--border-strong);
    transform: translateY(0);
}
.btn--secondary:focus-visible {
    outline: 2px solid var(--border-focus);
    outline-offset: 2px;
}
.btn--secondary:disabled,
.btn--secondary[aria-disabled="true"] {
    color: var(--text-disabled);
    border-color: var(--border-subtle);
}
.btn--secondary[data-success="true"] {
    background: var(--success-muted);
    color: var(--success);
    border-color: var(--success-border);
}

/* ── GHOST ─────────────────────────────────────────────────────── */

.btn--ghost {
    background: transparent;
    color: var(--text-secondary);
}
.btn--ghost:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
    transform: translateY(-1px);
}
.btn--ghost:active {
    background: var(--bg-active);
    color: var(--text-primary);
    transform: translateY(0);
}
.btn--ghost:focus-visible {
    outline: 2px solid var(--border-focus);
    outline-offset: 2px;
}
.btn--ghost:disabled,
.btn--ghost[aria-disabled="true"] {
    color: var(--text-disabled);
}
.btn--ghost[data-success="true"] {
    color: var(--success);
}

/* ── DANGER ────────────────────────────────────────────────────── */

.btn--danger {
    background: var(--danger);
    color: var(--danger-fg);
}
.btn--danger:hover {
    background: var(--danger-hover);
    box-shadow: 0 2px 8px var(--danger-muted);
    transform: translateY(-1px);
}
.btn--danger:active {
    background: var(--danger-active);
    box-shadow: none;
    transform: translateY(0);
}
.btn--danger:focus-visible {
    outline: 2px solid var(--danger);
    outline-offset: 2px;
}
.btn--danger:disabled,
.btn--danger[aria-disabled="true"] {
    background: var(--danger-muted);
    color: var(--text-disabled);
}
.btn--danger[data-success="true"] {
    background: var(--success);
    color: var(--success-fg);
}
