/* ============================================================
   AFRICAPFINANCE.COM — VisionFund by AfriCap
   Charte : Orange (#EA580C) + Noir + Blanc
   Version 3.0 — Rebrand VisionFund by AfriCap
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--orange:#EA580C;--orange-light:#FB923C;--orange-dark:#C2410C;--orange-soft:#FFF4ED;--navy:#1F2D54;--navy-light:#2D3F6F;--navy-dark:#162038;--navy-soft:#EEF1F8;--gold:#EA580C;--gold-light:#FB923C;--gold-dark:#C2410C;--black:#1A1A1A;--dark:#2A2A2A;--gray-dark:#444;--gray:#777;--gray-light:#BBB;--gray-bg:#FAF7F4;--white:#FFF;--green:#2E7D32;--red:#C62828;--font:'Inter','Segoe UI',system-ui,sans-serif;--max-w:1200px;--ease:all .3s ease;--radius:12px;--shadow:0 4px 20px rgba(0,0,0,.06);--shadow-hover:0 12px 40px rgba(0,0,0,.12)}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--dark);line-height:1.7;background:var(--white)}
a{color:var(--gold-dark);text-decoration:none;transition:var(--ease)}a:hover{color:var(--gold)}
img{max-width:100%;height:auto;display:block}.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.alert-banner{padding:10px 0;text-align:center;font-size:.85rem;font-weight:500;position:relative;z-index:1001}
.alert-banner .container{display:flex;align-items:center;justify-content:center;gap:12px}
.alert-info{background:#E3F2FD;color:#1565C0}.alert-urgent{background:#FFEBEE;color:#C62828}.alert-promo{background:#FFF8E1;color:#C2410C}
.alert-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:inherit;opacity:.6;position:absolute;right:16px}.alert-close:hover{opacity:1}
.btn{display:inline-block;padding:13px 28px;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:var(--ease);text-transform:uppercase;letter-spacing:.8px;border:none;font-family:var(--font)}
.btn-primary{background:var(--gold);color:var(--black)}.btn-primary:hover{background:var(--gold-light);color:var(--black);transform:translateY(-2px);box-shadow:0 4px 15px rgba(234,88,12,.3)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}.btn-outline:hover{background:var(--white);color:var(--black)}
.btn-dark{background:var(--black);color:var(--gold)}.btn-dark:hover{background:var(--dark);transform:translateY(-2px)}
.navbar{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);width:100%;box-shadow:0 2px 12px rgba(0,0,0,.06);border-bottom:1px solid rgba(234,88,12,.08)}
.navbar .container{display:flex;justify-content:space-between;align-items:center;height:120px}
.navbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:16px}.navbar-brand img{height:96px;width:auto}
@media(max-width:640px){.navbar .container{height:90px}.navbar-brand img{height:64px}}
.brand-text{display:none}
.nav-links{display:flex;list-style:none;gap:4px;align-items:center}
.nav-links a{color:var(--gray-dark);padding:7px 14px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.6px;border-radius:6px;transition:var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--orange);background:rgba(234,88,12,.06)}
.nav-cta{background:var(--orange)!important;color:var(--white)!important;padding:9px 20px!important;box-shadow:0 4px 12px rgba(234,88,12,.25)}.nav-cta:hover{background:var(--orange-dark)!important;transform:translateY(-1px);box-shadow:0 6px 16px rgba(234,88,12,.3)}
.nav-toggle{display:none;cursor:pointer;color:var(--black);font-size:1.5rem}
.hero{background:linear-gradient(135deg,#FFF 0%,#FFF8F2 50%,#FFE8D4 100%);min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(234,88,12,.12) 0%,transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-20%;left:-10%;width:40%;height:80%;background:radial-gradient(ellipse,rgba(234,88,12,.06) 0%,transparent 70%);pointer-events:none}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-content h1{font-size:3rem;font-weight:800;color:var(--black);line-height:1.15;margin-bottom:8px}
.hero-content h1 span{color:var(--orange);position:relative;display:inline-block}
.hero-content h1 span::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:6px;background:rgba(234,88,12,.15);border-radius:3px;z-index:-1}
.hero-subtitle{font-size:1.1rem;color:var(--gray-dark);margin-bottom:28px;line-height:1.8}
.hero-buttons{display:flex;gap:16px;margin-bottom:48px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.hero-stat{text-align:center;padding:14px;border-left:3px solid var(--orange);background:rgba(255,255,255,.5);border-radius:0 8px 8px 0}
.stat-number{font-size:1.8rem;font-weight:800;color:var(--orange)}.stat-label{font-size:.7rem;color:var(--gray-dark);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.hero-image{display:flex;justify-content:center;align-items:center}
.hero-card{background:var(--white);border:1px solid rgba(234,88,12,.15);border-radius:20px;padding:32px;box-shadow:0 20px 60px rgba(234,88,12,.12),0 4px 20px rgba(0,0,0,.04);text-align:center;max-width:380px}
.hero-card h3{color:var(--orange-dark);font-size:1.2rem;margin-bottom:10px;font-weight:700}.hero-card p{color:var(--gray-dark);font-size:.85rem;line-height:1.6}
section{padding:72px 0}.section-header{text-align:center;margin-bottom:50px}
.section-tag{display:inline-block;background:rgba(234,88,12,.1);color:var(--gold-dark);padding:5px 18px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-bottom:14px}
.section-header h2{font-size:2.2rem;font-weight:800;color:var(--black);margin-bottom:14px}
.section-header p{font-size:1rem;color:var(--gray);max-width:600px;margin:0 auto}
.bg-light{background:var(--gray-bg)}.bg-dark{background:var(--navy);color:var(--white)}
.bg-dark .section-header h2{color:var(--white)}.bg-dark .section-header p{color:var(--gray-light)}
.page-header{background:linear-gradient(135deg,#FFF8F2 0%,#FFE8D4 100%);padding:120px 0 48px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid rgba(234,88,12,.1)}
.page-header::before{content:'';position:absolute;top:-50%;right:-10%;width:50%;height:200%;background:radial-gradient(ellipse,rgba(234,88,12,.1) 0%,transparent 70%);pointer-events:none}
.page-header > .container{position:relative;z-index:1}
.page-header h1{color:var(--black);font-size:2.4rem;font-weight:800;margin-bottom:8px}
.page-header p{color:var(--gray-dark);font-size:1rem}
.page-header .breadcrumb{margin-top:12px}.page-header .breadcrumb a{color:var(--orange-dark);font-size:.8rem;font-weight:600}.page-header .breadcrumb span{color:var(--gray);font-size:.8rem}
.dg-section{padding:60px 0}.dg-grid{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center}
.dg-avatar{width:150px;height:150px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--black);font-weight:800;border:3px solid rgba(234,88,12,.3);overflow:hidden}
.dg-avatar img{width:100%;height:100%;object-fit:cover}
.dg-message blockquote{font-size:1.05rem;color:var(--gray-light);line-height:1.8;font-style:italic;border-left:3px solid var(--gold);padding-left:20px;margin-bottom:20px}
.dg-name{color:var(--gold);font-weight:700;font-size:.95rem}.dg-title{color:var(--gray-light);font-size:.8rem}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.product-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);transition:var(--ease);border:1px solid #eee;position:relative;overflow:hidden}
.product-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold)}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.product-card .card-icon{font-size:2.2rem;margin-bottom:16px}.product-card .card-image{width:100%;height:150px;object-fit:cover;border-radius:8px;margin-bottom:16px}
.product-card h3{font-size:1.1rem;color:var(--black);margin-bottom:10px}.product-card p{color:var(--gray);font-size:.85rem;margin-bottom:14px}
.product-card ul{list-style:none}.product-card ul li{padding:5px 0;font-size:.82rem;color:var(--gray-dark);border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:8px}
.product-card ul li::before{content:'✓';color:var(--gold);font-weight:700}
.product-highlight{background:var(--gold);color:var(--black);padding:3px 10px;border-radius:16px;font-size:.7rem;font-weight:700;display:inline-block;margin-bottom:6px}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.about-text h3{font-size:1.4rem;color:var(--black);margin-bottom:14px}.about-text p{color:var(--gray-dark);margin-bottom:14px;font-size:.95rem}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:28px}
.value-item{display:flex;align-items:flex-start;gap:10px}.value-icon{font-size:1.4rem;color:var(--gold);min-width:36px;text-align:center}
.value-item h4{font-size:.85rem;color:var(--black);margin-bottom:3px}.value-item p{font-size:.78rem;color:var(--gray);margin:0}
.about-image{border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.about-image img{width:100%;height:280px;object-fit:cover;border-radius:var(--radius)}
.about-timeline{background:var(--navy);border-radius:var(--radius);padding:36px}
.timeline-item{display:flex;gap:16px;padding-bottom:28px;border-left:2px solid var(--gold);padding-left:20px;position:relative}
.timeline-item::before{content:'';width:10px;height:10px;background:var(--gold);border-radius:50%;position:absolute;left:-6px;top:4px}
.timeline-item:last-child{border-left-color:transparent;padding-bottom:0}
.timeline-year{font-size:.8rem;font-weight:700;color:var(--gold);min-width:50px}.timeline-text{font-size:.85rem;color:var(--gray-light)}
.piliers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.pilier-card{background:var(--white);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);text-align:center;transition:var(--ease);border-bottom:3px solid var(--gold)}
.pilier-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.pilier-card .pilier-icon{font-size:2.5rem;margin-bottom:14px}.pilier-card h3{font-size:1rem;color:var(--black);margin-bottom:8px}.pilier-card p{font-size:.82rem;color:var(--gray)}
.secteurs-list{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.secteur-tag{background:rgba(234,88,12,.1);color:var(--gold-dark);padding:8px 20px;border-radius:20px;font-size:.82rem;font-weight:500}
.solutions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.solution-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);border-top:4px solid var(--gold);transition:var(--ease)}
.solution-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.solution-card .sol-icon{font-size:2.5rem;margin-bottom:16px}.solution-card h3{font-size:1.15rem;margin-bottom:8px}
.solution-card p{color:var(--gray);font-size:.85rem;margin-bottom:14px}
.solution-card ul{list-style:none}.solution-card ul li{padding:4px 0;font-size:.82rem;color:var(--gray-dark)}.solution-card ul li::before{content:'→ ';color:var(--gold);font-weight:700}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid #eee;border-radius:8px;margin-bottom:10px;overflow:hidden;transition:var(--ease)}.faq-item:hover{border-color:var(--gold)}
.faq-question{width:100%;padding:16px 20px;background:var(--white);border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.95rem;font-weight:600;color:var(--dark);font-family:var(--font);text-align:left}
.faq-icon{font-size:1.3rem;color:var(--gold);transition:transform .3s}.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}.faq-item.open .faq-answer{max-height:300px}
.faq-answer p{padding:0 20px 16px;color:var(--gray-dark);font-size:.9rem;line-height:1.7}
.agencies-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.agency-card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border-left:4px solid var(--gold);transition:var(--ease)}
.agency-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.agency-card .agency-province{color:var(--gold);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.agency-card h3{font-size:1rem;color:var(--black);margin-bottom:10px}.agency-card p{color:var(--gray);font-size:.82rem;margin-bottom:3px}
.articles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.article-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:var(--ease)}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.article-card .article-image{width:100%;height:200px;object-fit:cover;background:var(--gray-bg)}
.article-card .article-body{padding:24px}.article-card .article-date{color:var(--gold);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.article-card h3{font-size:1.1rem;margin-bottom:8px}.article-card h3 a{color:var(--dark)}.article-card h3 a:hover{color:var(--gold)}
.article-card p{color:var(--gray);font-size:.85rem}
.article-content{max-width:800px;margin:0 auto}.article-content h1{font-size:2rem;margin-bottom:12px}
.article-content .article-meta{color:var(--gray);font-size:.85rem;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #eee}
.article-content .article-body-content{font-size:1rem;line-height:1.8}
.article-content .article-body-content h2{font-size:1.5rem;margin:28px 0 12px}.article-content .article-body-content h3{font-size:1.2rem;margin:24px 0 10px}
.article-content .article-body-content p{margin-bottom:16px}.article-content .article-body-content img{border-radius:8px;margin:20px 0}
.promo-section{padding:40px 0}.promo-card{background:linear-gradient(135deg,var(--gold-dark),var(--gold));border-radius:var(--radius);padding:40px;text-align:center;color:var(--black)}.promo-card h3{font-size:1.5rem;margin-bottom:12px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}.contact-info h3{font-size:1.4rem;margin-bottom:20px}
.contact-item{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}.contact-icon{font-size:1.3rem;color:var(--gold);min-width:36px;text-align:center}
.contact-item h4{font-size:.9rem;color:var(--black);margin-bottom:3px}.contact-item p{font-size:.85rem;color:var(--gray);margin:0}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;font-family:var(--font);margin-bottom:14px;outline:none;transition:var(--ease)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(234,88,12,.1)}
.contact-form textarea{height:110px;resize:vertical}.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.captcha-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}.captcha-row label{font-size:.85rem;color:var(--gray-dark);white-space:nowrap}.captcha-row input{width:80px;text-align:center;margin-bottom:0}
.success-msg{background:#E8F5E9;color:var(--green);padding:14px;border-radius:8px;margin-bottom:20px;font-size:.9rem}
.error-msg{background:#FFEBEE;color:var(--red);padding:14px;border-radius:8px;margin-bottom:20px;font-size:.9rem}
.partenaires-row{display:flex;gap:40px;justify-content:center;align-items:center;flex-wrap:wrap;padding:24px 0;opacity:.6}
.partenaires-row span{font-size:.85rem;color:var(--gray);font-weight:500}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:40px}
.pagination a,.pagination span{padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500}
.pagination a{background:var(--gray-bg);color:var(--dark)}.pagination a:hover{background:var(--gold);color:var(--black)}
.pagination .active{background:var(--gold);color:var(--black);font-weight:700}
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(37,211,102,.4);z-index:999;transition:var(--ease)}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(37,211,102,.5)}
.footer{background:var(--navy);padding:52px 0 20px;border-top:3px solid var(--orange)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-col h4{color:var(--gold);font-size:.8rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.footer-col p,.footer-col a{color:var(--gray-light);font-size:.82rem;display:block;margin-bottom:6px}.footer-col a:hover{color:var(--gold)}
.footer-brand img{height:64px;margin-bottom:14px}.footer-legal-small{font-size:.7rem!important;color:var(--gray)!important;margin-top:8px!important}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{color:var(--gray);font-size:.75rem}.footer-legal{color:var(--gray);font-size:.7rem}
@media(max-width:968px){.hero .container{grid-template-columns:1fr;text-align:center}.hero-content h1{font-size:2.2rem}.hero-buttons{justify-content:center}.hero-image{display:none}.about-grid{grid-template-columns:1fr}.products-grid,.solutions-grid{grid-template-columns:1fr 1fr}.agencies-grid{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.dg-grid{grid-template-columns:1fr;text-align:center}.dg-avatar{margin:0 auto}.piliers-grid{grid-template-columns:1fr 1fr}.articles-grid{grid-template-columns:1fr}.page-header{padding:100px 0 36px}.page-header h1{font-size:1.8rem}}
@media(max-width:640px){.nav-links{display:none}.nav-toggle{display:block}.nav-links.active{display:flex;flex-direction:column;position:absolute;top:72px;left:0;width:100%;background:var(--black);padding:20px;box-shadow:0 8px 20px rgba(0,0,0,.3)}.products-grid,.solutions-grid,.agencies-grid,.piliers-grid{grid-template-columns:1fr}.hero-stats{grid-template-columns:repeat(3,1fr)}.hero-content h1{font-size:1.8rem}.section-header h2{font-size:1.6rem}.about-values{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:8px;text-align:center}.contact-form .form-row{grid-template-columns:1fr}}

/* --- Fixed Header (Alert + Navbar together) --- */
#site-header{position:fixed;top:0;left:0;width:100%;z-index:1000}
#header-spacer{display:block}
.navbar{position:relative;top:auto}
.hero{padding-top:0}
.page-header{padding-top:48px}

/* Fix: prevent nav links from wrapping */
.nav-links a{white-space:nowrap}
.nav-links{flex-wrap:nowrap}
@media(max-width:1200px){.nav-links a{padding:7px 10px;font-size:.72rem;letter-spacing:.3px}.nav-links{gap:2px}}
@media(max-width:1100px){.nav-links a{padding:6px 8px;font-size:.68rem;letter-spacing:.2px}}

/* --- Hero mantra --- */
.hero-mantra{display:inline-block;color:var(--orange);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;margin-bottom:18px;padding:6px 14px;background:rgba(234,88,12,.08);border-radius:20px;border:1px solid rgba(234,88,12,.2)}

/* --- Section signature (triptyque) --- */
.signature-section{padding:80px 0;background:var(--white);position:relative}
.signature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1000px;margin:0 auto 48px}
.signature-card{background:linear-gradient(135deg,#FFF 0%,#FFF8F2 100%);border:1px solid rgba(234,88,12,.12);border-radius:20px;padding:40px 32px;text-align:left;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1)}
.signature-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--orange),var(--navy));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.signature-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(31,45,84,.12)}
.signature-card:hover::before{transform:scaleX(1)}
.signature-num{font-size:.85rem;font-weight:700;color:var(--orange);letter-spacing:2px;margin-bottom:12px}
.signature-verb{font-size:2rem;font-weight:800;color:var(--navy);margin-bottom:6px;line-height:1}
.signature-comp{font-size:1rem;color:var(--gray-dark);font-weight:500}
.signature-raison{text-align:center;max-width:720px;margin:0 auto;font-size:1.15rem;color:var(--navy);font-style:italic;font-weight:500;line-height:1.7;padding:24px 32px;border-left:3px solid var(--orange);background:var(--navy-soft);border-radius:0 var(--radius) var(--radius) 0}
@media(max-width:768px){.signature-grid{grid-template-columns:1fr;gap:16px}.signature-verb{font-size:1.6rem}}

/* --- Page Manifeste --- */
.manifeste-section{padding:80px 0;background:linear-gradient(180deg,#FFF 0%,var(--navy-soft) 100%)}
.manifeste-container{max-width:820px;position:relative}
.manifeste-quote-mark{font-family:Georgia,serif;font-size:8rem;line-height:.7;color:var(--orange);opacity:.18;position:absolute;top:-20px;left:-10px;z-index:0;font-weight:700}
.manifeste-intro{position:relative;z-index:1;font-size:1.4rem;font-weight:600;color:var(--navy);margin-bottom:48px;line-height:1.5;text-align:center;padding:0 20px}
.manifeste-convictions{display:flex;flex-direction:column;gap:24px;margin-bottom:56px}
.manifeste-conviction{display:flex;gap:24px;align-items:flex-start;background:var(--white);padding:28px 32px;border-radius:16px;border-left:4px solid var(--orange);box-shadow:0 4px 20px rgba(31,45,84,.06);transition:all .4s cubic-bezier(.16,1,.3,1)}
.manifeste-conviction:hover{transform:translateX(4px);box-shadow:0 8px 28px rgba(31,45,84,.1)}
.manifeste-num{font-size:1.5rem;font-weight:800;color:var(--orange);min-width:48px;line-height:1;letter-spacing:1px;font-family:Georgia,serif}
.manifeste-conviction p{font-size:1.05rem;color:var(--navy);line-height:1.7;margin:0}
.manifeste-conviction p strong{color:var(--orange-dark);font-weight:700}
.manifeste-engagement{background:var(--navy);color:var(--white);padding:36px 40px;border-radius:16px;margin-bottom:56px;border-left:6px solid var(--orange);position:relative;overflow:hidden}
.manifeste-engagement::before{content:'';position:absolute;top:-50%;right:-10%;width:40%;height:200%;background:radial-gradient(ellipse,rgba(234,88,12,.15) 0%,transparent 70%);pointer-events:none}
.manifeste-engagement p{position:relative;z-index:1;font-size:1.15rem;line-height:1.7;margin:0;font-weight:500}
.manifeste-engagement p strong{color:var(--orange-light);font-weight:700}
.manifeste-signature{text-align:center;padding:40px 20px;border-top:1px solid rgba(31,45,84,.1);border-bottom:1px solid rgba(31,45,84,.1);margin-bottom:40px}
.manifeste-triptyque{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;margin-bottom:20px}
.manifeste-verbe{font-size:2.2rem;font-weight:800;color:var(--navy);position:relative;padding:0 4px}
.manifeste-verbe:not(:last-child)::after{content:'';position:absolute;right:-20px;top:50%;width:6px;height:6px;background:var(--orange);border-radius:50%;transform:translateY(-50%)}
.manifeste-mantra{font-size:.9rem;color:var(--orange);text-transform:uppercase;letter-spacing:4px;font-weight:700}
.manifeste-cta{text-align:center;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
@media(max-width:640px){.manifeste-intro{font-size:1.15rem}.manifeste-conviction{flex-direction:column;gap:8px;padding:20px 24px}.manifeste-engagement{padding:24px 28px}.manifeste-engagement p{font-size:1rem}.manifeste-verbe{font-size:1.5rem}.manifeste-quote-mark{font-size:5rem}}

/* --- Section stratégie (À propos) : Objectif + Piliers --- */
.strategy-section{padding:80px 0;background:linear-gradient(160deg,var(--navy-dark) 0%,var(--navy) 50%,var(--navy-light) 100%)!important;color:var(--white);position:relative;overflow:hidden}
.strategy-section::before{content:'';position:absolute;top:-30%;right:-10%;width:50%;height:160%;background:radial-gradient(ellipse,rgba(234,88,12,.08) 0%,transparent 70%);pointer-events:none}
.strategy-section .section-header h2,.strategy-section .section-header p{position:relative;z-index:1}
.objectif-card{background:rgba(255,255,255,.06);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(234,88,12,.2);border-left:5px solid var(--orange);border-radius:14px;padding:28px 32px;margin-bottom:48px;display:flex;gap:20px;align-items:flex-start;position:relative;z-index:1}
.objectif-icon{font-size:2.4rem;flex-shrink:0;line-height:1}
.objectif-label{font-size:.75rem;color:var(--orange);text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-bottom:8px}
.objectif-card p{font-size:1.05rem;color:var(--white);line-height:1.7;margin:0;font-weight:500}
.piliers-title{text-align:center;color:var(--white);font-size:1rem;margin-bottom:32px;text-transform:uppercase;letter-spacing:3px;font-weight:600;position:relative;z-index:1}
.piliers-strat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:1}
.pilier-strat-card{background:rgba(255,255,255,.05);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:28px 22px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}
.pilier-strat-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.08);border-color:rgba(234,88,12,.3);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.pilier-strat-num{font-size:.78rem;font-weight:700;color:var(--orange);letter-spacing:2px;margin-bottom:12px;font-family:Georgia,serif}
.pilier-strat-icon{font-size:1.8rem;margin-bottom:12px;line-height:1}
.pilier-strat-card h4{color:var(--white);font-size:1rem;font-weight:700;margin-bottom:10px;line-height:1.3}
.pilier-strat-card p{color:var(--gray-light);font-size:.85rem;line-height:1.6;margin:0}
@media(max-width:968px){.piliers-strat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.piliers-strat-grid{grid-template-columns:1fr}.objectif-card{flex-direction:column;gap:12px}}

/* --- Sous-piliers (À propos) --- */
.souspiliers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;max-width:1000px;margin:0 auto}
.souspilier-item{text-align:center;padding:24px 14px;background:var(--white);border-radius:12px;border:1px solid #eee;transition:all .3s ease}
.souspilier-item:hover{transform:translateY(-3px);border-color:var(--orange);box-shadow:0 8px 20px rgba(234,88,12,.08)}
.souspilier-icon{font-size:2rem;margin-bottom:10px;line-height:1}
.souspilier-titre{font-size:.85rem;color:var(--navy);font-weight:600;line-height:1.3}
@media(max-width:768px){.souspiliers-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.souspiliers-grid{grid-template-columns:1fr 1fr}}

/* --- Manifeste teaser (À propos) --- */
.manifeste-teaser{padding:60px 0}
.manifeste-teaser-card{max-width:780px;margin:0 auto;background:var(--white);border-radius:20px;padding:48px 56px;text-align:center;box-shadow:0 12px 40px rgba(31,45,84,.08);border:1px solid rgba(234,88,12,.08);position:relative;overflow:hidden}
.manifeste-teaser-quote{font-family:Georgia,serif;font-size:5rem;line-height:.7;color:var(--orange);opacity:.15;position:absolute;top:20px;left:30px;font-weight:700}
.manifeste-teaser-card h2{font-size:1.8rem;color:var(--navy);margin-bottom:14px;font-weight:800;position:relative;z-index:1}
.manifeste-teaser-card p{color:var(--gray-dark);font-size:1rem;line-height:1.7;margin-bottom:14px;position:relative;z-index:1}
.manifeste-teaser-engage{background:var(--navy-soft);padding:18px 24px;border-radius:10px;border-left:3px solid var(--orange);font-size:.95rem!important;color:var(--navy)!important;margin-bottom:24px!important;text-align:left}
.manifeste-teaser-engage strong{color:var(--orange-dark);font-weight:700}
@media(max-width:640px){.manifeste-teaser-card{padding:32px 24px}.manifeste-teaser-card h2{font-size:1.4rem}}

/* --- Testimonials --- */
.testi-section{background:linear-gradient(160deg,#162038 0%,#1F2D54 40%,#2D3F6F 100%);padding:80px 0;position:relative;overflow:hidden}
.testi-section::before{content:'';position:absolute;top:-30%;right:-10%;width:40%;height:160%;background:radial-gradient(ellipse,rgba(234,88,12,.06) 0%,transparent 70%);pointer-events:none}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.testi-card{background:rgba(255,255,255,.04);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:32px 28px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative}
.testi-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.07);border-color:rgba(234,88,12,.2);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.testi-featured{border-color:rgba(234,88,12,.15);background:rgba(234,88,12,.04)}
.testi-quote{font-family:Georgia,serif;font-size:4rem;line-height:1;color:var(--gold);opacity:.3;position:absolute;top:16px;right:24px}
.testi-text{color:rgba(255,255,255,.85);font-size:.92rem;line-height:1.8;margin-bottom:16px;position:relative;z-index:1}
.testi-stars{color:var(--gold);font-size:.85rem;letter-spacing:3px;margin-bottom:16px}
.testi-divider{width:40px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);margin-bottom:16px}
.testi-author{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.testi-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--black);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;overflow:hidden;flex-shrink:0;box-shadow:0 4px 12px rgba(234,88,12,.25)}
.testi-avatar img{width:100%;height:100%;object-fit:cover}
.testi-name{color:var(--white);font-weight:700;font-size:.88rem}
.testi-loc{color:var(--gray);font-size:.75rem}
.testi-badge{margin-left:auto;background:rgba(234,88,12,.12);color:var(--gold);font-size:.68rem;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;border:1px solid rgba(234,88,12,.2)}
@media(max-width:968px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.testi-grid{grid-template-columns:1fr}.testi-badge{margin-left:0;margin-top:8px}}

/* --- Gouvernance --- */
.gov-section{padding:60px 0}
.gov-intro{max-width:700px;margin:0 auto 48px;text-align:center;color:var(--gray-dark);font-size:.95rem;line-height:1.8}
.gov-group-title{font-size:1.4rem;font-weight:700;color:var(--black);margin-bottom:32px;padding-bottom:12px;border-bottom:3px solid var(--gold);display:inline-block}
.gov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:28px;margin-bottom:60px}
.gov-card{text-align:center;padding:24px 16px;border-radius:var(--radius);background:var(--white);border:1px solid #eee;transition:var(--ease)}
.gov-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.gov-photo{width:100px;height:100px;border-radius:50%;background:var(--dark);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;margin:0 auto 16px;overflow:hidden}
.gov-photo img{width:100%;height:100%;object-fit:cover}
.gov-name{font-weight:700;font-size:.9rem;color:var(--black);margin-bottom:4px}
.gov-titre{color:var(--gold);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.gov-bio{color:var(--gray-dark);font-size:.8rem;line-height:1.5}

/* ============================================================
   SCROLL REVEAL CARDS — Revolut-style animation
   ============================================================ */
.reveal-section{padding:100px 0;background:var(--white);overflow:hidden}
.reveal-header{text-align:center;margin-bottom:60px;opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.reveal-section.visible .reveal-header{opacity:1;transform:translateY(0)}
.reveal-header h2{font-size:2.4rem;font-weight:800;color:var(--black);margin-bottom:12px}
.reveal-header p{color:var(--gray);font-size:1rem}

.reveal-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:960px;margin:0 auto;perspective:1000px}

.reveal-card{opacity:0;transition:all .9s cubic-bezier(.16,1,.3,1)}
.reveal-left{transform:translateX(-80px) translateY(40px) scale(.9)}
.reveal-center{transform:translateY(60px) scale(.85)}
.reveal-right{transform:translateX(80px) translateY(40px) scale(.9)}

.reveal-section.visible .reveal-left{opacity:1;transform:translateX(0) translateY(0) scale(1);transition-delay:.15s}
.reveal-section.visible .reveal-center{opacity:1;transform:translateY(0) scale(1);transition-delay:0s}
.reveal-section.visible .reveal-right{opacity:1;transform:translateX(0) translateY(0) scale(1);transition-delay:.3s}

.reveal-card-inner{background:var(--white);border-radius:20px;padding:32px 24px;box-shadow:0 8px 40px rgba(0,0,0,.08);border:1px solid #eee;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}
.reveal-card-inner:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.15)}

.reveal-card-featured{background:linear-gradient(135deg,#1A1A1A,#2A2520);border:1px solid rgba(234,88,12,.3);color:var(--white)}
.reveal-card-featured .reveal-card-label{color:var(--gold)}
.reveal-card-featured .reveal-card-amount{color:var(--white)}
.reveal-card-featured .reveal-card-sub{color:var(--gray-light)}
.reveal-card-featured .reveal-card-btn{background:var(--gold);color:var(--black)}
.reveal-card-featured .reveal-card-btn:hover{background:var(--gold-light)}
.reveal-card-featured .reveal-detail-row{border-color:rgba(255,255,255,.1);color:var(--gray-light)}
.reveal-card-featured .reveal-detail-row span:first-child{color:var(--gray-light)}

.reveal-card-badge{position:absolute;top:16px;right:16px;background:var(--gold);color:var(--black);font-size:.65rem;font-weight:700;padding:4px 12px;border-radius:12px;text-transform:uppercase;letter-spacing:1px}

.reveal-card-icon{font-size:2.5rem;margin-bottom:12px}
.reveal-card-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--gold-dark);margin-bottom:16px}
.reveal-card-amount{font-size:2.2rem;font-weight:800;color:var(--black);line-height:1}
.reveal-card-amount span{font-size:1rem;font-weight:400;color:var(--gray)}
.reveal-card-sub{font-size:.78rem;color:var(--gray);margin:8px 0 12px}
.reveal-card-highlight{font-size:1.1rem;font-weight:700;color:var(--gold-dark);margin-bottom:20px}

.reveal-card-detail{border-top:1px solid #eee;padding-top:16px;margin-bottom:20px}
.reveal-detail-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.8rem;color:var(--gray-dark)}
.reveal-detail-row span:first-child{color:var(--gray)}

.reveal-card-btn{display:block;padding:12px 20px;background:var(--black);color:var(--gold);border-radius:8px;font-size:.82rem;font-weight:600;text-align:center;transition:all .2s}
.reveal-card-btn:hover{background:var(--dark);transform:translateY(-2px);color:var(--gold-light)}

@media(max-width:968px){.reveal-cards{grid-template-columns:1fr;max-width:360px}.reveal-left{transform:translateX(-40px) translateY(20px)}.reveal-right{transform:translateX(40px) translateY(20px)}.reveal-header h2{font-size:1.8rem}}

/* ── Section Pourquoi AfriCap (slider expérience scroll-pinned) ── */
.experience-section{background:linear-gradient(135deg,#1A1A1A 0%,#0F0F0F 100%);position:relative}
.experience-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(234,88,12,.4),transparent);z-index:2}
.experience-section .section-header{margin-bottom:40px}

/* Track : conteneur haut qui définit la durée du scroll-pin (N+1) × 100vh */
.experience-track{height:auto}
.experience-pin{padding:80px 0}

/* Mode scroll-pinned (activé via JS si desktop + pas de prefers-reduced-motion) */
.experience-section.scroll-pinned .experience-track{height:700vh}
.experience-section.scroll-pinned .experience-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden;padding:40px 0}
.experience-section.scroll-pinned .experience-pin-inner{width:100%}
.experience-section.scroll-pinned .section-header{margin-bottom:30px}

/* Progress bar dorée (visible uniquement en mode scroll-pinned) */
.experience-progress{position:absolute;top:0;left:0;height:3px;background:var(--gold);width:0;z-index:3;transition:width .15s linear;display:none}
.experience-section.scroll-pinned .experience-progress{display:block}

.experience-slider{display:grid;grid-template-columns:300px 1fr;gap:50px;align-items:start}

.experience-nav{list-style:none;padding:0;margin:0;border-left:1px solid rgba(255,255,255,.08)}
.experience-nav-item{padding:18px 24px;color:var(--gray);font-size:1.4rem;font-weight:500;cursor:pointer;transition:all .25s ease;border-left:3px solid transparent;margin-left:-1px;position:relative;display:flex;align-items:center;justify-content:space-between;gap:10px;letter-spacing:-.2px}
.experience-nav-item:hover:not(.disabled){color:var(--gray-light)}
.experience-nav-item.active{color:var(--white);font-weight:700;border-left-color:var(--gold);font-size:1.55rem}
.experience-nav-item.disabled{cursor:not-allowed;opacity:.45;font-size:1.1rem;color:var(--gray)}
.experience-nav-item .soon{display:inline-block;font-size:.6rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;background:rgba(234,88,12,.12);color:var(--gold);padding:3px 8px;border-radius:10px}

.experience-content{position:relative;min-height:480px}
.experience-slide{display:none;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center;animation:slideFade .5s ease}
.experience-slide.active{display:grid}

@keyframes slideFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* En mode scroll-pinned : cross-fade absolu plus fluide */
.scroll-pinned .experience-content{min-height:440px}
.scroll-pinned .experience-slide{position:absolute;inset:0;display:grid !important;opacity:0;pointer-events:none;transition:opacity .5s ease,transform .5s ease;transform:translateY(20px);animation:none}
.scroll-pinned .experience-slide.active{opacity:1;pointer-events:auto;transform:translateY(0)}
.scroll-pinned .experience-visual img{height:440px}

.experience-text h3{font-size:2rem;color:var(--gold);font-weight:800;margin-bottom:20px;letter-spacing:-.5px}
.experience-bullets{list-style:none;padding:0;margin:0 0 30px}
.experience-bullets li{padding:10px 0 10px 28px;color:var(--gray-light);font-size:.95rem;line-height:1.6;position:relative;border-bottom:1px solid rgba(255,255,255,.05)}
.experience-bullets li:last-child{border-bottom:none}
.experience-bullets li::before{content:'✓';position:absolute;left:0;top:10px;color:var(--gold);font-weight:700;font-size:1rem}
.btn-sm{font-size:.78rem;padding:10px 22px}

.experience-visual{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.experience-visual img{width:100%;height:480px;object-fit:cover;display:block;transition:transform .6s ease}
.experience-visual:hover img{transform:scale(1.03)}

.experience-card{position:absolute;bottom:24px;left:24px;background:var(--white);border-radius:14px;padding:18px 22px;box-shadow:0 12px 30px rgba(0,0,0,.35);min-width:200px;animation:cardSlideIn .5s ease .15s both}
@keyframes cardSlideIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.card-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--gray);margin-bottom:6px}
.card-value{font-size:1.6rem;font-weight:800;color:var(--black);line-height:1}
.card-sub{font-size:.82rem;color:var(--gray-dark);margin-top:4px}
.card-status{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.78rem;font-weight:600;color:var(--green)}
.card-status .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(46,125,50,.18)}

@media(max-width:968px){
    .experience-slider{grid-template-columns:1fr;gap:30px}
    .experience-nav{display:flex;overflow-x:auto;border-left:none;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:4px;gap:8px;scrollbar-width:none}
    .experience-nav::-webkit-scrollbar{display:none}
    .experience-nav-item{font-size:.95rem;padding:12px 16px;border-left:none;border-bottom:3px solid transparent;white-space:nowrap;flex-shrink:0}
    .experience-nav-item.active{font-size:1rem;border-left:none;border-bottom-color:var(--gold)}
    .experience-nav-item.disabled{display:none}
    .experience-slide{grid-template-columns:1fr;gap:24px}
    .experience-visual img{height:340px}
    .experience-text h3{font-size:1.5rem}
    .experience-card{bottom:16px;left:16px;padding:14px 18px;min-width:170px}
    .card-value{font-size:1.3rem}
}

/* ── Section L'app AfriCap arrive ── */
.app-section{position:relative;background:linear-gradient(180deg,#0F0F0F 0%,#161616 100%);padding:90px 0;overflow:hidden}
.app-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(234,88,12,.3),transparent)}
.app-glow{position:absolute;right:-180px;top:50%;transform:translateY(-50%);width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(234,88,12,.18) 0%,rgba(234,88,12,.06) 35%,transparent 65%);pointer-events:none;z-index:0}
.app-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}

.app-text{max-width:540px}
.app-badge{display:inline-block;background:rgba(234,88,12,.12);color:var(--gold);border:1px solid rgba(234,88,12,.3);padding:6px 14px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-bottom:20px}
.app-text h2{font-size:2.4rem;color:var(--white);font-weight:800;line-height:1.15;margin-bottom:14px;letter-spacing:-.5px}
.app-text h2 span{color:var(--gold)}
.app-tagline{font-size:1.15rem;color:var(--gray-light);margin-bottom:28px;font-weight:400}

.app-bullets{list-style:none;padding:0;margin:0 0 36px}
.app-bullets li{padding:12px 0 12px 32px;color:var(--gray-light);font-size:.95rem;line-height:1.5;position:relative;border-bottom:1px solid rgba(255,255,255,.06)}
.app-bullets li:last-child{border-bottom:none}
.app-bullets li::before{content:'';position:absolute;left:0;top:18px;width:18px;height:18px;border-radius:50%;background:rgba(234,88,12,.18);border:1px solid var(--gold)}
.app-bullets li::after{content:'';position:absolute;left:6px;top:23px;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.app-bullets li strong{color:var(--white);font-weight:600}

.app-waitlist{margin-bottom:28px}
.app-waitlist-row{display:flex;gap:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:6px;transition:all .25s ease}
.app-waitlist-row:focus-within{border-color:var(--gold);background:rgba(234,88,12,.04)}
.app-waitlist-row input{flex:1;background:transparent;border:none;outline:none;color:var(--white);padding:12px 16px;font-size:.95rem;font-family:inherit}
.app-waitlist-row input::placeholder{color:var(--gray)}
.app-waitlist-row button{flex-shrink:0;border:none;cursor:pointer;font-weight:600;border-radius:8px;padding:12px 22px;font-size:.85rem}
.app-waitlist-msg{margin-top:10px;font-size:.85rem;min-height:20px;color:var(--gray-light)}
.app-waitlist-msg.success{color:#7BC97E}
.app-waitlist-msg.error{color:#E57373}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.app-stores{display:flex;gap:14px;flex-wrap:wrap}
.app-store-badge{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 16px;color:var(--gray-light);min-width:160px;cursor:not-allowed;opacity:.85;transition:all .25s ease}
.app-store-badge:hover{opacity:1;border-color:rgba(234,88,12,.3)}
.app-store-icon{display:flex;align-items:center;justify-content:center;color:var(--white)}
.app-store-text{display:flex;flex-direction:column;line-height:1.1}
.app-store-sub{font-size:.65rem;color:var(--gray);text-transform:uppercase;letter-spacing:1px}
.app-store-name{font-size:.95rem;color:var(--white);font-weight:600;margin-top:2px}

.app-visual{position:relative;display:flex;justify-content:center;align-items:center;perspective:1200px}
.app-mockup{max-width:340px;width:100%;height:auto;display:block;transform:rotate(-4deg);filter:drop-shadow(0 30px 60px rgba(0,0,0,.6)) drop-shadow(0 0 80px rgba(234,88,12,.18));animation:appFloat 6s ease-in-out infinite}
@keyframes appFloat{0%,100%{transform:rotate(-4deg) translateY(0)}50%{transform:rotate(-4deg) translateY(-14px)}}

@media(max-width:968px){
    .app-section{padding:60px 0}
    .app-glow{width:480px;height:480px;right:-120px;opacity:.6}
    .app-grid{grid-template-columns:1fr;gap:40px;text-align:center}
    .app-text{max-width:none;margin:0 auto}
    .app-text h2{font-size:1.85rem}
    .app-tagline{font-size:1rem}
    .app-bullets li{text-align:left}
    .app-waitlist-row{flex-direction:column;gap:6px}
    .app-waitlist-row button{width:100%}
    .app-stores{justify-content:center}
    .app-mockup{max-width:260px;animation:appFloatMobile 6s ease-in-out infinite}
    @keyframes appFloatMobile{0%,100%{transform:rotate(0) translateY(0)}50%{transform:rotate(0) translateY(-10px)}}
}
@media (prefers-reduced-motion:reduce){.app-mockup{animation:none}}

/* ============================================================
   HUB DE TRANSITION (/transition) + Bandeau permanent
   Réutilise les variables du site (--orange, --navy, --gray-bg, etc.)
   ============================================================ */

/* --- Bandeau permanent (sous l'alerte standard) --- */
.transition-banner{background:linear-gradient(90deg,var(--orange-dark),var(--orange));color:#fff;padding:12px 0;font-size:.9rem;font-weight:500;position:relative;z-index:998;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.transition-banner .container{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.transition-banner a{color:#fff;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;font-weight:700;white-space:nowrap}
.transition-banner a:hover{color:var(--navy-soft)}
.transition-banner-close{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:0 8px;opacity:.85;line-height:1}
.transition-banner-close:hover{opacity:1}

/* --- Hero transition --- */
.transition-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 100%);color:#fff;padding:80px 0 60px;position:relative;overflow:hidden}
.transition-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 30%,rgba(234,88,12,.18) 0%,transparent 60%);pointer-events:none}
.transition-hero .container{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
.transition-hero h1{font-size:3.2rem;font-weight:800;line-height:1.1;margin-bottom:24px;color:#fff}
.transition-hero h1 span{color:var(--orange-light)}
.transition-hero-subtitle{font-size:1.15rem;color:var(--gray-light);line-height:1.7;margin-bottom:32px;max-width:580px}
.transition-hero-subtitle strong{color:#fff}
.transition-hero-cta{display:flex;gap:16px;margin-bottom:32px;flex-wrap:wrap}
.transition-hero-update{color:var(--gray-light);font-size:.85rem}
.transition-hero-update strong{color:var(--orange-light)}
.transition-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(234,88,12,.18);color:var(--orange-light);padding:8px 16px;border-radius:100px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:24px}
.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(234,88,12,.7);animation:transitionPulse 2s infinite}
@keyframes transitionPulse{0%{box-shadow:0 0 0 0 rgba(234,88,12,.7)}70%{box-shadow:0 0 0 12px rgba(234,88,12,0)}100%{box-shadow:0 0 0 0 rgba(234,88,12,0)}}
.transition-hero-logos{display:flex;align-items:center;justify-content:center;gap:24px;background:rgba(255,255,255,.05);border-radius:16px;padding:40px 32px;border:1px solid rgba(234,88,12,.25)}
.logo-block{display:flex;flex-direction:column;align-items:center;gap:18px}
.logo-block>img{height:110px;width:auto;filter:drop-shadow(0 4px 16px rgba(0,0,0,.3))}
.logo-block .logo-hero{height:110px}
.logo-block span{color:var(--orange-light);font-size:.78rem;text-transform:uppercase;letter-spacing:2px;font-weight:600}
@media(max-width:980px){.logo-block>img,.logo-block .logo-hero{height:80px}}

/* --- Bandeau BCC --- */
.bcc-banner{background:var(--gray-bg);border-top:4px solid var(--orange);border-bottom:4px solid var(--orange);padding:32px 0}
.bcc-banner-grid{display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center}
.bcc-banner-icon{font-size:3.5rem;line-height:1}
.bcc-banner-content h3{font-size:1.4rem;color:var(--black);margin-bottom:8px;font-weight:700}
.bcc-banner-content p{color:var(--gray-dark);font-size:.95rem;margin:0 0 4px}
.bcc-banner-content strong{color:var(--black)}
.bcc-banner-meta{font-size:.85rem !important;color:var(--gray) !important;margin-top:6px !important}

/* --- Vidéo DG --- */
.dg-video-section{padding:80px 0}
.dg-video-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center;margin-top:48px}
.dg-video-player{background:var(--dark);border-radius:12px;overflow:hidden;border:1px solid rgba(234,88,12,.25)}
.video-placeholder{aspect-ratio:16/9;background:linear-gradient(135deg,var(--dark),var(--black));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:32px}
.video-placeholder .play-icon{width:80px;height:80px;border-radius:50%;background:var(--orange);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--ease)}
.video-placeholder .play-icon:hover{transform:scale(1.1);background:var(--orange-light)}
.video-placeholder p{color:var(--gray-light);font-size:.9rem;margin:0}
.video-embed{aspect-ratio:16/9}
.video-embed iframe{width:100%;height:100%;border:0}
.video-lang-tabs{display:flex;border-top:1px solid rgba(234,88,12,.25)}
.lang-tab{flex:1;padding:14px;background:transparent;border:none;color:var(--gray-light);cursor:pointer;font-size:.85rem;font-weight:500;font-family:inherit;border-right:1px solid rgba(234,88,12,.25);transition:var(--ease)}
.lang-tab:last-child{border-right:none}
.lang-tab:hover{background:rgba(234,88,12,.06)}
.lang-tab.active{background:rgba(234,88,12,.18);color:var(--orange-light);font-weight:700}
.dg-video-quote blockquote{font-size:1.05rem;line-height:1.8;color:var(--gray-light);font-style:italic;border-left:3px solid var(--orange);padding-left:24px;margin-bottom:24px}
.dg-video-quote blockquote strong{color:#fff;font-style:normal}
.dg-video-quote .dg-name{color:var(--orange-light);font-weight:700;font-size:1rem}
.dg-video-quote .dg-title{color:var(--gray-light);font-size:.85rem}

/* --- Promesse 3 colonnes --- */
.promise-section{padding:80px 0;background:#fff}
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.promise-col{background:var(--gray-bg);border-radius:12px;padding:32px;border-top:4px solid var(--orange);display:flex;flex-direction:column}
.promise-col-keep{border-top-color:var(--green)}
.promise-col-improve{border-top-color:var(--orange)}
.promise-col-calendar{border-top-color:var(--navy)}
.promise-col-header{margin-bottom:24px}
.promise-icon{font-size:2.5rem;line-height:1;margin-bottom:12px}
.promise-col-header h3{font-size:1.4rem;color:var(--black);margin-bottom:8px;font-weight:700}
.promise-subtitle{color:var(--gray);font-size:.9rem;margin:0}
.promise-list{list-style:none;padding:0;margin:0;flex:1}
.promise-list li{padding:14px 0;border-bottom:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;gap:4px}
.promise-list li:last-child{border-bottom:none}
.promise-list li strong{color:var(--black);font-size:.95rem;font-weight:600}
.promise-list li span{color:var(--gray-dark);font-size:.85rem;line-height:1.5}

/* Calendrier */
.calendar-list{list-style:none;padding:0;margin:0;position:relative}
.calendar-list::before{content:'';position:absolute;left:8px;top:12px;bottom:12px;width:2px;background:var(--gray-light)}
.calendar-item{position:relative;padding:10px 0 14px 32px}
.calendar-item::before{content:'';position:absolute;left:0;top:16px;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--gray-light);z-index:1}
.calendar-item-done::before{background:var(--green);border-color:var(--green)}
.calendar-item-current::before{background:var(--orange);border-color:var(--orange);animation:calendarPulse 2s infinite}
@keyframes calendarPulse{0%{box-shadow:0 0 0 0 rgba(234,88,12,.7)}70%{box-shadow:0 0 0 10px rgba(234,88,12,0)}100%{box-shadow:0 0 0 0 rgba(234,88,12,0)}}
.calendar-date{color:var(--orange-dark);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.calendar-event strong{color:var(--black);font-size:.95rem;display:block;margin-bottom:2px}
.calendar-event span{color:var(--gray-dark);font-size:.85rem;line-height:1.5}
.calendar-note{margin-top:24px;font-size:.8rem;color:var(--gray);font-style:italic;text-align:center}

/* --- Statut des services --- */
.status-section{padding:80px 0}
.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:48px}
.status-card{background:#fff;border-radius:8px;padding:20px 24px;display:flex;align-items:center;gap:16px;border:1px solid rgba(0,0,0,.08);transition:var(--ease)}
.status-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.status-ok .status-dot{background:var(--green);box-shadow:0 0 0 4px rgba(46,125,50,.15)}
.status-soon .status-dot{background:var(--gray-light);box-shadow:0 0 0 4px rgba(187,187,187,.25)}
.status-info{display:flex;flex-direction:column;gap:2px}
.status-info strong{color:var(--black);font-size:.95rem}
.status-info span{color:var(--gray-dark);font-size:.8rem}
.status-update{margin-top:32px;text-align:center;font-size:.8rem;color:var(--gray)}

/* --- FAQ transition (override léger pour scoped style) --- */
.transition-faq-list{max-width:900px;margin:48px auto 0}
.faq-update{text-align:center;margin-top:32px;color:var(--gray);font-size:.9rem}
.faq-update a{color:var(--orange-dark);text-decoration:underline;font-weight:600}

/* --- Communiqués officiels --- */
.communiques-section{padding:80px 0}
.communiques-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;margin-top:48px}
.communique-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:24px;display:flex;align-items:center;gap:20px;color:var(--dark);transition:var(--ease)}
.communique-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08);border-color:var(--orange);color:var(--dark)}
.communique-icon{font-size:2rem;flex-shrink:0}
.communique-content{flex:1}
.communique-date{color:var(--orange-dark);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.communique-content h4{color:var(--black);font-size:1rem;margin-bottom:4px}
.communique-content p{color:var(--gray);font-size:.85rem;margin:0;line-height:1.5}
.communique-action{color:var(--orange);font-weight:700;font-size:.9rem;flex-shrink:0}

/* --- Confirmation agences --- */
.agencies-confirm-section{padding:80px 0;background:#fff}
.agencies-confirm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:48px}
.agency-confirm-card{background:var(--gray-bg);border-radius:8px;padding:24px;text-align:center;border:2px solid transparent;transition:var(--ease);color:var(--dark);text-decoration:none;display:block}
.agency-confirm-card:hover{border-color:var(--green);transform:translateY(-2px);color:var(--dark)}
.agency-status-badge{display:inline-block;background:var(--green);color:#fff;padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:700;margin-bottom:12px}
.agency-confirm-card h4{color:var(--black);font-size:1.1rem;margin-bottom:6px}
.agency-confirm-card p{color:var(--gray-dark);font-size:.85rem;margin:2px 0}
.agency-confirm-hours{color:var(--gray) !important;font-size:.75rem !important;margin-top:8px !important;font-style:italic}
.agencies-cta{margin-top:40px;text-align:center}

/* --- Bloc sécurité / anti-rumeurs --- */
.security-section{padding:64px 0}
.security-grid{display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center;background:rgba(198,40,40,.08);border-left:4px solid var(--red);border-radius:8px;padding:32px}
.security-icon{font-size:3rem;line-height:1}
.security-content h3{color:#fff;font-size:1.3rem;margin-bottom:12px}
.security-content p{color:var(--gray-light);margin-bottom:12px;line-height:1.6}
.security-content p strong{color:#fff}
.security-content ul{margin:12px 0 12px 24px;color:var(--gray-light)}
.security-content ul li{margin-bottom:6px}

/* --- CTA final --- */
.final-cta-section{padding:80px 0;background:linear-gradient(135deg,var(--orange-dark),var(--orange))}
.final-cta-content{text-align:center;max-width:900px;margin:0 auto}
.final-cta-content h2{color:#fff;font-size:2.4rem;margin-bottom:16px}
.final-cta-content>p{color:#fff;font-size:1.05rem;margin-bottom:40px;opacity:.92}
.final-cta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.final-cta-card{background:#fff;border-radius:12px;padding:32px 20px;text-align:center;color:var(--dark);transition:var(--ease);display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none}
.final-cta-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.18);color:var(--black)}
.final-cta-icon{font-size:2.5rem;margin-bottom:8px}
.final-cta-card strong{font-size:1.1rem;color:var(--black);font-weight:700}
.final-cta-card span{color:var(--gray-dark);font-size:.85rem}

/* --- Responsive --- */
@media(max-width:980px){
    .transition-hero .container,.dg-video-grid,.promise-grid,.bcc-banner-grid,.security-grid,.final-cta-grid{grid-template-columns:1fr;gap:32px}
    .transition-hero{padding:60px 0 40px}
    .transition-hero h1{font-size:2.2rem}
    .bcc-banner-cta,.security-cta{text-align:center}
    .transition-banner{font-size:.82rem;padding:10px 0}
    .transition-banner .container{flex-direction:column;gap:8px;text-align:center}
}
@media(max-width:600px){
    .transition-hero h1{font-size:1.8rem}
    .promise-col{padding:24px}
    .final-cta-content h2{font-size:1.8rem}
}

/* ============================================================
   RÉSEAUX SOCIAUX — Footer + bloc transition + bloc sécurité
   ============================================================ */

/* --- Footer : ligne d'icônes compacte --- */
.footer-col .social-icons{display:flex;gap:10px;margin-top:8px}
.footer-col .social-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--gray-light);transition:all .25s ease;text-decoration:none;border:1px solid rgba(255,255,255,.1)}
.footer-col .social-icon:hover{background:var(--orange);color:#fff;transform:translateY(-2px);border-color:var(--orange)}
.footer-col .social-icon svg{display:block}

/* --- Bloc "Suivez nos comptes officiels" sur /transition --- */
.official-social-section{padding:64px 0}
.official-social-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:40px}
.official-social-card{background:#fff;border-radius:10px;padding:20px;display:flex;align-items:center;gap:16px;color:var(--dark);text-decoration:none;border:1px solid rgba(0,0,0,.08);transition:all .25s ease}
.official-social-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1);border-color:var(--orange);color:var(--dark)}
.official-social-icon{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.official-social-card>div{flex:1}
.official-social-card strong{display:block;color:var(--black);font-size:1rem;margin-bottom:2px}
.official-social-card span{color:var(--gray);font-size:.82rem}
.official-social-arrow{color:var(--orange);font-size:1.4rem;font-weight:700;flex-shrink:0}
.official-social-warning{margin-top:32px;text-align:center;color:var(--gray-dark);font-size:.88rem;background:rgba(198,40,40,.06);border-left:3px solid var(--red);padding:14px 20px;border-radius:6px;max-width:760px;margin-left:auto;margin-right:auto}

/* --- Bloc "Comptes officiels" sur /securite --- */
.official-channels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-top:32px}
.official-channel-card{background:#fff;border-radius:10px;padding:18px;display:flex;align-items:center;gap:14px;border:1px solid rgba(0,0,0,.08);color:var(--dark);text-decoration:none;transition:all .25s ease}
.official-channel-card.official-channel-link:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.08);border-color:var(--orange);color:var(--dark)}
.official-channel-icon{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}
.official-channel-card>div{flex:1;min-width:0}
.official-channel-card strong{display:block;color:var(--black);font-size:.95rem;margin-bottom:2px}
.official-channel-card span{color:var(--gray);font-size:.8rem;word-break:break-all}
.official-channels-warning{margin-top:28px;background:rgba(198,40,40,.08);border-left:4px solid var(--red);padding:18px 22px;border-radius:8px;color:var(--dark);font-size:.92rem;line-height:1.6}
.official-channels-warning strong{color:var(--red);font-weight:700}

@media(max-width:600px){
    .official-social-grid,.official-channels-grid{grid-template-columns:1fr}
}
