/* ===== identité ACADÉMIE (teal/vert + orange) ===== */
.ac{font-family:'Poppins',system-ui,sans-serif;--at-deep:#062f2b;--at-teal:#0A6059;--at-teal2:#1f9d91;--at-mint:#45CEC3;--at-orange:#FAA211;--at-head:#0c534d;--at-body:#48565a}
[dir=rtl] .ac{font-family:'Noto Sans Arabic','Cairo',sans-serif}
.ac-wrap{max-width:1200px;margin:0 auto;padding:0 30px}
.ac-kick{display:inline-block;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:13px;background:linear-gradient(90deg,#0A6059,#1f9d91,#45CEC3);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;margin-bottom:14px}
.ac-kick.ac-kick-light{background:none;-webkit-text-fill-color:#7fe8dd;color:#7fe8dd}
.ac-h2{font-size:42px;font-weight:700;line-height:1.1;color:var(--at-head);margin:0 0 14px}
.ac-lead{font-size:18px;line-height:1.65;color:var(--at-body);max-width:64ch}
@media(max-width:767px){.ac-h2{font-size:30px}}
.ac-center{text-align:center;max-width:760px;margin:0 auto 40px}

/* hero */
.ac-hero{position:relative;overflow:hidden;background:#062f2b;color:#fff}
.ac-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(125deg,#0A6059 0%,#1f9d91 55%,#45CEC3 100%);opacity:.22}
.ac-hero::after{content:"";position:absolute;width:680px;height:680px;right:-200px;top:-280px;border-radius:50%;background:radial-gradient(circle,rgba(69,206,195,.4),transparent 62%)}
[dir=rtl] .ac-hero::after{right:auto;left:-200px}
.ac-hero .ac-wrap{position:relative;z-index:1;padding:96px 30px 86px;max-width:1200px}
.ac-hero h1{font-size:56px;font-weight:700;line-height:1.06;color:#fff;margin:0 0 14px;letter-spacing:-.01em}
.ac-hero .ac-h1sub{display:block;font-size:24px;font-weight:500;color:#bdeae3;margin-top:14px;letter-spacing:0}
.ac-hero .ac-lead{color:rgba(255,255,255,.92);font-size:20px;max-width:62ch;margin-top:22px}
.ac-hero .ac-kick{background:none;-webkit-text-fill-color:#7fe8dd;color:#7fe8dd}
@media(max-width:767px){.ac-hero h1{font-size:35px}.ac-hero .ac-h1sub{font-size:19px}.ac-hero .ac-lead{font-size:17px}}
.ac-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.ac-btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:16px;padding:15px 30px;border-radius:11px;text-decoration:none;border:2px solid transparent;transition:.2s;cursor:pointer}
.ac-btn.primary{background:#FAA211;color:#062f2b}
.ac-btn.primary:hover{background:#ffb733;transform:translateY(-2px)}
.ac-btn.ghost{border-color:rgba(255,255,255,.55);color:#fff}
.ac-btn.ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* split + visuels */
.ac-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center}
.ac-hero-fig svg{width:100%;height:auto;max-width:440px;margin-inline:auto;display:block;filter:drop-shadow(0 20px 50px rgba(0,0,0,.35))}
.ac-figure{border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(10,96,89,.18)}
.ac-figure svg{width:100%;height:auto;display:block}
@media(max-width:900px){.ac-split{grid-template-columns:1fr;gap:36px}.ac-hero-fig{max-width:340px;margin-inline:auto}}

/* sections */
.ac-sec{padding:84px 0}
.ac-sec.surface{background:#F2F8F5}

/* reveal */
.ac-reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.ac-reveal.in{opacity:1;transform:none}
.ac-reveal.d1{transition-delay:.08s}.ac-reveal.d2{transition-delay:.16s}.ac-reveal.d3{transition-delay:.24s}.ac-reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.ac-reveal{opacity:1;transform:none;transition:none}}

/* ===== SÉLECTEUR DE PROFIL (3 personas) ===== */
.ac-paths{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ac-path{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid #e2ece8;border-radius:18px;padding:32px 28px 30px;overflow:hidden;text-decoration:none;transition:transform .25s,box-shadow .25s,border-color .25s}
.ac-path::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#0A6059,#1f9d91,#45CEC3);transform:scaleX(0);transform-origin:left;transition:transform .35s}
[dir=rtl] .ac-path::before{transform-origin:right}
.ac-path:hover{transform:translateY(-6px);box-shadow:0 26px 54px rgba(10,96,89,.18);border-color:transparent}
.ac-path:hover::before{transform:scaleX(1)}
.ac-path .pic{width:56px;height:56px;border-radius:15px;display:flex;align-items:center;justify-content:center;background:rgba(31,157,145,.13);margin-bottom:20px}
.ac-path .pic svg{width:28px;height:28px;stroke:#0A6059}
.ac-path .who{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#1f9d91;margin-bottom:8px}
.ac-path h3{font-size:23px;font-weight:700;color:var(--at-head);margin:0 0 12px;line-height:1.2}
.ac-path p{font-size:15.5px;line-height:1.62;color:var(--at-body);margin:0 0 22px;flex:1}
.ac-path .go{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;color:#0A6059}
.ac-path .go svg{width:18px;height:18px;stroke:#FAA211;transition:transform .25s}
[dir=rtl] .ac-path .go svg{transform:scaleX(-1)}
.ac-path:hover .go svg{transform:translateX(5px)}
[dir=rtl] .ac-path:hover .go svg{transform:translateX(-5px) scaleX(-1)}
@media(max-width:900px){.ac-paths{grid-template-columns:1fr}}

/* ===== ARCHITECTURE brique -> module -> parcours ===== */
.ac-arch{display:flex;flex-direction:column;gap:18px;max-width:980px;margin:0 auto}
.ac-level{position:relative;display:grid;grid-template-columns:200px 1fr auto;align-items:center;gap:24px;border-radius:18px;padding:26px 30px;color:#fff;overflow:hidden}
.ac-level .lv-name{font-size:24px;font-weight:700;letter-spacing:.01em}
.ac-level .lv-name small{display:block;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.8;margin-bottom:4px}
.ac-level .lv-desc{font-size:16px;line-height:1.55;opacity:.96}
.ac-level .lv-desc b{font-weight:700}
.ac-level .lv-mark{flex:none;width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.ac-level .lv-mark svg{width:26px;height:26px;stroke:#fff;opacity:.85}
.ac-lvl-brick{background:linear-gradient(120deg,#3c4a63,#5a6b86)}
.ac-lvl-module{background:linear-gradient(120deg,#2f5fa0,#3f8f6f);width:94%;margin-inline-start:auto}
.ac-lvl-path{background:linear-gradient(120deg,#FAA211,#d98512);width:88%;margin-inline-start:auto;box-shadow:0 0 0 3px rgba(10,96,89,.25)}
.ac-lvl-path .lv-desc{color:#3a2600;opacity:1}
.ac-lvl-path .lv-name{color:#fff}
.ac-lvl-path .lv-mark svg{stroke:#fff;opacity:1}
[dir=rtl] .ac-lvl-module,[dir=rtl] .ac-lvl-path{margin-inline-start:0;margin-inline-end:auto}
@media(max-width:760px){.ac-level{grid-template-columns:1fr;gap:8px;padding:22px 24px}.ac-lvl-module,.ac-lvl-path{width:100%}.ac-level .lv-mark{display:none}}
.ac-arch-note{text-align:center;color:#6B6F70;font-size:14.5px;line-height:1.6;margin:28px auto 0;max-width:70ch}

/* cards génériques */
.ac-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ac-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ac-card{position:relative;background:#fff;border:1px solid #e2ece8;border-radius:16px;padding:30px 26px;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.ac-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,#0A6059,#1f9d91,#45CEC3);transform:scaleX(0);transform-origin:left;transition:transform .35s}
[dir=rtl] .ac-card::before{transform-origin:right}
.ac-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(10,96,89,.16);border-color:transparent}
.ac-card:hover::before{transform:scaleX(1)}
.ac-card .ic{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:rgba(31,157,145,.13);margin-bottom:18px}
.ac-card .ic svg{width:26px;height:26px;stroke:#0A6059}
.ac-card h3{font-size:21px;font-weight:600;color:var(--at-head);margin:0 0 10px;line-height:1.25}
.ac-card p{font-size:15.5px;line-height:1.6;color:var(--at-body);margin:0}
@media(max-width:980px){.ac-grid3{grid-template-columns:1fr 1fr}.ac-grid4{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.ac-grid3{grid-template-columns:1fr}.ac-grid4{grid-template-columns:1fr}}

/* method steps */
.ac-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ac-step{position:relative;background:#fff;border:1px solid #e2ece8;border-radius:16px;padding:30px 24px}
.ac-step .num{font-size:16px;font-weight:700;color:#fff;background:#0A6059;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ac-step:nth-child(2) .num{background:#1f9d91}.ac-step:nth-child(3) .num{background:#45CEC3;color:#062f2b}.ac-step:nth-child(4) .num{background:#FAA211;color:#062f2b}
.ac-step h3{font-size:20px;font-weight:600;color:var(--at-head);margin:0 0 8px}
.ac-step p{font-size:15px;line-height:1.55;color:var(--at-body);margin:0}
@media(max-width:860px){.ac-steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.ac-steps{grid-template-columns:1fr}}

.ac-foot{text-align:center;color:#6B6F70;font-size:14.5px;line-height:1.6;margin:30px auto 0;max-width:82ch}

/* quality badges */
.ac-qual{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ac-badge{text-align:center;background:#fff;border:1px solid #e2ece8;border-radius:16px;padding:28px 18px}
.ac-badge b{display:block;font-size:19px;color:var(--at-head);font-weight:700;margin-bottom:6px}
.ac-badge span{font-size:13.5px;color:var(--at-body);line-height:1.45}
.ac-badge .chk{width:40px;height:40px;border-radius:50%;background:rgba(31,157,145,.13);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.ac-badge .chk svg{width:22px;height:22px;stroke:#0A6059}
@media(max-width:760px){.ac-qual{grid-template-columns:1fr 1fr}}

/* CTA final */
.ac-final{position:relative;background:#0A6059;color:#fff;text-align:center;overflow:hidden;padding:80px 0}
.ac-final::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,#1f9d91,#45CEC3 60%,#FAA211);opacity:.18}
.ac-final .ac-wrap{position:relative;z-index:1;max-width:720px}
.ac-final h2{color:#fff;font-size:36px;font-weight:700;margin:0 0 12px}
.ac-final p{color:rgba(255,255,255,.92);font-size:18px;margin:0 0 26px}
.ac-final .ac-actions{justify-content:center}
@media(max-width:600px){.ac-final h2{font-size:27px}}
