.vibp-bundle-cart {
--vibp-accent: #1f7ab8;
--vibp-accent-soft: #eef7fc;
--vibp-border: #d9dee5;
--vibp-border-soft: #eceff3;
--vibp-text: #111827;
--vibp-muted: #6b7280;
--vibp-surface: #ffffff;
--vibp-surface-soft: #f7f9fb;
--vibp-swatch-size-desktop: 68px;
--vibp-swatch-size-mobile: 60px;
margin-top: 24px;
}
.vibp-bundle-cart,
.vibp-bundle-cart * {
box-sizing: border-box;
}
.vibp-bundle-cart .quantity {
display: inline-flex;
align-items: center;
margin: 0 10px 0 0;
vertical-align: middle;
}
.vibp-bundle-cart .quantity .qty,
.vibp-bundle-cart input.qty {
box-sizing: border-box;
width: 72px !important;
min-width: 72px;
height: 44px !important;
min-height: 44px;
padding: 6px 8px;
line-height: 30px;
text-align: center;
direction: ltr;
}
.vibp-bundle-cart .single_add_to_cart_button {
vertical-align: middle;
min-height: 44px;
}
.vibp-bundle-cart .vibp-fallback-submit:not([hidden]) {
display: inline-flex !important;
align-items: center;
justify-content: center;
}
.vibp-bundle-cart .vibp-fallback-submit.is-hidden,
.vibp-bundle-cart .vibp-fallback-submit[hidden] {
display: none !important;
}
.vibp-bundle-items {
display: grid;
gap: 14px;
margin: 0 0 20px;
}
.vibp-bundle-item {
position: relative;
display: block;
padding: 14px;
border: 1px solid var(--vibp-border-soft);
border-radius: 8px;
background: var(--vibp-surface);
box-shadow: 0 1px 2px rgba(17, 24, 39, 0.04);
transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}
.vibp-choice-group-wrap {
display: grid;
gap: 12px;
padding: 12px;
border: 1px solid var(--vibp-border);
border-radius: 8px;
background: #fbfcfd;
}
.vibp-choice-group-title {
margin: 0 0 2px;
color: var(--vibp-text);
font-size: 17px;
font-weight: 800;
line-height: 1.35;
text-align: start;
}
.vibp-bundle-item--choice {
padding: 0;
overflow: hidden;
border-color: var(--vibp-border);
cursor: pointer;
}
.vibp-bundle-item--choice.is-included {
border-color: var(--vibp-accent);
box-shadow: 0 0 0 2px rgba(31, 122, 184, 0.12), 0 8px 20px rgba(17, 24, 39, 0.06);
}
.vibp-bundle-item--choice .vibp-item-body {
padding: 12px 14px 14px;
}
.vibp-optional-toggle,
.vibp-choice-toggle {
display: inline-grid;
grid-template-columns: auto minmax(0, 1fr);
gap: 10px;
align-items: center;
margin: 0 0 12px;
font-weight: 800;
cursor: pointer;
color: var(--vibp-text);
}
.vibp-choice-toggle {
width: 100%;
min-height: 50px;
margin: 0;
padding: 12px 14px;
border: 0;
border-bottom: 1px solid var(--vibp-border-soft);
border-radius: 0;
background: var(--vibp-surface-soft);
}
.vibp-bundle-item--choice.is-included .vibp-choice-toggle {
border-bottom-color: rgba(31, 122, 184, 0.22);
background: var(--vibp-accent-soft);
}
.vibp-choice-toggle input[type="radio"] {
position: absolute;
opacity: 0;
pointer-events: none;
}
.vibp-choice-mark {
display: inline-flex;
flex: 0 0 auto;
align-items: center;
justify-content: center;
width: 24px;
height: 24px;
border: 2px solid #737b86;
border-radius: 50%;
background: #fff;
transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}
.vibp-choice-toggle input[type="radio"]:checked + .vibp-choice-included + .vibp-choice-mark {
border-color: var(--vibp-accent);
background: var(--vibp-accent);
box-shadow: inset 0 0 0 5px #fff;
}
.vibp-choice-text {
min-width: 0;
font-size: 16px;
line-height: 1.35;
color: var(--vibp-text);
}
.vibp-bundle-item--optional:not(.is-included) .vibp-child-variations,
.vibp-bundle-item--optional:not(.is-included) .vibp-fixed-item,
.vibp-bundle-item--choice:not(.is-included) .vibp-child-variations,
.vibp-bundle-item--choice:not(.is-included) .vibp-fixed-item {
opacity: 0.62;
}
.vibp-fixed-item {
display: grid;
grid-template-columns: 84px minmax(0, 1fr);
gap: 14px;
align-items: center;
padding: 0;
border: 0;
}
.vibp-fixed-media img {
display: block;
width: 84px;
height: 84px;
object-fit: cover;
border: 1px solid var(--vibp-border-soft);
border-radius: 8px;
background: #fff;
}
.vibp-fixed-info {
display: grid;
grid-template-columns: minmax(0, 1fr) 46px;
gap: 12px;
align-items: center;
min-width: 0;
padding-inline-end: 8px;
}
.vibp-fixed-info h3 {
margin: 0;
min-width: 0;
color: var(--vibp-text);
font-size: 16px;
font-weight: 700;
line-height: 1.45;
overflow-wrap: anywhere;
}
.vibp-fixed-info span {
display: inline-flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
width: 46px;
min-width: 46px;
min-height: 30px;
padding: 4px 7px;
border: 1px solid var(--vibp-border-soft);
border-radius: 999px;
background: var(--vibp-surface-soft);
color: var(--vibp-text);
font-weight: 800;
line-height: 1;
white-space: nowrap;
}
.vibp-child-variations {
display: block;
padding-top: 4px;
--visw-swatch-size: var(--vibp-swatch-size-desktop);
}
.vibp-bundle-item--choice .vibp-child-variations {
padding-top: 12px;
}
.vibp-variations {
margin: 0;
width: 100%;
}
.vibp-variations th,
.vibp-variations td {
display: block;
padding: 0 0 10px;
text-align: start;
}
.vibp-variations .label label {
display: inline-block;
margin-bottom: 6px;
color: var(--vibp-text);
font-weight: 800;
line-height: 1.3;
}
.vibp-child-variations .reset_variations {
display: none !important;
}
.vibp-child-variations .single_variation,
.vibp-child-variations .woocommerce-variation,
.vibp-child-variations .woocommerce-variation-price,
.vibp-child-variations .woocommerce-variation-availability,
.vibp-child-variations .woocommerce-price-suffix {
display: none !important;
}
.vibp-child-variations .visw-options,
.vibp-child-variations .visw-swatches,
.vibp-child-variations .visw-attribute-options {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.vibp-child-variations .visw-option {
margin: 0 !important;
transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}
.vibp-child-variations .visw-option--image {
width: var(--vibp-swatch-size-desktop);
height: var(--vibp-swatch-size-desktop);
padding: 3px;
border: 1px solid var(--vibp-border);
border-radius: 8px;
background: #fff;
}
.vibp-child-variations .visw-option--image img {
display: block;
width: 100%;
height: 100%;
object-fit: cover;
border-radius: 6px;
}
.vibp-child-variations .visw-option.is-selected,
.vibp-child-variations .visw-option.selected,
.vibp-child-variations .visw-option[aria-checked="true"] {
border-color: var(--vibp-accent);
box-shadow: 0 0 0 2px rgba(31, 122, 184, 0.16);
}
.vibp-bundle-notice {
display: grid !important;
grid-template-columns: 36px minmax(0, 1fr);
gap: 12px;
align-items: center;
margin: 0 0 16px !important;
padding: 14px 16px !important;
border: 1px solid #ffd8d8 !important;
border-radius: 8px !important;
background: #fff7f7 !important;
color: #c62525 !important;
list-style: none !important;
text-align: start;
box-shadow: 0 8px 24px rgba(17, 24, 39, 0.08);
}
.vibp-bundle-notice::before,
.vibp-bundle-notice::after {
display: none !important;
content: none !important;
}
.vibp-bundle-notice__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border-radius: 50%;
background: #ffe8e8;
color: #e03131;
font-size: 18px;
font-weight: 800;
line-height: 1;
}
.vibp-bundle-notice__copy {
display: grid;
gap: 4px;
min-width: 0;
}
.vibp-bundle-notice__copy strong {
color: #b91c1c;
font-size: 16px;
font-weight: 800;
line-height: 1.35;
}
.vibp-bundle-notice__copy small {
color: #6b1d1d;
font-size: 13px;
font-weight: 600;
line-height: 1.35;
}
.wac-toast--vibp-validation .wac-toast-progress {
background: #e03131;
}
.wac-toast-progress {
height: 3px;
width: 100%;
background: var(--wac-brand, #1976c9);
transform: scaleX(1);
transform-origin: right center;
pointer-events: none;
opacity: 0;
}
.wac-toast-progress.wac-toast-progress--active {
opacity: 1;
animation: wac-countdown linear forwards;
animation-duration: var(--wac-countdown, 5s);
}
@keyframes wac-countdown {
from {
transform: scaleX(1);
}
to {
transform: scaleX(0);
}
}
.wac-toast--vibp-validation .vibp-wac-validation {
display: grid;
gap: 6px;
justify-items: center;
text-align: center;
}
.wac-toast--vibp-validation .vibp-wac-validation__headline {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
color: #b91c1c;
font-size: 18px;
font-weight: 900;
line-height: 1.3;
}
.wac-toast--vibp-validation .vibp-wac-validation__headline .wac-toast-label-icon {
display: inline-flex;
align-items: center;
justify-content: center;
flex: 0 0 auto;
width: 28px;
height: 28px;
border-radius: 50%;
background: #fff0f0;
color: #e03131;
}
.wac-toast--vibp-validation .vibp-wac-validation__headline svg {
width: 18px;
height: 18px;
}
.vibp-wac-validation__help {
display: block;
color: #4b5563;
font-size: 13px;
font-weight: 700;
line-height: 1.4;
}
.vibp-cart-components {
display: grid;
gap: 8px;
margin-top: 10px;
padding-top: 10px;
border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.vibp-cart-component {
display: grid;
grid-template-columns: 42px minmax(0, 1fr) auto;
gap: 8px;
align-items: center;
font-size: 13px;
line-height: 1.35;
}
.vibp-cart-component__image img {
display: block;
width: 42px;
height: 42px;
object-fit: cover;
border-radius: 4px;
}
.vibp-cart-component__name {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: normal;
}
.vibp-cart-component__qty {
font-weight: 700;
white-space: nowrap;
}
.woocommerce-cart-form .vibp-cart-child-item td,
.woocommerce-checkout-review-order-table .vibp-cart-child-item td {
background: rgba(0, 0, 0, 0.025);
}
.vibp-cart-child-item .product-name,
.vibp-cart-child-item .product-thumbnail {
padding-inline-start: 22px;
}
.vibp-cart-child-item .product-name::before {
content: "\21B3";
display: inline-block;
margin-inline-end: 6px;
color: #6b7280;
}
.vibp-cart-child-item .product-price,
.vibp-cart-child-item .product-subtotal {
color: #6b7280;
}
@media (max-width: 600px) {
.vibp-bundle-cart {
margin-top: 18px;
}
.vibp-bundle-items {
gap: 12px;
}
.vibp-bundle-item {
padding: 12px;
}
.vibp-bundle-item--choice {
padding: 0;
}
.vibp-bundle-item--choice .vibp-item-body {
padding: 10px 12px 12px;
}
.vibp-choice-toggle {
min-height: 48px;
padding: 10px 12px;
}
.vibp-choice-mark {
width: 22px;
height: 22px;
}
.vibp-choice-text {
font-size: 15px;
}
.vibp-fixed-item {
grid-template-columns: 64px minmax(0, 1fr);
gap: 10px;
}
.vibp-fixed-media img {
width: 64px;
height: 64px;
}
.vibp-fixed-info {
grid-template-columns: minmax(0, 1fr) 40px;
gap: 8px;
padding-inline-end: 8px;
}
.vibp-fixed-info h3 {
font-size: 15px;
line-height: 1.45;
}
.vibp-fixed-info span {
width: 40px;
min-width: 40px;
min-height: 28px;
padding: 3px 6px;
}
.vibp-child-variations {
--visw-swatch-size: var(--vibp-swatch-size-mobile);
}
.vibp-child-variations .visw-options,
.vibp-child-variations .visw-swatches,
.vibp-child-variations .visw-attribute-options {
gap: 8px;
}
.vibp-child-variations .visw-option--image {
width: var(--vibp-swatch-size-mobile);
height: var(--vibp-swatch-size-mobile);
}
.vibp-bundle-notice {
grid-template-columns: 32px minmax(0, 1fr);
gap: 10px;
padding: 12px !important;
}
.vibp-bundle-notice__icon {
width: 32px;
height: 32px;
font-size: 16px;
}
.wac-toast--vibp-validation .vibp-wac-validation__headline {
font-size: 17px;
}
}