:root {
  /* Palette bleu nuit — ratios WCAG vérifiés (texte clair sur fond ≥ 4.5:1) */
  --bg:      #0f1c2e;   /* fond profond */
  --card:    #16283d;   /* élévation 1 */
  --card2:   #1b3049;   /* élévation 2 */
  --text:    #f2f6fc;   /* texte principal (~15:1 sur --bg) */
  --muted:   #a8b8cc;   /* texte secondaire (~7:1 sur --bg) */
  --accent:  #4da3ff;   /* accent unique */
  --accent-ink: #08172a; /* texte sur fond accent */
  --sel-bg:  #17324f;   /* fond option sélectionnée */
  --border:  #26364b;
  --radius: 14px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: radial-gradient(1200px 600px at 50% -10%, #14263c 0%, var(--bg) 60%);
  color: var(--text);
  min-height: 100vh;
  line-height: 1.5;
}

.wrap { max-width: 760px; margin: 0 auto; padding: 32px 20px 80px; }

h1 { font-size: 1.9rem; margin: 0 0 8px; letter-spacing: -0.02em; color: var(--text); }
h2 { font-size: 1.25rem; margin: 28px 0 12px; color: var(--text); }
.sub { color: var(--muted); margin: 0 0 24px; }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px;
  margin-bottom: 18px;
}

label.field { display: block; margin: 14px 0 6px; font-size: .92rem; color: var(--muted); }
input[type=text], select {
  width: 100%;
  padding: 12px;
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  font-size: 1rem;
}
input[type=text]::placeholder { color: #6f8199; }
input[type=text]:focus, select:focus { outline: 2px solid var(--accent); outline-offset: 1px; }

label.check { display: flex; gap: 10px; align-items: flex-start; margin: 10px 0 4px; color: var(--muted); font-size: .88rem; cursor: pointer; }
label.check input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--accent); flex: 0 0 auto; }

.modes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 8px; }
.mode-btn {
  text-align: left; cursor: pointer; color: var(--text);
  background: var(--card2); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px; transition: .15s; min-height: 44px;
}
.mode-btn:hover { border-color: var(--accent); }
.mode-btn.sel { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(77,163,255,.3); background: var(--sel-bg); }
.mode-btn b { display: block; font-size: 1.05rem; margin-bottom: 4px; color: var(--text); }
.mode-btn span { color: var(--muted); font-size: .88rem; }

button.primary {
  width: 100%; margin-top: 18px; padding: 14px;
  background: var(--accent); color: var(--accent-ink); font-weight: 700;
  border: 0; border-radius: 11px; font-size: 1.02rem; cursor: pointer; min-height: 48px;
}
button.primary:disabled { opacity: .45; cursor: not-allowed; }
button.ghost {
  background: transparent; color: var(--text); border: 1px solid var(--border);
  border-radius: 10px; padding: 11px 16px; cursor: pointer; font-size: .92rem; min-height: 44px;
}
button.ghost:hover { border-color: var(--accent); }

/* Quiz */
.progress { height: 6px; background: var(--card2); border-radius: 6px; overflow: hidden; margin-bottom: 20px; }
.progress > i { display: block; height: 100%; background: var(--accent); width: 0; transition: width .3s; }
.qcount { color: var(--muted); font-size: .85rem; margin-bottom: 8px; }
.qtext { font-size: 1.4rem; font-weight: 600; margin: 6px 0 22px; letter-spacing: -.01em; color: var(--text); }
.choices { display: grid; gap: 10px; }
.choice {
  cursor: pointer; padding: 15px 16px; border-radius: 11px;
  background: var(--card2); border: 1px solid var(--border);
  color: var(--text);              /* <-- correctif : plus de texte noir par défaut */
  font-size: 1rem; transition: .12s; text-align: left; min-height: 48px;
  font-family: inherit;
}
.choice:hover { border-color: var(--accent); transform: translateY(-1px); }
.choice.sel { border-color: var(--accent); background: var(--sel-bg); box-shadow: 0 0 0 2px rgba(77,163,255,.35); }
.navrow { display: flex; justify-content: space-between; align-items: center; margin-top: 20px; }

/* Résultats */
.gauge { margin: 16px 0; }
.gauge .g-top { display: flex; justify-content: space-between; font-size: .85rem; color: var(--muted); margin-bottom: 6px; }
.gauge .g-top b { color: var(--text); }
.gauge .g-bar { position: relative; height: 12px; background: var(--card2); border-radius: 8px; }
.gauge .g-bar .mid { position: absolute; left: 50%; top: -3px; bottom: -3px; width: 1px; background: var(--border); }
.gauge .g-bar .dot {
  position: absolute; top: 50%; width: 18px; height: 18px; border-radius: 50%;
  background: var(--accent); transform: translate(-50%, -50%); border: 2px solid var(--bg);
}
.gauge .g-val { text-align: center; font-size: .9rem; margin-top: 7px; color: var(--muted); }
.gauge .g-val b { color: var(--text); }

.quadrants { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 620px) { .quadrants { grid-template-columns: 1fr; } .modes { grid-template-columns: 1fr; } }

.label-box {
  text-align: center; padding: 30px 24px; margin: 6px 0 16px;
  background: linear-gradient(135deg, #1c3252, #16283d);
  border: 1px solid var(--border); border-radius: var(--radius);
}
.label-box .lb-k { color: var(--muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; }
.label-box .lb-v { font-size: 1.9rem; font-weight: 800; margin-top: 8px; color: var(--text); }

.detail-toggle {
  width: 100%; text-align: left; background: var(--card); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px 20px; cursor: pointer; font-size: 1rem; font-weight: 600;
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px;
}
.detail-toggle:hover { border-color: var(--accent); }
.detail-toggle .chev { transition: transform .2s; color: var(--muted); }
.detail-toggle.open .chev { transform: rotate(180deg); }

.share { display: flex; gap: 8px; margin-top: 10px; }
.share input { flex: 1; font-size: .85rem; }
.compare-row { color: var(--muted); font-size: .9rem; }

.pill { display:inline-block; padding:4px 11px; border-radius:999px; background:var(--card2); border:1px solid var(--border); font-size:.8rem; color:var(--muted); }
.err { color: #ff9db0; font-size: .9rem; margin-top: 10px; }
.hidden { display: none; }
a { color: var(--accent); }
