/* ═══════════════════════════════════════════════════════
   ARTICLES & REVIEWS STYLES
   French Choice Hub - Brutalism Theme
   ═══════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════
   ARTICLE LAYOUT
   ═══════════════════════════════════════════════════════ */
.l-article {
    max-width: 800px;
    margin: 0 auto;
    padding: var(--space-2xl) var(--space-lg);
}

.l-article-header {
    margin-bottom: var(--space-2xl);
    padding-bottom: var(--space-xl);
    border-bottom: 4px solid var(--champagne-gold);
}

.l-article-header__category {
    display: inline-block;
    background: var(--paris-blue);
    color: var(--ivory-white);
    padding: var(--space-xs) var(--space-md);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: var(--space-md);
    border: 2px solid var(--noir-profond);
}

.l-article-header__title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    margin-bottom: var(--space-md);
    line-height: 1.2;
}

.l-article-header__meta {
    display: flex;
    gap: var(--space-lg);
    flex-wrap: wrap;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.l-article-header__meta span {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

/* ═══════════════════════════════════════════════════════
   ARTICLE CONTENT
   ═══════════════════════════════════════════════════════ */
.l-article-content {
    line-height: 1.9;
    color: var(--text-secondary);
}

.l-article-content h2 {
    font-size: 1.5rem;
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-sm);
    border-bottom: 3px solid var(--champagne-gold);
    color: var(--paris-blue);
}

.l-article-content h3 {
    font-size: 1.25rem;
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
    color: var(--paris-blue);
}

.l-article-content p {
    margin-bottom: var(--space-lg);
}

.l-article-content ul,
.l-article-content ol {
    margin-bottom: var(--space-lg);
    padding-left: var(--space-xl);
}

.l-article-content li {
    margin-bottom: var(--space-sm);
    position: relative;
}

.l-article-content ul li::before {
    content: '→';
    position: absolute;
    left: -24px;
    color: var(--champagne-gold);
    font-weight: bold;
}

.l-article-content ol {
    counter-reset: article-counter;
    list-style: none;
}

.l-article-content ol li {
    counter-increment: article-counter;
}

.l-article-content ol li::before {
    content: counter(article-counter) '.';
    position: absolute;
    left: -28px;
    color: var(--champagne-gold);
    font-weight: bold;
}

.l-article-content a {
    color: var(--paris-blue);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.l-article-content a:hover {
    color: var(--champagne-gold);
}

.l-article-content blockquote {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    background: var(--gris-perle);
    border-left: 4px solid var(--champagne-gold);
    font-style: italic;
}

.l-article-content blockquote p:last-child {
    margin-bottom: 0;
}

/* ═══════════════════════════════════════════════════════
   INFO BOX
   ═══════════════════════════════════════════════════════ */
.m-info-box {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    background: var(--bg-card);
    border: var(--border-brutal);
    box-shadow: var(--shadow-brutal-sm);
}

.m-info-box--tip {
    border-left: 6px solid var(--champagne-gold);
}

.m-info-box--warning {
    border-left: 6px solid var(--bordeaux-red);
    background: #fff5f5;
}

.m-info-box--info {
    border-left: 6px solid var(--paris-blue);
}

.m-info-box__title {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-weight: 700;
    margin-bottom: var(--space-sm);
    color: var(--paris-blue);
}

.m-info-box p {
    margin-bottom: 0;
}

/* ═══════════════════════════════════════════════════════
   REVIEW CARD (in articles)
   ═══════════════════════════════════════════════════════ */
.m-review-summary {
    margin: var(--space-xl) 0;
    padding: var(--space-xl);
    background: var(--bg-card);
    border: var(--border-brutal);
    box-shadow: var(--shadow-brutal-md);
}

.m-review-summary__header {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-lg);
    border-bottom: 2px solid var(--gris-perle);
}

.m-review-summary__logo {
    width: 100px;
    height: 70px;
    object-fit: contain;
    background: white;
    padding: var(--space-sm);
    border: 2px solid var(--noir-profond);
}

.m-review-summary__info h3 {
    margin-bottom: var(--space-xs);
}

.m-review-summary__rating {
    color: var(--champagne-gold);
    font-weight: 700;
}

.m-review-summary__bonus {
    background: var(--champagne-gold);
    color: var(--noir-profond);
    padding: var(--space-md);
    font-weight: 700;
    text-align: center;
    border: 2px solid var(--noir-profond);
    margin-bottom: var(--space-lg);
}

.m-review-summary__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-lg);
    margin-bottom: var(--space-lg);
}

@media (max-width: 576px) {
    .m-review-summary__grid {
        grid-template-columns: 1fr;
    }
}

.m-review-summary__pros,
.m-review-summary__cons {
    padding: var(--space-md);
}

.m-review-summary__pros {
    background: #f0fff4;
    border: 2px solid #38a169;
}

.m-review-summary__cons {
    background: #fff5f5;
    border: 2px solid #e53e3e;
}

.m-review-summary__pros h4,
.m-review-summary__cons h4 {
    margin-bottom: var(--space-sm);
    font-size: 0.9rem;
    text-transform: uppercase;
}

.m-review-summary__pros ul,
.m-review-summary__cons ul {
    padding-left: var(--space-lg);
    margin: 0;
}

.m-review-summary__pros li::before {
    content: '✓ ';
    color: #38a169;
    font-weight: bold;
}

.m-review-summary__cons li::before {
    content: '✗ ';
    color: #e53e3e;
    font-weight: bold;
}

.m-review-summary__cta {
    display: flex;
    gap: var(--space-md);
}

.m-review-summary__cta .m-btn {
    flex: 1;
    text-align: center;
}

/* ═══════════════════════════════════════════════════════
   TABLE OF CONTENTS
   ═══════════════════════════════════════════════════════ */
.m-toc {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    background: var(--gris-perle);
    border: var(--border-brutal);
}

.m-toc__title {
    font-size: 1rem;
    margin-bottom: var(--space-md);
    color: var(--paris-blue);
}

.m-toc__list {
    padding-left: var(--space-lg);
}

.m-toc__list li {
    margin-bottom: var(--space-xs);
}

.m-toc__list a {
    color: var(--paris-blue);
    text-decoration: none;
    font-size: 0.95rem;
}

.m-toc__list a:hover {
    color: var(--champagne-gold);
    text-decoration: underline;
}

/* ═══════════════════════════════════════════════════════
   ARTICLE FOOTER
   ═══════════════════════════════════════════════════════ */
.l-article-footer {
    margin-top: var(--space-2xl);
    padding-top: var(--space-xl);
    border-top: 4px solid var(--gris-perle);
}

.l-article-footer__author {
    display: flex;
    gap: var(--space-lg);
    align-items: flex-start;
    padding: var(--space-lg);
    background: var(--gris-perle);
    border: var(--border-brutal);
}

.l-article-footer__author-avatar {
    width: 80px;
    height: 80px;
    background: var(--paris-blue);
    color: var(--ivory-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: bold;
    border: 2px solid var(--noir-profond);
    flex-shrink: 0;
}

.l-article-footer__author-info h4 {
    margin-bottom: var(--space-xs);
}

.l-article-footer__author-info p {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-bottom: 0;
}

/* ═══════════════════════════════════════════════════════
   RELATED ARTICLES
   ═══════════════════════════════════════════════════════ */
.m-related-articles {
    margin-top: var(--space-2xl);
}

.m-related-articles__title {
    margin-bottom: var(--space-lg);
    text-align: center;
}

.m-related-articles__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

@media (max-width: 768px) {
    .m-related-articles__grid {
        grid-template-columns: 1fr;
    }
}

/* ═══════════════════════════════════════════════════════
   REVIEW PAGE SPECIFIC
   ═══════════════════════════════════════════════════════ */
.l-review-hero {
    background: linear-gradient(135deg, var(--paris-blue) 0%, #2a4a6f 100%);
    color: var(--ivory-white);
    padding: var(--space-3xl) 0;
}

.l-review-hero__inner {
    display: flex;
    align-items: center;
    gap: var(--space-2xl);
    flex-wrap: wrap;
}

.l-review-hero__logo {
    background: white;
    padding: var(--space-lg);
    border: var(--border-brutal);
    box-shadow: var(--shadow-brutal-gold);
}

.l-review-hero__logo img {
    width: 150px;
    height: 100px;
    object-fit: contain;
}

.l-review-hero__info h1 {
    color: var(--ivory-white);
    margin-bottom: var(--space-sm);
}

.l-review-hero__rating {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.l-review-hero__rating .l-stars {
    font-size: 1.5rem;
}

.l-review-hero__rating strong {
    font-size: 1.5rem;
}

.l-review-hero__bonus {
    background: var(--champagne-gold);
    color: var(--noir-profond);
    padding: var(--space-md) var(--space-xl);
    display: inline-block;
    font-weight: 700;
    font-size: 1.25rem;
    border: var(--border-brutal);
    box-shadow: var(--shadow-brutal-sm);
}

/* ═══════════════════════════════════════════════════════
   SCORE TABLE
   ═══════════════════════════════════════════════════════ */
.m-score-table {
    margin: var(--space-xl) 0;
    border: var(--border-brutal);
    box-shadow: var(--shadow-brutal-sm);
    overflow: hidden;
}

.m-score-table__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-md) var(--space-lg);
    background: var(--bg-card);
    border-bottom: 2px solid var(--gris-perle);
}

.m-score-table__row:last-child {
    border-bottom: none;
}

.m-score-table__row:nth-child(even) {
    background: var(--gris-perle);
}

.m-score-table__label {
    font-weight: 600;
    color: var(--paris-blue);
}

.m-score-table__value {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.m-score-table__bar {
    width: 100px;
    height: 8px;
    background: var(--gris-perle);
    border: 1px solid var(--noir-profond);
    overflow: hidden;
}

.m-score-table__bar-fill {
    height: 100%;
    background: var(--champagne-gold);
}

.m-score-table__score {
    font-weight: 700;
    color: var(--champagne-gold);
    min-width: 40px;
    text-align: right;
}
