/* Table of Contents
1. Bundle Builder PIB Callout
2. Bundle Builder Modal Styling
3. Bundle Builder Modal Header
4. Bundle Builder Modal Close Button
5. Bundle Builder Modal Placeholder Thumbnail
6. Bundle Builder PIB Modal
7. Bundle Builder Modal Content
8. Card List
*/

/* 1. Bundle Builder PIB Callout */
.bundle-builder-pib-callout {
    width: 100%;
    min-height: 44px;
    display: flex;
    justify-content: center;
    align-items: var(--bb-pib-cta-vertical-alignment);
    cursor: pointer;
    padding: var(--bb-pib-cta-padding);
    border-radius: var(--bb-pib-cta-border-radius) ;
    border: var(--bb-pib-cta-border-width) solid var(--bb-pib-cta-border-color);
    color: var(--bb-pib-cta-font-color);
    background-color: var(--bb-pib-cta-background-color);
    transition: all 0.4s ease;
    margin-top: var(--bb-pib-cta-top-margin);
    margin-bottom: var(--bb-pib-cta-bottom-margin);
}
.bundle-builder-pib-callout:hover {
    background-color: var(--bb-pib-cta-hover-background-color);
}

.bundle-builder-pib-callout .bb-underline {
    text-decoration: underline;
}

.bundle-builder-pib-callout .bb-pib-icon {
    width: var(--bb-pib-cta-width-and-height);
    height: var(--bb-pib-cta-width-and-height);
    margin-right: 10px;
    margin-top: 3px;
}

.bb-pib-label {
    display: inline;
    font-size: var(--bb-pib-cta-font-size);
    text-align: var(--bb-pib-cta-text-alignment);
}

/* 2. Bundle Builder Modal Styling */
.bundle-builder-pib-modal {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

/* 3. Bundle Builder Modal Header */
.bundle-builder-modal-header {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-top: 24px;
    padding-bottom: 24px;
    padding-left: 48px;
    padding-right: 48px;
    border-bottom: 1px solid var(--bb-pib-modal-list-divider-color, #E0E0E0);
    position: sticky;
    top: 0px;
    overflow-x: hidden;
    z-index: 1;
    background: var(--bb-pib-modal-background-color);
    color: var(--bb-pib-modal-text-color);
}
.bundle-builder-modal-header-icon {
    width: var(--bb-pib-modal-icon-width);
    height: var(--bb-pib-modal-icon-width);
    margin-right: 10px;
}
.bundle-builder-modal-header h3 {
    flex: 1 auto;
    padding-top: 0px;
    padding-bottom: 0px;
    margin-top: 0px;
    margin-bottom: 0px;
    color: var(--bb-pib-modal-text-color);
    font-size: var(--bb-pib-modal-font-size);
}

/* 4. Bundle Builder Modal Close Button */
.bundle-builder-modal-close {
    width: 32px;
    height: 32px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bundle-builder-modal-close-icon {
    fill: none;
    stroke: var(--bb-pib-modal-text-color, #E0E0E0);
    width: 24px;
    height: 24px;
    transition: stroke 0.2s ease-in-out;
}

.bundle-builder-modal-close-icon:hover {
    opacity: 0.75;
}

/* 5. Bundle Builder Modal Placeholder Thumbnail */
.bundle-builder-modal-placeholder-thumbnail {
    opacity: 0.8;
}

/* 6. Bundle Builder PIB Modal */
bundle-builder-pib-modal[data-open="false"] {
    opacity: 0;
}
bundle-builder-pib-modal[data-open="false"] .bundle-builder-modal-inner {
    opacity: 0;
}
bundle-builder-pib-modal[data-open="true"] {
    width: 100%;
    height: 100vh;
    position: fixed;
    z-index: 99999;
    top: 0px;
    left: 0px;
    background: var(--bb-pib-modal-underlay-background-color);
    opacity: 1;
    transition: opacity 0.5s ease;
}
bundle-builder-pib-modal[data-open="true"] .bundle-builder-modal-inner {
    width: 95%;
    max-width: var(--bb-pib-modal-max-width);
    max-height: 90%;
    background-color: #fff;
    margin-left: auto;
    margin-right: auto;
    margin-top: 5%;
    background: var(--bb-pib-modal-background-color);
    transition: opacity 0.5s ease;
    opacity: 1;
    overflow-y: auto;
    border-radius: var(--bb-pib-modal-border-radius);
}
bundle-builder-pib-modal[data-open="true"] .bundle-builder-modal-inner {
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none;  /* IE 10+ */
}
bundle-builder-pib-modal[data-open="true"] .bundle-builder-modal-inner::-webkit-scrollbar {
    background: transparent;
    width: 0px;
}

/* 7. Bundle Builder Modal Content */
.bundle-builder-model-content {
    min-height: 400px;
    width: 100%;
}
.bundle-builder-modal-footer {
    position: sticky;
    bottom: 0px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 16px;
    padding-bottom: 16px;
    z-index: 1;
    background: var(--bb-pib-modal-background-color);
    border-top: 1px solid var(--bb-pib-modal-list-divider-color, #E0E0E0);
    width: 100%;
    color: var(--bb-pib-modal-text-color);
}

/* 8. Card List */
.display-as-grid .bundle-builder-model-content {
    display: flex;
    flex-wrap:wrap;
    padding-top: 32px;
    padding-left: 48px;
    padding-right: 48px;
}
.display-as-list .bundle-builder-model-content {
    display: flex;
    flex-direction: column;
    flex-wrap:wrap;
    padding-top: 32px;
    padding-left: 48px;
    padding-right: 48px;
}

.display-as-grid .bundle-builder-modal-content-product-card {
    width: calc(50% - 20px);
    margin-left: 10px;
    margin-right: 10px;
    margin-bottom: 24px;
    display: flex;
    flex-direction: column;
    align-items: var(--bb-pib-modal-grid-alignment);
    justify-content: flex-start;
}

.display-as-list .bundle-builder-modal-content-product-card {
    width: 100%;
    margin-left: 10px;
    margin-right: 10px;
    margin-bottom: 24px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: flex-start;
    border-width: var(--bb-pib-modal-list-border-width);
    border-color: var(--bb-pib-modal-list-border-color);
    border-radius: var(--bb-pib-cta-border-radius);
    border-style: solid;
    padding: var(--bb-pib-modal-list-padding);
    background-color: var(--bb-pib-cta-background-color);
    transition: all 0.4s ease;
}
.display-as-list .bundle-builder-modal-content-product-card:hover {
    background-color: var(--bb-pib-cta-hover-background-color);
}

.display-as-grid .bundle-builder-modal-content-product-card img {
    width: 100%;
    height: auto;
}
.display-as-list .bundle-builder-modal-content-product-card img {
    width: 100%;
    height: auto;
    max-width: var(--bb-pib-modal-list-thumbnail-width);
    margin-right: 24px;
}
a.bundle-builder-modal-content-product-card h3 {
    font-size: var(--bb-pib-modal-font-size);
    color: var(--bb-pib-modal-text-color);
}
a.bundle-builder-modal-content-product-card {
    text-decoration: none;
    /* Add font color */
    color: inherit;
    color: var(--bb-pib-modal-text-color);
}

/* 8. Product Cards */