/*
 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;
}

#page p a:not(.btn-all-style, .service-title a){
	text-decoration:none;
	font-weight:500;
	border-bottom: 1px dashed rgba(0, 0, 0, 0.2);
}

.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%; 
}

/*=====================================================================
3RD PARTY EMBEDS
======================================================================*/

/*------------------------------------
TRUSTINDEX.IO
------------------------------------*/

.ti-widget[data-layout-id='54'][data-set-id='dark-luxury-fame'] .ti-controls .ti-next, .ti-widget[data-layout-id='54'][data-set-id='dark-luxury-fame'] .ti-controls .ti-prev{
	background-color:transparent!important;
}

.ti-widget[data-layout-id='54'][data-set-id='dark-luxury-fame'] .ti-review-content{
	font-size:18px!important;
	line-height:1.6!important;
}

.ti-widget[data-layout-id='54'][data-set-id='dark-luxury-fame'][data-pid='a314b0160b122709b886bd164b6'] .ti-header .ti-logo-stars-flex{
	border-bottom:1px solid #39588e!important;
}


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

/* =========================================================================
 *  TABLE STYLING FOR WP BLOCK TABLE
========================================================================= */

.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: #f1f1f1;
}

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

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

/* overlay panel mega menu css fix for horizontal scroll when mega menu is shown */

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

/* default simple mega menu css - https://docs.generatepress.com/article/building-simple-mega-menu/ */
@media (min-width: 769px) {
    nav .main-nav .mega-menu {
        position: static;
    }

    nav .main-nav .mega-menu > ul {
        position: absolute;
        width: 100%;
        left: 0 !important;
        display: flex;
        flex-wrap: wrap;
    }

    nav .main-nav .mega-menu > ul > li > a {
        font-weight: bold;
    }

    nav .main-nav .mega-menu>ul>li {
        display: inline-block;
        width: 25%;
        vertical-align: top;
    }

    nav .main-nav .mega-menu.mega-menu-col-2>ul>li {
        width: 50%;
    }

    nav .main-nav .mega-menu.mega-menu-col-3>ul>li {
        width: 33.3333%;
    }

    nav .main-nav .mega-menu.mega-menu-col-5>ul>li {
        width: 20%;
    }

    nav .main-nav .mega-menu > ul > li:hover > a,
    nav .main-nav .mega-menu > ul > li:focus > a,
    nav .main-nav .mega-menu > ul > li[class*="current-"] > a,
    nav .main-nav .mega-menu ul ul {
        background-color: transparent !important;
        color: inherit;
    }

    nav .main-nav .mega-menu ul .sub-menu {
        position: static;
        display: block;
        opacity: 1;
        visibility: visible;
        width: 100%;
        box-shadow: 0 0 0;
        left: 0;
        height: auto;
        pointer-events: auto;
        transform: scale(1);
    }

    nav .main-nav .mega-menu ul.toggled-on .sub-menu {
        pointer-events: auto;
    }

    nav .main-nav .mega-menu .sub-menu .menu-item-has-children .dropdown-menu-toggle {
        display: none;
    }
}



/*=====================================================================
SERVICE PAGE / PROCEDURE PAGE CONTENT STYLING / BLOG CONTENT STYLING
======================================================================*/

/* 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:1.875rem;
		padding-left:1.875rem;
	}
}

.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:1.125rem;
	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);
}

/* enter css styles for service pages / procedure pages / blog pages that will be hardcoded here */

.services .entry-content div > h2,
.single-post .dynamic-entry-content div > h2,
.services .entry-content div > h3,
.single-post .dynamic-entry-content div > h3{
	margin-top:0!important;
	margin-bottom:unset!important;
}

.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(--blue-50);
	/*display:flex;
	flex-direction:column;
	row-gap:1rem;*/
}

.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(--blue-800);
	font-weight:500;
}

.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;
}

.services .entry-content ol,
.single-post .dynamic-entry-content ol{
	background-color:var(--green-50);
	border:2px solid var(--green-400);
	counter-reset: counter-list;
	border-radius:0.5em;

}

.services .entry-content ul:not(#rank-math-toc ul),
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul){
	background-color:var(--blue-25);
	border:2px solid var(--blue-400);
	border-radius:0.5em;
}

.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:1.5rem 2rem 1.5rem 5.5rem;
}

.services .entry-content ol li,
.single-post .dynamic-entry-content ol li{
	border-bottom:2px solid var(--green-400);
}

.services .entry-content ul:not(#rank-math-toc ul) li,
.single-post .dynamic-entry-content ul:not(#rank-math-toc ul) li{
	border-bottom:2px solid var(--blue-100);
}

.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;
	padding-bottom:1.5rem;
}

.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: 1.5rem;
	left:1.5rem;
    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: 1.5rem;
    left: 1.5rem;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--green-600);
    box-shadow: inset 0px -4px 0px 0px rgb(0 0 0 / 10%);
}

.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;
	top:1.6rem;
	left:2rem;
	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(--blue-400);
}


/*=====================================================================
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;
}

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

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

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

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

.gform-theme--foundation .gform_footer .gform_button{
	font-family:'Comfortaa', Arial!important;
	font-weight: 700;
    letter-spacing: -0.025em;
}

.gform-theme--foundation .gform-field-label{
	font-family:Comfortaa, sans-serif!important;
	font-weight: 700;
	color: var(--blue-800)!important;
}

.gform-theme--foundation .gform-field-label--type-inline{
	color:var(--paragraph)!important;
	font-family:DM Sans, sans-serif!important;
}

.gform_body .gform_fields .gsection{
	border-bottom-color:var(--blue-50)!important;
}

.gform-theme--foundation .gfield select{
	border:1px solid var(--blue-100)!important;
	height:50px;
	line-height:50px;
	padding-left:15px;
	padding-right:15px;
	font-size:16px;
}

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

/* RANK MATH FAQ */

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

.rank-math-list .rank-math-list-item h3.rank-math-question {
    display: flex;
    align-items: center;
    column-gap: .75rem;
	background-color:var(--blue-50);
	padding:1.5rem 3rem 1.5rem 1.5rem;
	border-radius:0.25rem;
	border:1px solid var(--blue-100);
}

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

.rank-math-list-item p:first-child{
	padding-top:2rem;
}

.rank-math-list-item p:last-child{
	margin-bottom:2rem
}

/* RANKMATH FAQ ACCORDION CSS */

/*#rank-math-faq .rank-math-list-item {
    margin-bottom: 1em;
    margin-top: 1em;
}*/

.rank-math-question {
    cursor: pointer;
    position: relative;
    display: block;
	margin-bottom:0;
}

.rank-math-question:after {
    position: absolute;
    right: 1rem;
    top: 50%; /* Pushes the starting point down 50% */
    content: "\2715";
    color:var(--blue-400);
    /* Combine transforms: center vertically AND rotate */
    transform: translateY(-50%) rotate(-45deg); 
    transition: all 150ms ease-in-out;
}

.rank-math-question.collapse:after {
    transform: translateY(-50%) rotate(0deg); 
}

.rank-math-question:hover {
    opacity: 0.8;
}

/* 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% }
}