/*
 Theme Name:   Eprompt Theme
 Theme URI:    https://eprompt.com
 Description:  Eprompt Child Theme of GeneratePress
 Author:       Eprompt
 Template:     generatepress
 Version:      2.0
*/


/* MEDIA QUERIES */

@media (max-width: 768px) {
    /* CSS in here for mobile only */
}
@media (min-width: 769px) and (max-width: 1024px) {
    /* CSS in here for tablet only */
}
@media (min-width: 1025px) {
    /* CSS in here for desktop only */
}


/*=====================================================================
GENERAL
======================================================================*/

html {
	scroll-behavior: smooth;
}

.no-underline, .no-underline a{
	text-decoration:none;
}

.embed-container { 
	position: relative; 
	padding-bottom: 56.25%; 
	height: 0; 
	overflow: hidden; 
	max-width: 100%; 
} 

.embed-container iframe, 
.embed-container object, 
.embed-container embed { 
	position: absolute; 
	top: 0; 
	left: 0; 
	width: 100%; 
	height: 100%; 
}

.textured-bg {
	background-position: center!important;
	background-size: cover!important;
	background-repeat: no-repeat!important;
	background-blend-mode: normal, color-burn !important;
}

/*=====================================================================
BUTTONS
======================================================================*/
/* enter button css here */

/* =========================================================================
 *  TABLES 
========================================================================= */

.wp-block-table{
	margin-top:3rem;
	overflow-x:scroll;
}

.wp-block-table table{
	min-width:600px;
}

@media (max-width: 768px) {
	.wp-block-table table{
		min-width:max-content;
		width:auto!important;
	}
}

.wp-block-table thead th{
	border:1px solid #ccc;
}

.wp-block-table thead{
	border-bottom:1px solid #ccc;
}

.wp-block-table thead strong{
	color:var(--black)!important;
}

.wp-block-table td, .wp-block-table th{
	border:1px solid #ccc;
	padding:20px;
}

.wp-block-table tbody tr td:first-child{
	background-color: var(--grey-100);
}

/*=====================================================================
HEADER / NAV STYLES / NAVIGATION
======================================================================*/
/* enter header or navigation css here*/



/*------------------------------------
GP MEGA MENU
------------------------------------*/
/* enter mega menu styles here */

.menu-item-has-gb-mega-menu .gb-overlay--anchored.gb-overlay--width-full {
  width: calc(100vw - var(--scrollbar-width, 0px));
}

/*=====================================================================
GENERAL PAGE CONTENT STYLING (HOME, ABOUT, CONTACT ETC..)
======================================================================*/

/* APPLY DIVIDER BETWEEN GRID CARDS 4COL, 2COL TAB, 1 COL MOBILE */
.card-w-divider:after { 
	content: '';
	position: absolute;
	border-left: 1px solid rgba(255,255,255,0.2);
	right: -2.5rem;
	height: 100%;
	top:0;
	bottom:0;
}

.card-w-divider:last-child:after {
  	display: none; /* Hide the divider for the last block */
}

@media (min-width: 769px) and (max-width: 1024px) {
	.card-w-divider:before {
		content: '';
		position: absolute;
		border-bottom: 1px solid rgba(255,255,255,0.2);
		border-left:0;
		left: 0;
		right:0;
		bottom:-2.5rem;
	}
	
    .card-w-divider:nth-child(2n):after {
		display: none; /* Hide the divider for the last block */
	}
	
	.card-w-divider:nth-child(3):before,
	.card-w-divider:nth-child(4):before {
		display:none;/* Hide bottom divider for the 3rd & 4th block */
	}
}

@media (max-width: 768px) {
	.card-w-divider:after {
		border-bottom: 1px solid rgba(255,255,255,0.2);
		border-left:0;
		left: 0;
		right:0;
		top:2.5rem;
	}
}



/*=====================================================================
SERVICE PAGE / PROCEDURE PAGE CONTENT STYLING / BLOG CONTENT STYLING
======================================================================*/
/* enter css styles for service pages / procedure pages / blog pages that will be hardcoded here */

/* SIDEBAR LAYOUT CSS */
/** CONTENT AREA **/


@media (min-width: 1025px) {
    .contained-content.separate-containers .inside-article{
		padding:4rem 0rem 4rem 4rem!important;
	}
}

/** LEFT SIDEBAR SERVICES **/

body.services .is-left-sidebar{
	border-right:1px solid var(--babyblue-300);;
}

.inside-left-sidebar{
	height:100%;
	/*padding-right:3.75rem;*/
	/*padding-left:2rem;*/
	padding-right:4rem;
}

@media (max-width: 768px) {
	.inside-left-sidebar{
		padding-right:1rem;
		padding-left:1rem;
	}
}

.separate-containers .inside-left-sidebar, .separate-containers .inside-left-sidebar{
	margin:0;
	padding-top:4rem;
	padding-bottom:40px;
}

.separate-containers.left-sidebar .site-main{
	margin-top:0;
	margin-bottom:0;
}

.inside-left-sidebar .sticky{
	top:150px;
}

@media (min-width: 769px) and (max-width: 1000px) {
    .site-content {
        flex-direction: column;
    }
	
	.site-content .content-area, .is-left-sidebar {
        width: 100%;
    }
	
	body.left-sidebar.contained-content.separate-containers .inside-article {
        padding: 2rem 4rem;
    }
	
	.site-content .content-area, .is-left-sidebar {
        width: 100%;
    }
	
	.separate-containers.left-sidebar .site-main{
		margin:0;
	}
}

@media (max-width: 768px) {
    body.left-sidebar.contained-content.separate-containers .inside-article{
        padding: 30px;
    }
}

/* SIDEBAR MENU */
.sidebar-menu ul li{
	display:block!important;
	width:100%;
	padding-bottom:0.5rem;
	margin-bottom:0.5rem;
	padding-right:0!important;
}

.sidebar-menu ul li:last-child{
	border:none;
	padding-bottom:0;
	margin-bottom:0;
}

.sidebar-menu ul li a{
	font-size:1rem;
	text-decoration:none;
	position:relative;
	display:flex;
	align-content: stretch;
	color:var(--paragraph-dark);
}

.services .sidebar-menu ul li a:hover,
.services .sidebar-menu ul li a:focus{
	color:var(--accent);
}

/* SERVICE PAGE TYPOGRAPHY */

.services .entry-content h2,
.single-post .dynamic-entry-content h2{
	margin-top:3.5rem;
	padding-top:3.5rem;
	margin-bottom:2.5rem;
	border-top:1px solid var(--pale-blue-200);
}

.services .entry-content h3,
.single-post .dynamic-entry-content h3{
	color:var(--paragraph-dark);
}

.services .entry-content h2:first-child,
.single-post .dynamic-entry-content h2:first-child{
	margin-top:0;
	padding-top:0;
	border-top:none;
}

.services .entry-content h3:not(.rank-math-question),
.single-post .dynamic-entry-content h3:not(.rank-math-question){
	margin-top:3.5rem;
	margin-bottom:2.5rem;
}

@media (max-width: 768px) {
	.services .entry-content h3:not(.rank-math-question),
	.single-post .dynamic-entry-content h3:not(.rank-math-question){
		margin-top:2rem;
		margin-bottom:1.5rem;
		font-size:1.5rem;
	}
	.services .entry-content h2,
	.single-post .dynamic-entry-content h2{
		margin-top:2rem;
		padding-top:2rem;
		margin-bottom:1.5rem;
	}
}

.services .entry-content ol li b,
.services .entry-content ol li strong,
.services .entry-content ul li b,
.services .entry-content ul li strong{
	color:var(--black);
}

.services .entry-content ol,
.services .entry-content ul:not(#rank-math-toc ul),
.single-post .dynamic-entry-content ol,
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul){
	list-style-type: none;
    margin: 0;
    padding: 0;
	margin-bottom:3rem;
	display:flex;
	flex-direction:column;
	gap:1.25rem;
	padding:2rem;
}

.services .entry-content ol,
.single-post .dynamic-entry-content ol{
	background-color:var(--grey-100);
	border:2px solid var(--beige-200);
	counter-reset: counter-list;

}

.services .entry-content ul:not(#rank-math-toc ul),
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul){
	background-color:var(--grey-100);
	border:2px solid var(--beige-200);

}

.services .entry-content ol li,
.services .entry-content ul:not(#rank-math-toc ul) li,
.single-post .dynamic-entry-content ol li,
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul) li{
	position:relative;
	padding-left:3rem;
}

.services .entry-content ol li:last-child,
.services .entry-content ul:not(#rank-math-toc ul) li:last-child,
.single-post .dynamic-entry-content ol li:last-child,
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul) li:last-child{
	border-bottom:0;
}

.services .entry-content ol li::before,
.single-post .dynamic-entry-content ol li::before{
    counter-increment: counter-list;
    content: counter(counter-list);
    position: absolute;
    z-index: 9;
    color: #fff;
    top: 0.25rem;
	left:0;
    font-weight: 700;
    font-size: 18px;
    height: 30px;
    width: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.services .entry-content ol li::after,
.single-post .dynamic-entry-content ol li::after{
    content: '';
    position: absolute;
    top: 0.25rem;
    left: 0;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--beige-600);
}

.services .entry-content ul li::before,
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul) li::before{
	width: 2rem;
	height: 2rem;
	position:absolute;
	left:0rem;
	content: '';
	-webkit-mask: url('/wp-content/uploads/2025/10/circle-arrow-right-duotone-solid-full.svg') no-repeat 50% 50%;
	mask: url('/wp-content/uploads/2025/10/circle-arrow-right-duotone-solid-full.svg') no-repeat 50% 50%;
	-webkit-mask-size: cover;
	mask-size: cover;
	vertical-align:middle;
	background-color:var(--beige-600);
}


/*=====================================================================
SPECIFIC BLOG STYLING & BLOG CONTENT STYLING ONLY
======================================================================*/
/* enter css styles for blog and single blog posts here */


/*=====================================================================
FOOTER CSS STYLES
======================================================================*/
/* enter css styles for footer here */

/*------------------------------------
FOOTER MENU QUICKLINKS
------------------------------------*/

.footer-menu ul{
	display:flex;
	row-gap:0.5rem;
	flex-direction:column;
}
.footer-menu ul li{
	display:block;
	width:100%;
}

.footer-menu ul li a{
	text-decoration:none;
	color:#666;
}

.footer-menu ul li a:hover,
.footer-menu ul li a:focus{
	color:#000;
}

/*------------------------------------
SUB FOOTER MENU
------------------------------------*/

.sub-footer-menu ul.menu{
	display:flex;
	flex-direction:row;
	align-items:center;
	gap:1rem;
}

@media (max-width: 768px) {
	.sub-footer-menu ul.menu{
		flex-direction:column;
		gap:0.25rem;
		margin-top:1rem;
	}
}

.sub-footer-menu ul.menu li{
	padding:0;
}

.sub-footer-menu ul.menu li a{
}

/*------------------------------------
MOBILE FIXED CTA BUTTONS IN FOOTER
------------------------------------*/

.footer-cta {
    position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 9;
}

/*=====================================================================
PLUGINS CUSTOM CSS STYLES
======================================================================*/

/*------------------------------------
GRAVITY FORMS
------------------------------------*/


/*------------------------------------
RANK MATH CSS STYLES
------------------------------------*/

/* RANK MATH FAQ */

.rank-math-list{
	display:flex;
	flex-direction:column;
	gap:2rem;
}

.rank-math-list .rank-math-list-item{
	border-bottom:1px solid var(--pale-blue-200);
	background-color:var(--pale-blue-200);
	padding:2rem;
}

.rank-math-list .rank-math-list-item:last-child{
	border-bottom:none;
}

.rank-math-list .rank-math-list-item h3.rank-math-question {
    display: flex;
    align-items: center;
    column-gap: .75rem;
	font-size:1.125rem;
}

.rank-math-list-item .rank-math-question:before {
    width: 2rem;
    height: 2rem;
    display: block;
    content: '';
    -webkit-mask: url('/wp-content/uploads/2025/10/circle-question-solid-full.svg') no-repeat 50% 50%;
    mask: url('/wp-content/uploads/2025/10/circle-question-solid-full.svg') no-repeat 50% 50%;
    -webkit-mask-size: cover;
    mask-size: cover;
    background-color: var(--beige-600);
    flex-shrink: 0;
}

.rank-math-list-item p:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
}

/* RANK MATH BREADCRUMBS */


/* RANK MATH TOC */

#rank-math-toc ul, 
.wp-block-rank-math-toc-block ul{
	border:0;
	background:none;
	margin-bottom:0;
	padding:0;
	margin-left:0;
	clear: both;
	list-style: none;
}

#rank-math-toc ul li, 
.wp-block-rank-math-toc-block ul li{
	border-bottom:0;
	background:none!important;
	position:relative;
	padding-top:0.25rem;
	padding-bottom:0.25rem;
}

#rank-math-toc nav > ul > li, 
.wp-block-rank-math-toc-block nav > ul > li{
	padding-left:1.5rem;
	font-weight:600;
}

#rank-math-toc ul ul,
.wp-block-rank-math-toc-block ul ul{
	padding-top:0.25rem;
}

#rank-math-toc ul ul li, 
.wp-block-rank-math-toc-block ul ul li{
	margin-left:-1.25rem;
	padding-left:calc(1.25rem - 2px);
	border-left:2px solid #ccc;
	font-weight:normal;
}

#rank-math-toc ul ul li a,
.wp-block-rank-math-toc-block ul ul li a{
	color:#666;
	text-decoration:none;
}

#rank-math-toc ul ul li

#rank-math-toc nav > ul > li:before, 
.wp-block-rank-math-toc-block nav > ul > li:before{
	content: '';
	-webkit-mask: url('/wp-content/uploads/2025/10/play-sharp-solid-full.svg') no-repeat 50% 50%;
	mask: url('/wp-content/uploads/2025/10/play-sharp-solid-full.svg') no-repeat 50% 50%;
	background:#000;
    width: 0.75rem;
    height: 0.75rem;
    top: 0.75rem;
	position:absolute;
	left:0;
	vertical-align: middle;
}

@media (max-width: 768px) {
	#rank-math-toc h2, 
	.wp-block-rank-math-toc-block h2{
		font-size:1.5rem;
		margin-bottom:1.5rem;
	}
}


/*=====================================================================
OTHER MISC. CSS STYLES (JS SCRIPTS ETC..)
======================================================================*/

/*------------------------------------------
INFINITE SCROLL AJAX (BLOG) - DO NOT DELETE
------------------------------------------*/

/* DISPLAYS MESSAGE WHEN ALL POSTS HAVE BEEN LOADED */
.page-load-status {
  opacity: 0; /* hidden by default */
  padding-top: 20px;
  border-top: 1px solid #DDD;
  text-align: center;
  color: #777;
}

/* LOADING ANIMATION 1 */
.loader-ellips {
  font-size: 20px; /* change size here */
  position: relative;
  width: 4em;
  height: 1em;
  margin: 10px auto;
}

.loader-ellips__dot {
  display: block;
  width: 1em;
  height: 1em;
  border-radius: 0.5em;
  background: #555; /* change color here */
  position: absolute;
  animation-duration: 0.5s;
  animation-timing-function: ease;
  animation-iteration-count: infinite;
}

.loader-ellips__dot:nth-child(1),
.loader-ellips__dot:nth-child(2) {
  left: 0;
}
.loader-ellips__dot:nth-child(3) { left: 1.5em; }
.loader-ellips__dot:nth-child(4) { left: 3em; }

@keyframes reveal {
  from { transform: scale(0.001); }
  to { transform: scale(1); }
}

@keyframes slide {
  to { transform: translateX(1.5em) }
}

.loader-ellips__dot:nth-child(1) {
  animation-name: reveal;
}

.loader-ellips__dot:nth-child(2),
.loader-ellips__dot:nth-child(3) {
  animation-name: slide;
}

.loader-ellips__dot:nth-child(4) {
  animation-name: reveal;
  animation-direction: reverse;
}

/* LOADING ANIMATION 2 */
/* HTML: <div class="loader"></div> */

.loader{
	margin:20px auto 0 auto;
}

.loader {
  width: 45px;
  aspect-ratio: .75;
  --c: no-repeat linear-gradient(var(--black) 0 0);
  background: 
    var(--c) 0%   50%,
    var(--c) 50%  50%,
    var(--c) 100% 50%;
  animation: l7 1s infinite linear alternate;
}

@keyframes l7 {
  0%  {background-size: 20% 50% ,20% 50% ,20% 50% }
  20% {background-size: 20% 20% ,20% 50% ,20% 50% }
  40% {background-size: 20% 100%,20% 20% ,20% 50% }
  60% {background-size: 20% 50% ,20% 100%,20% 20% }
  80% {background-size: 20% 50% ,20% 50% ,20% 100%}
  100%{background-size: 20% 50% ,20% 50% ,20% 50% }
}