/* === Thème Paris.fr - CLAIR ET OFFICIEL === */
:root {
  --bg: #f7f7f7; /* Fond clair général */
  --panel: #ffffff; /* Panneau de contenu principal (blanc) */
  --muted: #555555; /* Texte secondaire/muet (gris foncé) */
  --text-primary: #1e1e1e; /* Texte principal (presque noir) */
  --primary-blue: #0059b3; /* Bleu officiel Paris.fr */
  --accent-red: #d3102a; /* Rouge d'accentuation (pour les actions) */
  --border-light: rgba(0, 0, 0, 0.1); /* Bordures subtiles */
}

body {
  font-family: Arial, sans-serif;
  /* DÉGRADÉ PLUS MARQUÉ : Blanc cassé vers un bleu très clair un peu plus présent */
  background: linear-gradient(180deg, #f8f8ff 0%, #e6f0ff 100%);
  color: var(--text-primary);
  line-height: 1.6;
}

/* --- CORRECTION POUR QUE LE DÉGRADÉ SOIT VISIBLE --- */
/* Si vous avez un conteneur général (wrapper) qui entoure tout sauf le header/footer,
   assurez-vous qu'il n'écrase pas le background du body. */
.main-container, .main-wrapper, .page-content-wrapper { /* Rétablissement du sélecteur original suite à la demande de l'utilisateur. */
    background-color: transparent; /* Permet au dégradé du body d'être visible */
}
/* ------------------------------------------------ */

.main-nav a {
  border-radius: 6px;
}
.btn {
border-radius: 6px;
}
.pagination a, .pagination span {
  border-radius: 6px;
 } 
 .tag-cloud a {
   border-radius: 6px;
  } 
  .hero-content .btn {
    border-radius: 8px;
}
.sidebar {
  border-radius: 14px;
}
.contact {
  border-radius: 12px;
}
.contact .captcha img {
  border-radius: 6px;
 }
 .contact button {
   border-radius: 8px;
}
form {
border-radius: 10px;
}
input[type="text"],
input[type="email"],
textarea {
border-radius: 4px;
}


.card {
border-radius: 10px;
}
.hero-card {
  border-radius: 16px;
 }
.article-full::before {
    content: ""; 
    border-radius: 10px;
}
.article-photo img {
    border-radius: 8px;
}
.article-video-block .video-container {
    border-radius: 8px;
}
.article-video-block .video-container iframe {
    border-radius: 8px;
}
.article-link {
    border-radius: 8px;
}
@media (max-width: 768px) {
 .card { 
  border-radius:12px;
    }
}
/* === Header === */
.site-header {
  /* Bleu officiel pour l'en-tête, aspect institutionnel */
  background: var(--primary-blue);
  border-bottom: 2px solid #003c7d;
}

.header-inner {
  background: transparent !important;
}
.site-title {
  color: #ffffff; /* Titre blanc sur fond bleu */
  font-weight: bold;
}
.main-nav a {
  color: #ffffff;
  text-decoration: none;
  opacity: 0.9;
  padding: 8px 12px;
  border-radius: 4px;
  transition: all 0.3s ease;
}
.main-nav a:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.15);
  opacity: 1;
}


/* === Bouton menu mobile (Rouge pour haute visibilité) === */
#menu-toggle {
  background: var(--accent-red);
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
  transition: background 0.3s ease;
  border: none;
  border-radius: 4px;
}
#menu-toggle:hover { background: #e03c4f; }

/* === Sidebar === */
.sidebar {
  background: var(--panel);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  transition: none; /* Simplification */
}

/* Correction de la faute de frappe et utilisation du bleu */
.sidebar ul li.menu-title {
  color: var(--primary-blue);
  font-weight: bold;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  padding: 8px 12px;
}

/* Pour désactiver l’effet hover sur les titres */
.sidebar ul li.menu-title:hover {
  background: transparent;
  color: var(--primary-blue);
  transform: none;
  text-shadow: none;
}

.sidebar h3 {
  color: var(--primary-blue);
  border-bottom: 1px solid var(--border-light);
  padding-bottom: 8px;
}

.sidebar ul li a {
  color: var(--text-primary);
  padding: 8px 0;
  display: block;
  border-radius: 4px;
  transition: background 0.2s ease, color 0.2s ease;
}

.sidebar ul li a:hover {
  /* Nettoyage des effets flashy */
  background: rgba(0, 89, 179, 0.05); /* Léger fond bleu */
  color: var(--primary-blue);
  transform: none;
  text-shadow: none;
}
/* Scrollbar subtile en bleu pour la sidebar */
.sidebar::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
}

.sidebar::-webkit-scrollbar-thumb {
    background: rgba(0, 89, 179, 0.4);
    border-radius: 10px;
}

.sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 89, 179, 0.6);
}
/* Firefox */
.sidebar {
    scrollbar-color: rgba(0, 89, 179, 0.4) rgba(0, 0, 0, 0.05);
}

/* === Définition des panneaux de contenu OPAQUE (Non-Responsive) === */
.card, 
.article-full,
.contact,
#tags,
.search-container,
/* CIBLE CONTENU PRINCIPAL */
html body main.container div.page-layout div.page-layout div.main-content section {
  background: var(--panel); /* Fond blanc opaque par défaut */
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  transition: box-shadow 0.3s ease;
}
main.container div.page-layout div.main-content section {
  background: var(--panel);
}
/* CIBLE LES CARTES D'ARTICLES dans les listes (même comportement que .card) */
html body main.container div.page-layout main.main-content section.articles-liste article.card {
    background: var(--panel);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    border: 1px solid var(--border-light);
    border-radius: 8px;
}

.card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.meta { color: var(--muted); }
.btn {
  background: var(--primary-blue);
  color: #fff;
  border-radius: 4px;
  padding: 8px 16px;
  transition: background 0.3s ease;
}
.btn:hover {
    background: #00458c;
}

/* === Bouton d'action accentué (pour 'Vir' ou autres actions critiques) === */
.btn-accent {
  background: var(--accent-red);
  color: #fff;
  border-radius: 4px;
  padding: 8px 16px;
  transition: background 0.3s ease;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}
.btn-accent:hover {
    background: #a60c21; /* Rouge plus foncé au survol */
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

/* === Footer === */
.site-footer {
  /* Utilisation d'un bleu foncé pour le footer */
  background: #00458c;
  color: #ccc;
  border-top: 1px solid #003c7d;
  padding: 20px 0;
}
.footer-links a { 
  color: #f0f0f0; 
  text-decoration: none;
  transition: color 0.3s ease;
}
.footer-links a:hover { 
  text-decoration: underline; 
  color: #fff;
}

/* === Pagination === */
.pagination a, .pagination span {
  border-radius: 4px;
  border: 1px solid #ccc;
}
.pagination a {
  background: #e0e0e0;
  color: var(--text-primary);
}
.pagination a:hover { 
  background: var(--primary-blue); 
  color: #fff; 
  border-color: var(--primary-blue);
}
.pagination .current { 
  background: var(--primary-blue); 
  color: white; 
  font-weight: bold;
  border-color: var(--primary-blue);
}
.pagination .dots { color: var(--muted); }

/* === Mentions legales === */
main.container section#mentions-legales.article {
  background: var(--panel);
}
/* === Nuage de tags === */
#tags h2 {
  color: var(--primary-blue);
  text-shadow: none;
  border-bottom: 2px solid var(--border-light);
  padding-bottom: 8px;
}
.tag-cloud a {
  color: var(--primary-blue);
  transition: all 0.2s ease;
  opacity: 1;
  /* Retrait de l'animation floaty */
  animation: none;
  border: 1px solid rgba(0, 89, 179, 0.3);
  background: rgba(0, 89, 179, 0.05);
  border-radius: 4px;
  padding: 4px 8px;
  margin: 3px;
  display: inline-block;
}
.tag-cloud a:hover {
  color: var(--accent-red); /* Rouge d'accentuation au survol */
  opacity: 1;
  transform: scale(1.05);
  text-shadow: none;
  border-color: var(--accent-red);
}
@keyframes floaty {
  /* Animation désactivée */
  0%,100% { transform: none; }
}

/* === Hero / Catégories (Passage à un look clair et propre) === */
.categories-hero {
  background: var(--bg);
}
.hero-card {
  background: var(--panel);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  border: 1px solid var(--border-light);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  animation: none; /* Retrait de l'animation */
  border-radius: 8px;
}
.hero-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}
.hero-card figure { 
    background: #e9e9f0; 
    border-radius: 8px 8px 0 0;
}
.hero-content {
  background: var(--panel);
  color: var(--text-primary);
  padding: 15px;
}
.hero-content h3.cat-name { 
  color: var(--primary-blue); 
  text-shadow: none; 
  margin-bottom: 4px;
}
.hero-content h4 { color: var(--text-primary); }
.hero-content p { color: var(--muted); }
.hero-content .btn {
  /* Bouton principal en bleu */
  background: var(--primary-blue);
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}
.hero-content .btn:hover {
  background: #00458c;
  transform: scale(1.02);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}
@keyframes fadeUp { /* Retrait de l'animation */ }

/* === Responsive général === */
@media (max-width: 768px) {
  /* Réaffirme l'opacité sur mobile pour tous les conteneurs */
  .card, 
  .article-full,
  .contact,
  #tags,
  .search-container,
  /* Conteneur principal de recherche/contenu */
  html body main.container div.page-layout div.page-layout div.main-content section,
  /* CIBLE LA CARTE D'ARTICLE DANS LA LISTE EN MODE RESPONSIVE */
  html body main.container div.page-layout main.main-content section.articles-liste article.card {
    background: var(--panel); /* Fond blanc opaque */
    border: 1px solid var(--border-light); 
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); 
    border-radius: 8px; 
  }
  
  /* Assurer que les boutons gardent leurs couleurs */
  .btn {
    background: var(--primary-blue);
    color: #fff;
  }
  .btn-accent {
    background: var(--accent-red);
    color: #fff;
  }
  
  /* S'assurer que les liens de tags ont un fond */
  .tag-cloud a {
    background: rgba(0, 89, 179, 0.05);
  }

  /* === NOUVELLE RÈGLE : Bouton d'extrait d'article (.articles-liste) sur mobile === */
  html body main.container div.page-layout main.main-content section.articles-liste article.card div.excerpt p a.btn {
      /* Le style est déjà défini globalement par .btn, mais on le réaffirme ici pour garantir l'écrasement 
         de tout style moins prioritaire qui le rendrait transparent ou non stylé sur mobile */
      background: var(--primary-blue);
      color: #fff;
      border: none;
      box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
      text-decoration: none; /* Assurer qu'il n'y ait pas de soulignement */
      padding: 8px 16px; /* Taille cohérente */
      border-radius: 4px;
      display: inline-block; /* Assurer qu'il se comporte comme un bouton bloc pour la taille */
  }
}

/* === Sections Catégorie === */
.category-title { 
    color: var(--primary-blue);
    text-shadow: none; 
    border-bottom: 2px solid var(--border-light);
    padding-bottom: 8px;
}
.no-article { color: var(--muted); }
/* === Formulaire de contact – harmonisé avec le thème clair === */
.contact {
  color: var(--text-primary);
  padding: 20px;
}

.contact h2 {
  color: var(--primary-blue);
}

.contact input:focus,
.contact textarea:focus {
  border-color: var(--primary-blue);
  box-shadow: 0 0 4px rgba(0, 89, 179, 0.4);
  outline: none;
}
.contact h2,
.category-title {
  color: var(--primary-blue);
  text-shadow: none;
}
form {
  background: var(--panel); /* Formulaire sur fond blanc */
  box-shadow: none; /* Retrait de l'ombre interne */
  border: none;
  padding: 0;
}

label {
  color: var(--text-primary);
  text-shadow: none;
  font-weight: bold;
}

input[type="text"],
input[type="email"],
textarea {
  background: #fcfcfc;
  color: var(--text-primary);
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 10px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

input:focus,
textarea:focus {
  border-color: var(--primary-blue);
  box-shadow: 0 0 4px rgba(0, 89, 179, 0.4);
  outline: none;
}

/* Bouton d’envoi en Rouge d'accentuation */
.contact button,
button[type="submit"] {
  background: var(--accent-red);
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
  transition: background 0.3s ease, transform 0.2s ease;
  border: none;
  border-radius: 4px;
  padding: 10px 20px;
  font-weight: bold;
}

.contact button:hover,
button[type="submit"]:hover {
  background: #e03c4f;
  transform: scale(1.02);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

/* Messages de feedback */
.contact .feedback-success {
  color: #0d832d;
  font-weight: bold;
}

.contact .feedback-error {
  color: var(--accent-red);
  font-weight: bold;
}

section.contact form p.info-rgpd {
  color: var(--muted);
}
/* Captcha */
.contact .captcha img {
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.contact .captcha a {
  color: var(--primary-blue);
}

.contact .captcha a:hover {
  color: var(--accent-red);
}

/* === ARTICLE HERO-LIKE CENTRÉ === */
.article-full {
  padding: 20px;
}

/* --- fond léger derrière l'article (supprimé) --- */
.article-full::before {
    background: none;
}

/* --- images et vidéos centrées dans l’article --- */
.article-photo img,
.article-video-block img,
.article-video-block .video-container,
.article-video-block .video-container iframe {
    border-radius: 6px;
    border: 1px solid var(--border-light);
}


/* --- texte et métadonnées --- */
article .result-meta {
    color: var(--muted);
    font-style: italic;
}

.article-link {
    background: #eef2f8; /* Léger fond bleu clair pour les liens externes */
    border-radius: 6px;
    border: 1px solid rgba(0, 89, 179, 0.2);
    padding: 10px;
}

.article-link .link-comment {
    color: #444;
}

.article-link .link-item a {
    color: var(--primary-blue);
    font-weight: bold;
    text-decoration: none;
    transition: text-decoration 0.3s ease;
}

.article-link .link-item a:hover {
    text-decoration: underline;
    color: var(--accent-red);
}

.article-content p {
    color: var(--text-primary);
}

.social-share a {
  color: white;
  background-color: #777;
  transition: background-color 0.3s ease, transform 0.2s ease;
  border-radius: 50%;
  padding: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.social-share a:hover {
  transform: scale(1.1);
}

.facebook:hover { background-color: #3b5998; }
.twitter:hover  { background-color: #000000; } /* X / Twitter */
.linkedin:hover { background-color: #0077b5; }
.instagram:hover { background: #d6249f; } /* Couleur unie professionnelle */
/* =========================================================
   BLOC 2 : COULEURS ET EFFETS VISUELS (Thème Paris.fr Harmonisé)
   ========================================================= */

/* Le conteneur du fil d'actualité */
.sidebar-right.news-feed {
    /* Fond blanc net et propre */
    background: var(--panel); 
    /* Bordure subtile et professionnelle */
    border: 1px solid var(--border-light); 
    border-radius: 8px;
    /* Ombre claire et discrète */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); 
}

/* 2a. La ligne verticale de la timeline */
.sidebar-right.news-feed::before {
    /* Ligne fine et claire, similaire aux autres bordures */
    background: #ccc; 
}

/* 2d. L'horloge / Montre en haut de la timeline */
.sidebar-right.news-feed::after {
    /* Couleur de l'accent (Bleu Officiel) pour le point de départ */
    color: var(--primary-blue); 
    
    /* Le fond doit être blanc pour masquer la ligne derrière l'icône */
    background: var(--panel); 
    /* Retire toute ombre ou effet de 'glow' */
    text-shadow: none; 
}

/* 2c. Le point de la timeline (généré sur chaque li) */
.news-feed li::before {
    /* Remplissage du point en Bleu Officiel */
    background: var(--primary-blue); 
    
    /* Bordure en blanc pour un effet de contraste ou d'icône "percée" */
    border: 3px solid white; 
    /* Retire l'ombre (glow) */
    box-shadow: none; 
}

/* Bordure de séparation des éléments de la liste */
.news-feed li {
    /* Ligne de séparation très discrète */
    border-bottom: 1px dashed var(--border-light); 
}


/* 3. STYLES VISUELS ET TYPOGRAPHIE */
.news-feed h2 {
    /* Titre en Bleu Officiel */
    color: var(--primary-blue); 
    border-bottom: 2px solid var(--border-light); /* Bordure fine et claire */
    margin-bottom: 10px;
    padding-bottom: 5px;
    font-weight: 700;
}

.news-feed li strong {
    /* Date/titre en couleur de texte principale pour la clarté */
    color: var(--text-primary); 
    font-weight: 700;
}

.news-feed li p {
    /* Description en couleur muted (gris) */
    color: var(--muted); 
}
