/* ============================================================
   Buttons — All Variants
   ============================================================ */

.btn {
    --bs-btn-padding-x: 1rem;
    --bs-btn-padding-y: 0.75rem;
    --bs-btn-font-size: 0.875rem;
    --bs-btn-font-weight: 500;
    --bs-btn-line-height: 1.5;
    --bs-btn-color: var(--bs-body-color);
    --bs-btn-bg: transparent;
    --bs-btn-border-width: var(--bs-border-width);
    --bs-btn-border-radius: var(--bs-border-radius);
    --bs-btn-box-shadow: 0 0 transparent;
    --bs-btn-disabled-opacity: 0.65;
    --bs-btn-focus-box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), 0.5);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
    font-size: var(--bs-btn-font-size);
    font-weight: var(--bs-btn-font-weight);
    line-height: var(--bs-btn-line-height);
    color: var(--bs-btn-color);
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    background-color: var(--bs-btn-bg);
    border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
    border-radius: var(--bs-btn-border-radius);
    box-shadow: var(--bs-btn-box-shadow);
    transition:
        color var(--dur-fast) var(--ease-out-expo),
        background-color var(--dur-fast) var(--ease-out-expo),
        border-color var(--dur-fast) var(--ease-out-expo),
        box-shadow var(--dur-fast) var(--ease-out-expo),
        transform var(--dur-instant) var(--ease-out-expo);
    position: relative;
    overflow: hidden;
}

.btn:active:not(:disabled) { transform: scale(0.98); }

.btn:hover {
    color: var(--bs-btn-hover-color);
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
}

.btn:focus-visible {
    outline: 2.5px solid var(--bs-link-color);
    outline-offset: 2px;
}

.btn:disabled,
.btn.disabled {
    opacity: var(--bs-btn-disabled-opacity);
    pointer-events: none;
}

.btn-group-sm > .btn,
.btn-sm {
    --bs-btn-padding-y: 0.5rem;
    --bs-btn-padding-x: 1rem;
    --bs-btn-font-size: 0.8125rem;
    --bs-btn-border-radius: 0.3125rem;
}


/* ── Bootstrap Color Variants ─────────────────────────────── */
.btn-white {
    background-color: #fff;
    border: 0.0625rem solid var(--border-light);
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #005A8F;
    --bs-btn-hover-border-color: #005A8F;
    --bs-btn-focus-shadow-rgb: var(--bs-primary-rgb);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #004B77;
    --bs-btn-active-border-color: #004B77;
}

.btn-outline-primary {
    --bs-btn-color: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--bs-primary);
    --bs-btn-hover-border-color: var(--bs-primary);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #005A8F;
    --bs-btn-active-border-color: #005A8F;
}

.btn-danger {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--bs-danger);
    --bs-btn-border-color: var(--bs-danger);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #d63d68;
    --bs-btn-hover-border-color: #d63d68;
}

.btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--bs-success);
    --bs-btn-border-color: var(--bs-success);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #00b397;
    --bs-btn-hover-border-color: #00b397;
}


/* ── Action Buttons (Soft Frosted) ────────────────────────── */
.btn-action,
.btn-action-primary,
.btn-action-success,
.btn-action-info,
.btn-action-warning,
.btn-action-danger {
    border: 1px solid transparent;
    font-weight: 600;
    transition: all 0.2s ease;
}

.btn-action-primary       { background: rgba(var(--bs-primary-rgb), 0.12); color: var(--bs-primary); border-color: rgba(var(--bs-primary-rgb), 0.2); }
.btn-action-primary:hover { background: rgba(var(--bs-primary-rgb), 0.22); color: var(--bs-primary); border-color: rgba(var(--bs-primary-rgb), 0.35); }
.btn-action-success       { background: rgba(var(--bs-success-rgb), 0.12); color: var(--bs-success); border-color: rgba(var(--bs-success-rgb), 0.2); }
.btn-action-success:hover { background: rgba(var(--bs-success-rgb), 0.22); color: var(--bs-success); border-color: rgba(var(--bs-success-rgb), 0.35); }
.btn-action-info          { background: rgba(var(--bs-info-rgb), 0.12);    color: var(--bs-info);    border-color: rgba(var(--bs-info-rgb), 0.2); }
.btn-action-info:hover    { background: rgba(var(--bs-info-rgb), 0.22);    color: var(--bs-info);    border-color: rgba(var(--bs-info-rgb), 0.35); }
.btn-action-warning       { background: rgba(var(--bs-warning-rgb), 0.12); color: var(--color-warning); border-color: rgba(var(--bs-warning-rgb), 0.2); }
.btn-action-warning:hover { background: rgba(var(--bs-warning-rgb), 0.22); color: var(--color-warning); border-color: rgba(var(--bs-warning-rgb), 0.35); }
.btn-action-danger        { background: rgba(var(--bs-danger-rgb), 0.12);  color: var(--bs-danger);  border-color: rgba(var(--bs-danger-rgb), 0.2); }
.btn-action-danger:hover  { background: rgba(var(--bs-danger-rgb), 0.22);  color: var(--bs-danger);  border-color: rgba(var(--bs-danger-rgb), 0.35); }


/* ── Soft / Ghost Buttons ─────────────────────────────────── */
.btn-soft-primary   { color: var(--bs-primary);    background: var(--soft-primary-bg);   border: 1px solid var(--soft-primary-border); }
.btn-soft-success   { color: var(--bs-success);    background: var(--soft-success-bg);   border: 1px solid var(--soft-success-border); }
.btn-soft-info      { color: var(--bs-info);       background: var(--soft-info-bg);      border: 1px solid var(--soft-info-border); }
.btn-soft-warning   { color: var(--color-warning); background: var(--soft-warning-bg);   border: 1px solid var(--soft-warning-border); }
.btn-soft-secondary { color: var(--bs-secondary);   background: var(--soft-secondary-bg); border: 1px solid var(--soft-secondary-border); }

.btn-soft-primary:hover   { background: var(--soft-primary-bg-hover); }
.btn-soft-success:hover   { background: var(--soft-success-bg-hover); }
.btn-soft-info:hover      { background: var(--soft-info-bg-hover); }
.btn-soft-warning:hover   { background: var(--soft-warning-bg-hover); }
.btn-soft-secondary:hover { background: var(--soft-secondary-bg-hover); }

.btn-ghost {
    background: #fff;
    border: 1px solid var(--bs-gray-300);
    color: var(--text-sub);
    transition: all 0.15s ease;
}
.btn-ghost:hover {
    background: #fff;
    border-color: var(--bs-gray-400);
    color: var(--bs-heading-color);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}


/* ── Gradient Primary CTA ─────────────────────────────────── */
.btn-gradient-primary {
    background: var(--gradient-primary);
    color: #fff;
    border: none;
}
.btn-gradient-primary:hover {
    background: var(--gradient-primary-hover);
    color: #fff;
}


/* ── Icon-only pill buttons (paired with primary actions) ──── */
.btn-icon-pill {
    width: 32px;
    height: 32px;
    padding: 0;
    border-radius: 50%;
    line-height: 1;
}
.btn-icon-pill > i { font-size: 0.95rem; line-height: 1; }
.btn-icon-pill:focus-visible { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.18); }

/* Clinic-actions toolbar (in clinic_switcher) — keeps the primary
   "Add Clinic" CTA next to two icon-only side actions. */
.clinic-actions { flex-wrap: wrap; }
.clinic-actions .btn-soft-primary { box-shadow: 0 1px 2px rgba(var(--bs-primary-rgb), 0.12); }
.clinic-actions .btn-icon-pill:hover { transform: translateY(-1px); transition: transform 0.12s ease; }
