/* ==========================================================================
   GAMA STUDIO — DESIGN SYSTEM PLAYFUL NEO-BRUTALISM (MODE CARTOON)
   Inspiré de l'esthétique BD / MS Creators — Architecture Multi-Pages & Gamification
   ========================================================================== */

:root {
    /* --- PALETTE DE COULEURS CARTOON / BD --- */
    --bg-cream: #FFF8EE;
    --bg-white: #FFFFFF;
    --bg-dark: #121212;
    --bg-surface: #FFFBF5;
    
    --text-main: #121212;
    --text-muted: #555555;
    --text-white: #FFFFFF;
    
    /* Couleurs d'accentuation vives et joyeuses */
    --accent-yellow: #FFD13B;
    --accent-orange: #FF6B00;
    --accent-purple: #7F52FF;
    --accent-mint: #00E599;
    --accent-coral: #FF5E7E;
    --accent-blue: #2997FF;
    
    /* --- BORDURES & OMBRES CARTOON (NEO-BRUTALISM) --- */
    --border-black: #000000;
    --border-thick: 3px solid var(--border-black);
    --border-heavy: 4px solid var(--border-black);
    --border-medium: 2px solid var(--border-black);
    
    /* Ombres dures sans flou (Spécificité BD / Cartoon) */
    --shadow-hard-sm: 3px 3px 0px #000000;
    --shadow-hard: 5px 6px 0px #000000;
    --shadow-hard-lg: 8px 10px 0px #000000;
    
    /* --- TYPOGRAPHIES --- */
    --font-playful: 'Playpen Sans', 'Balsamiq Sans', cursive, sans-serif;
    --font-impact: 'Passion One', 'Inter', sans-serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    
    /* --- COURBES D'ANIMATION --- */
    --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-smooth: cubic-bezier(0.16, 1, 0.3, 1);
    
    /* --- RAYONS DE COURBURE --- */
    --radius-pill: 50px;
    --radius-card: 20px;
    --radius-small: 12px;
}

/* --- RESET & BASE --- */
* { margin: 0; padding: 0; box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    font-size: 16px;
    background-color: var(--bg-cream);
    color: var(--text-main);
}

body {
    font-family: var(--font-body);
    line-height: 1.6;
    overflow-x: hidden;
    position: relative;
    background-color: var(--bg-cream);
}

body.page-academie { background-color: #FFFDF0; }
body.page-agence { background-color: #120D20; color: #fff; }
body.page-agence .hero-title, 
body.page-agence .section-title-cartoon { color: #fff; }
body.page-recrutement { background-color: #F0FFF8; }
body.page-pass { background-color: #F4FFF9; }

a, button, input, select, textarea { font-family: inherit; color: inherit; text-decoration: none; }

/* --- BANNIÈRE URGENCE COHORTE / SAISON FERMÉE (VERSION COMIC FLOATING PILL) --- */
.cohort-urgency-bar {
    max-width: 1140px;
    margin: 16px auto 10px;
    background-color: var(--accent-yellow);
    color: #000;
    padding: 12px 24px;
    text-align: center;
    font-family: var(--font-playful);
    font-weight: 800;
    font-size: 0.95rem;
    border: var(--border-heavy);
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-hard);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
    position: relative;
    z-index: 2000;
    transform: rotate(-0.6deg);
    transition: all 0.3s var(--ease-bounce);
}

.cohort-urgency-bar:hover {
    transform: rotate(0deg) translateY(-2px);
    box-shadow: var(--shadow-hard-lg);
    background-color: #FFE169;
}

.cohort-tag {
    background-color: var(--accent-coral); color: #fff; padding: 6px 14px; border-radius: var(--radius-pill); border: 2.5px solid #000; box-shadow: 2px 2px 0px #000; font-size: 0.85rem; text-transform: uppercase; font-family: var(--font-impact); letter-spacing: 0.5px; animation: pulseBadge 1.5s infinite alternate;
}

@keyframes pulseBadge {
    0% { transform: scale(1); }
    100% { transform: scale(1.08) rotate(-2deg); background-color: #FF3355; }
}

.countdown-box {
    display: inline-flex; align-items: center; gap: 8px; background: #fff; padding: 6px 18px; border-radius: var(--radius-pill); border: 2.5px solid #000; box-shadow: 3px 3px 0px #000; color: #000; font-family: var(--font-impact); font-size: 1.15rem; letter-spacing: 0.5px;
}

/* --- PARTICULES ET ÉTOILES FLOTTANTES --- */
.bg-stars-container {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; overflow: hidden;
}

.floating-star {
    position: absolute; font-size: 1.8rem; color: var(--accent-yellow); opacity: 0.75; animation: floatIdle 6s ease-in-out infinite alternate; text-shadow: 2px 2px 0px #000; filter: drop-shadow(2px 2px 0px #000);
}
img.floating-star { text-shadow: none; object-fit: contain; }
.star-1 { top: 12%; left: 8%; animation-delay: 0s; color: var(--accent-yellow); width: 38px; height: 38px; }
.star-2 { top: 25%; right: 10%; animation-delay: 1.5s; color: var(--accent-orange); width: 28px; height: 28px; }
.star-3 { top: 55%; left: 5%; animation-delay: 2s; width: 45px; height: 45px; }
.star-4 { top: 70%; right: 7%; animation-delay: 3s; color: var(--accent-purple); width: 34px; height: 34px; }
.star-5 { top: 85%; left: 15%; animation-delay: 0.8s; color: var(--accent-coral); width: 32px; height: 32px; }
.star-6 { top: 40%; right: 4%; animation-delay: 4s; color: var(--accent-mint); width: 30px; height: 30px; }
.star-7 { top: 15%; left: 45%; animation-delay: 2.5s; color: var(--accent-yellow); width: 26px; height: 26px; }

@keyframes floatIdle {
    0% { transform: translateY(0px) rotate(0deg) scale(1); }
    50% { transform: translateY(-15px) rotate(10deg) scale(1.1); }
    100% { transform: translateY(5px) rotate(-5deg) scale(0.95); }
}

/* --- EN-TÊTE / NAVBAR CARTOON --- */
.navbar-wrapper {
    position: sticky; top: 0; z-index: 1000; max-width: 1240px; margin: 0 auto; padding: 16px 20px 12px;
}
.navbar-wrapper::before {
    content: ''; position: absolute; top: 0; left: -100vw; right: -100vw; height: 100%; z-index: -1;
    background: linear-gradient(to bottom, var(--bg-cream) 80%, transparent 100%);
    pointer-events: none;
}
body.page-academie .navbar-wrapper::before { background: linear-gradient(to bottom, #FFFDF0 80%, transparent 100%); }
body.page-agence .navbar-wrapper::before { background: linear-gradient(to bottom, #120D20 80%, transparent 100%); }
body.page-recrutement .navbar-wrapper::before { background: linear-gradient(to bottom, #F0FFF8 80%, transparent 100%); }
body.page-pass .navbar-wrapper::before { background: linear-gradient(to bottom, #F4FFF9 80%, transparent 100%); }

.navbar-pill {
    background-color: var(--bg-white); border: var(--border-thick); border-radius: var(--radius-pill); padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; box-shadow: var(--shadow-hard); transition: transform 0.3s var(--ease-bounce), box-shadow 0.3s ease; color: #000; overflow: hidden;
}
.navbar-pill:hover { transform: translateY(-2px); box-shadow: var(--shadow-hard-lg); }

.logo-box {
    display: flex; align-items: center; gap: 4px; font-family: var(--font-impact); font-size: 1.6rem; font-weight: 900; letter-spacing: -0.5px; color: #000; text-decoration: none; position: relative;
}
.logo-img { height: 78px; margin: -12px 0 -12px -8px; object-fit: contain; transition: transform 0.3s var(--ease-bounce); display: block; transform: scale(1.15); transform-origin: center left; }
.logo-box:hover .logo-img { transform: scale(1.22) rotate(-2deg); }
.logo-badge {
    font-family: var(--font-playful); font-size: 0.8rem; font-weight: 800; padding: 4px 10px; border-radius: 20px; border: 2px solid #000; box-shadow: 2px 2px 0px #000; margin-left: 6px; white-space: nowrap; flex-shrink: 0; text-transform: uppercase; letter-spacing: 0.5px;
}
.logo-badge-vip { background-color: #7F52FF; color: #fff; }
.logo-badge-pass { background-color: var(--accent-yellow); color: #000; }
.logo-badge-roster { background-color: #00E599; color: #000; }
.brand-seal-badge {
    display: inline-flex; align-items: center; gap: 16px; background-color: #fff; border: 4px solid #000; border-radius: 60px; padding: 8px 30px 8px 14px; box-shadow: 6px 6px 0px #000; margin: 20px 0 28px; transform: rotate(-1.5deg); transition: transform 0.3s var(--ease-bounce), box-shadow 0.3s ease; text-decoration: none; color: #000; overflow: hidden;
}
.brand-seal-badge:hover { transform: scale(1.05) rotate(0deg); box-shadow: 8px 8px 0px var(--accent-orange); }
.brand-seal-badge img { height: 76px; margin: -8px 0 -8px -6px; object-fit: contain; display: block; transform: scale(1.15); }
.brand-seal-badge span { font-family: var(--font-impact); font-size: 1.25rem; font-weight: 900; letter-spacing: 0.5px; text-transform: uppercase; }
.hero-brand-sticker {
    height: 110px; object-fit: contain; background-color: #fff; border: 3px solid #000; border-radius: 20px; padding: 6px 20px; box-shadow: 6px 6px 0px #000; transform: rotate(-1.5deg); transition: all 0.3s var(--ease-bounce); display: block;
}
.hero-brand-sticker:hover { transform: scale(1.05) rotate(0deg); box-shadow: 8px 8px 0px var(--accent-orange); }
.footer-logo-img {
    height: 130px; object-fit: contain; margin: 0 auto 20px; display: block; background-color: #fff; border: 4px solid #000; border-radius: 28px; padding: 10px 30px; box-shadow: 6px 6px 0px var(--accent-orange); transition: transform 0.3s var(--ease-bounce); transform: scale(1.08);
}
.footer-logo-img:hover { transform: scale(1.15) rotate(2deg); }
.logo-icon { font-size: 1.8rem; animation: bounceIcon 2s infinite var(--ease-bounce); }
@keyframes bounceIcon { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.15) rotate(8deg); } }
.logo-accent { color: var(--accent-orange); }

.nav-links-desktop { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.nav-link-item { font-family: var(--font-playful); font-weight: 800; font-size: 0.95rem; padding: 8px 14px; border-radius: var(--radius-pill); transition: all 0.2s; color: #000; }
.nav-link-item:hover, .nav-link-item.active { background-color: #eee; color: var(--accent-orange); }

.nav-link-badge { font-family: var(--font-playful); font-weight: 800; font-size: 0.88rem; padding: 8px 14px; border-radius: var(--radius-pill); border: var(--border-medium); box-shadow: var(--shadow-hard-sm); transition: all 0.25s var(--ease-bounce); }
.nav-link-badge:hover, .nav-link-badge.active { transform: translateY(-4px) rotate(-2deg); box-shadow: 5px 5px 0px #000; }
.badge-yellow { background-color: var(--accent-yellow); color: #000; }
.badge-purple { background-color: var(--accent-purple); color: #fff; }
.badge-mint { background-color: var(--accent-mint); color: #000; }

.btn-cartoon-small {
    background-color: var(--accent-coral); color: var(--text-white); font-family: var(--font-playful); font-weight: 800; font-size: 0.95rem; padding: 10px 22px; border: var(--border-thick); border-radius: var(--radius-pill); box-shadow: var(--shadow-hard-sm); display: inline-block; transition: all 0.25s var(--ease-bounce);
}
.btn-cartoon-small:hover { background-color: #FF3355; transform: translateY(-3px) scale(1.05); box-shadow: var(--shadow-hard); }

/* --- HERO SECTION --- */
.hero-section { max-width: 1280px; margin: 30px auto 70px; padding: 20px 24px; position: relative; z-index: 10; }
.hero-content { text-align: center; max-width: 900px; margin: 0 auto 50px; }

.top-badge-pill {
    display: inline-flex; align-items: center; gap: 10px; background-color: var(--bg-white); color: #000; border: var(--border-thick); border-radius: var(--radius-pill); padding: 8px 20px; font-family: var(--font-playful); font-weight: 800; font-size: 0.85rem; box-shadow: var(--shadow-hard-sm); margin-bottom: 24px; transform: rotate(-1deg);
}

.pulse-dot { width: 10px; height: 10px; background-color: var(--accent-orange); border-radius: 50%; border: 2px solid #000; animation: pulseOrange 1s infinite alternate; }
@keyframes pulseOrange { 0% { transform: scale(1); background-color: var(--accent-orange); } 100% { transform: scale(1.4); background-color: var(--accent-coral); } }

.hero-title {
    font-family: var(--font-impact); font-size: clamp(3rem, 6.5vw, 5.5rem); font-weight: 900; line-height: 1.05; letter-spacing: -1.5px; margin-bottom: 24px; color: var(--text-main); text-shadow: 3px 3px 0px #fff, 5px 5px 0px #000;
}
.highlight-text { color: var(--accent-orange); text-decoration: underline; text-decoration-color: #000; text-decoration-thickness: 5px; }
.subtitle-text { color: var(--accent-purple); }

.hero-description { font-size: clamp(1.1rem, 2vw, 1.35rem); color: var(--text-muted); max-width: 780px; margin: 0 auto 36px; font-weight: 600; }
body.page-agence .hero-description { color: #BBB; }

.hero-cta-group { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.btn-cartoon-big {
    font-family: var(--font-playful); font-weight: 800; font-size: 1.15rem; padding: 16px 32px; border: var(--border-heavy); border-radius: var(--radius-pill); box-shadow: var(--shadow-hard); display: inline-flex; align-items: center; gap: 10px; transition: all 0.25s var(--ease-bounce); cursor: pointer;
}
.btn-primary-bounce { background-color: var(--accent-yellow); color: #000; }
.btn-primary-bounce:hover { background-color: #FFE169; transform: translateY(-6px) rotate(-1.5deg) scale(1.03); box-shadow: var(--shadow-hard-lg); }
.btn-purple-bounce { background-color: var(--accent-purple); color: #fff; }
.btn-purple-bounce:hover { background-color: #9B78FF; transform: translateY(-6px) rotate(1.5deg) scale(1.03); box-shadow: var(--shadow-hard-lg); }
.btn-secondary-bounce { background-color: var(--accent-mint); color: #000; }
.btn-secondary-bounce:hover { background-color: #33FFB6; transform: translateY(-6px) rotate(1.5deg) scale(1.03); box-shadow: var(--shadow-hard-lg); }

/* HERO SHOWCASE GRID */
.hero-showcase-grid { display: grid; grid-template-columns: 280px 1fr 280px; gap: 30px; align-items: center; margin-top: 40px; }
@media (max-width: 1024px) { .hero-showcase-grid { grid-template-columns: 1fr; max-width: 700px; margin: 40px auto 0; } }

.floating-badge-card {
    background-color: var(--bg-white); color: #000; border: var(--border-thick); border-radius: var(--radius-card); padding: 24px; box-shadow: var(--shadow-hard); position: relative; transition: transform 0.3s var(--ease-bounce);
}
.card-left { transform: rotate(-3deg); }
.card-left:hover { transform: rotate(-1deg) translateY(-8px) scale(1.04); }
.card-right { transform: rotate(3deg); }
.card-right:hover { transform: rotate(1deg) translateY(-8px) scale(1.04); }

.badge-icon-top {
    position: absolute; top: -20px; left: 20px; background-color: var(--accent-orange); color: #fff; border: var(--border-thick); border-radius: 50%; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; box-shadow: 2px 2px 0px #000;
}
.icon-spark { background-color: var(--accent-purple); }

.card-body-yellow h3, .card-body-coral h3 { font-family: var(--font-playful); font-size: 1.3rem; font-weight: 800; margin: 10px 0 8px; color: #000; }
.card-body-yellow p, .card-body-coral p { font-size: 0.95rem; color: var(--text-muted); font-weight: 600; }
.trophy-icon { font-size: 2.2rem; margin-top: 12px; text-align: right; }
.big-number { font-family: var(--font-impact); font-size: 3rem; font-weight: 900; color: var(--accent-coral); line-height: 1; margin-top: 10px; }
.sub-number-label { font-weight: 700; margin-top: 6px; color: #333; }

/* ÉCRAN CENTRAL TV BD */
.main-screen-container { position: relative; z-index: 5; }
.screen-border {
    background-color: var(--bg-white); border: var(--border-heavy); border-radius: 24px; overflow: hidden; box-shadow: 10px 12px 0px #000; transform: scale(1.02);
}
.screen-header { background-color: #000; padding: 12px 20px; display: flex; align-items: center; gap: 8px; }
.dot { width: 12px; height: 12px; border-radius: 50%; border: 1.5px solid #fff; }
.dot-red { background-color: #FF5E7E; } .dot-yellow { background-color: #FFD13B; } .dot-green { background-color: #00E599; }
.screen-title { color: #fff; font-family: var(--font-playful); font-weight: 800; font-size: 0.85rem; margin-left: 10px; letter-spacing: 1px; }
.screen-content { position: relative; background-color: #000; aspect-ratio: 16 / 9; overflow: hidden; }
.creator-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ease-smooth); }
.screen-border:hover .creator-img { transform: scale(1.06); }

.play-button-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.25); transition: background 0.3s; }
.play-btn-cartoon {
    width: 80px; height: 80px; background-color: var(--accent-yellow); border: var(--border-heavy); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.8rem; color: #000; box-shadow: 5px 5px 0px #000; transition: all 0.3s var(--ease-bounce); cursor: pointer;
}
.play-btn-cartoon:hover { background-color: var(--accent-orange); color: #fff; transform: scale(1.2) rotate(10deg); box-shadow: 8px 8px 0px #000; }
.play-icon { margin-left: 5px; }
.video-overlay-badge {
    position: absolute; bottom: 16px; left: 16px; background-color: var(--bg-white); color: #000; border: var(--border-thick); border-radius: var(--radius-pill); padding: 6px 16px; font-family: var(--font-playful); font-weight: 800; font-size: 0.85rem; box-shadow: 3px 3px 0px #000;
}

/* --- BANDEAU DÉFILANT INFINI --- */
.marquee-wrapper {
    background-color: var(--accent-yellow); border-top: var(--border-heavy); border-bottom: var(--border-heavy); padding: 16px 0; overflow: hidden; white-space: nowrap; position: relative; z-index: 20; transform: rotate(-1.5deg) scale(1.02); margin: 30px 0; box-shadow: 0 10px 25px rgba(0,0,0,0.15);
}
.marquee-track {
    display: inline-block; white-space: nowrap; animation: marqueeAnimation 22s linear infinite; font-family: var(--font-impact); font-size: 1.6rem; font-weight: 900; color: #000; letter-spacing: 1px;
}
.star-sep { color: var(--accent-orange); margin: 0 24px; }
@keyframes marqueeAnimation { 0% { transform: translate3d(0, 0, 0); } 100% { transform: translate3d(-50%, 0, 0); } }

.cloud-divider { width: 100%; height: 70px; overflow: hidden; margin-top: -20px; position: relative; z-index: 10; }
.cloud-divider svg { width: 100%; height: 100%; }

/* ==========================================================================
   PROPOSITION 1 : CALCULATEUR DE POTENTIEL & CROISSANCE YOUTUBE 360°
   ========================================================================== */
.calculator-section {
    max-width: 1100px; margin: 40px auto 80px; padding: 0 24px; position: relative; z-index: 10;
}

.calculator-box {
    background-color: #1A1528; color: #fff; border: var(--border-heavy); border-radius: 32px; padding: 50px 40px; box-shadow: 12px 14px 0px #000; text-align: center; position: relative;
}
@media (max-width: 768px) { .calculator-box { padding: 30px 20px; } }

.calc-slider-container {
    max-width: 700px; margin: 36px auto; background: rgba(255,255,255,0.06); padding: 26px 30px; border-radius: 24px; border: 2px solid rgba(255,255,255,0.15);
}

.calc-slider-label {
    font-family: var(--font-playful); font-size: 1.3rem; font-weight: 800; color: var(--accent-yellow); margin-bottom: 16px; display: block;
}

.calc-range-input {
    width: 100%; -webkit-appearance: none; background: #000; height: 14px; border-radius: 10px; border: 2px solid #fff; outline: none; transition: background 0.3s; cursor: pointer;
}
.calc-range-input::-webkit-slider-thumb {
    -webkit-appearance: none; width: 34px; height: 34px; border-radius: 50%; background: var(--accent-orange); border: 3px solid #000; box-shadow: 3px 3px 0px #000; transition: transform 0.2s var(--ease-bounce);
}
.calc-range-input::-webkit-slider-thumb:hover { transform: scale(1.2); background: var(--accent-yellow); }

.calc-results-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin-top: 36px;
}

.calc-metric-card {
    background: #241D3B; border: var(--border-thick); border-radius: 20px; padding: 22px 16px; box-shadow: 5px 5px 0px #000; transition: transform 0.3s var(--ease-bounce);
}
.calc-metric-card:hover { transform: translateY(-5px); }

.calc-metric-val {
    font-family: var(--font-impact); font-size: 2.6rem; font-weight: 900; color: var(--accent-mint); line-height: 1.1; margin: 8px 0;
}

.calc-metric-title { font-family: var(--font-playful); font-size: 1rem; font-weight: 800; color: #DDD; }
.calc-metric-desc { font-size: 0.85rem; color: #999; margin-top: 6px; font-weight: 600; }

.calc-total-banner {
    background: var(--accent-yellow); color: #000; border: var(--border-heavy); border-radius: var(--radius-pill); padding: 18px 30px; margin-top: 36px; display: inline-flex; align-items: center; justify-content: center; gap: 16px; font-family: var(--font-impact); font-size: 1.6rem; font-weight: 900; box-shadow: 6px 6px 0px #000; flex-wrap: wrap;
}

/* ==========================================================================
   PROPOSITION 2 : SLIDER INTERACTIF AVANT / APRÈS (MINIATURES & CTR)
   ========================================================================== */
.before-after-section {
    max-width: 1200px; margin: 0 auto; padding: 60px 24px 80px;
}

.ba-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 30px; margin-top: 40px;
}
@media (max-width: 900px) { .ba-grid { grid-template-columns: 1fr; } }

.ba-state-card {
    background: #fff; border: var(--border-heavy); border-radius: 24px; padding: 30px; box-shadow: var(--shadow-hard); position: relative; color: #000; transition: transform 0.3s var(--ease-bounce);
}
.ba-state-card:hover { transform: translateY(-6px); }

.ba-badge {
    position: absolute; top: -18px; left: 24px; padding: 6px 16px; border-radius: var(--radius-pill); border: var(--border-thick); font-family: var(--font-playful); font-weight: 800; font-size: 0.9rem; box-shadow: 3px 3px 0px #000;
}
.ba-before { background-color: #FFCCD5; color: #B30021; }
.ba-after { background-color: var(--accent-mint); color: #000; }

.ba-mockup-box {
    aspect-ratio: 16 / 9; background: #222; border: var(--border-thick); border-radius: 16px; margin: 16px 0 20px; overflow: hidden; position: relative; display: flex; align-items: center; justify-content: center;
}

.ba-mockup-img { width: 100%; height: 100%; object-fit: cover; }
.ba-filter-blur { filter: grayscale(40%) contrast(85%) brightness(90%); }
.ba-filter-boost { filter: contrast(125%) saturate(130%) brightness(105%); }

.ba-stats-row {
    display: flex; justify-content: space-between; align-items: center; background: #F8F8F8; padding: 12px 18px; border-radius: 12px; border: 2px solid #000; font-weight: 800; font-family: var(--font-playful);
}
.ctr-val { font-size: 1.4rem; color: var(--accent-orange); }

/* ==========================================================================
   PROPOSITION 4 : SECTION AFFILIATION & PARRAINAGE TALENTS
   ========================================================================== */
.affiliate-section {
    max-width: 1100px; margin: 40px auto 80px; padding: 50px 36px; background-color: #FFF5F7; border: var(--border-heavy); border-radius: 30px; box-shadow: 10px 12px 0px #000; text-align: center; color: #000;
}

.affiliate-badge-top {
    display: inline-block; background-color: var(--accent-coral); color: #fff; font-family: var(--font-playful); font-weight: 800; font-size: 0.9rem; padding: 6px 18px; border: var(--border-thick); border-radius: var(--radius-pill); box-shadow: var(--shadow-hard-sm); margin-bottom: 16px; transform: rotate(-2deg);
}

.affiliate-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 36px; text-align: left;
}

.affiliate-card {
    background: #fff; border: var(--border-thick); border-radius: 20px; padding: 26px 20px; box-shadow: var(--shadow-hard);
}
.affiliate-card h4 { font-family: var(--font-playful); font-size: 1.25rem; font-weight: 800; margin: 10px 0; color: #000; }
.affiliate-card p { font-size: 0.95rem; color: #555; font-weight: 600; }

/* --- SECTION FONCTIONNEMENT DE L'ACCOMPAGNEMENT --- */
.workflow-section { max-width: 1200px; margin: 0 auto; padding: 80px 24px; position: relative; z-index: 10; }
.workflow-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 30px; margin-top: 50px; }
.workflow-step-card { background-color: #fff; border: var(--border-heavy); border-radius: var(--radius-card); padding: 32px 24px; box-shadow: var(--shadow-hard); position: relative; transition: transform 0.3s var(--ease-bounce); color: #000; }
.workflow-step-card:hover { transform: translateY(-8px) rotate(-1deg); box-shadow: var(--shadow-hard-lg); }
.step-num-badge { position: absolute; top: -20px; left: 20px; background-color: var(--accent-yellow); color: #000; font-family: var(--font-impact); font-size: 1.4rem; font-weight: 900; width: 46px; height: 46px; border: var(--border-thick); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 2px 2px 0px #000; }
.step-title { font-family: var(--font-playful); font-size: 1.4rem; font-weight: 800; margin: 16px 0 12px; color: #000; }
.step-desc { font-size: 0.95rem; color: #555; font-weight: 600; }

/* --- GUERRE DES CLANS & LEADERBOARD --- */
.gamification-section { max-width: 1240px; margin: 40px auto 80px; padding: 60px 30px; background-color: #1A1528; color: #fff; border: var(--border-heavy); border-radius: 32px; box-shadow: 12px 14px 0px #000; position: relative; }
.clans-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; margin: 40px 0; }
.clan-card { background-color: #241D3B; border: var(--border-heavy); border-radius: 20px; padding: 24px; box-shadow: 6px 6px 0px #000; text-align: center; transition: transform 0.3s var(--ease-bounce); }
.clan-card:hover { transform: scale(1.04) translateY(-6px); }
.clan-icon { font-size: 3.5rem; margin-bottom: 12px; }
.clan-name { font-family: var(--font-impact); font-size: 2rem; font-weight: 900; margin-bottom: 8px; color: var(--accent-yellow); }
.clan-stat { font-family: var(--font-playful); font-size: 0.9rem; color: #CCC; background: rgba(0,0,0,0.3); padding: 8px 14px; border-radius: 20px; display: inline-block; border: 1px solid rgba(255,255,255,0.1); }
.leaderboard-box { background-color: #FFD13B; color: #000; border: var(--border-heavy); border-radius: 24px; padding: 30px; margin-top: 40px; box-shadow: 8px 8px 0px #000; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.leaderboard-info h3 { font-family: var(--font-impact); font-size: 2.2rem; font-weight: 900; line-height: 1.1; }
.leaderboard-info p { font-size: 1.05rem; font-weight: 700; color: #222; margin-top: 6px; }
/* --- MODÈLE D'ASSOCIATION (VOIES-SECTION & VOIE-CARD) --- */
.voies-section {
    max-width: 1100px; margin: 80px auto; padding: 0 24px; position: relative; z-index: 10;
}
.voies-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 30px; margin-top: 50px;
}
@media (max-width: 900px) { .voies-grid { grid-template-columns: 1fr; } }
.voie-card {
    background-color: #1A1528; border: 4px solid #fff; border-radius: 28px; padding: 36px 30px; box-shadow: 10px 12px 0px #000; position: relative; display: flex; flex-direction: column; gap: 16px; transition: transform 0.3s var(--ease-bounce); text-align: left;
}
.voie-card:hover { transform: translateY(-8px); }
.voie-icon {
    font-size: 3rem; width: 64px; height: 64px; background: rgba(255,255,255,0.08); border-radius: 20px; display: flex; align-items: center; justify-content: center; border: 2px solid rgba(255,255,255,0.15); box-shadow: 4px 4px 0px #000; margin-bottom: 8px;
}
.voie-tag {
    font-family: var(--font-playful); font-size: 0.95rem; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; display: inline-block;
}
.voie-content h3 {
    font-family: var(--font-playful); font-size: 1.8rem; font-weight: 800; color: #fff; margin: 4px 0 12px;
}
.voie-content p {
    font-size: 1.05rem; color: #BBB; line-height: 1.6; font-weight: 600;
}
.voie-highlights {
    margin-top: auto; padding-top: 20px; border-top: 2px dashed rgba(255, 209, 59, 0.3); font-weight: 700; font-size: 0.95rem; line-height: 1.8; color: #FFD13B;
}

/* --- OFFRES & AXES --- */
.offres-section { max-width: 1280px; margin: 0 auto; padding: 80px 24px 100px; position: relative; z-index: 10; }
.section-header { text-align: center; max-width: 800px; margin: 0 auto 60px; }
.pill-tag-cartoon { display: inline-block; background-color: var(--accent-orange); color: #fff; font-family: var(--font-playful); font-weight: 800; font-size: 0.9rem; padding: 6px 18px; border: var(--border-thick); border-radius: var(--radius-pill); box-shadow: var(--shadow-hard-sm); margin-bottom: 16px; transform: rotate(2deg); }
.section-title-cartoon { font-family: var(--font-impact); font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 900; line-height: 1.1; margin-bottom: 16px; color: var(--text-main); text-shadow: 2px 2px 0px #fff, 4px 4px 0px #000; }
.section-subtitle { font-size: 1.2rem; color: var(--text-muted); font-weight: 600; }
body.page-agence .section-subtitle { color: #BBB; }
.offres-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 35px; }
@media (max-width: 768px) { .offres-grid { grid-template-columns: 1fr; } }
.offre-card { background-color: var(--bg-white); border: var(--border-heavy); border-radius: var(--radius-card); padding: 36px 28px; box-shadow: var(--shadow-hard); position: relative; display: flex; flex-direction: column; transition: all 0.3s var(--ease-bounce); color: #000; }
.offre-card:hover { transform: translateY(-10px) rotate(-1deg); box-shadow: var(--shadow-hard-lg); }
.card-theme-yellow { background-color: #FFFCEB; }
.card-theme-purple { background-color: #1A1528; color: #fff; }
.card-theme-purple .offre-title { color: #fff; }
.card-theme-purple .offre-desc { color: #DDD; }
.card-theme-coral { background-color: #FFF5F7; }
.card-theme-mint { background-color: #EEFFF8; }
.offre-badge-top { position: absolute; top: -16px; left: 24px; background-color: var(--accent-yellow); color: #000; font-family: var(--font-playful); font-weight: 800; font-size: 0.8rem; padding: 6px 14px; border: var(--border-thick); border-radius: var(--radius-pill); box-shadow: 2px 2px 0px #000; }
.badge-dark-bg { background-color: var(--accent-purple); color: #fff; }
.badge-yellow-bg { background-color: var(--accent-coral); color: #fff; }
.offre-icon-box { width: 64px; height: 64px; background-color: var(--bg-white); border: var(--border-thick); border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 2.2rem; box-shadow: var(--shadow-hard-sm); margin: 16px 0 20px; color: #000; }
.offre-title { font-family: var(--font-impact); font-size: 2.2rem; font-weight: 900; margin-bottom: 14px; line-height: 1.1; }
.offre-desc { font-size: 1.05rem; color: var(--text-muted); margin-bottom: 24px; flex-grow: 1; }
.offre-features { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 30px; font-weight: 700; font-size: 0.95rem; }
.btn-card-action { width: 100%; font-family: var(--font-playful); font-weight: 800; font-size: 1rem; padding: 14px; border: var(--border-thick); border-radius: var(--radius-pill); text-align: center; box-shadow: var(--shadow-hard-sm); transition: all 0.2s var(--ease-bounce); }
.btn-action-yellow { background-color: var(--accent-yellow); color: #000; }
.btn-action-yellow:hover { background-color: var(--accent-orange); color: #fff; transform: scale(1.03); }
.btn-action-purple { background-color: var(--accent-purple); color: #fff; }
.btn-action-purple:hover { background-color: var(--accent-yellow); color: #000; transform: scale(1.03); }
.btn-action-coral { background-color: var(--accent-coral); color: #fff; }
.btn-action-coral:hover { background-color: var(--accent-purple); color: #fff; transform: scale(1.03); }

/* --- REVIEWS --- */
.reviews-section { max-width: 1280px; margin: 0 auto; padding: 80px 24px; }
.text-center { text-align: center; }
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 30px; margin-top: 50px; }
.review-card-cartoon { background-color: var(--bg-white); border: var(--border-heavy); border-radius: var(--radius-card); padding: 30px; box-shadow: var(--shadow-hard); transition: transform 0.3s var(--ease-bounce); color: #000; }
.review-card-cartoon:hover { transform: translateY(-8px) rotate(1deg); box-shadow: var(--shadow-hard-lg); }
.review-header { display: flex; align-items: center; gap: 16px; margin-bottom: 14px; }
.user-avatar { width: 58px; height: 58px; background-color: var(--accent-yellow); border: var(--border-thick); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 800; box-shadow: var(--shadow-hard-sm); }
.user-name { font-family: var(--font-playful); font-size: 1.3rem; font-weight: 800; }
.user-meta { font-size: 0.85rem; color: var(--text-muted); font-weight: 600; }
.stars-bar { color: #00B67A; font-size: 1.4rem; letter-spacing: 2px; margin-bottom: 12px; }
.review-stars-img { height: 26px; object-fit: contain; margin-bottom: 12px; display: block; filter: drop-shadow(1px 1px 0px rgba(0,0,0,0.15)); }
.trustpilot-badge-header {
    background: #fff; border: var(--border-heavy); border-radius: var(--radius-pill); padding: 14px 24px; margin: 20px auto 40px; max-width: 820px; display: flex; align-items: center; justify-content: center; gap: 18px; flex-wrap: wrap; box-shadow: var(--shadow-hard); transform: rotate(0.5deg); transition: all 0.3s var(--ease-bounce);
}
.trustpilot-badge-header:hover { transform: rotate(0deg) scale(1.02); box-shadow: var(--shadow-hard-lg); }
.trustpilot-img-logo { height: 44px; object-fit: contain; }
.trustpilot-img-stars { height: 34px; object-fit: contain; }
.trustpilot-label { font-family: var(--font-playful); font-weight: 800; font-size: 1rem; background-color: #00B67A; color: #fff; padding: 6px 16px; border-radius: var(--radius-pill); border: 2px solid #000; box-shadow: 3px 3px 0px #000; }
.review-title { font-family: var(--font-playful); font-size: 1.2rem; font-weight: 800; margin-bottom: 8px; }
.review-text { color: var(--text-muted); font-weight: 600; font-size: 0.95rem; }

/* --- FORMULAIRE --- */
.join-section { max-width: 1000px; margin: 40px auto 100px; padding: 0 24px; }
.cta-box-cartoon { background-color: var(--accent-yellow); border: var(--border-heavy); border-radius: 30px; padding: 60px 40px; text-align: center; position: relative; box-shadow: 12px 14px 0px #000; color: #000; }
@media (max-width: 768px) { .cta-box-cartoon { padding: 40px 20px; } }
.floating-emoji { position: absolute; font-size: 3rem; animation: floatIdle 4s infinite alternate; }
.e-1 { top: -25px; left: 30px; } .e-2 { top: -30px; right: 40px; animation-delay: 1s; } .e-3 { bottom: -20px; right: 30px; animation-delay: 2s; }
.cta-box-cartoon h2 { font-family: var(--font-impact); font-size: clamp(2.2rem, 5vw, 3.8rem); font-weight: 900; margin-bottom: 16px; text-shadow: 2px 2px 0px #fff; }
.cta-box-cartoon p { font-size: 1.15rem; max-width: 680px; margin: 0 auto 36px; font-weight: 700; }
.cartoon-form { background-color: var(--bg-white); border: var(--border-heavy); border-radius: 24px; padding: 36px; text-align: left; box-shadow: var(--shadow-hard); display: flex; flex-direction: column; gap: 20px; color: #000; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 768px) { .form-row-2 { grid-template-columns: 1fr; } }
.input-group-cartoon { display: flex; flex-direction: column; gap: 8px; }
.input-group-cartoon label { font-family: var(--font-playful); font-weight: 800; font-size: 0.95rem; color: #000; }
.input-cartoon { background-color: var(--bg-surface); border: var(--border-thick); border-radius: var(--radius-small); padding: 14px 18px; font-family: var(--font-body); font-weight: 600; font-size: 1rem; color: #000; box-shadow: inset 2px 2px 0px rgba(0,0,0,0.08); transition: all 0.2s; }
.input-cartoon:focus { outline: none; border-color: var(--accent-orange); background-color: #fff; box-shadow: 3px 3px 0px var(--accent-orange); }
.btn-cartoon-submit { background-color: var(--accent-mint); color: #000; font-family: var(--font-playful); font-weight: 800; font-size: 1.25rem; padding: 18px 32px; border: var(--border-heavy); border-radius: var(--radius-pill); box-shadow: 6px 6px 0px #000; cursor: pointer; transition: all 0.25s var(--ease-bounce); margin-top: 10px; }
.btn-cartoon-submit:hover { background-color: var(--accent-purple); color: #fff; transform: translateY(-5px) scale(1.02); box-shadow: 8px 8px 0px #000; }

/* --- TOAST NOTIFICATION --- */
.cartoon-toast { position: fixed; bottom: 30px; right: 30px; background-color: var(--bg-white); border: var(--border-heavy); border-radius: 20px; padding: 20px 26px; display: flex; align-items: center; gap: 16px; box-shadow: 8px 8px 0px #000; z-index: 10000; transform: translateY(150%); transition: transform 0.4s var(--ease-bounce); max-width: 420px; color: #000; }
.cartoon-toast.show { transform: translateY(0); }
.toast-emoji { font-size: 2.5rem; }
.toast-content strong { font-family: var(--font-playful); font-size: 1.2rem; display: block; color: var(--accent-orange); }
.toast-content p { font-size: 0.9rem; color: var(--text-muted); font-weight: 600; }

/* --- FOOTER CARTOON --- */
.footer-cartoon { background-color: #000; color: #fff; padding: 60px 24px 40px; text-align: center; border-top: var(--border-heavy); }
.footer-inner { max-width: 800px; margin: 0 auto; }
.footer-logo { font-family: var(--font-impact); font-size: 2.5rem; font-weight: 900; color: var(--accent-yellow); margin-bottom: 16px; }
.footer-copy { color: #aaa; font-size: 0.95rem; margin-bottom: 24px; }
.footer-links a { color: #fff; font-weight: 700; transition: color 0.2s; }
.footer-links a:hover { color: var(--accent-yellow); }
.footer-discreet-hire { margin-top: 36px; padding-top: 24px; border-top: 1px dashed rgba(255,255,255,0.2); font-size: 0.9rem; color: #888; }
.discreet-link { display: inline-block; margin-top: 8px; color: var(--accent-mint); font-family: var(--font-playful); font-weight: 800; border: 1.5px solid var(--accent-mint); padding: 8px 18px; border-radius: 20px; transition: all 0.2s; }
.discreet-link:hover { background-color: var(--accent-mint); color: #000; transform: scale(1.05); }

/* --- ANIMATIONS AU SCROLL --- */
.scroll-animate { opacity: 0; transform: translateY(35px); transition: opacity 0.6s var(--ease-smooth), transform 0.6s var(--ease-smooth); transition-delay: var(--delay, 0s); }
.scroll-animate.in-view { opacity: 1; transform: translateY(0); }
