/*
Theme Name:   NeuroPress Child
Theme URI:    https://neuropress.ga
Description:  Thème enfant NeuroPress — design éditorial professionnel
Author:       NeuroPress
Author URI:   https://neuropress.ga
Template:     Newspaper
Version:      1.0.0
Text Domain:  neuropress-child
*/

/* =====================================================
   TABLE DES MATIÈRES
   1.  Variables & Reset
   2.  Barre d'info supérieure (top bar)
   3.  Header & Logo
   4.  Navigation principale
   5.  Ticker Breaking News
   6.  Grille & Cartes d'articles
   7.  Labels de catégories (couleurs)
   8.  Bloc "À la une" / Hero
   9.  Sections de rubriques
   10. Sidebar & Widgets
   11. Page article (single)
   12. Footer
   13. Responsive
   14. Animations & UX
   ===================================================== */

/* =====================================================
   1. VARIABLES & RESET
   ===================================================== */
:root {
    --np-dark:       #0d1b2a;
    --np-navy:       #1b2a3b;
    --np-red:        #c0392b;
    --np-red-light:  #e74c3c;
    --np-blue:       #1565C0;
    --np-blue-light: #1976D2;
    --np-gold:       #f39c12;
    --np-gray-1:     #f4f6f9;
    --np-gray-2:     #e8ecf0;
    --np-gray-3:     #c0cad4;
    --np-gray-4:     #8395a7;
    --np-text:       #1a1a2e;
    --np-text-light: #4a5568;
    --np-white:      #ffffff;
    --np-font-head:  'Georgia', 'Times New Roman', serif;
    --np-font-body:  -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', sans-serif;
    --np-radius:     4px;
    --np-shadow:     0 2px 8px rgba(0,0,0,.10);
    --np-shadow-lg:  0 4px 20px rgba(0,0,0,.15);
}

*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--np-font-body) !important;
    background: var(--np-gray-1) !important;
    color: var(--np-text) !important;
}

a { color: var(--np-blue); transition: color .2s; }
a:hover { color: var(--np-red); }

img { max-width: 100%; height: auto; }

/* =====================================================
   2. BARRE D'INFO SUPÉRIEURE
   ===================================================== */
.td-top-bar,
.td-header-top-bar,
.header_wrap.td-header-top-bar-wrap,
.td-bar {
    background: var(--np-dark) !important;
    border-bottom: none !important;
}

/* Top bar : date + réseaux sociaux */
.np-top-info-bar {
    background: var(--np-dark);
    color: rgba(255,255,255,.7);
    font-size: 11px;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.np-top-info-bar .np-tib-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
}
.np-tib-date { display: flex; align-items: center; gap: 6px; font-weight: 500; }
.np-tib-date svg { opacity: .7; }
.np-tib-social { display: flex; align-items: center; gap: 4px; }
.np-tib-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.8) !important;
    font-size: 12px;
    text-decoration: none;
    transition: background .2s;
}
.np-tib-social a:hover { background: var(--np-red) !important; color: #fff !important; }

/* =====================================================
   3. HEADER & LOGO
   ===================================================== */
.td-header-wrap,
.td-header-bg,
.td_block_wrap .td-header-wrap {
    background: var(--np-navy) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.25) !important;
}

.td-header-wrap .td-header-logo-wrap,
.td-header-logo {
    padding: 10px 0 !important;
}

/* Logo texte fallback */
.td-header-wrap .site-name,
.td-header-wrap .td-header-logo-wrap a {
    font-family: var(--np-font-head) !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    letter-spacing: -0.5px;
    text-decoration: none !important;
}
.td-header-wrap .site-tagline,
.td-header-wrap .site-description {
    color: rgba(255,255,255,.55) !important;
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Zone logo personnalisée */
.np-site-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none !important;
    padding: 12px 0;
}
.np-site-brand .np-logo-icon {
    width: 44px; height: 44px;
    background: var(--np-red);
    border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--np-font-head);
    font-size: 22px;
    font-weight: 900;
    color: #fff;
    flex-shrink: 0;
}
.np-site-brand .np-logo-text { line-height: 1.2; }
.np-site-brand .np-logo-name {
    font-family: var(--np-font-head) !important;
    font-size: 24px;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.3px;
}
.np-site-brand .np-logo-tag {
    font-size: 10px;
    color: rgba(255,255,255,.5);
    text-transform: uppercase;
    letter-spacing: 1.5px;
}

/* =====================================================
   4. NAVIGATION PRINCIPALE
   ===================================================== */
.td-main-menu-wrap,
.sf-menu,
.td-header-wrap .td-header-menu-wrap,
.td-header-menu-social {
    background: var(--np-red) !important;
}

.td-main-menu-wrap .sf-menu > li > a,
.td-header-wrap .td-header-menu-wrap ul.sf-menu > li > a {
    font-family: var(--np-font-body) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: #fff !important;
    padding: 12px 16px !important;
    border-bottom: 3px solid transparent !important;
    transition: background .2s, border-color .2s !important;
}

.td-main-menu-wrap .sf-menu > li > a:hover,
.td-main-menu-wrap .sf-menu > li.current-menu-item > a,
.td-main-menu-wrap .sf-menu > li.current-menu-ancestor > a,
.td-main-menu-wrap .sf-menu > li:hover > a {
    background: rgba(0,0,0,.2) !important;
    border-bottom-color: #fff !important;
    color: #fff !important;
}

/* Sous-menu dropdown */
.td-main-menu-wrap .sf-menu li ul {
    background: var(--np-dark) !important;
    border-top: 2px solid var(--np-red) !important;
    box-shadow: var(--np-shadow-lg) !important;
    min-width: 200px !important;
}
.td-main-menu-wrap .sf-menu li ul li a {
    color: rgba(255,255,255,.85) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    padding: 9px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.td-main-menu-wrap .sf-menu li ul li a:hover {
    background: var(--np-red) !important;
    color: #fff !important;
    padding-left: 22px !important;
}

/* Barre de recherche dans la nav */
.td-main-menu-wrap .td-search-form-wrap input {
    background: rgba(255,255,255,.15) !important;
    border: 1px solid rgba(255,255,255,.25) !important;
    color: #fff !important;
    border-radius: 20px !important;
    padding: 5px 14px !important;
    font-size: 12px !important;
}
.td-main-menu-wrap .td-search-form-wrap input::placeholder { color: rgba(255,255,255,.6) !important; }

/* =====================================================
   5. TICKER BREAKING NEWS
      Injecté dans le DOM par front.js après .td-header-desktop-wrap
   ===================================================== */
.np-ticker-bar {
    background: #fff;
    border-top: none;
    border-bottom: 3px solid var(--np-red);
    display: flex;
    align-items: center;
    overflow: hidden;
    height: 36px;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
    position: relative;
    z-index: 900;
    width: 100%;
}
.np-ticker-label {
    background: var(--np-red);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    padding: 0 16px;
    height: 100%;
    display: flex;
    align-items: center;
    white-space: nowrap;
    flex-shrink: 0;
    gap: 6px;
}
.np-ticker-dot {
    display: inline-block;
    width: 7px; height: 7px;
    background: #fff;
    border-radius: 50%;
    animation: np-blink 1.2s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes np-blink {
    0%, 100% { opacity: 1; }
    50%       { opacity: .2; }
}
.np-ticker-inner {
    flex: 1;
    overflow: hidden;
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
}
.np-ticker-track {
    display: inline-flex;
    align-items: center;
    gap: 32px;
    white-space: nowrap;
    animation: np-ticker-scroll 50s linear infinite;
    will-change: transform;
}
.np-ticker-track:hover { animation-play-state: paused; }
.np-ticker-item {
    display: inline-flex;
    align-items: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--np-text);
    flex-shrink: 0;
}
.np-ticker-item a {
    color: var(--np-text) !important;
    text-decoration: none !important;
    font-weight: 600;
    transition: color .2s;
    white-space: nowrap;
}
.np-ticker-item a:hover { color: var(--np-red) !important; }
.np-ticker-sep {
    color: var(--np-red);
    font-size: 14px;
    font-weight: 300;
    flex-shrink: 0;
}
@keyframes np-ticker-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* =====================================================
   6. GRILLE & CARTES D'ARTICLES
   ===================================================== */

/* Conteneur général */
.td-container, .td-main-content {
    max-width: 1200px !important;
}

/* Cartes d'articles (modules tagDiv) */
.td-module-container .td-item-details-block,
.td-block-row .td-post-small-box,
.td-cpt-rec article,
.td-big-grid-post,
.td-small-thumb,
.td-module-meta-info {
    background: var(--np-white);
    border-radius: var(--np-radius);
}

.td-block-row article,
.td-cpt-rec article,
.td-post-small-box {
    background: var(--np-white) !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    box-shadow: var(--np-shadow) !important;
    transition: transform .25s, box-shadow .25s !important;
    border: none !important;
}

.td-block-row article:hover,
.td-cpt-rec article:hover,
.td-post-small-box:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--np-shadow-lg) !important;
}

/* Image des cartes */
.td-block-row article .entry-thumb,
.td-block-row article .td-image-wrap,
.td-module-thumb {
    overflow: hidden !important;
    border-radius: 6px 6px 0 0 !important;
}
.td-block-row article .entry-thumb img,
.td-block-row article .td-image-wrap img,
.td-module-thumb img {
    transition: transform .4s ease !important;
}
.td-block-row article:hover .entry-thumb img,
.td-block-row article:hover .td-image-wrap img,
.td-post-small-box:hover .td-module-thumb img {
    transform: scale(1.05) !important;
}

/* Titre des articles */
.td-module-title a,
.td-post-title a,
.entry-title a {
    font-family: var(--np-font-head) !important;
    color: var(--np-text) !important;
    text-decoration: none !important;
    line-height: 1.35 !important;
    transition: color .2s !important;
}
.td-module-title a:hover,
.td-post-title a:hover,
.entry-title a:hover {
    color: var(--np-red) !important;
}

/* Méta-infos (auteur, date) */
.td-editor-date a,
.td-post-author-name a,
.td-module-meta-info a,
.entry-meta a {
    color: var(--np-gray-4) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    letter-spacing: .3px;
    text-decoration: none !important;
}
.td-post-date .entry-date {
    font-size: 11px;
    color: var(--np-gray-4) !important;
    font-weight: 500;
}

/* Extrait */
.td-excerpt, .td-module-container .td-post-content {
    color: var(--np-text-light) !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
}

/* Bouton "Lire la suite" */
.td-read-more a,
.more-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--np-red) !important;
    text-decoration: none !important;
    border-bottom: 1px solid var(--np-red) !important;
    padding-bottom: 1px !important;
    transition: gap .2s !important;
}
.td-read-more a:hover, .more-link:hover {
    color: var(--np-dark) !important;
    border-color: var(--np-dark) !important;
    gap: 8px !important;
}

/* =====================================================
   7. LABELS DE CATÉGORIES (couleurs)
   ===================================================== */
.td-post-category,
.td-category,
.td-post-small-box .td-post-category,
.td-module-meta-info .td-post-category a {
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .8px !important;
    text-transform: uppercase !important;
    padding: 3px 8px !important;
    border-radius: 3px !important;
    color: #fff !important;
    text-decoration: none !important;
    display: inline-block !important;
    line-height: 1.4 !important;
    transition: opacity .2s !important;
}
.td-post-category:hover, .td-post-category a:hover { opacity: .85 !important; }

/* Couleurs par rubrique */
.category-actualite    .td-post-category,
.tag-actualite         .td-post-category,
[data-cat="actualite"] .td-post-category  { background: var(--np-red)    !important; }

[class*="category-politique"] .td-post-category,
.np-cat-politique .td-post-category       { background: #1a237e !important; }

[class*="category-economie"] .td-post-category,
.np-cat-economie .td-post-category        { background: #1b5e20 !important; }

[class*="category-sport"] .td-post-category,
.np-cat-sport .td-post-category           { background: #e65100 !important; }

[class*="category-culture"] .td-post-category,
.np-cat-culture .td-post-category         { background: #4a148c !important; }

[class*="category-international"] .td-post-category,
.np-cat-international .td-post-category   { background: #006064 !important; }

[class*="category-faits-divers"] .td-post-category,
.np-cat-faits-divers .td-post-category    { background: #bf360c !important; }

[class*="category-societe"] .td-post-category,
.np-cat-societe .td-post-category         { background: #37474f !important; }

[class*="category-tourisme"] .td-post-category,
.np-cat-tourisme .td-post-category        { background: #00695c !important; }

[class*="category-musique"] .td-post-category,
.np-cat-musique .td-post-category         { background: #880e4f !important; }

[class*="category-magazine"] .td-post-category,
.np-cat-magazine .td-post-category        { background: #5c6bc0 !important; }

[class*="category-education"] .td-post-category,
.np-cat-education .td-post-category       { background: #2e7d32 !important; }

/* Couleur par défaut */
.td-post-category { background: var(--np-blue) !important; }

/* =====================================================
   8. BLOC "À LA UNE" / HERO
   ===================================================== */
.np-hero-section {
    background: var(--np-dark);
    padding: 0;
    margin-bottom: 30px;
}

/* Grand article en vedette */
.td-big-grid-post .td-post-title {
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.2) 60%, transparent 100%) !important;
    padding: 30px 20px 20px !important;
}
.td-big-grid-post .td-post-title h3 a,
.td-big-grid-post .entry-title a {
    font-family: var(--np-font-head) !important;
    font-size: 26px !important;
    font-weight: 800 !important;
    color: #fff !important;
    text-shadow: 0 1px 3px rgba(0,0,0,.4) !important;
    line-height: 1.25 !important;
}
.td-big-grid-post .td-post-category {
    margin-bottom: 8px !important;
    display: inline-block !important;
}

/* =====================================================
   9. SECTIONS DE RUBRIQUES
   ===================================================== */

/* Titre de bloc / rubrique */
.td-block-title-wrap .td-block-title,
.td_block_title .td-block-title,
.widget-title, .widgettitle {
    font-family: var(--np-font-head) !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    color: var(--np-dark) !important;
    margin: 0 !important;
    padding-bottom: 8px !important;
    border-bottom: 3px solid var(--np-red) !important;
    position: relative !important;
}

/* Barre décorative sous titre de bloc */
.td-block-title-wrap {
    margin-bottom: 16px !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
}

/* Section rubrique avec fond coloré */
.np-section-block {
    background: var(--np-white);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 28px;
    box-shadow: var(--np-shadow);
}

/* Séparateur entre sections */
.td-main-content .td-block-row + .td-block-row {
    margin-top: 28px;
}

/* Bloc "À lire aussi" */
.np-also-read {
    background: var(--np-gray-1);
    border-left: 4px solid var(--np-red);
    padding: 14px 18px;
    margin: 24px 0;
    border-radius: 0 6px 6px 0;
}
.np-also-read-title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 800;
    color: var(--np-red);
    margin-bottom: 6px;
}
.np-also-read ul { margin: 0; padding: 0; list-style: none; }
.np-also-read ul li { margin-bottom: 4px; }
.np-also-read ul li a {
    font-size: 13px;
    font-weight: 600;
    color: var(--np-text) !important;
    text-decoration: none !important;
}
.np-also-read ul li a:hover { color: var(--np-red) !important; }

/* Compteur de vues / trending */
.np-trending-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--np-red);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    flex-shrink: 0;
}

/* =====================================================
   10. SIDEBAR & WIDGETS
   ===================================================== */
.td-sidebar {
    background: transparent !important;
}
.td-pb-column .td-block-row,
.widget {
    background: var(--np-white);
    border-radius: 6px;
    box-shadow: var(--np-shadow);
    margin-bottom: 24px !important;
    overflow: hidden;
    padding: 0 !important;
}
.widget .widget-title, .widget .widgettitle {
    padding: 14px 18px 12px !important;
    margin: 0 !important;
    border-bottom: 3px solid var(--np-red) !important;
    background: var(--np-gray-1);
    display: block !important;
}

/* Widget derniers articles sidebar */
.widget ul li {
    padding: 10px 18px;
    border-bottom: 1px solid var(--np-gray-2);
    font-size: 13px;
    line-height: 1.4;
}
.widget ul li:last-child { border-bottom: none; }
.widget ul li a {
    color: var(--np-text) !important;
    font-weight: 600;
    text-decoration: none !important;
}
.widget ul li a:hover { color: var(--np-red) !important; }

/* Widget search */
.widget_search .search-form {
    display: flex;
    padding: 12px 18px;
}
.widget_search input[type="search"] {
    flex: 1;
    border: 1px solid var(--np-gray-2);
    border-right: none;
    padding: 8px 12px;
    font-size: 13px;
    border-radius: 4px 0 0 4px;
}
.widget_search input[type="submit"] {
    background: var(--np-red);
    color: #fff;
    border: none;
    padding: 8px 14px;
    cursor: pointer;
    border-radius: 0 4px 4px 0;
    font-size: 12px;
    font-weight: 700;
    transition: background .2s;
}
.widget_search input[type="submit"]:hover { background: var(--np-dark); }

/* =====================================================
   11. PAGE ARTICLE (SINGLE)
   ===================================================== */
.td-post-template-1 .td-post-header,
.single-post .td-post-header {
    margin-bottom: 24px;
}

/* Titre d'article */
.single-post h1.entry-title,
.td-post-template-1 h1.entry-title {
    font-family: var(--np-font-head) !important;
    font-size: 36px !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
    color: var(--np-text) !important;
    margin-bottom: 16px !important;
}

/* Meta article */
.single-post .td-post-sub-title,
.td-post-author-name,
.td-post-date {
    font-size: 13px;
    color: var(--np-gray-4) !important;
}

/* Image mise en avant */
.single-post .td-post-featured-image img {
    border-radius: 6px;
    box-shadow: var(--np-shadow);
    width: 100%;
}

/* Corps de l'article */
.td-post-content,
.single-post .entry-content {
    font-family: var(--np-font-body) !important;
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: #2d3748 !important;
    max-width: 760px;
}
.td-post-content p { margin-bottom: 20px !important; }
.td-post-content h2 {
    font-family: var(--np-font-head) !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--np-text) !important;
    border-left: 4px solid var(--np-red);
    padding-left: 14px;
    margin: 32px 0 16px !important;
}
.td-post-content h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--np-navy) !important;
    margin: 24px 0 12px !important;
}
.td-post-content blockquote {
    border-left: 4px solid var(--np-red) !important;
    background: var(--np-gray-1) !important;
    margin: 24px 0 !important;
    padding: 16px 20px !important;
    border-radius: 0 6px 6px 0 !important;
    font-style: italic !important;
    font-size: 17px !important;
    color: var(--np-navy) !important;
}

/* Temps de lecture */
.np-read-time {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    color: var(--np-gray-4);
    text-transform: uppercase;
    letter-spacing: .4px;
    margin-right: 12px;
}
.np-read-time svg { opacity: .7; }

/* Partage social article */
.np-share-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px 0;
    border-top: 1px solid var(--np-gray-2);
    border-bottom: 1px solid var(--np-gray-2);
    margin: 24px 0;
    flex-wrap: wrap;
}
.np-share-bar-label {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--np-gray-4);
    margin-right: 4px;
}
.np-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #fff !important;
    text-decoration: none !important;
    transition: filter .2s, transform .15s;
}
.np-share-btn:hover { filter: brightness(.9); transform: translateY(-1px); }
.np-share-btn.np-fb  { background: #1877f2; }
.np-share-btn.np-tw  { background: #1da1f2; }
.np-share-btn.np-wa  { background: #25d366; }
.np-share-btn.np-lk  { background: #0a66c2; }
.np-share-btn.np-cp  { background: var(--np-gray-4); }

/* Tags */
.td-tags a,
.post-tags a,
.tag-list a {
    display: inline-block;
    padding: 4px 10px;
    background: var(--np-gray-1);
    border: 1px solid var(--np-gray-2);
    border-radius: 3px;
    font-size: 11px;
    font-weight: 600;
    color: var(--np-text-light) !important;
    text-decoration: none !important;
    margin: 3px 2px;
    transition: background .2s, border-color .2s;
}
.td-tags a:hover, .post-tags a:hover {
    background: var(--np-red) !important;
    border-color: var(--np-red) !important;
    color: #fff !important;
}

/* Articles connexes */
.td-related-title h3 a {
    font-family: var(--np-font-head) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    color: var(--np-text) !important;
}
.td-related-title h3 a:hover { color: var(--np-red) !important; }

/* =====================================================
   12. FOOTER
   ===================================================== */
.td-footer-wrapper,
#tdi_78, .tdm-footer {
    background: var(--np-dark) !important;
    border-top: 4px solid var(--np-red) !important;
    color: rgba(255,255,255,.75) !important;
    padding-top: 40px !important;
}

.td-footer-wrapper .widget-title,
.td-footer-wrapper .widgettitle,
#tdi_78 .widget-title {
    color: #fff !important;
    font-size: 14px !important;
    border-bottom-color: var(--np-red) !important;
    background: transparent !important;
    padding: 0 0 10px !important;
    margin-bottom: 16px !important;
    text-transform: uppercase;
    letter-spacing: .5px;
}

.td-footer-wrapper a,
.td-footer-wrapper .widget ul li a {
    color: rgba(255,255,255,.7) !important;
    border-bottom: none !important;
}
.td-footer-wrapper a:hover,
.td-footer-wrapper .widget ul li a:hover { color: var(--np-red) !important; }
.td-footer-wrapper .widget ul li { border-bottom-color: rgba(255,255,255,.08) !important; }
.td-footer-wrapper p { color: rgba(255,255,255,.6) !important; font-size: 13px !important; }

/* Copyright bar */
.td-sub-footer-container,
.tdb_single_copyright {
    background: #000 !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    padding: 12px 0 !important;
}
.td-sub-footer-container .td-sub-footer-copyright,
.td-sub-footer-container p {
    color: rgba(255,255,255,.45) !important;
    font-size: 12px !important;
}
.td-sub-footer-container a { color: var(--np-red) !important; }

/* =====================================================
   13. RESPONSIVE
   ===================================================== */
@media (max-width: 1024px) {
    .single-post h1.entry-title { font-size: 28px !important; }
}

@media (max-width: 768px) {
    .np-tib-social { display: none; }
    .single-post h1.entry-title { font-size: 22px !important; }
    .td-post-content { font-size: 15px !important; }
    .np-share-bar { gap: 6px; }
    .np-share-btn { padding: 6px 10px; font-size: 11px; }
    .np-ticker-bar { height: 34px; }
}

@media (max-width: 480px) {
    .np-tib-date { font-size: 10px; }
    .single-post h1.entry-title { font-size: 20px !important; }
    .np-site-brand .np-logo-name { font-size: 20px; }
}

/* =====================================================
   14. ANIMATIONS & UX
   ===================================================== */

/* Skeleton loading (optionnel) */
.np-skeleton {
    background: linear-gradient(90deg, var(--np-gray-2) 25%, var(--np-gray-1) 50%, var(--np-gray-2) 75%);
    background-size: 200% 100%;
    animation: np-skeleton-wave 1.5s infinite;
    border-radius: 4px;
}
@keyframes np-skeleton-wave {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Scroll to top */
.np-scroll-top {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 42px; height: 42px;
    background: var(--np-red);
    color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .3s, transform .3s;
    z-index: 9999;
    box-shadow: 0 3px 10px rgba(192,57,43,.4);
    font-size: 18px;
    text-decoration: none !important;
    border: none;
}
.np-scroll-top.visible { opacity: 1; transform: translateY(0); }
.np-scroll-top:hover { background: var(--np-dark) !important; color: #fff !important; }

/* Focus accessibility */
a:focus-visible, button:focus-visible {
    outline: 2px solid var(--np-red);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Print */
@media print {
    .np-top-info-bar, .np-ticker-bar,
    .td-main-menu-wrap, .td-footer-wrapper { display: none !important; }
    .td-post-content { font-size: 12pt !important; color: #000 !important; }
    h1, h2, h3 { color: #000 !important; }
}

/* =====================================================
   UTILITAIRES
   ===================================================== */
.np-badge {
    display: inline-block;
    padding: 2px 7px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.np-badge-red   { background: var(--np-red);  color: #fff; }
.np-badge-blue  { background: var(--np-blue); color: #fff; }
.np-badge-gold  { background: var(--np-gold); color: #fff; }
.np-badge-dark  { background: var(--np-dark); color: #fff; }

.np-divider {
    border: none;
    border-top: 2px solid var(--np-gray-2);
    margin: 24px 0;
}
.np-divider-red { border-top-color: var(--np-red); }

/* =====================================================
   AJOUTS v1.1 — Templates, composants, interactions
   ===================================================== */

/* ---- Barre de progression de lecture ---- */
#np-read-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0;
    height: 3px;
    background: var(--np-red);
    z-index: 99999;
    transition: width .1s linear;
    border-radius: 0 2px 2px 0;
    box-shadow: 0 0 6px rgba(192,57,43,.5);
}

/* ---- Header sticky ---- */
.np-scrolled .td-header-wrap,
.np-scrolled .td-header-bg {
    position: sticky !important;
    top: 0 !important;
    z-index: 9990 !important;
    box-shadow: 0 3px 16px rgba(0,0,0,.25) !important;
    transition: transform .3s ease, box-shadow .3s !important;
}
.np-header-hidden .td-header-wrap,
.np-header-hidden .td-header-bg {
    transform: translateY(-100%) !important;
}

/* ---- Animations d'apparition ---- */
.np-fade-in {
    opacity: 1 !important;
    transform: translateY(0) !important;
    transition: opacity .5s ease, transform .5s ease !important;
}

/* =====================================================
   PAGE 404
   ===================================================== */
.np-404-wrap { background: var(--np-gray-1); min-height: 80vh; }

.np-404-hero {
    background: linear-gradient(135deg, var(--np-dark) 0%, #1a2a3a 100%);
    padding: 60px 20px;
    text-align: center;
    color: #fff;
}
.np-404-inner { max-width: 680px; margin: 0 auto; }
.np-404-code {
    font-size: 120px;
    font-weight: 900;
    font-family: var(--np-font-head);
    line-height: 1;
    color: transparent;
    -webkit-text-stroke: 2px var(--np-red);
    margin-bottom: 8px;
    letter-spacing: -4px;
}
.np-404-title {
    font-family: var(--np-font-head) !important;
    font-size: 32px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 14px !important;
}
.np-404-desc {
    color: rgba(255,255,255,.7);
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 30px;
}
.np-404-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
}
.np-btn-primary {
    display: inline-flex;
    align-items: center;
    padding: 12px 24px;
    background: var(--np-red);
    color: #fff !important;
    border-radius: 4px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none !important;
    transition: filter .2s, transform .15s;
    white-space: nowrap;
}
.np-btn-primary:hover { filter: brightness(.88); transform: translateY(-1px); color: #fff !important; }
.np-404-search {
    display: flex;
    flex: 1;
    max-width: 360px;
}
.np-404-search input {
    flex: 1;
    border: none;
    border-radius: 4px 0 0 4px;
    padding: 12px 16px;
    font-size: 14px;
    background: rgba(255,255,255,.12);
    color: #fff;
    outline: none;
}
.np-404-search input::placeholder { color: rgba(255,255,255,.5); }
.np-404-search input:focus { background: rgba(255,255,255,.2); }
.np-404-search button {
    background: var(--np-red);
    border: none;
    border-radius: 0 4px 4px 0;
    padding: 0 16px;
    color: #fff;
    font-size: 16px;
    cursor: pointer;
    transition: background .2s;
}
.np-404-search button:hover { background: #a93226; }

.np-404-content { padding: 40px 20px; max-width: 1200px; margin: 0 auto; }
.np-404-section { margin-bottom: 48px; }

.np-section-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--np-font-head) !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--np-dark) !important;
    margin: 0 0 24px !important;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.np-section-title-line {
    display: block;
    width: 4px;
    height: 24px;
    background: var(--np-red);
    border-radius: 2px;
    flex-shrink: 0;
}

.np-404-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
@media (max-width: 900px) { .np-404-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px) { .np-404-grid { grid-template-columns: 1fr; } }

.np-404-card {
    background: var(--np-white);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--np-shadow);
    transition: transform .25s, box-shadow .25s;
    display: flex;
    flex-direction: column;
}
.np-404-card:hover { transform: translateY(-3px); box-shadow: var(--np-shadow-lg); }
.np-404-card-img { display: block; height: 160px; overflow: hidden; }
.np-404-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.np-404-card:hover .np-404-card-img img { transform: scale(1.05); }
.np-404-card-body { padding: 14px 16px 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.np-404-card-cat {
    display: inline-block;
    font-size: 10px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .6px;
    background: var(--np-red); color: #fff !important;
    padding: 2px 8px; border-radius: 3px;
    text-decoration: none !important;
}
.np-404-card-title {
    font-family: var(--np-font-head) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    margin: 0 !important;
    flex: 1;
}
.np-404-card-title a { color: var(--np-text) !important; text-decoration: none !important; }
.np-404-card-title a:hover { color: var(--np-red) !important; }
.np-404-card-date { font-size: 11px; color: var(--np-gray-4); font-style: italic; }

.np-404-cats { display: flex; flex-wrap: wrap; gap: 10px; }
.np-404-cat-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 4px;
    color: #fff !important;
    font-size: 13px; font-weight: 700;
    text-decoration: none !important;
    transition: filter .2s, transform .15s;
}
.np-404-cat-badge:hover { filter: brightness(.88); transform: translateY(-1px); }
.np-404-cat-count {
    background: rgba(255,255,255,.25);
    border-radius: 10px;
    padding: 1px 7px;
    font-size: 11px; font-weight: 600;
}

/* =====================================================
   PAGE CATÉGORIE
   ===================================================== */
.np-cat-banner {
    position: relative;
    min-height: 220px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}
.np-cat-banner-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: blur(2px) brightness(.45);
    transform: scale(1.04);
}
.np-cat-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0,0,0,.75) 0%, rgba(0,0,0,.35) 100%);
}
.np-cat-banner-inner {
    position: relative;
    z-index: 2;
    padding: 32px 20px;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
}
.np-cat-banner-title {
    font-family: var(--np-font-head) !important;
    font-size: 42px !important;
    font-weight: 900 !important;
    color: #fff !important;
    margin: 8px 0 10px !important;
    text-shadow: 0 2px 8px rgba(0,0,0,.4);
    letter-spacing: -.5px;
}
.np-cat-banner-desc { color: rgba(255,255,255,.8); font-size: 15px; margin: 0 0 14px; max-width: 600px; }
.np-cat-count-badge {
    display: inline-block;
    background: rgba(255,255,255,.18);
    color: #fff;
    font-size: 12px; font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.3);
    backdrop-filter: blur(4px);
}

/* Fil d'Ariane */
.np-breadcrumb {
    font-size: 12px;
    color: rgba(255,255,255,.65);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 8px;
}
.np-breadcrumb a { color: rgba(255,255,255,.75) !important; text-decoration: none !important; }
.np-breadcrumb a:hover { color: #fff !important; }
.np-breadcrumb span[aria-current] { color: rgba(255,255,255,.9); font-weight: 600; }

/* Sous-catégories */
.np-sub-cats {
    background: var(--np-white);
    border-bottom: 1px solid var(--np-gray-2);
}
.np-sub-cats-list {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    list-style: none;
}
.np-sub-cats-list li a {
    display: block;
    padding: 10px 16px;
    font-size: 13px; font-weight: 600;
    color: var(--np-text-light) !important;
    text-decoration: none !important;
    border-right: 1px solid var(--np-gray-2);
    transition: color .2s, background .2s;
}
.np-sub-cats-list li a:hover { color: var(--np-red) !important; background: var(--np-gray-1); }
.np-sub-cats-list li a span { font-weight: 400; color: var(--np-gray-4); font-size: 11px; margin-left: 4px; }

/* Article vedette dans catégorie */
.np-featured-article {
    background: var(--np-white);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--np-shadow);
    margin-bottom: 28px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-top: 4px solid var(--np-red);
}
@media (max-width: 700px) { .np-featured-article { grid-template-columns: 1fr; } }
.np-featured-img { display: block; overflow: hidden; height: 100%; min-height: 220px; }
.np-featured-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.np-featured-article:hover .np-featured-img img { transform: scale(1.04); }
.np-featured-body { padding: 24px; display: flex; flex-direction: column; gap: 10px; justify-content: center; }
.np-featured-cat {
    display: inline-block;
    font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .7px;
    color: #fff !important; padding: 3px 9px; border-radius: 3px;
    text-decoration: none !important; width: fit-content;
}
.np-featured-title {
    font-family: var(--np-font-head) !important;
    font-size: 22px !important; font-weight: 800 !important;
    line-height: 1.3 !important; margin: 0 !important;
}
.np-featured-title a { color: var(--np-text) !important; text-decoration: none !important; }
.np-featured-title a:hover { color: var(--np-red) !important; }
.np-featured-excerpt { color: var(--np-text-light); font-size: 14px; line-height: 1.6; margin: 0; }
.np-featured-meta { font-size: 12px; color: var(--np-gray-4); display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.np-meta-author { font-weight: 600; color: var(--np-text-light); }
.np-meta-sep { color: var(--np-gray-3); }

/* Titre de section catégorie */
.np-cat-articles-header { margin: 28px 0 16px; }
.np-section-title[style] .np-section-title-line { background: var(--np-red); }

/* =====================================================
   PAGE RECHERCHE
   ===================================================== */
.np-search-header {
    background: var(--np-dark);
    padding: 32px 0 28px;
}
.np-search-header .np-breadcrumb { margin-bottom: 14px; }
.np-search-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
}
.np-search-title {
    font-family: var(--np-font-head) !important;
    font-size: 28px !important; font-weight: 800 !important;
    color: #fff !important; margin: 0 0 6px !important;
}
.np-search-title em { color: var(--np-red); font-style: normal; }
.np-search-count { color: rgba(255,255,255,.6); font-size: 13px; margin: 0; }
.np-search-form-main {
    display: flex;
    max-width: 400px;
    width: 100%;
    flex: 1;
}
.np-search-form-main input {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid rgba(255,255,255,.2);
    border-right: none;
    border-radius: 4px 0 0 4px;
    background: rgba(255,255,255,.1);
    color: #fff;
    font-size: 14px;
    outline: none;
    transition: background .2s;
}
.np-search-form-main input::placeholder { color: rgba(255,255,255,.45); }
.np-search-form-main input:focus { background: rgba(255,255,255,.18); }
.np-search-form-main button {
    background: var(--np-red);
    border: none;
    border-radius: 0 4px 4px 0;
    padding: 0 18px;
    color: #fff;
    cursor: pointer;
    display: flex; align-items: center;
    transition: background .2s;
}
.np-search-form-main button:hover { background: #a93226; }

/* Résultats */
.np-search-results { display: flex; flex-direction: column; gap: 0; }
.np-result-item {
    display: flex;
    gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid var(--np-gray-2);
    align-items: flex-start;
    transition: opacity .3s, transform .3s;
}
.np-result-item:last-child { border-bottom: none; }
.np-result-img { flex-shrink: 0; width: 120px; height: 80px; border-radius: 6px; overflow: hidden; display: block; }
.np-result-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.np-result-item:hover .np-result-img img { transform: scale(1.05); }
.np-result-body { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.np-result-cat {
    display: inline-block;
    font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .6px;
    padding: 2px 8px; border-radius: 3px;
    color: #fff !important; text-decoration: none !important; width: fit-content;
}
.np-result-title {
    font-family: var(--np-font-head) !important;
    font-size: 17px !important; font-weight: 700 !important;
    line-height: 1.35 !important; margin: 0 !important;
}
.np-result-title a { color: var(--np-text) !important; text-decoration: none !important; }
.np-result-title a:hover { color: var(--np-red) !important; }
.np-result-excerpt { color: var(--np-text-light); font-size: 13px; line-height: 1.5; margin: 0; }
.np-result-meta { font-size: 11px; color: var(--np-gray-4); display: flex; align-items: center; gap: 6px; }

/* Pas de résultats */
.np-no-results { text-align: center; padding: 60px 20px; }
.np-no-results-icon { font-size: 48px; margin-bottom: 16px; }
.np-no-results h2 { font-size: 24px; font-weight: 800; color: var(--np-text); margin-bottom: 10px; }
.np-no-results p { color: var(--np-text-light); margin-bottom: 24px; }
.np-no-results-cats { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.np-no-results-cat-link {
    padding: 8px 16px;
    background: var(--np-gray-1);
    border: 1px solid var(--np-gray-2);
    border-radius: 4px;
    font-size: 13px; font-weight: 600;
    color: var(--np-text) !important;
    text-decoration: none !important;
    transition: background .2s, border-color .2s, color .2s;
}
.np-no-results-cat-link:hover {
    background: var(--np-red) !important;
    border-color: var(--np-red) !important;
    color: #fff !important;
}

/* =====================================================
   PAGINATION
   ===================================================== */
.np-pagination,
.page-nav,
.td-pb-padding-side.td-page-wrap,
.td-page-wrap {
    margin: 32px 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 6px;
}
.np-pagination .page-numbers,
.td-page-wrap .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px; height: 38px;
    padding: 0 10px;
    border: 1px solid var(--np-gray-2);
    border-radius: 4px;
    background: var(--np-white);
    color: var(--np-text) !important;
    font-size: 13px; font-weight: 600;
    text-decoration: none !important;
    transition: background .2s, border-color .2s, color .2s;
}
.np-pagination .page-numbers:hover,
.td-page-wrap .page-numbers:hover {
    background: var(--np-red) !important;
    border-color: var(--np-red) !important;
    color: #fff !important;
}
.np-pagination .page-numbers.current,
.td-page-wrap .page-numbers.current {
    background: var(--np-red) !important;
    border-color: var(--np-red) !important;
    color: #fff !important;
}

/* =====================================================
   BOÎTE AUTEUR (single)
   ===================================================== */
.author-box-wrap {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    background: var(--np-gray-1) !important;
    border: 1px solid var(--np-gray-2) !important;
    border-left: 4px solid var(--np-red) !important;
    border-radius: 8px !important;
    padding: 20px 24px !important;
    margin: 32px 0 !important;
}
.author-box-wrap img {
    width: 80px !important; height: 80px !important;
    border-radius: 50% !important;
    flex-shrink: 0;
    border: 3px solid var(--np-white) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.12) !important;
}
.author-box-wrap .desc { flex: 1; }
.author-box-wrap .td-author-name { font-weight: 800 !important; font-size: 15px !important; margin-bottom: 4px !important; }
.author-box-wrap .td-author-name a { color: var(--np-text) !important; text-decoration: none !important; }
.author-box-wrap .td-author-name a:hover { color: var(--np-red) !important; }
.author-box-wrap .td-author-description { font-size: 13px !important; color: var(--np-text-light) !important; line-height: 1.6 !important; margin-top: 6px !important; }

/* =====================================================
   NAVIGATION PRÉCÉDENT / SUIVANT
   ===================================================== */
.td-post-next-prev {
    background: var(--np-white) !important;
    border: 1px solid var(--np-gray-2) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    margin: 32px 0 !important;
    display: flex !important;
}
.td-post-next-prev .td-block-span6 {
    flex: 1;
    padding: 20px 22px !important;
    transition: background .2s !important;
}
.td-post-next-prev .td-block-span6:hover { background: var(--np-gray-1) !important; }
.td-post-next-prev .td-block-span6 span {
    display: block !important;
    font-size: 10px !important; text-transform: uppercase !important;
    letter-spacing: .8px !important; font-weight: 700 !important;
    color: var(--np-red) !important; margin-bottom: 6px !important;
}
.td-post-next-prev .td-block-span6 a {
    font-family: var(--np-font-head) !important;
    font-size: 14px !important; font-weight: 700 !important;
    color: var(--np-text) !important; text-decoration: none !important;
    line-height: 1.35 !important; display: block !important;
}
.td-post-next-prev .td-block-span6 a:hover { color: var(--np-red) !important; }
.td-next-prev-separator {
    width: 1px !important;
    background: var(--np-gray-2) !important;
    flex-shrink: 0 !important;
}

/* =====================================================
   COMMENTAIRES
   ===================================================== */
#comments { margin-top: 40px; }
.comments-title {
    font-family: var(--np-font-head) !important;
    font-size: 20px !important; font-weight: 800 !important;
    color: var(--np-text) !important;
    padding-bottom: 12px !important;
    border-bottom: 3px solid var(--np-red) !important;
    margin-bottom: 24px !important;
}
.comment-list .comment {
    background: var(--np-white);
    border-radius: 8px;
    padding: 18px;
    margin-bottom: 16px;
    border: 1px solid var(--np-gray-2);
}
.comment-list .comment-author .fn { font-weight: 700; color: var(--np-text); font-size: 14px; }
.comment-list .comment-metadata a,
.comment-list .comment-metadata time { color: var(--np-gray-4) !important; font-size: 11px !important; }
.comment-list .comment-body p { font-size: 14px; line-height: 1.7; color: var(--np-text-light); margin: 10px 0 0; }
.comment-reply-link {
    font-size: 11px !important; font-weight: 700 !important;
    text-transform: uppercase !important; letter-spacing: .4px !important;
    color: var(--np-red) !important; text-decoration: none !important;
}

/* Formulaire commentaire */
#respond { background: var(--np-gray-1); border-radius: 8px; padding: 24px; margin-top: 32px; }
#respond .comment-reply-title {
    font-size: 18px !important; font-weight: 800 !important;
    color: var(--np-text) !important; margin-bottom: 20px !important;
}
#respond .comment-form label { font-weight: 600; font-size: 13px; display: block; margin-bottom: 5px; }
#respond .comment-form input[type="text"],
#respond .comment-form input[type="email"],
#respond .comment-form input[type="url"],
#respond .comment-form textarea {
    width: 100%;
    border: 1px solid var(--np-gray-2);
    border-radius: 4px;
    padding: 10px 14px;
    font-size: 14px;
    background: var(--np-white);
    transition: border-color .2s;
    margin-bottom: 14px;
}
#respond .comment-form input:focus,
#respond .comment-form textarea:focus {
    border-color: var(--np-red);
    outline: none;
    box-shadow: 0 0 0 2px rgba(192,57,43,.12);
}
#respond .form-submit input[type="submit"] {
    background: var(--np-red) !important;
    border: none !important;
    color: #fff !important;
    padding: 12px 28px !important;
    border-radius: 4px !important;
    font-size: 14px !important; font-weight: 700 !important;
    cursor: pointer !important;
    transition: filter .2s !important;
}
#respond .form-submit input[type="submit"]:hover { filter: brightness(.88) !important; }

/* =====================================================
   RESPONSIVE SUPPLÉMENTAIRE
   ===================================================== */
@media (max-width: 768px) {
    .np-404-code { font-size: 80px; }
    .np-404-title { font-size: 24px !important; }
    .np-cat-banner-title { font-size: 28px !important; }
    .np-search-title { font-size: 20px !important; }
    .np-result-img { width: 90px; height: 64px; }
    .np-search-hero { flex-direction: column; align-items: flex-start; }
    .np-search-form-main { max-width: 100%; }
    .np-featured-article { grid-template-columns: 1fr; }
    .np-featured-img { min-height: 180px; }
    .td-post-next-prev { flex-direction: column !important; }
    .td-next-prev-separator { width: 100% !important; height: 1px !important; }
    .author-box-wrap { flex-direction: column; }
}
@media (max-width: 480px) {
    .np-404-actions { flex-direction: column; width: 100%; }
    .np-btn-primary, .np-404-search { width: 100%; }
    .np-cat-banner { min-height: 160px; }
    .np-cat-banner-title { font-size: 22px !important; }
}

/* =====================================================
   TAGDIV BUILDER — SÉLECTEURS RÉELS (v2.0)
   Ciblage des vraies classes du builder tagDiv pour
   un rendu éditorial professionnel.
   ===================================================== */

/* Cartes d'articles tagDiv builder */
.tdb_module_loop .td-module-container,
.tdb_module_loop article,
.tdb-module-container,
.td-block-inner .td-module-container {
    background: #fff !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
    transition: transform .25s, box-shadow .25s !important;
}
.tdb_module_loop .td-module-container:hover,
.tdb-module-container:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,.14) !important;
}

/* Images des cartes */
.tdb_module_loop .td-image-wrap,
.td-block-inner .td-image-wrap {
    overflow: hidden !important;
}
.tdb_module_loop .td-image-wrap img,
.td-block-inner .td-image-wrap img {
    transition: transform .4s ease !important;
}
.tdb_module_loop .td-module-container:hover .td-image-wrap img {
    transform: scale(1.05) !important;
}

/* Titres articles dans les blocs tagDiv */
.tdb_module_loop .entry-title a,
.tdb_module_loop .td-module-title a,
.td-module-title a {
    font-family: Georgia, 'Times New Roman', serif !important;
    color: #1a1a2e !important;
    text-decoration: none !important;
    line-height: 1.35 !important;
}
.tdb_module_loop .entry-title a:hover,
.tdb_module_loop .td-module-title a:hover {
    color: #c0392b !important;
}

/* Labels catégorie tagDiv */
.tdb_module_loop .td-post-category,
.td-block-inner .td-post-category {
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .7px !important;
    text-transform: uppercase !important;
    padding: 2px 8px !important;
    border-radius: 3px !important;
    text-decoration: none !important;
}

/* Méta tagDiv */
.tdb_module_loop .td-editor-date,
.tdb_module_loop .td-post-author-name {
    font-size: 11px !important;
    color: #8395a7 !important;
    font-weight: 500 !important;
}

/* Menu mega tagDiv (navbar rouge déjà configurée, on affine) */
.tdb_header_mega_menu .tdb-menu-item > a,
.tdb_header_mega_menu .tdb-menu-item-text {
    font-weight: 700 !important;
    font-size: 13px !important;
    letter-spacing: .4px !important;
    text-transform: uppercase !important;
}
.tdb_header_mega_menu .tdb-menu-item > a:hover {
    text-decoration: none !important;
}
/* Sous-menu mega */
.tdb_header_mega_menu .sub-menu {
    background: #0d1b2a !important;
    border-top: 2px solid #c0392b !important;
    box-shadow: 0 6px 20px rgba(0,0,0,.25) !important;
}
.tdb_header_mega_menu .sub-menu a {
    color: rgba(255,255,255,.85) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
}
.tdb_header_mega_menu .sub-menu a:hover {
    color: #fff !important;
    background: #c0392b !important;
}

/* Sticky header tagDiv — classes réelles */
.np-scrolled .td-header-desktop-wrap {
    position: sticky !important;
    top: 0 !important;
    z-index: 9990 !important;
    box-shadow: 0 3px 16px rgba(0,0,0,.3) !important;
}
.np-header-hidden .td-header-desktop-wrap {
    transform: translateY(-100%) !important;
    transition: transform .3s ease !important;
}

/* Footer tagDiv — renforcement du dark theme */
.td-footer-template-wrap .tdb-block-inner,
.td-footer-template-wrap .tdc-inner-columns {
    color: rgba(255,255,255,.8) !important;
}
.td-footer-template-wrap a {
    color: rgba(255,255,255,.75) !important;
}
.td-footer-template-wrap a:hover {
    color: #c0392b !important;
}

/* Conteneur principal tagDiv */
.td-outer-wrap,
#td-outer-wrap {
    background: #f4f6f9;
}

/* Barre de progression lecture (visible sur single) */
#np-read-progress { z-index: 99999 !important; }

/* Bannière catégorie injectée par JS */
.np-cat-banner + .td-main-content-wrap,
.np-cat-banner + .td-container-wrap {
    padding-top: 28px;
}

/* Ticker : assure la visibilité quand injecté par JS */
#np-ticker.np-ticker-bar {
    display: flex !important;
    width: 100% !important;
}

/* =====================================================
   v2.0 — BARRE DE RUBRIQUES · NEWSLETTER · MAGAZINE
   ===================================================== */

/* ---- Barre de rubriques (chips colorés sous le ticker) ---- */
.np-cats-bar {
    background: #fff;
    border-bottom: 2px solid #e8ecf0;
    box-shadow: 0 2px 6px rgba(0,0,0,.05);
    position: relative;
    z-index: 800;
    width: 100%;
}
.np-cats-bar-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    align-items: center;
    gap: 5px;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    height: 42px;
}
.np-cats-bar-inner::-webkit-scrollbar { display: none; }
.np-cats-bar-label {
    font-size: 9px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    color: #8395a7;
    white-space: nowrap;
    padding-right: 12px;
    border-right: 1px solid #e8ecf0;
    margin-right: 6px;
    flex-shrink: 0;
}
.np-cat-chip {
    display: inline-flex;
    align-items: center;
    padding: 5px 13px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    text-decoration: none !important;
    white-space: nowrap;
    flex-shrink: 0;
    color: #fff !important;
    background-color: var(--chip-color, #1565C0);
    opacity: .82;
    transition: opacity .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.np-cat-chip:hover {
    opacity: 1;
    transform: translateY(-1px);
    box-shadow: 0 3px 9px rgba(0,0,0,.22);
    color: #fff !important;
}
@media (max-width: 768px) {
    .np-cats-bar-inner { height: 38px; padding: 0 12px; }
    .np-cat-chip { font-size: 10px; padding: 4px 10px; }
}

/* ---- Section Newsletter CTA ---- */
.np-newsletter-section {
    background: linear-gradient(135deg, #0d1b2a 0%, #1b2a3b 60%, #162030 100%);
    padding: 56px 24px;
    position: relative;
    overflow: hidden;
}
.np-newsletter-section::before {
    content: '';
    position: absolute;
    top: -80px; right: -60px;
    width: 340px; height: 340px;
    background: #c0392b;
    border-radius: 50%;
    opacity: .07;
    pointer-events: none;
}
.np-newsletter-section::after {
    content: '';
    position: absolute;
    bottom: -90px; left: 6%;
    width: 260px; height: 260px;
    background: #c0392b;
    border-radius: 50%;
    opacity: .05;
    pointer-events: none;
}
.np-newsletter-inner {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 48px;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}
.np-newsletter-icon {
    font-size: 56px;
    flex-shrink: 0;
    line-height: 1;
    filter: drop-shadow(0 4px 10px rgba(0,0,0,.4));
}
.np-newsletter-text { flex: 1; min-width: 200px; }
.np-newsletter-title {
    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 30px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 10px !important;
    letter-spacing: -.4px;
    line-height: 1.2 !important;
}
.np-newsletter-sub {
    color: rgba(255,255,255,.62);
    font-size: 14px;
    line-height: 1.65;
    margin: 0;
    max-width: 400px;
}
.np-newsletter-form { flex: 1; min-width: 280px; max-width: 460px; }
.np-newsletter-inputs {
    display: flex;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 6px 20px rgba(0,0,0,.35);
    margin-bottom: 12px;
}
.np-newsletter-inputs input[type="email"] {
    flex: 1;
    border: none;
    padding: 15px 18px;
    font-size: 14px;
    background: rgba(255,255,255,.1);
    color: #fff;
    outline: none;
    min-width: 0;
}
.np-newsletter-inputs input[type="email"]::placeholder { color: rgba(255,255,255,.38); }
.np-newsletter-inputs input[type="email"]:focus { background: rgba(255,255,255,.18); }
.np-newsletter-inputs button {
    background: #c0392b;
    border: none;
    padding: 15px 24px;
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 7px;
    white-space: nowrap;
    transition: background .2s;
    text-transform: uppercase;
    letter-spacing: .7px;
}
.np-newsletter-inputs button:hover { background: #a93226; }
.np-newsletter-inputs button.np-nl-success { background: #27ae60 !important; }
.np-newsletter-privacy {
    font-size: 11px;
    color: rgba(255,255,255,.36);
    margin: 0;
    text-align: center;
    letter-spacing: .2px;
}
@media (max-width: 768px) {
    .np-newsletter-inner { gap: 28px; }
    .np-newsletter-icon { font-size: 42px; }
    .np-newsletter-title { font-size: 24px !important; }
}
@media (max-width: 560px) {
    .np-newsletter-icon { display: none; }
    .np-newsletter-inputs { flex-direction: column; }
    .np-newsletter-inputs input[type="email"],
    .np-newsletter-inputs button { border-radius: 0; }
    .np-newsletter-inputs { border-radius: 6px; }
    .np-newsletter-inputs button { justify-content: center; }
}

/* ---- Section "Suivre sur les réseaux" ---- */
.np-social-follow {
    background: #f4f6f9;
    border-top: 3px solid #c0392b;
    border-bottom: 1px solid #e8ecf0;
    padding: 18px 24px;
}
.np-social-follow-inner {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
}
.np-social-follow-label {
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    color: #8395a7;
    margin-right: 4px;
}
.np-social-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 18px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #fff !important;
    text-decoration: none !important;
    transition: filter .2s, transform .15s;
    white-space: nowrap;
}
.np-social-btn:hover { filter: brightness(.88); transform: translateY(-1px); color: #fff !important; }
.np-social-btn.np-fb-btn { background: #1877f2; }
.np-social-btn.np-tw-btn { background: #1a1a1a; }
.np-social-btn.np-wa-btn { background: #25d366; }
.np-social-btn.np-yt-btn { background: #ff0000; }
.np-social-btn.np-ig-btn { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
@media (max-width: 560px) {
    .np-social-follow-label { width: 100%; text-align: center; }
}

/* ---- Badge NOUVEAU pour articles récents ---- */
.np-badge-new {
    display: inline-block;
    background: #c0392b;
    color: #fff;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 3px;
    vertical-align: middle;
    margin-left: 6px;
    animation: np-pulse-badge 2.5s ease-in-out infinite;
}
@keyframes np-pulse-badge {
    0%, 100% { opacity: 1; }
    50%       { opacity: .55; }
}

/* ---- Titre de bloc (accent rouge gauche) ---- */
.td-block-title-wrap {
    border-left: 4px solid #c0392b !important;
    padding-left: 12px !important;
    margin-bottom: 20px !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
}
.td-block-title-wrap .td-block-title {
    font-size: 16px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .8px !important;
    color: #0d1b2a !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
    margin: 0 !important;
}
.td-block-title-wrap .td-block-title span,
.td-block-title-wrap .td-block-title a {
    color: #0d1b2a !important;
    border-bottom: none !important;
    font-size: inherit !important;
    font-weight: inherit !important;
}

/* ---- Cartes modules tagDiv (flex_block_1 / _3 / _5) ---- */
.td_module_flex_1 .td-module-container,
.td_module_flex_5 .td-module-container,
.td_module_flex_3 .td-module-container,
.td_module_flex_4 .td-module-container {
    border-radius: 8px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 10px rgba(0,0,0,.07) !important;
    background: #fff !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
.td_module_flex_1:hover .td-module-container,
.td_module_flex_5:hover .td-module-container,
.td_module_flex_3:hover .td-module-container,
.td_module_flex_4:hover .td-module-container {
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 28px rgba(0,0,0,.13) !important;
}
.td_module_flex .td-image-container,
.td_module_flex .td-image-wrap { overflow: hidden !important; }
.td_module_flex .td-image-container img,
.td_module_flex .td-image-wrap img {
    transition: transform .5s ease !important;
}
.td_module_flex_1:hover .td-image-container img,
.td_module_flex_5:hover .td-image-container img,
.td_module_flex_3:hover .td-image-container img,
.td_module_flex_4:hover .td-image-container img {
    transform: scale(1.06) !important;
}

/* ---- Titres articles modules ---- */
.td-block-row .td-module-title a,
.td_flex_block .td-module-title a,
.tdb_module_loop .td-module-title a {
    font-family: Georgia, 'Times New Roman', serif !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    color: #1a1a2e !important;
    text-decoration: none !important;
    transition: color .2s !important;
}
.td-block-row .td-module-title a:hover,
.td_flex_block .td-module-title a:hover,
.tdb_module_loop .td-module-title a:hover {
    color: #c0392b !important;
}

/* ---- Séparateur décoratif entre sections de la homepage ---- */
.td-main-content-wrap .vc_row + .vc_row::before {
    content: '';
    display: block;
    max-width: 1160px;
    margin: 0 auto 20px;
    height: 1px;
    background: linear-gradient(to right, #c0392b 0, #e8ecf0 35%, transparent 100%);
}
