html { scroll-behavior: smooth; }

body { font-family: Helvetica, Arial, sans-serif; color: var(--ice-white); font-size: 18px; line-height: 1.4; }

h1, h2, h3, h4, h5, h6 { font-family: Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased }
a { color: var(--ice-white); text-decoration: none; transition: all 0.3s; }

/*Generics*/
.content { margin: 0 auto; max-width: 1360px; width: 100%; }
.admin-bar .main-header { top: 32px; }

/*Webkit Scrollbars*/
::-webkit-scrollbar { width: 15px; height: 15px; }  
::-webkit-scrollbar-track { background-color: #888888; }
::-webkit-scrollbar-thumb { background-color: var(--black); border-radius: 20px; transition: all 0.3s; }
::-webkit-scrollbar-thumb:hover { background-color: rgb(46, 46, 46); }  

/*Placeholders*/
::-webkit-input-placeholder { color: #999; }
::-moz-placeholder { color: #999; }
:-ms-input-placeholder { color: #999; }
:-moz-placeholder { color: #999; }

/*Forms*/
input,
select,
textarea { border: 1px solid var(--ice-white); font-family: "Open Sans", sans-serif; resize: none; color: var(--ice-white); background: transparent; border-radius: 20px; padding: 10px 16px; transition: all 0.3s; }

input:focus,
select:focus,
textarea:focus, 
button:focus { outline: none; border: 1px solid var(--light-sky-blue); }

input::placeholder { color: rgba(255, 255, 255, 0.676); }

.wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output { border: none; margin: 20px auto; padding: 0; color: #7c2424; font-size: 14px; }
.wpcf7 form .wpcf7-response-output { border: none; margin: 20px auto; padding: 0; font-size: 16px; margin-top: 0;}
.wpcf7-not-valid-tip { color: #7c2424; font-size: 14px; }

.input-wrapper { display: flex; flex-direction: column; gap: 6px; }
.input-wrapper label { font-weight: 600; }

/*Btn*/
.btn { font-family: Helvetica, Arial, sans-serif; width: fit-content; border: 1px solid var(--ice-white); border-radius: 12px; padding: 8px 16px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s; }
.btn:hover { border: 1px solid var(--light-sky-blue); color: var(--light-sky-blue); background-color: #4c7baa26; }
.btn.login-btn,
.btn.logout-btn { font-size: 14px; font-weight: 500; color: var(--ice-white); text-align: center; letter-spacing: 1px; min-width: 100px; }
.btn.login-btn:hover,
.btn.logout-btn:hover { color: var(--light-sky-blue); }

.btn.blue { padding: 8px 22px; background-color: var(--light-blue); border: 1px solid var(--light-blue); border-radius: 12px; font-size: 14px; }
.btn.blue:hover { background-color: var(--sky-blue-hover); border: 1px solid var(--sky-blue-hover); color: var(--ice-white); }

/*Header*/
.main-header { width: 100%; position: fixed; top: 0; left: 0; height: 84px; background-color: var(--sky-blue); color: var(--ice-white); padding: 20px; display: flex; justify-content: center; z-index: 100; transition: all 0.3s; transition-delay: .1s; }
.main-header.box-shadow { box-shadow: 0 5px 5px 0 rgba(0,0,0,0.25); }
.main-header nav { display: flex; align-items: center; justify-content: space-between; width: 100%; height: 100%; transition: all 0.3s; }
.main-header .logo-header { transition: all 0.3s; margin-right: 30px; padding: 20px 0; }
.main-header .logo-header img { width: 225px; }
.main-header .right-nav { display: flex; align-items: center; gap: 20px; }

.home .main-header,
.overview-page .main-header { background-color: #0F1F4D33;}

.home .main-header.box-shadow,
.overview-page .main-header.box-shadow { background-color: var(--sky-blue) !important; color: var(--ice-white); }

/*Login Header*/
.login-page header .login-btn { display: none; }

.logout-btn { display: none; }
.logout-btn.show { display: block; }

/*Gated Navigation*/
.main-header .gated-navigation { display: none; position: relative; margin-right: auto; }
.main-header .gated-navigation.show { display: block; }

.main-header .gated-navigation .menu { display: flex; align-items: center; gap: 16px; }
.main-header .gated-navigation .menu li a { padding: 20px 0; font-size: 16px; color: var(--ice-white); white-space: nowrap; cursor: pointer; transition: all 0.3s ease;  }
.main-header .gated-navigation .menu li:hover a { color: var(--light-sky-blue); }
.main-header .gated-navigation .menu li a i { font-size: 14px; margin-left: 4px; }
.main-header .gated-navigation .menuIcon,
.main-header .gated-navigation .menuIcon .fa-xmark { display: none; }
.main-header .gated-navigation .menu .current-menu-item * { color: #6ac1ff; font-weight: 600; }

/*Footer*/
.main-footer { width: 100%; padding: 80px 20px; background-color: var(--sky-blue); }
.main-footer .footer-wrapper { display: flex; gap: 30px; }

.main-footer .logos-wrapper { display: flex; flex-direction: column; gap: 20px; }
.main-footer .logos-wrapper .logo-footer img { width: 165px; }
.main-footer .logos-wrapper .by-cuemate { width: 165px; }

.main-footer .contact-wrapper ul { display: flex; flex-direction: column; gap: 10px; font-size: 16px; }
.main-footer .contact-wrapper ul li a:hover { color: var(--sky-blue-hover); }

.main-footer .keep-in-touch { display: flex; flex-direction: column; -webkit-font-smoothing: antialiased; }
.main-footer .keep-in-touch p { font-size: 16px; font-weight: 600; }
.main-footer .keep-in-touch span { font-size: 14px; display: block; margin: 6px 0 10px; font-weight: 300; }
.main-footer .keep-in-touch form { display: flex; flex-direction: column; gap: 12px; max-width: 220px; }
.main-footer .keep-in-touch form .wpcf7-submit { border-radius: 6px; color: var(--ice-white); border: 1px solid var(--ice-white); padding: 6px 16px; cursor: pointer; transition: all 0.3s; }
.main-footer .keep-in-touch form .wpcf7-submit:hover { color: var(--light-sky-blue); border: 1px solid var(--light-sky-blue); }
.main-footer .keep-in-touch form .wpcf7-email { width: 100%; }

.main-footer ul nav .menu { display: flex; gap: 24px; }
.main-footer ul nav .menu li a { text-decoration: underline; white-space: nowrap; font-size: 18px; }
.main-footer ul nav .menu li a:hover { color: var(--light-sky-blue) }

.main-footer .menu .menu-item-has-children .sub-menu { display: flex; flex-direction: column; gap: 8px; max-width: 114px; margin-top: 8px; }
.main-footer .menu .menu-item-has-children .sub-menu li a { font-size: 13px; font-weight: 300; white-space: unset; }

.main-footer .bottom { display: flex; align-items: center; justify-content: center; gap: 100px; padding-top: 100px; }
.main-footer .bottom .copy { font-size: 14px; }
.main-footer .bottom ul { display: flex; align-items: center; gap: 10px; }
.main-footer .bottom ul li a { border: 1px solid var(--ice-white); border-radius: 50%; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; }
.main-footer .bottom ul li a i { font-size: 14px; }
.main-footer .bottom ul li a:hover { color: var(--light-sky-blue); border: 1px solid var(--light-sky-blue) }

    /*Gated Navigation*/
    .main-footer .navigation-footer-menu { display: none; }
    .main-footer .navigation-footer-menu.show { display: block; }
    .main-footer .navigation-no-gated { display: flex; flex-direction: column; gap: 10px; }
    .main-footer .navigation-no-gated a { text-decoration: underline; }
    .main-footer .navigation-no-gated a:hover { text-decoration: none; }
    .main-footer .navigation-no-gated.hide { display: none; }
    .main-footer .footer-wrapper.no-gated { justify-content: center; gap: 60px; }


/*Hero*/
.hero { min-height: 100vh; height: 100%; display: flex; align-items: center; justify-content: center; position: relative; padding: 20px; }
.hero.with-background { background-repeat: no-repeat; background-position: center; background-size: cover; }
.hero .content { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.hero h1 { font-size: 50px; font-weight: 700; margin-bottom: 50px; }
.hero .container-buttons { display: flex; align-items: center; gap: 20px; }
.hero .container-buttons li { width: fit-content; border: 1px solid var(--ice-white); border-radius: 25px; padding: 10px 16px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s; }
.hero .container-buttons li:hover { border: 1px solid var(--light-sky-blue); color: var(--light-sky-blue); background-color: #4c7baa26; }
.hero .container-buttons li:hover a { color: var(--light-sky-blue); }
.hero .subtitle { font-size: 24px; text-align: center; }
.hero .wrapper-arrow { position: absolute; bottom: 70px; left: 50%; transform: translateX(-50%); animation: arrow-up-down 0.6s infinite alternate; }
.hero .wrapper-arrow .fa-sort-down { font-size: 22px; }

/*Section with background*/
.section-with-bg { height: 790px; width: 100%; display: flex; align-items: center; justify-content: center; background-repeat: no-repeat; background-position: center; background-size: cover; background-color: #275678d6; padding: 20px; transition: all 0.5s; overflow: hidden; }
.section-with-bg .content { display: flex; align-items: center; justify-content: center; }
.section-with-bg h2 { font-size: 24px; font-weight: 700; }

/*Text with image*/
.text-with-img .content { display: flex; align-items: center; justify-content: center; gap: 50px; }
.text-with-img .content .text-wrapper { display: flex; flex-direction: column; gap: 25px; position: relative; }
.text-with-img .content p { font-size: 20px; }
.text-with-img h2 { font-size: 24px; font-weight: 700; }
.text-with-img .content img { position: relative; }

/*Link*/
.link-item { display: flex; align-items: center; gap: 6px; }
.link-item a { color: var(--ice-white); text-decoration: underline; }
.link-item a i { transition: all 0.3s; font-size: 12px; margin-left: 6px; }
.link-item a:hover,
.link-item a:hover i { color: var(--light-sky-blue); }
.link-item a:hover i { transform: translateX(3px); }
.link-item:first-of-type { margin-bottom: 20px; }

.link-item.black { font-weight: 500; font-size: 14px; color: #0F1F4D; }
.link-item.black a { color: #0F1F4D; }
.link-item.black a:hover { color: var(--light-sky-blue); }
.link-item.black .link-item i { font-size: 10px; }

/*Common Section*/
.common-section { padding: 80px 20px; color: var(--black); }
.common-section .content { max-width: 940px; display: flex; flex-direction: column; align-items: center; }
.common-section h2 { font-size: 30px; font-weight: 700; margin-bottom: 30px; }
.common-section h3 { font-size: 24px; font-weight: 700; margin-bottom: 20px; }
.common-section .subtitle { font-size: 20px; font-weight: 500; line-height: 1.6; letter-spacing: 0.5px; max-width: 750px; margin-bottom: 60px; text-align: center; }
.common-section .subtitle.large { max-width: 800px; }
.common-section p { font-weight: 500; line-height: 1.6; }
.common-section .text-wrapper { max-width: 425px; text-align: center; }
.common-section .text-wrapper.large { max-width: 650px; }

/*Slider Section*/
.slider-section { padding: 40px 20px; color: var(--black); }
.slider-section .content { max-width: 1100px;}
.slider-section .swiper-wrapper .swiper-slide { position: relative; }
.slider-section .swiper-wrapper .swiper-slide img { width: 100%; }
.slider-section .swiper-wrapper .swiper-slide p { position: absolute; bottom: 30px; right: 30px; font-size: 16px; font-weight: 600; max-width: 450px; }
.slider-section .swiper-horizontal { padding-bottom: 50px; }
.swiper-horizontal>.swiper-pagination-bullets, 
.swiper-pagination-bullets.swiper-pagination-horizontal { bottom: 0; }

.swiper-button-next,
.swiper-button-prev { color: var(--black); transition: all 0.3s; }
.swiper-button-next:hover,
.swiper-button-prev:hover { color: var(--blue); }
.swiper-button-next:after, 
.swiper-button-prev:after { font-size: 20px; }

.swiper-pagination-bullet { width: 10px; height: 10px; background: #828282; }
.swiper-pagination-bullet-active { background: var(--blue); }

/*Two Sides Content*/
.two-sides-content { padding: 50px 20px; color: var(--black); overflow: hidden; }
.two-sides-content .content { display: flex; align-items: center; justify-content: center; gap: 60px; }
.two-sides-content .left { display: flex; flex-direction: column; gap: 25px; max-width: 415px; }
.two-sides-content .left.large { max-width: 440px; }
.two-sides-content .left h3 { font-size: 20px; font-weight: 700; }
.two-sides-content .left .subtitle { font-weight: 500; line-height: 1.6; letter-spacing: 0.5px; }
.two-sides-content .left ul li p { color: var(--blue); font-weight: 500; }
.two-sides-content .left p { font-weight: 500; }
.two-sides-content .right.display-flex { display: flex; align-items: center; }
.two-sides-content .right img { max-width: 650px; width: 100%; }
.two-sides-content .right span { display: block; color: #808080; font-size: 16px; padding-left: 40px; max-width: 370px; }
.two-sides-content .right span.max-600 { max-width: 600px; margin-top: 40px; }
.two-sides-content .link-item { font-size: 14px; font-weight: 500; text-align: center; justify-content: center; margin: 20px auto 0; }
.two-sides-content .link-item a { color: var(--black); }
.two-sides-content .link-item a:hover { color: var(--light-sky-blue); }

/*Two Sides Content With Circles*/
.two-sides-content.with-circle .right img { max-width: none; width: auto; }
.two-sides-content.with-circle .right .images-wrapper { max-width: 250px; width: 100%; position: relative; }
.two-sides-content.with-circle .right .images-wrapper .main-image { width: 100%; position: relative; z-index: 2; }

.two-sides-content.with-circle .right .images-wrapper .circle { position: absolute; z-index: 1; }
.two-sides-content.with-circle .right .images-wrapper .circle.left { left: -20px; }
.two-sides-content.with-circle .right .images-wrapper .circle.right { right: -50px; }

.two-sides-content.with-circle .right .images-wrapper .circle.blue { bottom: 70px; }
.two-sides-content.with-circle .right .images-wrapper .circle.green { bottom: -20px; left: -40px; width: 80px; }
.two-sides-content.with-circle .right .images-wrapper .circle.red { bottom: 150px; right: -45px; width: 85px;}

.two-sides-content.with-circle .right.reveal.active .images-wrapper .circle.left { animation: rotate-90 1s linear; }
.two-sides-content.with-circle .right.reveal.active .images-wrapper .circle.right { animation: rotate-90-minus 1s linear; }

/*Without span*/
.two-sides-content .no-span-section { justify-content: flex-start; padding-left: 130px; }

/*Lists*/
.list-item-circle { padding-left: 20px; margin-left: -20px; }
.list-item-circle li { display: flex; align-items: center; padding-bottom: 10px; position: relative; color: var(--blue); }
.list-item-circle li::before { content: ""; display: block; width: 4px; height: 4px; background-color: var(--blue); border-radius: 50%; position: absolute; left: -14px; top: 11px; }

/*Modal*/
.modal.show { opacity: 1; visibility: visible; }
.modal { opacity: 0; visibility: hidden; position: fixed; background: rgba(0, 0, 0, 0.60); width: 100%; min-height: 100vh; height: 100%; left: 0; top: 0; display: flex; align-items: center; justify-content: center; z-index: 110; }
.modal .modal-content { position: relative; max-width: 640px; width: 100%; padding-bottom: 56.25%; }
.modal .modal-content iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.modal .modal-content .fa-xmark { position: absolute; top: 25%; right: -50px; font-size: 20px; padding: 20px; cursor: pointer; opacity: 0.8; }
.modal .modal-content .fa-xmark:hover { opacity: 1; }

/*Animations*/
@keyframes rotate-360 {
    from { transform: rotate(0); }
    to { transform: rotate(360deg); }
}

@keyframes fadeInAnimation {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes rotate-90-minus {
    from { transform: rotate(-90deg); }
    to { transform: rotate(0deg); }
}

@keyframes rotate-90 {
    from { transform: rotate(90deg); }
    to { transform: rotate(0deg); }
}

@keyframes arrow-up-down {
    0% { bottom: 70px; }
    100% { bottom: 50px; }
}

/*Loading Spinner*/
.spinner-wrapper { opacity: 0; visibility: hidden; display: flex; align-items: center; justify-content: center; width: 100%; min-height: 100vh; height: 100%; position: fixed; z-index: 1000; left: 0; top: 0; }
.spinner-wrapper.show {  opacity: 1; visibility: visible; }

.spinner-wrapper .overlay { background: rgba(38, 77, 106, 0.9); width: 100%; height: 100%; position: absolute; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);}

.loading-spinner { position: relative; width: 60px; height: 60px; }

.loading-spinner:before { 
    content: ""; 
    box-sizing: border-box; 
    position: absolute; 
    top: 50%; 
    left: 50%; 
    width: 60px; 
    height: 60px; 
    margin-top: -30px; 
    margin-left: -30px; 
    border-radius: 50%; 
    border-top: 2px solid var(--blue); 
    border-right: 2px solid transparent; 
    animation: spinner .6s linear infinite; 
}

@keyframes spinner { 
    to {
        transform: rotate(360deg);
    } 
}