
/* #region - Variables, Defaults & Center methods */
:root{
    /* #region KRG Colours */
    --background: rgba(0, 214, 170, .85);
    --gradient: linear-gradient(70deg , #6d6b6b, #03b7ec);
    --reversegradient: linear-gradient(70deg , #03b7ec, #6d6b6b);
    --KRGBlue: #03b7ec;
    --shadowgradient: linear-gradient(65deg , #143051, #03b7ec);
    --KRGLight: #e8e9e9;
    --KRGDark: #15194B;
    --KRGWhite: white;
    --shadow:#9ca4b3;
    --plain:#eee;
    --Transparent: color: rgba(255, 255, 255, .4);
    --PaleWhite: color: rgba(255, 255, 255, .8);
    /* #endregion KRG Colours */

    /* #region KRG Fonts */
    --krg-font-family:"DM Sans", sans-serif;
    --krg-font-size-small : calc(6px + 0.5vw);
    --krg-font-size : calc(8px + 1vw);
    --krg-font-size-plus : calc(10px + 1vw);
    --krg-font-size-h1: 3rem;
    --krg-font-size-h2: 2rem;
    --krg-font-size-h1-mobile: 2.5rem;
    --krg-font-size-h2-mobile: 1rem;
    --krg-fontweight-normal: 500;
    --krg-fontweight-mid:700;
    --krg-fontweight-bold:900;
    --krg-header-chevron-mobile-width:3rem;
    --krg-headers-fontsize-mobile:2rem;
    --krg-headers-fontweight-mobile:900;
    --krg-headers-padding-mobile:0.5rem;
    --krg-left-indent: 2rem;
    --krg-left-indent-mobile: 2rem;
    --krg-max-width:1400px;
    /* #endregion KRG Fonts */
}

/* #region Defaults */

*{
    font-family: var(--krg-font-family);
    font-optical-sizing: auto;
    margin: 0; padding: 0;
    box-sizing: border-box;
    text-decoration: none;
    outline: none;
}


html{
    overflow-x: hidden;

}

body{
    background: var(--KRGWhite);
    margin: 0;
}

html, body{
    width: 100%;
    height: 100%;
    margin: 0px;
    padding: 0px;
    overflow-x: hidden;
    scroll-behavior:smooth;
    scroll-padding-top: var(--scroll-padding, 50px);
}

h1{
    font-size: var(--krg-font-size-h1);
    font-weight: var(--krg-fontweight-bold);
    color: var(--KRGDark);
    padding-left: 1rem;
}

h2{
    font-size: var(--krg-font-size-h2);
    font-weight:var(--krg-fontweight-bold);
    color: var(--KRGDark);
}

p{
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
    color: var(--KRGDark);
    padding: 1rem 0;
}

.button {
    border: none;
    color: var(--KRGBlue);
    padding: 10px 32px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: calc(8px + 1vw);
    margin: 3px 2px;
    cursor: pointer;
    border-radius: 7px;
    height: fit-content;
    width: fit-content;
    padding: 0.7rem;
    margin-top: 5px;
}
  
.button:hover{
    background: var(--KRGDark);
    border: none;
    color: white;
    padding: 10px 32px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: 1.6vw;
    margin: 3px 2px;
    cursor: pointer;
    border-radius: 7px;
    height: fit-content;
    width: fit-content;
    padding: 1rem;
    margin-top: 5px;
}

.button-trans {
    border-radius: 10px;
    color: var(--KRGWhite);
    background: var(--KRGDark);
    display: inline-block;
    font-size: var(--krg-font-size);
    width: fit-content;
    align-items: center;
    font-weight: var(--krg-fontweight-normal);
    padding: 0.1rem;

}

.button-trans:hover {
    border-radius: 12px;
    color: var(--KRGWhite);
    background: var(--KRGBlue);
    display: inline-block;
    font-size: var(--krg-font-size);
    width: fit-content;
    align-items: center;
    font-weight: var(--krg-fontweight-normal);
    padding: 0.1rem;
    opacity: 0.6;
}


.header-background{
    display: flex;
}
.header-icon{
    padding-left: 3rem;
    height: 5rem;
}

.key-words{
    font-size: var(--krg-font-size);
    font-weight: bold;
    font-weight: 700;
    color: var(--KRGDark);
}

/* #endregion Defaults */

/* #region Modal Control */

.modal-sector-part{
    height: 70%;
    width: 70vw;
    margin: auto;
    border-radius: 10px;
    overflow: hidden;
}

.modal-sector-container{
    position: relative;
    height: 100%;
    width: 100%;
}

.modal-sector-container .modal-sector-content{
    position: absolute;
    top: 0;
    left: 0;
    width:100%;
    height:100%;
    padding-top: 3rem;
}

.modal-sector-container img{
    width:100%;
    height: 100%;
}

.modal-sector-container .modal-sector-content .modal-sector-header{
    padding-top: 1rem;
    padding-left: 6%;
}

.modal-sector-container .modal-sector-content .modal-sector-textbox{
    width: 90%;
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
    padding-left: 12%;
    display: flex;
    align-items: center;
    justify-content: center;

}

.modal-sector-container .modal-sector-content .modal-sector-list{
    padding-left: 16%;
    font-size: var(--krg-font-size-small);
    font-weight: var(--krg-fontweight-normal);
}

.modal-sector-container .modal-sector-content .modal-sector-list ul{
    padding-left: 2rem;
}

.modal-sector-container .modal-sector-content .modal-sector-list li,h2{
    color: white;
    padding-right: 10px;
}

.modal-sector-container .modal-sector-content .modal-sector-list li{
    font-size: var(--krg-font-size-small);
}

.modal-sector-container .modal-sector-content .modal-sector-list h2{
    font-size: var(--krg-font-size-h2);
}

.modal-sector-container .modal-sector-content .modal-sector-textbox p{
    color: white;
}

.modal-sector-container .modal-sector-content .modal-sector-header h1{
    font-size: var(--krg-font-size-h1);
    font-weight: var(--krg-fontweight-bold);
    color: white;
}



.modal-service-part{
     height: fit-content;
     width: fit-content;
     margin: auto;
     border-radius: 10px;
     overflow: hidden;
 }

 .modal-service-image img{
   width:100%;
   height: 105%;
 }

 .modal-close-button{
    display: flex;
    margin: auto;
    align-items: center;
    justify-content: center;
    padding-bottom: 0.5rem;
 }

/* #endregion Modal Control */

/* #endregion - Variables, Defaults & Center methods  */

/* #region - Header & Navbar */

header{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: fixed;
    top: 0; left: 0;
    background: var(--KRGWhite);
    z-index: 1000;
    padding: 2rem 7%;
    height: 50px;
}

header .logo{
    width:80px;
}

header .navbar ul{
    display: flex;
    align-items: left; 
    justify-content: center;
    list-style:none;
}

header .navbar ul li a{                                                                                                                                  
    margin-left: 2rem;
    color: var(--KRGBlue);
    position: relative;
    font-weight: 700;
    font-style: normal;
    font-size: var(--krg-font-size);
}

header .navbar1 ul li{
    width: 100%;
    text-align: center;                                                                                                                                                                                                                                                                                                                                                                                                        
    list-style-type: none;
}

header .navbar1 ul li a{
    display: block;
    background: var(--KRGWhite);
    color: var(--KRGBlue);
    margin: 0rem 0;
    padding: 0rem;
    font-size: 1.5rem;
    z-index: 0;
    list-style-type: none;
    font-weight: 700;
    font-style: normal;
    font-size: var(--krg-font-size);
  }

header .navbar ul li a::before{
    content: '';
    position: absolute;
    bottom:-.5rem; right: 0;
    height:.2rem;
    width:0%;
    background: var(--KRGBlue);
    transition: .2s linear;
}

header .navbar ul li a:hover::before{
    left: 0;
    width: 100%;
}

header #menu{
    font-size: 3rem;
    color: var(--KRGBlue);
    cursor: pointer;
    visibility: hidden;
}

header .navbar.brochure {
    color: var(--KRGDark);
    background-color: #143051;
} 
/* #endregion - Header & Navbar */

/* #region - Landing */
.landing{
    position: relative;
    min-height:100svh;
    padding-top: 100px;  
    background-color: white;
    background-image: url("../assets/images/main/landing1.png");
    background-blend-mode:multiply;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: right;
}

.landing-container{
    height: 100%;
}

.landing-statement-wrapper{
    padding-top: 4rem;
    padding-left: 5rem;
    padding-bottom: 2rem;
    text-align:  left;
}
.landing-statement-wrapper img{
    max-width:35%;   
    min-width: 200px;
}

.landing-statement-wrapper h1{
    font-size: var(--krg-font-size-h2);
    font-weight: var(--krg-fontweight-bold);
    text-shadow: 2px 2px 2px gray;
    color: var(--KRGDark);
    padding-left: 1rem;
}

.back{
    background-color: white;
    padding: 1rem;
    width:fit-content;
    border-radius: 10px;
}

/* #region - Carousel */
.carousel{
    min-height: 30vh; 
    display: grid;
    place-items: center;
    padding-top: 2rem;
}

.slider{
    position: relative;
    min-height: 250px;
    margin: auto;
    width: 100%;
    display: grid;
    place-items: center;
    overflow: hidden;
}

.slide-track{
    display: flex;
    width: calc(250px * 18);
    animation: scroll 40s linear infinite;
}

    @keyframes scroll{
        0%{
        transform: translateX(0);
        }
        100%{
        transform: translate(calc(-250px * 9));
        }
    }

    .slide{
        display: flex;
        align-items: center;
        padding: 15px;
    }


/* GRADIENT SHADOWS */
.slider::before,
.slider::after{
    background: linear-gradient(to right, rgba(255, 255,255,1) 35%,
    rgba(255,255,255,0) 100%);
    content: '';
    height: 80%;
    position: absolute;
    width:15%;
    z-index:2;
}
.slider::before{
    left: -90px;
    top: 25px;
}
.slider::after{
    right: -160px;
    top: 25px;
    transform: rotateZ(180deg);
}

/* #endregion - Carousel */

.landing .landing-images{
    visibility: hidden;
    display: flex;
    align-items: center;
    justify-content:center;
    flex-wrap: wrap;
    position: absolute;
    top: 60vh;
}
.landing .landing-images img{
    border-radius: 10px;
    max-width: 200px;
    min-width:60px;
}

/* #endregion-Landing */

/* #region - about */
.about{
    min-height:100svh; 
 }

 .about .about-wrapper{
    max-width: var(--krg-max-width);
    margin: auto;
 }

 .about .about-group{
    display:grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
 }

 .about  .group-card{
    padding: 3rem; 
    min-width: 450px;
  }

  .about .about-wrapper .group-card-vid {
    display: grid;
    justify-content: center;
    align-items: center;
  }

 .about .about-wrapper .group-card-vid video{
    padding: 10px;
    max-width: 640px;
 }

 /* #endregion - about */

/* #region - Banners */

/* #region Banner 1*/
.banner1{
    min-height:100svh;
    padding-top: 200px;
    background-image: url(../assets/images/sections/banner1-small.jpg);
    background-size:cover;
    background-repeat: no-repeat;  
    background-attachment: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
}

.banner1 .statement{
    width: 60%;
    padding-bottom: 10rem;
}

.banner1 .statement p{
    color: white;
    font-size: var(--krg-font-size-h2);
    font-weight: var(--krg-fontweight-bold);
}
/* #endregion Banner 1*/

/* #region Banner 2 */
.banner2{
    min-height:fit-content;
}

.banner-video-wrapper{
    max-width: var(--krg-max-width);
    margin: auto;
    padding: 3rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

.banner-video-wrapper video{
    max-width: 100%;
}

/* #endregion Banner 2*/

/* #region Banner 3 Hero slider */
.hero{
    height: fit-content;
    overflow: hidden;
 }
.hero .slider-header{
    display: flex;
    align-items: center;
    justify-content: center;
    height:80%;
    width: 100%;
    opacity: 0.7;
    margin: auto;
 }
 #slideImg{
    height: 100%;
    width:100%;
  }

  .sliderA{
    width:100%;
    animation: zoom-out 14.5s linear infinite;

  }

  @keyframes zoom-out{
    100%{
        transform: scale(1.0);
    }
    50%{
        transform: scale(1.1);
    }
    0%{
        transform: scale(1.2);
    }

  }

/* #endregion Banner 3 Hero slider */


/* #endregion - Banners */

/* #region - Sectors */

.sectors{
    min-height:100svh;
    background-color:var(--plain);  
 }

.sectors .sectors-wrapper{
    max-width: var(--krg-max-width);
    margin: auto;
}

.sectors .sectors-wrapper .sectors-text{
    display:grid;
    padding-left: 3rem;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
}

.sectors .sectors-wrapper .sectors-text .sectors-card{
    padding: 1rem;
    min-width: 350px;
    padding-right: 3rem;

}

.sectors .sectors-wrapper .sectors-text .sectors-card h2{
    font-size: var(--krg-font-size-h2);
    font-weight: var(--krg-fontweight-bold);
    color: var(--KRGDark);
}

/* #region - Carousel */
.carousel2{
    min-height: 30vh;
    display: grid;
    place-items: center;
}

.slider2{
    height: 300px;
    margin: auto;
    position: relative;
 
    width: 100%;
    display: grid;
    place-items: center;
    overflow: hidden;
}

.slide-track2{
    display: flex;
    width: calc(250px * 18);
    animation: scroll 40s linear infinite;
}



    @keyframes scroll{
        0%{
        transform: translateX(0);
        }
        100%{
        transform: translate(calc(-250px * 9));
        }
    }

    .slide2{
        display: flex;
        align-items: center;
        padding: 15px;
    }


/* GRADIENT SHADOWS */
.slider2::before,
.slider2::after{
    background: linear-gradient(to right, rgba(255, 255,255,1) 35%,
    rgba(255,255,255,0) 100%);
    content: '';
    height: 100%;
    position: absolute;
    width:15%;
    z-index:2;
}
.slider2::before{
    left: -90px;
    top: -50px;
}
.slider2::after{
    right: -110px;
    top: -50px;
    transform: rotateZ(180deg);
}

/* #endregion - Carousel */



/* #endregion - Sectors */

/* #region - Services */
.services{
    min-height: 100svh;
    background-color:var(--plain);  
}

.services .service-wrapper{
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    padding: 3rem;
}

.services .service-wrapper .services-text {
    width: 300px;
}
.services .service-wrapper .service-text p{
    font-size: var(--krg-font-size);
    font-family: var(--krg-font-family);
}

.services .service-wrapper >div p:hover{
    color: var(--KRGBlue);
}


.notify{
    background: url(../assets/images/services/arrows.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
  }

.add-size{
    padding: 1rem;
    max-height: 500px;
    min-width: 300px;
    height: 70vh;
    width: 55%;
    display: flex;
    justify-content: center;
    align-items: center;
}

  .sd-1-desc{
    background: url(../assets/images/services/precision.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }
  .sd-2-desc{
    background: url(../assets/images/services/special.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }
  .sd-3-desc{
    background: url(../assets/images/services/nodestruct.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }

  .sd-4-desc{
    background: url(../assets/images/services/welding.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }

  .sd-5-desc{
    background: url(../assets/images/services/cmm.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }

  .sd-6-desc{
    background: url(../assets/images/services/surface.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }

  .sd-7-desc{
    background: url(../assets/images/services/testing.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }

  .sd-8-desc{
    background: url(../assets/images/services/refurbish.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:center;
    margin-left: 1rem;
  }
/* #endregion - services */

/* #region - LinkedIn */
.linkedin{
    min-height: 100svh;
    background: var(--plain);
}

.linkedin-wrapper{
    max-width: var(--krg-max-width);
    margin: auto;
    padding: 3rem;
    display: flex;
    justify-content: center;
    align-items: center;
}


.linkedpage {
    display: block;
    font-size: var(--krg-font-size);
    font-weight: 500;
    margin: auto;
    height: 100%;
}

.linkedpage-mobile {
    display:none;
    font-size: var(--krg-font-size);
    font-weight: 500;
    margin: auto;
} 

.linkedin .header{
    width: 100%;
    margin:auto;
}

.linkedin .logo{
    max-width: 30%;
    height: auto;
} 
 /* #endregion - LinkedIn */

/* #region - Contact */
.contact{
    min-height: 5svh;
    background:var(--KRGWhite);
    background-image: url(../assets/images/contact/graphic-chevron.png);
    background-size: 20vh;
    background-repeat: no-repeat;
    background-position: right;  
    margin-right: 200px; 
}

.contact .contact-statement-wrapper{
    width: 800px;
    padding-left: 0rem;
    text-align:  left;
}

.contact .contact-statement-wrapper img{
    max-width:15%;   
    min-width: 100px;
    padding-top: 2rem;
    padding-bottom: 10px;
    padding-left: 2rem;
}

.contact .contact-statement-wrapper h1{
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-bold);
    color: var(--KRGDark);
    padding-left: 5rem;
}

.contact .contact-wrapper{
    width: 800px;
    padding-left: 2rem;
}

.contact .contact-wrapper .contact-address{
    min-width:350px;
    padding-left: 4rem;
}

.contact .contact-wrapper .contact-address h3{
    font-size: var(--krg-font-size);
}


.contact-wrapper .contact-address address{
    color: var(--KRGDark); 
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
    font-style: normal;
}

.contact .contact-wrapper .contact-address p{
    color: var(--KRGDark); 
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
    font-style: normal;
}

.contact .contact-wrapper .contact-address .icons i{
    font-size: var(--krg-font-size);
    color: var(--KRGBlue);
    padding-right: 1rem;
} 

.contact .contact-wrapper .contact-address .number{
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
}

/* #endregion - Contact */

/* #region - Footer */
.footer{
    text-align: center;
}

.footer .share h3{
    color: var(--KRGBlue);
    font-size: var(--krg-font-size-h1);
    padding-top: 1rem;
    padding-bottom: 2rem;
}

.footer .share img{
    height: 50px;
}

.footer .credit{
    padding: 2rem 1rem;
    color: var(--KRGBlue);
    font-weight: var(--krg-fontweight-normal);
    background: var(--gradient);
    text-align: center;
    font-size: 1rem;
}


.footer .credit a{
    color: var(--KRGDark);
    font-weight: var(--krg-fontweight-normal);
    font-size: 1rem;
}

.conditionofsale{
    display: flex;
    align-items: center;
    justify-content:space-around;
    padding-top: 1rem;
    padding-bottom: 1rem;
    max-width: 800px;
    margin: auto;
}

.conditionofsale .doc a{
    font-size: calc(4px + 0.6vw);
    color: var(--KRGBlue);
}

.conditionofsale .doc a:hover{
    font-size: calc(4px + 0.6vw);
    color:var(--KRGDark);
}

.conditionofsale .doc a > img{
    color: var(--KRGBlue);
}

.conditionofsale .doc a > img:hover{
    color: var(--KRGDark);
}
/* #endregion - Footer */

/* #region - Sitemap */
.sitemap{
    min-height: 300px;
    background-image: url(../assets/images/sections/banner1-small.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    padding:30px;
    margin: auto;
}

.sitemap h1{
    color: white;
}
.sitemap h3{
    font-size: var(--krg-font-size-h2);
    font-weight: var(--krg-fontweight-bold);  
    color: white;
    text-decoration: none;
    text-align: left;
}

.sitemap-wrapper{
    max-width: 80vw;
    margin: auto;
}

.sitemap-text{
    display:grid;
    justify-content:space-between;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    align-items: left;
    margin: auto;
}

.sitemap .sitemap-wrapper .sitemap-text .sm1{
   padding-left: 2rem;
   max-width: 650px;
}
.sitemap .sitemap-wrapper .sitemap-text .sm1 ul{
    list-style: none;
    text-align: left;
    padding-top: 1rem;
    padding-bottom: 2rem;
}

.sitemap .sitemap-wrapper .sitemap-text .sm1 ul li a{
    color: white;
    text-align: left;
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
}


.sitemap .sitemap-wrapper .sitemap-text .sm2{
    padding-left: 2rem;
    max-width: 650px;
 }
 .sitemap .sitemap-wrapper .sitemap-text .sm2 ul{
     list-style: none;
     text-align: left;
     padding-top: 1rem;
 }
 
 .sitemap .sitemap-wrapper .sitemap-text .sm2 ul li a{
     color: white;
     text-align: left;
     font-size: var(--krg-font-size);
     font-weight: var(--krg-fontweight-normal);
 }

 .sitemap .sitemap-wrapper .sitemap-text .sm3{
    padding: 2rem;
    max-width: 650px;
    margin-bottom: 3rem;
 }

 .sitemap .sitemap-wrapper .sitemap-text .sm3 h3{
    font-size: var(--krg-font-size);
    font-weight: var(--krg-fontweight-normal);
 }

 .sitemap .sitemap-wrapper .sitemap-text .sm3 ul{
     list-style: none;
     text-align: left;
     padding-top: 1rem;
 }
 
 .sitemap .sitemap-wrapper .sitemap-text .sm3 ul li{
     color: white;
     text-align: left;
     font-size: var(--krg-font-size);
     font-weight: var(--krg-fontweight-normal);
 }

/*#endregion - Sitemap*/

/* #region Not Used on Index.html */
/* Used on plantlist.html and brochure.html Only*/
    .frame{
        height: 100svh;
    }

    /* Used on Service.html only */
    .service-image{
        height: auto;
        cursor: grab;
    }
/* #endregion Not Used on Index.html */






