/* ==========================================================================
   Patrimoines-Médias — Components CSS
   Composants partagés entre tous les templates :
   Nav, Cartes article, Sidebar, Formulaire newsletter, Footer,
   Archive Bento Grid, Page Guides/Premium.
   Chargé sur toutes les pages via functions.php (pm-components).
   ========================================================================== */

/* ==========================================================================
   Navigation GP — Sticky + design éditorial
   On cible les classes GP natives et on les enrichit.
   GP génère .site-header pour le header et .main-navigation pour la nav.
   Config GP attendue : Navigation positionnée "après le header" ou "merged".
   La classe pm-sticky-header est injectée via filter generate_header_class.
   ========================================================================== */

/* Header sticky */
.site-header.pm-sticky-header,
.main-navigation {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: rgba(255, 255, 255, 0.93);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--pm-color-border);
    transition: background-color var(--pm-transition);
}

.site-header:not(.pm-sticky-header) {
    position: relative;
}

/* Conteneur interne de la nav */
.main-navigation .inside-navigation,
.main-navigation .main-nav-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--pm-container);
    margin: 0 auto;
    padding: 0 var(--pm-padding-x);
    height: var(--pm-nav-height);
    gap: var(--pm-gap);
}

/* Logo Patrimoines-Médias */
.site-logo a,
.site-title a,
.main-navigation .site-logo a {
    font-family: var(--pm-font-heading);
    font-style: italic;
    font-size: 22px;
    font-weight: 700;
    color: var(--pm-color-primary);
    letter-spacing: -0.02em;
    text-decoration: none;
    white-space: nowrap;
}

.site-logo a:hover,
.site-title a:hover {
    color: var(--pm-color-primary);
    opacity: 0.85;
}

/* Menu principal GP */
.main-navigation .menu,
.main-navigation .nav-menu,
.main-navigation ul {
    display: flex;
    align-items: center;
    gap: 32px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.main-navigation .menu-item > a {
    font-family: var(--pm-font-heading);
    font-size: 14px;
    letter-spacing: 0.05em;
    color: var(--pm-color-text-muted);
    text-decoration: none;
    padding-bottom: 4px;
    border-bottom: 2px solid transparent;
    transition: color var(--pm-transition), border-color var(--pm-transition);
}

.main-navigation .menu-item > a:hover {
    color: var(--pm-color-secondary);
}

.main-navigation .current-menu-item > a,
.main-navigation .current-menu-ancestor > a {
    color: var(--pm-color-primary);
    border-bottom-color: var(--pm-color-primary);
}

/* Sous-menus GP */
.main-navigation .sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background-color: var(--pm-color-surface);
    border: 1px solid var(--pm-color-border);
    border-top: 3px solid var(--pm-color-primary);
    box-shadow: var(--pm-shadow-card);
    z-index: 200;
    flex-direction: column;
    gap: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity var(--pm-transition), transform var(--pm-transition), visibility var(--pm-transition);
}

.main-navigation .menu-item:hover > .sub-menu,
.main-navigation .menu-item:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.main-navigation .sub-menu .menu-item > a {
    display: block;
    padding: 12px 20px;
    font-size: 14px;
    border-bottom: 1px solid var(--pm-color-surface-alt);
    border-left: none;
}

/* Actions nav : recherche + S'abonner (via hooks.php) */
.pm-nav__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-shrink: 0;
}

.pm-nav__search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--pm-color-text-muted);
    padding: 4px;
    transition: color var(--pm-transition);
}

.pm-nav__search-btn:hover { color: var(--pm-color-primary); }

.pm-nav__subscribe-btn,
a.pm-nav__subscribe-btn,
.main-navigation .pm-nav__subscribe-btn {
    display: inline-flex;
    align-items: center;
    background-color: var(--pm-color-primary);
    color: var(--pm-color-secondary-light) !important; /* ambre clair = couleur hover */
    padding: 10px 24px;
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background-color var(--pm-transition), color var(--pm-transition);
    white-space: nowrap;
}

.pm-nav__subscribe-btn:hover,
a.pm-nav__subscribe-btn:hover,
.main-navigation .pm-nav__subscribe-btn:hover {
    background-color: var(--pm-color-secondary);
    color: var(--pm-color-secondary-light) !important;
}

.menu-toggle {
    background: none;
    border: 1px solid var(--pm-color-border);
    color: var(--pm-color-primary);
    padding: 8px 12px;
    cursor: pointer;
    font-family: var(--pm-font-body);
    font-size: 13px;
}

@media (max-width: 768px) {
    .pm-nav__subscribe-btn { padding: 8px 16px; font-size: 11px; }

    .main-navigation .menu,
    .main-navigation .nav-menu {
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
        width: 100%;
    }

    .main-navigation .menu-item > a {
        display: block;
        padding: 12px 0;
        border-bottom: 1px solid var(--pm-color-surface-alt);
        width: 100%;
    }
}

/* ==========================================================================
   Carte article — pm-card
   ========================================================================== */

.pm-card {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--pm-color-border);
    background-color: var(--pm-color-surface);
    transition: box-shadow var(--pm-transition);
    cursor: pointer;
}

.pm-card:hover { box-shadow: var(--pm-shadow-card); }

.pm-card__image-wrap {
    overflow: hidden;
    aspect-ratio: 1 / 1;
}

.pm-card__image-wrap--wide { aspect-ratio: 16 / 9; }

.pm-card__image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    display: block;
}

.pm-card:hover .pm-card__image-wrap img { transform: scale(1.05); }

.pm-card__body {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 12px;
}

.pm-card__category {
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pm-color-secondary);
    text-decoration: none;
}

.pm-card__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    line-height: 1.4;
    color: var(--pm-color-primary);
    margin: 0;
    transition: color var(--pm-transition);
}

.pm-card:hover .pm-card__title { color: var(--pm-color-secondary); }

.pm-card__title a { color: inherit; text-decoration: none; }

.pm-card__excerpt {
    font-size: var(--pm-text-body);
    line-height: 1.6;
    color: var(--pm-color-text-muted);
    margin: 0;
    flex: 1;
}

.pm-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pm-color-primary);
    text-decoration: none;
    margin-top: auto;
    transition: color var(--pm-transition), gap var(--pm-transition);
}

.pm-card__cta:hover { color: var(--pm-color-secondary); gap: 10px; }

.pm-card__cta svg { width: 14px; height: 14px; flex-shrink: 0; }

/* ==========================================================================
   Sidebar — pm-sidebar
   ========================================================================== */

.pm-sidebar {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.pm-sidebar__widget {
    background-color: var(--pm-color-surface-alt);
    border: 1px solid var(--pm-color-border);
    padding: 24px;
}

.pm-sidebar__widget-title {
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pm-color-secondary);
    border-bottom: 1px solid var(--pm-color-border);
    padding-bottom: 12px;
    margin-bottom: 20px;
}

.pm-sidebar__posts {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pm-sidebar__post-item { display: flex; flex-direction: column; gap: 4px; }

.pm-sidebar__post-num {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pm-color-text-muted);
}

.pm-sidebar__post-title {
    font-family: var(--pm-font-heading);
    font-size: 15px;
    font-weight: 600;
    color: var(--pm-color-primary);
    text-decoration: none;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--pm-transition);
}

.pm-sidebar__post-title:hover { color: var(--pm-color-secondary); }

.pm-sidebar__newsletter {
    background-color: var(--pm-color-primary);
    color: var(--pm-color-primary-text);
    padding: 32px 24px;
}

.pm-sidebar__newsletter-title {
    font-family: var(--pm-font-heading);
    font-style: italic;
    font-size: 20px;
    font-weight: 600;
    color: var(--pm-color-primary-text);
    margin-bottom: 12px;
}

.pm-sidebar__newsletter-desc {
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: 20px;
}

.pm-sidebar__newsletter-btn {
    display: block;
    width: 100%;
    padding: 12px;
    background-color: var(--pm-color-surface);
    color: var(--pm-color-primary);
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: background-color var(--pm-transition);
}

.pm-sidebar__newsletter-btn:hover { background-color: var(--pm-color-secondary-light); }

/* ==========================================================================
   Formulaire Newsletter — pm-newsletter-form
   ========================================================================== */

.pm-newsletter-form {
    display: flex;
    gap: 0;
    max-width: 480px;
}

.pm-newsletter-form__input {
    flex: 1;
    background-color: var(--pm-color-surface);
    border: 1px solid var(--pm-color-border);
    border-right: none;
    padding: 14px 20px;
    font-family: var(--pm-font-body);
    font-size: var(--pm-text-body);
    color: var(--pm-color-text);
    outline: none;
    transition: border-color var(--pm-transition);
}

.pm-newsletter-form__input:focus { border-color: var(--pm-color-primary); }
.pm-newsletter-form__input::placeholder { color: var(--pm-color-text-muted); }

.pm-newsletter-form__submit {
    background-color: var(--pm-color-primary);
    color: var(--pm-color-primary-text);
    border: none;
    padding: 14px 24px;
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color var(--pm-transition);
}

.pm-newsletter-form__submit:hover { background-color: var(--pm-color-secondary); }

@media (max-width: 480px) {
    .pm-newsletter-form { flex-direction: column; gap: 8px; }
    .pm-newsletter-form__input { border-right: 1px solid var(--pm-color-border); }
}

/* ==========================================================================
   Footer — pm-footer
   ========================================================================== */

.pm-footer {
    background-color: var(--pm-color-surface-alt);
    border-top: 1px solid var(--pm-color-border);
    padding: 48px 0;
}

.pm-footer__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}

.pm-footer__brand {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pm-footer__logo {
    font-family: var(--pm-font-heading);
    font-style: italic;
    font-size: 20px;
    color: var(--pm-color-primary);
    text-decoration: none;
    transition: opacity var(--pm-transition);
}

.pm-footer__logo:hover { opacity: 0.75; color: var(--pm-color-primary); }

.pm-footer__tagline {
    font-size: 11px;
    color: var(--pm-color-text-muted);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0;
}

.pm-footer__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: center;
}

.pm-footer__link {
    font-size: 11px;
    color: var(--pm-color-text-muted);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: underline;
    text-underline-offset: 4px;
    transition: color var(--pm-transition);
}

.pm-footer__link:hover { color: var(--pm-color-primary); }

@media (max-width: 640px) {
    .pm-footer__inner { flex-direction: column; align-items: center; text-align: center; }
    .pm-footer__nav { justify-content: center; gap: 16px; }
}

/* ==========================================================================
   Sections communes (archive header, section headers, méta)
   ========================================================================== */

.pm-archive-header {
    padding: var(--pm-section-gap) 0 40px;
    border-bottom: 1px solid var(--pm-color-border);
    margin-bottom: 48px;
}

.pm-archive-header__label { display: block; margin-bottom: 12px; }

.pm-archive-header__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h1);
    font-weight: 700;
    color: var(--pm-color-primary);
    margin: 0 0 16px;
    max-width: 800px;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.pm-archive-header__desc {
    font-size: var(--pm-text-body-lg);
    color: var(--pm-color-text-muted);
    max-width: 640px;
    margin: 0;
    line-height: 1.6;
}

.pm-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--pm-gap);
    padding-bottom: 16px;
    border-bottom: 1px solid var(--pm-color-border);
    margin-bottom: 32px;
    flex-wrap: wrap;
}

.pm-section-header__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h2);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0;
}

.pm-section-header__filters {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.pm-section-header__filter {
    font-size: var(--pm-text-label);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pm-color-text-muted);
    text-decoration: none;
    transition: color var(--pm-transition), border-color var(--pm-transition);
    padding-bottom: 2px;
    border-bottom: 2px solid transparent;
}

.pm-section-header__filter:hover,
.pm-section-header__filter--active {
    color: var(--pm-color-primary);
    border-bottom-color: var(--pm-color-primary);
}

/* Méta article */
.pm-entry-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.pm-entry-meta__sep {
    display: inline-block;
    width: 24px;
    height: 1px;
    background-color: var(--pm-color-border);
    vertical-align: middle;
}

/* ==========================================================================
   Archive — Bento Grid (Template 2)
   Grille 12 colonnes asymétrique pour les 4 premiers articles.
   ========================================================================== */

.pm-bento { margin-bottom: var(--pm-section-gap); }

.pm-bento__grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--pm-gap);
}

/* Article principal : 8/12 colonnes */
.pm-bento__main {
    grid-column: 1 / 9;
    border: 1px solid var(--pm-color-border);
    background-color: var(--pm-color-surface);
    padding: 32px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 24px;
    transition: box-shadow var(--pm-transition);
}

.pm-bento__main:hover { box-shadow: var(--pm-shadow-card); }

.pm-bento__main-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.pm-bento__main-title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h2);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0 0 12px;
}

.pm-bento__main-title a { color: inherit; text-decoration: none; }
.pm-bento__main-title a:hover { color: var(--pm-color-secondary); }

.pm-bento__main-desc {
    font-size: var(--pm-text-body);
    color: var(--pm-color-text-muted);
    line-height: 1.6;
    margin: 0;
    max-width: 480px;
}

.pm-bento__main-icon { color: var(--pm-color-primary); flex-shrink: 0; }

.pm-bento__main-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    border-top: 1px solid var(--pm-color-border);
    padding-top: 24px;
}

.pm-bento__stat-label { font-size: var(--pm-text-label); margin-bottom: 4px; }

.pm-bento__stat-value {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0;
}

/* Article mis en avant : fond sombre, 4/12 colonnes */
.pm-bento__featured {
    grid-column: 9 / 13;
    background-color: var(--pm-color-primary);
    color: var(--pm-color-primary-text);
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
    overflow: hidden;
}

.pm-bento__featured-title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    color: var(--pm-color-primary-text);
    margin: 0;
    line-height: 1.3;
}

.pm-bento__featured-title a {
    color: inherit;
    text-decoration: none;
    transition: opacity var(--pm-transition);
}

.pm-bento__featured-title a:hover { opacity: 0.8; color: inherit; }

.pm-bento__featured-desc {
    font-size: var(--pm-text-body);
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.6;
    margin: 0;
}

.pm-bento__featured-image {
    margin-top: auto;
    overflow: hidden;
}

.pm-bento__featured-image img {
    width: 100%;
    height: 140px;
    object-fit: cover;
    filter: grayscale(1);
    opacity: 0.5;
    transition: filter 0.5s ease, opacity 0.5s ease;
    display: block;
}

.pm-bento__featured:hover .pm-bento__featured-image img {
    filter: grayscale(0);
    opacity: 1;
}

/* Article secondaire 1 : 4/12 */
.pm-bento__secondary {
    grid-column: 1 / 5;
    border: 1px solid var(--pm-color-border);
    background-color: var(--pm-color-surface);
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: border-color var(--pm-transition);
}

.pm-bento__secondary:hover { border-color: var(--pm-color-secondary); }

.pm-bento__secondary-content { display: flex; flex-direction: column; gap: 8px; }

.pm-bento__secondary-title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0;
}

.pm-bento__secondary-title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--pm-transition);
}

.pm-bento__secondary:hover .pm-bento__secondary-title a { color: var(--pm-color-secondary); }

.pm-bento__secondary-desc {
    font-size: var(--pm-text-body);
    color: var(--pm-color-text-muted);
    margin: 0;
    line-height: 1.6;
    flex: 1;
}

.pm-bento__secondary-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--pm-color-primary);
    text-decoration: none;
    transition: color var(--pm-transition);
}

.pm-bento__secondary:hover .pm-bento__secondary-link { color: var(--pm-color-secondary); }

/* Article secondaire 2 avec barre décorative : 8/12 */
.pm-bento__alt {
    grid-column: 5 / 13;
    background-color: var(--pm-color-surface-alt);
    padding: 32px;
    display: flex;
    flex-direction: row;
    gap: 32px;
    align-items: center;
}

.pm-bento__alt-content { flex: 1; }

.pm-bento__alt-title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0 0 12px;
}

.pm-bento__alt-title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--pm-transition);
}

.pm-bento__alt-title a:hover { color: var(--pm-color-secondary); }

.pm-bento__alt-desc {
    font-size: var(--pm-text-body);
    color: var(--pm-color-text-muted);
    margin: 0;
    line-height: 1.6;
}

/* Barre décorative (mini graphique) */
.pm-bento__alt-bar {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    width: 120px;
    height: 80px;
    flex-shrink: 0;
}

.pm-bento__bar-item {
    flex: 1;
    background-color: rgba(15, 36, 33, 0.2);
    border-radius: 0;
}

.pm-bento__bar-item--sm  { height: 30%; }
.pm-bento__bar-item--md  { height: 50%; }
.pm-bento__bar-item--lg  { height: 65%; }
.pm-bento__bar-item--xl  { height: 75%; }
.pm-bento__bar-item--accent {
    height: 85%;
    background-color: var(--pm-color-secondary);
}

/* Grille articles archive (après le bento) */
.pm-archive-grid { padding-bottom: var(--pm-section-gap); }

.pm-archive-pagination { padding-top: 32px; }

/* Pagination GP */
.navigation.pagination,
.page-navigation {
    display: flex;
    justify-content: center;
    padding: 32px 0;
}

.navigation .nav-links {
    display: flex;
    gap: 8px;
    align-items: center;
}

.navigation .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 8px;
    border: 1px solid var(--pm-color-border);
    font-size: var(--pm-text-label);
    font-weight: 600;
    color: var(--pm-color-text-muted);
    text-decoration: none;
    transition: background-color var(--pm-transition), color var(--pm-transition), border-color var(--pm-transition);
}

.navigation .page-numbers:hover,
.navigation .page-numbers.current {
    background-color: var(--pm-color-primary);
    border-color: var(--pm-color-primary);
    color: var(--pm-color-primary-text);
}

/* Responsive bento */
@media (max-width: 1024px) {
    .pm-bento__grid { grid-template-columns: 1fr 1fr; }
    .pm-bento__main    { grid-column: 1 / -1; }
    .pm-bento__featured { grid-column: 1 / 2; }
    .pm-bento__secondary { grid-column: 2 / 3; }
    .pm-bento__alt     { grid-column: 1 / -1; }
}

@media (max-width: 640px) {
    .pm-bento__grid { grid-template-columns: 1fr; }
    .pm-bento__main,
    .pm-bento__featured,
    .pm-bento__secondary,
    .pm-bento__alt { grid-column: 1 / -1; }
    .pm-bento__alt { flex-direction: column; }
    .pm-bento__alt-bar { width: 100%; height: 48px; }
}

/* ==========================================================================
   Page Guides / Premium (templates/page-guides.php)
   ========================================================================== */

/* Hero */
.pm-guides-hero { padding: 80px 0 var(--pm-section-gap); }

.pm-guides-hero__grid {
    display: grid;
    grid-template-columns: 7fr 5fr;
    gap: 48px;
    align-items: center;
}

.pm-guides-hero__content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.pm-guides-hero__label { display: block; }

.pm-guides-hero__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h1);
    font-weight: 700;
    color: var(--pm-color-primary);
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0;
}

.pm-guides-hero__desc {
    font-size: var(--pm-text-body-lg);
    color: var(--pm-color-text-muted);
    line-height: 1.7;
    max-width: 520px;
    margin: 0;
}

.pm-guides-hero__form-wrap {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.pm-guides-hero__form {
    display: flex;
    flex-direction: column;
    gap: 4px;
    max-width: 480px;
}

.pm-guides-hero__form-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.pm-guides-hero__input {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--pm-color-border);
    padding: 12px 0;
    font-family: var(--pm-font-body);
    font-size: var(--pm-text-body);
    color: var(--pm-color-text);
    outline: none;
    transition: border-color var(--pm-transition);
    width: 100%;
}

.pm-guides-hero__input:focus { border-bottom-color: var(--pm-color-secondary); }
.pm-guides-hero__input::placeholder { color: var(--pm-color-text-muted); }

.pm-guides-hero__submit {
    align-self: flex-start;
    margin-top: 8px;
    background-color: var(--pm-color-primary);
    color: var(--pm-color-primary-text);
    border: none;
    padding: 14px 32px;
    font-family: var(--pm-font-heading);
    font-size: 13px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color var(--pm-transition), transform 0.1s ease;
}

.pm-guides-hero__submit:hover { background-color: var(--pm-color-secondary); }
.pm-guides-hero__submit:active { transform: scale(0.98); }

.pm-guides-hero__disclaimer {
    font-size: 10px;
    color: var(--pm-color-text-muted);
    font-style: italic;
    margin: 0;
}

/* Image héro */
.pm-guides-hero__image-col { position: relative; }

.pm-guides-hero__image-wrap {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(0,0,0,0.12);
}

.pm-guides-hero__image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pm-guides-hero__image-deco {
    position: absolute;
    bottom: -32px;
    left: -32px;
    width: 192px;
    height: 192px;
    background-color: rgba(119, 90, 25, 0.15);
    z-index: -1;
}

/* Bénéfices */
.pm-benefits {
    background-color: var(--pm-color-surface-alt);
    padding: var(--pm-section-gap) 0;
}

.pm-benefits__header { max-width: 560px; margin-bottom: 48px; }

.pm-benefits__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h2);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin-bottom: 12px;
}

.pm-benefits__subtitle {
    font-size: var(--pm-text-body);
    color: var(--pm-color-text-muted);
    margin: 0;
}

.pm-benefits__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--pm-gap);
    align-items: start;
}

.pm-benefits__card {
    background-color: var(--pm-color-surface);
    border: 1px solid var(--pm-color-border);
    padding: 40px;
    transition: box-shadow var(--pm-transition);
}

.pm-benefits__card:hover { box-shadow: var(--pm-shadow-card); }

/* Décalage vertical des cartes (design en escalier) */
.pm-benefits__card--offset-1 { margin-top: 48px; }
.pm-benefits__card--offset-2 { margin-top: 96px; }

.pm-benefits__icon { margin-bottom: 24px; }

.pm-benefits__card-title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h3);
    font-weight: 600;
    color: var(--pm-color-primary);
    margin: 0 0 12px;
    transition: color var(--pm-transition);
}

.pm-benefits__card:hover .pm-benefits__card-title { color: var(--pm-color-secondary); }

.pm-benefits__card-desc {
    font-size: var(--pm-text-body);
    color: var(--pm-color-text-muted);
    line-height: 1.6;
    margin: 0;
}

/* Citation manifesto */
.pm-manifesto {
    background-color: var(--pm-color-surface);
    padding: var(--pm-section-gap) 0;
}

.pm-manifesto__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 840px;
    margin: 0 auto;
}

.pm-manifesto__line {
    width: 64px;
    height: 4px;
    background-color: var(--pm-color-secondary);
    margin-bottom: 40px;
}

.pm-manifesto__quote {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
}

.pm-manifesto__quote p {
    font-family: var(--pm-font-heading);
    font-style: italic;
    font-size: 28px;
    font-weight: 600;
    color: var(--pm-color-primary);
    line-height: 1.4;
    margin-bottom: 20px;
}

.pm-manifesto__quote cite {
    font-style: normal;
    font-size: var(--pm-text-label);
    color: var(--pm-color-text-muted);
}

/* Stats */
.pm-stats {
    background-color: var(--pm-color-primary);
    padding: var(--pm-section-gap) 0;
}

.pm-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--pm-gap);
    text-align: center;
}

.pm-stats__value {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h2);
    font-weight: 700;
    color: var(--pm-color-secondary-light);
    margin-bottom: 8px;
}

.pm-stats__label {
    font-size: var(--pm-text-label);
    color: rgba(255, 255, 255, 0.65);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* CTA final */
.pm-cta-final { padding: var(--pm-section-gap) 0; }

.pm-cta-final__inner {
    background-color: var(--pm-color-surface-alt);
    border: 1px solid var(--pm-color-border);
    padding: 80px;
    text-align: center;
    position: relative;
    overflow: hidden;
    max-width: 900px;
    margin: 0 auto;
}

.pm-cta-final__deco {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(var(--pm-color-border) 0.5px, transparent 0.5px);
    background-size: 10px 10px;
    opacity: 0.4;
    pointer-events: none;
}

.pm-cta-final__content { position: relative; z-index: 1; }

.pm-cta-final__title {
    font-family: var(--pm-font-heading);
    font-size: var(--pm-text-h1);
    font-weight: 700;
    color: var(--pm-color-primary);
    margin-bottom: 16px;
}

.pm-cta-final__desc {
    font-size: var(--pm-text-body-lg);
    color: var(--pm-color-text-muted);
    max-width: 480px;
    margin: 0 auto 32px;
    line-height: 1.6;
}

.pm-cta-final .pm-newsletter-form { margin: 0 auto; justify-content: center; }

/* Tags article single */
.pm-single-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid var(--pm-color-border);
}

.pm-single-tags__item {
    display: inline-block;
    background-color: var(--pm-color-surface-alt);
    border: 1px solid var(--pm-color-border);
    color: var(--pm-color-text-muted);
    padding: 4px 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background-color var(--pm-transition), color var(--pm-transition), border-color var(--pm-transition);
}

.pm-single-tags__item:hover {
    background-color: var(--pm-color-secondary-light);
    border-color: var(--pm-color-secondary);
    color: var(--pm-color-primary);
}

/* Responsive page guides */
@media (max-width: 1024px) {
    .pm-guides-hero__grid { grid-template-columns: 1fr; }
    .pm-guides-hero__image-col { display: none; }
    .pm-benefits__grid { grid-template-columns: 1fr; }
    .pm-benefits__card--offset-1,
    .pm-benefits__card--offset-2 { margin-top: 0; }
    .pm-stats__grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
    .pm-cta-final__inner { padding: 40px 20px; }
    .pm-cta-final__title { font-size: var(--pm-text-h2); }
}

@media (max-width: 640px) {
    .pm-benefits__grid { grid-template-columns: 1fr; }
    .pm-stats__grid { grid-template-columns: repeat(2, 1fr); }
    .pm-manifesto__quote p { font-size: var(--pm-text-h3); }
    .pm-guides-hero__title { font-size: var(--pm-text-h2); }
}
