/* =========================================================
   CITYZ'Formation Côte d'Ivoire — style.css
   Charte : orange #F47B20 · vert #3E9245 · crème · encre
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root{
  --orange:#F47B20; --orange-dk:#E06A10; --orange-soft:#FFF1E6;
  --green:#3E9245; --green-dk:#2F7536; --green-soft:#EDF6EC;
  --green-lt:#71BC44;
  --cream:#F4EFE3; --cream-2:#FBF8F1;
  --ink:#241F1A; --ink-2:#332D26; --ink-soft:#4a443d;
  --grey:#6a635b; --grey-lt:#9a938a;
  --line:#ece4d6; --line-2:#e3d9c8;
  --white:#fff;
  --maxw:1200px;
  --r:16px; --r-lg:24px; --r-sm:10px;
  --sh:0 24px 60px -28px rgba(36,31,26,.32);
  --sh-sm:0 10px 26px -14px rgba(36,31,26,.28);
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Poppins',system-ui,Arial,sans-serif;color:var(--ink-soft);background:#fff;
  line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
h1,h2,h3,h4,h5{line-height:1.18;color:var(--ink);font-weight:700}
::selection{background:var(--orange);color:#fff}

/* ---- tricolor signature ---- */
.flag{height:5px;background:linear-gradient(90deg,var(--orange) 0 33.33%,var(--cream) 33.33% 66.66%,var(--green) 66.66% 100%)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.section{padding:96px 0}
.section.tight{padding:72px 0}
.bg-cream{background:var(--cream-2)}
.bg-ink{background:var(--ink);color:#e8e2d8}
.center{text-align:center}

/* ---- eyebrow + titles ---- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.74rem;font-weight:700;
  letter-spacing:.17em;text-transform:uppercase;color:var(--orange);margin-bottom:16px}
.eyebrow::before{content:'';width:26px;height:2px;background:var(--orange);border-radius:2px}
.eyebrow.g{color:var(--green)}.eyebrow.g::before{background:var(--green)}
.bg-ink .eyebrow{color:var(--green-lt)}.bg-ink .eyebrow::before{background:var(--green-lt)}
.h-xl{font-size:clamp(2.1rem,4.2vw,3.3rem);font-weight:800;letter-spacing:-.02em}
.h-lg{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:800;letter-spacing:-.01em}
.h-md{font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:700}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
.o{color:var(--orange)} .g{color:var(--green)}
.lead{font-size:1.08rem;color:var(--grey);max-width:640px;line-height:1.75}
.center .lead{margin-inline:auto}
.head{max-width:720px;margin-bottom:56px}
.head.center{margin-inline:auto}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.97rem;
  padding:13px 28px;border-radius:50px;border:2px solid transparent;cursor:pointer;
  transition:transform .22s var(--ease),box-shadow .22s,background .22s,color .22s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 12px 24px -12px rgba(244,123,32,.75)}
.btn-primary:hover{background:var(--orange-dk);transform:translateY(-2px)}
.btn-ghost{border-color:var(--green);color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{transform:translateY(-2px);background:var(--ink-2)}
.btn-white{background:#fff;color:var(--ink)}.btn-white:hover{transform:translateY(-2px);box-shadow:var(--sh-sm)}
.btn-lg{padding:16px 34px;font-size:1.04rem}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--orange);font-size:.95rem}
.link-arrow svg{width:17px;height:17px;transition:transform .2s}
.link-arrow:hover svg{transform:translateX(4px)}
.link-arrow.g{color:var(--green)}

/* ---- header ---- */
.hd{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0;padding-right:8px}
.brand img{height:44px;flex-shrink:0}
.brand b{font-size:1rem;font-weight:800;color:var(--ink);line-height:1.08;display:block;white-space:nowrap}
.brand small{font-size:.6rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--green);white-space:nowrap}
.menu{display:flex;align-items:center;gap:4px;flex-shrink:0}
.menu a{font-size:.95rem;font-weight:500;color:var(--ink);padding:9px 16px;border-radius:50px;transition:.2s}
.menu a:hover{background:var(--cream)}
.menu a.active{color:var(--orange);font-weight:600}
.menu .btn{margin-left:10px}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;flex-direction:column;
  gap:5px;align-items:center;justify-content:center}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---- hero ---- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:104px 0 116px}
.hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(820px 460px at 80% 12%,rgba(244,123,32,.22),transparent 58%),
            radial-gradient(720px 420px at 8% 96%,rgba(62,146,69,.24),transparent 60%)}
.hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:5px;
  background:linear-gradient(90deg,var(--orange) 0 33.33%,var(--cream) 33.33% 66.66%,var(--green) 66.66% 100%)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.badge-pill{display:inline-flex;align-items:center;gap:9px;font-size:.78rem;font-weight:700;letter-spacing:.13em;
  text-transform:uppercase;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  padding:8px 16px;border-radius:50px;margin-bottom:24px}
.badge-pill .d{width:7px;height:7px;border-radius:50%;background:var(--orange)}
.hero h1{font-size:clamp(2.3rem,4.7vw,3.7rem);font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:22px}
.hero h1 .o{color:var(--orange)} .hero h1 .g{color:var(--green-lt)}
.hero p.sub{font-size:1.14rem;color:#d6cfc4;max-width:540px;margin-bottom:34px}
.hero-cta{display:flex;gap:15px;flex-wrap:wrap}
.hero-vis{position:relative;display:flex;align-items:center;justify-content:center}
.medallion{position:relative;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#fff,var(--cream));display:flex;align-items:center;justify-content:center;
  box-shadow:0 44px 100px -34px rgba(0,0,0,.66)}
.medallion::after{content:'';position:absolute;inset:-16px;border-radius:50%;border:2px dashed rgba(255,255,255,.2)}
.medallion img{width:214px}
.chip{position:absolute;background:#fff;color:var(--ink);border-radius:14px;padding:11px 15px;
  box-shadow:var(--sh);display:flex;align-items:center;gap:10px;font-size:.84rem;font-weight:600}
.chip b{font-size:1.15rem;font-weight:800}
.chip .ci{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chip.c1{top:14px;left:-14px}.chip.c2{bottom:54px;right:-18px}.chip.c3{bottom:-4px;left:54px}

/* ---- trust strip ---- */
.trust{background:var(--orange);color:#fff;padding:0}
.trust .wrap{display:flex;flex-wrap:wrap;gap:10px 40px;justify-content:center;padding-block:18px}
.trust span{display:inline-flex;align-items:center;gap:10px;font-size:.92rem;font-weight:600}
.trust svg{width:18px;height:18px}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 20px;text-align:center;
  position:relative;overflow:hidden;transition:transform .28s var(--ease),box-shadow .28s}
.stat::before{content:'';position:absolute;inset:0 0 auto 0;height:4px}
.stat::before{background:var(--green)}
.stat:hover{transform:translateY(-5px);box-shadow:var(--sh-sm)}
.stat .n{font-size:2.4rem;font-weight:800;line-height:1}
.stat .n{color:var(--green)}
.stat .l{font-size:.83rem;color:var(--grey);margin-top:9px;line-height:1.4}

/* ---- generic grids/cards ---- */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;
  transition:transform .28s var(--ease),box-shadow .28s,border-color .28s}
.card.hover:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:transparent}
.ico{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.ico svg{width:27px;height:27px}
.ico.o{background:var(--orange-soft)}.ico.gn{background:var(--green-soft)}
.card h3{font-size:1.18rem;margin-bottom:10px}
.card p{color:var(--grey);font-size:.96rem}

/* ---- value row ---- */
.vrow{display:flex;gap:14px;align-items:flex-start;padding:11px 0}
.vrow .ck{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--green-soft);
  display:flex;align-items:center;justify-content:center;margin-top:2px}
.vrow .ck svg{width:15px;height:15px}
.vrow p{font-size:.99rem;color:var(--ink-soft)}.vrow b{color:var(--ink)}

/* ---- steps (admin) ---- */
.steps{display:flex;flex-direction:column;gap:0;position:relative;margin-left:8px}
.step{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:0 0 36px;position:relative}
.step:last-child{padding-bottom:0}
.step::before{content:'';position:absolute;left:31px;top:60px;bottom:-6px;width:2px;background:var(--line-2)}
.step:last-child::before{display:none}
.step .num{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.3rem;color:#fff;position:relative;z-index:2}
.step:nth-child(4n+1) .num{background:var(--orange)}.step:nth-child(4n+2) .num{background:var(--green)}
.step:nth-child(4n+3) .num{background:var(--orange)}.step:nth-child(4n) .num{background:var(--green)}
.step .ct{padding-top:6px}
.step h3{font-size:1.2rem;margin-bottom:7px}
.step p{color:var(--grey);font-size:.97rem}

/* ---- formation cards (catalogue) ---- */
.fcat{display:flex;flex-direction:column;gap:30px}
.fc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-sm);scroll-margin-top:100px}
.fc-head{display:flex;align-items:center;gap:20px;padding:30px 36px;position:relative;color:#fff;overflow:hidden}
.fc:nth-child(odd) .fc-head{background:linear-gradient(120deg,var(--green),var(--green-dk))}
.fc:nth-child(even) .fc-head{background:linear-gradient(120deg,var(--green),var(--green-dk))}
.fc-head::after{content:'';position:absolute;right:0;top:0;bottom:0;width:120px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1))}
.fc-head .fi{width:62px;height:62px;border-radius:16px;background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-head .fi svg{width:32px;height:32px}
.fc-head h3{color:#fff;font-size:1.5rem;line-height:1.15}
.fc-head .s{color:rgba(255,255,255,.92);font-size:.94rem;margin-top:4px}
.fc-head .ref{margin-left:auto;background:rgba(0,0,0,.18);font-size:.78rem;font-weight:700;
  padding:6px 14px;border-radius:50px;letter-spacing:.04em;z-index:2;white-space:nowrap}
.fc-body{display:grid;grid-template-columns:1.25fr 1fr;gap:0}
.fc-main{padding:30px 36px;border-right:1px solid var(--line)}
.fc-main p.desc{color:var(--grey);margin-bottom:22px}
.fc-main h4,.fc-side h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:13px;font-weight:700}
.objlist li{display:flex;gap:11px;align-items:flex-start;padding:6px 0;font-size:.96rem;color:var(--ink-soft)}
.objlist li svg{flex-shrink:0;width:19px;height:19px;margin-top:3px}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.tag{background:var(--cream);border:1px solid var(--line);color:var(--green);font-size:.78rem;font-weight:600;
  padding:6px 13px;border-radius:50px}
.fc-side{padding:30px 32px;background:var(--cream-2)}
.spec{display:flex;flex-direction:column}
.spec .row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.spec .row:last-of-type{border-bottom:none}
.spec .row .k{color:var(--grey);flex-shrink:0}
.spec .row .v{color:var(--ink);font-weight:600;text-align:right}
.fc-side .btn{width:100%;justify-content:center;margin-top:18px}
.fc-side .access{margin-top:14px;font-size:.8rem;color:var(--grey);display:flex;gap:8px;align-items:flex-start}
.fc-side .access svg{width:15px;height:15px;flex-shrink:0;margin-top:2px;color:var(--green)}

/* ---- info banner ---- */
.note{background:var(--green-soft);border:1px solid #cfe6cf;border-left:4px solid var(--green);
  border-radius:var(--r-sm);padding:20px 24px;font-size:.94rem;color:var(--ink-soft);
  display:flex;gap:13px;align-items:flex-start}
.note b{color:var(--green-dk)}
.note>svg{width:22px;height:22px;flex-shrink:0;margin-top:2px}

/* ---- CTA banner ---- */
.cta{position:relative;background:linear-gradient(125deg,var(--ink),var(--ink-2));border-radius:var(--r-lg);
  padding:62px;text-align:center;color:#fff;overflow:hidden}
.cta::before,.cta::after{content:'';position:absolute;top:0;bottom:0;width:8px}
.cta::before{left:0;background:linear-gradient(180deg,var(--green) 0 50%,var(--orange) 50% 100%)}
.cta::after{right:0;background:linear-gradient(180deg,var(--orange) 0 50%,var(--green) 50% 100%)}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:#cfc7bc;max-width:560px;margin:0 auto 28px}

/* ---- page hero (interior) ---- */
.phero{background:var(--ink);color:#fff;padding:76px 0;position:relative;overflow:hidden}
.phero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(620px 320px at 86% 16%,rgba(244,123,32,.2),transparent 58%),
            radial-gradient(520px 300px at 8% 92%,rgba(62,146,69,.22),transparent 60%)}
.phero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:5px;
  background:linear-gradient(90deg,var(--orange) 0 33.33%,var(--cream) 33.33% 66.66%,var(--green) 66.66% 100%)}
.phero .in{position:relative}
.crumb{font-size:.84rem;color:var(--green-lt);margin-bottom:16px;display:flex;gap:8px;align-items:center}
.crumb a:hover{color:#fff}
.phero h1{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;margin-bottom:13px}
.phero p{color:#cfc7bc;max-width:620px;font-size:1.06rem}

/* ---- contact ---- */
.cinfo{display:flex;flex-direction:column;gap:13px}
.cline{display:flex;gap:15px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.cline .ci{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cline .lab{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--green)}
.cline .val{font-weight:500;color:var(--ink)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);overflow:hidden}
.form-hd{background:var(--ink);padding:26px 32px;color:#fff}
.form-hd h3{color:#fff;font-size:1.3rem}
.form-hd p{color:#cfc7bc;font-size:.9rem;margin-top:4px}
.form form{padding:30px 32px;display:flex;flex-direction:column;gap:17px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{font-size:.85rem;font-weight:600;color:var(--ink)}
.fg input,.fg select,.fg textarea{padding:13px 15px;border:1px solid var(--line-2);border-radius:10px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(244,123,32,.13)}
.fg textarea{resize:vertical;min-height:96px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:var(--grey)}
.consent input{margin-top:4px;width:16px;height:16px;flex-shrink:0;accent-color:var(--orange)}
.req{color:var(--orange)}
.form-note{display:none;background:var(--green-soft);border:1px solid var(--green);color:var(--green-dk);
  padding:13px 16px;border-radius:10px;font-size:.92rem;font-weight:500}
.form-note.show{display:block}
.map-wrap{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-sm);position:relative}
.map-wrap .pinbtn{position:absolute;right:16px;bottom:16px;background:#fff;color:var(--ink);font-weight:600;
  font-size:.85rem;padding:10px 16px;border-radius:50px;box-shadow:var(--sh-sm);display:inline-flex;align-items:center;gap:8px}
.map-wrap .pinbtn svg{width:16px;height:16px}

/* ---- footer ---- */
.ft{background:var(--ink);color:#cfc7bc;padding:66px 0 0}
.ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1.3fr;gap:44px;padding-bottom:46px}
.ft-logo{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.ft-badge{width:54px;height:54px;border-radius:15px;background:linear-gradient(160deg,#fff,var(--cream));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 20px -10px rgba(0,0,0,.5)}
.ft-badge img{height:38px;margin:0}
.ft-name b{display:block;color:#fff;font-size:1.08rem;font-weight:800;line-height:1.05}
.ft-name small{display:block;color:var(--green-lt);font-size:.64rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-top:2px}
.ft p{font-size:.92rem;color:#aaa39a;max-width:300px}
.ft .quote{font-style:italic;color:#cfc7bc;margin-top:14px;border-left:3px solid var(--orange);padding-left:14px}
.ft h5{color:#fff;font-size:.95rem;font-weight:700;margin-bottom:16px}
.ft-links a{display:block;font-size:.92rem;padding:6px 0;color:#cfc7bc;transition:.2s}
.ft-links a:hover{color:var(--orange);padding-left:5px}
.ft-c li{display:flex;gap:11px;align-items:flex-start;font-size:.92rem;padding:6px 0}
.ft-c svg{width:17px;height:17px;flex-shrink:0;margin-top:3px;color:var(--orange)}
.socials{display:flex;gap:11px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;
  align-items:center;justify-content:center;transition:.25s}
.socials a:hover{background:var(--orange);transform:translateY(-3px)}
.socials svg{width:18px;height:18px;fill:#fff}
.socials.brand a{background:var(--cream);border:1px solid var(--line)}
.socials.brand svg{fill:var(--orange)}
.socials.brand a:hover{background:var(--orange)}.socials.brand a:hover svg{fill:#fff}
.ft-bot{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;justify-content:space-between;
  align-items:center;gap:14px;flex-wrap:wrap;font-size:.84rem;color:#8a847c}

/* ---- reveal ---- */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}

/* ---- responsive ---- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:44px}.hero-vis{order:-1}
  .medallion{width:280px;height:280px}.medallion img{width:172px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr 1fr}
  .fc-body{grid-template-columns:1fr}.fc-main{border-right:none;border-bottom:1px solid var(--line)}
  .ft-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .section{padding:64px 0}
  .menu{position:fixed;inset:78px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:8px 20px 22px;border-bottom:1px solid var(--line);box-shadow:var(--sh);
    transform:translateY(-130%);transition:transform .35s var(--ease)}
  .menu.open{transform:translateY(0)}
  .menu a{padding:14px 12px;border-bottom:1px solid var(--line);border-radius:0}
  .menu .btn{margin:14px 0 0;justify-content:center}
  .burger{display:flex}
  .g2,.g3,.f2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .cta{padding:44px 26px}
  .ft-grid{grid-template-columns:1fr}.ft-bot{flex-direction:column;text-align:center}
  .step{grid-template-columns:52px 1fr;gap:18px}.step .num{width:50px;height:50px;font-size:1.1rem}
  .step::before{left:25px}
}

/* =========================================================
   V2 — REFONTE « MODERNE & CHALEUREUX / HUMAIN »
   (surcharge ciblée, charte CI strictement respectée)
   ========================================================= */
:root{
  --r:20px; --r-lg:30px; --r-sm:14px; --r-xl:40px;
  --peach:#FFF6EE; --peach-2:#FDEFE2;
  --sh-soft:0 30px 70px -36px rgba(193,108,40,.28);
  --sh-warm:0 18px 44px -22px rgba(244,123,32,.28);
}
body{background:var(--cream-2)}

/* ---- décor organique réutilisable ---- */
.blob{position:absolute;border-radius:46% 54% 60% 40%/52% 44% 56% 48%;filter:blur(2px);z-index:0;pointer-events:none}

/* ---- HERO clair & chaleureux ---- */
.hero{background:linear-gradient(170deg,var(--peach) 0%,var(--cream-2) 58%,#fff 100%);color:var(--ink);
  padding:96px 0 120px}
.hero::before{content:'';position:absolute;inset:0;z-index:0;
  background:
   radial-gradient(620px 420px at 88% 8%,rgba(244,123,32,.18),transparent 60%),
   radial-gradient(560px 420px at 4% 92%,rgba(62,146,69,.16),transparent 62%)}
.hero::after{height:6px}
.hero-grid{z-index:2}
.hero h1{color:var(--ink)}
.hero h1 .o{color:var(--orange)}.hero h1 .g{color:var(--green-dk)}
.hero p.sub{color:var(--ink-soft)}
.hero .badge-pill{background:#fff;border:1px solid var(--line-2);color:var(--ink-soft);
  box-shadow:var(--sh-sm)}
.hero .badge-pill .d{background:var(--green)}
.hero .btn-white{background:#fff;border-color:var(--line-2);color:var(--ink);box-shadow:var(--sh-sm)}
.hero .btn-white:hover{border-color:var(--green);color:var(--green-dk)}

/* médaillon plus doux + halo tricolore organique */
.hero-vis::before{content:'';position:absolute;width:400px;height:400px;z-index:0;
  border-radius:46% 54% 62% 38%/50% 42% 58% 50%;
  background:conic-gradient(from 200deg,var(--orange),var(--green-lt),var(--green),var(--orange));
  opacity:.16;animation:floaty 9s var(--ease) infinite alternate}
.medallion{width:360px;height:360px;background:radial-gradient(circle at 50% 36%,#fff,var(--peach-2));
  box-shadow:0 50px 90px -40px rgba(193,108,40,.5),inset 0 2px 0 #fff;
  border-radius:48% 52% 56% 44%/52% 48% 52% 48%}
.medallion::after{inset:-14px;border:2px dashed rgba(244,123,32,.3)}
.medallion img{width:230px}
.chip{border-radius:18px;box-shadow:var(--sh-soft);border:1px solid var(--line)}
@keyframes floaty{from{transform:translateY(-10px) rotate(-3deg)}to{transform:translateY(12px) rotate(3deg)}}

/* ---- sections : douceur ---- */
.section.soft{background:
  radial-gradient(900px 360px at 100% 0,var(--peach),transparent 60%),var(--cream-2)}
.bg-cream{background:linear-gradient(180deg,#fff,var(--cream-2))}

/* cartes plus rondes, ombres chaudes */
.card{border-radius:var(--r-lg);border-color:var(--line);box-shadow:0 10px 30px -22px rgba(36,31,26,.3)}
.card.hover:hover{box-shadow:var(--sh-soft);transform:translateY(-6px)}
.ico{border-radius:18px}
.stat{border-radius:var(--r-lg)}
.ico.o{background:var(--peach-2)}

/* ---- bande de confiance : pilule flottante au lieu d'un bloc plein ---- */
.trust{background:transparent;margin-top:-46px;position:relative;z-index:5}
.trust .wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-soft);padding:22px 30px;gap:14px 36px}
.trust span{color:var(--ink-soft)}
.trust svg{stroke:var(--orange)}
.trust span:nth-child(2) svg{stroke:var(--green)}

/* ---- eyebrow pill ---- */
.eyebrow{background:var(--peach-2);padding:7px 15px;border-radius:50px;margin-bottom:18px}
.eyebrow.g{background:var(--green-soft)}
.eyebrow::before{display:none}
.bg-ink .eyebrow{background:rgba(255,255,255,.08)}

/* ---- CTA : chaleureux, dégradé orange→vert doux ---- */
.cta{background:linear-gradient(125deg,#fff,var(--peach));border:1px solid var(--line-2);
  color:var(--ink);box-shadow:var(--sh-soft)}
.cta::before{background:linear-gradient(180deg,var(--orange),var(--orange-dk))}
.cta::after{background:linear-gradient(180deg,var(--green),var(--green-dk))}
.cta h2{color:var(--ink)}
.cta p{color:var(--ink-soft)}

/* ---- section "différence" : on garde foncé mais adouci ---- */
.bg-ink{background:linear-gradient(160deg,var(--ink),#1c1813)}

/* ---- footer arrondi en haut ---- */
.ft{border-radius:var(--r-xl) var(--r-xl) 0 0;margin-top:8px}

@media(max-width:960px){
  .medallion{width:300px;height:300px}.medallion img{width:188px}
  .hero-vis::before{width:330px;height:330px}
  .trust{margin-top:-30px}
}

/* ---- page-hero intérieur : version claire chaleureuse ---- */
.phero{background:linear-gradient(165deg,var(--peach) 0%,var(--cream-2) 70%,#fff 100%);color:var(--ink);
  padding:84px 0 76px}
.phero::before{background:
  radial-gradient(520px 320px at 90% 6%,rgba(244,123,32,.18),transparent 60%),
  radial-gradient(460px 320px at 4% 96%,rgba(62,146,69,.15),transparent 62%)}
.phero::after{height:6px}
.phero h1{color:var(--ink)}
.phero p{color:var(--ink-soft)}
.crumb{color:var(--green-dk)}
.crumb a:hover{color:var(--orange)}

/* fiches formation : en-têtes plus ronds + ombres chaudes */
.fc{border-radius:var(--r-lg);box-shadow:0 12px 34px -24px rgba(36,31,26,.34)}
.fc:hover{box-shadow:var(--sh-soft)}
.fc-head{transition:.3s}
.fc-side{background:linear-gradient(180deg,#fff,var(--peach))}
.tag{background:#fff;border-color:var(--line-2)}

/* steps : pastilles plus douces */
.step .num{border-radius:20px;box-shadow:var(--sh-warm)}
.step:nth-child(4n+2) .num,.step:nth-child(4n) .num{box-shadow:0 14px 30px -18px rgba(62,146,69,.6)}

/* note / encadrés : plus ronds */
.note{border-radius:var(--r)}

/* contact : champs plus ronds */
.cline{border-radius:18px;box-shadow:0 8px 24px -20px rgba(36,31,26,.3)}
.form{border-radius:var(--r-lg)}
.fg input,.fg select,.fg textarea{border-radius:12px}
.map-wrap{border-radius:var(--r-lg)}

/* ---- ligne signature / slogan ---- */
.slogan-line{font-style:italic;font-weight:600;font-size:1.18rem;color:var(--ink);
  margin:0 auto 10px;max-width:560px}
.cta .slogan-line{margin-bottom:6px}
.hero .slogan-line{font-size:1.05rem;color:var(--ink-soft);text-align:left;margin:0 0 22px}

/* =========================================================
   SYSTÈME ORBITAL — 5 satellites en orbite, toujours droits,
   bulles SANS fond (transparentes), icône + texte centrés.
   ========================================================= */
.orbit-system{position:relative;width:600px;height:540px;display:flex;align-items:center;justify-content:center;z-index:2}
.orbit-system .medallion{position:relative;z-index:3}
.orbit{position:absolute;top:50%;left:50%;width:0;height:0;z-index:4;animation:spin 30s linear infinite}
.arm{position:absolute;top:0;left:0;width:0;height:0}
.orbit .sat{position:absolute;top:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;
  white-space:nowrap;font-size:.86rem;font-weight:700;color:var(--ink);text-align:center;
  transform:translate(-50%,-50%);animation:spin-rev 30s linear infinite;
  text-shadow:0 1px 2px rgba(255,255,255,.9),0 0 10px rgba(255,255,255,.7)}
.orbit .sat .ci{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 10px 24px -12px rgba(36,31,26,.4)}
.orbit .sat .ci svg{width:26px;height:26px}
.orbit .sat .ci.o{background:#fff}
.orbit .sat .ci.gn{background:#fff}

/* 5 orbites réparties à 72° (0,72,144,216,288), rayon identique */
.orbit1 .arm{transform:rotate(0deg)   translateY(-232px) rotate(0deg)}
.orbit2 .arm{transform:rotate(72deg)  translateY(-232px) rotate(-72deg)}
.orbit3 .arm{transform:rotate(144deg) translateY(-232px) rotate(-144deg)}
.orbit4 .arm{transform:rotate(216deg) translateY(-232px) rotate(-216deg)}
.orbit5 .arm{transform:rotate(288deg) translateY(-232px) rotate(-288deg)}

@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes spin-rev{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(-360deg)}}

.orbit-system:hover .orbit,.orbit-system:hover .orbit .sat{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.orbit,.orbit .sat{animation:none}}

@media(max-width:960px){
  .orbit-system{width:420px;height:400px}
  .orbit1 .arm{transform:rotate(0deg) translateY(-175px) rotate(0deg)}
  .orbit2 .arm{transform:rotate(72deg) translateY(-175px) rotate(-72deg)}
  .orbit3 .arm{transform:rotate(144deg) translateY(-175px) rotate(-144deg)}
  .orbit4 .arm{transform:rotate(216deg) translateY(-175px) rotate(-216deg)}
  .orbit5 .arm{transform:rotate(288deg) translateY(-175px) rotate(-288deg)}
  .orbit .sat{font-size:.76rem}
  .orbit .sat .ci{width:40px;height:40px}.orbit .sat .ci svg{width:22px;height:22px}
}
@media(max-width:520px){
  .orbit-system{width:330px;height:330px;transform:scale(.92)}
  .orbit1 .arm{transform:rotate(0deg) translateY(-142px) rotate(0deg)}
  .orbit2 .arm{transform:rotate(72deg) translateY(-142px) rotate(-72deg)}
  .orbit3 .arm{transform:rotate(144deg) translateY(-142px) rotate(-144deg)}
  .orbit4 .arm{transform:rotate(216deg) translateY(-142px) rotate(-216deg)}
  .orbit5 .arm{transform:rotate(288deg) translateY(-142px) rotate(-288deg)}
}

/* =========================================================
   PAGES LÉGALES (CGV / Confidentialité)
   ========================================================= */
.legal{max-width:880px;margin:0 auto;padding:8px 0 20px}
.legal .updated{font-size:.85rem;color:var(--grey);margin-bottom:34px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.legal h2{font-size:1.32rem;color:var(--ink);margin:38px 0 14px;padding-left:14px;position:relative;line-height:1.3}
.legal h2::before{content:'';position:absolute;left:0;top:5px;bottom:5px;width:4px;border-radius:3px;background:var(--green)}
.legal h2:first-of-type{margin-top:0}
.legal h3{font-size:1.04rem;color:var(--ink);margin:24px 0 9px;font-weight:700}
.legal p{color:var(--ink-soft);margin-bottom:13px;line-height:1.72}
.legal ul{margin:0 0 14px;padding-left:4px;list-style:none}
.legal ul li{position:relative;padding-left:26px;margin-bottom:9px;color:var(--ink-soft);line-height:1.65}
.legal ul li::before{content:'';position:absolute;left:6px;top:10px;width:7px;height:7px;border-radius:50%;background:var(--green)}
.legal a{color:var(--green-dk);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--orange)}
.legal .lbox{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);padding:22px 26px;margin:22px 0}
.legal .lbox p:last-child{margin-bottom:0}
.legal table.lt{width:100%;border-collapse:collapse;margin:8px 0 20px;font-size:.93rem}
.legal table.lt th,.legal table.lt td{text-align:left;padding:11px 14px;border:1px solid var(--line);vertical-align:top}
.legal table.lt th{background:var(--green-soft);color:var(--ink);font-weight:700;width:38%}
.legal .toc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px 24px;margin-bottom:34px;box-shadow:var(--sh-sm)}
.legal .toc h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:12px;font-weight:700}
.legal .toc ol{margin:0;padding-left:20px;columns:2;column-gap:36px}
.legal .toc ol li{margin-bottom:7px;color:var(--ink-soft)}
.legal .toc ol li::before{display:none}
.legal .toc a{font-weight:500;text-decoration:none;color:var(--ink-soft)}
.legal .toc a:hover{color:var(--orange)}
@media(max-width:640px){.legal .toc ol{columns:1}.legal table.lt th{width:auto}}

/* lien légal dans le bas de footer */
.ft-legal{font-size:.86rem}
.ft-legal a{color:#cfc7bc;text-decoration:none;border-bottom:1px solid transparent;transition:.2s}
.ft-legal a:hover{color:#fff;border-bottom-color:var(--orange)}
.ft-bot{flex-wrap:wrap;gap:10px 18px}

/* =========================================================
   COOKIES — pop-up modal centré (façon RGPD/CNIL)
   ========================================================= */
.cookie-overlay{position:fixed;inset:0;z-index:1000;background:rgba(36,31,26,.55);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.3s}
.cookie-overlay.show{opacity:1;visibility:visible}
.cookie-modal{background:#fff;border-radius:var(--r-lg);max-width:520px;width:100%;
  box-shadow:0 40px 90px -30px rgba(36,31,26,.6);overflow:hidden;transform:translateY(16px) scale(.98);transition:.35s var(--ease);max-height:90vh;display:flex;flex-direction:column}
.cookie-overlay.show .cookie-modal{transform:none}
.cookie-modal-head{display:flex;align-items:center;gap:14px;padding:24px 28px 0}
.cookie-modal-head .cookie-ico{width:48px;height:48px;border-radius:14px;background:var(--orange-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cookie-modal-head .cookie-ico svg{width:28px;height:28px}
.cookie-modal-head h3{font-size:1.18rem;color:var(--ink);line-height:1.25}
.cookie-modal-body{padding:16px 28px 4px;overflow-y:auto}
.cookie-modal-body p{font-size:.92rem;color:var(--ink-soft);line-height:1.6;margin-bottom:8px}
.cookie-modal-body a{color:var(--green-dk);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.cookie-modal-body a:hover{color:var(--orange)}
.cookie-custom{margin-top:14px;display:flex;flex-direction:column;gap:12px}
.cookie-custom[hidden]{display:none}
.cookie-opt{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:var(--cream-2);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.cookie-opt b{font-size:.95rem;color:var(--ink)}
.cookie-opt small{color:var(--grey);font-weight:400;font-size:.84rem}
.cookie-opt input{width:20px;height:20px;flex-shrink:0;accent-color:var(--green);margin-top:2px}
.cookie-modal-foot{padding:18px 28px 24px;display:flex;gap:10px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:14px}
.btn-cookie{flex:1;min-width:130px;font-family:inherit;font-size:.92rem;font-weight:700;padding:13px 18px;border-radius:50px;cursor:pointer;border:1px solid var(--line-2);transition:.2s;white-space:nowrap;text-align:center}
.btn-cookie.ghost{background:#fff;color:var(--ink)}
.btn-cookie.ghost:hover{background:var(--cream);border-color:var(--green)}
.btn-cookie.accept{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:0 12px 24px -12px rgba(244,123,32,.7)}
.btn-cookie.accept:hover{background:var(--orange-dk)}
.cookie-link{background:none;border:0;color:#cfc7bc;cursor:pointer;font:inherit;font-size:.86rem;padding:0}
.cookie-link:hover{color:#fff;text-decoration:underline}
@media(max-width:560px){.cookie-modal-foot{flex-direction:column}.btn-cookie{width:100%}}

/* =========================================================
   AVIS CLIENTS — section "Ils nous font confiance"
   ========================================================= */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 26px 24px;
  box-shadow:0 12px 34px -24px rgba(36,31,26,.3);display:flex;flex-direction:column;gap:14px;position:relative}
.review-card .stars{display:flex;gap:3px}
.review-card .stars svg{width:18px;height:18px}
.review-card .rtext{color:var(--ink-soft);line-height:1.65;font-size:.96rem;flex:1}
.review-card .rwho{display:flex;align-items:center;gap:13px;margin-top:4px}
.review-card .ravatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1rem;color:#fff;flex-shrink:0}
.review-card .ravatar.o,.review-card .ravatar.g{background:linear-gradient(135deg,var(--green),var(--green-dk))}
.review-card .rwho>span{display:flex;flex-direction:column;justify-content:center}
.review-card .rname{font-weight:700;color:var(--ink);font-size:.95rem;line-height:1.25}
.review-card .rrole{font-size:.82rem;color:var(--grey);line-height:1.2;margin-top:1px}
.star-on{fill:var(--orange);stroke:var(--orange)}
.star-off{fill:none;stroke:var(--line-2)}
.reviews-foot{text-align:center;margin-top:34px}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* =========================================================
   FORMULAIRE D'AVIS (page Contact)
   ========================================================= */
.rate-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.star-input{display:inline-flex;gap:5px;direction:rtl}
.star-input input{position:absolute;opacity:0;width:0;height:0}
.star-input label{cursor:pointer;line-height:1}
.star-input label svg{width:34px;height:34px;fill:none;stroke:var(--line-2);stroke-width:2;transition:.15s}
.star-input input:checked ~ label svg,
.star-input label:hover svg,
.star-input label:hover ~ label svg{fill:var(--orange);stroke:var(--orange)}
.rate-label{font-size:.9rem;color:var(--grey);font-weight:600}
.form.review-form .form-hd{background:linear-gradient(120deg,var(--green),var(--green-dk))}
