:root {
  --bg: #0a0b0d;
  --bg2: #0e0f12;
  --carte: #131419;
  --carte2: #1a1c22;
  --bordure: #212329;
  --bordure2: #2b2e36;
  --texte: #e9eaee;
  --gris: #9a9ea8;
  --gris2: #62656e;
  --accent: #6f7bf0;
  --accent2: #99a2f6;
  --vert: #5bba84;
  --orange: #d6a24a;
  --rouge: #d6726e;
  --r: 12px;
  --r-s: 9px;
  --r-l: 16px;
  --e: 140ms cubic-bezier(.4, 0, .2, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: "Inter", system-ui, sans-serif;
  background: var(--bg);
  color: var(--texte);
  min-height: 100vh;
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }
::selection { background: rgba(111, 123, 240, .3); }

/* ---------- Nav ---------- */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; border-bottom: 1px solid var(--bordure);
}
.brand { display: flex; align-items: center; gap: 11px; }
.logo {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--carte2); border: 1px solid var(--bordure2);
  display: grid; place-items: center; font-size: 18px; color: var(--accent2);
}
.brand-txt { display: flex; flex-direction: column; line-height: 1.1; font-weight: 600; font-size: 16px; letter-spacing: -.01em; }
.brand-txt small { font-weight: 400; font-size: 10.5px; color: var(--gris2); letter-spacing: .12em; text-transform: uppercase; margin-top: 3px; }
.prive {
  font-size: 12px; color: var(--gris); display: flex; align-items: center; gap: 7px;
  padding: 6px 11px; border: 1px solid var(--bordure); border-radius: 999px;
}
.prive .ti { color: var(--vert); font-size: 14px; }

main { padding: 40px 24px 72px; max-width: 1180px; margin: 0 auto; }

/* ---------- Accueil ---------- */
.accueil { display: grid; place-items: center; min-height: 60vh; }
.accueil-inner { max-width: 560px; width: 100%; text-align: center; }
h1 { font-weight: 600; font-size: 30px; line-height: 1.15; letter-spacing: -.025em; margin: 0 0 12px; color: var(--texte); }
.accroche { color: var(--gris); font-size: 15px; line-height: 1.6; margin: 0 auto 32px; max-width: 480px; }

.tabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--carte); border: 1px solid var(--bordure); border-radius: 10px; margin-bottom: 24px; }
.tab {
  border: none; background: transparent; color: var(--gris);
  padding: 8px 16px; border-radius: 7px; cursor: pointer; font: inherit; font-size: 13.5px; font-weight: 500;
  display: flex; align-items: center; gap: 7px; transition: color var(--e), background var(--e);
}
.tab:hover { color: var(--texte); }
.tab.actif { background: var(--carte2); color: var(--texte); box-shadow: inset 0 0 0 1px var(--bordure2); }
.tab .ti { font-size: 16px; }

.depot {
  border: 1px dashed var(--bordure2); border-radius: var(--r);
  padding: 48px 24px; cursor: pointer; transition: border-color var(--e), background var(--e);
}
.depot:hover, .depot.survol { border-color: var(--accent); background: rgba(111, 123, 240, .04); }
.depot-ico { font-size: 34px; color: var(--gris2); transition: color var(--e); }
.depot:hover .depot-ico { color: var(--accent2); }
.depot-titre { font-size: 16px; font-weight: 500; margin: 12px 0 4px; }
.depot-sous { color: var(--gris2); font-size: 13px; margin: 0; }
.lien { background: none; border: none; color: var(--accent2); cursor: pointer; font: inherit; padding: 0; border-bottom: 1px solid transparent; }
.lien:hover { border-bottom-color: currentColor; }

.webcam-carte { display: flex; flex-direction: column; align-items: center; gap: 16px; }
#cam { width: 100%; max-width: 540px; border-radius: var(--r); border: 1px solid var(--bordure); background: #000; transform: scaleX(-1); }

.statut { color: var(--gris2); font-size: 13px; margin-top: 20px; min-height: 18px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.statut.erreur { color: var(--rouge); }
.statut.ok { color: var(--gris); }
.spin { animation: spin 1s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ---------- Boutons ---------- */
button {
  font-family: inherit; font-size: 13px; font-weight: 500; cursor: pointer;
  background: transparent; color: var(--texte);
  border: 1px solid var(--bordure2); border-radius: var(--r-s);
  padding: 8px 12px; display: inline-flex; align-items: center; gap: 7px;
  transition: background var(--e), border-color var(--e), color var(--e);
}
button:hover { background: var(--carte2); border-color: #353842; }
button:active { transform: translateY(.5px); }
button .ti { font-size: 16px; }
button.primaire { background: var(--accent); border-color: var(--accent); color: #fff; }
button.primaire:hover { background: var(--accent2); border-color: var(--accent2); }
button.gros { padding: 12px 24px; font-size: 14px; border-radius: 10px; }
.chip { color: var(--gris); }
.chip.actif { border-color: var(--accent); color: var(--accent2); background: rgba(111, 123, 240, .07); }

/* ---------- Analyse : pleine largeur ---------- */
.analyse { display: flex; flex-direction: column; gap: 22px; }
.panel { background: var(--carte); border: 1px solid var(--bordure); border-radius: var(--r); padding: 18px; }

.top-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: 22px; align-items: start; }
@media (max-width: 880px) { .top-grid { grid-template-columns: 1fr; } }

.toolbar { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; align-items: center; }
.toolbar .flex { flex: 1; }
.canvas-wrap { background: #000; border-radius: var(--r-s); overflow: hidden; line-height: 0; border: 1px solid var(--bordure); }
#cv { width: 100%; height: auto; display: block; cursor: grab; }
#cv:active { cursor: grabbing; }
.aide-glisser { color: var(--gris2); font-size: 12px; margin: 12px 2px 0; display: flex; align-items: center; gap: 7px; }

/* Section titles */
.section-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; padding: 0 2px; }
.section-head h2 { font-size: 17px; font-weight: 600; margin: 0; letter-spacing: -.01em; }
.muted { color: var(--gris2); font-size: 12.5px; }

/* ---------- Score global ---------- */
.score-panel { display: flex; flex-direction: column; gap: 18px; height: 100%; }
.overall { display: flex; align-items: center; gap: 20px; }
.ring-wrap { position: relative; width: 108px; height: 108px; flex-shrink: 0; }
.ring-wrap svg { width: 108px; height: 108px; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke: var(--carte2); stroke-width: 7; }
.ring-fg { fill: none; stroke: var(--gris2); stroke-width: 7; stroke-linecap: round; transition: stroke-dashoffset .7s var(--e), stroke var(--e); }
.ring-center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.ring-center span { font-weight: 600; font-size: 34px; line-height: 1; font-variant-numeric: tabular-nums; letter-spacing: -.02em; }
.ring-center small { color: var(--gris2); font-size: 12px; margin-top: 2px; }
.overall-label b { font-size: 19px; font-weight: 600; display: block; letter-spacing: -.01em; }
.overall-label > span { color: var(--gris2); font-size: 12.5px; }
.pill {
  display: inline-block; margin-top: 10px; font-size: 11px; font-weight: 500;
  padding: 4px 10px; border-radius: 999px; background: var(--carte2); color: var(--gris);
  border: 1px solid var(--bordure2);
}
.pill.bon { color: var(--vert); border-color: rgba(91, 186, 132, .4); background: rgba(91, 186, 132, .1); }
.pill.moyen { color: var(--orange); border-color: rgba(214, 162, 74, .4); background: rgba(214, 162, 74, .1); }
.pill.mauvais { color: var(--rouge); border-color: rgba(214, 114, 110, .4); background: rgba(214, 114, 110, .1); }

.key-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--bordure); border: 1px solid var(--bordure); border-radius: var(--r-s); overflow: hidden; }
.kstat { background: var(--carte); padding: 12px 10px; text-align: center; }
.kstat span { display: block; color: var(--gris2); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 5px; }
.kstat b { font-size: 16px; font-weight: 600; font-variant-numeric: tabular-nums; }

/* Where you stand (bell curve) */
.stand { background: var(--carte2); border: 1px solid var(--bordure); border-radius: var(--r-s); padding: 12px 14px 10px; }
.stand-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4px; }
.stand-head span { color: var(--gris2); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.stand-head b { font-size: 14px; font-weight: 600; color: var(--accent2); }
.bell { width: 100%; height: 56px; display: block; overflow: visible; }
.stand-dot { filter: drop-shadow(0 0 5px var(--accent)); }
#standMark, #standDot { transition: all .5s cubic-bezier(.4, 0, .2, 1); }
#bellArea, #bellLine { transition: d .5s cubic-bezier(.4, 0, .2, 1); }
.stand-scale { display: flex; justify-content: space-between; margin-top: 2px; }
.stand-scale span { color: var(--gris2); font-size: 9.5px; }

.comp-strip { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.chip-stat { display: flex; align-items: center; gap: 8px; background: var(--carte2); border: 1px solid var(--bordure); border-radius: 999px; padding: 6px 12px; font-size: 12px; }
.chip-stat span { color: var(--gris2); }
.chip-stat b { font-weight: 600; font-variant-numeric: tabular-nums; }
.chip-stat .swatch { width: 13px; height: 13px; border-radius: 50%; border: 1px solid var(--bordure2); background: #000; }

/* ---------- Grille des ratios ---------- */
.metrics-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; }
.m-cat {
  grid-column: 1 / -1; margin: 8px 2px 0; font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .1em; color: var(--gris2);
  display: flex; align-items: center; gap: 10px;
}
.m-cat::after { content: ""; flex: 1; height: 1px; background: var(--bordure); }
.m-cat:first-child { margin-top: 0; }
.m-cat .ti { font-size: 14px; color: var(--accent2); -webkit-text-stroke: 0; }
.m-card {
  background: var(--carte); border: 1px solid var(--bordure); border-radius: var(--r); padding: 15px 16px;
  transition: border-color var(--e), transform var(--e), box-shadow var(--e);
  animation: cardIn .42s cubic-bezier(.2, .7, .3, 1) both;
  animation-delay: calc(var(--i, 0) * 35ms);
}
.m-card:hover { border-color: var(--bordure2); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 0, 0, .25); }
@keyframes cardIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .m-card { animation: none; } }
.m-top { display: flex; justify-content: space-between; align-items: center; }
.m-name { font-size: 13px; color: var(--gris); }
.m-score { font-size: 22px; font-weight: 600; font-variant-numeric: tabular-nums; letter-spacing: -.02em; color: var(--texte); }
.m-score.ok { color: var(--vert); }
.m-score.near { color: var(--orange); }
.m-score.off { color: var(--rouge); }
.m-score em { font-size: 12px; font-style: normal; color: var(--gris2); font-weight: 400; }
.m-val { display: flex; align-items: baseline; gap: 7px; margin-top: 6px; }
.m-val b { font-size: 15px; font-weight: 600; font-variant-numeric: tabular-nums; }
.m-ref { font-size: 11px; color: var(--gris2); }
.spectrum { position: relative; height: 5px; background: var(--carte2); border-radius: 999px; margin-top: 13px; }
.sp-ideal { position: absolute; top: 0; bottom: 0; background: rgba(91, 186, 132, .25); border-radius: 999px; }
.sp-mark { position: absolute; top: 50%; width: 3px; height: 13px; border-radius: 2px; background: var(--texte); transform: translate(-50%, -50%); transition: left .5s var(--e); }
.sp-mark.ok { background: var(--vert); }
.sp-mark.near { background: var(--orange); }
.sp-mark.off { background: var(--rouge); }

/* ---------- Conseils ---------- */
.advice-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 16px; align-items: start; }
@media (max-width: 760px) { .advice-grid { grid-template-columns: 1fr; } }
.block-title { font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: var(--gris2); margin: 0 0 12px; font-weight: 600; }
.conseils-prio { display: flex; flex-direction: column; gap: 9px; }
.conseil {
  display: flex; gap: 11px; padding: 12px 14px; border-radius: var(--r-s);
  background: var(--carte2); border-left: 2px solid var(--gris2);
  font-size: 13px; line-height: 1.5; color: var(--gris);
}
.conseil.off { border-left-color: var(--rouge); }
.conseil.near { border-left-color: var(--orange); }
.conseil .ti { color: var(--gris2); font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.conseil b { font-weight: 600; color: var(--texte); }
.conseil-vide { color: var(--vert); font-size: 13px; display: flex; align-items: center; gap: 8px; }
.conseils-base { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 11px; }
.conseils-base li { display: flex; gap: 10px; font-size: 13px; color: var(--gris); line-height: 1.5; }
.conseils-base .ti { color: var(--vert); font-size: 16px; flex-shrink: 0; margin-top: 1px; }

/* ---------- SEO static content ---------- */
.seo-blurb {
  max-width: 820px; margin: 32px auto 0; padding: 32px 24px;
  border-top: 1px solid var(--bordure); color: var(--gris2); font-size: 13px; line-height: 1.7;
}
.seo-blurb h2 { font-size: 15px; font-weight: 600; color: var(--gris); margin: 0 0 10px; }
.seo-blurb h3 { font-size: 13px; font-weight: 600; color: var(--gris); margin: 20px 0 8px; }
.seo-blurb p { margin: 0 0 10px; }
.seo-blurb ul { margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 4px; }
.seo-blurb strong { color: var(--gris); font-weight: 600; }

.disclaimer { color: var(--gris2); font-size: 11.5px; line-height: 1.55; margin: 2px; display: flex; gap: 7px; max-width: 820px; }
.disclaimer .ti { flex-shrink: 0; margin-top: 1px; }
.disclaimer b { color: var(--gris); font-weight: 600; }

/* ---------- Paywall ---------- */
.pill-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
#proBadge .ti { font-size: 13px; }

/* Cartes verrouillées */
.m-card { position: relative; }
.m-card .m-lock { display: none; }
.m-card.verrou .m-body { filter: blur(6px); opacity: .55; pointer-events: none; user-select: none; }
.m-card.verrou .m-lock {
  display: grid; place-items: center; position: absolute; inset: 0; margin: 0;
  background: transparent; border: none; color: var(--accent2); cursor: pointer;
  font-size: 20px; border-radius: var(--r);
}
.m-card.verrou .m-lock:hover { background: rgba(111,123,240,.07); }
.m-card.verrou { border-color: var(--bordure2); }

/* Bannière CTA */
.paywall-cta {
  display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(111,123,240,.12), rgba(111,123,240,.04));
  border: 1px solid rgba(111,123,240,.35); border-radius: var(--r); padding: 16px 20px;
}
.pc-left { display: flex; align-items: center; gap: 14px; }
.pc-ico { width: 42px; height: 42px; border-radius: 10px; display: grid; place-items: center;
  background: rgba(111,123,240,.15); color: var(--accent2); font-size: 22px; flex-shrink: 0; }
.pc-left b { display: block; font-size: 15px; font-weight: 600; }
.pc-left span { color: var(--gris); font-size: 12.5px; }

/* Section conseils verrouillée */
.gated { position: relative; }
.gated.verrou .advice-grid { filter: blur(7px); opacity: .5; pointer-events: none; user-select: none; }
.gate-overlay { display: none; }
.gated.verrou .gate-overlay {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
  position: absolute; inset: 0; text-align: center; padding: 20px;
}
.gate-overlay .ti { font-size: 26px; color: var(--accent2); }
.gate-overlay b { font-size: 14px; font-weight: 600; }

/* Modale */
.modal { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center;
  background: rgba(5,6,8,.72); backdrop-filter: blur(3px); padding: 20px; }
.modal[hidden] { display: none; }
.modal-card {
  position: relative; width: 100%; max-width: 380px; background: var(--carte);
  border: 1px solid var(--bordure2); border-radius: var(--r-l); padding: 26px 24px;
  box-shadow: 0 24px 60px rgba(0,0,0,.5); animation: pop .18s var(--e);
}
@keyframes pop { from { transform: scale(.96); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.modal-x { position: absolute; top: 14px; right: 14px; border: none; background: transparent;
  color: var(--gris2); padding: 4px; min-height: auto; }
.modal-x:hover { color: var(--texte); background: var(--carte2); }
.pw-head { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.pw-price { font-family: "Space Grotesk", sans-serif; font-size: 46px; font-weight: 700;
  line-height: 1; color: var(--accent2); letter-spacing: -.02em; }
.pw-price span { font-size: 24px; vertical-align: top; margin-right: 1px; }
.pw-head h3 { margin: 0 0 3px; font-size: 17px; font-weight: 600; }
.pw-head p { margin: 0; color: var(--gris2); font-size: 12px; }
.pw-list { list-style: none; margin: 0 0 20px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pw-list li { display: flex; gap: 10px; font-size: 13px; color: var(--gris); line-height: 1.45; }
.pw-list .ti { color: var(--vert); font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.pw-buy { width: 100%; justify-content: center; }
.pw-restore { display: block; width: 100%; text-align: center; margin: 12px 0 0; font-size: 12.5px; }
.pw-note { color: var(--gris2); font-size: 11px; text-align: center; margin: 14px 0 0; }

/* ---------- Infobulle ---------- */
#infobulle {
  position: fixed; pointer-events: none; z-index: 60; display: none;
  background: var(--carte2); color: var(--texte); padding: 4px 9px; border-radius: 6px;
  font-size: 11.5px; transform: translate(-50%, -160%); white-space: nowrap;
  border: 1px solid var(--bordure2);
}
