/*
Theme Name: FiiNGO Child Theme
Description: This is a custom child theme for FiiNGO
Theme URI:   https://fiingo.ca/
Author:      Dynamic Pixels
Author URI:  https://www.dynamicpixels.ca/
Template: fiingo
Version: 1.0
*/

/* =====================================================
   BASE / GLOBAL
===================================================== */

hr {
    color: #f2f2f2;
    border: 1px solid;
}

.center-page-column {
    max-width: 800px;
    margin: 0 auto;
}

.custom-spacing p {
	padding-bottom: 20px;
}

/* =====================================================
   HEADER & NAVIGATION
===================================================== */

body #header-outer .widget_shopping_cart a.button {
    background-color: #ec008c !important;
}

body #header-outer .widget_shopping_cart a.button:hover {
    background-color: #f148a0 !important;
}

#header-outer #mobile-menu ul li>a {
    font-size: 15px !important;
}

#header-outer #mobile-menu ul li a:hover,
#header-outer #mobile-menu ul li a:hover .sf-sub-indicator i,
#header-outer #mobile-menu ul li a:focus,
#header-outer #mobile-menu ul li a:focus .sf-sub-indicator i,
#header-outer #mobile-menu ul li[class*="current"] > a,
#header-outer #mobile-menu ul li[class*="current"] > a i {
    color: #00aeef !important;
}

#header-outer[data-full-width=true] #mobile-menu:before {
    background: #F7F7F7 !important;
}

.slide-out-widget-area-toggle .lines-button {
    transform: scale(1.25);
}

.slide-out-widget-area-toggle {
    padding: 12px 16px;
}

body.ascend #top #mobile-cart-link i {
    line-height: 24px;
    height: 24px;
    font-size: 24px !important;
    margin-right: 6px;
}

/* =====================================================
   BUTTONS
===================================================== */

button[type="submit"],
input[type="button"],
input[type="submit"] {
    background-color: #00aeef;
}

input[type="submit"]:hover {
    background-color: #3FBBEF;
}

.custom-booking-button .link_text {
    min-width: 160px;
    display: inline-block;
    text-align: center;
}

/* =====================================================
   TOGGLES
===================================================== */

.toggle > .toggle-title a {
    color: #000000;
}

div[data-style="minimal"] .toggle > .toggle-title i::before {
    background-color: #ec008c;
}

div[data-style="minimal"] .toggle > .toggle-title i::after {
    background-color: #ec008c;
}

div[data-style*="minimal"] .toggle > .toggle-title i {
    border: 2px solid #ec008c;
}

/* =====================================================
   WOOCOMMERCE / CHECKOUT
===================================================== */

.wc-block-components-checkout-place-order-button
.wc-block-components-checkout-place-order-button__text {
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 8px 0px;
}

.wc-block-cart .wc-block-cart__submit-container
.wc-block-components-button:not(.is-link),
.wp-block-woocommerce-checkout
.wc-block-components-checkout-place-order-button:not(.is-link) {
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
}

.wc-block-cart__empty-cart__title.with-empty-cart-icon:before {
    color: #00aeef;
}

.wc-block-grid__product-add-to-cart.wp-block-button .wp-block-button__link {
    background-color: #00aeef;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 16px !important;
    border-radius: 4px!important;
}

.wc-block-grid__product .wc-block-grid__product-title {
    font-size: 18px !important;
}

.wc-block-grid__product-price  {
    font-size: 18px !important;
}

/* =====================================================
   MAILCHIMP
===================================================== */

.mc4wp-form input[type="email"] {
  border: 1px solid #f2f2f2 !important; 
  background-color: #ffffff !important;
}

.mc4wp-form p {
  display: flex;
  gap: 10px;
  margin: 0;
}

.mc4wp-form input[type="email"] {
  flex: 1;
}

.mc4wp-form input[type="submit"] {
  white-space: nowrap;
  background-color: #ec008c;
}

.mc4wp-form input[type="submit"]:hover {
    background-color: #f148a0; 
    cursor: pointer;
}

.mc4wp-success {
    margin-top: 10px;
}

/* =====================================================
   FOOTER
===================================================== */

#footer-outer {
    border-top: 1px solid #f2f2f2;
}

#footer-outer[data-link-hover="underline"][data-custom-color="true"]
#footer-widgets ul:not([class*="nectar_blog_posts"])
a:not(.tag-cloud-link):not(.nectar-button),
#footer-outer[data-link-hover="underline"]
#footer-widgets .textwidget a:not(.nectar-button) {
  background-image: linear-gradient(to right,#ec008c 0,#ec008c 100%);
}

/* =====================================================
   FOOTER SOCIAL ICONS
===================================================== */

.footer-social-icons {
    display: flex;
    gap: 10px;
    margin-top: 15px;
}

.footer-social-icons a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    text-decoration: none;
    font-size: 24px;
    background-color: #000;
    transition: background 0.3s, transform 0.3s;
    line-height: 0;
    padding: 0;
}

.footer-social-icons a i {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #ffffff;
    font-size: 24px;
}

.footer-social-icons a.fb {
    background-color: #00aeef;
}

.footer-social-icons a.fb:hover {
    background-color: #3fbbef;
}

.footer-social-icons a.insta {
    background-color: #ec008c;
}

.footer-social-icons a.insta:hover {
    background-color: #f148a0;
}

.footer-social-icons a.tiktok {
    background-color: #fff200;
}

.footer-social-icons a.tiktok:hover {
    background-color: #fff64d;
}

/* =====================================================
   PMS (MEMBERSHIPS)
===================================================== */

.pms-block-container ul li,
.pms-form ul li {
    list-style: none;
}

.pms-subscription-plan-sign-up-fee {
    text-transform: none;
}

.pms-subscription-plan-name {
	color: #00aeef;
	font-family: Poppins;
    text-transform: none;
    letter-spacing: 0px;
    font-size: 30px;
    line-height: 40px;
    font-weight: 700;
}

.pms-subscription-plan-price {
	color: #ec008c;
	font-family: Poppins;
    text-transform: none;
    letter-spacing: 0px;
    font-size: 30px;
    line-height: 40px;
    font-weight: 700;
}

.pms-subscription-plan-description {
    margin-top: 30px;
    font-size: 100% !important;
    font-weight: bold;
    line-height: 24px;
}

.pms-account-section-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 0px 16px;
    margin-bottom: 20px !important;
}

.pms-account-section-wrapper .pms-field {
    flex: 1 1 45%;
    min-width: 200px;
    box-sizing: border-box;
}

.pms-account-section-wrapper .pms-field label {
    display: block;
    margin-bottom: 4px;
}

.pms-account-section-wrapper .pms-field input {
    width: 100%;
}

@media (max-width: 768px) {
    .pms-account-section-wrapper .pms-field {
        flex: 1 1 100%;
    }
}

/* ===== PMS Country ===== */

#pms_billing_country_chosen,
#pms_billing_country_chosen * {
	box-sizing: border-box;
	font-family: inherit;
}

#pms_billing_country_chosen .chosen-single,
#pms_billing_country_chosen.chosen-container-active .chosen-single,
#pms_billing_country_chosen.chosen-with-drop .chosen-single,
#pms_billing_country_chosen .chosen-single:hover {
	height: 60px !important;
	min-height: 60px !important;
	line-height: 60px !important;
	padding: 0 14px !important;
	margin: 0 !important;
	border: 1px solid #f2f2f2 !important;
	border-radius: 4px !important;
	background: #fafafa !important;
	box-shadow: none !important;
	color: #000 !important;
	font-size: 15px !important;
	font-weight: 400 !important;
}

#pms_billing_country_chosen .chosen-single span {
	line-height: 60px !important;
	color: #000 !important;
}

#pms_billing_country_chosen .chosen-single div { 
	width: 20px !important;
}

#pms_billing_country_chosen .chosen-single div b {
	background-position: 0 20px !important;
}

#pms_billing_country_chosen .chosen-drop {
	margin-top: 0 !important;
	border: 1px solid #f2f2f2 !important;
	box-shadow: none !important;
}

#pms_billing_country_chosen .chosen-search input {
	height: 36px !important;
	line-height: 36px !important;
	padding: 0 10px !important;
	border: 1px solid #f2f2f2 !important;
	box-shadow: none !important;
}

#pms_billing_country_chosen .chosen-results li {
	padding: 8px 12px !important;
	font-size: 14px !important;
	color: #000 !important;
}

#pms_billing_country_chosen .chosen-results li.highlighted {
	background: #f5f5f5 !important;
	color: #000 !important;
}

#pms_billing_country_chosen,
#pms_billing_country_chosen * {
	color: #000 !important;
}

/* ===== PMS State ===== */

#pms_billing_state_chosen,
#pms_billing_state_chosen * {
	box-sizing: border-box;
	font-family: inherit;
}

#pms_billing_state_chosen .chosen-single,
#pms_billing_state_chosen.chosen-container-active .chosen-single,
#pms_billing_state_chosen.chosen-with-drop .chosen-single,
#pms_billing_state_chosen .chosen-single:hover {
	height: 60px !important;
	min-height: 60px !important;
	line-height: 60px !important;
	padding: 0 14px !important;
	margin: 0 !important;
	border: 1px solid #f2f2f2 !important;
	border-radius: 4px !important;
	background: #fafafa !important;
	box-shadow: none !important;
	color: #000 !important;
	font-size: 15px !important;
	font-weight: 400 !important;
}

#pms_billing_state_chosen .chosen-single span {
	line-height: 60px !important;
	color: #000 !important;
}

#pms_billing_state_chosen .chosen-single div { width: 20px; }

#pms_billing_state_chosen .chosen-single div b {
	background-position: 0 20px !important;
}

#pms_billing_state_chosen .chosen-drop {
	margin-top: 0 !important;
	border: 1px solid #f2f2f2 !important;
	box-shadow: none !important;
}

#pms_billing_state_chosen .chosen-search input {
	height: 36px !important;
	line-height: 36px !important;
	padding: 0 10px !important;
	border: 1px solid #f2f2f2 !important;
	box-shadow: none !important;
}

#pms_billing_state_chosen .chosen-results li {
	padding: 8px 12px !important;
	font-size: 14px !important;
	color: #000 !important;
}

#pms_billing_state_chosen .chosen-results li.highlighted {
	background: #f5f5f5 !important;
	color: #000 !important;
}

#pms_billing_state_chosen,
#pms_billing_state_chosen * {
	color: #000 !important;
}

/* =====================================================
   AMELIA BOOKING
===================================================== */

.amelia-v2-booking [class*=" icon-"] {
    background-color: #ffffff;
}

.amelia-v2-booking #amelia-container.am-fs__wrapper,
.amelia-v2-booking #amelia-container.am-cap__wrapper {
    margin: 50px auto 100px auto !important;
}

.amelia-v2-booking #amelia-container .am-els__pagination-info {
    display: none;
}

/* =====================================================
   MY ACCOUNT PAGE
===================================================== */

.woocommerce-MyAccount-navigation ul li a {
    opacity: 0.8;
}

.woocommerce-MyAccount-navigation
ul li.woocommerce-MyAccount-navigation-link--manage-bookings a:before {
    content: "\f274";
}

.woocommerce-MyAccount-navigation
ul li.woocommerce-MyAccount-navigation-link--manage-membership a:before {
    content: "\f2c2";
}

.custom-account-button {
    display: inline-block;
    padding: 5px 20px;
    background-color: #00aeef;
    color: #ffffff;
    text-decoration: none;
    border-radius: 4px;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    transition: background-color 0.3s ease;
    margin-right: 10px;
    margin-bottom: 20px;
    min-width: 200px;
    text-align: center;
}

.custom-account-button:hover {
    background-color: #3fbbef;
    color: #ffffff;
}

.woocommerce-account .woocommerce>#customer_login .nectar-form-controls .control {
    font-size: 26px !important;
}

/* =====================================================
   CONTACT FORM 7
===================================================== */

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 textarea {
    color: black;
}

.wpcf7 input[type="text"]::placeholder,
.wpcf7 input[type="email"]::placeholder,
.wpcf7 input[type="tel"]::placeholder,
.wpcf7 input[type="url"]::placeholder,
.wpcf7 textarea::placeholder {
    color: black;
    opacity: 1;
}

.wpcf7 input[type="text"]::-webkit-input-placeholder,
.wpcf7 input[type="email"]::-webkit-input-placeholder,
.wpcf7 input[type="tel"]::-webkit-input-placeholder,
.wpcf7 input[type="url"]::-webkit-input-placeholder,
.wpcf7 textarea::-webkit-input-placeholder,
.wpcf7 input[type="text"]:-moz-placeholder,
.wpcf7 input[type="email"]:-moz-placeholder,
.wpcf7 input[type="tel"]:-moz-placeholder,
.wpcf7 input[type="url"]:-moz-placeholder,
.wpcf7 textarea:-moz-placeholder,
.wpcf7 input[type="text"]::-moz-placeholder,
.wpcf7 input[type="email"]::-moz-placeholder,
.wpcf7 input[type="tel"]::-moz-placeholder,
.wpcf7 input[type="url"]::-moz-placeholder,
.wpcf7 textarea::-moz-placeholder,
.wpcf7 input[type="text"]:-ms-input-placeholder,
.wpcf7 input[type="email"]:-ms-input-placeholder,
.wpcf7 input[type="tel"]:-ms-input-placeholder,
.wpcf7 input[type="url"]:-ms-input-placeholder,
.wpcf7 textarea:-ms-input-placeholder {
    color: black;
}

/* =====================================================
   RESPONSIVE
===================================================== */

@media (min-width: 1001px) {
    .hero-title-large h1 {
        line-height: 58px !important;
    }
}

@media (max-width: 767px) {

  .short-bg-column {
    min-height: 0 !important;
    height: auto !important;
  }

  .short-bg-column .vc_column-inner {
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
  }

  .short-bg-column .column-image-bg {
    background-size: cover !important;
    background-position: center center !important;
  }
}