/*
 Theme Name:   GeneratePress RDR-IT
 Theme URI:    https://rdr-it.com
 Description:  Thème enfant GeneratePress pour RDR-IT — Dark/Light tech design v4
 Author:       Romain Drouche
 Author URI:   https://rdr-it.com
 Template:     generatepress
 Version:      4.0.0
 License:      GNU General Public License v2 or later
 Text Domain:  generatepress-rdr-it
*/

/* ============================================================
   IMPORT POLICES
   ============================================================ */
/* Polices chargées localement via css/rdr-fonts.css (wp_enqueue_style) */

/* ============================================================
   VARIABLES CSS — DARK MODE (défaut)
   ============================================================ */
:root,
[data-theme="dark"] {
    --rdr-bg-primary:    #0d1117;
    --rdr-bg-surface:    #161b22;
    --rdr-bg-card:       #1c2128;
    --rdr-bg-accent:     rgba(46,168,255,0.08);
    --rdr-accent:        #2ea8ff;
    --rdr-accent-2:      #00e5c0;
    --rdr-text-primary:  #e6edf3;
    --rdr-text-secondary:#8b949e;
    --rdr-text-muted:    #484f58;
    --rdr-border:        rgba(255,255,255,0.07);
    --rdr-border-strong: rgba(255,255,255,0.15);
    --rdr-nav-bg:        rgba(13,17,23,0.95);
    --rdr-nav-text:      #8b949e;
    --rdr-nav-hover:     #e6edf3;
    --rdr-nav-sub-bg:    #161b22;
    --rdr-code-bg:       #0d1117;
    --rdr-shadow:        0 8px 32px rgba(0,0,0,0.4);
    --rdr-shadow-card:   0 2px 8px rgba(0,0,0,0.3);
    --contrast:          #e6edf3;
    --contrast-2:        #8b949e;
    --contrast-3:        #484f58;
    --base:              #1c2128;
    --base-2:            #161b22;
    --base-3:            #0d1117;
    --accent:            #2ea8ff;
    --global-color-1:    #2ea8ff;
}

[data-theme="light"] {
    --rdr-bg-primary:    #f5f7fa;
    --rdr-bg-surface:    #ffffff;
    --rdr-bg-card:       #ffffff;
    --rdr-bg-accent:     rgba(30,115,190,0.06);
    --rdr-accent:        #1e73be;
    --rdr-accent-2:      #0a9b7d;
    --rdr-text-primary:  #1a1a2e;
    --rdr-text-secondary:#4a5568;
    --rdr-text-muted:    #a0aec0;
    --rdr-border:        rgba(0,0,0,0.08);
    --rdr-border-strong: rgba(0,0,0,0.15);
    --rdr-nav-bg:        rgba(255,255,255,0.97);
    --rdr-nav-text:      #2d3748;
    --rdr-nav-hover:     #1e73be;
    --rdr-nav-sub-bg:    #ffffff;
    --rdr-code-bg:       #f8fafc;
    --rdr-shadow:        0 4px 20px rgba(0,0,0,0.1);
    --rdr-shadow-card:   0 2px 8px rgba(0,0,0,0.08);
    --contrast:          #1a1a2e;
    --contrast-2:        #4a5568;
    --contrast-3:        #a0aec0;
    --base:              #f5f5f5;
    --base-2:            #fafafa;
    --base-3:            #ffffff;
    --accent:            #1e73be;
    --global-color-1:    #1e73be;
}

/* ============================================================
   BASE
   ============================================================ */
body {
    font-family: 'DM Sans', Arial, sans-serif !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    background-color: var(--rdr-bg-primary) !important;
    color: var(--rdr-text-primary) !important;
    transition: background-color 0.3s ease, color 0.3s ease;
}

body, .site, #page, .site-content, .site-inner {
    background-color: var(--rdr-bg-primary) !important;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header,
#masthead,
.site-header .inside-header {
    background-color: var(--rdr-nav-bg) !important;
    background: var(--rdr-nav-bg) !important;
    border-bottom: 1px solid var(--rdr-border) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

/* ============================================================
   STICKY MENU — FIX COMPLET
   GP utilise .is_stuck pour le sticky. On force les styles.
   ============================================================ */
.sticky-enabled .main-navigation.is_stuck,
.sticky-enabled .nav-primary.is_stuck,
.main-navigation.is_stuck {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 9999 !important;
    background-color: var(--rdr-nav-bg) !important;
    background: var(--rdr-nav-bg) !important;
    border-bottom: 1px solid var(--rdr-border) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    box-shadow: 0 2px 20px rgba(0,0,0,0.25) !important;
}

/* La nav en mode normal */
.nav-primary,
.main-navigation,
.main-navigation .inside-navigation,
nav.main-navigation {
    background: transparent !important;
    background-color: transparent !important;
}

/* ============================================================
   LOGO — MASQUER L'IMAGE CARRÉE, GARDER LE TITRE TEXTE
   ============================================================ */

/* Masquer le logo image */
.site-logo img,
.navigation-branding .site-logo img,
.navigation-branding .site-logo,
.main-navigation .site-logo,
.main-navigation .site-logo img,
img.header-image,
img.is-logo-image {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
}

/* Style du titre RDR-IT dans la nav */
.navigation-branding .main-title {
    font-family: 'Syne', sans-serif !important;
    font-weight: 800 !important;
    font-size: 22px !important;
    line-height: 60px !important;
    letter-spacing: -0.5px !important;
}

.navigation-branding .main-title a {
    text-decoration: none !important;
    background: none !important;
    /* On cache le texte pour afficher les pseudo-éléments */
    font-size: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
}

/* "RDR" en blanc */
.navigation-branding .main-title a::before {
    content: 'RDR' !important;
    color: #ffffff !important;
    font-family: 'Syne', sans-serif !important;
    font-weight: 800 !important;
    font-size: 22px !important;
    letter-spacing: -0.5px !important;
}

/* "-IT" en bleu accent */
.navigation-branding .main-title a::after {
    content: '-IT' !important;
    color: var(--rdr-accent) !important;
    font-family: 'Syne', sans-serif !important;
    font-weight: 800 !important;
    font-size: 22px !important;
    letter-spacing: -0.5px !important;
}

[data-theme="light"] .navigation-branding .main-title a::before {
    color: #1a1a2e !important;
}

/* ============================================================
   BOUTON DARK/LIGHT TOGGLE
   ============================================================ */
#rdr-theme-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 44px !important;
    height: 24px !important;
    border-radius: 12px !important;
    border: 1.5px solid rgba(255,255,255,0.2) !important;
    cursor: pointer !important;
    padding: 3px !important;
    margin: 0 10px !important;
    position: relative !important;
    background: #374151 !important;
    transition: background 0.3s ease, border-color 0.3s ease !important;
    flex-shrink: 0 !important;
    vertical-align: middle !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    /* Pastille glissante */
    overflow: visible !important;
}

[data-theme="light"] #rdr-theme-toggle {
    background: #3b82f6 !important;
    border-color: rgba(59,130,246,0.5) !important;
}

/* Pastille */
#rdr-theme-toggle::after {
    content: '' !important;
    position: absolute !important;
    width: 16px !important;
    height: 16px !important;
    border-radius: 50% !important;
    background: white !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    left: 4px !important;
    transition: left 0.3s ease !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.4) !important;
}

[data-theme="light"] #rdr-theme-toggle::after {
    left: 22px !important;
}

/* Emoji icône */
#rdr-theme-toggle::before {
    content: '🌙' !important;
    font-size: 11px !important;
    position: absolute !important;
    right: 4px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    transition: opacity 0.3s !important;
    line-height: 1 !important;
}

[data-theme="light"] #rdr-theme-toggle::before {
    content: '☀️' !important;
    right: auto !important;
    left: 4px !important;
}

/* ============================================================
   NAVIGATION — LIENS
   ============================================================ */
.main-navigation .main-nav ul li a,
.main-navigation ul li > a,
#primary-menu > li > a {
    color: var(--rdr-nav-text) !important;
    background-color: transparent !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    padding: 0 10px !important;
    transition: color 0.2s ease !important;
    white-space: nowrap !important;
}

.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.sfHover > a {
    color: var(--rdr-nav-hover) !important;
    background-color: transparent !important;
}

.main-navigation .main-nav ul li[class*="current-menu-"] > a {
    color: var(--rdr-accent) !important;
    background-color: transparent !important;
}

/* ============================================================
   SOUS-MENUS — FIX LARGEUR (texte vertical = sous-menu trop étroit)
   ============================================================ */

/* Le problème: GP ne fixe pas de width sur les sous-menus.
   On force min-width et white-space:nowrap pour éviter retour à la ligne */
.main-navigation ul ul,
.main-navigation .sub-menu,
.main-navigation .main-nav ul ul {
    background-color: var(--rdr-nav-sub-bg) !important;
    border: 1px solid var(--rdr-border-strong) !important;
    border-radius: 8px !important;
    box-shadow: var(--rdr-shadow) !important;
    min-width: 240px !important;
    width: auto !important;
    padding: 6px 0 !important;
    overflow: visible !important;
}

/* Sous-sous-menus */
.main-navigation .main-nav ul ul ul {
    min-width: 240px !important;
    width: auto !important;
}

/* Chaque item dans le sous-menu */
.main-navigation .main-nav ul ul li {
    width: auto !important;
    float: none !important;
    display: block !important;
    min-width: 240px !important;
}

/* Lien dans le sous-menu */
.main-navigation .main-nav ul ul li a {
    color: var(--rdr-nav-text) !important;
    background-color: transparent !important;
    font-size: 13px !important;
    padding: 8px 18px !important;
    display: block !important;
    white-space: nowrap !important;    /* ← empêche le texte vertical */
    width: auto !important;
    min-width: 200px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.main-navigation .main-nav ul ul li a:hover,
.main-navigation .main-nav ul ul li:hover > a,
.main-navigation .main-nav ul ul li.sfHover > a {
    color: var(--rdr-accent) !important;
    background-color: var(--rdr-bg-accent) !important;
}

/* ============================================================
   CONTENEURS ARTICLES
   ============================================================ */
.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.one-container .container,
.separate-containers .paging-navigation,
.inside-page-header {
    background-color: var(--rdr-bg-surface) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--rdr-shadow-card) !important;
}

/* ============================================================
   TYPOGRAPHIE
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
    font-family: 'Syne', sans-serif !important;
    color: var(--rdr-text-primary) !important;
}

p, li, td, th {
    color: var(--rdr-text-primary);
}

a {
    color: var(--rdr-accent) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}
a:hover { color: var(--rdr-accent-2) !important; }

.entry-title {
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: var(--rdr-text-primary) !important;
}

.entry-meta, .entry-footer {
    color: var(--rdr-text-secondary) !important;
    font-size: 13px !important;
}

/* H2/H3 dans articles */
.entry-content h2 {
    font-size: 22px !important;
    border-left: 3px solid var(--rdr-accent) !important;
    padding-left: 12px !important;
    margin-top: 32px !important;
}

.entry-content h3 {
    font-size: 18px !important;
    font-weight: 600 !important;
    margin-top: 24px !important;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar .widget {
    background-color: var(--rdr-bg-surface) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 10px !important;
    box-shadow: var(--rdr-shadow-card) !important;
    color: var(--rdr-text-primary) !important;
}

.widget-title, .sidebar .widget h2 {
    font-family: 'Syne', sans-serif !important;
    color: var(--rdr-accent) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    border-bottom: 2px solid var(--rdr-accent) !important;
    padding-bottom: 8px !important;
    margin-bottom: 12px !important;
}

/* ============================================================
   FOOTER — FIX LARGEUR ET COLONNES
   Les widgets s'affichent en petit à gauche car le container
   n'est pas en full-width et les colonnes ne sont pas définies.
   ============================================================ */

/* Wrapper footer widgets — full width */
#footer-widgets,
.footer-widgets {
    background-color: var(--rdr-bg-surface) !important;
    background: var(--rdr-bg-surface) !important;
    border-top: 1px solid var(--rdr-border) !important;
    color: var(--rdr-text-secondary) !important;
    width: 100% !important;
    display: block !important;
}

/* Container interne footer */
.footer-widgets-container {
    max-width: 1280px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 40px 30px !important;
    box-sizing: border-box !important;
}

/* Grid 4 colonnes */
.inside-footer-widgets {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 32px !important;
    width: 100% !important;
    align-items: start !important;
}

/* Chaque colonne */
.footer-widget-1,
.footer-widget-2,
.footer-widget-3 {
    min-width: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Responsive footer */
@media (max-width: 900px) {
    .inside-footer-widgets {
        grid-template-columns: 1fr 1fr !important;
    }
}
@media (max-width: 560px) {
    .inside-footer-widgets {
        grid-template-columns: 1fr !important;
    }
    .footer-widgets-container {
        padding: 24px 16px !important;
    }
}

/* Titres widgets footer */
.footer-widgets .widget-title,
.footer-widgets h2,
.footer-widgets h3 {
    color: var(--rdr-text-primary) !important;
    font-family: 'Syne', sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    margin-bottom: 14px !important;
    border-bottom: 1px solid var(--rdr-border) !important;
    padding-bottom: 8px !important;
}

.footer-widgets a {
    color: var(--rdr-text-secondary) !important;
    font-size: 13px !important;
    line-height: 1.9 !important;
}
.footer-widgets a:hover { color: var(--rdr-accent) !important; }

/* Tag cloud footer */
.footer-widgets .wp-block-tag-cloud {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 5px !important;
}

.footer-widgets .tag-cloud-link {
    background: var(--rdr-bg-card) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 4px !important;
    padding: 3px 7px !important;
    font-size: 11px !important;
    color: var(--rdr-text-secondary) !important;
    text-decoration: none !important;
    line-height: 1.5 !important;
    white-space: nowrap !important;
}

.footer-widgets .tag-cloud-link:hover {
    border-color: var(--rdr-accent) !important;
    color: var(--rdr-accent) !important;
}

/* Réseaux sociaux footer */
.footer-widgets .wp-block-social-links {
    padding: 0 !important;
    margin: 0 !important;
}

/* Bar copyright */
.site-footer,
#colophon,
.footer-bar,
.site-info {
    background-color: var(--rdr-bg-primary) !important;
    background: var(--rdr-bg-primary) !important;
    color: var(--rdr-text-muted) !important;
    border-top: 1px solid var(--rdr-border) !important;
}

.site-info a, .footer-bar a { color: var(--rdr-text-secondary) !important; }

.inside-site-info {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 12px 30px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    font-size: 12px !important;
}

/* ============================================================
   CODE
   ============================================================ */
.entry-content pre,
.wp-block-syntaxhighlighter-code pre,
.syntaxhighlighter {
    background: var(--rdr-code-bg) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 8px !important;
    padding: 16px !important;
    overflow-x: auto !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #a8b3cf !important;
    position: relative !important;
}

code {
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 0.85em !important;
    background: var(--rdr-bg-card) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 4px !important;
    padding: 2px 6px !important;
    color: var(--rdr-accent-2) !important;
}

pre code {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    color: inherit !important;
}

/* Bouton copier — uniquement sur blocs code WP (pas Gitlab snippets) */
.rdr-code-wrapper {
    position: relative !important;
}

.rdr-copy-btn {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    z-index: 10 !important;
    background: rgba(28,33,40,0.8) !important;
    border: 1px solid var(--rdr-border-strong) !important;
    border-radius: 5px !important;
    color: var(--rdr-text-secondary) !important;
    font-size: 11px !important;
    padding: 3px 8px !important;
    cursor: pointer !important;
    font-family: 'DM Sans', sans-serif !important;
    transition: all 0.2s ease !important;
    opacity: 0 !important;
    backdrop-filter: blur(4px) !important;
}

.rdr-code-wrapper:hover .rdr-copy-btn {
    opacity: 1 !important;
}

.rdr-copy-btn:hover {
    background: var(--rdr-accent) !important;
    color: white !important;
    border-color: var(--rdr-accent) !important;
    opacity: 1 !important;
}

.rdr-copy-btn.copied {
    background: #00e5c0 !important;
    color: #0d1117 !important;
    border-color: #00e5c0 !important;
    opacity: 1 !important;
}

/* ============================================================
   TABLE OF CONTENTS (Rank Math) — LISIBILITÉ DARK + LIGHT
   ============================================================ */
.wp-block-rank-math-toc-block,
#rank-math-toc,
.wp-block-rank-math-toc-block.has-accent-background-color {
    background: var(--rdr-bg-card) !important;
    border: 1px solid var(--rdr-border) !important;
    border-left: 4px solid var(--rdr-accent) !important;
    border-radius: 10px !important;
    padding: 20px 24px !important;
    margin: 24px 0 !important;
}

.wp-block-rank-math-toc-block h2,
#rank-math-toc h2 {
    color: var(--rdr-text-primary) !important;
    background: none !important;
    font-size: 15px !important;
    border: none !important;
    padding: 0 0 10px 0 !important;
    margin-bottom: 12px !important;
    border-bottom: 1px solid var(--rdr-border) !important;
}

/* Liens TOC */
.wp-block-rank-math-toc-block a,
.wp-block-rank-math-toc-block nav a,
#rank-math-toc a,
#rank-math-toc nav a,
.has-base-3-color {
    color: var(--rdr-text-secondary) !important;
    text-decoration: none !important;
    font-size: 13.5px !important;
    line-height: 1.8 !important;
}

.wp-block-rank-math-toc-block a:hover,
#rank-math-toc a:hover {
    color: var(--rdr-accent) !important;
}

/* MODE CLAIR — TOC lisible */
[data-theme="light"] .wp-block-rank-math-toc-block,
[data-theme="light"] #rank-math-toc {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
    border-left-color: var(--rdr-accent) !important;
}

[data-theme="light"] .wp-block-rank-math-toc-block h2,
[data-theme="light"] #rank-math-toc h2 {
    color: #1a1a2e !important;
    border-bottom-color: #e2e8f0 !important;
}

[data-theme="light"] .wp-block-rank-math-toc-block a,
[data-theme="light"] .wp-block-rank-math-toc-block nav a,
[data-theme="light"] #rank-math-toc a,
[data-theme="light"] .has-base-3-color {
    color: #4a5568 !important;
}

[data-theme="light"] .wp-block-rank-math-toc-block a:hover,
[data-theme="light"] #rank-math-toc a:hover {
    color: var(--rdr-accent) !important;
}

/* ============================================================
   LISIBILITÉ MODE CLAIR — corrections globales
   ============================================================ */
[data-theme="light"] body,
[data-theme="light"] p,
[data-theme="light"] li,
[data-theme="light"] td,
[data-theme="light"] th,
[data-theme="light"] span:not(.rdr-stat-number) {
    color: #1a1a2e;
}

[data-theme="light"] h1,
[data-theme="light"] h2,
[data-theme="light"] h3,
[data-theme="light"] h4,
[data-theme="light"] h5,
[data-theme="light"] h6 {
    color: #1a1a2e !important;
}

[data-theme="light"] .entry-content,
[data-theme="light"] .entry-content p,
[data-theme="light"] .entry-content li {
    color: #2d3748 !important;
}

[data-theme="light"] .entry-content blockquote {
    background: #f8fafc !important;
    border-left-color: var(--rdr-accent) !important;
}

[data-theme="light"] .entry-content blockquote p {
    color: #4a5568 !important;
}

[data-theme="light"] code {
    background: #f1f5f9 !important;
    color: #0a9b7d !important;
    border-color: #e2e8f0 !important;
}

[data-theme="light"] .entry-content pre,
[data-theme="light"] .wp-block-syntaxhighlighter-code pre,
[data-theme="light"] .syntaxhighlighter {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
    color: #2d3748 !important;
}

[data-theme="light"] .separate-containers .inside-article {
    background: #ffffff !important;
    border-color: #e2e8f0 !important;
}

[data-theme="light"] .sidebar .widget {
    background: #ffffff !important;
    border-color: #e2e8f0 !important;
}

[data-theme="light"] .site-header, [data-theme="light"] #masthead {
    background-color: rgba(255,255,255,0.97) !important;
    background: rgba(255,255,255,0.97) !important;
    border-bottom-color: #e2e8f0 !important;
}

[data-theme="light"] .main-navigation.is_stuck {
    background-color: rgba(255,255,255,0.97) !important;
    background: rgba(255,255,255,0.97) !important;
}

[data-theme="light"] .main-navigation .main-nav ul li a {
    color: #2d3748 !important;
}

[data-theme="light"] .main-navigation ul ul,
[data-theme="light"] .main-navigation .sub-menu {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1) !important;
}

[data-theme="light"] .main-navigation .main-nav ul ul li a {
    color: #2d3748 !important;
}

[data-theme="light"] #footer-widgets,
[data-theme="light"] .footer-widgets {
    background-color: #f8fafc !important;
    background: #f8fafc !important;
    border-top-color: #e2e8f0 !important;
}

[data-theme="light"] .site-footer,
[data-theme="light"] #colophon,
[data-theme="light"] .footer-bar,
[data-theme="light"] .site-info {
    background-color: #f1f5f9 !important;
    border-top-color: #e2e8f0 !important;
    color: #718096 !important;
}

[data-theme="light"] .footer-widgets .tag-cloud-link {
    background: #f1f5f9 !important;
    border-color: #e2e8f0 !important;
    color: #4a5568 !important;
}

/* ============================================================
   SYNTAXHIGHLIGHTER
   ============================================================ */
.syntaxhighlighter .line,
.syntaxhighlighter table,
.syntaxhighlighter td {
    background: var(--rdr-code-bg) !important;
    border: none !important;
}

.syntaxhighlighter .gutter,
.syntaxhighlighter .gutter .line {
    background: rgba(255,255,255,0.03) !important;
    color: var(--rdr-text-muted) !important;
    border-right: 1px solid var(--rdr-border) !important;
}

[data-theme="light"] .syntaxhighlighter .line,
[data-theme="light"] .syntaxhighlighter table,
[data-theme="light"] .syntaxhighlighter td {
    background: #f8fafc !important;
}

[data-theme="light"] .syntaxhighlighter .gutter,
[data-theme="light"] .syntaxhighlighter .gutter .line {
    background: #f1f5f9 !important;
    color: #a0aec0 !important;
    border-right-color: #e2e8f0 !important;
}

/* ============================================================
   BARRE PROGRESSION LECTURE
   ============================================================ */
#rdr-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0%;
    background: linear-gradient(90deg, var(--rdr-accent), var(--rdr-accent-2));
    z-index: 99999;
    transition: width 0.1s linear;
    pointer-events: none;
}

/* ============================================================
   BLOCKQUOTES
   ============================================================ */
.entry-content blockquote {
    background: var(--rdr-bg-card) !important;
    border-left: 4px solid var(--rdr-accent) !important;
    border-radius: 0 8px 8px 0 !important;
    padding: 16px 20px !important;
    margin: 20px 0 !important;
    color: var(--rdr-text-secondary) !important;
}

/* ============================================================
   INPUTS & FORMULAIRES
   ============================================================ */
input[type="text"], input[type="email"], input[type="url"],
input[type="search"], input[type="password"], textarea, select {
    background: var(--rdr-bg-card) !important;
    border: 1px solid var(--rdr-border-strong) !important;
    border-radius: 6px !important;
    color: var(--rdr-text-primary) !important;
    padding: 8px 12px !important;
    font-family: 'DM Sans', sans-serif !important;
}

input:focus, textarea:focus {
    border-color: var(--rdr-accent) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(46,168,255,0.15) !important;
}

/* ============================================================
   BOUTONS — Système de variantes dark/light
   Usage : class="button"              → Primaire (accent bleu)
           class="button button-outline" → Contour accent
           class="button button-ghost"   → Transparent
           class="button button-muted"   → Discret (surface)
           class="button button-danger"  → Rouge
           class="button button-sm"      → Petit
           class="button button-lg"      → Grand
           class="button button-full"    → Pleine largeur
   ============================================================ */

/* Base commune */
.button,
a.button,
input[type="submit"],
button[type="submit"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 9px 20px !important;
    border-radius: 7px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease, color .15s ease !important;
    white-space: nowrap !important;
    border: 1.5px solid transparent !important;
    /* Variante par défaut : primaire */
    background: var(--rdr-accent) !important;
    color: #fff !important;
    border-color: var(--rdr-accent) !important;
}
.button:hover,
a.button:hover,
input[type="submit"]:hover,
button[type="submit"]:hover {
    background: var(--rdr-accent-2) !important;
    border-color: var(--rdr-accent-2) !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 14px rgba(46,168,255,.35) !important;
    text-decoration: none !important;
}
.button:active, a.button:active {
    transform: translateY(0) !important;
    box-shadow: none !important;
}

/* ── Outline ── */
.button.button-outline,
a.button.button-outline {
    background: transparent !important;
    color: var(--rdr-accent) !important;
    border-color: var(--rdr-accent) !important;
}
.button.button-outline:hover,
a.button.button-outline:hover {
    background: var(--rdr-accent) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(46,168,255,.25) !important;
}

/* ── Ghost ── */
.button.button-ghost,
a.button.button-ghost {
    background: transparent !important;
    color: var(--rdr-text-primary) !important;
    border-color: var(--rdr-border) !important;
}
.button.button-ghost:hover,
a.button.button-ghost:hover {
    background: var(--rdr-bg-accent) !important;
    border-color: var(--rdr-accent) !important;
    color: var(--rdr-accent) !important;
    box-shadow: none !important;
}

/* ── Muted (surface) ── */
.button.button-muted,
a.button.button-muted {
    background: var(--rdr-bg-card) !important;
    color: var(--rdr-text-secondary) !important;
    border-color: var(--rdr-border) !important;
}
.button.button-muted:hover,
a.button.button-muted:hover {
    background: var(--rdr-bg-accent) !important;
    color: var(--rdr-text-primary) !important;
    border-color: var(--rdr-accent) !important;
    box-shadow: none !important;
}

/* ── Danger ── */
.button.button-danger,
a.button.button-danger {
    background: #e53e3e !important;
    color: #fff !important;
    border-color: #e53e3e !important;
}
.button.button-danger:hover,
a.button.button-danger:hover {
    background: #c53030 !important;
    border-color: #c53030 !important;
    box-shadow: 0 4px 14px rgba(229,62,62,.35) !important;
}

/* ── Tailles ── */
.button.button-sm, a.button.button-sm {
    padding: 6px 14px !important;
    font-size: 12px !important;
    border-radius: 5px !important;
}
.button.button-lg, a.button.button-lg {
    padding: 12px 28px !important;
    font-size: 15px !important;
    border-radius: 8px !important;
}
.button.button-full, a.button.button-full {
    width: 100% !important;
}

/* ── Mode clair : ajustements ── */
[data-theme="light"] .button,
[data-theme="light"] a.button {
    box-shadow: 0 1px 3px rgba(0,0,0,.1);
}
[data-theme="light"] .button.button-muted,
[data-theme="light"] a.button.button-muted {
    background: #f0f4f8 !important;
    color: #4a5568 !important;
    border-color: #cbd5e0 !important;
}
[data-theme="light"] .button.button-ghost,
[data-theme="light"] a.button.button-ghost {
    color: #2d3748 !important;
}


/* ============================================================
   GENERATEBLOCKS OVERRIDES
   ============================================================ */
.gb-headline-text { color: var(--rdr-text-primary) !important; }

h2.gb-headline-text { color: var(--rdr-accent) !important; }

.gb-headline-text a,
.gb-headline-text a:visited {
    color: var(--rdr-text-primary) !important;
    font-size: 13.5px !important;
}

.gb-headline-text a:hover { color: var(--rdr-accent) !important; }

p.gb-headline-text a { color: var(--rdr-text-muted) !important; font-size: 11px !important; }

.gb-container[class*="gb-container-"] {
    background-color: var(--rdr-bg-surface) !important;
    border-color: var(--rdr-border) !important;
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.rank-math-breadcrumb, .rank-math-breadcrumb p {
    font-size: 12px !important;
    color: var(--rdr-text-muted) !important;
}

.rank-math-breadcrumb a { color: var(--rdr-text-secondary) !important; font-size: 12px !important; }
.rank-math-breadcrumb a:hover { color: var(--rdr-accent) !important; }

/* ============================================================
   BOÎTES INFO ARTICLES
   ============================================================ */
.rdr-info-box {
    display: flex; gap: 14px; padding: 16px 18px;
    border-radius: 10px; margin: 20px 0; border: 1px solid;
}
.rdr-info-info    { background: var(--rdr-bg-accent); border-color: var(--rdr-accent); }
.rdr-info-warning { background: rgba(255,180,0,0.1); border-color: rgba(255,180,0,0.4); }
.rdr-info-success { background: rgba(0,200,100,0.1); border-color: rgba(0,200,100,0.4); }
.rdr-info-danger  { background: rgba(255,80,80,0.1); border-color: rgba(255,80,80,0.4); }
.rdr-info-tip     { background: rgba(0,229,192,0.1); border-color: rgba(0,229,192,0.4); }
.rdr-info-icon    { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.rdr-info-title   { display: block; font-weight: 700; margin-bottom: 4px; color: var(--rdr-text-primary); }
.rdr-info-content { font-size: 14px; color: var(--rdr-text-secondary); }
.rdr-info-content p { margin: 0; }

/* ============================================================
   COMMENTAIRES
   ============================================================ */
.comment-body {
    background: var(--rdr-bg-card) !important;
    border: 1px solid var(--rdr-border) !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin-bottom: 16px !important;
}

.comment-author cite { color: var(--rdr-text-primary) !important; font-weight: 600 !important; }

[data-theme="light"] .comment-body {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.generate-back-to-top {
    background-color: var(--rdr-accent) !important;
    color: white !important;
    border-radius: 8px !important;
}
.generate-back-to-top:hover { background-color: var(--rdr-accent-2) !important; }

/* ============================================================
   MOBILE NAV
   ============================================================ */
@media (max-width: 768px) {
    .main-navigation ul {
        background: var(--rdr-nav-bg) !important;
        border-top: 1px solid var(--rdr-border) !important;
    }
    .main-navigation .main-nav ul li a {
        border-bottom: 1px solid var(--rdr-border) !important;
        padding: 12px 16px !important;
        white-space: normal !important;
    }
    .main-navigation ul ul,
    .main-navigation .sub-menu {
        min-width: unset !important;
        width: 100% !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        border: none !important;
        border-top: 1px solid var(--rdr-border) !important;
    }
    .main-navigation .main-nav ul ul li { min-width: unset !important; }
    .inside-site-info {
        flex-direction: column;
        gap: 6px;
        text-align: center;
    }
}

/* ============================================================
   OVERRIDE STYLES INLINE GP CUSTOMIZER
   (ces règles sont injectées dans wp_head avec priorité 999
    dans functions.php mais on les met ici aussi pour sécurité)
   ============================================================ */
[style*="background-color: #ffffff"],
[style*="background-color:#ffffff"],
[style*="background-color: #fff"],
[style*="background-color:#fff"] {
    background-color: var(--rdr-bg-surface) !important;
}

/* ============================================================
   PAGE D'ACCUEIL (template page-home.php)
   ============================================================ */
.page-template-page-home .entry-title,
.page-template-page-home .page-header { display: none !important; }

