/*!
  Theme Name: Core-Tech Services
  Author: Core-Tech Team
  Author URI: https://core-tech-services.com
  Version: 1.0.0
  Description: A modern one-page WordPress theme for Core-Tech Services with backend manageable metaboxes
  License: GNU General Public License v2 or later
  License URI: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
  Text Domain: core-tech
  Tags: one-column, custom-colors, custom-menu, featured-images, full-width-template, theme-options
  Theme URI: https://core-tech-services.com
*/

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html
{
    line-height: 1.15; /* 1 */

    -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body
{
    margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main
{
    display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1
{
    font-size: 2em;

    margin: .67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr
{
    overflow: visible; /* 2 */

    box-sizing: content-box; /* 1 */
    height: 0; /* 1 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre
{
    font-family: monospace, monospace; /* 1 */
    font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a
{
    background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title]
{
    text-decoration: underline; /* 2 */
    text-decoration: underline dotted; /* 2 */

    border-bottom: none; /* 1 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong
{
    font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp
{
    font-family: monospace, monospace; /* 1 */
    font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small
{
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup
{
    font-size: 75%;
    line-height: 0;

    position: relative;

    vertical-align: baseline;
}

sub
{
    bottom: -.25em;
}

sup
{
    top: -.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img
{
    border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea
{
    font-family: inherit; /* 1 */
    font-size: 100%; /* 1 */
    line-height: 1.15; /* 1 */

    margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input
{
    /* 1 */
    overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select
{
    /* 1 */
    text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type='button'],
[type='reset'],
[type='submit']
{
    -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner
{
    padding: 0;

    border-style: none;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type='button']:-moz-focusring,
[type='reset']:-moz-focusring,
[type='submit']:-moz-focusring
{
    outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset
{
    padding: .35em .75em .625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend
{
    display: table; /* 1 */

    box-sizing: border-box; /* 1 */
    max-width: 100%; /* 1 */
    padding: 0; /* 3 */

    white-space: normal; /* 1 */

    color: inherit; /* 2 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress
{
    vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea
{
    overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type='checkbox'],
[type='radio']
{
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button
{
    height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type='search']
{
    outline-offset: -2px; /* 2 */

    -webkit-appearance: textfield; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type='search']::-webkit-search-decoration
{
    -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button
{
    font: inherit; /* 2 */

    -webkit-appearance: button; /* 1 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details
{
    display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary
{
    display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template
{
    display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden]
{
    display: none;
}

/* Slick slider styles */

.slick-slider
{
    position: relative;

    display: block;

    box-sizing: border-box;

    -webkit-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}

.slick-list:focus
{
    outline: none;
}

.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
}

.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}

.slick-track:after
{
    clear: both;
}

.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}

[dir='rtl'] .slick-slide
{
    float: right;
}

.slick-slide img
{
    display: block;
}

.slick-slide.slick-loading img
{
    display: none;
}

.slick-slide.dragging img
{
    pointer-events: none;
}

.slick-initialized .slick-slide
{
    display: block;
}

.slick-loading .slick-slide
{
    visibility: hidden;
}

.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}

.slick-arrow.slick-hidden
{
    display: none;
}

/**
 * Set up a decent box model on the root element
 */

html
{
    box-sizing: border-box;
}

/**
 * Make all elements from the DOM inherit from the parent box-sizing
 * Since `*` has a specificity of 0, it does not override the `html` value
 * making all elements inheriting from the root box-sizing value
 * See: https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/
 */

*,
*::before,
*::after
{
    box-sizing: inherit;
}

/*
 * Hide only visually, but have it available for screen readers:
 * https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 *
 * 1. For long content, line feeds are not interpreted as spaces and small width
 *    causes content to wrap 1 word per line:
 *    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
 */

.visually-hidden
{
    position: absolute;

    overflow: hidden;
    clip: rect(0, 0, 0, 0);

    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;

    white-space: nowrap;

    border: 0;
}

/*
 * Extends the .visually-hidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visually-hidden.focusable:active,
.visually-hidden.focusable:focus
{
    position: static;

    overflow: visible;
    clip: auto;

    width: auto;
    height: auto;
    margin: 0;

    white-space: inherit;
}

.clearfix:after
{
    display: block;
    clear: both;

    content: '';
}

.ellipsis
{
    overflow: hidden;

    white-space: nowrap; /* 1 */
    text-overflow: ellipsis; /* 2 */
}

.two-columns
{
    padding: 50px 0;
}

.content .navigation
{
    max-width: none;
    margin: 0 0 30px;
    padding: 0;

    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.content .navigation .prev,
.content .navigation .next
{
    position: relative;

    -webkit-transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: transform .3s linear, box-shadow .3s linear;
            transition: transform .3s linear, box-shadow .3s linear, -webkit-transform .3s linear;
}

.content .navigation .prev:hover,
.content .navigation .next:hover
{
    -webkit-transform: translateY(-5px);
        -ms-transform: translateY(-5px);
            transform: translateY(-5px);
    text-decoration: underline;

    opacity: 1;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .15);
}

.content .navigation-single .prev,
.content .navigation-single .next
{
    position: relative;

    -webkit-transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: transform .3s linear, box-shadow .3s linear;
            transition: transform .3s linear, box-shadow .3s linear, -webkit-transform .3s linear;
}

.content .navigation-single .prev:hover,
.content .navigation-single .next:hover
{
    -webkit-transform: translateY(-5px);
        -ms-transform: translateY(-5px);
            transform: translateY(-5px);
    text-decoration: underline;

    opacity: 1;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .15);
}

.content .navigation-comments .prev,
.content .navigation-comments .next
{
    position: relative;

    -webkit-transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: transform .3s linear, box-shadow .3s linear;
            transition: transform .3s linear, box-shadow .3s linear, -webkit-transform .3s linear;
}

.content .navigation-comments .prev:hover,
.content .navigation-comments .next:hover
{
    -webkit-transform: translateY(-5px);
        -ms-transform: translateY(-5px);
            transform: translateY(-5px);
    text-decoration: underline;

    opacity: 1;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .15);
}

.iframe-holder
{
    position: relative;

    margin: 0 0 1.8rem;
    padding-top: 56.25%;
}

.iframe-holder iframe
{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    vertical-align: top;

    border: none;
}

.widget
{
    margin-bottom: 20px;
}

.widget ul a
{
    text-decoration: underline;

    color: #5f79ea;
}

.widget ul a:hover
{
    text-decoration: none;
}

.widget select
{
    min-width: 150px;
}

.comment-form label
{
    display: block;

    padding-bottom: 4px;
}

.comment-form textarea
{
    overflow: auto;

    height: 120px;
    min-height: 120px;
    margin: 0;
}

.comment-form textarea,
.comment-form input[type='text']
{
    width: 100%;
    max-width: 300px;
    margin: 0 4px 0 0;
}

.comment-form input[type='submit']
{
    display: block;
    float: none;
}

.post-password-form label
{
    display: block;

    margin-bottom: 4px;
}

.post-password-form input[type='password']
{
    width: 100%;
    max-width: 300px;
    margin: 0 4px 0 0;
}

.search-form
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin-bottom: 15px;
}

.search-form fieldset
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.search-form input
{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;

    height: 40px;
}

.search-form input[type='search']
{
    width: calc(100% - 100px);
    margin: 0;
}

.search-form input[type='submit']
{
    width: 100px;
    height: 40px !important;

    text-align: center;

    -ms-flex-negative: 0;
    flex-shrink: 0;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.post-password-form input
{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;

    height: 32px;
}

.post-password-form input[type='password']
{
    width: 150px;
}

.comment-form fieldset,
.post-password-form fieldset,
.search-form fieldset
{
    padding: 0;

    border: 0;
}

.comment-form input[type='submit'],
.post-password-form input[type='submit'],
.search-form input[type='submit']
{
    position: relative;

    height: 32px;
    padding: 0 8px;

    cursor: pointer;
    -webkit-transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: box-shadow .3s linear, -webkit-transform .3s linear;
            transition: transform .3s linear, box-shadow .3s linear;
            transition: transform .3s linear, box-shadow .3s linear, -webkit-transform .3s linear;

    color: #fff;
    border: 0;
    background: #3bb2e1;
}

.comment-form input[type='submit']:hover,
.post-password-form input[type='submit']:hover,
.search-form input[type='submit']:hover
{
    -webkit-transform: translateY(-5px);
        -ms-transform: translateY(-5px);
            transform: translateY(-5px);
    text-decoration: underline;

    opacity: 1;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .15);
}

.commentlist
{
    margin: 0 0 20px;
}

.commentlist .edit-link
{
    margin: 0;
}

.commentlist .avatar-holder
{
    float: left;

    margin: 0 20px 4px 0;
}

.commentlist-item .commentlist-item
{
    padding: 0;
}

.comment,
.commentlist-holder
{
    overflow: hidden;
}

.commentlist-item .commentlist-item,
.commentlist-item + .commentlist-item
{
    padding-top: 20px;
}

.widget_calendar #next
{
    text-align: right;
}

.gallery-item dt
{
    float: none;

    padding: 0;
}

.navigation,
.navigation-comments
{
    position: relative;

    margin-bottom: 20px;

    vertical-align: middle;
}

.navigation .screen-reader-text,
.navigation-comments .screen-reader-text
{
    position: absolute;
    left: -99999px;
}

.navigation .page-numbers,
.navigation-comments .page-numbers
{
    display: inline-block;

    padding: 0 6px;

    vertical-align: middle;
}

.navigation .next,
.navigation .prev,
.navigation-comments .next,
.navigation-comments .prev
{
    display: inline-block;

    max-width: 48%;
    padding: 10px;

    vertical-align: middle;
    text-decoration: none;

    color: #fff;
    background: #3bb2e1;
}

.navigation .next:hover,
.navigation .prev:hover,
.navigation-comments .next:hover,
.navigation-comments .prev:hover
{
    opacity: .8;
}

.navigation .nav-links > *,
.navigation-comments .nav-links > *
{
    margin-bottom: 10px;
}

.navigation-comments > *
{
    margin-bottom: 10px;
}

.navigation-single
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin-bottom: 20px;

    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.navigation-single .next,
.navigation-single .prev
{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;

    max-width: 48%;
    margin-bottom: 10px;

    text-decoration: none;

    color: #fff;
    background: #3bb2e1;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.navigation-single .next:hover,
.navigation-single .prev:hover
{
    opacity: .8;
}

.navigation-single .next a,
.navigation-single .prev a
{
    display: block;

    padding: 10px;

    text-decoration: none;

    color: inherit;
}

.navigation-single .next a
{
    margin-left: auto;
}

.wp-caption
{
    clear: both;

    max-width: 100%;
    margin-bottom: 20px;
    padding: 10px;

    border: 1px solid #000;
}

.wp-caption img
{
    margin: 0;

    vertical-align: top;
}

.wp-caption p
{
    margin: 10px 0 0;
}

div.aligncenter
{
    margin: 0 auto 20px;
}

img.aligncenter
{
    display: block;

    margin: 0 auto;
}

.alignleft
{
    float: left;

    margin: 0 20px 4px 0;
}

.alignright
{
    float: right;

    margin: 0 0 4px 20px;
}

.mejs-container
{
    margin-bottom: 20px;
}

.wp-caption-text,
.gallery,
.alignnone,
.gallery-caption,
.sticky,
.bypostauthor
{
    height: auto;
}

#wp-calendar
{
    width: 100%;
}

#wp-calendar tbody td
{
    text-align: center;
}

#wp-calendar td,
#wp-calendar th
{
    padding: 5px;

    border: 1px solid #000;
}

.iframe-holder
{
    position: relative;

    margin: 0 0 1.5em;
    padding-top: 56.25%;
}

.iframe-holder iframe
{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    vertical-align: top;

    border: none;
}

/*
	Set up a decent box model on the root element
*/

html
{
    font-size: 10px;
}

/*
	Basic typography style for copy text
*/

body
{
    font-family: 'Roboto', Arial, 'Noto Sans', sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.7368;

    color: #000;
}

/*
	Basic styles for links
*/

a
{
    text-decoration: none;

    color: #5f79ea;
    outline: none;
}

a:hover
{
    text-decoration: none;

    color: #3bb2e1;
}

dl,
p
{
    margin: 0 0 1.8rem;
}

/*
	Basic styles for typography, generate classes for sizes provided into sass-map $font-sizes
	Using fluid type behavior
*/

/*
	Basic styles for headings, generate classes for sizes provided into sass-map $font-sizes
	Using fluid type behavior
*/

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6,
.h
{
    font-family: 'Roboto Mono', monospace;
    font-weight: 700;
    line-height: 1.22223;

    margin: 0 0 1.7368em;

    color: #5f79ea;
}

h1 a,
.h1 a,
h2 a,
.h2 a,
h3 a,
.h3 a,
h4 a,
.h4 a,
h5 a,
.h5 a,
h6 a,
.h6 a,
.h a
{
    color: inherit;
}

h1,
.h1
{
    font-size: 44px;

    margin-bottom: 32px;
}

h2,
.h2
{
    font-size: 40px;

    margin-bottom: 33px;
}

h3,
.h3
{
    font-size: 30px;

    margin-bottom: 32px;
}

h4,
.h4
{
    font-size: 24px;

    margin-bottom: 21px;
}

h5,
.h5
{
    font-size: 20px;

    margin-bottom: 10px;
}

h6,
.h6
{
    font-size: 18px;

    margin-bottom: 10px;
}

p + .link
{
    margin-top: 10px;
}

p + .link-sm
{
    margin-top: 13px;
}

input[type='text'],
input[type='email'],
input[type='tel'],
textarea
{
    width: 100%;
    min-width: 0;
    padding: 1.2rem 2.4rem;

    -webkit-transition: border-color .35s cubic-bezier(.3, .86, .36, .95);
            transition: border-color .35s cubic-bezier(.3, .86, .36, .95);

    border: 1px solid currentColor;
    border-radius: 0;
    background-color: transparent;

    -webkit-appearance: none;
}

input[type='text']:focus,
input[type='text']:hover,
input[type='email']:focus,
input[type='email']:hover,
input[type='tel']:focus,
input[type='tel']:hover,
textarea:focus,
textarea:hover
{
    outline: none;
    box-shadow: none;
}

.contact-btn > a,
.btn
{
    display: inline-block;

    min-width: 150px;
    padding: 10px 16px;

    text-align: center;
    vertical-align: top;

    color: #fff;
    border-radius: 26px;
    background: -webkit-linear-gradient(top, #5f79ea 0%, #3bb2e1 100%);
    background:         linear-gradient(180deg, #5f79ea 0%, #3bb2e1 100%);
}

.contact-btn > a:hover,
.btn:hover
{
    color: #fff;
    background: -webkit-linear-gradient(top, #3bb2e1 0%, #5f79ea 100%);
    background:         linear-gradient(180deg, #3bb2e1 0%, #5f79ea 100%);
}

.header
{
    position: fixed;
    z-index: 3;
    top: 0;
    left: 0;
    left: 0;

    width: 100%;
    padding: 16px 0;

    -webkit-transition: background .3s ease-in-out, box-shadow .3s ease-in-out, padding .3s ease-in-out;
            transition: background .3s ease-in-out, box-shadow .3s ease-in-out, padding .3s ease-in-out;
}

.header .container
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    padding: 0 18px;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.header.scrolled
{
    position: fixed;

    padding: 10px 0;

    background: rgba(255, 255, 255, .9);
    box-shadow: 0 0 8px rgba(0, 0, 0, .1);

    backdrop-filter: blur(10px);
}

.header.scrolled .logo .logo-img
{
    width: 40px;
}

.logo
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
}

.logo .logo-img
{
    width: 50px;

    -webkit-transition: width .3s ease-in-out;
            transition: width .3s ease-in-out;
}

.logo .logo-text
{
    font: 400 14px/1.5 'Roboto Condensed', sans-serif;

    text-transform: uppercase;

    color: #3bb2e1;
}

.logo .logo-text small
{
    font-size: 10px;

    display: block;
}

.nav-opener
{
    position: relative;

    display: block;

    width: 27px;
    height: 20px;
}

.nav-opener:before,
.nav-opener:after,
.nav-opener span
{
    position: absolute;
    right: 0;
    left: 0;

    width: 25px;
    height: 2px;

    content: '';
    -webkit-transition: top .3s ease-in-out, -webkit-transform .3s ease-in-out;
            transition: top .3s ease-in-out, -webkit-transform .3s ease-in-out;
            transition: transform .3s ease-in-out, top .3s ease-in-out;
            transition: transform .3s ease-in-out, top .3s ease-in-out, -webkit-transform .3s ease-in-out;

    border-radius: 2px;
    background-color: #3bb2e1;
}

.nav-opener:before
{
    top: 0;
}

.nav-active .nav-opener:before
{
    top: 9px;

    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
}

.nav-opener:after
{
    top: 14px;
}

.nav-active .nav-opener:after
{
    top: 9px;

    -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
            transform: rotate(-45deg);
}

.nav-opener span
{
    top: 7px;
}

.nav-active .nav-opener span
{
    opacity: 0;
}

.resize-active .nav-drop
{
    -webkit-transition: none;
            transition: none;
}

.main-nav
{
    font-size: 18px;
    font-weight: 500;
    line-height: 1.3;

    margin: 0;
    padding: 0;

    list-style: none;
}

.main-nav li + li
{
    margin-top: 24px;
}

.main-nav li.active a
{
    color: #5f79ea;
}

.main-nav li.contact-btn a
{
    color: #fff;
}

.main-nav a
{
    color: #3bb2e1;
}

.main-nav a:hover,
.main-nav a:focus,
.main-nav a.anchor-active
{
    color: #5f79ea;
}

body
{
    font-size: 16px;
    font-weight: 300;
    line-height: 1.5;

    min-width: 360px;

    background-color: #fff;
}

.resize-active *
{
    -webkit-transition: none !important;
            transition: none !important;
}

img
{
    max-width: 100%;
    height: auto;

    vertical-align: top;
}

.wrapper
{
    position: relative;

    overflow: hidden;

    width: 100%;
}

.accessibility
{
    position: absolute;
    top: auto;
    left: -99999px;

    overflow: hidden;

    width: 1px;
    height: 1px;
}

.accessibility:focus
{
    position: static;

    width: auto;
    height: auto;
}

.hidden
{
    position: absolute;
    top: auto;
    left: -9999px;

    overflow: hidden;

    width: 1px;
    height: 1px;
}

a
{
    -webkit-transition: color .3s linear, background-color .3s linear, opacity .3s linear;
            transition: color .3s linear, background-color .3s linear, opacity .3s linear;
}

.container
{
    max-width: 1470px;
    margin-right: auto;
    margin-left: auto;
    padding-right: 15px;
    padding-left: 15px;
}

section
{
    margin-bottom: 20px;
    padding: 30px 0;
}

section h2
{
    margin-bottom: 30px;
}

.common-banner
{
    position: relative;

    overflow: hidden;

    margin: 0;
    padding: 120px 0 50px;
}

.common-banner .bg-img
{
    position: absolute;
    z-index: -1;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.common-banner .bg-img:after
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    content: '';

    background: -webkit-linear-gradient(top, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .5) 100%);
    background:         linear-gradient(to bottom, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .5) 100%);
}

.common-banner img,
.common-banner video
{
    display: block;

    min-width: 100%;
    min-height: 100%;

    object-fit: cover;
    object-position: center center;
}

.common-banner h1
{
    text-transform: uppercase;

    color: #fff;
}

.common-banner h1:only-child
{
    margin-bottom: 0;
}

.highlight
{
    color: #5f79ea;
}

.heading-block
{
    margin-bottom: 40px;

    text-align: center;
}

.section-title
{
    font: 700 14px/1.5 'Roboto Condensed', sans-serif;

    display: block;

    margin-bottom: 10px;

    letter-spacing: 2px;
    text-transform: uppercase;

    color: #3bb2e1;
}

.intro-section
{
    position: relative;

    text-align: center;
}

.intro-section .container
{
    margin-top: 20px;
}

.intro-section:after
{
    position: absolute;
    z-index: -1;
    right: 0;
    bottom: 0;
    left: 0;

    height: 50%;

    content: '';

    background: -webkit-linear-gradient(transparent, #fff);
    background:         linear-gradient(transparent, #fff);
}

.intro-section h1
{
    color: #3bb2e1;
}

.intro-section p
{
    max-width: 800px;

    margin-inline: auto;
}

.intro-section p:last-child
{
    margin-bottom: 0;
}

.intro-section .bg-img
{
    position: absolute;
    z-index: -1;
    top: -80px;
    right: 0;
    left: 0;
}

.intro-section .bg-img img
{
    opacity: .03;
}

.logos-slider
{
    position: relative;

    margin-top: 60px;
}

.logos-slider:before,
.logos-slider:after
{
    position: absolute;
    z-index: 1;
    top: 0;
    bottom: 0;
    left: 0;

    width: 200px;

    content: '';

    background: -webkit-linear-gradient(left, white 20%, transparent);
    background:         linear-gradient(90deg, white 20%, transparent);
}

.logos-slider:after
{
    right: 0;
    left: auto;

    background: -webkit-linear-gradient(right, white 20%, transparent);
    background:         linear-gradient(-90deg, white 20%, transparent);
}

.logos-slider .line-wrap
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.logos-slider .slide
{
    min-width: 80px;
    max-width: 100px;
    padding: 0 40px;
}

.logos-slider img
{
    -webkit-transition: filter .3s linear, opacity .3s linear;
            transition: filter .3s linear, opacity .3s linear;

    opacity: .7;

    filter: grayscale(1);
}

.logos-slider img:hover
{
    opacity: 1;

    filter: none;
}

.read-more-content.expanded .content
{
    max-height: 500px;

    opacity: 1;
}

.read-more-content.expanded .read-more-btn .less
{
    display: inline;
}

.read-more-content.expanded .read-more-btn .more
{
    display: none;
}

.read-more-content .content
{
    overflow: hidden;

    max-height: 0;

    -webkit-transition: max-height .4s linear, opacity .4s linear;
            transition: max-height .4s linear, opacity .4s linear;

    opacity: 0;
}

.read-more-btn
{
    font-family: 'Roboto Condensed', sans-serif;
    font-weight: 500;

    text-decoration: underline;
    text-transform: capitalize;
}

.read-more-btn .less
{
    display: none;
}

.img-text-section .img
{
    position: relative;

    overflow: hidden;

    margin-bottom: 20px;
}

.img-text-section .img img
{
    display: block;

    width: 100%;
    height: auto;
}

.img-text-section .img .cover-img
{
    position: absolute;
    z-index: -1;
    top: 3px;
    left: 2px;

    width: 99%;
    height: 99%;

    object-fit: cover;
    object-position: center;
}

.img-text-section .text p:last-child
{
    margin-bottom: 0;
}

.social-links
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin: 0;
    padding: 0;

    list-style: none;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 10px;
}

.social-links li
{
    width: 30px;
}

.social-links a:hover
{
    opacity: .75;
}

.footer
{
    font-size: 14px;
    line-height: 1.3;

    text-align: center;

    color: #fff;
    background: #060d2b;
}

.footer .footer-logo
{
    margin-bottom: 15px;
}

.footer .footer-logo .logo-img
{
    display: block;

    width: 50px;
    margin: 0 auto 10px;
}

.footer .footer-logo .logo-text
{
    font: 400 14px/1 'Roboto Condensed', sans-serif;

    text-decoration: none;
    text-transform: uppercase;

    color: #3bb2e1;
}

.footer address
{
    font-size: 14px;
    font-style: normal;

    margin-bottom: 15px;
}

.footer address p
{
    margin: 0;
}

.footer a
{
    color: #3bb2e1;
}

.footer a:hover
{
    color: #5f79ea;
}

.footer-top
{
    padding: 30px 0;
}

.footer-top .footer-col strong
{
    display: block;

    margin-bottom: 8px;
}

.footer-top .footer-col p
{
    margin-bottom: 6px;
}

.footer-top .footer-col p:last-child
{
    margin-bottom: 0;
}

.footer-bottom
{
    font-size: 14px;
    line-height: 1.3;

    padding: 15px 0;

    border-top: 1px solid rgba(255, 255, 255, .08);
}

.footer-bottom p
{
    margin: 0;
}

.footer-bottom .container
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    text-align: center;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 10px;
}

.footer-links
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin: 0;
    padding: 0;

    list-style: none;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 15px;
}

.hero-section
{
    position: relative;

    margin: 0;
    padding: 0;
}

.hero-section .arrow-down
{
    position: absolute;
    bottom: 20px;
    left: 50%;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
        flex-direction: column;

    width: 50px;
    height: 50px;

    cursor: pointer;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    -webkit-animation: bounce 2s infinite;
            animation: bounce 2s infinite;

    border: 1px solid #fff;
    border-radius: 50%;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
}

.banner-slider .slide
{
    position: relative;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
        flex-direction: column;

    min-height: 100vh;
    padding: 110px 0;

    color: #fff;

    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.banner-slider .slide .container
{
    width: 100%;
}

.banner-slider .slide .img
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.banner-slider .slide .img:after
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    content: '';

    background: -webkit-linear-gradient(top, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .5) 100%);
    background:         linear-gradient(to bottom, rgba(0, 0, 0, .95) 0%, rgba(0, 0, 0, .5) 100%);
}

.banner-slider .slide img,
.banner-slider .slide video
{
    display: block;

    min-width: 100%;
    min-height: 100%;

    object-fit: cover;
    object-position: center center;
}

.banner-slider .slide .text-block
{
    font-size: 24px;

    position: relative;
    z-index: 1;
}

.banner-slider .slide h1
{
    font-size: 46px;

    color: #fff;
}

.banner-slider .slide .btn
{
    font-size: 18px;

    min-width: 200px;
    margin-top: 20px;
}

section:has(.service-row)
{
    margin-bottom: 0;
}

.service-row
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin: 0 -15px;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.service-row .col
{
    width: 100%;
    margin-bottom: 20px;
    padding: 0 15px;
}

.service-card
{
    font-size: 14px;
    line-height: 1.5;

    position: relative;

    height: 100%;
    padding: 30px 20px 20px;
}

.service-card:after,
.service-card:before
{
    position: absolute;
    z-index: -1;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    content: '';

    background: -webkit-linear-gradient(top, #5f79ea 0%, #3bb2e1 100%);
    background:         linear-gradient(180deg, #5f79ea 0%, #3bb2e1 100%);
}

.service-card:after
{
    z-index: 0;
    top: 1px;
    right: 1px;
    bottom: 1px;
    left: 1px;

    background: #fff;
}

.service-card *
{
    position: relative;
    z-index: 1;
}

.service-card h3
{
    font-size: 20px;

    margin-bottom: 12px;
}

.service-card .icon-hold
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: 40px;
    height: 40px;
    margin-bottom: 20px;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.service-card .icon-hold .ico
{
    position: absolute;

    width: 20px;

    fill: #fff;
}

.custom-checkbox
{
    font-size: 14px;
    line-height: 1.5;

    position: relative;
}

.custom-checkbox label input[type='checkbox']
{
    position: absolute;
    top: 0;
    left: 0;

    opacity: 0;
}

.custom-checkbox label input[type='checkbox']:checked + span:after
{
    opacity: 1;
}

.custom-checkbox label span
{
    position: relative;

    display: inline-block;

    padding-left: 20px;

    vertical-align: top;
}

.custom-checkbox label span:before,
.custom-checkbox label span:after
{
    position: absolute;

    content: '';
}

.custom-checkbox label span:before
{
    top: 3px;
    left: 0;

    width: 15px;
    height: 15px;

    border: 1px solid #000;
}

.custom-checkbox label span:after
{
    top: 6px;
    left: 3px;

    width: 9px;
    height: 5px;

    -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
            transform: rotate(-45deg);

    opacity: 0;
    border-width: 0 0 1px 1px;
    border-style: solid;
    border-color: #000;
}

.custom-checkbox p:last-child
{
    margin-bottom: 0;
}

.contact-section
{
    margin: 0;
    padding-bottom: 60px;

    background: #f9f9f9;
}

.contact-section .heading-block
{
    max-width: 800px;
    margin: 0 auto 40px;
}

.contact-form-holder
{
    position: relative;

    max-width: 800px;
    margin: 0 auto;
    padding: 28px 16px;

    border-radius: 20px;
    background: #fff;
    box-shadow: 0 0 26px 0 rgba(0, 0, 0, .06);
}

.contact-form-holder form
{
    position: relative;
    z-index: 1;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.contact-form-holder .input-wrap
{
    width: calc(50% - 10px);
}

.contact-form-holder .w-full
{
    width: 100%;
}

.contact-form-holder input[type='text'],
.contact-form-holder input[type='email'],
.contact-form-holder input[type='tel'],
.contact-form-holder input[type='password'],
.contact-form-holder textarea
{
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5;

    width: 100%;
    height: 40px;
    padding: 6px 15px;

    color: #242c47;
    border: 1px solid #f0f0f0;
    border-radius: 100px;
    outline: none;
    background: none;

    -webkit-appearance: none;
}

.contact-form-holder input[type='text']::-webkit-input-placeholder,
.contact-form-holder input[type='email']::-webkit-input-placeholder,
.contact-form-holder input[type='tel']::-webkit-input-placeholder,
.contact-form-holder input[type='password']::-webkit-input-placeholder,
.contact-form-holder textarea::-webkit-input-placeholder
{
    opacity: .6;
    color: #242c47;
}

.contact-form-holder input[type='text']:-ms-input-placeholder,
.contact-form-holder input[type='email']:-ms-input-placeholder,
.contact-form-holder input[type='tel']:-ms-input-placeholder,
.contact-form-holder input[type='password']:-ms-input-placeholder,
.contact-form-holder textarea:-ms-input-placeholder
{
    opacity: .6;
    color: #242c47;
}

.contact-form-holder input[type='text']::placeholder,
.contact-form-holder input[type='email']::placeholder,
.contact-form-holder input[type='tel']::placeholder,
.contact-form-holder input[type='password']::placeholder,
.contact-form-holder textarea::placeholder
{
    opacity: .6;
    color: #242c47;
}

.contact-form-holder textarea
{
    min-height: 120px;

    resize: none;

    border-radius: 20px;
}

.contact-form-holder input[type='submit']
{
    margin: 10px auto 0;

    cursor: pointer;
    text-transform: capitalize;

    border: none;
}

.contact-form-holder a
{
    text-decoration: underline;

    color: inherit;
}

.contact-form-holder .custom-checkbox + .custom-checkbox
{
    margin-top: 13px;
}

.accessibility
{
    position: absolute;
    top: 0;
    left: 0;

    overflow: hidden;

    width: 0;
    height: 0;
}

.accessibility:focus
{
    position: static;

    width: auto;
    height: auto;
}

@media (min-width: 768px)
{
    .two-columns
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    }

    .two-columns .content
    {
        width: 65%;
    }

    .two-columns .content:only-child
    {
        width: 100%;
    }

    .two-columns .sidebar
    {
        width: 35%;
        padding-left: 30px;
    }

    .two-columns .sidebar:only-child
    {
        width: 100%;
        padding: 0;
    }

    .commentlist-item .commentlist-item
    {
        padding: 0 0 0 32px;
    }

    .header
    {
        padding: 20px 0;
    }

    .header.scrolled .logo .logo-img
    {
        width: 60px;
    }

    .logo .logo-img
    {
        width: 80px;
    }

    .nav-opener
    {
        display: none;
    }

    .main-nav
    {
        font-weight: 400;

        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 30px;
    }

    .main-nav li + li
    {
        margin-top: 0;
    }

    body
    {
        font-size: 18px;
    }

    section
    {
        margin-bottom: 60px;
        padding: 40px 0;
    }

    .common-banner
    {
        padding: 200px 0 80px;
    }

    .logos-slider .slide
    {
        min-width: 180px;
        max-width: 200px;
    }

    .img-text-section .container
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 40px;
    }

    .img-text-section .img
    {
        width: 40%;
    }

    .img-text-section .img + .text
    {
        width: 55%;
    }

    .footer .footer-logo
    {
        margin: 0;
    }

    .footer-top .footer-links
    {
        display: block;
    }

    .footer-top .container
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .footer-top .footer-col
    {
        max-width: calc(25% - 10px);
        padding-top: 15px;
    }

    .footer-bottom .container
    {
        gap: 30px;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .banner-slider .slide
    {
        padding: 200px 0;
    }

    .banner-slider .slide h1
    {
        font-size: 64px;
    }

    .service-row .col
    {
        width: 50%;
        margin-bottom: 40px;
    }

    .service-card
    {
        font-size: 16px;
    }

    .service-card h3
    {
        font-size: 24px;

        margin-bottom: 24px;
    }

    .service-card .icon-hold
    {
        width: 60px;
        height: 60px;
    }

    .service-card .icon-hold .ico
    {
        dth: 30px;
    }

    .contact-form-holder
    {
        padding: 45px;
    }

    .contact-form-holder .custom-checkbox + .custom-checkbox
    {
        margin-top: 7px;
    }
}

@media (min-width: 1024px)
{
    .two-columns .content
    {
        width: 70%;
    }

    .two-columns .sidebar
    {
        width: 30%;
        padding-left: 50px;
    }

    h1,
    .h1
    {
        font-size: 44px;
    }

    h2,
    .h2
    {
        font-size: 40px;
    }

    h3,
    .h3
    {
        font-size: 30px;
    }

    h4,
    .h4
    {
        font-size: 24px;

        margin-bottom: 29px;
    }

    h5,
    .h5
    {
        font-size: 20px;

        margin-bottom: 18px;
    }

    .service-row .col
    {
        width: 33.3333%;
    }
}

@media (max-width: 1023px)
{
    iframe
    {
        width: 100%;
    }
}

@media (max-width: 767px)
{
    .navigation .page-numbers,
    .navigation-comments .page-numbers
    {
        padding: 0 3px;
    }

    .navigation .next,
    .navigation .prev,
    .navigation-comments .next,
    .navigation-comments .prev
    {
        padding: 4px;
    }

    .navigation-single .next a,
    .navigation-single .prev a
    {
        padding: 4px;
    }

    .nav-drop
    {
        position: absolute;
        top: 100%;
        right: 0;
        left: 0;

        visibility: hidden;

        padding: 40px 20px;

        -webkit-transition: opacity .3s ease-in-out, visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
                transition: opacity .3s ease-in-out, visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
                transition: transform .3s ease-in-out, opacity .3s ease-in-out, visibility .3s ease-in-out;
                transition: transform .3s ease-in-out, opacity .3s ease-in-out, visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
        -webkit-transform: translateX(100%);
            -ms-transform: translateX(100%);
                transform: translateX(100%);

        opacity: 0;
        background: #fff;
        box-shadow: 0 0 8px rgba(0, 0, 0, .1);
    }

    .nav-active .nav-drop
    {
        visibility: visible;

        -webkit-transform: translateX(0);
            -ms-transform: translateX(0);
                transform: translateX(0);

        opacity: 1;
    }

    h1,
    h2
    {
        font-size: 36px;
    }
}

@-webkit-keyframes bounce
{
    0%,
    20%,
    50%,
    80%,
    100%
    {
        -webkit-transform: translateX(-50%) translateY(0);
                transform: translateX(-50%) translateY(0);
    }

    40%
    {
        -webkit-transform: translateX(-50%) translateY(-10px);
                transform: translateX(-50%) translateY(-10px);
    }

    60%
    {
        -webkit-transform: translateX(-50%) translateY(-5px);
                transform: translateX(-50%) translateY(-5px);
    }
}

@keyframes bounce
{
    0%,
    20%,
    50%,
    80%,
    100%
    {
        -webkit-transform: translateX(-50%) translateY(0);
                transform: translateX(-50%) translateY(0);
    }

    40%
    {
        -webkit-transform: translateX(-50%) translateY(-10px);
                transform: translateX(-50%) translateY(-10px);
    }

    60%
    {
        -webkit-transform: translateX(-50%) translateY(-5px);
                transform: translateX(-50%) translateY(-5px);
    }
}