/* Brand colours */
:root {
    --bcgba-purple: #393186;
    --bcgba-red: #E31E27;
    --bcgba-green: #519C4B;
    --bcgba-purple-light: #4a41a0;
    --bcgba-purple-dark: #2b2566;
    --bcgba-green-dark: #3e7a3a;
}

#bcgba-club-finder {
    max-width: 1100px !important;
    margin: 0 auto !important;
    font-family: inherit !important;
}

/* Search form */
.bcgba-form-row {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 24px !important;
}

#bcgba-postcode {
    flex: 1 !important;
    padding: 14px 18px !important;
    font-size: 16px !important;
    border: 2px solid #d0d0d0 !important;
    border-radius: 8px !important;
    outline: none !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
}

#bcgba-postcode:focus {
    border-color: var(--bcgba-purple) !important;
    box-shadow: 0 0 0 3px rgba(57, 49, 134, 0.15) !important;
}

#bcgba-search-form button {
    padding: 14px 32px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background-color: var(--bcgba-green) !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: background-color 0.2s, transform 0.1s !important;
}

#bcgba-search-form button:hover {
    background-color: var(--bcgba-green-dark) !important;
}

#bcgba-search-form button:active {
    transform: scale(0.98) !important;
}

/* Error message */
#bcgba-error {
    padding: 12px 16px !important;
    margin-bottom: 20px !important;
    color: #fff !important;
    background-color: var(--bcgba-red) !important;
    border: none !important;
    border-radius: 8px !important;
    font-weight: 500 !important;
}

/* Loading */
#bcgba-loading {
    display: flex;
    align-items: center !important;
    gap: 10px !important;
    padding: 16px 0 !important;
    font-size: 16px !important;
    color: var(--bcgba-purple) !important;
    font-weight: 500 !important;
}

.bcgba-spinner {
    display: inline-block;
    width: 22px !important;
    height: 22px !important;
    border: 3px solid rgba(57, 49, 134, 0.2) !important;
    border-top-color: var(--bcgba-purple) !important;
    border-radius: 50% !important;
    animation: bcgba-spin 0.8s linear infinite !important;
}

@keyframes bcgba-spin {
    to { transform: rotate(360deg); }
}

/* Map */
#bcgba-map {
    width: 100% !important;
    height: 450px !important;
    margin-bottom: 28px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    border: 2px solid var(--bcgba-purple) !important;
}

/* Results grid */
#bcgba-results-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
}

.bcgba-club-item {
    flex: 1 1 calc(33.333% - 16px) !important;
    min-width: 260px !important;
    max-width: 100% !important;
    padding: 20px 22px !important;
    background: #fff !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 10px !important;
    border-top: 4px solid var(--bcgba-purple) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    transition: box-shadow 0.2s, transform 0.2s !important;
    display: flex !important;
    flex-direction: column !important;
    box-sizing: border-box !important;
}

.bcgba-club-item:first-child {
    flex: 1 1 100% !important;
}

.bcgba-club-item:hover {
    box-shadow: 0 4px 16px rgba(57, 49, 134, 0.15) !important;
    transform: translateY(-2px) !important;
}

.bcgba-club-name {
    margin: 0 0 8px !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--bcgba-purple) !important;
    line-height: 1.3 !important;
}

.bcgba-club-address {
    margin: 0 0 6px !important;
    color: #444 !important;
    font-size: 14px !important;
}

.bcgba-address-line {
    display: block !important;
    line-height: 1.6 !important;
}

.bcgba-club-distance {
    margin: 0 0 12px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--bcgba-green) !important;
}

/* Facilities */
.bcgba-club-facilities {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin: 0 0 14px !important;
    align-items: center !important;
}

.bcgba-facilities-label {
    display: block !important;
    width: 100% !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: var(--bcgba-purple) !important;
    margin-bottom: 2px !important;
}

.bcgba-facility {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    padding: 6px 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    background: linear-gradient(135deg, #f8f8fa, #eef0f4) !important;
    color: #444 !important;
    border: 1px solid #ddd !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    transition: transform 0.15s, box-shadow 0.15s !important;
}

.bcgba-facility:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1) !important;
}

.bcgba-facility--gold {
    background: linear-gradient(135deg, #fffbeb, #fef3c7) !important;
    color: #78350f !important;
    border-color: #f59e0b !important;
    box-shadow: 0 1px 3px rgba(245, 158, 11, 0.15) !important;
}

.bcgba-facility--silver {
    background: linear-gradient(135deg, #f8fafc, #e2e8f0) !important;
    color: #334155 !important;
    border-color: #94a3b8 !important;
    box-shadow: 0 1px 3px rgba(148, 163, 184, 0.2) !important;
}

.bcgba-facility--bronze {
    background: linear-gradient(135deg, #fef7f0, #fde8d8) !important;
    color: #6c2710 !important;
    border-color: #cd7f32 !important;
    box-shadow: 0 1px 3px rgba(205, 127, 50, 0.15) !important;
}

.bcgba-facility-stars {
    font-size: 10px !important;
    line-height: 1 !important;
}

.bcgba-facility--gold .bcgba-facility-stars {
    color: #d97706 !important;
}

.bcgba-facility--silver .bcgba-facility-stars {
    color: #64748b !important;
}

.bcgba-facility--bronze .bcgba-facility-stars {
    color: #b45309 !important;
}

.bcgba-club-links {
    margin-top: auto !important;
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

.bcgba-club-link {
    display: inline-block !important;
    padding: 6px 14px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background-color: var(--bcgba-purple) !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    transition: background-color 0.2s !important;
}

.bcgba-club-link:hover {
    background-color: var(--bcgba-purple-light) !important;
    text-decoration: none !important;
    color: #fff !important;
}

.bcgba-club-link--email {
    background-color: var(--bcgba-green) !important;
}

.bcgba-club-link--email:hover {
    background-color: var(--bcgba-green-dark) !important;
}

/* Info window */
.bcgba-info-window {
    font-size: 14px !important;
    line-height: 1.5 !important;
    max-width: 260px !important;
}

.bcgba-info-window strong {
    font-size: 15px !important;
    color: var(--bcgba-purple) !important;
}

.bcgba-info-window p {
    margin: 4px 0 !important;
}

.bcgba-info-window a {
    color: var(--bcgba-purple) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

.bcgba-info-window a:hover {
    text-decoration: underline !important;
}

/* Responsive */
@media (max-width: 768px) {
    .bcgba-club-item {
        flex: 1 1 calc(50% - 16px) !important;
    }
}

@media (max-width: 600px) {
    .bcgba-form-row {
        flex-direction: column !important;
    }

    #bcgba-search-form button {
        width: 100% !important;
    }

    #bcgba-map {
        height: 300px !important;
    }

    .bcgba-club-item {
        flex: 1 1 100% !important;
    }
}
