div.section1euro {
  position: absolute;
  right: 3px;
  top: 8px;
  color: #30a9ff;
}

img.sp {
  width: 24px;
  height: 24px;
}

a.button.papotage_link {
  max-width: 300px;
  overflow: hidden;
  position: relative;
  display: block;
  background: none !important;
  color: #3a36a0 !important;
  text-decoration: underline;
  font-size: 16px;
  line-height: 16px;
  white-space: nowrap;
  text-overflow: ellipsis;
  padding-right: 20px;
  padding-left: 0;
  margin: 6px 0;
  text-align: left;
}

a.button.papotage_link:hover {
  text-decoration: none;
  color: #7BF !important;
}

.papotage_link:after {
  content: " \f08e";
  font-family: "FontAwesome";
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
  text-align: center;
  background: white;
  color: #3a36a0;
}

.font-family-satisfy {
  font-family: 'Satisfy';
}

div.image_bg {
  background-position: center center;
  background-size: contain;
  background-color: #000;
  width: 100%;
  height: 195px;
  background-repeat: no-repeat;
}

* {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  /* Firefox */
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
  zoom: 1;
}

div[data-toggle="pub-recocontenuR"] {
  max-width: 800px;
  margin: auto;
}

.stickybar {
  position: sticky;
  top: 100px;
}

.minh100 {
  min-height: 100px;
}

.minh600 {
  min-height: 600px;
}

.minh800 {
  min-height: 800px;
}

.minh200 {
  min-height: 200px;
}

.minh400 {
  min-height: 400px;
}

.w100p {
  width: 100px;
}

.h100p {
  height: 100px;
}

html {
  font-size: 18px;
  min-height: 100%;
}

.text-black {
  color: black;
}

.vcenter_parent {
  display: grid;
  height: 100%;
}

.vcenter_enfant {
  margin: auto;
}

.vtop {
  vertical-align: top;
}

body {
  font: 75%/150% "Lato", Arial, Helvetica, sans-serif;
  background-color: #fff;
  color: #838383;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -ms-overflow-style: scrollbar;
  oveflow-y: scroll;
}

iframe,
img {
  border: 0;
}

a {
  text-decoration: none;
  color: inherit;
}

a:hover,
a:focus {
  color: #01b7f2;
  text-decoration: none;
}

a:focus {
  outline: none;
}

dt {
  font-weight: normal;
}

span.active,
a.active,
h2.active,
h3.active,
h4.active,
h5.active,
h6.active {
  color: #01b7f2;
}

h3.bigLineHeight {
  line-height: 2em;
}

.maxwidth300px {
  max-width: 300px;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}

h1 {
  font-size: 2em;
  line-height: 1.25em;
  /*24px, 30px*/
}

h2 {
  font-size: 1.6667em;
  line-height: 1.25em;
  /*20px, 35px*/
}

h3 {
  font-size: 1.5em;
  line-height: 1.2222em;
  /*18px, 22px*/
}

h4 {
  font-size: 1.3333em;
  line-height: 1.25em;
  /*16px, 20px*/
}

h5 {
  font-size: 1.1666em;
  line-height: 1.1428em;
  /*14px, 16px*/
}

h6 {
  font-size: 1em;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 15px;
  font-weight: normal;
  color: #2d3e52;
}

.padding0-15 {
  padding: 0 15px;
}

.padding0-30 {
  padding: 0 30px;
}

.border1 {
  border: 1px solid #AAA;
}

#footer .footer-wrapper {
  background-image: linear-gradient(225deg, #1993B6 0, #4DD2B8 100%);
  padding: 80px 0;
}

div.half-page+div.w100pm300 hr.separebloc {
  margin-left: -17px;
}

hr.mini.separebloc {
  padding-top: 15px;
  padding-bottom: 15px;
}

hr.transparent {
  margin-top: 20px;
  margin-bottom: 20px;
  border-color: transparent !important;
}

hr.mini.transparent {
  border-color: transparent;
  margin-top: 10px;
  margin-bottom: 10px;
}

hr.pubBasTransparent {
  padding-top: 50px;
  padding-bottom: 50px;
  background: #f5f5f5;
  border-color: #f5f5f5;
  margin: 0;
}

hr.umini {
  margin-top: 2px;
  margin-bottom: 2px;
  border-color: #f5f5f5;
}

hr.bloc {
  border-width: 50px;
  margin-top: 20px;
  width: 100%;
  float: left;
  margin-left: -20px;
  padding-right: 40px;
}

hr.bloc.mini {
  border-width: 20px;
  margin-top: 10px;
  margin-bottom: 10px;
  width: 100%;
  float: left;
  margin-left: -20px;
  padding-right: 40px;
}

.checkbox.custom {}

.checkbox.custom:before {
  display: inline-block;
  position: absolute;
  vertical-align: top;
  z-index: -1;
}

.checkbox.custom.checked:before {}

.checkbox.custom label {
  display: inline-block;
  vertical-align: top;
  margin: 0;
  padding-left: 28px;
  user-select: none;
}

.checkbox.custom input[type="checkbox"] {
  display: none;
}

/* 5) Table */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

.boutonrond {
  border-radius: 5px;
}

a.button.btn-medium.boutonSP {
  border-radius: 50px;
  width: 80px;
  height: 80px;
  line-height: 80px;
  padding: 0;
  background: url(/ressources/images/coupdepatte3transparent.png);
  background-size: 70%;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: #3184cc52;
  color: #1f5879;
  text-shadow: 1px 1px 10px rgba(255, 255, 255, 1);
  border: 4px solid #1f587936;
  position: relative;
}

a.button.btn-medium.boutonSP.split:hover:after {
  content: "✂️";
  position: absolute;
  margin-top: 50%;
  margin-left: 50%;
  transform: translateX(-50%) translateY(-50%) rotate(180deg);
  left: 0;
  top: 0;
  font-size: 38px;
}

a.button.btn-medium.boutonSP.quizz:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background: url(/ressources/images/superpattes_quizz.png);
  background-size: 100% 100%;
  opacity: 0.5;
}

a.button.btn-medium.boutonSP.parrainage:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background: url(/ressources/images/superpattes_parrainage.png);
  background-size: 100% 100%;
  opacity: 0.5;
}

a.button.btn-medium.boutonSP.loto:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background: url(/ressources/images/superpattes_loto.png);
  background-size: 100% 100%;
  opacity: 0.5;
}

a.button.btn-medium.boutonSP:hover {
  background-color: #3184cca6;
  color: #fff;
  box-shadow: 0px 0px 5px 0px #555;
}

/* SIZE */
.little-size {
  font-size: 10px;
  line-height: 12px;
}

.little-size .big-size {
  position: relative;
  top: 10px;
}

.big-size {
  font-size: 30px;
}

.gg-size {
  font-size: 25px;
  line-height: 25px;
}

.m-size {
  font-size: 16px;
  line-height: 25px;
}

.g-size {
  font-size: 20px;
  line-height: 25px;
}

.xxl-size {
  font-size: 40px;
  line-height: 40px;
}

.normal-size {
  font-size: 0.8333em !important;
}

.gras {
  font-weight: bold;
}

/* 8) Colors */
.transparent-color {
  color: transparent !important;
}

.blue-color {
  color: #01b7f2 !important;
}

.light-blue-color {
  color: #7692b4;
}

.yellow-color {
  color: #5BC0DE !important;
}

.red-color {
  color: #e01a33 !important;
}

.orange-color {
  color: #ee9e03 !important;
}

.green-color {
  color: #7db921 !important;
}

.white-color {
  color: #fff !important;
}

.dark-blue-color {
  color: #2d3e52 !important;
}

.text-color {
  color: #5e676f
}

.skin-color {
  color: #01b7f2;
}

.grey-color {
  color: #797979;
}

.default-color {
  color: inherit !important;
}

.gray-color {
  color: #9e9e9e !important;
}

.hotel-color {
  color: #01b7f2;
}

.select-color {
  color: #5BC0DE;
}

.blue-bg {
  background-color: #01b7f2 !important;
}

.yellow-bg {
  background-color: #5BC0DE;
}

.black-bg {
  background-color: #000;
}

.gold-bg {
  background-color: #ffe5ab !important;
  color: #9b6b00 !important;
}

.gold-bg:hover {
  background-color: #fff5cb !important;
  color: #ab8b30 !important;

}

.duck-blue-bg {
  background-color: #276375;
}

.red-bg {
  background-color: #e01a33 !important;
}

.green-bg {
  background-color: #98ce44 !important;
}

.logosp-bg {
  background-image: url(/ressources/images/coupdepatte3.png);
  background-position: center center;
  background-size: auto 80%;
  background-repeat: no-repeat;
}

.white-bg {
  background-color: #fff !important;
}

.white-bg.hover:hover {
  background-color: #ddd !important;
}

.dark-blue-bg {
  background-color: #2d3e52 !important;
}

.skin-bg {
  background-color: #01b7f2 !important;
}

.dark-bg {
  background-color: #6d6d6d !important;
}

.darkgray-bg {
  background-color: #efefef !important;
}

.gray-bg {
  background-color: #f5f5f5 !important;
}

.bandeau-bg {
  background-color: #c3f0ff !important;
}

button.btn-small-img,
a.button.btn-small-img {
  height: 28px;
  padding: 0 10px;
  line-height: 28px;
  font-size: 0.9167em;
}

button.btn-mini,
a.button.btn-mini {
  height: 19px;
  padding: 0 20px;
  font-size: 0.8333em;
  line-height: 19px;
}

button.full-width,
a.button.full-width {
  padding-left: 0;
  padding-right: 0;
}

button:hover,
a.btn-inscription:hover {
  background: #7fb231;
}

button:focus {
  box-shadow: none;
  outline: none;
}

a.button:hover {
  background: #98ce44;
}

.button.outline-skin {
  color: #01b7f2;
  ;
  border-color: #01b7f2;
}

.button.outline-skin:hover {
  color: #fff;
  background-color: #01b7f2;
  border-color: #01b7f2;
}

a.button.blue:hover,
a.btn.blue:hover {
  background: #4498ce;
}

a.button.btn-mini {
  padding-left: 10px;
  padding-right: 10px;
}

a.button.btn-large,
a.button.btn-medium,
a.button.btn-small,
a.button.full-width {
  font-weight: bold;
}

span.input-group-addon.perso {
  padding: 0;
  border: 0;
  border-radius: 0;
}

button,
a.button {
  cursor: pointer;
  /* Extra buttons */
}

button.white,
a.button.white {
  background: #fff;
  color: inherit;
}

button.silver,
a.button.silver {
  background: #d9d9d9;
}

button.sky-blue1,
a.button.sky-blue1 {
  background: #01b7f2;
}

button.sky-blue1:hover,
a.button.sky-blue1:hover {
  background: #07a5d8;
}

button.yellow,
a.button.yellow {
  background: #5BC0DE;
}

button.yellow:hover,
a.button.yellow:hover {
  background: #e9b02b;
}

button.dark-blue1,
a.button.dark-blue1 {
  background: #2d3e52;
}

a.btn.green,
button.green,
a.button.green {
  background: #98ce44;
}

button.green:hover,
a.button.green:hover,
a.btn.green:hover {
  background: #7fb231;
}

a.btn.pink,
button.pink,
a.button.pink {
  background: #ff51ad;
}

button.pink:hover,
a.button.pink:hover,
a.btn.pink:hover {
  background: #b23180;
}

button.btn-link:hover {
  background: initial;
}

label.btn.red.active,
button.red,
a.button.red {
  background: #e44049;
}

label.btn.red {
  border: 1px solid rgba(0, 0, 0, 0.2);
}

label.btn.red.active {
  color: #FFF;
}

a.button.red[disabled] {
  background: #f48089;
}

button.redhover:hover,
a.button.redhover:hover {
  background: #e44049;
}

button.light-brown,
a.button.light-brown {
  background: #e6c687;
}

button.orange,
a.button.orange {
  background: #ff6000;
}

button.dull-blue,
a.button.dull-blue {
  background: #12a0c3;
}

button.light-orange,
a.button.light-orange {
  background: #f5a77d;
}

button.light-purple,
a.button.light-purple {
  background: #db8df6;
}

button.sea-blue,
a.button.sea-blue {
  background: #0ab596;
}

button.sea-blue,
a.button.sea-blue:hover {
  background: #33e2c3;
}

button.sky-blue2,
a.button.sky-blue2 {
  background: #6dace6;
}

button.dark-blue2,
a.button.dark-blue2 {
  background: #194eb0;
}

button.dark-orange,
a.button.dark-orange {
  background: #ff3e3e;
}

button.purple,
a.button.purple {
  background: #9f60b5;
}

button.light-yellow,
a.button.light-yellow {
  background: #ffd200;
}

.instagram-button {
  display: inline-block;
  background: #E4405F;
  color: #fff;
  padding: 10px 15px;
  font-size: 16px;
  text-decoration: none;
  border-radius: 5px;
  font-family: Arial, sans-serif;
}

.instagram-button i {
  margin-right: 5px;
}

.instagram-button:hover {
  background: #c13584;
}

.button.share {
  font-size: 24px;
  border-radius: 50px;
  height: 54px;
  width: 54px;
  text-align: center;
  line-height: 54px;
}

.button.share.little {
  font-size: 24px;
  border-radius: 50px;
  height: 32px;
  min-width: 32px;
  width: 32px;
  text-align: center;
  line-height: 32px;
  vertical-align: middle;
  padding: 0 8px;
}

q,
blockquote {
  quotes: '\201C' '\201D' '\2018' '\2019';
}

blockquote {
  font-size: 1.3333em;
  line-height: 1.6em;
  padding: 20px 20px 20px 40px;
  border-left: none;
  position: relative;
  text-indent: -19px;
}

blockquote p {
  font-size: 1em;
}

blockquote:before,
blockquote:after {
  font-family: Georgia, serif;
  font-size: 2.5em;
  vertical-align: middle;
  line-height: 0;
}

blockquote:before {
  /* content: open-quote; */
  margin-right: 4px;
}

blockquote:after {
  /* content: close-quote; */
  margin-left: 3px;
}

button,
a.button {
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 0 15px;
  white-space: nowrap;
  user-select: none;
}

.btn-img img {
  max-height: calc(100% - 8px);
  vertical-align: top;
  padding-top: 8px;
  padding-right: 2px;
}

.btn-img-big img {
  max-height: 98%;
  vertical-align: top;
  padding-top: 1%;
  padding-right: 0px;
}

span.important {
  font-weight: bold;
  text-decoration: underline;
  color: rgb(2 134 187 / 80%);
}

i.important {
  font-weight: bold;
  color: rgb(2 134 187 / 80%);
}

.circle {
  width: 105px;
  border-radius: 135px;
  height: 105px;
  display: inline-block;
  box-sizing: border-box;
  padding-top: 22px;
  font-size: 55px;
  line-height: 55px;
}

i.circle {
  padding-top: 0;
}

.circle i.fa {}

.circle:hover {
  font-size: 75px;
  line-height: 75px;
  transition: 0.5s font-size ease;
}

.vmiddle {
  vertical-align: middle;
}

img.size-logo {
  max-width: 96px;
  max-height: 96px;
}

#page-wrapper {
  position: relative;
  overflow: visible;
  z-index: 999;
}

.gray-area {
  background: #f5f5f5;
}

a#coupdepatte {
  cursor: url(/ressources/images/paw.png), auto;
}

div.floating-cagnotte {
  position: fixed;
  right: 0;
  top: calc((100vh - 575px) / 2);
  z-index: 10000;
  opacity: 0.4;
}

div.floating-cagnotte:hover {
  opacity: 1;
}

section.liste_cagnottes article.box figure span img {
  max-width: 96px;
  max-height: 96px;
}

section#content.liste_collectes,
section#content.liste_cagnottes {
  padding-top: 0;
}

section#content.cagnotte,
section#content.admin {
  z-index: initial;
}

#main {
  margin-bottom: 40px;
  z-index: 1001;
}

.box-title {
  margin-bottom: 0;
  line-height: 1em;
}

.box-title small {
  font-size: 10px;
  color: #838383;
  text-transform: uppercase;
  display: block;
  margin-top: 4px;
  /*letter-spacing: normal;*/
}

.border-circle {
  border: 1px solid;
}

input.input-text,
input.form-control,
select,
textarea,
span.custom-select {
  background: #f5f5f5 !important;
  border: none !important;
  line-height: normal !important;
  box-shadow: none !important;
}

input.input-text:focus,
input.form-control:focus,
textarea:focus {
  background: #e5E5e5 !important;
  box-shadow: none;
}

input.bg-grey {
  background: #c5c5c5;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

input.input-text+span.input-group-addon {
  background: #5BC0DE !important;
  color: white;
  border: none;
}

input.transparent {
  display: inline-block;
  border: 0;
  padding: 2px 10px;
}

div.custom_select a.dropdown-toggle {
  padding-left: 17px;
  position: relative;
}

div.custom_select a.dropdown-toggle:after {
  position: absolute;
  right: 10px;
  top: calc(50% - 5px);
}

div.custom_select a.dropdown-item img {
  max-height: 32px;
  margin-right: 10px;
  width: 32px;
}

div.custom_select a.dropdown-item {
  border-bottom: 1px solid #88bde0;
  background: #a4dbff;
  cursor: pointer;
}

div.custom_select a.dropdown-item:hover {
  border-bottom: 1px solid #A8ddff;
  background: #b4ebff;
}

select.input-text+span.input-group-addon {
  background: #5BC0DE !important;
  color: white;
  border: none;
}

textarea.form-control+div.input-group-append span.input-group-text,
input+div.input-group-append span.input-group-text {
  background: #5BC0DE !important;
  color: white;
  border: none;
}

select {
  height: 34px;
  padding: 8px 0 8px 8px;
}

select option {
  padding: 2px 10px;
}

div.input-group textarea.input-text {
  display: block;
  resize: none;
  height: 50px;
}

div.input-group textarea.input-text.description {
  height: 190px;
}

.w100 {
  width: 100px;
}

div.half-page.h240 {
  height: 240px;
}

div.half-page.h200 {
  height: 200px;
}

div.half-page.environnement_test {
  width: 300px;
  height: 600px;
  display: inline-block;
  vertical-align: top;
}

div.p300x200 {
  width: 300px;
  height: 250px;
  display: inline-block;
  vertical-align: top;
}

div.environnement_test {
  background: pink;
}

div.environnement_test:before {
  content: "Publicité";
  position: absolute;
}

section#content div.section div.half-page {
  top: 172px;
}

section#content div.half-page {
  top: 40px;
}

div.half-page.publeft {
  left: 0;
}

div.half-page.pubright {
  right: 0;
}

div.half-page.fleft {
  float: left;
}

.habillage {
  margin-top: 250px;
}

.vbottom {
  vertical-align: bottom;
}

.nowrap {
  white-space: nowrap;
}

.selector {
  position: relative;
  min-width: 60px;
  line-height: 0;
}

.selector select {
  position: absolute;
  z-index: 1;
  filter: alpha(opacity=0);
  opacity: 0;
  width: 100%;
  line-height: 30px;
}

.selector span.custom-select {
  display: inline-block;
  line-height: 32px !important;
  padding: 0 10px;
  position: relative;
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
}

.selector span.custom-select:before {
  position: absolute;
  right: 0;
  top: 0;
  content: '';
  background: #5BC0DE;
  width: 24px;
  height: 100%;
}

.selector span.custom-select:after {
  position: absolute;
  right: 9px;
  top: 15px;
  border-top: 5px solid #fff;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  content: "";
}

.selector.style1 span.custom-select:before {
  background: transparent;
}

.selector.style1 span.custom-select:after {
  border-top-color: #5BC0DE;
}

.tab-container ul.nav.nav-tabs {
  margin: 0;
  padding: 0;
}

.tab-container ul.nav.nav-tabs li {
  float: left;
  padding-right: 4px;
}

.tab-container ul.nav.nav-tabs li:last-child {
  padding-right: 0;
}

.tab-container ul.nav.nav-tabs li a {
  color: #fff;
  display: block;
  padding: 0 10px;
  background: #bbb;
  font-size: 1em;
  font-weight: bold;
  height: 40px;
  line-height: 40px;
  text-decoration: none;
  text-transform: uppercase;
}

.tab-container ul.nav.nav-tabs li:first-child a {
  background: #5bc0de;
}

.tab-container ul.nav.nav-tabs li>a.active,
.tab-container ul.nav.nav-tabs li:hover>a {
  color: #FFF;
  background: #7db921;
}

.tab-container ul.nav.nav-tabs.full-width {
  display: block;
}

.tab-container ul.nav.nav-tabs.full-width li {
  float: none;
  display: table-cell;
  vertical-align: middle;
  width: 1%;
  white-space: nowrap;
}

.tab-container ul.nav.nav-tabs.full-width li a {
  padding: 0;
  text-align: center;
}

.tab-container ul.nav.nav-tabs:after {
  display: table;
  content: "";
  clear: both;
}

.tab-container .tab-content {
  background: #fff;
}

.tab-container .tab-content .tab-pane,
div#hotel-main-content.tab-container div.tab-content div.tab-pane.tab-padding {
  padding: 20px;
  line-height: 1.7em;
}

.tab-container .tab-content .tab-pane .row {
  margin-bottom: 15px;
}

.tab-container .tab-content .tab-pane>img {
  margin: 0 15px 0 0;
}

.tab-container .tab-content .tab-pane:after {
  content: "";
  display: table;
  clear: both;
}

.tab-container .tab-content .tab-pane .image-box .details {
  padding-right: 0;
}

.tab-container .tab-content .tab-pane .image-box .box.little .details {
  padding-top: 0 !important;
}

.tab-container.full-width-style>ul.nav.nav-tabs {
  width: 14%;
  float: left;
}

.tab-container.full-width-style ul.nav.nav-tabs:after {
  display: none;
  clear: none;
}

.tab-container.full-width-style>ul.nav.nav-tabs li {
  float: none;
  margin: 0;
  padding-right: 0;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a {
  height: 100px;
  display: block;
  border-bottom: 3px solid #f5f5f5;
  border-right: 3px solid #f5f5f5;
  background: #fff;
  color: inherit;
  font-size: 1.1667em;
  text-transform: none;
  font-weight: normal;
  text-align: center;
  padding-top: 12px;
  line-height: 1.3em;
  transition: 1s all ease;
}

.tab-container.full-width-style>ul.nav.nav-tabs.mini li a {
  height: 65px;
  padding-top: 6px;
  line-height: 1.1em;
}

.tab-container.full-width-style>ul.nav.nav-tabs.mini li a>i {
  font-size: 28px;
  width: 1.3em;
  height: 1.3em;
  line-height: 1.2em;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a>i {
  color: #d9d9d9;
  display: block;
  font-size: 40px;
  margin: 0 auto;
  line-height: 40px;
  overflow: hidden;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a:hover i:before {
  -webkit-animation: toTopFromBottom 0.3s forwards;
  -moz-animation: toTopFromBottom 0.3s forwards;
  animation: toTopFromBottom 0.3s forwards;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a.active,
.tab-container.full-width-style ul.nav.nav-tabs li a:hover {
  color: #01b7f2;
  background: #ddeeff;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a.active i,
.tab-container.full-width-style ul.nav.nav-tabs li a:hover i {
  color: #FFF;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a:hover i,
.tab-container.full-width-style ul.nav.nav-tabs li a.active i {
  color: #FFF;
  border-color: #FFF;
}

.tab-container.full-width-style>ul.nav.nav-tabs li:last-child a.active {
  border-bottom: none;
}

.tab-container.full-width-style>ul.nav.nav-tabs li a.active {
  border-right-color: transparent;
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li {
  margin-bottom: 4px;
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li a {
  border: none;
  margin-right: 4px;
  border-radius: 0px;
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li a.active {
  margin-right: 0;
  border-left: 2px solid #5BC0DE;
  position: relative;
  background: #5BC0DE;
  color: #FFF;
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li a.active:after {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -5px;
  border-left: 3px solid #5BC0DE;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li.new a {
  background: #fc8f8f;
  color: #FFF;
  animation: bgcolorchange 1s infinite;
}

@keyframes bgcolorchange {
  0% {
    background-color: #fc8f8f;
  }

  50% {
    background-color: #fd5454;
  }

  100% {
    background-color: #fc8f8f;
  }
}

.tab-container.full-width-style.arrow-left>ul.nav.nav-tabs li.new a i {
  color: #FFF;
}

.tab-container.full-width-style.arrow-left .tab-content .tab-pane {
  padding: 30px;
  min-height: 620px;
}

.tab-container.full-width-style .tab-content {
  float: left;
  width: 100%;
}

.tab-container.full-width-style>.tab-content {
  float: left;
  width: 86%;
}

.tab-container.full-width-style .tab-content .tab-content-title {
  color: #01b7f2;
}

.tab-container.full-width-style:after {
  display: table;
  content: "";
  clear: both;
}

.tab-container.full-width-style>ul.nav.nav-tabs.orga-tabs li a {
  background: rgba(13, 18, 24, 0.6);
  color: #708bac;
}

.tab-container.full-width-style>ul.nav.nav-tabs.orga-tabs li a.active {
  background: #fff;
  color: #2d3e52;
}

.tab-container.full-width-style>ul.nav.nav-tabs.orga-tabs li a>i {
  border-color: #708bac;
  color: #708bac;
}

.tab-container.full-width-style>ul.nav.nav-tabs.orga-tabs li a.active>i {
  border-color: #5BC0DE;
  color: #5BC0DE;
}

.datepicker-wrap {
  position: relative;
}

.datepicker-wrap .ui-datepicker-trigger {
  width: 30px;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  cursor: pointer;
  background-color: transparent;
  z-index: 1;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -moz-opacity: 0;
  -khtml-opacity: 0;
  opacity: 0;
}

.datepicker-wrap:after {
  display: block;
  font-family: "FontAwesome";
  content: "\f073";
  font-size: 25px;
  color: #fff;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 30px;
  height: 100%;
  text-align: center;
  line-height: 34px;
  background: #5BC0DE;
}

.datepicker-wrap.yellow:after {
  background: #5BC0DE;
}

.datepicker-wrap.green:after {
  background: #98ce44;
}

.datepicker-wrap.blue:after {
  background-color: #01b7f2;
}

.datepicker-wrap.dark-blue:after {
  background-color: #2d3e52;
}

.datepicker-wrap.transparent:after {
  background-color: transparent;
  color: #5BC0DE;
}

.ui-datepicker {
  width: 20em;
  padding: 0;
  display: none;
  background: #fff;
  border: 1px solid #5BC0DE;
}

.ui-datepicker .ui-datepicker-header {
  position: relative;
  padding: .2em 0;
  background: #5BC0DE;
}

.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  position: absolute;
  top: 11px;
  cursor: pointer;
}

.ui-datepicker .ui-datepicker-prev.ui-state-disabled,
.ui-datepicker .ui-datepicker-next.ui-state-disabled {
  visibility: hidden;
}

.ui-datepicker .ui-datepicker-prev:before,
.ui-datepicker .ui-datepicker-next:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}

.ui-datepicker .ui-datepicker-prev {
  left: 24px;
}

.ui-datepicker .ui-datepicker-prev:before {
  border-right: 8px solid #fff;
}

.ui-datepicker .ui-datepicker-next {
  right: 24px;
}

.ui-datepicker .ui-datepicker-next:before {
  border-left: 8px solid #fff;
}

.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  display: none;
}

.ui-datepicker .ui-datepicker-title {
  margin: 5px;
  text-align: center;
  color: #fff;
  font-size: 1.1667em;
  font-weight: bold;
}

.ui-datepicker .ui-datepicker-title select {
  font-size: 1em;
  margin: 1px 0;
}

.ui-datepicker select.ui-datepicker-month-year {
  width: 100%;
}

.ui-datepicker select.ui-datepicker-month,
.ui-datepicker select.ui-datepicker-year {
  width: 49%;
}

.ui-datepicker table {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}

.ui-datepicker th {
  width: 30px;
  height: 30px;
  line-height: 30px;
  background: #f5f5f5;
}

.ui-datepicker th span {
  display: block;
  text-align: center;
  font-size: 1.1667em;
  font-weight: normal;
  color: #5BC0DE;
}

.ui-datepicker span.ui-datepicker-month {
  font-weight: bold;
}

.ui-datepicker .ui-datepicker-calendar td {
  vertical-align: middle;
  text-align: center;
}

.ui-datepicker .ui-datepicker-calendar td a,
.ui-datepicker .ui-datepicker-calendar td span {
  color: inherit;
  display: block;
  height: 30px;
  line-height: 30px;
}

.ui-datepicker .ui-datepicker-calendar td.ui-state-disabled span {
  color: #dbdbdb;
}

.ui-datepicker .ui-datepicker-calendar td.ui-datepicker-today a,
.ui-datepicker .ui-datepicker-calendar td a:hover {
  background: #5BC0DE;
  color: #fff;
}

.ui-datepicker.yellow {
  border: 1px solid #5BC0DE;
}

.ui-datepicker.yellow .ui-datepicker-header {
  background: #5BC0DE;
}

.ui-datepicker.yellow th span {
  color: #5BC0DE;
}

.ui-datepicker.yellow .ui-datepicker-calendar td.ui-datepicker-today a,
.ui-datepicker.yellow .ui-datepicker-calendar td a:hover {
  background: #5BC0DE;
}

.ui-datepicker.green {
  border: 1px solid #98ce44;
}

.ui-datepicker.green .ui-datepicker-header {
  background: #98ce44;
}

.ui-datepicker.green th span {
  color: #98ce44;
}

.ui-datepicker.green .ui-datepicker-calendar td.ui-datepicker-today a,
.ui-datepicker.green .ui-datepicker-calendar td a:hover {
  background: #98ce44;
}

.ui-datepicker.blue {
  border: 1px solid #01b7f2;
}

.ui-datepicker.blue .ui-datepicker-header {
  background: #01b7f2;
}

.ui-datepicker.blue th span {
  color: #01b7f2;
}

.ui-datepicker.blue .ui-datepicker-calendar td.ui-datepicker-today a,
.ui-datepicker.blue .ui-datepicker-calendar td a:hover {
  background: #01b7f2;
}

.ui-datepicker.dark-blue {
  border: 1px solid #2d3e52;
}

.ui-datepicker.dark-blue .ui-datepicker-header {
  background: #2d3e52;
}

.ui-datepicker.dark-blue th span {
  color: #2d3e52;
}

.ui-datepicker.dark-blue .ui-datepicker-calendar td.ui-datepicker-today a,
.ui-datepicker.dark-blue .ui-datepicker-calendar td a:hover {
  background: #2d3e52;
}

.fileinput {
  position: relative;
  display: inline-block;
  min-width: 100px;
}

.fileinput.image {
  vertical-align: middle;
  cursor: pointer;
  max-height: 100%;
  max-width: 100%;
  text-align: center;
}

.fileinput.image.avatar:before {
  content: 'Avatar';
  position: absolute;
  top: -25px;
  vertical-align: top;
  display: block;
  height: 25px;
  width: 100%;
  line-height: initial;
  font-weight: bold;
}

form.organisme .fileinput.image.avatar:before {
  content: 'Logo';
}

.fileinput img {
  max-height: 100%;
  max-width: 100%;
  line-height: normal;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.5);
}

.fileinput input[type=file] {
  width: 100%;
  cursor: pointer;
  height: calc(1.5em + .75rem + 2px);
  padding: 0;
  vertical-align: top;
}

.fileinput.avatar input[type=file] {
  width: 100%;
  height: 100%;
  position: absolute;
}

.fileinput span {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 1;
  text-align: center;
  background: linear-gradient(225deg, #04afe7 0, #5bc0de 100%);
  color: white;
  cursor: pointer;
}

.fileinput.avatar:hover span {
  opacity: 1;
}

.fileinput.avatar span i {
  vertical-align: middle;
  margin-top: 50%;
  /* pouss? de la moiti? de hauteur de viewport */
  transform: translateY(-50%);
  font-size: 32px;
}

.fileinput input[type=file] {
  position: relative;
  z-index: 2;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -moz-opacity: 0;
  -khtml-opacity: 0;
  opacity: 0;
  width: 100%;
}

.fileinput .custom-fileinput {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: calc(100% - 82px);
  line-height: normal;
  text-align: right;
}

div.fileinput.fichier input.input-text.noname+.custom-fileinput {
  display: inline-block;
  max-width: 226px;
  overflow: hidden;
}

input.input-text.noname+.custom-fileinput {
  display: none;
}

.fileinput.miniature:after {
  display: none;
}

.fileinput.miniature input[type="file"] {
  display: none;
}

.fileinput.miniature div.apercu span {
  display: none;
}

.fileinput.miniature div.apercu:hover span {
  display: block;
  position: absolute;
  text-align: center;
  width: 100%;
  height: 100%;
  top: 0;
  background: rgb(35, 155, 205);
  color: white;
  opacity: 0.8;
}

.fileinput.miniature div.apercu {
  position: relative;
  background: #FFF;
}

.fileinput.miniature div.apercu i {
  border: 2px solid #FFF;
  padding: 15px;
  border-radius: 50px;
  vertical-align: middle;
  display: inline-block;
  top: 50%;
  /* pouss? de la moiti? de hauteur du r?f?rent */
  transform: translateY(-50%);
  position: relative;
}

.fileinput.miniature div.apercu img {
  margin-bottom: 0;
}

.fileinput.avatar:after {
  display: none;
}

.skin-bg .fileinput:after {
  background: #c63d3d;
}

.fileinput.image:after {
  display: block;
  content: "Télécharger une photo";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 1;
  background: #5BC0DE;
  color: #fff;
  font-size: 1em;
  min-width: 200px;
  padding-left: 15px;
  padding-right: 15px;
  letter-spacing: 0.04em;
  font-weight: bold;
  vertical-align: middle;
  right: inherit;
  line-height: 32px;
}

.fileinput:after {
  display: block;
  content: "Choisir...";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  background: #5BC0DE;
  color: #fff;
  font-size: 1em;
  padding-left: 15px;
  padding-right: 15px;
  letter-spacing: 0.04em;
  font-weight: bold;
  vertical-align: middle;
  line-height: 40px;
}

form#compte_organisme_creer_cagnotte .bs-stepper .line,
form#compte_organisme_creer_cagnotte .bs-stepper-line {
  -ms-flex: 1 0 26px;
  flex: 1 0 26px;
}

form#compte_organisme_creer_cagnotte .bs-stepper .active .step-trigger {
  background-color: #01b7f2;
}

form#compte_organisme_creer_cagnotte .active .bs-stepper-circle {
  background-color: #ffffff;
  color: #2ea1d8;
}

form#compte_organisme_creer_cagnotte .active .bs-stepper-label {
  color: white;
}

input.form-control.lecture_icad,
select.lecture_icad+span.custom-select {
  background: #88e4ff !important;
}

form label {
  text-transform: uppercase;
  display: block;
  margin-bottom: 5px;
  margin-top: 15px;
  font-weight: bold;
  font-size: 1.25em;
}

form .checkbox label,
form label.checkbox {
  font-size: 1.0833em;
  text-transform: none;
  text-indent: 10px;
}

form .radio label,
form label.radio {
  font-size: 0.9167em;
}

form .form-group {
  margin-bottom: 15px;
}

label.image_radio input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* IMAGE STYLES */
label.image_radio input[type=radio]+img {
  cursor: pointer;
  margin: 0 10px;
  opacity: 0.6;
  border: 5px solid transparent;
}

label.image_radio input[type=radio]+img:hover {
  opacity: 0.95;
}

/* CHECKED STYLES */
label.image_radio input[type=radio]:checked+img {
  opacity: 1;
  border: 5px solid #fefbe421;
  background: #c11c02;
  border-radius: 10px;
}

.checkbox,
.radio {
  position: relative;
  margin-top: 0;
  line-height: 20px;
  text-align: left
}

.checkbox:before,
.radio:before {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 0px;
  width: 21px;
  height: 21px;
  border: 1px solid #d1d1d1;
  z-index: 0;
  font-family: "FontAwesome";
  line-height: 21px;
  text-align: center;
}

.checkbox.checked:before,
.radio.checked:before {
  border-color: #01b7f2;
  color: #fff;
  background: #01b7f2;
  content: "\f00c";
}

/* checkbox */
.checkbox label,
.checkbox.label {
  font-size: 1.0833em;
  line-height: 20px;
  color: #9e9e9e;
}

.checkbox input[type="checkbox"] {
  position: relative;
  z-index: 1;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -moz-opacity: 0;
  -khtml-opacity: 0;
  opacity: 0;
  width: 21px;
  height: 21px;
  display: inline-block;
  vertical-align: middle;
}

/* radio */
.radio label,
.radio.label {
  font-size: 0.9167em;
  line-height: 20px;
}

.radio input[type="radio"] {
  position: relative;
  z-index: 1;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -moz-opacity: 0;
  -khtml-opacity: 0;
  opacity: 0;
}

.radio:before {
  background: #fff;
  -webkit-border-radius: 50% 50% 50% 50%;
  -moz-border-radius: 50% 50% 50% 50%;
  -ms-border-radius: 50% 50% 50% 50%;
  border-radius: 50% 50% 50% 50%;
  font-size: 1.3333em;
  line-height: 13px;
}

.radio.radio-square:before {
  -webkit-border-radius: 0 0 0 0;
  -moz-border-radius: 0 0 0 0;
  -ms-border-radius: 0 0 0 0;
  border-radius: 0 0 0 0;
}

.radio.checked:before {
  content: "\e892";
}

.travelo-signup-box,
.travelo-login-box {
  border: 2px solid #01b7f2;
  width: 300px;
  margin: 0 auto;
  display: none;
  padding: 20px;
}

.travelo-signup-box .login-social .button,
.travelo-login-box .login-social .button {
  width: 100%;
  height: 36px;
  line-height: 36px;
  margin-bottom: 10px;
  font-size: 1.3333em;
  font-weight: 400;
  text-align: left;
  padding-left: 20px;
  letter-spacing: 0.04em;
}

.travelo-signup-box .login-social .button i,
.travelo-login-box .login-social .button i {
  font-size: 1.5em;
  margin-right: 36px;
  width: 20px;
  float: left;
  display: block;
}

.travelo-signup-box .login-facebook,
.travelo-login-box .login-facebook,
.button.facebook {
  background: #155c92;
}

.travelo-signup-box .login-googleplus,
.travelo-login-box .login-googleplus {
  background: #d13535;
}

.travelo-signup-box .seperator,
.travelo-login-box .seperator {
  line-height: 0;
  border-top: 1px solid #f5f5f5;
  position: relative;
  margin-top: 10px;
  margin-bottom: 10px;
}

.travelo-signup-box .seperator label,
.travelo-login-box .seperator label {
  display: block;
  font-size: 0.9167em;
  position: absolute;
  left: 50%;
  top: 50%;
  line-height: 1;
  background: #fff;
  padding: 0 10px;
  margin: -1px 0 0;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-weight: 400;
}

.travelo-signup-box p,
.travelo-login-box p {
  margin-bottom: 0;
}

.travelo-signup-box .description,
.travelo-login-box .description {
  font-size: 1em;
  color: #9e9e9e;
}

.travelo-signup-box .form-group,
.travelo-login-box .form-group {
  margin-bottom: 10px;
  text-align: left;
}

.travelo-signup-box .checkbox label,
.travelo-login-box .checkbox label {
  font-size: 1em;
}

.travelo-signup-box .goto-login,
.travelo-signup-box .goto-signup,
.travelo-signup-box .signup-email,
.travelo-login-box .goto-login,
.travelo-login-box .goto-signup,
.travelo-login-box .signup-email {
  color: #01b7f2;
  font-size: 1.0833em;
}

.travelo-signup-box .signup-email-section {
  margin-bottom: 10px;
}

.travelo-signup-box .signup-email i {
  font-size: 1.2em;
  margin-right: 4px;
}

.travelo-signup-box .email-signup {
  margin-top: 5px;
  margin-bottom: 20px;
  display: block;
}

.travelo-login-box .checkbox-inline {
  margin-left: 0;
}

.travelo-login-box .forgot-password {
  color: #01b7f2;
  text-decoration: underline;
}

div.modal {
  z-index: 3000 !important;
}

div.modal#waiting {
  z-index: 30000 !important;
}

.modal-big {
  width: 1200px;
  max-width: 100%;
}

.modal-full {
  width: 100%;
  max-width: 100%;
}

.modal.modal-paiement {}

.modal.modal-paiement .modal-content {
  background: transparent;
  box-shadow: none;
  border: none;
}

.modal.modal-paiement .modal-header {
  display: none;
}

.modal.modal-paiement+.modal-backdrop {
  opacity: 0.9;
  z-index: 999;
}

body.dashboard.style1 {
  background-color: #276375;
}

body.admin .modal-backdrop {
  z-index: 1998;
}

section.cagnotte_menu {
  padding: 25px 35px;
  background: #FFF;
}

.valignbottom {
  display: flex;
  align-items: flex-end;
}

.aligncenter {
  display: flex;
  align-items: center;
  justify-content: center;
}

body.modal-open .modal-backdrop {
  bottom: 0;
  position: fixed;
  z-index: 998;
}

body.modal-open .modal-content {
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5)
}

body.modal-open .modal {
  bottom: 0;
  position: fixed;
  z-index: 1040;
  background: rgba(61, 86, 109, 0.5)
}

body.modal-open .modal#waiting {
  bottom: 0;
  position: fixed;
  z-index: 10400000;
  background: rgba(61, 86, 109, 0.5)
}

body.modal-open .modal#erreur {
  z-index: 10400;
}

.opacity-overlay {
  outline: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.75);
  z-index: 3000;
  display: none;
  -webkit-backface-visibility: hidden;
}

.opacity-overlay .container {
  height: 100%;
  position: relative;
  z-index: 10001;
}

.opacity-overlay .spinner {
  color: #fff;
  font-size: 32px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -16px;
  margin-top: -16px;
}

.modal.popupresize {
  z-index: 10003;
}

.popup-wrapper {
  text-align: center;
  position: fixed;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  padding: 0 5px;
  z-index: 10003;
  overflow: auto;
}

.popup-wrapper:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

.popup-wrapper .popup-content {
  float: none;
  padding: 0;
  margin: 0 auto;
  text-align: left;
  z-index: 10003;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 100%;
}

.bloc_explicatif {
  padding: 0.8vw;
  margin: 0.5vw 0.05vw;
  border: 1px solid rgba(55, 55, 55, 0.5);
  height: 150px;
}

.bloc_explicatif h2 {
  font-size: 1.5em;
}

.bloc_explicatif a {
  display: block;
  width: 100%;
  height: 100%;
}

section.liste_cagnottes div.section_cagnotte,
section.cagnotte div.section_cagnotte {
  display: block;
  border: 1px solid rgba(0, 0, 0, 0.5);
  background: rgba(0, 0, 0, 0.1);
  height: 21px;
  border-radius: 2px;
  text-align: center;
  margin-bottom: 5px;
}

section.liste_cagnottes div.section_cagnotte.termine,
section.cagnotte div.section_cagnotte.termine {
  background: #5BC0DE;
  color: #000;
}

section.liste_cagnottes div.section_cagnotte.encours,
section.cagnotte div.section_cagnotte.encours {
  background: tomato;
  color: white;
}

table>tbody>tr>td.hover.active {
  background: rgba(200, 50, 50, 0.8);
  color: rgba(255, 255, 255, 1);
}

table>tbody>tr>td.hover:hover {
  cursor: pointer;
  background: rgba(50, 175, 205, 0.8);
  color: rgba(255, 255, 255, 1);
}

.table_annonces .dataTables_info {
  display: none;
}

.table_annonces .dataTables_filter {
  text-align: right;
}

.table_annonces .dataTables_filter label input:before {
  content: "une annonce";
}

table.table.annonces {
  border-collapse: separate;
  border-spacing: 0 20px;
}

.tab-container .tab-content .tab-pane table.table.annonces div.row,
.tab-container .tab-content .tab-pane table.table.annonces p {
  margin-bottom: 0;
}

.tab-container .tab-content .tab-pane table.table.annonces div.row:before,
.tab-container .tab-content .tab-pane table.table.annonces div.row:after {
  content: "";
  display: none;
}

table.table.annonces tr td {
  border-bottom: 1px solid rgba(0, 0, 0, 0.6);
  border-top: 1px solid rgba(0, 0, 0, 0.6);
}

table.table.annonces tr td:first-child {
  border-left: 1px solid rgba(0, 0, 0, 0.6);
}

table.table.annonces tr td:last-child,
table.table.annonces tr td[colspan="2"] {
  border-right: 1px solid rgba(0, 0, 0, 0.6);
}

table.table.annonces tr td figure {
  height: 96px;
  width: 200px;
}

table.table.annonces tr td figure img {
  max-height: 100%;
  max-height: 100%;
  margin: auto;
}

div.legend {
  line-height: 34px;
  font-size: 18px;
}

div.legend div:before {
  content: '';
  display: inline-block;
  width: 64px;
  height: 24px;
  border: 1px solid #666;
  vertical-align: middle;
}

div.legend div.danger:before {
  background: #f2dede;
}

div.legend div.warning:before {
  background: #fcf8e3;
}

.bulle {
  display: inline-block;
  background: rgba(255, 90, 90, 0.6);
  border: 1px solid #d64f4f;
  border-radius: 50px;
  padding: 3px 10px;
  text-align: center;
  margin: auto;
  color: #d64f4f;
}

.marginauto {
  margin: auto !important;
}

.bac {
  position: absolute;
  font-size: 40px;
  right: 100px;
  bottom: 0;
}

#spp_compteur {
  position: fixed;
  font-size: 100px;
  margin: 20vh auto auto auto;
  text-align: center;
  z-index: 1000;
  color: white;
  top: 0;
  line-height: 100px;
  background: rgba(0, 0, 0, 0.8);
  display: inline-block;
  width: 45%;
  left: 27%;
}

div.favoris_bouton a img {
  height: 96px;
}

div.favoris_bouton a {
  display: inline-block;
  opacity: 0.4;
  cursor: pointer;
}

div.favoris_bouton a.active {
  opacity: 0.9;
}

div.favoris_bouton a:hover {
  opacity: 1;
}

.fact.accueil .numbers dl {
  float: none;
  text-align: center;
  margin: 0;
  font-size: 26px;
  line-height: 36px;
}

.fact.accueil .numbers dt {
  color: #01b7f2;
}

.fact.accueil .numbers dd {
  color: #1e6f8a;
}

.destinations .listing-style1.flight .box a.box_link {
  padding: 0px;
}

.destinations .listing-style1.flight .box {
  padding: 0px;
  border: 2px solid rgb(23 103 115);
  background: #31aace;
  color: white;
}

.destinations .listing-style1.flight .box h4.box-title {
  background: rgb(16 86 93 / 80%);
  padding: 4px 20px;
  text-align: center;
  font-size: 26px;
}

.destinations .listing-style1.flight .box p.duration {
  height: auto;
}

.destinations .listing-style1.flight .box a.box_link:hover {
  background: #5ed2f5;
  box-shadow: none;
  color: white;
  border: none;
}

.destinations .listing-style1.flight .box div.details {
  padding: 0 !important;
}

.fact.accueil .numbers .icon {
  font-size: 6em;
}

.dropdown-menu.show li a.button.full-width {
  padding: 0 30px;
}

/**
PAIEMENT STRIPE*/
.paiement_stripe .error svg {
  margin-top: 0 !important;
}

.paiement_stripe .error svg .base {
  fill: #e25950;
}

.paiement_stripe .error svg .glyph {
  fill: #fff;
}

.paiement_stripe .error .message {
  color: #e25950;
}

.paiement_stripe .success .icon .border {
  stroke: #abe9d2;
}

.paiement_stripe .success .icon .checkmark {
  stroke: #24b47e;
}

.paiement_stripe .success .title {
  color: #32325d;
  font-size: 16px !important;
}

.paiement_stripe .success .message {
  color: #8898aa;
  font-size: 20px !important;
}

.paiement_stripe .success .reset path {
  fill: #24b47e;
}

.paiement_stripe.submitted form,
.paiement_stripe.submitting form {
  opacity: 0;
  transform: scale(0.9);
  pointer-events: none;
}

.paiement_stripe.submitted .success,
.paiement_stripe.submitting .success {
  pointer-events: all;
}

.paiement_stripe.submitting .success .icon {
  opacity: 1;
}

.paiement_stripe.submitted .success>* {
  opacity: 1;
  transform: none !important;
}

.paiement_stripe.submitted .success> :nth-child(2) {
  transition-delay: 0.1s;
}

.paiement_stripe.submitted .success> :nth-child(3) {
  transition-delay: 0.2s;
}

.paiement_stripe.submitted .success> :nth-child(4) {
  transition-delay: 0.3s;
}

.paiement_stripe.submitted .success .icon .border,
.paiement_stripe.submitted .success .icon .checkmark {
  opacity: 1;
  stroke-dashoffset: 0 !important;
}


.paiement_stripe .caption {
  display: flex;
  justify-content: space-between;
  position: absolute;
  width: 100%;
  top: 100%;
  left: 0;
  padding: 15px 10px 0;
  color: #aab7c4;
  font-family: Roboto, "Open Sans", "Segoe UI", sans-serif;
  font-size: 15px;
  font-weight: 500;
}

.paiement_stripe .caption * {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
}

.paiement_stripe .caption .no-charge {
  color: #cfd7df;
  margin-right: 10px;
}

.paiement_stripe .caption a.source {
  text-align: right;
  color: inherit;
  transition: color 0.1s ease-in-out;
  margin-left: 10px;
}

.paiement_stripe .caption a.source:hover {
  color: #6772e5;
}

.paiement_stripe .caption a.source:active {
  color: #43458b;
}

.paiement_stripe .caption a.source svg {
  margin-right: 10px;
}

.paiement_stripe .caption a.source svg path {
  fill: currentColor;
}

.paiement_stripe form {
  transition-property: opacity, transform;
  transition-duration: 0.35s;
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
}

.paiement_stripe form input::-webkit-input-placeholder {
  opacity: 1;
}

.paiement_stripe form input::-moz-placeholder {
  opacity: 1;
}

.paiement_stripe form input:-ms-input-placeholder {
  opacity: 1;
}

.paiement_stripe .error {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  width: 100%;
  top: 100%;
  margin-top: 20px;
  left: 0;
  padding: 0 15px;
  font-size: 13px !important;
  opacity: 0;
  transform: translateY(10px);
  transition-property: opacity, transform;
  transition-duration: 0.35s;
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
}

.paiement_stripe .error.visible {
  opacity: 1;
  transform: none;
}

.paiement_stripe .error .message {
  font-size: inherit;
}

.paiement_stripe .error svg {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-top: -1px;
  margin-right: 10px;
}

.paiement_stripe .success {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  padding: 10px;
  text-align: center;
  pointer-events: none;
  overflow: hidden;
}

@media (min-width: 670px) {
  .paiement_stripe .success {
    padding: 40px;
  }
}

.paiement_stripe .success>* {
  transition-property: opacity, transform;
  transition-duration: 0.35s;
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0;
  transform: translateY(50px);
}

.paiement_stripe .success .icon {
  margin: 15px 0 30px;
  transform: translateY(70px) scale(0.75);
}

.paiement_stripe .success .icon.animation_rotation {
  animation: 1s infinite rotation;
}

.paiement_stripe .success .icon svg {
  will-change: transform;
}

.paiement_stripe .success .icon .border {
  stroke-dasharray: 251;
  stroke-dashoffset: 62.75;
  transform-origin: 50% 50%;
  transition: stroke-dashoffset 0.35s cubic-bezier(0.165, 0.84, 0.44, 1);
  animation: spin 1s linear infinite;
}

.paiement_stripe .success .icon .checkmark {
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  transition: stroke-dashoffset 0.35s cubic-bezier(0.165, 0.84, 0.44, 1) 0.35s;
}

.paiement_stripe .success .title {
  font-size: 17px;
  font-weight: 500;
  margin-bottom: 8px;
}

.paiement_stripe .success .message {
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 25px;
  line-height: 1.6em;
}

.paiement_stripe .success .message span {
  font-size: inherit;
}

.paiement_stripe .success .reset:active {
  transition-duration: 0.15s;
  transition-delay: 0s;
  opacity: 0.65;
}

.paiement_stripe .success .reset svg {
  will-change: transform;
}

@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.progressbar_cagnotte.little {
  width: 100%;
  height: 18px;
  line-height: 18px;
}

.progressbar_cagnotte.little .percentage {
  height: 18px;
}

.progressbar_cagnotte.little span {
  font-size: 16px;
  line-height: 16px;
  top: -2px;
  color: black;
}

.progressbar_cagnotte {
  width: 100%;
  height: 36px;
  border-radius: 0.5em;
  position: relative;
  background: #004f74;
  box-shadow: inset 0 0 0 1px rgb(0 0 0 / 10%);
  margin-top: 0px;
  text-align: center;
  line-height: 21px;
  border: 1px solid #0089ef;
}

.progressbar_cagnotte span {
  font-size: 21px;
  line-height: 21px;
  vertical-align: middle;
  position: relative;
  top: 4px;
  color: white;
}

.progressbar_cagnotte .percentage {
  position: absolute;
  font-size: 1em;
  background: tomato;
  height: 34px;
  border-radius: 0.5em;
  top: 0;
  left: 0;
  z-index: 0;
}

.listing-style1.flight figure img,
.listing-style1.car figure img,
.listing-style2.flight figure img,
.listing-style2.car figure img {
  width: auto;
  margin: auto;
}

.style1.image-box .box img,
.style1.image-box.box img {
  max-width: 100%;
  height: auto;
  max-height: 184px;
}

.image-box .box img,
.image-box.box img {
  max-width: 100%;
  height: auto;
  max-height: 100%;
}

.bloc_animal {
  background: rgb(255 219 119);
  display: block;
  height: auto;
  position: relative;
  padding: 10px;
  margin: 5px 5px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  transition: 0.5s ease all;
}

.bloc_animal:hover {
  background: rgb(102 208 228 / 80%);
  color: #FFF;
}

.bloc_animal:hover img {
  opacity: 1;
}

.bloc_animal span {
  display: block;
  text-align: center;
}

.bloc_animal img {
  max-width: 100%;
  max-height: calc(100% - 20px);
  margin: auto;
  opacity: 0.5;
}

.sprite {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 100%;
}

div#remplissage_bac_container ul.reponse div.jauge {
  text-align: left;
  color: #000;
  width: calc(100% - 50px);
  position: relative;
  height: auto;
}

div#remplissage_bac_container ul.reponse div.jauge span {
  min-width: 20px;
  display: inline-block;
  height: 5px;
  background-color: #4ae7b8;
  vertical-align: top;
  margin-top: 5px;
}

div#remplissage_bac_container ul.reponse div.jauge div {
  position: absolute;
  right: -50px;
  line-height: 16px;
}

div.boite_friandise {
  width: 124px;
  margin: auto;
}

div.boite_friandise div.jauge {
  background: #525252;
  margin-top: 4px;
  border-radius: 3px;
  position: relative;
}

div.boite_friandise div.jauge div {
  background: #c96a19;
  position: absolute;
  left: 0;
  top: 0;
}

div.boite_friandise div.jauge span {
  position: relative;
  color: #ebb02c;
}

div.modal-loader div.travelo-box {
  background: transparent;
  border: none;
  box-shadow: none;
}

div.modal-loader div.travelo-box div.modal-header {
  display: none;
}

div.modal-loader~div.modal-backdrop {
  z-index: 2999;
}

.filters-container ul.filters-option {
  margin-bottom: 10px;
}

.filters-container ul.filters-option li {
  margin-bottom: 1px;
  background: #f5f5f5;
  padding: 0 15px;
}

.filters-container ul.filters-option li a {
  color: inherit;
  display: block;
  padding: 8px 0;
  text-transform: uppercase;
  font-size: 11px;
}

.filters-container ul.filters-option li small {
  float: right;
}

.filters-container ul.filters-option li.active:before {
  float: left;
  width: 18px;
  height: 18px;
  display: block;
  line-height: 14px;
  text-align: center;
  margin-top: 10px;
}

.toggle-container .panel .panel-title>a.collapsed:before {
  content: "\f067";
  color: #fff;
  background: #01b7f2;
}

.filters-container ul.filters-option li:after {
  display: table;
  clear: both;
  content: "";
}

.filters-container ul.filters-option li.active {
  background: #01b7f2;
}

.filters-container ul.filters-option li a.active {
  color: #fff;
}

ul.check-square li.active:before {
  font-family: 'FontAwesome';
  content: "\f00c";
  background: #d9d9d9;
  color: #fff;
  padding: 1px 4px 0;
  margin-right: 10px;
  font-size: 12px;
}

ul.check-square li.active {
  background: #01b7f2;
  color: #fff;
}

ul.check-square li.active>a {
  color: #fff;
}

ul.check-square li.active:before {
  background: #fff;
  color: #5BC0DE;
}

.toggle-container .panel .panel-title>a {
  line-height: 24px;
}

.toggle-container .panel .panel-title>a:before {
  display: block;
  content: "\f068";
  font-family: FontAwesome;
  margin-right: 16px;
  line-height: 24px;
  font-size: 10px;
  float: left;
  width: 24px;
  height: 24px;
  text-align: center;
  color: #9e9e9e;
  background: #f5f5f5;
  border-radius: 50%;
}

.toggle-container .panel.arrow-right .panel-title>a:before {
  float: none;
  position: absolute;
  right: 0;
  height: 16px;
  line-height: 17px;
  width: 16px;
  font-size: 9px;
  border: none;
  margin-top: -8px;
  top: 50%;
}

.card.card-price1 {
  border-color: #a9e3ff;
}

.card.card-price1 .card-header {
  background-color: #a9e3ff;
}

.card.card-price1 .card-header span {
  line-height: 40px;
  color: #207eaf;
}

.card.card-price1 .card-footer {
  background-color: #a9e3ff;
}

.card.card-price2 {
  border-color: #70cefb;
}

.card.card-price2 .card-header {
  background-color: #70cefb;
}

.card.card-price2 .card-header span {
  line-height: 40px;
  color: #207eaf;
}

.card.card-price2 .card-footer {
  background-color: #70cefb;
}


.card.card-price3 {
  border-color: #32b1ef;
}

.card.card-price3 .card-header {
  background-color: #32b1ef;
  padding: 0.5rem 1.25rem 1rem;
}

.card.card-price3 .card-header span {
  line-height: 40px;
  color: #ffffff;
}

.card.card-price3 .card-header span.bonus {
  position: absolute;
  right: 0px;
  top: 38px;
  font-size: 15px;
  color: #fff252;
  text-shadow: 1px 1px 15px rgba(0, 0, 0, 01);
}

.card.card-price3 .card-header span.bonus:before,
.card.card-price3 .card-header span.bonus:after {
  content: "\f005";
  font-family: "FontAwesome";
  color: #FF0;
  padding-right: 2px;
  padding-left: 2px;
  text-shadow: 1px 1px 12px rgba(0, 0, 0, 1);
}

.card.card-price3 .card-footer {
  background-color: #32b1ef;
}

.card.card-price4 {
  border-color: #e7d12f;
}

.card.card-price4 .card-header {
  background-color: #fbdd70;
}

.card.card-price4 .card-header span {
  line-height: 40px;
  color: #af4f20;
}

.card.card-price4 .card-footer {
  background-color: #fbdd70;
}

.clignote {
  animation: infinite ease bgcolorchange 1s;
  color: #FFF;
}

.annonce_ok {
  opacity: 0.3;
  position: relative;
}

.annonce_ok img {
  padding: 20%;
}

.annonce_ok.inactif:before {
  content: "\f00d";
  font-family: "FontAwesome";
  font-size: 36px;
  position: absolute;
  left: calc(50% - 18px);
  top: 50px;
  color: #F55;
}

.annonce_ok.actif {
  opacity: 0.9;
}

.annonce_ok.actif:before {
  content: "\f00c";
  font-family: "FontAwesome";
  font-size: 36px;
  position: absolute;
  left: calc(50% - 18px);
  top: 50px;
  color: #12c32f;
}

div[data-toggle="pub-300x600"] {
  max-height: 600px;
  overflow: hidden;
  min-height: 600px;
  width: 300px;
  margin: auto;
  z-index: 100000;
}

.fact.blue {
  background: #01b7f2;
}

.fact.blue .description {
  background: #04afe7;
}

.fact.yellow {
  background: #5BC0DE;
}

.fact.yellow .description {
  background: #f5b010;
}

.fact.red {
  background: #e01a33;
}

.fact.gold {
  background: #fcaa32;
}

.fact.red .description {
  background: #d51a32;
}

.fact.green {
  background: #98ce44;
}

.fact.pink {
  background: #c85eb4;
}

.fact.green .description {
  background: #91c63d;
}

.titremsvsign {
  font-size: 20px;
  color: #ffd600;
  font-weight: 700;
}

.titremsvdate {
  font-size: 20px;
  color: #cc99cc;
  font-weight: 400;
  line-height: 26px;
}

.titremsvcate {
  font-weight: 700;
  color: #cc99cc;
}

.textemsvcate {
  font-style: italic;
}

div.boite div div:last-child {
  display: none;
}

div.horoscope {
  margin-top: 0px;
}

div.horoscope div.boite {
  padding: 15px;
  position: relative;
  z-index: 1;
}

div.horoscope div.boite:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 46px;
  right: 0;
  background: #7d0052;
  z-index: -1;
}

div.horoscope div.boite+div.bouton_plus {
  position: absolute;
  top: 0;
  right: 0;
  width: 161px;
  z-index: 1;
  height: 47px;
}

div.horoscope div.boite+div.bouton_plus a.button.btn-large {
  line-height: 46px;
  height: 46px;
}

.modal-success .travelo-box .modal-header {
  background: rgb(222, 255, 233);
}

.modal-success .travelo-box .modal-header h2 {
  color: rgb(47, 169, 87);
}

.modal-success .travelo-box .modal-body {
  background: rgb(244, 253, 247);
}

.modal-danger .travelo-box .modal-header {
  background: rgb(255, 229, 224);
}

.modal-danger .travelo-box .modal-header h2 {
  color: rgb(173, 103, 103);
}

.modal-danger .travelo-box .modal-body {
  background: #fff9f9;
}

.modal .modal-content.travelo-box .modal-header {
  padding: 10px 10px 20px 20px;
}

.list-row .list-item {
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-align: center;
  align-items: center;
  padding: .75rem .625rem
}

.list-item {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word
}

.list-row .list-item>* {
  padding-left: .625rem;
  padding-right: .625rem
}

.w-40 {
  width: 40px !important;
  height: 40px !important
}

.hoverglass {
  position: relative;
}

.hoverglass:hover:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.1);
}

.avatar {
  position: relative;
  line-height: 1;
  white-space: nowrap;
  font-weight: 700;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  border-radius: 0px;
  min-height: 92px;
  box-shadow: 0 5px 10px 0 rgba(50, 50, 50, .15)
}

.ratio1p1 {
  position: relative;
  width: 100%;
  padding-top: 100%;
}

.ratio1p1>div {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: auto;
  height: auto;
}

.avatar img {
  border-radius: inherit;
  width: 100%
}

.gd-primary {
  color: #fff;
  border: none;
  background: #000;
}

.list-group-item {
  user-select: none;
}

.list-group input[type="checkbox"] {
  display: none;
}

.list-group input[type="checkbox"]+.list-group-item {
  cursor: pointer;
}

.list-group input[type="checkbox"]+.list-group-item:before {
  content: "\2713";
  color: transparent;
  font-weight: bold;
  margin-right: 1em;
}

button.close:hover {
  background: initial;
}

button.close span:hover {
  background: #A56;
}

button.close span {
  padding: 0 3px;
}

.list-group input[type="checkbox"]:checked+.list-group-item {
  background-color: #01b7f2;
  color: #FFF;
}

.list-group input[type="checkbox"]:disabled+.list-group-item {
  cursor: not-allowed;
}

.list-group input[type="checkbox"]:checked+.list-group-item:before {
  color: inherit;
}

.icon-box {
  text-transform: uppercase;
}

.icon-box>i {
  text-align: center;
}

.icon-box.style1 {
  height: 42px;
  background: #fff;
  line-height: 42px;
  font-size: 0.9167em;
}

.icon-box.style1>i {
  display: block;
  width: 64px;
  float: left;
  background: #5BC0DE;
  line-height: 71px;
  color: #fff;
  font-size: 3em;
  margin-right: 15px;
}

.icon-box.style1>i.bg-default {
  background: #DDD;
}

.bubble.you {
  max-width: 70%;
  -ms-flex-item-align: start;
  align-self: flex-start;
  -webkit-animation-name: slideFromLeft;
  animation-name: slideFromLeft;
  display: block;
}

.bubble.you div {
  color: #fff;
  background-color: #00b0ff;
}

.bubble div {
  font-size: 16px;
  position: relative;
  display: inline-block;
  clear: both;
  margin-bottom: 8px;
  padding: 13px 14px;
  vertical-align: top;
  border-radius: 5px;
}

.bubble.me {
  text-align: right;
  max-width: 100%;
  -ms-flex-item-align: end;
  align-self: flex-end;
  animation-name: slideFromRight;
}

.bubble.me div {
  color: #1a1a1a;
  background-color: #eceff1;
  max-width: 70%;
  text-align: left;
}

.bubble img {
  max-width: 30%;
  min-width: 32px;
}

.bubble .date {
  display: block;
  color: black;
  font-size: 14px;
  line-height: 17px;
  margin-bottom: 4px;
  margin-top: 6px;
}

.bubble div:before {
  position: absolute;
  top: 19px;
  display: block;
  width: 8px;
  height: 6px;
  content: '\00a0';
  transform: rotate(29deg) skew(-35deg);
}

.bubble.you div:before {
  left: -3px;
  background-color: #00b0ff;
}

.bubble.me div:before {
  right: -3px;
  background-color: #eceff1;
}

@keyframes slideFromLeft {
  0% {
    margin-left: -200px;
    opacity: 0;
  }

  100% {
    margin-left: 0;
    opacity: 1;
  }
}

@keyframes slideFromRight {
  0% {
    margin-right: -200px;
    opacity: 0;
  }

  100% {
    margin-right: 0;
    opacity: 1;
  }
}

/*********************************
**
**      AUTOCOMPLETE
**
**********************************/
div.autocomplete div.conteneur_input {
  font-size: 14px;
  line-height: 1.42857143;
  color: #555;
  background-color: #fff;
  background-image: none;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}

div.autocomplete div.conteneur_input div.affichage {
  display: inline-block;
  cursor: pointer;
  background: rgba(255, 255, 220, 0.8);
  padding: 3px 20px 3px 10px;
  margin: 0 4px;
}

div.autocomplete div.conteneur_input div.affichage:hover {
  padding-right: 7px;
}

div.autocomplete div.conteneur_input div.affichage span {
  display: none;
}

div.autocomplete div.conteneur_input div.affichage span:hover {
  color: rgba(155, 50, 0, 0.8);
}

div.autocomplete div.conteneur_input div.affichage:hover span {
  display: inline-block;
}

div.autocomplete div.conteneur_input input {
  width: 120px;
  float: initial;
  background: transparent;
  border: none;
  outline: none;
}

div.autocomplete div.result {
  position: absolute;
  background: rgba(255, 255, 255, 0.95);
  margin-top: 0px;
  border: 1px solid rgba(5, 5, 5, 0.3);
  color: rgba(0, 0, 0, 0.8);
  z-index: 10;
  max-height: initial;
  overflow: auto;
  border-radius: 0px 0px 10px 10px;
  width: 100%;
}

div.autocomplete div.result div {
  padding: 3px 10px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  box-sizing: initial;
}

div.autocomplete div.result>div:last-child {
  position: relative;
  right: 0px;
  padding: 0;
  left: 0;
}

div.autocomplete div.result>div:last-child a:hover {
  background: #b93a27;
  color: #AAA;
}

div.autocomplete div.result div div {
  box-sizing: initial;
  display: inline-block;
  border-top: 0;
  user-select: none;
}

div.autocomplete div.result>div:hover {
  background: rgb(200 50 50 / 10%);
  color: rgba(205, 0, 0, 0.8);
  cursor: pointer;
}

div.autocomplete div.result div:first-child {
  border-top: 0px solid rgba(0, 0, 0, 0.8);
}

div.autocomplete div.result span.nom div:first-child {
  border-top: 0px solid rgba(0, 0, 0, 0.8);
}

div.autocomplete div.result div:last-child a img {
  width: 18px;
}

div.autocomplete div.result div span.civ {
  margin-right: 5px;
  font-variant: small-caps;
  font-style: italic;
  font-size: 20px;
  box-sizing: initial;
  display: inline-block;
}

div.autocomplete div.result div span.nom {

  box-sizing: initial;

  display: block;
}

div.autocomplete div.result div span.mail {
  display: block;
  font-size: 11px;
}

/*************************************
**
**      RIBBON
**
***************************************/
.ribbon {
  position: absolute;
  left: -5px;
  top: -5px;
  z-index: 1;
  overflow: hidden;
  width: 75px;
  height: 75px;
  text-align: right;
}

.ribbon span {
  font-size: 10px;
  font-weight: bold;
  color: #FFF;
  text-transform: uppercase;
  text-align: center;
  line-height: 20px;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  width: 100px;
  display: block;
  background: #79A70A;
  background: linear-gradient(#F70505 0%, #8F0808 100%);
  box-shadow: 0 3px 10px -5px rgba(0, 0, 0, 1);
  position: absolute;
  top: 19px;
  left: -21px;
}

.ribbon span::before {
  content: "";
  position: absolute;
  left: 0px;
  top: 100%;
  z-index: -1;
  border-left: 3px solid #8F0808;
  border-right: 3px solid transparent;
  border-bottom: 3px solid transparent;
  border-top: 3px solid #8F0808;
}

.ribbon span::after {
  content: "";
  position: absolute;
  right: 0px;
  top: 100%;
  z-index: -1;
  border-left: 3px solid transparent;
  border-right: 3px solid #8F0808;
  border-bottom: 3px solid transparent;
  border-top: 3px solid #8F0808;
}

.floatingLabel+label {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 8px;
  color: #cfd7df;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transform-origin: 0 50%;
  cursor: text;
  pointer-events: none;
  transition-property: color, transform;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  font-size: 20px;
}

.floatingLabel {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
  padding-bottom: 7px;
  color: #fff3b5;
  background-color: transparent !important;
  border: 0;
  outline: none;
  font-size: 20px;
  height: 40px;
  padding-top: 20px;
}

.paiement_stripe input:-webkit-autofill,
.paiement_stripe input:-webkit-autofill:focus {
  -webkit-text-fill-color: #e39f48;
  transition: background-color 5000s ease-in-out 0s;
  -webkit-animation: 1ms void-animation-out;
  -webkit-box-shadow: 0 0 0px 1000px transparent inset;
}

.paiement_stripe .StripeElement--webkit-autofill {
  background: transparent !important;
}

.floatingLabel::-webkit-input-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.floatingLabel::-moz-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.floatingLabel:-ms-input-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.floatingLabel.StripeElement {
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  will-change: opacity;
}

.floatingLabel.focused,
.floatingLabel:not(.empty) {
  opacity: 1;
}

.floatingLabel.focused::-webkit-input-placeholder,
.floatingLabel:not(.empty)::-webkit-input-placeholder {
  color: #cfd7df;
}

.floatingLabel.focused::-moz-placeholder,
.floatingLabel:not(.empty)::-moz-placeholder {
  color: #cfd7df;
}

.floatingLabel.focused:-ms-input-placeholder,
.floatingLabel:not(.empty):-ms-input-placeholder {
  color: #cfd7df;
}

.floatingLabel.focused+label,
.floatingLabel:not(.empty)+label {
  color: #aab7c4;
  transform: scale(0.85) translateY(-25px);
  cursor: default;
}

.floatingLabel.focused+label {
  color: #24b47e;
}

.floatingLabel.invalid+label {
  color: #ffa27b;
}

.floatingLabel.focused+label+.baseline {
  background-color: #24b47e;
}

.floatingLabel.focused.invalid+label+.baseline {
  background-color: #e25950;
}

.paiement_stripe .field {
  position: relative;
  height: 50px;
}

.paiement_stripe .baseline {
  position: absolute;
  width: 100%;
  height: 1px;
  left: 0;
  bottom: 0;
  background-color: #cfd7df;
  transition: background-color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

#card-error {
  color: rgb(255, 115, 134);
  text-align: left;
  font-size: 13px;
  line-height: 17px;
  margin-top: 12px;
}

.help-bg {
  background: linear-gradient(135deg, #3b63a7 0%, #3f84d9 100%);
  position: relative;
  overflow: hidden;
}

.help-bg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
}

.section-content {
  position: relative;
  z-index: 2;
}

.grey-color {
  color: #ffffff !important;
}

.step-card {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 20px;
  padding: 1rem 0.5rem;
  margin: 1rem 0.5rem;
  backdrop-filter: blur(15px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

.step-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(45deg, rgba(255, 255, 255, 0.1), transparent);
  transition: opacity 0.3s ease;
  opacity: 0;
  z-index: -1;
}

.step-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
}

.step-card:hover::before {
  opacity: 1;
}

.step-icon {
  font-size: 2.5rem;
  margin-bottom: 1.0rem;
  background: linear-gradient(45deg, #fff, #f8f9fa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
}

.step-text {
  font-size: 0.9rem;
  line-height: 1.3;
  font-weight: 500;
}

.step-link {
  color: #e4d838;
  text-decoration: none;
  transition: all 0.3s ease;
}

.step-link:hover {
  color: #f8f9fa;
  text-decoration: none;
}

.arrow-container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: relative;
  z-index: 3;
}

.arrow {
  font-size: 2.5rem;
  color: rgba(255, 255, 255, 0.8);
  animation: pulsePerso 2s infinite;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

@keyframes pulsePerso {

  0%,
  100% {
    transform: scale(1);
    opacity: 0.8;
  }

  50% {
    transform: scale(1.1);
    opacity: 1;
  }
}

.main-title {
  font-size: 1.5rem;
  font-weight: 700;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  margin-bottom: 0.5rem;
}

.step-number {
  position: absolute;
  top: -10px;
  right: -10px;
  background: linear-gradient(45deg, #ff6b6b, #ee5a24);
  color: white;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 1.2rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  padding-right: 5px;
  padding-top: 5px;
}

@media (max-width: 768px) {
  .arrow-container {
    display: none;
  }

  .step-card {
    margin: 1rem 0;
  }

  .main-title {
    font-size: 2rem;
  }

  .step-icon {
    font-size: 2.5rem;
  }
}

.transparent {
  border: none;
  height: 2rem;
}

/* Animation d'apparition */
.step-card {
  animation: fadeInUpPerso 0.6s ease forwards;
  opacity: 0;
  transform: translateY(30px);
}

.step-card:nth-child(1) {
  animation-delay: 0.1s;
}

.step-card:nth-child(2) {
  animation-delay: 0.2s;
}

.step-card:nth-child(3) {
  animation-delay: 0.3s;
}

.step-card:nth-child(4) {
  animation-delay: 0.4s;
}

.step-card:nth-child(5) {
  animation-delay: 0.5s;
}

@keyframes fadeInUpPerso {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}