body {
	--wp--style--gallery-gap-default: 20px; 
	--wp--style--block-gap: 20px;
}

[class^="wp-block-"] figcaption {
	font-size: 14px;
	margin-bottom: 0;
	padding: 16px 0;
}

@media screen and (min-width: 46.25em) {
	[class^="wp-block-"] figcaption {
		font-size: 14px;
	}
}

@media screen and (min-width: 55em) {
	[class^="wp-block-"] figcaption {
		font-size: 16px;
	}
}

@media screen and (min-width: 59.6875em) {
	[class^="wp-block-"] figcaption {
		font-size: 12px;
	}
}

@media screen and (min-width: 68.75em) {
	[class^="wp-block-"] figcaption {
		font-size: 14px;
	}
}

@media screen and (min-width: 77.5em) {
	[class^="wp-block-"] figcaption {
		font-size: 16px;
	}
}

/* Alignments */

[class^="wp-block-"].alignleft,
[class^="wp-block-"] .alignleft {
	margin-right: 1em;
}

[class^="wp-block-"].alignright,
[class^="wp-block-"] .alignright {
	margin-left: 1em;
}


/*--------------------------------------------------------------
2.0 Blocks - Common Blocks
--------------------------------------------------------------*/

/* Paragraph */

p.has-drop-cap:not(:focus)::first-letter {
	font-size: 5em;
}

p a:link,
p a:visited,
p a:hover,
p a:active,
p a:focus,
p a {
	text-decoration: underline;
}

/* Audio */

.wp-block-audio audio {
	display: block;
	width: 100%;
}

/* Cover */

.wp-block-cover-image .wp-block-cover-image-text,
.wp-block-cover .wp-block-cover-text,
.wp-block-cover-image h2,
.wp-block-cover h2 {
	font-size: 26px;
	line-height: 1.2069;
}

/* Quote */

.wp-block-quote {
	border-width: 0;
	margin: 0 0 25px 0;
	padding: 0;
	font-size: 22px;
	color: var(--primary);
}

.wp-block-quote cite,
.wp-block-quote__citation {
	font-style: normal;
	text-transform: none;
}

.wp-block-quote.has-text-color cite,
.wp-block-quote.has-background cite {
	color: inherit;
}

.wp-block-quote em,
.wp-block-quote i {
	font-style: normal;
}

.wp-block-quote strong,
.wp-block-quote b {
	font-weight: 400;
}


@media screen and (min-width: 46.25em) {
	.edit-post-visual-editor .wp-block-quote p {
		font-size: 20px;
		line-height: 1.75;
	}

	.wp-block-quote cite,
	.wp-block-quote__citation {
		font-size: 17px;
		line-height: 1.6471;
	}
}

@media screen and (min-width: 55em) {
	.edit-post-visual-editor .wp-block-quote p {
		font-size: 22px;
		line-height: 1.8182;
	}

	.wp-block-quote cite,
	.wp-block-quote__citation {
		font-size: 19px;
		line-height: 1.6842;
	}
}

@media screen and (min-width: 59.6875em) {
	.edit-post-visual-editor .wp-block-quote p {
		font-size: 18px;
		line-height: 1.6667;
	}

	.wp-block-quote cite,
	.wp-block-quote__citation {
		font-size: 15px;
		line-height: 1.6;
	}
}

@media screen and (min-width: 68.75em) {
	.edit-post-visual-editor .wp-block-quote p {
		font-size: 20px;
		line-height: 1.75;
	}

	.wp-block-quote cite,
	.wp-block-quote__citation {
		font-size: 17px;
		line-height: 1.6471;
	}
}

@media screen and (min-width: 77.5em) {
	.edit-post-visual-editor .wp-block-quote p {
		font-size: 22px;
		line-height: 1.8182;
	}

	.wp-block-quote cite,
	.wp-block-quote__citation {
		font-size: 19px;
		line-height: 1.6842;
	}
}

/* Cover Image */

.wp-block-cover-image.aligncenter,
.wp-block-cover.aligncenter,
.wp-block-cover-image.alignleft,
.wp-block-cover.alignleft,
.wp-block-cover-image.alignright,
.wp-block-cover.alignright {
	display: flex;
}

/* File */

.wp-block-file a.wp-block-file__button {
	background-color: #333;
	border: 0;
	border-radius: 0;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.5;
	margin-top: 2em;
	padding: 0.7917em 1.5em;
	text-transform: uppercase;
	vertical-align: baseline;
}

.wp-block-file a.wp-block-file__button:hover,
.wp-block-file a.wp-block-file__button:focus {
	background-color: #707070;
	background-color: rgba(51, 51, 51, 0.7);
	outline: 0;
}

.rtl .wp-block-file * + .wp-block-file__button {
	margin-left: 0.75em;
	margin-right: 0;
}

@media screen and (min-width: 46.25em) {
	.wp-block-file a.wp-block-file__button {
		font-size: 14px;
		font-size: 1.4rem;
		padding: 0.8214em 1.6429em;
	}
}

@media screen and (min-width: 55em) {
	.wp-block-file a.wp-block-file__button {
		font-size: 16px;
		font-size: 1.6rem;
		padding: 0.8125em 1.625em;
	}
}

@media screen and (min-width: 59.6875em) {
	.wp-block-file a.wp-block-file__button {
		font-size: 12px;
		font-size: 1.2rem;
		padding: 0.7917em 1.5833em;
	}
}

@media screen and (min-width: 68.75em) {
	.wp-block-file a.wp-block-file__button {
		font-size: 14px;
		font-size: 1.4rem;
		padding: 0.8214em 1.5714em;
	}
}

@media screen and (min-width: 77.5em) {
	.wp-block-file a.wp-block-file__button {
		font-size: 16px;
		font-size: 1.6rem;
		padding: 0.8125em 1.625em;
	}
}

/*--------------------------------------------------------------
3.0 Blocks - Formatting
--------------------------------------------------------------*/

/* Code */

.wp-block-code {
	background-color: transparent;
	border: 0;
	padding: 0;
}

.wp-block-code code {
	font-family: Inconsolata, monospace;
	font-size: inherit;
}

/* Preformatted */

.wp-block-preformatted {
	background-color: rgba(0, 0, 0, 0.01);
	border: 1px solid #eaeaea;
	line-height: 1.2;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 0.8em;
	white-space: pre;
	white-space: pre-wrap;
	word-wrap: break-word;
}

/* Pullquote */

.wp-block-pullquote {
	border: 0;
}

.wp-block-pullquote blockquote {
	border: 0;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0;
	padding-right: 0;
}

.wp-block-pullquote cite {
	color: #333;
	font-style: normal;
	line-height: 1.6;
	text-transform: none;
}

.wp-block-pullquote[class*="-text-color"] blockquote cite,
.wp-block-pullquote[style*="color"] blockquote cite {
	color: inherit;
}

@media screen and (min-width: 46.25em) {
	.wp-block-pullquote cite {
		font-size: 17px;
		line-height: 1.6471;
	}
}

@media screen and (min-width: 55em) {
	.wp-block-pullquote cite {
		font-size: 19px;
		line-height: 1.6842;
	}
}

@media screen and (min-width: 59.6875em) {
	.wp-block-pullquote cite {
		font-size: 15px;
		line-height: 1.6;
	}
}

@media screen and (min-width: 68.75em) {
	.wp-block-pullquote cite {
		font-size: 17px;
		line-height: 1.6471;
	}
}

@media screen and (min-width: 77.5em) {
	.wp-block-pullquote cite {
		font-size: 19px;
		line-height: 1.6842;
	}
}

/* Table */

.wp-block-table th,
.wp-block-table td {
	border-color: #eaeaea;
	border-width: 0 1px 1px 0;
}

/*--------------------------------------------------------------
4.0 Blocks - Layout Elements
--------------------------------------------------------------*/

/* Button */

.wp-block-button .wp-block-button__link {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	padding: 10px 16px;
	text-transform: none;
	vertical-align: baseline;
	border-radius: 0;
}

.wp-block-buttons[style*="text-transform"] .wp-block-button__link,
.wp-block-button[style*="text-transform"] .wp-block-button__link {
	text-transform: inherit;
}

.is-style-outline .wp-block-button__link {
	border: 2px solid;
}

.entry-content .wp-block-button:not(.is-style-outline) .wp-block-button__link {
	border: 0;
}

.entry-content .wp-block-button.is-style-outline .wp-block-button__link:hover {
	border-bottom: 2px solid;
}

a.wp-block-file__button,
.wp-block-button__link {
	background-color: var(--yellow);
	color: var(--white);
	text-decoration: none !important;
}

.wp-block-file a.wp-block-file__button:hover,
.wp-block-file a.wp-block-file__button:focus,
.wp-block-button__link:hover,
.wp-block-button__link:focus,
.is-style-outline .wp-block-button__link:hover,
.is-style-outline .wp-block-button__link:focus {
	background-color: var(--light-yellow);
	color: var(--white);
}

/* Separators */

.wp-block-separator {
	border: 0;
	max-width: 100px;
}

.wp-block-separator.is-style-wide,
.wp-block-separator.is-style-dots {
	max-width: 100%;
}

/* Media & Text */

.wp-block-media-text {
	margin-bottom: 1.6em;
}

.wp-block-media-text *:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
5.0 Blocks - Widgets
--------------------------------------------------------------*/

/* Archives, Categories & Latest Posts */

.wp-block-archives.aligncenter,
.wp-block-categories.aligncenter,
.wp-block-latest-posts.aligncenter {
	list-style-position: inside;
	text-align: center;
}

/* Latest Comments */

.wp-block-latest-comments {
	margin: 0;
}

.wp-block-latest-comments__comment,
.wp-block-latest-comments__comment-excerpt,
.wp-block-latest-comments__comment-excerpt p {
	font-size: inherit;
}

.wp-block-latest-comments__comment-meta a {
	border-bottom-color: transparent;
	font-weight: 700;
}

.wp-block-latest-comments__comment-excerpt p:last-child {
	margin-bottom: 0;
}

.wp-block-latest-comments__comment-date {
	color: var(--primary);
	font-size: 12px;
	margin-bottom: 40px;
}

@media screen and (min-width: 46.25em) {
	.wp-block-latest-comments__comment-date {
		font-size: 14px;
	}
}

@media screen and (min-width: 55em) {
	.wp-block-latest-comments__comment-date {
		font-size: 16px;
	}
}

@media screen and (min-width: 59.6875em) {
	.wp-block-latest-comments__comment-date {
		font-size: 12px;
	}
}

@media screen and (min-width: 68.75em) {
	.wp-block-latest-comments__comment-date {
		font-size: 14px;
	}
}

@media screen and (min-width: 77.5em) {
	.wp-block-latest-comments__comment-date {
		font-size: 16px;
	}
}

.wp-block-latest-comments .wp-block-latest-comments__comment {
	border-top: 1px solid #eaeaea;
	border-top: 1px solid rgba(51, 51, 51, 0.1);
	margin-bottom: 0;
	padding: 1.6em 0;
}

/*--------------------------------------------------------------
6.0 Blocks - Colors
--------------------------------------------------------------*/

.has-dark-gray-color {
	color: #111;
}

.has-dark-gray-background-color {
	background-color: #111;
}

.has-light-gray-color {
	color: #f1f1f1;
}

.has-light-gray-background-color {
	background-color: #f1f1f1;
}

.has-white-color {
	color: #fff;
}

.has-white-background-color {
	background-color: #fff;
}

.has-yellow-color {
	color: #f4ca16;
}

.has-yellow-background-color {
	background-color: #f4ca16;
}

.has-dark-brown-color {
	color: #352712;
}

.has-dark-brown-background-color {
	background-color: #352712;
}

.has-medium-pink-color {
	color: #e53b51;
}

.has-medium-pink-background-color {
	background-color: #e53b51;
}

.has-light-pink-color {
	color: #ffe5d1;
}

.has-light-pink-background-color {
	background-color: #ffe5d1;
}

.has-dark-purple-color {
	color: #2e2256;
}

.has-dark-purple-background-color {
	background-color: #2e2256;
}

.has-purple-color {
	color: #674970;
}

.has-purple-background-color {
	background-color: #674970;
}

.has-blue-gray-color {
	color: #22313f;
}

.has-blue-gray-background-color {
	background-color: #22313f;
}

.has-bright-blue-color {
	color: #55c3dc;
}

.has-bright-blue-background-color {
	background-color: #55c3dc;
}

.has-light-blue-color {
	color: #e9f2f9;
}

.has-light-blue-background-color {
	background-color: #e9f2f9;
}

.has-dark-gray-gradient-background {
	background-image: linear-gradient(90deg, rgba(17,17,17,1) 0%, rgba(42,42,42,1) 100%);
}

.has-light-gray-gradient-background {
	background-image: linear-gradient(90deg, rgba(241,241,241,1) 0%, rgba(215,215,215,1) 100%);
}

.has-white-gradient-background {
	background-image: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(230,230,230,1) 100%);
}

.has-yellow-gradient-background {
	background-image: linear-gradient(90deg, rgba(244,202,22,1) 0%, rgba(205,168,10,1) 100%);
}

.has-dark-brown-gradient-background {
	background-image: linear-gradient(90deg, rgba(53,39,18,1) 0%, rgba(91,67,31,1) 100%);
}

.has-medium-pink-gradient-background {
	background-image: linear-gradient(90deg, rgba(229,59,81,1) 0%, rgba(209,28,51,1) 100%);
}

.has-light-pink-gradient-background {
	background-image: linear-gradient(90deg, rgba(255,229,209,1) 0%, rgba(255,200,158,1) 100%);
}

.has-dark-purple-gradient-background {
	background-image: linear-gradient(90deg, rgba(46,34,86,1) 0%, rgba(66,48,123,1) 100%);
}

.has-purple-gradient-background {
	background-image: linear-gradient(90deg, rgba(103,73,112,1) 0%, rgba(131,93,143,1) 100%);
}

.has-blue-gray-gradient-background {
	background-image: linear-gradient(90deg, rgba(34,49,63,1) 0%, rgba(52,75,96,1) 100%);
}

.has-bright-blue-gradient-background {
	background-image: linear-gradient(90deg, rgba(85,195,220,1) 0%, rgba(43,180,211,1) 100%);
}

.has-light-blue-gradient-background {
	background-image: linear-gradient(90deg, rgba(233,242,249,1) 0%, rgba(193,218,238,1) 100%);
}

.wp-block-heading {
	margin-top: 60px;
	margin-bottom: 15px;
}

.wp-block-heading + .wp-block-heading {
	margin-top: 15px;
}

.wp-block-columns.is-layout-flex {
	justify-content: center;
}

.wp-block-columns {
	margin-top: 0;
	margin-bottom: 0;
}

.wp-block-column > *:first-child {
	margin-top: 0 !important;
}

.wp-block-column > *:last-child {
	margin-bottom: 0 !important;
}

.wp-block-media-text > .wp-block-media-text__content {
	padding-left: 30px;
	padding-right: 30px;
}

.wp-block-media-text__content:first-child {
	padding-left: 0 !important;
}

.wp-block-media-text__content:last-child {
	padding-right: 0 !important;
}

.wp-block-columns {
	gap: 35px 25px;
}

.wp-block-gallery {
	margin: 0 auto 80px auto;
	max-width: 1440px;
	gap: 20px;
}

.wp-block-image .aligncenter img {
	margin-left: auto;
	margin-right: auto;
}

.wp-block-image {
	margin-bottom: 25px;
}

.wp-block-image img {
	border-radius: 8px !important;
	overflow: hidden;
	width: 100%;
	height: auto;
	object-fit: cover;
	object-position: center center;
	contain-intrinsic-size: unset !important;
}

.wp-block-image.default-image img {
	aspect-ratio: auto;
	width: auto !important;
	height: auto !important;
}

.wp-block-image,
.gallery figure.gallery-item {
	overflow: hidden;
	border-radius: 8px !important;
}

.wp-block-gallery img,
.gallery img {
	cursor: pointer;
	object-fit: cover;
	object-position: center 30%;
	transition: all 300ms ease;
}

.wp-block-gallery img:hover,
.gallery img:hover {
	transform: scale(1.2);
}

.wp-block-image.icon {
	border-radius: 0 !important;
}

.wp-block-image.icon img {
	width: auto !important;
	border-radius: 0 !important;
	aspect-ratio: auto;
	margin: 0 auto;
}

.is-resized img {
	object-fit: contain !important;
	aspect-ratio: auto !important;
}

.wp-block-embed {
	margin-bottom: 80px;
}

.wp-block-embed iframe {
	display: block;
	margin: 0 auto;
	width: 100%;
	max-width: 900px;
	height: auto;
}

.wp-embed-aspect-16-9 iframe {
	aspect-ratio: 16 / 9;
}

.gallery {
    margin: 0 auto 80px auto;
    text-align: center;
    width: 100%;
	display: grid;
	justify-content: center;
	align-content: center;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.gallery.gallery-columns-1 {
	grid-template-columns: repeat(1, 1fr);
}

.gallery.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery.gallery-columns-7 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery.gallery-columns-8 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery.gallery-columns-9 {
	grid-template-columns: repeat(6, 1fr);
}

@media screen and (max-width: 1500px) {
	.gallery.gallery-columns-5 {
		grid-template-columns: repeat(4, 1fr);
	}

	.gallery.gallery-columns-6 {
		grid-template-columns: repeat(4, 1fr);
	}

	.gallery.gallery-columns-7 {
		grid-template-columns: repeat(4, 1fr);
	}

	.gallery.gallery-columns-8 {
		grid-template-columns: repeat(4, 1fr);
	}

	.gallery.gallery-columns-9 {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media screen and (max-width: 1200px) and (min-width: 782px) {
	.wp-block-columns:has(> div:first-child + div + div + div:last-child) {
		flex-wrap: wrap !important;
	}
	
	.wp-block-columns:has(> div:first-child + div + div + div:last-child) > div {
		flex-basis: calc(50% - 15px) !important;
	}
}

@media screen and (max-width: 980px) {
	.gallery.gallery-columns-4 {
		grid-template-columns: repeat(3, 1fr);
	}

	.gallery.gallery-columns-5 {
		grid-template-columns: repeat(3, 1fr);
	}

	.gallery.gallery-columns-6 {
		grid-template-columns: repeat(3, 1fr);
	}

	.gallery.gallery-columns-7 {
		grid-template-columns: repeat(3, 1fr);
	}

	.gallery.gallery-columns-8 {
		grid-template-columns: repeat(3, 1fr);
	}

	.gallery.gallery-columns-9 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media screen and (max-width: 640px) {
	.gallery.gallery-columns-3 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-5 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-6 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-7 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-8 {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery.gallery-columns-9 {
		grid-template-columns: repeat(2, 1fr);
	}
}

.gallery .gallery-item {
    display: flex;
    flex-flow: column;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    width: 100%;
    margin: 0;
    text-align: center;
}

.gallery .gallery-item .gallery-icon,
.gallery .gallery-item a {
	display: block;
	width: 100%;
	margin: 0;
}

.gallery .gallery-item:not(:has(img)) {
	display: none;
}

.gallery img {
	border: none;
	display: block;
	width: 100%;
	height: auto;
	margin: 0;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	object-position: center center;
}

.gallery .gallery-caption {
    display: none;
}

.wp-block-media-text__media img {
	border-radius: 8px;
}

.wp-block-media-text > .wp-block-media-text__media {
	margin-bottom: 25px;
}

@media screen and (max-width: 600px) {
	.wp-block-media-text > .wp-block-media-text__content {
		padding-left: 0;
		padding-right: 0;
	}
}

.wp-block-accordion-item {
	background-color: var(--primary);
	border-bottom-left-radius: 8px;
	border-bottom-right-radius: 8px;
}

.wp-block-accordion-item + .wp-block-accordion-item {
	margin-top: 15px;
}

.wp-block-accordion-heading {
	font-size: 18px;
}

.wp-block-accordion-heading__toggle {
	padding: 10px 25px !important;
	background-color: var(--primary) !important;
}

.wp-block-accordion-heading__toggle:focus,
.wp-block-accordion-heading__toggle:hover,
.wp-block-accordion-heading__toggle[aria-expanded="true"] {
	background-color: var(--light-green) !important;
	text-decoration: none !important;
}

.wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-title {
	text-decoration: none !important;
}

.wp-block-accordion-panel {
	padding: 15px 25px;
}

