/* Public layout for page-builder blocks */

.lv-blocks {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.lv-block {
    max-width: 68rem;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

.lv-block--text-image__grid {
    display: grid;
    gap: 1.5rem;
    align-items: start;
}

@media (min-width: 720px) {
    .lv-block--text-image__grid {
        grid-template-columns: 1fr 1.1fr;
    }

    .lv-block--text-image-rev .lv-block--text-image__grid {
        direction: rtl;
    }

    .lv-block--text-image-rev .lv-block--text-image__grid > * {
        direction: ltr;
    }
}

.lv-block--text-image__fig {
    margin: 0;
    border-radius: 0.65rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.lv-block--text-image__fig img {
    display: block;
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.lv-block--gallery__caption {
    margin: 0 0 1rem;
    font-size: 0.95rem;
    color: var(--lv-muted);
    text-align: center;
}

.lv-block--gallery__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 0.65rem;
}

.lv-block--gallery__cell {
    margin: 0;
    border-radius: 0.5rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.lv-block--gallery__cell img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: cover;
}

.lv-block--cards__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1.25rem;
}

.lv-block--cards__card {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    height: 100%;
}

.lv-block--cards__imgwrap {
    margin: -0.25rem -0.25rem 0;
    border-radius: 0.5rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.lv-block--cards__imgwrap img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 160px;
    object-fit: cover;
}

.lv-block--cards__title {
    margin: 0;
    font-family: var(--lv-font-display);
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--lv-moon);
}

.lv-block--cards__body {
    flex: 1;
    font-size: 0.95rem;
}

.lv-block--html {
    padding: 2rem 1.75rem;
}
