@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/lato-regular.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/lato-bold.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
:root {
    --white: #fff;
    --dark: #666;
    --bright: #537285;
    --padding: 20px;
    --main-text-color: var(--dark);
    --main-font: 'Lato', sans-serif;
    --highlight-font: var(--main-font);
    --flex-base: 250px;
    --max-width: 1800px;
}
html, body {
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
}
html {
    overflow-x: hidden;
    position: relative;
    min-height: 550px;
    font-size: 22px;
    scrollbar-width: thin;
    height: 100%;
}
@media (max-width: 1680px){
html {
    font-size: 20px;
}
}
@media (max-width: 1200px){
html {
    font-size: 18px;
}
}
body {
    position: relative;
    font-family: var(--main-font);
    font-weight: 400;
    overflow: hidden;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    color: var(--main-text-color);
    min-width: 300px;
    background-color: var(--white);
    min-height: 100vh;
    line-height: 1.3
}
body.index {
    height: 100vh;
    min-height: 800px;
}
body, body * {
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}
a {
    text-decoration: none;
    color: var(--bright);
    transition: color 0.5s ease-in;
}
a:hover {
    color: var(--dark);
}
p {
    margin: 0.25rem 0;
}
h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4, .h5 {
    line-height: 1;
    color: var(--bright);
    margin: 1em 0 .5em
}
h1, .h1 {
    font-size: 2rem;
    position: relative;
    text-transform: uppercase;
    font-family: var(--highlight-font);
    margin-top: 0
}
h1 small, .h1 small {
    margin-top: .5rem;
}
h1 small, .h1 small, h2, .h2 {
    display: block;
    font-size: 1.9rem;
    color: var(--blue-light);
    position: relative;
    font-family: var(--main-font)
}
p:last-child {
    margin-bottom: .5em
}
h3, .h3 {
    font-size: 1.2rem;
    font-family: var(--highlight-font);
    margin: .75em 0 .5em
}
h4, .h4 {
    font-size: 1rem;
    margin: .75em 0 .5em
}
small + h3 {
    margin-top: .2rem
}
body img {
    height: auto;
    max-width: 100%;
}
.center {
    text-align: center;
}
.right {
    text-align: right
}
sup {
    font-size: .6em
}

img.absolute {
    position: absolute;
    object-fit: contain;
    pointer-events: none;
    z-index: 1;
}
img.absolute.full {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
}
img.absolute.full.fixed {
    position: fixed;
    z-index: -1;
    object-fit: contain;
    object-position: bottom center;
    bottom: 0;
    opacity: .5;
}
.flex.halfpad > [class*="box"] img.absolute.full {
    top: calc(.5 * var(--padding));
    left: calc(.5 * var(--padding));
    width: calc(100% - var(--padding));
    height: calc(100% - var(--padding))
}
.content.flex.halfpad > [class*="box"] img.absolute.full {
    top: calc(1 * var(--padding));
    height: calc(100% - 2 * var(--padding))
}
.nomargin {
    margin-bottom: 0;
    margin-top: 0
}
.nomargintop {
    margin-top: 0
}
.nomarginbottom {
    margin-bottom: 0;
}
/* FLEX */
.flex {
    display: flex;
    flex-flow: row wrap;
    align-content: flex-start;
    width: auto;
    padding: var(--padding)
}
.pad {
    padding: var(--padding)
}
.flex.halfpad {
    padding: calc(.5 * var(--padding));
}
.flex.halfpad > [class*="box"] {
    padding: calc(.5 * var(--padding))
}
.content.flex.halfpad > [class*="box"] {
    padding: calc(1 * var(--padding)) calc(.5 * var(--padding))
}
.flex.nm {
    margin: calc(-1 * var(--padding));
}
.flex.nw {
    flex-flow: row nowrap;
}
.flex.unpad {
    margin: calc(-1 * var(--padding));
    max-width: calc(100% + 2 * var(--padding))
}
.halfpad > .flex.unpad {
    margin: calc(-.5 * var(--padding));
    max-width: calc(100% + 1 * var(--padding))
}
.flex.wr {
    flex-flow: row wrap-reverse;
}
.flex.vcenter {
    align-items: center;
    align-content: center;
}
.flex.vstretch {
    align-items: stretch;
    align-content: stretch;
}
.flex.vstart {
    align-items: flex-start !important;
    align-content: flex-start !important;
}
.flex.vend {
    align-items: flex-end !important;
    align-content: flex-end !important;
}
.vcenter[class*="box"] {
    align-self: center;
}
.vend[class*="box"] {
    align-self: flex-end;
}
.box0, .appartement .box1.pu {flex: .5 1 max(calc(.5 * var(--flex-base)), 12.5%);}
.box1 {flex: 1 1 max(calc(1 * var(--flex-base)), 25%);}
.box2 {flex: 2 1 max(calc(2 * var(--flex-base)), 50%);}
.box3 {flex: 3 1 max(calc(3 * var(--flex-base)), 75%);}
.boxfull {flex: 1 1 100%;}
.box0, .box1, .box2, .box3, .box4, .box5, .box6, .box-po, .boxfull {padding: var(--padding);max-width: 100%;position: relative;order: 2}
.flex.box1.fw, .flex.box2.fw, .flex.box3.fw, .flex.box4.fw, .flex.box5.fw, .flex.box6.fw  {
    width: calc(100% + (2 * var(--padding)));
    max-width: calc(100% + (2 * var(--padding)));
}
.flex > .nopad[class*="box"], .flex.nopad {
    padding: 0;
}
.flex > .doublepad[class*="box"] {
    padding: calc(2 * var(--padding));
}
.flex > .flex[class*="box"]:not(.fpad) {
    padding: 0;
}
.flex > .divider {
    flex: 1 1 100%;
    padding: 0;
    margin: 0;
}
.flex > .hdivider {
    flex: 0 0 0%;
    padding: 0;
    margin: 0;
}
.flex > .hw + .hdivider {
    flex: 1 1 100%;
    padding: 0;
    margin: 0;
}
@media (max-width: 1220px){
.flex > .divider {
    display: none;
}    
}
img[classbox]:only-child, 
picture[class^="box"]:only-child, 
picture[class^="box"] > img, 
[class^="box"] > picture:only-child > img {
    width: 100%;
    display: block;
    height: 100%;
}
/* HEADER */
.header {
    position: relative;
    height: auto;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
}
.header > * {
    flex: 1 1 100%;
}
.header .logo {
    position: relative;
    z-index: 9;
    padding: calc(2 * var(--padding));
}
.header .logo a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50%;
    position: relative;
    margin: 0 auto;
    min-width: 200px;
    max-width: 425px;
    margin: calc(2 * var(--padding)) auto;
    font-size: 1.5rem;
    text-transform: uppercase;
    padding: calc(2 * var(--padding));
    background-color: var(--bright);
    color: var(--white);
    transition: color 0s ease-in;
} 
.index header {
    height: 90vh
}
.index .header .logo a {
    width: 100%;
    min-width: 200px;
    max-width: 700px;
    font-size: 2.5rem;
}
.header .logo a img {
    display: block;
    width: 100%; 
    height: auto;
    object-fit: contain;
    object-position: center;
    transform: translateX(-.8%)
}
.headertop {
    position: relative;
    z-index: 10;
}
.headertop > .menubar {
    position: absolute;
    width: 100%;
    top: 100%;;
    left: 0;
    background-color: var(--beige);
    padding: calc(1 * var(--padding));
}
.headertext .h1 {
    font-size: 5.7rem;
    margin: var(--padding) 0;
    text-shadow: 0 0 15px var(--dark),0 0 5px #000
}
/* CONTENT */
.wrapper {
    position: relative;
    max-width: var(--max-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.smallwrapper {
    max-width: calc(.5 * var(--max-width)) !important;
}
.content {
    flex: 1 1 auto;
    position: relative;
    min-height: calc(60vh - 1rem - 1 * var(--padding))
}
main :not(.bigslider) > ul {
    padding: 0;
    margin: .25rem 0 .5rem;
    list-style: none
}
main :not(.bigslider) > ul li {
    padding-left: 1rem;
    position: relative;
}
main :not(.bigslider) > ul li:before {
    content: '';
    display: block;
    position: absolute;
    width: .5em;
    height: .5em;
    background-color: var(--blue-light);
    left: 0;
    top: .45em;
    border-radius: 100%
}
.flex > aside.flex {
    padding-top: calc(4 * var(--padding));
    padding-bottom: calc(4 * var(--padding));
}
.halfimage img {
    max-height: calc(2 * var(--padding) + 3rem);
    object-fit: cover
}
.footergal img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    aspect-ratio: 1/1
}

/* FOOTER */
.index footer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
footer {
    padding: var(--padding);
    font-size: .8rem
} 
footer * {
    margin: 0;
} 
/* TABLET */
@media  only screen 
    and (min-device-width: 810px) 
    and (max-device-width: 1080px) 
    and (-webkit-min-device-pixel-ratio: 3), 
    only screen 
    and (min-device-width: 810px) 
    and (max-device-width: 1080px) 
    and (-webkit-min-device-pixel-ratio: 2),
    (max-width: 1200px){
:root {
    --padding: 18px;
}  
}
@media  only screen 
    and (min-device-width: 810px) 
    and (max-device-width: 1080px) 
    and (-webkit-min-device-pixel-ratio: 3)
    and (orientation: landscape), 
    only screen 
    and (min-device-width: 810px) 
    and (max-device-width: 1080px) 
    and (-webkit-min-device-pixel-ratio: 2)
    and (orientation: landscape){
.index .header .logo a {
    font-size: 1.8rem
}
h1, .h1, h2, .h2 {
    font-size: 2.5rem
}
.smallwrapper {
    max-width: calc(.35 * var(--max-width)) !important;
}      
}
@media only screen 
    and (min-device-width: 375px) 
    and (max-device-width: 812px) 
    and (-webkit-min-device-pixel-ratio: 3), 
    only screen 
    and (min-device-width: 375px) 
    and (max-device-width: 667px) 
    and (-webkit-min-device-pixel-ratio: 2),
    (max-width: 650px)
{
:root {
    --padding: 10px;
}  
body {
    font-size: 16px
}
body.index {
    min-height: 350px
}  
.index .header .logo a {
    font-size: 1.4rem
}
h1, .h1, h2, .h2 {
    font-size: calc(0.8rem + 1vh);
}
}
.empty {
    min-height: 0 !important;
    height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    opacity: 0 !important;
    margin-bottom: 0 !important;
}
body.loaded {opacity: 1}