
/* sr-only — masque visuellement, reste accessible */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
/* =============================================================
 * style.css — Optimisé par optimize_css.py v6.7.0
 * Variables CSS extraites, propriétés factorisées
 * ============================================================= */

/* --- Reset minimal --- */
* { margin: 0; padding: 0; box-sizing: border-box; }
body { overflow-x: hidden; }

/* --- Variables CSS (extraites automatiquement) --- */
:root {
  --font-weight-400: 400;
  --font-ballers-delight: "ballers-delight";
  --color-b95128: #B95128;
  --font-size-34-67px: 34.67px;
  --color-efede5: #EFEDE5;
  --font-size-clamp-29-9px-1-8064r: clamp(29.9px, 1.8064rem + 0.266vw, 34.01px);
  --font-size-clamp-12-1px-0-7309r: clamp(12.1px, 0.7309rem + 0.1081vw, 13.77px);
  --font-futura: Futura;
  --font-weight-700: 700;
  --line-height-14-79px: 14.79px;
  --gap-20-24px: 20.24px;
}

/* --- Classes optimisées --- */

/* =============================================================
 * Reset responsive minimal
 * Généré par fluidify_css.py v3.0.0
 * ============================================================= */
*, *::before, *::after {
  box-sizing: border-box;
}

/* =============================================================
 * CSS extrait du HTML par extract_styles.py v3.0.0
 * 1 bloc(s) <style> fusionné(s)
 * NE PAS MODIFIER — fichier regénéré automatiquement
 * ============================================================= */
/* Reset minimal */
    *, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.page__img {
  flex: 1 1 0;
  height: 388.26px;
  max-width: 400px;
  min-width: 250px;
  max-height: 388.26px;
  min-height: 242.66px;
  object-fit: cover;
  object-position: center;
}

.page__mentions-legales-128d {
  font-size: clamp(22px, 1.2503rem + 0.532vw, 30.22px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__mentions-legales {
  align-self: stretch;
}

.page__politique-de-e0e1-f680 {
  font-size: clamp(22px, 1.2503rem + 0.532vw, 30.22px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__politique-de-e0e1 {
  align-self: stretch;
}

.page__contact-contact-3d4c {
  font-size: clamp(25.87px, 1.43rem + 0.7974vw, 38.19px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__contact-contact-3d4d {
  font-size: clamp(25.87px, 1.5796rem + 0.1592vw, 28.33px);
  font-family: Montserrat;
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__contact-contact-70f7 {
  align-self: stretch;
  height: 83.10px;
  text-align: right;
}

.page__instagram-span {
  font-size: clamp(32px, 1.9061rem + 0.4006vw, 38.19px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__instagram {
  width: 363.57px;
  height: 43.44px;
  text-align: right;
}

.page__img-2 {
  width: 96.32px;
  height: 95.75px;
  object-fit: cover;
  object-position: center;
}

.page__img-3 {
  width: 601.30px;
  height: 339.27px;
  object-fit: cover;
  object-position: center;
}

.page__notre-menu-est-367b-f368 {
  font-size: clamp(23.9px, 1.3697rem + 0.5294vw, 32.08px);
  font-family: "aviano-sans";
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: white;
}

.page__notre-menu-est-367b {
  align-self: stretch;
}

.page__rectangle-9 {
  width: 100%;
  height: 100.0000%;
  left: 0.0000%;
  top: 0.0000%;
  position: absolute;
  background: linear-gradient(90deg, #EFEDE5 0%, #E7E1CA 100%);
  box-shadow: 3.1465370655059814px 6.293074131011963px 6.712612152099609px 2.097691297531128px rgba(0, 0, 0, 0.80);
  border-radius: 20.98px;
  border: 0.52px white solid;
}

.page__nous-contacter-span {
  font-size: clamp(26.38px, 1.5118rem + 0.5845vw, 35.41px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__nous-contacter {
  width: 433.17px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  top: 0;
  bottom: 0;
  margin-top: auto;
  margin-bottom: auto;
  position: absolute;
  z-index: 1;
  text-align: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
}

.page__img-4 {
  width: 226.32px;
  height: 182.01px;
  object-fit: cover;
  object-position: center;
}

.page__bouchees-aperitives-db0d {
  font-size: var(--font-size-clamp-29-9px-1-8064r);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__bouchees-aperitives {
  align-self: stretch;
  text-align: center;
}

.page__maki-facon-croque-c31b {
  font-size: var(--font-size-clamp-12-1px-0-7309r);
  font-family: var(--font-futura);
  font-weight: var(--font-weight-700);
  line-height: var(--line-height-14-79px);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__maki-facon-croque-1c0b {
  align-self: stretch;
  text-align: center;
}

.page__plats-a-partager-8c2b {
  font-size: var(--font-size-clamp-29-9px-1-8064r);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: black;
}

.page__plats-a-partager {
  align-self: stretch;
  text-align: center;
}

.page__aubergine-rotie-9cb1 {
  font-size: var(--font-size-clamp-12-1px-0-7309r);
  font-family: var(--font-futura);
  font-weight: var(--font-weight-700);
  line-height: var(--line-height-14-79px);
  word-wrap: break-word;
  color: black;
}

.page__aubergine-rotie-f40b {
  align-self: stretch;
  text-align: center;
}

.page__becs-sucres-span {
  font-size: var(--font-size-clamp-29-9px-1-8064r);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__becs-sucres {
  align-self: stretch;
  text-align: center;
}

.page__mousse-chocolat-6245 {
  font-size: var(--font-size-clamp-12-1px-0-7309r);
  font-family: var(--font-futura);
  font-weight: var(--font-weight-700);
  line-height: var(--line-height-14-79px);
  word-wrap: break-word;
  color: var(--color-b95128);
}

.page__mousse-chocolat-1ef0 {
  align-self: stretch;
  text-align: center;
}

.page__accueil-span {
  font-size: var(--font-size-34-67px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-efede5);
}

.page__accueil {
  text-align: center;
}

.page__menu-02-span {
  font-size: var(--font-size-34-67px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-efede5);
}

.page__menu-02 {
  opacity: 0.60;
  text-align: center;
}

.page__photos-span {
  font-size: var(--font-size-34-67px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-efede5);
}

.page__photos {
  opacity: 0.60;
  text-align: center;
}

.page__contact-span {
  font-size: var(--font-size-34-67px);
  font-family: var(--font-ballers-delight);
  font-weight: var(--font-weight-400);
  word-wrap: break-word;
  color: var(--color-efede5);
}

.page__contact {
  opacity: 0.60;
  text-align: center;
}

.page__img-5 {
  width: 118.33px;
  height: 41px;
  object-fit: cover;
  object-position: center;
}

.page__texte-gauche {
  flex: 1 1 0;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 43.44px;
}

.page__bloc-1 {
  width: 469.71px;
  height: 498.86px;
  overflow: hidden;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: var(--gap-20-24px);
  padding-left: 13.65px;
  padding-right: 13.65px;
}

.page__bloc-2 {
  width: 469.71px;
  height: 614.57px;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: var(--gap-20-24px);
  padding-left: 13.65px;
  padding-right: 13.65px;
}

.page__bloc-3 {
  width: 469.71px;
  height: 501.43px;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: var(--gap-20-24px);
  padding-left: 13.65px;
  padding-right: 13.65px;
}

.page__menu-droite-02 {
  width: 654px;
  height: 55px;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.50);
  border-bottom-right-radius: 25px;
  border-bottom-left-radius: 25px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 63px;
  padding: 30px 10px;
}

.page__insta {
  width: 100%;
  align-self: stretch;
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
}

.page__bouton-droite {
  width: 100%;
  height: 62.93px;
  position: relative;
}

.page__bloc-devor-menu {
  width: 306.68px;
  height: 168.44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 22.89px;
}

.page__bloc-gauche {
  flex: 1 1 0;
  align-self: stretch;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 40px;
  padding-left: 40px;
  padding-right: 40px;
}

.page__f-3-bloc {
  width: 100%;
  align-self: stretch;
  display: inline-flex;
  justify-content: center;
  align-items: flex-start;
  gap: 85.71px;
  padding: 21.86px 0;
}

.page__menu-droite {
  width: 36px;
  height: 44px;
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 28px;
}

.page__texte {
  flex: 1 1 0;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
}

.page__bouton {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 52.14px;
}

.page__titre {
  width: 442.29px;
  height: 168.86px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 118.09px;
}

.page__texte-02 {
  width: 100%;
  height: 52px;
  flex-grow: 1;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding-left: 10px;
  padding-right: 10px;
}

.page__bloc-droit {
  flex: 1 1 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-left: 41.55px;
  padding-right: 41.55px;
}

.page__bloc-droite {
  width: 1064.59px;
  height: 339.38px;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 53.19px;
}

.page__bloc-menu {
  width: 1830.86px;
  height: 787.71px;
  background: rgba(239, 237, 229, 0.60);
  box-shadow: 3.661343812942505px 2.4408957958221436px 6.041216850280762px 1.8306719064712524px rgba(0, 0, 0, 0.35);
  overflow: hidden;
  outline: 3.05px #B95128 solid;
  outline-offset: -3.05px;
  backdrop-filter: blur(4px);
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 17.14px;
  padding: 2.44px 0;
}

.page__menu-active-accueil {
  width: 100%;
  height: 52px;
  align-self: stretch;
  background: #B95128;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.50);
  overflow: hidden;
  border-bottom: 1px black solid;
  display: inline-flex;
  justify-content: flex-start;
  align-items: flex-start;
}

.page__footer-vh-25 {
  width: 100%;
  height: 25.3165%;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  bottom: 0.0000%;
  position: absolute;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(./assets/img/image-1.png);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.page__container-2-vh-75 {
  width: 100%;
  height: 28.6131%;
  left: 0.0000%;
  top: 49.0881%;
  position: absolute;
  z-index: 1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  background-image: url(./assets/img/image-4.png);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8.44px;
  padding-left: 122.41px;
  padding-right: 123.26px;
}

.page__bloc {
  width: 100%;
  height: 927px;
  align-self: stretch;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}

.page__menu {
  width: 100%;
  height: 2.8619%;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  top: 0.0000%;
  position: absolute;
  z-index: 3;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
}

.page__container-1-hero-vh-9aa7 {
  width: 100%;
  height: 51.0182%;
  left: 0.0000%;
  top: 0.1651%;
  position: absolute;
  z-index: 2;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(./assets/img/image-6.png);
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.page__desktop {
  width: 100%;
  height: 1817px;
  position: relative;
  background: white;
  overflow: hidden;
}

/* --- Blocs @media (responsive) --- */

@media (max-width: 370px) {
  .page__desktop {
    height: 3465px;
    overflow: hidden;
  }
  .page__img {
    width: 100%;
    height: 286.34px;
    min-width: 100px;
    min-height: 97.07px;
    align-self: stretch;
  }
  .page__mentions-legales {
    text-align: center;
  }
  .page__politique-de-e0e1 {
    text-align: center;
  }
  .page__contact-contact-70f7 {
    width: 312px;
    height: 57px;
    text-align: center;
  }
  .page__instagram {
    width: 246.22px;
    height: 29.42px;
    text-align: center;
  }
  .page__img-2 {
    width: 235px;
    height: 234px;
  }
  .page__img-3 {
    align-self: stretch;
    height: 151.67px;
    width: auto;
  }
  .page__notre-menu-est-367b {
    text-align: center;
  }
  .page__rectangle-9 {
    box-shadow: 2.343841791152954px 4.687683582305908px 5.0001959800720215px 1.5625611543655396px rgba(0, 0, 0, 0.80);
    border-radius: 15.63px;
    border: 0.39px white solid;
  }
  .page__nous-contacter {
    width: 322.67px;
  }
  .page__img-4 {
    width: 198.99px;
    height: 160.03px;
  }
  .page__maki-facon-croque-c31b {
    line-height: 13px;
  }
  .page__aubergine-rotie-9cb1 {
    line-height: 13px;
  }
  .page__mousse-chocolat-6245 {
    line-height: 13px;
  }
  .page__menu-02-span {
    width: 100%;
    height: 1.5007%;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: 0.0000%;
    position: absolute;
    z-index: 3;
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: inherit;
    font-weight: normal;
    color: inherit;
  }
  .page__texte-gauche {
    align-self: stretch;
    display: flex;
    gap: 50px;
  }
  .page__bloc-1 {
    width: 100%;
    height: 403px;
    padding-left: 12px;
    padding-right: 12px;
    align-self: stretch;
    display: flex;
    gap: 17.80px;
  }
  .page__bloc-2 {
    width: 100%;
    padding-left: 12px;
    padding-right: 12px;
    align-self: stretch;
    display: flex;
    gap: 17.80px;
    height: auto;
  }
  .page__bloc-3 {
    width: 100%;
    padding-left: 12px;
    padding-right: 12px;
    align-self: stretch;
    display: flex;
    gap: 17.80px;
    height: auto;
  }
  .page__insta {
    height: 337px;
    padding-top: 24px;
    padding-bottom: 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .page__bouton-droite {
    height: 46.88px;
  }
  .page__bloc-devor-menu {
    width: 269.63px;
    height: 148.10px;
    gap: 20.12px;
  }
  .page__bloc-gauche {
    width: 100%;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
  }
  .page__f-3-bloc {
    padding-top: 19.22px;
    padding-bottom: 19.22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 48px;
  }
  .page__texte {
    align-self: stretch;
    display: flex;
    gap: 50px;
  }
  .page__bouton {
    gap: 38.84px;
  }
  .page__titre {
    width: 100%;
    height: 148.10px;
    align-self: stretch;
    gap: 103.83px;
  }
  .page__bloc-droit {
    width: 100%;
    align-self: stretch;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
  }
  .page__bloc-droite {
    align-self: stretch;
    height: 475.44px;
    padding-left: 11.72px;
    padding-right: 11.72px;
    display: flex;
    justify-content: center;
    gap: 48.81px;
    width: auto;
  }
  .page__bloc-menu {
    width: 100%;
    height: 1600px;
    padding-top: 2.85px;
    padding-bottom: 2.85px;
    box-shadow: 4.2715678215026855px 2.8477118015289307px 7.048086643218994px 2.1357839107513428px rgba(0, 0, 0, 0.35);
    outline: 3.56px #B95128 solid;
    outline-offset: -3.56px;
    backdrop-filter: blur(4.66px);
    display: flex;
    gap: 0;
  }
  .page__footer-vh-25 {
    height: 28.8600%;
    background-image: url(./assets/img/image-10.png);
    flex-direction: column;
  }
  .page__container-2-vh-75 {
    height: 23.6670%;
    padding-left: 9.76px;
    padding-right: 9.76px;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: 48.7437%;
    background-image: url(./assets/img/image-13.png);
    flex-direction: column;
    gap: 50.77px;
  }
  .page__bloc {
    height: 1710px;
    padding-top: 25px;
    padding-bottom: 25px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    width: auto;
  }
  .page__container-1-hero-vh-9aa7 {
    height: 49.3506%;
    padding-left: 18px;
    padding-right: 18px;
    top: 1.4430%;
    background-image: url(./assets/img/image-15.png);
  }
}

@media (max-width: 370px) {
      body {
        max-width: 375px;
        overflow-x: hidden;
        margin: 0 auto;
      }
    }

/* ======= NEW MENU COMPONENT ======= */
.menu-bg {
  width: 100%;
  height: 107.5269%;
  left: 0.0000%;
  top: 0;
  bottom: 0;
  margin-top: auto;
  margin-bottom: auto;
  position: absolute;
  object-fit: cover;
  object-position: center;
}

.logo-1-devor-1 {
  width: 181px;
  height: 64px;
  object-fit: cover;
  object-position: center;
}

.accueil-span {
  font-size: 40.44px;
  font-family: "ballers-delight";
  font-weight: 400;
  word-wrap: break-word;
  color: #EFEDE5;
}

.accueil {
  width: 147.78px;
  text-align: center;
}

.menu-span {
  font-size: 40.44px;
  font-family: "ballers-delight";
  font-weight: 400;
  word-wrap: break-word;
  color: #EFEDE5;
}

.menu {
  width: 216.22px;
  opacity: 0.60;
  text-align: center;
}

.photos-span {
  font-size: 40.44px;
  font-family: "ballers-delight";
  font-weight: 400;
  word-wrap: break-word;
  color: #EFEDE5;
}

.photos {
  width: 216.22px;
  opacity: 0.60;
  text-align: center;
}

.contact-span {
  font-size: 40.44px;
  font-family: "ballers-delight";
  font-weight: 400;
  word-wrap: break-word;
  color: #EFEDE5;
}

.contact {
  width: 216.22px;
  opacity: 0.60;
  text-align: center;
}

.menu-droite {
  width: 849px;
  height: 93px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 17.50px;
}

.logo {
  width: 100%;
  height: 93px;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 10px;
  padding-right: 10px;
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.menu-active-accueil-e82f {
  width: 100%;
  align-self: stretch;
  position: relative;
  display: inline-flex;
  justify-content: flex-start;
  align-items: flex-start;
}

.burger-menu-btn {
  display: none;
  cursor: pointer;
  z-index: 5;
}

@media (max-width: 767px) {
  .menu-bg {
    height: 100%;
    top: 0;
    z-index: 2;
    bottom: auto;
  }
  .logo-1-devor-1 {
    width: 147px;
    height: 52px;
  }
  
  .burger-menu-btn {
    display: block;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%); /* Centered vertically relative to the logo container */
  }

  .logo {
    padding-top: 19px;
    padding-bottom: 19px;
    align-self: stretch;
    z-index: 5;
    flex-direction: row; /* keep it row to align logo and burger */
    justify-content: center; /* Center the Devor logo */
    padding-left: 0;
    padding-right: 0;
    background: #B95128;
  }

  .menu-active-accueil-e82f {
    display: flex;
    flex-direction: column;
    z-index: 1000;
  }

  /* Dropdown styling */
  .menu-droite {
    width: 280px; /* Slightly narrower than full width for aesthetic */
    height: auto;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, -10px); /* Start slightly translated up for animation */
    background: #B95128;
    padding-top: 30px;
    padding-bottom: 40px;
    flex-direction: column;
    justify-content: flex-start;
    gap: 30px;
    border-bottom-left-radius: 25px;
    border-bottom-right-radius: 25px;
    box-shadow: 0px 8px 15px rgba(0,0,0,0.3);
    border: 2px solid #EFEDE5; 
    border-top: none; /* Connect seamlessly to the header */
    z-index: 1; /* Below the logo */
    
    /* Animation states */
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease-in-out;
  }

  .menu-droite.active {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -2px); /* Slight overlap with header to hide seam */
  }
}

/* ========================================================
   RESPONSIVE REFLOW (EVERYTHING-IN-VW / FLEXBOX FIXES)
======================================================== */
.page__desktop, .desktop {
    height: auto !important;
    position: relative;
    overflow: hidden;
}

.page-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding-top: 107px; /* Space for the absolute header */
}

.page__container-1-hero-vh-9aa7,
.page__container-2-vh-75,
.page__footer-vh-25 {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    height: auto !important;
}

/* SECTION 1: HERO / MENU (Light background) */
.page__container-1-hero-vh-9aa7 {
    padding-top: 50px;
    padding-bottom: 50px;
    background-size: cover;
    background-position: top center;
    background-color: #EFEDE5;
}
.page__bloc {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}
.page__bloc-menu {
    width: 100% !important;
    position: relative !important;
    height: auto !important;
}
.page__titre {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
}
.page__bloc-devor-menu { position: relative !important; left: auto !important; top: auto !important; margin: 0 auto; width: 100% !important; max-width: 400px !important; padding: 0 15px !important; height: auto !important; } .page__img-4 { position: relative !important; width: 100% !important; height: auto !important; object-fit: contain !important; }
.page__f-3-bloc {
    position: relative !important;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 3vw;
    padding: 0 5%;
}
.page__bloc-1, .page__bloc-2, .page__bloc-3 {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: 320px !important;
    height: auto !important;
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 10px;
}
.page__bloc-2 {
    max-width: 380px !important; /* Middle block (Plats) is wider */
}

.page__bouchees-aperitives, .page__maki-facon-croque-1c0b,
.page__plats-a-partager, .page__aubergine-rotie-f40b,
.page__becs-sucres, .page__mousse-chocolat-1ef0,
.page__mentions-legales, .page__politique-de-e0e1, 
.page__contact-contact-70f7, .page__instagram {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    text-align: center;
    margin-bottom: 20px;
}

/* SECTION 2: ORANGE SECTION (Images + Button) */
.page__container-2-vh-75 {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 5%;
    padding: 70px 5%;
}
.page__img-3 { /* The eggs / blinis */
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 35vw !important;
    max-width: 602px;
    height: auto !important;
}
.page__bloc-droite {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 50% !important;
    height: auto !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 40px;
}
.page__notre-menu-est-367b {
    position: relative !important;
    width: 100% !important;
    max-width: 650px;
    height: auto !important;
    top: auto !important;
    left: auto !important;
}

/* FIX NOUS CONTACTER BUTTON */
.page__bouton {
    position: relative !important;
    width: auto !important;
    height: auto !important;
    display: inline-flex !important;
}
.page__bouton-droite {
    position: relative !important;
    width: auto !important;
    height: auto !important;
    background: linear-gradient(90deg, #EFEDE5 0%, #E7E1CA 100%);
    box-shadow: 3.1px 6.29px 6.7px 2px rgba(0, 0, 0, 0.40);
    border-radius: 40px;
    border: 1px solid white;
    padding: 15px 45px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}
.page__bouton-droite:hover {
    transform: translateY(-2px);
    box-shadow: 3.1px 12px 20px 2px rgba(0, 0, 0, 0.50);
}
.page__rectangle-9 {
    display: none !important;
}
.page__nous-contacter {
    position: static !important;
    width: auto !important;
    margin: 0 !important;
}
.page__nous-contacter-span {
    color: #B95128 !important;
    line-height: 1 !important;
}

/* SECTION 3: FOOTER */
.page__footer-vh-25 {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    padding: 40px 10%;
    background: #EFEDE5;
    z-index: 10 !important;
    visibility: visible !important;
    opacity: 1 !important;
}
.page__bloc-gauche, .page__bloc-droit {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    display: flex;
    align-items: center;
    gap: 30px;
}
.page__texte-gauche, .page__texte {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
}
.page__img, .page__img-2 { object-fit: contain !important; height: auto !important; 
    position: relative !important;
    left: auto !important;
    top: auto !important;
}

/* MOBILE ADJUSTMENTS */
@media (max-width: 900px) {
    .page__container-2-vh-75 {
        flex-direction: column;
        text-align: center;
    }
    .page__bloc-droite {
        width: 100% !important;
        margin-top: 20px;
    }
    .page__img-3 {
        width: 90vw !important;
    }
    .page__footer-vh-25 {
        flex-direction: column;
        text-align: center;
        gap: 40px;
    }
    .page__bloc-gauche, .page__bloc-droit {
        flex-direction: column;
        gap: 20px;
    }
}

/* MASSIVE MOBILE SCROLL & VISIBILITY RESET */
html, body {
    height: auto !important;
    min-height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.page__desktop, .desktop, .page-content, .page__container-1-hero-vh-9aa7, 
.page__container-2-vh-75, .page__footer-vh-25, 
.page__bloc, .page__bloc-menu, .page__f-3-bloc, 
.page__bloc-1, .page__bloc-2, .page__bloc-3,
.page__bloc-droite, .page__bloc-gauche, .page__bloc-droit {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important; 
    position: relative !important;
}





/* -- Page active : menu-traiteur -- */
.accueil { opacity: 0.60 !important; }
.menu    { opacity: 1    !important; }
