/*
Theme Name: PlanB Child
Template: hello-elementor
*/

@font-face {
  font-family: "Aceh Soft";
  src: url("fonts/AcehSoftRegular.woff2") format("woff2"),
       url("fonts/AcehSoftRegular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Aceh Soft";
  src: url("fonts/AcehSoftMedium.woff2") format("woff2"),
       url("fonts/AcehSoftMedium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}


/* Resets
--------------------------------------------- */

body,
.elementor {
    margin: 0;
    padding: 0;
    border: 0;
    color: var(--black);
	font-family: "Aceh Soft", serif;
}

.swiper-free-mode>.swiper-wrapper {
    transition-timing-function: linear !important;
}

.swiper-free-mode::before,
.swiper-free-mode::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 100px;
    pointer-events: none;
    z-index: 10;
}

.swiper-free-mode::before {
    left: 0;
    background: linear-gradient(to right, white, transparent);
}

.swiper-free-mode::after {
    right: 0;
    background: linear-gradient(to left, white, transparent);
}

.elementor:not([data-elementor-type="header"]) {
    overflow: hidden;
}

h1, h2, h3, h4, h5, h6, blockquote {
    color: var(--text-heading);
}

a:hover,
a:active {
    color: inherit;
}

button:focus,
input:focus {
    outline: none !important;
}

.acf-map {
    width: 100%;
    height: 400px;
    border: #ccc solid 1px;
    margin: 20px 0;
}

.elementor-element p:last-child {
    margin-bottom: 0px;
}

body table tbody>tr:nth-child(odd)>td,
body table tbody>tr:nth-child(odd)>th,
body table tbody tr:hover>td,
body table tbody tr:hover>th {
    background-color: initial;
}

body table td,
body table th {
    border: 0;
    padding: 0;
    text-align: left;
}

.elementor-field-group .elementor-field-textual:focus {
    box-shadow: none;
}

/* Fixes potential theme css conflict. */
.acf-map img {
    max-width: inherit !important;
}

a {
    cursor: pointer;
    color: inherit;
}


select {
    appearance: none;
    -webkit-appearance: none;
}

::placeholder,
::-webkit-input-placeholder,
::-moz-placeholder,
:-ms-input-placeholder,
:-moz-placeholder,
body .elementor-field-group .elementor-field-textual::placeholder,
.elementor-field-group .elementor-field-textual::placeholder {
    opacity: 1; !important;
	color: #000 !important;
}

.elementor-kit-7 input:not([type="button"]):not([type="submit"])::placeholder,
.elementor-kit-7 textarea::placeholder,
.elementor-kit-7 .elementor-field-textual::placeholder {
    color: #000000;
    opacity: 1;
}

/* Firefox requires vendor prefix */
.elementor-kit-7 input:not([type="button"]):not([type="submit"])::-moz-placeholder,
.elementor-kit-7 textarea::-moz-placeholder,
.elementor-kit-7 .elementor-field-textual::-moz-placeholder {
    color: #000000;
    opacity: 1;
}

/* Edge/IE compatibility */
.elementor-kit-7 input:not([type="button"]):not([type="submit"]):-ms-input-placeholder,
.elementor-kit-7 textarea:-ms-input-placeholder,
.elementor-kit-7 .elementor-field-textual:-ms-input-placeholder {
    color: #000000;
    opacity: 1;
}

body .elementor-column-gap-default>.elementor-column>.elementor-element-populated {
    padding: 0;
}

.elementor .elementor-heading-title {
    line-height: inherit;
}

.animate-words .word {
	opacity: 0;
}

.elementor-widget-text-editor ul, .elementor-widget-text-editor ol {
    padding: 0 0 0 1em;
    margin: 1em 0;
}

/* Checkmark list styling */
.check ul {
    list-style: none;
    padding-left: 0;
    margin: 1em 0;
}

.check ul li {
    position: relative;
    padding-left: 1.5em;
    margin-bottom: 0.5em;
}

.check ul li::before {
    content: "\f00c";
    font-family: 'Font Awesome 6 Pro';
	font-weight: 600;
    position: absolute;
    left: 0;
    top: 0.1em;
}

/* Global Font Styles
--------------------------------------------- */

/* Desktop font sizes */
:root { 
    --siteheadings-eyebrow: 1.25rem;
    --blogheadings-h1: 3.25rem;
    --blogheadings-h2: 2.25rem;
    --blogheadings-h3: 1.75rem;
    --blogheadings-h4: 1.375rem;
    --siteheadings-display: 9.375rem;
	--siteheadings-cta: 4.69rem;
    --siteheadings-h1: 4.6875rem;
    --siteheadings-h2: 3.75rem;
    --siteheadings-h3: 2.375rem;
    --siteheadings-h4: 3.125rem;
    --siteheadings-h5: 1.25rem;
    --body-body-lg: 1.625rem;
    --body-body-md: 1.25rem;
    --body-body-sm: 0.9375rem;
    --body-body-xsm: 0.75rem;
    --component-testimonial: 0rem;
    --component-blockquote: 0rem;
    --component-button-buttonlg: 1.25rem;
    --component-button-buttondefault: 1.25rem;
    --component-button-buttonsm: 1rem;
}

/* Tablet font sizes */
@media all and (max-width:1440px) {
    :root {
        --siteheadings-eyebrow: 1.125rem;
        --blogheadings-h1: 2.8rem;
        --blogheadings-h2: 2rem;
        --blogheadings-h3: 1.5rem;
        --blogheadings-h4: 1.125rem;
        --siteheadings-display: 6.25rem;
		--siteheadings-cta: 2.75rem;
        --siteheadings-h1: 2.75rem;
        --siteheadings-h2: 2.5rem;
        --siteheadings-h3: 1.5rem;
        --siteheadings-h4: 1.25rem;
        --siteheadings-h5: 1.125rem;
        --body-body-lg: 1.125rem;
        --body-body-md: 0.875rem;
        --body-body-sm: 0.75rem;
        --body-body-xsm: 0.75rem;
        --component-testimonial: 0rem;
        --component-blockquote: 0rem;
        --component-button-buttonlg: 0.875rem;
        --component-button-buttondefault: 0.875rem;
        --component-button-buttonsm: 0.75rem;
        --component-nav: 0rem;
        --component-submenu: 0rem;
        --component-tag: 0.75rem;
    }
}

/* Tablet Portrait font sizes */
@media all and (max-width:900px) {
    :root {
        --siteheadings-display: 5rem;
    }
}

/* Mobile font sizes */
@media all and (max-width:767px) {
    :root {
        --siteheadings-eyebrow: 1.125rem;
        --blogheadings-h1: 2.5rem;
        --blogheadings-h2: 2rem;
        --blogheadings-h3: 1.5rem;
        --blogheadings-h4: 1.125rem;
        --siteheadings-display: 3.438rem;
		--siteheadings-cta: 2.5rem;
        --siteheadings-h1: 1.88rem;
        --siteheadings-h2: 2rem;
        --siteheadings-h3: 1.5rem;
        --siteheadings-h4: 1.25rem;
        --siteheadings-h5: 1.125rem;
        --body-body-lg: 1rem;
        --body-body-md: 0.875rem;
        --body-body-sm: 0.75rem;
        --body-body-xsm: 0.75rem;
        --component-testimonial: 0rem;
        --component-blockquote: 0rem;
        --component-button-buttonlg: 0.875rem;
        --component-button-buttondefault: 0.875rem;
        --component-button-buttonsm: 0.75rem;
        --component-nav: 0rem;
        --component-submenu: 0rem;
        --component-tag: 0.75rem;
    }
}

.elementor .text-display {
  font-size: var(--siteheadings-display, 6rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.1em;
}

.elementor .text-cta {
  	font-size: var(--siteheadings-cta);
	line-height: 1em;
}

.text-h1,
h1,
.elementor h1.elementor-heading-title,
.elementor .text-h1 {
  font-size: var(--siteheadings-h1, 4rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.1em;
}
.text-h2,
h2,
.elementor h2.elementor-heading-title,
.elementor .text-h2 {
  font-size: var(--siteheadings-h2, 3rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.056em;
}
.text-h3,
h3,
.elementor h3.elementor-heading-title,
.elementor .text-h3 {
  font-size: var(--siteheadings-h3, 2rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.1em;
}
.text-h4,
h4,
.elementor h4.elementor-heading-title,
.elementor .text-h4 {
  font-size: var(--siteheadings-h4, 1.5rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.1em;
}
.text-h5,
h5,
.elementor h5.elementor-heading-title,
.elementor .text-h5,
.elementor .elementor-widget-n-accordion .e-n-accordion-item-title-text {
  font-size: var(--siteheadings-h5, 1.25rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.2em;
}
.elementor .elementor-widget-n-accordion .e-n-accordion-item-title-text {
    font-weight: 500;
}
h6,.text-body-large,
.elementor h6.elementor-heading-title,
.elementor .text-body-large,
.text-blog-styles > .elementor-widget-container > p:first-child {
  font-size: var(--body-body-lg, 1.25rem);
  font-style: normal;
  font-weight: 300;
  line-height: 1.2em;
}
.text-body-medium,
body,
.elementor .text-body-medium,
.elementor .elementor-widget-woocommerce-cart .woocommerce .product-name a {
  font-size: var(--body-body-md, 1.13rem);
  font-style: normal;
  font-weight: 300;
  line-height: 1.2em;
}
.text-body-small,
.elementor .text-body-small,
.elementor-widget-woocommerce-cart .woocommerce table.cart td span {
  font-size: var(--body-body-sm, 0.875rem);
  font-style: normal;
  font-weight: 300;
  line-height: 1.2em;
}
.text-body-xsmall,
.elementor .text-body-xsmall {
  font-size: var(--body-body-xsm, 0.75rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.2em;
}
.text-button, .elementor-button,
.elementor .text-button,
.elementor [type=submit],
.elementor [type=button]{
  	font-size: var(--component-button-buttondefault);
	font-style: normal;
	font-weight: 500;
	line-height: normal;
}
.text-button.large,
.elementor .text-button.large {
	font-size: var(--component-button-buttonlg);
	font-style: normal;
	font-weight: 500;
	line-height: normal;
}
.text-button.small,
.elementor .text-button.small {
	font-size: var(--component-button-buttonsm);
	font-style: normal;
	font-weight: 500;
	line-height: normal;
}
.text-caption,
.elementor .text-caption {
  font-size: var(--body-body-sm, 0.875rem);
  font-style: normal;
  font-weight: 400;
  line-height: 1.5em;
}
.text-footnote,
.elementor .text-footnote {
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 500;
  line-height: 1.5em;
  text-transform: uppercase;
}
.text-tag,
.elementor .text-tag {
	font-size: var(--component-tag);
	font-style: normal;
	font-weight: 500;
	line-height: normal;
	text-transform: uppercase;
	color: var(--navy);
}
.text-eyebrow,
.elementor .text-eyebrow,
.eyebrow {
  font-size: var(--body-body-sm, 0.875rem);
  font-style: normal;
  font-weight: 500;
  line-height: 1.2em;
}
.text-body-large.bold,
.text-body-medium.bold,
.text-body-small.bold,
.text-body-xsmall.bold,
.elementor .text-body-large.bold,
.elementor .text-body-medium.bold,
.elementor .text-body-small.bold,
.elementor .text-body-xsmall.bold {
	font-weight: 500;
}

/* Blog Heading Styles */

.text-blog-styles h1,
.text-blog-h1 {
	font-size: var(--blogheadings-h1);
}
.text-blog-styles h2,
.text-blog-h2 {
	font-size: var(--blogheadings-h2);
}
.text-blog-styles h3,
.text-blog-h3,
blockquote {
	font-size: var(--blogheadings-h3);
	line-height: 1.3em;
	font-weight: 400;
	letter-spacing: -0.56px;
}
.text-blog-styles h4,
.text-blog-h2 {
	font-size: var(--blogheadings-h4);
}


/* Color Variables
--------------------------------------------- */
:root {
    --black: #000;
    --white: #fff;
	--text-heading:#000;
	--text-body: #000;
	--text: #000;
	
	/* Brand */
    --green-50: #F7FFEC;
	--green-75: #DFFFB2;
	--green-100: #D1FF93;
	--green-200: #BDFF64;
	--green-300: #B0FF44;
	--green-400: #7BB330;
	--green-500: #6B9C29;
	--blue-50: #EBFAFF;
	--blue-75: #AEE9FF;
	--blue-100: #8CE0FF;
	--blue-200: #5BD2FF;
	--blue-300: #38C9FF;
	--blue-400: #288DB3;
	--blue-500: #237B9C;
	--neutral-50: #FEFEFF;
	--neutral-75: #F9FBFD;
	--neutral-100: #F6F9FC;
	--neutral-200: #F3F7FB;
	--neutral-300: #F0F5FA;
	--neutral-400: #A8ACAF;
	--neutral-500: #929599;
    --green: #6B9C29;
    --blue: #237B9C;
	
	/* Global Fonts */
    --bodyFont:"Aceh Soft", serif;
    --titleFont:"Aceh Soft", serif;
}

/* Gradient Variables
--------------------------------------------- */

:root {
  --horizontal-gradient: linear-gradient(90deg, #97F01D 0%, #39C9FF 100%);
	--horizontal-gradient-alt: linear-gradient(90deg, #97F01D 0%, #39C9FF 60%);
}



/* Background Splines
--------------------------------------------- */
/* Background Spline Container */
#bg-spline-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: -1;
    overflow: hidden;
}

.bg-spline-element {
    position: absolute;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    will-change: transform;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Base positions */
.spline-pos-tl { top: 0; left: 0; transform-origin: top left; }
.spline-pos-tr { top: 0; right: 0; transform-origin: top right; }
.spline-pos-bl { bottom: 0; left: 0; transform-origin: bottom left; }
.spline-pos-br { bottom: 0; right: 0; transform-origin: bottom right; }

/* bg-spline-1 configuration */
.bg-spline-1-element {
    width: 854px;
    height: 904px;
}

/* Desktop */
@media (min-width: 1025px) {
    .bg-spline-1-element {
        transform: translate(-30px, 150px) rotate(15deg);
    }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1024px) {
    .bg-spline-1-element {
        width: 600px;
        height: 635px;
        transform: translate(-20px, 100px) rotate(10deg);
    }
}

/* Mobile */
@media (max-width: 767px) {
    .bg-spline-1-element {
        width: 400px;
        height: 424px;
        transform: translate(-10px, 50px) rotate(5deg);
    }
}

/* bg-spline-2 configuration */
.bg-spline-2-element {
    width: 600px;
    height: 700px;
}

@media (min-width: 1025px) {
    .bg-spline-2-element {
        transform: translate(50px, -100px) rotate(-20deg);
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .bg-spline-2-element {
        width: 450px;
        height: 525px;
        transform: translate(30px, -75px) rotate(-15deg);
    }
}

@media (max-width: 767px) {
    .bg-spline-2-element {
        width: 300px;
        height: 350px;
        transform: translate(20px, -50px) rotate(-10deg);
    }
}



/* Primary Spacing Variables
--------------------------------------------- */
:root {
    --spacing-4px-2: 2px;
    --spacing-4px-4: 4px;
    --spacing-4px-8: 8px;
    --spacing-4px-12: 12px;
    --spacing-4px-16: 16px;
    --spacing-4px-20: 20px;
    --spacing-4px-24: 24px;
    --spacing-4px-32: 32px;
    --spacing-4px-40: 40px;
    --spacing-4px-48: 48px;
    --spacing-4px-56: 56px;
    --spacing-4px-64: 64px;
    --spacing-4px-80: 80px;
    --spacing-4px-96: 96px;
    --spacing-4px-128: 128px;
    --spacing-4px-160: 160px;
    --spacing-4px-192: 192px;
    --spacing-4px-224: 224px;
    --spacing-4px-256: 256px;
    --spacing-4px-320: 320px;
    --spacing-4px-384: 384px;
    --spacing-4px-512: 512px;
    --spacing-4px-full: 999px;
}


/* Global Sizing Variables
--------------------------------------------- */
:root {
    /* The BASE size */
    --base-size: 4px;
    /* The size steps */
    --size-0: calc(var(--base-size) * 0);
    /* 0px */
    --size-1: calc(var(--base-size) * 1);
    /* 4px */
    --size-2: calc(var(--base-size) * 2);
    /* 8px */
    --size-3: calc(var(--base-size) * 3);
    /* 12px */
    --size-4: calc(var(--base-size) * 4);
    /* 16px */
    --size-5: calc(var(--base-size) * 5);
    /* 20px */
    --size-6: calc(var(--base-size) * 6);
    /* 24px */
    --size-7: calc(var(--base-size) * 7);
    /* 28px */
    --size-8: calc(var(--base-size) * 8);
    /* 32px */
    --size-9: calc(var(--base-size) * 9);
    /* 36px */
    --size-10: calc(var(--base-size) * 10);
    /* 40px */
    --size-11: calc(var(--base-size) * 11);
    /* 44px */
    --size-12: calc(var(--base-size) * 12);
    /* 48px */
    --size-14: calc(var(--base-size) * 14);
    /* 56px */
    --size-16: calc(var(--base-size) * 16);
    /* 64px */
    --size-20: calc(var(--base-size) * 20);
    /* 80px */
    --size-24: calc(var(--base-size) * 24);
    /* 96px */
    --size-28: calc(var(--base-size) * 28);
    /* 112px */
    --size-32: calc(var(--base-size) * 32);
    /* 128px */
    --size-36: calc(var(--base-size) * 36);
    /* 144px */
    --size-40: calc(var(--base-size) * 40);
    /* 160px */
    --size-44: calc(var(--base-size) * 44);
    /* 176px */
    --size-48: calc(var(--base-size) * 48);
    /* 192px */
    --size-52: calc(var(--base-size) * 52);
    /* 208px */
    --size-56: calc(var(--base-size) * 56);
    /* 224px */
    --size-60: calc(var(--base-size) * 60);
    /* 240px */
    --size-64: calc(var(--base-size) * 64);
    /* 256px */
    --size-72: calc(var(--base-size) * 72);
    /* 288px */
    --size-80: calc(var(--base-size) * 80);
    /* 320px */
    --size-96: calc(var(--base-size) * 96);
    /* 384px */
}


/* Global Configuration
--------------------------------------------- */

/* Extra size helper for fractional sizes */
:root {
    --size-0\.5: calc(var(--base-size) * 0.5); /* 2px */
}

/* Global Configuration - DESKTOP */
:root {
    /* From mockup */
    --page-width: 1536px;
    --hero-height: 900px;
    --green: #97F01C;
    --blue: #00B9FF;
    
    /* Section Padding */
    --section-padding-smaller: var(--size-16);
    --section-padding: var(--size-32);
    --section-padding-larger: var(--size-48);
    --section-padding-sides: 0;
    
    /* Component Padding */
    --cp-3xs: var(--size-1);
    --cp-2xs: var(--size-2);
    --cp-xs: var(--size-3);
    --cp-s: var(--size-4);
    --cp-m: var(--size-5);
    --cp-l: var(--size-8);
    --cp-xl: var(--size-12);
    --cp-2xl: var(--size-16);
    --cp-3xl: var(--size-24);
    --cp-4xl: var(--size-32);
    
    /* Component Vertical Padding */
    --cp-v-none: 0;
    --cp-v-xsm: var(--size-1);
    --cp-v-sm: var(--size-2);
    --cp-v-md: var(--size-3);
    --cp-v-lg: var(--size-6);
    --cp-v-xlg: var(--size-8);
    --cp-v-heading-padding: var(--size-16);
    
    /* Column Spacing */
    --column-sm: var(--size-16);
    --column-md: var(--size-24);
    --column-lg: var(--size-32);
    
    /* Radius */
    --radius-xs: var(--size-0.5);
    --radius-s: var(--size-1);
    --radius-m: var(--size-2);
    --radius-l: var(--size-3);
    --radius-xl: var(--size-4);
    --radius-full: 999px;
    
    /* Button Elements */
    --button-height-default: var(--size-14);
    --button-padding-default: var(--size-8);
    --button-height-large: var(--size-16);
    --button-padding-large: var(--size-8);
    --button-height-small: var(--size-10);
    --button-padding-small: var(--size-5);
    --button-radius: var(--radius-m);
    
    /* Other Elements */
    --menu-height: var(--size-32);
}

/* TABLET */
@media all and (max-width: 1600px) {
    :root {
        
        /* Section Padding - changed values */
        --section-padding-smaller: var(--size-12);
        --section-padding: var(--size-24);
        --section-padding-larger: var(--size-40);
        --section-padding-sides: var(--size-24);
        
        /* Component Padding - changed values */
        --cp-3xs: var(--size-0.5);
        --cp-2xs: var(--size-1);
        --cp-xs: var(--size-2);
        --cp-s: var(--size-3);
        --cp-m: var(--size-4);
        --cp-l: var(--size-5);
        --cp-xl: var(--size-8);
        --cp-2xl: var(--size-12);
        --cp-3xl: var(--size-16);
        --cp-4xl: var(--size-24);
        
        /* Component Vertical Padding - changed values */
        --cp-v-sm: var(--size-1);
        --cp-v-md: var(--size-2);
        --cp-v-lg: var(--size-4);
        --cp-v-xlg: var(--size-6);
        --cp-v-heading-padding: var(--size-12);
        
        /* Column Spacing - changed values */
        --column-sm: var(--size-12);
        --column-md: var(--size-16);
        --column-lg: var(--size-24);
        
        /* Button Elements - changed values */
        --button-height-default: var(--size-12);
        --button-padding-default: var(--size-6);
        --button-height-large: var(--size-14);
        --button-padding-large: var(--size-6);
        --button-height-small: var(--size-8);
        --button-padding-small: var(--size-4);
        --button-radius: var(--radius-s);
        
        /* Other Elements - changed values */
        --menu-height: var(--size-20);
    }
}

@media all and (max-width: 1440px) {
    :root {
        /* From mockup - changed values */
        --page-width: 1024px;
        --hero-height: 700px;
		
	}
}
@media (max-width:1200px) {
    :root {
        --section-padding-sides:var(--size-16);
        --section-padding:var(--size-16);
    }
}
/* MOBILE */
@media all and (max-width: 767px) {
    :root {
        /* From mockup - changed values */
        --page-width: 375px;
        
        /* Section Padding - changed values */
        --section-padding-smaller: var(--size-10);
        --section-padding: var(--size-8);
        --section-padding-larger: var(--size-32);
        --section-padding-sides: var(--size-8);
        
        /* Component Padding - changed values */
        --cp-4xl: var(--size-20);
        
        /* Component Vertical Padding - changed values */
        --cp-v-xsm: var(--size-0.5);
        --cp-v-lg: var(--size-3);
        --cp-v-xlg: var(--size-4);
        --cp-v-heading-padding: var(--size-8);
        
        /* Column Spacing - changed values */
        --column-sm: var(--size-10);
        --column-md: var(--size-12);
        --column-lg: var(--size-20);
        
        /* Button Elements - changed values */
        --button-radius: var(--size-1);
        
        /* Other Elements - changed values */
        --menu-height: var(--size-14);
    }
}

/* Section Padding
--------------------------------------------- */

.section-padding-small {
    padding: var(--section-padding-smaller) var(--section-padding-sides);
}

.section-padding {
    padding: var(--section-padding) var(--section-padding-sides);
}

.section-padding-large {
    padding: var(--section-padding-larger) var(--section-padding-sides);
}

.section-padding.top {
    padding-bottom: 0;
}

.section-padding.bottom {
    padding-top: 0;
}

.section-padding.sides-only {
    padding-top: 0;
    padding-bottom: 0;
}

.header-offset {
    margin-top: -144px;
}


/* Drop Shadows
--------------------------------------------- */
.drop-shadow-xs {
    box-shadow: 0px 2px 4px 0px rgba(0, 65, 87, 0.16);
}

.drop-shadow-s {
    box-shadow: 0px 2px 4px 0px rgba(0, 43, 62, 0.04), 0px 16px 32px -4px rgba(0, 43, 62, 0.10);
}

.drop-shadow-m {
    box-shadow: 0px 2px 4px 0px rgba(0, 43, 62, 0.04), 0px 24px 48px -8px rgba(0, 43, 62, 0.12);
}

.drop-shadow-l {
    box-shadow: 0px 2px 4px 0px #002b3e0a, 0px 40px 80px -16px rgba(0, 43, 62, 0.16);
}

.drop-shadow-xl {
    box-shadow: 0px 2px 4px 0px rgba(0, 43, 62, 0.04), 0px 56px 112px -20px rgba(0, 43, 62, 0.18);
}


/* PlanB Theme Elements
--------------------------------------------- */

.glass {
	background: rgba(243, 247, 251, 0.80);
	backdrop-filter: blur(5px);
}
.card {
    border-radius: var(--radius-xl);
    padding: var(--cp-2xl);
}
.eyebrow {
    background: var(--white);
    display: inline-flex;
    padding: var(--cp-xs) var(--cp-m);
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: var(--radius-full);
    width: auto;
    margin-right: auto;
}
.gradient-cta {
    background: var(--horizontal-gradient);
    border-radius: var(--radius-xl);
    padding: var(--cp-3xl);
	overflow: hidden;
	position: relative;
}
.gradient-cta .elementor-widget-button:before {
    content: '';
    width: 120%;
    height: 150px;
    background: url(/wp-content/themes/planb-child/img/PlanB-Cutout.svg);
    position: absolute;
    display: block;
    padding: 20px;
    z-index: -1;
    background-repeat: no-repeat;
    background-position: top left;
}
.gradient-cta .elementor-button-wrapper {
    position: relative;
    top: 12px;
}
.shimmer-container {
	opacity: 0.6;
	pointer-events: none;
}

@media all and (max-width:1440px){
	.card {
		padding: var(--cp-xl);
	}
}
@media all and (max-width:900px){
	.gradient-cta .elementor-button-wrapper {
		top: 0px;
	}
}


/* Button Styles
--------------------------------------------- */
.elementor-button {
    background: var(--horizontal-gradient);
    border-radius: var(--radius-full);
    padding: var(--cp-xs) var(--cp-xs) var(--cp-xs) var(--cp-m);
}
.elementor-button-content-wrapper {
    align-items: center;
}
.elementor-button-icon {
    align-items: center;
    display: flex;
    width: 32px;
    height: 32px;
    justify-content: center;
    align-content: center;
    border: 2px solid #fff;
    overflow: hidden;
    border-radius: var(--radius-full);
}
/* Seamless Gradient Hover Effect */
.elementor-button {
    background-image: linear-gradient(90deg, 
        #97F01D 0%, #39C9FF 50%, 
        #97F01D 100%);
    background-size: 200% 100%;
    background-position: 0% 0%;
    transition: background-position 0.5s ease;
}

.elementor-button:hover {
    background-position: 100% 0%;
}

.elementor-button:hover .elementor-button-icon i,
.elementor-button:hover .elementor-button-icon svg {
    animation: slideArrow 1s infinite;
}

@keyframes slideArrow {
    0% {
        transform: translateX(0);
    }
    40% {
        transform: translateX(100%);
        opacity: 0;
    }
    41% {
        transform: translateX(-100%);
        opacity: 0;
    }
    42% {
        transform: translateX(-100%);
        opacity: 1;
    }
    100% {
        transform: translateX(0);
    }
}

/* Animated Marquee
--------------------------------------------- */
.marquee-container {
  width: 100%;
}

.marquee {
  overflow: hidden;
  white-space: nowrap;
  position: relative;
}

.marquee-content {
  display: inline-block;
  padding-right: 0;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

.right-to-left .marquee-content {
  animation-name: marqueeRightToLeft;
  animation-duration: 10s;
}

.left-to-right .marquee-content {
  animation-name: marqueeLeftToRight;
  animation-duration: 10s;
}

@keyframes marqueeRightToLeft {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes marqueeLeftToRight {
  0% { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* Animated Radial Logos
--------------------------------------------- */
.animation-container {
            position: sticky;
            top: 0;
            display: flex;
            justify-content: center;
            align-items: flex-end;
            height: 50vh;
            width: 100%;
        }

        .half-circle-clip {
            position: relative;
            width: 100%;
            height: 50vh; /* Half the viewport height */
        }

        .circle-container {
            position: absolute;
            width: 180vh;
            height: 180vh;
            left: 50%;
            top: 0;
            transform: translateX(-50%); /* Center horizontally */
        }

        .circle {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            transform-origin: center;
            border-radius: 50%;
            border: 1px solid #ccc;
        }

        .logo-item {
            position: absolute;
            transform-origin: center;
            display: flex;
            justify-content: center;
            align-items: center;
            background: #fff;
            border-radius: 50%;
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
            border: 1px solid #ccc;
			z-index: 2;
			padding: 12px;
        }

        .logo-item img {
            max-width: 80%;
            max-height: 80%;
        }

        .radial-cta {
            position: absolute;
            bottom: 64px;
            left: 50%;
            transform: translateX(-50%);
            text-align: center;
            z-index: 10;
            max-width: 460px;
        }
        .radial-cta img {
            max-width: 100%;
        }



@media all and (max-width:900px){
	.logo-item {
			padding: 0px;
        }

}

/* Card Carousel Shortcode
--------------------------------------------- */
.swiper-carousel-container .card {
    background: var(--neutral-200);
    padding: var(--cp-l);
    min-height: 642px;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.swiper-carousel-container .card .image-wrapper img {
    border-radius: var(--radius-l);
}
.swiper-carousel-container h3 {
	font-size: 1.88rem;
	font-style: normal;
	font-weight: 500;
	line-height: 1.13em;
	letter-spacing: -0.3px;
}
.swiper-carousel-container .card .image-wrapper {
    margin-bottom: var(--cp-l);
}
.swiper-carousel-container .card-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--cp-l);
    height: 100%;
    flex: 1;
    justify-content: space-between;
}
.swiper-carousel-container .elementor-button-content-wrapper {
    flex-direction: row-reverse;
    gap: var(--cp-xs);
}
.card-content-wrapper * {
    margin: 0;
}
.swiper-carousel-container .header-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.swiper-nav-container {
    display: flex;
    gap: 32px;
	margin-top: var(--cp-2xl);
}
.swiper-nav-container i {
    font-size: 50px;
    font-weight: 300;
}


/* Animated Ribbons
--------------------------------------------- */
.ribbon-container {
	width: 800px;
	height: 500px;
}
body.admin-bar .dialog-type-lightbox {
    position: fixed;
}
/* responsive 
=============================================*/
@media (max-width:1200px) {
    .swiper-nav-container i {
        font-size: 30px;
    }
    div.radial-cta img {
        max-width: 255px;
    }
    .swiper-carousel-container .card {
        min-height: 520px;
    }
    .swiper-carousel-container .card .image-wrapper img,
    .gradient-cta,
    .card {
        border-radius: var(--radius-xl);
    }
}
@media (max-width:1024px) {
    div.radial-cta img {
        max-width: 209px;
    }
    .elementor .text-display {
        font-size: var(--siteheadings-display, 5rem);
    }
    .hero-section .glass {
        background: none;
        backdrop-filter: none;
    }
    .circle-container {
        width: 100vw;
        height: 100vw;
    }
    .animation-container,
    .half-circle-clip {
        height: 36vh;
    }
}
@media (max-width:767px) {
    .radial-cta {
        bottom: 35px;
    }
    div.radial-cta img {
        max-width: 90px;
    }
    .elementor .text-display {
        font-size: var(--siteheadings-display, 3.44rem);
    }
    .gradient-cta {
        padding:calc(var(--section-padding-larger) + var(--section-padding))  var(--section-padding-sides) var(--section-padding-larger);
    }
    .swiper-nav-container {
        margin-top: var(--cp-xl);
    }
    .animation-container,
    .half-circle-clip {
        height: 20vh;
    }

}



/* FAQ Accordion
--------------------------------------------- */
/* FAQ Accordion Styles */
.faq-accordion-wrapper {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.faq-accordion-item {
    background: #f3f7fb;
    border-radius: 16px;
    padding: 32px;
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
}

.faq-accordion-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    cursor: pointer;
    user-select: none;
}

.faq-question.text-body-large {
    margin: 0;
    flex: 1;
}

.faq-toggle-icon {
    font-family: 'Aceh Soft', sans-serif;
    font-weight: 500;
    font-size: 26px;
    line-height: 32px;
    color: #000000;
    min-width: 12px;
    transition: transform 0.3s ease;
    display: block;
}

/* Remove rotation, use text change instead */
.faq-accordion-item.active .faq-toggle-icon {
    /* Transform removed - using text change in JS instead */
}

.faq-accordion-content {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.4s ease, opacity 0.3s ease, padding-top 0.3s ease;
}

.faq-accordion-item.active .faq-accordion-content {
    opacity: 1;
    padding-top: 20px;
    /* max-height will be set by JS */
}

.faq-answer {
    font-size: 18px;
    line-height: 1.6;
    color: #333333;
}

/* Ensure header is clickable */
.faq-accordion-header:hover {
    opacity: 0.9;
}

@media all and (max-width:1200px){
    .faq-accordion-item {
        padding: 16px;
    }
    .faq-question.text-body-large {
        font-size: 20px;
    }
}