/* =========================================
   Ciel & Saisons — outils & simulateurs
   Styles partagés (assets/tools.css)
   S'appuie sur les variables :root de styles.css (DA light)
   ========================================= */
.tool-page { padding: var(--space-2xl) 0 var(--space-3xl); }
.tool-head { max-width: 760px; margin: 0 auto var(--space-xl); text-align: center; }
.tool-head .tool-eyebrow {
  display: inline-block; font-family: var(--font-sans); font-weight: 600;
  font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--primary); background: var(--primary-light);
  padding: 6px 14px; border-radius: 50px; margin-bottom: var(--space-md);
}
.tool-head h1 { margin-bottom: var(--space-md); }
.tool-head p { color: var(--text-light); font-size: 1.1rem; line-height: 1.7; }

.tool-card {
  max-width: 760px; margin: 0 auto; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md); padding: var(--space-xl);
}
.tool-card + .tool-card { margin-top: var(--space-lg); }

.tool-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-md); }
.tool-field { display: flex; flex-direction: column; gap: 6px; }
.tool-field label { font-weight: 600; font-size: 0.9rem; color: var(--text); }
.tool-field select, .tool-field input {
  font-family: var(--font-sans); font-size: 1rem; padding: 11px 14px;
  border: 1.5px solid var(--border); border-radius: var(--radius-md);
  background: #fff; color: var(--text); transition: border-color 0.2s ease;
}
.tool-field select:focus, .tool-field input:focus { outline: none; border-color: var(--primary); }

.tool-actions { margin-top: var(--space-lg); display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.tool-btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 13px 30px;
  border-radius: 50px; font-family: var(--font-sans); font-weight: 600; font-size: 0.95rem;
  background: var(--primary); color: var(--on-primary, #fff); cursor: pointer;
  border: none; transition: all 0.25s ease;
}
.tool-btn:hover { background: var(--primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.tool-btn.secondary { background: var(--secondary); }
.tool-btn.secondary:hover { background: var(--secondary-dark); }

/* NB : le styles.css du builder définit sa propre .tool-result (fond bleu + display:none,
   révélée par .show). On neutralise cette collision ici (tools.css chargé après) avec une
   spécificité supérieure (:not([hidden])) pour nos outils à révélation par attribut hidden. */
.tool-result { margin-top: var(--space-lg); background: transparent; color: inherit; padding: 0; border-radius: 0; }
.tool-result[hidden] { display: none; }
.tool-result:not([hidden]) { display: block; }
.tool-result p { color: inherit; font-size: inherit; margin: 0 0 var(--space-md); }
.result-banner {
  display: flex; align-items: center; gap: var(--space-md);
  padding: var(--space-lg); border-radius: var(--radius-md);
  background: var(--primary-light); border: 1px solid var(--border);
}
.result-banner .result-emoji { font-size: 2.6rem; line-height: 1; }
.result-banner h3 { font-size: 1.35rem; margin: 0 0 4px; }
.result-banner p { margin: 0; color: var(--text-light); }
.result-banner.is-ok    { background: var(--printemps-light); border-color: var(--printemps); }
.result-banner.is-warn  { background: var(--secondary-light); border-color: var(--secondary); }
.result-banner.is-alert { background: var(--automne-light); border-color: var(--automne); }

.result-list { margin-top: var(--space-md); display: grid; gap: 10px; }
.result-list li {
  display: flex; gap: 10px; align-items: flex-start; padding: 12px 16px;
  background: var(--bg-warm); border-radius: var(--radius-md); line-height: 1.5;
}
.result-list li::before { content: "✓"; color: var(--primary); font-weight: 700; }

.tool-table { width: 100%; border-collapse: collapse; margin-top: var(--space-md); }
.tool-table th, .tool-table td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--border); }
.tool-table th { font-family: var(--font-sans); font-size: 0.8rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-muted); }
.tool-table tr:last-child td { border-bottom: none; }

.tool-gauge { height: 14px; border-radius: 50px; background: var(--border-light); overflow: hidden; margin: 10px 0; }
.tool-gauge > span { display: block; height: 100%; border-radius: 50px; transition: width 0.5s ease; }

.tool-note {
  margin-top: var(--space-lg); padding: var(--space-md) var(--space-lg);
  background: var(--secondary-light); border-left: 4px solid var(--secondary);
  border-radius: var(--radius-md); font-size: 0.92rem; color: var(--text);
}
.tool-note strong { color: var(--automne); }

.tool-back { display: block; max-width: 760px; margin: var(--space-xl) auto 0; text-align: center; }
.tool-back a { color: var(--primary); font-weight: 600; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.chip { padding: 6px 14px; border-radius: 50px; background: var(--bg-warm); border: 1px solid var(--border); font-size: 0.85rem; }
