/* ============================================
   FEATURE SHOWCASE - Offset Row Designs
   Two variants: A (overlapping cards) and B (alternating rows)
   ============================================ */

/* ============================================
   VARIANT A: Masonry-Style Two Column Layout
   Left: feature cards, Right: screenshots
   No vertical alignment - each column flows independently
   ============================================ */

.feature-showcase-a {
    display: flex;
    flex-direction: column;
}

/* Masonry container - two columns, no gap between items vertically */
.showcase-masonry {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 var(--space-6);
    align-items: start;
}

/* Column base styles */
.showcase-masonry-col {
    display: flex;
    flex-direction: column;
}

/* Feature cards column - spaced to match screenshots */
.showcase-masonry-features {
    gap: var(--space-4);
    background: none;
    border: none;
}

.showcase-masonry-card {
    height: auto;
    border-radius: var(--radius-lg);
}

.showcase-masonry-card .card-title {
    font-size: var(--text-lg);
    margin-bottom: var(--space-2);
}

.showcase-masonry-card .card-description {
    font-size: var(--text-sm);
    margin-bottom: var(--space-3);
    line-height: 1.6;
}

.showcase-masonry-card .check-list-unified {
    margin: var(--space-3) 0 0 0;
}

.showcase-masonry-card .check-list-item-unified {
    margin-bottom: var(--space-2);
}

.showcase-masonry-card .check-title-unified {
    font-size: var(--text-sm);
}

.showcase-masonry-card .check-subtitle-unified {
    font-size: var(--text-xs);
}

/* Screenshots column - contains screenshots stack + CTA */
.showcase-masonry-screenshots {
    background: none;
    border: none;
    gap: var(--space-5);
    position: sticky;
    top: 6rem;
    align-self: start;
}

/* Screenshots stack with vertical spacing */
.showcase-screenshots-stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.showcase-masonry-screenshot {
    line-height: 0; /* Remove any line-height spacing */
}

.showcase-masonry-screenshot .section-screenshot {
    width: 100%;
    max-width: 100%;
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: block;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.showcase-masonry-screenshot .section-screenshot:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35);
}

/* Screenshots column - contains screenshots stack + CTA */
.showcase-masonry-screenshots {
    background: none;
    border: none;
    gap: var(--space-5);
}

/* CTA aligned under screenshots column */
.showcase-screenshots-cta {
    display: flex;
    justify-content: center;
    margin-top: var(--space-2);
    position: relative;
    z-index: 2;
}

/* Prominent always-visible CTA button */
.showcase-demo-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-6);
    background: var(--gradient-cta);
    color: white;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    border-radius: var(--radius-full);
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(var(--color-success-rgb), 0.3);
    transition: all 0.3s ease;
}

.showcase-demo-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(var(--color-success-rgb), 0.4);
}

.showcase-demo-cta-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

.showcase-demo-cta-icon svg {
    opacity: 0.9;
}

.showcase-demo-cta-text {
    flex: 1;
}

.showcase-demo-cta-arrow {
    display: flex;
    align-items: center;
    transition: transform 0.2s ease;
}

.showcase-demo-cta:hover .showcase-demo-cta-arrow {
    transform: translateX(4px);
}

/* ============================================
   VARIANT B: True Alternating Rows
   Content and screenshot side by side, flipping each row
   ============================================ */

.feature-showcase-b {
    display: flex;
    flex-direction: column;
    gap: var(--space-10);
}

.showcase-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
    align-items: center;
}

/* Normal order: content left, image right */
.showcase-row-content {
    order: 1;
}

.showcase-row-image {
    order: 2;
    display: flex;
    justify-content: center;
}

/* Reversed row: image left, content right */
.showcase-row-reversed .showcase-row-content {
    order: 2;
}

.showcase-row-reversed .showcase-row-image {
    order: 1;
}

/* Card styling for variant B */
.showcase-row-card {
    height: auto;
    min-height: auto;
}

/* Screenshot sizing in rows */
.showcase-row-image .section-screenshot {
    max-width: 100%;
    width: 100%;
}

/* Row divider decoration */
.showcase-row:not(:last-child)::after {
    content: '';
    grid-column: 1 / -1;
    height: 1px;
    background: linear-gradient(
        to right,
        transparent 0%,
        rgba(255, 255, 255, 0.1) 20%,
        rgba(255, 255, 255, 0.1) 80%,
        transparent 100%
    );
    margin-top: var(--space-10);
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

@media (max-width: 1023px) {
    /* Variant A adjustments - stack vertically on tablet/mobile */
    .showcase-masonry {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    /* Show screenshots first on mobile, then feature cards */
    .showcase-masonry-screenshots {
        order: -1;
        position: static;
    }

    .showcase-masonry-card .card-title {
        font-size: var(--text-xl);
    }

    .showcase-masonry-card .card-description {
        font-size: var(--text-base);
    }

    .showcase-screenshots-stack {
        gap: var(--space-3);
    }

    .showcase-screenshots-cta {
        margin-top: var(--space-4);
    }

    /* Variant B adjustments */
    .showcase-row {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    /* On mobile, always show content first, then image */
    .showcase-row-content {
        order: 1 !important;
    }

    .showcase-row-image {
        order: 2 !important;
    }

    .showcase-row-image .section-screenshot {
        max-width: 400px;
    }
}

@media (max-width: 768px) {
    .showcase-row-image .section-screenshot {
        max-width: 100%;
    }

    .showcase-demo-cta {
        padding: var(--space-3) var(--space-5);
        font-size: var(--text-sm);
    }
}
