.crs-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:block;opacity:0;pointer-events:none;transition:.2s}
.crs-open .crs-modal{opacity:1;pointer-events:auto}
.crs-modal[aria-hidden="false"]{opacity:1;pointer-events:auto;z-index: 9999;}
.crs-modal__dialog{background:#fff;max-width:920px;margin:5vh auto;padding:20px;border-radius:12px;position:relative}
.crs-modal__close{position:absolute;right:12px;top:10px;border:0;background:transparent;font-size:24px}
.crs-grid{display:grid;grid-template-columns:260px 1fr;gap:20px}
.crs-aside{border-right:1px solid #eee}
.crs-summary-block{font-size:13px;padding: 0 10px 0 0;}
.crs-total{font-size:15px}
.crs-steps{display:flex;gap:8px;list-style:none;padding:0;margin:0 0 10px}
.crs-steps li{background:#f6f6f6;border-radius:999px;padding:6px 10px;font-size:12px}
.crs-steps li.active{background:#111;color:#fff}
.crs-string-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding-top: 35px;}
.crs-card{border:1px solid #eee;border-radius:10px;padding:10px;cursor:pointer;transition:.15s}
.crs-card:hover{box-shadow:0 4px 18px rgba(0,0,0,.06)}
.crs-card__img{text-align:center;height:120px;display:flex;align-items:center;justify-content:center}
.crs-card__img img{max-height:110px;width:auto}
.crs-card__title{font-weight:600;font-size:11px;margin:0px 0}
.crs-card__price{font-weight:600}
.crs-card__badge{display:inline-block;background:#111;color:#fff;font-size:11px;border-radius:6px;padding:2px 6px;margin-top:6px}
.hidden{display:none}
.crs-gauge{margin-top:8px}
.crs-gauge-btn{margin:4px 4px 0 0;padding:6px 10px;border:1px solid #ddd;border-radius:999px;background:#fafafa;cursor:pointer}
.crs-gauge-btn.active,.crs-gauge-btn:focus{outline:0;border-color:#111;background:#111;color:#fff}
.crs-tensions{display:grid;grid-template-columns: 1fr 1fr; gap:12px;max-width:460px}
.crs-actions{margin-top:14px;display:flex;gap:10px}
.crs-string-block {
    height: 490px;
    overflow: scroll;
}

span#sum-crosses {
    font-size: 11px !important;
}

span#sum-mains {
    font-size: 11px !important;
}

span#sum-tensions {
    font-size: 11px !important;
}

span#sum-options {
    font-size: 11px !important;
}

.crs-total #sum-extra {
    background-color: #00a6e9;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    color: #FFF;
    margin-left: 5px;
    font-weight: 600;
}

.crs-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem !important;
}

.crs-summary-block div {
    margin: 5px 0;
}

.crs-string-block h5 {
    font-size: 14px !important;
    color: #000000 !important;
    font-weight: 600;
    position: fixed;
    z-index: 99;
    background-color: #FFFFFF;
    width: 40%;
    padding-bottom: 1rem;
}

aside.crs-aside h4 {
    font-size: 16px;
    font-weight: 600;
    color: #000;
    text-transform: uppercase;
}

button.crs-card__choose {
    display: none;
}

.crs-pill{display:flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:10px 14px;margin:8px 0}
.crs-pill--primary{background:#111;color:#fff;font-weight:600;border:0;cursor:pointer;width:100%;text-align:left}
.crs-pill--summary{background:#111;color:#fff}
.crs-pill .crs-edit{background:transparent;border:0;color:#fff;cursor:pointer;font-size:16px;line-height:1}
.crs-sep{opacity:.6;margin:0 6px}

.crs-card {
  position: relative;
  border: 1px solid #e6e6e6;
  border-radius: 10px;
  padding: 10px;
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: box-shadow .2s ease, border-color .2s ease;
  cursor: pointer;
}
.crs-card.active {
    box-shadow: 0 6px 18px rgba(0, 0, 0, .08);
    border: 2px solid #000000;
}
.crs-card__img { height: 120px; display: flex; place-items: center; }
.crs-card__img img { max-height: 100%; max-width: 100%; object-fit: contain; }
.crs-card__title { font-weight: 600; min-height: 38px; }
.crs-card__price { font-weight: 700; }
.crs-card__gauge { width: 91%;position:absolute; top:8px; left:8px; background:#fff; padding:6px 8px; border:1px solid #e1e1e1; border-radius:8px; box-shadow:0 4px 12px rgba(0,0,0,.06); }
.crs-gauge-label { display:block; font-size:12px; margin-bottom:4px; color:#555; }
.crs-gauge-select {
      min-width: 100%;
      font-size: 11px;
      border-radius: 20px;
      padding: 2px 5px;
}
.crs-card.active label.crs-gauge-label {
    margin: 0;
    font-size: 12px;
    color: #000000 !important;
    font-weight: 600;
    display: none;
}
.crs-card__choose { align-self: flex-end; }

div#crs-summary {
    font-size: 10px;
}
/* Ligne quantité / ATC */
.product-quantity .d-flex{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
}

/* Le bloc CRS en pleine largeur au-dessus */
#crs-inline{
  order:-1;
  flex:0 0 100%;
  margin:0;
}
/* Quantité à gauche (largeur fixe) */
.product-quantity .qty{ flex:0 0 6.5rem; }
/* ATC prend tout l’espace restant */
.product-quantity .add{ flex:1 1 auto; }
.product-quantity .add .add-to-cart{ width:100%; }

.crs-options--grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px
}
@media(max-width:992px){.crs-options--grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:576px){.crs-options--grid{grid-template-columns:1fr}}

.crs-opt-group{background:#fff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.06);padding:12px}
.crs-opt-title {
    background: #efefef;
    color: #000;
    font-weight: 700;
    border-radius: 8px;
    padding: 8px 10px;
    text-align: center;
    margin-bottom: 10px;
    /* border: 1px solid; */
    font-size: 12px;
}
.crs-opt-choices{display:flex;gap:8px;justify-content:space-between}
.crs-chip{flex:1;position:relative}
.crs-chip input{position:absolute;inset:0;opacity:0;cursor:pointer}
.crs-chip span {
    display: block;
    text-align: center;
    border-radius: 8px;
    padding: 4px 8px;
    border: 1px solid #e5e7eb;
    background: #f3f4f6;
    font-weight: 600;
    font-size: 12px;
}.crs-chip input:checked + span{background: #00A6E9;color: #FFF;}
.crs-opt-help{
    font-size: 12px;
    line-height: inherit;
    margin: 8px 0 0;
    color: #000;
}

.crs-modal button#step1-next {
    padding: 8px 20px;
    font-size: 14px;
}

.crs-modal button#step1-next,.crs-modal button#stepCross-next, .crs-modal button#step2-next {
    background: #373f50;
    border: none;
    padding: 8px 20px;
    font-size: 14px;
    line-height: inherit;
}

.crs-modal button.btn {
    max-height: 37px;
    line-height: normal;
    font-size: 14px;
}

.crs-modal button#stepCross-prev, .crs-modal button#step2-prev, .crs-modal button#step3-prev {
    border: 1px solid #000;
    color: #000;
}

.crs-modal button#crs-validate {
    background-color: #00A6E9;
    font-weight: 600;
}

/* Cache l'input natif */
.crs-checkbox-wrapper input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

/* Conteneur visuel */
.crs-checkbox-wrapper {
  position: relative;
  padding-left: 28px; /* espace pour la fausse coche */
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  margin: 0 !important;
  color: #000 !important;
  font-size: 13px;
}

/* Carré custom */
.crs-checkbox-wrapper .crs-checkbox {
  position: absolute;
  left: 0;
  width: 18px;
  height: 18px;
  border: 2px solid #444;
  border-radius: 4px; /* arrondi, optionnel */
  background: #fff;
  transition: all 0.2s ease;
}

/* Style quand cochée */
.crs-checkbox-wrapper input[type="checkbox"]:checked + .crs-checkbox {
  background: #00a6e9;
  border-color: #00a6e9;
}

/* Petit checkmark */
.crs-checkbox-wrapper input[type="checkbox"]:checked + .crs-checkbox::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 0px;
  width: 6px;
  height: 12px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.personnalisation-info {
    display: block;
    width: 100%;
    text-align: center;
    margin-top: 20px;
}

.crs-auto-tension {
    padding: 5px 1rem;
    background-color: #fbfbfb;
    border-radius: 13px;
    width: fit-content;
}

.crs-toggle-crosses {
    padding: 5px 1rem;
    background-color: #fbfbfb;
    border-radius: 13px;
    width: fit-content;
    margin-bottom: 10px;
}

.personnalisation-info span {
    font-size: 12px;
    font-weight: 600;
}

/* Résumé inline CRS */
.crs-pill--summary{
  display:flex;
  align-items:center;
  gap:.5rem;
  white-space:nowrap;
  max-width:100%;
}
.crs-pill--summary .crs-inline-clip{
  flex:1 1 auto;
  min-width:0;              /* clé pour text-overflow en flex */
  overflow:hidden;
  text-overflow:ellipsis;   /* affiche … */
  white-space:nowrap;
}
.crs-pill--summary .crs-sep{ opacity:.5; }
.crs-pill--summary .crs-inline-price{ font-weight:600; }
.crs-pill--summary .crs-edit{
  margin-left:.25rem;
  background:transparent;
  border:0;
  cursor:pointer;
  line-height:1;
}

.product-quantity div#crs-inline {
    width: 100%;
}


/* =========================
   CRS Modal — Mobile tweaks
   ========================= */
@media (max-width: 768px){

  .crs-toggle-crosses {
      padding: 0px 5px;
      background-color: #fbfbfb;
      border-radius: 13px;
      width: fit-content;
      margin-bottom: 2px;
  }

  /* Dialog plein écran + scroll interne propre */
  .crs-modal__dialog{
    margin: 0 !important;
    max-width: none !important;
    width: 100%;
    height: auto;
    border-radius: 20px;
    padding: 8px 5px 5px; /* espace pour boutons collés en bas */
    display: flex;
    flex-direction: column;
  }

  .crs-card__price {
      font-weight: 700;
      font-size: 12px;
  }

  .personnalisation-info {
      line-height: 10px;
      margin: 0;
  }

  /* Overlay interne en grille 1 colonne, scrolable */
  .crs-grid{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 0px 0 !important;
    overflow: hidden;
    flex: 1 1 auto;           /* occupe toute la hauteur */
  }

  /* Close plus confortable */
  .crs-modal__close {
      right: 6px;
      top: 6px;
      width: 25px;
      height: 25px;
      border-radius: 50%;
      background: #000;
      color: #fff;
      font-size: 16px;
      line-height: normal;
      opacity: .9;
  }

  /* Récap en haut, style carte */
  .crs-aside {
      order: 2;
      border-right: 0 !important;
      border: 1px solid #eee;
      border-radius: 12px;
      padding: 8px 10px;
      background: #fafafa;
      width: 97%;
      height: max-content;
  }

  .crs-auto-tension {
      width: 97%;
  }

  /* Stepper scrollable horizontal */
  .crs-steps{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, max-content));
    gap: 6px 8px;
    width: 100%;
    overflow: visible;
  }
  .crs-steps li{ white-space: nowrap; }

  /* Liste cordages : 2 colonnes (1 en très petit) */
  .crs-string-grid{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    gap: 4px !important;
    padding-top: 0px !important; /* place pour le titre sticky */
    width: 97%;
    padding: 0 5px;
  }


  /* Titre de bloc sticky, largeur 100% */
  .crs-string-block h5{
    position: sticky !important;
    top: 0;
    background: #fff;
    padding: 8px 0 0px !important;
    z-index: 5;
    width: 100%;
  }

  div#crs-modal {
      padding: 5px;
  }

  /* Hauteur raisonnable pour scroller la liste */
  .crs-string-block{
    height: auto !important;
    max-height: 49vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .crs-chip span {
      display: block;
      text-align: center;
      border-radius: 8px;
      padding: 4px 8px;
      border: 1px solid #e5e7eb;
      background: #f3f4f6;
      font-weight: 600;
      font-size: 11px;
  }

  .crs-card {
      padding: 7px;
  }

  .crs-summary-block div {
      margin: 2px 0;
  }

  /* Cartes plus compactes */
  .crs-card__img{ height: 80px !important; }
  .crs-card__title{ font-size: 11px !important; min-height: 2.2em; font-weight: 500;}

  /* La jauge ne flotte plus : elle passe en flux normal */
  .crs-card__gauge{
    position: static !important;
    width: 100% !important;
    box-shadow: none !important;
    margin: 6px 0 0 !important;
  }
  .crs-gauge-select{
    width: 100%;
    font-size: 10px;
    padding: 2px 5px !important;
    border-radius: 10px !important;
  }

  .crs-tensions label {
      color: #000;
      font-size: 12px;
      font-weight: 600;
  }

  /* Tensions sur une seule colonne */
  .crs-tensions{
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    max-width: 100% !important;
  }
  .crs-tensions .form-control {
          font-size: 12px;
          padding: 5px 12px;
          color: #000;
          width: 97%;
          box-shadow: none;
          transition: none;
      }


  .personnalisation-info span {
      font-size: 10px;
      font-weight: 500;
  }

  /* Options en 1 colonne */
  .crs-options--grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

  /* Chips plein largeur si besoin */
  .crs-opt-choices{ gap: 5px; }
  .crs-chip{ flex: 1 1 0; }

  .crs-opt-help {
      font-size: 11px;
      line-height: inherit;
      margin: 0px 0 0;
      color: #000;
  }

  /* Barre d’actions collée en bas avec ombre */
  .crs-step .crs-actions{
    position: sticky;
    bottom: -1px;                 /* évite l’artefact de bord */
    background: #fff;
    padding: 10px 0 0;
    margin-top: 6px;
    gap: 8px;
    box-shadow: 0 -10px 20px rgba(0,0,0,.06);
    z-index: 10;
    justify-content: center;
  }
  .crs-actions .btn {
      font-size: 13px !important;
      padding: 8px 12px !important;
      border-radius: 5px !important;
      font-weight: 600;
  }

  /* Badges récap + texte plus petits */
  .crs-summary-block div,
  span#sum-mains,
  span#sum-crosses,
  span#sum-tensions,
  span#sum-options{
    font-size: 11px !important;
  }

  .crs-total {
      margin-top: 10px !important;
  }

  /* Pastille de supplément visible sur mobile */
  .crs-total #sum-extra{
    font-size: 12px !important;
    padding: 4px 10px !important;
  }
}

/* Ultra-petits écrans : force 1 colonne partout */
@media (max-width: 340px){
  .crs-string-grid{ grid-template-columns: 1fr !important; }
  .crs-steps li{ font-size: 11px; padding: 6px 8px; }
}
