/*
Theme Name:     Maison Dureau
Theme URI:      https://maisondureau.fr
Description:    Thème enfant GeneratePress sur mesure pour Maison Dureau — peinture d'art, restauration de façades et décor de patrimoine depuis 1936.
Author:         OneTab IT Services
Author URI:     https://onetab.fr
Template:       generatepress
Version:        1.0.0
Text Domain:    maisondureau
*/

/* ───────────────────────────────────────────────────────────────────
   DESIGN SYSTEM — Maison Dureau
   Direction : éditorial / luxe / patrimonial
   Palette : pierre de taille, encre de Chine, or vieilli
   ─────────────────────────────────────────────────────────────────── */

:root {
    /* Couleurs */
    --md-noir:           #14110f;   /* encre de Chine */
    --md-noir-doux:      #2a2520;
    --md-creme:          #f4efe6;   /* badigeon clair */
    --md-creme-fonce:    #e7dfd1;
    --md-pierre:         #c8baa3;   /* pierre de Paris */
    --md-or:             #b89968;   /* or vieilli, rare et précieux */
    --md-or-clair:       #d4b985;
    --md-bordeaux:       #5c1f1f;   /* accent profond */
    --md-blanc:          #ffffff;

    /* Typographie */
    --md-font-display:   "Cormorant Garamond", "Playfair Display", "Times New Roman", serif;
    --md-font-serif:     "Lora", "Crimson Pro", Georgia, serif;
    --md-font-sans:      "Inter Tight", "Helvetica Neue", Arial, sans-serif;

    /* Espacements (échelle modulaire) */
    --md-space-3xs: 0.25rem;
    --md-space-2xs: 0.5rem;
    --md-space-xs:  0.75rem;
    --md-space-sm:  1rem;
    --md-space-md:  1.5rem;
    --md-space-lg:  2.5rem;
    --md-space-xl:  4rem;
    --md-space-2xl: 6rem;
    --md-space-3xl: 9rem;

    /* Conteneurs */
    --md-container:     min(1280px, 92vw);
    --md-container-narrow: min(780px, 90vw);

    /* Transitions */
    --md-ease:          cubic-bezier(0.16, 1, 0.3, 1);
    --md-duration:      600ms;
}

/* ───────────────────────────────────────────────────────────────────
   RESET DOUX
   ─────────────────────────────────────────────────────────────────── */

body.maison-dureau {
    font-family: var(--md-font-serif);
    color: var(--md-noir);
    background-color: var(--md-creme);
    font-size: 17px;
    line-height: 1.7;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

body.maison-dureau h1,
body.maison-dureau h2,
body.maison-dureau h3,
body.maison-dureau h4 {
    font-family: var(--md-font-display);
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--md-noir);
}

body.maison-dureau h1 {
    font-size: clamp(2.5rem, 5vw, 4.5rem);
    line-height: 1.05;
    font-weight: 300;
}

body.maison-dureau h2 {
    font-size: clamp(2rem, 3.5vw, 3rem);
    line-height: 1.15;
    margin-block: var(--md-space-xl) var(--md-space-md);
}

body.maison-dureau h3 {
    font-size: clamp(1.4rem, 2.2vw, 1.85rem);
    line-height: 1.25;
    margin-block: var(--md-space-lg) var(--md-space-sm);
}

body.maison-dureau .md-eyebrow {
    font-family: var(--md-font-sans);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--md-or);
    font-weight: 500;
    margin-bottom: var(--md-space-xs);
    display: inline-block;
}

body.maison-dureau a {
    color: var(--md-noir);
    text-decoration: underline;
    text-decoration-color: var(--md-or);
    text-decoration-thickness: 1px;
    text-underline-offset: 4px;
    transition: text-decoration-color var(--md-duration) var(--md-ease);
}

body.maison-dureau a:hover {
    text-decoration-color: var(--md-noir);
}

/* ───────────────────────────────────────────────────────────────────
   COMPOSANTS — Bouton
   ─────────────────────────────────────────────────────────────────── */

.md-btn {
    display: inline-block;
    padding: 1rem 2rem;
    font-family: var(--md-font-sans);
    font-size: 0.85rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    background: var(--md-noir);
    color: var(--md-creme);
    text-decoration: none;
    border: 1px solid var(--md-noir);
    transition: background var(--md-duration) var(--md-ease),
                color      var(--md-duration) var(--md-ease);
}
.md-btn:hover {
    background: var(--md-or);
    color: var(--md-noir);
    border-color: var(--md-or);
}
.md-btn--ghost {
    background: transparent;
    color: var(--md-noir);
}
.md-btn--ghost:hover {
    background: var(--md-noir);
    color: var(--md-creme);
}

/* ───────────────────────────────────────────────────────────────────
   COMPOSANTS — Hero Accueil
   ─────────────────────────────────────────────────────────────────── */

.md-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background: var(--md-noir);
    color: var(--md-creme);
}
.md-hero__media {
    position: absolute;
    inset: 0;
    z-index: 1;
}
.md-hero__media img,
.md-hero__media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.65) contrast(1.05);
}
.md-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: linear-gradient(180deg, transparent 40%, rgba(20, 17, 15, 0.7) 100%);
}
.md-hero__content {
    position: relative;
    z-index: 3;
    width: var(--md-container);
    margin: 0 auto;
    padding-block: var(--md-space-3xl) var(--md-space-2xl);
}
.md-hero__title {
    font-size: clamp(3rem, 7vw, 6rem);
    color: var(--md-creme);
    max-width: 18ch;
    margin: 0 0 var(--md-space-md);
}
.md-hero__tagline {
    font-family: var(--md-font-sans);
    font-size: 0.9rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--md-or-clair);
    margin-bottom: var(--md-space-md);
}

/* ───────────────────────────────────────────────────────────────────
   COMPOSANTS — Galerie de chantiers
   ─────────────────────────────────────────────────────────────────── */

.md-section {
    padding-block: var(--md-space-2xl);
}
.md-container {
    width: var(--md-container);
    margin-inline: auto;
}
.md-container--narrow {
    width: var(--md-container-narrow);
    margin-inline: auto;
}

.md-galerie {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--md-space-lg);
}

.md-card {
    position: relative;
    cursor: pointer;
    background: var(--md-noir);
    overflow: hidden;
    aspect-ratio: 4 / 5;
    border: 1px solid transparent;
    transition: border-color var(--md-duration) var(--md-ease);
}
.md-card:hover {
    border-color: var(--md-or);
}
.md-card__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--md-ease),
                filter    var(--md-duration) var(--md-ease);
    filter: brightness(0.85);
}
.md-card:hover .md-card__img {
    transform: scale(1.04);
    filter: brightness(1);
}
.md-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--md-space-md);
    background: linear-gradient(180deg, transparent, rgba(20, 17, 15, 0.85));
    color: var(--md-creme);
    transform: translateY(0);
}
.md-card__title {
    font-family: var(--md-font-display);
    font-size: 1.35rem;
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 var(--md-space-3xs);
    color: var(--md-creme);
}
.md-card__subtitle {
    font-family: var(--md-font-sans);
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--md-or-clair);
    opacity: 0.85;
}

/* ───────────────────────────────────────────────────────────────────
   COMPOSANTS — Modale chantier
   ─────────────────────────────────────────────────────────────────── */

.md-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    background: rgba(20, 17, 15, 0.92);
    backdrop-filter: blur(8px);
    overflow-y: auto;
}
.md-modal.is-open {
    display: block;
    animation: md-fade-in 0.4s var(--md-ease);
}
@keyframes md-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.md-modal__inner {
    width: min(1100px, 94vw);
    margin: 4rem auto;
    background: var(--md-creme);
    color: var(--md-noir);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.4);
}
.md-modal__close {
    position: fixed;
    top: 1.5rem;
    right: 1.5rem;
    width: 48px;
    height: 48px;
    border: 1px solid var(--md-creme);
    background: transparent;
    color: var(--md-creme);
    cursor: pointer;
    font-family: var(--md-font-sans);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    transition: all var(--md-duration) var(--md-ease);
    z-index: 10;
}
.md-modal__close:hover {
    background: var(--md-or);
    color: var(--md-noir);
    border-color: var(--md-or);
}
.md-modal__hero {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--md-noir);
}
.md-modal__hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.md-modal__body {
    padding: var(--md-space-xl) var(--md-space-lg);
}
.md-modal__meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: var(--md-space-md);
    border-top: 1px solid var(--md-pierre);
    border-bottom: 1px solid var(--md-pierre);
    padding-block: var(--md-space-md);
    margin-block: var(--md-space-lg);
}
.md-modal__meta-item dt {
    font-family: var(--md-font-sans);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--md-or);
    margin-bottom: var(--md-space-3xs);
}
.md-modal__meta-item dd {
    font-family: var(--md-font-display);
    font-size: 1.15rem;
    margin: 0;
}
.md-modal__galerie {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--md-space-2xs);
    margin-top: var(--md-space-lg);
}
.md-modal__galerie img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    cursor: zoom-in;
    transition: opacity var(--md-duration) var(--md-ease);
}
.md-modal__galerie img:hover {
    opacity: 0.85;
}

/* ───────────────────────────────────────────────────────────────────
   ANIMATIONS de révélation au scroll
   ─────────────────────────────────────────────────────────────────── */

.md-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 1s var(--md-ease),
                transform 1s var(--md-ease);
}
.md-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ───────────────────────────────────────────────────────────────────
   RESPONSIVE
   ─────────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .md-modal__inner { margin: 1.5rem auto; }
    .md-modal__body  { padding: var(--md-space-lg) var(--md-space-md); }
    .md-galerie      { grid-template-columns: 1fr; }
}
