/* Style for custom FAQ page */
html {
  scroll-behavior: smooth;
}
body strong,
body b{
    font-weight: 500;
}
body a {
	color: var(--main-button-color);
}
body a:hover,
body a:focus{
	color: var(--main-button-hover-color);
}
#ast-scroll-top.ast-scroll-top-icon {
    background-color: var(--main-theme-color);
}

#main {
	padding: 4rem 1.2rem 6rem;
/* 	background-color: #f7f9fd; */
 	height: 100%; 
}
#main .content {
	max-width: 1200px;
	margin: 0 auto;
	background-color: #ffffff;
/*     box-shadow: 3px 4px 15px 2px rgb(44 50 66 / 0.12); */
/*     padding: 2rem 2.5rem; */
	min-height: 35rem;
}

/* Page title */
.page-title-wrapper {
	margin: 20px 0;
	text-align: center;
}
.page-title-wrapper p {
	margin-bottom: 0.8rem;
}
.page-title-wrapper .page-title {
	margin: 0;
}
.page-title-wrapper .title {
	margin-bottom: 5px;
	font-weight: 900;
	font-size: 2.5rem;
    letter-spacing: 2.5px;
	color: #465566
}
.separator-parent {
	text-align: center;
	line-height: 0;
}
.separator {
/* 	text-align: left; */
	margin: 1px 0 10px 0;
	border-top: 2px solid var(--main-theme-color);
    width: 9%;
    display: inline-block;
}
.page-title-wrapper .page-description {
	margin-top: 0.8rem;
	line-height: 1.7;
	margin: 0.8rem auto 0;
    line-height: 1.7;
    max-width: 55rem;
}

h3.title {
	font-size: 1.1rem;
	text-transform: none;
	font-weight: 700;
    color: #465566;
}

/* FAQ Section */

.table-of-contents {
	margin: 2rem auto;
    max-width: 45rem;
     /* border-bottom: 1px solid #e5e5e5; */
    display: flex;
    flex-direction: column;
    align-items: center; 
}
.table-of-contents .toc-wrapper {
/*     text-align: left; */
	display: flex;
    gap: 1rem 2rem;
    flex-wrap: wrap;
    align-items: flex-start;
	margin: 0 0 1rem 0;
}
.table-of-contents .element-heading {
	margin-bottom: 0.7em;
}
.table-of-contents ul {
	list-style: none;
	margin: 0;
	--icon-space: 1.7em;
	padding: 0;
}
.table-of-contents li {
    display: flex;
    align-items: center;
}
.table-of-contents li.minor {
	margin-left: 0.3em;
	padding-left: var(--icon-space);
}
.table-of-contents li.minor::before {
	content: "\f111"; /* FontAwesome Unicode */
	font-family: "Font Awesome 5 Free";
	font-size: var(--icon-size);
	font-weight: 900;
	display: inline-block;
  	margin-left: calc( var(--icon-space) * -1 );
  	width: var(--icon-space);
	font-size: 0.4em;
	color: var(--main-button-color);
	
}
.table-of-contents .section-link {
	font-weight: 400;
}
.faq-container {
	margin: 2rem auto 3rem;
	max-width: 45rem;
}
.faq-major-section:not(:last-of-type) {
	margin-bottom: 3rem;
}
.faq-major-section .section-heading {
	margin-bottom: 3px;
}
.faq-major-section .section-heading h2.title {
	font-size: 2rem;
	text-transform: none;
	font-weight: 900;
    color: #465566;
}
.faq-major-section.admin h2.title {
	font-weight: 700!important;
	font-size: 1.5rem!important;
	padding: 0!important;
}
.section-heading h3.title {
	font-size: 1.4rem;
}
.faq-major-section.admin .section-heading h3.title {
	font-size: 1.2rem;
}
.faq-major-section .separator-parent {
	text-align: left;
}
.faq-major-section .separator {
	margin-bottom: 2em;
}
.faq-section:not(:last-of-type) {
	margin-bottom: 3rem;
}
.faq-section .note {
	font-size: 1.2rem;
}
.faq-section .section-heading {
	margin-bottom: 0.2em;
}

.quvent-faq-container .accordion .accordion-item {
  	border-bottom: 1px solid #e5e5e5;
}

.quvent-faq-container .accordion .accordion-item button[aria-expanded='true'] {
  	border-bottom: 1px solid var(--main-button-color);
}

.quvent-faq-container .accordion button {
	position: relative;
	display: block;
	text-align: left;
	width: 100%;
	padding: 0.85em 0;
	color: #55687e;
	font-size: 1.1rem;
	font-weight: 400;
	border: none;
	border-radius: 0;
	background: none;
	outline: none;
	text-transform: none;
	line-height: 1.3;
	letter-spacing: 1px;
	padding-right: 1.7em;
}

.quvent-faq-container .accordion button:hover,
.quvent-faq-container .accordion button:focus {
	cursor: pointer;
	color: var(--main-button-color);
}

.quvent-faq-container .accordion button:hover::after,
.quvent-faq-container .accordion button:focus::after {
	cursor: pointer;
	color: var(--main-button-color);
	border: 1px solid var(--main-button-color);
}

.quvent-faq-container .accordion button .accordion-title {
  	padding: 1em 1.5em 1em 0;
}

.quvent-faq-container .accordion button .icon {
  display: inline-block;
  position: absolute;
  top: 18px;
  right: 0;
  width: 22px;
  height: 22px;
  border: 1px solid;
  border-radius: 22px;
}

.quvent-faq-container .accordion button .icon::before {
  display: block;
  position: absolute;
  content: '';
  top: 9px;
  left: 5px;
  width: 10px;
  height: 2px;
  background: currentColor;
}
.quvent-faq-container .accordion button .icon::after {
  display: block;
  position: absolute;
  content: '';
  top: 5px;
  left: 9px;
  width: 2px;
  height: 10px;
  background: currentColor;
}

.quvent-faq-container .accordion button[aria-expanded='true'] {
  	color: var(--main-button-color);
}
.quvent-faq-container .accordion button[aria-expanded='true'] .icon::after {
  	width: 0;
}
.quvent-faq-container .accordion button[aria-expanded='true'] + .accordion-content {
	opacity: 1;
	max-height: 25em;
	transition: all 200ms linear;
	will-change: opacity, max-height;
}
.quvent-faq-container .accordion .accordion-content {
	opacity: 0;
	max-height: 0;
	overflow: hidden;
	transition: opacity 200ms linear, max-height 200ms linear;
	will-change: opacity, max-height;
	color: #454f64;
}
.quvent-faq-container .accordion .accordion-content p {
	font-size: 1rem;
	font-weight: 300;
	margin: 2em 0;
	line-height: 1.6;
}

@media screen and (max-width: 768px) {
	.content {
		padding: 1rem 1.5rem;
		min-height: 40rem;
	}	
	.page-title-wrapper .page-title .title {
		font-size: 2.2rem;
		letter-spacing: 1.5px;
	}
	
}