@charset "UTF-8";
@font-face {
  font-family: "Brandon Text";
  src: local("Brandon Text Bold"), local("BrandonText-Bold"), url("fonts/BrandonText-Bold.woff2") format("woff2"), url("fonts/BrandonText-Bold.woff") format("woff"), url("fonts/BrandonText-Bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Brandon Text";
  src: local("Brandon Text Regular"), local("BrandonText-Regular"), url("fonts/BrandonText-Regular.woff2") format("woff2"), url("fonts/BrandonText-Regular.woff") format("woff"), url("fonts/BrandonText-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Brandon Text";
  src: local("Brandon Text Light"), local("BrandonText-Light"), url("fonts/BrandonText-Light.woff2") format("woff2"), url("fonts/BrandonText-Light.woff") format("woff"), url("fonts/BrandonText-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Helvetica Neue LT Pro";
  src: local("Helvetica Neue LT Pro 73 Bold Extended"), local("HelveticaNeueLTPro-BdEx"), url("fonts/HelveticaNeueLTPro-BdEx.woff2") format("woff2"), url("fonts/HelveticaNeueLTPro-BdEx.woff") format("woff"), url("fonts/HelveticaNeueLTPro-BdEx.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Helvetica Neue LT Pro";
  src: local("Helvetica Neue LT Pro 33 Thin Extended"), local("HelveticaNeueLTPro-ThEx"), url("fonts/HelveticaNeueLTPro-ThEx.woff2") format("woff2"), url("fonts/HelveticaNeueLTPro-ThEx.woff") format("woff"), url("fonts/HelveticaNeueLTPro-ThEx.ttf") format("truetype");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}
/* Modern reset: https://piccalil.li/blog/a-more-modern-css-reset/ */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Prevent font size inflation */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

/* Remove default margin in favour of better control in authored CSS */
/* https://www.joshwcomeau.com/css/custom-css-reset/#two-remove-default-margin-3 */
* {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* A questionner avec : https://chriscoyier.net/2023/10/03/being-picky-about-a-css-reset-for-fun-pleasure/ & quid du padding sur le ul ? */
/* Set core body defaults */
body {
  min-height: 100vh;
  line-height: 1.5;
}

/* Set shorter line heights on headings and interactive elements */
h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.1;
}

/* Balance text wrapping on headings */
h1,
h2,
h3,
h4 {
  text-wrap: balance;
}

/* https://www.joshwcomeau.com/css/custom-css-reset/#seven-word-wrapping-8 */
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/* https://www.stefanjudis.com/today-i-learned/how-to-use-language-dependent-quotes-in-css/ */
blockquote::before {
  content: open-quote;
}

blockquote::after {
  content: close-quote;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */
/* https://www.joshwcomeau.com/css/custom-css-reset/#five-sensible-media-defaults-6 */
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

/* Inherit fonts -- and color https://piccalil.li/blog/css-inheritance/ -- for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

/* @https://piccalil.li/blog/css-inheritance/ */
::-webkit-input-placeholder {
  color: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */
textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */
:target {
  scroll-margin-block: 5ex;
}

/* https://dbushell.com/2024/03/10/css-button-styles-you-might-not-know/ */
*:focus-visible {
  outline: 2px solid currentcolor;
  outline-offset: 2px;
}

:root {
  /* ------ Colors */
  --color-brand-01: #88B3DF;
  --color-brand-02: #344a63;
  --color-brand-03: #247273;
  --color-dark: #000000;
  --color-light: #FFFFFF;
  /* ------ Fonts */
  --fs-step-2: clamp(2rem, 1.455rem + 2.73vw, 3.5rem);
  --fs-step-1: clamp(1.5rem, 1.4rem + 0.5vw, 2rem);
  --fs-step-0: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
  /* https://systemfontstack.com/ */
  --ff-stack-sans: -apple-system, BlinkMacSystemFont, avenir next, avenir, segoe ui, helvetica neue, helvetica, Cantarell, Ubuntu, roboto, noto, arial, sans-serif;
  --ff-stack-serif: Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
  --ff-stack-mono: Menlo, Consolas, Monaco, Liberation Mono, Lucida Console, monospace;
  --ff-stack-01: "Helvetica Neue LT Pro", var(--ff-stack-sans);
  --ff-stack-02: "Brandon Text", var(--ff-stack-sans);
  --leading-base: 1.5;
  --leading-fine: 1.15;
  --line--text-max: 85ch;
  --line-title-max: 50ch;
  /* ------ Spaces */
  --space: clamp(1.563rem, 1.25rem + 1.56vw, 3.125rem);
  --space-2x: calc(var(--space) * 2);
  --space-3x: calc(var(--space) * 3);
  --space-4x: calc(var(--space) * 4);
  --space-content: clamp(1rem, -0.05rem + 5.25vw, 6.25rem);
  --gutter: 2rem;
  /* ------ Others */
  /* --- Radius */
  /* --- shadow --- */
  /* --- Elevation */
  /* --- Transitions */
  --transition-base: 250ms ease;
  --transition-movement: 200ms linear;
  --transition-fade: 300ms ease;
  --transition-bounce: 500ms cubic-bezier(0.5, 0.05, 0.2, 1.5);
}

body {
  background: var(--color-light);
  color: var(--color-dark);
  font-size: var(--fs-step-0);
  font-family: var(--ff-body, sans-serif);
  font-weight: var(--fw-text), 300;
  line-height: var(--leading-base);
}
body.post-type-nacarapresentation, body.single-nacarapresentation,
body .main-nacara {
  --ff-body: var(--ff-stack-01);
  --fs-heading: var(--fs-step-1);
  --fw-text: 100;
  --fw-heading: bold;
}
body.post-type-holtpresentation, body.single-holtpresentation,
body .main-holt {
  --ff-body: var(--ff-stack-02);
  --fs-heading: var(--fs-step-2);
  --fw-text: 300;
  --fw-heading: 300;
}
body.post-type-lamaisonpresentation, body.single-lamaisonpresentation,
body .main-lamaison {
  --ff-body: var(--ff-stack-02);
  --fs-heading: var(--fs-step-1);
  --fw-text: 300;
  --fw-heading: bold;
}

main .entry-content {
  display: flex;
  overflow-y: none;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
main .entry-content > * {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

h1, h2, h3 {
  font-size: var(--fs-heading);
  font-weight: var(--fw-heading);
}

a {
  /* https://ashleemboyer.com/blog/should-i-use-a-button-or-a-link */
}
a[rel=external]::after {
  content: " (external link)";
}
a[target=_blank]::after {
  content: " (opens in new tab)";
}

/* 
	voir firefox / wip / focus
	voir comment gérer le focus au niveau macro et micro > regarder du coté de la méthodo CUBE : https://piccalil.li/blog/how-were-approaching-theming-with-modern-css et https://dev.37signals.com/modern-css-patterns-and-techniques-in-campfire/
*/
/*
CLUSTER
More info: https://every-layout.dev/layouts/cluster/
A layout that lets you distribute items with consitent
spacing, regardless of their size

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--cluster-horizontal-alignment (flex-start) How items should align
horizontally. Can be any acceptable flexbox aligmnent value.

--cluster-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/
.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, 1rem);
  justify-content: var(--cluster-horizontal-alignment, flex-start);
  align-items: var(--cluster-vertical-alignment, center);
}

/* 
FLOW COMPOSITION 
Like the Every Layout stack: https://every-layout.dev/layouts/stack/
Info about this implementation: https://piccalil.li/quick-tip/flow-utility/ 
*/
[class^=flow] > * {
  /* top and bottom margins in horizontal-tb writing mode */
  margin-block: 0;
}

.flow > * + * {
  margin-block-start: var(--flow-space, 1em);
}

.grid {
  display: grid;
  grid-template-columns: repeat(var(--_grid-cols), 1fr);
  grid-template-rows: repeat(var(--_grid-rows), auto);
}
@media (min-width: 56.25em) {
  .grid.l-split-h-50-50 {
    grid-template-columns: repeat(2, 1fr);
  }
}

.grid-media {
  --_grid-media-cols: 4;
  --_grid-media-areas: "m1 m1 m1 m1"
                        "m2 m2 m2 m2"
                        "m3 m3 m4 m4";
  display: grid;
  grid-template-columns: repeat(var(--_grid-media-cols), 1fr);
  grid-template-areas: var(--_grid-media-areas);
  gap: 1em;
  aspect-ratio: var(--_grid-media-ratio);
  min-height: 1px;
}
@media (min-width: 56.25em) {
  .grid-media {
    --_grid-media-ratio: 1920/790;
    --_grid-media-areas: "m1 m1 m1 m1"
                          "m2 m2 m3 m4";
  }
  .grid-media.l-50-50 {
    --_grid-media-areas: "m1 m1 m2 m2"
                          "m1 m1 m3 m4";
  }
}
.grid-media.l-full {
  --_grid-media-cols: 1;
  --_grid-media-areas:"m1";
  --_grid-media-ratio: unset;
  height: 100%;
}
.grid-media.l-full--400 {
  --_grid-media-cols: 1;
  --_grid-media-areas:"m1";
  --_grid-media-ratio: 1920/400;
}
.grid-media .media-1 {
  grid-area: m1;
}
.grid-media .media-2 {
  grid-area: m2;
}
.grid-media .media-3 {
  grid-area: m3;
}
.grid-media .media-4 {
  grid-area: m4;
}

/*
REPEL
A little layout that pushes items away from each other where
there is space in the viewport and stacks on small viewports

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--repel-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/
.repel {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: var(--repel-vertical-alignment, center);
  gap: var(--gutter, var(--space-s-m));
}

.repel--nowrap {
  flex-wrap: nowrap;
}

/* 
SIDEBAR
More info: https://every-layout.dev/layouts/sidebar/
A layout that allows you to have a flexible main content area
and a "fixed" width sidebar that sits on the left or right.
If there is not enough viewport space to fit both the sidebar
width *and* the main content minimum width, they will stack
on top of each other

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between the sidebar and main content.

--sidebar-target-width (20rem): How large the sidebar should be

--sidebar-content-min-width(50%): The minimum size of the main content area

EXCEPTIONS
.sidebar[data-direction='rtl']: flips the sidebar to be on the right 
*/
.sidebar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, 1rem);
}

.sidebar > :first-child {
  flex-basis: var(--sidebar-target-width, 20rem);
  flex-grow: 1;
}

.sidebar > :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: var(--sidebar-content-min-width, 50%);
}

/*
SWITCHER
More info: https://every-layout.dev/layouts/switcher/
A layout that allows you to lay **2** items next to each other
until there is not enough horizontal space to allow that.

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between each item

--switcher-target-container-width (40rem): How large the container
needs to be to allow items to sit inline with each other

--switcher-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/
.switcher {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-l));
  align-items: var(--switcher-vertical-alignment, flex-start);
}

.switcher > * {
  flex-grow: 1;
  flex-basis: calc((var(--switcher-target-container-width, 40rem) - 100%) * 999);
}

/* Max 2 items,
so anything greater than 2 is full width */
.switcher > :nth-child(n+3) {
  flex-basis: 100%;
}

/*
WRAPPER COMPOSITION 
A common wrapper/container
*/
.wrapper {
  margin-inline: auto;
  max-width: clamp(16rem, var(--wrapper-max-width, 100vw), 80rem);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  position: relative;
}

.single-nacarapresentation,
.main-nacara,
.post-type-nacarapresentation {
  --color-brand: var(--color-brand-01);
}

.single-holtpresentation,
.main-holt,
.post-type-holtpresentation {
  --color-brand: var(--color-brand-02);
}

.single-lamaisonpresentation,
.main-lamaison,
.post-type-lamaisonpresentation {
  --color-brand: var(--color-brand-03);
}

.color-brand {
  color: var(--color-brand);
}

.color-dark {
  color: var(--color-dark);
}

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

.bg-brand {
  background-color: var(--color-brand);
}

.bg-dark {
  background-color: var(--color-dark);
}

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

.flex {
  display: flex;
}

.column {
  flex-direction: column;
}

.space-between {
  justify-content: space-between;
}

.center {
  justify-content: center;
  align-items: center;
}

.region {
  width: 100vw;
  height: 100dvh;
}

.space {
  margin-block-start: var(--space);
}

.space-2x {
  margin-block-start: var(--space-2x);
}

.space-3x {
  margin-block-start: var(--space-3x);
}

.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}

/* 
VISUALLY HIDDEN UTILITY
Info: https://piccalil.li/quick-tip/visually-hidden/ 
*/
.visually-hidden,
.screen-reader-text {
  border: 0;
  clip: rect(0 0 0 0);
  height: 0;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

/* Pour amélioration !!!!
https://dev.37signals.com/modern-css-patterns-and-techniques-in-campfire/ */
/* https://dbushell.com/2024/03/10/css-button-styles-you-might-not-know/ */
.button,
::file-selector-button {
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  touch-action: manipulation;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  cursor: pointer;
}

/* https://github.com/imperavi/superkube/blob/main/superkube/modules/button.scss */
.button {
  -webkit-appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: baseline;
  text-align: center;
  font-family: inherit;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  font-family: var(--button-font-family, inherit);
  font-weight: var(--button-font-weight, 500);
  font-size: var(--button-font-size, 1em);
  line-height: var(--button-line-height, 1);
  letter-spacing: var(--button-letter-spacing, 0.01em);
  text-transform: var(--button-text-transform);
  padding-inline: var(--button-padding-x, 0.5em);
  padding-block-start: var(--button-padding-y, 0.25em);
  padding-block-end: calc(var(--button-padding-y, 0.25em) / 1.25);
  border-radius: var(--button-border-radius);
  border-width: var(--button-border-width, 1px);
  border-style: var(--button-border-style, solid);
  height: var(--button-height);
  box-shadow: var(--button-box-shadow);
  opacity: var(--button-opacity);
  color: var(--button-color, #FFF);
  border-color: var(--button-border-color, currentcolor);
  background-color: var(--button-background-color, #000);
}
.button:hover {
  outline: none;
}
.button:hover, .button:focus-visible {
  background-image: none;
  text-decoration: none;
  color: var(--button-hover-color, #000);
  border-color: var(--button-hover-border-color);
  background-color: var(--button-hover-background-color, #FFF);
  background-image: var(--button-hover-background-image);
  box-shadow: var(--button-hover-box-shadow);
}
.button:hover::file-selector-button, .button:focus-visible::file-selector-button {
  color: var(--button-color, #000);
  background-color: var(--button-background-color, #FFF);
}
.button.disabled, .button:disabled {
  --button-opacity: 0.5;
  cursor: default;
  color: var(--button-disabled-color);
  border-color: var(--button-disabled-border-color);
  background-color: var(--button-disabled-background-color);
  background-image: var(--button-disabled-background-image);
  box-shadow: var(--button-disabled-box-shadow);
}
.button-outline {
  --button-background-color: transparent;
  --button-border-color: ;
  --button-color: ;
  --button-hover-background-color: ;
  --button-hover-border-color: ;
  --button-hover-color: ;
  --button-disabled-background-color: ;
  --button-disabled-border-color: ;
  --button-disabled-color: ;
}
.button-round {
  --button-border-radius: 50%;
}
.button::file-selector-button {
  border: 0;
  color: var(--button-color, #FFF);
  background-color: var(--button-background-color, #000);
}

.brand {
  width: inherit;
  max-width: var(--_brand-max-width, 21.875rem);
  padding: 1rem;
  /* Sizes */
  /* position */
}
.brand.size--sm {
  --_brand-max-width: 21.875rem;
}
@media (max-width: 29.99em) {
  .brand.size--sm {
    --_brand-max-width: 15.625rem;
  }
}
.brand.size--md {
  --_brand-max-width: 46.875rem;
}
.brand.size--lg {
  --_brand-max-width: 59.375rem;
}
.brand-lamaison {
  --_brand-max-width: 28.125rem;
}
@media (max-width: 29.99em) {
  .brand-lamaison {
    --_brand-max-width: 15.625rem;
  }
}
.brand-lamaison--sm {
  --_brand-max-width: 10rem;
}
.brand-holt {
  --_brand-max-width: 28.125rem;
}
@media (max-width: 29.99em) {
  .brand-holt {
    --_brand-max-width: 15.625rem;
  }
}
.brand-holt--sm {
  --_brand-max-width: 10rem;
}
.brand.pos {
  position: absolute;
}
.region:has(> .brand.pos) {
  position: relative;
}
.brand.bottom-right {
  bottom: var(--space, 1.5rem);
}
@media (max-width: 56.24em) {
  .brand.bottom-right {
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 56.25em) {
  .brand.bottom-right {
    right: var(--space-2x, 1.5rem);
  }
}
.brand svg {
  fill: currentcolor;
}

.lamaisonpresentation-template-default .entry-content > section:last-child .brand-lamaison img {
  max-height: 30dvh;
  margin-inline: auto;
}

.content {
  --flow-space: var(--fs-body);
  --_content-padding: var(--space-content);
  padding: var(--_content-padding);
}
.content.state-editorial {
  height: 100%;
}
.content-header {
  text-transform: uppercase;
  padding-block-end: var(--fs-body);
  border-bottom: 2px solid currentcolor;
}
.content-body {
  max-width: 60ch;
}
.state-editorial .content-body {
  max-width: none;
  flex-grow: 1;
}
.state-editorial .content-body > *:last-child {
  flex-grow: 1;
}
@media (max-width: 56.24em) {
  .state-editorial .content-body > *:last-child {
    margin-block-end: var(--space-4x);
  }
}

.gallery > * {
  overflow: hidden;
  position: relative;
}
.gallery figure {
  height: 100%;
}
.gallery img,
.gallery video {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
}
.gallery .cover {
  position: absolute;
  inset: 0;
}

.garanties {
  --cluster-horizontal-alignment: center;
  max-width: 60ch;
}
.garanties-logo {
  max-width: 110px;
}
.garanties-registration {
  padding-inline: 1rem;
  padding-block-start: var(--space);
  padding-block-end: 2rem;
}

@media (max-width: 29.99em) {
  .legal {
    flex-grow: 1;
  }
}

.location {
  --cluster-horizontal-alignment: space-between;
  width: 100%;
  max-width: 59.375rem;
  padding-block: var(--space) var(--space-2x);
}
.location-address {
  flex-grow: 1;
  text-align: center;
  padding-inline: 1rem;
}

.navigation__button {
  --button-background-color: transparent;
  --button-hover-background-color: transparent;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 0;
  padding: 0.25em;
  background-color: rgba(255, 255, 255, 0.4);
  border-radius: 50%;
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
}
.navigation__button:hover {
  background-color: rgb(255, 255, 255);
}
.navigation__button::before {
  content: "";
  display: block;
  width: var(--fs-step-0);
  height: var(--fs-step-0);
  background-color: var(--color-brand);
  -webkit-mask: url("img/arrow-right.svg") no-repeat;
          mask: url("img/arrow-right.svg") no-repeat;
  -webkit-mask-size: cover;
          mask-size: cover;
  -webkit-mask-position: center;
          mask-position: center;
}
.navigation__button--prev {
  left: 0.5rem;
}
.navigation__button--prev::before {
  transform: rotate(-180deg);
}
.navigation__button--next {
  right: 0.5rem;
}
@media (max-width: 56.24em) {
  .navigation__button {
    display: none;
  }
}

#dots {
  position: fixed;
  bottom: var(--space);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 5px;
  z-index: 1000;
  cursor: pointer;
}

#dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: rgb(200, 200, 200);
  display: inline-block;
}

#dots .active {
  background-color: var(--color-brand);
  cursor: default;
}

/*# sourceMappingURL=lmnh-group.css.map */