/*!
Theme Name: gg_starter
Theme URI: http://underscores.me/
Author: growwgenie
Author URI: https://growwgenie.com/
Description: Reusable starter theme
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: gg_starter
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.

gg_starter is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

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

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

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

/* 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;
    font-size: 100%;
    line-height: 1.15;
    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"] {
    appearance: button;
    -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: 1px dotted ButtonText;
}

/**
 * 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"] {
    appearance: textfield;
    -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
--------------------------------------------------------------*/

:root {
    --gg-color-primary: #ED1C24;
    --gg-color-accent: #ffc107;
    --gg-container-width: 1400px;
}

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
    font: normal normal normal 18px/27px Barlow;
    color: #333;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    clear: both;
    font-family: 'Barlow', sans-serif;
}

p {
    margin-bottom: 1.5em;
}

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%;
}

/* Elements
--------------------------------------------- */
body {
    background: #fff;
}

hr {
    background-color: #ccc;
    border: 0;
    height: 1px;
    margin-bottom: 1.5em;
}

ul,
ol {
    margin: 0 0 1.5em 1.5em;
    padding: 0;
}

ul {
    list-style: disc;
}

ol {
    list-style: decimal;
}

li>ul,
li>ol {
    margin-bottom: 0;
    margin-left: 1.5em;
}

dt {
    font-weight: 700;
}

dd {
    margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
    max-width: 100%;
}

img,
video {
    height: auto;
    max-width: 100%;
}

figure {
    margin: 1em 0;
}

table {
    margin: 0 0 1.5em;
    width: 100%;
}

/* Links
--------------------------------------------- */
a {
    color: var(--gg-color-primary)
}

a:visited {
    color: var(--gg-color-primary)
}

a:hover,
a:focus,
a:active {
    color: var(--gg-color-primary)
}

a:focus {
    outline: thin dotted;
}

a:hover,
a:active {
    outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
    border: 1px solid;
    border-color: #ccc #ccc #bbb;
    border-radius: 3px;
    background: #e6e6e6;
    color: rgba(0, 0, 0, 0.8);
    line-height: 1;
    padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
    border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
    border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
    color: #666;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
    color: #111;
}

select {
    border: 1px solid #ccc;
    background: url("data:image/svg+xml,<svg height='10px' width='10px' viewBox='0 0 16 16' fill='%23000000' xmlns='http://www.w3.org/2000/svg'><path d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/></svg>") no-repeat;
    background-position: calc(100% - 0.75em) center !important;
    -moz-appearance: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    padding-right: 1.5em !important;
}

textarea {
    width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
    display: block;
    width: 100%;
}

.main-navigation ul {
    display: none;
    list-style: none;
    margin: 0;
    padding-left: 0;
}

.main-navigation ul ul {
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
    float: left;
    position: absolute;
    top: 100%;
    left: -999em;
    z-index: 99999;
}

.main-navigation ul ul ul {
    left: -999em;
    top: 0;
}

.main-navigation ul ul li:hover>ul,
.main-navigation ul ul li.focus>ul {
    display: block;
    left: auto;
}

.main-navigation ul ul a {
    width: 200px;
}

.main-navigation ul li:hover>ul,
.main-navigation ul li.focus>ul {
    left: auto;
    display: block;
    background: #fff;
    border-top: solid 2px var(--gg-color-primary);
}

.main-navigation li {
    position: relative;
}

.main-navigation .sub-menu li {
    padding: 7px 10px 10px;
}

.main-navigation .sub-menu li a {
    color: #333;
}

.main-navigation a {
    display: block;
    text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
    display: block;
}

@media screen and (min-width: 768px) {

    .menu-toggle {
        display: none;
    }

    .main-navigation ul {
        display: flex;
        flex-wrap: wrap;
    }
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
    margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
    display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
    flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
    text-align: end;
    flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
    display: block;
}

.post,
.page {
    margin: 0;
}

.updated:not(.published) {
    display: none;
}

.page-content,
.entry-content,
.entry-summary {
    margin: 1.5em 0 0;
}

.page-links {
    clear: both;
    margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
    word-wrap: break-word;
}

.bypostauthor {
    display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
    margin: 0 0 1.5em;
}

.widget select {
    max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
    border: none;
    margin-bottom: 0;
    margin-top: 0;
    padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
    display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
    margin-bottom: 1.5em;
    max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption .wp-caption-text {
    margin: 0.8075em 0;
}

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

/* Galleries
--------------------------------------------- */
.gallery {
    margin-bottom: 1.5em;
    display: grid;
    grid-gap: 1.5em;
}

.gallery-item {
    display: inline-block;
    text-align: center;
    width: 100%;
}

.gallery-columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
    grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
    grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
    grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
    grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
    grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
    grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
    display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
    display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
    display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

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

/* common */

h1 {
    font: normal normal 600 36px/50px Barlow;
    color: #333;
}

h2 {
    font: normal normal bold 28px/36px Barlow;
    color: #333;
}

h3 {
    font: normal normal bold 24px/35px Barlow;
    color: #333;
}

.container-gg {
    max-width: var(--gg-container-width);
}

lite-vimeo[reel],
lite-youtube[reel] {
    padding-bottom: calc(100% / (9 / 16));
    border-radius: 10px;
}

.gform_required_legend {
    display: none;
}

.gg-btn {
    font-family: Barlow;
    font-size: 20px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    padding: 10px 20px;
    background: var(--gg-color-primary);
    color: #fff;
    border: 0;
    border-radius: 4px;
    box-shadow: 0px 4px 4px 0px #00000040;
}

.gg-btn:hover,
.gg-btn:focus,
.gg-btn:active,
.gg-btn:visited {
    background: var(--gg-color-primary);
    text-decoration: none;
    color: #fff;
}

.gg-btn.white {
    background: #fff;
    color: #272727;
}

.gg-btn-outline,
.gg-btn-outline:active,
.gg-btn-outline:focus {
    font-family: Barlow;
    font-size: 20px;
    font-weight: 400;
    line-height: 30px;
    text-align: center;
    padding: 5px 10px;
    background: #fff;
    color: var(--gg-color-primary);
    border: solid 2px var(--gg-color-primary);
    border-radius: 0;
}

.gg-btn-outline:hover {
    text-decoration: none;
    background: var(--gg-color-primary);
    color: #fff;
}

@media screen and (max-width: 992px) {
    h1 {
        font: normal normal 600 28px/38px Barlow;
    }

    h2 {
        font: normal normal bold 24px/35px Barlow;
    }

    h3 {
        font: normal normal bold 20px/30px Barlow;
    }
}

/* header start */

header#masthead {
    width: 100%;
    background: transparent;
    z-index: 999;
    box-shadow: none;
}

header#masthead.active {
    background: #fff 0% 0% no-repeat padding-box;
    box-shadow: 0px 6px 20px #bfbfbf;
}

.admin-bar #masthead.active {
    top: var(--wp-admin--admin-bar--height);
}

.site-branding .custom-logo-link img {
    padding: 16px 0;
    transition: all .7s ease;
    max-height: calc(90px + 32px);
    width: auto;
}

header#masthead.active .site-branding .custom-logo-link img {
    max-height: 100px;
}

.nav-close {
    display: none;
}

.header-icons {
    display: flex;
    align-items: center;
}

.main-navigation .header-icons a {
    color: var(--gg-color-primary);
}

.main-navigation .header-icons a svg {
    width: 28px;
    height: 28px;
}

nav#site-navigation {
    display: flex;
    align-items: center;
}

.main-navigation ul {
    justify-content: start;
}

.main-navigation li {
    transition: all .7s ease;
    padding: 15px 10px;
}

.main-navigation li.menu-item-has-children {
    padding: 15px 15px;
}

.main-navigation a:not(.gg-btn) {
    font: normal normal 500 18px/22px Barlow;
    color: #333;
    position: relative;
    display: inline-block;
    padding: 0 5px;
}

.main-navigation li:hover>a::after,
.main-navigation li.current-menu-parent>a::after,
.main-navigation li.current-menu-item>a::after {
    content: '';
    width: 100%;
    height: 2px;
    position: absolute;
    left: 0%;
    top: 0px;
    background: var(--gg-color-primary);
}

.main-navigation .sub-menu li:hover>a {
    color: var(--gg-color-primary);
}

.main-navigation .sub-menu li>a::after {
    display: none;
}

.main-navigation li.current-menu-item>a {
    color: var(--gg-color-primary);
}

.main-navigation .sub-menu li.current-menu-item>a {
    color: var(--gg-color-primary);
}

.main-navigation li.menu-item-has-children>a::before {
    content: ' \25BE';
    position: absolute;
    left: 100%;
    top: 0;
    margin-left: 0;
    font-family: sans-serif;
}

.main-navigation li.menu-item-has-children:hover>a::before,
.main-navigation li.menu-item-has-children.focus>a::before {
    transform: rotate(180deg);
    color: var(--gg-color-primary);
}

.main-navigation-holder {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.main-navigation-part-top {
    padding: 15px 0 0;
    display: flex;
}

.main-navigation-part-top a:not(.gg-btn) {
    color: #333;
    position: relative;
}

.main-navigation-part-top .gg-btn {
    color: #fff;
}

.main-navigation-part-top-links a {
    display: inline-block;
    margin: 0 15px;
}

.main-navigation-part-top-links a:not(:last-child)::after {
    content: '';
    height: 20px;
    position: absolute;
    width: 2px;
    background: #333;
    right: -18px;
    top: 5px;
}

/* search start */

.gg-searchbar {
    position: absolute;
    width: 0%;
    height: 100%;
    z-index: 1;
    overflow: hidden;
    transition: 0.3s ease;
    right: 0;
    top: 0;
    opacity: 0;
}

.search_open .gg-searchbar {
    opacity: 1;
    width: 100%;
    background: #fff;
    display: flex;
    align-items: center;
    padding: 0 15px;
}

.gg-searchbar .search-form {
    width: calc(100% - 60px);
    display: flex;
}

.gg-searchbar .search-form .search-field {
    height: 40px;
    width: 100%;
    background-color: transparent;
    color: #000;
    border: 0;
    border-bottom: 2px solid #000;
    border-radius: 0;
    outline: none;
}

.gg-searchbar .search-form label {
    margin: 0;
    width: calc(100% - 50px);
}

.gg-searchbar input.search-field::-webkit-input-placeholder,
.gg-searchbar input.search-field::placeholder {
    color: #000;
}

.gg-searchbar .search-submit {
    display: none;
}

.search_open .gg-searchbar .search-submit {
    display: block;
    height: 48px;
    width: 48px;
    padding: 0;
    background-color: var(--gg-color-primary);
    border-radius: 50%;
    border: solid 2px var(--gg-color-primary);
    background-image: url(assets/img/search.svg);
    background-repeat: no-repeat;
    background-position: center;
    color: transparent;
}

.gg-searchbar .search-close {
    height: 48px;
    width: 48px;
    padding: 0;
    background-color: var(--gg-color-primary);
    border-radius: 50%;
    border: solid 2px var(--gg-color-primary);
    position: relative;
    bottom: 0;
    right: 0;
    outline: 0;
    font-size: 30px;
    color: #fff;
    margin-left: 15px;
}

/* search end */

/* sub-header start */
.sub-header {
    color: #fff;
    background-color: var(--gg-color-primary);
    padding: 10px 0;
}

.active .sub-header {
    display: none;
}

/* sub-header end */

/* footer Start  */
.site-footer {
    width: 100%;
    padding-top: 50px;
    position: relative;
    background: #E6E5E4;
    margin-top: 40px;
}

.footer-heading {
    font: normal normal 600 18px/28px Barlow;
    margin-bottom: 18px;
}

.contact-details .footer-heading {
    margin-bottom: 10px;
}

.footer-menu-content ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-menu-content li {
    font: normal normal normal 18px/27px Barlow;
    margin-bottom: 22px;
    color: #333;
}

.footer-link-first .footer-menu-content li {
    position: relative;
    padding-left: 15px;
    margin-bottom: 7px;
}

.footer-link-first .footer-menu-content li::before {
    content: '';
    display: block;
    width: 10px;
    height: 2px;
    background: var(--gg-color-primary);
    position: absolute;
    left: 0;
    top: 50%;
}

.footer-link-third {
    height: max-content;
}

.footer-link-third-bg {
    position: absolute;
    max-width: 120px;
    bottom: 10px;
    right: 0;
}

.footer-menu-content a {
    color: #333;
}

.site-info {
    padding: 15px;
    margin-top: 25px;
    text-align: center;
    font: normal normal normal 15px/32px Barlow;
    background-color: #E6E5E4;
    border-top: solid 1px #fff5;
}

.top-icon {
    position: absolute;
    max-width: 60px;
    top: -60px;
    right: 0px;
    z-index: 99;
}

.footer-social a {
    margin-right: 25px;
}

.footer-social a:hover {
    color: var(--gg-color-primary);
}

/* footer end*/

@media screen and (max-width: 767px) {

    .gg-menu-btn {
        line-height: 0px;
        padding: 5px;
        width: 40px;
        border: 0;
        background-color: transparent;
        border-radius: 5px;
        outline: none !important;
        display: block;
        text-align: center;
        height: 40px;
        color: #fff;
        margin-left: 15px;
    }

    nav#site-navigation.gg-nav.toggled .gg-menu-btn {
        display: none;
    }

    .active .gg-menu-btn {
        color: var(--gg-color-primary);
    }

    .gg-menu-btn span {
        display: inline-block;
        height: 3px;
        width: 100%;
        background-color: var(--gg-color-primary);
        margin: 4px 0;
    }

    .active .gg-menu-btn span {
        background-color: var(--gg-color-primary);
    }

    .site-branding .custom-logo-link {
        background: #fff;
        padding: 10px 0;
    }

    .site-branding .custom-logo-link img {
        padding: 0;
        max-height: 100px;
    }

    nav#site-navigation.gg-nav.toggled {
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        background: #fff;
        height: 100vh;
        z-index: 999;
        display: block;
        padding-bottom: 100px;
        overflow-y: scroll;
    }

    .admin-bar nav#site-navigation.gg-nav.toggled {
        top: var(--wp-admin--admin-bar--height);
    }

    .gg-nav.toggled .nav-close {
        display: flex;
        justify-content: space-between;
        padding: 15px 20px 0;
        align-items: center;
    }

    .gg-nav.toggled .header-icons {
        display: none;
    }

    .nav-close-btn {
        width: 40px;
        border-radius: 50%;
        border: 0;
        outline: 0;
        background-color: var(--gg-color-primary);
        font-size: 40px;
        padding: 0;
        height: 40px;
        color: #fff;
    }

    .menu_name {
        color: #000;
        margin: 0;
        font: normal normal normal 22px/40px Barlow;
        text-transform: uppercase;
    }

    .main-navigation .sub-menu li a,
    .main-navigation ul a {
        display: inline-block;
    }

    .main-navigation li {
        padding: 10px 15px;
    }

    .main-navigation li.menu-item-has-children {
        padding: 10px 15px;
    }

    /* .main-navigation li.current-menu-item.current_page_item a {
        color: var(--gg-color-primary);
    } */

    .main-navigation ul li:hover>ul,
    .main-navigation ul li.focus>ul {
        background: #fff;
    }

    .main-navigation li.menu-item-has-children>a::before {
        top: 0;
        left: calc(100% + 1em);
    }

    .main-navigation li.menu-item-has-children.focus>a::before {
        transform: rotate(180deg);
    }

    /* .main-navigation li.current-menu-parent>a::after,
    .main-navigation li.current-menu-item>a::after {
        display: none;
    } */

    .main-navigation-part-top {
        display: none;
    }

    .gg-nav.toggled .main-navigation-part-top {
        display: flex;
        flex-wrap: wrap;
        border-top: solid 1px #3333;
        margin-top: 20px;
    }

    .main-navigation-part-top-links a {
        margin: 5px;
    }

    .main-navigation-part-top-links a:not(:last-child)::after {
        right: -8px;
        top: 2px;
    }

    .main-navigation a.gg-btn-search {
        display: none;
    }

    .main-navigation-part-top .gg-btn {
        margin: 10px auto;
    }

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

    .footer-link-third {
        border-top: solid 1px;
    }

    .footer-links .footer-menu-content {
        display: none;
    }

    .footer-menu-content ul {
        margin-bottom: 1rem;
    }

    .footer-social {
        margin-bottom: 20px;
    }

    .footer-links .footer-heading {
        font: normal normal 500 18px/30px Barlow;
        border-top: solid 1px;
        padding-top: 15px;
        padding-bottom: 10px;
        margin-bottom: 0;
        position: relative;
        cursor: pointer;
    }

    .footer-links .footer-heading::after {
        content: "+";
        font-size: 40px;
        line-height: 1;
        position: absolute;
        right: 16px;
        top: 6px;
        font-weight: 400;
        color: var(--gg-color-primary);
    }

    .footer-links.open .footer-heading::after {
        content: "-";
        font-size: 40px;
    }

    .top-icon {
        right: 1rem;
        top: -65px;
    }

    .top-icon img {
        max-width: 58px;
    }

    .site-info {
        margin-top: 5px;
        padding: 15px 0 20px;
        font: normal normal normal 15px/32px Barlow;
    }

    .site-footer::before {
        height: 40px;
        top: -39px;
    }
}

/* header end */

/* breadcrumbs start*/

.gg-breadcrumb {
    margin: 25px 0 0px;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    font-size: .875em;
    text-transform: capitalize;
    font: normal normal normal 16px/28px Barlow;
    z-index: 2;
    position: relative;
}

.gg-breadcrumb li a:after {
    display: inline-block;
    content: "";
    height: 7px;
    width: 7px;
    transform: rotate(-45deg);
    bottom: 0;
    margin: 0 10px;
    border: none;
    border-right: 2px solid;
    border-bottom: 2px solid;
    color: #000;
}

h1.head_title {
    font: normal normal 600 35px/42px Barlow;
}

@media screen and (max-width: 992px) {
    h1.head_title {
        font: normal normal normal 28px/38px Barlow;
    }
}

/* breadcrumbs end*/

/* Blog start */
.archive-blog {
    margin-bottom: 35px;
    padding-bottom: 5px;
}

.blog-title {
    font: normal normal normal 28px/38px Barlow;
    color: #000;
    margin: 16px 0 5px;
}

.blog-title a {
    color: #000;
}

.blog-title a:hover {
    color: var(--gg-color-primary);
    text-decoration-thickness: 2px;
}

.blog-category a {
    font: normal normal 600 16px/26px Barlow;
    margin-bottom: 10px;
    display: inline-block;
}

.blog-decription {
    font: normal normal normal 15px/26px Barlow;

    color: #3B3B3B;
    margin-bottom: 16px;
}

.short-desc {
    margin: 10px 0;
}

.categories-main {
    background: #fff;
    box-shadow: 0px 3px 10px #0003;
    padding: 20px;
    margin-bottom: 30px;
    position: relative;
}

.categories-main h3 {
    font: normal normal bold 20px/30px Barlow;

    color: #000;
}

.categories ul {
    margin: 0 0 0 1rem;
    padding: 0;
}

.categories li.cat-item-all,
.categories li.cat-item {
    margin-bottom: 20px;
}

.categories li::marker {
    color: #CDD4E3;
    font-size: 20px;
}

.categories li.cat-item.current-cat::marker {
    color: var(--gg-color-primary);
}

.categories-main ul li a {
    color: #000;
    font: normal normal normal 16px/25px Barlow;

}

/* pagination */

.pagination {
    margin: 40px 0 30px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.pagination .page-numbers.current {
    color: #fff;
    background: var(--gg-color-primary);
    height: 30px;
    width: 30px;
    border-radius: 50%;
    padding: 3px;
    text-align: center;
}

.pagination .page-numbers {
    height: 24px;
    width: 24px;
    margin-right: 24px;
    display: inline-block;
    text-align: center;
    color: #000;
}

.pagination .prev {
    display: block;
    height: 14px;
    width: 14px;
    text-indent: -9999999%;
    position: relative;
}

.pagination .prev::before {
    content: "";
    border-left: 3px solid var(--gg-color-primary);
    border-top: 3px solid var(--gg-color-primary);
    transform: rotate(-45deg);
    top: 0px;
    left: 0;
    height: 15px;
    width: 15px;
    position: absolute;
}

.pagination .next {
    display: block;
    height: 14px;
    width: 14px;
    text-indent: -9999999%;
    position: relative;
}

.pagination .next::before {
    content: "";
    border-right: 3px solid var(--gg-color-primary);
    border-bottom: 3px solid var(--gg-color-primary);
    transform: rotate(-45deg);
    top: 0px;
    left: 0;
    height: 15px;
    width: 15px;
    position: absolute;
}

/* single Blog start */

.single_blog .entry-meta,
.single_blog .entry-footer {
    display: none;
}

.single_blog .entry-content {
    color: #000;
    font: normal normal normal 16px/25px Barlow;

}

.single_blog .post-thumbnail img {
    width: 100%;
}

.blog-category a,
.blog-author-category a {
    font: normal normal 600 16px/26px Barlow;
    margin-bottom: 0;
}

.blog-author-category svg {
    vertical-align: middle;
    margin-right: 8px;
}

/* Blog end */


/* 404 page Start */
.error-404 form.search-form {
    display: flex;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 3px 10px #4e4c4c29;
    border-radius: 10px;
    padding: 30px 35px;
    font: normal normal normal 16px/24px Barlow;
}

.error-404 form.search-form label,
.error-404 form.search-form input.search-field {
    width: 100%;
    padding: 13px;
    outline: none;
}

.error-404 form.search-form .search-submit {
    text-align: center;
    font: normal normal 600 17px/26px Barlow;
    color: #fff;
    background: var(--gg-color-primary);
    border-radius: 4px;
    padding: 10px 40px;
    border: 0;
}

@media screen and (max-width: 767px) {
    .error-404 form.search-form {
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-direction: column;
        padding: 30px 0px;
    }
}

/* 404 page End */


/* Contact Us Start */
.contact-form-field input,
.contact-form-field textarea {
    font: normal normal normal 18px/25px Barlow;
    letter-spacing: 0px;
    color: #aeb0b3;
    padding: 10px;
    border-radius: 12px;
}

.gg-contact-form .gform_footer input {
    font-family: Barlow;
    font-size: 20px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    padding: 10px 20px;
    background: var(--gg-color-primary);
    color: #fff;
    border: 0;
    box-shadow: 0px 4px 4px 0px #00000040;
    min-width: 150px;
    border-radius: 4px;
}

.get_touch h4 {
    font: normal normal bold 24px/35px Barlow;
    letter-spacing: 0px;
    color: #000;
}

.gg-contact-details a {
    color: #000;
    display: block;
    margin-bottom: 14px;
}

.contact-social-icons a {
    display: flex;
    height: 48px;
    width: 48px;
    justify-content: center;
    align-items: center;
    background-color: var(--gg-color-primary);
    border-radius: 50%;
    margin: 0 15px;
}

.contact-social-icons a svg {
    width: 25px;
    height: 25px
}

.contact-social-icons a svg path {
    stroke: #fff;
}

/* Contact Us End */


/* home start */

.home-banner {
    padding: 0 0 35px 0;
}

.home-banner h1 {
    width: 444px;
    position: absolute;
    right: 50px;
    bottom: 50px;
    font: normal normal bold 35px / 50px Barlow;
    color: #fff;
    text-shadow: 0px 4px 4px #000000E5;
}

.home-banner h1 span {
    font: normal normal bold 70px/50px Barlow;
}

.home-banner-media img {
    width: 100%;
    max-width: unset;
    object-fit: cover;
}

.home-banner-media video {
    width: 100%;
    max-width: unset;
    object-fit: cover;
    max-height: 530px;
}

.home-banner-partners {
    padding: 20px 0 0;
}

.home-after-banner {
    padding: 35px 0;
}

.home-after-banner-head {
    font: normal normal 900 90px/80px Barlow;
    text-align: right;
    color: #C9C9C9;
}

.home-after-banner-list {
    margin-top: 30px;
}

.home-after-banner-list ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 20px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.home-after-banner-list ul li {
    position: relative;
    padding: 0 0 0 15px;
}

.home-after-banner-list ul li::before {
    content: '';
    display: block;
    width: 10px;
    height: 2px;
    background: var(--gg-color-primary);
    position: absolute;
    left: 0;
    top: 50%;
}

.home-after-banner-img {
    position: absolute;
    left: 0;
    bottom: -60px;
    z-index: -1;
}

.home-after-banner-img img {
    max-width: 140px;
}

.home-partners {
    padding: 35px 0;
}

.home-partners-item {
    position: relative;
    padding: 50px 0 10px;
}

.home-partners-item-head {
    font: normal normal 600 45px/54px Barlow;
}

.home-partners-item:nth-child(odd)::after {
    content: '';
    width: calc(100% - 60px);
    height: 50%;
    background: #E6E5E4;
    z-index: -1;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    max-width: var(--gg-container-width);
}

@media screen and (max-width: 1200px) {
    .home-partners-item:nth-child(odd)::after {
        width: 100%;
    }
}

.home-partners-item-circle {
    position: absolute;
    top: 50px;
    right: 100px;
    width: 200px;
    height: 200px;
    background: var(--gg-color-primary);
    color: #fff;
    text-align: center;
    border-radius: 50%;
    display: flex;
    align-items: center;
    z-index: 1;
    text-wrap: balance;
    padding: 10px;
}

.home-partners-item-image {
    position: relative;
    margin-bottom: -170px;
    text-align: center;
}

.home-partners-item-image img {
    aspect-ratio: 1.9;
    object-fit: contain;
    object-position: bottom;
}

.home-partners-item-content {
    margin-left: 30px;
}

.home-partners-item-content::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #C8C8C8;
    position: absolute;
    left: 0;
    top: -30px;
}

.home-partners-item-content::after {
    content: '';
    width: 2px;
    height: 100%;
    background: #C8C8C8;
    position: absolute;
    left: 3px;
    top: -30px;
}

.home-partners-item .gg-btn {
    position: relative;
    bottom: -32px;
    border-radius: 0;
    box-shadow: none;
    z-index: 1;
}

.home-testimonials {
    padding: 35px 0 20px;
    text-wrap: balance;
}

.home-testimonials-items:not(.slick-slider) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 60px;
}

.home-testimonials-item {
    background: #E6E5E4;
    padding: 50px 40px 25px;
    border-radius: 35px;
    margin: 40px 22px 40px 0;
}

.home-testimonials-item-icon {
    color: var(--gg-color-primary);
    position: relative;
    margin-top: -75px;
    margin-bottom: 20px;
}

.home-testimonials-item-info {
    padding-left: 15px;
    line-height: 25px;
}

.home-testimonials-item-info::before {
    content: '';
    display: block;
    width: 10px;
    height: 2px;
    background: var(--gg-color-primary);
    position: absolute;
    left: 0;
    top: 25%;
}

.home-testimonials-item-info strong {
    font-weight: 600;
}

.home-from-floor {
    padding: 35px 0;
    text-wrap: balance;
}

.home-from-floor-media img,
.home-from-floor-media video {
    border-radius: 35px;
}

.home-from-floor-media iframe {
    width: 100%;
    border-radius: 35px;
}

.home-from-floor-box {
    background: #E6E5E4;
    padding: 30px 40px 25px;
    border-radius: 35px;
    position: relative;
    margin-left: -120px;
}

.home-from-floor-box-head {
    font: normal normal 600 20px/27px Barlow;
    margin-bottom: 10px;
}

@media screen and (max-width: 950px) {
    .home-banner h1 {
        width: 50%;
        right: 15px;
        bottom: 15px;
        font: normal normal bold 22px / 38px Barlow;
    }

    .home-banner h1 span {
        font: normal normal bold 38px / 38px Barlow
    }
}

@media screen and (max-width: 767px) {
    .home-after-banner {
        padding: 70px 0 20px;
    }

    .home-banner-media {
        margin: 0 -15px;
    }

    .home-banner-media video {
        max-height: unset;
    }

    .home-banner h1 {
        width: auto;
        right: 15px;
        left: 15px;
        font: normal normal bold 22px / 38px Barlow;
    }

    .home-banner h1 span {
        font: normal normal bold 38px / 38px Barlow
    }

    .home-after-banner-img {
        bottom: 0;
        top: -80px;
    }

    .home-after-banner-head {
        font: normal normal 900 50px / 50px Barlow;
    }

    .home-partners {
        padding: 25px 0 35px;
    }

    .home-partners-item {
        padding: 10px 0;
    }

    .home-partners-item-head {
        font: normal normal 600 24px / 35px Barlow;
    }

    .home-partners-item+.home-partners-item {
        padding: 60px 0 10px;
    }

    .home-partners-item-content::before,
    .home-partners-item-content::after {
        display: none;
    }

    .home-partners-item-circle-holder {
        padding: 180px 0 0 0;
    }

    .home-partners-item-circle {
        width: 170px;
        height: 170px;
        left: unset;
        right: 0;
        top: 0;
    }

    .home-partners-item-image {
        margin: 0;
    }

    .home-partners-item-image img {
        aspect-ratio: unset;
    }

    .home-testimonials {
        padding: 35px 0 0px;
    }

    .home-testimonials-item {
        padding: 50px 20px 25px;
        margin: 40px 16px 20px 0;
        border-radius: 15px;
    }

    .home-from-floor-media img,
    .home-from-floor-media video {
        border-radius: 15px;
    }

    .home-from-floor-box {
        margin-left: 0;
        padding: 20px 20px 25px;
        border-radius: 15px;
    }

}

/* home end */

/* single-product start */
.single-product-banner {
    position: relative;
}

.single-product-banner-text {
    font-weight: 500;
}

.single-product-banner-big {
    font: normal normal 900 90px / 80px Barlow;
    color: #C9C9C9;
    text-align: right;
    display: flex;
    justify-content: flex-end;
    margin: 70px 0 10px;
}

.single-product-banner-link {
    color: #FF0000;
}

.single-product-info-cards-row {
    padding: 50px 0;
    font: normal normal 500 18px/30px Barlow;
}

.single-product-info-cards-row-col {
    background: #E6E5E4;
    border-radius: 12px;
    padding: 30px 40px;
    display: flex;
    gap: 15px;
    height: 100%;
    position: relative;
}

.single-product-info-cards-row-col-text {
    position: relative;
    z-index: 1;
}

.single-product-info-cards-row-col-text ul {
    margin-bottom: 0;
}

.single-product-info-cards-row-col-image {
    flex: 0 0 50%;
    max-width: 50%;
    position: relative;
    display: flex;
    align-items: center;
}

.single-product-info-cards-row-col-image img {
    position: absolute;
    left: 0;
}

.gg-col-count-1 {
    position: relative;
    padding: 50px 0 100px;
}

.gg-col-count-1 .single-product-info-cards-row-col-image {
    flex: 0 0 10%;
    max-width: 10%;
    position: unset;
    align-items: baseline;
}

.gg-col-count-1 .single-product-info-cards-row-col-image img {
    max-width: 300px;
    max-height: 400px;
    object-fit: cover;
    top: 0;
}

.gg-col-count-1 .single-product-info-cards-row-col {
    position: unset;
    margin-left: 15%;
}

.single-product-next-prev {
    padding: 90px 0 40px;
}

a.single-product-next-prev-item {
    display: flex;
    align-items: center;
    color: #000;
    text-decoration: none;
    position: relative;
    height: 100%;
}

a.single-product-next-prev-item::before {
    content: '';
    width: 70%;
    height: 100%;
    background: #E6E5E4;
    border-radius: 12px;
    position: absolute;
    z-index: -1;
}

.single-product-next-prev-item-prev {
    justify-content: flex-end;
}

.single-product-next-prev-item-text {
    font-family: Barlow;
    font-size: 25px;
    font-weight: 600;
    line-height: 30px;
    color: #000;
    margin: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
}

.single-product-specifications {
    padding: 25px 0 25px;
}

.single-product-specifications-box-heading {
    font: normal normal bold 20px/27px Barlow;
}

.single-product-specifications-box {
    background: #E6E5E4;
    border-radius: 12px;
    padding: 20px 40px 30px;
    position: relative;
}

.single-product-specifications-box .gg-btn {
    position: absolute;
    left: 50%;
    bottom: -22px;
    transform: translate(-50%, 0);
    width: max-content;
}

.single-product-specifications-box-images {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

.page-template-gg-single-product-3 .single-product-specifications-box-images img,
.products-template-gg-single-product-3 .single-product-specifications-box-images img {
    flex: 1 1 auto;
    max-width: min(100%, calc(268px - 15px));
}

.page-template-gg-single-product-3 .box_specifications-images img,
.products-template-gg-single-product-3 .box_specifications-images img {
    flex: 1 1 auto;
    max-width: min(100%, calc(555px - 15px));
}

@media screen and (max-width: 950px) {
    .single-product-banner-big {
        font: normal normal 900 60px / 50px Barlow;
    }

    .gg-col-count-1 .single-product-info-cards-row-col-image {
        flex: 0 0 20%;
        max-width: 20%;
    }
}

@media screen and (max-width: 767px) {
    .single-product-banner-big {
        margin: 20px 0 10px;
        text-align: left;
        justify-content: flex-start;
        font: normal normal 900 70px / 60px Barlow;
    }

    section.single-product-info-cards {
        padding: 30px 0 0;
    }

    .single-product-info-cards-row {
        padding: 0;
    }

    .single-product-info-cards-row-col {
        flex-wrap: wrap;
        padding: 20px;
    }

    .single-product-info-cards-row-col-image {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .single-product-info-cards-row-col-image img {
        position: static;
    }

    .gg-col-count-1 .single-product-info-cards-row-col {
        position: relative;
        margin: 0;
    }

    .gg-col-count-1 .single-product-info-cards-row-col-image {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .single-product-specifications-box {
        flex-wrap: wrap;
        padding: 20px 20px 40px;
    }
}

/* single-product end */

/* About Us start */
.about-content-row {
    padding-top: 60px;
    align-items: center;
}

.about-content-row:nth-child(even) {
    flex-direction: row-reverse;
}

.about-us-call-action {
    padding: 70px 0 80px;
}

.pm-call-action-content {
    background-color: #E6E5E4;
    padding: 28px;
    text-align: center;
}

.pm-call-action-content h3 {
    margin-bottom: 20px;
}

.about-our-partners-logos {
    padding: 0 0 84px;
}

.about-our-partners-logos-slider {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 20px;
}

.about-equipments {
    background: #E6E5E4;
    border: 1px solid #E6E5E4;
    padding: 64px 0 50px;
    /* text-align: center; */
}

/* About Us end */