@charset "UTF-8";

/*
Theme Name: Twenty Twenty Child
Template: twentytwenty
*/

:root {
	--blue: #09b5ac;
	--blue_dark: #435052;
	--blue_mid: #4d747b;
	--blue_pale: #cce3de;
	--white: #fff;
}

@font-face {
	font-family: "Cinzel";
	src: url("fonts/Cinzel-Regular.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

/* @font-face {
    font-family: 'Genos';
    src: url('fonts/Genos-ThinItalic.woff2') format('woff2');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
} */

@font-face {
	font-family: "Genos";
	src: url("fonts/Genos-Regular.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Orbitron";
	src: url("fonts/Orbitron-Regular.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	overflow-x: hidden;
}

body {
	background-color: var(--blue_pale);
	color: var(--blue_dark);
	font-family: "Genos";
	font-size: 18px;
	letter-spacing: 0.1rem;
	min-height: 100vh;
	max-width: 100vw;
}

body.home .hide_onHome,
.hideMe {
	display: none;
}

@media screen and (min-width: 320px) {
	/* === general ============================================================ */

	.reset-list-style,
	.reset-list-style ul,
	.reset-list-style ol {
		list-style: none;
		margin: 0;
	}

	/* --- layout ------------------------------------------------------------- */

	body :where(.wp-block-columns.is-layout-flex) {
		gap: 0;
	}

	.wp-block-columns {
		gap: 30px;
	}

	/* --- text ----------------------------------------------------------------------------- */

	.list_major {
		font-family: cinzel;
		font-size: 1.5rem;
	}

	.list_major .wp-block-column {
		align-self: center;
	}

	.list_major .wp-block-column ul {
		list-style: none;
		margin: 0;
	}

	.list_major > .wp-block-column ul {
		text-align: center;
	}

	.list_major > .wp-block-column:nth-child(2n + 1) ul li:nth-child(2n + 2) {
		color: var(--blue_pale);
	}

	.list_major > .wp-block-column:nth-child(2n + 2) ul li:nth-child(2n + 1) {
		color: var(--blue_pale);
	}

	/* === header  ========================================================= */

	.menu-bottom {
		align-items: center;
		display: flex;
		justify-content: space-between;
		padding: 0;
	}

	#site-header {
		background-image: url(img/top_bg-m.png);
		background-repeat: no-repeat;
		background-size: cover;
		background-position: left bottom;
		background-color: transparent;
		width: 100%;
		max-width: 100vw;
		padding-bottom: 5px;
		position: fixed;
		z-index: 9999;
	}

	#site-header.open {
		padding-bottom: 70px;
	}

	.header-titles {
		position: relative;
	}

	.header-titles-wrapper {
		align-items: center;
		display: flex;
		justify-content: center;
		padding: 0;
		text-align: left;
	}

	.site-description-wrap {
		max-width: unset;
	}

	.header-titles .site-description {
		color: var(--blue_pale);
		margin: 10px 0;
	}

	button.mobile-nav-toggle-child {
		display: inline-block;
		position: absolute;
		top: 0px;
		left: 60px;
	}

	#top-menu-wrapper {
		overflow: hidden;
		height: 0;
		transition: height 0.25s ease-out;
		-webkit-transition: height 0.25s ease-out;
	}

	.header-inner {
		padding: 0.8rem 0;
	}

	.header-titles-wrapper {
		width: 680px;
		max-width: 100%;
	}

	.site-description-wrap {
		overflow: hidden;
		height: 0;
		transition: height 0.25s ease-out;
		-webkit-transition: height 0.25s ease-out;
	}

	.site-description-wrap * {
		color: var(--white);
	}

	#site-description-cnt {
		padding-bottom: 40px;
	}

	.co_services {
		color: var(--white);
		line-height: 1rem;
	}

	.site-logo {
		display: inline-block;
	}

	.site-logo .site-logo-desk {
		display: none;
		width: 150px;
	}

	.site-logo .site-logo-mob {
		display: block;
		width: 46px;
	}

	.site-logo img {
		margin-left: 0;
	}

	/* --- top menu ------------------------------------------------------------------------------------------ */

	.modal-menu {
		text-align: center;
	}

	.modal-menu li {
		border-width: 0 0 0 1px;
		flex-wrap: wrap;
		justify-content: flex-start;
		margin: 0;
		padding: 5px;
	}

	.modal-menu a {
		color: var(--blue_pale);
		text-decoration: none;
		text-transform: uppercase;
		text-decoration: none;
		display: inline-block;
		width: 100%;
	}

	.modal-menu li:hover a {
		color: var(--white);
	}

	.social-icons a {
		align-items: center;
		background: none;
		background-color: transparent;
		border-radius: 50%;
		color: var(--blue_pale);
		display: flex;
		justify-content: center;
		padding: 0;
		text-decoration: none;
		transition: transform 0.15s ease-in-out;
		-webkit-transition: transform 0.15s ease-in-out;
		width: 35px;
		height: 35px;
	}

	.mobile-nav-toggle-child {
		padding: 10px 20px 10px 0;
	}

	.toggle-icon svg {
		color: var(--blue_pale);
		width: 25px;
		max-width: unset;
	}

	.toggle-icon svg:hover {
		color: var(--white);
	}

	.modal-menu li {
		display: inline-block;
	}

	/* === content ======================================================== */

	/* --- main ------------------------------------------------------------------------------------------------------- */

	main {
		background-color: var(--blue_pale);
		display: block;
		padding-top: 100px;
	}

	/* --- header --------------------------------------------------------------- */

	body.hide_page_title header.entry-header,
	body.hide_page_title header.entry-header {
		display: none;
	}

	h1.entry-title,
	h2.entry-title,
	.title_logo h1,
	.title_logo h3,
	h1.archive-title {
		font-family: "cinzel", "sans serif";
		font-weight: 100;
		font-size: 3rem;
	}

	.title_logo h3 {
		font-size: 1.2rem;
	}

	.archive-header {
		background-color: transparent;
	}

	.entry-content {
		padding: 0;
		/* padding: 0 30px; */
	}

	.entry-content p {
		padding-left: 15px;
		padding-right: 15px;
	}

	.entry-content h3 {
		font-family: "cinzel", "sans serif";
	}

	.post-meta-wrapper {
		display: none;
	}

	/* blog ============================================ */

	body.blog main {
		background-color: var(--blue_mid);
	}

	body.blog figure {
		margin: 2.5rem auto;
	}

	body.blog .entry-content {
		display: none;
	}

	body.is-blog-post .entry-content h3.wp-block-heading {
		margin-bottom: 0.25em;
	}

	body.is-blog-post .entry-content::after {
		margin-bottom: 150px;
	}

	/* forms ============================================== */

	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-textarea,
	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-input,
	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-input
		input,
	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-iti-input
		.iti__selected-dial-code,
	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-button-submit {
		font-family: "Orbitron" !important  ;
		letter-spacing: 0.1rem;
	}

	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-button-submit {
		background-color: var(--blue_dark);
	}

	.forminator-ui#forminator-module-443.forminator-design--default
		.forminator-button-submit:hover {
		background-color: var(--blue);
	}

	/* --- archives ---------------------------------------------------------------- */
	body.archive,
	body.archive main {
		background-color: var(--blue_mid);
		padding-bottom: 38px !important;
		/* padding-bottom: 200px !important; */
	}

	h1.archive-title {
		color: var(--blue_pale);
	}

	body.blog .entry-title a,
	body.archive .entry-title a {
		color: var(--white);
	}

	body.blog .entry-title a:hover,
	body.archive .entry-title a:hover {
		text-decoration: none;
	}

	body.blog .entry-categories a,
	body.archive .entry-categories a {
		color: var(--blue);
		font-weight: 400;
	}

	body.blog .entry-categories a:hover,
	body.archive .entry-categories a:hover {
		color: var(--white);
	}

	/* --- content menu --------------------------------------------------------- */

	.entry-content .cnt_menu {
		margin-bottom: 0px !important;
		/* margin-bottom: 30px !important; */
	}

	.cnt_menu .wp-classic-menu-block > .menu,
	.cnt_menu ul {
		text-align: center !important;
	}

	.cnt_menu .wp-classic-menu-block > .menu li,
	.cnt_menu ul li {
		display: block !important;
		text-align: center !important;
		margin-bottom: 30px;
	}

	.cnt_menu .wp-classic-menu-block > .menu a,
	.cnt_menu ul a {
		color: var(--blue_pale);
		font-family: "Orbitron";
		font-size: 2rem;
		font-weight: 400;
		line-height: 1.75rem;
		text-decoration: none;
	}

	.cnt_menu .wp-classic-menu-block > .menu a:hover,
	.cnt_menu ul a:hover {
		color: var(--white);
	}

	/* single ==================================== */

	.singular .entry-header {
		padding: 8rem 0;
	}

	body.single-post .entry-categories a,
	.pagination-single a {
		color: var(--blue_mid);
		font-weight: 400;
	}

	body.single-post .entry-categories a:hover,
	.pagination-single a:hover {
		color: var(--blue);
	}

	.pagination-single {
		margin-top: 0;
	}

	.pagination-single hr {
		display: none;
	}

	/* --- sections -------------------------------------------------------------------- */

	.entry-content > .wp-block-group {
		padding: 0 30px;
	}

	.sect {
		background-color: #fff;
		background-position: top;
		background-repeat: no-repeat;
		background-size: contain;
		margin: 0 !important;
		padding-top: 100px !important;
		padding-bottom: 100px !important;
		width: 100%;
	}

	main.sect {
		padding-bottom: 200px !important;
	}

	.sect h2 {
		font-family: "Cinzel";
		font-size: 2rem;
		font-weight: 100;
	}

	#site-content.sect {
		padding-top: 0 !important;
	}
	.sect.sect_w-d {
		background-image: url(img/sections/white-on-dark-m.jpg);
	}
	.sect.sect_m-w {
		background-image: url(img/sections/mid-on-white-m.jpg);
		background-color: var(--blue_mid);
		color: var(--blue_pale);
	}

	.sect.sect_m-w a {
		color: var(--blue_pale);
		text-decoration: none;
	}
	.sect.sect_m-w a:hover {
		color: var(--white);
	}

	.sect.sect_w-m {
		background-image: url(img/sections/white-on-mid-m.jpg);
	}
	.sect.sect_d-w {
		background-image: url(img/sections/dark-on-white-m.jpg);
		background-color: var(--blue_dark);
		color: var(--white);
	}
	.sect.sect_m-d {
		background-image: url(img/sections/mid-on-dark-m.jpg);
		background-color: var(--blue_mid);
		color: var(--blue_pale);
	}
	.sect.sect_d-m {
		background-image: url(img/sections/dark-on-mid-m.jpg);
		background-color: var(--blue_dark);
		color: var(--white);
	}
	.sect.sect_m-t {
		background-color: var(--blue_mid);
		color: var(--blue_pale);
		margin-top: -100px !important;
		position: relative;
	}
	.sect.sect_m-t::before {
		content: " ";
		display: block;
		height: 38px;
		min-height: 38px;
		background-image: url(img/sections/mid-on-transp-m.png);
		background-position: bottom;
		background-repeat: no-repeat;
		background-size: contain;
		position: absolute;
		top: -38px;
		width: 100%;
	}
	.sect_imgL h3,
	.sect_imgR h3 {
		color: var(--blue_pale);
		font-family: "Orbitron";
		font-size: 2rem;
		font-weight: 400;
	}
	.sect_imgL .wp-block-image img {
		border-radius: 0 170px 300px 0;
		width: calc(100% + 30px);
		max-width: calc(100% + 30px);
		margin-left: -30px;
	}
	.sect_imgL .wp-block-image .wp-element-caption,
	.sect_imgR .wp-block-image .wp-element-caption {
		display: none;
	}
	.sect_imgR .wp-block-image img {
		border-radius: 300px 0 0 170px;
		max-width: calc(100% + 30px);
		min-width: calc(100% + 30px);
		margin-right: -30px;
	}

	.sect_imgR .wp-block-image .wp-element-caption {
		display: none;
	}

	.sect ul.list_cnt {
		list-style: none;
		margin-left: 10px;
	}

	.sect ul.list_cnt li {
		margin-left: 20px;
		position: relative;
	}

	.sect ul.list_cnt li::before {
		background: url(../../uploads/2025/02/drop3.png) no-repeat left center;
		background-size: contain;
		background-position: left center;
		content: " ";
		display: block;
		position: absolute;
		left: -30px;
		top: 0;
		width: 30px;
		height: 20px;
	}

	/* --- envira gallery -------------------------------------------------------------------------------------------------- */

	body .envira-gallery-wrap {
		margin-bottom: 50px;
	}

	[class*="envira-"] {
		font-size: 1.25rem !important;
		line-height: 1.15rem !important;
	}

	.envirabox-caption {
		font-size: 2rem;
		margin-left: auto;
		margin-right: auto;
	}

	.envirabox-theme-base_dark .envirabox-caption-wrap > div {
		font-size: 1.4rem;
		text-align: center;
		width: 100%;
	}

	.envira-gallery-wrap.narrow_cnt {
		width: 768px;
		max-width: 100%;
	}

	/* --- article -------------------------------------------------------------------------------------------------------- */
	.post-meta-wrapper.post-meta-edit-link-wrapper {
		display: none;
	}

	/* === footer ========================================================== */

	.footer-nav-widgets-wrapper.sect {
		padding-top: 0 !important;
	}

	/* --- footer contact ------------------------------------------------------------------------------------------ */
	.footer-contact {
		background-image: url(img/bott_bg.png);
		background-repeat: no-repeat;
		background-position: left top;
		background-size: cover;
		display: block;
		text-align: right;
		width: 390px;
		position: fixed;
		right: -70px;
		bottom: 0;
		transition: all 0.25s ease-out;
		-webkit-transition: all 0.25s ease-out;
	}

	.footer-contact:hover,
	.footer-contact.open {
		right: -50px;
	}

	.co_contact {
		display: inline-block;
		color: var(--blue_dark);
		font-size: 0.8rem;
		line-height: 1.5rem;
		text-align: center;
		padding: 3.25rem 4.5rem 0.5rem 1rem;
		margin-left: auto;
		margin-right: 0;
		width: 230px;
	}

	.co_contact a {
		color: var(--blue_dark);
		text-decoration: none;
	}

	.co_contact a:hover,
	.co_contact a:visited {
		color: var(--blue_dark);
	}

	.footer-contact img {
		display: none;
		margin: 0 auto 10px auto;
		max-width: 100px;
	}

	.footer-contact:hover img,
	.footer-contact.open img {
		display: block;
	}

	/* --- footer ----------------------------------------------------------------------------------------------- */

	#site-footer {
		background-color: var(--blue_mid);
		padding: 30px 0;
	}
}

@media screen and (min-width: 1000px) {
	/* ###################################################### */

	/* === general ====================================================== */

	/* --- text ------------------------------------------------------------------------------------------ */

	.list_major > .wp-block-column:nth-child(2n + 1) ul {
		text-align: right;
	}

	.list_major > .wp-block-column:nth-child(2n + 2) ul {
		text-align: left;
	}

	/* === header  ========================================================= */

	#site-header {
		background-size: auto 100%;
		padding-bottom: 40px;
	}

	.header-titles-wrapper {
		padding: 0;
		text-align: center;
	}

	.header-titles .site-title,
	.header-titles .site-logo,
	.header-titles .site-description,
	.co_services {
		margin: 1rem 0 0 0;
	}

	.site-logo {
		display: block;
	}

	.site-logo .site-logo-desk {
		display: block;
		width: 150px;
	}

	.site-logo .site-logo-mob {
		display: none;
		width: 46px;
	}

	.site-logo img {
		width: 200px;
	}

	button.mobile-nav-toggle-child {
		position: relative;
		top: 0;
		left: 0;
	}

	.site-description-wrap {
		overflow: hidden;
		max-width: 70%;
		text-align: left;
	}

	/* --- top menu -------------------------------------------------------------- */

	#top-menu-wrapper > div {
		padding: 0.8rem 4rem 0 4rem;
	}

	.modal-menu {
		text-align: left;
	}

	.modal-menu li {
		padding: 0 10px 0 0;
	}

	#topMenuClose {
		position: relative;
		left: -3.5rem;
	}

	.header-titles .site-title,
	.header-titles .site-logo,
	.header-titles .site-description,
	.co_services {
		margin-left: 2.4rem;
	}

	.menu-top {
		max-width: 40%;
	}
	/* === content ========================================================= */

	.entry-content p,
	.post-inner .entry-content .wp-block-group p {
		padding-left: 0;
		padding-right: 0;
	}

	.post-inner .entry-content p {
		padding-left: 15px;
		padding-right: 15px;
	}

	body.blog .entry-content > *:not(.sect),
	body.is-blog-post .entry-content > *:not(.sect),
	body.wp-child-theme-twentytwenty-child.singular
		#site-content
		.post-inner
		.entry-content
		> p {
		max-width: 768px;
		min-width: unset;
	}

	/* --- slider ---------------------------------------------------------------------------------------- */

	/* --- layout ------------------------------------------------------------- */
	body :where(.wp-block-columns.is-layout-flex) {
		gap: 2rem;
	}

	/* --- sections ----------------------------------------------------------*/
	#site-content.sect {
		padding-top: 50px !important;
	}

	/* === footer ========================================================== */

	/* --- footer contact ------------------------------------------------------------------------------------------ */
	.footer-contact {
		background-position: right top;
		background-size: contain;
		height: 105px;
		right: 0;
	}

	.co_contact {
		padding: 3rem 0.5rem 0 0;
		width: 130px;
	}

	.footer-contact:hover .co_contact,
	.footer-contact.open .co_contact {
		width: 230px;
	}
}

@media screen and (min-width: 1920px) {
	.sect {
		background-size: contain;
	}
}
