@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Rajdhani:wght@400;500;700&display=swap');

:root {
  --vert-fonce: #0d2b1f;
  --vert-mid: #1f4539;
  --vert-clair: #55a781;
  --or: #D8BB5D;
  --or-fonce: #a8893a;
  --texte: #a8d4bc;
  --texte-dim: #2d6b50;
  --font-mono: 'Share Tech Mono', monospace;
  --font-title: 'Rajdhani', sans-serif;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: var(--vert-fonce); color: var(--texte); font-family: var(--font-mono); min-height: 100vh; }
body::before { content:''; position:fixed; top:0;left:0;right:0;bottom:0; background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,0.05) 3px,rgba(0,0,0,0.05) 4px); pointer-events:none; z-index:9999; }
h1,h2,h3 { font-family:var(--font-title); color:var(--or); font-weight:700; }
.btn { background:transparent; border:1px solid var(--vert-clair); color:var(--vert-clair); font-family:var(--font-mono); font-size:13px; padding:8px 20px; border-radius:4px; cursor:pointer; letter-spacing:1px; transition:all 0.2s; }
.btn:hover { background:var(--vert-clair); color:var(--vert-fonce); }
.btn:disabled { opacity:0.4; cursor:not-allowed; }
.btn-or { border-color:var(--or); color:var(--or); }
.btn-or:hover { background:var(--or); color:var(--vert-fonce); }
.btn-lg { font-size:16px; padding:12px 32px; font-family:var(--font-title); font-weight:700; letter-spacing:2px; }
.card { background:var(--vert-mid); border:1px solid var(--vert-clair); border-radius:8px; padding:1.5rem; }
.tag { font-size:9px; letter-spacing:2px; color:var(--texte-dim); text-transform:uppercase; }
.divider { height:1px; background:var(--texte-dim); margin:1rem 0; opacity:0.4; }
input[type="text"],textarea { background:var(--vert-fonce); border:1px solid var(--texte-dim); border-radius:4px; color:var(--texte); font-family:var(--font-mono); font-size:13px; padding:8px 12px; width:100%; outline:none; transition:border-color 0.2s; }
input[type="text"]:focus,textarea:focus { border-color:var(--vert-clair); }
input[type="range"] { -webkit-appearance:none; width:100%; height:4px; background:var(--texte-dim); border-radius:2px; outline:none; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--vert-clair); cursor:pointer; border:2px solid var(--vert-fonce); }
.choice-btn { background:var(--vert-mid); border:1px solid var(--texte-dim); border-radius:6px; padding:10px 16px; color:var(--texte); font-family:var(--font-mono); font-size:12px; cursor:pointer; text-align:left; transition:all 0.2s; width:100%; margin-bottom:0.4rem; }
.choice-btn:hover { border-color:var(--vert-clair); color:var(--vert-clair); }
.choice-btn.selected { border-color:var(--vert-clair); background:rgba(85,167,129,0.15); color:var(--vert-clair); }
.fade-in { animation:fadeIn 0.5s ease forwards; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.pulse { animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }
.screen-header { display:flex; align-items:center; gap:1rem; padding-bottom:1rem; border-bottom:1px solid var(--texte-dim); flex-shrink:0; }
.screen-header img { width:50px; height:50px; object-fit:cover; border-radius:50%; border:1px solid var(--or); }
.prenom-badge { font-family:var(--font-title); font-size:1.2rem; color:var(--or); }
.screen-title { font-size:11px; color:var(--texte-dim); letter-spacing:2px; }
.progress-bar-wrap { background:var(--texte-dim); border-radius:2px; height:4px; opacity:0.5; flex-shrink:0; }
.progress-bar-inner { height:100%; background:var(--vert-clair); border-radius:2px; transition:width 0.4s ease; }
.nav-step { font-size:10px; color:var(--texte-dim); letter-spacing:1px; }
.choices { display:flex; flex-direction:column; gap:0.4rem; }
.vote-bar-row { display:flex; align-items:center; gap:8px; font-size:11px; margin-bottom:4px; }
.vote-bar-label { width:120px; flex-shrink:0; }
.vote-bar-track { flex:1; height:6px; background:var(--vert-fonce); border-radius:3px; overflow:hidden; border:1px solid var(--texte-dim); }
.vote-bar-fill { height:100%; background:var(--vert-clair); border-radius:3px; transition:width 0.6s ease; }
.vote-count { font-size:10px; color:var(--or); width:20px; text-align:right; }
.axe-vote-q { background:var(--vert-mid); border:1px solid var(--texte-dim); border-radius:8px; padding:1rem; margin-bottom:0.75rem; }
.axe-vote-label { font-size:12px; color:var(--texte); margin-bottom:0.75rem; }
