/**
 * Snap Events - Interactive Elements Styles
 *
 * Styles for the Load More button, Sort toggle, and loading states.
 */

/* ==========================================================================
   Controls Container
   ========================================================================== */

.snap-events-controls {
    grid-column: 1 / -1;
    margin-top: 30px;
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: center;
    justify-content: center;
}

/* ==========================================================================
   Buttons - Shared Styles
   ========================================================================== */

.snap-events-sort-toggle,
.snap-events-load-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background-color: var(--btn-bg, #333333);
    color: var(--btn-color, #ffffff);
    border: var(--btn-border, 0);
    border-radius: var(--btn-radius, 4px);
    cursor: pointer;
    transition: filter 0.2s ease;
}

.snap-events-sort-toggle:hover,
.snap-events-load-more:hover {
    filter: brightness(0.85);
}

/* ==========================================================================
   Buttons - Focus & Disabled States
   ========================================================================== */

.snap-events-sort-toggle:focus-visible,
.snap-events-load-more:focus-visible {
    outline: 3px solid #4a90e2;
    outline-offset: 2px;
}

.snap-events-sort-toggle:disabled,
.snap-events-load-more:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ==========================================================================
   Button Icons
   ========================================================================== */

.snap-events-icon {
    flex-shrink: 0;
}

/* ==========================================================================
   Status Messages
   ========================================================================== */

.snap-events-status {
    flex-basis: 100%;
    text-align: center;
    font-size: 14px;
    color: #666;
    min-height: 20px;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.snap-events-hidden {
    display: none !important;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 767px) {
    .snap-events-controls {
        flex-direction: column;
        gap: 10px;
    }

    .snap-events-sort-toggle,
    .snap-events-load-more {
        width: 100%;
        max-width: 300px;
    }
}
