/**
Theme Name: GBN Scaffolding
Author: Brainstorm Force
Author URI: http://wpastra.com/about/
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs, personal portfolios and business websites. It is very lightweight (less than 50KB on frontend) and offers unparalleled speed. Built with SEO in mind, Astra comes with schema.org code integrated so search engines will love your site. Astra offers plenty of sidebar options and widget areas giving you a full control for customizations. Furthermore, we have included special features and templates so feel free to choose any of your favorite page builder plugin to create pages flexibly. Some of the other features: # WooCommerce Ready # Responsive # Compatible with major plugins # Translation Ready # Extendible with premium addons # Regularly updated # Designed, Developed, Maintained & Supported by Brainstorm Force. Looking for a perfect base theme? Look no further. Astra is fast, fully customizable and beautiful theme!
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gbn-scaffolding
Template: astra
*/


:root {
    --color-primary: #15120D;
    --color-secondary: #F17123;
    --color-text: #000000;
    --color-accent: #F3995B;
    --color-accent-hover: #d87533;
    --color-white: #fff;

    --gradient-orange: linear-gradient(134.42deg, var(--color-accent) 0.99%, var(--color-secondary) 100%);
    --gradient-orange-hover: linear-gradient(134.42deg, var(--color-secondary) 0.99%, var(--color-accent) 100%);
}
/* h1 {
    line-height: 0.9427083333333334em!important;
} */
a {
    /* color: var(--color-accent); */
    text-decoration: none !important;
}
a:hover,
a:focus,
a:active,
a:visited,
a:focus-within,
a:focus-visible {
    outline: none!important;
}
.fs-14 {
  font-size: 14px !important;
}
.fw-500,
.fw-500 * {
  font-weight: 500 !important;
}
.text-white {
  color: var(--color-white)!important;
}
.height-100,
.height-100 * {
  height: 100%!important;
}
img.height-100,
.height-100 img {
  height: 100%!important;
  object-fit: cover;
}
.height-60p {
  height: 60% !important;
  min-height: 60% !important;
}
.height-40p {
  height: calc(40% - 30px) !important;
  min-height: calc(40% - 30px) !important;
}
header {
  z-index: 3!important;
}
/*---- Global Button CSS - START ----*/
.elementor-widget-button .elementor-button {
  position: relative;
  color: #fff;
  padding-right: 51px;
  background-image: var(--gradient-orange), linear-gradient(to right, #000 0%, #000 100%) !important;
  background-repeat: no-repeat;
  background-size: 100% 100%, 0% 100%;
  background-position: right, left;
  transition: background-image 0.5s ease, 0.5s ease, color 0.5s ease;;
  /* overflow: hidden; */
}
.elementor-widget-button .elementor-button .elementor-button-text {
  position: relative;
  left: 0;
  transition: left 0.5s ease;
}
.elementor-widget-button .elementor-button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 28px;
  width: 15px;
  height: 15px;
  background: url('/wp-content/uploads/2025/10/icon-button-right-arrow.svg') no-repeat center center / contain;
  transform: translateY(-50%) rotate(0deg);
  transition: transform 0.5s ease, background-image 0.5s ease, 0.5s ease;
}
.elementor-widget-button .elementor-button:hover {
  background-image: var(--gradient-orange), linear-gradient(to right, #000 100%, #000 100%) !important;
  background-size: 0% 100%, 100% 100%;
  color: #F17123 !important;
}
.elementor-widget-button .elementor-button:hover .elementor-button-text {
  left: 4px;
}
.elementor-widget-button .elementor-button:hover::after {
  transform: translateY(-50%) rotate(-45deg);
  background-image: url('/wp-content/uploads/2025/10/icon-button-right-arrow-orange.svg')!important;
}
/* Button Hover BG White CSS - START */
.elementor-widget-button.hover-bg-white .elementor-button {
  background-image: var(--gradient-orange), linear-gradient(to right, #fff 0%, #fff 100%) !important;
}
.elementor-widget-button.hover-bg-white .elementor-button:hover {
  background-image: var(--gradient-orange), linear-gradient(to right, #fff 100%, #fff 100%) !important;
}
/* Button Hover BG White CSS - END */
/* Form Button CSS - START */
.elementor-field-type-submit.e-form__buttons button.elementor-button {
  /* background:  url('/wp-content/uploads/2025/10/icon-button-right-arrow.svg') no-repeat right 26px center, var(--gradient-orange) !important;
  color: #fff;
  padding-right: 51px;
  transition: all 0.5s; */
  position: relative;
  color: #fff;
  padding-right: 51px;
  background-image: var(--gradient-orange), linear-gradient(to right, #000 0%, #000 100%) !important;
  background-repeat: no-repeat;
  background-size: 100% 100%, 0% 100%;
  background-position: right, left;
  transition: background-image 0.5s ease, 0.5s ease, color 0.5s ease;
  /* overflow: hidden; */
}
.elementor-field-type-submit.e-form__buttons button.elementor-button:hover {
  background-image: var(--gradient-orange), linear-gradient(to right, #000 100%, #000 100%) !important;
  background-size: 0% 100%, 100% 100%;
  color: #F17123 !important;
}
.elementor-field-type-submit.e-form__buttons button.elementor-button .elementor-button-text {
  position: relative;
  left: 0;
  transition: left 0.5s ease;
}
.elementor-field-type-submit.e-form__buttons button.elementor-button:hover .elementor-button-text {
  left: 4px;
}
.elementor-field-type-submit.e-form__buttons button.elementor-button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 28px;
  width: 15px;
  height: 15px;
  background: url('/wp-content/uploads/2025/10/icon-button-right-arrow.svg') no-repeat center center / contain;
  transform: translateY(-50%) rotate(0deg);
  transition: transform 0.5s ease, background-image 0.5s ease, 0.5s ease;
}
.elementor-field-type-submit.e-form__buttons button.elementor-button:hover::after {
  transform: translateY(-50%) rotate(-45deg);
  background-image: url('/wp-content/uploads/2025/10/icon-button-right-arrow-orange.svg')!important;
}
/* Form Button CSS - END */
/* Go Home Button CSS - START */
.elementor-widget-button.btn-go-to-home .elementor-button {
  border-radius: 12px;
  padding: 16px 70px 16px 40px;
  font-weight: 500;
}
.elementor-widget-button.btn-go-to-home .elementor-button:hover {
  background: var(--gradient-orange) !important;
  border-radius: 25px;
  color: #fff !important;
}
.elementor-widget-button.btn-go-to-home .elementor-button::after {
  background-image: url('/wp-content/uploads/2025/10/icon-button-right-arrow-small.svg');
  right: 40px;
  width: 10px;
  height: 10px;
}
.elementor-widget-button.btn-go-to-home .elementor-button:hover::after {
  background-image: url('/wp-content/uploads/2025/10/icon-button-right-arrow-small.svg')!important;
  transform: translateY(-50%) rotate(0);
}
/* Go Home Button CSS - END */
/*---- Global Button CSS - END ----*/
/*---- Astra Theme Default CSS Reset - START ----*/
.ast-container {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
}
.ast-article-single{
  padding: 0 !important;
}
.ast-separate-container #primary{
    margin: 0 !important;
    padding: 0 !important;
}
.ast-separate-container .ast-article-single:not(.ast-related-post) {
    background-color: transparent;
}
#ast-scroll-top {
    display: none!important;
}
footer .ast-footer-row-stack {
  display: none!important;
}
/*---- Astra Theme Default CSS Reset - END ----*/
/*---- Gradients CSS - START ----*/
.gradient-orange .elementor-icon {
  background: var(--gradient-orange);
}
.gradient-orange-cont-bg {
  background: var(--gradient-orange);
}
.gradient-orange-border {
  border: 1px solid transparent;
  background: linear-gradient(white, white) padding-box, var(--gradient-orange);
}
.gradient-orange-text>*,
.gradient-orange-text-span span {
  background: var(--gradient-orange);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text; /* for browsers supporting unprefixed version */
  color: transparent;
  display: inline-block;
}
/*---- Gradients CSS - START ----*/
/*---- Background Blur CSS - START ----*/
.backdrop-filter-megamenu,
.backdrop-filter>.e-con-inner>.elementor-element,
.backdrop-filter>.e-con-inner>.elementor-element {
  backdrop-filter: blur(12px)
}
/*---- Background Blur CSS - END ----*/
/*---- Image Aspect Ratios - CSS - START ----*/
.img-460-340 img {
  aspect-ratio: 1.35 / 1;
  object-fit: cover;
  object-position: center center;
}
.img-367-189 img {
  aspect-ratio: 1.41 / 1;
  object-fit: cover;
  object-position: center center;
}
/*---- Image Aspect Ratios - CSS - END ----*/
/*---- Image Zoom - CSS - START ----*/
.img-zoom-hover {
  overflow: hidden;
}
.img-zoom-hover img {
  transition: all 0.5s;
}
.img-zoom-hover img:hover {
  transform: scale(1.25);
}
/*---- Image Zoom - CSS - END ----*/
/*---- Responsive Menu - CSS - START ----*/
.elementor-nav-menu a, 
.elementor-nav-menu a:focus, 
.elementor-nav-menu a:hover {
  line-height: unset;
  /* padding: 10px 20px; */
}
/*---- Responsive Menu - CSS - END ----*/
/*---- Inner Page Banner - CSS - START ----*/
.inner-banner-title h1.elementor-heading-title p {
  font-weight: 400;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
  white-space: nowrap;
}
.inner-banner-title h1.elementor-heading-title p span {
  background-color: var(--color-white);
  display: block;
  height: 2px;
  width: 100%;
}
/*---- 404 page default theme footer disable ----*/
body.error404 .e-con-inner > .elementor-element.e-con-full {
    border-bottom: 1px solid #0000001A;
}
.wcs-box {
  transition: all 0.5s;
}
.wcs-box.gradient-orange-cont-bg:hover {
  border: 1px solid transparent;
  background: linear-gradient(white, white) padding-box, var(--gradient-orange);
}
.wcs-box.gradient-orange-cont-bg:hover .elementor-heading-title,
.wcs-box.gradient-orange-cont-bg:hover p {
  color: var(--color-text);
}
.wcs-box.gradient-orange-border:hover {
  background: var(--gradient-orange);
}
.wcs-box.gradient-orange-border:hover .elementor-heading-title,
.wcs-box.gradient-orange-border:hover p {
  color: var(--color-white);
}
/*---- Inner Page Banner - CSS - END ----*/
@media (min-width:1025px) and (max-width: 1366px) {
  /*---- Inner Page Banner - CSS - START ----*/
  .inner-banner-title h1.elementor-heading-title p {
    gap: 40px;
  }
  /*---- Inner Page Banner - CSS - END ----*/
}
@media screen and (max-width:1024px) {
  nav ul li.menu-item a.menu-link {
      justify-content: space-between;
  }
  element {
    z-index: unset;
  }
}
@media (min-width:768px) and (max-width: 1024px) {
  /*---- Inner Page Banner - CSS - START ----*/
  .inner-banner-title h1.elementor-heading-title p {
    gap: 30px;
  }
  /*---- Inner Page Banner - CSS - END ----*/
}
@media screen and (max-width: 767px) {
  .footer-menu ul li a {
    justify-content: center !important;
  }
  /*---- Inner Page Banner - CSS - START ----*/
  .inner-banner-title h1.elementor-heading-title p {
    gap: 20px;
  }
  /*---- Inner Page Banner - CSS - END ----*/
}