/* ============================================ */
/* === static/css/landing_styles.css ===        */
/* ============================================ */
/* Styles spécifiques à la page d'atterrissage (landing.html) */

/* --- Section Héros Landing --- */
.landing-hero-section {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Deux colonnes égales */
    align-items: center;
    gap: 50px; /* Espace entre texte et visuel */
    padding: 60px 0 80px 0; /* Plus de padding vertical */
    min-height: 60vh; /* Donner de la hauteur (réduit un peu) */
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 50px;
}
.landing-hero-content { text-align: left; }
.landing-hero-title {
    font-size: 3.2rem; /* Titre plus grand */
    line-height: 1.2; margin-bottom: 0.6em;
    font-weight: 800;
    /* --- Animation Texte Héros (Définie plus bas) --- */
}
.landing-hero-subtitle {
    font-size: 1.15rem; color: var(--text-muted);
    margin-bottom: 2.5rem; max-width: 550px;
}
.hero-cta-button { /* Style spécifique bouton héros landing */
    padding: 14px 30px; font-size: 1.1rem;
}
.landing-hero-content .small-text { font-size: 0.85rem; margin-top: 15px; }
.landing-hero-visual { display: flex; justify-content: center; align-items: center; perspective: 1000px; }
.hero-visual-placeholder {
    width: 100%; max-width: 450px; height: auto;
    transition: transform var(--transition-medium); /* Garder transition pour JS fallback */
    /* transform: rotateY(10deg) rotateX(5deg); /* État initial géré par animation */
    filter: drop-shadow(0 10px 20px rgba(0,0,0,0.3));
    /* --- Animation Flottement (Définie plus bas) --- */
}

/* --- Animation Texte Héros --- */
@keyframes gradient-animation {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.animate-gradient-text {
    background: linear-gradient(90deg, var(--accent-color1), var(--accent-color2), var(--accent-color1));
    background-size: 200% 100%; /* Double largeur pour l'animation */
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: gradient-animation 6s ease infinite; /* Animation lente */
}

/* --- Animation Flottement Visuel Héros --- */
@keyframes float-animation {
  0%, 100% { transform: translateY(0) rotateY(10deg) rotateX(5deg); }
  50% { transform: translateY(-10px) rotateY(10deg) rotateX(5deg); } /* Monte légèrement */
}
/* Appliquer l'animation */
.animate-float .hero-visual-placeholder {
    animation: float-animation 6s ease-in-out infinite;
}
/* Ajuster le hover quand l'animation est active */
.animate-float:hover .hero-visual-placeholder {
    transform: translateY(-10px) rotateY(10deg) rotateX(5deg) scale(1.03); /* Garde le léger flottement + scale */
}


/* --- Section Titres Communs (utilisé sur Landing) --- */
.section-title {
    text-align: center; margin-bottom: 40px; font-size: 2rem;
    font-family: var(--font-primary); color: #fff;
}

/* --- Section Le Problème --- */
.problem-section {
    padding: 60px 0;
}
.problem-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
    margin-bottom: 30px; /* Espace avant la conclusion */
}
.problem-item {
    /* Utilise .card et .interactive-card de base_styles */
    text-align: center; /* Centre contenu de la carte */
    padding: 30px 25px;
}

/* Nouvelle règle (sans rouge) */
.problem-icon {
    width: 50px; height: 50px;
    /* Fond neutre ou couleur d'accentuation très transparente */
    background-color: rgba(0, 209, 197, 0.08); /* Fond cyan très léger */
    /* Ou un gris neutre: background-color: rgba(136, 141, 168, 0.1); */
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px auto;
    /* Couleur de l'icône (Cyan pour correspondre aux autres sections) */
    color: var(--accent-color2);
    /* Ou couleur neutre: color: var(--text-muted); */
    transform: scale(0);
    opacity: 0;
    transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.problem-item h3 {
    color: var(--text-color); /* Titre plus clair */
    font-size: 1.2rem; margin-bottom: 10px;
}
.problem-item p {
    font-size: 0.95rem; color: var(--text-muted);
}
.problem-conclusion {
    text-align: center;
    font-style: italic;
    color: var(--text-muted);
    max-width: 700px;
    margin: 0 auto;
}


/* --- Section Notre Solution --- */
.solution-section {
    padding: 70px 0;
    background: linear-gradient(180deg, rgba(13, 15, 26, 0) 0%, rgba(138, 43, 226, 0.08) 50%, rgba(13, 15, 26, 0) 100%);
}
.solution-grid {
    display: grid;
    grid-template-columns: 1fr 2fr; /* Visuel plus petit, texte plus grand */
    gap: 50px;
    align-items: center;
}
.solution-visual {
    text-align: center;
}
.solution-visual svg {
     /* --- Animation Pulse (Définie plus bas) --- */
     /* Appliquée via la classe .animate-pulse */
}
.solution-text p {
    margin-bottom: 1.5em;
    line-height: 1.7;
    color: var(--text-color); /* Texte principal plus clair */
}
.solution-text strong {
    color: var(--accent-color2); /* Mots clés en cyan */
}
.solution-benefits {
    list-style: none;
    padding: 0; margin: 25px 0;
}
.solution-benefits li {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 1rem;
    color: var(--text-muted);
}
.solution-benefits li svg {
    flex-shrink: 0;
}
.solution-benefits li strong {
     color: var(--text-color); /* Mettre en évidence le bénéfice */
     font-weight: 500;
}


/* --- Section Chiffres Clés --- */
.stats-section {
    padding: 50px 0; margin-bottom: 50px;
    background-color: rgba(26, 28, 42, 0.5);
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
}
.stats-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 30px; text-align: center; max-width: 900px; margin: 0 auto;
}
.stat-item { padding: 15px; }
.stat-number {
    font-family: var(--font-primary); font-size: 2.8rem; font-weight: 700;
    line-height: 1.2; margin-bottom: 5px; color: var(--accent-color1);
    min-height: 1.2em; /* Empêche le saut pendant le comptage */
}
.stat-label { font-family: var(--font-secondary); font-size: 1rem; color: var(--text-muted); margin: 0; }

/* --- Animation Section Stats "24/7" --- */
@keyframes pulse-quick-animation {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.05); opacity: 0.8; }
}
.animate-pulse-quick {
    animation: pulse-quick-animation 2s ease-in-out infinite;
    display: inline-block; /* Nécessaire pour transform */
}


/* --- Section Avantages (Landing Version) --- */
.advantages-section { padding: 60px 0; margin-bottom: 50px; }
.advantages-section .features-grid { /* Structure grid réutilisée */
    display: grid; gap: 25px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.advantages-section .feature-card { /* Styles carte spécifiques landing */
    background: linear-gradient(155deg, var(--card-bg-color), #161824);
    text-align: left; display: flex; flex-direction: column;
     /* Utilise .card et .interactive-card de base_styles pour hover */
}
.advantages-section .feature-icon { /* Styles icônes spécifiques landing */
    color: var(--accent-color2); width: 45px; height: 45px; display: flex; align-items: center; justify-content: center;
    background-color: rgba(0, 209, 197, 0.1); border-radius: 50%; margin-bottom: 15px;
    transition: transform var(--transition-fast), background-color var(--transition-fast); flex-shrink: 0;
    /* Animation Bounce au survol via .animate-bounce-on-hover */
}
.advantages-section .feature-icon svg { width: 22px; height: 22px; stroke: var(--accent-color2); }
/* Pas besoin de redéfinir le hover de l'icône si l'animation le gère */
/* .advantages-section .feature-card:hover .feature-icon { transform: scale(1.1); background-color: rgba(0, 209, 197, 0.2); } */
.advantages-section .feature-card h3 { /* Titre carte landing */
    color: var(--accent-color2); font-size: 1.25rem; margin-bottom: 10px;
}
.advantages-section .feature-card p { /* Texte carte landing */
     font-size: 0.95rem; flex-grow: 1; margin-bottom: 0;
}


/* --- Animation Icones Features --- */
@keyframes bounce-animation {
  0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
  40% {transform: translateY(-8px);} /* Rebond haut */
  60% {transform: translateY(-4px);} /* Rebond bas */
}
/* Appliquer l'animation au survol du conteneur parent */
.animate-bounce-on-hover:hover .feature-icon {
  animation: bounce-animation 1s ease;
}


/* --- Section Roadmap Highlight --- */
.roadmap-highlight-section {
    padding: 30px 0;
    text-align: center;
    margin: 40px 0;
    background-color: rgba(0, 209, 197, 0.08); /* Fond cyan léger */
    border-top: 1px solid rgba(0, 209, 197, 0.2);
    border-bottom: 1px solid rgba(0, 209, 197, 0.2);
}
.roadmap-content {
    display: inline-flex; /* Aligner icône et texte */
    align-items: center;
    gap: 10px;
    color: var(--text-color);
    font-family: var(--font-primary);
    font-size: 1.1rem;
    letter-spacing: 0.5px;
}
.roadmap-content svg {
    stroke: var(--accent-color2);
    width: 20px; height: 20px;
}
.roadmap-content span strong {
     color: var(--accent-color2); /* Mettre en évidence la date */
}


/* --- Section Final CTA --- */
.cta-section {
    text-align: center; padding: 60px 20px; margin-top: 40px;
    background: linear-gradient(180deg, var(--bg-color) 0%, #1a1c2a 100%);
    border-top: 1px solid var(--border-color);
}
.cta-section h2 { font-size: 2.2rem; margin-bottom: 15px; }
.cta-section p { font-size: 1.1rem; color: var(--text-muted); margin-bottom: 30px; max-width: 600px; margin-left: auto; margin-right: auto; }
.large-cta-button { /* Style bouton CTA landing */
    padding: 15px 35px; font-size: 1.15rem;
}


/* --- Animations Communes --- */
@keyframes pop-in-animation {
  0% { transform: scale(0); opacity: 0; }
  80% { transform: scale(1.1); opacity: 1;}
  100% { transform: scale(1); opacity: 1; }
}
.animate-pop-in {
    /* Sera déclenché par JS via IntersectionObserver en ajoutant une classe ou en modifiant style */
    /* Le CSS ici définit l'animation elle-même */
    animation: pop-in-animation 0.6s cubic-bezier(0.25, 0.8, 0.25, 1) forwards;
    /* On garde la visibilité/transform initial pour JS */
     /* transform: scale(0); */
     /* opacity: 0; */
}

@keyframes pulse-animation {
  0% { transform: scale(1); opacity: 0.7; }
  50% { transform: scale(1.05); opacity: 1; }
  100% { transform: scale(1); opacity: 0.7; }
}
.animate-pulse {
    animation: pulse-animation 3s ease-in-out infinite;
}


/* --- Responsive Adjustments pour Landing Page --- */
@media (max-width: 992px) {
    .landing-hero-section {
        grid-template-columns: 1fr; text-align: center;
        padding: 40px 0 60px 0; min-height: auto;
    }
    .landing-hero-content { text-align: center; order: 1; }
    .landing-hero-subtitle { margin-left: auto; margin-right: auto; }
    .landing-hero-visual { order: 2; margin-top: 30px; }
    .hero-visual-placeholder { max-width: 380px; /* transform: rotateY(0deg) rotateX(0deg); /* Géré par anim */ }
    .landing-hero-title { font-size: 2.8rem; }
    .stats-grid { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
    .stat-number { font-size: 2.5rem; }
    .section-title { font-size: 1.9rem; }

    .solution-grid {
        grid-template-columns: 1fr; /* Empiler sur tablette */
        gap: 30px;
    }
    .solution-visual {
        max-width: 150px; /* Limiter taille visuel */
        margin: 0 auto 20px auto;
    }
    .solution-text {
        text-align: center;
    }
     .solution-text .section-title {
        text-align: center;
    }
     .solution-benefits {
        display: inline-block; /* Pour centrer la liste */
        text-align: left; /* Garder texte à gauche dans la li */
        max-width: 400px; /* Limiter largeur pour centrage */
    }
     .solution-benefits li { justify-content: flex-start; } /* Aligner au début */
}

@media (max-width: 768px) {
    .landing-hero-title { font-size: 2.4rem; }
    .hero-cta-button { font-size: 1rem; padding: 12px 25px; }
    .section-title { font-size: 1.8rem; }
    .stats-grid { grid-template-columns: 1fr 1fr; gap: 20px;}
    .stat-number { font-size: 2.2rem; }
    .stat-label { font-size: 0.9rem; }
    .cta-section h2 { font-size: 1.9rem; }
    .large-cta-button { font-size: 1rem; padding: 14px 30px;}
    .advantages-section .features-grid { grid-template-columns: 1fr; } /* Stack avantages sur mobile */
    .problem-grid { grid-template-columns: 1fr; } /* 1 colonne problème sur mobile */
    .roadmap-content { font-size: 1rem; }

}

@media (max-width: 480px) {
    .landing-hero-title { font-size: 2rem; }
    .landing-hero-subtitle { font-size: 1rem; }
    .hero-cta-button { width: 100%; text-align: center; justify-content: center;}
    .hero-cta-button svg { margin-right: 8px; }
    .stats-grid { grid-template-columns: 1fr; gap: 25px;}
    .stat-item { padding: 10px; }
    .stat-number { font-size: 2rem; }
    .advantages-section .features-grid { gap: 20px; }
    .large-cta-button { padding: 12px 25px; font-size: 1rem;}

}

/* --- Fin de landing_styles.css --- */
