/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/

.brx-body {
	min-height: calc(100dvh);
}

.cart-link {
    position: relative;
    display: inline-block;
}

.cart-count {
    position: absolute;
    top: -5px;
    right: -10px;
    background: red;
    color: white;
    font-size: 12px;
    font-weight: bold;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}
label.woocommerce-form__label,
label.woocommerce-form__label span,
.woocommerce-form__label-for-checkbox {
  all: unset !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
  display: inline-block !important;
  white-space: normal !important;
  line-height: 1.4 !important;
  font-size: 1.5rem !important;
  color: inherit !important;
}
body.woocommerce-page .woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address input {
  position: relative !important;
  align-items: center;
  gap: 0.5em !important;
  top: 50%;
  transform: translateY(-0%);
}


/* custom css 
 * 
 * /**
 * Bos Sierbeton — Zoekresultaten CSS
 * bs-search.css
 *
 * Plak in Bricks → Custom CSS, of laad via child theme.
 * Alle classes prefixed met .bs-search voor geen conflicten.
 */

/* ---- Header ---- */
.bs-search-header {
    background: #0D1B2A;
    padding: 32px 0 28px;
    padding-top: 134px; /* 34px topbar + 68px sticky header + 32px eigen padding */
    margin-top: -102px; /* 34px topbar + 68px header: trek omhoog zodat bg achter navbar doorloopt */
}

.bs-search-header__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 36px;
}

.bs-search-header__breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: rgba(255,255,255,.3);
    margin-bottom: 12px;
}

.bs-search-header__breadcrumb a {
    color: rgba(255,255,255,.45);
    text-decoration: none;
}

.bs-search-header__breadcrumb a:hover {
    color: rgba(255,255,255,.7);
}

.bs-search-header__title {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 22px;
    font-weight: 800;
    color: #FFFFFF;
    margin-bottom: 14px;
    letter-spacing: -0.025em;
}

.bs-search-header__title span {
    color: #0066FF;
}

.bs-search-header__count {
    font-size: 13px;
    color: rgba(255,255,255,.35);
}

/* Search form */
.bs-search-form {
    display: flex;
    gap: 8px;
    margin-top: 16px;
    max-width: 520px;
}

.bs-search-form__input {
    flex: 1;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 14px;
    padding: 10px 16px;
    border: 2px solid rgba(255,255,255,.12);
    border-radius: 8px;
    background: rgba(255,255,255,.06);
    color: #FFFFFF;
    transition: all 0.15s;
}

.bs-search-form__input::placeholder {
    color: rgba(255,255,255,.3);
}

.bs-search-form__input:focus {
    outline: none;
    border-color: #0066FF;
    background: rgba(255,255,255,.1);
}

.bs-search-form__btn {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 20px;
    background: #0066FF;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.12s;
    white-space: nowrap;
}

.bs-search-form__btn:hover {
    background: #004EC2;
}

/* ---- Main ---- */
.bs-search-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px 36px 80px;
}

/* Toolbar */
.bs-search-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid #E3E8EE;
}

.bs-search-toolbar__count {
    font-size: 13px;
    color: #8898A8;
}

.bs-search-toolbar__count strong {
    color: #0D1B2A;
    font-weight: 700;
}

.bs-search-toolbar__sort {
    display: flex;
    align-items: center;
    gap: 8px;
}

.bs-search-toolbar__sort-label {
    font-size: 12px;
    color: #8898A8;
}

/* WooCommerce ordering override */
.bs-search-toolbar .woocommerce-ordering select,
.bs-search-toolbar__sort-select {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 13px;
    color: #0D1B2A;
    padding: 6px 28px 6px 10px;
    border: 1px solid #E3E8EE;
    border-radius: 6px;
    background: #FFFFFF;
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238898A8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

.bs-search-toolbar .woocommerce-ordering {
    margin: 0;
}

/* ---- Product grid ---- */
.bs-search-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

/* Product card */
.bs-search-card {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.2s cubic-bezier(.25,.46,.45,.94);
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}

.bs-search-card:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,.05);
    border-color: transparent;
    transform: translateY(-2px);
}

.bs-search-card__img {
    aspect-ratio: 4 / 3;
    background: #FFFFFF;
    overflow: hidden;
    border-bottom: 1px solid #E3E8EE;
    position: relative;
}

.bs-search-card__img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 14px;
}

.bs-search-card__badge {
    position: absolute;
    top: 8px;
    left: 8px;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    z-index: 1;
}

.bs-search-card__badge--sale {
    background: #DC2626;
    color: #FFFFFF;
}

.bs-search-card__badge--new {
    background: #0066FF;
    color: #FFFFFF;
}

.bs-search-card__badge--custom {
    background: #059669;
    color: #FFFFFF;
}

.bs-search-card__body {
    padding: 14px 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.bs-search-card__footer {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 10px;
    border-top: 1px solid #E3E8EE;
}

.bs-search-card__price {
    display: flex;
    align-items: baseline;
    gap: 5px;
}

.bs-search-card__price-from {
    font-size: 11px;
    color: #8898A8;
    font-weight: 500;
}

/* WooCommerce price overrides */
.bs-search-card__price .woocommerce-Price-amount {
    font-family: 'Manrope', system-ui, sans-serif;
    font-weight: 800;
    font-size: 16px;
    color: #0066FF;
}

.bs-search-card__price del,
.bs-search-card__price del .woocommerce-Price-amount {
    font-size: 12px;
    font-weight: 400;
    color: #C4CDD5;
}

.bs-search-card__price ins {
    text-decoration: none;
}

.bs-search-card__price ins .woocommerce-Price-amount {
    font-weight: 800;
    font-size: 16px;
    color: #0066FF;
}

/* "Vanaf:" prefix die WooCommerce genereert */
.bs-search-card__price .price {
    font-size: 13px;
    color: #8898A8;
    display: flex;
    align-items: baseline;
    gap: 4px;
}

.bs-search-card__price .price .woocommerce-Price-amount {
    font-size: 16px;
}

/* BTW / suffix tekst kleiner */
.bs-search-card__price .woocommerce-price-suffix,
.bs-search-card__price small.woocommerce-price-suffix {
    font-size: 10px;
    font-weight: 400;
    color: #8898A8;
}

/* Hele card tekst reset — voorkom overerving van theme */
.bs-search-card,
.bs-search-card * {
    line-height: 1.4;
}

.bs-search-card__name {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 14px !important;
    font-weight: 700;
    color: #0D1B2A;
    margin-bottom: 4px;
    line-height: 1.3;
    letter-spacing: -0.025em;
}

.bs-search-card__cat {
    font-size: 10.5px !important;
    font-weight: 600;
    color: #0066FF;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 3px;
}

.bs-search-card__meta {
    font-size: 12px !important;
    color: #8898A8;
    margin-bottom: 10px;
}

.bs-search-card__cta {
    font-size: 12px !important;
}

.bs-search-card__cta {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: #0066FF;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    transition: gap 0.12s;
}

.bs-search-card:hover .bs-search-card__cta {
    gap: 6px;
}

/* ---- No results ---- */
.bs-search-empty {
    text-align: center;
    padding: 64px 0;
}

.bs-search-empty__icon {
    font-size: 48px;
    margin-bottom: 16px;
}

.bs-search-empty__title {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: #0D1B2A;
    margin-bottom: 8px;
    letter-spacing: -0.025em;
}

.bs-search-empty__text {
    font-size: 14px;
    color: #8898A8;
    max-width: 400px;
    margin: 0 auto 20px;
    line-height: 1.7;
}

.bs-search-empty__suggestions {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

.bs-search-empty__tag {
    font-size: 13px;
    font-weight: 500;
    padding: 7px 14px;
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 6px;
    color: #556270;
    transition: all 0.12s;
    text-decoration: none;
}

.bs-search-empty__tag:hover {
    border-color: #0066FF;
    color: #0066FF;
}

/* ---- Pagination ---- */
.bs-search-pagination {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-top: 32px;
}

.bs-search-pagination .page-numbers {
    width: 36px;
    height: 36px;
    display: inline-grid;
    place-items: center;
    border-radius: 7px;
    font-size: 13px;
    font-weight: 600;
    color: #556270;
    border: 1px solid #E3E8EE;
    background: #FFFFFF;
    transition: all 0.12s;
    text-decoration: none;
}

.bs-search-pagination .page-numbers:hover {
    border-color: #0066FF;
    color: #0066FF;
}

.bs-search-pagination .page-numbers.current {
    background: #0066FF;
    border-color: #0066FF;
    color: #FFFFFF;
}

.bs-search-pagination .page-numbers.prev,
.bs-search-pagination .page-numbers.next {
    font-size: 16px;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
    .bs-search-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 640px) {
    .bs-search-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .bs-search-header__inner,
    .bs-search-main {
        padding-left: 16px;
        padding-right: 16px;
    }

    .bs-search-header__title {
        font-size: 18px;
    }

    .bs-search-toolbar {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
}

/**
 * Bos Sierbeton — Categorie / Shop pagina CSS
 * bs-category.css
 *
 * Plak in Bricks → Custom CSS, of laad via child theme.
 * Alle classes prefixed met .bs-cat voor geen conflicten.
 */

/* ============================================
   PAGE HEADER
   ============================================ */
.bs-cat-header {
    background: #0D1B2A;
    padding: 36px 0 32px;
}

.bs-cat-header__inner {
    max-width: var(--site-width);
    margin: 0 auto;
	margin-top: var(--nav-h);
}

.bs-cat-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    color: rgba(255,255,255,.35);
    margin-bottom: 10px;
}

.bs-cat-breadcrumb a {
    color: rgba(255,255,255,.5);
    text-decoration: none;
    transition: color 0.15s;
}

.bs-cat-breadcrumb a:hover {
    color: #FFFFFF;
}

.bs-cat-header__title {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: var(--text-xl);
    font-weight: 800;
    color: #FFFFFF;
    margin-bottom: 6px;
    letter-spacing: -0.025em;
}

.bs-cat-header__desc {
    font-size: 14px;
    color: rgba(255,255,255,.45);
    max-width: 520px;
    line-height: 1.6;
}

.bs-cat-header__count {
    margin-top: 10px;
    font-size: 12.5px;
    color: rgba(255,255,255,.3);
}

/* ============================================
   SHOP LAYOUT (sidebar + content)
   ============================================ */
.bs-cat-shop {
    max-width: var(--site-width);
    margin: 0 auto;
    padding: 28px 0px 80px;
    display: grid;
    grid-template-columns: 230px 1fr;
    gap: 24px;
    align-items: start;
}

/* ============================================
   FILTER SIDEBAR
   ============================================ */
.bs-cat-filters {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.bs-cat-filter {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 10px;
    overflow: hidden;
}

.bs-cat-filter__header {
    padding: 14px 18px;
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: #0D1B2A;
    border-bottom: 1px solid #E3E8EE;
}

.bs-cat-filter__body {
    padding: 12px 18px;
}

/* Category links */
.bs-cat-filter__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 13.5px;
    font-weight: 500;
    color: #556270;
    text-decoration: none;
    transition: color 0.12s;
}

.bs-cat-filter__link:hover {
    color: #0066FF;
}

.bs-cat-filter__link--active {
    color: #0066FF;
    font-weight: 600;
}

.bs-cat-filter__count {
    font-size: 11px;
    color: #C4CDD5;
    background: #F7F8FA;
    padding: 1px 7px;
    border-radius: 10px;
}

/* Checkbox links */
.bs-cat-filter__check {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    font-size: 13px;
    color: #556270;
    text-decoration: none;
    cursor: pointer;
    transition: color 0.12s;
}

.bs-cat-filter__check:hover {
    color: #0D1B2A;
}

.bs-cat-filter__box {
    width: 16px;
    height: 16px;
    border: 1.5px solid #C4CDD5;
    border-radius: 4px;
    flex-shrink: 0;
    transition: all 0.15s;
}

.bs-cat-filter__check:hover .bs-cat-filter__box {
    border-color: #0066FF;
}

.bs-cat-filter__check--active .bs-cat-filter__box {
    background: #0066FF;
    border-color: #0066FF;
}

.bs-cat-filter__check--active {
    color: #0066FF;
    font-weight: 600;
}

/* ============================================
   TOOLBAR
   ============================================ */
.bs-cat-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
}

.bs-cat-toolbar__count {
    font-size: 13px;
    color: #8898A8;
}

.bs-cat-toolbar__count strong {
    color: #0D1B2A;
    font-weight: 600;
}

.bs-cat-toolbar__sort {
    display: flex;
    align-items: center;
    gap: 8px;
}

.bs-cat-toolbar__sort-label {
    font-size: 12.5px;
    color: #8898A8;
}

/* WooCommerce ordering override */
.bs-cat-toolbar .woocommerce-ordering {
    margin: 0;
}

.bs-cat-toolbar .woocommerce-ordering select {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: #0D1B2A;
    padding: 7px 28px 7px 12px;
    border: 1px solid #E3E8EE;
    border-radius: 6px;
    background: #FFFFFF;
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238898A8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

/* ============================================
   PRODUCT GRID
   ============================================ */
.bs-cat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

/* Product card */
.bs-cat-card {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.2s cubic-bezier(.25,.46,.45,.94);
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}

.bs-cat-card:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,.06);
    border-color: transparent;
    transform: translateY(-2px);
}

.bs-cat-card__img {
    aspect-ratio: 4 / 3;
    background: #FFFFFF;
    overflow: hidden;
    position: relative;
    border-bottom: 1px solid #E3E8EE;
}

.bs-cat-card__img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 12px;
}

/* Badges */
.bs-cat-card__badge {
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    z-index: 1;
    background: #0066FF;
    color: #FFFFFF;
}

.bs-cat-card__badge--sale {
    background: #DC2626;
}

.bs-cat-card__badge--popular {
    background: #0066FF;
}

.bs-cat-card__badge--custom {
    background: #059669;
}

/* Card body */
.bs-cat-card__body {
    padding: 14px 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.bs-cat-card__name {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 13.5px !important;
    font-weight: 700;
    color: #0D1B2A;
    margin-bottom: 3px;
    line-height: 1.3;
    letter-spacing: -0.025em;
}

.bs-cat-card__meta {
    font-size: 11.5px !important;
    color: #8898A8;
    margin-bottom: 8px;
}

.bs-cat-card__footer {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 10px;
    border-top: 1px solid #E3E8EE;
	font-size: var(--text-s);
}

/* Price - WooCommerce overrides */
.bs-cat-card__price {
    display: flex;
    align-items: baseline;
    gap: 4px;
}

.bs-cat-card__price .price {
    font-size: var(--text-m);
    color: #8898A8;
    display: flex;
    align-items: baseline;
    gap: 4px;
}

.bs-cat-card__price .woocommerce-Price-amount {
    font-family: 'Manrope', system-ui, sans-serif;
    font-weight: 800;
    font-size: var(--text-s);
    color: #0066FF;
}

.from-text {
	font-size: var(--text-s);
}

.bs-cat-card__price del,
.bs-cat-card__price del .woocommerce-Price-amount {
    font-size: 12px;
    font-weight: 400;
    color: #C4CDD5;
}

.bs-cat-card__price ins {
    text-decoration: none;
}

.bs-cat-card__price ins .woocommerce-Price-amount {
    font-weight: 800;
    font-size: 16px;
    color: #0066FF;
}

.bs-cat-card__price .woocommerce-price-suffix,
.bs-cat-card__price small.woocommerce-price-suffix {
    font-size: 10px;
    font-weight: 400;
    color: #8898A8;
}

/* CTA */
.bs-cat-card__cta {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 12px !important;
    font-weight: 600;
    color: #0066FF;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: gap 0.15s;
    white-space: nowrap;
}

.bs-cat-card:hover .bs-cat-card__cta {
    gap: 6px;
}

/* ============================================
   PAGINATION
   ============================================ */
.bs-cat-pagination {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-top: 32px;
}

.bs-cat-pagination .page-numbers {
    width: 36px;
    height: 36px;
    display: inline-grid;
    place-items: center;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    color: #556270;
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    text-decoration: none;
    transition: all 0.15s;
}

.bs-cat-pagination .page-numbers:hover {
    border-color: #0066FF;
    color: #0066FF;
}

.bs-cat-pagination .page-numbers.current {
    background: #0066FF;
    border-color: #0066FF;
    color: #FFFFFF;
}

.bs-cat-pagination .page-numbers.prev,
.bs-cat-pagination .page-numbers.next {
    font-size: 16px;
    color: #8898A8;
}

/* ============================================
   EMPTY STATE
   ============================================ */
.bs-cat-empty {
    text-align: center;
    padding: 64px 0;
}

.bs-cat-empty__icon {
    font-size: 48px;
    margin-bottom: 16px;
}

.bs-cat-empty__title {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: #0D1B2A;
    margin-bottom: 8px;
}

.bs-cat-empty__text {
    font-size: var(--text-m);
    color: #8898A8;
    max-width: 400px;
    margin: 0 auto 20px;
    line-height: 1.7;
}

.bs-cat-empty__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: var(--text-m);
    font-weight: 600;
    padding: 11px 22px;
    background: #0066FF;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    text-decoration: none;
    transition: background 0.15s;
}

.bs-cat-empty__btn:hover {
    background: #004EC2;
}

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

/* Tablet */
@media (max-width: 1024px) {
    .bs-cat-shop {
        grid-template-columns: 200px 1fr;
        gap: 20px;
        padding-left: 24px;
        padding-right: 24px;
    }

    .bs-cat-header__inner {
        padding-left: 24px;
        padding-right: 24px;
    }

    .bs-cat-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Small tablet — sidebar collapst */
@media (max-width: 768px) {
    .bs-cat-shop {
        grid-template-columns: 1fr;
        gap: 0;
    }

    /* Sidebar → horizontaal scrollbare strip */
    .bs-cat-filters {
        position: static;
        flex-direction: row;
        overflow-x: auto;
        gap: 8px;
        padding-bottom: 16px;
        margin-bottom: 16px;
        border-bottom: 1px solid #E3E8EE;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .bs-cat-filters::-webkit-scrollbar {
        display: none;
    }

    .bs-cat-filter {
        min-width: 160px;
        flex-shrink: 0;
    }

    .bs-cat-filter__body {
        max-height: 120px;
        overflow-y: auto;
    }

    .bs-cat-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .bs-cat-toolbar {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .bs-cat-header {
        padding: 28px 0 24px;
    }

    .bs-cat-header__title {
        font-size: 22px;
    }

    .bs-cat-header__desc {
        font-size: 13px;
    }

    .bs-cat-card__img {
        aspect-ratio: 1 / 1;
    }

    .bs-cat-card__img img {
        padding: 10px;
    }

    .bs-cat-card__body {
        padding: 10px 12px;
    }

    .bs-cat-card__name {
        font-size: 13px !important;
    }

    .bs-cat-card__meta {
        font-size: 11px !important;
    }

    .bs-cat-card__price .woocommerce-Price-amount,
    .bs-cat-card__price ins .woocommerce-Price-amount {
        font-size: var(--text-m);
    }

    .bs-cat-card__footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .bs-cat-pagination .page-numbers {
        width: 32px;
        height: 32px;
        font-size: 12px;
    }
}

/* Phone */
@media (max-width: 480px) {
    .bs-cat-header__inner,
    .bs-cat-shop {
        padding-left: 16px;
        padding-right: 16px;
    }

    .bs-cat-header__title {
        font-size: 18px;
    }

    .bs-cat-breadcrumb {
        font-size: 11px;
    }

    .bs-cat-grid {
        gap: 8px;
    }

    .bs-cat-card__name {
        font-size: 12px !important;
        -webkit-line-clamp: 2;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .bs-cat-card__meta {
        display: none;
    }

    .bs-cat-card__badge {
        font-size: 8px;
        padding: 2px 6px;
    }

    .bs-cat-card__price .woocommerce-Price-amount,
    .bs-cat-card__price ins .woocommerce-Price-amount {
        font-size: var(--text-m);
    }

    .bs-cat-card__price .woocommerce-price-suffix,
    .bs-cat-card__price small.woocommerce-price-suffix {
        font-size: var(--text-s);
    }

    .bs-cat-filter {
        min-width: 140px;
        border-radius: 8px;
    }

    .bs-cat-filter__header {
        font-size: 11px;
        padding: 10px 12px;
    }

    .bs-cat-filter__body {
        padding: 8px 12px;
    }

    .bs-cat-empty__title {
        font-size: 17px;
    }
} 


/**
 * Bos Sierbeton — Product Pagina CSS
 * bs-product.css
 *
 * Plak in Bricks → Custom CSS, of laad via child theme.
 * Alle classes prefixed met .bs-prod
 */

/* ============================================
   BREADCRUMB
   ============================================ */
.bs-prod-breadcrumb-bar {
  background: #FFFFFF;
  padding: 12px 0;
  top: 102px;
  position: absolute;
}

.bs-prod-breadcrumb-bar__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 36px;
}

.bs-prod-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    color: #8898A8;
}

.bs-prod-breadcrumb a {
    color: #556270;
    text-decoration: none;
    transition: color 0.12s;
}

.bs-prod-breadcrumb a:hover {
    color: #0066FF;
}

.bs-prod-breadcrumb__current {
    color: #0D1B2A;
    font-weight: 500;
}

/* ============================================
   PRODUCT LAYOUT
   ============================================ */
.bs-prod {
	
    max-width: var(--site-width);
    margin: 0 auto;
	margin-top: var(--nav-h);
    padding: 28px 0px 48px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: start;
}

/* ============================================
   GALLERY
   ============================================ */
.bs-prod-gallery {
    position: sticky;
    top: 100px;
    /* top waarde = jouw navbar hoogte + wat spacing */
}

.bs-prod-gallery__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    font-size: 10px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 5px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.bs-prod-gallery__badge--sale {
    background: #DC2626;
    color: #FFFFFF;
}

.bs-prod-gallery__main {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 12px;
    aspect-ratio: 4 / 3;
    display: grid;
    place-items: center;
    overflow: hidden;
    margin-bottom: 12px;
    position: relative;
}

.bs-prod-gallery__main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 20px;
}

.bs-prod-gallery__thumbs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.bs-prod-gallery__thumb {
    width: 80px;
    height: 60px;
    background: #FFFFFF;
    border: 2px solid #E3E8EE;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.15s;
    display: grid;
    place-items: center;
    padding: 0;
}

.bs-prod-gallery__thumb:hover {
    border-color: #8898A8;
}

.bs-prod-gallery__thumb--active {
    border-color: #0066FF;
}

.bs-prod-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 4px;
}

/* ============================================
   PRODUCT INFO
   ============================================ */
.bs-prod-info {
    display: flex;
    flex-direction: column;
}

.bs-prod-info__name {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: var(--text-l);
    font-weight: 800;
    color: #0D1B2A;
    margin-bottom: 8px;
    letter-spacing: -0.025em;
    line-height: 1.2;
}

.bs-prod-info__short-desc {
    font-size: 14px;
    color: #556270;
    line-height: 1.6;
    margin-bottom: 12px;
}

.bs-prod-info__short-desc p {
    margin: 0 0 6px;
}

/* Price */
.bs-prod-info__price {
    margin-bottom: 6px;
}

.bs-prod-info__price .price {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 14px;
    color: #8898A8;
    display: flex;
    align-items: baseline;
    gap: 5px;
}

.bs-prod-info__price .woocommerce-Price-amount {
    font-family: 'Manrope', system-ui, sans-serif;
    font-weight: 800;
    font-size: 26px;
    color: #0D1B2A;
}

.bs-prod-info__price del .woocommerce-Price-amount {
    font-size: 16px;
    font-weight: 500;
    color: #C4CDD5;
}

.bs-prod-info__price ins {
    text-decoration: none;
}

.bs-prod-info__price ins .woocommerce-Price-amount {
    color: #0D1B2A;
    font-weight: 800;
    font-size: 26px;
}

.bs-prod-info__price .woocommerce-price-suffix,
.bs-prod-info__price small.woocommerce-price-suffix {
    font-size: 13px;
    font-weight: 400;
    color: #8898A8;
}

/* Stock */
.bs-prod-info__stock {
    font-size: 13.5px;
    color: #556270;
    margin-bottom: 16px;
}

.bs-prod-info__stock--instock {
    color: #059669;
    font-weight: 600;
}

.bs-prod-info__stock--onorder {
    color: #556270;
}

.bs-prod-info__divider {
    height: 1px;
    background: #E3E8EE;
    margin-bottom: 20px;
}

/* ============================================
   ADD TO CART AREA (WooCommerce overrides)
   ============================================ */
.bs-prod-cart {
    margin-bottom: 16px;
}

/* --- Variable product: variation dropdowns --- */
.bs-prod-cart .variations {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 16px;
}

.bs-prod-cart .variations td,
.bs-prod-cart .variations th {
    padding: 0 0 12px;
    border: none;
    vertical-align: top;
}

.bs-prod-cart .variations .label label {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: #0D1B2A;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.bs-prod-cart .variations select {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #0D1B2A;
    padding: 9px 36px 9px 12px;
    border: 1.5px solid #E3E8EE;
    border-radius: 7px;
    background: #FFFFFF;
    appearance: none;
    cursor: pointer;
    width: 100%;
    transition: border-color 0.15s, box-shadow 0.15s;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238898A8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}

.bs-prod-cart .variations select:focus {
    outline: none;
    border-color: #0066FF;
    box-shadow: 0 0 0 3px rgba(0,102,255,.08);
}

/* Reset link */
.bs-prod-cart .reset_variations {
    font-size: 12px;
    color: #8898A8;
    margin-top: 4px;
    display: inline-block;
}

/* Variation price update */
.bs-prod-cart .woocommerce-variation-price .price {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 13px;
    color: #8898A8;
    margin-bottom: 12px;
}

.bs-prod-cart .woocommerce-variation-price .woocommerce-Price-amount {
    font-weight: 800;
    font-size: 22px;
    color: #0066FF;
}

.bs-prod-cart .woocommerce-variation-description {
    font-size: 13px;
    color: #556270;
    margin-bottom: 12px;
}

.bs-prod-cart .woocommerce-variation-availability {
    font-size: 12px;
    margin-bottom: 8px;
}

/* --- Quantity + Add to Cart --- */
.bs-prod-cart .quantity {
    display: inline-flex;
    align-items: center;
    border: 1.5px solid #E3E8EE;
    border-radius: 8px;
    overflow: hidden;
    margin-right: 10px;
    vertical-align: middle;
}

.bs-prod-cart .quantity .qty {
    width: 52px;
    height: 44px;
    text-align: center;
    border: none;
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: #0D1B2A;
    background: #FFFFFF;
    -moz-appearance: textfield;
}

.bs-prod-cart .quantity .qty::-webkit-inner-spin-button,
.bs-prod-cart .quantity .qty::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Add to cart button */
.bs-prod-cart .single_add_to_cart_button,
.bs-prod-cart button[type="submit"] {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-weight: 600;
    font-size: 15px;
    padding: 13px 28px;
    background: #0066FF;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s;
    vertical-align: middle;
}

.bs-prod-cart .single_add_to_cart_button:hover {
    background: #004EC2;
    box-shadow: 0 2px 12px rgba(0,102,255,.25);
}

.bs-prod-cart .single_add_to_cart_button:active {
    transform: scale(0.98);
}

/* Disabled state */
.bs-prod-cart .single_add_to_cart_button.disabled,
.bs-prod-cart .single_add_to_cart_button:disabled {
    background: #C4CDD5;
    cursor: not-allowed;
    box-shadow: none;
}

/* ============================================
   NOTICE & SAMPLE
   ============================================ */
.bs-prod-notice {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #F0F5FF;
    border: 1px solid #EBF2FF;
    border-radius: 8px;
    font-size: 13.5px;
    font-weight: 600;
    color: #3B4F68;
    margin-bottom: 12px;
}

.bs-prod-notice__icon {
    font-size: 16px;
    flex-shrink: 0;
}

.bs-prod-sample {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    background: #FFFBEB;
    border: 1px solid #FDE68A;
    border-radius: 7px;
    margin-bottom: 16px;
    text-decoration: none;
    color: inherit;
    transition: background 0.15s, border-color 0.15s;
}

.bs-prod-sample:hover {
    background: #FEF3C7;
    border-color: #F59E0B;
}

.bs-prod-sample__icon {
    font-size: 18px;
    flex-shrink: 0;
}

.bs-prod-sample__text {
    font-size: 13px;
    color: #92400E;
    line-height: 1.4;
}

.bs-prod-sample__text strong {
    display: block;
    font-weight: 700;
    color: #78350F;
}

/* ============================================
   USPs (onder stock status)
   ============================================ */
.bs-prod-usps {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 16px;
    margin-top: 10px;
    margin-bottom: 4px;
}

.bs-prod-usp {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    font-weight: 500;
    color: #059669;
}

.bs-prod-usp svg {
    flex-shrink: 0;
}

/* ============================================
   TABS (WooCommerce override)
   Full-width, kopjes links naast elkaar, content volle breedte
   ============================================ */
.bs-prod-tabs {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 36px 48px;
}

/* Forceer WooCommerce tabs wrapper volle breedte */
.bs-prod-tabs .woocommerce-tabs,
.bs-prod-tabs > div {
    width: 100% !important;
    max-width: none !important;
}

/* Tab nav — horizontaal, links uitgelijnd */
.bs-prod-tabs .wc-tabs,
.bs-prod-tabs .woocommerce-tabs ul.tabs {
    list-style: none;
    display: flex;
    gap: 0;
    border-bottom: 2px solid #E3E8EE;
    margin: 0 0 0;
    padding: 0;
}

.bs-prod-tabs .wc-tabs li,
.bs-prod-tabs .woocommerce-tabs ul.tabs li {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
}

.bs-prod-tabs .wc-tabs li a,
.bs-prod-tabs .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 14px 28px;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #556270;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.15s;
}

.bs-prod-tabs .wc-tabs li a:hover {
    color: #0D1B2A;
}

.bs-prod-tabs .wc-tabs li.active a,
.bs-prod-tabs .woocommerce-tabs ul.tabs li.active a {
    color: #0066FF;
    border-bottom-color: #0066FF;
}

/* Tab content — volle breedte, geen max-width beperking */
.bs-prod-tabs .woocommerce-Tabs-panel,
.bs-prod-tabs .panel {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 0px 36px;
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box;
}

.bs-prod-tabs .woocommerce-Tabs-panel h2 {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: #0D1B2A;
    margin-bottom: 14px;
    letter-spacing: -0.025em;
}

.bs-prod-tabs .woocommerce-Tabs-panel p {
    font-size: 14px;
    color: #556270;
    line-height: 1.75;
    margin-bottom: 12px;
    max-width: none;
}

/* Spec table in tabs — volle breedte */
.bs-prod-tabs table.shop_attributes {
    width: 100%;
    border-collapse: collapse;
}

.bs-prod-tabs table.shop_attributes tr {
    border-bottom: 1px solid #E3E8EE;
}

.bs-prod-tabs table.shop_attributes tr:last-child {
    border-bottom: none;
}

.bs-prod-tabs table.shop_attributes th {
    text-align: left;
    padding: 12px 0;
    font-size: 13px;
    font-weight: 600;
    color: #0D1B2A;
    width: 200px;
}

.bs-prod-tabs table.shop_attributes td {
    padding: 12px 0;
    font-size: 13px;
    color: #556270;
}

.bs-prod-tabs table.shop_attributes td p {
    margin: 0;
}

/* Beschrijving content — links uitlijnen, geen centering */
.bs-prod-tabs .woocommerce-Tabs-panel--description,
.bs-prod-tabs .woocommerce-Tabs-panel--additional_information {
    text-align: left;
}

/* ============================================
   WooCommerce Aanvullende Informatie table
   (eigen classes die WooCommerce genereert)
   Forceer volle breedte, geen centering
   ============================================ */
.bs-prod-tabs .woocommerce-product-attributes {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    border-collapse: collapse;
    border: none !important;
}

.bs-prod-tabs .woocommerce-product-attributes tr,
.bs-prod-tabs .woocommerce-product-attributes .woocommerce-product-attributes-item {
    border-bottom: 1px solid #E3E8EE !important;
    background: none !important;
}

.bs-prod-tabs .woocommerce-product-attributes tr:last-child,
.bs-prod-tabs .woocommerce-product-attributes .woocommerce-product-attributes-item:last-child {
    border-bottom: none !important;
}

.bs-prod-tabs .woocommerce-product-attributes th,
.bs-prod-tabs .woocommerce-product-attributes .woocommerce-product-attributes-item__label {
    text-align: left !important;
    padding: 14px 16px 14px 0 !important;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #0D1B2A !important;
    width: 200px !important;
    background: none !important;
    border: none !important;
    vertical-align: middle;
}

.bs-prod-tabs .woocommerce-product-attributes td,
.bs-prod-tabs .woocommerce-product-attributes .woocommerce-product-attributes-item__value {
    padding: 14px 0 !important;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 13px !important;
    color: #556270 !important;
    background: none !important;
    border: none !important;
    vertical-align: middle;
}

.bs-prod-tabs .woocommerce-product-attributes .woocommerce-product-attributes-item__value p {
    margin: 0 !important;
}

/* Tab content panel — volle breedte override voor WooCommerce panels */
.bs-prod-tabs .woocommerce-Tabs-panel {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* ============================================
   VERBERG DUBBELE STOCK in WooCommerce add-to-cart
   (wij tonen stock al boven de divider)
   ============================================ */
.bs-prod-cart .stock,
.bs-prod-cart .woocommerce-variation-availability,
.bs-prod-cart p.stock {
    display: none !important;
}

/* ============================================
   RELATED PRODUCTS
   ============================================ */
.bs-prod-related {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 36px 80px;
}

.bs-prod-related__head {
    margin-bottom: 18px;
}

.bs-prod-related__label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11.5px;
    font-weight: 700;
    color: #0066FF;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 6px;
}

.bs-prod-related__label::before {
    content: '';
    width: 18px;
    height: 2px;
    background: #0066FF;
    border-radius: 1px;
}

.bs-prod-related__title {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: var(--text-l);
    font-weight: 800;
    color: #0D1B2A;
    letter-spacing: -0.025em;
}

.bs-prod-related__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}

.bs-prod-rcard {
    background: #FFFFFF;
    border: 1px solid #E3E8EE;
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.2s cubic-bezier(.25,.46,.45,.94);
    display: block;
    text-decoration: none;
    color: inherit;
}

.bs-prod-rcard:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.05);
    transform: translateY(-2px);
}

.bs-prod-rcard__img {
    aspect-ratio: 4 / 3;
    background: #FFFFFF;
    display: grid;
    place-items: center;
    border-bottom: 1px solid #E3E8EE;
    overflow: hidden;
}

.bs-prod-rcard__img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 10px;
}

.bs-prod-rcard__body {
    padding: 12px 14px;
}

.bs-prod-rcard__name {
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: var(--text-s);
    font-weight: 700;
    color: #0D1B2A;
    margin-bottom: 2px;
    line-height: 1.3;
}

.bs-prod-rcard__price .woocommerce-Price-amount {
    font-family: 'Manrope', system-ui, sans-serif;
    font-weight: 700;
    font-size: var(--text-xs);
    color: #0066FF;
}

.bs-prod-rcard__price .woocommerce-price-suffix {
    font-size: var(--text-xs);
    color: #8898A8;
    font-weight: 500;
}

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

@media (max-width: 1024px) {
    .bs-prod {
        gap: 28px;
        padding-left: 24px;
        padding-right: 24px;
    }

    .bs-prod-related__grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .bs-prod-tabs,
    .bs-prod-related,
    .bs-prod-breadcrumb-bar__inner {
        padding-left: 24px;
        padding-right: 24px;
    }
}

@media (max-width: 768px) {
    .bs-prod {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 20px 16px 32px;
    }

    .bs-prod-gallery {
        position: static;
    }

    .bs-prod-gallery__main {
        aspect-ratio: 1 / 1;
        border-radius: 10px;
    }

    .bs-prod-gallery__thumbs {
        gap: 6px;
    }

    .bs-prod-gallery__thumb {
        width: 60px;
        height: 48px;
    }

    .bs-prod-info__name {
        font-size: 20px;
    }

    .bs-prod-info__price .woocommerce-Price-amount,
    .bs-prod-info__price ins .woocommerce-Price-amount {
        font-size: 22px;
    }

    .bs-prod-cart .single_add_to_cart_button {
        width: 100%;
        text-align: center;
        padding: 14px 20px;
    }

    .bs-prod-cart .quantity {
        margin-right: 0;
        margin-bottom: 10px;
    }

    .bs-prod-related__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .bs-prod-tabs,
    .bs-prod-related,
    .bs-prod-breadcrumb-bar__inner {
        padding-left: 16px;
        padding-right: 16px;
    }

    /* Tabs responsive */
    .bs-prod-tabs .wc-tabs,
    .bs-prod-tabs .woocommerce-tabs ul.tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .bs-prod-tabs .wc-tabs::-webkit-scrollbar {
        display: none;
    }

    .bs-prod-tabs .wc-tabs li a {
        padding: 10px 16px;
        font-size: 13px;
        white-space: nowrap;
    }

    .bs-prod-tabs .woocommerce-Tabs-panel,
    .bs-prod-tabs .panel {
        padding: 20px 16px;
    }
}

@media (max-width: 480px) {
    .bs-prod-info__name {
        font-size: 18px;
    }

    .bs-prod-info__price .woocommerce-Price-amount,
    .bs-prod-info__price ins .woocommerce-Price-amount {
        font-size: 20px;
    }

    .bs-prod-breadcrumb {
        font-size: 11px;
    }

    .bs-prod-rcard__name {
        font-size: 11px;
    }

    .bs-prod-rcard__body {
        padding: 8px 10px;
    }

    .bs-prod-notice {
        font-size: 12px;
        padding: 10px 12px;
    }

    .bs-prod-sample {
        padding: 10px 12px;
    }

    .bs-prod-sample__text {
        font-size: 12px;
    }

    .bs-prod-tabs table.shop_attributes th {
        width: 120px;
        font-size: 12px;
    }

    .bs-prod-tabs table.shop_attributes td {
        font-size: 12px;
    }

    .bs-prod-usps {
        gap: 2px 12px;
    }

    .bs-prod-usp {
        font-size: 11px;
    }
}

/* ============================================
   QUANTITY VELD (WooCommerce + Bricks markup)
   ============================================ */
.bs-prod-cart .quantity {
    display: inline-flex !important;
    align-items: center;
    border: 1.5px solid #E3E8EE;
    border-radius: 8px;
    overflow: hidden;
    margin-right: 10px;
    vertical-align: middle;
    visibility: visible !important;
    opacity: 1 !important;
}

.bs-prod-cart .quantity .qty {
    width: 52px;
    height: 44px;
    text-align: center;
    border: none;
    border-left: 1px solid #E3E8EE;
    border-right: 1px solid #E3E8EE;
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: #0D1B2A;
    background: #FFFFFF;
    -moz-appearance: textfield;
    display: block !important;
    visibility: visible !important;
}

.bs-prod-cart .quantity .action {
    display: grid !important;
    place-items: center;
    width: 40px;
    height: 44px;
    background: #FFFFFF;
    border: none;
    cursor: pointer;
    color: #556270;
    transition: all 0.12s;
    visibility: visible !important;
}

.bs-prod-cart .quantity .action:hover {
    background: #F7F8FA;
    color: #0D1B2A;
}

.bs-prod-cart .quantity .action svg {
    width: 16px;
    height: 16px;
}


/* NAV */
/* ============================================
   CONTACT LAYOUT
   ============================================ */


/* FORM */

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.form-row--full {
  grid-template-columns: 1fr;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.form-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink);
}

.form-input {
  font-family: var(--font-b);
  font-size: 14px;
  color: var(--ink);
  padding: 10px 14px;
  border: 1.5px solid var(--line);
  border-radius: 7px;
  background: var(--paper);
  transition: border-color 0.15s;
}

.form-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(0,102,255,.08);
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
}

.form-select {
  appearance: none;
  background: var(--paper) url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238898A8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  padding-right: 32px;
}

.contact-form__actions {
  margin-top: 20px;
  display: flex;
  gap: 10px;
}

.contact-form__actions .btn {
  padding: 12px 28px;
  font-size: 15px;
}

/* SIDEBAR */
.contact-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.info-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 24px;
}

.info-card__icon {
  width: 40px;
  height: 40px;
  background: var(--blue-soft);
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 18px;
  margin-bottom: 12px;
}

.info-card__title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 4px;
}

.info-card__text {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.6;
}

.info-card__text a {
  color: var(--blue);
  font-weight: 600;
}

.info-card__text a:hover {
  text-decoration: underline;
}

/* WhatsApp card */
.wa-card {
  background: #ECFDF5;
  border: 1px solid #A7F3D0;
}

.wa-card .info-card__icon {
  background: #D1FAE5;
}

/* Openingstijden */
.hours-list {
  margin-top: 8px;
}

.hours-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  font-size: 12.5px;
  color: var(--slate);
}

.hours-row__day {
  font-weight: 500;
}

.hours-row__time {
  font-weight: 600;
  color: var(--ink);
}

/* Map placeholder */
.map-card {
  aspect-ratio: 16 / 9;
  background: var(--surface);
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 13px;
  color: var(--slate-light);
  border: 1px solid var(--line);
  overflow: hidden;
}

.boost-woo-wrapper {
	padding: 0px;
}

.boost-woo-wrapper:first-of-type {
	margin-top: var(--nav-h);
}

.boost-woo-page-header h1 {
	font-size: var(--text-xl);
}


.boost-cart-icon-wrapper {
    color: #556270;
}

.btn.btn--wa {
 background: #25D366;
	color: white;
}

.btn.btn--wa:hover {
  background: #1da851;
  box-shadow: 0 4px 14px rgba(37, 211, 102, .3);
}

/* ============================================
   BOS SIERBETON — Parent Category Styles v4
   
   Mobile-first: standaard 2-col verticale cards.
   Desktop opschalen naar sidebar + 3-col.
   ============================================ */

/* --- Reset --- */
.bs-parent-header,
.bs-parent-header *,
.bs-parent-layout,
.bs-parent-layout *,
.bs-parent-grid,
.bs-parent-grid * {
  box-sizing: border-box !important;
  max-width: 100% !important;
}

/* --- Buttons --- */
.bs-btn { display: inline-flex !important; align-items: center !important; gap: 7px !important; font-family: 'DM Sans', system-ui, sans-serif !important; font-weight: 600 !important; font-size: 14px !important; border: none !important; cursor: pointer !important; border-radius: 8px !important; padding: 11px 22px !important; transition: all .2s !important; text-decoration: none !important; line-height: 1.4 !important; }
.bs-btn--primary { background: #0066FF !important; color: #fff !important; }
.bs-btn--primary:hover { background: #004EC2 !important; }
.bs-btn--outline { background: transparent !important; color: #0066FF !important; border: 1.5px solid #0066FF !important; }
.bs-btn--outline:hover { background: #0066FF !important; color: #fff !important; }
.bs-btn--wa { background: #25D366 !important; color: #fff !important; }
.bs-btn--wa:hover { background: #1fb855 !important; }
.bs-btn--sm { padding: 8px 16px !important; font-size: 13px !important; }

/* ============================================
   PAGE HEADER — default mobile
   ============================================ */
.bs-parent-header {
  background: #0D1B2A !important;
  padding: 28px 0 0 !important;
  position: relative !important;
  overflow: hidden !important;
  width: 100% !important;
}
.bs-parent-header::before {
  content: '' !important;
  position: absolute !important;
  top: -30% !important;
  right: 5% !important;
  width: 400px !important;
  height: 400px !important;
  background: radial-gradient(circle, rgba(0,102,255,.1) 0%, transparent 60%) !important;
  border-radius: 50% !important;
  pointer-events: none !important;
}
.bs-parent-header__inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 16px !important;
  position: relative !important;
  width: 100% !important;
}

/* Breadcrumb */
.bs-parent-breadcrumb {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 11px !important;
  color: rgba(255,255,255,.35) !important;
  margin-bottom: 12px !important;
  list-style: none !important;
  padding: 0 !important;
}
.bs-parent-breadcrumb a { color: rgba(255,255,255,.5) !important; text-decoration: none !important; }
.bs-parent-breadcrumb a:hover { color: #fff !important; }
.bs-parent-breadcrumb__sep { color: rgba(255,255,255,.2) !important; }

/* Header content — stacked on mobile */
.bs-parent-header__content {
  display: block !important;
  padding-bottom: 24px !important;
}
.bs-parent-header__title {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #fff !important;
  letter-spacing: -0.025em !important;
  line-height: 1.15 !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
}
.bs-parent-header__desc {
  font-size: 13px !important;
  color: rgba(255,255,255,.45) !important;
  line-height: 1.65 !important;
  margin: 0 0 16px 0 !important;
  padding: 0 !important;
}

/* Stats — full width mobile */
.bs-parent-header__stats {
  display: flex !important;
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  width: 100% !important;
}
.bs-parent-header__stat {
  flex: 1 !important;
  padding: 10px 8px !important;
  text-align: center !important;
  border-right: 1px solid rgba(255,255,255,.06) !important;
}
.bs-parent-header__stat:last-child { border-right: none !important; }
.bs-parent-header__stat-val {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  color: #fff !important;
  line-height: 1 !important;
}
.bs-parent-header__stat-val em { font-style: normal !important; color: #0066FF !important; }
.bs-parent-header__stat-label {
  font-size: 9px !important;
  font-weight: 600 !important;
  color: rgba(255,255,255,.3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  margin-top: 3px !important;
}

/* ============================================
   LAYOUT — default mobile: single column
   ============================================ */
.bs-parent-layout {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 16px 12px 32px !important;
  display: block !important;
  width: 100% !important;
}

/* Sidebar: hidden on mobile */
.bs-parent-sidebar { display: none !important; }

/* ============================================
   TOOLBAR
   ============================================ */
.bs-parent-toolbar {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 12px !important;
}
.bs-parent-toolbar__count { font-size: 13px !important; color: #8898A8 !important; }
.bs-parent-toolbar__count strong { color: #0D1B2A !important; font-weight: 600 !important; }

/* ============================================
   SUBCATEGORY GRID
   DEFAULT = 2 kolommen (mobile-first)
   ============================================ */
.bs-parent-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 8px !important;
  margin-bottom: 24px !important;
  width: 100% !important;
  padding: 0 !important;
  list-style: none !important;
}

/* ============================================
   CARD — verticaal: image boven, text onder
   ============================================ */
.bs-parent-card {
  display: block !important;
  background: #fff !important;
  border: 1px solid #E3E8EE !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  color: inherit !important;
  width: 100% !important;
  min-width: 0 !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  transition: all .2s !important;
}
.bs-parent-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,.06) !important;
  border-color: transparent !important;
  transform: translateY(-2px) !important;
}

.bs-parent-card__img {
  aspect-ratio: 1 / 1 !important;
  background: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  border-bottom: 1px solid #E3E8EE !important;
  overflow: hidden !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
.bs-parent-card__img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 8px !important;
  display: block !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  float: none !important;
}

.bs-parent-card__placeholder {
  width: 60px !important;
  height: 44px !important;
  border-radius: 6px !important;
  background: rgba(0,102,255,.06) !important;
  border: 1.5px dashed rgba(0,102,255,.15) !important;
  display: grid !important;
  place-items: center !important;
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  color: rgba(0,102,255,.25) !important;
}

.bs-parent-card__badge {
  position: absolute !important;
  top: 6px !important;
  left: 6px !important;
  color: #fff !important;
  font-size: 8px !important;
  font-weight: 700 !important;
  padding: 2px 5px !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  z-index: 2 !important;
  line-height: 1.4 !important;
}
.bs-parent-card__badge--popular { background: #0066FF !important; }
.bs-parent-card__badge--new { background: #059669 !important; }

.bs-parent-card__count-badge {
  position: absolute !important;
  top: 6px !important;
  right: 6px !important;
  background: rgba(255,255,255,.92) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  border: 1px solid #E3E8EE !important;
  border-radius: 6px !important;
  padding: 2px 6px !important;
  font-size: 8px !important;
  font-weight: 700 !important;
  color: #0D1B2A !important;
  font-family: 'Manrope', system-ui, sans-serif !important;
  z-index: 2 !important;
  line-height: 1.4 !important;
}

.bs-parent-card__body {
  padding: 8px 10px !important;
  width: 100% !important;
}
.bs-parent-card__name {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #0D1B2A !important;
  margin: 0 0 3px 0 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.3 !important;
  -webkit-line-clamp: 2 !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

/* Beschrijving: verborgen op mobile */
.bs-parent-card__desc { display: none !important; }

.bs-parent-card__footer {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 3px !important;
  padding-top: 6px !important;
  border-top: 1px solid #E3E8EE !important;
  margin: 0 !important;
}
.bs-parent-card__price {
  display: flex !important;
  align-items: baseline !important;
  gap: 3px !important;
  flex-wrap: wrap !important;
}
.bs-parent-card__price-from { font-size: 9px !important; color: #8898A8 !important; }
.bs-parent-card__price-now {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  color: #0066FF !important;
  line-height: 1 !important;
}
.bs-parent-card__price-now--muted { font-size: 11px !important; color: #556270 !important; font-weight: 600 !important; }
.bs-parent-card__price-vat { font-size: 8px !important; color: #8898A8 !important; }
.bs-parent-card__price .woocommerce-Price-amount {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  color: #0066FF !important;
}
.bs-parent-card__cta { font-size: 10px !important; font-weight: 600 !important; color: #0066FF !important; }

/* ============================================
   SEO CONTENT — default mobile
   ============================================ */
.bs-parent-seo {
  background: #fff !important;
  border: 1px solid #E3E8EE !important;
  border-radius: 10px !important;
  padding: 16px 14px !important;
  margin-bottom: 20px !important;
  width: 100% !important;
}
.bs-parent-seo h2 {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #0D1B2A !important;
  margin: 0 0 6px 0 !important;
}
.bs-parent-seo p {
  font-size: 13px !important;
  color: #556270 !important;
  line-height: 1.7 !important;
  margin: 0 0 10px 0 !important;
}
.bs-parent-seo p:last-child { margin-bottom: 0 !important; }
.bs-parent-seo p strong { color: #0D1B2A !important; font-weight: 600 !important; }
.bs-parent-seo__toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #0066FF !important;
  cursor: pointer !important;
  border: none !important;
  background: none !important;
  padding: 0 !important;
  font-family: 'DM Sans', system-ui, sans-serif !important;
  margin-top: 4px !important;
}
.bs-parent-seo__extra { display: none !important; margin-top: 14px !important; padding-top: 14px !important; border-top: 1px solid #E3E8EE !important; }
.bs-parent-seo__extra.active { display: block !important; }
.bs-parent-seo__columns { display: block !important; }

.bs-parent-usp-strip { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; margin-top: 12px !important; padding: 0 !important; }
.bs-parent-usp { display: inline-flex !important; align-items: center !important; gap: 4px !important; padding: 5px 10px !important; border-radius: 6px !important; background: #F0F5FF !important; font-size: 11px !important; font-weight: 600 !important; color: #004EC2 !important; }

/* ============================================
   CTA BANNER — default mobile
   ============================================ */
.bs-parent-cta-banner {
  background: #0D1B2A !important;
  border-radius: 10px !important;
  padding: 18px 14px !important;
  display: block !important;
  text-align: center !important;
  width: 100% !important;
}
.bs-parent-cta-banner__title {
  font-family: 'Manrope', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin: 0 0 4px 0 !important;
}
.bs-parent-cta-banner__desc { font-size: 12px !important; color: rgba(255,255,255,.4) !important; line-height: 1.5 !important; margin: 0 0 12px 0 !important; }
.bs-parent-cta-banner__actions { display: flex !important; flex-direction: column !important; gap: 6px !important; width: 100% !important; }
.bs-parent-cta-banner__actions .bs-btn { width: 100% !important; justify-content: center !important; }

/* ============================================
   SIDEBAR CARDS (voor desktop)
   ============================================ */
.bs-parent-sidebar__card { background: #fff !important; border: 1px solid #E3E8EE !important; border-radius: 10px !important; overflow: hidden !important; }
.bs-parent-sidebar__card-header { padding: 14px 18px !important; font-family: 'Manrope', system-ui, sans-serif !important; font-size: 13px !important; font-weight: 700 !important; color: #0D1B2A !important; border-bottom: 1px solid #E3E8EE !important; display: flex !important; justify-content: space-between !important; align-items: center !important; }
.bs-parent-sidebar__card-count { font-size: 10.5px !important; font-weight: 500 !important; color: #8898A8 !important; }
.bs-parent-sidebar__card-body { padding: 10px 14px !important; }
.bs-parent-sidebar__link { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 7px 6px !important; border-radius: 6px !important; font-size: 13px !important; font-weight: 500 !important; color: #556270 !important; text-decoration: none !important; transition: all .12s !important; }
.bs-parent-sidebar__link:hover { color: #0066FF !important; background: #F0F5FF !important; }
.bs-parent-sidebar__link--active { color: #0066FF !important; font-weight: 600 !important; background: #F0F5FF !important; }
.bs-parent-sidebar__link-badge { font-size: 10px !important; color: #C4CDD5 !important; background: #F7F8FA !important; padding: 1px 7px !important; border-radius: 10px !important; }
.bs-parent-sidebar__link--active .bs-parent-sidebar__link-badge { background: #EBF2FF !important; color: #0066FF !important; }
.bs-parent-sidebar__cta { background: #0D1B2A !important; border-radius: 10px !important; padding: 20px 18px !important; text-align: center !important; }
.bs-parent-sidebar__cta-title { font-family: 'Manrope', system-ui, sans-serif !important; font-size: 13.5px !important; font-weight: 700 !important; color: #fff !important; margin-bottom: 4px !important; }
.bs-parent-sidebar__cta-desc { font-size: 12px !important; color: rgba(255,255,255,.4) !important; margin-bottom: 14px !important; line-height: 1.5 !important; }
.bs-parent-sidebar__cta-btns { display: flex !important; flex-direction: column !important; gap: 6px !important; }
.bs-parent-sidebar__cta-btns .bs-btn { justify-content: center !important; width: 100% !important; font-size: 12.5px !important; padding: 9px 16px !important; }

/* ============================================
   DESKTOP — min-width: 769px
   Sidebar zichtbaar, 3-col grid, grotere cards
   ============================================ */
@media (min-width: 769px) {
  .bs-parent-header { padding: 36px 0 0 !important; }
  .bs-parent-header__inner { padding: 0 36px !important; }
  .bs-parent-header__content {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 40px !important;
    align-items: end !important;
    padding-bottom: 32px !important;
  }
  .bs-parent-header__title { font-size: clamp(1.6rem, 3vw, 2.2rem) !important; }
  .bs-parent-header__desc { font-size: 14.5px !important; max-width: 540px !important; margin-bottom: 0 !important; }
  .bs-parent-header__stats { width: auto !important; flex-shrink: 0 !important; }
  .bs-parent-header__stat { flex: 0 0 auto !important; padding: 14px 22px !important; }
  .bs-parent-header__stat-val { font-size: 20px !important; }
  .bs-parent-header__stat-label { font-size: 10px !important; }
  .bs-parent-breadcrumb { font-size: 12.5px !important; margin-bottom: 14px !important; }

  .bs-parent-layout {
    display: grid !important;
    grid-template-columns: 240px 1fr !important;
    gap: 24px !important;
    padding: 28px 36px 60px !important;
  }

  .bs-parent-sidebar {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    position: sticky !important;
    top: 28px !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .bs-parent-toolbar { margin-bottom: 18px !important; }

  .bs-parent-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
    margin-bottom: 32px !important;
  }

  .bs-parent-card__img {
    aspect-ratio: 4 / 3 !important;
  }
  .bs-parent-card__img img {
    padding: 16px !important;
    transition: transform .3s !important;
  }
  .bs-parent-card:hover .bs-parent-card__img img { transform: scale(1.04) !important; }

  .bs-parent-card__badge { top: 10px !important; left: 10px !important; font-size: 10px !important; padding: 3px 8px !important; }
  .bs-parent-card__count-badge { top: 10px !important; right: 10px !important; font-size: 10px !important; padding: 3px 9px !important; }

  .bs-parent-card__body { padding: 14px 16px !important; }
  .bs-parent-card__name { font-size: 14px !important; }
  .bs-parent-card__desc { display: -webkit-box !important; font-size: 12px !important; margin-bottom: 10px !important; }
  .bs-parent-card__footer {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0 !important;
    padding-top: 10px !important;
  }
  .bs-parent-card__price-from { font-size: 11px !important; }
  .bs-parent-card__price-now { font-size: 16px !important; }
  .bs-parent-card__price .woocommerce-Price-amount { font-size: 16px !important; }
  .bs-parent-card__price-vat { font-size: 10px !important; }
  .bs-parent-card__cta { font-size: 12px !important; gap: 4px !important; transition: gap .15s !important; }
  .bs-parent-card:hover .bs-parent-card__cta { gap: 7px !important; }

  .bs-parent-seo { padding: 28px 32px !important; margin-bottom: 28px !important; }
  .bs-parent-seo h2 { font-size: 18px !important; }
  .bs-parent-seo p { font-size: 14px !important; }
  .bs-parent-seo__columns { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 24px !important; }

  .bs-parent-usp-strip { gap: 10px !important; margin-top: 16px !important; }
  .bs-parent-usp { font-size: 12px !important; padding: 6px 12px !important; }

  .bs-parent-cta-banner {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 24px !important;
    align-items: center !important;
    padding: 28px 32px !important;
    border-radius: 12px !important;
    text-align: left !important;
  }
  .bs-parent-cta-banner__title { font-size: 17px !important; }
  .bs-parent-cta-banner__desc { font-size: 13px !important; margin-bottom: 0 !important; }
  .bs-parent-cta-banner__actions { flex-direction: row !important; flex-shrink: 0 !important; width: auto !important; }
  .bs-parent-cta-banner__actions .bs-btn { width: auto !important; }
}

/* ============================================
   TABLET — sidebar smaller, 2-col grid
   ============================================ */
@media (min-width: 769px) and (max-width: 1024px) {
  .bs-parent-layout { grid-template-columns: 200px 1fr !important; gap: 20px !important; padding-left: 24px !important; padding-right: 24px !important; }
  .bs-parent-header__inner { padding: 0 24px !important; }
  .bs-parent-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .bs-parent-seo__columns { grid-template-columns: 1fr !important; }
}

/* ============================================
   SMALL PHONE — extra compact
   ============================================ */
@media (max-width: 360px) {
  .bs-parent-grid { gap: 6px !important; }
  .bs-parent-card__name { font-size: 11px !important; }
  .bs-parent-card__price-now { font-size: 12px !important; }
  .bs-parent-card__price .woocommerce-Price-amount { font-size: 12px !important; }
  .bs-parent-card__price-vat { display: none !important; }
  .bs-parent-card__body { padding: 6px 8px !important; }
  .bs-parent-card__badge { font-size: 7px !important; padding: 2px 4px !important; }
  .bs-parent-card__count-badge { font-size: 7px !important; padding: 1px 5px !important; }
  .bs-parent-header__stat { padding: 8px 6px !important; }
  .bs-parent-header__stat-val { font-size: 15px !important; }
}