/* ============================================================
   CONVERTU — Styles spécifiques aux pages outil
   ============================================================ */

.tool-page { padding: var(--sp-7) 0 var(--sp-11); }
.tool-page__head { margin-bottom: var(--sp-7); }
.tool-page__icon {
  width: 64px; height: 64px;
  border-radius: var(--r-lg);
  display: grid; place-items: center;
  color: #fff;
  font-size: 28px;
  margin-bottom: var(--sp-4);
}
.tool-page__title { font-size: clamp(28px, 4vw, var(--fs-4xl)); margin-bottom: var(--sp-2); }
.tool-page__subtitle { font-size: var(--fs-lg); color: var(--c-text-muted); max-width: 720px; }

/* ---------- Tool box ---------- */
.tool-box {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  box-shadow: var(--sh-md);
  margin-bottom: var(--sp-7);
}
.tool-box--narrow { max-width: 720px; margin-left: auto; margin-right: auto; }

/* ---------- Dropzone ---------- */
.dropzone {
  border: 2px dashed var(--c-border-strong);
  border-radius: var(--r-lg);
  padding: var(--sp-9);
  text-align: center;
  background: var(--c-bg-soft);
  cursor: pointer;
  transition: all var(--t-base);
  position: relative;
}
.dropzone:hover, .dropzone[data-drag="true"] {
  border-color: var(--c-primary);
  background: var(--c-primary-50);
  transform: scale(1.005);
}
.dropzone__icon { width: 56px; height: 56px; margin: 0 auto var(--sp-4); color: var(--c-primary); }
.dropzone__title { font-size: var(--fs-lg); font-weight: 600; color: var(--c-text); margin: 0 0 var(--sp-2); }
.dropzone__desc { font-size: var(--fs-sm); color: var(--c-text-soft); margin: 0; }
.dropzone__input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }

.file-list { margin-top: var(--sp-5); display: grid; gap: var(--sp-2); }
.file-item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
}
.file-item__icon { color: var(--c-primary); flex: 0 0 auto; }
.file-item__name { flex: 1; font-size: var(--fs-sm); font-weight: 500; }
.file-item__size { font-size: var(--fs-xs); color: var(--c-text-soft); }
.file-item__remove {
  background: transparent; border: 0; color: var(--c-text-soft); cursor: pointer; padding: 4px;
  border-radius: var(--r-xs);
}
.file-item__remove:hover { background: var(--c-hover); color: var(--c-danger); }

/* ---------- Tool input groups ---------- */
.tool-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
.tool-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
@media (max-width: 768px) {
  .tool-grid-2, .tool-grid-3 { grid-template-columns: 1fr; }
}

.tool-result { margin-top: var(--sp-5); padding: var(--sp-5); background: var(--c-bg-soft); border: 1px solid var(--c-border); border-radius: var(--r-md); }
.tool-result__label { font-size: var(--fs-sm); color: var(--c-text-soft); margin-bottom: var(--sp-2); font-weight: 600; }
.tool-result__value { font-size: var(--fs-2xl); font-weight: 700; color: var(--c-text); font-family: var(--font-mono); word-break: break-all; }
.tool-result__row { display: flex; justify-content: space-between; align-items: baseline; padding: 8px 0; border-bottom: 1px solid var(--c-border); }
.tool-result__row:last-child { border-bottom: 0; }

/* ---------- Stats display (word counter, etc.) ---------- */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--sp-3); margin-top: var(--sp-5); }
.stat-card { background: var(--c-bg-soft); padding: var(--sp-4); border-radius: var(--r-md); border: 1px solid var(--c-border); text-align: center; }
.stat-card__value { font-size: var(--fs-3xl); font-weight: 700; color: var(--c-text); font-family: var(--font-mono); line-height: 1; }
.stat-card__label { font-size: var(--fs-xs); color: var(--c-text-soft); text-transform: uppercase; letter-spacing: 0.05em; margin-top: var(--sp-2); }

/* ---------- Color tools ---------- */
.color-preview {
  width: 100%;
  height: 240px;
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  margin-bottom: var(--sp-4);
}
.color-swatches { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--sp-2); }
.color-swatch { aspect-ratio: 1; border-radius: var(--r-sm); cursor: pointer; position: relative; border: 1px solid var(--c-border); transition: transform var(--t-fast); }
.color-swatch:hover { transform: scale(1.05); z-index: 2; box-shadow: var(--sh-md); }
.color-swatch__label { position: absolute; bottom: 4px; left: 4px; right: 4px; font-size: 10px; font-family: var(--font-mono); color: rgba(255,255,255,.95); background: rgba(0,0,0,.30); padding: 2px 4px; border-radius: 4px; text-align: center; }

/* ---------- QR display ---------- */
.qr-display { display: grid; place-items: center; padding: var(--sp-7); background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-md); }
.qr-display canvas, .qr-display svg { max-width: 280px; height: auto; }

/* ---------- Section guest notice ---------- */
.guest-notice {
  margin-top: var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  background: var(--c-primary-50);
  border: 1px solid var(--c-primary-100);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.guest-notice__icon { font-size: 22px; }
.guest-notice__text { flex: 1; min-width: 200px; font-size: var(--fs-sm); color: var(--c-primary-900); }
.guest-notice__cta { white-space: nowrap; }

/* ---------- Tool content sections ---------- */
.tool-content { display: grid; grid-template-columns: 1fr; gap: var(--sp-9); margin-top: var(--sp-9); max-width: 760px; }
.tool-content h2 { margin-bottom: var(--sp-3); font-size: var(--fs-2xl); }
.tool-content h3 { margin: var(--sp-5) 0 var(--sp-2); font-size: var(--fs-lg); }
.tool-content p { font-size: var(--fs-base); line-height: 1.7; }
.tool-content ul, .tool-content ol { font-size: var(--fs-base); line-height: 1.7; }

/* ---------- Related tools ---------- */
.related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--sp-3); }
