/*
 Theme Name:     SA Ez Child
 Description:    SA Ez Child Theme
 Template:       Divi
 Version:        1.0.2
*/
 
 
/* Theme customization starts here
------------------------------------------------------- */
/* ======================= Globals =======================*/
:root {
    --primary-color: lightgray;
    --secondary-color: black;
    --font-family-primary: 'Roboto', sans-serif;
    --font-family-secondary: 'Jost';
    --loading-spinner-image-path: url(/wp-content/uploads/2025/06/favicon-1.png);
    --plan-topper-image-path: url(/wp-content/uploads/2024/11/topper-image.png);
  }


/* ======================= Plan Loading Start =======================*/
div .loading_box .loading_icon {
	border: none;
	content: var(--loading-spinner-image-path);
	animation: spin 2.5s linear infinite;
	width: 100px;
	height: 100px;
}

/* ======================= All Plans List Start =======================*/
form div #regForm.sweti_join_now * {
	font-family:var(--font-family-primary);
}

#regForm.sweti_join_now{
	padding: 0 120px !important;
	max-width: 100% !important;
}

/* ======================= Individual Plan Detail Start =======================*/

/* ======================= Plan Container ======================= */
.sweti_join_now .plan_names {
    margin: 0 24px !important;
	width: 275px !important;
	max-width: 275px !important;
}
@media only screen and (min-width: 1240px) {
    #regForm .plan_names {
        flex: 0 0 25% !important;
        max-width: 245px !important;
    }
}
/* ======================= Plan Topper ======================= */
/* div .sweti_join_now .plan-items::before {
    display: block;
    content: '';
    position: relative;
    top: 1px;
    left: -13px;
    width: 300px;
    height: 70px;
    scale: 0.96;
    background-image: var(--plan-topper-image-path);
    background-repeat: no-repeat;
    z-index: 1;
} */

/* ======================= Plan Data ======================= */
div .sweti_join_now .plan-feature {
	display: flex;
	flex-direction: column;
	background: var(--primary-color);
	margin:0 0 15px;
	border:3px solid var(--secondary-color);
	border-top:none;
	padding-top:20px;
	/* Height fixed to fit all amenities - Tweak as needed */
	height: 550px;
	width: 275px;
}
/* ABC Attributes - We want to pull all we can for customizations but need to only show what we need */
div[abcname] {
	display:none;
	font-size: 14px;
}

.plan-title{
	order: 1;
}

.plan-header {
    order: 2;
}

/* Enrollment contains name, pretax value, tax, and total */
div[abcname="Enrollment"] {
	display:flex;
	justify-content: center;
	color:var(--secondary-color);
	font-size:1.2em;
	font-weight:normal;
	padding:15px 0;
	order: 3;
}

div[abcname="Enrollment"]>div[abcname="name"] {
    display: flex;
    order: 2;
    margin-left: 5px;
}
div[abcname="Enrollment"]>div[abcname="name"]::after  {
	content:" Fee ";
	margin: 0 4px;
}

div[abcname="subTotal"]{
	display: block;
}

.sabasiccontainer {
    order: 4;
}

.sweticlubfee {
    order: 5;
	color: #fff;
    margin-top: auto;
    margin-bottom: 10px;
	display: flex;
	gap: 3px;
	font-size: 8px;
	line-height: 150%;
}

/* ======================= Plan Name ======================= */
div .sweti_join_now .plan-feature .plan-title h3 {
	color:var(--secondary-color);
	font-weight:400;
	text-transform:uppercase;
	font-size: 16px;
	padding:10px 0;
	min-height: 50px;
}

/* ======================= Plan Price ======================= */

div .sweti_join_now .plan-feature .plan-header .Monthly_Rate, div .sweti_join_now .plan-feature .plan-header div {
	display: flex;
	justify-content:center;
	align-items: center;
    color: var(--secondary-color);
    font-size: 2em;
	line-height:1em;
	padding: 10px 0;
	height: 80px;
	font-family: var(--font-family-secondary);
}

div .sweti_join_now .plan-feature .plan-header .sabasic_Monthly_Rate{
	display:none;
}

p.Enrollment_Fee {
    display: none;
}

div .sweti_join_now .plan-feature .sabasic_Monthly_Rate_Pretax .sabasic_dollarsign {
    align-self: flex-start;
	font-size: 32px;
}
/* Price number */
div .sweti_join_now .plan-feature .sabasic_Monthly_Rate_Pretax .sabasic_dollar {
	font-size: 80px;
}

div .sweti_join_now .plan-feature .sabasic_Monthly_Rate_Pretax .sabasic_cent {
	flex-direction: column;
    display: flex;
    align-self: flex-start;
	font-size: 32px;
    text-align: center;
	line-height:1em;
}

span.sabasic_cent {
    display: none;
}
.sabasic_cent::after {
	content: 'per month';
	font-size: 7px;
	line-height:1em;
}

div .sweti_join_now .plan-feature .plan-header .Enrollment_Fee {
	color:var(--secondary-color);
	font-size: 14px;
	font-weight:normal;
	padding:15px 0;
	text-transform: uppercase;
}

/* ======================= Plan Amenities List ======================= */
/* If ul li for amenity list */
div .sweti_join_now .plan-feature .sabasiccontainer {
	padding: 20px 0;
	text-align:left;
	line-height:1em;
	display: flex;
	flex-direction: column;
}

div .sweti_join_now .plan-feature .sabasiccontainer ul li {
	color:#fff;
	font-size:1em;
}

div .sweti_join_now .plan-feature .sabasiccontainer ul li::before {
	background:rgba(255,255,255,.7);
}

/* If p for amenity list */
.sabasiclogocontainer {
    display: flex;
    justify-content: flex-start;
	align-items: center;
	text-align:left;
	padding: 5px 0;
}

/* Replace content with checkbox image link*/
.sabasiclogocontainer img {
	/* content:url("/wp-content/uploads/2025/01/checkbox.png"); */
	height:14px;
}

.sabasiclogocontainer p {
	padding-left: 5px;
	font-size: 12px;
	color: var(--secondary-color);
}

/* Adjust attribute for custom text below amenities list */
/* Custom text at end of amenity listing */
/* .plan-feature:has([sweti_planname*="Gold"]) [sweticlubfeename]{
    display: none;
}

.plan-feature:has([sweti_planname*="Gold"]) .sweticlubfee::before{
    content: 'No annual membership fee';
    width: 100%;
} */

/* $0 annual fee displayed [sweticlubfeename*="default"] so using that as condition for no annual fee language */
/* .sweticlubfee:has(> div[sweticlubfeename="default"]) span {
    display:none;
}

.sweticlubfee:has(> div[sweticlubfeename="default"])::before {
    content: "No Annual Membership Fee";
	width:100%;
} */

/* How to add translation for pseudo elements */
/* html[lang="es"] .sweticlubfee:has(> div[sweticlubfeename="default"])::before {
    content: "Sin cuota anual de membresía";
	width:100%;
} */

.select_button{
	width: 275px;
	margin: 0 auto !important;
	border: 3px solid var(--primary-color) !important;
	background: var(--primary-color) important;
}


/* ======================= Alt 1 Plans Detail Start ======================= */
/* Will need logic added for the attribute name added for the alt design 
Preferred to target unique name they put in the plan name like "alt1" or "design2" */

/* div .sweti_join_now .plan-feature:has([sweti_planname*="Student"]) {
	background: #fff !important;
	color: #000;
}  */

/* ======================= STEP 3 CSS START ======================= */
#step3 .field-info, #step4 .field-info, #step5 .field-info{
	width:1080px;
}

div .sweti_join_now #step3 .plan-items::before,
div .sweti_join_now #step4 .plan-items::before,
div .sweti_join_now #step5 .plan-items::before{
    display: none;
}

/* Plan Display on Step 3 sidebar */
#step3 .plan-feature::before,
#step4 .plan-feature::before,
#step5 .plan-feature::before{
	content: '';
    position: absolute;
    top: -9px;
    left: -3px;
    width: 269px;
    height: 20px;
    background: var(--primary-color);
    clip-path: ellipse(60% 100% at bottom);
    border-left: 3px solid var(--secondary-color);
    border-right: 3px solid var(--secondary-color);
}

/* Plan on sidebar: field-info > aside > aside-inner > plan-items > new_details*/

.aside-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.sweti_join_now .aside-inner .plan-items{
	overflow: unset !important;
}
.sweti_join_now .aside-inner .new_details {
    padding: 0 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.new_details #plan_data_one,
.new_details #plan_data_two{
    background: unset;
}

#planDescription,
#planDescription2,
#planDescription3{
	position: relative;
}

#step3 .plan-feature,
#step4 .plan-feature,
#step5 .plan-feature{
    margin-top: 50px;
	position: relative;
	overflow: unset;
	display: none;
}

.frq_col {
    width: 275px;
}

#step3 .sabasiccontainer::after,
#step4 .sabasiccontainer::after,
#step5 .sabasiccontainer::after{
	bottom: 20px;
}

.frq_col span.payment{
	font-size: 22px !important;
}

/* ======================= STEP 4 Start ======================= */
.sweti_join_now #step4 .info-form h3.plan_heading_h3.addons_heading:after {
    content: "Add Ons" !important;
}
div#plan_data_one {
	background: rgb(249 255 250 / 67%);
	font-weight: 700;
}

/* ======================= STEP 5 ======================= */
div#plan_data_two {
	background: rgb(249 255 250 / 67%);
	font-weight: 700;
}

.sweti_join_now #step2 .plan_heading .field-header .plan_heading_h3{
	display: none;
}

@media only screen and (max-width: 767px) {
    #regForm #step2 .plan_heading .field-header .plan_heading_h3 {
        display: none;
    }
}

.sweti_join_now .plans_data_wrapper .plan_heading{
	height: 100px;
}

/* Padding adjustment for the forms */
div#step3,
div#step4,
div#step5{
    padding: 0 20px;
}

#step3 #plan_data,
.new_details #plan_data_one, .new_details #plan_data_two {
    padding-bottom: 20px;
}

/* Force mobile menu at 1200px and below */
@media (max-width: 1420px) {
  /* Hide desktop menu */
  .et_pb_menu__menu {
    display: none !important;
  }

  /* Show mobile menu toggle */
  .et_mobile_nav_menu {
    display: block !important;
  }

	.et_pb_menu_0_tb_header.et_pb_menu ul li a {
		border-bottom: 1px solid #4e4e4e;
	}
}

.plan-feature:has([sweti_planname*="SUMMER"]) .plan-title{
	margin-bottom: 108px;
}

/* Adjusting padding for mobile */
@media (max-width: 768px){
	#regForm .progress-list {
	padding: 0;
	}

	#regForm .plans_data_wrapper {
		row-gap: 50px;
		padding-bottom: 0;
	}
}

/* Fading in the footer on load for z-index issue on the spin logo */
.et-l--footer{
	animation: fade-in linear 3s !important;
	color: red !important;
}

@keyframes fade-in{
	0%{
		opacity: 0;
	}
	100%{
		opacity: 1;
	}
}

#regForm .side-bar{
	min-height: unset;	
}

@media only screen and (max-width: 767px) {
    #regForm #step4 .field-header .plan_heading_h3:after {
        font-size: 24px !important;
    }
}

.plan-feature:has([sweti_planname*="SUMMER"]) .plan-title::after{
    position: absolute;
    top: 140px;
    content: "$350";
    font-size: 60px;
    font-weight: 800;
}

.plan-feature:has([sweti_planname*="SUMMER"]) .plan-header::before{
    content: "";
    position: absolute;
    top: 198px;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 90%;
    height: 3px;
    background: #cbb751;
}

#regForm .step2 .plan_heading {
    border-radius: 0px 0px 16px 16px;
}