/* ============================================================
   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:100px}
.navbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:16px}.navbar-brand img{height:72px;width:auto}
.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}}
