/*
 * This file is part of theme "CESL2019"
 * 
 * */




/****
 *  FORMS
 ****/

/* error msg */
.has-error {
   position: relative
}

.form-error {
   display: none
}

.has-error:hover .form-error {
   display: block;
}


/* cus-form */
.cus-form .ui-selectmenu-button.ui-button {
   width: 100%;
   border: 0;
   border-bottom: 2px solid #9a9a9a
}

.cus-form .ui-selectmenu-button.ui-button:hover {
   border-color: #F8B133;
   background-color: #fff
}

.cus-form .ui-selectmenu-button.ui-button:focus {
   border-color: #ffc107 !important;
   outline-style: none
}

.cus-form .ui-selectmenu-button.ui-button.ui-selectmenu-button-open {
   background-color: #fff;
}

.cus-form input[type=text].w3-input,
.cus-form input[type=tel].w3-input,
.cus-form input[type=email].w3-input,
.cus-form input[type=password].w3-input,
/*.cus-form input[type=date].w3-input
{background-color:#deeffc; border-color:#9a9a9a; color:#074b83; border-radius:3px; border-bottom-width:2px; outline-style:none; padding:4px;}*/
.cus-form input.w3-input:focus {
   background-color: #ffffff;
   border-color: #ffc107 !important;
}

.cus-form input.w3-input:hover {
   background-color: #ffffff;
   border-color: #F8B133;
}

.cus-form .w3-bar-item label {
   display: inline-block;
   font-size: .99rem
}

input.valid {
   background-image: url(/themes/chicplanet2021/img/iconmonstr-check-mark-1.svg) !important;
}


/* cus-checkboxradiobar BASIC SCHEM */
.cus-checkboxradiobar {
   display: flex;
   font-size: 0;
   border: 0 !important;
   padding: 0 !important;
   background-color: transparent !important;
   position: relative
}

.cus-checkboxradiobar label {
   border: 0;
   border-bottom: 2px solid;
   border-radius: 0;
   margin: 0;
   padding: 4px 24px 4px 24px;
   line-height: inherit;
   font-family: inherit;
   opacity: .75;
   filter: Alpha(Opacity=75);
   font-size: 1rem !important;
   display: inline-block !important;
}

/*.cus-checkboxradiobar label:hover {border:0; border-bottom:2px solid; opacity:.85; filter:Alpha(Opacity=85); display:inherit;}*/
.cus-checkboxradiobar label.ui-state-active {
   border: 0;
   border-bottom: 2px solid
}

.cus-checkboxradiobar label.ui-state-active:hover {
   border: 0;
   border-bottom: 2px solid
}

.cus-checkboxradiobar label:not(.ui-state-active):hover {
   border: 0;
   border-bottom: 2px solid
}

.cus-checkboxradiobar label.ui-state-focus {
   outline-style: none;
   box-shadow: unset !important
}

.cus-checkboxradiobar label:not(:last-of-type),
.cus-checkboxradiobar label.ui-state-focus:not(:last-of-type),
.cus-checkboxradiobar label:not(:last-of-type):hover {
   border-right: 1px solid
}

.cus-checkboxradiobar label.ui-checkboxradio-checked {
   background-repeat: no-repeat !important;
   background-position: 10px 50% !important;
   opacity: 1;
   filter: Alpha(Opacity=100);
   background: no-repeat url(/themes/chicplanet2021/img/iconmonstr-check-mark-1.svg);
}

.cus-checkboxradiobar label:first-of-type {
   border-top-left-radius: 3px;
   border-bottom-left-radius: 3px
}

.cus-checkboxradiobar label:last-of-type {
   border-top-right-radius: 3px;
   border-bottom-right-radius: 3px
}

.cus-checkboxradiobar input {
   left: 0
}


/* cus-checkboxradiobar ERROR */
.cus-checkboxradiobar.has-error .form-error {
   bottom: calc(100% + 4px)
}

.cus-checkboxradiobar.has-error label:last-of-type

/*,
.cus-checkboxradiobar.has-error.controlgroup-vertical label:first-of-type*/
   {
   background-position: right 2px center;
   background-repeat: no-repeat;
   background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjIwIiBoZWlnaHQ9IjIwIiB2aWV3Qm94PSIwIDAgMjAgMjAiPiAgPHRpdGxlPiAgICBhbGVydCAgPC90aXRsZT4gIDxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+KiB7IGZpbGw6ICNmZjVkMDAgfTwvc3R5bGU+ICA8cGF0aCBkPSJNMTkuNjQgMTYuMzZMMTEuNTMgMi4zQTEuODUgMS44NSAwIDAgMCAxMCAxLjIxIDEuODUgMS44NSAwIDAgMCA4LjQ4IDIuM0wuMzYgMTYuMzZDLS40OCAxNy44MS4yMSAxOSAxLjg4IDE5aDE2LjI0YzEuNjcgMCAyLjM2LTEuMTkgMS41Mi0yLjY0ek0xMSAxNkg5di0yaDJ6bTAtNEg5VjZoMnoiLz48L3N2Zz4=);
}

.cus-checkboxradiobar.has-error.controlgroup-vertical label:last-of-type {
   /*background-image:none*/
}

select.error+span.ui-selectmenu-button {
   background-position: right 2px center;
   background-repeat: no-repeat;
   background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjIwIiBoZWlnaHQ9IjIwIiB2aWV3Qm94PSIwIDAgMjAgMjAiPiAgPHRpdGxlPiAgICBhbGVydCAgPC90aXRsZT4gIDxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+KiB7IGZpbGw6ICNmZjVkMDAgfTwvc3R5bGU+ICA8cGF0aCBkPSJNMTkuNjQgMTYuMzZMMTEuNTMgMi4zQTEuODUgMS44NSAwIDAgMCAxMCAxLjIxIDEuODUgMS44NSAwIDAgMCA4LjQ4IDIuM0wuMzYgMTYuMzZDLS40OCAxNy44MS4yMSAxOSAxLjg4IDE5aDE2LjI0YzEuNjcgMCAyLjM2LTEuMTkgMS41Mi0yLjY0ek0xMSAxNkg5di0yaDJ6bTAtNEg5VjZoMnoiLz48L3N2Zz4=);
}


/* cus-checkboxradiobar VERTICAL SCHEM */
.cus-checkboxradiobar.controlgroup-vertical {
   width: 100%
}

.cus-checkboxradiobar.controlgroup-vertical label,
.cus-checkboxradiobar.controlgroup-vertical label:hover {
   border-right: 0 !important
}

.cus-checkboxradiobar.controlgroup-vertical label:first-of-type {
   border-radius: 3px 3px 0 0;
}

.cus-checkboxradiobar.controlgroup-vertical label:last-of-type {
   border-radius: 0 0 3px 3px;
}


/* cus-checkboxradiobar DEFAULT COLORS SCHEM */
.cus-checkboxradiobar label {
   border-bottom-color: #ccc;
   background-color: #f6f6f6;
   color: #999999
}

.cus-checkboxradiobar label:hover {
   border-bottom-color: #93e0ff;
   background-color: #ffffff !important;
   color: #000000 !important;
   /*background-repeat:no-repeat!important; background-position:0 50%!important;*/
}

.cus-checkboxradiobar label.ui-state-active {
   border-bottom-color: #ffc107
}

.cus-checkboxradiobar label.ui-state-active:hover {
   border-bottom-color: #ffc107;
}

.cus-checkboxradiobar label:not(.ui-state-active):hover {
   border-bottom-color: #93e0ff
}

.cus-checkboxradiobar label.ui-state-focus {
   background-color: #ffffff
}

.cus-checkboxradiobar label:not(:last-of-type),
.cus-checkboxradiobar label.ui-state-focus:not(:last-of-type),
.cus-checkboxradiobar label:not(:last-of-type):hover {
   border-right-color: #999
}

.cus-checkboxradiobar label.ui-checkboxradio-checked {
   background-color: #deeffc;
   color: #000000
}




/****
 *  WIDTHS - HEIGHTS
 ****/

.cus-w-xxs {
   max-width: 96px;
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-xs {
   max-width: 112px;
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-s {
   max-width: 160px;
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-m {
   max-width: 224px;
   width: 50% !important;
   box-sizing: border-box
}

.cus-w-l {
   max-width: 256px;
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-ml {
   /*max-width:320px;*/
   width: 50% !important;
   box-sizing: border-box
}

.cus-w-xl {
   max-width: 336px;
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-xxl {
   /*max-width:480px;*/
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-xxxl {
   width: 100% !important;
   box-sizing: border-box
}

.cus-w-max {
   width: 100% !important
}

/*.cus-height-150 {height:150px;}*/




/****
 *  MARGINS - PADDINGS
 ****/

.cus-margin-0 {
   margin: 0 !important;
}

.cus-padding-0 {
   padding: 0 !important;
}

.cus-padding-all-4 {
   padding: 4px
}

.cus-padding-all-8 {
   padding: 8px
}

.cus-padding-12,
.cus-padding-all-12 {
   padding: 12px
}

.cus-padding-all-16 {
   padding: 16px
}

.cus-padding-xxsmall {
   padding: 0px 4px
}

.cus-padding-xsmall {
   padding: 2px 4px
}

.cus-padding-small {
   padding: 2px 8px
}

.cus-margin-padding-0 {
   margin: 0 !important;
   padding: 0 !important;
}

.cus-margin-bottom-small {
   margin-bottom: 8px
}

.cus-margin-small {
   margin: 8px;
}

.cus-margin-vertical-xsmall {
   margin-top: 4px;
   margin-bottom: 4px
}

.cus-margin-vertical-small {
   margin-top: 8px;
   margin-bottom: 8px
}

.cus-margin-vertical {
   margin-top: 12px;
   margin-bottom: 12px
}




/****
 *  POSITIONING
 ****/

.cus-vertical-middle {
   vertical-align: middle
}

.cus-vertical-text-bottom {
   vertical-align: text-bottom
}




/****
 *  ROUNDS
 ****/

.cus-round-12 {
   border-radius: 12px
}

.cus-round-top-small {
   border-top-left-radius: 2px;
   border-top-right-radius: 2px
}

.cus-round-top-medium {
   border-top-left-radius: 4px;
   border-top-right-radius: 4px
}

.cus-round-top-12 {
   border-top-left-radius: 12px;
   border-top-right-radius: 12px
}

.cus-round-top-8 {
   border-top-left-radius: 8px;
   border-top-right-radius: 8px
}

.cus-round-bottom-8 {
   border-bottom-left-radius: 8px;
   border-bottom-right-radius: 8px
}




/****
 *  BACKGROUNDS
 ****/

.cus-bg-shadow {
   /*background: url(../img/cesl-b70-10x10.png) repeat 0 0 transparent; border-top-left-radius:12px; border-top-right-radius:12px*/
}

.cus-bg-shadow-70 {
   /*background: url(../img/cesl-b70-10x10.png) repeat 0 0 transparent*/
}




/****
 *  BARS
 ****/

/* extend .w3-leftbar classes */
.cus-leftbar-circle {
   position: relative
}

.cus-leftbar-circle:after {
   content: '';
   position: absolute;
   top: 25%;
   left: -12px;
   width: 18px;
   height: 18px;
   border-radius: 8px
}




/****
 *  DISPLAYS
 ****/

.cus-hide {
   display: none;
}




/****
 *  EFFECTS
 ****/

/* extend w3-animate classes */
.cus-animate-height {
   overflow: hidden;
   max-height: 0;
   transition: max-height 0.15s linear
}

.cus-animate-height.w3-show {
   overflow: hidden;
   max-height: 1200px;
   transition: max-height 0.25s linear
}

.cus-animate-height-slow {
   overflow: hidden;
   max-height: 0;
   transition: max-height 0.5s ease-out
}

.cus-animate-height-slow.w3-show {
   overflow: hidden;
   max-height: 1200px;
   transition: max-height 0.5s ease-in;
}

/* spin */
@-moz-keyframes spin {
   100% {
      -moz-transform: rotate(360deg);
   }
}

@-webkit-keyframes spin {
   100% {
      -webkit-transform: rotate(360deg);
   }
}

@keyframes spin {
   100% {
      -webkit-transform: rotate(360deg);
      transform: rotate(360deg);
   }
}




/****
 *  FONTS
 ****/

.cus-font-0 {
   font-size: 0;
}

.cus-font-12 {
   font-size: 12px;
}

.cus-font-24 {
   font-size: 24px;
}

.cus-font-32 {
   font-size: 32px;
}

.cus-font-48 {
   font-size: 48px;
}

.cus-font-64 {
   font-size: 64px;
}

.cus-font-128 {
   font-size: 128px;
}

.cus-font-small {
   font-size: .85rem;
}

.cus-font-normal {
   font-size: 1rem;
}

.cus-bold-medium {
   font-weight: 600 !important
}

.cus-bold-700 {
   font-weight: 700 !important
}

.cus-bold {
   font-weight: bold !important
}

.cus-text-uppercase {
   text-transform: uppercase
}

.cus-text-error-wavy {
   text-decoration: red wavy underline
}

.cus-text-underline {
   text-decoration: underline
}




/****
 *  COLORS
 ****/

.cus-text-deep-green {
   color: #000 !important
}

.cus-text-deep-orange {
   color: #F8B133 !important
}

.cus-hover-deep-green:hover {
   background-color: #F8B133 !important;
   color: #fff !important
}

.cus-hover-green {
   background-color: #F8B133 !important;
   color: #fff !important
}

.cus-hover-green:focus,
.cus-hover-green:hover {
   background-color: #F8B133 !important;
   color: #fff !important;
   outline: 0
}

.cus-hover-orange {
   background-color: #F8B133 !important;
   color: #fff !important;
}

.cus-hover-orange:focus,
.cus-hover-orange:hover {
   background-color: #F8B133 !important;
   color: #fff !important;
   outline: 0
}

.cus-hover-yellow:hover,
.cus-hover-yellow:focus {
   background-color: #F8B133 !important;
   color: #fff !important;
   outline: 0
}

.cus-hover-white:hover,
.cus-hover-white:focus {
   background-color: #fff !important;
   color: #fff !important;
   outline: 0
}

.cus-deep-green {
   background-color: #F8B133 !important;
   color: #fff !important
}

.cus-hover-deep-green:focus,
.cus-hover-deep-green:hover {
   background-color: #F8B133 !important;
   color: #fff !important
}

.cus-deep-purple,
.cus-hover-deep-purple:hover {
   background-color: #F8B133
      /*9d00bc*/
       !important;
   color: #fff !important
}

.cus-text-deep-purple {
   color: #F8B133
}

.cus-deep-blue,
.cus-hover-deep-blue:hover {
   background-color: #F8B133 !important;
   color: #fff !important
}

.cus-deep-yellow,
.cus-hover-deep-yellow:hover {
   background-color: #e5ac00 !important;
   color: #fff !important
}

.cus-light-purple,
.cus-hover-light-purple:hover {
   background-color: #F8B133 !important;
   color: #e5ac00 !important
}

.cus-deep-orange {
   background-color: #F8B133 !important;
   color: #F8B133 !important
}

.cus-hover-opacity-90-100 {
   opacity: .9;
   margin: 0 8px;
}

.suivez-nous img {
   width: 50px;
   height: 50px;
}

.cus-hover-opacity-95-100 {
   opacity: .95
}

/*.cus-hover-opacity-97-100 {opacity:.97}*/
.cus-hover-opacity-90-100:hover,
.cus-hover-opacity-95-100:hover,
.cus-hover-opacity-97-100:hover {
   opacity: 1
}




/****
 *  LINKS
 ****/

.cus-lnk,
.cus-lnk-external {
   cursor: pointer
}

.cus-lnk-external::after {
   font-family: 'Material Icons';
   content: '\e895';
   vertical-align: super;
   display: inline-block
}




/****
 *  BUTTONS
 ****/

.w3-button .material-icons {
   vertical-align: middle
}




/****
 *  BUBBLES
 ****/
/* NOT USED ACTUALY*/
.bubble-text {
   background: #F8B133;
   color: #fff;
   padding: 7px 15px;
   border-radius: 3px;
   width: 100%;
   max-width: 350px;
}

.bubble-text::after {
   content: "";
   position: absolute;
   right: -20px;
   top: 20px;
   border-left: 20px solid #F8B133;
   border-top: 20px solid transparent;
   border-bottom: 20px solid transparent;
}




/****
 *  INHERIT OF CESL 2014 THEME
 ****/

#bgShadow {
   position: absolute;
   z-index: 50000;
   background-color: #000;
   display: none;
   top: 0px;
   left: 0px;
}

#modal {
   position: fixed;
   width: 260px;
   height: 120px;
   display: none;
   z-index: 50001;
   padding: 20px;
   border-radius: 10px;
   background-color: white;
   border: 1px solid grey;
   text-align: center;
}

#modal .exit {
   float: right;
   color: #F8B133;
   font-weight: bold;
   font-size: 16px;
}

#modal .exit:hover {
   color: #F8B133;
   text-decoration: none;
}

#modal p {
   color: #777;
   font-size: 14px;
   padding: 8px 0;
}