/*!
Theme Name: jswindow
Theme URI:
Author:
Author URI:
Description:
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: jswindow
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
    - Normalize
    - Box sizing
# Base
    - Typography
    - Elements
    - Links
    - Forms
## Layouts
# Components
    - Navigation
    - Posts and pages
    - Comments
    - Widgets
    - Media
    - Captions
    - Galleries
# plugins
    - Jetpack infinite scroll
# Utilities
    - Accessibility
    - Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! 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: 26px;
    -webkit-text-size-adjust: 100%;
}

/* Sections
     ========================================================================== */
@font-face {
    font-family: 'Source Sans Pro';
    src: url("assets/fonts/SourceSansPro-Regular.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Source Sans Pro';
    src: url("assets/fonts/SourceSansPro-Light.otf") format("opentype");
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'Source Sans Pro';
    src: url("assets/fonts/SourceSansPro-Semibold.otf") format("opentype");
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Source Sans Pro';
    src: url("assets/fonts/SourceSansPro-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
}

/**
 * Remove the margin in all browsers.
 */
body {
    margin: 0;
    font-size: 16px;
    line-height: 26px;
    font-weight: 400;
    letter-spacing: 0.02em;
    font-family: "Source Sans Pro", sans-serif;
    color: #4C545D;
}

/**
 * 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,
.h1 {
    font-size: 50px;
    line-height: 60px;
}

h2,
.h2 {
    font-size: 45px;
    line-height: 55px;
}

h3,
.h3 {
    font-size: 34px;
    line-height: 44px;
}

h4,
.h4 {
    font-size: 24px;
    line-height: 34px;
}

h5,
.h5 {
    font-size: 20px;
    line-height: 1.2;
}

h6,
.h6 {
    font-size: 18px;
    line-height: 1.2;
}

@media (max-width: 767.98px) {

    h1,
    .h1 {
        font-size: 30px;
        line-height: 40px;
    }

    h2,
    .h2 {
        font-size: 25px;
        line-height: 35px;
    }

    h3,
    .h3 {
        font-size: 22px;
        line-height: 32px;
    }

    h4,
    .h4 {
        font-size: 22px;
        line-height: 32px;
    }

    h5,
    .h5 {
        font-size: 18px;
        line-height: 1.2;
    }

    h6,
    .h6 {
        font-size: 16px;
        line-height: 1.2;
    }
}

ul,
ol {
    margin: 0;
}

ul ul,
ul ol,
ol ul,
ol ol {
    padding-left: 19px;
}

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

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

/**
 * 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;
    font-size: 1em;
}

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

/**
 * Remove the gray background on active links in IE 10.
 */
a {
    background-color: transparent;
    text-decoration: none;
    color: inherit;
}

a:focus,
a:visited {
    color: inherit;
}

a:hover {
    color: #97D700;
}


a.button:hover,
a.button:focus,
a.button:visited {
    border: 1px solid #97D700;
    background-color: #97D700;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted;
}

/**
 * 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;
    font-size: 1em;
}

/**
 * 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: -0.25em;
}

sup {
    top: -0.5em;
}

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

/**
 * Remove the border on images inside links in IE 10.
 */
img {
    border-style: none;
    vertical-align: top;
    max-width: 100%;
}

/* Forms
     ========================================================================== */
label {
    font-weight: 600;
}

.required {
    color: #B20000;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="search"],
input[type="url"],
textarea,
select {
    -webkit-appearance: none;
    -moz-appearance: none;
}

select::-ms-expand {
    display: none;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus {
    outline: none;
}

:focus {
    outline: none;
}

::-webkit-input-placeholder {
    color: inherit;
    opacity: 1;
    filter: alpha(opacity=100);
}

:-moz-placeholder {
    /* Firefox 18- */
    color: inherit;
    opacity: 1;
    filter: alpha(opacity=100);
}

::-moz-placeholder {
    /* Firefox 19+ */
    color: inherit;
    opacity: 1;
    filter: alpha(opacity=100);
}

:-ms-input-placeholder {
    color: inherit;
    opacity: 1;
    filter: alpha(opacity=100);
}

input[type="number"],
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="search"],
input[type="url"],
textarea,
select {
    border: 1px solid #4C545D;
    background-color: #fff;
    padding: 0 20px;
    max-width: 100%;
    font-size: 16px;
    letter-spacing: 0.02em;
    color: #4C545D;
    height: 45px;
    line-height: 43px;
    border-radius: 3px;
}

textarea {
    display: block;
    line-height: 26px;
    padding: 15px 20px;
    height: 140px;
    width: 100%;
}

button,
input[type="submit"],
input[type="button"] {
    display: inline-block;
    height: 44px;
    line-height: 42px;
    font-size: 18px;
    letter-spacing: 0.02em;
    color: #4C545D;
    padding: 0 20px;
    border: 1px solid #4C545D;
    background-color: #fff;
    border-radius: 3px;
    cursor: pointer;
}

button:hover,
input[type="submit"]:hover,
input[type="button"]:hover {
    border-color: transparent;
    background-color: #97D700;
    color: #4C545D;
}

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

button,
input,
optgroup,
select,
textarea {
    margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
    overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
    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 {
    border-style: none;
    padding: 0;
}

/**
 * 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: none;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
    padding: 0.35em 0.75em 0.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 {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal;
}

/**
 * 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;
    padding: 0;
}

/**
 * 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"] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

/**
 * 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 {
    -webkit-appearance: button;
    font: inherit;
}

/* 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;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
    box-sizing: inherit;
}

html {
    box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
    font-weight: 400;
    letter-spacing: 0.02em;
    margin: 0 0 30px;
}

p {
    margin-bottom: 24px;
    margin-top: 0;
}

dfn,
cite,
em,
i {
    font-style: italic;
}

blockquote {
    margin: 0 1.5em;
}

address {
    margin: 0 0 1.5em;
}

pre {
    background: #eee;
    font-family: "Courier 10 Pitch", courier, monospace;
    line-height: 1.6;
    margin-bottom: 1.6em;
    max-width: 100%;
    overflow: auto;
    padding: 1.6em;
}

code,
kbd,
tt,
var {
    font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
    border-bottom: 1px dotted #666;
    cursor: help;
}

mark,
ins {
    background: #fff9c0;
    text-decoration: none;
}

big {
    font-size: 125%;
}

/* Text meant only for screen readers. */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
    outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {
    /*rtl:ignore*/
    float: left;
    /*rtl:ignore*/
    margin-right: 1.5em;
    margin-bottom: 1.5em;
}

.alignright {
    /*rtl:ignore*/
    float: right;
    /*rtl:ignore*/
    margin-left: 1.5em;
    margin-bottom: 1.5em;
}

.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5em;
}

.text-center {
    text-align: center;
}

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

.text-right {
    text-align: right;
}

.text-green {
    color: #97D700;
}

.text-brown {
    color: #8C714C;
}

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

.container {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    max-width: 1184px;
    padding-left: 44px;
    padding-right: 44px;
}

.container-small {
    max-width: 960px;
}

.container-big {
    max-width: 1320px;
    padding-left: 0;
    padding-right: 0;
}

.video-wrap {
    position: relative;
    padding-bottom: 56.25%;
    overflow: hidden;
    width: 100%;
    height: 0;
}

.video-wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: scale(1.01);
    -moz-transform: scale(1.01);
    -ms-transform: scale(1.01);
    -o-transform: scale(1.01);
    transform: scale(1.01);
}

.jsw-tablet .video-wrap iframe {
    clip-path: inset(1px 1px);
}

.jsw-mobile .video-wrap iframe {
    clip-path: inset(1px 1px);
}

*.jswindow-button {
    display: inline-block;
    padding: 7px 20px;
    line-height: 28px;
    text-align: center;
    font-size: 18px;
    font-weight: 400;
    border-radius: 3px;
    border: 1px solid #4C545D;
    color: #4C545D;
    background-color: #fff;
    -webkit-transition: all 0.4s ease 0s;
    -moz-transition: all 0.4s ease 0s;
    -o-transition: all 0.4s ease 0s;
    transition: all 0.4s ease 0s;
    text-transform: capitalize;
}

*.jswindow-button svg {
    margin-left: 12px;
    vertical-align: middle;
}

*.jswindow-button:hover {
    border-color: transparent;
    background-color: #97D700;
    color: #4C545D;
}

*.jswindow-button.button-green {
    border-color: transparent;
    background-color: #97D700;
}

*.jswindow-button.button-green:hover {
    border: 1px solid #4C545D;
    background-color: #fff;
    color: #4C545D;
}

/*site-footer*/
.site-footer {
    position: relative;
    background-color: #fff;
}

.site-footer .footer-top {
    border-top: 2px solid #97D700;
    padding-top: 58px;
    padding-bottom: 60px;
}

.site-footer .footer-top .container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.site-footer .footer-top .footer-topleft {
    width: 60.7664234%;
}

.site-footer .footer-top .footer-topleft .footer-menu {
    padding-left: 0;
    list-style: none;
    margin-bottom: 40px;
}

.site-footer .footer-top .footer-topleft .footer-menu .menu-item {
    display: inline-block;
    vertical-align: top;
    margin-right: 27px;
}

.site-footer .footer-top .footer-topleft .footer-menu .menu-item:last-child {
    margin-right: 0;
}

.site-footer .footer-top .footer-topleft .footer-menu .menu-item a {
    font-size: 18px;
    line-height: 28px;
    font-weight: 700;
}

.site-footer .footer-top .footer-topleft .footer-menu .menu-item a:hover {
    color: #8C714C;
}

.site-footer .footer-top .footer-topleft .footer-contact {
    margin-bottom: 16px;
}

.site-footer .footer-top .footer-topleft .footer-contact .contact-item {
    display: inline-block;
    vertical-align: top;
    margin-right: 37px;
}

.site-footer .footer-top .footer-topleft .footer-contact .contact-item:last-child {
    margin-right: 0;
}

.site-footer .footer-top .footer-topleft .footer-contact .contact-item a:hover {
    color: #8C714C;
}

.site-footer .footer-top .footer-topright {
    width: 39.2335766%;
    text-align: right;
    font-size: 0;
}

.site-footer .footer-top .footer-topright img {
    margin-right: 30px;
    width: 79px;
}

.site-footer .footer-top .footer-topright img:last-child {
    margin-right: 0;
    width: 149px;
}

.site-footer .footer-bottom {
    background-color: #F2F1F0;
    padding-top: 20px;
    padding-bottom: 20px;
}

.site-footer .footer-bottom .container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.site-footer .footer-bottom .footer-socials {
    width: 50%;
    font-size: 0;
}

.site-footer .footer-bottom .footer-socials a {
    display: inline-block;
    vertical-align: top;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    background-color: #4C545D;
    -webkit-transition: all 0.4s ease 0s;
    -moz-transition: all 0.4s ease 0s;
    -o-transition: all 0.4s ease 0s;
    transition: all 0.4s ease 0s;
    margin-right: 16px;
}

.site-footer .footer-bottom .footer-socials a:last-child {
    margin-right: 0;
}

.site-footer .footer-bottom .footer-socials a img {
    vertical-align: middle;
}

.site-footer .footer-bottom .footer-socials a:hover {
    background-color: #97D700;
}

.site-footer .footer-bottom .footer-copyright {
    width: 50%;
    text-align: right;
    font-size: 12px;
    line-height: 22px;
}

a.backtotop {
    position: absolute;
    bottom: 130px;
    right: 60px;
    z-index: 99;
    display: flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    border: 1px solid #97D700;
    border-radius: 3px;
    background-color: #fff;
}

a.backtotop:hover {
    background-color: #97D700;
}

a.backtotop:hover path {
    stroke: #fff;
}

.chaty .chaty-widget {
    right: 36px !important;
    /*bottom: -22px !important;*/
}

.chaty .on-hover-text {
    display: none !important;
}

.chaty .channel-icon-Whatsapp .color-element {
    fill: #97D700 !important;
    color: #97D700 !important;
}

.chaty-widget .chaty-channel-list .chaty-channel {
    opacity: 1;
}

#chaty-widget-0 .chaty-channel-list .chaty-channel:nth-child(1) {
    -webkit-transform: translateY(-124px);
    transform: translateY(-124px);
}

#chaty-widget-0 .chaty-channel-list .chaty-channel:nth-child(2) {
    -webkit-transform: translateY(-62px);
    transform: translateY(-62px);
}

.chaty-widget .chaty-channel-list {
    pointer-events: auto;
}

/* .chaty-i-trigger {
    display: none;
} */

.jsw-desktop .chaty-i-trigger .chaty-channel {
    bottom: 50px;
}

@media (max-width: 767.98px) {
    .chaty .chaty-widget {
        right: 26px !important;
        /*bottom: -32px !important;*/
    }

    .site-footer .footer-top {
        padding-top: 38px;
        padding-bottom: 40px;
    }

    .site-footer .footer-top .footer-topleft {
        width: 100%;
    }

    .site-footer .footer-top .footer-topleft .footer-menu .menu-item {
        display: block;
        margin-right: 0;
        margin-bottom: 16px;
    }

    .site-footer .footer-top .footer-topleft .footer-menu .menu-item:last-child {
        margin-bottom: 0;
    }

    .site-footer .footer-top .footer-topleft .footer-contact .contact-item {
        display: block;
        margin-right: 0;
        margin-bottom: 16px;
    }

    .site-footer .footer-top .footer-topleft .footer-contact .contact-item:last-child {
        margin-bottom: 0;
    }

    .site-footer .footer-top .footer-topright {
        width: 100%;
        margin-top: 40px;
        text-align: center;
    }

    .site-footer .footer-bottom .footer-socials {
        width: 100%;
        text-align: center;
    }

    .site-footer .footer-bottom .footer-copyright {
        width: 100%;
        margin-top: 16px;
        text-align: center;
    }

    a.backtotop {
        top: 40px;
        bottom: auto;
        right: 44px;
    }
}

/*site-header*/
.site-header.header-bg .header-wrap {
    background-color: #fff;
}

.site-header.header-fixed .header-wrap {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 99999;
}

.admin-bar .site-header.header-fixed .header-wrap {
    top: 32px;
}

.site-header .header-container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 30px 60px;
    width: 100%;
    max-width: 1320px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

.site-header .header-height {
    height: 100px;
}

.site-header .header-logo img {
    max-height: 40px;
}

.site-header .primary-menu {
    padding-left: 0;
}

.site-header .primary-menu .carets {
    display: none;
}

.site-header .primary-menu .menu-item {
    list-style: none;
    position: relative;
}

.site-header .primary-menu .menu-item a {
    -webkit-transition: all 0.4s ease 0s;
    -moz-transition: all 0.4s ease 0s;
    -o-transition: all 0.4s ease 0s;
    transition: all 0.4s ease 0s;
    color: #4C545D;
}

.site-header .button-menu {
    display: none;
}

@media (min-width: 1025px) {
    .site-header.header-light:not(.header-bg) .header-logo img {
        filter: brightness(0) invert(1);
    }

    .site-header.header-light:not(.header-bg) .primary-menu>.menu-item>a {
        color: #fff;
    }

    .site-header.header-light:not(.header-bg) .primary-menu>.menu-item.current-menu-item>a,
    .site-header.header-light:not(.header-bg) .primary-menu>.menu-item:hover>a {
        color: rgba(255, 255, 255, 0.8);
    }

    .site-header.header-light .header-height {
        display: none;
    }

    .site-header:not(.header-light):not(.header-bg) .header-container {
        border-bottom: 1px solid #DFDEDE;
    }

    .site-header .primary-menu .menu-item {
        font-size: 18px;
        line-height: 28px;
    }

    .site-header .primary-menu>.menu-item.current-menu-item>a,
    .site-header .primary-menu>.menu-item:hover>a {
        color: #8C714C;
    }

    .site-header .primary-menu .sub-menu .menu-item:hover>a {
        color: #97D700;
    }

    .site-header .primary-menu .sub-menu {
        position: absolute;
        top: calc(100% + 17px);
        left: -6px;
        border-top: 1px solid #8C714C;
        padding: 20px 0;
        background-color: #fff;
        z-index: 1;
        min-width: 248px;
        text-align: left;
        opacity: 0;
        visibility: hidden;
        -webkit-transition: all 0.25s ease 0s;
        -moz-transition: all 0.25s ease 0s;
        -o-transition: all 0.25s ease 0s;
        transition: all 0.25s ease 0s;
    }

    .site-header .primary-menu .menu-item:hover>.sub-menu {
        opacity: 1;
        visibility: visible;
    }

    .site-header .primary-menu>.menu-item:hover>.sub-menu::before {
        content: '';
        position: absolute;
        top: -20px;
        left: 0;
        width: 100%;
        height: 20px;
        z-index: 1;
    }

    .site-header .primary-menu>.menu-item {
        display: inline-block;
        line-height: 40px;
        margin-right: 20px;
    }

    .site-header .primary-menu>.menu-item:last-child {
        margin-right: 0;
    }

    .site-header .primary-menu .sub-menu .menu-item {
        margin-bottom: 20px;
    }

    .site-header .primary-menu .sub-menu .menu-item:last-child {
        margin-bottom: 0;
    }

    .site-header .primary-menu .sub-menu .menu-item a {
        padding: 0 20px;
        display: block;
    }

    .site-header .primary-menu .sub-menu .sub-menu {
        top: -21px;
        left: 100%;
    }
}

@media (max-width: 1024px) {
    .site-header .header-container {
        padding: 22px 44px;
    }

    .site-header .header-height {
        height: 84px;
    }

    .site-header.header-fixed .header-wrap {
        background-color: #fff;
    }

    .site-header .primary-menu {
        width: 100%;
        background-color: #fff;
        position: absolute;
        top: 100%;
        left: 0;
        padding: 0 30px;
        max-height: calc(100vh - 84px);
        overflow-y: auto;
        opacity: 0;
        visibility: hidden;
        -webkit-transition: all 0.4s ease 0s;
        -moz-transition: all 0.4s ease 0s;
        -o-transition: all 0.4s ease 0s;
        transition: all 0.4s ease 0s;
    }

    .site-header .primary-menu {
        max-height: calc(100vh - 170px);
    }

    .site-header .primary-menu .carets {
        position: absolute;
        top: 0;
        right: 0;
        height: 50px;
        line-height: 50px;
        width: 24px;
        text-align: center;
        z-index: 1;
        display: block;
        cursor: pointer;
    }

    .site-header .primary-menu .carets svg {
        -webkit-transition: all 0.4s ease 0s;
        -moz-transition: all 0.4s ease 0s;
        -o-transition: all 0.4s ease 0s;
        transition: all 0.4s ease 0s;
    }

    .site-header .primary-menu .show-sub .carets svg {
        -webkit-transform: rotate(90deg);
        -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        -o-transform: rotate(90deg);
        transform: rotate(90deg);
    }

    .site-header .primary-menu .menu-item {
        border-bottom: 1px solid #DFDEDE;
        line-height: 49px;
    }

    .site-header .primary-menu .menu-item.show-sub,
    .site-header .primary-menu>.menu-item:last-child {
        border-bottom: none;
    }

    .site-header .primary-menu .sub-menu {
        border-top: 1px solid #DFDEDE;
        display: none;
        padding-left: 30px;
    }

    .site-header .primary-menu .menu-item.show-sub>a,
    .site-header .primary-menu .menu-item a:hover {
        color: #8C714C;
    }

    .site-header .header-logo {
        width: 100%;
        text-align: center;
    }

    .site-header .button-menu {
        position: absolute;
        top: 50%;
        right: 44px;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        -o-transform: translateY(-50%);
        transform: translateY(-50%);
        width: 24px;
        height: 24px;
        display: block;
    }

    .menu-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: rgba(0, 0, 0, 0.8);
        z-index: 998;
        display: none;
    }

    body.open-menu {
        overflow: hidden;
    }

    body.open-menu .primary-menu {
        opacity: 1;
        visibility: visible;
    }

    body.open-menu .menu-overlay {
        display: block;
    }
}

@media (max-width: 782px) {
    .admin-bar .site-header.header-fixed .header-wrap {
        top: 46px;
    }
}

@media (min-width: 768px) {

    .page-template-template-solutions .main-cta,
    .solutions-template-default .main-cta {
        padding-bottom: 160px;
    }

    .home .main-cta:last-child {
        padding-bottom: 160px;
    }
}

@media (max-width: 767.98px) {
    .site-header .header-container {
        padding: 22px 20px;
    }

    .site-header .button-menu {
        right: 30px;
    }
}

/*main-banner*/
.main-banner .banner-parallax .banner-fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
}

.admin-bar .main-banner .banner-parallax .banner-fixed {
    top: 32px;
}

.main-banner>.image:not(.banner-parallax) {
    padding-bottom: 0;
}

.main-banner [data-aos="line-scale"] {
    transition: all .5s cubic-bezier(.455, .03, .515, .955);
    transform: scaleX(0);
}

.main-banner [data-aos="line-scale"].aos-animate {
    transform: scaleX(1);
}

.main-banner .image {
    padding-bottom: 600px;
    position: relative;
    background-position: center;
    background-size: cover;
}

.main-banner .image.image-mobile {
    display: none;
}

.main-banner .banner-info {
    background-color: #fff;
    padding-bottom: 180px;
    position: relative;
}

.main-banner .border-green+* {
    margin-top: 60px;
}

.main-banner .banner-item+.banner-item {
    padding-top: 180px;
}

.main-banner .banner-item h3.subtitle {
    margin-bottom: 16px;
}

.main-banner h1.subtitle,
.main-banner h2.subtitle {
    font-family: 'Roboto', sans-serif;
}

.main-banner .title {
    font-family: 'Roboto', sans-serif;
    padding-top: 55px;
    padding-bottom: 55px;
    margin: 0;
}

.main-banner .scroll-down {
    position: absolute;
    bottom: 53px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 2;
}

.main-banner .scroll-down svg {
    vertical-align: top;
}

.main-banner #scroll-down {
    position: absolute;
    bottom: 99px;
}

@media (max-width: 1319px) {
    .main-banner .image {
        padding-bottom: 45.4545455%;
    }
}

@media (max-width: 1024px) {
    .main-banner .banner-parallax .banner-fixed {
        top: 84px;
    }

    .admin-bar .main-banner .banner-parallax .banner-fixed {
        top: 116px;
    }
}

@media (max-width: 991px) {
    .main-banner .banner-item h3.subtitle {
        margin-bottom: 20px;
    }

    .main-banner #scroll-down {
        bottom: 83px;
    }
}

@media (max-width: 767.98px) {

    .main-banner .border-green+* {
        margin-top: 30px;
    }

    .main-banner .banner-info {
        padding-bottom: 80px;
    }

    .home-info .info-item {
        padding-bottom: 80px;
    }

    .main-banner .banner-item+.banner-item {
        padding-top: 80px;
    }

    .home-list {
        padding-bottom: 80px;
    }

    .main-banner .title {
        padding-top: 30px;
        padding-bottom: 30px;
    }

    .main-banner .image {
        padding-bottom: 100%;
    }

    .main-banner .image.image-desktop {
        display: none;
    }

    .main-banner .image.image-mobile {
        display: block;
    }

    .main-banner .subtitle br {
        /* display: none; */
    }

    .main-banner .scroll-down {
        bottom: 27px;
    }

    .main-banner .banner-info .desc {
        text-align: justify;
    }

    .main-banner .banner-info .desc br {
        display: none;
    }
}

/*home-info*/
.home-info {
    background-color: #fff;
    position: relative;
}

.home-info .info-item {
    padding-bottom: 180px;
}

.home-info .info-item .image {
    margin-bottom: 80px;
}

.home-info .info-item .image-wrap {
    position: relative;
    padding-bottom: 56.1926606%;
}

.home-info .info-item .image-wrap img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.home-info .info-item .title {
    margin-bottom: 16px;
}

.home-info .info-item .desc {
    text-align: justify;
}

@media (max-width: 991px) {
    .home-info .info-item .title {
        margin-bottom: 20px;
        text-align: center;
    }
}

/*home-testimonial*/
.home-testimonial {
    background-color: #fff;
    position: relative;
}

.home-testimonial .text-center {
    padding-bottom: 180px;
}

.home-testimonial .testimonial-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding-bottom: 180px;
}

.home-testimonial .testimonial-item .image {
    width: 40.1376147%;
}

.home-testimonial .testimonial-item .image-wrap {
    position: relative;
    padding-bottom: 185.7142857%;
}

.home-testimonial .testimonial-item .image-wrap img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.home-testimonial .testimonial-item .testimonial-info {
    width: 59.8623853%;
    padding-left: 60px;
}

.home-testimonial .testimonial-item .name {
    margin-top: 16px;
}

.home-testimonial .testimonial-item .desc {
    text-align: justify;
}

@media (max-width: 991px) {
    .home-testimonial .text-center {
        padding-bottom: 80px;
    }

    .home-testimonial .testimonial-item .testimonial-info {
        padding-left: 30px;
    }
}

@media (max-width: 767.98px) {
    .home-testimonial .testimonial-item {
        text-align: center;
    }

    .home-testimonial .testimonial-item .image {
        width: 100%;
    }

    .home-testimonial .testimonial-item .image-wrap {
        padding-bottom: 185.4304636%;
    }

    .home-testimonial .testimonial-item .testimonial-info {
        width: 100%;
        padding-left: 0;
        padding-top: 30px;
    }

    .home-testimonial .testimonial-item .name {
        text-align: left;
    }

    .home-testimonial .testimonial-item {
        padding-bottom: 80px;
    }

    .solution-service {
        padding-bottom: 80px;
    }
}

/*.home-list*/
.home-list {
    padding-bottom: 180px;
    background-color: #fff;
    position: relative;
}

.home-list .list-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding-bottom: 60px;
}

.home-list .list-item:last-child {
    padding-bottom: 0;
}

.home-list .list-item .video {
    width: 48.9051095%;
}

.home-list .list-item .list-info {
    width: 51.0948905%;
    padding-left: 60px;
}

.home-list .list-item .list-info .title {
    margin-bottom: 16px;
}

.home-list .list-item .list-info .desc {
    text-align: justify;
}

@media (max-width: 991px) {


    .home-list .list-item {
        padding-bottom: 80px;
    }

    .home-list .list-item .video {
        width: 100%;
    }

    .home-list .list-item .list-info {
        width: 100%;
        padding-left: 0;
        padding-top: 30px;
    }

    .home-list .list-item .list-info .title {
        margin-bottom: 20px;
        text-align: center;
    }
}

/*.main-cta*/
.main-cta {
    padding-bottom: 160px;
    background-color: #fff;
    position: relative;
}

.main-cta .title {
    margin-bottom: 16px;
}

.main-cta .main-cta-wrap {
    padding-top: 180px;
}

.main-cta .main-cta-wrap:first-child {
    padding-top: 0;
}

.main-cta .main-cta-wrap+.cta-button {
    padding-top: 180px;
}

.jsw-tablet .main-cta .main-cta-wrap+.cta-button {
    padding-top: 180px;
}

.jsw-mobile .main-cta .main-cta-wrap+.cta-button {
    padding-top: 80px;
}

.main-cta .cta-button+.cta-button {
    margin-top: 80px;
}

@media (max-width: 991px) {
    .main-cta {
        padding-bottom: 60px;
    }

    .main-cta .title {
        margin-bottom: 20px;
    }

    .main-cta .desc-wrap {
        padding-bottom: 80px;
        text-align: justify;
    }

    .main-cta .main-cta-wrap+.cta-button {
        padding-top: 80px;
    }


}

/*.solution-listing*/
.solution-listing {
    padding-bottom: 180px;
    position: relative;
    background-color: #fff;
}

.solution-listing .title {
    margin-bottom: 0;
}

.solution-listing .title+.solution-wrap {
    margin-top: 60px;
}

.solution-listing .content {
    margin-bottom: 60px;
    max-width: 872px;
    margin-left: auto;
    margin-right: auto;
}

.solution-listing .title+.content {
    margin-top: 30px;
}

.solution-listing .solution-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding-bottom: 60px;
}

.solution-listing .solution-item:last-child {
    padding-bottom: 0;
}

.solution-listing .solution-item .image {
    width: 48.9051095%;
    overflow: hidden;
}

.solution-listing .solution-item .image-wrap {
    position: relative;
    padding-bottom: 55.9701493%;
    display: block;
}

.solution-listing .solution-item.square .image-wrap {
    padding-bottom: 100%;
}

.solution-listing .solution-item .image-wrap img {
    -webkit-transition: -webkit-transform .3s cubic-bezier(.4, 0, 1, 1);
    -moz-transition: -moz-transform .3s cubic-bezier(.4, 0, 1, 1);
    -o-transition: -o-transform .3s cubic-bezier(.4, 0, 1, 1);
    transition: transform .3s cubic-bezier(.4, 0, 1, 1);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.solution-listing .solution-item .image-wrap:hover img {
    -webkit-transform: scale(1.05) translateZ(0);
    -moz-transform: scale(1.05) translateZ(0);
    -o-transform: scale(1.05) translateZ(0);
    transform: scale(1.05) translateZ(0);
}

.solution-listing .solution-item .solution-info {
    width: 51.0948905%;
    padding-left: 60px;
}

.solution-listing .solution-item .solution-title {
    margin-bottom: 0;
    padding-bottom: 16px;
    position: relative;
}

.solution-listing .solution-item .solution-title::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 200px;
    border-bottom: 1px solid #97D700;
}

.solution-listing .solution-item .desc {
    text-align: justify;
    margin-top: 16px;
}

@media (max-width: 991px) {

    .solution-listing .solution-item {
        text-align: center;
    }

    .solution-listing .solution-item .image {
        width: 100%;
    }

    .solution-listing .solution-item .solution-info {
        width: 100%;
        padding-left: 0;
        padding-top: 20px;
    }

    .solution-listing .solution-item .solution-title {
        font-size: 20px;
        padding-bottom: 20px;
    }

    .solution-listing .solution-item .solution-title::before {
        margin: 0 auto;
        right: 0;
    }

    .solution-listing .solution-item .desc {
        margin-top: 20px;
        margin-bottom: 20px;
    }

    .solution-listing .solution-item:last-child .desc {
        margin-bottom: 0;
    }

    .solution-listing .title+.solution-wrap {
        margin-top: 30px;
    }

    .solution-listing .content {
        margin-bottom: 60px;
    }

    .single-solutions .solution-listing .title {
        font-size: 22px;
        line-height: 35px;
    }
}

/*solution-service*/
.solution-service {
    padding-bottom: 180px;
    position: relative;
    background-color: #fff;
}

.solution-service .title {
    margin-bottom: 0;
}

.solution-service .title+* {
    margin-top: 30px;
}

.solution-service .content+.service-wrap {
    margin-top: 60px;
}

.solution-service .content {
    max-width: 872px;
    margin-left: auto;
    margin-right: auto;
}

.solution-service .content p:last-child {
    margin-bottom: 0;
}

.solution-service .service-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
}

.solution-service .service-wrap .service-item {
    width: calc(20% - 39px);
    position: relative;
}

.solution-service .service-wrap .service-item .service-inner {
    background-color: #F2F1F0;
    border-radius: 10px;
    text-align: center;
    height: 100%;
    padding: 14px 16px 24px;
}

.solution-service .service-wrap .service-item .image {
    margin-bottom: 20px;
    background: #fff;
}

.solution-service .service-wrap .service-item .image-wrap {
    position: relative;
    padding-bottom: 100%;
}

.solution-service .service-wrap .service-item .image-wrap img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.solution-service .service-wrap .service-item svg {
    position: absolute;
    top: 50%;
    right: -37px;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
}

.solution-service .service-wrap .service-item:last-child svg {
    display: none;
}

@media (max-width: 991px) {


    .solution-service .service-wrap {
        flex-direction: column;
        justify-content: center;
        gap: 64px;
    }

    .solution-service .service-wrap .service-item {
        width: 214px;
        margin: 0 auto;
    }

    .solution-service .service-wrap .service-item svg {
        top: calc(100% + 20px);
        right: 50%;
        -webkit-transform: translateX(50%) rotate(90deg);
        -moz-transform: translateX(50%) rotate(90deg);
        -ms-transform: translateX(50%) rotate(90deg);
        -o-transform: translateX(50%) rotate(90deg);
        transform: translateX(50%) rotate(90deg);
    }

    .solution-service .service-wrap .service-item .service-inner {
        padding-top: 16px;
    }

    .solution-service .service-wrap .service-item .image {
        padding: 18px;
    }

    .solution-service .service-wrap .service-item .desc {
        text-align: left;
        min-height: 130px;
    }
}

.pp_nav .currentTextHolder {
    display: none;
}

/* --fix-bug: Update styles */
@media (max-width: 1024px) and (min-width: 768px) {
    /* Update padding on Suntech */
    .page-template-template-suntech .main-cta,
    .page-template-template-renson .main-cta,
    .page-template-template-secco .main-cta,
    .page-template-template-aliplast .main-cta {
        padding-bottom: 160px;
    }
}

.jsw-tablet .main-banner .banner-info,
.jsw-tablet .home-info .info-item,
.jsw-tablet .home-testimonial .testimonial-item,
.jsw-tablet .home-list,
.jsw-tablet .solution-listing,
.jsw-tablet .solution-service {
    padding-bottom: 180px;
}
/* --end-fix-bug: Update styles */

/* --fix-bug: Update styles - 13/05/2024 */
.content-post-item-description .responsiveIframe iframe {
    position: static;
}

.content-post-item-description .responsiveIframe {
    padding-bottom: 100px;
}

.jsw-mobile .content-post-item-description .responsiveIframe {
    padding-bottom: 60px;
}
/* Style for tablet */
.jsw-tablet .home-info .info-item .image {
    margin-bottom: 80px;
}

.jsw-tablet .main-banner .banner-item+.banner-item {
    padding-top: 180px;
}

.jsw-tablet .main-cta {
    padding-bottom: 160px;
}

.jsw-tablet .projects-page .main-cta {
    padding-bottom: 0;
}

.page-template-template-suntech.jsw-tablet .main-cta,
.page-template-template-renson.jsw-tablet .main-cta,
.page-template-template-secco.jsw-tablet .main-cta,
.page-template-template-aliplast.jsw-tablet .main-cta {
    padding-bottom: 160px;
}

/* Style for mobile */
.jsw-mobile .home-info .info-item .image {
    margin-bottom: 40px;
}

.jsw-mobile .home-list .list-item .list-info,
.jsw-mobile .home-testimonial .testimonial-item .testimonial-info {
    padding-top: 40px;
}

.jsw-mobile .main-cta {
    padding-bottom: 60px;
}
/* --end-fix-bug: Update styles */

/* --start: Update 15/05/2025 */
.home.jsw-mobile .main-banner .banner-info,
.page-template-template-solutions.jsw-mobile .main-banner .banner-info,
.home.jsw-mobile .home-info .info-item,
.jsw-mobile .home-info .info-item,
.home.jsw-mobile .home-testimonial .testimonial-item,
.jsw-mobile .home-testimonial .testimonial-item,
.home.jsw-mobile .home-list,
.jsw-mobile .home-list,
.page-template-template-solutions.jsw-mobile .solution-listing,
.solution-listing,
.page-template-template-solutions.jsw-mobile .solution-service,
.solution-service {
    padding-bottom: 180px;
}

.jsw-mobile .main-cta {
    padding-bottom: 60px;
}
.home.jsw-mobile .main-cta,
.page-template-template-solutions.jsw-mobile .main-cta {
    padding-bottom: 160px;
}
/* --end: Update 15/05/2025 */

@media (max-width: 767.98px) {
    .solution-listing {
        padding-bottom: 80px;
    }
}
/* Likely mobile: coarse pointer, no hover (touch screen) */
@media (pointer: coarse) and (hover: none) {
    /* CSS for phones */
    .main-banner .banner-info,
    .home-info .info-item,
    .home-testimonial .testimonial-item,
    .home-list,
    .solution-listing,
    .solution-service {
        padding-bottom: 80px;
    }
}

.single-solutions.jsw-mobile .main-cta .main-cta-wrap {
    padding-top: 80px;
}

.single-solutions.jsw-mobile .main-cta .main-cta-wrap:first-child {
    padding-top: 0;
}