/*
Theme Name: CHRU Nancy
Theme URI: https://chru-nancy-2026.dev-commpagnie.com/
Description: Theme enfant pour le site du CHRU de Nancy. Full PHP templates + Gutenberg. Conforme RGAA 4.1.2.
Author: Commpagnie
Author URI: https://commpagnie.com/
Template: hello-elementor
Version: 2.1.0
Text Domain: chru-nancy
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: hospital, accessibility, rgaa
*/

/* ============================================
   Open Sans — Chargement local (RGPD)
   ============================================ */

@font-face {
    font-family: 'Open Sans';
    src: url('./fonts/OpenSans-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    src: url('./fonts/OpenSans-Italic.woff2') format('woff2');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    src: url('./fonts/OpenSans-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    src: url('./fonts/OpenSans-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* ============================================
   Base typographique (Figma CHRU)
   ============================================ */

*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: var(--body-size, 16px);
    font-weight: var(--weight-semibold, 600);
    line-height: 1.5;
    color: var(--chru-blue-text, #2D4356);
    background: var(--chru-white, #FFFFFF);
    max-width: none;
    margin: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Italique : pas de bold (override) */
em, i { font-weight: 400; }

/* Headings — Figma scale */
h1, h2, h3, h4, h5, h6 {
    font-family: 'Open Sans', sans-serif;
    font-weight: var(--weight-bold, 700);
    line-height: 1;
    color: var(--chru-blue-service, #14446B);
    margin-top: 0;
}

h1 { font-size: var(--h1-size, 45px); }
h2 { font-size: var(--h2-size, 24px); }
h3 { font-size: var(--h3-size, 20px); }
h4 { font-size: var(--h4-size, 18px); }

/* Links — Base */
a {
    color: var(--chru-blue-service, #14446B);
    font-weight: 600;
    text-decoration: underline;
    line-height: 21.88px;
}

a:hover,
a:focus {
    color: var(--chru-blue-light, #0096D6);
    font-weight: 700;
}

/* Liens texte dans le contenu — soulignement statique (RGAA), pas d'animation slide */
.chru-content p a,
.chru-content li a,
.entry-content p a,
.entry-content li a,
a.chru-link-more,
.chru-sommaire__link {
    text-decoration: underline;
    text-underline-offset: 0.2em;
}

/* Paragraphs */
p {
    margin-top: 0;
    margin-bottom: 16px;
}

/* Images */
img {
    max-width: 100%;
    height: auto;
}

/* ============================================
   Gutenberg Blocks — Espacement global
   Appliqué dans tous les contextes .chru-content
   (single-post, single-evenement, single-service, etc.)
   ============================================ */

.chru-content > * + * {
    margin-top: 24px;
}

.chru-content > .wp-block-group + .wp-block-group,
.chru-content > .wp-block-columns + .wp-block-columns,
.chru-content > .wp-block-image + .wp-block-image,
.chru-content > .wp-block-cover + .wp-block-cover {
    margin-top: 32px;
}

.chru-content > *:first-child {
    margin-top: 0;
}

/* Blocs Gutenberg avec bordure / fond : padding minimum */
.chru-content .wp-block-group.has-background,
.chru-content .wp-block-group:not(.is-layout-flow) {
    padding: 24px;
    border-radius: 12px;
}

/* ============================================
   Layout — Conteneur global
   Figma frame = 1440px, padding = 45px
   ============================================ */

.chru-container {
    width: 100%;
    max-width: var(--container-max, 1440px);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding, 45px);
    padding-right: var(--container-padding, 45px);
}

@media (max-width: 1024px) {
    .chru-container {
        padding-left: 20px;
        padding-right: 20px;
    }
}