/*
Theme Name: Duniya Kibaru
Theme URI: https://duniyakibaru.ml
Author: Flantie
Author URI: https://duniyakibaru.ml
Description: Thème personnalisé pour le journal Duniya Kibaru, compatible TagDiv Composer.
Version: 1.1
Text Domain: duniya-kibaru
*/

:root{
  --navy:#0C2540;
  --navy-light:#16365C;
  --coral:#D85A30;
  --coral-dark:#993C1D;
  --cream:#F7F4ED;
  --gray-100:#EDEBE3;
  --gray-300:#D3D1C7;
  --gray-500:#888780;
  --gray-700:#5F5E5A;
  --text:#1A1A18;
  --green:#27500A;
  --green-bg:#EAF3DE;
  --blue-bg:#E6F1FB;
  --blue-text:#0C447C;
  --coral-bg:#FAECE7;
  --serif: 'Georgia', 'Times New Roman', serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
}
*{margin:0; padding:0; box-sizing:border-box;}
body{font-family:var(--sans); background:var(--cream); color:var(--text); line-height:1.6;}
a{text-decoration:none; color:inherit;}
img{max-width:100%; display:block;}
.wrap{max-width:1180px; margin:0 auto; padding:0 20px;}

/* === Topbar === */
.topbar{background:#fff; border-bottom:1px solid var(--gray-300); font-size:13px; color:var(--gray-700);}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; height:38px; flex-wrap:wrap; gap:8px;}
.topbar-left, .topbar-right{display:flex; align-items:center; gap:18px;}
.topbar-right a{color:var(--gray-700);}
.topbar-right .subscribe{background:var(--coral); color:#fff; font-weight:600; padding:4px 12px; border-radius:4px; font-size:12px;}
.icon{font-size:14px; opacity:.8;}
.social-icons{display:flex; gap:10px; font-size:14px; color:var(--navy);}

/* === Header / logo === */
.header{background:#fff; border-bottom:1px solid var(--gray-300);}
.header .wrap{display:flex; align-items:center; justify-content:space-between; padding:18px 20px; flex-wrap:wrap; gap:16px;}
.logo, .logo-link{display:flex; align-items:center; gap:12px;}
.logo-mark{position:relative; width:48px; height:48px; border-radius:50%; border:3px solid var(--navy); display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:bold; font-size:22px; color:var(--navy); flex-shrink:0;}
.logo-mark .ring{position:absolute; width:66px; height:18px; border:2px solid #6FA8DC; border-radius:50%; transform:rotate(-20deg);}
.logo-text{font-family:var(--serif); font-size:32px; font-weight:bold; color:var(--navy); letter-spacing:0.5px;}
.logo-sub{font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--gray-500); margin-top:2px;}
.ad-slot{background:var(--gray-100); border:1px dashed var(--gray-300); color:var(--gray-500); font-size:12px; text-transform:uppercase; letter-spacing:1px; display:flex; align-items:center; justify-content:center; width:300px; height:80px; border-radius:6px;}

/* Sur mobile : la pub 300x80 du header dépasse souvent l'écran et casse la mise
   en page (logo + pub côte à côte ne tiennent plus). On la masque purement et
   simplement sous 480px ; entre 481px et 768px on la réduit à un format bannière
   plus étroit (320x50, format standard "mobile banner") pour rester lisible. */
@media (max-width: 768px) and (min-width: 481px){
  .header .ad-slot{ width:100%; max-width:320px; height:50px; font-size:10px; }
  .header .wrap{ flex-direction:column; align-items:flex-start; }
}
@media (max-width: 480px){
  .header .ad-slot{ display:none; }
}

/* === Nav (bandeau bleu marine) === */
.nav{background:var(--navy); border-bottom:3px solid var(--coral); position:relative;}
.nav .wrap{display:flex; align-items:center; gap:26px; flex-wrap:wrap; padding:0 20px;}
.nav .primary-menu{list-style:none; display:flex; gap:26px; flex-wrap:wrap; margin:0; padding:0;}
.nav .primary-menu li{display:inline-block;}
.nav a{color:#C7D6E8; font-size:14px; font-weight:600; padding:14px 0; display:inline-block; border-bottom:3px solid transparent; margin-bottom:-3px; transition:color .15s, border-color .15s;}
.nav a:hover, .nav .current-menu-item a{color:#fff; border-bottom-color:var(--coral);}
.nav .search{margin-left:auto; color:#C7D6E8; font-size:16px;}

/* Bouton burger : caché par défaut (desktop), affiché seulement en media query mobile */
.nav-toggle{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:32px;
  height:32px;
  background:none;
  border:none;
  cursor:pointer;
  padding:0;
  flex-shrink:0;
}
.nav-toggle .burger-bar{
  display:block;
  width:100%;
  height:2px;
  background:#C7D6E8;
  border-radius:2px;
  transition: transform .2s ease, opacity .2s ease;
}
/* Animation en "croix" quand le menu est ouvert */
.nav-toggle.is-active .burger-bar:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-active .burger-bar:nth-child(2){ opacity:0; }
.nav-toggle.is-active .burger-bar:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* === Responsive nav : menu burger sous 880px === */
@media (max-width: 880px){
  .nav .wrap{ position:relative; padding:0 16px; flex-wrap:nowrap; }
  .nav-toggle{ display:flex; order:1; }
  .nav .search{ order:2; margin-left:auto; }

  .nav .primary-menu{
    order:3;
    display:none;
    flex-direction:column;
    gap:0;
    width:100%;
    position:absolute;
    top:100%;
    left:0;
    background:var(--navy-light);
    box-shadow:0 8px 16px rgba(0,0,0,0.25);
    z-index:50;
  }
  .nav .primary-menu.is-open{ display:flex; }
  .nav .primary-menu li{ width:100%; border-bottom:1px solid rgba(255,255,255,0.08); }
  .nav .primary-menu a{
    width:100%;
    padding:14px 20px;
    margin-bottom:0;
    border-bottom:none;
  }
  .nav .primary-menu a:hover, .nav .primary-menu .current-menu-item a{
    background:rgba(255,255,255,0.06);
    border-bottom:none;
  }
}

/* === Ticker (défilement dynamique des derniers articles) === */
.ticker{background:var(--coral); color:var(--coral-bg); font-size:13px;}
.ticker .wrap{display:flex; align-items:center; gap:14px; padding:8px 20px; overflow:hidden;}
.ticker .badge{background:var(--coral-dark); color:var(--coral-bg); font-weight:700; padding:4px 10px; border-radius:4px; flex-shrink:0; font-size:12px; letter-spacing:0.5px;}

.ticker .ticker-track{
  flex:1 1 auto !important;
  overflow:hidden !important;
  position:relative !important;
  height:20px !important;
  width:100% !important;
}

/* Liste UNIQUE contenant les articles dupliqués deux fois à la suite.
   On anime translateX(0) -> translateX(-50%) : comme le contenu réel
   n'occupe que la moitié de la largeur totale, la boucle est invisible. */
.ticker .ticker-track .ticker-items{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
  position:absolute !important;
  top:0 !important;
  left:0 !important;
  white-space:nowrap !important;
  width:max-content !important;
  animation: ticker-scroll 60s linear infinite;
  will-change: transform;
}
.ticker .ticker-track .ticker-items li{
  display:inline-flex !important;
  flex-shrink:0 !important;
  white-space:nowrap !important;
  padding-right:60px !important; /* espacement net entre chaque titre */
}
.ticker .ticker-items a{
  color:var(--coral-bg);
  font-weight:600;
  white-space:nowrap !important;
}
.ticker .ticker-items a:hover{text-decoration:underline;}
.ticker .ticker-items li[aria-hidden="true"] a{ pointer-events:none; } /* copie purement visuelle */

@keyframes ticker-scroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
.ticker .ticker-track .ticker-items{ animation-duration: 90s; }

/* Pause au survol pour le confort de lecture */
.ticker .ticker-track:hover .ticker-items{ animation-play-state:paused; }

/* Sur mobile, encore plus lent (écran plus étroit = lecture plus longue par ligne visible) */
@media (max-width: 600px){
  .ticker .ticker-track .ticker-items{ animation-duration: 120s; }
}

/* === Section labels === */
.section-label{font-family:var(--serif); font-size:13px; font-weight:bold; letter-spacing:1.5px; text-transform:uppercase; color:var(--gray-700); border-bottom:2px solid var(--coral); padding-bottom:8px; margin-bottom:14px; display:inline-block;}
.section-label.plain{border-bottom:1px solid var(--gray-300); display:block; width:100%; padding-bottom:12px; margin-top:24px;}

/* === Main grid (index.php : liste + sidebar) === */
.main-grid{display:grid; grid-template-columns:2fr 1fr; gap:28px; padding:28px 0;}
@media (max-width: 880px){ .main-grid{grid-template-columns:1fr;} }

/* === Liste d'articles (index.php) === */
.post-list{display:flex; flex-direction:column; gap:22px;}
.post-item{display:grid; grid-template-columns:220px 1fr; gap:18px; background:#fff; border:1px solid var(--gray-300); border-radius:8px; overflow:hidden;}
@media (max-width: 600px){ .post-item{grid-template-columns:1fr;} }
.post-thumb{display:block; overflow:hidden; height:100%;}
.post-thumb img{width:100%; height:100%; object-fit:cover; min-height:140px;}
.post-content{padding:16px 18px 16px 0;}
@media (max-width: 600px){ .post-content{padding:14px 16px 16px;} }
.post-cat{display:inline-block; font-size:10px; font-weight:700; letter-spacing:0.5px; text-transform:uppercase; padding:3px 9px; border-radius:4px; margin-bottom:8px; background:var(--coral-bg); color:var(--coral-dark);}
.post-title{font-family:var(--serif); font-size:19px; font-weight:bold; line-height:1.3; margin-bottom:6px;}
.post-title a:hover{color:var(--coral-dark);}
.post-excerpt{font-size:14px; color:var(--gray-700); margin-top:8px;}

/* === Pagination === */
.pagination{display:flex; justify-content:center; gap:8px; margin-top:30px; flex-wrap:wrap;}
.pagination .page-numbers{display:inline-flex; align-items:center; justify-content:center; min-width:36px; height:36px; padding:0 10px; border:1px solid var(--gray-300); border-radius:4px; background:#fff; font-size:13px; font-weight:600; color:var(--text);}
.pagination .page-numbers.current{background:var(--navy); color:#fff; border-color:var(--navy);}
.pagination .page-numbers:hover:not(.current){border-color:var(--coral); color:var(--coral-dark);}

/* === Article complet (single.php) === */
.single-post{background:#fff; border:1px solid var(--gray-300); border-radius:8px; padding:28px; margin-bottom:28px;}
.single-post .post-cat{margin-bottom:14px;}
.single-title{font-family:var(--serif); font-size:32px; font-weight:bold; line-height:1.3; margin-bottom:12px; color:var(--navy);}
.single-meta{display:flex; align-items:center; gap:8px; margin-bottom:20px; font-size:13px; color:var(--gray-500);}
.single-meta .meta-sep{color:var(--gray-300);}
.single-meta a{font-weight:600; color:var(--navy);}
.single-meta a:hover{color:var(--coral-dark);}
.single-thumb{margin-bottom:24px; border-radius:8px; overflow:hidden;}
.single-thumb img{width:100%; height:auto; max-height:480px; object-fit:cover;}
.single-content{font-size:16px; line-height:1.75; color:var(--text);}
.single-content p{margin-bottom:18px;}
.single-content h2, .single-content h3{font-family:var(--serif); color:var(--navy); margin:28px 0 12px;}
.single-content img{border-radius:6px; margin:16px 0;}
.single-content blockquote{border-left:4px solid var(--coral); padding:12px 20px; margin:20px 0; background:var(--gray-100); font-style:italic; color:var(--gray-700);}
.page-links{margin-top:20px; font-size:13px; font-weight:600;}

.single-tags{margin-top:24px; padding-top:20px; border-top:1px solid var(--gray-100); display:flex; gap:10px; flex-wrap:wrap;}
.tag-pill{background:var(--gray-100); color:var(--gray-700); font-size:12px; font-weight:600; padding:5px 12px; border-radius:20px;}
.tag-pill:hover{background:var(--coral-bg); color:var(--coral-dark);}

.single-nav{display:flex; justify-content:space-between; gap:20px; margin-bottom:28px; font-size:14px; font-weight:600;}
.single-nav a{color:var(--navy);}
.single-nav a:hover{color:var(--coral-dark);}
.single-nav .nav-next{text-align:right; margin-left:auto;}

/* Zone de commentaires */
.comments-area{background:#fff; border:1px solid var(--gray-300); border-radius:8px; padding:28px;}
.comments-area .comment-reply-title,
.comments-area h2{font-family:var(--serif); color:var(--navy); margin-bottom:16px;}
.comments-area textarea, .comments-area input[type="text"], .comments-area input[type="email"]{
  width:100%; border:1px solid var(--gray-300); border-radius:4px; padding:10px; font-size:14px; margin-bottom:10px;
}
.comments-area .submit{background:var(--coral); color:#fff; border:none; font-weight:700; padding:10px 20px; border-radius:4px; cursor:pointer;}

/* === Sidebar / widgets === */
.sidebar-area{display:flex; flex-direction:column; gap:20px;}
.side-card{background:#fff; border:1px solid var(--gray-300); border-radius:8px; padding:18px 20px;}
.side-card.dark{background:var(--navy); color:#fff; border:none;}
.widget-title{font-family:var(--serif); font-size:15px; font-weight:bold; margin-bottom:12px; border-bottom:2px solid var(--coral); padding-bottom:8px;}
.news-item{display:flex; gap:10px; padding:9px 0; border-bottom:1px solid var(--gray-100); font-size:13px;}
.news-item:last-child{border-bottom:none;}
.news-item .time{font-weight:700; color:var(--coral); flex-shrink:0; font-size:12px;}
.trend-item{display:flex; gap:10px; padding:8px 0; align-items:center; font-size:13px;}
.trend-num{width:22px; height:22px; border-radius:50%; background:var(--coral-bg); color:var(--coral-dark); font-size:12px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.nl-text{font-size:13px; color:#C7D6E8; line-height:1.6; margin-bottom:12px;}
.nl-form{display:flex; gap:8px;}
.nl-form input{flex:1; height:36px; border:none; border-radius:4px; padding:0 10px; font-size:13px;}
.nl-form button{background:var(--coral); color:#fff; border:none; font-weight:700; padding:0 16px; border-radius:4px; font-size:13px; cursor:pointer;}
.widget-pub{background:var(--gray-100); border:1px dashed var(--gray-300); border-radius:6px; text-align:center; padding:20px; color:var(--gray-500); font-size:12px; text-transform:uppercase; letter-spacing:1px;}

/* Pubs de sidebar sur mobile : on évite qu'un format desktop large (ex: 600px
   dans le shortcode TagDiv td_block_ad_box) ne dépasse de l'écran. On force
   une largeur fluide à 100% du conteneur, plafonnée à un format mobile standard. */
@media (max-width: 600px){
  .widget-pub, .widget-pub img,
  .ad-slot,
  .sidebar-area img{
    max-width:100% !important;
    width:100% !important;
    height:auto !important;
  }
  .widget-pub{ max-width:320px; margin:0 auto; }
}

/* === Featured / sub grid (utilisés par d'anciennes sections statiques) === */
.featured-img{background:var(--gray-300); border-radius:6px; height:320px; position:relative; overflow:hidden; margin-bottom:14px; display:flex; align-items:center; justify-content:center; color:var(--gray-500); font-size:13px;}
.featured-img .tag{position:absolute; top:14px; left:14px; background:var(--coral-dark); color:var(--coral-bg); font-size:11px; font-weight:700; padding:4px 10px; border-radius:4px; letter-spacing:1px;}
.featured-title{font-family:var(--serif); font-size:30px; font-weight:bold; line-height:1.25; margin-bottom:10px;}
.featured-excerpt{font-size:15px; color:var(--gray-700); margin-bottom:8px;}
.meta{font-size:12px; color:var(--gray-500);}

.sub-grid{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:24px;}
.sub-card .img{background:var(--gray-300); border-radius:6px; height:140px; margin-bottom:10px; position:relative; display:flex; align-items:center; justify-content:center; color:var(--gray-500);}
.sub-card .img .tag{position:absolute; top:10px; left:10px; font-size:10px; font-weight:700; padding:3px 9px; border-radius:4px; letter-spacing:0.5px;}
.tag-afrique{background:var(--green-bg); color:var(--green);}
.tag-economie, .tag-économie{background:var(--blue-bg); color:var(--blue-text);}
.tag-mali{background:var(--coral-bg); color:var(--coral-dark);}
.sub-card h3{font-family:var(--serif); font-size:17px; font-weight:bold; margin-bottom:6px; line-height:1.3;}

/* === Video + ad row === */
.feature-row{display:grid; grid-template-columns:1.4fr 1fr; gap:20px; padding-bottom:28px;}
@media (max-width: 880px){ .feature-row{grid-template-columns:1fr;} }
.video-card{background:#fff; border:1px solid var(--gray-300); border-radius:8px; padding:16px; display:flex; gap:14px;}
.video-thumb{width:160px; height:110px; background:var(--gray-300); border-radius:6px; flex-shrink:0; position:relative; display:flex; align-items:center; justify-content:center; color:#fff;}
.video-thumb .play{font-size:28px;}
.video-thumb .dur{position:absolute; bottom:6px; right:6px; background:rgba(0,0,0,0.65); color:#fff; font-size:10px; padding:2px 6px; border-radius:3px;}
.video-eyebrow{font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--coral-dark); margin-bottom:6px;}
.video-title{font-family:var(--serif); font-size:18px; font-weight:bold; margin-bottom:6px;}
.video-desc{font-size:13px; color:var(--gray-700);}

.ad-card{background:var(--gray-300); border-radius:8px; padding:20px; display:flex; flex-direction:column; justify-content:space-between;}
.ad-eyebrow{font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gray-700);}
.ad-title{font-family:var(--serif); font-size:20px; font-weight:bold; margin:8px 0 4px;}
.ad-desc{font-size:13px; color:var(--gray-700); margin-bottom:10px;}
.ad-link{font-size:13px; font-weight:700; color:var(--navy);}

/* === Category grid === */
.cat-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:24px; padding-bottom:36px;}
.cat-card .img{background:var(--gray-300); border-radius:6px; height:140px; margin-bottom:10px; display:flex; align-items:center; justify-content:center; color:var(--gray-500);}
.cat-card h4{font-family:var(--serif); font-size:16px; font-weight:bold; line-height:1.35;}

/* === Footer === */
.footer{background:var(--navy); color:#C7D6E8; padding:36px 0 0;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1fr; gap:24px; font-size:13px; padding-bottom:28px;}
@media (max-width: 880px){ .footer-grid{grid-template-columns:1fr 1fr;} }
.footer-grid h5{color:#fff; font-weight:700; margin-bottom:12px; font-size:13px; letter-spacing:0.5px;}
.footer-grid p{margin-bottom:7px; color:#9FB3CC;}
.footer-logo{font-family:var(--serif); font-size:22px; color:#fff; font-weight:bold; margin-bottom:8px;}
.footer-social{display:flex; gap:12px; font-size:18px; color:#C7D6E8;}
.copyright{border-top:1px solid rgba(255,255,255,0.1); text-align:center; padding:14px 0; font-size:12px; color:#6F8AAB;}

/* === Builder compatibility tweaks === */
.elementor-section{max-width:none;}
.duniya-content-area{width:100%;}

/* === Accueil Builder : Elementor / TagDiv === */
.duniya-builder-page {
  width: 100%;
  max-width: none;
  padding: 0;
  margin: 0;
  overflow-x: hidden;
}

.duniya-builder-page .elementor,
.duniya-builder-page .elementor-section,
.duniya-builder-page .elementor-container,
.duniya-builder-page .tdc_zone,
.duniya-builder-page .tdc-zone,
.duniya-builder-page .tdc-row,
.duniya-builder-page .vc_row {
  max-width: none;
}

.duniya-builder-page img {
  max-width: 100%;
  height: auto;
}