/* =========================================================
   TERRE D'AFRIQUE TV — PREMIUM BRAND OVERRIDE
   (charge après /assets/css/main.css)
========================================================= */

:root{
  /* === Brand (logo-based) === */
  --tda-500:#0F70B7;    /* bleu principal */
  --tda-300:#68C7E2;    /* cyan clair */
  --tda-700:#0B4B78;    /* bleu profond */
  --tda-900:#06243A;    /* navy/ink */

  /* === Neutrals premium === */
  --ink:#0b1220;
  --muted:#5b6575;
  --paper:#ffffff;
  --wash:#f6f8fb;
  --line:rgba(15, 23, 42, .10);

  /* === Radius / Shadow / Motion === */
  --r-sm:10px;
  --r-md:14px;
  --r-lg:18px;

  --sh-1:0 8px 24px rgba(2, 8, 20, .06);
  --sh-2:0 16px 40px rgba(2, 8, 20, .10);

  --ease:cubic-bezier(.2,.8,.2,1);
  --t-fast:160ms;
  --t-med:240ms;

  /* === Type === */
  --font-body: "Roboto", system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  --font-head: "Poppins", system-ui, -apple-system, Segoe UI, Arial, sans-serif;

  /* === Bootstrap runtime vars (quand dispo) === */
  --bs-primary: var(--tda-500);
  --bs-link-color: var(--tda-500);
  --bs-link-hover-color: var(--tda-700);
}

/* Base */
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--wash);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Headings premium */
h1,h2,h3,h4,h5,h6,
.h1,.h2,.h3,.h4,.h5,.h6{
  font-family:var(--font-head);
  letter-spacing:-0.02em;
}
p{ color:var(--ink); }
.small, small, .text-muted{ color:var(--muted)!important; }

/* Links */
a{
  text-decoration:none;
  transition:color var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease);
}
a:hover{ opacity:.95; }

/* Containers / Sections */
.section{ padding:28px 0; }
@media (min-width: 992px){
  .section{ padding:40px 0; }
}

/* =========================================================
   HEADER / NAV — look grand média
========================================================= */
.header{
  background:
    linear-gradient(90deg, var(--tda-700), var(--tda-500)) !important;
  border-bottom:1px solid rgba(255,255,255,.14);
  box-shadow:0 10px 30px rgba(2, 8, 20, .12);
}
.header .logo img{
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.20));
}
.navmenu a{
  color:rgba(255,255,255,.92) !important;
  font-weight:600;
}
.navmenu a:hover,
.navmenu .active{
  color:#fff !important;
}
.mobile-nav-toggle{ color:#fff !important; }

/* =========================================================
   CARDS — premium + cohérence
========================================================= */
.card,
.widget-item,
.news-card,
.same-category .post-card{
  border:1px solid var(--line) !important;
  border-radius:var(--r-md) !important;
  background:var(--paper) !important;
  box-shadow:var(--sh-1);
  overflow:hidden;
}
.card:hover,
.news-card:hover,
.same-category .post-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--sh-2);
}
.card, .news-card, .same-category .post-card{
  transition:transform var(--t-fast) var(--ease), box-shadow var(--t-med) var(--ease);
}

/* =========================================================
   BUTTONS — style média
========================================================= */
.btn{
  border-radius:12px !important;
  font-weight:700;
  letter-spacing:.2px;
  transition:transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.btn:active{ transform:translateY(1px); }

.btn-primary,
.btn.btn-primary{
  background:var(--tda-500) !important;
  border-color:var(--tda-500) !important;
  box-shadow:0 10px 22px rgba(15, 112, 183, .22);
}
.btn-primary:hover{
  background:var(--tda-700) !important;
  border-color:var(--tda-700) !important;
}

.btn-light{
  background:rgba(255,255,255,.92) !important;
  border-color:rgba(255,255,255,.70) !important;
}

.btn-outline-secondary{
  border-color:var(--line) !important;
}
.btn-outline-secondary:hover{
  background:rgba(15,112,183,.08) !important;
  border-color:rgba(15,112,183,.25) !important;
}

/* =========================================================
   INPUTS / SEARCH
========================================================= */
input[type="text"], input[type="email"], input[type="search"],
textarea, select{
  border-radius:12px !important;
  border:1px solid var(--line) !important;
  background:#fff !important;
}
input:focus, textarea:focus, select:focus{
  border-color:rgba(15,112,183,.45) !important;
  box-shadow:0 0 0 .22rem rgba(15,112,183,.18) !important;
}

/* Widget titles */
.widget-title{
  font-family:var(--font-head);
  font-weight:800;
  font-size:1rem;
  margin-bottom:10px;
  position:relative;
  padding-bottom:10px;
}
.widget-title::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:48px; height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--tda-500), var(--tda-300));
  opacity:.95;
}

/* =========================================================
   TICKER — plus premium
========================================================= */
.breaking-ticker{
  background:rgba(255,255,255,.80) !important;
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line) !important;
}
.breaking-ticker .badge.bg-danger{
  background:linear-gradient(90deg, #d90429, #ef233c) !important;
  border-radius:999px !important;
  box-shadow:0 10px 22px rgba(217,4,41,.18);
}

/* =========================================================
   HERO — rendu plus cinéma
========================================================= */
.hero-une .swiper{
  border-radius:var(--r-lg) !important;
  box-shadow:var(--sh-2);
}
.hero-grad{
  background:linear-gradient(180deg,
    rgba(0,0,0,.05) 0%,
    rgba(0,0,0,.40) 55%,
    rgba(0,0,0,.88) 100%) !important;
}
.hero-title{
  text-shadow:0 10px 30px rgba(0,0,0,.45);
}
.hero-meta .badge{
  border-radius:999px !important;
  background:rgba(15,112,183,.70) !important;
}

/* Thumbs */
.thumb-slide{
  border-radius:12px !important;
  box-shadow:0 10px 22px rgba(0,0,0,.10);
}
.swiper-slide-thumb-active .thumb-caption{
  background:rgba(15,112,183,.82) !important;
}

/* =========================================================
   BLOG LIST — typographie “grands médias”
========================================================= */
.blog-posts article{
  background:transparent;
}
.blog-posts .title a{
  color:var(--ink) !important;
  font-weight:900;
  letter-spacing:-.02em;
}
.blog-posts .title a:hover{
  color:var(--tda-700) !important;
}
.blog-posts .meta-top i{
  color:rgba(15,112,183,.9);
}

/* Pagination */
.pagination .page-link{
  border-radius:12px !important;
  border:1px solid var(--line) !important;
}
.pagination .page-link:hover{
  background:rgba(15,112,183,.08) !important;
}
.pagination .page-item.disabled .page-link{
  background:transparent !important;
}

/* =========================================================
   BLOG DETAILS — lecture premium
========================================================= */
.blog-details-page .article{
  width: 100%;
  max-width: 100%;
  margin: 0 !important;
  padding-left: 10px;
  padding-right: 10px;
}

/* Desktop : un peu plus respirant */
@media (min-width: 992px){
  .blog-details-page .article{
    padding-left: 15px;
    padding-right: 15px;
  }
}

.blog-details-page .article .content{
  font-size:1.06rem;
  line-height:1.75;
  color:var(--ink);
}
.blog-details-page .article .content p{
  margin:0 0 1rem;
}
.blog-details-page .article .content a{
  color:var(--tda-500);
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-thickness:2px;
  text-decoration-color:rgba(15,112,183,.28);
}
.blog-details-page .article .content a:hover{
  color:var(--tda-700);
  text-decoration-color:rgba(11,75,120,.40);
}

/* Share bar */
.share-bar{
  border-top:1px solid var(--line) !important;
  border-bottom:1px solid var(--line) !important;
}
.share-bar .share-icons a{
  border:1px solid var(--line) !important;
  border-radius:999px !important;
}
.share-bar .share-icons a:hover{
  background:rgba(15,112,183,.08) !important;
  border-color:rgba(15,112,183,.20) !important;
}

/* =========================================================
   FOOTER — cohérent avec la marque
========================================================= */
.footer.dark-background{
  background:
    radial-gradient(1200px 500px at 20% 0%,
      rgba(104,199,226,.18), transparent 60%),
    linear-gradient(180deg, #071a2a, #061422) !important;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer, .footer p, .footer a{
  color:rgba(255,255,255,.86) !important;
}
.footer a:hover{ color:#fff !important; }

/* Scroll top */
#scroll-top{
  border-radius:999px !important;
  background:var(--tda-500) !important;
  box-shadow:0 12px 30px rgba(15,112,183,.25);
}

/* =========================================================
   BLOG LIST – enlever l'effet “bloc” autour du grid
   et agrandir les articles
========================================================= */

/* 1) La section blog-posts ne doit pas ressembler à une carte */
#blog-posts.blog-posts.section{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;

  /* réduire le gros padding vertical de .section (60px) */
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

/* 2) Le container et la row doivent être neutres */
#blog-posts .container{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#blog-posts .row.gy-4{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;

  /* enlever l'espace "sensation de marge" autour */
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* 3) Agrandir la “carte article” (moins de padding, plus large) */
#blog-posts article{
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;

  /* l'article parait plus grand car on enlève le padding interne */
  padding: 0 !important;
}

/* 4) Le bloc interne de Presento qui donnait l'effet card (si présent) */
#blog-posts .post-img{
  margin: 0 0 14px 0 !important;
}

/* 5) Optionnel: augmenter un peu la taille du titre + extrait */
#blog-posts .title{
  font-size: 30px !important;
  margin: 18px 0 10px !important;
}

#blog-posts .content p{
  font-size: 16px !important;
  line-height: 1.7 !important;
}

/* =========================================================
   BLOG CARDS — mise en valeur par col-12
========================================================= */

/* La colonne devient la carte */
#posts-grid > .col-12{
  background: var(--paper);
  border: 1px solid var(--line);

  /* Ombre surtout vers le bas */
  box-shadow:
    0 12px 22px rgba(0,0,0,.08),
    0 4px 8px rgba(0,0,0,.05);

  padding: 22px;
  margin-bottom: 26px;

  transition:
    transform var(--t-fast) var(--ease),
    box-shadow var(--t-med) var(--ease);
}

/* Effet hover “élévation” */
#posts-grid > .col-12:hover{
  transform: translateY(-3px);

  box-shadow:
    0 20px 40px rgba(0,0,0,.12),
    0 6px 14px rgba(0,0,0,.08);
}

/* L’article interne devient neutre */
#posts-grid > .col-12 article{
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border: 0 !important;
}


/* =========================================================
   FLASH — clignotement média discret
========================================================= */

.breaking-ticker .badge{
  animation: flashPulse 1.4s ease-in-out infinite;
}

@keyframes flashPulse{
  0%   { box-shadow:0 0 0 rgba(255,0,0,0); }
  50%  { box-shadow:0 0 12px rgba(255,0,0,.45); }
  100% { box-shadow:0 0 0 rgba(255,0,0,0); }
}


/* =========================================================
   HEADER — gradient TV premium
========================================================= */

.header{
  background:
    linear-gradient(135deg,
      #06243A 0%,
      #0B4B78 35%,
      #0F70B7 65%,
      #68C7E2 100%) !important;

  position: relative;
  overflow: hidden;
}

/* Effet lumière */
.header::after{
  content:"";
  position:absolute;
  inset:0;

  background:
    radial-gradient(
      circle at 20% 0%,
      rgba(255,255,255,.18),
      transparent 60%
    );

  pointer-events:none;
}

/* =========================================================
   BOUTON "LIRE PLUS" — charte TERRE D'AFRIQUE TV (premium)
========================================================= */

#posts-grid .read-more a{
  /* reset template */
  background: none !important;
  border: 0 !important;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;

  padding: 10px 18px !important;
  border-radius: 2px !important;

  color: #fff !important;
  font-weight: 800;
  letter-spacing: .2px;

  background: linear-gradient(135deg, var(--tda-700), var(--tda-500)) !important;
  box-shadow: 0 10px 22px rgba(15,112,183,.22);

  transition:
    transform var(--t-fast) var(--ease),
    box-shadow var(--t-med) var(--ease),
    filter var(--t-fast) var(--ease);
}

#posts-grid .read-more a:hover{
  transform: translateY(-2px);
  filter: brightness(1.03);
  box-shadow: 0 16px 34px rgba(2,8,20,.16), 0 10px 22px rgba(15,112,183,.22);
}

#posts-grid .read-more a:active{
  transform: translateY(0px);
  filter: brightness(.98);
  box-shadow: 0 8px 18px rgba(15,112,183,.18);
}

#posts-grid .read-more a:focus-visible{
  outline: none;
  box-shadow: 0 0 0 .22rem rgba(104,199,226,.35), 0 12px 26px rgba(15,112,183,.22);
}


/* =========================================================
   ESPACE ENTRE LES CARDS — réduire marge trop grande
========================================================= */

/* 1) Réduit le gap vertical Bootstrap (gy-4) */
#posts-grid{
  --bs-gutter-y: 14px; /* était ~24px via gy-4 */
}

/* 2) Réduit la marge que tu avais ajoutée */
#posts-grid > .col-12{
  margin-bottom: 12px !important; /* était 26px */
}


/* =========================================================
   FIX BLOG IMAGE — full bleed (sans marges) + padding texte
========================================================= */

/* 1) La carte */
#posts-grid > .col-12{
  border-radius: 9px !important;
  overflow: hidden !important;
  padding: 0 !important;
}

/* 2) IMPORTANT : aucun padding sur l'article (sinon l'image aura des marges) */
#posts-grid > .col-12 article{
  padding: 0 !important;
}

/* 3) Image plein bord */
#posts-grid > .col-12 .post-img{
  margin: 0 !important;
  padding: 0 !important;
}

#posts-grid > .col-12 .post-img img{
  display: block !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  border-radius: 0 !important; /* pas d'arrondis internes */
}

/* 4) Padding uniquement pour le contenu texte */
#posts-grid > .col-12 h2.title,
#posts-grid > .col-12 .meta-top,
#posts-grid > .col-12 .content{
  padding-left: 22px !important;
  padding-right: 22px !important;
}

/* Option : petit espace au-dessus du titre */
#posts-grid > .col-12 h2.title{
  padding-top: 18px !important;
}

/* Option : espace bas de la carte */
#posts-grid > .col-12 .content{
  padding-bottom: 22px !important;
}

/* =========================================================
   COUVERTURE + NAV “logo apparaît au scroll”
========================================================= */

/* Couverture : AUCUN padding/marge, l'image = la section */
.tda-cover{
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;          /* annule le padding global des <section> */
  line-height: 0;                 /* supprime tout petit espace “baseline” */
  background: #06243A;
  border: 0;                      /* si tu veux 100% collé */
  display: block;
}

/* Image : 100% responsive, AUCUN recadrage, ratio conservé */
.tda-cover img{
  display: block;
  width: 100%;
  height: auto;                   /* garde toutes les dimensions */
  max-width: 100%;
  margin: 0 !important;
  padding: 0 !important;
  object-fit: contain;            /* sécurité (mais ne recadre pas) */
}

/* Sentinel : doit être neutre (aucun espace) */
#tda-cover-sentinel{
  height: 1px;
  margin: 0 !important;
  padding: 0 !important;
}

/* Header : par défaut (tout en haut) => logo caché */


#header .logo img{
  max-height: 34px;
}

/* Quand on a scrollé après la couverture => logo visible */
#header.is-stuck .logo{
  opacity: 1;
  visibility: visible;
  width: auto;
  pointer-events: auto;
  transform: translateY(0);
}

/* Ajuste le padding du header si tu veux */
#header.header{
  padding: 14px 0;
}

/* =========================================================
   HEADER — Logo invisible sans casser le layout
========================================================= */

/* Container du header toujours en flex */
#header .container-fluid{
  display: flex !important;
  align-items: center;
}

/* Zone logo : garde sa place même cachée */
#header .logo{
  display: flex;
  align-items: center;

  min-width: 150px;   /* réserve l’espace du logo */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;

  transition: opacity .2s ease, visibility .2s ease;
}

/* Image logo */
#header .logo img{
  max-height: 34px;
}

/* Nav toujours à droite */
#header .navmenu{
  margin-left: auto !important; /* force à droite */
}

/* Quand on scroll → logo visible */
#header.is-stuck .logo{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Mobile : bouton hamburger à droite */
#header .mobile-nav-toggle{
  margin-left: auto !important;
}

/* Sécurité : ne jamais centrer */
#header .container-xl,
#header .container-fluid{
  justify-content: flex-start !important;
}


/* =========================================================
   STICKY HEADER (reste figé en haut)
========================================================= */

/* Le header reste au top quand on scroll */
#header.header{
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important; /* au-dessus du contenu */
}

/* IMPORTANT : comme le header devient sticky, il doit être opaque */
#header.header{
  backdrop-filter: none !important;
}

/* (Optionnel) évite les petits sauts sur mobile */
#header.header{
  will-change: transform;
}

/* =========================================================
   MITALA NEWS — SECTION HEAD (barre ombrée + languette)
   -> Adapté couleurs TERRE D'AFRIQUE TV (navy/bleu/cyan)
========================================================= */

.mn-section-head{
  position: relative;
  margin: 16px 0 14px;
  padding: 0; /* pas de padding = pas de décalage */
  margin-bottom: 30px !important;
}

/* La barre ombrée */
.mn-section-head::before{
  content:"";
  display:block;
  height: 10px;
  border-radius: 999px;

  /* Charte TDA: navy -> bleu profond -> bleu -> cyan */
  background: linear-gradient(90deg,
    rgba(6,36,58,.70),    /* --tda-900 */
    rgba(11,75,120,.65),  /* --tda-700 */
    rgba(15,112,183,.75), /* --tda-500 */
    rgba(104,199,226,.65) /* --tda-300 */
  );

  box-shadow:
    0 10px 18px rgba(2, 8, 20, .16),
    inset 0 1px 0 rgba(255,255,255,.14);
}

/* La languette (titre) */
.mn-section-head .mn-tab{
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);

  display: inline-flex;
  align-items: center;
  gap: .5rem;

  padding: .55rem .9rem;
  border-radius: 999px;

  /* fond languette: navy TDA */
  background: rgba(6,36,58,.86);
  color: #fff;

  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .78rem;

  /* bordure cyan TDA */
  border: 1px solid rgba(104,199,226,.30);
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  backdrop-filter: blur(6px);
}

/* Petite pastille (cyan) */
.mn-section-head .mn-tab::before{
  content:"";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(104,199,226,1);
  box-shadow: 0 0 0 3px rgba(104,199,226,.18);
}

/* Variante sur fond sombre (si parent .dark-background) */
.dark-background .mn-section-head .mn-tab{
  background: rgba(6,36,58,.72);
  border-color: rgba(104,199,226,.40);
}

/* Responsive */
@media (max-width: 575.98px){
  .mn-section-head{ margin: 12px 0 12px; }
  .mn-section-head::before{ height: 9px; }
  .mn-section-head .mn-tab{
    left: 10px;
    padding: .5rem .75rem;
    font-size: .72rem;
  }
}
