/*
Theme Name: NU's Hullforest 2023Child theme
Theme URI: https://wordpress.org/themes/twentytwentythree
Author: Nubbernaut Cooperative
Author URI: https://nubbernaut.com
Description: A clean simple theme with added useful blocks
Requires at least: 6.1
Tested up to: 6.1
Requires PHP: 5.6
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
Text Domain: hullforesttwentytwentythree
Template: twentytwentythree
Tags: one-column, custom-colors, custom-menu, custom-logo, editor-style, featured-images, full-site-editing, block-patterns, rtl-language-support, sticky-post, threaded-comments, translation-ready, wide-blocks, block-styles, accessibility-ready, blog, portfolio, news
*/

/* -- General -- */
.full-width {
  width: 100%;
}
body {
  font-size: 18px;
}

body .wp-site-blocks > * + * {
  margin-block-start: 0.25em;
}
@media (min-width: 745px) {
  /* .hull_cat_display_block {
        max-height: 368px;
        overflow: hidden;
    } */
  .desktop-partial-width {
    max-width: var(--wp--style--global--content-size);
    margin-right: auto;
    margin-left: auto;
  }
}

/* -- Header Sizing -- */

@media (min-width: 1324px) {
  .mobile-only {
    display: none !important;
  }
  header.wp-block-template-part > * > div.desktop-only.desktop-header {
    height: 89px;
  }

  .desktop-only {
    display: inherit;
  }
}
@media (max-width: 1325px) {
  .mobile-only {
    display: inherit;
  }

  header.wp-block-template-part > * > div.mobile-only {
    height: 50px;
  }

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

  .mobile-center-text-align,
  .mobile-center-text-align h3,
  .mobile-center-text-align p {
    text-align: center !important;
  }

  h1.mobile-left-text-align {
    font-size: 21px;
  }

  .desktop-only {
    display: none !important;
  }

  .mobile-only:has(nav) figure a img {
    max-width: 154px;
    max-height: 75px;
  }

  body .nu-searchboxToggle {
    display: none;
  }

  .wp-block-navigation__container {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
    gap: 36px !important;
  }

  .wp-block-navigation-submenu {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
  }

  .wp-block-navigation__submenu-icon {
    display: inline !important;
    align-self: end !important;
    height: 2em !important;
    width: 3em !important;
    margin-top: -1.7em;
    transition: all 0.25s ease-in-out;
    transform: rotate(0turn);
    background-color: #9fb93c !important;
  }

  .wp-block-navigation__submenu-container {
    opacity: 0 !important;
    max-height: 0 !important;
    z-index: 0 !important;
    overflow: hidden;
    transition: all 0.25s ease-in-out;
    padding-top: 0.25em !important;
    padding-right: 0 !important;
    width: calc(100% -2rem) !important;
  }

  ul.wp-block-navigation__submenu-container {
    width: calc(100% - 2rem) !important;
    gap: 36px !important;
  }
  footer .wp-block-columns {
    flex-wrap: wrap !important;
    padding: 0 !important;
    margin: auto !important;
  }

  footer .wp-block-column {
    width: 100% !important;
    flex-basis: 100% !important;
  }
  .homepage-mobile-padding {
    margin: 0 var(--wp--preset--spacing--30);
  }
}
.hidden-content {
  display: none !important;
}
.header-flex-container {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

body h2,
body h3,
body h4 {
  padding-top: 1rem;
  margin-block-end: 1.125rem;
}

@media screen and (min-width: 1460px) {
  .header-flex-container {
    padding-left: var(--wp--preset--spacing--50) !important;
    padding-right: var(--wp--preset--spacing--50) !important;
  }
}
@media screen and (max-width: 1077px) and (min-width: 745px) {
  header.wp-block-template-part > * > div.desktop-only.desktop-header {
    height: initial;
  }
  .header-flex-container {
    justify-content: center !important;
  }
}

@media (max-width: 745px) {
  h3 {
    font-size: clamp(21px, 1.3rem + ((1vw - 3.2px) * 1.33), 34px);
  }

  .woocommerce ul.products[class*="columns-"] li.product,
  .woocommerce-page ul.products[class*="columns-"] li.product {
    width: 100% !important;
  }
  /* .hull_cat_display_block {
        max-height: 300px;
        overflow: hidden;
        width: 100%;
    } */
  .mobile-full-width {
    margin-right: calc(var(--wp--style--root--padding-right) * -1);
    margin-left: calc(var(--wp--style--root--padding-left) * -1);
  }
  .mobile-partial-width {
    padding-right: var(--wp--style--root--padding-right);
    padding-left: var(--wp--style--root--padding-left);
  }
  .breadcrumbs.wp-block-bcn-breadcrumb-trail {
    display: none;
  }

  footer h5.wp-block-heading.has-text-align-center {
    font-size: 18px !important;
  }
  footer .hull-footer-address {
    text-align: center;
    font-size: 18px !important;
  }

  .h4-sizing {
    font-size: 24px;
  }

  .wp-block-navigation__container {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
    gap: 36px !important;
  }
  .wp-block-navigation-submenu {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
  }
  .wp-block-navigation__submenu-icon {
    display: inline !important;
    align-self: end !important;
    height: 2em !important;
    width: 3em !important;
    margin-top: -1.7em;
    transition: all 0.25s ease-in-out;
    transform: rotate(0turn);
    background-color: #9fb93c !important;
  }
  .wp-block-navigation__submenu-container {
    opacity: 0 !important;
    max-height: 0 !important;
    z-index: 0 !important;
    overflow: hidden;
    transition: all 0.25s ease-in-out;
    padding-top: 0.25em !important;
    padding-right: 0 !important;
    width: calc(100% -2rem) !important;
  }
  ul.wp-block-navigation__submenu-container {
    width: calc(100% - 2rem) !important;
    gap: 36px !important;
  }
}

footer.wp-block-template-part {
  margin-block-start: 0;
}

.wp-block-file * + .wp-block-file__button {
  margin-left: 0;
}

.desktop-only nav ul li a:hover {
  text-decoration: underline;
  text-decoration-line: underline;
}

/* -- WooCommerce Overrides -- */
body a:where(:not(.wp-element-button)):hover {
  border-color: #ffffff;
  border-width: 0;
  border-style: none;
  text-decoration: solid;
  color: var(--wp--preset--color--primary);
}

a.woocommerce-LoopProduct-link.woocommerce-loop-product__link p {
  margin: 0;
}

/*Browse by species page*/

/* This will need to change on live since page ids are different and browse by species isn't unique */
/* .tax-product_cat h1,
.page-id-4095 h1 {
  font-weight: 600;
  font-size: 40px;
} */

/* .archive.tax-product_cat .products.columns-3 {
    margin-top: calc(var(--wp--style--block-gap) + 18px);
} */

.woocommerce .products .product-category a div {
  font-weight: 600;
  text-decoration-color: var(--wp--preset--color--primary);
  text-decoration-line: underline;
  color: var(--wp--preset--color--primary);
  font-size: 18px;
}
.woocommerce .products .product-category a:hover > div {
  text-decoration-line: none;
}
.woocommerce-LoopProduct-link.woocommerce-loop-product__link {
  width: 100%;
}
.hull_cat_display_block img.attachment-woocommerce_thumbnail {
  height: 100% !important;
  max-width: 100%;
  width: 100% !important;
  object-fit: cover;
}

.tax-product_cat footer .wp-block-separator,
.page-id-4095 footer .wp-block-separator,
.page-id-3894 footer .wp-block-separator,
.single-product footer .wp-block-separator {
  margin-top: 0 !important;
}

@media screen and (min-width: 745px) {
  .woocommerce .products .product-category a div {
    font-size: 21px;
  }
}

/* -- Menu Customisation -- */
.wp-block-navigation-item.open-on-click
  .wp-block-navigation-submenu__toggle[aria-expanded="false"]
  ~ ul.wp-block-navigation__submenu-container {
  display: none;
}

@media (max-width: 745px) {
  .woocommerce .products .product-category a div {
    font-size: 21px;
  }
}
.current-menu-item,
.tax-product_cat
  .wp-block-navigation-item.wp-block-navigation-submenu:first-of-type,
.single-product
  .wp-block-navigation-item.wp-block-navigation-submenu:first-of-type,
.wp-block-navigation-item.wp-block-navigation-submenu:first-of-type:has(
    .current-menu-item
  ),
.wp-block-navigation-item:has(.current-menu-item) {
  box-shadow: 0 4px 0px 0px var(--wp--preset--color--tertiary);
}
@media (min-width: 745px) {
  .wp-block-navigation
    .has-child:not(.open-on-click):hover
    > .wp-block-navigation__submenu-container {
    min-width: 250px;
  }
}

body header .desktop-header {
  margin-block-start: 0.75rem;
}
i.fas.fa-cart-shopping {
  position: relative;
  z-index: 1;
  display: inline-block;
  color: #ffffff !important;
  min-width: 20px;
}

.cart-button:hover {
  cursor: pointer;
  background-color: var(--wp--preset--color--contrast) !important;
  color: var(--wp--preset--color--base);
}
.product-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  cursor: pointer;
  background-color: var(--wp--preset--color--contrast) !important;
  color: var(--wp--preset--color--base);
  text-decoration: underline !important;
}

i.fas.fa-cart-shopping:hover:after {
  content: "";
  position: absolute;
  width: 100%;
  bottom: -4px;
  left: 0;
  height: 2px;
  background-color: #ffffff;
}

i.fa-solid.fa-magnifying-glass {
  position: relative;
}

.desktop-only nav {
  margin-right: 6px;
}

.mobile-only nav button.always-shown svg path {
  stroke: black;
}

/* .mobile-only nav button:has(svg):focus {
    background-color: white !important;
} */

.mobile-only .nu-searchboxToggle > i.fa-solid.fa-magnifying-glass:after {
  content: "Search";
  font-size: 12px;
  font-family: "Sofia-Pro";
  position: absolute;
  bottom: -1rem;
  left: 0;
  font-weight: 100;
  text-transform: uppercase;
}

header
  .wp-block-group.mobile-only.wp-block-group-is-layout-flex:has(
    nav.mobile-only
  ) {
  flex-direction: row-reverse;
}

.nu-searchbox {
  background-color: rgba(0, 0, 0, 0.9) !important;
  font-family: var(--wp--preset--font-family--graphik);
  color: var(--wp--preset--color--white) !important;
  margin-block-start: 0;
  position: absolute !important;
  top: 103px !important;
  height: 100vh !important;
  padding: 0 !important;
  width: 100vw !important;
  -webkit-backdrop-filter: blur(1px);
  backdrop-filter: blur(1px);
  padding-top: 8rem !important;
}
@media screen and (max-width: 1199px) {
  .nu-searchbox {
    top: 134px !important;
  }
}
@media screen and (max-width: 868px) {
  .nu-searchbox {
    top: 99px !important;
    flex-grow: unset;
  }
  button.nu-searchboxClose {
    top: 8.9rem !important;
    width: 32px !important;
    height: 32px !important;
    left: calc(50% + 10rem) !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .nu-searchbox form > div > div {
    max-width: calc(100vw - 8rem) !important;
  }

  .nu-searchbox input[type="submit"] {
    left: 0 !important;
  }

  .nu-searchbox .fa-magnifying-glass:before,
  .fa-search:before {
    font-size: 23px;
    top: -0.3rem !important;
  }
}

@media screen and (max-width: 534px) {
  button.nu-searchboxClose {
    left: calc(100vw - 4rem) !important;
  }
}
.nu-searchbox label {
  display: block;
  position: absolute;
  top: 5rem;
}

.nu-searchbox .fa-magnifying-glass:before,
.fa-search:before {
  content: "\f002";
  color: rgba(0, 0, 0, 0.7);
  position: absolute;
  left: -2.2rem;
  top: -0.2rem;
  font-size: 23px;
}

/* This button is positioned in front of the input field */
body button.nu-searchboxClose {
  border: none;
  position: absolute;
  top: 9rem;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  height: 32px;
  width: 32px;
  font-weight: bold;
  color: white;
  left: calc(50% + 12rem);
  display: flex;
  justify-content: center;
  align-items: center;
}
button.nu-searchboxClose:hover {
  cursor: pointer;
}

.nu-searchbox form {
  /* margin-left: 15em; */
  /* padding: 100px; */
  max-width: var(--wp--style--global--content-size);
  margin: auto;
}

.nu-searchbox form > div > div {
  margin-left: calc(50% - 250px);
  margin-right: calc(50% - 250px);
  border-bottom: 1px solid black;
  position: relative;
  margin-top: 0.5em;
  height: 1.6em;
  background-color: white;
  padding: 0.5rem 3rem;
  border-radius: 3px;
}

.nu-searchbox input[type="submit"] {
  position: absolute;
  top: 4.7rem;
  color: #ffffff;
  background-color: var(--wp--preset--color--primary);
  border: none;
  padding: 0.5rem 2rem 0.5rem 2rem;
  width: 100%;
  font-size: 18px;
}

.nu-searchbox input[type="text"] {
  background-color: inherit;
  border: none;
  width: 100%;
}

.nu-searchbox input[type="text"]::placeholder {
  font-weight: 900;
}

nav.is-responsive.mobile-only.wp-block-navigation {
  margin-top: -9px;
}
nav.is-responsive.mobile-only.wp-block-navigation:after {
  content: "Menu";
  font-size: 12px;
  font-family: "Sofia-Pro";
  position: absolute;
  bottom: -1rem;
  left: 0.35rem;
  font-weight: 100;
}

.nu-searchboxToggle {
  min-width: 39px;
}

.nu-searchboxToggle .fa-solid.fa-magnifying-glass {
  font-size: 33px;
  margin-bottom: 4px;
  padding-bottom: 2px;
  min-width: 33px;
}

.cart-button a {
  min-width: 83px;
}
.nu-searchboxToggle .fa-solid.fa-magnifying-glass:before {
  position: relative;
  left: 5px;
}
.wp-block-navigation__responsive-container-close svg,
.wp-block-navigation__responsive-container-open svg {
  height: 44px;
  width: 44px;
}

/* -- Home Page -- */
.normal-line-height {
  line-height: 1;
}

.home .wp-site-blocks > * + *,
.page-id-75316 .wp-site-blocks > * + * {
  margin-block-start: 0;
}
.home .homepage-text-container {
  column-gap: 0.25em !important;
  gap: 0.25em !important;
}
.landing-header {
  font-weight: 500;
}
@media screen and (min-width: 745px) {
  .landing-header {
    text-shadow: 1px 1px 1px #000;
    font-size: 5.2em !important;
  }
  .home .landing-button {
    font-size: 24px !important;
  }
}
@media screen and (max-width: 745px) {
  .landing-header {
    text-shadow: 1px 1px 1px #000;
    font-size: 2.55rem !important;
  }
  .home .landing-button {
    font-size: 18px !important;
  }
}
.landing-header-image h1,
.landing-header-image .wp-block-button,
.landing-header-image p {
  z-index: 1;
}
.landing-links a {
  color: #ffffff !important;
}
.landing-links a:hover {
  color: #ffffff !important;
  text-decoration: none;
}
/* --Single Product Page -- */
.productgrid {
  display: grid;
  grid-template-columns: 1fr 402px;
  gap: 36px;
}
.woocommerce .quantity input[type="number"] {
  border: 1px solid #000000;
  margin-top: 15px;
  height: 24px;
}

.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
  text-align: left;
  color: var(--wp--preset--color--primary) !important;
  padding-top: 0px;
  text-decoration: underline !important;
  margin-top: 0px;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.6;
}

.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
  font-size: 21px;
}
.woocommerce ul.products li.product a:hover h2 {
  text-decoration: none !important;
}

@media screen and (max-width: 745px) {
  .archive .tax-product.woocommerce ul.products[class*="columns-"] li.product,
  .woocommerce-page ul.products[class*="columns-"] li.product {
    margin-bottom: 1rem;
  }
}
.archive
  .tax-product_cat
  .woocommerce
  ul.products
  li.product
  h2.woocommerce-loop-product__title {
  line-height: 28.8px;
}
.product-button {
  width: 100%;
  height: 54px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--wp--preset--color--primary);
  color: #ffffff;
  border: none;
  font-size: 18px;
}

.forminator-field p {
  margin: 0;
}

@media (max-width: 768px) {
  .productgrid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.product-specifications-top {
  display: grid;
  grid-template-columns: 1fr;
  outline: 1px solid #d5d3d3;
}
.product-specifications-item__item {
  padding: 8px 16px;
}
.product-specifications-top .product-specifications-item__item:nth-child(odd) {
  background-color: #f4efef;
}

.tax-product_cat.woocommerce ul.products li.product,
.tax-product_cat.woocommerce-page ul.products li.product {
  margin-bottom: 1rem;
}

.woocommerce ul.products li.product {
  margin-top: 0;
}

body.woocommerce-page .is-layout-flex.is-nowrap {
  flex-wrap: nowrap;
}
@media (max-width: 768px) {
  .woocommerce.woocommerce-page .wp-block-group {
    flex-wrap: wrap;
  }
}

@media (min-width: 745px) {
  .tax-product_cat .products.columns-4 img {
    aspect-ratio: 300/230;
  }
}

.fade-in {
  opacity: 0;
  animation: fadeIn ease 1s;
  animation-fill-mode: forwards;
  animation-duration: 1s;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.nu-searchboxToggle .fa-solid.fa-magnifying-glass:before,
i.fas.fa-cart-shopping:before {
  opacity: 0;
  animation: fadeIn ease 0.75s;
  animation-fill-mode: forwards;
  animation-duration: 0.75s;
}
.postid-5458.woocommerce .product-content-block .single_add_to_cart_button,
.postid-5458 .hullforest-product-title,
.postid-5455.woocommerce .product-content-block .single_add_to_cart_button,
.postid-5455 .hullforest-product-title {
  display: none;
}

.postid-5458 .product-specifications-top,
.postid-5455 .product-specifications-top {
  outline: none;
}

.page-id-4095 .is-layout-constrained > p {
  margin-block-start: 1.125rem; /* top */
  margin-block-end: 0; /* bottom */
}

.tax-product_cat ul.products.columns-3 {
  margin-bottom: -3rem;
}

h1.wp-block-post-title {
  margin-block-start: 1.5rem;
}

.wp-block-woocommerce-cart .wc-block-grid {
  display: none;
}

.wp-block-woocommerce-cart .wp-block-heading.has-text-align-center {
  display: none;
}
.wp-block-woocommerce-cart .wc-block-components-totals-taxes,
.wp-block-woocommerce-cart .wc-block-components-order-meta,
.wp-block-woocommerce-cart .wc-block-components-product-metadata {
  display: none;
}

/*
Theme Name: NU's Hullforest 2023Child theme
Theme URI: https://wordpress.org/themes/twentytwentythree
Author: Nubbernaut Cooperative
Author URI: https://nubbernaut.com
Description: A clean simple theme with added useful blocks
Requires at least: 6.1
Tested up to: 6.1
Requires PHP: 5.6
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
Text Domain: hullforesttwentytwentythree
Template: twentytwentythree
Tags: one-column, custom-colors, custom-menu, custom-logo, editor-style, featured-images, full-site-editing, block-patterns, rtl-language-support, sticky-post, threaded-comments, translation-ready, wide-blocks, block-styles, accessibility-ready, blog, portfolio, news
*/

/* -- General -- */
.full-width {
  width: 100%;
}
body {
  font-size: 18px;
}

body .wp-site-blocks > * + * {
  margin-block-start: 0.25em;
}
@media (min-width: 745px) {
  /* .hull_cat_display_block {
        max-height: 368px;
        overflow: hidden;
    } */
  .desktop-partial-width {
    max-width: var(--wp--style--global--content-size);
    margin-right: auto;
    margin-left: auto;
  }
}

/* -- Header Sizing -- */

@media (min-width: 1324px) {
  .mobile-only {
    display: none !important;
  }
  header.wp-block-template-part > * > div.desktop-only.desktop-header {
    height: 89px;
  }

  .desktop-only {
    display: inherit;
  }
}
@media (max-width: 1325px) {
  .mobile-only {
    display: inherit;
  }

  header.wp-block-template-part > * > div.mobile-only {
    height: 50px;
  }

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

  .mobile-center-text-align,
  .mobile-center-text-align h3,
  .mobile-center-text-align p {
    text-align: center !important;
  }

  h1.mobile-left-text-align {
    font-size: 21px;
  }

  .desktop-only {
    display: none !important;
  }

  .mobile-only:has(nav) figure a img {
    max-width: 154px;
    max-height: 75px;
  }

  body .nu-searchboxToggle {
    display: none;
  }

  .wp-block-navigation__container {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
    gap: 36px !important;
  }

  .wp-block-navigation-submenu {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
  }

  .wp-block-navigation__submenu-icon {
    display: inline !important;
    align-self: end !important;
    height: 2em !important;
    width: 3em !important;
    margin-top: -1.7em;
    transition: all 0.25s ease-in-out;
    transform: rotate(0turn);
    background-color: #9fb93c !important;
  }

  .wp-block-navigation__submenu-container {
    opacity: 0 !important;
    max-height: 0 !important;
    z-index: 0 !important;
    overflow: hidden;
    transition: all 0.25s ease-in-out;
    padding-top: 0.25em !important;
    padding-right: 0 !important;
    width: calc(100% -2rem) !important;
  }

  ul.wp-block-navigation__submenu-container {
    width: calc(100% - 2rem) !important;
    gap: 36px !important;
  }
  footer .wp-block-columns {
    flex-wrap: wrap !important;
    padding: 0 !important;
    margin: auto !important;
  }

  footer .wp-block-column {
    width: 100% !important;
    flex-basis: 100% !important;
  }
  .homepage-mobile-padding {
    margin: 0 var(--wp--preset--spacing--30);
  }
}
.hidden-content {
  display: none;
}
.header-flex-container {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

body h2,
body h3,
body h4 {
  padding-top: 1rem;
  margin-block-end: 1.125rem;
}

@media screen and (min-width: 1460px) {
  .header-flex-container {
    padding-left: var(--wp--preset--spacing--50) !important;
    padding-right: var(--wp--preset--spacing--50) !important;
  }
}
@media screen and (max-width: 1077px) and (min-width: 745px) {
  header.wp-block-template-part > * > div.desktop-only.desktop-header {
    height: initial;
  }
  .header-flex-container {
    justify-content: center !important;
  }
}

@media (max-width: 745px) {
  h3 {
    font-size: clamp(21px, 1.3rem + ((1vw - 3.2px) * 1.33), 34px);
  }

  .woocommerce ul.products[class*="columns-"] li.product,
  .woocommerce-page ul.products[class*="columns-"] li.product {
    width: 100% !important;
  }
  /* .hull_cat_display_block {
        max-height: 300px;
        overflow: hidden;
        width: 100%;
    } */
  .mobile-full-width {
    margin-right: calc(var(--wp--style--root--padding-right) * -1);
    margin-left: calc(var(--wp--style--root--padding-left) * -1);
  }
  .mobile-partial-width {
    padding-right: var(--wp--style--root--padding-right);
    padding-left: var(--wp--style--root--padding-left);
  }
  .breadcrumbs.wp-block-bcn-breadcrumb-trail {
    display: none;
  }

  footer h5.wp-block-heading.has-text-align-center {
    font-size: 18px !important;
  }
  footer .hull-footer-address {
    text-align: center;
    font-size: 18px !important;
  }

  .h4-sizing {
    font-size: 24px;
  }

  .wp-block-navigation__container {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
    gap: 36px !important;
  }
  .wp-block-navigation-submenu {
    width: 100% !important;
    transition: all 0.25s ease-in-out;
  }
  .wp-block-navigation__submenu-icon {
    display: inline !important;
    align-self: end !important;
    height: 2em !important;
    width: 3em !important;
    margin-top: -1.7em;
    transition: all 0.25s ease-in-out;
    transform: rotate(0turn);
    background-color: #9fb93c !important;
  }
  .wp-block-navigation__submenu-container {
    opacity: 0 !important;
    max-height: 0 !important;
    z-index: 0 !important;
    overflow: hidden;
    transition: all 0.25s ease-in-out;
    padding-top: 0.25em !important;
    padding-right: 0 !important;
    width: calc(100% -2rem) !important;
  }
  ul.wp-block-navigation__submenu-container {
    width: calc(100% - 2rem) !important;
    gap: 36px !important;
  }
}

footer.wp-block-template-part {
  margin-block-start: 0;
}

.wp-block-file * + .wp-block-file__button {
  margin-left: 0;
}

.desktop-only nav ul li a:hover {
  text-decoration: underline;
  text-decoration-line: underline;
}

/* -- WooCommerce Overrides -- */
body a:where(:not(.wp-element-button)):hover {
  border-color: #ffffff;
  border-width: 0;
  border-style: none;
  text-decoration: solid;
  color: var(--wp--preset--color--primary);
}

a.woocommerce-LoopProduct-link.woocommerce-loop-product__link p {
  margin: 0;
}

/*Browse by species page*/

/* This will need to change on live since page ids are different and browse by species isn't unique */
/* .tax-product_cat h1,
.page-id-4095 h1 {
  font-weight: 600;
  font-size: 40px;
} */

/* .archive.tax-product_cat .products.columns-3 {
    margin-top: calc(var(--wp--style--block-gap) + 18px);
} */

.woocommerce .products .product-category a div {
  font-weight: 600;
  text-decoration-color: var(--wp--preset--color--primary);
  text-decoration-line: underline;
  color: var(--wp--preset--color--primary);
  font-size: 18px;
}
.woocommerce .products .product-category a:hover > div {
  text-decoration-line: none;
}
.woocommerce-LoopProduct-link.woocommerce-loop-product__link {
  width: 100%;
}
.hull_cat_display_block img.attachment-woocommerce_thumbnail {
  height: 100% !important;
  max-width: 100%;
  width: 100% !important;
  object-fit: cover;
}

.tax-product_cat footer .wp-block-separator,
.page-id-4095 footer .wp-block-separator,
.page-id-3894 footer .wp-block-separator,
.single-product footer .wp-block-separator {
  margin-top: 0 !important;
}

@media screen and (min-width: 745px) {
  .woocommerce .products .product-category a div {
    font-size: 21px;
  }
}

/* -- Menu Customisation -- */
.wp-block-navigation-item.open-on-click
  .wp-block-navigation-submenu__toggle[aria-expanded="false"]
  ~ ul.wp-block-navigation__submenu-container {
  display: none;
}

@media (max-width: 745px) {
  .woocommerce .products .product-category a div {
    font-size: 21px;
  }
}
.current-menu-item,
.tax-product_cat
  .wp-block-navigation-item.wp-block-navigation-submenu:first-of-type,
.single-product
  .wp-block-navigation-item.wp-block-navigation-submenu:first-of-type,
.wp-block-navigation-item.wp-block-navigation-submenu:first-of-type:has(
    .current-menu-item
  ),
.wp-block-navigation-item:has(.current-menu-item) {
  box-shadow: 0 4px 0px 0px var(--wp--preset--color--tertiary);
}
@media (min-width: 745px) {
  .wp-block-navigation
    .has-child:not(.open-on-click):hover
    > .wp-block-navigation__submenu-container {
    min-width: 250px;
  }
}

body header .desktop-header {
  margin-block-start: 0.75rem;
}
i.fas.fa-cart-shopping {
  position: relative;
  z-index: 1;
  display: inline-block;
  color: #ffffff !important;
  min-width: 20px;
}

.cart-button:hover {
  cursor: pointer;
  background-color: var(--wp--preset--color--contrast) !important;
  color: var(--wp--preset--color--base);
}
.product-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  cursor: pointer;
  background-color: var(--wp--preset--color--contrast) !important;
  color: var(--wp--preset--color--base);
  text-decoration: underline !important;
}

i.fas.fa-cart-shopping:hover:after {
  content: "";
  position: absolute;
  width: 100%;
  bottom: -4px;
  left: 0;
  height: 2px;
  background-color: #ffffff;
}

i.fa-solid.fa-magnifying-glass {
  position: relative;
}

.desktop-only nav {
  margin-right: 6px;
}

.mobile-only nav button.always-shown svg path {
  stroke: black;
}

/* .mobile-only nav button:has(svg):focus {
    background-color: white !important;
} */

.mobile-only .nu-searchboxToggle > i.fa-solid.fa-magnifying-glass:after {
  content: "Search";
  font-size: 12px;
  font-family: "Sofia-Pro";
  position: absolute;
  bottom: -1rem;
  left: 0;
  font-weight: 100;
  text-transform: uppercase;
}

header
  .wp-block-group.mobile-only.wp-block-group-is-layout-flex:has(
    nav.mobile-only
  ) {
  flex-direction: row-reverse;
}

.nu-searchbox {
  background-color: rgba(0, 0, 0, 0.9) !important;
  font-family: var(--wp--preset--font-family--graphik);
  color: var(--wp--preset--color--white) !important;
  margin-block-start: 0;
  position: absolute !important;
  top: 103px !important;
  height: 100vh !important;
  padding: 0 !important;
  width: 100vw !important;
  -webkit-backdrop-filter: blur(1px);
  backdrop-filter: blur(1px);
  padding-top: 8rem !important;
}
@media screen and (max-width: 1199px) {
  .nu-searchbox {
    top: 134px !important;
  }
}
@media screen and (max-width: 868px) {
  .nu-searchbox {
    top: 99px !important;
    flex-grow: unset;
  }
  button.nu-searchboxClose {
    top: 8.9rem !important;
    width: 32px !important;
    height: 32px !important;
    left: calc(50% + 10rem) !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .nu-searchbox form > div > div {
    max-width: calc(100vw - 8rem) !important;
  }

  .nu-searchbox input[type="submit"] {
    left: 0 !important;
  }

  .nu-searchbox .fa-magnifying-glass:before,
  .fa-search:before {
    font-size: 23px;
    top: -0.3rem !important;
  }
}

@media screen and (max-width: 534px) {
  button.nu-searchboxClose {
    left: calc(100vw - 4rem) !important;
  }
}
.nu-searchbox label {
  display: block;
  position: absolute;
  top: 5rem;
}

.nu-searchbox .fa-magnifying-glass:before,
.fa-search:before {
  content: "\f002";
  color: rgba(0, 0, 0, 0.7);
  position: absolute;
  left: -2.2rem;
  top: -0.2rem;
  font-size: 23px;
}

/* This button is positioned in front of the input field */
body button.nu-searchboxClose {
  border: none;
  position: absolute;
  top: 9rem;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  height: 32px;
  width: 32px;
  font-weight: bold;
  color: white;
  left: calc(50% + 12rem);
  display: flex;
  justify-content: center;
  align-items: center;
}
button.nu-searchboxClose:hover {
  cursor: pointer;
}

.nu-searchbox form {
  /* margin-left: 15em; */
  /* padding: 100px; */
  max-width: var(--wp--style--global--content-size);
  margin: auto;
}

.nu-searchbox form > div > div {
  margin-left: calc(50% - 250px);
  margin-right: calc(50% - 250px);
  border-bottom: 1px solid black;
  position: relative;
  margin-top: 0.5em;
  height: 1.6em;
  background-color: white;
  padding: 0.5rem 3rem;
  border-radius: 3px;
}

.nu-searchbox input[type="submit"] {
  position: absolute;
  top: 4.7rem;
  color: #ffffff;
  background-color: var(--wp--preset--color--primary);
  border: none;
  padding: 0.5rem 2rem 0.5rem 2rem;
  width: 100%;
  font-size: 18px;
}

.nu-searchbox input[type="text"] {
  background-color: inherit;
  border: none;
  width: 100%;
}

.nu-searchbox input[type="text"]::placeholder {
  font-weight: 900;
}

nav.is-responsive.mobile-only.wp-block-navigation {
  margin-top: -9px;
}
nav.is-responsive.mobile-only.wp-block-navigation:after {
  content: "Menu";
  font-size: 12px;
  font-family: "Sofia-Pro";
  position: absolute;
  bottom: -1rem;
  left: 0.35rem;
  font-weight: 100;
}

.nu-searchboxToggle {
  min-width: 39px;
}

.nu-searchboxToggle .fa-solid.fa-magnifying-glass {
  font-size: 33px;
  margin-bottom: 4px;
  padding-bottom: 2px;
  min-width: 33px;
}

.cart-button a {
  min-width: 83px;
}
.nu-searchboxToggle .fa-solid.fa-magnifying-glass:before {
  position: relative;
  left: 5px;
}
.wp-block-navigation__responsive-container-close svg,
.wp-block-navigation__responsive-container-open svg {
  height: 44px;
  width: 44px;
}

/* -- Home Page -- */
.normal-line-height {
  line-height: 1;
}

.home .wp-site-blocks > * + *,
.page-id-75316 .wp-site-blocks > * + * {
  margin-block-start: 0;
}
.home .homepage-text-container {
  column-gap: 0.25em !important;
  gap: 0.25em !important;
}
.landing-header {
  font-weight: 500;
}
@media screen and (min-width: 745px) {
  .landing-header {
    text-shadow: 1px 1px 1px #000;
    font-size: 5.2em !important;
  }
  .home .landing-button {
    font-size: 24px !important;
  }
}
@media screen and (max-width: 745px) {
  .landing-header {
    text-shadow: 1px 1px 1px #000;
    font-size: 2.55rem !important;
  }
  .home .landing-button {
    font-size: 18px !important;
  }
}
.landing-header-image h1,
.landing-header-image .wp-block-button,
.landing-header-image p {
  z-index: 1;
}
.landing-links a {
  color: #ffffff !important;
}
.landing-links a:hover {
  color: #ffffff !important;
  text-decoration: none;
}
/* --Single Product Page -- */
.productgrid {
  display: grid;
  grid-template-columns: 1fr 402px;
  gap: 36px;
}
.woocommerce .quantity input[type="number"] {
  border: 1px solid #000000;
  margin-top: 15px;
  height: 24px;
}

.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
  text-align: left;
  color: var(--wp--preset--color--primary) !important;
  padding-top: 0px;
  text-decoration: underline !important;
  margin-top: 0px;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.6;
}

.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
  font-size: 21px;
}
.woocommerce ul.products li.product a:hover h2 {
  text-decoration: none !important;
}

@media screen and (max-width: 745px) {
  .archive .tax-product.woocommerce ul.products[class*="columns-"] li.product,
  .woocommerce-page ul.products[class*="columns-"] li.product {
    margin-bottom: 1rem;
  }
}
.archive
  .tax-product_cat
  .woocommerce
  ul.products
  li.product
  h2.woocommerce-loop-product__title {
  line-height: 28.8px;
}
.product-button {
  width: 100%;
  height: 54px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--wp--preset--color--primary);
  color: #ffffff;
  border: none;
  font-size: 18px;
}

.forminator-field p {
  margin: 0;
}

@media (max-width: 768px) {
  .productgrid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.product-specifications-top {
  display: grid;
  grid-template-columns: 1fr;
  outline: 1px solid #d5d3d3;
}
.product-specifications-item__item {
  padding: 8px 16px;
}
.product-specifications-top .product-specifications-item__item:nth-child(odd) {
  background-color: #f4efef;
}

.tax-product_cat.woocommerce ul.products li.product,
.tax-product_cat.woocommerce-page ul.products li.product {
  margin-bottom: 1rem;
}

.woocommerce ul.products li.product {
  margin-top: 0;
}

body.woocommerce-page .is-layout-flex.is-nowrap {
  flex-wrap: nowrap;
}
@media (max-width: 768px) {
  .woocommerce.woocommerce-page .wp-block-group {
    flex-wrap: wrap;
  }
}

@media (min-width: 745px) {
  .tax-product_cat .products.columns-4 img {
    aspect-ratio: 300/230;
  }
}

.fade-in {
  opacity: 0;
  animation: fadeIn ease 1s;
  animation-fill-mode: forwards;
  animation-duration: 1s;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.nu-searchboxToggle .fa-solid.fa-magnifying-glass:before,
i.fas.fa-cart-shopping:before {
  opacity: 0;
  animation: fadeIn ease 0.75s;
  animation-fill-mode: forwards;
  animation-duration: 0.75s;
}
.postid-5458.woocommerce .product-content-block .single_add_to_cart_button,
.postid-5458 .hullforest-product-title,
.postid-5455.woocommerce .product-content-block .single_add_to_cart_button,
.postid-5455 .hullforest-product-title {
  display: none;
}

.postid-5458 .product-specifications-top,
.postid-5455 .product-specifications-top {
  outline: none;
}

.page-id-4095 .is-layout-constrained > p {
  margin-block-start: 1.125rem; /* top */
  margin-block-end: 0; /* bottom */
}

.tax-product_cat ul.products.columns-3 {
  margin-bottom: -3rem;
}

h1.wp-block-post-title {
  margin-block-start: 1.5rem;
}

.wp-block-woocommerce-cart .wc-block-grid {
  display: none;
}

.wp-block-woocommerce-cart .wp-block-heading.has-text-align-center {
  display: none;
}
.wp-block-woocommerce-cart .wc-block-components-totals-taxes,
.wp-block-woocommerce-cart .wc-block-components-order-meta,
.wp-block-woocommerce-cart .wc-block-components-product-metadata {
  display: none;
}

@media (min-width: 745px) {
  li.product-category.product a {
    width: 100%;
  }

  .woocommerce .product-category a img {
    width: 100%;
    aspect-ratio: 1 / 1;
  }
}