/*
Theme Name: TBM06
Theme URI: https://www.tbm06.fr
Author: TBM06
Author URI: https://www.tbm06.fr
Description: Block theme officiel de TBM06 · Très Bon Média Côte d'Azur. Direction artistique Pop Provençal (navy + cream + moutarde + rose + cyan). Conçu pour info locale Nice/06, mobile-first, optimisé Google Discover et lecture longue.
Version: 0.1.0
Requires at least: 6.4
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tbm06
Tags: news, magazine, full-site-editing, block-styles, custom-colors, editor-style
*/

/* CSS additionnel non couvert par theme.json · surtout les ombres solides signature */

/* === SHADOWS SOLIDES (signature Pop Provençal) === */
.tbm-shadow-pop { box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85); transition: all 0.2s ease; }
.tbm-shadow-pop:hover { box-shadow: 0 4px 0 rgba(20, 17, 15, 0.85); transform: translateY(4px); }

.tbm-shadow-soft { box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7); transition: all 0.2s ease; }
.tbm-shadow-soft:hover { box-shadow: 0 3px 0 rgba(20, 17, 15, 0.7); transform: translateY(3px); }

.tbm-shadow-pill { box-shadow: 0 5px 0 rgba(0, 0, 0, 0.85); transition: all 0.15s ease; }
.tbm-shadow-pill:hover { box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85); transform: translateY(3px); }

/* === PILL (badge / bouton) === */
.tbm-pill {
    display: inline-block;
    border-radius: 999px;
    padding: 8px 20px;
    font-weight: 700;
    font-style: italic;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    text-decoration: none;
}
.tbm-pill:hover { box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85); transform: translateY(3px); }

/* === BADGE === */
.tbm-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 999px;
}

/* === CARD === */
.tbm-card-pop {
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85);
    transition: all 0.2s ease;
}
.tbm-card-pop:hover { box-shadow: 0 4px 0 rgba(20, 17, 15, 0.85); transform: translateY(4px); }

.tbm-card-soft {
    border-radius: 20px;
    box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7);
}

/* === DISPLAY (titres italique chaud Fraunces) === */
.tbm-display {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    letter-spacing: -0.02em;
    line-height: 1.05;
}
.tbm-display-r {
    font-family: "Fraunces", Georgia, serif;
    font-weight: 800;
    letter-spacing: -0.02em;
}

/* === LETTRINE (article actu) === */
/* === CHAPÔ : 1er paragraphe d'article en gros + semi-bold (règle TBM06) === */
.wp-block-post-content > p:first-of-type,
.entry-content > p:first-of-type,
article .wp-block-post-content > p:first-of-type {
    font-size: clamp(20px, 2.4vw, 26px) !important;
    line-height: 1.4;
    font-weight: 600;
    color: var(--wp--preset--color--navy, #1F3D52);
    margin-bottom: 28px;
    font-family: "Mulish", Arial, sans-serif;
}
/* Si le chapô est dans un wp:paragraph (cas de meteo et necro) → cible aussi le 1er .wp-block-paragraph */
.wp-block-post-content > .wp-block-paragraph:first-of-type p,
.wp-block-post-content > p.wp-block-paragraph:first-of-type {
    font-size: clamp(20px, 2.4vw, 26px) !important;
    line-height: 1.4;
    font-weight: 600;
    color: var(--wp--preset--color--navy, #1F3D52);
    margin-bottom: 28px;
}

.tbm-dropcap::first-letter {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 5em;
    line-height: 0.85;
    float: left;
    padding: 0.06em 0.1em 0 0;
    color: var(--wp--preset--color--rose, #E83A6E);
}

/* === BLOCKQUOTE === */
.entry-content blockquote,
.tbm-quote {
    border-left: 5px solid var(--wp--preset--color--rose, #E83A6E);
    padding: 0.5em 0 0.5em 1.5em;
    margin: 1.8em 0;
    font-style: italic;
    font-size: 1.4em;
    line-height: 1.4;
    font-weight: 700;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-family: "Fraunces", Georgia, serif;
}
.entry-content blockquote cite,
.tbm-quote cite {
    display: block;
    font-size: 0.55em;
    font-weight: 500;
    color: #5A5651;
    margin-top: 0.5em;
    font-style: italic;
}

/* === LINKS in articles === */
.entry-content a {
    color: var(--wp--preset--color--rose, #E83A6E);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
    font-weight: 600;
}

/* === TICKER (fil d'infos) === */
.tbm-ticker {
    animation: tbm-ticker 9s linear infinite;
}
@keyframes tbm-ticker {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* === MINI-PLAYER STICKY === */
.tbm-mini-player {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 40;
    background: var(--wp--preset--color--navy, #1F3D52);
    color: white;
    border-top: 3px solid var(--wp--preset--color--moutarde, #F4C32D);
}

/* === WHATSAPP FLOATING === */
.tbm-whatsapp-floating {
    position: fixed;
    bottom: 78px;
    right: 16px;
    z-index: 40;
    width: 56px;
    height: 56px;
    border-radius: 999px;
    background: var(--wp--preset--color--cyan, #4EAAA8);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease;
}
.tbm-whatsapp-floating:hover { transform: scale(1.1); }

/* === RESPONSIVE === */
@media (max-width: 640px) {
    .tbm-whatsapp-floating { bottom: 70px; right: 12px; width: 48px; height: 48px; }
    .tbm-display { font-size: 1.5rem; }
}

/* === RESPONSIVE HEADER LOGO === */
/* Mobile : logo plus compact + padding header réduit */
@media (max-width: 781px) {
    .wp-block-site-logo img {
        max-width: 220px !important;
    }
    header.wp-block-template-part > .wp-block-group:first-child > .wp-block-group {
        padding-top: 16px !important;
        padding-bottom: 16px !important;
    }
}

/* === NAV HEADER PILLS COLORÉES (Pop Provençal multi-couleurs) === */
.tbm-nav-pills .wp-block-navigation__container {
    gap: 8px !important;
}
.tbm-nav-pills .wp-block-navigation-item__content {
    padding: 8px 18px !important;
    border-radius: 999px !important;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.85);
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    transition: all 0.15s ease;
    text-decoration: none !important;
    line-height: 1.2;
    display: inline-block;
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-nav-pills .wp-block-navigation-item:nth-child(1) .wp-block-navigation-item__content {
    background: var(--wp--preset--color--cream, #FEF7E7) !important;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
}
.tbm-nav-pills .wp-block-navigation-item:nth-child(2) .wp-block-navigation-item__content {
    background: var(--wp--preset--color--cyan, #4EAAA8) !important;
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
}
.tbm-nav-pills .wp-block-navigation-item:nth-child(3) .wp-block-navigation-item__content {
    background: var(--wp--preset--color--moutarde, #F4C32D) !important;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
}
.tbm-nav-pills .wp-block-navigation-item:nth-child(4) .wp-block-navigation-item__content {
    background: var(--wp--preset--color--rose, #E83A6E) !important;
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
}
.tbm-nav-pills .wp-block-navigation-item:nth-child(5) .wp-block-navigation-item__content {
    background: white !important;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
}
.tbm-nav-pills .wp-block-navigation-item__content:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(2px);
    filter: brightness(1.05);
}
.tbm-nav-pills .wp-block-navigation__responsive-container-open {
    color: white !important;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 999px;
    padding: 8px;
}

/* === FIL D'INFOS TICKER (mockup) === */
header .wp-block-template-part:has(.tbm-ticker),
.tbm-ticker-bar {
    background: var(--wp--preset--color--navy-deep, #143246);
    overflow: hidden;
    color: var(--wp--preset--color--cream, #FEF7E7);
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
/* Force le wrapper template-part du fil-infos à être full width */
header > .wp-block-group > .wp-block-template-part:last-child {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
}
.tbm-ticker-label {
    color: var(--wp--preset--color--moutarde, #F4C32D);
    font-weight: 900;
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 12px 20px;
    flex-shrink: 0;
    background: rgba(0,0,0,0.15);
}
.tbm-ticker-sep {
    color: var(--wp--preset--color--moutarde, #F4C32D);
    margin: 0 14px;
}
.tbm-ticker-track {
    display: flex;
    gap: 32px;
    padding: 8px 0;
    white-space: nowrap;
    animation: tbm-ticker 9s linear infinite;
    font-style: italic;
    font-size: 13px;
    color: var(--wp--preset--color--cream, #FEF7E7);
}
.tbm-ticker-track a {
    color: inherit !important;
    text-decoration: none !important;
}

/* === DIRECT RADIO BUTTON (rose pulsant) === */
.tbm-direct-radio {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--wp--preset--color--rose, #E83A6E);
    color: white !important;
    padding: 10px 20px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    text-decoration: none !important;
    box-shadow: 0 5px 0 rgba(0,0,0,0.85);
    transition: all 0.15s ease;
    white-space: nowrap;
    line-height: 1;
}
.tbm-direct-radio:hover {
    box-shadow: 0 2px 0 rgba(0,0,0,0.85);
    transform: translateY(3px);
}
.tbm-direct-radio .tbm-pulse {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: white;
    flex-shrink: 0;
    animation: tbm-pulse 1.5s ease-in-out infinite;
}
@keyframes tbm-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(1.4); }
}
.tbm-direct-radio-label-mobile { display: none; }
@media (max-width: 600px) {
    .tbm-direct-radio-label { display: none; }
    .tbm-direct-radio-label-mobile { display: inline; }
    .tbm-direct-radio { padding: 8px 14px; font-size: 13px; }
}

/* === HEADER MOBILE COMPACT (mobile <782px) === */
/* Force logo + nav + direct sur ligne unique, padding réduit, logo plus petit */
@media (max-width: 781px) {
    /* Le wrapper header (wp-block-group flex) reste en row, pas en column */
    header > .wp-block-group > .wp-block-group {
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 8px !important;
        padding: 12px 16px !important;
    }
    /* Logo en mobile : un peu plus grand pour bien lire TBM06 */
    header .wp-block-site-logo,
    header .custom-logo-link,
    header .custom-logo {
        width: 190px !important;
        max-width: 190px !important;
        height: auto !important;
    }
    header .custom-logo {
        width: 190px !important;
        height: auto !important;
    }
    /* Conteneur droite : nav + direct, prend l'espace restant */
    header > .wp-block-group > .wp-block-group > .wp-block-group:last-child {
        flex: 1 !important;
        justify-content: flex-end !important;
        gap: 6px !important;
    }
    /* Direct radio plus compact */
    .tbm-direct-radio {
        padding: 6px 12px !important;
        font-size: 12px !important;
    }
    .tbm-direct-radio .tbm-pulse {
        width: 6px !important;
        height: 6px !important;
    }
    /* Bouton hamburger nav */
    .tbm-nav-pills .wp-block-navigation__responsive-container-open {
        padding: 6px !important;
        background: rgba(255, 255, 255, 0.1) !important;
    }
    /* Ticker fil-infos plus discret en mobile */
    .tbm-ticker-label {
        font-size: 12px !important;
        padding: 8px 12px !important;
        letter-spacing: 0.04em !important;
    }
    .tbm-ticker-track {
        font-size: 12px !important;
        animation-duration: 14s !important;
    }
}

/* === SECTIONS HOME MOBILE · paddings réduits === */
@media (max-width: 600px) {
    /* Toutes les sections .has-cream-background-color avec padding 56px → réduire à 32px */
    .has-cream-background-color,
    .has-navy-deep-background-color {
        padding-top: 32px !important;
        padding-bottom: 32px !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
    /* Cards colorées internes : padding plus serré */
    .has-rose-background-color,
    .has-cyan-background-color,
    .has-navy-background-color {
        /* Garde leur padding interne mais réduit légèrement */
    }
    /* Hero TITLE mobile : réduire margin-top */
    .has-navy-deep-background-color h1 {
        margin-top: 0 !important;
    }
    /* Cards 4:3 grid : passe à 1 colonne forcé en mobile */
    .wp-block-post-template.is-layout-grid {
        grid-template-columns: 1fr !important;
    }
    /* Mini-cards latérales hero : restent en row (image + texte) mais image plus petite */
    .wp-block-post-template:not(.is-layout-grid) .wp-block-post-featured-image {
        max-width: 120px !important;
    }
}

/* === RADIO LIVE PILL (small pill avec point pulsant) === */
.tbm-radio-live-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--wp--preset--color--rose, #E83A6E);
    color: white !important;
    padding: 6px 14px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 800;
    font-size: 13px;
    line-height: 1;
}
.tbm-radio-live-pill .tbm-pulse {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: white;
    flex-shrink: 0;
    animation: tbm-pulse 1.5s ease-in-out infinite;
}

/* === NEWSLETTER FORM === */
.tbm-newsletter-form {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.tbm-newsletter-input {
    flex: 1;
    min-width: 240px;
    padding: 14px 20px;
    border-radius: 999px;
    border: none;
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-style: italic;
    font-weight: 600;
    font-size: 16px;
}
.tbm-newsletter-input::placeholder {
    color: rgba(31, 61, 82, 0.5);
}
.tbm-newsletter-btn {
    background: var(--wp--preset--color--moutarde, #F4C32D);
    color: var(--wp--preset--color--navy, #1F3D52);
    border: none;
    padding: 14px 28px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 900;
    font-size: 16px;
    cursor: pointer;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    white-space: nowrap;
}
.tbm-newsletter-btn:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(3px);
}
.tbm-newsletter-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.tbm-nl-status {
    width: 100%;
    margin: 12px 0 0;
    font-style: italic;
    font-weight: 700;
    font-size: 14px;
    color: var(--wp--preset--color--cream, #FEF7E7);
    min-height: 20px;
}

/* === ZODIAC GRID (12 signes Horoscope socca) === */
.tbm-zodiac-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 6px;
    margin-top: 4px;
}
.tbm-zodiac {
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
    text-decoration: none !important;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    font-size: 22px;
    transition: all 0.15s ease;
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0.5);
}
.tbm-zodiac:hover {
    transform: translateY(-3px) scale(1.05);
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
    box-shadow: 0 5px 0 rgba(20, 17, 15, 0.5);
}

/* === IMAGES CARDS GRID · hauteur uniforme via aspect-ratio 16:9 === */
/* S'applique à TOUTES les cards en grid (Agenda, L'info de la côte, Villes…) */
.has-cream-background-color .wp-block-post-template.is-layout-grid .wp-block-post-featured-image,
.has-cream-background-color .wp-block-post-template.is-layout-grid .wp-block-post-featured-image a,
.has-cream-background-color .wp-block-post-template.is-layout-grid .wp-block-post-featured-image img {
    aspect-ratio: 16 / 9 !important;
    width: 100% !important;
    height: auto !important;
}
.has-cream-background-color .wp-block-post-template.is-layout-grid .wp-block-post-featured-image img {
    object-fit: cover !important;
    object-position: center !important;
    display: block;
}

/* === CARDS UNIFORMES (UNIQUEMENT cards 4:3 grid, pas mini cards latérales) === */
/* Cible uniquement le post-template avec is-layout-grid (cards 4:3 colonnées 3)
   et NON les mini cards latérales du hero (qui sont en flex row image+texte) */
.has-cream-background-color .wp-block-post-template.is-layout-grid {
    align-items: stretch !important;
}
.has-cream-background-color .wp-block-post-template.is-layout-grid > .wp-block-post {
    display: flex !important;
    flex-direction: column !important;
    height: 100%;
}
.has-cream-background-color .wp-block-post-template.is-layout-grid > .wp-block-post > .wp-block-group {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}
.has-cream-background-color .wp-block-post-template.is-layout-grid > .wp-block-post .wp-block-post-featured-image {
    flex-shrink: 0;
}
.has-cream-background-color .wp-block-post-template.is-layout-grid > .wp-block-post > .wp-block-group > .wp-block-group {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
}

/* === HERO BIG CARD : titre overlay en bas (justify-content end) === */
.tbm-hero-big {
    position: relative;
}
.tbm-hero-big .wp-block-cover__inner-container {
    height: 100%;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    gap: 16px;
}

/* Mobile : aspect-ratio 4/5 (portrait), pill BONS PLANS en haut, titre en bas */
@media (max-width: 781px) {
    .tbm-hero-big {
        aspect-ratio: 4 / 5 !important;
        min-height: 0 !important;
        height: auto !important;
    }
    .tbm-hero-big .wp-block-cover__inner-container {
        height: 100% !important;
        justify-content: space-between !important;
        padding: 20px 24px 24px !important;
    }
    /* La pill catégorie reste alignée à gauche en haut */
    .tbm-hero-big .wp-block-tbm06-post-main-category {
        align-self: flex-start !important;
    }
    /* Léger gradient sombre en bas pour mieux lire le titre sans assombrir toute la photo */
    .tbm-hero-big::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        height: 50%;
        background: linear-gradient(to top, rgba(20, 17, 15, 0.65) 0%, rgba(20, 17, 15, 0.3) 50%, rgba(20, 17, 15, 0) 100%);
        pointer-events: none;
        border-radius: 0 0 24px 24px;
        z-index: 1;
    }
    .tbm-hero-big .wp-block-cover__inner-container {
        position: relative;
        z-index: 2;
    }
    /* Réduit l'overlay navy global pour mieux voir la photo */
    .tbm-hero-big > .wp-block-cover__background.has-background-dim {
        opacity: 0.25 !important;
    }
}
.tbm-hero-big .wp-block-tbm06-post-main-category {
    align-self: flex-start;
}

/* === HERO ÉDITORIAL : badge catégorie compact pill (post-terms) === */
.tbm-hero-big .wp-block-post-terms {
    display: inline-block !important;
    width: fit-content !important;
}
.has-cream-background-color .wp-block-post-terms.has-background {
    width: fit-content !important;
    display: inline-block !important;
}

/* === HERO ÉDITORIAL : équilibrer hauteur big card vs 3 mini cards === */
@media (min-width: 782px) {
    /* Force la grande card sticky à matcher la hauteur de la colonne droite */
    .tbm-hero-big {
        min-height: 0 !important;
        aspect-ratio: auto !important;
        height: 100% !important;
    }
    /* La column droite se comporte en flex pour distribuer ses 3 cards verticalement */
    .has-cream-background-color > .wp-block-columns > .wp-block-column:nth-child(2),
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child {
        display: flex;
        flex-direction: column;
    }
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child .wp-block-query {
        flex: 1;
        display: flex;
        flex-direction: column;
    }
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child .wp-block-query > .wp-block-post-template,
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child .wp-block-query > div {
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        gap: 16px;
    }
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child .wp-block-post {
        flex: 1;
    }
    /* Big card : aspect-ratio fixé pour matcher la stack des 3 mini cards (~488px haut sur ~820px large = 5/3) */
    .wp-block-columns > .wp-block-column:first-child .tbm-hero-big {
        min-height: 0 !important;
        height: auto !important;
        aspect-ratio: 5 / 3 !important;
    }
    /* Mini cards distribuées en flex avec gap entre elles (gérées via wp:post-template gap) */
    .has-cream-background-color > .wp-block-columns > .wp-block-column:last-child > .wp-block-query {
        height: 100%;
    }
}

/* === SVG WAVE NAVY -> CREAM === */
.tbm-wave-navy-cream {
    line-height: 0;
    margin-top: -1px;
}
.tbm-wave-navy-cream svg {
    display: block;
    width: 100%;
    height: 80px;
}
@media (max-width: 781px) {
    .tbm-wave-navy-cream svg { height: 50px; }
}

/* === MOUTARDE ACCENT (inspiration leprogrammepourlafrance.fr) === */
/* Mots-clés en gras dans le contenu : moutarde au lieu de noir */
.entry-content strong,
.wp-block-post-content strong,
main strong {
    color: var(--wp--preset--color--moutarde, #F4C32D);
}

/* Chiffres-clés mis en valeur : moutarde + Fraunces black italic */
.tbm-figure {
    color: var(--wp--preset--color--moutarde, #F4C32D);
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 2.4em;
    line-height: 1;
    letter-spacing: -0.02em;
}

/* Citations en gras dans articles infos (TBM06 règle CLAUDE.md) : restent navy ET le strong à l'intérieur reste navy aussi */
.entry-content blockquote strong,
.tbm-quote strong {
    color: inherit;
}

/* === COLONNES UNIFORMES (Radio+Horoscope, Newsletter+Cafteurs) === */
/* Force les colonnes alignées en hauteur sur les sections cream à 2 colonnes */
@media (min-width: 782px) {
    /* Toutes les wp-block-columns avec verticalAlignment stretch (Radio+Horoscope, Newsletter+Cafteurs) */
    .has-cream-background-color > .wp-block-columns {
        align-items: stretch !important;
    }
    .has-cream-background-color > .wp-block-columns > .wp-block-column.is-vertically-aligned-stretch {
        display: flex !important;
        flex-direction: column !important;
    }
    /* Le wp-block-group inner (card colorée rose/cyan/navy/moutarde) doit prendre toute la hauteur */
    .has-cream-background-color > .wp-block-columns > .wp-block-column.is-vertically-aligned-stretch > .wp-block-group:not(.wp-block-query) {
        flex: 1 !important;
        height: 100% !important;
    }
}

/* === SIGNATURE PRESSE EYEBROW : "📍 Notre motiv' ? C'est vous !" plus gros === */
.tbm-signature-eyebrow {
    font-size: clamp(20px, 2.5vw, 28px) !important;
    font-weight: 800 !important;
    font-style: italic !important;
    letter-spacing: 0.02em !important;
    color: var(--wp--preset--color--moutarde, #F4C32D) !important;
    margin-bottom: 12px !important;
    display: block;
}

/* === CAFTEURS : card flex column, contenu serré, bouton dans le cadre === */
.has-cream-background-color > .wp-block-columns > .wp-block-column.is-vertically-aligned-stretch > .wp-block-group.has-cyan-background-color {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    padding: 32px 32px 40px !important;
}
.tbm-cafteurs-logo {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    display: block;
    margin: 0 auto 24px !important;
}
.has-cyan-background-color .tbm-whatsapp-btn {
    margin-top: 8px;
    margin-bottom: 0;
}
.tbm-whatsapp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 14px 24px;
    border-radius: 999px;
    background: #25D366;
    color: white !important;
    font-style: italic;
    font-weight: 900;
    font-size: 18px;
    text-decoration: none !important;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    line-height: 1;
}
.tbm-whatsapp-btn:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(3px);
    color: white !important;
}
.tbm-whatsapp-btn svg {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    fill: currentColor;
}

/* === BOUTON CAFTEURS sur la home (ouvre /cafteurs/) === */
.tbm-cafteurs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 14px 24px;
    border-radius: 999px;
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
    font-style: italic;
    font-weight: 900;
    font-size: 18px;
    text-decoration: none !important;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    line-height: 1;
}
.tbm-cafteurs-btn:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(3px);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
}
.tbm-cafteurs-btn-icon {
    font-size: 22px;
    line-height: 1;
}

/* === RADIO PLAYER CUSTOM (RadioKing TBM06) === */
.tbm-radio-player {
    display: flex;
    align-items: center;
    gap: 16px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    padding: 14px 16px;
    margin-top: 8px;
    transition: background 0.2s ease;
}
.tbm-radio-player.is-playing {
    background: rgba(244, 195, 45, 0.15);
    border-color: rgba(244, 195, 45, 0.35);
}
.tbm-radio-cover {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border-radius: 12px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.tbm-radio-cover-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.tbm-radio-cover-fallback {
    font-size: 32px;
    opacity: 0.5;
}
.tbm-radio-info {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}
.tbm-radio-now-label {
    margin: 0 0 4px;
    font-style: italic;
    font-weight: 800;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--wp--preset--color--moutarde, #F4C32D);
    opacity: 0.9;
}
.tbm-radio-title {
    margin: 0 0 2px;
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 18px;
    line-height: 1.2;
    color: var(--wp--preset--color--cream, #FEF7E7);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.tbm-radio-artist {
    margin: 0;
    font-style: italic;
    font-size: 13px;
    color: var(--wp--preset--color--cream, #FEF7E7);
    opacity: 0.7;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.tbm-radio-playbtn {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--wp--preset--color--moutarde, #F4C32D);
    color: var(--wp--preset--color--navy, #1F3D52);
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}
.tbm-radio-playbtn:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(2px);
}
.tbm-radio-playbtn-icon {
    font-size: 22px;
    line-height: 1;
    margin-left: 2px;
}
.tbm-radio-player.is-playing .tbm-radio-playbtn-icon {
    margin-left: 0;
}
@media (max-width: 480px) {
    .tbm-radio-player { padding: 12px; gap: 12px; }
    .tbm-radio-cover { width: 60px; height: 60px; }
    .tbm-radio-title { font-size: 16px; }
    .tbm-radio-playbtn { width: 48px; height: 48px; }
    .tbm-radio-playbtn-icon { font-size: 18px; }
}

/* === CAPSULE AUDIO PLAYER === */
.tbm-capsule-player {
    background: rgba(0, 0, 0, 0.25);
    padding: 14px 16px;
    border-radius: 14px;
    margin-top: 16px;
    backdrop-filter: blur(2px);
}
.tbm-capsule-player audio {
    filter: invert(0.9) hue-rotate(180deg);
    border-radius: 999px;
}

/* === METEO CARD === */
.tbm-meteo-card-link {
    display: block;
    background: white;
    border-radius: 16px;
    box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7);
    overflow: hidden;
    transition: all 0.15s ease;
    text-decoration: none !important;
    color: inherit !important;
    height: 100%;
}
.tbm-meteo-card-link:hover {
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0.7);
    transform: translateY(3px);
}

/* === PILULE PAR CATARINÀ : centrée sous le titre === */
.tbm-catarina-byline {
    display: inline-block;
    width: fit-content;
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7);
    padding: 6px 14px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 800;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 8px 0 14px;
    text-decoration: none !important;
}

/* === FRANCHISE OFFERTE · formulaire === */
.tbm-franchise-form {
    max-width: 640px;
    margin: 0 auto;
    background: var(--wp--preset--color--cream, #FEF7E7);
    border-radius: 20px;
    box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85);
    padding: 32px 28px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-franchise-form .tbm-ff-row {
    margin-bottom: 18px;
}
.tbm-franchise-form .tbm-ff-row-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.tbm-franchise-form .tbm-ff-row-split-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1.4fr;
    gap: 12px;
}
@media (max-width: 720px) {
    .tbm-franchise-form .tbm-ff-row-split-3 {
        grid-template-columns: 1fr 1fr;
    }
    .tbm-franchise-form .tbm-ff-row-split-3 .tbm-ff-col:last-child {
        grid-column: 1 / 3;
    }
}
@media (max-width: 600px) {
    .tbm-franchise-form .tbm-ff-row-split {
        grid-template-columns: 1fr;
    }
    .tbm-franchise-form .tbm-ff-row-split-3 {
        grid-template-columns: 1fr;
    }
    .tbm-franchise-form .tbm-ff-row-split-3 .tbm-ff-col:last-child {
        grid-column: 1;
    }
}
.tbm-franchise-form .tbm-ff-section-label {
    margin: 24px 0 8px;
    font-style: italic;
    font-size: 13px;
    font-weight: 700;
    color: var(--wp--preset--color--navy, #1F3D52);
    opacity: 0.65;
    line-height: 1.4;
}
.tbm-franchise-form .tbm-ff-col {
    min-width: 0;
}
.tbm-franchise-form label {
    display: block;
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    margin-bottom: 6px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-franchise-form input[type="text"],
.tbm-franchise-form input[type="email"],
.tbm-franchise-form textarea {
    width: 100%;
    padding: 12px 16px;
    border-radius: 12px;
    border: 2px solid rgba(31, 61, 82, 0.15);
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-family: inherit;
    font-size: 16px;
    font-style: italic;
    line-height: 1.4;
    box-sizing: border-box;
    transition: border-color 0.15s ease;
}
.tbm-franchise-form input:focus,
.tbm-franchise-form textarea:focus {
    outline: none;
    border-color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-franchise-form textarea {
    resize: vertical;
    min-height: 100px;
}
.tbm-ff-audio-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}
.tbm-ff-btn-record,
.tbm-ff-btn-stop {
    background: var(--wp--preset--color--rose, #E83A6E);
    color: white;
    border: none;
    padding: 10px 18px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    cursor: pointer;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
}
.tbm-ff-btn-stop {
    background: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-ff-btn-record:disabled,
.tbm-ff-btn-stop:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
}
.tbm-ff-btn-record:not(:disabled):hover,
.tbm-ff-btn-stop:not(:disabled):hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(2px);
}
.tbm-ff-or {
    font-style: italic;
    font-size: 13px;
    opacity: 0.6;
}
.tbm-ff-audio-file {
    flex: 1;
    min-width: 200px;
    font-size: 13px;
}
.tbm-ff-image-file {
    width: 100%;
    font-size: 13px;
    padding: 8px;
    border-radius: 12px;
    border: 2px dashed rgba(31, 61, 82, 0.25);
    background: rgba(255, 255, 255, 0.5);
    box-sizing: border-box;
    cursor: pointer;
}
.tbm-ff-image-file:hover {
    border-color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-ff-actions {
    text-align: center;
    margin-top: 24px;
}
.tbm-ff-submit {
    background: var(--wp--preset--color--moutarde, #F4C32D);
    color: var(--wp--preset--color--navy, #1F3D52);
    border: none;
    padding: 16px 36px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 900;
    font-size: 18px;
    cursor: pointer;
    box-shadow: 0 6px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
}
.tbm-ff-submit:hover {
    box-shadow: 0 3px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(3px);
}
.tbm-ff-status {
    margin: 16px 0 0;
    text-align: center;
    font-style: italic;
    font-weight: 700;
    min-height: 24px;
}

/* === SELECT COMMUNE sur /category/meteo/ === */
.tbm-meteo-select-form {
    display: flex;
    gap: 12px;
    align-items: center;
    margin: 16px 0 24px;
    flex-wrap: wrap;
    background: var(--wp--preset--color--cyan, #4EAAA8);
    color: var(--wp--preset--color--cream, #FEF7E7);
    padding: 16px 20px;
    border-radius: 16px;
    box-shadow: 0 4px 0 rgba(20, 17, 15, 0.7);
}
.tbm-meteo-select-form label {
    font-style: italic;
    font-weight: 800;
    font-size: 15px;
    color: var(--wp--preset--color--cream, #FEF7E7);
    flex-shrink: 0;
}
.tbm-meteo-select-form select {
    flex: 1;
    min-width: 240px;
    padding: 10px 16px;
    border-radius: 12px;
    border: 2px solid white;
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-family: inherit;
    font-style: italic;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 14 10'><path fill='%231F3D52' d='M7 10L0 0h14z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 44px;
}
.tbm-meteo-select-form select:focus {
    outline: 3px solid var(--wp--preset--color--moutarde, #F4C32D);
}
.tbm-meteo-select-form .tbm-reset-link {
    color: var(--wp--preset--color--moutarde, #F4C32D);
    font-style: italic;
    font-weight: 800;
    text-decoration: underline;
    font-size: 14px;
}
@media (max-width: 600px) {
    .tbm-meteo-select-form {
        flex-direction: column;
        align-items: stretch;
    }
    .tbm-meteo-select-form select { width: 100%; }
}

/* === ENCART VOTE FIN D'ARTICLE === */
.tbm-vote-widget {
    background: linear-gradient(135deg, #FFF5F8 0%, #FEEEF3 100%);
    border-left: 6px solid var(--wp--preset--color--rose, #E83A6E);
    border-radius: 16px;
    padding: 24px 28px;
    margin: 48px 0 32px;
    box-shadow: 0 4px 0 rgba(20, 17, 15, 0.1);
}
.tbm-vote-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 8px;
}
.tbm-vote-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-style: italic;
    font-weight: 800;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-size: 16px;
}
.tbm-vote-icon {
    color: var(--wp--preset--color--rose, #E83A6E);
    font-size: 20px;
}
.tbm-vote-count {
    font-style: italic;
    font-size: 13px;
    opacity: 0.7;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-vote-count-n {
    font-weight: 800;
    color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-vote-buttons {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.tbm-vote-question {
    font-style: italic;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-size: 15px;
}
.tbm-vote-pills {
    display: flex;
    gap: 12px;
}
.tbm-vote-btn {
    border: 2px solid var(--wp--preset--color--rose, #E83A6E);
    background: white;
    color: var(--wp--preset--color--rose, #E83A6E);
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.15s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 3px 0 rgba(232, 58, 110, 0.4);
    /* Desktop : rond compact (lettre seule), mobile : pill avec lettre + libellé */
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 20px;
    padding: 0;
    gap: 8px;
}
.tbm-vote-letter { display: inline; }
.tbm-vote-text { display: none; }
.tbm-vote-btn:hover:not(:disabled) {
    background: var(--wp--preset--color--rose, #E83A6E);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 5px 0 rgba(232, 58, 110, 0.4);
}
.tbm-vote-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Résultats */
.tbm-vote-results {
    margin-top: 8px;
}
.tbm-vote-thanks {
    margin: 0 0 12px;
    font-style: italic;
    font-weight: 800;
    color: var(--wp--preset--color--rose, #E83A6E);
    font-size: 15px;
}
.tbm-vote-bars {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.tbm-vote-bar {
    display: grid;
    grid-template-columns: 130px 1fr 90px;
    gap: 12px;
    align-items: center;
}
.tbm-vote-bar-label {
    font-style: italic;
    font-weight: 700;
    font-size: 14px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-vote-bar-track {
    background: rgba(232, 58, 110, 0.15);
    border-radius: 999px;
    height: 14px;
    overflow: hidden;
}
.tbm-vote-bar-fill {
    height: 100%;
    border-radius: 999px;
    transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.tbm-vote-bar-t .tbm-vote-bar-fill { background: linear-gradient(90deg, #4EAAA8, #5BB6B4); }
.tbm-vote-bar-b .tbm-vote-bar-fill { background: linear-gradient(90deg, #F4C32D, #FFD24A); }
.tbm-vote-bar-m .tbm-vote-bar-fill { background: linear-gradient(90deg, #E83A6E, #ff5288); }
.tbm-vote-bar-pct {
    font-style: italic;
    font-size: 13px;
    color: var(--wp--preset--color--navy, #1F3D52);
    text-align: right;
}

/* Erreur */
.tbm-vote-erreur {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px dashed rgba(232, 58, 110, 0.25);
    text-align: right;
}
.tbm-vote-erreur-toggle {
    background: none;
    border: none;
    color: var(--wp--preset--color--rose, #E83A6E);
    font-style: italic;
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    cursor: pointer;
    padding: 4px 8px;
}
.tbm-vote-erreur-toggle:hover { text-decoration: underline; }
.tbm-vote-erreur-form {
    margin-top: 12px;
    text-align: left;
}
.tbm-vote-erreur-form textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 2px solid rgba(232, 58, 110, 0.25);
    background: white;
    font-family: inherit;
    font-style: italic;
    font-size: 14px;
    color: var(--wp--preset--color--navy, #1F3D52);
    box-sizing: border-box;
    resize: vertical;
    min-height: 80px;
}
.tbm-vote-erreur-form textarea:focus {
    outline: none;
    border-color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-vote-erreur-form button {
    margin-top: 8px;
    background: var(--wp--preset--color--rose, #E83A6E);
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    cursor: pointer;
    box-shadow: 0 3px 0 rgba(0, 0, 0, 0.7);
    transition: all 0.15s ease;
}
.tbm-vote-erreur-form button:hover {
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.7);
    transform: translateY(2px);
}
.tbm-vote-erreur-status {
    margin: 8px 0 0;
    font-style: italic;
    font-size: 13px;
    font-weight: 700;
}

@media (max-width: 600px) {
    .tbm-vote-widget { padding: 18px 20px; margin: 32px 0 24px; }
    .tbm-vote-buttons { flex-direction: column; align-items: stretch; }
    .tbm-vote-pills {
        justify-content: stretch;
        flex-direction: column;
        gap: 10px;
    }
    /* Sur mobile : pills longues avec lettre + libellé */
    .tbm-vote-btn {
        width: 100% !important;
        height: auto !important;
        border-radius: 999px !important;
        font-size: 16px !important;
        padding: 12px 20px !important;
        justify-content: flex-start !important;
    }
    .tbm-vote-letter {
        display: inline-flex !important;
        width: 32px;
        height: 32px;
        border-radius: 50%;
        background: var(--wp--preset--color--rose, #E83A6E);
        color: white;
        align-items: center;
        justify-content: center;
        font-size: 18px;
        flex-shrink: 0;
    }
    .tbm-vote-btn:hover .tbm-vote-letter {
        background: white;
        color: var(--wp--preset--color--rose, #E83A6E);
    }
    .tbm-vote-text {
        display: inline !important;
        font-size: 15px;
        font-weight: 700;
    }
    .tbm-vote-bar { grid-template-columns: 110px 1fr 70px; gap: 8px; }
}

/* === PAGE /villes/ · grille des communes du 06 === */
.tbm-villes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 20px;
    max-width: 1280px;
    margin: 0 auto;
}
.tbm-ville-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: white;
    padding: 24px 20px;
    border-radius: 16px;
    text-decoration: none !important;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
    box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7);
    transition: all 0.15s ease;
    text-align: center;
}
.tbm-ville-card:hover {
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0.7);
    transform: translateY(3px);
    background: var(--wp--preset--color--moutarde, #F4C32D);
}
.tbm-ville-emoji {
    font-size: 40px;
    line-height: 1;
    margin-bottom: 8px;
}
.tbm-ville-nom {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 22px;
    letter-spacing: -0.01em;
    margin: 4px 0;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-ville-meta {
    margin: 0;
    font-style: italic;
    font-size: 13px;
    opacity: 0.7;
}
.tbm-ville-tag {
    margin: 4px 0 12px;
    font-style: italic;
    font-size: 12px;
    color: var(--wp--preset--color--rose, #E83A6E);
    font-weight: 700;
}
.tbm-ville-cta {
    display: inline-block;
    font-style: italic;
    font-weight: 800;
    font-size: 13px;
    color: var(--wp--preset--color--navy, #1F3D52);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: auto;
}

/* === ARCHIVE TOOLS · search + pills sous-catégories + filtre date === */
.tbm-archive-tools {
    margin: 24px 0 16px;
}
.tbm-archive-search {
    display: flex;
    gap: 8px;
    max-width: 560px;
}
.tbm-archive-search input[type="search"] {
    flex: 1;
    padding: 12px 18px;
    border-radius: 999px;
    border: 2px solid rgba(31, 61, 82, 0.15);
    background: white;
    font-style: italic;
    font-size: 15px;
    color: var(--wp--preset--color--navy, #1F3D52);
    transition: border-color 0.15s ease;
}
.tbm-archive-search input[type="search"]:focus {
    outline: none;
    border-color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-archive-search button {
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7);
    border: none;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
    font-size: 20px;
    line-height: 1;
}
.tbm-archive-search button:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(2px);
}
.tbm-archive-subcats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 0;
}
.tbm-archive-subcats a {
    display: inline-block;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(31, 61, 82, 0.08);
    color: var(--wp--preset--color--navy, #1F3D52);
    font-style: italic;
    font-weight: 700;
    font-size: 13px;
    text-decoration: none;
    transition: all 0.15s ease;
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0);
}
.tbm-archive-subcats a:hover,
.tbm-archive-subcats a.active {
    background: var(--wp--preset--color--moutarde, #F4C32D);
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0.7);
    color: var(--wp--preset--color--navy, #1F3D52);
    transform: translateY(-2px);
}

/* Filtre date Agenda */
.tbm-agenda-date-filter {
    display: flex;
    gap: 12px;
    align-items: center;
    margin: 16px 0 24px;
    flex-wrap: wrap;
}
.tbm-agenda-date-filter label {
    font-style: italic;
    font-weight: 700;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-agenda-date-filter input[type="date"] {
    padding: 10px 14px;
    border-radius: 12px;
    border: 2px solid rgba(31, 61, 82, 0.15);
    background: white;
    font-style: italic;
    font-size: 14px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-agenda-date-filter button {
    background: var(--wp--preset--color--moutarde, #F4C32D);
    color: var(--wp--preset--color--navy, #1F3D52);
    border: none;
    padding: 10px 20px;
    border-radius: 999px;
    cursor: pointer;
    font-style: italic;
    font-weight: 800;
    box-shadow: 0 3px 0 rgba(0, 0, 0, 0.85);
    transition: all 0.15s ease;
}
.tbm-agenda-date-filter button:hover {
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.85);
    transform: translateY(2px);
}
.tbm-agenda-date-filter .tbm-reset-link {
    margin-left: auto;
    font-size: 13px;
    color: var(--wp--preset--color--rose, #E83A6E);
    font-style: italic;
}

/* === RAPPELS CONSO (page /alerte-conso/) · grid de cards rappels === */
.tbm-rappels-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
    max-width: 1280px;
    margin: 0 auto;
}
.tbm-rappel-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none !important;
    color: var(--wp--preset--color--navy, #1F3D52) !important;
    box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7);
    transition: all 0.15s ease;
    display: flex;
    flex-direction: column;
}
.tbm-rappel-card:hover {
    box-shadow: 0 3px 0 rgba(20, 17, 15, 0.7);
    transform: translateY(3px);
    color: var(--wp--preset--color--navy, #1F3D52) !important;
}
.tbm-rappel-img {
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f5f3ee;
    display: flex;
    align-items: center;
    justify-content: center;
}
.tbm-rappel-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.tbm-rappel-img-empty {
    background: linear-gradient(135deg, #FBEED1 0%, #f5e3ad 100%);
}
.tbm-rappel-img-empty span {
    font-size: 64px;
    opacity: 0.7;
}
.tbm-rappel-body {
    padding: 16px 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
}
.tbm-rappel-cat {
    font-style: italic;
    font-weight: 800;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--wp--preset--color--rose, #E83A6E);
}
.tbm-rappel-title {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 18px;
    letter-spacing: -0.01em;
    line-height: 1.2;
    color: var(--wp--preset--color--navy, #1F3D52);
    margin: 4px 0 4px;
}
.tbm-rappel-marque,
.tbm-rappel-risque,
.tbm-rappel-motif {
    margin: 0;
    font-style: italic;
    font-size: 13px;
    line-height: 1.35;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-rappel-risque {
    color: var(--wp--preset--color--rose, #E83A6E);
    font-weight: 700;
}
.tbm-rappel-motif {
    opacity: 0.7;
}
.tbm-rappel-meta {
    margin: 8px 0 0;
    font-style: italic;
    font-size: 12px;
    opacity: 0.6;
}
.tbm-rappel-cta {
    display: inline-block;
    margin-top: 12px;
    font-style: italic;
    font-weight: 800;
    font-size: 13px;
    color: var(--wp--preset--color--rose, #E83A6E);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.tbm-rappels-source {
    text-align: center;
    margin: 32px 0 0;
    font-style: italic;
    font-size: 13px;
    opacity: 0.7;
}
.tbm-rappels-source a {
    color: inherit;
    text-decoration: underline;
}

/* === CAFTEURS form (réutilise les styles franchise + checkbox anonymat) === */
.tbm-cafteurs-form {
    max-width: 640px;
    margin: 0 auto;
    background: var(--wp--preset--color--cream, #FEF7E7);
    border-radius: 20px;
    box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85);
    padding: 32px 28px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-cafteurs-form .tbm-ff-row { margin-bottom: 18px; }
.tbm-cafteurs-form label:not(.tbm-cf-anonyme-label) {
    display: block;
    font-style: italic;
    font-weight: 800;
    font-size: 14px;
    margin-bottom: 6px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-cafteurs-form input[type="text"],
.tbm-cafteurs-form input[type="email"],
.tbm-cafteurs-form textarea {
    width: 100%;
    padding: 12px 16px;
    border-radius: 12px;
    border: 2px solid rgba(31, 61, 82, 0.15);
    background: white;
    color: var(--wp--preset--color--navy, #1F3D52);
    font-family: inherit;
    font-size: 16px;
    font-style: italic;
    line-height: 1.4;
    box-sizing: border-box;
    transition: border-color 0.15s ease;
}
.tbm-cafteurs-form input:focus,
.tbm-cafteurs-form textarea:focus {
    outline: none;
    border-color: var(--wp--preset--color--cyan, #4EAAA8);
}
.tbm-cafteurs-form textarea {
    resize: vertical;
    min-height: 120px;
}
.tbm-cf-anonyme-label {
    display: flex !important;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 18px;
    background: var(--wp--preset--color--cyan, #4EAAA8);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
    border-radius: 12px;
    cursor: pointer;
    font-style: italic;
    font-weight: 600;
    font-size: 14px;
    line-height: 1.4;
    transition: background 0.15s ease;
}
.tbm-cf-anonyme-label:hover { background: #5BB6B4; }
.tbm-cf-anonyme-label input[type="checkbox"] {
    width: 22px;
    height: 22px;
    margin: 0;
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--wp--preset--color--moutarde, #F4C32D);
}
.tbm-cf-anonyme-label strong {
    color: var(--wp--preset--color--moutarde, #F4C32D);
}

/* === FRANCHISE OFFERTE · liste des questions répondues === */
.tbm-franchise-liste {
    display: grid;
    gap: 24px;
    max-width: 720px;
    margin: 32px auto 0;
}
.tbm-franchise-item {
    background: white;
    border-radius: 16px;
    padding: 24px 28px;
    box-shadow: 0 6px 0 rgba(20, 17, 15, 0.7);
}

/* === MAINTENANT À NICE (bandeau live navy + 5 mini-cards colorées) === */
.tbm-now-wrap {
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7);
    border-radius: 24px;
    padding: 28px 24px;
    box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85);
    max-width: 1280px;
    margin: 0 auto;
}
.tbm-now-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.tbm-now-header-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.tbm-now-eyebrow-main {
    font-style: italic;
    color: var(--wp--preset--color--moutarde, #F4C32D);
    font-size: 14px;
    font-weight: 700;
}
.tbm-now-title {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: clamp(24px, 4vw, 36px);
    letter-spacing: -0.02em;
    line-height: 1;
    color: var(--wp--preset--color--cream, #FEF7E7);
    margin: 0;
}
.tbm-now-live-badge {
    display: inline-block;
    background: var(--wp--preset--color--moutarde, #F4C32D);
    color: var(--wp--preset--color--navy, #1F3D52);
    padding: 6px 14px;
    border-radius: 999px;
    font-style: italic;
    font-weight: 900;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    box-shadow: 0 3px 0 rgba(0, 0, 0, 0.85);
}
.tbm-now-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
}
.tbm-now-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 16px;
    text-decoration: none !important;
    color: var(--wp--preset--color--cream, #FEF7E7);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    min-height: 96px;
}
.tbm-now-card:hover {
    transform: scale(1.02) translateY(-2px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.2);
}
.tbm-now-meteo { background: var(--wp--preset--color--cyan, #4EAAA8); }
.tbm-now-lignesdazur { background: #FBEED1; color: var(--wp--preset--color--navy, #1F3D52) !important; }
.tbm-now-horoscope { background: var(--wp--preset--color--rose, #E83A6E); }
.tbm-now-cesoir { background: var(--wp--preset--color--moutarde, #F4C32D); color: var(--wp--preset--color--navy, #1F3D52) !important; }
.tbm-now-rappels { background: white; color: var(--wp--preset--color--navy, #1F3D52) !important; }
.tbm-now-rappels .tbm-now-eyebrow { color: var(--wp--preset--color--rose, #E83A6E) !important; }
.tbm-now-rappels .tbm-now-bigvalue { color: var(--wp--preset--color--rose, #E83A6E); }
.tbm-now-eyebrow {
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.95;
    line-height: 1.3;
}
.tbm-now-bigvalue {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: clamp(20px, 3vw, 32px);
    letter-spacing: -0.02em;
    line-height: 1;
    margin: 4px 0 2px;
}
.tbm-now-flexrow {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: clamp(15px, 2vw, 18px);
}
.tbm-now-symbol { font-size: 1.3em; line-height: 1; }
.tbm-now-icon { font-size: 0.9em; }
.tbm-now-pulse {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--wp--preset--color--cyan, #4EAAA8);
    flex-shrink: 0;
    animation: tbm-pulse 1.5s ease-in-out infinite;
}
.tbm-now-sub {
    font-style: italic;
    font-size: 12px;
    line-height: 1.3;
    opacity: 0.85;
    margin-top: auto;
}
.tbm-now-clamp2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* Titre "Ce soir" : titre complet (pas de troncature), font petite, card auto-grow */
.tbm-now-cesoir-title {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: clamp(13px, 1.5vw, 15px) !important;
    letter-spacing: -0.01em;
    line-height: 1.2;
    margin: 4px 0 4px;
    display: flex;
    gap: 6px;
    align-items: flex-start;
}
.tbm-now-cesoir-text {
    flex: 1;
    min-width: 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
}
/* La card "Ce soir" peut grandir verticalement pour contenir le titre entier */
.tbm-now-cesoir {
    min-height: auto;
}
.tbm-now-rappels-suffix {
    font-family: "Mulish", Arial, sans-serif;
    font-style: italic;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0;
    line-height: 1.1;
    margin-left: 6px;
    display: inline-block;
    vertical-align: middle;
}
@media (max-width: 781px) {
    .tbm-now-wrap { padding: 20px 16px; }
    .tbm-now-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .tbm-now-rappels { grid-column: 1 / 3; }
}
@media (max-width: 380px) {
    .tbm-now-grid { grid-template-columns: 1fr; }
    .tbm-now-rappels { grid-column: 1; }
}

/* === HOROSCOPE DU JOUR (page /horoscope/) · tous les 12 signes === */
.tbm-horoscope-du-jour {
    max-width: 880px;
    margin: 0 auto;
}
.tbm-horoscope-jour-header {
    text-align: center;
    background: var(--wp--preset--color--moutarde, #F4C32D);
    border-radius: 24px;
    padding: 32px 28px;
    box-shadow: 0 8px 0 rgba(20, 17, 15, 0.85);
    margin-bottom: 32px;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-horoscope-jour-eyebrow {
    margin: 0 0 8px;
    font-style: italic;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 14px;
    color: var(--wp--preset--color--navy, #1F3D52);
    opacity: 0.85;
}
.tbm-horoscope-jour-title {
    margin: 0;
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: clamp(28px, 4.5vw, 44px);
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-horoscope-jour-body {
    font-size: 17px;
    line-height: 1.6;
    color: var(--wp--preset--color--navy, #1F3D52);
}
.tbm-horoscope-jour-body h4 {
    margin: 28px 0 8px;
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-weight: 900;
    font-size: 26px;
    letter-spacing: -0.01em;
    line-height: 1.1;
    color: var(--wp--preset--color--navy, #1F3D52);
    border-top: 2px solid rgba(31, 61, 82, 0.1);
    padding-top: 24px;
}
.tbm-horoscope-jour-body h4:first-of-type {
    border-top: none;
    padding-top: 0;
}
.tbm-horoscope-jour-body h4 em {
    font-size: 14px;
    font-weight: 600;
    opacity: 0.6;
    letter-spacing: 0;
}
.tbm-horoscope-jour-body p {
    margin: 0 0 12px;
    font-style: italic;
}
.tbm-horoscope-jour-archive {
    text-align: center;
    margin: 40px 0 0;
    font-style: italic;
    font-weight: 800;
}
.tbm-horoscope-jour-archive a {
    color: var(--wp--preset--color--navy, #1F3D52);
    text-decoration: underline;
}

/* === FRANCHISE CTA dans card Horoscope (home) === */
.tbm-franchise-cta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    padding: 12px 16px;
    background: var(--wp--preset--color--navy, #1F3D52);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
    border-radius: 14px;
    text-decoration: none !important;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 0.6);
    transition: all 0.15s ease;
}
.tbm-franchise-cta:hover {
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.6);
    transform: translateY(2px);
    color: var(--wp--preset--color--cream, #FEF7E7) !important;
}
.tbm-franchise-cta-icon {
    font-size: 24px;
    flex-shrink: 0;
    line-height: 1;
}
.tbm-franchise-cta-text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}
.tbm-franchise-cta-text strong {
    font-style: italic;
    font-weight: 900;
    font-size: 15px;
    color: var(--wp--preset--color--moutarde, #F4C32D) !important;
}
.tbm-franchise-cta-text em {
    font-style: italic;
    font-size: 12px;
    opacity: 0.8;
    font-weight: 600;
}
