/*
 Theme Name:   Astra Child
 Theme URI:    
 Description:  Child theme for Astra
 Author:       Andy
 Author URI:   
 Template:     astra
 Version:      1.0.0
 Text Domain:  astra-child
*/

/* SITEWIDE STYLES */

body {
  background-color: #FAF8F4 !important;
}

 .wp-block-uagb-advanced-heading.uagb-block-fd3b9084.wp-block-uagb-advanced-heading .uagb-heading-text {
     text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.15);
}

 .wp-block-uagb-advanced-heading.uagb-block-fd3b9084.wp-block-uagb-advanced-heading .uagb-desc-text {
    text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.15);
}

 @keyframes rubberWiggleBounce {
     0% {
         transform: translateY(0) rotate(0deg);
    }
     15% {
         transform: translateY(-1.5px) rotate(5deg);
    }
     30% {
         transform: translateY(1px) rotate(-5deg);
    }
     45% {
         transform: translateY(-1px) rotate(3deg);
    }
     60% {
         transform: translateY(0.5px) rotate(-2deg);
    }
     75% {
         transform: translateY(-0.5px) rotate(1.5deg);
    }
     90% {
         transform: translateY(0px) rotate(-1deg);
    }
     100% {
         transform: translateY(0) rotate(0deg);
    }
}

 @keyframes starSpin {
     from {
         transform: rotate(0deg);
    }
     to {
         transform: rotate(360deg);
    }
}

 #LogoGroup {
     transform-box: fill-box;
     transform-origin: center;
     animation: rubberWiggleBounce 0.85s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
     animation-delay: 0.4s;
}

 #Star {
     transform-box: fill-box;
     transform-origin: center;
     animation: starSpin 0.5s ease-out;
     animation-play-state: paused;
     animation-iteration-count: 1;
     animation-fill-mode: none;
    /* Reset after each run */
}

 #LogoGroup:hover #Star {
     animation-play-state: running;
}

/* Header hover effects (icons + avatar) */
 .ast-search-menu-icon svg:hover, .ast-header-woo-cart .icon-bag svg:hover, .ast-header-account-type-icon .account-icon:hover, .ast-header-account-link:hover img {
     transform: scale(1.1);
     transition: transform 0.1s ease;
     cursor: pointer;
}

/* Footer subscription form */
 .ff-btn-submit[data-name="custom_submit_button-2_1"]:hover {
	border-radius: 12px !important;
	background-color: #2b2b2b !important;
	color:#F3F4F6 !important;
	vertical-align: middle !important;
}

.site-footer .ff-el-form-control {
	border-radius: 10px !important;
}

.ff-t-container {
  display: flex;
  align-items: center;
}

.ff-t-cell {
  display: flex;
  align-items: center;
}

.ff-t-column-1 {
  flex: 1; /* Let the input column grow */
}

.ff-t-column-2 {
  flex: 0 0 auto; /* Button keeps its natural size */
}

.ff-t-column-1 .ff-el-input--content {
  width: 100%; /* Ensures input fills its cell */
}

#ff_2_email {
  min-width: 160px;
}

@media (min-width: 768px) {
  #ff_2_email {
    min-width: 280px;
  }
}

/* End Footer subscription form */
/* Hide next post at the bottom */
 .post-navigation {
	display:none;
}

/* Fade on home hero bg */
/* 
.hero-header::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  pointer-events: none;
  min-height: 80px;
   background: linear-gradient(to bottom, rgba(250, 248, 244, 0) 0%, #FAF8F4 100%);
  z-index: 2;
  transform: translateZ(0);
  backface-visibility: hidden;
  will-change: transform;
  transform-style: preserve-3d;
}

.hero-header:before {
      backface-visibility: hidden;
  will-change: transform;
  transform-style: preserve-3d;
}
*/

/* Home search box */
#wp-block-search__input-1 {
	border: 1px solid #70b3a6;
}

#post-37 .wp-block-search__button {
	background:#70b3a6;
}
#post-37 .wp-block-search__button:hover {
	background:#3B82F6;
}

#post-37 nav ul li a {
	text-decoration:none !important;
}

a.menu-link:hover {
    transform: scale(1.05) !important;
}


/* WPDISCUZ ELEMENTS */

.comments-area, #comments, .comment-respond {
     margin-top: 0rem !important;
}

 .wpd-login {
     color: #3c7c75;
     font-size: 1.1em;
}

 .wpd-login a {
     color: #3c7c75 !important;
     font-size: 1.1em;
     font-weight:600;
     text-decoration: none;
}

 .wpd-login a:hover {
     color:#355c7d;
}

 #wpdcom .wpd-form-head {
     margin-bottom:0px;
     border-bottom: 1px solid rgba(90, 78, 92, 0.3);
}

 .ast-separate-container .ast-article-single {
    padding-bottom:1px;
}

 .wpd-login::before {
     content: "\f007";
    /* Font Awesome user icon */
     font-family: "Font Awesome 6 Free";
    /* or Font Awesome 5, depending on your version */
     font-weight: 900;
     display: inline-block;
     margin-right: 6px;
     margin-bottom: 2px;
     vertical-align: middle;
}

.comments-area {
    width:auto;
}

 #wpdcom {
    max-width:950px !important;
}

 .wpd-login {
    color:#355c7d;
}

 #wpdcom .wpd-thread-head {
     border-bottom: 2px solid rgba(90, 78, 92, 0.3);
}

 #wpdcom .wpd-thread-head .wpd-thread-info {
    color:rgba(90, 78, 92, 0.9);
     border-bottom: 2px solid rgba(90, 78, 92, 0.6);
}

 #wpdcom .wpd-thread-head .wpdiscuz-user-settings {
    color:rgba(90, 78, 92, 0.9);
     border-bottom: 2px solid rgba(90, 78, 92, 0.6);
}


/* WPFORO PAGES */

/* Pill for subscriber categories */
 .exclusive {
     pointer-events: none;
     background-color: #046bd2;
     border: none;
     color: #ffffff !important;
     padding: 5px 10px;
     text-align: center;
     font-weight: 120%;
     text-decoration: none;
     display: inline-block;
     margin-right: 13px;
     margin-left: 0px;
     margin-bottom: 10px;
     margin-top: 10px;
     border-radius: 10px;
}

/* Header and footer changes */
 .wpf-head-bar,.wpforo-category,.wpf-breadcrumb div:first-child,.wpf-button,.wpf-button-outlined, .wpf-post-create {
    border-radius:5px !important;
}

 .wpf-breadcrumb .wpf-root {
    border-left: none !important;
}

 .wpft-forum .wpf-breadcrumb {
     display: none !important;
}

 .wpforo-category .cat-name {
     font-family: 'Fredoka', sans-serif;
     font-size:130%;
     letter-spacing: 1.5px;
}

 .wpf-head-bar #wpforo-title {
    display:block;
}

 #wpforo-title {
    display:none;
}

#wpforo-wrap{
     font-size: 13px;
     width: 90% !important;
     padding: 10px 0;
     margin: auto !important;
}

@media (max-width: 480px) {
  #wpforo-wrap {
    width: 100% !important;
  }
}

 .wpforo-topic-footer {
    display:none;
}

 .cat-name {
    font-weight: bold!important;
     color: #35186e!important;
     font-size: 120% !important;
}

 .wpforo-profile-back {
    display: none !important;
}

/* Hiding profile options */
 .wpforo-membertoggle {
    display:none;
}

/* Update buttons */
 #main #wpforo #wpforo-wrap .wpforo-main .wpforo-content .wpf-head-bar .wpf-head-bar-right #add_wpftopic.wpf-button {
     border-radius: 999px !important;
     border: 0 !important;
     padding: 10px 20px !important;
}

 .wpf-button-outlined {
     border-radius: 999px !important;
     border: 1px solid #5A4E5C !important;
     color: #5A4E5C !important;
}

 .wpfcl-5 {
     color: #5A4E5C !important;
}

 .fa-feather-alt {
    display:none;
}



/* ULTIMATE MEMBERS PAGES */

/* Link colors */
.um a.um-link,
.um .um-tip:hover,
.um .um-field-radio.active:not(.um-field-radio-state-disabled) i,
.um .um-field-checkbox.active:not(.um-field-radio-state-disabled) i,
.um .um-member-name a:hover,
.um .um-member-more a:hover,
.um .um-member-less a:hover,
.um .um-members-pagi a:hover,
.um .um-cover-add:hover,
.um .um-profile-subnav a.active,
.um .um-item-meta a,
.um-account-name a:hover,
.um-account-nav a.current,
.um-account-side li a.current span.um-account-icon,
.um-account-side li a.current:hover span.um-account-icon,
.um-dropdown li a:hover,
i.um-active-color,
span.um-active-color
{
    color: #3c7c75 !important;
}

.um a.um-link:hover,
.um a.um-link-hvr:hover {
    color: #1E2A38 !important;
}

/* Button colors */
.um .um-field-group-head,
.picker__box,
.picker__nav--prev:hover,
.picker__nav--next:hover,
.um .um-members-pagi span.current,
.um .um-members-pagi span.current:hover,
.upload,
.um-modal-header,
.um-modal-btn,
.um-modal-btn.disabled,
.um-modal-btn.disabled:hover,
div.uimob800 .um-account-side li a.current,
div.uimob800 .um-account-side li a.current:hover,
.um .um-button,
.um a.um-button,
.um a.um-button.um-disabled:hover,
.um a.um-button.um-disabled:focus,
.um a.um-button.um-disabled:active,
.um input[type=submit].um-button,
.um input[type=submit].um-button:focus,
.um input[type=submit]:disabled:hover
{
    background: #3c7c75 !important;
}

.um .um-field-group-head:hover,
.picker__footer,
.picker__header,
.picker__day--infocus:hover,
.picker__day--outfocus:hover,
.picker__day--highlighted:hover,
.picker--focused .picker__day--highlighted,
.picker__list-item:hover,
.picker__list-item--highlighted:hover,
.picker--focused .picker__list-item--highlighted,
.picker__list-item--selected,
.picker__list-item--selected:hover,
.picker--focused .picker__list-item--selected,
.um .um-button:hover,
.um a.um-button:hover,
.um input[type=submit].um-button:hover{
    background: #1E2A38 !important;
}

.um .um-profile-nav-item.active a {
	background: #334155 !important;
}

.um .um-profile-nav-item.active a:hover {
	background: #334155 !important;
}

/* Button alt colors */
.um .um-button.um-alt, 
.um input[type=submit].um-button.um-alt {
    background: #eeeeee !important;
}

.um .um-button.um-alt:hover,
.um input[type=submit].um-button.um-alt:hover {
    background: #e5e5e5 !important;	
}

/* Profile and account */
 .um-account-profile-link a.um-link {
     display: inline-block;
     background-color: #3c7c75;
    /* light brand tone */
     color: #ffffff !important;
     padding: 6px 6px;
     border-radius: 4px;
     font-weight: 600;
     text-decoration: none;
     transition: background-color 0.1s ease;
     margin-top:8px;
}
 .um-account-profile-link a.um-link:hover {
     background-color: #2b2b2b;
     color: #ffffff !important;
}
 .um-account-side li a {
     color: #3c7c75;
}
 .um-account-side li,.um-profile-nav {
     background: #D4DCE0;
}
 .um-profile-nav {
     background: #D4DCE0;
}
 .um-profile-nav-item a {
	 color: #334155 !important;
}
 .um-profile-nav-item:hover a {
	 color: #D4DCE0 !important;
}

 p.um-notice.success {
    background:#355c7d;
}
 .um-faicon-cog {
    color:#3c7c75;
}
 .um-field-error {
     background: #D9737C;
}
 .um-field-arrow,.um span.um-req {
     color: #D9737C;
}
 #um_field_0_user_login {
    display:none;
}
 .um-account-side li {
     border-radius: 5px;
}
 .um-account-tab-merch-shop .woocommerce-MyAccount-content {
  display: none;
}
 .um-account-meta .um-1824 {
        max-width: 1000px !important;
    }
 
.um-request-button {
	text-decoration:none !important;
	background: #F3F4F6;
	color: #3c7c75;
}
.um-request-button:hover {
	text-decoration:none !important;
	background: #3c7c75;
	color: white;
}


/* TUTORLMS PAGES */

/* Hide specific Tutor dashboard menu items */
 .tutor-dashboard-menu-purchase_history, 
 .tutor-dashboard-menu-my-profile, 
 .tutor-dashboard-menu-logout, 
 .tutor-dashboard-menu-settings, 
 .tutor-dashboard-menu-index, 
 .tutor-dashboard-menu-divider, 
 .tutor-frontend-dashboard-header {
     display: none !important;
}


/* WOOCOMMERCE PAGES */

 .woocommerce-MyAccount-navigation-link--dashboard {
     display:none;
}

.fh-cart-hidden {
  display: none !important;
}

@keyframes cartPop {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.25);
  }
  100% {
    transform: scale(1);
  }
}

.cart-pop {
  animation: cartPop 0.3s ease-in-out;
}

.woocommerce-page .ast-archive-description {
    border-bottom:none !important;
    margin: 0 !important;
}

.custom-archive-description {
    color: #3c7c75;
    font-weight: 500;
    font-size: 100%;
    font-family: inherit;
    text-align: center;
    margin-bottom: 5px;
}

.custom-merch-title {
    color: #355c7d;
    font-weight: 600;
    font-size: 32px;
    margin-bottom: 15px;
    text-align: center;
    font-family: 'Fredoka', sans-serif;
    line-height: 1.4em;
}

.custom-merch-title {
    color: #355c7d;
    font-weight: 600;
    font-size: 32px;
    margin-bottom: 15px;
    text-align: center;
    font-family: 'Fredoka', sans-serif;
    line-height: 1.4em;
}

@media (min-width: 922px) {
  .custom-merch-title {
    margin-top: -50px;
  }
}

/* OneSignal Button  */

.onesignal-customlink-container {
    min-height: 0 !important;
    display: inline !important;
    margin-left: 10px !important;
    font-size: 13px !important;
    padding: 4px 8px !important;
}

#fh-header-left {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.onesignal-customlink-subscribe {
    align-self: center !important;
    display: inline-flex !important;
    margin: 0 !important;
    align-items: center !important;
    font-weight: 600 !important;
    justify-content: center !important;
    min-height: 19px !important;
    background-color: transparent !important ;
    color: #3c7c75 !important;
    border: 1px solid #3c7c75 !important;
    transition: all 0.2s ease;
    padding: 2px 5px !important;
    white-space: nowrap !important;
    font-size: 0.9rem !important;
    line-height: 25px !important;
}

.onesignal-customlink-subscribe i {
  pointer-events: none;
  font-size: 1.2rem !important;
}

.onesignal-customlink-subscribe:hover {
    transform: scale(1.03) !important;
    color: #1E2A38 !important;
    border: 1px solid #1E2A38 !important;
}

@keyframes bell-ring {
  0% { transform: rotate(0deg); }
  15% { transform: rotate(15deg); }
  30% { transform: rotate(-10deg); }
  45% { transform: rotate(7deg); }
  60% { transform: rotate(-5deg); }
  75% { transform: rotate(3deg); }
  100% { transform: rotate(0deg); }
}

.bell-animate-once {
  display: inline-block;
  animation: bell-ring 1s ease;
  animation-delay: 4.5s;
  animation-fill-mode: both;
  transform-origin: center;
}

@media (max-width: 600px) {
  .onesignal-customlink-subscribe {
    padding: 4px !important;
    font-size: 0 !important;
    width: 20px !important;
    height: 20px !important;
  }

  .onesignal-customlink-subscribe i {
    font-size: 1.2rem !important;
    margin-right: 0 !important;
  }
}

  @media (max-width: 921px) {
  #fh-header-left {
    flex-direction: row-reverse;
  }
  .onesignal-customlink-container {
    margin-right: 10px;
  }
}

/* Fade-in for the subscribe button */
.onesignal-customlink-subscribe {
  opacity: 0 !important;
  transition: opacity 0.4s ease-in !important;
}
.onesignal-customlink-subscribe.ready {
  opacity: 1 !important;
  transform-origin: center center !important;
  animation: subscribePulse 0.3s ease-in-out 4s 2 both;
}
@keyframes subscribePulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.05); }
}

/* POST HEADER */

 .fh-breakout {
            width: 100vw;
            max-width: 100vw;
            position: relative;
            left: 50%;
            right: 50%;
            margin-left: -50vw;
            margin-right: -50vw;
            padding-left: 2rem;
            padding-right: 2rem;
            box-sizing: border-box;
        }

        .fh-header-inner {
            max-width: 1000px;
            margin: 0 auto;
        }

        .fh-post-header {
            display: flex;
            flex-wrap: wrap;
            align-items: flex-start;
            justify-content: space-between;
            margin-bottom: 2rem;
            gap: 1.5rem;
        }
        .fh-post-header-text {
            flex: 1 1 60%;
            min-width: 0;
        }
        .fh-post-meta-line {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 0.75rem;
            color: #3c7c75;
            font-weight: 500;
            margin-bottom: 1rem;
            font-size: 1rem;
        }
        .fh-post-meta-line .fh-meta-date,
        .fh-post-meta-line .fh-meta-reading {
            color: #3c7c75;
        }
        .fh-post-category {
            background: #3c7c75;
            color: #fff;
            padding: 0.2rem 0.6rem;
            border-radius: 6px;
            display: inline-block;
            font-size: 1rem;
            text-decoration: none;
            transition: background 0.3s ease;
        }
        .fh-post-category:hover {
            background: #1E2A38;
            cursor: pointer;
            color: white;
            transform: scale(1.03);
            transition: background 0.3s ease, transform 0.3s ease;
        }
        .fh-post-title {
            font-size: 3.0rem;
            line-height: 1.2;
            margin: 0 0 1rem;
            color: #334155;
        }
        .fh-post-meta, .fh-post-author {
            font-size: 1rem;
            color: #555;
            margin-top: 0.25rem;
        }
        .fh-post-author {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        .fh-author-wrapper {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            flex-wrap: nowrap;
            min-width: 0;
        }

        .fh-author-inline {
            font-size: 1rem;
            white-space: normal;
        }

        .fh-author-inline .fh-author-name {
            text-decoration: none;
            font-weight: 500;
            color: #3c7c75;
            font-family: 'Caveat';
            font-size: 1.5rem;
        }
        .fh-author-inline .fh-author-byline {
            color: #334155;
            font-weight: 400;
        }

        .custom-avatar {
            border-radius: 999px;
            width: 40px;
            height: 40px;
            display: block;
            object-fit: cover;
            aspect-ratio: 1 / 1;
        }
        .fh-post-image-sticker {
            flex: 0 0 auto;
            max-width: 300px;
            transform: rotate(2deg);
            transition: transform 0.3s ease;
            border: 6px solid #fff;
            border-radius: 1rem;
            overflow: hidden;
            box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
            align-self: flex-start;
            margin-left: auto;
        }
        .fh-post-image-sticker:hover {
             transform: rotate(4deg) scale(1.01)
        }
        .fh-meta-feedback {
            color: #3c7c75;
            text-decoration: none;
            font-size: 0.95rem;
        }
        .fh-meta-feedback:hover {
            color: #4a726f;
            text-decoration: none;
            transform: scale(1.03);
            transition: transform 0.3s ease;
        }
        .fh-meta-feedback:hover i.fa-heart {
            color: #D9737C;
        }
        .fh-meta-feedback:hover i.fa-comment {
            color: #3B82F6;
        }
        .fh-meta-feedback i,
        .fh-meta-reading i, .fh-meta-date i {
            color: #3c7c75;
        }

        .fa-arrow-right {
          opacity: 0.7;
        }

        @media (max-width: 1024px) {
            .fh-post-title {
                font-size: 2.5rem;
            }
            .fh-post-image-sticker {
                max-width: 250px;
            }
            .fh-author-name {
                font-size: 1.3rem;
            }
        }

        @media (max-width: 905px) {
            .fh-post-header {
                flex-direction: column;
                align-items: flex-start;
            }
            .fh-post-header-text {
                order: 1;
            }
            .fh-post-image-sticker {
                order: 2;
                max-width: 90%;
                margin: 1rem auto;
                display: block;
                text-align: center;
            }
            .fh-post-author {
                order: 3;
                flex-wrap: wrap;
            }
          .fh-author-name {
                font-size: 1rem;
            }

            .fh-post-title {
                font-size: 2rem;
            }
                 .fh-post-header-text,
            .fh-post-meta-line,
            .fh-post-title,
            .fh-post-author {
                text-align: center;
                align-items: center;
                justify-content: center;
            }

            .fh-author-wrapper {
                justify-content: center;
            }
        }

        @media (max-width: 500px) {
            .fh-post-title {
                font-size: 1.6rem;
            }
            .fh-post-meta-line, .fh-meta-feedback, .fh-post-category, .fh-author-inline {
                font-size: 0.8rem;
                gap: 0.5rem;
            }
            
            .fh-author-name {
                font-size: 0.8rem;
            }
            
            .fh-post-image-sticker {
                max-width: 50%;
            }
        }
        .fh-header-separator {
            width: 15%;
            height: 4px;
            background-color: #e8aa0b;
            margin: 1rem auto 2rem;
            border-radius: 2px;
            box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
            mask-image: linear-gradient(to right, transparent, black 20%, black 80%, transparent);
            -webkit-mask-image: linear-gradient(to right, transparent, black 20%, black 80%, transparent);
        }
   
        .fh-meta-date {
          margin-left: 7px;
        }

        .fh-feedback-icons {
          display: inline-flex;
          align-items: center;
          gap: 2px;
        }

        .fh-post-subtitle {
          font-size: 1.3rem;
          line-height: 1.5;
          color: #3c7c75;
          font-weight: 400;
          margin: -0.3rem 0 1.5rem;
          font-family: 'Fredoka', sans-serif;
          max-width: 45rem;
          margin-bottom: 1.8rem;
      }

      @media (max-width: 768px) {
          .fh-post-subtitle {
              font-size: 1.05rem;
              line-height: 1.4;
              margin-bottom: 1.25rem;
          }
      }

      .fh-author-wrapper img {
          box-shadow: none !important;
          -webkit-box-shadow: none !important;
      }

      /* POST BODY */
body.single-post .entry-content h2 {
  padding-bottom: 0.6rem;
  position: relative;
  margin-bottom: 1.5rem;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  color: #334155;
  margin-top: 2rem;
  font-weight: 600;
}

body.single-post .entry-content h2::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 40px;
  height: 3px;
  background-color: #e8aa0b;
  border-radius: 3px;
}

body.single-post .entry-content h3 {
  font-size: clamp(1.4rem, 2.2vw, 1.6rem);
  font-weight: 600;
  margin-bottom: 0.5rem;
  margin-top: 0.5rem;
  color: #1e2a38;
}

body.single-post .entry-content h4 {
  font-size: clamp(1.2rem, 2vw, 1.4rem);
  font-weight: 500;
  margin-bottom: 0.5rem;
  margin-top: 0.5rem;
  color: #1e2a38;
  text-transform: uppercase;
}

body.single-post .entry-content ul {
  list-style: none;
  padding-left: 1.5rem;
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

body.single-post .entry-content ul li {
  position: relative;
  margin-bottom: 0.75rem;
  padding-left: 1.5rem;
}

body.single-post .entry-content ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.3rem;
  width: 1rem;
  height: 1rem;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%233c7c75' d='M8 5v14l11-7z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
}

/* Spoiler */

.fh-fade-spoiler {
  color: transparent;
  position: relative;
  cursor: pointer;
  display: inline-block;
  margin-left: 0.3rem;
  vertical-align: baseline;
  text-decoration: none;
  font-weight: 500;
}

.fh-fade-spoiler::after {
  content: 'Click to reveal';
  color: #3c7c75;
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  pointer-events: none;
}

.fh-fade-spoiler.visible {
  color: #2b2b2b;
}

.fh-fade-spoiler.visible::after {
  content: '';
}

.fh-fade-spoiler:hover::after {
  text-decoration: underline;
}

/* numbered lists */

body.single-post .entry-content ol {
  counter-reset: step-counter;
  list-style: none;
  padding-left: 1.5rem;
  margin: 1.5rem 0;
}

body.single-post .entry-content ol li {
  counter-increment: step-counter;
  position: relative;
  margin-bottom: 1.2rem;
  padding-left: 3rem;
  font-weight: 400;
  color: #2b2b2b;
}

body.single-post .entry-content ol li::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0;
  width: 1.6rem;
  height: 1.6rem;
  background-color: #3c7c75;
  color: #fff;
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: 50%;
  text-align: center;
  line-height: 1.6rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  font-family: 'Fredoka', sans-serif;
}

/* quotes */

.fh-quote-block {
  font-style: italic;
  color: #2b2b2b;
  background: #f3f6f5;
  border-left: 4px solid #3c7c75;
  padding: 0.75rem 1rem;
  margin: 1.25rem 0;
  border-radius: 6px;
  margin-left: 20px !important;
}

.fh-single-quote {
  font-style: italic;
  color: #334155;
  font-size: 1.0rem;
  margin: 1rem 0;
  margin-left: 0.5rem !important;
}

.fh-single-quote i {
  color: #3c7c75;
  font-size: 1.3rem;
  margin-right: 0.5rem;
}


  /* SITE HEADER */

  /* Basic reset and container styles */
  :root {
    --logo-height: /* LOGO_HEIGHT placeholder */ 48px;
    --top-row-height: /* TOP_ROW_HEIGHT placeholder */ 48px;
  }
  #fh-custom-header {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    background: #faf8f4;       /* UPDATED */
    overflow: visible;
    transition: none;
    padding-left: 10px;
    padding-right:10px;
    /* min-height: calc(var(--top-row-height) + var(--logo-height)); */
  }

  #fh-custom-header.js-ready {
    transition: height 0.2s ease-out, box-shadow 0.2s ease, background-color 0.3s ease-out;
  }

  /* Push page content down to make room for the new fixed header */
  body {
    padding-top: 120px;
  }

  @media (max-width: 921px) {
  body {
    padding-top: 110px; /* match Astra’s 60px mobile header */
  }
}

  /* Fade-in border and shadow when scrolled */
  #fh-custom-header.scrolled {
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  }
  /* When the mobile menu is open, hide the header shadow/border artifact */
  #fh-custom-header.menu-open.scrolled {
    box-shadow: none !important;
  }
  body.admin-bar #fh-custom-header {
      top: 32px;
  }
  /* Admin bar is taller on mobile; adjust header offset */
  @media (max-width: 600px) {
    body.admin-bar #fh-custom-header {
      top: 46px;
    }
  }
  .fh-header-top, .fh-header-bottom {
    display: flex;
    align-items: center;
    padding: 10px 0;
  }
  .fh-header-top {
    position: relative;
    justify-content: center;
  }
  .fh-search {
    /* search area */
    position: absolute;
    left: 20px;
    opacity: 1;
  }
  .onesignal-customlink-container {
    position: absolute;
    left: 60px; /* match the search 20px + icon width + desired gap */
    transition: opacity 0.2s ease; /* remove transform transition */
  }
  .fh-links a {
    margin: 0 /* LINK_GAP placeholder */ 15px;
    text-decoration: none;
    color: #355c7d !important;            /* force correct link color */
  }
  .fh-links a:visited {
    color: #355c7d !important;
  }
  .fh-links a:hover {
    color: #2a4e63 !important;            /* optional hover shade */
  }
  .fh-links {
    white-space: nowrap;
    font-size: 0.9rem;
    font-weight: 600;
    font-family: 'Work Sans', sans-serif;
    letter-spacing: 1px;
  }
  .fh-menu {
    /* menu area */
    position: absolute;
    right: 20px;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .fh-header-bottom {
    justify-content: center;
    padding: 10px 0;
  }
  .fh-logo {
    position: relative;
    width: /* LOGO_WIDTH placeholder */ 175px;
    height: /* LOGO_HEIGHT placeholder */ 48px;
    margin: 0 auto;  /* center the container */
    overflow: visible;
    transition: transform 0.2s ease-out;
    transform-origin: center top;
  }

  .fh-logo svg {
    overflow: visible;
  }

  path#n {
    transform-origin: center center;
    transition: transform 0.2s ease-out;
    will-change: transform;
  }

  /* Extra left image, positioned off-center */
  .fh-logo .fh-extra-logo {
    position: absolute;
    left: -150px;           /* adjust as needed to sit left of logo */
    top: 60%;
    transform: translateY(-50%);
    width: 120px;
    height: 40px;
    opacity: 1;
    transition: transform 0.2s ease-out, opacity 0.2s ease-out;
    will-change: transform, opacity;
    transform-origin: center center;
  }

  /* Smooth transition for search and menu on scroll */
  .fh-search,
  .fh-menu {
    transition: margin-top 0.2s ease-out;
  }


.fh-hamburger span {
  display: block;
  height: 3px;
  background: #3c7c75;
  border-radius: 2px;
}

.fh-hamburger {
  position: relative;
  z-index: 10001;
  width: 24px;
  height: auto;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  transition: transform 0.3s ease;
}
.fh-hamburger.open {
  transform: rotate(90deg);
}

/* Prevent icons and text in mobile menu from wrapping */
  #fh-mobile-menu ul li a {
    white-space: nowrap;
    display: flex;
    align-items: center;
  }

  .fh-cart-icon {
    margin-right: 1rem;        /* increase gap to separate from hamburger */
    display: inline-flex;
    align-items: center;
    transition: opacity 0.2s ease; /* remove transform transition */
  }

  .fh-cart-count {
    margin-left: 3px;
    font-weight: 600;
    color: #3c7c75;
  }
  
  .fh-auth-link {
    margin-right: 1rem;
    display: inline-flex;
    align-items: center;
    transition: opacity 0.2s ease;
  }
  .fh-cart-icon i {
    color: #3c7c75;              /* match hamburger bars */
    font-size: 1.35rem;
  }

   .fh-auth-link i {
     color: #3c7c75;              /* match hamburger bars */
    font-size: 1.35rem;
  }

  /* Show or hide the top row based on scroll */
  /* Add top border and shadow to mobile menu */
  #fh-mobile-menu {
    border-top: 0px solid transparent;
    box-shadow: 0 -2px 8px rgba(0,0,0,0.1);
  }
  /* Hide the links row on screens 900px wide and under */
  @media (max-width: 900px) {
    .fh-header-top .fh-links {
      visibility: hidden !important;
    }
  }
  /* Performance: hint upcoming transforms and opacity changes */
  .fh-logo {
    will-change: transform;
  }
  .fh-search,
  .fh-menu,
  .fh-hamburger,
  .fh-header-top .fh-links,
  .fh-header-top .onesignal-customlink-container,
  .fh-header-top .fh-cart-icon,
  .fh-header-top .fh-auth-link {
    will-change: transform, opacity;
  }
  /* Hover effect for cart and auth icons */
  .fh-cart-icon:hover i,
  .fh-auth-link:hover i,
  .fh-cart-icon i:hover,
  .fh-auth-link i:hover {
    transform: scale(1.1);
    color: #1E2A38;
  }
  /* Smooth vertical scroll of links, notify, cart icon, auth link, hamburger, extra logo, and path#n */
  .fh-header-top .fh-links,
  .fh-header-top .onesignal-customlink-container,
  .fh-header-top .fh-cart-icon,
  .fh-header-top .fh-auth-link,
  .fh-header-top .fh-hamburger,
  .fh-logo .fh-extra-logo,
  path#n {
    transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  }
  .fas {
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900;
  }

@media (max-width: 600px) {
  /* Hide extra logo on mobile phone sizes */
  .fh-logo .fh-extra-logo {
    display: none !important;
  }
  #fh-custom-header {
        padding-left: 0 !important;
        padding-right: 0 !important;
      }
}


/* FEEDBACK */

/* in your child-theme style.css */

.fh-feedback-badge {
  position: fixed;
  top: 80%;
  right: -46px;
  /* move it into view and rotate */
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: center center;

  background-color: #E8AA0B;   /* mustard accent */
  color:            #fff;
  padding:          8px 16px;
  font-weight:      600;
  text-decoration:  none;
  box-shadow:       0 2px 6px rgba(0,0,0,0.2);
  z-index:          9999;
  border-radius:    4px 4px 0 0; /* adjust corner rounding as needed */
  width: 125px;
   text-align: center;
}

/* slightly smaller on mobile */
@media (max-width: 600px) {
  .fh-feedback-badge {
    padding:    6px 12px;
    font-size:  0.9rem;
  }
}
.fh-feedback-badge:hover {
  background-color: darken(#E8AA0B, 10%);
}

/* slightly smaller on mobile */
@media (max-width: 600px) {
  .fh-feedback-badge {
    padding:    6px 12px;
    font-size:  0.9rem;
  }
}

.fh-feedback-badge i {
  margin-bottom: 0.25em;
}

/* FUTURE MAP LANDING PAGE */
.future-map-button {
  width:70% !important;
	background-color:#3B82F6;
	padding: 10px 20px;
	border-radius:999px;
	margin: 0 auto; 
	box-shadow: 3px 3px 0 0 #b0a1bb;
transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
	cursor: pointer;
	color: #ffffff !important;
	text-decoration:none !important;
	display: flex;
	justify-content: center; 
  align-items: center;
  text-align: center;
	font-size: 22px;
	font-weight: 500;
}

.future-map-button:hover {
  color:#ffffff !important;
	background-color:#b0a1bb;
	box-shadow: 3px 3px 0 0 #3B82F6;
	transform: scale(1.02);
}

@media (max-width: 768px) {
  .future-map-button {
width:90% !important;
  }
}

.future-map-image {
	transform: rotate(2deg);
	transition: transform 0.4s ease;
}

.future-map-image:hover {
	transform: rotate(3deg) scale(1.02);
}