@font-face {
    font-family: 'os-roman';
    src: url('../fonts/os-roman.otf');
}
@font-face {
    font-family: 'os-bold';
    src: url('../fonts/os-bold.otf');
}
@font-face {
    font-family: 'os-light';
    src: url('../fonts/os-light.otf');
}
@font-face {
    font-family: 'os-med';
    src: url('../fonts/os-med.otf');
}


/* baskerville font */

@font-face {
    font-family: 'fos';
    src: url('../fonts/fos.ttf');
}
@font-face {
    font-family: 'fos-bold';
    src: url('../fonts/fos-b.ttf');
}
@font-face {
    font-family: 'fos-italic';
    src: url('../fonts/fos-i.ttf');
}

::-moz-selection { /* Code for Firefox */
    color: #fff;
    background: rgba(210, 177, 148, 0.53);
}

::selection {
    color: #fff;
    background: rgba(210, 177, 148, 0.53);
}

b {
	font-family: "fos-bold";

}

body{
  color: var(--black);
	font-family: "fos";

	letter-spacing: var(--lp);
	-webkit-font-smoothing: antialiased;
  font-size: var(--font-size);
  line-height: calc(var(--font-size) * var(--lh));
  margin: 0;
  padding: 0;
  font-style: normal;
  font-weight: normal;
  -webkit-tap-highlight-color: transparent;

}

:root {
  --font-size: 19px;
  --ratio: 1.6;
  --lp: 0.005em;
  --green: #464C49;
  --color_passive: #666;
  --black: #191919;
  --beige: #F1E5DC;
  --beige2: #fff8f3;
  --red: #F26D63;
  --media-max: 768px;
  --media-min: 769px;
  --nav: 50px;
  --padcont: 25px;
  --padcont-m: 12px;
  --height: calc(100vh - 0px);
  --lh: 1.2;
  --h3: calc(var(--font-size) * var(--ratio));
  --h2: calc(var(--h3) * var(--ratio));
  --h1: calc(var(--h2) * var(--ratio));


}

h1,h2,h3,h4 {
  font-weight: normal;
  margin: 0px;
}
h1 {
  font-size: var(--h1);
  line-height: calc(var(--h1) * var(--lh));
  letter-spacing: calc(var(--lp) * 1.15);
}

h2 {
  font-size: var(--h2);
  line-height: calc(var(--h2) * var(--lh));
  letter-spacing: calc(var(--lp) * 1.1);
}
h3 {
  font-size: var(--h3);
  line-height: calc(var(--h3) * var(--lh));
  letter-spacing: calc(var(--lp) * 1.05);
}

.container {
  width: 94%;
  margin-left: auto;
  margin-right: auto;
}


/*#nav-sousmenu2 li:not([style*="display:none"]):not([style*="display: none"]):last-child{

opacity: 0.2;

}*/

html {
     overflow-y: -moz-scrollbars-vertical;
     overflow-y: scroll;
}

input, textarea {
	background-color: #ececec;
    padding: 11px 0px;
    margin-bottom: 20px;
    width: 100%;
    margin-top: 10px;

}


* {
	margin: 0;
	padding: 0;
	border: 0;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	outline:0;
	vertical-align:baseline;
	/* background:transparent; */
	font-weight: normal;
	list-style: none;

}



article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
	display:block; zoom:1;
}

a {
	font-size:100%;
	vertical-align:baseline;
	text-decoration: none;
	cursor: pointer;
	color: inherit;
  -webkit-transition: opacity 0.1s ease-in-out;
  -moz-transition: opacity 0.1s ease-in-out;
  -o-transition: opacity 0.1s ease-in-out;
  -ms-transition: opacity 0.1s ease-in-out;
  transition: opacity 0.1s ease-in-out;
}

a:hover {
opacity: 0.82;
-webkit-transition: opacity 0.1s ease-in-out;
-moz-transition: opacity 0.1s ease-in-out;
-o-transition: opacity 0.1s ease-in-out;
-ms-transition: opacity 0.1s ease-in-out;
transition: opacity 0.1s ease-in-out;
}

img {
	max-width: 100%;
	height: auto;
}

table {
	border-collapse:collapse;
	border-spacing:0;
}

input, select {
	vertical-align:middle;
}


#about img {

    min-width: 100%;
}

#contact-txt-w {

	 width: 100%;
    font-size: 18px;
    color: #848484;

}


#contact-txt-w h1{

    font-size: 40px;
    letter-spacing: 2px;
    margin-bottom: 10px;
    color: #000;

}




#art-2-img-w {

	width: 100%;
	margin-top: 30px;

}


.img100 {

	width: 100%;
	margin-bottom: 12px;

}

#vid-txt h1 {

	font-size: 18px;
	margin-top: 9px;
	margin-bottom: 1px;

}

#vid-txt h2 {
	color: #f18181;
	font-size: 12px;
}

.art-1 {

	display: flex;
}

.art {

      display: flex;
      flex-wrap: wrap;
      /* justify-content: space-between; */
      margin-bottom: 50px;
}

#art-1-img{

	width: 65%;
}

#art-1-img img{

	width: 100%;
}


.art-2-txt-class{

	width: 32%;
    margin-left: 3%;
}


#art-2-txt h1 {
    font-size: 40px;
    letter-spacing: 2px;
    display: inline-block;
    text-decoration: none;
    border-bottom: 4px solid black;
    line-height: 44px;

}

#art-2-txt h2 {
	line-height: 24px;
	display: inline;
	font-size: 16px;
    letter-spacing: 2px;
	font-family: "a_condensed";
	color: #4a7aa7;
	margin-left: 2px;
	margin-top: 3px;
}

#art-2-txt h3 {
    font-size: 13px;
    letter-spacing: 2px;
    color: #fff;
    background-color: #0e0e0e;
    display: inline-block;
    margin-top: 16px;
    padding: 5px 7px 5px 9px;
    border-radius: 1px;
    text-transform: uppercase;
}

#art-2-txt p {
	font-family: "a_italic";
    font-size: 20px;
    line-height: 28px;
    margin-top: 40px;
    margin-bottom: 30px;
    color: #808080;
}

@media (min-width: 901px) {
  .w33 {

      width: 31%;
      margin-bottom: 45px;
  }

  .art .w33{
    margin-right: 3.49999%;
  }
  .art :nth-child(3n+3){
    margin-right: 0px;
  }
}

@media (max-width: 900px) {
  .w33 {

      width: 48%;
      margin-bottom: 45px;
  }
  .art .w33{
    margin-right: 3.9999%;
  }
  .art :nth-child(2n+2){
    margin-right: 0px;
  }
}

@media (max-width: 600px) {
  .w33 {

      width: 100%;
      margin-bottom: 45px;
  }
  .art .w33{
    margin-right: 0%;
  }
}


.material {
  margin-bottom: 60px;
}

.art-image-w {
  width: 100%;
  height: 100%;
opacity: 1;
cursor: pointer;
-webkit-transition: opacity 0.1s ease-in-out;
-moz-transition: opacity 0.1s ease-in-out;
-o-transition: opacity 0.1s ease-in-out;
-ms-transition: opacity 0.1s ease-in-out;
transition: opacity 0.1s ease-in-out;
}

.art-image-w:hover {

opacity: 0.89;
-webkit-transition: opacity 0.1s ease-in-out;
-moz-transition: opacity 0.1s ease-in-out;
-o-transition: opacity 0.1s ease-in-out;
-ms-transition: opacity 0.1s ease-in-out;
transition: opacity 0.1s ease-in-out;

}




.art-link p {
  margin-top: 5px;
  margin-bottom: 5px;
}

.art-image {
  background-size:cover;
  background-repeat: no-repeat;
  background-position: center;
  margin-bottom: 10px;
}



#w25 {
	width: 21.5%;
    margin-bottom: 45px;
    margin-right: 4.6666%;
    opacity: 1;
    /* -webkit-transition: opacity 0.1s ease-in-out;
    -moz-transition: opacity 0.1s ease-in-out;
    -o-transition: opacity 0.1s ease-in-out;
    -ms-transition: opacity 0.1s ease-in-out;
    transition: opacity 0.1s ease-in-out; */
    cursor: pointer;
}



#w25:hover {
	opacity: 0.7;

}


#w25:nth-child(4n+4) {
    margin-right: 0;
}

#vid-img {
	width: 100%;
	background-size: cover;
    justify-content: center;
    align-items: center;
    background-position: center;
}
/*#vid-img img {
    flex-shrink: 0;
    min-width: 100%;
    min-height: 100%
}
*/

#about-txt{

	 width: 100%;
	 margin-left: auto;
	 margin-right: auto;
	 margin-bottom: 50px;

}

#about-txt h1{

    margin-bottom: 29px;
    margin-top: 16px;
    font-size: 42px;

}

#about-txt p{

	font-size: 19px;
    line-height: 25px;
    color: #999;

}

#nav-menu{
	     height: 50px;
      color:var(--color_passive);

}
#logo-w{
	position: absolute;
	width: 180px;
	height: 40px;
}
#logo{
	background-image:url(../images/logo.svg);
	background-position: left;
	background-repeat: no-repeat;
	background-size:contain;
	width: 190px;
	height: 60px;
	cursor: pointer;
}
#logo:hover{
	opacity: 0.8;
}
#nav-txt li.active{
 color: var(--black);
}

/* #nav-txt li.active:hover{
	opacity: 0.8;
} */

.tiret {

opacity: 0.5;
}

#nav-sousmenu {

    font-size: 16px;
    letter-spacing: 2px;
    font-family: "a_condensed";
    text-transform: uppercase;
}

#nav-sousmenu ul li{
    margin-left: 50px;
}
#nav-sousmenu ul li:first-child{
	margin-left: 0px
}


#nav-sousmenu li a.active{
	opacity: 1;

}


#nav-sousmenu2-w {
	margin-top: 65px;
    margin-bottom: 25px;

}
#nav-sousmenu2 li{

    display: inline;
    text-align: center;
    margin-right: 16px;
    margin-left: 2px;
    letter-spacing: 0.8px;
    font-size: 15px;
}

#nav-sousmenu2 ul li:last-child{
	display: none;
}



#contact-txt-w div{

	width: 100%;
	margin-bottom: 40px;

}


#txt-intro {
    font-size: 40px;
    letter-spacing: 3px;
    text-align: center;
    margin-bottom: 135px;
}


.spanclass {

  cursor: pointer;
  margin-right: 10px;

}

#close-w {

  width: 100%;
  height:1px;
}

#spanmob {

    width: 100%;
    text-align: right;
    padding-top: 9px;
    font-size: 30px;
    transition: 0.002s;
    opacity: 1;
    color: #000;

}

#spanmob:hover {

  opacity: 0.6;
}

/* The side navigation menu */
.sidenav {
    height: 100%; /* 100% Full-height */
    width: 0; /* 0 width - change this with JavaScript */
    position: fixed; /* Stay in place */
    z-index: 1; /* Stay on top */
    top: 0;
    right: 0;
    background-color: #fff; /* Black*/
    overflow-x: hidden; /* Disable horizontal scroll */
    padding-top: 60px; /* Place content 60px from the top */
    transition: 0.2s; /* 0.5 second transition effect to slide in the sidenav */
    display: block;
}

/* The navigation menu links */


.sidenav a.active {
  color: #000;
}


.sidenav a {

    padding: 0px 9px 12px 0px;
    text-decoration: none;
    font-size: 21px;

    color: #bbb;
    display: block;
    transition: 0.2s;
    letter-spacing: 1px;
    text-align:  right;
}

/* When you mouse over the navigation links, change their color */
.sidenav a:hover, .offcanvas a:focus{
    color: #000;
}

/* Position and style the close button (top right corner) */
.sidenav .closebtn {
    color: #000;
    padding-top: 4px;
    position: absolute;
    top: 3px;
    right: 3px;
    font-size: 33px;
    margin-left: 50px;
    font-family: "a_italic";
/*    width: 100%;*/
    opacity: 1;
    transition: 0.2s;
}

.sidenav .closebtn:hover {
  opacity: 0.6;
}

@media (min-width: 769px) {
#logo{
	float: left;
}
#nav-txt {

	float:right;
	margin-top: 6px;
}

#contact-txt-w div{

	width: 50%;
	margin-bottom: 40px;

}


#nav-txt li{
	display: inline;
	margin-left: 55px;



    padding: 5px 2px 6px 7px;
    margin-left: 45px;

    /* -webkit-transition: opacity 0.1s ease-in-out;
    -moz-transition: opacity 0.1s ease-in-out;
    -o-transition: opacity 0.1s ease-in-out;
    -ms-transition: opacity 0.1s ease-in-out;
    transition: opacity 0.1s ease-in-out; */
}

#nav-txt li:last-child{
	margin-right: 0px;
}

#nav-txt li:hover{



}

#art-2-img {

	width: 70%;
	margin-left: auto;
	margin-right: auto;

}

#contact-txt-w {

	  display: inline-flex;


}



#spanmob {
  display: none;
}

.sidenav {
  display: none;

}

#nav-menu{
    margin-top: 12px;
    margin-bottom: 90px;
}

#nav-sousmenu li{
    display: inline;
}

}

@media (max-width: 769px) {

#nav-sousmenu li a {


     display: inline-block;

}

#nav-sousmenu ul li {

     margin-left: 0px;
    margin-bottom: 10px;


}

#w25 {

	min-width: 100%;
	margin-right: 0px;
}

#nav-txt {

    display: none;
}

#art-1-img, #art-2-txt, .art-2-txt-class {
	width: 100%;
	margin-left: 0;
}

.art-1 {
display: block;
}

#art-2-img {

	width: 100%;

}

#contact-txt-w {

      display: block;
}

#nav-menu{
    margin-top: -31px;
    margin-bottom: 40px;
}

}

.pop-art-image {

overflow: hidden;
display: none;
z-index: 10;
position: fixed;
height: 100vh;
width: 100vw;
top: 0px;
left: 0px;
right: 0px;
bottom: 0px;
background-position: center;
background-size: cover;
background-repeat: no-repeat;



-webkit-transition: background-position .2s ease-out;
-moz-transition: background-position .3s ease-out;
-o-transition: background-position .3s ease-out;
-ms-transition: background-position .3s ease-out;
transition: background-position .3s ease-out;

}

.pop-art-image,.inner-pop {

  cursor: url(../images/icons/1.svg), auto;

}

.inner-pop {

overflow: hidden;
display: none;
z-index: 10;
position: fixed;
height: 100vh;
width: 100vw;
top: 0px;
left: 0px;
right: 0px;
bottom: 0px;
background-position: center;
background-size: contain;
background-repeat: no-repeat;
background-color: var(--black);



/* -webkit-transition: background-position .2s ease-out;
-moz-transition: background-position .3s ease-out;
-o-transition: background-position .3s ease-out;
-ms-transition: background-position .3s ease-out;
transition: background-position .3s ease-out; */

}



.hider-w {
  color: var(--beige);
}

.hider-w header {
  position: absolute;
  top: var(--padcont);
}

.hider-w footer {
  position: fixed;
  bottom: var(--padcont);
}


.hider,.hider2 {


  font-size: 50px;
  font-family: "os-light";
  /* float: right;
  margin-top: var(--padcont);
  padding-top: 5px; */
  width: 100%;
  height:100vh;
  opacity: O;
}

@media (max-width: 900px) {

.download {
  display: none;
}
}

.download {

  font-size: 45px;

  float: right;
  margin-top: var(--padcont);
  padding-top: 10px;


}

.download a {

  padding-left: 22px;
  padding-right: 22px;
  padding-bottom: 5px;
  padding-top: 13px;
    margin-right: 38px;
}

.magnifier,.magnifier-off {
  position: absolute;
  font-size: 50px;
  font-family: "os-light";
  top: var(--padcont);
  text-align: right;
  right: 20px;
  padding-bottom: 10px;
  color: var(--beige);
  padding: 10px;

}
/*
.magnifier-off {

  display: none;

} */

.art-image-mob-w {

  position: relative;
  top: 50%;
  transform: translateY(-50%);


}
.art-image-mob-w-w {
  display: none;
  position: fixed;
  height: 100vh;
  left: 0;
  top: 0;
  width: 100%;
  background-color: var(--beige);
  }



#image-mob {

  padding-left: 4vw;
    padding-right: 4vw;
    top: 0px;
    position: relative;
        margin-bottom: 3%;
}

#image-mob img {

  max-height: 65vh;
left: 50%;
display: block;
margin-left: auto;
margin-right: auto;

}

.titre-mob {
  padding-top: 10px;
  width: 100%;
text-align: center;

}

.titre-mob p, .titre-mob h3 {

  padding-left: 10px;
    padding-right: 10px;

}
.titre-mob h3 {
hyphens: auto;
}

#slideshow-w {

    display: none;
    width: 100%;
    position: fixed;
    height: 100vh;

}

.slideshow,.fade,.slick-list {


    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}


.slick-list, .centering {
    height: 100vh;
}







    #myVideo {

  position: fixed;
  right: 0;
  min-width: 100%;
  min-height: 100%;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);

}


.centering, .centering2 {
	  width: 100%;
    background-size: cover;
    justify-content: center;
    align-items: center;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #fff;
}

.centering .top {

height: 50%;
background-size: cover;
justify-content: center;
align-items: center;
background-color: #fff;
background-position: left;
background-repeat: no-repeat;
border-bottom: 4px solid white;




}


.centering .bottom {

border-top: 4px solid white;

height: 50%;
background-size: cover;
justify-content: center;
align-items: center;
background-position: right;
background-repeat: no-repeat;
background-color: #fff;


}


.prix {
  z-index: 10;
  background-image: url(../images/icons/prix.svg);
  width: 120px;
  height: 120px;
  position: absolute;
  top:20px;
  left: 20px;
  background-size: contain;
  justify-content: center;
  align-items: center;
  background-position: center;
  background-repeat: no-repeat;

}

textarch-w {
  display: block;
    position: absolute;
    font-size: 17px;
    width: 100%;
    bottom: 20px;
    text-align: center;
}

textarch {
  background-color: white;
  padding: 8px;
}


#about-txt p.apropos {


margin-top: 30px;


}

@media (min-width: 900px) {
  #about-txt p.apropos {



    column-count: 2;
  column-gap: 7%;

  }

}

@media (min-width: 770px) {
.margo {
  margin:30px;
}}


@media (max-width: 769px) {
div#about {
  margin-bottom:20px;
}}


.slick-slider{
    touch-action: auto!important;
}
