:root{
    --v3m-bg: #f3f3f3;
    --v3m-surface: #ffffff;
    --v3m-text: #1f2328;
    --v3m-text-soft: rgba(31,35,40,.82);
    --v3m-text-muted: rgba(31,35,40,.68);
    --v3m-border: rgba(0,0,0,.08);
    --v3m-accent: #ff6233;
    --v3m-hero-bg: #f5efe8;
    --v3m-shadow: 0 10px 26px rgba(0,0,0,.06);
    --v3m-site-header-h: 0px;
}

html,
body{
    margin: 0;
    padding: 0;
}

.v3-minimal-body{
    background: var(--v3m-bg);
    color: var(--v3m-text);
    font-family: "Lora", Georgia, serif;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.v3m-shell{
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
}

.v3m-hero{
    position: relative;
    overflow: hidden;
    background: var(--v3m-hero-bg, #f5efe8);
    border-bottom: 1px solid var(--v3m-border);
}

.v3m-hero__media{
    position: absolute;
    inset: 0;
    z-index: 0;
}

.v3m-hero__media img{
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.v3m-hero__overlay{
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(255,255,255,.62) 0%, rgba(255,255,255,.86) 100%);
}

.v3-minimal-body.has-site-header .v3m-hero__overlay{
    background: linear-gradient(180deg, rgba(25,25,25,.18) 0%, rgba(255,255,255,.58) 32%, rgba(255,255,255,.88) 100%);
}

.v3m-hero__inner{
    position: relative;
    z-index: 2;
    padding-top: 18px;
    padding-bottom: 20px;
}

.v3-minimal-body.has-site-header .v3m-hero__inner{
    padding-top: calc(var(--v3m-site-header-h) + 16px);
}

.v3m-breadcrumb{
    margin: 0 0 12px;
    padding: 0;
}

.v3m-breadcrumb__list{
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 8px;
    margin: 0;
    padding: 0;
    font-family: "Montserrat", Arial, sans-serif;
    font-size: .72rem;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(31,35,40,.64);
}

.v3m-breadcrumb__item{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.v3m-breadcrumb__item:not(:last-child)::after{
    content: "•";
    color: rgba(31,35,40,.28);
}

.v3m-breadcrumb__link{
    color: inherit;
    text-decoration: none;
    transition: color .18s ease;
}

.v3m-breadcrumb__link:hover{
    color: var(--v3m-accent);
}

.v3m-breadcrumb__current{
    color: var(--v3m-text);
    font-weight: 800;
}

.v3m-hero__copy{
    max-width: 860px;
}

.v3m-eyebrow{
    margin: 0 0 8px;
    font-family: "Montserrat", Arial, sans-serif;
    font-size: .84rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--v3m-accent);
}

.v3m-eyebrow span{
    opacity: .68;
}

.v3m-hero-title{
    margin: 0;
    font-family: "Montserrat", Arial, sans-serif;
    font-size: clamp(1.75rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -.03em;
    color: var(--v3m-text);
    text-wrap: balance;
    max-width: 14ch;
}

.v3m-subtitle{
    margin: 8px 0 0;
    max-width: 62ch;
    font-family: "Lora", Georgia, serif;
    font-size: clamp(.98rem, 1.3vw, 1.08rem);
    line-height: 1.5;
    color: var(--v3m-text-soft);
}

.v3m-main{
    padding: 24px 0 44px;
}

.v3m-main > .v3m-shell{
    min-height: 1px;
}

.page-recette-family .v3m-main{
    padding-top: 20px;
}

.page-recette-family .family-sheet-wrap{
    margin-left: auto;
    margin-right: auto;
}

.page-recette-family .family-sheet{
    box-shadow: 0 12px 28px rgba(0,0,0,.08);
}

.page-recette-family .family-sharebar,
.page-recette-family .rf-actions-bar{
    box-shadow: var(--v3m-shadow);
}

.no-site-footer .v3m-main{
    padding-bottom: 34px;
}

@media (max-width: 1060px){
    .v3m-shell{
        width: min(100% - 24px, 1120px);
    }

    .v3m-hero-title{
        max-width: 15ch;
    }
}

@media (max-width: 900px){
    .v3m-hero__inner{
        padding-top: 16px;
        padding-bottom: 18px;
    }

    .v3-minimal-body.has-site-header .v3m-hero__inner{
        padding-top: calc(var(--v3m-site-header-h) + 14px);
    }

    .v3m-breadcrumb{
        margin-bottom: 10px;
    }

    .v3m-breadcrumb__list{
        font-size: .68rem;
        gap: 4px 7px;
    }

    .v3m-hero-title{
        max-width: 16ch;
        font-size: clamp(1.45rem, 7vw, 2.25rem);
        line-height: 1.03;
    }

    .v3m-subtitle{
        margin-top: 6px;
        font-size: .95rem;
    }

    .v3m-main{
        padding-top: 18px;
        padding-bottom: 36px;
    }
}

@media (max-width: 640px){
    .v3m-shell{
        width: calc(100% - 18px);
    }

    .v3m-hero__inner{
        padding-top: 14px;
        padding-bottom: 16px;
    }

    .v3-minimal-body.has-site-header .v3m-hero__inner{
        padding-top: calc(var(--v3m-site-header-h) + 12px);
    }

    .v3m-breadcrumb{
        margin-bottom: 8px;
    }

    .v3m-breadcrumb__list{
        font-size: .66rem;
        line-height: 1.24;
    }

    .v3m-hero-title{
        max-width: 100%;
        font-size: clamp(1.35rem, 8vw, 1.95rem);
        line-height: 1.04;
        text-wrap: pretty;
    }

    .v3m-subtitle{
        font-size: .92rem;
        line-height: 1.45;
    }

    .v3m-main{
        padding-top: 16px;
        padding-bottom: 30px;
    }
}

@media (prefers-reduced-motion: reduce){
    .v3m-breadcrumb__link{
        transition: none;
    }
}
