/* =============================================
   Smash Balloon Instagram Feed — Theme Overrides
   =============================================
   Styles the free Smash Balloon Instagram Feed plugin output
   to match the Neuburg Architekten design system.
   Only loaded when the plugin is active.
   ============================================= */

/* ── Container ── */
.social-slider-classic #sb_instagram,
.social-slider-classic .sb_instagram_header,
.social-slider-classic #sbi_images,
.social-slider-classic .sbi {
    background: transparent !important;
    padding: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* ── Hide Smash Balloon default header ──
   We use our own section header above */
.social-slider-classic #sb_instagram .sb_instagram_header,
.social-slider-classic .sbi_header_text,
.social-slider-classic .sbi_header_img {
    display: none !important;
}

/* ── Image Grid ── */
.social-slider-classic #sb_instagram #sbi_images,
.social-slider-classic .sbi_images {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: var(--space-m) !important;
    float: none !important;
}

/* ── Individual Items ── */
.social-slider-classic .sbi_item {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    float: none !important;
}

/* ── Photo Wrapper ── */
.social-slider-classic .sbi_photo_wrap {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: var(--radius-m) !important;
    display: block;
}

/* ── Photos ── */
.social-slider-classic .sbi_photo {
    display: block;
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 0 !important;
}

.social-slider-classic .sbi_photo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.4s ease !important;
}

/* ── Hover Effect: Scale image + overlay ── */
.social-slider-classic .sbi_photo_wrap:hover img {
    transform: scale(1.05) !important;
}

.social-slider-classic .sbi_photo_wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 2;
    pointer-events: none;
    border-radius: inherit;
}

.social-slider-classic .sbi_photo_wrap:hover::after {
    opacity: 1;
}

/* ── Instagram icon overlay on hover ── */
.social-slider-classic .sbi_photo_wrap::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 40px;
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='20' x='2' y='2' rx='5' ry='5'/%3E%3Cpath d='M16 11.37A4 4 0 1 1 12.63 8 4 4 0 0 1 16 11.37z'/%3E%3Cline x1='17.5' x2='17.51' y1='6.5' y2='6.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
}

.social-slider-classic .sbi_photo_wrap:hover::before {
    opacity: 1;
}

/* ── Load More Button ── */
.social-slider-classic #sbi_load,
.social-slider-classic .sbi_load_btn {
    text-align: center !important;
}

.social-slider-classic .sbi_load_btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-l) !important;
    background: transparent !important;
    color: var(--text-body) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-full) !important;
    font-family: var(--font-primary) !important;
    font-size: var(--text-s) !important;
    font-weight: 500 !important;
    letter-spacing: 0.02em !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    margin-top: var(--space-xl) !important;
    text-decoration: none !important;
}

.social-slider-classic .sbi_load_btn:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: white !important;
}

/* ── Follow Button ── */
.social-slider-classic .sbi_follow_btn a {
    display: inline-flex !important;
    align-items: center !important;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-l) !important;
    background: transparent !important;
    color: var(--text-body) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-full) !important;
    font-family: var(--font-primary) !important;
    font-size: var(--text-s) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
}

.social-slider-classic .sbi_follow_btn a:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: white !important;
}

/* Hide the follow button — we already have the CTA in our header */
.social-slider-classic .sbi_follow_btn {
    display: none !important;
}

/* ── Responsive: 3 columns ── */
@container social-slider-classic (max-width: 968px) {
    .social-slider-classic #sb_instagram #sbi_images,
    .social-slider-classic .sbi_images {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* ── Responsive: 2 columns ── */
@container social-slider-classic (max-width: 768px) {
    .social-slider-classic #sb_instagram #sbi_images,
    .social-slider-classic .sbi_images {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ── Responsive: 2 columns on mobile ── */
@container social-slider-classic (max-width: 480px) {
    .social-slider-classic #sb_instagram #sbi_images,
    .social-slider-classic .sbi_images {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--space-s) !important;
    }
}

/* ── Smash Balloon error/empty states ── */
.social-slider-classic .sbi_no_images,
.social-slider-classic .sb_instagram_error {
    font-family: var(--font-primary) !important;
    color: var(--text-body) !important;
    text-align: center !important;
    padding: var(--space-2xl) !important;
}
