/* Styles personnalisés pour Le Gazouilleur */

/* Configuration des couleurs personnalisées - Palette #2381 "In Fashion Balance" */
:root {
    /* Palette principale - Jaune moutarde vif (#fbb023) */
    --color-primary-50: #fefdf8;
    --color-primary-100: #fef9e7;
    --color-primary-200: #fdf2c7;
    --color-primary-300: #fbe8a3;
    --color-primary-400: #f9d571;
    --color-primary-500: #fbb023;
    --color-primary-600: #e09e1f;
    --color-primary-700: #c18a1b;
    --color-primary-800: #a27617;
    --color-primary-900: #836213;

    /* Palette secondaire - Rouge doux (#fb6465) */
    --color-secondary-50: #fef7f7;
    --color-secondary-100: #fdeaea;
    --color-secondary-200: #fbd5d5;
    --color-secondary-300: #f8b5b6;
    --color-secondary-400: #f59596;
    --color-secondary-500: #fb6465;
    --color-secondary-600: #e55a5b;
    --color-secondary-700: #cf5051;
    --color-secondary-800: #b94647;
    --color-secondary-900: #a33c3d;

    /* Palette accent - Orange vif (#d0581c) */
    --color-accent-50: #fdf6f2;
    --color-accent-100: #fbece5;
    --color-accent-200: #f7d8c6;
    --color-accent-300: #f2c4a7;
    --color-accent-400: #edb088;
    --color-accent-500: #d0581c;
    --color-accent-600: #bb4f19;
    --color-accent-700: #a64616;
    --color-accent-800: #913d13;
    --color-accent-900: #7c3410;

    /* Neutres - Gris ardoise (#98a3a5) et noir profond (#0a0400) */
    --color-gray-50: #f8fafc;
    --color-gray-100: #f1f5f9;
    --color-gray-200: #e2e8f0;
    --color-gray-300: #cbd5e1;
    --color-gray-400: #98a3a5;
    --color-gray-500: #7a8a8c;
    --color-gray-600: #5c6b6d;
    --color-gray-700: #3e4c4e;
    --color-gray-800: #202d2f;
    --color-gray-900: #0a0400;

    /* Palette bleu canard (#0f666f) */
    --color-teal-50: #f0fdfa;
    --color-teal-100: #ccfbf1;
    --color-teal-200: #99f6e4;
    --color-teal-300: #5eead4;
    --color-teal-400: #2dd4bf;
    --color-teal-500: #0f666f;
    --color-teal-600: #0d5a61;
    --color-teal-700: #0b4e54;
    --color-teal-800: #094247;
    --color-teal-900: #07363a;

    /* Couleurs de succès - Rouge doux (#fb6465) */
    --color-success-50: #fef7f7;
    --color-success-100: #fdeaea;
    --color-success-200: #fbd5d5;
    --color-success-300: #f8b5b6;
    --color-success-400: #f59596;
    --color-success-500: #fb6465;
    --color-success-600: #e55a5b;
    --color-success-700: #cf5051;
    --color-success-800: #b94647;
    --color-success-900: #a33c3d;

    /* Couleurs d'erreur - Rouge doux (#fb6465) */
    --color-error-50: #fef7f7;
    --color-error-100: #fdeaea;
    --color-error-200: #fbd5d5;
    --color-error-300: #f8b5b6;
    --color-error-400: #f59596;
    --color-error-500: #fb6465;
    --color-error-600: #e55a5b;
    --color-error-700: #cf5051;
    --color-error-800: #b94647;
    --color-error-900: #a33c3d;

    /* Couleurs d'avertissement - Jaune moutarde vif (#fbb023) */
    --color-warning-50: #fefdf8;
    --color-warning-100: #fef9e7;
    --color-warning-200: #fdf2c7;
    --color-warning-300: #fbe8a3;
    --color-warning-400: #f9d571;
    --color-warning-500: #fbb023;
    --color-warning-600: #e09e1f;
    --color-warning-700: #c18a1b;
    --color-warning-800: #a27617;
    --color-warning-900: #836213;

    /* Couleurs d'info - Gris ardoise (#98a3a5) */
    --color-info-50: #f8fafc;
    --color-info-100: #f1f5f9;
    --color-info-200: #e2e8f0;
    --color-info-300: #cbd5e1;
    --color-info-400: #98a3a5;
    --color-info-500: #7a8a8c;
    --color-info-600: #5c6b6d;
    --color-info-700: #3e4c4e;
    --color-info-800: #202d2f;
    --color-info-900: #0a0400;

    /* Rétrocompatibilité avec l'ancienne palette */
    --color-nature-50: var(--color-gray-50);
    --color-nature-100: var(--color-gray-100);
    --color-nature-200: var(--color-gray-200);
    --color-nature-300: var(--color-gray-300);
    --color-nature-400: var(--color-gray-400);
    --color-nature-500: var(--color-gray-500);
    --color-nature-600: var(--color-gray-600);
    --color-nature-700: var(--color-gray-700);
    --color-nature-800: var(--color-gray-800);
    --color-nature-900: var(--color-gray-900);

    --color-earth-50: var(--color-secondary-50);
    --color-earth-100: var(--color-secondary-100);
    --color-earth-200: var(--color-secondary-200);
    --color-earth-300: var(--color-secondary-300);
    --color-earth-400: var(--color-secondary-400);
    --color-earth-500: var(--color-secondary-500);
    --color-earth-600: var(--color-secondary-600);
    --color-earth-700: var(--color-secondary-700);
    --color-earth-800: var(--color-secondary-800);
    --color-earth-900: var(--color-secondary-900);

    /* Couleurs des plateformes sociales */
    --color-facebook-50: #eff6ff;
    --color-facebook-100: #dbeafe;
    --color-facebook-500: #3b82f6;
    --color-facebook-600: #2563eb;
    --color-facebook-700: #1d4ed8;

    --color-instagram-50: #fdf2f8;
    --color-instagram-100: #fce7f3;
    --color-instagram-500: #ec4899;
    --color-instagram-600: #db2777;
    --color-instagram-700: #be185d;

    --color-x-50: #f8fafc;
    --color-x-100: #f1f5f9;
    --color-x-500: #64748b;
    --color-x-600: #475569;
    --color-x-700: #334155;

    --color-linkedin-50: #eff6ff;
    --color-linkedin-100: #dbeafe;
    --color-linkedin-500: #0ea5e9;
    --color-linkedin-600: #0284c7;
    --color-linkedin-700: #0369a1;

    /* Couleurs des boosts (système existant) */
    --color-boost-primary: #FF6B35;
    --color-boost-secondary: #FF4D4D;
    --color-boost-accent: #FFE66D;
    --color-boost-light: rgba(255, 107, 53, 0.1);
    --color-boost-medium: rgba(255, 107, 53, 0.2);
    --color-boost-dark: rgba(255, 107, 53, 0.3);
}

/* Typographie moderne */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.heading-font {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    letter-spacing: -0.025em;
}

.display-font {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    letter-spacing: -0.05em;
}

/* Styles pour les cartes Google Maps */
.google-maps-popup {
    font-family: 'Nunito', sans-serif;
    margin: 8px;
}

.google-maps-popup h4 {
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--color-nature-800);
}

.google-maps-popup p {
    margin-bottom: 8px;
    color: #666;
}

.google-maps-popup a {
    color: var(--color-earth-600);
    text-decoration: none;
    font-weight: 500;
}

.google-maps-popup a:hover {
    color: var(--color-earth-700);
}

/* Cartes d'événements modernisées */
.event-card {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 8px;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    position: relative;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.event-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-primary-500), var(--color-secondary-500), var(--color-accent-500));
    opacity: 0;
    transition: opacity 0.3s ease;
}

.event-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    border-color: var(--color-primary-300);
}

.event-card:hover::before {
    opacity: 1;
}

.event-card:active {
    transform: translateY(-4px) scale(1.01);
}

/* Focus state pour l'accessibilité */
.event-card:focus {
    outline: 2px solid #3B82F6;
    outline-offset: 2px;
}

/* ========================================
   SURBRILLANCE DES CARTES D'ÉVÉNEMENTS
   Interactivité avec la carte Google Maps
   ======================================== */

/* Surbrillance de base - Visible mais douce */
.event-card-highlighted {
    transform: scale(1.02);
    box-shadow: 0 8px 25px -5px rgba(59, 130, 246, 0.25), 0 4px 10px -2px rgba(0, 0, 0, 0.1);
    border: 2px solid #3B82F6;
    transition: all 0.2s ease-in-out;
    z-index: 10;
    position: relative;
}

/* Surbrillance spécifique par type d'événement - Couleurs douces */
.event-card-highlighted[data-event-type="theater"] {
    border-color: #8B5CF6;
    box-shadow: 0 8px 25px -5px rgba(139, 92, 246, 0.25);
}

.event-card-highlighted[data-event-type="music"] {
    border-color: #EF4444;
    box-shadow: 0 8px 25px -5px rgba(239, 68, 68, 0.25);
}

.event-card-highlighted[data-event-type="cinema"] {
    border-color: #3B82F6;
    box-shadow: 0 8px 25px -5px rgba(59, 130, 246, 0.25);
}

.event-card-highlighted[data-event-type="workshop"] {
    border-color: #10B981;
    box-shadow: 0 8px 25px -5px rgba(16, 185, 129, 0.25);
}

.event-card-highlighted[data-event-type="exhibition"] {
    border-color: #F59E0B;
    box-shadow: 0 8px 25px -5px rgba(245, 158, 11, 0.25);
}

/* Responsive pour la surbrillance */
@media (max-width: 768px) {
    .event-card-highlighted {
        transform: scale(1.01);
        box-shadow: 0 6px 20px -3px rgba(59, 130, 246, 0.2);
    }
}

/* Transitions fluides pour tous les éléments */
.event-card {
    transition: all 0.2s ease-in-out;
}

/* Hover state amélioré */
.event-card:hover:not(.event-card-highlighted) {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Hashtags inline - Style générique */
.hashtag-inline {
    display: inline;
    color: #1da1f2;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
}

.hashtag-inline:hover {
    text-decoration: underline;
    color: #0d8bd9;
}

/* Badges modernisés */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 8px;
    text-align: center;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.badge-primary {
    background: linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));
    color: white;
    box-shadow: 0 2px 4px rgba(14, 165, 233, 0.2);
}

.badge-secondary {
    background: linear-gradient(135deg, var(--color-secondary-500), var(--color-secondary-600));
    color: white;
    box-shadow: 0 2px 4px rgba(249, 115, 22, 0.2);
}

.badge-accent {
    background: linear-gradient(135deg, var(--color-accent-500), var(--color-accent-600));
    color: white;
    box-shadow: 0 2px 4px rgba(168, 85, 247, 0.2);
}

.badge-success {
    background: linear-gradient(135deg, var(--color-success-500), var(--color-success-600));
    color: white;
    box-shadow: 0 2px 4px rgba(107, 142, 35, 0.2);
}

.badge-warning {
    background: linear-gradient(135deg, var(--color-warning-500), var(--color-warning-600));
    color: white;
    box-shadow: 0 2px 4px rgba(184, 149, 106, 0.2);
}

.badge-error {
    background: linear-gradient(135deg, var(--color-error-500), var(--color-error-600));
    color: white;
    box-shadow: 0 2px 4px rgba(160, 82, 45, 0.2);
}

.badge-info {
    background: linear-gradient(135deg, var(--color-info-500), var(--color-info-600));
    color: white;
    box-shadow: 0 2px 4px rgba(112, 128, 144, 0.2);
}

.badge-gray {
    background: linear-gradient(135deg, var(--color-gray-100), var(--color-gray-200));
    color: var(--color-gray-700);
    border-color: var(--color-gray-300);
}

/* Rétrocompatibilité avec nouvelle palette */
.badge-nature {
    background: linear-gradient(135deg, var(--color-primary-100), var(--color-primary-200));
    color: var(--color-primary-700);
    border-color: var(--color-primary-300);
}

.badge-earth {
    background: linear-gradient(135deg, var(--color-secondary-100), var(--color-secondary-200));
    color: var(--color-secondary-700);
    border-color: var(--color-secondary-300);
}

.badge-green {
    background: linear-gradient(135deg, var(--color-success-100), var(--color-success-200));
    color: var(--color-success-700);
    border-color: var(--color-success-300);
}

.badge-blue {
    background: linear-gradient(135deg, var(--color-info-100), var(--color-info-200));
    color: var(--color-info-700);
    border-color: var(--color-info-300);
}

.badge-yellow {
    background: linear-gradient(135deg, var(--color-warning-100), var(--color-warning-200));
    color: var(--color-warning-700);
    border-color: var(--color-warning-300);
}

/* Badges spécifiques pour les event cards - Palette harmonisée */
.badge-gratuit {
    background: linear-gradient(135deg, var(--color-secondary-500), var(--color-secondary-600));
    color: white;
    box-shadow: 0 2px 4px rgba(251, 100, 101, 0.2);
}

.badge-payant {
    background: linear-gradient(135deg, var(--color-accent-500), var(--color-accent-600));
    color: white;
    box-shadow: 0 2px 4px rgba(208, 88, 28, 0.2);
}

.badge-beau-temps {
    background: linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));
    color: white;
    box-shadow: 0 2px 4px rgba(251, 176, 35, 0.2);
}

.badge-interieur {
    background: linear-gradient(135deg, var(--color-gray-500), var(--color-gray-600));
    color: white;
    box-shadow: 0 2px 4px rgba(122, 138, 140, 0.2);
}

.badge-exterieur {
    background: linear-gradient(135deg, #048b9a, #036a75);
    color: white;
    box-shadow: 0 2px 4px rgba(4, 139, 154, 0.2);
}

.badge-age-theme {
    background: linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));
    color: white;
    box-shadow: 0 2px 4px rgba(251, 176, 35, 0.2);
}

.badge-restauration {
    background: linear-gradient(135deg, #D7520A, #B84408);
    color: white;
    box-shadow: 0 2px 4px rgba(215, 82, 10, 0.2);
}

.badge-adulte {
    background: linear-gradient(135deg, #47622B, #3A4F23);
    color: white;
    box-shadow: 0 2px 4px rgba(71, 98, 43, 0.2);
}

/* Couleurs pour "En voiture Simone" */
.badge-voiture-simone {
    background: linear-gradient(135deg, #AFBCA4, #9BA892);
    color: #28373B;
    box-shadow: 0 2px 4px rgba(175, 188, 164, 0.2);
}

/* Boutons modernisés */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 8px;
    border: 1px solid transparent;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.btn-primary {
    background: linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));
    color: white;
    box-shadow: 0 4px 12px rgba(212, 165, 116, 0.3);
    border: none;
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--color-primary-600), var(--color-primary-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(212, 165, 116, 0.4);
}

.btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 4px 12px rgba(212, 165, 116, 0.3);
}

.btn-secondary {
    background: linear-gradient(135deg, var(--color-secondary-500), var(--color-secondary-600));
    color: white;
    box-shadow: 0 4px 12px rgba(139, 115, 85, 0.3);
    border: none;
}

.btn-secondary:hover {
    background: linear-gradient(135deg, var(--color-secondary-600), var(--color-secondary-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(139, 115, 85, 0.4);
}

.btn-teal {
    background: linear-gradient(135deg, var(--color-teal-500), var(--color-teal-600));
    color: white;
    box-shadow: 0 4px 12px rgba(15, 102, 111, 0.3);
    border: none;
}

.btn-teal:hover {
    background: linear-gradient(135deg, var(--color-teal-600), var(--color-teal-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(15, 102, 111, 0.4);
}

.btn-teal:active {
    transform: translateY(0);
    box-shadow: 0 4px 12px rgba(15, 102, 111, 0.3);
}

.btn-outline-primary {
    background: transparent;
    border: 2px solid var(--color-primary-500);
    color: var(--color-primary-600);
}

.btn-outline-primary:hover {
    background: linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(14, 165, 233, 0.3);
}

.btn-outline-secondary {
    background: transparent;
    border: 2px solid var(--color-secondary-500);
    color: var(--color-secondary-600);
}

.btn-outline-secondary:hover {
    background: linear-gradient(135deg, var(--color-secondary-500), var(--color-secondary-600));
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(249, 115, 22, 0.3);
}

.btn-ghost {
    background: transparent;
    border: 1px solid var(--color-gray-300);
    color: var(--color-gray-700);
}

.btn-ghost:hover {
    background: var(--color-gray-50);
}

/* Boutons avec nouvelles couleurs d'accent */
.btn-success {
    background: linear-gradient(135deg, var(--color-success-500), var(--color-success-600));
    color: white;
    box-shadow: 0 4px 12px rgba(107, 142, 35, 0.3);
    border: none;
}

.btn-success:hover {
    background: linear-gradient(135deg, var(--color-success-600), var(--color-success-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(107, 142, 35, 0.4);
}

.btn-error {
    background: linear-gradient(135deg, var(--color-error-500), var(--color-error-600));
    color: white;
    box-shadow: 0 4px 12px rgba(160, 82, 45, 0.3);
    border: none;
}

.btn-error:hover {
    background: linear-gradient(135deg, var(--color-error-600), var(--color-error-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(160, 82, 45, 0.4);
}

.btn-info {
    background: linear-gradient(135deg, var(--color-info-500), var(--color-info-600));
    color: white;
    box-shadow: 0 4px 12px rgba(112, 128, 144, 0.3);
    border: none;
}

.btn-info:hover {
    background: linear-gradient(135deg, var(--color-info-600), var(--color-info-700));
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(112, 128, 144, 0.4);
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.75rem;
    border-radius: 6px;
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: 1rem;
    border-radius: 10px;
}

/* Styles pour les formulaires */
.form-control:focus {
    border-color: var(--color-earth-500);
    box-shadow: 0 0 0 0.2rem rgba(193, 107, 79, 0.25);
}

/* Classes de formulaire */
.form-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid #d1d5db;
    border-radius: 0.375rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    font-size: 0.875rem;
    line-height: 1.25rem;
    transition: all 0.15s ease-in-out;
}

.form-select {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid #d1d5db;
    border-radius: 0.375rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    font-size: 0.875rem;
    line-height: 1.25rem;
    background-color: white;
    transition: all 0.15s ease-in-out;
}

.form-textarea {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid #d1d5db;
    border-radius: 0.375rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    font-size: 0.875rem;
    line-height: 1.25rem;
    resize: vertical;
    transition: all 0.15s ease-in-out;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--color-earth-500);
    box-shadow: 0 0 0 3px rgba(193, 107, 79, 0.1);
}

/* Styles pour la navigation */
.navbar-brand {
    font-weight: 700;
    font-size: 1.5rem;
}

/* Styles pour les messages */
.alert-success {
    background-color: #dcfce7;
    border-color: #bbf7d0;
    color: #166534;
}

.alert-info {
    background-color: #dbeafe;
    border-color: #bfdbfe;
    color: #1e40af;
}

.alert-warning {
    background-color: #fef3c7;
    border-color: #fde68a;
    color: #92400e;
}

.alert-danger {
    background-color: #fee2e2;
    border-color: #fecaca;
    color: #991b1b;
}

/* Styles pour la pagination */
.pagination .page-link {
    color: var(--color-earth-600);
    border-color: var(--color-earth-200);
}

.pagination .page-item.active .page-link {
    background-color: var(--color-earth-600);
    border-color: var(--color-earth-600);
}

.pagination .page-link:hover {
    color: var(--color-earth-700);
    background-color: var(--color-earth-50);
    border-color: var(--color-earth-300);
}

/* Styles pour les modales */
.modal-header {
    background-color: var(--color-nature-50);
    border-bottom: 1px solid var(--color-nature-200);
}

.modal-title {
    color: var(--color-nature-800);
    font-weight: 600;
}

/* Styles pour les tooltips */
.tooltip-inner {
    background-color: var(--color-nature-800);
    color: white;
}

.tooltip.bs-tooltip-top .tooltip-arrow::before {
    border-top-color: var(--color-nature-800);
}

/* Styles pour les animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in {
    animation: fadeIn 0.3s ease-in-out;
}

/* Styles pour le responsive */
@media (max-width: 768px) {
    .hero-section h1 {
        font-size: 2.5rem;
    }
    
    .hero-section p {
        font-size: 1.1rem;
    }
    
    .filters-section .grid {
        grid-template-columns: 1fr;
    }
}

/* Styles pour les états de chargement */
.loading {
    opacity: 0.6;
    pointer-events: none;
}

.loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid var(--color-earth-200);
    border-top: 2px solid var(--color-earth-600);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Styles pour les transitions HTMX */
.htmx-indicator {
    opacity: 0;
    transition: opacity 200ms ease-in;
}

.htmx-request .htmx-indicator {
    opacity: 1;
}

.htmx-request.htmx-indicator {
    opacity: 1;
}

/* Styles pour les cartes d'événements avec line-clamp */
.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Styles pour les icônes SVG */
.icon {
    width: 1em;
    height: 1em;
    vertical-align: middle;
    fill: currentColor;
}

/* Styles pour les gradients personnalisés */
.gradient-nature {
    background: linear-gradient(135deg, var(--color-nature-50) 0%, var(--color-nature-100) 100%);
}

.gradient-earth {
    background: linear-gradient(135deg, var(--color-earth-50) 0%, var(--color-earth-100) 100%);
}

/* Styles pour les ombres personnalisées */
.shadow-nature {
    box-shadow: 0 4px 6px -1px rgba(76, 76, 56, 0.1), 0 2px 4px -1px rgba(76, 76, 56, 0.06);
}

.shadow-earth {
    box-shadow: 0 4px 6px -1px rgba(193, 107, 79, 0.1), 0 2px 4px -1px rgba(193, 107, 79, 0.06);
} 

/* Search group arrondis UX-proof */
.search-group #geoloc-btn {
  border-top-right-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
}
.search-group.with-change #geoloc-btn {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.search-group #change-location-btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-top-right-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
} 

/* Styles pour les vignettes de type d'événement */
.event-type-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.event-type-card {
    position: relative;
    border: 2px solid var(--color-nature-200);
    border-radius: 12px;
    padding: 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
    background: white;
    text-align: center;
}

.event-type-card:hover {
    border-color: var(--color-earth-400);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.event-type-card.selected {
    border-color: var(--color-earth-600);
    background: linear-gradient(135deg, var(--color-earth-50), var(--color-earth-100));
    box-shadow: 0 8px 25px rgba(209, 122, 90, 0.2);
}

.event-type-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.event-type-icon {
    font-size: 2.5rem;
    margin-bottom: 0.75rem;
    display: block;
}

.event-type-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-nature-800);
    margin-bottom: 0.5rem;
}

.event-type-description {
    font-size: 0.9rem;
    color: var(--color-nature-600);
    line-height: 1.4;
}

.event-type-card.selected .event-type-title {
    color: var(--color-earth-800);
}

.event-type-card.selected .event-type-description {
    color: var(--color-earth-700);
}

/* Responsive pour les vignettes */
@media (max-width: 640px) {
    .event-type-cards {
        grid-template-columns: 1fr;
    }
    
    .event-type-card {
        padding: 1rem;
    }
    
    .event-type-icon {
        font-size: 2rem;
    }
} 

/* ========================================
   PAGE D'ACCUEIL - SECTIONS ÉDITORIALES
   ======================================== */

/* Styles de base pour les sections */
.home-section .section-title a {
    text-decoration: none;
    color: inherit;
}

.home-section .section-title a:hover {
    color: var(--color-earth-600);
}

/* Responsive pour tablette - Icône plus petite et grille 2 colonnes */
@media (min-width: 768px) and (max-width: 1023px) {
    .home-section .section-icon {
        width: 20% !important; /* Réduire légèrement la largeur */
    }
    
    .home-section .events-grid {
        width: 80% !important; /* Augmenter la largeur de la grille */
    }
}

/* Responsive pour mobile - Masquer l'icône et étendre la grille */
@media (max-width: 1023px) {
    .home-section .section-icon {
        display: none; /* Masquer complètement la boîte à gauche */
    }
    
    .home-section .events-grid {
        width: 100% !important; /* Étendre sur toute la largeur */
        max-width: 100%;
    }
    
    .home-section .section-title a {
        text-decoration: underline;
        text-decoration-color: var(--color-earth-300);
        text-underline-offset: 4px;
    }
    
    .home-section .section-title a:hover {
        text-decoration-color: var(--color-earth-600);
    }
    
    /* Améliorer l'espacement sur mobile */
    .home-section {
        margin-bottom: 2rem;
    }
    
    .home-section .space-y-6 > * + * {
        margin-top: 1.5rem;
    }
} 

/* Limiter strictement le gradient au hero */
.hero-section {
    background: #fbb023 !important;
    background-size: 100% auto !important;
    background-repeat: no-repeat !important;
}

/* ========================================
   PAGE DÉTAIL ÉVÉNEMENT - Limitation du gradient
   ======================================== */

/* Limiter la section principale de la page de détail */
.event-main-content {
    height: auto !important;
    min-height: fit-content !important;
    max-height: fit-content !important;
    overflow: visible !important;
    background-size: 100% auto !important;
    background-repeat: no-repeat !important;
}

/* S'assurer que le contenu après cette section a un fond blanc */
.event-main-content + *,
.event-main-content ~ * {
    background-color: white !important;
}

/* ========================================
   BOUTONS HERO - Positionnement précis
   ======================================== */

/* Ajustement fin du positionnement des boutons sur desktop */
@media (min-width: 1024px) {
    .hero-buttons {
        top: -20px !important;
    }
}

/* ========================================
   STYLES POUR LES PLATEFORMES SOCIALES
   ======================================== */

/* Styles pour les plateformes sociales */
.platform-facebook {
    --platform-color: var(--color-facebook-500);
    --platform-color-light: var(--color-facebook-100);
    --platform-color-dark: var(--color-facebook-700);
}

.platform-instagram {
    --platform-color: var(--color-instagram-500);
    --platform-color-light: var(--color-instagram-100);
    --platform-color-dark: var(--color-instagram-700);
}

.platform-x {
    --platform-color: var(--color-x-500);
    --platform-color-light: var(--color-x-100);
    --platform-color-dark: var(--color-x-700);
}

.platform-linkedin {
    --platform-color: var(--color-linkedin-500);
    --platform-color-light: var(--color-linkedin-100);
    --platform-color-dark: var(--color-linkedin-700);
}

/* Styles pour les boosts (système existant) */
.boost-theme {
    --boost-color: var(--color-boost-primary);
    --boost-color-light: var(--color-boost-light);
    --boost-color-dark: var(--color-boost-dark);
    --boost-accent: var(--color-boost-accent);
}

/* Animation du bouton principal - Vibration d'excitation */
@keyframes excitement-vibration {
    0%, 100% {
        transform: translateX(0) translateY(0) rotate(0deg);
    }
    10% {
        transform: translateX(-1px) translateY(-1px) rotate(-0.5deg);
    }
    20% {
        transform: translateX(1px) translateY(1px) rotate(0.5deg);
    }
    30% {
        transform: translateX(-1px) translateY(1px) rotate(-0.3deg);
    }
    40% {
        transform: translateX(1px) translateY(-1px) rotate(0.3deg);
    }
    50% {
        transform: translateX(-0.5px) translateY(-0.5px) rotate(-0.2deg);
    }
    60% {
        transform: translateX(0.5px) translateY(0.5px) rotate(0.2deg);
    }
    70% {
        transform: translateX(-0.5px) translateY(0.5px) rotate(-0.1deg);
    }
    80% {
        transform: translateX(0.5px) translateY(-0.5px) rotate(0.1deg);
    }
    90% {
        transform: translateX(0) translateY(0) rotate(0deg);
    }
}

@keyframes energy-glow {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(255, 107, 53, 0.6);
    }
    50% {
        box-shadow: 0 0 0 6px rgba(255, 107, 53, 0);
    }
}

@keyframes energy-pulse {
    0%, 100% {
        background: linear-gradient(135deg, #FF6B35, #FF4D4D);
    }
    50% {
        background: linear-gradient(135deg, #FF4D4D, #FF6B35);
    }
}

.boost-action-button {
    animation: excitement-vibration 2s infinite, energy-glow 2.5s infinite, energy-pulse 3s infinite;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #FF6B35, #FF4D4D);
    transition: all 0.3s ease;
}

.boost-action-button::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.4s ease;
}

.boost-action-button:hover::before {
    left: 100%;
}

.boost-action-button:hover {
    animation-play-state: paused;
    transform: scale(1.05);
    box-shadow: 0 10px 25px rgba(255, 107, 53, 0.4);
}

/* Styles pour les icônes de plateformes */
.platform-icon {
    background: var(--platform-color-light);
    color: var(--platform-color);
}

.platform-gradient {
    background: linear-gradient(135deg, var(--platform-color), var(--platform-color-dark));
}

.platform-border {
    border-color: var(--platform-color);
}

/* Styles pour les éléments boost */
.boost-icon {
    background: var(--boost-color-light);
    color: var(--boost-color);
}

.boost-gradient {
    background: linear-gradient(135deg, var(--boost-color), var(--boost-color-dark));
}

.boost-border {
    border-color: var(--boost-color);
}

.boost-accent {
    color: var(--boost-accent);
} 