html {
    scroll-behavior: smooth;
}

body {
    font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: #14213D;
}

@media (min-width: 1350px){
    /* Support for XXL devices */
    .container {
        max-width: 85%;
    }
}

::-moz-selection {background-color: #ECBFC0;}
::selection {background-color: #ECBFC0;}

/* Structure: navbar, footer and wrapper */
.navbar{
    box-shadow: 0px 0px 10px 0px rgba(20,33,61,0.01);
    background: #ffffff;
}

.keet-logo-img{
    height: 2rem;
    width:auto;
}

@media only screen and (max-width: 576px){
    .keet-logo-img{
        height: 1.5rem;
    }
}

.navbar-option.selected{
    font-weight: 500;
    border-bottom: 3px solid #c1292e;
}

.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(.input-group-btn){ /* Ovewrite standard code by bootstrap select */
    width: 60px;
}

#wrapper{
    background-color: #F1F2F4;
}

.gradient-background{
    background-image: linear-gradient(0deg, white, #f1f2f4);
}

.white-background{
    background-color: white;
}

footer{
    background-color: white;
    padding: 1rem;
    box-shadow: 0px 0px 10px 0px rgba(20,33,61,0.1);
}

.footer-links-header{
    font-weight: 500;
    font-size: 1.2rem;
}

.footer-social-img{
    max-width: 2rem;
    max-height: 2rem;
    border-radius: 0.25rem;
}

.footer-italian-flag{
    max-height: 1.2rem;
    padding-bottom: 0.2rem;
}
/* Structure / End */



/* Special pages (full screen) */
.special-page-html, .special-page-body {
    height: 100%
}

.special-page-wrapper{
    height: 85%;
}
/* Special pages / End */



/* Elements */
.page-title{
    font-weight: 600;
    font-size: 2.675rem;
}

@media only screen and (max-width: 768px){
    .page-title{
        font-size: 2rem;
    }
}

.page-subtitle,
.subtitle{
    font-weight: 400;
}

u {
    cursor: auto;
    text-decoration: underline #C1292E;
}

p.smaller-paragraph{
    font-size: 0.9rem;
}

p.small-paragraph{
    font-size: 0.75rem;
}

.homepage-hero-cta,
.homepage-map-cta-box{
    background-color: white;
    border-radius: 1.5rem;
    box-shadow: 0 0.25rem 0.5rem 0 rgba(20,33,61,0.1);
}

.homepage-hero-cta-option{
    margin: 0.5rem 0 0 0;
    padding: 0.125rem;
    border-radius: 1rem;
    border: 1.5px solid #F1F2F4; /* To prevent layout shift when selecting an option */
    cursor: pointer;
    transition: all 0.15s ease-in-out;
}

.homepage-hero-cta-option:hover{
    transform: scale(1.02);
    box-shadow: 0 0.125rem 0.25rem 0 rgba(20,33,61,0.05);
}

.homepage-hero-cta-option.selected{
    background-color: #F3FCF5;
    border: 1.5px solid #7FDA98;
}

.homepage-hero-cta-icon{
    width: 4rem;
}

.homepage-map-cta-subtitle{
    font-weight: 400;
    font-size: 1.25rem;
}

.homepage-map-coverage-icon{
    width: 3rem;
}

.homepage-map-coverage-result{
    background-color: #55CE75;
    border-radius: 1.25rem;
    color:white;
}

.homepage-map-cta-disclaimer{
    font-size: 0.85rem;
    font-style: italic;
}

#homepage-blog-posts{
    max-width:1280px;
}

.blog-card{
	border:none;
	border-radius: 1rem;
	box-shadow: 0 0.25rem 0.5rem 0 rgba(20,33,61,0.05);
    max-width: 25rem;
}

.homepage-blog-card-img{
	border-radius: 1rem 1rem 0 0;
	height: 12.5rem;
}

.homepage-blog-card-body{
    background-color: white;
    border-radius: 0 0 1rem 1rem;
}

.header-icon {
    width:3rem;
    height: auto;
}

.product-section,
.total-section{
    background-color: white;
    border-radius: 1rem;
    border: 1.5px solid #F1F2F4; /* To prevent layout shift when selecting an option */
    box-shadow: 0 0.25rem 0.5rem 0 rgba(20,33,61,0.05);
    min-width: 10rem;
    transition: all 0.15s ease-in-out;
}

.product-section:hover{
    cursor: pointer;
    transform: scale(1.01);
    background-color: #F3FCF5;
}

.product-section.selected{
    background-color: #F3FCF5;
    border: 1.5px solid #7FDA98;
}

.swal2-close{
    outline: none !important;
}

.paragraph-title{
    text-align: left;
}

.paragraph-text{
    font-size: 0.8rem;
}

.pricing-details{
    font-size: 0.8rem;
}

#perks-testimonial{
    border: 5px solid #c1292e;
    background-color: #F8E9EA;
}

.perks-testimonial-logo{
    border-radius:.75rem;
    border: 2px solid #14213D;
}

.perks-testimonial-picture{
    width: 3rem;
    height: 3rem;
    border-radius:50%;
    border: 2px solid #14213D;
}

.perks-results-number{
    color: #C1292E;
    font-weight: bold
}

.medium-sized-icon{
    max-width:8rem;
    height: auto;
}

.mini-icon{
    max-width:2rem;
    height: auto;
}

@media only screen and (min-width: 768px){
    .lp-cta-title{
        font-size: 2rem; /* Style an h4 element like an h2 element on large screens */
    }
}
/* Elements / End */



/* Button styles */
a {
    color: #14213D;
}

a:hover{
    color: #C1292E;
    transition: all 0.15s ease-in-out;
    text-decoration: none;
}

a.hover-enlarge:hover{
    text-decoration: none;
    transform: scale(1.04);
    box-shadow: 0 0.25rem 0.5rem 0 rgba(20,33,61,0.1);
}

a.button{
    display: inline-block;
    background-color: #C1292E;
    color: white !important;
    border-radius: .5rem;
    cursor: pointer;
    padding: 0.5rem 1rem;
    transition: all 0.15s ease-in-out;
}

a.button-blue{
    background-color: #14213D;
}

a.button>span{
    color: white !important;
}

a.button-white{
    display: inline-block;
    background-color: white;
    color: #14213D !important;
    border-radius: .5rem;
    cursor: pointer;
    padding: 0.5rem 1rem;
    transition: all 0.15s ease-in-out;
}

a.button>.user-choice{
    color: white;
    font-size: 1.25rem;
}
/* Button / End */


/* Background pictures */
#home-carousel{
    background-image: url(../images/home-carousel-bg.svg);
    background-size: cover;
    background-position: top;
}
/* Background pictures / End */

/* Animated vehicles on homepage */
.animated-vehicle{
    width:200px;
    height:126.391px;
    position: absolute;
    right:-300px;
    bottom: -40px;
    -webkit-animation-iteration-count: 1; /* only do the animation once */
    animation-iteration-count: 1; /* only do the animation once */
}

#animated-vehicle-1{
    -webkit-animation-delay: 1s;
    -webkit-animation: moveVehicle1 2s ease-in-out;
    -webkit-animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
    animation-delay: 1s;
    animation: moveVehicle1 2s ease-in-out;
    animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
}

#animated-vehicle-2{
    -webkit-animation-delay: 3s;
    -webkit-animation: moveVehicle2 3s ease-in-out;
    -webkit-animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
    animation-delay: 3s;
    animation: moveVehicle2 3s ease-in-out;
    animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
}

#animated-vehicle-3{
    -webkit-animation-delay: 4s;
    -webkit-animation: moveVehicle3 4s ease-in-out;
    -webkit-animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
    animation-delay: 4s;
    animation: moveVehicle3 4s ease-in-out;
    animation-fill-mode: forwards; /* keep the vehicle in the final spot at the end of animation */
}

@-webkit-keyframes moveVehicle1{
    0% {right: -300px;}
    100% {right: 36%;}
}

@keyframes moveVehicle1{
    0% {right: -300px;}
    100% {right: 36%;}
}

@-webkit-keyframes moveVehicle2{
    0% {right: -300px;}
    100% {right: 22%;}
}

@keyframes moveVehicle2{
    0% {right: -300px;}
    100% {right: 22%;}
}

@-webkit-keyframes moveVehicle3{
    0% {right: -300px;}
    100% {right: 8%;}
}

@keyframes moveVehicle3{
    0% {right: -300px;}
    100% {right: 8%;}
}

@media only screen and (max-width: 1499px){
    @-webkit-keyframes moveVehicle2{
        0% {right: -300px;}
        100% {right: 20%;}
    }
    
    @keyframes moveVehicle2{
        0% {right: -300px;}
        100% {right: 20%;}
    }
    
    @-webkit-keyframes moveVehicle3{
        0% {right: -300px;}
        100% {right: 4%;}
    }
    
    @keyframes moveVehicle3{
        0% {right: -300px;}
        100% {right: 4%;}
    }
}

@media only screen and (max-width: 1199px){
    @-webkit-keyframes moveVehicle2{
        0% {right: -300px;}
        100% {right: 18%;}
    }
    
    @keyframes moveVehicle2{
        0% {right: -300px;}
        100% {right: 18%;}
    }
    
    @-webkit-keyframes moveVehicle3{
        0% {right: -300px;}
        100% {right: 0%;}
    }
    
    @keyframes moveVehicle3{
        0% {right: -300px;}
        100% {right: 0%;}
    }
}

@media only screen and (max-width: 575px){
    .animated-vehicle{
        width:160px;
        height:101.113px;
    }
}

/* Animated vehicles on homepage / End */


/* Divider */
.divider>.divider-content{
    border-bottom: 1px solid #14213D;
}
/* Divider / End */


/* Spacer: different heights for different screen sizes */
@media only screen and (min-width: 1500px){
    .spacer {
        height: 7.5rem;       
    }
}

@media only screen and (min-width: 769px){
    .spacer {
        height: 4rem;       
    }
}

@media only screen and (max-width: 768px){
    .spacer {
        height: 2.5rem;       
    }
}
/* Spacer / End */

/* Features */
#features img{
    max-width: 7.5rem;
    height:auto;
}

/* Carousel caption: different size and position for different screen sizes */
.carousel-caption{
    left: 1%;
    right: 1%;
    color: #14213D;
    bottom: -20px;
}

.carousel-caption>h2{
    font-size: 3.5rem;
    letter-spacing: -0.1rem;
}

.carousel-caption>p{
    font-size: 1.125rem;
}

@media only screen and (max-width: 1200px){
    .carousel-caption{
        bottom: -15px;
    }
    .carousel-caption>h2 {
        font-size: 3rem;
    }
}

@media only screen and (max-width: 992px){
    .carousel-caption{
        bottom: -25px;
    }
    .carousel-caption>h2 {
        font-size: 2.5rem;
    }
    .carousel-caption>p {
        font-size: 0.85rem;
    }
}

@media only screen and (max-width: 768px){
    .carousel-caption{
        bottom: -10px;
    }
    .carousel-caption>h2 {
        font-size: 2rem;
        font-weight: 400;
    }
    .carousel-caption>p {
        display: none;
    }
}

@media only screen and (max-width: 576px){
    .carousel-caption{
        bottom: -25px;
    }
    .carousel-caption>h2 {
        font-size: 1.25rem;
        font-weight: 400;
    }
    .carousel-caption>p {
        display: none;
    }
}
/* Carousel caption / End */

/* Parallax Sections */
.parallax-background{
    background-size: cover;
    background-attachment: fixed;
    background-position: center;
    box-shadow: 0px 0px 10px 0px rgba(20,33,61,0.05);
}

#homepage-parallax{
    background-image: url(../images/home-parallax-bg.jpg);
}

#product-cta-parallax-1,
#product-cta-parallax-2{
    background-image: url(../images/product-parallax-bg.jpg);
}

.parallax-overlay{
    background-color: rgba(20,33,61,0.92);
}

.parallax-content-icon{
    max-width: 5rem;
}

.parallax-content>*{
    color: white;
}
/* Parallax Sections / End */

/* Homepage Slider */
.rs-range {
    margin-top: 2rem;
    width: 100%;
    -webkit-appearance: none;
}
.rs-range:focus {
    outline: none;
}
.rs-range::-webkit-slider-runnable-track {
    width: 100%;
    height: 2.5px;
    cursor: pointer;
    box-shadow: none;
    background: white;
    border-radius: .2rem;
    border: 1px solid #D0D3D8;
}
.rs-range::-moz-range-track {
    width: 100%;
    height: 2.5px;
    cursor: pointer;
    box-shadow: none;
    background: white;
    border-radius: .2rem;
    border: 1px solid #D0D3D8;
}
.rs-range::-webkit-slider-thumb {
    box-shadow: none;
    border: 0px solid white;
    box-shadow: 0px 5px 5px rgba(20, 33, 61, 0.05);
    height: 2.5rem;
    width: 1.25rem;
    border-radius: 22px;
    background: #14213D;
    cursor: pointer;
    -webkit-appearance: none;
    margin-top: -20px;
}
.rs-range::-moz-range-thumb {
    box-shadow: none;
    border: 0px solid white;
    box-shadow: 0px 5px 5px rgba(20, 33, 61, 0.05);
    height: 2.5rem;
    width: 1.25rem;
    border-radius: 22px;
    background: #14213D;
    cursor: pointer;
    -webkit-appearance: none;
    margin-top: -20px;
}
.rs-range::-moz-focus-outer {
    border: 0;
}
.rs-label {
    position: relative;
    transform-origin: center center;
    display: block;
    width: 4rem;
    height: 4rem;
    background: transparent;
    border-radius: 50%;
    text-align: center;
    font-weight: 500;
    padding-top: 0.9rem;
    box-sizing: border-box;
    border: 2px solid #14213D;
    margin-top: 1rem;
    margin-left: -1.75rem;

    /* Initial position -> Value = 5 */
    left: 2.25rem;

    color: #C1292E;
    font-style: normal;
    font-weight: normal;
    line-height: normal;
    font-size: 1.5rem;
    font-weight: 500;
}

/* Homepage Slider / End */

/* Form styles */
.form-check-input{
    cursor:pointer;
}

.form-check-input:checked{
    background-color: #29c251 !important;
}

.form-control.is-valid, .was-validated .form-control:valid{
    border-color: #29C251 !important;
}

.form-control.is-invalid, .was-validated .form-control:invalid {
    border-color: #C1292E !important;
}
/* Form styles / End */

/* Accordion styles */
.accordion{
    border-radius: .5rem;
    border: 1px solid #D0D3D8;
    background-color: white;
}

.accordion-head{
    border-radius: .5rem;
    cursor: pointer;
}

.accordion-body{
    background-color: rgba(193, 41, 46, 0.1);;
}

.accordion-body>br{
    display: block;
    margin-bottom: 0.5rem;
    content: " ";
}
/* Accordion styles / End */

/* Form styles */
.form-group>label{
    background-color: #A1A6B1;
    border: 1px solid #14213D;
    color: white;
    font-weight: bold;
    padding: 0.125rem 0.5rem;
    font-size: 0.9em;
    border-radius: 0.375rem;
}

.form-control{
    display:inline-block;
    max-width:15rem;
    color: #14213D !important;
    border: 1px solid #14213D;
    border-radius: 0.375rem;
    padding: 1.25rem 0.5rem;
}

input:focus{
    outline: none !important;
    box-shadow: 0 0 .2rem 0 #14213D !important;
}
/* Form styles / End */

/* Swal popup styles */
.swal2-popup{
    border-radius: 0.75rem !important; /* Overwrite standard border-radius for SWAL */
    padding-left: 0 !important; /* Overwrite standard padding for SWAL */
    padding-right: 0 !important; /* Overwrite standard padding for SWAL */
}

.swal2-styled.swal2-confirm{
    border-radius: 0.5rem !important; /* Overwrite standard border-radius for SWAL button */
}

.swal-buttons{
    /* box-shadow: 0 0.25rem 0.5rem 0 rgba(20,33,61,0.1); */
    border-radius: 0.5rem;
    border: 1px solid #14213D;
}
  
.btn.swal-option{
    background-color: white;
    border-radius: 0.5rem; /* Overwrite Bootstrap default */ 
}
  
input[type=text]:focus{
    outline-width: 0;
}

.swal-option{
    color: #D0D3D8;
}
  
.swal-option.active{
    background-color: #434D64;
    color: white;
}
  
.btn.focus{
    box-shadow: none !important;
}
  
/* Swal popup styles / End */


/* Get button - Whatsapp style */
div[id^=gb-widget]>div:nth-child(2){display:none;}   /* To hide the "Get button" button at the bottom */
/* Get button - Whatsapp style / End */