/**
 * EAAS Theme - Content Styles
 *
 * @package    EAAS
 * @version    2.5
 * @author     Rodolphe
 * @link       https://enaccordavecsoi.fr
 * @file       content.css
 */

.site-content {
    margin-top: var(--header-height);
    padding-top: var(--page-padding-top, 40px);
    min-height: calc(100vh - var(--header-height) - 300px);
    padding-bottom: var(--page-padding-bottom, 60px);
    padding-left: var(--page-edge-spacing, 0px);
    padding-right: var(--page-edge-spacing, 0px);
}

/* Elementor pages: remove extra padding from site-content, Elementor handles spacing */
.elementor-page .site-content {
    padding-top: 0;
    padding-bottom: 0;
}

body.admin-bar .site-content {
    margin-top: calc(var(--header-height) + 32px);
}

/* Fix for Elementor Editor */
body.elementor-editor-active .site-content {
    margin-top: var(--header-height);
    padding-top: var(--section-padding, 80px);
}

.content-wrapper {
    /* Width and horizontal padding handled by layout-width.css */
    padding-top: var(--spacing-3xl, 60px);
    padding-bottom: var(--spacing-3xl, 60px);
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - var(--header-height));
}

.content-wrapper > *:not(.elementor) {
    flex: 1;
}

/* Let Elementor handle its own layout when it controls the page */
.elementor-page .content-wrapper {
    padding-top: 0;
    padding-bottom: 0;
    display: block;
    min-height: auto;
}

.content-wrapper h2:not(.elementor-heading-title) {
    margin-top: var(--spacing-2xl, 40px);
    margin-bottom: var(--spacing-md, 20px);
}

.content-wrapper h3:not(.elementor-heading-title) {
    margin-top: var(--spacing-lg, 30px);
    margin-bottom: var(--spacing-sm, 15px);
}

/* Hide default page title on homepage to avoid "black square" or duplication */
.home .entry-header,
.page-template-default.home .entry-title {
    display: none !important;
}

article {
    margin-bottom: var(--spacing-2xl, 50px);
    padding-bottom: var(--spacing-2xl, 40px);
    border-bottom: var(--border-width, 1px) solid var(--border-color, rgba(0,0,0,0.08));
}

article:last-child {
    border-bottom: none;
}

article h2 a {
    color: var(--primary-color);
    transition: var(--transition);
}

article h2 a:hover {
    color: var(--secondary-color);
}

.entry-content {
    font-size: var(--font-size-base, 16px);
    line-height: var(--line-height-base, 1.6);
}

body:not(.elementor-page) .entry-content {
    color: var(--text-color);
}

.entry-content p {
    margin-bottom: var(--spacing-md, 20px);
}

.pagination {
    display: flex;
    gap: var(--spacing-sm, 10px);
    justify-content: center;
    margin-top: var(--spacing-2xl, 50px);
}

.pagination a,
.pagination span {
    padding: var(--spacing-sm, 10px) var(--spacing-md, 18px);
    background: var(--light-bg);
    color: var(--text-color);
    border-radius: var(--border-radius-md, 8px);
    transition: var(--transition);
    font-weight: var(--font-weight-medium, 500);
}

.pagination a:hover {
    background: var(--secondary-color);
    color: var(--white);
    transform: translateY(-2px);
}

.pagination .current {
    background: var(--secondary-color);
    color: var(--white);
}

.content-wrapper ul:not(.primary-menu):not(.sub-menu):not([class*="elementor"]) {
    list-style: none;
    padding-left: 0;
}

.content-wrapper ul:not(.primary-menu):not(.sub-menu):not([class*="elementor"]) > li:not([class*="elementor"]) {
    padding-left: var(--spacing-lg, 30px);
    position: relative;
    margin-bottom: var(--spacing-sm, 12px);
}

.content-wrapper ul:not(.primary-menu):not(.sub-menu):not([class*="elementor"]) > li:not([class*="elementor"])::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--accent-color);
    font-weight: var(--font-weight-bold, bold);
    font-size: var(--font-size-lg, 18px);
}

.section-alt {
    background: var(--warm-beige);
    padding: var(--section-spacing, 80px) 0;
}

.section-primary {
    background: linear-gradient(135deg, var(--soft-blue) 0%, var(--warm-beige) 100%);
    padding: var(--section-spacing, 80px) 0;
}

hr {
    border: none;
    height: var(--underline-thickness, 2px);
    background: linear-gradient(90deg, transparent, var(--secondary-color), transparent);
    margin: var(--spacing-2xl, 40px) 0;
}

blockquote {
    margin: var(--spacing-lg, 30px) 0;
    padding: var(--spacing-lg, 25px) var(--spacing-lg, 30px);
    background: var(--soft-blue);
    border-left: var(--blockquote-border-width, 4px) solid var(--secondary-color);
    border-radius: var(--border-radius-md, 8px);
    font-style: italic;
    color: var(--text-color);
}

blockquote p {
    margin: 0;
    font-size: var(--font-size-lg, 18px);
    line-height: var(--line-height-base, 1.6);
}

/* ========================================
   Responsive Content
   ======================================== */

/* Tablet Landscape (max 1199px) */
@media screen and (max-width: 1199px) {
    .content-wrapper {
        padding-top: var(--spacing-2xl, 50px);
        padding-bottom: var(--spacing-2xl, 50px);
    }
}

/* Tablet Portrait (max 991px) */
@media screen and (max-width: 991px) {

    .content-wrapper {
        padding-top: var(--spacing-xl, 40px);
        padding-bottom: var(--spacing-xl, 40px);
    }

    article {
        margin-bottom: var(--spacing-xl, 40px);
        padding-bottom: var(--spacing-xl, 30px);
    }

    .section-alt,
    .section-primary {
        padding: var(--section-spacing-tablet, 60px) 0;
    }
}

/* Mobile + Admin Bar (max 782px) */
@media (max-width: 782px) {
    body.admin-bar .site-content {
        margin-top: calc(var(--header-height) + 46px);
    }
}

/* Mobile (max 767px) */
@media screen and (max-width: 767px) {
    .site-content {
        margin-top: calc(var(--header-height-mobile, 70px));
    }

    .content-wrapper {
        padding: var(--spacing-lg, 25px) var(--container-padding-mobile, 15px);
    }

    .content-wrapper h1:not(.elementor-heading-title) {
        font-size: var(--font-size-h1-mobile, 32px);
    }

    .content-wrapper h2:not(.elementor-heading-title) {
        font-size: var(--font-size-h2-mobile, 26px);
        margin-top: var(--spacing-xl, 30px);
    }

    .content-wrapper h3:not(.elementor-heading-title) {
        margin-top: var(--spacing-lg, 20px);
    }

    article {
        margin-bottom: var(--spacing-lg, 30px);
        padding-bottom: var(--spacing-lg, 25px);
    }

    .entry-content {
        font-size: var(--font-size-base-mobile, 14px);
    }

    .pagination {
        gap: var(--spacing-xs, 6px);
        flex-wrap: wrap;
    }

    .pagination a,
    .pagination span {
        padding: var(--spacing-xs, 8px) var(--spacing-sm, 14px);
        font-size: var(--font-size-sm, 14px);
        min-width: 40px;
        min-height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    blockquote {
        padding: var(--spacing-md, 20px);
        margin: var(--spacing-md, 20px) 0;
    }

    blockquote p {
        font-size: var(--font-size-base, 16px);
    }

    .section-alt,
    .section-primary {
        padding: var(--section-spacing-mobile, 40px) 0;
    }

    hr {
        margin: var(--spacing-xl, 30px) 0;
    }
}

/* Small Mobile (max 480px) */
@media screen and (max-width: 480px) {
    .content-wrapper {
        max-width: 100%;
        padding: var(--spacing-md, 20px) var(--spacing-sm, 12px);
    }

    .pagination a,
    .pagination span {
        padding: var(--spacing-xs, 6px) var(--spacing-sm, 10px);
        font-size: var(--font-size-xs, 13px);
        min-width: 36px;
        min-height: 36px;
    }

    blockquote {
        padding: var(--spacing-md, 15px);
    }

    blockquote p {
        font-size: var(--font-size-sm, 15px);
    }
}

/* Very Small Mobile (max 360px) */
@media screen and (max-width: 360px) {
    .content-wrapper {
        padding: var(--spacing-md, 15px) var(--spacing-sm, 10px);
    }
}

.post-thumbnail {
    margin: var(--spacing-md, 20px) 0;
}

.post-thumbnail img {
    width: 100%;
    height: auto;
    display: block;
}
