/* Report Generation (Aggregate data & automate report generation) */

.ccb-report-generation {
    --ccb-rg-container-max: var(--ccb-rg-container-max-desktop, 1200px);
    --ccb-rg-pt: var(--ccb-rg-pt-desktop, 60px);
    --ccb-rg-pb: var(--ccb-rg-pb-desktop, 60px);
    --ccb-rg-px: var(--ccb-rg-px-desktop, 24px);

    --ccb-rg-header-gap: var(--ccb-rg-header-gap-desktop, 10px);
    --ccb-rg-header-mb: var(--ccb-rg-header-mb-desktop, 40px);

    --ccb-rg-title-fs: var(--ccb-rg-title-fs-desktop, 40px);
    --ccb-rg-subtitle-fs: var(--ccb-rg-subtitle-fs-desktop, 18px);

    --ccb-rg-flow-gap: var(--ccb-rg-flow-gap-desktop, 28px);
    --ccb-rg-card-w: var(--ccb-rg-card-w-desktop, 360px);
    --ccb-rg-card-radius: var(--ccb-rg-card-radius-desktop, 6px);

    --ccb-rg-card-shadow-blur: var(--ccb-rg-card-shadow-blur-desktop, 24px);
    --ccb-rg-card-shadow-opacity: var(--ccb-rg-card-shadow-opacity-desktop, 0.18);

    --ccb-rg-card-pad-y: var(--ccb-rg-card-pad-y-desktop, 26px);
    --ccb-rg-card-pad-x: var(--ccb-rg-card-pad-x-desktop, 26px);

    --ccb-rg-card-head-fs: var(--ccb-rg-card-head-fs-desktop, 16px);

    --ccb-rg-list-fs: var(--ccb-rg-list-fs-desktop, 18px);
    --ccb-rg-list-gap: var(--ccb-rg-list-gap-desktop, 18px);
    --ccb-rg-list-icon: var(--ccb-rg-list-icon-desktop, 28px);

    --ccb-rg-mid-icon: var(--ccb-rg-mid-icon-desktop, 70px);
    --ccb-rg-mid-gap: var(--ccb-rg-mid-gap-desktop, 22px);
    --ccb-rg-mid-footer-fs: var(--ccb-rg-mid-footer-fs-desktop, 18px);

    --ccb-rg-right-icon: var(--ccb-rg-right-icon-desktop, 70px);
    --ccb-rg-right-row-gap: var(--ccb-rg-right-row-gap-desktop, 26px);
    --ccb-rg-right-label-fs: var(--ccb-rg-right-label-fs-desktop, 18px);

    --ccb-rg-arrow-size: var(--ccb-rg-arrow-size-desktop, 46px);

    /* Non-responsive style vars (can be overridden via inline style vars) */
    --ccb-rg-bg: var(--ccb-rg-bg-color, transparent);
    --ccb-rg-title-color: var(--ccb-rg-title-color, #3b82f6);
    --ccb-rg-subtitle-color: var(--ccb-rg-subtitle-color, #111827);

    --ccb-rg-card-bg: var(--ccb-rg-card-bg, #ffffff);
    --ccb-rg-card-border: var(--ccb-rg-card-border, rgba(17, 24, 39, 0.08));

    --ccb-rg-card-head-bg: var(--ccb-rg-card-head-bg, #4f7fb8);
    --ccb-rg-card-head-color: var(--ccb-rg-card-head-color, #ffffff);

    --ccb-rg-arrow-color: var(--ccb-rg-arrow-color, #5b8fcb);

    --ccb-rg-left-icon-color: var(--ccb-rg-left-icon-color, #7bc043);
    --ccb-rg-mid-icon-color: var(--ccb-rg-mid-icon-color, #7bc043);
    --ccb-rg-right-doc-color: var(--ccb-rg-right-doc-color, #7bc043);
    --ccb-rg-right-person-color: var(--ccb-rg-right-person-color, #5b8fcb);

    background: var(--ccb-rg-bg);
    padding: var(--ccb-rg-pt) var(--ccb-rg-px) var(--ccb-rg-pb);
}

.ccb-report-generation__inner {
    max-width: var(--ccb-rg-container-max);
    margin: 0 auto;
}

.ccb-report-generation__header {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--ccb-rg-header-gap);
    margin-bottom: var(--ccb-rg-header-mb);
}

.ccb-report-generation__title {
    margin: 0;
    color: var(--ccb-rg-title-color);
    font-size: var(--ccb-rg-title-fs);
    font-weight: 700;
    line-height: 1.15;
}

.ccb-report-generation__subtitle {
    margin: 0;
    color: var(--ccb-rg-subtitle-color);
    font-size: var(--ccb-rg-subtitle-fs);
    font-weight: 400;
    line-height: 1.35;
}

.ccb-report-generation__flow {
    display: grid;
    grid-template-columns: minmax(0, var(--ccb-rg-card-w)) minmax(0, var(--ccb-rg-arrow-size)) minmax(0, var(--ccb-rg-card-w)) minmax(0, var(--ccb-rg-arrow-size)) minmax(0, var(--ccb-rg-card-w));
    gap: var(--ccb-rg-flow-gap);
    align-items: stretch;
    justify-content: center;
}

.ccb-report-generation__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ccb-rg-arrow-color);
}

.ccb-report-generation__arrow svg {
    width: var(--ccb-rg-arrow-size);
    height: var(--ccb-rg-arrow-size);
    display: block;
}

.ccb-report-generation__card {
    background: var(--ccb-rg-card-bg);
    border: 1px solid var(--ccb-rg-card-border);
    border-radius: var(--ccb-rg-card-radius);
    overflow: hidden;
    box-shadow: 0 12px var(--ccb-rg-card-shadow-blur) rgba(0, 0, 0, var(--ccb-rg-card-shadow-opacity));
}

.ccb-report-generation__card-head {
    background: var(--ccb-rg-card-head-bg);
    color: var(--ccb-rg-card-head-color);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    font-weight: 700;
    font-size: var(--ccb-rg-card-head-fs);
    padding: 18px 22px;
    text-align: center;
}

.ccb-report-generation__card-body {
    padding: var(--ccb-rg-card-pad-y) var(--ccb-rg-card-pad-x);
}

/* Left card list */
.ccb-report-generation__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ccb-rg-list-gap);
}

.ccb-report-generation__list-item {
    display: grid;
    grid-template-columns: var(--ccb-rg-list-icon) 1fr;
    gap: 16px;
    align-items: center;
}

.ccb-report-generation__list-icon {
    width: var(--ccb-rg-list-icon);
    height: var(--ccb-rg-list-icon);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ccb-rg-left-icon-color);
}

/* MediaUpload renders buttons in editor; reset only those */
button.ccb-report-generation__list-icon,
button.ccb-report-generation__mid-icon-button,
button.ccb-report-generation__row-icon {
    appearance: none;
    -webkit-appearance: none;
    border: 0;
    background: transparent;
    padding: 0;
    margin: 0;
    cursor: pointer;
    line-height: 0;
}

button.ccb-report-generation__list-icon:hover,
button.ccb-report-generation__mid-icon-button:hover,
button.ccb-report-generation__row-icon:hover {
    opacity: 0.9;
}

.ccb-report-generation__list-icon svg,
.ccb-report-generation__list-icon img {
    width: 100%;
    height: 100%;
    display: block;
}

.ccb-report-generation__list-text {
    font-size: var(--ccb-rg-list-fs);
    font-weight: 700;
    color: var(--ccb-rg-body-text-color, #111827);
    line-height: 1.25;
}

/* Middle card */
.ccb-report-generation__mid-icons {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--ccb-rg-mid-gap);
    justify-items: center;
    align-items: center;
    margin-bottom: 22px;
}

.ccb-report-generation__mid-icon {
    width: var(--ccb-rg-mid-icon);
    height: var(--ccb-rg-mid-icon);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ccb-rg-mid-icon-color);
}

.ccb-report-generation__mid-icon-button {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ccb-report-generation__mid-icon svg,
.ccb-report-generation__mid-icon img {
    width: 100%;
    height: 100%;
    display: block;
}

.ccb-report-generation__mid-footer {
    text-align: center;
    font-size: var(--ccb-rg-mid-footer-fs);
    font-weight: 700;
    color: var(--ccb-rg-body-text-color, #111827);
    margin: 0;
}

/* Right card */
.ccb-report-generation__rows {
    display: flex;
    flex-direction: column;
    gap: var(--ccb-rg-right-row-gap);
}

.ccb-report-generation__row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    gap: 14px;
}

.ccb-report-generation__row-icons {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
}

.ccb-report-generation__row-icon {
    width: var(--ccb-rg-right-icon);
    height: var(--ccb-rg-right-icon);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ccb-report-generation__row-icon svg,
.ccb-report-generation__row-icon img {
    width: 100%;
    height: 100%;
    display: block;
}

.ccb-report-generation__row-icon--doc {
    color: var(--ccb-rg-right-doc-color);
}

.ccb-report-generation__row-icon--person {
    color: var(--ccb-rg-right-person-color);
}

.ccb-report-generation__row-label {
    text-align: center;
    font-size: var(--ccb-rg-right-label-fs);
    font-weight: 700;
    color: var(--ccb-rg-body-text-color, #111827);
    margin: 0;
}

/* Editor preview device switching */
.ccb-report-generation[data-preview-device="tablet"] {
    --ccb-rg-container-max: var(--ccb-rg-container-max-tablet, var(--ccb-rg-container-max-desktop, 1200px));
    --ccb-rg-pt: var(--ccb-rg-pt-tablet, var(--ccb-rg-pt-desktop, 60px));
    --ccb-rg-pb: var(--ccb-rg-pb-tablet, var(--ccb-rg-pb-desktop, 60px));
    --ccb-rg-px: var(--ccb-rg-px-tablet, var(--ccb-rg-px-desktop, 24px));

    --ccb-rg-header-gap: var(--ccb-rg-header-gap-tablet, var(--ccb-rg-header-gap-desktop, 10px));
    --ccb-rg-header-mb: var(--ccb-rg-header-mb-tablet, var(--ccb-rg-header-mb-desktop, 40px));

    --ccb-rg-title-fs: var(--ccb-rg-title-fs-tablet, var(--ccb-rg-title-fs-desktop, 40px));
    --ccb-rg-subtitle-fs: var(--ccb-rg-subtitle-fs-tablet, var(--ccb-rg-subtitle-fs-desktop, 18px));

    --ccb-rg-flow-gap: var(--ccb-rg-flow-gap-tablet, var(--ccb-rg-flow-gap-desktop, 28px));
    --ccb-rg-card-w: var(--ccb-rg-card-w-tablet, var(--ccb-rg-card-w-desktop, 360px));
    --ccb-rg-card-radius: var(--ccb-rg-card-radius-tablet, var(--ccb-rg-card-radius-desktop, 6px));

    --ccb-rg-card-shadow-blur: var(--ccb-rg-card-shadow-blur-tablet, var(--ccb-rg-card-shadow-blur-desktop, 24px));
    --ccb-rg-card-shadow-opacity: var(--ccb-rg-card-shadow-opacity-tablet, var(--ccb-rg-card-shadow-opacity-desktop, 0.18));

    --ccb-rg-card-pad-y: var(--ccb-rg-card-pad-y-tablet, var(--ccb-rg-card-pad-y-desktop, 26px));
    --ccb-rg-card-pad-x: var(--ccb-rg-card-pad-x-tablet, var(--ccb-rg-card-pad-x-desktop, 26px));

    --ccb-rg-card-head-fs: var(--ccb-rg-card-head-fs-tablet, var(--ccb-rg-card-head-fs-desktop, 16px));

    --ccb-rg-list-fs: var(--ccb-rg-list-fs-tablet, var(--ccb-rg-list-fs-desktop, 18px));
    --ccb-rg-list-gap: var(--ccb-rg-list-gap-tablet, var(--ccb-rg-list-gap-desktop, 18px));
    --ccb-rg-list-icon: var(--ccb-rg-list-icon-tablet, var(--ccb-rg-list-icon-desktop, 28px));

    --ccb-rg-mid-icon: var(--ccb-rg-mid-icon-tablet, var(--ccb-rg-mid-icon-desktop, 70px));
    --ccb-rg-mid-gap: var(--ccb-rg-mid-gap-tablet, var(--ccb-rg-mid-gap-desktop, 22px));
    --ccb-rg-mid-footer-fs: var(--ccb-rg-mid-footer-fs-tablet, var(--ccb-rg-mid-footer-fs-desktop, 18px));

    --ccb-rg-right-icon: var(--ccb-rg-right-icon-tablet, var(--ccb-rg-right-icon-desktop, 70px));
    --ccb-rg-right-row-gap: var(--ccb-rg-right-row-gap-tablet, var(--ccb-rg-right-row-gap-desktop, 26px));
    --ccb-rg-right-label-fs: var(--ccb-rg-right-label-fs-tablet, var(--ccb-rg-right-label-fs-desktop, 18px));

    --ccb-rg-arrow-size: var(--ccb-rg-arrow-size-tablet, var(--ccb-rg-arrow-size-desktop, 46px));
}

.ccb-report-generation[data-preview-device="mobile"] {
    --ccb-rg-container-max: var(--ccb-rg-container-max-mobile, var(--ccb-rg-container-max-tablet, var(--ccb-rg-container-max-desktop, 1200px)));
    --ccb-rg-pt: var(--ccb-rg-pt-mobile, var(--ccb-rg-pt-tablet, var(--ccb-rg-pt-desktop, 60px)));
    --ccb-rg-pb: var(--ccb-rg-pb-mobile, var(--ccb-rg-pb-tablet, var(--ccb-rg-pb-desktop, 60px)));
    --ccb-rg-px: var(--ccb-rg-px-mobile, var(--ccb-rg-px-tablet, var(--ccb-rg-px-desktop, 24px)));

    --ccb-rg-header-gap: var(--ccb-rg-header-gap-mobile, var(--ccb-rg-header-gap-tablet, var(--ccb-rg-header-gap-desktop, 10px)));
    --ccb-rg-header-mb: var(--ccb-rg-header-mb-mobile, var(--ccb-rg-header-mb-tablet, var(--ccb-rg-header-mb-desktop, 40px)));

    --ccb-rg-title-fs: var(--ccb-rg-title-fs-mobile, var(--ccb-rg-title-fs-tablet, var(--ccb-rg-title-fs-desktop, 40px)));
    --ccb-rg-subtitle-fs: var(--ccb-rg-subtitle-fs-mobile, var(--ccb-rg-subtitle-fs-tablet, var(--ccb-rg-subtitle-fs-desktop, 18px)));

    --ccb-rg-flow-gap: var(--ccb-rg-flow-gap-mobile, var(--ccb-rg-flow-gap-tablet, var(--ccb-rg-flow-gap-desktop, 28px)));
    --ccb-rg-card-w: var(--ccb-rg-card-w-mobile, var(--ccb-rg-card-w-tablet, var(--ccb-rg-card-w-desktop, 360px)));
    --ccb-rg-card-radius: var(--ccb-rg-card-radius-mobile, var(--ccb-rg-card-radius-tablet, var(--ccb-rg-card-radius-desktop, 6px)));

    --ccb-rg-card-shadow-blur: var(--ccb-rg-card-shadow-blur-mobile, var(--ccb-rg-card-shadow-blur-tablet, var(--ccb-rg-card-shadow-blur-desktop, 24px)));
    --ccb-rg-card-shadow-opacity: var(--ccb-rg-card-shadow-opacity-mobile, var(--ccb-rg-card-shadow-opacity-tablet, var(--ccb-rg-card-shadow-opacity-desktop, 0.18)));

    --ccb-rg-card-pad-y: var(--ccb-rg-card-pad-y-mobile, var(--ccb-rg-card-pad-y-tablet, var(--ccb-rg-card-pad-y-desktop, 26px)));
    --ccb-rg-card-pad-x: var(--ccb-rg-card-pad-x-mobile, var(--ccb-rg-card-pad-x-tablet, var(--ccb-rg-card-pad-x-desktop, 26px)));

    --ccb-rg-card-head-fs: var(--ccb-rg-card-head-fs-mobile, var(--ccb-rg-card-head-fs-tablet, var(--ccb-rg-card-head-fs-desktop, 16px)));

    --ccb-rg-list-fs: var(--ccb-rg-list-fs-mobile, var(--ccb-rg-list-fs-tablet, var(--ccb-rg-list-fs-desktop, 18px)));
    --ccb-rg-list-gap: var(--ccb-rg-list-gap-mobile, var(--ccb-rg-list-gap-tablet, var(--ccb-rg-list-gap-desktop, 18px)));
    --ccb-rg-list-icon: var(--ccb-rg-list-icon-mobile, var(--ccb-rg-list-icon-tablet, var(--ccb-rg-list-icon-desktop, 28px)));

    --ccb-rg-mid-icon: var(--ccb-rg-mid-icon-mobile, var(--ccb-rg-mid-icon-tablet, var(--ccb-rg-mid-icon-desktop, 70px)));
    --ccb-rg-mid-gap: var(--ccb-rg-mid-gap-mobile, var(--ccb-rg-mid-gap-tablet, var(--ccb-rg-mid-gap-desktop, 22px)));
    --ccb-rg-mid-footer-fs: var(--ccb-rg-mid-footer-fs-mobile, var(--ccb-rg-mid-footer-fs-tablet, var(--ccb-rg-mid-footer-fs-desktop, 18px)));

    --ccb-rg-right-icon: var(--ccb-rg-right-icon-mobile, var(--ccb-rg-right-icon-tablet, var(--ccb-rg-right-icon-desktop, 70px)));
    --ccb-rg-right-row-gap: var(--ccb-rg-right-row-gap-mobile, var(--ccb-rg-right-row-gap-tablet, var(--ccb-rg-right-row-gap-desktop, 26px)));
    --ccb-rg-right-label-fs: var(--ccb-rg-right-label-fs-mobile, var(--ccb-rg-right-label-fs-tablet, var(--ccb-rg-right-label-fs-desktop, 18px)));

    --ccb-rg-arrow-size: var(--ccb-rg-arrow-size-mobile, var(--ccb-rg-arrow-size-tablet, var(--ccb-rg-arrow-size-desktop, 46px)));
}

/* Frontend responsive */
@media (max-width: 1024px) {
    .ccb-report-generation:not([data-preview-device]) {
        --ccb-rg-container-max: var(--ccb-rg-container-max-tablet, var(--ccb-rg-container-max-desktop, 1200px));
        --ccb-rg-pt: var(--ccb-rg-pt-tablet, var(--ccb-rg-pt-desktop, 60px));
        --ccb-rg-pb: var(--ccb-rg-pb-tablet, var(--ccb-rg-pb-desktop, 60px));
        --ccb-rg-px: var(--ccb-rg-px-tablet, var(--ccb-rg-px-desktop, 24px));
        --ccb-rg-title-fs: var(--ccb-rg-title-fs-tablet, var(--ccb-rg-title-fs-desktop, 40px));
        --ccb-rg-subtitle-fs: var(--ccb-rg-subtitle-fs-tablet, var(--ccb-rg-subtitle-fs-desktop, 18px));
        --ccb-rg-flow-gap: var(--ccb-rg-flow-gap-tablet, var(--ccb-rg-flow-gap-desktop, 28px));
        --ccb-rg-card-w: var(--ccb-rg-card-w-tablet, var(--ccb-rg-card-w-desktop, 360px));
        --ccb-rg-arrow-size: var(--ccb-rg-arrow-size-tablet, var(--ccb-rg-arrow-size-desktop, 46px));
    }

    .ccb-report-generation__flow {
        grid-template-columns: minmax(0, 1fr);
        max-width: 700px;
        margin: 0 auto;
    }

    .ccb-report-generation__arrow {
        display: none;
    }
}

@media (max-width: 768px) {
    .ccb-report-generation:not([data-preview-device]) {
        --ccb-rg-container-max: var(--ccb-rg-container-max-mobile, var(--ccb-rg-container-max-tablet, var(--ccb-rg-container-max-desktop, 1200px)));
        --ccb-rg-pt: var(--ccb-rg-pt-mobile, var(--ccb-rg-pt-tablet, var(--ccb-rg-pt-desktop, 60px)));
        --ccb-rg-pb: var(--ccb-rg-pb-mobile, var(--ccb-rg-pb-tablet, var(--ccb-rg-pb-desktop, 60px)));
        --ccb-rg-px: var(--ccb-rg-px-mobile, var(--ccb-rg-px-tablet, var(--ccb-rg-px-desktop, 24px)));
        --ccb-rg-title-fs: var(--ccb-rg-title-fs-mobile, var(--ccb-rg-title-fs-tablet, var(--ccb-rg-title-fs-desktop, 40px)));
        --ccb-rg-subtitle-fs: var(--ccb-rg-subtitle-fs-mobile, var(--ccb-rg-subtitle-fs-tablet, var(--ccb-rg-subtitle-fs-desktop, 18px)));
        --ccb-rg-flow-gap: var(--ccb-rg-flow-gap-mobile, var(--ccb-rg-flow-gap-tablet, var(--ccb-rg-flow-gap-desktop, 28px)));
        --ccb-rg-card-w: var(--ccb-rg-card-w-mobile, var(--ccb-rg-card-w-tablet, var(--ccb-rg-card-w-desktop, 360px)));
    }
}
