/**
 * CMS Source - Static Pages Styles
 * Styles for: about, contact, faq, terms, privacy, cookies, legal
 * @version 1.0.0
 */

/* ==========================================================================
   PAGE CONTENT - Base styles for all static pages
   ========================================================================== */
.page-content {
    padding: var(--spacing-12, 3rem) 0;
}

.page-content .container {
    max-width: 900px;
}

/* ==========================================================================
   ABOUT PAGE - Content blocks
   ========================================================================== */
.page-about .content-block {
    margin-bottom: var(--spacing-8, 2rem);
    padding: var(--spacing-6, 1.5rem);
    background: var(--white, #fff);
    border-radius: var(--border-radius-lg, 1rem);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.05));
}

.page-about .content-block h2 {
    /* H2 dans une card de contenu → on neutralise le traitement décoratif
       global (stroke + ombre) et on utilise Quicksand pour la lisibilité */
    font-family: var(--font-family-subtitle);
    font-size: var(--font-size-xl, 1.25rem);
    font-weight: var(--font-weight-semibold, 600);
    color: var(--color-sage-dark, #8fa889);
    margin: 0 0 0.75rem;
    text-shadow: none;
}

.page-about .content-block p {
    margin: 0 0 0.5rem;
    line-height: 1.7;
    color: var(--text-secondary, #374151);
}

.page-about .content-block ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.page-about .content-block ul li {
    padding: 0.5rem 0;
    padding-left: 1.5rem;
    position: relative;
    line-height: 1.6;
}

.page-about .content-block ul li::before {
    content: '🌿';
    position: absolute;
    left: 0;
    font-size: 0.875rem;
}

/* ==========================================================================
   CONTACT PAGE - Form styling
   ========================================================================== */
.page-contact .contact-form {
    background: var(--white, #fff);
    padding: var(--spacing-8, 2rem);
    border-radius: var(--border-radius-lg, 1rem);
    box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,0.08));
}

.page-contact .form-group {
    margin-bottom: var(--spacing-5, 1.25rem);
}

.page-contact .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: var(--font-weight-medium, 500);
    color: var(--text-primary, #111827);
    font-size: var(--font-size-sm, 0.875rem);
}

.page-contact .form-group input,
.page-contact .form-group textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: var(--border-radius, 0.5rem);
    font-size: var(--font-size-base, 1rem);
    font-family: inherit;
    transition: border-color var(--transition, 200ms ease), box-shadow var(--transition, 200ms ease);
    background: var(--white, #fff);
}

.page-contact .form-group input:focus,
.page-contact .form-group textarea:focus {
    outline: none;
    border-color: var(--color-sage, #A8BBA3);
    box-shadow: 0 0 0 3px rgba(168, 187, 163, 0.2);
}

.page-contact .form-group textarea {
    resize: vertical;
    min-height: 150px;
}

.page-contact .form-group .error {
    display: block;
    color: var(--danger, #ef4444);
    font-size: var(--font-size-sm, 0.875rem);
    margin-top: 0.25rem;
}

.page-contact .btn-primary {
    width: 100%;
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
    font-weight: var(--font-weight-semibold, 600);
    margin-top: var(--spacing-4, 1rem);
}

/* ==========================================================================
   FAQ PAGE
   ========================================================================== */
.page-faq .faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4, 1rem);
}

.page-faq .faq-item {
    background: var(--white, #fff);
    padding: var(--spacing-6, 1.5rem);
    border-radius: var(--border-radius-lg, 1rem);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.05));
    border-left: 4px solid var(--color-sage, #A8BBA3);
    transition: box-shadow var(--transition, 200ms ease);
}

.page-faq .faq-item:hover {
    box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,0.08));
}

.page-faq .faq-item h3 {
    /* Titre de question FAQ → Quicksand, lisibilité prime sur décoratif */
    font-family: var(--font-family-subtitle);
    font-size: var(--font-size-lg, 1.125rem);
    font-weight: var(--font-weight-semibold, 600);
    color: var(--text-primary, #111827);
    margin: 0 0 0.5rem;
    text-shadow: none;
}

.page-faq .faq-item p {
    margin: 0;
    color: var(--text-secondary, #374151);
    line-height: 1.7;
}

.page-faq .faq-more {
    margin-top: var(--spacing-10, 2.5rem);
    text-align: center;
    padding: var(--spacing-8, 2rem);
    background: var(--bg-secondary, #f9fafb);
    border-radius: var(--border-radius-lg, 1rem);
}

.page-faq .faq-more p {
    margin: 0 0 var(--spacing-4, 1rem);
    font-size: var(--font-size-lg, 1.125rem);
    color: var(--text-secondary, #374151);
}

/* ==========================================================================
   LEGAL PAGES (terms, privacy, cookies, legal)
   ========================================================================== */
.page-content.legal article {
    background: var(--white, #fff);
    padding: var(--spacing-6, 1.5rem);
    border-radius: var(--border-radius-lg, 1rem);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.05));
    margin-bottom: var(--spacing-4, 1rem);
}

.page-content.legal article h2 {
    /* H2 dans un article légal → Quicksand + neutralisation du traitement décoratif */
    font-family: var(--font-family-subtitle);
    font-size: var(--font-size-xl, 1.25rem);
    font-weight: var(--font-weight-semibold, 600);
    color: var(--text-primary, #111827);
    margin: 0 0 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-sage-light, #c4d4c0);
    text-shadow: none;
}

.page-content.legal article h3 {
    font-family: var(--font-family-subtitle);
    font-size: var(--font-size-base, 1rem);
    font-weight: var(--font-weight-semibold, 600);
    color: var(--text-primary, #111827);
    margin: 1rem 0 0.5rem;
    text-shadow: none;
}

.page-content.legal article p {
    margin: 0 0 0.75rem;
    line-height: 1.7;
    color: var(--text-secondary, #374151);
}

.page-content.legal article p:last-child {
    margin-bottom: 0;
}

.page-content.legal article ul {
    padding-left: 1.5rem;
    margin: 0.5rem 0 0.75rem;
}

.page-content.legal article ul li {
    padding: 0.25rem 0;
    line-height: 1.6;
    color: var(--text-secondary, #374151);
}

.page-content.legal article address {
    font-style: normal;
    padding: var(--spacing-4, 1rem);
    background: var(--bg-secondary, #f9fafb);
    border-radius: var(--border-radius, 0.5rem);
    margin: 0.75rem 0;
    line-height: 1.8;
}

.page-content.legal .last-updated {
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--text-muted, #6b7280);
    font-style: italic;
}

/* ==========================================================================
   LEGAL TABLES (cookies, CGV)
   ========================================================================== */
.page-content.legal table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
}

.page-content.legal th,
.page-content.legal td {
    padding: 0.75rem;
    text-align: left;
    border: 1px solid var(--border-color, #e0e0e0);
}

.page-content.legal th {
    background: var(--bg-secondary, #f5f5f5);
    font-weight: var(--font-weight-semibold, 600);
}

.page-content.legal tr:nth-child(even) td {
    background: var(--bg-secondary, #f9f9f9);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 768px) {
    .page-content {
        padding: var(--spacing-8, 2rem) 0;
    }

    .page-about .content-block,
    .page-faq .faq-item,
    .page-content.legal article {
        padding: var(--spacing-4, 1rem);
    }

    .page-contact .contact-form {
        padding: var(--spacing-5, 1.25rem);
    }
}
