/*
Theme Name: GeneratePress Child
Theme URI: https://generatepress.com
Template: generatepress
Author: Tom Usborne
Author URI: https://tomusborne.com
Description: GeneratePress is a lightweight WordPress theme built with a focus on speed and usability. Performance is important to us, which is why a fresh GeneratePress install adds less than 10kb (gzipped) to your page size. We take full advantage of the block editor (Gutenberg), which gives you more control over creating your content. If you use page builders, GeneratePress is the right theme for you. It is completely compatible with all major page builders, including Beaver Builder and Elementor. Thanks to our emphasis on WordPress coding standards, we can boast full compatibility with all well-coded plugins, including WooCommerce. GeneratePress is fully responsive, uses valid HTML/CSS, and is translated into over 25 languages by our amazing community of users. A few of our many features include 60+ color controls, powerful dynamic typography, 5 navigation locations, 5 sidebar layouts, dropdown menus (click or hover), and 9 widget areas. Learn more and check out our powerful premium version at https://generatepress.com
Tags: two-columns,three-columns,one-column,right-sidebar,left-sidebar,footer-widgets,blog,e-commerce,flexible-header,full-width-template,buddypress,custom-header,custom-background,custom-menu,custom-colors,sticky-post,threaded-comments,translation-ready,rtl-language-support,featured-images,theme-options
Version: 3.5.1.1744816639
Updated: 2025-04-16 15:17:19

*/

html {
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--contrast);
}

body {
  color: var(--contrast-2);
  overflow-x: hidden;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.site-content {
  overflow: clip;
}

.primary-btn {
  background-size: 100% 100%;
  transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.primary-btn .gb-shape {
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.5);
  transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.primary-btn:hover {
  background-size: 100% 150%;
}

.primary-btn:hover .gb-shape {
  transform: translateX(0.125rem);
}

.secondary-btn {
  position: relative;
  background-size: 100% 100%;
  transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.secondary-btn::before {
  content: "";
  -webkit-mask: linear-gradient(white 0 0) padding-box,
    linear-gradient(white 0 0);
  mask: linear-gradient(white 0 0) padding-box, linear-gradient(white 0 0);
  -webkit-mask-composite: xor !important;
  mask-composite: exclude !important;
  background: linear-gradient(to right, #1f2937, #374151, #1f2937) border-box;
  border: 1px solid transparent;
  border-radius: inherit;
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.secondary-btn:hover {
  background-size: 100% 150%;
}

.hero-bg {
  position: relative;
  isolation: isolate;
}

.hero-bg::before {
  content: "";
  background: url("/wp-content/themes/generatepress-child/assets/image/page-illustration.svg");
  position: absolute;
  width: 846px;
  height: 594px;
  top: 0;
  left: 50%;
  transform: translateX(-25%);
  z-index: -10;
}

.hero-secondary-bg {
  position: relative;
  isolation: isolate;
}

.hero-secondary-bg::before {
  content: "";
  width: 1165px;
  height: 1012px;
  background-image: url("/wp-content/themes/generatepress-child/assets/image/secondary-illustration.svg");
  position: absolute;
  bottom: 2rem;
  left: 50%;
  margin-left: -7rem;
  transform: translate(-50%, 50%);
  background-size: contain;
  z-index: -10;
  pointer-events: none;
}

@media (max-width: 768px) {
  .hero-secondary-bg::before {
    width: 291px;
    height: 252px;
  }
}

.text-gradient-container::before,
.text-gradient-container::after {
  content: "";
  width: 2rem;
  height: 1px;
}

.text-gradient-container::before {
  background-image: linear-gradient(
    to right,
    transparent,
    rgb(199 210 254 / 0.5)
  );
}

.text-gradient-container::after {
  background-image: linear-gradient(
    to left,
    transparent,
    rgb(199 210 254 / 0.5)
  );
}

.text-gradient {
  color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
  background-image: linear-gradient(to right, #6366f1, #c7d2fe);
}

@media (max-width: 768px) {
  .text-gradient-container.only-large-screen::before,
  .text-gradient-container.only-large-screen::after {
    display: none;
  }
}

.border-gradient {
  -o-border-image: linear-gradient(
      to right,
      transparent,
      rgb(148 163 184/0.25),
      transparent
    )
    1;
  border-image: linear-gradient(
      to right,
      transparent,
      rgb(148 163 184 / 0.25),
      transparent
    )
    1;
}

.features-bg {
  position: relative;
  isolation: isolate;
}

.features-bg::before {
  content: "";
  background-image: url("/wp-content/themes/generatepress-child/assets/image/blurred-shape.svg");
  width: 760px;
  height: 668px;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-bottom: -20rem;
  transform: translateX(-120%);
  opacity: 0.5;
  z-index: -10;
  pointer-events: none;
}

.svg-fill-none svg {
  fill: none !important;
}

.content-bg {
  position: relative;
  isolation: isolate;
}

.content-bg::before {
  content: "";
  background-image: url("/wp-content/themes/generatepress-child/assets/image/blurred-shape-gray.svg");
  width: 760px;
  height: 668px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  margin-top: -5rem;
  pointer-events: none;
  z-index: -10;
}

.testimonials-bg {
  position: relative;
  isolation: isolate;
}

.testimonials-bg::before {
  content: "";
  background-image: url("/wp-content/themes/generatepress-child/assets/image/blurred-shape.svg");
  width: 760px;
  height: 668px;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-bottom: -5rem;
  transform: translateX(-33.333333%);
  z-index: -10;
  pointer-events: none;
}

.testimonials .testimonial--item,
.testimonials .testimonial--item-inner {
  position: relative;
  overflow: hidden;
}

.testimonials .testimonial--item-inner {
  z-index: 20;
  cursor: default;
}

.testimonials .testimonial--item::before {
  content: "";
  position: absolute;
  left: -10rem;
  top: -10rem;
  z-index: 10;
  height: 20rem;
  width: 20rem;
  border-radius: 9999px;
  transform: translate(var(--mouse-x), var(--mouse-y));
  opacity: 0;
  filter: blur(64px);
  background-color: rgb(99 102 241/0.8);
  transition: opacity 500ms cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.testimonials:hover .testimonial--item::before {
  opacity: 1;
}

.testimonials .testimonial--item::after {
  content: "";
  position: absolute;
  left: -12rem;
  top: -12rem;
  z-index: 30;
  height: 16rem;
  width: 16rem;
  border-radius: 9999px;
  transform: translate(var(--mouse-x), var(--mouse-y));
  opacity: 0;
  filter: blur(64px);
  background-color: var(--accent);
  transition: opacity 500ms cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.testimonials .testimonial--item:hover:after {
  opacity: 0.2;
}

.testimonials .testimonial--item-inner::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(
    to bottom,
    rgb(17 24 39 / 0.5),
    rgb(17 24 39 / 0.5)
  );
  border-radius: inherit;
  z-index: -10;
}

.cta-bg {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.cta-bg::before {
  content: "";
  background-image: url("/wp-content/themes/generatepress-child/assets/image/blurred-shape.svg");
  width: 760px;
  height: 668px;
  position: absolute;
  left: 50%;
  bottom: 0;
  z-index: -10;
  margin-left: 5rem;
  margin-bottom: -6rem;
  transform: translateX(-50%);
  pointer-events: none;
}

.separate-containers .comments-area,
.separate-containers .inside-article,
.separate-containers .page-header,
.separate-containers .paging-navigation {
  padding-left: 24px;
  padding-right: 24px;
}

@media (max-width: 768px) {
  .separate-containers .comments-area,
  .separate-containers .inside-article,
  .separate-containers .page-header,
  .separate-containers .paging-navigation {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* Header */
.site-header {
  margin: 20px auto 0;
  width: 100%;
  padding: 0 24px;
  max-width: var(--gb-container-width);
}

.site-header .inside-header {
  max-width: 100%;
  padding: 0 12px;
  background-color: rgb(17 24 39 / 0.9);
  min-height: 56px;
  border-radius: 16px;
  position: relative;
}

.site-header .inside-header::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  background: linear-gradient(to right, #1f2937, #374151, #1f2937) border-box;
  -webkit-mask-composite: xor !important;
  mask-composite: exclude !important;
  -webkit-mask: linear-gradient(white 0 0) padding-box,
    linear-gradient(white 0 0);
  mask: linear-gradient(white 0 0) padding-box, linear-gradient(white 0 0);
  pointer-events: none;
}

.menu-toggle {
  line-height: normal;
  padding: 0;
  width: 32px;
  height: 32px;
}

.main-navigation,
.main-navigation ul ul {
  background: transparent;
}

.mobile-menu-control-wrapper .menu-toggle,
.mobile-menu-control-wrapper .menu-toggle:hover,
.mobile-menu-control-wrapper .menu-toggle:focus,
.has-inline-mobile-toggle #site-navigation.toggled {
  background: transparent;
}

.main-navigation .main-nav > ul {
  gap: 32px;
}

.main-navigation .main-nav ul li a {
  line-height: normal;
  padding: 4px 12px;
  font-size: 14px;
  line-height: 20px;
  color: rgb(229, 231, 235);
}

.site-header .site-logo img {
  height: 32px;
  width: auto;
}

@media (max-width: 1024px) {
  .main-navigation .main-nav > ul {
    gap: 16px;
  }

  .main-navigation .main-nav ul li a {
    padding: 4px 8px;
  }
}

@media (max-width: 768px) {
  .site-header {
    margin-top: 8px;
    padding: 0 16px;
  }

  .site-header .inside-header #site-navigation {
    display: none;
  }

  .site-header .inside-header #site-navigation.toggled {
    display: block;
  }

  .mobile-menu-open .site-header .inside-header {
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .main-navigation .main-nav ul li a {
    padding: 6px 4px;
  }

  .has-inline-mobile-toggle #site-navigation.toggled {
    margin-top: 16px;
  }
}

/* Footer */
.footer-bg {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.footer-bg::before {
  content: "";
  background-image: url("/wp-content/themes/generatepress-child/assets/image/footer-illustration.svg");
  width: 1076px;
  height: 378px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -10;
  pointer-events: none;
}

.footer-menu ul {
  gap: 8px;
}

.footer-menu ul li a {
  font-size: 14px;
  line-height: 20px;
  color: var(--contrast-2) !important;
  transform: color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.footer-menu ul li a:hover {
  color: var(--accent) !important;
}
