/*
Theme Name: Brockett Hello Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.0.1.1707834477
Updated: 2024-02-13 14:27:57
*/

:root {
  /*
  * Update these + Elementor Site Settings + Atomic Variables in V4 editor when setting up a new site.
  * ----------------------------------------- */

  /*
  * BRAND COLORS
  * ----------------------------------------- */
  --clr-brand-1: #385170;
  --clr-brand-2: #142d4c;
  --clr-brand-3: #9fd3c7;

  /*
  * NEUTRALS
  * ----------------------------------------- */
  --clr-white: #fff;
  --clr-black: #000;
  --clr-off-white: #f8f8f8;
  --clr-light-gray: #eee;
  --clr-border: #ddd;
  --clr-mid-gray: #999;
  --clr-text: #333;
  --clr-dark: #1a1a1a;

  /*
  * UTILITY
  * ----------------------------------------- */
  --clr-transparent: rgba(255, 255, 255, 0);
  --clr-success: #4caf50;
  --clr-error: #e53935;

  /*
  * FONT FAMILIES
  * ----------------------------------------- */
  /* Display is for headings */
  --ff-display: "Open Sans", sans-serif;
  /* Prose is for paragraph */
  --ff-prose: "Open Sans", sans-serif;
  /* UI is for buttons or menus */
  --ff-ui: "Open Sans", sans-serif;

  /*
  * FONT WEIGHTS
  * ----------------------------------------- */
  --fw-light: 300;
  --fw-regular: 400;
  --fw-semibold: 600;
  --fw-bold: 700;

  /*
  * LINE HEIGHTS
  * ----------------------------------------- */
  --lh-tight: 1.1;
  --lh-snug: 1.3;
  --lh-normal: 1.65;

  /*
  * FONT SIZES
  * ----------------------------------------- */
  --fs-display: clamp(2.5rem, 0.8929rem + 5.3571vw, 5rem);
  --fs-heading-xl: clamp(2rem, 0.4286rem + 4.9107vw, 3.75rem);
  --fs-heading-lg: clamp(1.75rem, 0.8393rem + 2.8482vw, 3rem);
  --fs-heading-md: clamp(1.5rem, 0.9643rem + 1.6741vw, 2.25rem);
  --fs-heading-sm: clamp(1.25rem, 1.0179rem + 0.7813vw, 1.75rem);
  --fs-heading-xs: clamp(1.1rem, 0.9946rem + 0.3348vw, 1.375rem);
  --fs-body-lg: clamp(1.125rem, 1.0536rem + 0.2232vw, 1.375rem);
  /* --fs-body: clamp(1rem, 0.9643rem + 0.1116vw, 1rem); */
  --fs-body: 1rem;
  --fs-body-sm: clamp(0.875rem, 0.8714rem + 0.0893vw, 0.95rem);
  --fs-caption: clamp(0.75rem, 0.7143rem + 0.1116vw, 0.875rem);
  --fs-button: clamp(0.875rem, 0.8393rem + 0.1116vw, 1rem);
}

/* -----------------------------------------------
   TYPOGRAPHY UTILITY CLASSES
   Apply via CSS Classes field in Elementor.
   IMPORTANT: Do not style an element in the
   Elementor panel while one of these classes
   is active — Elementor will write to the class
   globally and affect all elements using it. (In V4 editor)
   ----------------------------------------------- */
/* .fs-display {
  font-size: var(--fs-display);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  font-family: var(--ff-display);
}
.fs-heading-xl {
  font-size: var(--fs-heading-xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  font-family: var(--ff-display);
}
.fs-heading-lg {
  font-size: var(--fs-heading-lg);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  font-family: var(--ff-display);
}
.fs-heading-md {
  font-size: var(--fs-heading-md);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  font-family: var(--ff-display);
}
.fs-heading-sm {
  font-size: var(--fs-heading-sm);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  font-family: var(--ff-display);
}
.fs-heading-xs {
  font-size: var(--fs-heading-xs);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  font-family: var(--ff-display);
} */

/* PARAGRAPH */
/* .fs-body-lg {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  font-family: var(--ff-prose);
  color: var(--clr-text);
}
.fs-body {
  font-size: var(--fs-body);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  font-family: var(--ff-prose);
  color: var(--clr-text);
}
.fs-body-sm {
  font-size: var(--fs-body-sm);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  font-family: var(--ff-prose);
  color: var(--clr-text);
}
.fs-caption {
  font-size: var(--fs-caption);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  font-family: var(--ff-prose);
  color: var(--clr-text);
}
.fs-button {
  font-size: var(--fs-button);
  font-weight: var(--fw-semibold);
  line-height: 1;
  font-family: var(--ff-ui);
  color: var(--clr-white);
} */

/*
 * GENERAL QOL
 * ----------------------------------------- */
.link-style-fix,
.elementor-element .inline-link a {
  color: var(--clr-brand-1);
  font-weight: var(--fw-bold);
  text-decoration: none;
}
.link-style-fix:hover,
.elementor-element .inline-link a:hover {
  color: var(--clr-brand-1);
  font-weight: var(--fw-bold);
}
ul {
  padding-left: 20px;
}
article.privacy-policy ul,
article.accessibility-statement ul {
  margin-bottom: 1em;
}
article.privacy-policy ul li,
article.accessibility-statement ul li {
  margin-bottom: 0.5em;
}

/*
 * ADA WIDGET
 * ----------------------------------------- */
@media (max-width: 767px) {
  .userway_buttons_wrapper {
    bottom: 50px !important;
  }
  .cky-btn-revisit-wrapper {
    bottom: 50px !important;
  }
}

/*
 * SCROLL TO TOP
 * ----------------------------------------- */
#scroll-top-top-wrapper .scroll-to-top {
  position: fixed;
  bottom: 62px;
  right: 7px;
  background-color: transparent;
  padding: 5px 10px;
  border-radius: 50%;
  border: 1px solid white;
  font-size: 20px;
  text-align: center;
  text-decoration: none;
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
  z-index: 9999;
}
#scroll-top-top-wrapper .scroll-to-top:hover,
#scroll-top-top-wrapper .scroll-to-top:focus,
#scroll-top-top-wrapper .scroll-to-top:focus-visible {
  opacity: 1;
  background-color: transparent;
}
#scroll-top-top-wrapper .scroll-to-top i {
  color: white;
}

/*
 * SHRINKING HEADER
    Be sure to add the ID 'ele-shrink-header' on the header element in elementor.
    On the header element, under 'advanced' > 'Motion Effects', set 'Sticky' to 'Top' and add all the breakpoints.
    'Offset' and 'Effects Offset' to 0, those are controlled in js/app.js, as well as adding/removing the 'scrolled' class.
    See comments below on what values can be adjusted as needed per site.
 * ----------------------------------------- */
#ele-shrink-header {
  transition: all 0.3s linear;
}
#ele-shrink-header.scrolled {
  width: 100% !important;
  padding: 0px 10px; /* Adjust as needed */
  transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
}
/* Logo default state */
#ele-shrink-header img {
  width: 100%;
  transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -moz-transition: all 0.2s;
}
/* Mobile logo on scroll */
#ele-shrink-header.scrolled img {
  width: 80%; /* Adjust as needed */
}
/* Shrink Logo more only on tablet and larger */
@media (min-width: 767px) {
  #ele-shrink-header.scrolled img {
    width: 70%; /* Adjust as needed */
  }
}
/* Shrink nav items */
#ele-shrink-header.scrolled .elementor-nav-menu li a {
  font-size: 0.9rem; /* Adjust as needed */
  transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
}
/* Buttons */
#ele-shrink-header .elementor-button {
  font-size: 1.2rem;
}
/* Buttons */
#ele-shrink-header.scrolled .elementor-button {
  font-size: 0.9rem;
}

/*
 * SEARCH WIDGET
 * ----------------------------------------- */
.custom-search-wrapper {
  position: relative;
  display: inline-block;
  padding: 0 1em;
}
.fa-solid.fa-magnifying-glass {
  color: white;
}
.fa-solid.fa-magnifying-glass:hover {
  color: white;
  transition: all 0.3s;
}
.custom-search-wrapper button.search-toggle {
  background: none;
  padding: 0;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
}
.custom-search-wrapper button.search-toggle:hover {
  background: none;
}
.custom-search-wrapper button.search-toggle:focus {
  background: none;
  outline: none;
}
.custom-search-wrapper button.search-toggle:focus-visible {
  background: none;
  outline: none;
}
.search-box {
  position: absolute;
  top: 120%;
  right: 0;
  width: 0;
  max-width: 400px;
  background: white;
  padding: 10px;
  border-radius: 6px;
  border: 1px solid #ccc;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  opacity: 0;
  overflow: hidden;
  transition:
    width 0.3s ease,
    opacity 0.3s ease;
  pointer-events: none;
  z-index: 1000;
}
.search-box.show {
  width: 400px;
  opacity: 1;
  pointer-events: auto;
}
.header-search-form input {
  border: 1px solid #ddd;
  outline: none;
  border-radius: 6px;
  font-family: var(--ff-display);
  transition: all 0.2s ease;
  box-shadow: none;
}
.header-search-form input:focus {
  border: 1px solid transparent;
  outline: none;
  box-shadow: 0 2px 8px rgba(17, 17, 17, 0.2);
}
.search-field {
  padding: 6px;
  font-size: 1rem;
}
.search-submit,
.search-submit:hover {
  padding: 6px 10px;
  font-size: 1rem;
  background: none;
  border: none;
  outline: none;
}
.search-form-btn.fa-solid.fa-magnifying-glass,
.search-form-btn.fa-solid.fa-magnifying-glass:hover {
  background: none;
  color: white;
}

/*
 * MOBILE CONTACT TRAY
 * ----------------------------------------- */
.bcg-contact-tray {
  display: flex;
  align-items: center;
  justify-content: stretch;
  background-color: var(--clr-brand-1);
  width: 100%;
  border-top: 1px solid white;
}
.bcg-contact-tray__item {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.875rem 0;
  color: white;
  text-decoration: none;
  font-size: 1.25rem;
  transition: opacity 0.2s ease;
}
.bcg-contact-tray__item:hover,
.bcg-contact-tray__item:focus {
  opacity: 0.75;
  color: white;
}
.bcg-contact-tray__divider {
  width: 1px;
  height: 1.5rem;
  background-color: rgba(255, 255, 255, 0.4);
  flex-shrink: 0;
}
