
body {
    font-family: 'PT Sans', sans-serif;
    color: var(--font_2)
}

.shape {
    display: block;
    border-color: transparent transparent transparent white;
    border-style: solid;
    border-width: 0 0 10vh 100vw;
    left: 0;
    height: 0;
    position: relative;
    float: left;
    width: 0;
    z-index: 2;
}

.shape_2 {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 10vh;
    background: white;
    clip-path: polygon(0 100%, 100% 0, 100% 100%, 0 100%);
}

.shape_3 {
    display: block;
    position: relative;
    width: 100%;
    height: 10vh;
    background: var(--bg_footer);
    clip-path: polygon(0 100%, 100% 0, 100% 100%, 0 100%);
}

.shape_4 {
    display: block;
    position: relative;
    width: 100%;
    height: 10vh;
    background: var(--bg_footer);
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 100%);
}

header {
    display: block;
    position: relative;
    height: 70vh;
    width: 100%;
    background: var(--bg_footer);
    overflow: hidden;
    background: linear-gradient(to bottom, var(--bleu_4) 0%, var(--bleu) 100%);
}

header:before {
    content: "";
    display: block;
    position: relative;
    height: 60px;
    width: 100%;
}

header:after {
    content: '';
    display: block;
    position: absolute;
    border-color: transparent transparent #fff transparent;
    border-style: solid;
    border-width: 0 0 10vh 100vw;
    bottom: 0;
    height: 0;
    width: 0;
}

header span.bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: 50% 50%;
    background-size: cover;
    background-attachment: fixed;
    opacity: .37;
}

header video {
    display: block;
    width: 100%;
}

.desc {
    display: block;
    position: absolute;
    color: white;
    padding: 0 25px;
    font-family: 'Roboto', sans-serif;
    top: 100px;
    text-shadow: 0 1px 2px var(--text_shadow);
}

.desc h1 {
    display: block;
    font-size: 42px;
    margin-bottom: 4px;
}

.desc h5 {
    display: block;
    font-size: 16px;
    font-weight: normal;
    margin-bottom: 30px;
}

.desc ul {
    display: block;
    list-style: none;
    padding: 0;
    margin: 0 0 30px 0;
    font-size: 24px;
}

.desc ul li i {
    color: var(--vert)
}

.btn {
    display: block;
    position: relative;
    text-align: center;
    transition: all 0.25s ease-out;
    cursor: pointer;
    text-transform: uppercase;
    background-color: var(--bleu_4);
    font-size: 22px;
    color: white;
    margin: 10px 0 0;
    max-width: 300px;
    padding: 15px 5px;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.17);
}

.btn:hover {
    box-shadow: 0 5px 10px var(--box_shadow);
    transform: scale(.9);
}

.mailer {
    display: block;
    position: absolute;
    text-align: center;
    border-radius: 50%;
    right: 15px;
    width: 100px;
    height: 100px;
    line-height: 100px;
    bottom: 30px;
    z-index: 6;
    font-size: 30px;
    color: white;
    background-color: var(--bleu_4);
    box-shadow: 0 12px 20px var(--blue_shadow);
    transition: all 0.25s ease-out;
    cursor: pointer;
}

.mailer:hover {
    background: var(--bleu_7);
    box-shadow: 0 5px 10px var(--blue_shadow_2);
    height: 95px;
    width: 95px;
    line-height: 95px;
    bottom: 20px

}

.mailer.floating{
    position:fixed;
    width:75px;
    height:75px;
    line-height:75px;
    font-size:25px
}

.offers {
    position: relative;
    padding: 30px 50px;
    font-family: 'Roboto', sans-serif;
    font-size: 16px;
    transition: all 0.2s ease-out;
    background: white;
}

.offers:before {
    content: '';
    display: block;
    position: relative;
    height: 16px;
}

.top {
    font-size: 21px;
    margin-bottom: 10px;
}

.price {
    font-size: 21px;
    margin-bottom: 15px;
}

[data-o="price"] {
    margin-left: 4px;
}

[data-o="code"] {
    text-transform: uppercase;
    font-weight: bold;
}

[data-o="set"] {
    margin-bottom: 10px;
}

[data-o="hint"],
[data-o="scale"] {
    font-size: 18px
}

[data-cap="0"] [data-o="code"],
[data-cap="0"] [data-o="price"] {
    color: var(--bleu_6)
}

[data-cap="1"] [data-o="code"],
[data-cap="1"] [data-o="price"] {
    color: var(--bleu_4)
}

[data-cap="2"] [data-o="code"],
[data-cap="2"] [data-o="price"] {
    color: var(--bleu_5)
}

[data-o="content"] {
    margin-bottom: 15px
}

.offers ul li {
    font-size: 16px;
    margin-bottom: 5px;
}

.offers ul li i {
    color: var(--vert);
    margin-right: 5px
}

#trigger.btn {
    max-width: 250px;
    line-height: 55px;
    font-size: 18px;
    padding: 0;
    text-shadow: 0 1px 1px var(--text_shadow_light);
    box-shadow: 0 8px 12px var(--box_shadow);
    margin-top: 25px;
}

[data-cap="0"] #trigger.btn {
    background: var(--bleu_6);
}

[data-cap="1"] #trigger.btn {
    background: var(--bleu_4);
}

[data-cap="2"] #trigger.btn {
    background: var(--bleu_5);
}

[data-o="gif"] {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#displayer {
    display: flex;
    justify-content: center;
    margin: auto;
    max-width: 1280px;
}

#displayer .left {
    position: relative;
    transition: all .2s ease-out;
    left: -100%;
    animation: pushLeft .2s ease-out forwards;
    opacity: 0;
    flex: 1;
}

#displayer .right {
    position: relative;
    transition: all .2s ease-out;
    max-width: 500px;
    right: -100%;
    animation: pushRight .2s ease-out forwards;
    opacity: 0;
    flex: 1;

}

#offers.off #displayer .left {
    animation: exit_left .3s ease-out forwards;
}

#offers.off #displayer .right {
    animation: exit_right .3s ease-out forwards;
}

.nav_swifter{
    display:flex;
    justify-content:center;
    gap:4px;
    position: absolute;
    top:0;
    right: 0;
}

#nav_swifter_left,
#nav_swifter_right{
    font-size:26px;
    color:white;
    background-color:var(--bleu_4);
    padding:4px 14px;
    border-radius:2px;
    cursor:pointer
}

#nav_swifter_left:hover,
#nav_swifter_right:hover{
    background-color:var(--bleu_5);
}

#nav_swifter_left i, #nav_swifter_right i{
    pointer-events: none;
}


.compare {
    display: block;
    position: relative;
    background-color: var(--bleu_3);
    padding: 80px 15px 100px;
    background-attachment: fixed;
    background-position: 50% 50%;
    background-size: cover;
    font-family: 'Roboto', sans-serif;
}

.prices {
    display: block;
    position: relative;
    width: 95%;
    color: white;
    text-shadow: 0 1px 2px var(--text_shadow);
    margin: 5vh auto auto auto;
    max-width: 1028px;
}

.prices h1 {
    font-size: 42px;
}

.prices h2 {
    font-size: 24px;
}

.prices h5 {
    font-size: 18px;
    font-weight: normal;
    padding-right: 37.5%;
}

.price_tag {
    display: flex;
    justify-content: center;
    align-items: center;
    top: -30px;
    position: relative;
    gap: 0;
}

.price_tag div[data-tag] {
    position: relative;
    padding: 25px;
    background: white;
    text-align: center;
    color: var(--font_2);
    text-shadow: none;
    flex: 1;
    box-shadow: 0 10px 20px var(--active_shadow);
}

.price_tag div[data-tag] i {
    display: block;
    margin-bottom: 10px
}

.price_tag div[data-tag] .typo {
    font-size: 24px;
    margin-bottom: 10px;
    display: block;
}

.price_tag div[data-tag="mini"] i,
.price_tag div[data-tag="mini"] strong,
.price_tag div[data-tag="mini"] b {
    color: var(--bleu_6);
}

.price_tag div[data-tag="mini"] i {
    font-size: 25px;
}

.price_tag div[data-tag="standard"] i,
.price_tag div[data-tag="standard"] strong,
.price_tag div[data-tag="standard"] b {
    color: var(--bleu_4);
}

.price_tag div[data-tag="standard"] i {
    font-size: 40px;
    margin-bottom: 14px
}

.price_tag div[data-tag="premium"] i,
.price_tag div[data-tag="premium"] strong,
.price_tag div[data-tag="premium"] b {
    color: var(--bleu_5);
}

.price_tag div[data-tag="premium"] i {
    font-size: 60px;
    margin-bottom: 18px
}

.price_tag div[data-tag] i {
    display: block;
}

.price_tag div[data-tag] strong {
    text-transform: uppercase;
}

.price_tag div[data-tag] li {
    line-height: 1.5;
    font-weight: normal;
    margin-bottom: 4px;
}

.price-info {
    display: block;
    margin-top: 10px;
    font-weight: bold;
}

.price-info strong {
    display: block;
    font-size: 36px;
    margin: 4px 0 15px 0;
}

.price-info strong b {
    display: inline-block;
    position: relative;
    font-size: 18px;
    vertical-align: top;
    top: 8px;
    text-transform: none;
}

.price-info button {
    display: block;
    text-transform: uppercase;
    background-color: var(--vert_3);
    color: white;
    font-size: 16px;
    margin: 10px auto;
    width: 100%;
    max-width: 300px;
    padding: 20px 5px;
    box-shadow: 0 15px 30px var(--box_shadow);
    transition: all 0.25s ease-out;
    font-family: 'Roboto', sans-serif;
    cursor: pointer;
}

.price-info button:hover {
    transform: scale3d(0.95, 0.95, 0.95) translate3d(0, 5px, 0);
    box-shadow: 0 5px 10px var(--box_shadow);
    background: var(--vert_5);
}

.check {
    display: flex;
    justify-content: center;
    position: relative;
    background: white;
    padding: 40px 15px 15px 15px;
    font-family: 'Roboto', sans-serif;
    max-width: 1280px;
    margin: auto;
}

.check div {
    flex: 1;
}

.check div li {
    padding: 0 25px;
    height: 55px;
    line-height: 55px;
    white-space: nowrap;
}

.check div:not(:first-child) {
    max-width: 250px;
    text-align: center;
}

.check div:nth-child(2n) {
    box-shadow: 0 15px 30px var(--box_shadow);
}

.check div:last-child li {
    padding-left: 20px;
    position: relative;
}

.check {
    font-size: 16px;
    margin-bottom: calc(40px + 10vh);
}

.check .col {
    font-size: 18px;

}

.check .line {
    border-top: 1px solid var(--grey_5);

}

.check .line i {
    display: inline-block;
    position: relative;

}

.check .col svg {
    display: block;
    position: relative;
    width: 100%;
    height: 60px;
    margin: auto;
}

.check .line i.fa-check {
    color: var(--vert_6);
}

.check .line i.fa-times {
    color: red;
}

.check .line i.fa-star {
    color: var(--star);
}

.included {
    display: block;
    position: relative;
    background: var(--bg_footer);
    font-family: 'Roboto', sans-serif;
    padding: 25px 0
}

.included h1 {
    display: block;
    text-align: center;
    font-size: 38px;
    font-weight: normal;
    margin: auto
}

.included h1 strong {
    text-transform: uppercase;
    color: var(--bleu_4);
}

.included h3 {
    font-weight: normal;
    font-size: 21px;
    display: block;
    text-align: center;
}

.included .btn{
    margin:auto;
    max-width: 300px;
    font-size:18px;
    background:var(--vert_3);
    box-shadow: 0 8px 12px var(--box_shadow);
}
.included .btn:hover{
    background:var(--vert_5)
}


#feat {
    display: flex;
    justify-content: center;
    max-width: 1028px;
    margin: 25px auto;
}

#feat div {
    flex: 1;
    width: 16.66%;
    padding: 0 15px;
}

#feat div span {
    height: 85px;
    display: block;
    text-align: center;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: auto 75%;
    font-weight: bold;
}

#feat div span.ic-o {
    height: max-content;
}

.tip{
    cursor: pointer;
}

.tip .div{
    display:flex;
    justify-content:center;
    padding:40px 40px 20px;
    font-family: 'Roboto', sans-serif;
    margin:auto;
    max-width: 1028px;
}

.tip:last-of-type .div{
    padding-bottom:0;
}

.tip .titre{
    display:block;
    font-size:24px;
    margin-bottom:5px;
}

.tip .content{
    display:block;
    font-size:18px;
    margin-bottom:15px;
    max-width:580px;
}

.tip .div > div{
    flex:1
}

.tip .description{
    z-index:3;
}

.tip .illustration{
    z-index:2;
}

.tip .illustration span{
    display:block;
    width:100%;
    height:100%;
    background-size:contain;
    background-position:center;
    background-repeat:no-repeat;
}

.tip ul{
    display: block;
    position: relative;
    margin-bottom: 30px;
}

.tip ul li{
    margin-bottom: 5px;
}

.tip ul li i.fa-check{
    color: var(--vert)
}

.promo-box{
    display:flex;
    justify-content:center;
    margin-bottom:20px
}
.promo-box div{
    flex:1;
}
.promo-box div:first-child{
    padding:5px;
    color:white;
    background:var(--bleu_4);
    max-width: 90px;
}

.promo-box div:last-child{
    padding-left:20px ;
}

.promo-box div span{
    display:block;
    text-align:center;
}

.promo{
    font-size:28px;
    font-weight:bold;
    position:relative;
}

.promo:after{
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 5px;
    border-radius: 5px;
    background-color: #454545;
    transform: rotate(-22.5deg);
}

.tip b{
    font-weight:normal;
    font-size:12px
}

.tip:nth-of-type(even):before{
    content:none;
    display:block;
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100vw;
    background:var(--bg_footer);

}

.tip:nth-of-type(even) {
    background:var(--bg_footer)
}

.tip:nth-of-type(even) + .shape{
border-color: transparent transparent transparent var(--bg_footer) ;
    background:white
}
.tip:nth-of-type(odd) + .shape{
background:var(--bg_footer) ;
}


[data-trigger]{
    font-weight:bold;
    font-size:18px;
    color:var(--bleu_4);
    cursor:pointer
}
[data-trigger] i{
    position:relative;
    transition:all .2s ease-out;
    left:0
}
[data-trigger]:hover i{
    left:-4px
}




.ide {
    display: block;
    position: relative;
    background: var(--bg_footer);
    min-height: 200px;
    padding: 60px 0 10px;
    font-family: 'Roboto', sans-serif;
}

.ide h1 {
    display: block;
    text-transform: uppercase;
    font-size: 24px;
    text-align: center;
    margin-bottom: 8px;
}

.ide h3 {
    display: block;
    text-align: center;
    font-weight: normal;
    max-width: 640px;
    padding: 0 25px;
    font-size: 16px;
    margin: auto;
    color: var(--font_3)
}

.ide hr {
    display: block;
    height: 3px;
    width: 100px;
    margin: 30px auto;
    background: var(--bleu)
}

.tools {
    display: flex;
    justify-content: center;
    max-width: 680px;
    margin: auto;
}

.tools span {
    display: block;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 100px;
    flex: 1;
    filter: grayscale(100%);
    -webkit-filter: grayscale(100%);
    opacity: .4;
}

.tools span:hover {
    opacity: .6;
}



@media screen and (max-width: 1028px) {

    header {
        height: 60vh;
    }

    header:before {
        content: none;
    }

    header span.bg {
        opacity: 1;
    }

    header video {
        display: none;
    }

    .desc {
        top: 110px;
        margin: auto;
        left: 0;
        right: 0;
    }

    .desc h1 {
        font-size: 22px;
        text-align: center;
    }

    .desc h5 {
        text-align: center;
        margin-bottom: 10px;
    }

    .desc ul {
        text-align: center;
        font-size: 16px;
        margin-bottom: 20px;
    }

    .desc .btn {
        margin: auto;
        color: var(--bleu_8);
        background: white;
        text-shadow: none;
        font-size: 20px;
        max-width: 250px;
    }

    .mailer {
        display: none;
    }

    .offers {
        padding: 30px 40px
    }

    .compare {
        padding: 50px 15px;
    }

    .prices {
        width: 100%;
        text-align: center;
    }

    .prices h1 {
        font-size: 30px;
    }

    .prices h2 {
        font-size: 18px;
    }

    .prices h5 {
        padding-right: 0;
        font-size: 16px;
    }

    .price_tag {
        display: block;
        top: 0;
        margin-top: 60px;
    }

    .price_tag div[data-tag] {
        padding-top: 60px;
    }

    .price_tag div[data-tag]:not(:last-child) {
        margin-bottom: 80px;
    }

    .price_tag div[data-tag] i {
        position: absolute;
        font-size: 28px;
        width: 75px;
        height: 75px;
        line-height: 75px;
        border-radius: 0;
        margin: auto;
        box-shadow: 0 15px 30px var(--box_shadow);
        left: 0;
        right: 0;
        top: -37.5px;
        color: white;
    }

    .price_tag div[data-tag="mini"] i {
        background: var(--bleu_6);
    }

    .price_tag div[data-tag="standard"] i {
        background: var(--bleu_4);
    }

    .price_tag div[data-tag="premium"] i {
        background: var(--bleu_5);
    }

    .price_tag div[data-tag] li {
        line-height: 1.5;
    }

    .check {
        margin-bottom: 40px
    }

    .included h1 {
        font-size: 28px;
    }

    #feat{
        flex-wrap: wrap;
        max-width: 768px;
    }
    #feat div {
        flex: 0 0 calc(33.33% - 10px);
        margin-bottom: 40px;
    }

    .promo-box{
        display:block
    }
    .promo-box div:last-child {
        padding-left:0;
        margin-top:15px
    }

    .tip{
        display:block;
        position:relative;
        overflow: hidden;
    }
    .tip .div{
        padding: 40px 20px 20px;
    }
    .illustration{
        position: absolute;
        top: 0;
        right: -40%;
        bottom: 0;
        opacity: .35;
        z-index: -1;
        width: 100%;
    }

    .tip + .shape,
    .shape_2,
    .shape_3,
    .shape_4{
        display: none
    }


}

@media screen and (max-width: 768px) {
    #displayer .right {
        display: none;
    }

    #trigger.btn {
        margin: 25px auto auto auto;
        max-width: 100%;
    }

    .check {
        display: none
    }

    .included h1 {
        font-size: 20px;
    }

    .included h3 {
        font-size: 16px;
    }
}

@media screen and (max-width: 580px) {
    .included {
        padding: 30px 0;
    }

    #feat {
        display: block;
        margin-top: 35px
    }

    #feat div {
        width: 100%;
        height: 120px;
        margin-bottom: 40px;
    }

    #feat .ic {
        background-size: contain;
        margin-bottom: 15px;
    }

    .nav_swifter{
        top:-16px
    }
}

@media screen and (min-width: 1028px){
    #x-contact-trigger-box.floating > #x-contact {
        left:20px;
        right:unset!important
    }
    #x-contact-trigger-box.floating > #x-trigger + #x-contact ~ button {
        left: 22px;
        right:unset!important
    }
}

@keyframes exit_left {
    0% {
        left: 0;
        opacity: 1
    }
    100% {
        left: -100%;
        opacity: 0
    }
}

@keyframes exit_right {
    0% {
        right: 0;
        opacity: 1
    }
    100% {
        right: -100%;
        opacity: 0
    }
}

@keyframes pushRight {
    0% {
        right: -100%;
        opacity: 0
    }
    100% {
        right: 0;
        opacity: 1
    }
}

@keyframes pushLeft {
    0% {
        left: -100%;
        opacity: 0
    }
    100% {
        left: 0;
        opacity: 1
    }
}
