/**
 * IABT Buttons (Global UI Primitive)
 *
 * These styles are theme-owned so they can be used across the whole site
 * (theme templates, Elementor, and custom plugins) via shared classes.
 */

.iabt-btn,
a.iabt-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 18px;
    font-size: var(--iabt-ui-font-size);
    font-weight: var(--iabt-cta-font-weight);
    letter-spacing: var(--iabt-cta-letter-spacing);
    text-decoration: none;
    border-radius: var(--iabt-radius-pill, 50px);
    border: 1px solid transparent;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
    text-align: center;
    white-space: nowrap;
    line-height: var(--iabt-line-height-tight);
    cursor: pointer;
}

.iabt-btn:focus-visible,
a.iabt-btn:focus-visible {
    outline: 2px solid var(--iabt-focus-ring, hsl(var(--iabt-accent-hsl), 0.35));
    outline-offset: 2px;
}

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

.iabt-btn i,
.iabt-btn svg,
a.iabt-btn i,
a.iabt-btn svg {
    font-size: var(--iabt-text-sm);
    width: 14px;
    height: 14px;
    color: inherit;
}

.iabt-btn svg path,
a.iabt-btn svg path {
    fill: currentColor;
}

.iabt-btn--outlined,
a.iabt-btn--outlined {
    background: transparent;
    color: var(--iabt-primary);
    border-color: hsl(var(--iabt-primary-hsl), 0.3);
}

.iabt-btn--outlined:hover,
a.iabt-btn--outlined:hover {
    background: hsl(var(--iabt-primary-hsl), 0.08);
    border-color: hsl(var(--iabt-primary-hsl), 0.5);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px hsl(var(--iabt-primary-hsl), 0.2);
}

.iabt-btn--filled,
a.iabt-btn--filled {
    background: var(--iabt-primary);
    color: var(--iabt-bg-main);
    border-color: var(--iabt-primary);
    font-weight: var(--iabt-font-semibold);
}

.iabt-btn--filled:hover,
a.iabt-btn--filled:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px hsl(var(--iabt-primary-hsl), 0.2);
}

a.iabt-btn--filled:visited {
    color: var(--iabt-bg-main);
}

a.iabt-btn--outlined:visited {
    color: var(--iabt-primary);
}

a.iabt-btn--danger:visited {
    color: var(--iabt-error);
}

.iabt-btn--text,
a.iabt-btn--text {
    background: transparent;
    color: var(--iabt-text-muted);
    border-color: transparent;
    padding: 8px 12px;
}

.iabt-btn--text:hover,
a.iabt-btn--text:hover {
    color: var(--iabt-primary);
    background: transparent;
}

a.iabt-btn--text:visited {
    color: var(--iabt-text-muted);
}

.iabt-btn--danger,
a.iabt-btn--danger {
    background: hsl(var(--iabt-error-hsl), 0.12);
    color: var(--iabt-error);
    border-color: hsl(var(--iabt-error-hsl), 0.42);
    font-weight: var(--iabt-font-semibold);
}

.iabt-btn--danger:hover,
a.iabt-btn--danger:hover {
    background: var(--iabt-error);
    color: var(--iabt-bg-main);
    border-color: var(--iabt-error);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px hsl(var(--iabt-error-hsl), 0.22);
}

@media (max-width: 767px) {
    .iabt-btn,
    a.iabt-btn {
        padding: 10px 14px;
        gap: 6px;
    }

    .iabt-btn i,
    .iabt-btn svg,
    a.iabt-btn i,
    a.iabt-btn svg {
        font-size: var(--iabt-text-xs);
        width: 12px;
        height: 12px;
    }
}
