/* ───────────────────────────────────────────────────────────
   Kuabo Careers — careers.kuabo.co
   Design clair & lisible, animations au scroll + Lottie.
   Palette : Navy #0b1526 · Gold #e8b84b · Teal #2dd4bf
   ─────────────────────────────────────────────────────────── */
:root{
  --navy:#0b1526; --navy2:#14233a; --gold:#e8b84b; --teal:#2dd4bf;
  --ink:#16243a;        /* texte principal (foncé, lisible) */
  --muted:#52617a;      /* texte secondaire */
  --bg:#ffffff; --bg2:#f3f7fc; --line:#e4ebf3;
  --shadow:0 10px 30px rgba(11,21,38,.08);
  --shadow-h:0 18px 44px rgba(11,21,38,.16);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Nunito Sans",-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; width:100%; max-width:100%;
}
h1,h2,h3,h4{font-family:"Nunito",sans-serif;color:var(--navy);line-height:1.15;margin:0}
h1{font-size:clamp(34px,5vw,56px);font-weight:900;letter-spacing:-.5px}
h2{font-size:clamp(26px,3.4vw,38px);font-weight:900}
h3{font-size:21px;font-weight:800}
h4{font-size:18px;font-weight:800}
p{margin:.5em 0}
a{color:#0d7a8c;text-decoration:none}
.grad{background:linear-gradient(90deg,var(--gold),#f4d27a);-webkit-background-clip:text;background-clip:text;color:transparent}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}

/* i18n */
[data-lang]{display:none}
[data-lang].show{display:revert}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{max-width:1080px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:9px}
.logo img{width:40px;height:40px}
.logo b{font-family:"Nunito";font-weight:900;font-size:22px;color:var(--navy)}
.logo b span{color:var(--gold)}
.nav-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.langs{display:flex;gap:4px}
.lb{border:1px solid var(--line);background:#fff;border-radius:9px;padding:5px 9px;font-size:12.5px;font-weight:700;cursor:pointer;color:var(--muted)}
.lb.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.cta-top{background:var(--gold);color:var(--navy);font-weight:800;padding:9px 16px;border-radius:11px;font-size:14px}

/* ── BUTTONS ── */
.btn{display:inline-block;background:var(--gold);color:var(--navy);font-weight:800;font-size:16px;padding:14px 26px;border-radius:14px;box-shadow:0 6px 0 #c79a31;transition:transform .12s,box-shadow .12s}
.btn:hover{transform:translateY(2px);box-shadow:0 4px 0 #c79a31}
.btn.alt{background:#fff;color:var(--navy);border:2px solid var(--navy);box-shadow:0 6px 0 rgba(11,21,38,.18)}

/* ── HERO ── */
.hero{background:radial-gradient(1200px 500px at 80% -10%,#1b3358 0,transparent 60%),linear-gradient(160deg,#0b1526,#14233a);color:#fff;overflow:hidden}
.hero-in{max-width:1080px;margin:0 auto;padding:64px 22px 72px;display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center}
.hero h1{color:#fff}
.hero .lead{color:#c4d2e6;font-size:19px;margin:16px 0 26px;max-width:540px}
.eyebrow{display:inline-block;background:rgba(232,184,75,.16);color:var(--gold);border:1px solid rgba(232,184,75,.4);font-weight:800;font-size:13px;padding:6px 14px;border-radius:999px;margin-bottom:18px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.hero-visual{display:flex;justify-content:center;align-items:center}
.lottie-box{width:100%;max-width:360px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative}
.lottie-box .emoji{font-size:110px;animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(-8px)}50%{transform:translateY(8px)}}
lottie-player,dotlottie-wc{width:100%;height:100%}

/* ── SECTIONS ── */
.sec{padding:64px 0}
.sec.alt{background:var(--bg2)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 36px}
.sec-head .kicker{color:var(--teal);font-weight:800;letter-spacing:1px;text-transform:uppercase;font-size:13px}
.sec-head h2{margin:8px 0}
.sec-head p{color:var(--muted);font-size:18px}

/* Vision split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.split .txt p{color:var(--muted);font-size:17.5px}
.vchips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.vchip{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-weight:700;font-size:14px;color:var(--ink);box-shadow:var(--shadow)}

/* Deal */
.deal{background:linear-gradient(160deg,#13213a,#0b1526);color:#eaf1fb;border-radius:22px;padding:30px;box-shadow:var(--shadow)}
.deal h3{color:var(--gold);margin-bottom:14px}
.deal ul{margin:0;padding-left:6px;list-style:none}
.deal li{position:relative;padding-left:30px;margin:12px 0;font-size:16.5px;color:#dbe6f5}
.deal li::before{content:"✓";position:absolute;left:0;top:0;color:var(--teal);font-weight:900}

/* Roles */
.roles{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.role{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}
.role:hover{transform:translateY(-4px);box-shadow:var(--shadow-h)}
.role .top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.role .emo{font-size:30px}
.role .cnt{margin-left:auto;background:var(--navy);color:#fff;font-weight:800;font-size:12px;padding:3px 11px;border-radius:999px;white-space:nowrap}
.role p{color:var(--muted);font-size:15px;margin:0}

/* Ambassadors */
.amb{background:linear-gradient(135deg,#0b1526,#0f2e2a);color:#fff;border-radius:22px;padding:32px;box-shadow:var(--shadow)}
.amb h3{color:var(--teal)}
.amb p{color:#c7d6e6;font-size:16.5px}
.perks{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.perk{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 14px;font-size:14px;font-weight:700;color:#eaf1fb}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;text-align:center;box-shadow:var(--shadow)}
.step .n{width:46px;height:46px;border-radius:50%;background:var(--gold);color:var(--navy);font-weight:900;font-size:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.step h4{margin-bottom:6px}
.step p{color:var(--muted);font-size:15px;margin:0}

/* Video */
.video{background:linear-gradient(160deg,#13213a,#0b1526);border-radius:22px;padding:54px 22px;text-align:center;color:#c4d2e6;box-shadow:var(--shadow)}
.video .play{width:74px;height:74px;border-radius:50%;background:var(--gold);color:var(--navy);font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 8px 24px rgba(232,184,75,.4);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}

/* CTA */
.final{background:radial-gradient(800px 300px at 50% 0,#1b3358 0,transparent 60%),linear-gradient(160deg,#0b1526,#14233a);color:#fff;border-radius:24px;padding:54px 28px;text-align:center;box-shadow:var(--shadow)}
.final h2{color:#fff}.final p{color:#c4d2e6;font-size:18px;margin:10px 0 22px}
.applybtns{flex-wrap:wrap;gap:16px;justify-content:center;margin-top:6px}
.applybtns.show{display:flex}
.applybtns .btn{min-width:240px;text-align:center;font-size:16.5px;padding:16px 28px}
.applybtns .btn.alt{background:#fff;border-color:#fff;box-shadow:0 6px 0 rgba(0,0,0,.18)}
.applybtns .btn.alt:hover{box-shadow:0 4px 0 rgba(0,0,0,.18)}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:6px 18px;margin:10px 0;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:800;color:var(--navy);padding:12px 0;font-size:16.5px;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold);font-weight:900}
.faq details[open] summary::after{content:"–"}
.faq p{color:var(--muted);font-size:15.5px;padding-bottom:12px;margin:0}

/* Footer */
footer{background:var(--navy);color:#9fb0c8;text-align:center;padding:34px 22px;font-size:14px}
footer a{color:#cdd9e8;margin:0 6px}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.lottie-box .emoji,.video .play{animation:none}}

/* ── RESPONSIVE ── */
@media(max-width:820px){
  .hero-in{grid-template-columns:1fr;text-align:center}
  .hero .lead{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .hero-visual{order:-1}.lottie-box{max-width:240px}
  .split{grid-template-columns:1fr}
  .roles{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .modal-card{padding:24px 18px}
  .grid2{grid-template-columns:1fr}
}

/* ── CARTES POSTES CLIQUABLES ── */
.role{cursor:pointer;position:relative}
.role:focus-visible{outline:3px solid var(--teal);outline-offset:2px}
.applyhint{display:inline-block;margin-top:12px;color:var(--teal);font-weight:800;font-size:14px;opacity:.85;transition:transform .15s}
.role:hover .applyhint{transform:translateX(3px)}

/* ── MODAL CANDIDATURE ── */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:28px 14px}
.modal.open{display:flex}
.modal-bg{position:fixed;inset:0;background:rgba(11,21,38,.55);backdrop-filter:blur(3px)}
.modal-card{position:relative;background:#fff;border-radius:22px;max-width:560px;width:100%;padding:30px 28px 28px;box-shadow:var(--shadow-h);margin:auto;animation:popin .22s ease}
@keyframes popin{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:14px;right:14px;background:var(--bg2,#eef2f7);border:none;width:34px;height:34px;border-radius:50%;font-size:15px;cursor:pointer;color:var(--navy)}
.modal-x:hover{background:#e2e8f0}
.modal-head{text-align:center;margin-bottom:16px}
.kua-mini{font-size:34px}
.modal-head h3{margin:6px 0 2px;font-size:23px}
.modal-sub{color:var(--teal);font-weight:800;font-size:14px;margin:0}
.seg{display:flex;gap:8px;background:#eef2f7;border-radius:14px;padding:5px;margin-bottom:16px}
.seg-b{flex:1;border:none;background:transparent;font-weight:800;font-size:14px;padding:9px;border-radius:10px;cursor:pointer;color:var(--navy);font-family:inherit}
.seg-b.on{background:var(--navy);color:#fff}
.form-intro{background:#f1f8f6;border:1px solid #cdeae3;color:#0b6b58;border-radius:12px;padding:11px 14px;font-size:14px;font-weight:600;margin:0 0 16px}
.fld{display:block;margin-bottom:13px}
.fld .lab{display:block;font-weight:700;font-size:13.5px;color:var(--navy);margin-bottom:6px}
.fld .hint{display:block;font-weight:500;font-size:12.5px;color:var(--muted);margin:-2px 0 7px}
.consent a{color:var(--teal);font-weight:700;text-decoration:underline}
/* champ anti-spam (honeypot) : invisible pour les humains, visible pour les bots */
#hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
.fld input,.fld select,.fld textarea{width:100%;border:1.6px solid var(--line);border-radius:12px;padding:11px 13px;font-size:16px;font-family:inherit;color:var(--navy);background:#fff;transition:border-color .15s}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--teal)}
.fld textarea{resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* WhatsApp : indicatif + numéro */
.wa-row{display:flex;gap:10px}
.wa-row select{flex:0 0 130px;min-width:0;padding-left:9px;padding-right:4px}
.wa-row input{flex:1;min-width:0}

/* Langues : pastilles cliquables */
.checks{display:flex;flex-wrap:wrap;gap:10px}
.checks label{display:flex;align-items:center;gap:7px;font-weight:700;font-size:15px;color:var(--navy);cursor:pointer;border:1.6px solid var(--line);border-radius:999px;padding:9px 16px;user-select:none;transition:background .12s,border-color .12s,color .12s}
.checks label:has(input:checked){background:var(--navy);color:#fff;border-color:var(--navy)}
.checks input{width:auto;accent-color:var(--teal)}

/* Pays : recherche (combobox) */
.combo{position:relative}
.combo-list{position:absolute;top:100%;left:0;right:0;z-index:30;background:#fff;border:1.6px solid var(--line);border-radius:0 0 12px 12px;max-height:240px;overflow-y:auto;margin:4px 0 0;padding:0;list-style:none;box-shadow:var(--shadow-h);display:none}
.combo-list.open{display:block}
.combo-list li{padding:11px 13px;cursor:pointer;font-size:15.5px;display:flex;gap:9px;align-items:center;color:var(--navy);border-bottom:1px solid #f1f5f9}
.combo-list li:last-child{border-bottom:none}
.combo-list li:hover,.combo-list li.active{background:var(--bg2)}
.combo-list li .cflag{font-size:18px}
.consent{display:flex;align-items:flex-start;gap:9px;margin:6px 0 14px;font-size:13.5px;color:var(--muted);cursor:pointer}
.consent input{margin-top:2px}
.modal-err{color:#c0392b;font-weight:700;font-size:13.5px;margin-bottom:10px;min-height:0}
.modal-submit{width:100%;border:none;cursor:pointer;font-family:inherit}
.modal-submit:disabled{opacity:.6;cursor:default}
.apply-ok{text-align:center;padding:24px 6px}
.apply-ok .ok-emo{font-size:54px;margin-bottom:6px}
.apply-ok h3{font-size:24px;margin-bottom:8px}
.apply-ok p{color:var(--muted);font-size:16px;margin-bottom:20px}
