.tools {
   font-weight:600;
    color: var(--indigo-fonce);
	margin:0 auto;
}

.tools-header { text-align: center; margin-bottom: 30px; }
.tools-header h1 { font-size: 32px; font-weight: 800; margin-bottom: 8px; }
.tools-container {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.tools-card {
	display: flex; 
	flex-direction: column; justify-content: space-evenly; gap:15px;
    background: transparent;
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 4px 6px -1px var(--noir);
}
.tools-card.flex-row-wrap h2{ flex: 1 1 100%; align-self: flex-start;}
.tools-tabs{display: flex; align-self:center; gap:10px;}
.tools-cb-btns { display: flex; width:100%;  justify-content: center; gap: 5px 3px;}
.tools-level-btns{ display: flex; width:90%; justify-content: space-around;}
.tools-toggle-group{display: flex; justify-content: center;gap:5%;}
  
/* Row alignement inputs */
.tools-inputs-row {
    display: flex;
	flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
}


.tools-input-group label {
    display: block; font-weight: 700; color: var(--indigo);
    text-transform: uppercase; margin-bottom: 8px;
}

.tools-field {
    display: flex; align-items: center; padding: 4px 10px;
}

.tools-field input[type="text"] {
    border: none; outline: none;
}

.tools-swatch-wrapper { position: relative; width: 32px; height: 32px; }
.tools-swatch-wrapper input[type="color"] {
    position: absolute; opacity: 0; width: 100%; height: 100%; cursor: pointer;
}
.tools-swatch {
    width: 100%; height: 100%; border-radius: 6px; border: 1px solid var(--taupe);
}

.tools-swap-btn {margin-top: 15px; max-height:60px;}
.tools-main-btn{width: 90%; align-self: center; margin: 10px auto;}
/* Preview Box */
.tools-preview-box {
    border-radius: 16px; padding: 40px; margin-bottom: 20px; line-height:1.6;
}
.tools-tag {  font-weight: 800; text-transform: uppercase; opacity: 0.6; margin-bottom: 15px; display: block; }
.p-32{font-size: 32px; font-weight:800;}
.p-24{font-size: 24px; font-weight:700;}
.p-16{font-size: 16px; font-weight:400;}
.p-14{font-size: 14px; font-weight:400;}
.p-12{font-size: 12px; font-weight:400;}
/* Grille de boutons couleur de base */
.tools-base-grid {
 display:flex;
 flex-direction: column;
 flex-wrap: wrap;
 gap: 2%;
 height: 320px;
 width: 75%;
  align-self: center;
}

.tools-base-grid button {
    display: flex;
    align-items: center;
    gap: 10px;
    transition: all 0.2s;
    text-align: left;
}

.tools-base-grid button:hover {
    background: var(--mauve-pale);
    border-color: var(--labvande);
}

.tools-base-grid .dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* Sliders et jauges colorées */
.tools-sliders{width: 80%;
  align-self: center;}
.tools-slider-row { display: flex; align-items: center; gap: 15px; margin-bottom: 12px; font-size: 20px;}
.tools-slider-row .label 
{ 
	font-weight: 800; font-family: monospace; text-align: center;
	width: 30px;height:30px; 
	font-size:25px; border-radius: 50px;
}
.tools-slider-row .label.r { background-color: #ef4444; color:var(--blanc);}
.tools-slider-row .label.g { background-color: #22c55e;color:var(--blanc);}
.tools-slider-row .label.b { background-color: #3b82f6; color:var(--blanc);}
span.val{min-width: 35px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: auto;}
input[type="range"] 
{
	-webkit-appearance: none;
    flex: 1;  
	width:100%;
	height: 8px; 
	border-radius: 10px; border:2px solid var(--indigo-fonce);
}

input[type="range"]::-webkit-slider-thumb{
    -webkit-appearance:none;
    width:22px;
    height:22px;
    border-radius:50%;
    background:transparent;
     border:4px solid var(--tools-thumb-border, var(--gris));
    backdrop-filter: blur(4px) saturate(1.3);
    cursor:pointer;
    transition:border-color .2s, box-shadow .2s;

}

input[type="range"]::-webkit-slider-thumb:hover{
    box-shadow:0 0 0 4px rgba(0,0,0,0.5);
}

input[type="range"]::-moz-range-thumb{
    width:22px;
    height:22px;
    border-radius:50%;
    background:transparent;
    border:4px solid var(--tools-thumb-border, var(--gris));
    cursor:pointer;
	 backdrop-filter: blur(4px) saturate(1.3);
	
}

input[type="range"]::-moz-range-thumb:hover{
    box-shadow:0 0 0 4px rgba(0,0,0,0.5);
}


/* Ratio et Badges */
.tools-check-item,.tools-sugg-card { position: relative;display: flex;
align-items: center;
 gap: 15px; padding: 15px;
 background: var(--blanc);  border-radius: 12px; 
	margin: 10px 0;}
.tools-check-list{display: flex; flex-direction: column;justify-content: center;
align-self:center; width:90%; }
.tools-ratio-big { display: flex; align-items: baseline; gap: 10px; margin-bottom: 20px; }
.tools-ratio-big span { font-size: clamp(2.5rem, 1.25rem + 4vi, 3.75rem); font-weight: 800; }


.tools-check-item {justify-content: space-between;}
.tools-badge-pass { background: var(--menthe); color: var(--vert); padding: 4px 12px; border-radius: 20px;  font-weight: 700; }
#sticky-pass{padding: 4px 12px; border-radius: 20px;}
/* Suggestions Statiques */
.tools-sugg-card 
{
justify-content: space-around; cursor: pointer;
transition: all 0.2s ease;
}

.tools-sugg-card:hover {
    background: var(--ivoire); 
    border-color: var(--mauve-pale);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px var(--taupe);
}

/* Optionnel : effet de clic (pression) */
.tools-sugg-card:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    background: var(--bleu-pale);
}
/* Conteneur des suggestions */
.tools-sugg-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* L'item de suggestion (la carte) */
.tools-suggestion-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--blanc);
    border: 1px solid var(--bleu-pale);
    border-radius: 12px;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

/* Effet au survol discret (pas d'effet bouton) */
.tools-suggestion-item:hover {
    background: var(--ivoire);
    border-color: var(--mauve);
}

.tools-sugg-left {
    display: flex;
    align-items: center;
    gap: 15px;
}

/* La pastille de couleur à gauche */
.tools-sugg-swatch {
     display: flex;
    align-items: center;
    justify-content: center;
	width: 45px;
    height: 45px;
    border-radius: 8px;
    font-weight: bold;

}

.tools-sugg-details {
    display: flex;
    flex-direction: column;
}

.tools-sugg-hex {
    font-family: monospace;
    font-weight: 700;
    color: var(--marine);
}

.tools-sugg-meta {
   
    color: var(--gris);
}

.tools-sugg-right {
    display: flex;
    align-items: center;
    gap: 15px;
}

/* Badges AA, AAA, AAA+ */
.tools-badge-norm {
   
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 10px;
	white-space: nowrap;
}
.tools-badge-norm.aa { background: var(--bleu-pale); color: var(--bleu); }
.tools-badge-norm.aaa { background: var(--mauve-pale); color: var(--violet); }
.tools-badge-norm.aaa-plus { background: var(--pink); color: var(--rouge); }

/* Le petit aperçu texte/fond à droite */
.tools-sugg-preview-circle {
    width: 36px;
    height: 36px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
   
    background: var(--noir); /* Sera surchargé par le JS */
}
/*active*/
/* Style générique pour les boutons actifs dans les groupes de boutons/onglets */
.tools-level-btns button.active,
.tools-tabs button.active,
.tools-toggle-group button.active,
.tools-adjust-tabs button.active,
.tools-level-btns button.focus,
.tools-tabs button.focus,
.tools-toggle-group button.focus,
.tools-adjust-tabs button.focus,
.tools-copy-btn.is-copied, .tools-lock-btn.is-locked {
    background: var(--blanc) !important;
    color:var(--indigo-fonce)  !important;
    border-color: var(--indigo-fonce) !important;
}
.tools-lock-btn.is-locked:hover {
   background: var(--mauve-pale) !important;
    color:var(--indigo-fonce)  !important;
    border-color: var(--indigo-fonce) !important;
}
/* Optionnel : Amélioration du style de base des boutons pour qu'ils ressemblent à tes captures */
.tools-level-btns button, 
.tools-tabs button, 
.tools-toggle-group button {
    background: var(--blanc);
    border: 1px solid var(--ivoire);
    padding: 8px 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

/* ── Daltonisme ─────────────────────────────────────────── */
.tools-cb-desc { margin-bottom: 12px;}

.tools-cb-btns button {
    background: var(--blanc);
    border: 1px solid var(--ivoire);
    padding: 6px 14px;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 600;
    transition: all 0.2s;
}
.tools-cb-btns button span {
    font-weight: 400;
    opacity: 0.55;
    margin-left: 3px;
}
.tools-cb-btns button.active {
    background: var(--blanc) !important;
    color: var(--indigo-fonce) !important;
    border-color: var(--indigo-fonce) !important;
}
.tools-cb-ratio {
    margin-top: 10px;
    padding: 8px 12px;
    background: var(--bleu-pale);
    border-radius: 8px;
    
    font-weight: 700;
    color: var(--bleu);
}
.tools-cb-badge {
   
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 10px;
}
.tools-cb-badge.pass { background: var(--menthe); color: var(--vert); }
.tools-cb-badge.fail { background: var(--pink); color: var(--rouge); }

/* -----------------État sticky : colle en haut, prend toute la largeur ------------------------*/

/* Sticky via position:fixed (compatible Chrome) */
.tools-preview-box.is-sticky {
  position: fixed;
  top: 105px;
  left: 0;
  width: 100%;
  min-height: 50px;
  padding: 10px 6%;
  z-index: 1000;
  border-radius: 0;
}

/* Placeholder pour éviter le saut de contenu quand fixed s'active */
.tools-preview-placeholder {
 height: var(--tools-preview-height);
  display: none;
}
.tools-preview-placeholder.visible {
  display: block;
}
/* Contenu normal : visible par défaut, masqué en sticky */
.tools-preview-box .full-content { display: block; }
.tools-preview-box.is-sticky .full-content { display: none; }

/* Contenu compact : masqué par défaut, visible en sticky */
.tools-preview-box .sticky-content { display: none; }
.tools-preview-box.is-sticky .sticky-content {
  display: flex;
  position:relative;
  align-content: center; 
  align-items: center;
  justify-content:flex-start; 
  gap: 5px 10px;
  flex-wrap: wrap;
  font-weight:800 !important;
  width:85%;
  height:100%;
}
.tools-preview-box.is-sticky .sticky-content,
.tools-preview-box.is-sticky .sticky-content * {
    font-weight: 600 !important;
    font-variation-settings: "wght" 700 !important;
}
/* ── Bouton pipette ──────────────────────────────────────── */
.tools-picker-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    border: 1.5px solid var(--taupe);
    background: var(--blanc);
    color: var(--indigo-fonce);
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.15s;
    margin-left: 10px;
}
 
.tools-picker-btn:hover {
    border-color: var(--indigo);
    background: var(--mauve-pale);
    transform: scale(1.08);
}
 
/* État actif : la pipette est ouverte */
.tools-picker-btn.is-active {
    border-color: var(--violet);
    background: var(--lavande, var(--mauve-pale));
    box-shadow: 0 0 0 3px var(--mauve-pale);
    animation: tools-pulse 1s ease-in-out infinite;
}
 
/* Après sélection : fond = couleur choisie (géré en JS) */
.tools-picker-btn svg {
    pointer-events: none;
    transition: stroke 0.2s;
}
 
@keyframes tools-pulse {
    0%, 100% { box-shadow: 0 0 0 3px var(--mauve-pale); }
    50%       { box-shadow: 0 0 0 6px transparent; }
}
/* ── Copier + Lock sous la pastille ────────────────────── */
.tools-swatch-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    padding: 0 2px;
    flex-wrap: wrap;
}

.tools-copy-btn,
.tools-lock-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 6px;
    border: 1.5px solid var(--taupe);
    background: var(--blanc);
    color: var(--indigo-fonce);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    white-space: nowrap;
}

.tools-lock-btn.is-locked {
    background: var(--indigo-fonce);
    color: var(--blanc);
    border-color: var(--indigo-fonce);
}

.tools-swatch-hint {
    font-size: 14px;
    color: var(--gris-fonce);
    font-style: italic;
    margin-left: 2px;
}

/* Pastille verrouillée : anneau visible */
.tools-swatch.is-locked {
    box-shadow: 0 0 0 3px var(--bleu-violet);
}