/* Container voor de xx*/
.footer-columns {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

/* standaard kolommen */
.footer-columns .column {
    flex: 1;                 /* allemaal gelijke breedte */
    min-width: 300px;
}

/* alléén de eerste kolom meer ruimte */
.footer-columns .column:first-child {
    flex: 3;                 /* bijvoorbeeld dubbel zoveel */
    min-width: 350px;
}

/* Container voor de usps homepage*/
.icon-box {
    display: flex;
    align-items: center;
    gap: 20px;
    max-width: 350px;  /* of verwijder max-width voor volledige breedte */
    margin: 0 auto 30px auto;
}

.icon-box i.fa-solid {
    font-size: 35px !important; /* dwing grootte af */
    color: #EF5B33;
}

.icon-box .icon-content {
    display: flex;
    flex-direction: column;
}

.icon-box .title {
    font-size: 1.6rem;  /* groter en beter leesbaar */
    margin: 0 0 8px 0;
}

.icon-box .text {
    font-size: 1.2rem;
    color: #555;
    margin: 0;
    line-height: 1.5;
}

.heading-balk {
    display: inline-flex;        /* inline-flex reageert beter op responsief */
    align-items: center;         /* verticale centrering van tekst */
    background-color: #21314B;
    padding: 4px 12px;
    border-radius: 4px;
    color: #fff;
    white-space: nowrap;         /* voorkomt tekstomslag */
    max-width: 100%;             /* voorkomt overschrijden container */
    box-sizing: border-box;      /* padding telt mee in breedte */
}

.page-footer {
    background-color: #21314B;  /* jouw gewenste kleur */
    color: #ffffff;             /* optioneel: standaard tekst wit */
}

.footer-producten ul li a {
    color: #ffffff !important;  /* wit, dwing af */
    text-decoration: none;
}

.footer-producten ul li a:hover {
    color: #f2c94c !important;  /* geel bij hover */
}

/* ===== Desktop styling montagepunten container ===== */
.step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background-color: #f8f9fa; /* lichte achtergrond voor stap */
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.step:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

.step-icon {
  flex-shrink: 0;
  color: #EF5B33; /* blauwe accentkleur */
  font-size: 2rem; /* standaard icoon grootte desktop */
}

.step-content .step-title {
  margin: 0 0 8px 0;
  font-size: 1.3rem;
  color: #222;
}

.step-content .step-text {
  margin: 0;
  font-size: 1rem;
  color: #555;
  line-height: 1.5;
}

.homepage-mp-banner {
    max-width: 85%;       /* iets kleiner dan de volledige breedte */
    height: auto;         /* behoud verhoudingen */
    border-radius: 25px;   /* kleine afronding */
    display: block;       /* voorkom inline spacing issues */
    margin: 0 auto;       /* centrum horizontaal */
}

/* Normale knopkleur */
.action.tocart.primary {
    background-color: #21314B;  /* normale achtergrondkleur */
    color: #ffffff;             /* tekstkleur wit */
    border: none;               /* verwijder standaard rand */
    padding: 10px 20px;         /* pas naar wens aan */
    border-radius: 4px;         /* lichte afronding */
    font-size: 1rem;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

/* Hover effect */
.action.tocart.primary:hover {
    background-color: #EF5B33;  /* hover kleur */
    color: #ffffff;             /* blijf wit */
}

.actions-secondary .action.tocompare,
.action.tocompare {
    display: none !important;
}

/* Overschrijf de huidige kleur van .panel.wrapper op desktop */
@media (min-width: 769px), print {
  .page-header .panel.wrapper {
    background-color: #21314B; /* vervang door je nieuwe kleur */
    border-bottom: 1px solid #e8e8e8; /* eventueel behouden of aanpassen */
  }
}

/* Standaardkleur shop now button (geldt voor alle schermen) */
a.pagebuilder-button-primary,
button.pagebuilder-button-primary,
div.pagebuilder-button-primary {
  background: #21314B;
  border-color: #21314B;
  color: #fff;
}

/* Hover/focus staat (alle schermen) */
a.pagebuilder-button-primary:hover,
button.pagebuilder-button-primary:hover,
div.pagebuilder-button-primary:hover,
a.pagebuilder-button-primary:focus,
button.pagebuilder-button-primary:focus,
div.pagebuilder-button-primary:focus {
  background: #EF5B33;
  border-color: #EF5B33;
  color: #fff;
}

/* Standaard knopstijl checkout mini cart button (desktop) */
.action.primary,
.action-primary,
.amshopby-button,
.am-filter-go {
  background-image: none;
  background: #21314B; /* Standaardkleur */
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-family: 'Open Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-weight: 600;
  padding: 7px 15px; /* Desktop padding */
  font-size: 1.4rem; /* Desktop font-size */
  box-sizing: border-box;
  vertical-align: middle;
  transition: background 0.3s, border 0.3s;
}

/* Hoverkleur */
.action.primary:hover,
.action-primary:hover,
.amshopby-button:hover,
.am-filter-go:hover {
  background: #EF5B33; /* Hoverkleur */
}


.footer-social {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
}

.footer-social a i {
  color: #ffffff !important;           /* wit op alle schermen */
  font-size: 2.5rem;                   /* desktop grootte */
  transition: color 0.3s ease;
}

.footer-social a:hover i {
  color: #EF5B33 !important;           /* hoverkleur overal */
}

.brand-list ul {
  list-style: none;
  padding: 0;
  margin: 0.5rem 0;
  display: block;       /* of gewoon weglaten */
}

.brand-list li {
  margin-bottom: 0.5rem; /* verticale ruimte tussen items */
}

.brand-list a {
  display: inline-block;
  padding: 0.35rem 0.6rem;
  background: #fff;
  border: 1px solid #e6e9ef;
  border-radius: 6px;
  color: var(--text);
  text-decoration: none;
  font-weight: 500;
}

.brand-list a:hover {
  color: #EF5B33;            /* oranje tekstkleur bij hover */
  border-color: #EF5B33;     /* oranje rand bij hover */
}

/* Bandenlabels tab conten */
.bandenlabel-info {
  max-width: 800px;
  margin: 2rem auto;
  font-family: Arial, sans-serif;
  line-height: 1.6;
}
.bandenlabel-info h2 {
  font-size: 1.8rem;
  color: #21314B;
  margin-bottom: 1rem;
}
.bandenlabel-info .criteria {
  list-style: none;
  padding: 0;
  margin: 1rem 0 2rem;
}
.bandenlabel-info .criteria li {
  margin-bottom: 0.5rem;
}
.bandenlabel-info .criteria i {
  color: #EF5B33;
  margin-right: 0.5rem;
}
.label-item {
  margin-bottom: 1.5rem;
  padding: 1rem;
  border-left: 4px solid #EF5B33;
  background: #f9f9f9;
  border-radius: 4px;
}
.label-item h3 {
  margin-top: 0;
  color: #21314B;
  font-size: 1.3rem;
}
.label-item i {
  color: #EF5B33;
  margin-right: 0.4rem;
}

.bandenlabel-tabs-img {
  width: 85%;
  height: auto;
}

.amfinder-extra-link {
    margin-top: 15px;
    text-align: left; /* linkerkant */
}

.amfinder-extra-link a {
    color: #EF5B33;
    text-decoration: underline;
    cursor: pointer;
    display: inline-block;
}

/* Product Attributes Styling */

/* Product Attributes Styling */

.product-attributes {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 10px 0;
}

.product-attributes-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: flex-start;
    min-height: 40px;
}

.product-attribute-item {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border: 2px solid;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    white-space: nowrap;
}

.product-attribute-item .attribute-icon {
    margin-right: 6px;
    font-size: 14px;
}

.product-attribute-item .attribute-icon i {
    font-size: 14px;
}

.product-attribute-item .attribute-value {
    font-weight: 600;
}

/* Energielabels - A to F with specific colors */
.product-attribute-item.energielabel.a {
    background-color: #016531;
    border-color: #016531;
    color: #ffffff;
}

.product-attribute-item.energielabel.b {
    background-color: #40a72c;
    border-color: #40a72c;
    color: #ffffff;
}

.product-attribute-item.energielabel.c {
    background-color: #9ac10f;
    border-color: #9ac10f;
    color: #ffffff;
}

.product-attribute-item.energielabel.d {
    background-color: #feed02;
    border-color: #feed02;
    color: #000000; /* Changed to black for better contrast on yellow */
}

.product-attribute-item.energielabel.e {
    background-color: #f19500;
    border-color: #f19500;
    color: #ffffff;
}

.product-attribute-item.energielabel.f {
    background-color: #e8501d;
    border-color: #e8501d;
    color: #ffffff;
}

/* Grip op glad wegdek */
.product-attribute-item.grip-op-glad-wegdek {
    background-color: #4ba6dd;
    border-color: #4ba6dd;
    color: #ffffff;
}

/* Externe rolgeluid auto db */
.product-attribute-item.externe-rolgeluid-auto-db {
    background-color: #000000;
    border-color: #000000;
    color: #ffffff;
    max-width: 2.25cm;
    padding: 4px 8px;
    width: auto;
}

/* Voertuigtype - uses SVG icon */
.product-attribute-item.voertuigtype {
    background-color: #f8f9fa;
    border-color: #cccccc;
    color: #333333;
    text-transform: none; /* Don't uppercase the voertuigtype */
}

.product-attribute-item.voertuigtype .attribute-icon {
    width: 16px;
    height: 16px;
    margin-right: 6px;
}

/* Extra informatie */
.product-attribute-item.extra-informatie {
    background-color: #f8f9fa;
    border-color: #cccccc;
    color: #333333;
    text-transform: none; /* Don't uppercase the extra info */
    align-self: flex-start;
}

/* Second row - stack vertically */
.product-attributes-row.second-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
}

/* Voertuigtype container */
.voertuigtype-container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-left: 0;
}

.voertuigtype-container h4 {
    margin: 0 0 8px 0;
    font-size: 14px;
    font-weight: bold;
    color: #333;
    line-height: 1.2;
}

/* Extra informatie container */
.extra-info-container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-left: 0;
}

.extra-info-container h4 {
    margin: 0 0 8px 0;
    font-size: 14px;
    font-weight: bold;
    color: #333;
    line-height: 1.2;
}

/* Default styling for other attributes */
.product-attribute-item:not(.energielabel):not(.grip-op-glad-wegdek):not(.externe-rolgeluid-auto-db):not(.voertuigtype):not(.extra-informatie) {
    background-color: #f8f9fa;
    border-color: #cccccc;
    color: #333333;
}

/* Quantity Field Styling */
.product-item-actions .field.qty {
    display: inline-block;
    margin-right: 10px;
    vertical-align: middle;
}

.product-item-actions .field.qty .label {
    display: inline-block;
    margin-right: 5px;
    font-size: 12px;
    font-weight: 500;
    color: #666;
    vertical-align: middle;
}

.product-item-actions .field.qty .control {
    display: inline-block;
    vertical-align: middle;
}

.product-item-actions .select.qty {
    width: 60px;
    padding: 5px;
    border: 1px solid #ccc;
    border-radius: 3px;
    font-size: 14px;
    background-color: #fff;
}

.product-item-actions .select.qty:focus {
    border-color: #21314B;
    outline: none;
    box-shadow: 0 0 3px rgba(33, 49, 75, 0.3);
}

.mega-menu-columns {
    display: flex;
    gap: 2rem;
}

.mega-menu-column {
    flex: 1;
}

.mega-menu-column ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mega-menu-column ul li {
    margin-bottom: 0.5rem;
}

.button.btn-cta {
    display: inline-block;
    padding: 0.6rem 1.2rem;
    background-color: #21314B;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    margin-top: 1rem;
}

.mega-menu-columns.three-columns {
  display: flex;
  gap: 2rem; /* ruimte tussen kolommen */
  padding: 1rem 2rem;
}

/* Menu and homepage brand list */
.brand-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px; /* verticale en horizontale spacing */
  list-style: none;
  margin: 0 0 20px 0; /* ruimte tussen rijen */
  padding: 0;
}

.brand-list li {
  flex: 1 1 auto;
  padding: 0 10px; /* horizontale padding */
  box-sizing: border-box; /* zorgt dat padding binnen de flex-breedte blijft */
}

.brand-list a {
  display: block;
  text-align: center;
  padding: 8px 12px; /* meer ruimte rond de tekst */
  color: #333;
  text-decoration: none;
  border: 1px solid #eee; /* optioneel voor visueel blokje */
  border-radius: 4px;     /* afgeronde hoeken */
  background: #f9f9f9;    /* lichte achtergrond voor blokjes */
}

/* Container voor product cards */
.product-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* De card zelf */
.product-card {
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  overflow: hidden;
  transition: box-shadow 0.3s ease, transform 0.2s ease;
}

.product-card:hover {
  box-shadow: 0 4px 15px rgba(0,0,0,0.1);
  transform: translateY(-3px);
}

/* Link vult hele card */
.product-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

/* Afbeelding boven */
.product-media {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 12px;
  background: #fafafa;
}

.product-media img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  transition: transform 0.3s ease;
}

.product-card:hover img {
  transform: scale(1.05);
}

/* Info onder de afbeelding */
.product-info {
  padding: 12px 16px;
  text-align: center;
}

.product-name {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
  margin: 0;
  color: #333;
}

/* USPS product page */
.features {
  --card-border: #e6e8ec;
  --card-bg: #fff;
  --text: #0f172a;
  --muted: #475569;
  --accent: #16a34a; /* groen */
}

.features-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 20px 22px;
  max-width: 520px;
  width: 100%;              /* vult altijd de container */
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
  color: var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}

.features-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px; /* afstand tussen regels */
}

.features-item {
  display: flex;
  align-items: flex-start; /* icon mooi uitlijnen met multi-line tekst */
  gap: 10px;
  line-height: 1.45;
  color: var(--muted);
}

.features-item i {
  color: var(--accent);
  font-size: 18px;
  margin-top: 2px; /* optisch centreren t.o.v. de tekst */
  flex: 0 0 auto;
}

/* optioneel: subtiele hover voor interactieve feel */
.features-item:hover {
  color: var(--text);
}

.custom-block-below-addtocart > * + * {
  margin-top: 16px; /* pas waarde aan naar wens, bv. 8px of 24px */
}

.amsearch-button.-clear.-compare.-icon {
    display: none !important;
}

.amlocator-block.-filter {
    display: none !important;
}

    .feature {
        display: flex;
        align-items: center;
        color: white; /* maakt zowel tekst als icon wit */
        font-size: 1.2em;
    }

    .feature i {
        margin-right: 10px; /* ruimte tussen vinkje en tekst */
    }

.blue-bar-header {
    color: white; /* tekst wordt wit */
}
