/* ============================================
   BIM Buttons — Centralized Button System
   ============================================
   High specificity selectors (button.bim-btn,
   a.bim-btn) to override WordPress theme and
   Elementor aggressive styles.

   CRITICAL: WordPress themes apply broad rules
   like button:hover { background: #ff1b1b; }.
   We use !important on background hover rules
   and element-qualified selectors to win.
   ============================================ */

/* ── BASE ── */
button.bim-btn,
a.bim-btn,
.bim-btn {
    padding: 0.625rem 1.25rem;
    border-radius: var(--bim-radius);
    font-size: 0.875rem;
    font-weight: 700;
    font-family: var(--bim-font);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--bim-space-2);
    border: none;
    text-decoration: none;
    line-height: 1.4;
    white-space: nowrap;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}

/* ── ICON INSIDE BUTTONS ── */
button.bim-btn .material-symbols-outlined,
a.bim-btn .material-symbols-outlined,
.bim-btn .material-symbols-outlined {
    font-size: 1rem;
    line-height: 1;
}

/* ── LOADING PATTERN ── */
.bim-btn-text {
    display: inline-flex;
    align-items: center;
    gap: var(--bim-space-2);
}

.bim-btn-loading {
    display: none;
    align-items: center;
    gap: var(--bim-space-2);
}

/* ============================================
   VARIANTS
   ============================================ */

/* ── PRIMARY (Red accent) ── */
button.bim-btn.bim-btn-primary,
a.bim-btn.bim-btn-primary,
.bim-btn.bim-btn-primary {
    background: var(--bim-accent) !important;
    color: var(--bim-surface) !important;
    box-shadow: var(--bim-shadow-accent);
}

button.bim-btn.bim-btn-primary:hover,
a.bim-btn.bim-btn-primary:hover,
.bim-btn.bim-btn-primary:hover {
    background: var(--bim-accent-hover) !important;
    box-shadow: var(--bim-shadow-accent-hover);
}

button.bim-btn.bim-btn-primary:active,
a.bim-btn.bim-btn-primary:active,
.bim-btn.bim-btn-primary:active {
    transform: scale(0.98);
}

button.bim-btn.bim-btn-primary:focus-visible,
a.bim-btn.bim-btn-primary:focus-visible,
.bim-btn.bim-btn-primary:focus-visible {
    outline: 2px solid var(--bim-accent);
    outline-offset: 2px;
}

/* ── OUTLINE (Light/secondary) ── */
button.bim-btn.bim-btn-outline,
a.bim-btn.bim-btn-outline,
.bim-btn.bim-btn-outline {
    background: var(--bim-surface) !important;
    color: var(--bim-text-secondary) !important;
    border: 1px solid var(--bim-border);
    box-shadow: var(--bim-shadow-sm);
}

button.bim-btn.bim-btn-outline:hover,
a.bim-btn.bim-btn-outline:hover,
.bim-btn.bim-btn-outline:hover {
    background: var(--bim-bg-input) !important;
    border-color: var(--bim-text-faint);
}

button.bim-btn.bim-btn-outline:active,
a.bim-btn.bim-btn-outline:active,
.bim-btn.bim-btn-outline:active {
    transform: scale(0.98);
}

button.bim-btn.bim-btn-outline:focus-visible,
a.bim-btn.bim-btn-outline:focus-visible,
.bim-btn.bim-btn-outline:focus-visible {
    outline: 2px solid var(--bim-accent);
    outline-offset: 2px;
}

/* ── GHOST (Dark-background transparent button) ── */
button.bim-btn.bim-btn-ghost,
a.bim-btn.bim-btn-ghost,
.bim-btn.bim-btn-ghost {
    background: transparent !important;
    color: rgba(255, 255, 255, 0.45) !important;
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: none;
}

button.bim-btn.bim-btn-ghost:hover,
a.bim-btn.bim-btn-ghost:hover,
.bim-btn.bim-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    border-color: rgba(255, 255, 255, 0.3);
    color: rgba(255, 255, 255, 0.7) !important;
}

button.bim-btn.bim-btn-ghost:active,
a.bim-btn.bim-btn-ghost:active,
.bim-btn.bim-btn-ghost:active {
    transform: scale(0.98);
}

/* ── DARK ── */
button.bim-btn.bim-btn-dark,
a.bim-btn.bim-btn-dark,
.bim-btn.bim-btn-dark {
    background: var(--bim-dark) !important;
    color: var(--bim-surface) !important;
}

button.bim-btn.bim-btn-dark:hover,
a.bim-btn.bim-btn-dark:hover,
.bim-btn.bim-btn-dark:hover {
    background: var(--bim-dark-hover) !important;
}

button.bim-btn.bim-btn-dark:active,
a.bim-btn.bim-btn-dark:active,
.bim-btn.bim-btn-dark:active {
    transform: scale(0.98);
}

/* ── SUCCESS ── */
button.bim-btn.bim-btn-success,
a.bim-btn.bim-btn-success,
.bim-btn.bim-btn-success {
    background: var(--bim-success) !important;
    color: var(--bim-surface) !important;
}

button.bim-btn.bim-btn-success:hover,
a.bim-btn.bim-btn-success:hover,
.bim-btn.bim-btn-success:hover {
    background: var(--bim-success-dark) !important;
}

/* ── DANGER ── */
button.bim-btn.bim-btn-danger,
a.bim-btn.bim-btn-danger,
.bim-btn.bim-btn-danger {
    background: var(--bim-danger) !important;
    color: var(--bim-surface) !important;
}

button.bim-btn.bim-btn-danger:hover,
a.bim-btn.bim-btn-danger:hover,
.bim-btn.bim-btn-danger:hover {
    background: var(--bim-accent-hover) !important;
}

/* ── ACCENT (brand red) ── */
button.bim-btn.bim-btn-accent,
a.bim-btn.bim-btn-accent,
.bim-btn.bim-btn-accent {
    background: var(--bim-accent) !important;
    color: var(--bim-surface) !important;
}

button.bim-btn.bim-btn-accent:hover,
a.bim-btn.bim-btn-accent:hover,
.bim-btn.bim-btn-accent:hover {
    background: var(--bim-accent-hover) !important;
}

button.bim-btn.bim-btn-accent:active,
a.bim-btn.bim-btn-accent:active,
.bim-btn.bim-btn-accent:active {
    transform: scale(0.98);
}

/* ── AUTH (Red accent CTA - used in customer forms) ── */
button.bim-btn.bim-btn-auth,
a.bim-btn.bim-btn-auth,
.bim-btn.bim-btn-auth {
    background: var(--bim-accent) !important;
    color: var(--bim-surface) !important;
    padding: 1rem 1.5rem;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: var(--bim-shadow-accent);
}

button.bim-btn.bim-btn-auth:hover,
a.bim-btn.bim-btn-auth:hover,
.bim-btn.bim-btn-auth:hover {
    background: var(--bim-accent-hover) !important;
    box-shadow: var(--bim-shadow-accent-hover);
    transform: translateY(-2px);
}

button.bim-btn.bim-btn-auth:active,
a.bim-btn.bim-btn-auth:active,
.bim-btn.bim-btn-auth:active {
    transform: translateY(0);
}

button.bim-btn.bim-btn-auth:focus-visible,
a.bim-btn.bim-btn-auth:focus-visible,
.bim-btn.bim-btn-auth:focus-visible {
    outline: 2px solid var(--bim-accent);
    outline-offset: 2px;
}

button.bim-btn.bim-btn-auth .material-symbols-outlined,
a.bim-btn.bim-btn-auth .material-symbols-outlined,
.bim-btn.bim-btn-auth .material-symbols-outlined {
    font-size: 1.25rem;
}

/* ============================================
   SIZES
   ============================================ */

/* ── SMALL ── */
button.bim-btn.bim-btn-sm,
a.bim-btn.bim-btn-sm,
.bim-btn.bim-btn-sm {
    padding: 0.375rem 1rem;
    font-size: 0.75rem;
    gap: var(--bim-space-1);
}

/* ── LARGE ── */
button.bim-btn.bim-btn-lg,
a.bim-btn.bim-btn-lg,
.bim-btn.bim-btn-lg {
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
}

/* ── FULL WIDTH ── */
button.bim-btn.bim-btn-full,
a.bim-btn.bim-btn-full,
.bim-btn.bim-btn-full,
button.bim-btn.bim-btn-block,
a.bim-btn.bim-btn-block,
.bim-btn.bim-btn-block {
    width: 100%;
}

/* ============================================
   SHAPE MODIFIERS
   ============================================ */

/* ── PILL (Fully rounded) ── */
button.bim-btn.bim-btn-pill,
a.bim-btn.bim-btn-pill,
.bim-btn.bim-btn-pill {
    border-radius: 9999px !important;
}

/* ============================================
   SPECIAL BUTTONS
   ============================================ */

/* ── FINALIZE (Full-width CTA in sidebar) ── */
button.bim-btn.bim-btn-finalize,
.bim-btn.bim-btn-finalize {
    width: calc(100% - 3rem);
    margin: 0 var(--bim-space-6) var(--bim-space-6);
    padding: var(--bim-space-4);
    background: var(--bim-accent) !important;
    color: var(--bim-surface) !important;
    border-radius: var(--bim-radius-lg);
    font-weight: 900;
    font-style: italic;
    box-shadow: var(--bim-shadow-accent);
}

button.bim-btn.bim-btn-finalize:hover,
.bim-btn.bim-btn-finalize:hover {
    background: var(--bim-accent-hover) !important;
}

button.bim-btn.bim-btn-finalize:active,
.bim-btn.bim-btn-finalize:active {
    transform: scale(0.98);
}

button.bim-btn.bim-btn-finalize .material-symbols-outlined {
    font-size: 1.25rem;
}

/* ============================================
   STATES
   ============================================ */

/* ── DISABLED ── */
button.bim-btn:disabled,
button.bim-btn.bim-btn-locked,
a.bim-btn.bim-btn-locked,
.bim-btn:disabled,
.bim-btn.bim-btn-locked {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* ── ICON-ONLY (No padding, shrinks to content) ── */
button.bim-btn-icon,
.bim-btn-icon {
    min-width: auto;
    padding: 0;
}

/* Loading state is handled entirely via JS span swap — no CSS rules needed here */

/* ============================================
   UTILITY BUTTONS - Form Actions
   ============================================ */

/* ── TOGGLE COSTS (Gradient accent button) ── */
.bim-toggle-costs {
    background: linear-gradient(135deg, var(--bim-accent) 0%, var(--bim-accent-hover) 100%) !important;
    color: var(--bim-surface);
    padding: var(--bim-space-3) var(--bim-space-5);
    border-radius: var(--bim-radius);
    font-size: var(--bim-text-sm);
    font-weight: 900;
    font-style: italic;
    display: inline-flex;
    align-items: center;
    gap: var(--bim-space-2);
    border: none;
    cursor: pointer;
    transition: all var(--bim-transition-base);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    box-shadow: var(--bim-shadow-accent);
}

.bim-toggle-costs:hover {
    box-shadow: var(--bim-shadow-accent-hover);
    transform: translateY(-1px);
}

.bim-toggle-costs:active {
    transform: translateY(0);
}

.bim-toggle-arrow {
    font-size: 1.125rem;
    transition: transform 0.3s;
}

/* ── REMOVE COST (Icon button, danger) ── */
.bim-remove-cost {
    width: 2rem;
    height: 2rem;
    background-color: var(--bim-danger-light);
    color: var(--bim-accent-hover);
    border: none;
    border-radius: var(--bim-radius-sm);
    cursor: pointer;
    font-size: var(--bim-text-xl);
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
}

.bim-remove-cost:hover {
    background-color: #fecaca;
}

/* ── CTA (Banner hero call-to-action — Bolivian red) ── */
button.bim-btn.bim-btn-cta,
a.bim-btn.bim-btn-cta,
.bim-btn-cta {
    padding: 1.125rem 2.25rem;
    background: var(--bim-bolivia-red);
    color: white;
    font-size: 0.9375rem;
    font-weight: 800;
    letter-spacing: 1.5px;
    border-radius: var(--bim-radius-sm);
    border: none;
    box-shadow: 0 4px 20px rgba(227, 30, 36, 0.4);
    width: fit-content;
    transition: background var(--bim-transition-base) ease, box-shadow var(--bim-transition-base) ease !important;
}

button.bim-btn.bim-btn-cta:hover,
a.bim-btn.bim-btn-cta:hover,
.bim-btn-cta:hover {
    background: var(--bim-bolivia-red-hover) !important;
    box-shadow: 0 6px 30px rgba(227, 30, 36, 0.6) !important;
    color: white;
}

/* ── ADD COST (Text button with icon) ── */
.bim-add-cost {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--bim-text-muted);
    font-size: 0.6875rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: none;
    border: none;
    cursor: pointer;
    transition: color 0.3s;
    margin-top: var(--bim-space-3);
    margin-bottom: var(--bim-space-4);
}

.bim-add-cost:hover {
    color: var(--bim-text-secondary);
}

/* ── CHAT SEND (Gradient accent — order chat input action) ── */
button.bim-btn.bim-chat-send-btn,
.bim-btn.bim-chat-send-btn {
    background: linear-gradient(135deg, var(--bim-accent) 0%, var(--bim-accent-hover) 100%) !important;
    color: var(--bim-surface) !important;
}

button.bim-btn.bim-chat-send-btn:hover,
.bim-btn.bim-chat-send-btn:hover {
    background: linear-gradient(135deg, var(--bim-accent-hover) 0%, #b91c1c 100%) !important;
    filter: brightness(1.05);
}

/* ── RESTORE PULSE — Draws attention to submit button after order restore ── */
button.bim-pulse-animation,
.bim-pulse-animation {
    animation: bimRestorePulse 0.8s ease-in-out 3;
}

/* ============================================
   FILTER PILLS — Segmented toggle group
   ============================================
   Used in toolbars for filtering a list.
   Structure: .bim-filter-pills > .bim-filter-pill
   Active state: add .bim-filter-pill--active
   ============================================ */

.bim-filter-pills {
    display: flex;
    align-items: center;
    background: var(--bim-bg-input);
    border: 1px solid var(--bim-border);
    border-radius: var(--bim-radius-sm);
    padding: 3px;
    gap: 2px;
}

button.bim-filter-pill,
.bim-filter-pill {
    font-family: var(--bim-font);
    font-size: var(--bim-text-sm);
    font-weight: 600;
    color: var(--bim-text-muted);
    background: transparent;
    border: none;
    border-radius: calc(var(--bim-radius-sm) - 3px);
    padding: 5px var(--bim-space-3);
    cursor: pointer;
    transition: background var(--bim-transition-fast) ease,
                color var(--bim-transition-fast) ease;
    white-space: nowrap;
}

button.bim-filter-pill:hover,
.bim-filter-pill:hover {
    color: var(--bim-text-primary);
    background: var(--bim-bg-hover) !important;
}

button.bim-filter-pill:focus,
button.bim-filter-pill:focus-visible,
.bim-filter-pill:focus,
.bim-filter-pill:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 1px var(--bim-accent) !important;
}

button.bim-filter-pill.bim-filter-pill--active,
.bim-filter-pill.bim-filter-pill--active {
    background: var(--bim-accent) !important;
    color: var(--bim-surface) !important;
}

button.bim-filter-pill.bim-filter-pill--active:hover,
.bim-filter-pill.bim-filter-pill--active:hover {
    background: var(--bim-accent-hover) !important;
    color: var(--bim-surface) !important;
}
