/* ============================
   SELECT2 (hors couleurs)
   ============================ */
.product-variants .select2-container {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: auto !important;
}
.product-variants select.form-control-select.select2-hidden-accessible {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    border: 0 !important;
    clip: rect(0 0 0 0) !important;
    overflow: hidden !important;
}

/* ============================
   Floating labels
   ============================ */
.form-group { position: relative; }
.form-group.checkbox_box { height: initial !important; }

.form-group.floating label {
    position: absolute;
    left: 12px; top: 12px;
    padding: 0 4px;
    line-height: 1.1;
    pointer-events: none;
    transition: all .15s ease;
    opacity: .85;
    background: transparent !important;
    z-index: 2;
}
.form-group.floating .select2-container--default .select2-selection--single {
    position: relative; z-index: 1;
}
.form-group.floating.filled label,
.form-group.floating.focus  label { top: -8px; font-size: 12px; opacity: .95; }

.form-group.floating .form-control,
.form-group.floating input[type="text"],
.form-group.floating input[type="email"],
.form-group.floating input[type="tel"],
.form-group.floating input[type="password"],
.form-group.floating input[type="search"],
.form-group.floating input[type="url"],
.form-group.floating textarea,
.form-group.floating select { padding: 16px 12px 10px 12px; }

.form-group.floating textarea { padding-top: 22px; min-height: 110px; }
.form-group.floating input::placeholder,
.form-group.floating textarea::placeholder { color: transparent; }

.form-group .form-control,
.form-group input:not([type="checkbox"]):not([type="radio"]),
.form-group textarea,
.form-group select { color: #000; -webkit-text-fill-color: #000; }

.form-group input[type="checkbox"],
.form-group input[type="radio"] { position: static; }

.form-group.checkbox label,
.ps-checkbox label {
    position: static !important;
    transform: none !important;
    padding: 0; opacity: 1;
}

.select2-container--default .select2-selection--single { height: 42px; padding-top: 18px; }
.select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 42px; }
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 42px; }

/* =========================================================
   TEINTES – Grille + tuiles (couleurs/textures)
   ========================================================= */

/* Grille : 7 colonnes sur desktop, responsive en dessous */
.product-variants-item--color ul[id^="attributes_"]{
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important; /* 7 par ligne */
    gap: 16px 18px;
    list-style: none;
    padding: 0;
    margin: 10px 0 0;
}
/* Neutralise les styles du thème */
.product-variants-item--color ul[id^="attributes_"] > li{
    float: none !important;
    width: auto !important;
    display: block;
}

/* Tuile */
.colors-item {}
.colors-item__label{
    display: block;
    cursor: pointer;
    user-select: none;
}

/* Radio masqué mais accessible */
.colors-item .input-color{
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

/* Plaque ~150×80 (ratio 53.333%) */
.colors-item__swatch{
    display: block;
    width: 100%;
    height: 0;
    padding-top: 53.333%; /* ← AU LIEU DE 26.666% */
    border: 1px solid #d9d9d9;
    border-radius: 6px;
    background-color: #f1efed;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    box-shadow: 0 0 0 0 rgba(0,0,0,0);
    transition: border-color .15s ease, box-shadow .15s ease, transform .08s ease;
}

/* Texture: image de fond */
.colors-item__swatch--texture{ background-size: contain; }

/* Libellé sous la plaque */
.colors-item__name{
    display: block;
    margin-top: 8px;
    text-align: center;
    font-size: 12px;
    line-height: 1.15;
    letter-spacing: .02em;
    color: #111;
}

/* Hover/Focus */
.colors-item__label:hover .colors-item__swatch{ border-color: #b5b5b5; }
.colors-item .input-color:focus-visible + .colors-item__swatch{
    box-shadow: 0 0 0 3px rgba(0,0,0,.25);
}

/* Sélection */
.colors-item .input-color:checked + .colors-item__swatch{
    border-color: #000;
    box-shadow: 0 2px 0 0 rgba(0,0,0,.25);
}

/* Responsive colonnes */
@media (max-width: 1399px){
    .product-variants-item--color ul[id^="attributes_"]{ grid-template-columns: repeat(6, 1fr) !important; }
}
@media (max-width: 1199px){
    .product-variants-item--color ul[id^="attributes_"]{ grid-template-columns: repeat(5, 1fr) !important; }
}
@media (max-width: 991px){
    .product-variants-item--color ul[id^="attributes_"]{ grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 767px){
    .product-variants-item--color ul[id^="attributes_"]{ grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 575px){
    .product-variants-item--color ul[id^="attributes_"]{ grid-template-columns: repeat(2, 1fr) !important; }
}

/* Sécurité : ne jamais ré-afficher le select couleur */
.is-color-select{ display: none !important; }

/* Place le label au-dessus de la grille et annule les floats/colonnes du thème */
.product-variants .product-variants-item .control-label{
    display:block;
    float:none !important;
    width:auto !important;
    margin:0 0 8px !important;
    padding:0 !important;
    text-align:left;
}

/* Annule tout padding/marge latéral qui pousse la grille à droite */
.product-variants,
.product-variants .product-variants-item,
.product-variants-item--color ul[id^="attributes_"]{
    margin-left:0 !important;
    padding-left:0 !important;
}

/* Neutralise les styles de liste du thème */
.product-variants-item--color ul[id^="attributes_"] > li{
    float:none !important;
    width:auto !important;
    display:block;
}

/* 7 par ligne sur desktop (garde tes media queries existants) */
.product-variants-item--color ul[id^="attributes_"]{
    display:grid !important;
    grid-template-columns:repeat(7,1fr) !important;
    gap:16px 18px;
}

/* Optionnel: aligner tout le bloc actions comme les titres (si le thème met un padding) */
.right-column .product-actions{
    padding-left:0 !important;
    margin-left:0 !important;
}
