/* Last-loaded custom overrides. Add new CSS here when it must override other theme styles. */

.step-item.inactive {
  border: 1px solid #D4E9FF6B;
}

.steps-nav {
  gap: 0;
}

button.step-item {
  border-radius: 0;
}

.section-header.section-header--full {
  border-radius: 0;
  height: 45px;
  padding: 0 20px;
}

.config-left .section-header {
  height: 37px;
  border-radius: 4px;
  padding: 4.5px 0 7.5px 10px;
  max-height: 31px;
}

.config-wrapper .cards-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}

label.card-option.card-option--imposte {
  width: 100%;
}

@media (max-width: 1200px) {
  .config-wrapper .cards-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .config-wrapper .cards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .config-wrapper .cards-grid {
    grid-template-columns: repeat(var(--gamme-mobile-columns, 2), minmax(0, 1fr));
  }
}

label.card-option.card-option--opening {
  width: 100%;
}

label.card-option.card-option--window-type {
  width: 100%;
}

.cards-grid--dynamic .card-option--gamme {
  width: 100%;
  padding: 0 9px 0px;
}

.config-wrapper .section-subheader {
  width: unset;
}


/* Configurator dimensions - Figma 702:12858 */
[data-config-section="dimensions"] .config-section--figma-dimensions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
  width: 100%;
}

[data-config-section="dimensions"] .section-header.section-header--full {
  align-items: center;
  box-sizing: border-box;
  background: #124170;
  border-radius: 0;
  color: #ffffff;
  display: flex;
  font-family: Poppins, sans-serif;
  font-size: 12px;
  font-weight: 600;
  height: 30px;
  letter-spacing: 0;
  line-height: 20px;
  padding: 5px 10px;
  text-transform: uppercase;
  width: 100%;
}

[data-config-section="dimensions"] .section-label {
  color: #333;
  font-family: Poppins, sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px;
  margin: 0 0 2px;
}

[data-config-section="dimensions"] .dimensions-grid--figma {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
}

[data-config-section="dimensions"] .dimension-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  text-align: left;
}

[data-config-section="dimensions"] .dimension-field label {
  color: #222222;
  display: block;
  font-family: Poppins, sans-serif;
  font-size: 9px;
  font-weight: 400;
  line-height: 12px;
  margin: 0;
}

[data-config-section="dimensions"] .dimension-label-unit {
  color: #222;
  font-family: Poppins, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 400;
  line-height: 18.571px;
}

[data-config-section="dimensions"] .dimension-input-wrap {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  background: #ffffff;
  border: 1px solid #bdbdbd;
  border-radius: 0;
  height: 40px;
  overflow: hidden;
  width: 100%;
}

[data-config-section="dimensions"] .dimension-input-wrap .dim-value {
  background: transparent;
  box-sizing: border-box;
  border: 0;
  border-radius: 0;
  color: #222;
  flex: 1 1 auto;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  height: 100%;
  line-height: 19.2px;
  min-width: 0;
  overflow: hidden;
  padding: 6px 8px;
  text-align: left;
  text-overflow: ellipsis;
  width: auto;
}

[data-config-section="dimensions"] .dimension-input-wrap .dim-value:focus {
  box-shadow: none;
  outline: 1px solid #91ae3b;
  outline-offset: -1px;
}

[data-config-section="dimensions"] .dimension-input-wrap .dim-value::placeholder {
  color: #222222;
  opacity: 1;
}

[data-config-section="dimensions"] .dimension-input-max {
  color: #222;
  flex: 0 0 auto;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 19.2px;
  overflow: hidden;
  padding: 0 8px;
  pointer-events: none;
  text-overflow: ellipsis;
}

[data-config-section="dimensions"] .dimension-limit-hint {
  display: none;
}

[data-config-section="dimensions"] .dimension-field-error {
  color: #b42318;
  font-family: Poppins, sans-serif;
  font-size: 9px;
  font-weight: 500;
  line-height: 12px;
  margin: 2px 0 0;
}

[data-config-section="dimensions"] .dimension-field.has-error .dimension-input-wrap {
  border-color: #d92d20;
}

[data-config-section="dimensions"] .dimension-field.has-error .dim-value {
  box-shadow: none;
}

@media (max-width: 600px) {
  [data-config-section="dimensions"] .dimensions-grid--figma {
    grid-template-columns: 1fr;
  }
}

/* Configurator gamme grid */
.config-wrapper .cards-grid--range.gamme {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
}

.config-wrapper .cards-grid--range.gamme .card-option--gamme {
  width: 100%;
}

@media (max-width: 900px) {
  .config-wrapper .cards-grid--range.gamme {
    grid-template-columns: repeat(var(--gamme-tablet-columns, 3), minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .config-wrapper .cards-grid--range.gamme {
    grid-template-columns: repeat(var(--gamme-mobile-columns, 2), minmax(0, 1fr));
  }
}

.cards-grid--dynamic .card-option--profile {
  padding: 0 14px 0px;
}

[data-config-section="dimensions"] .dimension-label-text {
  color: #222;
  font-family: Poppins, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 600;
  line-height: 18.571px;
}

.glazing-card {
  width: unset;
}

.glazing-card-row--families,
.glazing-card-row--options {
  display: grid;
  grid-template-columns: repeat(5, 4fr);
}

.cards-grid--dynamic .card-option--handle {
  width: 100%;
}

.cards-grid--dynamic .card-option--range,
.cards-grid--dynamic .card-option--gamme,
.cards-grid--dynamic .card-option--window-type,
.cards-grid--dynamic .card-option--special-shape,
.cards-grid--dynamic .card-option--opening,
.cards-grid--dynamic .card-option--imposte,
.cards-grid--dynamic .card-option--glazing,
.cards-grid--dynamic .card-option--spacer,
.cards-grid--dynamic .card-option--ventilation,
.cards-grid--dynamic .card-option--handle,
.cards-grid--dynamic .card-option--accessory {
  width: 100%;
}

.card-option .card-visual {
  padding: 0;
}

.card-option .card-visual img {
  object-fit: contain;
}

.volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rs,
.volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rn,
.volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--ra {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.sliding-profile-card {
  width: 100%;
}

.color-material-band {
  width: unset;
}

[data-config-section="dimensions"] label.dimension-field .dimension-label {
  display: block;
  margin: 0;
}

[data-config-section="dimensions"] .dimension-input-wrap small {
  color: #222;
  flex: 0 0 auto;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 19.2px;
  padding: 0 8px 0 0;
}

[data-config-section="dimensions"] .config-info-message--dimensions {
  color: #777777;
  font-family: Poppins, sans-serif;
  font-size: 11px;
  font-weight: 400;
  line-height: 16px;
  margin: 0;
}

/* Sliding bay dimensions - Figma */
.config-section--sliding-bay-dimensions.config-section--figma-dimensions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
  width: 100%;
}

.config-section--sliding-bay-dimensions .section-header.section-header--full {
  align-items: center;
  background: #124170;
  border-radius: 0;
  box-sizing: border-box;
  color: #ffffff;
  display: flex;
  font-family: Poppins, sans-serif;
  font-size: 12px;
  font-weight: 600;
  height: 30px;
  letter-spacing: 0;
  line-height: 20px;
  padding: 5px 10px;
  text-transform: uppercase;
  width: 100%;
}

.config-section--sliding-bay-dimensions .section-label {
  color: #333;
  font-family: Poppins, sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px;
  margin: 0 0 2px;
}

.config-section--sliding-bay-dimensions .dimensions-grid--figma {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
}

.config-section--sliding-bay-dimensions .dimension-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  text-align: left;
}

.config-section--sliding-bay-dimensions label.dimension-field .dimension-label {
  display: block;
  margin: 0;
}

.config-section--sliding-bay-dimensions .dimension-label-text {
  color: #222;
  font-family: Poppins, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 600;
  line-height: 18.571px;
}

.config-section--sliding-bay-dimensions .dimension-label-unit {
  color: #222;
  font-family: Poppins, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 400;
  line-height: 18.571px;
}

.config-section--sliding-bay-dimensions .dimension-input-wrap {
  align-items: center;
  background: #ffffff;
  border: 1px solid #bdbdbd;
  border-radius: 0;
  box-sizing: border-box;
  display: flex;
  height: 40px;
  overflow: hidden;
  width: 100%;
}

.config-section--sliding-bay-dimensions .dimension-input-wrap .dim-value {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-sizing: border-box;
  color: #222;
  flex: 1 1 auto;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  height: 100%;
  line-height: 19.2px;
  min-width: 0;
  overflow: hidden;
  padding: 6px 8px;
  text-align: left;
  text-overflow: ellipsis;
  width: auto;
}

.config-section--sliding-bay-dimensions .dimension-input-max,
.config-section--sliding-bay-dimensions .dimension-input-wrap small {
  color: #222;
  flex: 0 0 auto;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 19.2px;
  overflow: hidden;
  padding: 0 8px;
  pointer-events: none;
  text-overflow: ellipsis;
}

.config-section--sliding-bay-dimensions .config-info-message--dimensions {
  color: #777777;
  font-family: Poppins, sans-serif;
  font-size: 11px;
  font-weight: 400;
  line-height: 16px;
  margin: 0;
}

@media (max-width: 600px) {
  .config-section--sliding-bay-dimensions .dimensions-grid--figma {
    grid-template-columns: 1fr;
  }
}

.config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material.cards-grid--sliding-bay-material {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}

.config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}

.cards-grid--sliding-bay-step2 {
  overflow-x: unset;
}

.crossbar-preview-frame--sliding-bay {
  width: 100%;
}

.cards-grid.cards-grid--dynamic.cards-grid--profile.cards-grid--door-models {
  grid-template-columns: repeat(5, 1fr) !important;
}

.color-palette-grid {
  gap: 5px 5px;
}

.color-palette-option--image-only {
  margin: 0;
}

.crossbar-repartition {
  margin-bottom: 28px;
}

.cards-grid.cards-grid--dynamic.cards-grid--profile {
  grid-template-columns: repeat(3, 1fr) !important;
}

.color-palette-grid.color-palette-grid--aluminium.color-palette-grid--aluminium-bands {
  gap: unset;
}

.config-section--sliding-bay-material .card-option--material {
  width: 100%;
}

.garage-dimension-field input {
  width: unset;
}


/* Responsive audit fixes - 2026-06-21 */
html,
body {
  max-width: 100%;
  overflow-x: clip;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

#header,
header,
main,
#wrapper,
.container,
.config-page-header,
.config-wrapper,
.config-left,
.config-right,
.config-step-panel,
.config-section,
.section-header.section-header--full {
  max-width: 100%;
}

.section-header.section-header--full {
  width: 100%;
}

.config-page-header {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.config-page-header h1,
.config-page-header p {
  max-width: 100%;
  overflow-wrap: anywhere;
}

.blockcart.cart-preview.active,
header .middle #_desktop_cart,
#_desktop_cart {
  max-width: 100%;
  position: relative;
}

header .middle #_desktop_cart .cart-products-count,
#_desktop_cart .cart-products-count,
.cart-products-count {
  right: 0 !important;
  left: auto !important;
  max-width: 24px;
  transform: none !important;
}

.config-wrapper {
  box-sizing: border-box;
  overflow-x: hidden;
  width: 100%;
}

.config-wrapper .cards-grid,
.cards-grid,
.glazing-card-row--families,
.glazing-card-row--options,
.nf-accessoires-card-row,
.volet-type-grid,
.color-palette-grid {
  min-width: 0;
  max-width: 100%;
}

.config-wrapper .cards-grid > *,
.cards-grid > *,
.glazing-card-row--families > *,
.glazing-card-row--options > *,
.nf-accessoires-card-row > *,
.volet-type-grid > *,
.color-palette-grid > * {
  min-width: 0;
}

.card-option,
.nf-accessoires-card,
.nf-accessoires-family-card,
.glazing-card,
.sliding-profile-card,
.volet-type-card {
  max-width: 100%;
  min-width: 0;
}

.card-title,
.card-label,
.card-desc,
.card-meta,
.card-price,
.nf-accessoires-card strong,
.nf-accessoires-card span,
.nf-accessoires-family-card strong,
.nf-accessoires-family-card span {
  overflow-wrap: anywhere;
  word-break: normal;
}

.card-option .card-visual,
.card-option .card-visual img,
.nf-accessoires-card__image,
.nf-accessoires-family-card__image,
.glazing-card img {
  max-width: 100%;
}

.steps-nav {
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: thin;
}

.step-item {
  min-width: 0;
  white-space: nowrap;
}

@media (max-width: 1366px) {
  .config-page-header {
    padding-left: 20px;
    padding-right: 20px;
  }
}

@media (max-width: 1024px) {
  .config-wrapper {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding-left: 20px;
    padding-right: 20px;
  }

  .config-left,
  .config-right {
    width: 100% !important;
    max-width: 100% !important;
  }

  .config-wrapper .cards-grid,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material.cards-grid--sliding-bay-material,
  .cards-grid.cards-grid--dynamic.cards-grid--profile,
  .cards-grid.cards-grid--dynamic.cards-grid--profile.cards-grid--door-models,
  .glazing-card-row--families,
  .glazing-card-row--options {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .config-wrapper .cards-grid--range.gamme,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rs,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rn,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--ra {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .nf-accessoires-card-row {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 768px) {
  body {
    min-width: 0;
  }

  header .bottom,
  header .bottom .container,
  header ul.bottom,
  header ul.bottom.has-active,
  .header-nav,
  .menu,
  .top-menu,
  #top-menu {
    max-width: 100%;
  }

  header ul.bottom,
  header ul.bottom.has-active,
  .top-menu,
  #top-menu {
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
  }

  header ul.bottom li,
  header ul.bottom li.parent,
  .top-menu li,
  #top-menu li {
    flex: 0 0 auto;
  }

  .config-page-header {
    padding-left: 16px;
    padding-right: 16px;
  }

  .config-wrapper {
    padding-left: 16px;
    padding-right: 16px;
  }

  .steps-nav {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    overflow-x: hidden;
  }

  .step-item {
    width: 100%;
    min-height: 40px;
    padding-left: 8px;
    padding-right: 8px;
    white-space: normal;
  }

  .config-wrapper .cards-grid,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material.cards-grid--sliding-bay-material,
  .cards-grid.cards-grid--dynamic.cards-grid--profile,
  .cards-grid.cards-grid--dynamic.cards-grid--profile.cards-grid--door-models,
  .glazing-card-row--families,
  .glazing-card-row--options,
  .config-wrapper .cards-grid--range.gamme,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rs,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rn,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--ra {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .nf-accessoires-card-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px;
  }

  a,
  button,
  input,
  select,
  textarea,
  label.card-option,
  .wishlistIcon,
  #ToggleMenu {
    min-height: 32px;
  }
}

@media (max-width: 430px) {
  .config-page-header,
  .config-wrapper {
    padding-left: 10px;
    padding-right: 10px;
  }

  .config-page-header h1 {
    font-size: clamp(22px, 7vw, 32px);
    line-height: 1.15;
  }

  .config-page-header p {
    font-size: 14px;
    line-height: 1.4;
  }

  .steps-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .step-item {
    font-size: 12px;
    line-height: 16px;
  }

  .config-wrapper .cards-grid,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material,
  .config-wrapper .cards-grid.cards-grid--dynamic.cards-grid--material.cards-grid--sliding-bay-material,
  .cards-grid.cards-grid--dynamic.cards-grid--profile,
  .cards-grid.cards-grid--dynamic.cards-grid--profile.cards-grid--door-models,
  .glazing-card-row--families,
  .glazing-card-row--options,
  .config-wrapper .cards-grid--range.gamme,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rs,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--monobloc-rn,
  .volet-type-grid.volet-type-grid--type-volet-roulant.volet-type-grid--ra,
  .nf-accessoires-card-row {
    grid-template-columns: 1fr !important;
  }

  .card-option,
  .nf-accessoires-card,
  .nf-accessoires-family-card,
  .glazing-card {
    width: 100% !important;
  }

  .section-header.section-header--full,
  .config-left .section-header {
    min-width: 0;
  }

  header .middle #_desktop_cart .cart-products-count,
  #_desktop_cart .cart-products-count,
  .cart-products-count {
    right: 0 !important;
  }
}

@media (max-width: 320px) {
  .config-page-header,
  .config-wrapper {
    padding-left: 8px;
    padding-right: 8px;
  }

  .steps-nav {
    grid-template-columns: 1fr;
  }
}

/* Desktop configurator layout correction */
@media (min-width: 1025px) {
  .config-page-header,
  .config-wrapper {
    max-width: 1340px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
  }

  .config-wrapper {
    max-width: 1340px;
    overflow: visible;
    overflow-x: visible;
    overflow-y: visible;
  }

  .config-left {
    width: 40%;
    min-width: 380px;
    position: sticky;
    top: var(--cfg-sticky-offset);
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    height: calc(100vh - var(--cfg-sticky-offset) - 8px);
    max-height: calc(100vh - var(--cfg-sticky-offset) - 8px);
    min-height: 0;
    overflow: hidden;
  }
}

@media (max-width: 768px) {
  .cards-grid--dynamic .card-option--gamme {
    width: 100% !important;
  }
}
