/* ============================================================
   COMPONENTS.CSS — LMM v3 / Giscardpunk × Verge
   Le Monde Moderne

   All reusable UI components. Typography sizes/weights via GP.
   ============================================================ */


/* ══════════════════════════════════════
   BADGES
   ══════════════════════════════════════ */

.badge {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 3px 10px;
    line-height: 1.4;
}

.badge--rubrique {
    background: var(--lmm-moutarde);
    color: var(--lmm-noir);
}

.badge--rubrique:hover {
    background: var(--lmm-moutarde-dark);
}

.badge--opinion {
    background: var(--lmm-brique);
    color: var(--lmm-blanc);
}

.badge--format {
    background: transparent;
    color: var(--lmm-moutarde);
    border: 1px solid var(--lmm-moutarde);
}

/* Badge on dark backgrounds */
.on-dark .badge--rubrique {
    background: var(--lmm-moutarde);
    color: var(--lmm-noir);
}

.on-dark .badge--format {
    border-color: rgba(255, 255, 255, 0.3);
    color: rgba(255, 255, 255, 0.7);
}


/* ══════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    font-family: var(--font-ui);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 12px 24px;
    border: none;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-decoration: none;
}

.btn--primary {
    background: var(--lmm-moutarde);
    color: var(--lmm-noir);
}

.btn--primary:hover {
    background: var(--lmm-moutarde-dark);
}

.btn--ghost {
    background: transparent;
    color: var(--color-text);
    border: 2px solid currentColor;
}

.btn--ghost:hover {
    border-color: var(--lmm-moutarde);
    color: var(--lmm-moutarde);
}

.btn--small {
    padding: 8px 16px;
    font-size: 0.625rem;
}


/* ══════════════════════════════════════
   FORMS
   ══════════════════════════════════════ */

.form-input {
    font-family: var(--font-ui);
    font-size: 0.875rem;
    padding: 12px 16px;
    border: 2px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text);
    transition: border-color var(--transition-fast);
}

.form-input:focus {
    border-color: var(--lmm-moutarde);
    outline: none;
}


/* ══════════════════════════════════════
   SECTION LABEL — the giscardpunk filet
   ══════════════════════════════════════ */

.section-label {
    font-family: var(--font-ui);
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--lmm-moutarde);
    padding-bottom: var(--space-sm);
    border-bottom: 3px solid var(--color-border-strong);
    margin-bottom: var(--space-lg);
}

.on-dark .section-label,
.dark-mode .section-label {
    border-bottom-color: var(--lmm-moutarde);
}


/* ══════════════════════════════════════
   READING PROGRESS BAR
   ══════════════════════════════════════ */

.reading-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0;
    height: 3px;
    background: var(--lmm-moutarde);
    z-index: 1000;
    transition: width 100ms linear;
}


/* ══════════════════════════════════════
   DARK MODE TOGGLE
   ══════════════════════════════════════ */

.dark-mode-toggle {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.125rem;
    padding: var(--space-sm);
    color: var(--lmm-gris);
    transition: color var(--transition-fast);
    line-height: 1;
}

.dark-mode-toggle:hover {
    color: var(--lmm-moutarde);
}


/* ══════════════════════════════════════
   CARDS — Archive pages, related articles
   ══════════════════════════════════════ */

.card {
    background: var(--color-surface);
    border-bottom: 3px solid var(--color-border-strong);
    overflow: hidden;
    transition: transform var(--transition-base);
}

.card:hover {
    transform: translateY(-3px);
}

.card__image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.card:hover .card__image img {
    transform: scale(1.04);
}

.card__body {
    padding: var(--space-md);
}

.card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: var(--space-sm);
}

.card__title {
    font-family: var(--font-titre);
    font-size: 1.125rem;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -0.3px;
    margin-bottom: var(--space-sm);
}

.card__title a { color: var(--color-text); }
.card__title a:hover { color: var(--lmm-moutarde); }

.card__chapo {
    font-family: var(--font-corps);
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-sm);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.card__meta {
    font-family: var(--font-ui);
    font-size: 0.6875rem;
    color: var(--color-text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Card on dark bg */
.on-dark .card {
    background: var(--dark-bg-elevated);
    border-bottom-color: var(--lmm-moutarde);
}

.on-dark .card__title a { color: var(--dark-text); }
.on-dark .card__meta { color: var(--dark-text-secondary); }


/* ══════════════════════════════════════
   NEWSLETTER CTA
   ══════════════════════════════════════ */

.newsletter-cta {
    background: var(--lmm-noir);
    padding: var(--space-xl) var(--space-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xl);
    flex-wrap: wrap;
    border-top: 4px solid var(--lmm-moutarde);
}

.newsletter-cta__text { flex: 1; min-width: 240px; }

.newsletter-cta__title {
    font-family: var(--font-titre);
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--lmm-creme);
    letter-spacing: -0.5px;
    margin-bottom: var(--space-xs);
}

.newsletter-cta__desc {
    font-family: var(--font-ui);
    font-size: 0.875rem;
    color: var(--lmm-gris);
}

.newsletter-cta__form {
    display: flex;
    gap: var(--space-sm);
    flex-shrink: 0;
}

.newsletter-cta__form .form-input {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
    color: var(--lmm-creme);
    min-width: 240px;
}

.newsletter-cta__form .form-input::placeholder {
    color: var(--lmm-gris);
}


/* ══════════════════════════════════════
   SOURCES LIST (single article)
   ══════════════════════════════════════ */

.sources-list {
    border-top: 2px solid var(--color-border-strong);
    padding-top: var(--space-lg);
    margin-top: var(--space-xl);
}

.dark-mode .sources-list { border-top-color: var(--lmm-moutarde); }

.sources-list__title {
    font-family: var(--font-ui);
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
}

.sources-list ul { list-style: none; padding: 0; }

.sources-list li {
    font-family: var(--font-ui);
    font-size: 0.875rem;
    padding: var(--space-xs) 0;
    border-bottom: 1px solid var(--color-border);
}

.sources-list a {
    text-decoration: underline;
    text-underline-offset: 2px;
}


/* ══════════════════════════════════════
   AUTHOR BOX (single article)
   ══════════════════════════════════════ */

.author-box {
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: var(--color-surface);
    border-left: 4px solid var(--lmm-moutarde);
    margin-top: var(--space-xl);
}

.author-box__avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
}

.author-box__name {
    font-family: var(--font-titre);
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: var(--space-xs);
}

.author-box__bio {
    font-size: 0.875rem;
    color: var(--color-text-secondary);
    line-height: 1.5;
}


/* ══════════════════════════════════════
   GP STRUCTURAL OVERRIDES
   ══════════════════════════════════════ */

/* Force column layout — GP sets .site-content to display:flex (row) */
.site-content { flex-direction: column !important; }
.site-content .content-area { width: 100%; float: none; }
.site #page { max-width: 100%; }
.site-content { max-width: 100%; }
.inside-article { padding: 0; }
.home .entry-header { display: none; }
.site-info { display: none; }
div.site-footer:not(footer) { background: none; padding: 0; margin: 0; }

.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.one-container .container {
    background: transparent;
}
