/* ============================================================
   ATUM · Collecte langue baoulé — style éditorial « Nature »
   Fond blanc, serif de titres (Source Serif 4), Inter pour l'UI.
   ============================================================ */

:root{
  --bg:#ffffff;
  --ink:#1f2a28;          /* near-black, légère chaleur verte */
  --ink-soft:#3c4744;
  --muted:#727b77;
  --line:#e9e3d5;         /* filet chaud */
  --line-strong:#d8cfb9;
  --teal:#136F6C;
  --teal-deep:#0C4F4D;
  --ochre:#C98A1B;
  --terra:#B4502E;
  --cream:#FBF4E8;
  --cream-2:#F4ECD9;
  --serif:"Source Serif 4","Spectral",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --measure:42rem;
  --wide:75rem;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.72;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--wide);margin:0 auto;padding:0 clamp(1.2rem,4vw,3rem)}
.measure{max-width:var(--measure);margin-left:auto;margin-right:auto}

/* ---------- Masthead ---------- */
.topline{height:4px;background:linear-gradient(90deg,var(--teal) 0 38%,var(--ochre) 38% 62%,var(--terra) 62% 100%)}
.masthead{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:1.15rem 0 1rem;border-bottom:1px solid var(--line)}
.brand{font-family:var(--serif);font-weight:700;font-size:1.5rem;letter-spacing:.02em;color:var(--ink);text-decoration:none}
.brand .dot{color:var(--ochre)}
.brand small{display:block;font-family:var(--sans);font-weight:500;font-size:.6rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--muted);margin-top:.15rem}
.mnav{display:flex;gap:1.6rem;font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.mnav a{text-decoration:none}
.mnav a:hover{color:var(--teal)}
@media(max-width:640px){.mnav{display:none}}

/* ---------- Eyebrows / labels ---------- */
.eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--teal)}
.eyebrow.ochre{color:var(--ochre)}
.rule-short{width:46px;height:3px;background:var(--ochre);border:0;margin:1.1rem 0 0}
.secnum{font-family:var(--serif);font-style:italic;color:var(--ochre);font-size:1rem;margin-right:.5rem}

/* ---------- Headlines ---------- */
h1,h2,h3{font-family:var(--serif);color:var(--ink);font-weight:600;line-height:1.12;margin:0}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem);line-height:1.04;letter-spacing:-.015em;font-weight:600}
h2.sec{font-size:clamp(1.55rem,3vw,2.15rem);margin:.5rem 0 0}
h3{font-size:1.18rem}

/* ---------- Hero ---------- */
.hero{padding:clamp(3rem,7vw,5.5rem) 0 clamp(2.2rem,5vw,3.5rem)}
.hero .kick{display:flex;align-items:center;gap:.8rem;margin-bottom:1.5rem}
.hero h1{max-width:18ch}
.hero .lead{font-size:clamp(1.18rem,2.1vw,1.4rem);line-height:1.62;color:var(--ink-soft);
  max-width:40ch;margin:1.6rem 0 0;font-family:var(--serif);font-weight:400}
.hero .cta{margin-top:2.2rem;display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
.hero .note{font-size:.85rem;color:var(--muted)}

/* boutons */
.btn{display:inline-flex;align-items:center;gap:.55rem;border:0;cursor:pointer;
  font-family:var(--sans);font-size:.95rem;font-weight:600;letter-spacing:.01em;
  padding:.85rem 1.5rem;border-radius:2px;text-decoration:none;transition:.18s}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-deep)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn .arr{font-size:1.05em;transform:translateY(.5px)}

/* ---------- Sections ---------- */
section{padding:clamp(2.6rem,5vw,4.2rem) 0}
.section-head{margin-bottom:1.8rem}
.divider{border:0;border-top:1px solid var(--line)}

/* histoire ATUM — colonne de lecture, lettrine */
.story p{font-size:1.12rem;line-height:1.75;color:var(--ink-soft)}
.story .measure > p:first-of-type::first-letter{
  font-family:var(--serif);float:left;font-size:3.4rem;line-height:.82;font-weight:600;
  padding:.35rem .55rem 0 0;color:var(--teal)}
.pull{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.32;color:var(--ink);
  font-weight:600;border-left:3px solid var(--ochre);padding:.2rem 0 .2rem 1.4rem;margin:2rem 0}
.badge-indep{display:inline-block;background:var(--cream);color:var(--teal-deep);border:1px solid var(--line-strong);
  font-size:.74rem;font-weight:600;letter-spacing:.06em;padding:.3rem .7rem;border-radius:2px;margin-bottom:1.2rem}

/* pourquoi — bandeau crème */
.why{background:var(--cream)}
.why .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:1.6rem}
.why .cell h3{font-size:1.06rem;margin-bottom:.35rem}
.why .cell p{font-size:.97rem;color:var(--ink-soft);margin:0}
.why .num{font-family:var(--serif);font-size:1.5rem;color:var(--ochre);line-height:1}
@media(max-width:760px){.why .grid{grid-template-columns:1fr;gap:1.3rem}}

/* invitation (ennéagramme implicite) — grille 3x3 numérotée */
.invite .grid9{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:1.8rem;
  border:1px solid var(--line);border-radius:3px;overflow:hidden}
.invite .it{padding:1.25rem 1.3rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;gap:.85rem;align-items:flex-start;background:#fff}
.invite .it:nth-child(3n){border-right:0}
.invite .it:nth-last-child(-n+3){border-bottom:0}
.invite .it .n{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ochre);line-height:1;min-width:1.2rem}
.invite .it p{margin:0;font-size:.98rem;line-height:1.45;color:var(--ink-soft)}
.invite .it strong{color:var(--ink);font-weight:600}
@media(max-width:820px){.invite .grid9{grid-template-columns:1fr}
  .invite .it{border-right:0}.invite .it:nth-last-child(-n+3){border-bottom:1px solid var(--line)}
  .invite .it:last-child{border-bottom:0}}

/* comment ça marche — 3 étapes */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:1.6rem}
.step .big{font-family:var(--serif);font-size:2.6rem;color:var(--teal);line-height:1;font-weight:600}
.step h3{margin:.5rem 0 .3rem}
.step p{margin:0;color:var(--ink-soft);font-size:.98rem}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:1.3rem}}

/* ---------- Sélecteur de questionnaires ---------- */
.selector{padding-top:1rem}
.domain-block{margin-top:2.2rem}
.domain-label{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.domain-label .eyebrow{white-space:nowrap}
.domain-label .ln{flex:1;border-top:1px solid var(--line)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px}
.card{display:flex;flex-direction:column;justify-content:space-between;gap:1.1rem;
  background:#fff;border:1px solid var(--line);border-radius:3px;padding:1.15rem 1.2rem 1rem;
  text-decoration:none;transition:.16s;min-height:148px}
.card:hover{border-color:var(--teal);box-shadow:0 6px 22px -14px rgba(19,111,108,.45);transform:translateY(-2px)}
.card .ct{font-family:var(--serif);font-size:1.18rem;font-weight:600;line-height:1.22;color:var(--ink)}
.card .cd{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.card .meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.card .palier{font-size:.72rem;color:var(--teal-deep);background:var(--cream);border:1px solid var(--line-strong);
  padding:.16rem .5rem;border-radius:20px;font-weight:600}
.card .time{font-size:.8rem;color:var(--muted)}
.card .go{color:var(--teal);font-weight:700;font-size:1.15rem}

/* ---------- Éthique ---------- */
.ethics{background:var(--cream)}
.ethics .box{background:#fff;border:1px solid var(--line);border-radius:3px;padding:1.6rem 1.7rem}
.ethics p{font-size:.95rem;color:var(--ink-soft);margin:.4rem 0 0}
.ethics .tag{display:inline-block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--terra);font-weight:700;margin-bottom:.3rem}

/* ---------- Footer ---------- */
.foot{background:var(--teal-deep);color:#eaf3f2;padding:2.6rem 0 2.2rem}
.foot .row{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;align-items:flex-end}
.foot .brand{color:#fff}
.foot a{color:#cfe6e4;text-decoration:none}
.foot a:hover{color:#fff}
.foot .akpe{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:#fff}
.foot small{color:#9cc4c1;font-size:.8rem}

/* ============================================================
   PAGE QUESTIONNAIRE
   ============================================================ */
.qhead{padding:clamp(2rem,5vw,3.2rem) 0 1.4rem}
.qhead .back{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none}
.qhead .back:hover{color:var(--teal)}
.qhead h1{font-size:clamp(1.9rem,4vw,2.7rem);margin:.9rem 0 0;max-width:20ch}
.qhead .intro{font-size:1.1rem;color:var(--ink-soft);margin:1.1rem 0 0;max-width:46ch;font-family:var(--serif)}
.qmeta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:1.1rem;font-size:.82rem;color:var(--muted)}
.qmeta .pill{background:var(--cream);border:1px solid var(--line-strong);border-radius:20px;padding:.18rem .65rem;color:var(--teal-deep);font-weight:600}

/* encadré Comment lire */
.howto{background:var(--cream);border-left:3px solid var(--ochre);border-radius:3px;
  padding:1rem 1.2rem;margin:1.6rem 0 0;font-size:.93rem;color:var(--ink-soft)}
.howto b{color:var(--ink)}
.howto .ar{font-weight:700;color:var(--teal)}

/* items */
.qform{padding:1.4rem 0 2rem}
.item{border-top:1px solid var(--line);padding:1.7rem 0}
.item:first-child{border-top:0}
.item .qn{font-family:var(--serif);font-style:italic;color:var(--ochre);font-size:1rem;margin-right:.45rem}
.item .prompt{font-family:var(--serif);font-size:1.22rem;font-weight:600;color:var(--ink);line-height:1.3}
.item .sens{color:var(--muted);font-size:.92rem;margin-top:.25rem}
.item .aide{color:var(--muted);font-size:.85rem;font-style:italic;margin-top:.2rem}
.item .ans{margin-top:1rem}

label{font-size:.82rem;font-weight:600;color:var(--ink-soft);display:block;margin-bottom:.35rem;letter-spacing:.01em}
input[type=text],textarea,select,.fld{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:#fff;border:1px solid var(--line-strong);border-radius:3px;padding:.7rem .8rem;transition:.15s}
input[type=text]:focus,textarea:focus,select:focus{outline:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(19,111,108,.12)}
textarea{resize:vertical;min-height:3.2rem;line-height:1.55}
.baoule-in{background:#FFFDF7;font-size:1.08rem}

/* mélodie — choix ancrés sur des intonations françaises connues */
.melody{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem;margin-top:.3rem}
@media(min-width:680px){.melody{grid-template-columns:repeat(4,1fr)}}
.melody button{font-family:var(--sans);cursor:pointer;border:1px solid var(--line-strong);background:#fff;
  border-radius:4px;padding:.7rem .8rem;color:var(--ink-soft);transition:.14s;display:flex;flex-direction:column;
  align-items:flex-start;text-align:left;gap:.14rem;height:100%}
.melody button:hover{border-color:var(--teal);background:#fafdfc}
.melody button.on{background:var(--teal);border-color:var(--teal)}
.melody .mc{font-family:var(--serif);font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.15}
.melody .me{font-size:.92rem;color:var(--teal-deep);font-weight:600}
.melody .md{font-size:.78rem;color:var(--muted);line-height:1.25}
.melody .md b{color:var(--ochre);font-size:1rem}
.melody button.on .mc,.melody button.on .me{color:#fff}
.melody button.on .md{color:#e4f3f1}
.melody button.on .md b{color:#fff}
.melody-help{font-size:.82rem;color:var(--muted);margin-top:.4rem}

/* qcm / échelle */
.opts{display:flex;flex-direction:column;gap:.55rem}
.opt{display:flex;align-items:center;gap:.6rem;border:1px solid var(--line);border-radius:3px;padding:.6rem .8rem;cursor:pointer;transition:.14s}
.opt:hover{border-color:var(--teal);background:#fafdfc}
.opt input{accent-color:var(--teal);width:1.05rem;height:1.05rem}
.scale{display:flex;gap:.5rem;align-items:stretch;flex-wrap:wrap}
.scale .sc{flex:1;min-width:58px;text-align:center;border:1px solid var(--line-strong);border-radius:3px;
  padding:.6rem .3rem;cursor:pointer;transition:.14s;background:#fff}
.scale .sc:hover{border-color:var(--teal)}
.scale .sc.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.scale .sc .v{font-family:var(--serif);font-size:1.3rem;font-weight:600;display:block}
.scale-ends{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-top:.3rem}

/* paire minimale */
.pair{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.8rem}
.pair .w{flex:1;min-width:140px;background:var(--cream);border:1px solid var(--line-strong);border-radius:3px;
  text-align:center;padding:1rem;font-family:var(--serif);font-size:1.6rem;font-weight:600;color:var(--teal-deep)}

/* liste */
.listrows{display:flex;flex-direction:column;gap:.6rem}
.listrow{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
@media(max-width:560px){.listrow{grid-template-columns:1fr}}
.addrow{margin-top:.6rem;background:transparent;border:1px dashed var(--line-strong);color:var(--teal);
  cursor:pointer;border-radius:3px;padding:.55rem;font-weight:600;font-family:var(--sans);width:100%}
.addrow:hover{border-color:var(--teal);background:#fafdfc}

/* enregistreur audio */
.rec{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-top:.7rem;
  background:#fff;border:1px dashed var(--terra);border-radius:3px;padding:.7rem .9rem}
.rec .micbtn{cursor:pointer;border:0;border-radius:50%;width:42px;height:42px;background:var(--terra);color:#fff;
  font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:.15s;flex:none}
.rec .micbtn:hover{filter:brightness(1.07)}
.rec .micbtn.recording{background:#8c2f15;animation:pulse 1.1s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(180,80,46,.5)}50%{box-shadow:0 0 0 7px rgba(180,80,46,0)}}
.rec .lbl{font-size:.86rem;color:var(--ink-soft)}
.rec .lbl b{color:var(--terra)}
.rec audio{height:34px}
.rec .redo{font-size:.8rem;color:var(--muted);background:none;border:0;cursor:pointer;text-decoration:underline}

/* bloc référent */
.referent{background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:1.5rem 1.6rem;margin-top:1.5rem}
.referent h3{font-size:1.15rem;margin-bottom:1rem}
.rgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:560px){.rgrid{grid-template-columns:1fr}}
.consents{margin-top:1.2rem;display:flex;flex-direction:column;gap:.6rem}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;color:var(--ink-soft)}
.consent input{accent-color:var(--teal);margin-top:.2rem}

.submitbar{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-top:1.7rem}
.submitbar .btn-primary{padding:.95rem 2.2rem;font-size:1rem}
.submitbar .hint{font-size:.84rem;color:var(--muted)}

/* bandeau démo (non utilisé en final) */
.demo{background:var(--ochre);color:#3a2a05;text-align:center;font-size:.82rem;font-weight:600;
  letter-spacing:.04em;padding:.5rem 1rem}
.demo b{color:#000}

/* bandeau défilant — pays baoulé (villages & sous-groupes) */
.ticker{background:var(--ochre);overflow:hidden;white-space:nowrap;border-bottom:1px solid rgba(0,0,0,.10)}
.ticker .track{display:inline-block;padding:.5rem 0;animation:ticker 72s linear infinite;will-change:transform}
.ticker .track .nm{font-size:.8rem;font-weight:700;letter-spacing:.05em;color:#3f2d06}
.ticker .track .sep{color:#8a6614;margin:0 .65rem;font-size:.62rem;vertical-align:middle}
.ticker:hover .track{animation-play-state:paused}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.ticker .track{animation:none}}
