@import url('https://fonts.googleapis.com/css2?family=Content:wght@400;700&display=swap');
/* font-family: "Content", system-ui; */

@font-face {
    font-family: 'Kapakana Regular';
    src: url('Kapakana-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    /* colors */
    --bs-principal: #5F100E;
    --bs-clair: #8C2523;
    --bs-obscure: #320708;
    --bs-decoration: #AE8A78;

    /* fonts */
    --font-principal: "Kapakana Regular", sans-serif;
    --font-secondaire: "Content", system-ui;

    /* sizes */
    --logo: clamp(2rem, 1.4737rem + 2.1053vw, 4rem);
    /* entre 32 et 64px */
    --titre-page: clamp(3rem, -3.6547rem + 14.3885vw, 8rem);
    /* entre 48 et 128px */
    --mini-titre: clamp(1.5rem, -0.4964rem + 4.3165vw, 3rem);
    /* entre 24 et 48px */
    --sublogo: clamp(1.25rem, 0.2518rem + 2.1583vw, 2rem);
    /* entre 20 et 32px */
    --maxi-body: clamp(1rem, 0.375rem + 2vw, 1.5rem);
    /* entre 16 et 24px */
    --body: clamp(0.875rem, 0.3759rem + 1.0791vw, 1.25rem);
    /* entre 14 et 20px Content */
    --mini-body: clamp(0.75rem, 0.4173rem + 0.7194vw, 1rem);
    /* entre 12 et 16px */
    /* spacing */
}


ul {
    list-style: none;
}

.lien {
    text-decoration: none;
    color: var(--bs-principal);
}

.logo {
    font-family: var(--font-principal);
    font-size: var(--logo);
}

.sublogo {
    font-family: var(--font-secondaire);
    font-size: var(--sublogo);
}

.titre-principal {
    font-family: var(--font-principal);
    font-size: var(--titre-page);
}

.subtitre-principal {
    font-family: var(--font-secondaire);
    font-size: var(--maxi-body);
}

.titre-menus {
    font-family: var(--font-principal);
    font-size: var(--sublogo);
}

.espaciado {
    margin-top: 800px;
}

.espaciado-contact {
    margin-top: 300px;
}

.espaciado-menu {
    margin-top: 150px;
}

.espaciado-plats {
    margin-top: 400px;
}

.titre-section {
    font-family: var(--font-principal);
    font-size: var(--logo);
    color: #5F100E;
}

.text-corp {
    font-family: var(--font-secondaire);
    font-size: var(--body);
}

.propos-svg {
    width: 64px;
    height: 64px;
}

.titre-valeurs {
    font-family: var(--font-principal);
    font-size: var(--mini-titre);
}

.text-valeurs {
    font-family: var(--font-secondaire);
    font-size: var(--mini-body);
}

/* images galerie */

.ratio-1 {
    aspect-ratio: 1;
}


/* Navigation */

.nav-link-custom {
    position: relative;
    color: #212529;
    font-weight: 500;
    text-decoration: none;
    padding-bottom: 5px;
    transition: color 0.3s ease;
}

.nav-link-custom::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 2px;
    background-color: #8C2523;
    transition: width 0.3s ease;
}

.nav-link-custom:hover {
    color: #8C2523;
}

.nav-link-custom:hover::after {
    width: 100%;
}


/* Component carte accueil */

.menu-grid {
    display: grid;
    gap: 1rem;
    margin: auto 10rem;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, auto);
    gap: 1rem;
}

.item-1 {
    grid-area: 1 / 1 / 3 / 2;
}

/* filas 1–3, columna 1 */
.item-2 {
    grid-area: 1 / 2 / 3 / 3;
}

/* filas 1–3, columna 2 */
.item-3 {
    grid-area: 1 / 3 / 2 / 4;
}

/* fila 1, columna 3 */
.item-4 {
    grid-area: 2 / 3 / 3 / 4;
}

/* fila 2, columna 3 */
.item-5 {
    grid-area: 3 / 1 / 4 / 3;
}

/* fila 3, columnas 1–3 */
.item-6 {
    grid-area: 3 / 3 / 4 / 4;
}

/* fila 3, columna 3 */

.menu-grid>div {
    position: relative;
    overflow: hidden;
}

.menu-grid img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.menu-grid div:hover img {
    filter: blur(3px);
}

.menu-grid .lien {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: 0;
    color: white;
    background-color: rgba(0, 0, 0, 0.6);
    text-shadow: 0 0 12px rgba(0, 0, 0, 0.9);
    cursor: pointer;
    transform-origin: center;
    padding: 16px 32px;
    border-radius: 30px;
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.menu-grid .lien:hover {
    transform: translate(-50%, -50%) scale(1.1);
    background-color: rgba(255, 255, 255, 0.8);
    color: #5F100E;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3), 0 0 40px rgba(95, 16, 14, 0.2);
    filter: brightness(1.3);
    opacity: 1;
    transition: all 0.4s ease-in-out;
}


/* animation lion */
.leon-dibujo path {
    stroke: white;
    stroke-width: 2;
    fill: none;

    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;
    animation: dibujar 4s ease-in-out infinite alternate;
}

@keyframes dibujar {
    0% {
        stroke-dashoffset: 1000;
    }

    100% {
        stroke-dashoffset: 0;
    }
}

.leon-dibujo path:nth-child(1) {
    animation-delay: 0s;
}

.leon-dibujo path:nth-child(2) {
    animation-delay: 0.2s;
}

.leon-dibujo path:nth-child(3) {
    animation-delay: 0.4s;
}

.leon-dibujo path:nth-child(3) {
    animation-delay: 0.6s;
}

.leon-dibujo path:nth-child(3) {
    animation-delay: 0.8s;
}

.leon-dibujo path:nth-child(3) {
    animation-delay: 1s;
}


/* formulaire de contact */
.form-floating input:focus,
.form-floating select:focus,
.form-floating textarea:focus {
    border-color: #5F100E;
    box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
}

.floating-with-icon {
    position: relative;
}

.floating-with-icon svg {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: #5F100E;
}


/* responsive */
@media (max-width: 1024px) {

    /* Navigation */
    .navNav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100vh;
        background-color: white;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        padding: 2rem;
        transform: translateY(-100%);
        transition: transform 0.3s ease-in-out;
        z-index: 1050;
    }

    .navNav.show {
        transform: translateY(0);
    }

    #menu-toggle {
        z-index: 1100;
    }

    #menu-close {
        position: absolute;
        top: 1rem;
        right: 1rem;
    }

    body.menu-open {
        overflow: hidden;
    }

    .language-switcher-mobile {
        position: absolute;
        bottom: 2rem;
        display: flex;
        gap: 1rem;
        justify-content: center;
    }

    .language-switcher-mobile svg {
        width: 64px;
        height: 64px;
    }

    /* contact */
    .contact-section-top {
        flex-direction: column-reverse;
        justify-content: center;
        align-items: center;
        gap: 2rem;
    }

    .espaciado-contact {
        margin-top: 150px;
    }

    /* plats */
    .decoration-plats {
        display: none;
    }

    .espaciado {
        margin-top: 400px;
    }

    /* Container principal: cambia a columna en lugar de fila */
    .propos-container {
        flex-direction: column;
        align-items: center;
    }

    /* Artículos en stack (uno encima del otro) */
    .propos-container-img,
    .propos-container article {
        width: 90% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Imágenes: ajusta el grid y cambia proporciones */
    .propos-container-img {
        display: none;
    }

    .propos-container-img img {
        width: 100%;
        height: auto;
        object-fit: cover;
    }

    /* Texto “À propos” centrado */
    .propos-container article .titre-section {
        text-align: center;
        width: 100%;
    }

    .propos-container article .border-top {
        margin-left: auto;
        margin-right: auto;
    }

    /* Valores en columna en lugar de fila */
    .liste-valeurs {
        flex-direction: column;
        justify-content: center !important;
        align-items: center !important;
        gap: 2rem;
    }

    .liste-valeurs li {
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
        border-left: none !important;
        border-right: none !important;
        border-top: 1px solid #5F100E;
        padding-top: 1rem;
    }

    .liste-valeurs li:last-child {
        border-bottom: 1px solid #5F100E;
        padding-bottom: 1rem;
    }


}

/* Menos de 1368px: 2 columnas */
@media (max-width: 1368px) {
    .footer {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Menos de 768px: 1 columna */
@media (max-width: 768px) {
    .footer {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
    }

    .menu-cards {
        flex-direction: column;
        align-items: stretch;
        margin: auto 20px;
    }

    .menu-cards .card {
        width: 100% !important;
    }

    .decoration-menu {
        display: none;
    }

    .espaciado-menu {
        margin-top: 0px;
    }

    .filtre-plats {
        margin-top: 20px;
    }

    .container-formulaire {
        margin: 0px !important;
        padding: 0px ! important;
    }

    .menu-grid {
        display: grid;
        grid-template-columns: 1fr;
        /* una sola columna */
        grid-template-rows: auto;
        margin: 0 1rem;
        /* reduce el margen lateral */
        gap: 1rem;
    }

    .menu-grid>div {
        grid-area: unset !important;
        /* quita las áreas personalizadas */
        width: 100%;
        aspect-ratio: 16 / 9;
        /* mantén proporción si quieres */
    }

    .menu-grid img {
        height: auto;
        /* altura automática para que se adapte */
    }

    .text-index-car {
        display: none ! important;
    }

    .text-index-title {
        margin-top: 100px;
    }

    /* index accueil */
    .index-mobile {
        display: flex;
    }

    .carousel-index {
        display: none;
    }

}

@media (max-width: 478px) {
    .logo-contact-top-facebook {
        display: none;
    }

    .espaciado-contact {
        margin-top: 100px;
    }

    .espaciado {
        margin-top: 340px;
    }

    .espaciado-plats {
        margin-top: 270px;
    }

    .liste-valeurs {
        margin: 0 !important;
        padding: 0 !important;
    }

    .galerie-photos>div {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .propos-container {
        flex-direction: column-reverse;
    }
}

@media (min-width: 768px) {
    .index-mobile {
        display: none;
    }
}
