﻿/* ==========================
   FONTS
========================== */
@font-face {
    font-family: "Charmonman";
    src: url("/assets/font/charmonman/Charmonman-Regular.ttf");
    font-weight: 400;
}

@font-face {
    font-family: "Charmonman";
    src: url("/assets/font/charmonman/Charmonman-Bold.ttf");
    font-weight: 700;
}

/* ==========================
   VARIABLES GLOBALES
========================== */
:root {
    --color-white: #ffffff;
    --color-gold: #ffdca8;
    --color-voile: #b4602fb3;
    --color-voile-light: #b4602f4d;
    --color-card-bg: rgba(0, 0, 0, 0.6);
    --radius: 12px;
    --shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* ==========================
   BASE
========================== */
html, body {
    font-family: "Charmonman", Helvetica, Arial, sans-serif;
    background: url("/assets/pictures/fond.jpg") center / cover no-repeat fixed;
    margin: 0;
    padding: 0;
    color: var(--color-white);
    /*height: 100%;*/
}

/*body {
    display: flex;
    flex-direction: column;
}*/

a {
    color: inherit;
    text-decoration: none;
}

.content {
    padding-top: 2.1rem;
}
/*.main-content {
    flex: 1 0 auto;*/ /* pousse le footer en bas si peu de contenu */
/*}*/

/* ==========================
   VOILES TEXTE
========================== */
.text-content,
.text-content-center,
.voile {
    background-color: var(--color-voile);
    padding: 20px 30px;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    line-height: 1.6;
    margin: 20px auto;
}

.text-content {
    font-size: 1.4rem;
}

.text-content-center {
    max-width: 600px;
    display: flex;
    align-items: center;
    font-size: 1.2rem;
}

.voile {
    background-color: var(--color-voile-light);
}

/* ==========================
   IMAGE + TEXTE
========================== */
.row-picture-text {
    display: flex;
    align-items: center;
    gap: 20px;
}

    .row-picture-text img,
    .picture-text img {
        border-radius: var(--radius);
        height: auto;
    }

.picture-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

/* ==========================
   GRILLES D’IMAGES
========================== */
.massage-picture,
.gift-picture {
    display: flex;
    gap: 50px;
    width: 100%;
    justify-content: center;
    align-items: center;
}

    .massage-picture img,
    .gift-picture img {
        max-width: 100%;
        max-height: 220px;
        object-fit: contain;
        border-radius: 10px;
    }

/* Sur mobile, les images passent en colonne */
@media (max-width: 640px) {
    .massage-picture,
    .gift-picture {
        flex-direction: column;
        gap: 15px; /* moins d’espace sur mobile */
    }
}

/* ==========================
   CARD (COMMUN)
========================== */
.card {
    background-color: var(--color-card-bg);
    border: 2px solid var(--color-white);
    border-radius: var(--radius);
    padding: 20px;
    color: var(--color-white);
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Titre commun */
.card-title {
    position: relative;
    text-align: center;
    font-weight: 600;
}

    .card-title::after {
        content: "";
        display: block;
        width: 100%;
        height: 2px;
        margin-top: 6px;
        background-color: var(--color-gold);
    }

/* Contenu texte commun */
.card-info span,
.card-summary {
    line-height: 1.5;
    display: block;
}

/* ==========================
   IMAGE DE CARTE (COMMUN)
========================== */
.card-photo {
    width: 100%;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .card-photo img {
        max-width: 100%;
        max-height: 100%;
        object-fit: contain; /* jamais de crop */
        border-radius: 8px;
    }

/* ==========================
   Footer
========================== */
/* Conteneur principal pour forcer le footer en bas */
.main-page {
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* Hauteur de la page entière */
}


/* Main prend tout l'espace restant */
main {
    flex: 1;
}


/* Footer */
.site-footer {
    flex-shrink: 0; /* jamais compressé */
    padding: 20px 10px;
    text-align: center;
    font-size: 1rem;
    color: white;
    background: rgba(0, 0, 0, 0.6);
}


    .site-footer a {
        color: #ffdca8;
        text-decoration: none;
        margin: 0 8px;
    }


        .site-footer a:hover {
            text-decoration: underline;
        }