:root{
  --bg:#fbf8f4;
  --surface:#ffffff;
  --ink:#2a2622;
  --ink-2:#79716a;
  --line:#ece6df;

  --blue:#2d8cff;     --blue-ink:#1366d6;
  --coral:#ff7a3d;    --coral-ink:#e85f20;
  --purple:#8a5cff;   --purple-ink:#6f3fe6;
  --green:#34c759;
  --amber:#f5a623;
  --gold:#e9a72c;     --gold-soft:#fdf0d2;

  --radius:20px; --radius-sm:13px;
  --shadow:0 1px 2px rgba(40,30,20,.04), 0 10px 34px rgba(40,30,20,.07);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --ease:cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;
}
h1,h2{letter-spacing:-.02em;margin:0}
a{color:var(--blue-ink);text-decoration:none}
button{font-family:inherit}
em{font-style:normal;font-weight:700}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  border:1px solid transparent;border-radius:999px;padding:.8em 1.3em;font-size:1rem;font-weight:700;
  cursor:pointer;transition:transform .15s var(--spring),background .2s,box-shadow .2s;
  background:#f0ece6;color:var(--ink)}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 6px 16px rgba(45,140,255,.28)}
.btn-primary:hover{background:var(--blue-ink)}
.btn-accent{background:var(--coral);color:#fff;box-shadow:0 6px 16px rgba(255,122,61,.3)}
.btn-accent:hover{background:var(--coral-ink)}
.btn-block{width:100%}
.btn-ghost{background:transparent;border-color:var(--line);font-weight:600;padding:.5em .95em;font-size:.85rem}
.btn-ghost:hover{background:#f6f1ec}
.btn-ghost.danger{color:#d23b2e;border-color:#f3c9c4}
.btn-wa{background:#25d366;color:#fff;font-size:.82rem;padding:.45em .85em;box-shadow:none}
.btn-wa:hover{background:#1eb558}

/* ---------- Auth ---------- */
.auth-body{display:grid;place-items:center;min-height:100dvh;padding:24px;
  background:radial-gradient(120% 80% at 50% -10%, #ffe9d6 0%, var(--bg) 55%)}
.auth{width:100%;max-width:390px}
.brand{text-align:center;margin-bottom:22px}
.brand-mark{font-size:46px;line-height:1}
.brand h1{font-size:1.8rem;margin-top:8px}
.brand-sub{color:var(--ink-2);margin:6px 0 0}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px}
.tabs{display:flex;background:#f3ede6;border-radius:999px;padding:4px;margin-bottom:18px}
.tab{flex:1;text-align:center;padding:.6em 0;border-radius:999px;color:var(--ink-2);font-weight:700;font-size:.92rem}
.tab.is-active{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.form{display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field>span{font-size:.84rem;font-weight:700;color:var(--ink-2)}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.75em .85em;font-size:1rem;background:#fff;color:var(--ink);
  transition:border-color .15s,box-shadow .15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--coral);
  box-shadow:0 0 0 4px rgba(255,122,61,.16)}
.fineprint{font-size:.82rem;color:var(--ink-2);text-align:center;margin:16px 0 0}
.alert{background:#fff1ef;border:1px solid #ffd4cd;color:#c23a2b;
  padding:.8em 1em;border-radius:var(--radius-sm);font-size:.92rem;margin:0 0 16px}
.alert.ok{background:#eafaef;border-color:#c7eed1;color:#1d8a3c}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:10;background:rgba(251,248,244,.82);
  backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line)}
.topbar-in{max-width:660px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 20px}
.topbar-title{font-weight:800;font-size:.98rem}
.topbar-nav{display:flex;gap:16px;font-size:.9rem}
.topbar-nav a{color:var(--ink-2);font-weight:600}
.topbar-nav a:hover{color:var(--ink)}

/* ---------- Page ---------- */
.page{max-width:660px;margin:0 auto;padding:24px 20px 90px}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(135deg,#fff1e6 0%,#ffe4ef 50%,#eae6ff 100%);
  border:1px solid #f3e3d8;border-radius:24px;padding:26px 24px;margin-bottom:22px}
.hero-hi{margin:0;font-weight:700;color:var(--coral-ink)}
.hero-title{font-size:2rem;margin:6px 0 8px;line-height:1.1}
.hero-sub{margin:0;color:#5d564f;font-size:1.05rem}

/* ---------- Comment ça marche ---------- */
.how{margin-bottom:30px}
.how-title{font-size:1.05rem;color:var(--ink-2);margin-bottom:12px}
.steps{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.step{display:flex;gap:14px;align-items:flex-start;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;border-left-width:5px}
.step-1{border-left-color:var(--coral)}
.step-2{border-left-color:var(--purple)}
.step-3{border-left-color:var(--gold)}
.step-num{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;color:#fff;font-size:.95rem}
.step-1 .step-num{background:var(--coral)}
.step-2 .step-num{background:var(--purple)}
.step-3 .step-num{background:var(--gold)}
.step-txt{color:var(--ink-2);font-size:.92rem}

/* ---------- Blocs ---------- */
.block{margin-top:34px}
.block-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.block-tag{display:inline-block;font-size:.72rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;padding:.22em .7em;border-radius:999px;margin-bottom:8px}
.tag-1{background:#ffe7d8;color:var(--coral-ink)}
.tag-2{background:#ece2ff;color:var(--purple-ink)}
.tag-3{background:var(--gold-soft);color:#a9760a}
.block-title{font-size:1.3rem}
.block-help{color:var(--ink-2);margin:6px 0 16px;font-size:.96rem}
.muted{color:var(--ink-2)}

/* ---------- État vide ---------- */
.empty{text-align:center;display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:20px}
.empty-emoji{font-size:40px}
.empty-title{font-weight:700;font-size:1.1rem;margin:0}

/* ---------- Date retenue ---------- */
.final{text-align:center;margin:8px 0 6px;border:2px solid var(--gold);
  background:linear-gradient(180deg,#fff8ea,#fff)}
.final-badge{display:inline-block;background:var(--gold);color:#fff;font-size:.74rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.05em;padding:.35em .8em;border-radius:999px}
.final-date{font-size:1.5rem;font-weight:800;margin:12px 0 4px}
.final-note{color:var(--ink-2);margin:0}

/* ---------- Bulletin ---------- */
.ballot{display:flex;flex-direction:column;gap:12px}
.ballot-row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;flex-wrap:wrap;transition:border-color .2s,box-shadow .2s}
.ballot-row.answered{border-color:#d7ecdd;box-shadow:0 0 0 3px rgba(52,199,89,.08)}
.ballot-when{display:flex;flex-direction:column;min-width:0}
.ballot-day{font-weight:700;text-transform:capitalize;font-size:1.05rem}
.ballot-meta{font-size:.84rem;color:var(--ink-2)}
.by{display:inline-block;background:#f3ede6;color:var(--ink-2);font-size:.74rem;
  padding:.1em .5em;border-radius:999px;margin-left:4px}
.choices{display:flex;gap:6px;background:#f3ede6;padding:5px;border-radius:999px}
.choice{border:none;background:transparent;border-radius:999px;padding:.55em .95em;
  font-size:.9rem;font-weight:700;color:var(--ink-2);cursor:pointer;white-space:nowrap;
  transition:all .18s var(--spring)}
.choice:hover{color:var(--ink)}
.choice.on{background:#fff;box-shadow:0 1px 5px rgba(0,0,0,.14)}
.choice-yes.on{color:var(--green);box-shadow:0 0 0 2px rgba(52,199,89,.35),0 1px 5px rgba(0,0,0,.12)}
.choice-maybe.on{color:#cf8a12;box-shadow:0 0 0 2px rgba(245,166,35,.35),0 1px 5px rgba(0,0,0,.12)}
.choice-no.on{color:#c23a2b;box-shadow:0 0 0 2px rgba(194,58,43,.28),0 1px 5px rgba(0,0,0,.12)}

/* ---------- Proposer ---------- */
.propose{border:2px dashed #e7d4c4;background:#fffdfb}
.propose-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.propose-grid .field{flex:1 1 130px}
.propose-grid .field.grow{flex:2 1 200px}

/* ---------- Live + classement ---------- */
.live{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;color:var(--ink-2);
  background:#fff;border:1px solid var(--line);padding:.35em .7em;border-radius:999px;white-space:nowrap}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.6s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,199,89,.5)}70%{box-shadow:0 0 0 8px rgba(52,199,89,0)}100%{box-shadow:0 0 0 0 rgba(52,199,89,0)}}
.board-caption{min-height:1.4em;color:var(--gold);font-weight:800;font-size:1rem;margin:0 0 16px;transition:opacity .3s}
.board{position:relative;display:flex;flex-direction:column;gap:14px}
.voters{margin:16px 0 0;font-weight:700;color:var(--blue-ink)}

.bar-row{position:relative;transition:transform .55s var(--spring)}
.bar-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:7px}
.bar-name{font-weight:700;text-transform:capitalize;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bar-rank{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;
  background:#f0ece6;color:var(--ink-2);font-size:.78rem;font-weight:800}
.bar-row.leader .bar-rank{background:var(--gold);color:#fff}
.crown{font-size:1.05rem}
.bar-counts{font-size:.82rem;color:var(--ink-2);font-weight:600;text-transform:none}
.bar-track{height:16px;background:#efe9e2;border-radius:999px;overflow:hidden}
.bar-fill{height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,#7fd99a,var(--green));transition:width .8s var(--spring)}
.bar-row.leader .bar-fill{background:linear-gradient(90deg,#f6cf7a,var(--gold))}
.bar-row.leader{background:var(--gold-soft);margin:0 -12px;padding:14px 12px;border-radius:16px}
.bar-row.leader .bar-track{background:#fff}
.tag{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  background:var(--gold);color:#fff;padding:.18em .6em;border-radius:999px}

/* ---------- Échéance ---------- */
.deadline{display:flex;gap:12px;align-items:flex-start;border-radius:var(--radius);
  padding:14px 16px;margin-bottom:8px;border:1px solid}
.deadline-ico{font-size:1.4rem;line-height:1.3}
.deadline.open{background:#eef6ff;border-color:#cfe4ff;color:#0d4f96}
.deadline.closed{background:#f3efe9;border-color:var(--line);color:#6a6258}
.deadline-sub{font-size:.9rem;opacity:.9}

/* ---------- État verrouillé ---------- */
.choice:disabled{cursor:default}
.choice:disabled:not(.on){opacity:.38}
.ballot.locked .choices{background:#efe9e2}

/* ---------- Confettis ---------- */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:50;overflow:hidden}
.confetti i{position:absolute;top:-12px;width:9px;height:13px;border-radius:2px;opacity:.92;animation:fall linear forwards}
@keyframes fall{to{transform:translateY(106vh) rotate(560deg);opacity:0}}

/* ---------- Admin ---------- */
.admin .card{margin-bottom:20px}
.sub{font-size:.98rem;font-weight:700;margin:20px 0 2px}
.status{font-size:1rem;font-weight:600;margin:0 0 6px}
.status.open{color:#1d8a3c}
.status.closed{color:#b3261e}
code{background:#f3ede6;padding:.1em .4em;border-radius:6px;font-size:.88em}
.sub:first-of-type{margin-top:14px}
.field select{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.75em .85em;font-size:1rem;background:#fff;color:var(--ink);appearance:none;
  transition:border-color .15s,box-shadow .15s}
.field select:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,122,61,.16)}
.form.inline{flex-direction:row;flex-wrap:wrap;align-items:flex-end;gap:12px}
.form.inline .field{flex:0 0 auto}
.form.inline .field.grow{flex:1 1 160px}
.table{width:100%;border-collapse:collapse;margin-top:14px;font-size:.92rem}
.table th{text-align:left;color:var(--ink-2);font-weight:700;font-size:.8rem;
  border-bottom:1px solid var(--line);padding:8px 10px}
.table td{border-bottom:1px solid var(--line);padding:10px;vertical-align:middle}
.table tr.is-chosen{background:var(--gold-soft)}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.row-actions form{display:inline}
.pill{display:inline-block;background:var(--gold);color:#fff;font-size:.68rem;font-weight:800;
  padding:.12em .55em;border-radius:999px;vertical-align:middle}
.share-box{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:8px}

@media (max-width:520px){
  .hero-title{font-size:1.7rem}
  .ballot-row{flex-direction:column;align-items:stretch}
  .choices{justify-content:space-between}
  .choice{flex:1;text-align:center}
  .block-head{flex-direction:column}
  .form.inline{flex-direction:column;align-items:stretch}
  .form.inline .field{flex:1 1 auto}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
