@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.0/font/bootstrap-icons.css");
* { 
    margin: 0px;
    font-family: Verdana;
}
@font-face {
    font-family: "ComicSans";
    src: url('./assets/fonts/ldfcomicsans-font/Ldfcomicsanslight-6dZo.ttf');
}
header { 
    height: 80px;
    width: 100%;
    background: rgb(166, 248, 255);
}
header .logo { 
    float: left;  
    width: 20%;
    height: 100%;
}
header .details { 
    float: right;
    width: 20%; 
    padding-top: 20px; 
    height: 60px;
    text-align: center;
}
header .details a { 
    text-decoration: none; 
    color: rgb(7, 7, 7);
}
header .details a:hover { 
    color: rgb(0, 136, 160);
}
header .details .details-full {
    display: block;
}
header .details .details-full a {
    font-size: 20px;
}
header .details .details-icon { 
    display: none;
}
nav ul {
    padding: 15px;
    text-align: center;
}
nav li { 
    display: inline-block;
}
nav li a {
    text-decoration: none;
    color: black;
    padding: 20px 20px;
} 
nav ul li a:hover {
    background-color: rgb(36, 222, 255);
}
/*-Segments-*/
.info-container {
    height: 875px;
    background: #d3eef7;
    position: relative;
}
.info {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
/*-Segments-*/
.services { 
    height: 1200px; 
    width: 80%; 
    padding: 50px 10% 50px 10%;
    background-color: rgba(3,64,119,255);
}
.service-container { 
    height: 170px; 
    width: 45%;  
    padding: 15px 2% 15px 2%; 
    background-color: rgb(246, 255, 166); 
    /* border: solid; */
    margin-bottom: 20px;
}
.service-container:hover { 
    box-shadow: 0px 5px 15px rgb(255, 255, 255);
}
.service-img { 
    float: left;
    height: 100%;  
    width: 30%; 
}
.service-description { 
    float: right;
    height: 100%;
    width: 65%;
    padding-left: 5%;
}
.heading {
    height: 30%;
    background-color: rgb(166, 248, 255);
}
.summary { 
    height: 70%;   
    background-color: beige;
} 
.heading #text { 
    text-align: center; 
    position: relative; 
    top: 25%;  
    /**/
    font-size: 18px;
} 
.summary #text {  
    text-align: center; 
    position: relative; 
    top: 10%;
    /**/
    font-size: 15px;
    /**/
    padding-left: 3px; 
    padding-right: 3px;
}
/*-Segments-*/
.portfolio {
    max-height: 1100px; 
    width: 80%; 
    padding: 50px 10% 50px 10%;
    background-color: rgba(3,64,119,255);
}
.portfolio .filter {
    width: 80%; 
    padding: 0px 10% 0px 10%; 
    background-color: rgb(166, 248, 255); 
    text-align: center; 
} 
.portfolio .filter br { 
    display: none;
}
.portfolio .filter .filter-item {
    display: inline-block;
    color: #333;
    font-size: 20px; 
    margin: 30px;
    cursor: pointer;
    transition: all .3s ease;
}
.portfolio .filter .filter-item.active { 
    color: black; 
    border-bottom: 2.5px solid;
}
.portfolio .grid { 
    max-height: 800px; 
    width: 80%; 
    padding: 50px 10% 50px 10%; 
    background-color: rgb(246, 255, 166);
} 
.portfolio .grid .content-box { 
    height: 300px; 
    width: 26.66%;
    padding: 50px 3% 50px 3%;
    display: inline-block;
}
.portfolio .grid .content-box.show { 
    animation: fadeIn .5s ease; 
}   
@keyframes fadeIn { 
    0% { opacity: 0; } 
    100% { opacity: 100; }
}
.portfolio .grid .content-box.hide { 
    display: none;
}
.portfolio .grid .content-box .img-container { 
    height: 100%; 
    width: 100%;
}
.portfolio .grid .content-box .img-container:hover {
    box-shadow: 0px 5px 15px rgb(61, 61, 57);
}
/*-Segments-*/
.customers { 
    height: 400px; 
    width: 80%; 
    padding: 50px 10% 50px 10%;
    background-color: rgba(3,64,119,255); 
}
.carousel { 
    height: 300px; 
    width: 100%; 
    position: relative;
    overflow: hidden;
}
.slider { 
    height: 300px;  
    width: 400%;
    background-color: beige; 
    display: flex; 
    transition: 0.3s;
}
.slider section { 
    flex-basis: 100%;  
    display: flex; 
    justify-content: center; 
    align-items: center;
    /**/  
    font-family: "ComicSans";
    font-size: 30px;
}
.controls .arrow { 
    position: absolute; 
    top: 50%;  
    transform: translateY(-50%);
    cursor: pointer; 
    font-size: 50px;
}
.arrow.left { 
    left: 10px;
}
.arrow.right { 
    right: 10px;
}
.controls ul {  
    position: absolute; 
    bottom: 20px;
    left: 50%; 
    transform: translate(-50%); 
    display: flex;
    margin: 0; 
    padding: 0; 
    list-style: none; 
}
.controls ul li { 
    height: 14px; 
    width: 14px; 
    border: 2px solid #333; 
    border-radius: 50px;
    margin: 10px; 
    cursor: pointer; 
    background-color: #333;
}
.controls ul li.selected { 
    background-color: transparent;
}
/*-Segments-*/
.faq { 
    min-height: 300px; 
    width: 80%; 
    padding: 50px 10% 50px 10%;
    background-color: rgba(3,64,119,255); 
}
.faq .accordion-box {
    margin-bottom: 20px; 
}
.accordion-box .faq-label { 
    padding: 10px;
    background-color: rgb(166, 248, 255);   
    cursor: pointer; 
    position: relative; 
    /**/ 
    font-family: "ComicSans"; 
    font-size: 20px;
}
.accordion-box .faq-label::before {  
    content: "+";  
    position: absolute;
    right: 20px;
    top: 50%; 
    transform: translateY(-50%); 
    font-size: 20px;
}
.accordion-box.active .faq-label::before { 
    content: "-";
}
.accordion-box .faq-content { 
    height: 0; 
    background-color: beige;
    overflow: hidden; 
    transition: 0.3s;  
    /**/ 
    font-family: "ComicSans"; 
    font-size: 19px;
}
.accordion-box.active .faq-content { 
    height: 100px;
    padding: 10px;  
}
/*-Segments-*/
.contact {
    height: 1150px; 
    width: 80%; 
    padding: 50px 10% 50px 10%;
    background-color: rgba(3,64,119,255);
}
.contact-details { 
    height: 200px; 
    width: 90%; 
    padding: 35px 5% 15px 5%;
    background-color: rgb(246, 255, 166);
}
.contact-details .mail, .contact-details .phone, .contact-details .address {
    width: 29.33%; 
    padding: 0px 2% 0px 2%;
    float: left;
    text-align: center;
}
.contact-details .mail i, .contact-details .phone i, .contact-details .address i { 
    margin-bottom: 50px; 
    font-size: 50px; 
}
.contact-details .mail p, .contact-details .phone p, .contact-details .address p { 
    font-size: 15px; 
}
.contact-map {
    height: 800px; 
    width: 48%;  
    padding: 25px 0% 25px 2%;
    float: right; 
    background-color: rgba(3,64,119,255);
}
.contact-form { 
    height: 800px; 
    width: 48%;  
    padding: 25px 2% 25px 0%; 
    float: left;
    background-color: rgba(3,64,119,255);
} 
.contact-form .form-container { 
    height: 750px; 
    width: 90%;
    padding: 25px 5% 25px 5%; 
    color: #333;
    background-color: beige; 
    font-size: 20px;
}
.form-container .inputBox {
    display: flex; 
    flex-direction: column; 
    margin-bottom: 20px;
    position: relative;
}
.form-container .inputBox input { 
    height: 50px; 
    font-size: 17.5px; 
    border: 2.5px solid rgb(177, 177, 177);
} 
.form-container .inputBox input[type="submit"] { 
    background-color: rgb(246, 255, 166); 
    border: solid rgb(246, 240, 145); 
    cursor: pointer; 
}
.form-container .inputBox input[type="submit"]:hover { 
    box-shadow: 0px 5px 15px rgb(98, 98, 94);
} 
.form-container .inputBox textarea { 
    resize: none; 
    font-size: 17.5px;
    border: 2.5px solid rgb(177, 177, 177); 
}
.form-container .inputBox i { 
    position: absolute; 
    top: 41px; 
    right: 13px; 
    visibility: hidden;
}
.form-container .inputBox small {
    visibility: hidden;
}
.form-container .inputBox.success input, .inputBox.success textarea { 
    border-color: rgb(151, 243, 159);
}
.form-container .inputBox.success i.bi-check-circle-fill { 
    visibility: visible; 
    color: rgb(79, 184, 87);
}
.form-container .inputBox.error input, .inputBox.error textarea { 
    border-color: rgb(243, 132, 112);
}
.form-container .inputBox.error i.bi-exclamation-circle-fill { 
    visibility: visible; 
    color: rgb(194, 64, 41);
}
.form-container .inputBox.error small {
    visibility: visible;
    color: rgb(194, 64, 41);
}
/*-Segments-*/
.water-waves {
    position: relative; /*edited*/
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg); 
    background-color: rgb(41, 36, 36); /*edited*/
}
.water-waves svg {
    display: block;
    width: calc(110% + 1.3px);
    height: 178px;
}
.water-waves .shape-fill {
    fill: rgba(3,64,119,255); /*edited*/
}
/*-Segments-*/
footer { 
    height: 100px;  
    width: 80%;
    padding: 40px 10% 50px 10%;
    background-color: rgb(41, 36, 36);
    text-align: center;
    position: relative;
}
/*
footer ul { 
    padding: 20px; 
}
footer li { 
    display: inline-block;  
    list-style: none;
}
footer li a { 
    display: inline-block;  
    color: beige; 
    font-size: 30px;   
    margin: 10px; 
    transition: 0.3s;
} 
footer li a:hover { 
    color: rgb(246, 255, 166);
    transform: translateY(-10px);
}
*/
footer .copywrite {  
    padding: 2px;
    color: rgba(245, 245, 245, 0.815);
}
footer .scrollUp { 
    position: absolute;
    top: 70%; 
    left: 95%;
}
footer .scrollUp a { 
    display: inline-block; 
    color: beige; 
    font-size: 30px; 
    transition: 0.3s;
} 
footer .scrollUp a:hover { 
    color: rgb(246, 255, 166); 
    transform: rotate(360deg);
}

/*---------*/ 
.bars { 
    display: none; 
    position: relative; 
    height: 2px; 
    width: 20px;
    background: grey;
}
.bars::before, .bars::after { 
    content: "";
    display: flex; 
    position: absolute; 
    height: 2px; 
    width: 35px;
    background: grey; 
    /* Initial Sizes: 2px 18px */
} 
.bars::before { top: 8px; /* Initial Size: 5px */ }
.bars::after { top: -8px; }
/*---------*/

/* Media Queries - Responsive Web Design */
/* HEADER LOGO - Desktop View */
@media (max-width: 2700px) {
    header .logo .img-container { 
        height: 100%; 
        width: 20%;
    }
}
/* HEADER LOGO - Tablet View */
@media (max-width: 1740px) { 
    header .logo .img-container { 
        height: 100%; 
        width: 35%;
    }
}
/* HEADER LOGO - Large_Screen_Mobile View */
@media (max-width: 1000px) {
    header .logo .img-container { 
        height: 100%; 
        width: 50%;
    }
}
/* HEADER LOGO - Small_Screen_Mobile View */
@media (max-width: 650px) {
    header .logo .img-container { 
        height: 100%; 
        width: 100%;
    }
}
/* HEADER NAVBAR - Tablet View | Mobile View */  
@media (max-width: 1030px) {
    nav .hamburger {
        padding: 20px; 
        display: flex; 
        justify-content: center;
    }
    nav .hamburger .bars { 
        display: flex;
    }
    nav ul li { 
        display: none; 
        justify-content: center;
    }
    nav ul li a {
        width: 100%;
        background: rgb(246, 255, 166);
        z-index: 2;
    }
}
/* HEADER DETAILS - Large/Small_Screen_Mobile View */
@media (max-width: 650px) {
    header .details .details-full {
        display: none;
    } 
    header .details .details-icon { 
        display: block; 
        color: rgb(92, 92, 92); 
        font-size: 30px; 
        cursor: pointer; 
        transition: .3s;
    }
    header .details .details-icon:hover {
        transform: translateY(-10px);
    }
}
/* INFO - Tablet View */
@media (max-width: 1200px) { 
    .info-container {
        height: 775px;
        background: #d3eef7;
        position: relative;
    }
    .info {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}
@media (max-width: 950px) { 
    .info-container {
        height: 675px;
        background: #d3eef7;
        position: relative;
    }
    .info {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}
@media (max-width: 750px) { 
    .info-container {
        height: 500px;
        background: #d3eef7;
        position: relative;
    }
    .info {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}
/* INFO - Mobile View */ 
@media (max-width: 550px) { 
    .info-container {
        height: 575px;
        width: 100%;
        background: #d3eef7;
    }
    .info {
        height: 100%;
        width: 80%;
    }
}
/* SERVICES - Tablet View */ 
@media (max-width: 1150px) {
    .services { 
        height: 2600px;
    }
    .service-container { 
        float: none !important;
        width: 95%; 
        padding: 30px 2.5% 30px 2.5%;   
    }
}
/* SERVICES - Mobile View */
@media (max-width: 500px) { 
    .services { 
        height: 4300px;
    }
    .service-container {
        height: 340px;
        width: 85%; 
        padding: 30px 7.5% 30px 7.5%;   
    }
    .service-img {
        height: 50%;  
        width: 100%;
    }
    .service-description {
        height: 50%;
        width: 100%;
    }
    .heading #text {
        font-size: 17px;
    } 
    .summary #text {
        font-size: 16px;
        /**/
        padding-left: 2.5px; 
        padding-right: 2.5px;
    }
}
/* PORTFOLIO - Tablet View */ 
@media (max-width: 1400px) {
    .portfolio { 
        max-height: 1500px;
    }
    .portfolio .grid { 
        max-height: 1200px;
    }
    .portfolio .grid .content-box { 
        height: 300px; 
        width: 40%;
        padding: 50px 4.30% 50px 4.30%;
    }
}
/* PORTFOLIO - Small_Screen_Tablet View */ 
@media (max-width: 820px) {  
    .portfolio .filter .filter-item {  
        margin: 18px;
    }
}
/* PORTFOLIO - Mobile View */ 
@media (max-width: 700px) {
    .portfolio { 
        max-height: 3300px;
    }
    .portfolio .filter br { 
        display: block;
    }
    .portfolio .grid { 
        max-height: 2700px;
    } 
    .portfolio .grid .content-box { 
        height: 250px; 
        width: 80%;
        padding: 25px 10% 25px 10%;
    }
}
/* CUSTOMERS - Mobile View */ 
@media (max-width: 600px) {
    .customers { 
        height: 400px; 
    }
    .carousel { 
        height: 250px;
    }
    .slider { 
        height: 250px;
    }
    .slider section {
        font-size: 18.5px;
    }
    .controls .arrow {
        font-size: 20px;
    }
    .controls ul li { 
        height: 11px; 
        width: 11px;
    }
}
/* FAQ - Mobile View */
@media (max-width: 500px) {
    .faq { 
        min-height: 250px; 
    }
    .accordion-box .faq-label { 
        padding: 16.5px;
        font-size: 17.5px;
    }
    .accordion-box .faq-label::before {
        right: 7.5px;
    }
    .accordion-box .faq-content {
        font-size: 17px;
    }
    .accordion-box.active .faq-content { 
        height: 150px;
        padding: 10px;  
    }
}
/* CONTACT - Tablet View */
@media (max-width: 1000px) {
    .contact {
        height: 1900px;
    }
    .contact-details { 
        height: 170px;
    }
    .contact-details .mail i, .contact-details .phone i, .contact-details .address i { 
        font-size: 45px; 
    }
    .contact-details .mail p, .contact-details .phone p, .contact-details .address p { 
        font-size: 14px; 
    }
    .contact-map {
        float: none;
        height: 700px; 
        width: 100%;  
        padding: 50px 0% 50px 0%;     
    }
    .contact-form {
        float: none; 
        height: 750px; 
        width: 100%;
        padding: 50px 0% 50px 0%;   
    }   
}
/* CONTACT - Mobile View */ 
@media (max-width: 750px) {
    .contact {
        height: 1870px; 
    }
    .contact-details { 
        height: 510px;
    }
    .contact-details .mail, .contact-details .phone, .contact-details .address { 
        height: 140px;
        width: 90%; 
        padding: 10px 5% 10px 5%;
    }
    .contact-details .mail i, .contact-details .phone i, .contact-details .address i { 
        font-size: 40px; 
    }
    .contact-details .mail p, .contact-details .phone p, .contact-details .address p { 
        font-size: 16px; 
    }
    .contact-map {
        height: 400px;  
        padding: 30px 0% 30px 0%;   
    }
    .contact-form {
        height: 700px; 
    } 
    .contact-form .form-container { 
        height: 680px;
    }
    .form-container .inputBox input { 
        height: 40px; 
        font-size: 16.5px;
    }
    .form-container .inputBox textarea {
        font-size: 16.5px;
    }
    .form-container .inputBox i {
        top: 40px;  
        font-size: 15px;
    }
}
/* WATER WAVES - Tablet View */ 
@media (max-width: 1024px) { 
    .water-waves svg { 
        height: 130px;
    }
}
/* WATER WAVES - Mobile View */ 
@media (max-width: 700px) {
    .water-waves svg {
        height: 110px;
    }
}
/* FOOTER - Tablet View */ 
@media (max-width: 1024px) {
    footer .scrollUp {
        left: 91%;
    }
}
/* FOOTER - Mobile View */
@media (max-width: 500px) {
    /*
    footer ul { 
        padding: 15px; 
    }
    footer li a { 
        font-size: 25px;
    }
    */
    footer .copywrite {
        font-size: 12px;
    }
    footer .scrollUp {
        top: 80%; 
        left: 85%;
    }
    footer .scrollUp a {
        font-size: 20px; 
    }
}
/* <h1> Element Size - Mobile View */  
@media (max-width: 1000px) {
    h1, h2 { 
        font-size: 25px;
    }
}
/*-----------------------------------------------*/