/* ========================================================================= PARALLAX INTRO — MVA Global Fret Page unique. Photo aérienne d'Antananarivo en fond + avion 3D piloté par la souris (entre par le haut-gauche, sort par la droite). Bouton CTA doré centré, toujours visible. ========================================================================= */ :root { --navy: #1a1a3e; --navy-deep: #050518; --gold: #c5a55a; --gold-light: #e0c98a; --red: #ff2a3d; --white: #fff; --mx: 0; --my: 0; } * { box-sizing: border-box; margin: 0; padding: 0; } html, body { height: 100%; background: var(--navy-deep); } .parallax-body { font-family: 'Inter', sans-serif; color: var(--white); overflow: hidden; } /* ── HEADER ─────────────────────────────────────────────────────────────── */ .parallax-header { position: fixed; top: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; padding: 22px 36px; z-index: 100; } .parallax-logo { display: inline-flex; align-items: center; gap: 12px; color: var(--white); font-family: 'Poppins', sans-serif; font-weight: 700; letter-spacing: 1.2px; font-size: 0.92rem; text-transform: uppercase; user-select: none; } .parallax-logo img { height: 44px; width: auto; filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.65)); } .lang-switcher { display: inline-flex; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.18); border-radius: 50px; padding: 4px; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); } .lang-switcher button { background: transparent; border: none; color: rgba(255, 255, 255, 0.7); padding: 6px 14px; cursor: pointer; border-radius: 50px; font-weight: 600; font-size: 0.78rem; font-family: inherit; transition: all 0.2s; } .lang-switcher button.active { background: var(--gold); color: var(--navy); } .lang-switcher button:hover:not(.active) { color: var(--white); } /* ── STAGE ──────────────────────────────────────────────────────────────── */ .stage { position: relative; width: 100vw; height: 100vh; overflow: hidden; } .layer { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; will-change: transform; } /* Photo de fond — léger zoom + parallaxe souris discrète */ .layer-bg { object-fit: cover; object-position: center; transform: translate(calc(var(--mx) * -16px), calc(var(--my) * -10px)) scale(1.05); } .layer-tint { background: radial-gradient(ellipse at center, transparent 0%, rgba(5, 5, 24, 0.32) 100%), linear-gradient(180deg, transparent 55%, rgba(5, 5, 24, 0.40) 100%); } .layer-three { display: block; z-index: 2; } /* ── BOUTON CTA centré ──────────────────────────────────────────────────── État caché : positionné là où l'avion est au centre de sa course (~27% au-dessus du centre du viewport), à scale ≈ 0. Quand le JS ajoute la classe `.revealed` (au moment où l'avion atteint p ≥ 0.5), les variables CSS basculent et le bouton « sort » de l'avion en grossissant jusqu'à sa taille finale au centre. */ .cta-btn { --cta-y: -27vh; /* offset vertical : 0 = centré */ --cta-scale: 0.05; --cta-opacity: 0; position: absolute; top: 50%; left: 50%; transform: translate(-50%, calc(-50% + var(--cta-y))) scale(var(--cta-scale)); opacity: var(--cta-opacity); pointer-events: none; z-index: 10; display: inline-flex; align-items: center; gap: 16px; padding: 22px 56px; background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 50%, var(--gold) 100%); color: var(--navy); text-decoration: none; border-radius: 50px; font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 1.1rem; letter-spacing: 0.6px; overflow: hidden; white-space: nowrap; box-shadow: 0 20px 60px rgba(197, 165, 90, 0.55), 0 0 0 0 rgba(197, 165, 90, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.45); transition: transform 2.2s cubic-bezier(0.34, 1.4, 0.64, 1), opacity 0.9s ease 0.1s, box-shadow 0.32s cubic-bezier(0.2, 0.8, 0.2, 1); } .cta-btn.revealed { --cta-y: 0vh; --cta-scale: 1; --cta-opacity: 1; pointer-events: auto; } /* Hover seulement après la révélation, avec une transition rapide */ .cta-btn.revealed:hover { --cta-scale: 1.04; transition: transform 0.32s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.32s cubic-bezier(0.2, 0.8, 0.2, 1); box-shadow: 0 28px 75px rgba(197, 165, 90, 0.7), 0 0 0 12px rgba(197, 165, 90, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.55); } .cta-btn-shine { position: absolute; top: 0; left: -120%; width: 60%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.65), transparent); transform: skewX(-22deg); transition: left 0.7s ease; pointer-events: none; } .cta-btn:hover .cta-btn-shine { left: 130%; } .cta-btn i { font-size: 0.95rem; transition: transform 0.32s ease; } .cta-btn:hover i { transform: translateX(8px); } .cta-btn::after { content: ''; position: absolute; inset: -3px; border-radius: 50px; border: 2px solid rgba(197, 165, 90, 0.55); animation: none; /* halo dormant tant que le bouton n'est pas révélé */ pointer-events: none; } .cta-btn.revealed::after { animation: ctaPulse 2.8s ease-out 1s infinite; /* démarre après l'arrivée du bouton */ } @keyframes ctaPulse { 0% { transform: scale(1); opacity: 0.7; } 100% { transform: scale(1.18); opacity: 0; } } /* ── RESPONSIVE ─────────────────────────────────────────────────────────── */ @media (max-width: 768px) { .parallax-header { padding: 14px 18px; } .parallax-logo span { display: none; } .parallax-logo img { height: 38px; } .lang-switcher button { padding: 5px 10px; font-size: 0.74rem; } .cta-btn { padding: 16px 36px; font-size: 0.98rem; } } @media (prefers-reduced-motion: reduce) { .cta-btn::after { animation: none; } }