
@import url('https://fonts.googleapis.com/css?family=Raleway:400,600&display=swap');


/* ========================================================================== Basic ===== */


html {
  height: 100%;
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

body {
  position: relative;
  min-height: 100%;
  overflow-x: hidden;
  font-family: 'Raleway', sans-serif;
  font-weight: 400;
  color: #333333;
  font-size: 1rem;
  line-height: 1.2rem;
  background:  url('r_images/triangle_light.svg') left top no-repeat fixed, url('r_images/triangle_right.png') right top no-repeat fixed, #b1cac9;
  margin: 0px;
}
a {
  color: #389a98;
  text-decoration: none;
}
a:hover{
  color: #46c1be;
  text-decoration: none;
}
p{
  margin-bottom: 0.3rem;
}
b{
  font-weight: 600;
}


/* ========================================================================== Styling ===== */

.titrepage{
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.8rem;
  margin: 1rem 0;
}
.set_title{
  font-size: 1.2rem;
  font-weight: 600;
  padding-bottom: .2rem;
}
.set_totalimages{
  font-weight: 400;
  font-size: 0.9rem;
  padding-bottom: .5rem;
}
.set_description{
  font-weight: 400;
  font-size: 0.9rem;
  line-height: 1rem;
}
.fullcol {
  height: 100%; 
}
.set_actions{
  text-align: right;
  position: absolute;
  right: 1rem;
  bottom: 0;
}
.modal-title{
  margin-right: -2rem;
  text-align: center;
}
.spaceattop{
  padding-top: 5rem;
}
.alignright {
  text-align: right;
}
.smalltext {
  font-size: 0.8rem;
  line-height: 1rem;
}
.thumb{
  padding: .2rem;
}
.mypage{
  color: #666666;
  display: inline-block;
  padding: .2rem;
  border: 1px solid #999999;
  border-radius: .2rem;
}
.mypage.active{
  color: #FFFFFF;
  background-color: #46c1be;
}
img.set-image {
  max-width: 100%;
  transform: scale(1.25); /* Cache le filigrane Wallimage */
}
.portfolio-item {
  overflow: hidden;
}
.portfolio-item img:hover {
  transform: scale(1.5);
  cursor: zoom-in;
}
.portfolio-item img {
  transition: transform .4s ease;
}
.portfolio-item-fade{
  overflow: hidden;
  opacity: .3;
}
.legende{
  margin-bottom: -0.2rem;
  font-size: 0.8rem;
  line-height: 1.7rem;
}


/* ========================================================================== Parallax ===== */

/* make keyframes that tell the start state and the end state of our object */
@-webkit-keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@-moz-keyframes fadeIn { from { opacity:0;  } to { opacity:1; } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

.fade-in {
    opacity:0;  /* make things invisible upon start */
    -webkit-animation:fadeIn 1s ease-in 0s 1 normal forwards;  /* call our keyframe named fadeIn, use animation ease-in and repeat it only 1 time */
    -moz-animation:fadeIn 1s ease-in 0s 1 normal forwards;
    animation:fadeIn 1s ease-in 0s 1 normal forwards;
}
.fade-in.one {
    -webkit-animation-delay: .2s ;
    -moz-animation-delay: .2s ;
    animation-delay: .2s;
}
.w-screen{
  margin: -1rem -1rem 0;
  height: 25rem;
  overflow: hidden;
}
.head_img{
  position: relative;
  background-attachment: fixed;  
  background-size: 100% auto;
  background: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)), url("r_slides/4.jpg") no-repeat;
  background-size: 100% auto;
  background-position: top;
  min-height: 26rem;
}
.filmhead_img{
  position: relative;
  background-attachment: fixed;  
  background-size: 100% auto;
  background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)), url("_img/../slir/w1500-h1500-c1x1-q100/_img/") no-repeat;
  filter: blur(6px);
  -webkit-filter: blur(6px);
  background-size: 100% auto;
  background-position: top;
  min-height: 26rem;
}
.caption {
  color: white;
  margin-top: 0rem;
  z-index:1000;
  position: absolute;
  padding: 0rem;
  text-shadow: .1rem .1rem .5rem black;
}
.caption2 {
  width:100%;
  color: white;
  margin-top: 0rem;
  z-index:1000;
  position: relative;
  padding: 0rem;
  text-shadow: .1rem .1rem .5rem black;
}
.banners{
  width:100%;
  justify-content: end;
}
.banner{
  padding-left: .4rem;
  width:100%;
}
.bottom-align-text {
  position: absolute;
  padding-bottom: 1rem;
  bottom: 0;
  left: 0;
}
.bottom-align-text2 {
  position: absolute;
  padding-bottom: 1.6rem;
  bottom: 0;
  right: 0;
}
.caption h3 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 2.2rem;
}
.caption h4 {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.4rem;
}
.caption h5 {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.2rem;
}
.caption p {
  font-size: 1.2rem;
  line-height: 1.4rem;
  font-weight: 400;
  text-shadow: .1rem .1rem .5rem black;
}


/* ========================================================================== Containers ===== */

.container.big {
  padding: .5rem 1rem 1rem;
  margin-top: 1rem;
  //background-color: #FF5511;
  background-color: rgba(255, 255, 255, 0.3);
}
.container.stroke {
  padding: 1rem .5rem 1rem;
  margin-bottom: 1rem;
  background-color: rgba(255, 255, 255, 0.3);
}
.container.stroke-fade {
  padding: 1rem .5rem 1rem;
  margin-bottom: 1rem;
  background-color: rgba(255, 255, 255, 0.3);
  opacity: .5;
}
.container.foot {
  padding: .8rem .6rem .8rem;
  margin-bottom: .8rem;
  margin-top: .8rem;
  width: 100vw;
}


/* ========================================================================== Rows ===== */

/*--- Extra Bootstrap Column Padding --*/
[class*="col-"] {
  padding: 1rem;
}
.row.padding {
  padding: 2rem 0 1rem;
}
.row.nopad {
  padding: 0;
}
.row.head {
  height:20rem;
  margin-top: -20rem;
  padding: 0;
}
.row.rowpad [class*=col-] {
  padding: 0 .4rem 0;
}
.row.imagesrow [class*=col-] {
  padding: 0rem;
}
.row.formrow [class*=col] {
  padding: 0;
}
.row.formrow [class*=bite] {
  padding: 0 .3rem 0;
}
.row.no-padding [class*=col-] {
  padding: 0;
}
.row.banner-row [class*=col-] {
  padding: 0 0 0 .4rem;
}
.row-eq-height {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display:         flex;
}
.row.modalpadcenter{
  text-align: center;
}
.row.carnetrow {
  margin-top: 1rem;
}


/* ========================================================================== Forms ===== */

.formtitle {
  font-size: 1.2rem;
}
input[readonly].myreadonly{
  background-color:white;
}

.custom-file-input ~ .custom-file-label::after {
    content: "Choisir";
}
.form-control:focus {
  border-color: none !important;
  box-shadow: none !important;
}
input[type="text fa"] {
    font-family: "Font Awesome 5 Free", "FontAwesome";
    font-size: 1em;
    font-weight: 600;
}
.form-control:required {
  background-color: #c7eceb;
}
label.error {
    position: absolute;
    background: rgba(0, 0, 0, 0.5);
    margin-bottom: 2rem;
    padding: .5rem;
    top: -1.8rem;
    left: 1rem;
    color: #fff;
    font-size: 1rem;
    z-index: 5;
}
label.error:before {
    content: "";
    border: .5rem solid transparent;
    border-top: .5rem solid rgba(0, 0, 0, 0.5);
    position: absolute;
    bottom: -1rem;
}
.alert-success{
  background-color: #c7eceb;
}


/* ========================================================================== Navigation ===== */

.navbar {
  min-height: 6rem;
  padding: .7rem 1rem;
  text-transform: uppercase;
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .1rem;
  transition: background-color .5s ease 0s;
  background: rgba(255, 255, 255, 0.6)!important;
}
.navbar-brand img {
  height: 4rem;
}
nav.navbar .navbar-toggler {
  margin-top: -1.4rem;
}
.navbar-nav li {
  padding-left: 0.2rem;
}
.navbar-nav .nav-link {
  color: #333333;
  padding-top: .8rem;
}
.navbar-nav .nav-link:hover {
  color: #389a98;
}
.navbar.solid {
  background: rgba(255, 255, 255, 0.8)!important;
  transition: background-color 1s ease 0s;
}
.nav{
  margin-top: 1rem;
  margin-left: -1rem;
}
.nav-tabs { 
  border: 0px;
  margin-bottom: 1px;
 }
.nav-tabs .nav-item{
  background-color: rgba(255, 255, 255, 0.3);
  opacity: .5;
  border: 0px;
}
.nav-tabs .nav-item:hover{
  background-color: rgba(255, 255, 255, 0.3);
  opacity: 1;
}
.nav-tabs .nav-item.active{
  background-color: rgba(255, 255, 255, 0.3);
  opacity: 1;
}
.tab-pane{
  border: 0;
  padding: 1rem .5rem 1rem;
  margin: 0 -1rem;
  background-color: rgba(255, 255, 255, 0.3);
}
.flag{
  height: 1.2rem;
  margin-top: -.23rem;
}
.flag_uk{
  height: 1.2rem;
  margin-left: -0.5rem;
  margin-top: -.23rem;
}
.flag.fade{
  opacity: 0.5;
}

/*--- Nav Scrolling Offset --*/
.offset:before {
  height: 7rem;
  margin-top: -7rem;
  content: "";
  display: block;
}


/* ========================================================================== Sous-menus ===== */

/* animation sous-menu ici : https://startbootstrap.com/snippets/animated-navbar-dropdown/ */
@media (min-width: 992px) {
  .animate {
    animation-duration: 0.3s;
    -webkit-animation-duration: 0.3s;
    animation-fill-mode: both;
    -webkit-animation-fill-mode: both;
  }
}
@keyframes slideIn {
  0% {
    transform: translateY(2rem);
    opacity: 0;
  }
  100% {
    transform:translateY(0rem);
    opacity: 1;
  }
  0% {
    transform: translateY(2rem);
    opacity: 0;
  }
}
@-webkit-keyframes slideIn {
  0% {
    -webkit-transform: transform;
    -webkit-opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    -webkit-opacity: 1;
  }
  0% {
    -webkit-transform: translateY(2rem);
    -webkit-opacity: 0;
  }
}
.slideIn {
  -webkit-animation-name: slideIn;
  animation-name: slideIn;
}
.dropdown-toggle::after {
    display:none;
}
.dropdown-menu{
  font-size: 0.8rem;
  line-height: 0.9rem;
  text-align:center;
  width: auto;
}
.dropdown{
  text-align:center;
}
.button, .dropdown-menu{
  margin:4px auto
}
.dropdown-menu.w300{
  width: 300px; 
  left: 50%;
  margin-left:-150px;
}
.dropdown-menu.w200{
  width: 200px;
  left: 50%;
  margin-left:-100px;
}
/* fin animation sous-menu ici : https://startbootstrap.com/snippets/animated-navbar-dropdown/ */


/* ========================================================================== Buttons ===== */

button:focus, button:active {
   outline: none !important;
   box-shadow: none;
}
.btn:focus, .btn:active {
  outline: none !important;
  box-shadow: none !important;
}
.btn-info {
  background-color: #46c1be;
  border:none;
}
.btn-info a:hover {
  background-color: #666666;
}
.btn-primary{
  background-color: #46c1be;
  border: none;
}
.btn-primary:hover, .btn-primary:hover, .btn-primary:focus, .btn-primary:active{
  background-color: #389a98 !important;
}


/* ========================================================================== Buttons on images ===== */

.fa-edit, .fa-eye, .fa-eye-slash, .fa-folder, .fa-folder-open, .fa-trash-alt{
  color: white;
  font-size: 1.2rem;
}
.fa-eye.vignette{
  color: #46c1be;
  font-size: 1.2rem;
}
.fa-eye.big{
  color: #666666;
  font-size: 1.5rem;
  margin-right: .5rem;
  padding-top: .3rem;
}
.fixed-btn-1 {
  left: 1rem;
}
.fixed-btn-2 {
  left: 2rem;
}
.fixed-btn-3 {
  left: 3.2rem;
}
.fixed-btn-4 {
  left: 4.4rem;
}
.fixed-btn-1, .fixed-btn-2, .fixed-btn-3, .fixed-btn-4 {
  color: white;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  position: absolute;
  bottom: .8rem;
}
.spec-container {
  //display: inline-block;
  position: relative;
}
.overlay {
    background: rgba(0,0,0,0.5);
    opacity: 0;
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    transition:opacity 0.5s ease;
}
.fa-edit, .fa-eye, .fa-eye-slash, .fa-folder, .fa-folder-open, .fa-trash-alt{
  color: white;
  font-size: .8rem;
}
.fa-eye.vignette{
  color: #46c1be;
  font-size: .8rem;
}

/* ========================================================================== Scroll to top ===== */

.back-to-top {
    cursor: pointer;
    position: fixed;
    z-index:2000;
    bottom: 20px;
    right: 20px;
    //display:none;
}
.svg-inline--fa-chevron-up {
 color: white;
}
.top-scroll svg.svg-inline--fa {
  font-size: 3rem;
  height: 1.7rem;
  color: #53595f;
  background: white;
}
a.top-scroll {
  right: 1.2rem;
  bottom: 1.2rem;
  position: fixed;
  opacity: .3;
  z-index: 1000;
  display: none;
}
a.top-scroll:hover {
  opacity: .5;
}


/* ========================================================================== Decos obstrusives ===== */

select:-moz-focusring {
color: transparent;
text-shadow: 0 0 0 #000;
}
button::-moz-focus-inner,
input[type="reset"]::-moz-focus-inner,
input[type="button"]::-moz-focus-inner,
input[type="submit"]::-moz-focus-inner,
input[type="file"] > input[type="button"]::-moz-focus-inner {
  border: none;
}
/*--- Enlève le jaune pâle des input autofill --*/
input {
  filter: none;
}


/* ========================================================================== Scories ===== */

.ok{
  background-color: green !important;
}
.ko{
  background-color: red !important;
}


/* ========================================================================== Footer ===== */
.footertop{
  line-height: 1rem;
  height: 14rem;
}
footer {
  background: rgba(255, 255, 255, 0.6)!important;
  //background: url('r_images/footer_img.jpg') no-repeat;
  //background-size: cover;
  margin-bottom: -1rem;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100vw !important;
}
footer svg.svg-inline--fa {
  font-size: 2rem;
  margin: 0rem .2rem 0 0;
}
footer a{
  cursor: pointer;
}
#footer{
  margin-top: 1rem;
}


/* ========================================================================== Media queries ===== */

/* Devices under 992px (lg) +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media (max-width: 991px) {
  .caption h1 {
    font-size: 3.5rem;
    letter-spacing: .2rem;
    padding-bottom: .8rem;
  }
  .caption h3 {
    font-size: 1.6rem;
    line-height: 1.8rem;
    /*padding-bottom: 1.7rem;*/
  }
  .btn-lg {
    padding: .7rem 1.2rem;
    font-size: 1rem;
  }
  .narrow h1 {
    font-size: 2.1rem;
  }

/* Modifications pour le menu ============================= */
.nav-item{
  text-align: left;
  margin:0;
}
.dropdown-toggle::after {
    display:none;
}
.dropdown-menu{
  font-size: 0.8rem;
  line-height: 0.9rem;
  text-align:left;
  width: auto;
}
.dropdown{
  text-align:left;
}
.button, .dropdown-menu{
  margin: 4px auto;
}
.dropdown-menu.w300{
  width: 100%; 
  left: 50%;
  margin-left: 0px;
}
.dropdown-menu.w200{
  width: 200px;
  left: 50%;
  margin-left: 0px;
}
/* Fin Modifications pour le menu ========================= */

}

/* Devices under 768px (md) +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
@media (max-width: 767px) {

body{
  background: url('r_images/triangle_light.svg') left top no-repeat fixed, #b1cac9;
}
.set_description{
  margin-top: .2rem;
  margin-bottom: .2rem;
  font-size: .8rem;
  line-height: .9rem;
}
.w-screen{
  margin: -1rem -1rem 0;
  height: 15rem;
  overflow: hidden;
}
.head_img{
  min-height: 16rem;
}


}

/* Devices under 576px (sm) +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
@media (max-width: 575px) {

.set_title{
  font-size: 1.2rem;
  padding-top: .8rem;
  padding-bottom: .5rem;
}
.container.stroke {
  padding: 1rem .5rem 1rem;
  margin-bottom: 1rem;
  border: 0px;
}
.container.stroke-fade {
  padding: 1rem .5rem 1rem;
  border: 0px;
  margin-bottom:1rem;
  opacity: .5;
}
.footertop{
  line-height: 1rem;
  height: 28rem;
}


}


/*============ BOOTSTRAP BREAK POINTS:

Extra small (xs) devices (portrait phones, less than 576px)
No media query since this is the default in Bootstrap

Small (sm) devices (landscape phones, 576px and up)
@media (min-width: 576px) { ... }

Medium (md) devices (tablets, 768px and up)
@media (min-width: 768px) { ... }

Large (lg) devices (desktops, 992px and up)
@media (min-width: 992px) { ... }

Extra (xl) large devices (large desktops, 1200px and up)
@media (min-width: 1200px) { ... }

=============*/


