:root{
  --g:#38c86b;
  --gsoft: rgba(56,200,107,.22);
  --gray:#d9d9d9;
  --gray2:#efefef;
}

/* =========================
   BOUTON OUVERTURE
========================= */
.yaniro-open{
  display:inline-block !important;
  padding:14px 18px !important;
  background:#111 !important;
  color:#fff !important;
  border-radius:14px !important;
  font-weight:800 !important;
  text-decoration:none !important;
}

/* =========================
   LIGHTBOX (:target)
========================= */
#yaniro-modal{ display:none !important; }

#yaniro-modal:target{
  display:block !important;
  position:fixed !important;
  inset:0 !important;
  z-index:999999 !important;
}

.yaniro-backdrop{
  position:absolute !important;
  inset:0 !important;
  background:rgba(0,0,0,.55) !important;
  display:block !important;
}

.yaniro-panel{
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%,-50%) !important;
  width:min(760px,92vw) !important;
  max-height:86vh !important;
  overflow:auto !important;
  background:#fff !important;
  border-radius:18px !important;
  padding:18px !important;
  box-shadow:0 24px 80px rgba(0,0,0,.35) !important;
}

.yaniro-close{
  position:absolute !important;
  top:10px !important;
  right:12px !important;
  font-size:30px !important;
  line-height:1 !important;
  text-decoration:none !important;
  color:#111 !important;
  background:#fff !important;
  border-radius:12px !important;
  padding:2px 10px !important;
  box-shadow:0 6px 18px rgba(0,0,0,.12) !important;
}

/* =========================
   FORM (2 colonnes)
========================= */
.y-fields{
  display:grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap:14px !important;
  margin:4px 0 10px !important;
}

@media (max-width: 520px){
  .y-fields{ grid-template-columns: 1fr !important; }
}

.y-field{
  display:flex !important;
  flex-direction:column !important;
}

.y-field label{
	display:block !important;
  margin-bottom:2px !important;
  line-height:1 !important;
  font-size:14px !important;
}

.y-field input{
  display:block !important;
  width:100% !important;
  height:48px !important;
  min-height:48px !important;
  padding:0 14px !important;
  margin:0 !important;
  box-sizing:border-box !important;
  border-radius:12px !important;
  border:1px solid #e6e6e6 !important;
  background:#fff !important;
  color:#111 !important;
  font-size:16px !important;
  outline:none !important;
}

.y-field input:focus{
  border-color:rgba(56,200,107,.60) !important;
  box-shadow:0 0 0 4px var(--gsoft) !important;
}

/* neutralise les différences number */
.y-field input[type="number"]{
  -moz-appearance:textfield !important;
  appearance:textfield !important;
}
.y-field input[type="number"]::-webkit-inner-spin-button,
.y-field input[type="number"]::-webkit-outer-spin-button{
  margin:0 !important;
}

/* =========================
   BOUTON CALCUL
========================= */
.y-calc{
  margin:12px 0 10px !important;
  width:100% !important;
  padding:16px !important;
  border-radius:16px !important;
  border:0 !important;
  background:var(--g) !important;
  color:#111 !important;
  font-weight:900 !important;
  font-size:20px !important;
  cursor:pointer !important;
  box-shadow:0 14px 26px rgba(0,0,0,.10) !important;
}

/* =========================
   SLIDER + TAILLES
   (cachés avant calcul)
========================= */
.y-sizes,
.y-slider{
  display:none;
}

.yaniro-sim.is-calculated .y-sizes,
.yaniro-sim.is-calculated .y-slider{
  display:block;
}

.y-sizes{
  display:flex !important;
  justify-content:space-between !important;
  margin:10px 2px 6px !important;
  font-weight:900 !important;
  font-size:18px !important;
}
.y-sizes span{ flex:1 !important; }
.y-left{ text-align:left !important; }
.y-center{ text-align:center !important; }
.y-right{ text-align:right !important; }

.y-slider{
  position:relative !important;
  height:24px !important;
  margin:6px 0 14px !important;
}

/* base grise */
.y-slider::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  height:8px !important;
  background:var(--gray) !important;
  border-radius:999px !important;
}

/* zone verte 20% -> 80% */
.y-zone{
  position:absolute !important;
  left:20% !important;
  width:60% !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  height:8px !important;
  background:var(--g) !important;
  border-radius:999px !important;
}

/* curseur (NE JAMAIS fixer left ici) */
.y-cursor{
  position:absolute !important;
  top:50% !important;
  transform:translate(-50%,-50%) !important;
  width:18px !important;
  height:18px !important;
  border-radius:50% !important;
  background:var(--g) !important;
  box-shadow:0 0 0 5px var(--gsoft) !important;
  display:none !important;          /* caché avant calcul */
}

/* après calcul : on l’affiche + animation, le JS contrôle left */
.yaniro-sim.is-calculated .y-cursor{
  display:block !important;
  transition:left .25s ease !important;
}

/* =========================
   RESULTATS
========================= */
.y-final{
  margin:10px 0 14px !important;
  padding:14px !important;
  border:2px solid var(--g) !important;
  border-radius:14px !important;
  font-weight:900 !important;
  font-size:18px !important;
  text-align:center !important;
}

.y-measures{
  background:var(--gray2) !important;
  border-radius:14px !important;
  padding:14px !important;
  font-size:16px !important;
  color:#555 !important;
}
.y-measures strong{
  display:block !important;
  margin-bottom:8px !important;
  color:#444 !important;
  font-size:18px !important;
}

/* =========================
   COMPACT MODE – simulateur plus resserré
========================= */

/* bloc global */
.yaniro-sim{
  margin:0 !important;
  padding:0 !important;
}

/* grille des champs */
.y-fields{
  gap:8px !important;
  margin:2px 0 6px !important;
}

/* chaque champ */
.y-field{
  gap:2px !important;
}

/* labels */
.y-field label{
  margin:0 !important;
  font-size:14px !important;
  line-height:1.1 !important;
}

/* inputs */
.y-field input{
  height:42px !important;
  min-height:42px !important;
  font-size:15px !important;
}

/* bouton calcul */
.y-calc{
  margin:8px 0 6px !important;
  padding:12px !important;
  font-size:17px !important;
}

/* tailles M L XL */
.y-sizes{
  margin:6px 0 2px !important;
  font-size:16px !important;
}

/* slider */
.y-slider{
  margin:2px 0 8px !important;
}

/* résultat */
.y-final{
  margin:6px 0 8px !important;
  padding:10px !important;
  font-size:16px !important;
}

/* bloc mesures */
.y-measures{
  padding:10px !important;
  font-size:15px !important;
}

/* Lightbox target (générée par JS) */
.yaniro-modal{ display:none !important; }
.yaniro-modal:target{ display:block !important; }

/* ===== LIGHTBOX NOGRAD GENERIC – FIX POSITION & Z-INDEX ===== */

.yaniro-modal{
  display:none !important;

  position:fixed !important;
  inset:0 !important;

  z-index:999999999 !important; /* au-dessus de tout */

}

/* activation */
.yaniro-modal:target{
  display:block !important;
}

/* fond sombre */
.yaniro-backdrop{
  position:absolute !important;
  inset:0 !important;
  background:rgba(0,0,0,.55) !important;
  z-index:1 !important;
}

/* panneau centré verticalement + horizontalement */
.yaniro-panel{

  position:absolute !important;

  left:50% !important;
  top:50% !important;

  transform:translate(-50%,-50%) !important;

  width:min(760px,92vw) !important;
  max-height:86vh !important;

  overflow:auto !important;

  background:#fff !important;
  border-radius:18px !important;
  padding:18px !important;

  z-index:2 !important;

  box-shadow:0 30px 80px rgba(0,0,0,.35) !important;
}

/* bouton fermeture */
.yaniro-close{
  position:absolute !important;
  top:10px !important;
  right:12px !important;

  font-size:30px !important;

  background:#fff !important;

  z-index:3 !important;
}