/*
Theme Name: saito-cleaning-theme
Author: Takechan
Version: 1.0
*/
@charset "UTF-8";
/*
Theme Name: ManaSys
Template: basic
Author: Trendmake
Copyright: (c) 2020 Trendmake
Version: 20200403
*/


:root {
	--main-color: #00A5E2;
	--accent-red: #CA1633;
	--accent-green: #1CBC20;
	--hover-color: #E3AE00;
	--text-color: #222222;
	--bg-light: #F2F9FF;
	--font-primary: 'Noto Sans JP', sans-serif;
	--border-radius-btn: 9999px;
	--shadow-btn: 1px 2px 7px rgba(0, 0, 0, 0.3);
}

.saito-visually-hidden {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	clip-path: inset(50%) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

.privacy-policy-content-row {
	padding: 80px 3%;
}

.privacy-policy-page .subpage-main-row {
	width: 100vw;
	margin-left: 0;
	margin-right: 0;
}

.privacy-policy-content {
	max-width: 900px;
	margin: 0 auto;
}

.privacy-policy-content .tb_text_wrap h2 {
	margin: 2.2em 0 0.7em;
	color: #004fa0;
	font-size: 24px;
	line-height: 1.5;
}

.privacy-policy-content .tb_text_wrap p,
.privacy-policy-content .tb_text_wrap li {
	line-height: 2;
}

.privacy-policy-content .tb_text_wrap ul {
	margin: 0 0 1.5em 1.4em;
}

.privacy-policy-updated {
	margin-top: 3em;
	text-align: right;
}

.ft-policy-link {
	margin-top: 16px;
	text-align: center;
	font-size: 14px;
}

.ft-policy-link a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 3px;
}

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

/* Base Adjustments */
body {
	color: var(--text-color);
}

/* Typography Adjustments */
h1,
h2,
h3,
.module-title {
	font-weight: bold !important;
}

/* Button Overrides */
.builder_button,
.module-buttons a,
.ui.builder_button {
	border-radius: var(--border-radius-btn) !important;
	box-shadow: var(--shadow-btn) !important;
	transition: all 0.3s ease !important;
	padding: 15px 40px !important;
	font-weight: bold !important;
}

.builder_button:hover,
.module-buttons a:hover,
.ui.builder_button:hover {
	opacity: 0.8 !important;
	color: #fff !important;
	transform: translateY(-2px);
}

/* Inner border effect for buttons */
.builder_button::before,
.module-buttons a::before {
	content: '';
	position: absolute;
	top: 4px;
	left: 4px;
	right: 4px;
	bottom: 4px;
	border: 2px solid rgba(255, 255, 255, 0.5);
	border-radius: var(--border-radius-btn);
	pointer-events: none;
}

.builder_button,
.module-buttons a {
	position: relative;
	overflow: hidden;
}

/* Section Spacing Adjustments */
@media screen and (min-width: 1025px) {
	.module_row {
		padding-top: 50px !important;
		padding-bottom: 120px !important;
	}

	.module_row.home-main {
		padding-top: 0 !important;
		padding-bottom: 0 !important;
	}
}

@media screen and (max-width: 1024px) {
	.module_row {
		padding-top: 60px !important;
		padding-bottom: 60px !important;
	}

	.module_row.home-main {
		padding-top: 0 !important;
		padding-bottom: 0 !important;
	}
}

/* Scroll Animation Classes */
.js-fadein {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.js-fadein.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/*******************************
Common Setting
*******************************/

body {
	font-family: var(--font-primary);
	font-size: 16px;
	line-height: 2;
}

#content {
	padding: 0;
}

body.page:not(.home) main#content {
	float: none !important;
	width: 100% !important;
	max-width: none !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Those Classes change row_inner width,
   when you set the Themify Builder > Row Options > Row Width to Default and Boxed. */
.module_row>.row_inner,
.module-layout-part .module_row.fullwidth_row_container>.row_inner {
	width: 100%;
}

body table {
	width: 100%;
	border-collapse: collapse;
	box-sizing: border-box;
}

/*******************************
Header Fix
*******************************/
#header.header {
	height: auto;
	border-bottom: none;
}

/* Header Site Branding */
#site-logo,
#site-description {
	position: static;
}

#site-logo {
	line-height: 1;
}

#site-logo a,
#site-logo a img {
	display: block;
}

/* Search Form in Header */
#headerwrap #header #searchform {
	position: static;
}

#headerwrap #header #searchform #s {
	float: none;
}

/* Mobile Menu Button */
#menu-button {
	visibility: hidden;
	opacity: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: fixed;
	z-index: 900;
	top: 0;
	right: 0;
	width: 48px;
	height: 48px;
	background-color: #fafafa;
}

#menu-button.nav-on {
	visibility: visible;
	opacity: 1;
}

#menu-button .ham-lines {
	position: relative;
	margin: 0 auto;
	width: 32px;
	height: 32px;
}

#menu-button .ham-lines span,
#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
	position: absolute;
	display: block;
	right: 0;
	left: 0;
	margin: 0 auto;
	width: 28px;
	height: 2px;
	background-color: #111;
	border-radius: 1px;
}

#menu-button .ham-lines span {
	bottom: 15px;
	transition: all .25s .25s;
	opacity: 1;
}

#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
	content: "";
}

#menu-button .ham-lines::before {
	bottom: 24px;
	animation: menu-bar01 .75s forwards;
}

#menu-button .ham-lines::after {
	bottom: 6px;
	animation: menu-bar03 .75s forwards;
}

#menu-button .ham-text {
	font-size: 12px;
	line-height: 1;
}

#menu-button.is-active .ham-lines span {
	opacity: 0;
}

#menu-button.is-active .ham-lines::before {
	animation: active-menu-bar01 .5s forwards;
}

#menu-button.is-active .ham-lines::after {
	animation: active-menu-bar03 .5s forwards;
}

@keyframes menu-bar01 {
	0% {
		transform: translateY(9px) rotate(45deg);
	}

	50% {
		transform: translateY(9px) rotate(0);
	}

	100% {
		transform: translateY(0) rotate(0);
	}
}

@keyframes menu-bar03 {
	0% {
		transform: translateY(-9px) rotate(-45deg);
	}

	50% {
		transform: translateY(-9px) rotate(0);
	}

	100% {
		transform: translateY(0) rotate(0);
	}
}

@keyframes active-menu-bar01 {
	0% {
		transform: translateY(0) rotate(0);
	}

	50% {
		transform: translateY(9px) rotate(0);
	}

	100% {
		transform: translateY(9px) rotate(45deg);
	}
}

@keyframes active-menu-bar03 {
	0% {
		transform: translateY(0) rotate(0);
	}

	50% {
		transform: translateY(-9px) rotate(0);
	}

	100% {
		transform: translateY(-9px) rotate(-45deg);
	}
}

/* Mobile Header Menu Container */
nav.nav-off {
	display: none;
}

#main-menu-container.is-active {
	position: fixed;
	z-index: 700;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	overflow-y: auto;
	background-color: #f1f1f1;
	display: block;
}

/* Header Main Menu */
#main-menu-container.is-active .main-menu,
#main-menu-container.is-active .sub-menu {
	margin: 0;
	list-style: none;
}

#main-menu-container.is-active .menu-item {
	margin: 0;
	padding: 8px 0 0 16px;
}

#main-menu-container.is-active .main-menu {
	position: static;
	width: 100%;
	max-width: 94%;
	margin: 0 auto 16px;
	padding: 0;
	border: none;
	border-radius: 0;
	background-color: transparent;
	box-shadow: none;
}

#main-menu-container.is-active .main-menu>li {
	margin: 0 16px;
	padding: 8px;
	border-bottom: dotted 1px #ccc;
}

#main-menu-container.is-active .main-menu>li:last-of-type {
	border-bottom: none;
}

#main-menu-container.is-active .main-menu li a {
	font-size: 16px;
	line-height: 2;
	color: #111;
}


/*******************************
Footer Fix
*******************************/
#footer {
	border-top: none;
	clear: none;
	padding: 0;
}

#pc-backtop {
	display: block;
	position: fixed;
	z-index: 500;
	bottom: 50px;
	right: 50px;
	opacity: 0;
	transition: opacity .3s;
}

#pc-backtop.is-visible {
	opacity: 1;
}

#pc-backtop.is-visible:hover {
	opacity: .7;
}

#pc-backtop a,
#pc-backtop a img {
	display: block;
}

.sp-footer-icons-container {
	display: none;
}

/*******************************
Contact form
*******************************/
.wpcf7 table tr th {
	width: 30%;
	text-align: left;
}

.wpcf7 table tr th,
.wpcf7 table tr td {
	padding: 10px 15px
}

.wpcf7 table tr td input,
.wpcf7 table tr td select,
.wpcf7 table tr td textarea {
	background-color: #f3f3f3;
	border: solid 1px #ddd;
	padding: 6px 10px;
	border-radius: 5px;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.wpcf7 table tr td span input {
	margin-top: 10px;
}

.wpcf7 table tr td span:first-child input {
	margin-top: 0px;
}

.wpcf7 table tr td input[type="radio"],
.wpcf7 table tr td input[type="checkbox"] {
	width: auto;
}

.wpcf7 .submit_btn {
	display: block;
}

.wpcf7 .submit_btn input[type="submit"] {
	display: block;
	width: 250px;
	margin: 0 auto;
}

/************************************************
***************** Media Query *******************
*************************************************/
@media screen and (max-width: 1024px) {

	/*******************************
	Body, Header and Footer Fix
	*******************************/
	#pagewrap {
		position: relative;
		padding-bottom: 51px;
	}

	/*******************************
	Header Fix
	*******************************/
	#header.header {
		padding-top: 0;
	}

	/* Mobile Header Site Brand */
	.header-brand-container #site-description {
		margin: 0;
		padding-bottom: 8px;
	}

	/* Search Form in Header Nav */
	#headerwrap #header #searchform {
		position: static;
		width: auto;
		margin: 0 auto;
		padding: 8px 16px;
		text-align: center;
	}

	#headerwrap #header #searchform #s {
		float: none;
		width: 80%;
		height: auto;
		font-size: 16px;
		line-height: 1.6;
	}

	#menu-button {
		visibility: visible;
		opacity: 1;
	}

	#main-menu-container:not(.is-active) {
		display: none;
	}

	/*******************************
	Footer Fix
	*******************************/
	#pc-backtop {
		display: none;
	}

	.sp-footer-icons-container {
		display: flex;
		justify-content: space-around;
		align-items: center;
		position: fixed;
		z-index: 600;
		right: 0;
		left: 0;
		bottom: 0;
		width: 100%;
	}

	.sp-footer-icons-container a {
		display: block;
		width: 100%;
		line-height: 1;
		text-align: center;
		background-color: #fafafa;
		text-decoration: none;
		font-size: 10px;
		padding: 10px 0 6px;
		border-left: 1px solid #1f7bb6;
	}

	.sp-footer-icons-container a:first-child {
		border-left: 0;
	}

	.sp-footer-icons-container a i {
		display: block;
		font-size: 16px;
		margin-bottom: 8px;
	}

	.wpcf7 table tr th,
	.wpcf7 table tr td {
		width: 100%;
		display: block;
		padding: 10px 0px;
	}

	.wpcf7 table tr th {
		padding-bottom: 0;
	}

}

@charset "UTF-8";

/* Setting */
body a {
	transition: .2s all linear;
}

body a:hover {
	opacity: 0.7;
}

hgroup {
	position: relative;
}

hgroup::after,
.main-menu-container::after {
	display: block;
	width: 100%;
	content: "";
	clear: both;
}

body .site {
	color: #2c2c2c;
	font-size: 15px;
	line-height: 2;
}

body #main-menu,
body #main-menu ul {
	margin: 0;
	list-style: none;
}

body #main-menu li {
	display: inline-block;
	margin: 0;
	padding: 0 30px;
	position: relative;
	float: left;

	vertical-align: top;
}

body #main-menu li.menu-hide a {
	display: none;
}

body #main-menu ul {
	display: none;
	width: 100%;
	padding: 10px 5px 5px;
	position: absolute;
	left: 0;
	top: 100%;
	z-index: 2;
	background: rgba(255, 255, 255, 0.8);
	visibility: hidden;
	opacity: 0;
}

body #main-menu li:hover ul {
	display: block;
	visibility: visible;
	opacity: 1;
}

body #main-menu ul li {
	display: block;
	margin: 0 0 5px;
	padding: 0;
	float: none;
}

body .main-menu-container {
	position: relative;
}

.module-fancy-heading .fancy-heading {
	margin: 0;
}

body .footer-nav {
	margin: 0;
	text-align: center;
}

body .footer-nav li {
	display: inline-block;
	margin: 0 0 5px;
	padding: 0 5px 0 10px;
	position: relative;
	float: none;
	text-align: center;
	vertical-align: top;
}

body .footer-nav li::before {
	width: 1px;
	height: 90%;
	position: absolute;
	left: 0;
	top: 0;
	background: #000;

	content: "";
}

body .footer-nav li ul.sub-menu {
	display: inline-block;
	margin: 0 0 0 5px;
	padding: 0;
	position: relative;
}

body .footer-nav li ul.sub-menu::before {
	content: "[";
}

body .footer-nav li ul.sub-menu::after {
	content: "]";
}

body .footer-nav li ul.sub-menu li:first-child::before,
body .footer-nav li:first-child::before {
	display: none;
}

body .footer-nav li ul.sub-menu li {
	margin-bottom: 0;
}

body .copyright-container {
	text-align: center;
}

body #pc-backtop {
	right: 10px;
	bottom: 50px;
}

/* Font */
body,
.step-image .image-title::before {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.title--font-HiraMin .module-title,
.text--font-HiraMin {
	font-family: "ヒラギノ明朝 ProN", "HiraMinProN", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}

/* CSS Menu */
@keyframes menu-bar01 {
	0% {
		transform: translateY(9px) rotate(45deg);
	}

	50% {
		transform: translateY(9px) rotate(0);
	}

	100% {
		transform: translateY(0) rotate(0);
	}
}

@keyframes menu-bar03 {
	0% {
		transform: translateY(-9px) rotate(-45deg);
	}

	50% {
		transform: translateY(-9px) rotate(0);
	}

	100% {
		transform: translateY(0) rotate(0);
	}
}

@keyframes active-menu-bar01 {
	0% {
		transform: translateY(0) rotate(0);
	}

	50% {
		transform: translateY(9px) rotate(0);
	}

	100% {
		transform: translateY(9px) rotate(45deg);
	}
}

@keyframes active-menu-bar03 {
	0% {
		transform: translateY(0) rotate(0);
	}

	50% {
		transform: translateY(-9px) rotate(0);
	}

	100% {
		transform: translateY(-9px) rotate(-45deg);
	}
}

#menu-button {
	top: 5px;
	right: 5px;
	background: rgba(255, 255, 255, 0.7);
}

#main-menu-container.is-active {
	display: flex;
	flex-direction: column;
	justify-content: center;
	background-image: none;
}

#main-menu-container.is-active .main-menu>li {
	display: block;
	width: auto;
	float: none;
	border: 0;
	text-align: center;
}

#main-menu-container.is-active .main-menu li a {
	display: inline-block;
	height: auto;
	background: none;
	text-indent: 0;
}

#main-menu-container.is-active .menu-item ul li a {
	padding: 5px 0;
	font-size: 14px;
	line-height: 1.7;
}

#main-menu-container.is-active .menu-item ul li {
	border-bottom: 0;
	padding-top: 0;
	padding-left: 0;
	line-height: 1;
}

#main-menu-container.is-active .menu-item ul li a:hover {
	text-decoration: underline;
}

body #main-menu-container.is-active #main-menu ul {
	position: relative;
	background: none;
	display: block;
	padding: 0;
	visibility: visible;
	opacity: 1;
}

body .pagewidth {
	max-width: 1200px;
	width: 100%;
}

body #header {
	padding: 0;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}

body #header.pagewidth {
	max-width: 1600px;
	margin-left: auto;
	margin-right: auto;
}

.lb {
	padding-left: 200px;
}

.head-button-contact {
	width: 200px;
	display: inline-block;
}

.head-button-contact a {
	display: block;
	padding: 18px 10px 19px;
	background: var(--main-color);
	color: #fff;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
}

.head-button-contact a span {
	display: inline-block;
	padding: 4px 0 4px 40px;
	background: url(../../uploads/contact-btn-icon.png) no-repeat left center;
}

#main-menu-container,
.head-button-contact {
	display: inline-block;
	vertical-align: middle;
}

body #main-menu li {
	padding: 5px 12px 0;
	font-size: 15px;
	line-height: 1.8;
}

body #main-menu li.hide-menu {
	display: none;
}

body #main-menu li a,
body #main-menu li a:visited,
body #main-menu li a:active,
body #main-menu li a:focus {
	color: #2c2c2c;
}

body #main-menu li a:hover {
	color: var(--main-color);
	text-decoration: none;
}

#footerwrap #footer {
	padding: 70px 0 50px;
}

.footer-content {
	text-align: center;
	max-width: 670px;
	width: 100%;
	margin: 0 auto;
	font-size: 15px;
}

.ft-logo img {
	vertical-align: middle;
}

.ft-info-box {
	padding: 25px 0;
	border-top: 1px solid #c4c4c4;
	border-bottom: 1px solid #c4c4c4;
	margin: 20px auto 25px;
}

.ft-info-details {
	margin-bottom: 15px;
}

.ft-info-details .ft-tel,
.ft-info-details .ft-banners,
.ft-info-details .ft-banners .ft-banner {
	display: inline-block;
	vertical-align: middle;
}

.ft-info-details .ft-tel {
	color: #2c2c2c;
	font-size: 36px;
	font-weight: bold;
	line-height: 1.3;
	padding-left: 20px;
}

.ft-info-details .ft-tel span {
	display: inline-block;
	background: url(../../uploads/tel-icon.png) no-repeat left center;
	padding: 0 0 0 45px;
}

.ft-info-details .ft-banners {
	padding: 0 10px;
	text-align: center;
}

.ft-info-details .ft-banners .ft-banner {
	padding: 0 6px;
}

.ft-info-details .ft-banners .ft-banner img {
	vertical-align: middle;
}

body .copyright-container {
	padding: 17px 3%;
	background: var(--main-color);
	color: #fff;
	font-size: 15px;
}

.copyright-container span img {
	vertical-align: middle;
}

body .copyright-container .copyright {
	margin-right: 15px;
}

body .module_row.fullwidth.contact-banner>.row_inner {
	max-width: 730px;
	width: 100%;
}

.contact-banner {
	background: url(../../uploads/contact-row-pattern.png), url(../../uploads/contact-row-bg.jpg);
	background-repeat: repeat, no-repeat;
	background-position: left top, center center;
	background-size: auto, cover;
	padding: 78px 3% !important;
}

.module_row.contact-banner>.row_inner {
	padding: 54px 58px !important;
	background: rgba(255, 255, 255, 0.14);
	border: 6px double #8ee6ff;
	border-radius: 8px;
	box-shadow: 0 12px 30px rgba(0, 79, 160, 0.2);
}

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

.module-text.subpage-main-name .tb_text_wrap p:last-of-type,
.module-text.text--size-40 .tb_text_wrap p:last-of-type,
.module-text.text--size-30 .tb_text_wrap p:last-of-type,
.module-text.text--size-20 .tb_text_wrap p:last-of-type,
.module-text.custom-anchor-list .tb_text_wrap p:last-of-type,
.module-text.contact-text .tb_text_wrap p:last-of-type {
	margin-bottom: 0;
}

.module.contact-text {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 30px;
}

.module.contact-text .tb_text_wrap {
	flex-grow: 1;
	padding-left: 20px;
	color: #fff;
}

.module.contact-text .module-title {
	margin-bottom: 0;
	margin-right: auto;
	background: #fff;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	color: var(--main-color);
	font-size: 15px;
	line-height: 1.8;
	padding: 13px 20px 10px;
	position: relative;
}

.module.contact-text .module-title::after {
	content: "";
	border: 10px solid transparent;
	border-left: 15px solid #fff;
	position: absolute;
	right: -20px;
	top: calc(50% - 10px);
}

.box-arrow-text {
	padding: 11px 5px 7px;
	background: #fff;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	position: relative;
}

.box-arrow-text::after {
	content: "";
	position: absolute;
	border: 10px solid transparent;
	border-top: 15px solid #fff;
	left: calc(50% - 10px);
	bottom: -22px;
}

.contact-tel-box {
	border-top: 1px solid #c4c4c4;
	border-bottom: 1px solid #c4c4c4;
	padding: 12px 10px;
	color: #fff;
	text-align: center;
}

.contact-tel-box .tb_text_wrap {
	display: inline-block;
	font-size: 36px;
	font-weight: bold;
	background: url(../../uploads/contact-tel-icon.png) no-repeat left center;
	line-height: 1.2;
}

.contact-tel-box a {
	color: inherit;
	text-decoration: none;
}

.white-button .tf_inline_b {
	display: block;
}

.module.module-buttons.white-button a.tb_default_color {
	display: block;
	text-align: center;
	max-width: 374px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	font-size: 18px;
	font-weight: bold;
	box-sizing: border-box;
}

.contact-banner .module.module-buttons.white-button a.tb_default_color {
	margin-right: 0;
}

.module.module-buttons.white-button a.tb_default_color,
.module.module-buttons.white-button a.tb_default_color:visited,
.module.module-buttons.white-button a.tb_default_color:active,
.module.module-buttons.white-button a.tb_default_color:focus,
.module.module-buttons.white-button a.tb_default_color:hover {
	color: var(--main-color);
}

.module.module-buttons.white-button a span {
	font-size: 18px;
	display: inline-block;
	margin: 0;
	padding: 11px 60px 11px 30px;
	background: url(../../uploads/blue-right-button.png) no-repeat right center;
}

body .module_row.fullwidth>.row_inner {
	max-width: 1200px;
	width: 100%;
}

.module_row.home-main {
	background: url(../../uploads/home-main-bg.jpg) no-repeat center center;
}

.module_row.home-main>.row_inner {
	padding: 50px 0;
}

.text--size-40 .tb_text_wrap {
	font-size: 40px;
	line-height: 1.2;
}

.text--size-30 .tb_text_wrap {
	font-size: 30px;
	line-height: 1.6;
}

.border-box {
	border: 3px solid #fa4949;
	border-radius: 20px;
	-moz-border-radius: 20px;
	-webkit-border-radius: 20px;
	-o-border-radius: 20px;
	position: relative;
	margin-bottom: 40px;
}

.border-box>.tb-column-inner {
	height: 100%;
	display: flex;
	flex-direction: column;
}

.border-box.border--color-red {
	border-color: #fa4949;
}

.border-box.border--color-orange {
	border-color: #ff9000;
}

.border-box.border--color-green {
	border-color: #39bc3f;
}

.border-box.border--color-blue {
	border-color: var(--main-color);
}

.border-box.border--color-pink {
	border-color: #bc36c4;
}

.module.box-text-content {
	padding: 25px 20px;
}

.module.box-text-title {
	padding: 18px 20px 3px;
	position: relative;
	border-bottom: 1px solid;
	box-sizing: border-box;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.5;
	border-radius: 20px 20px 0 0;
	-moz-border-radius: 20px 20px 0 0;
	-webkit-border-radius: 20px 20px 0 0;
	-o-border-radius: 20px 20px 0 0;
	margin-bottom: auto;
	flex-shrink: 1;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
}



.border-box.border--color-red .module.box-text-title {
	background: #ffe9e9;
	border-bottom-color: #fa4949;
}

.border-box.border--color-orange .module.box-text-title {
	background: #fff6e9;
	border-bottom-color: #ff9000;
}

.border-box.border--color-green .module.box-text-title {
	background: #f6ffe9;
	border-bottom-color: #39bc3f;
}

.border-box.border--color-blue .module.box-text-title {
	background: #e5f2ff;
	border-bottom-color: var(--main-color);
}

.border-box.border--color-pink .module.box-text-title {
	background: #fee9ff;
	border-bottom-color: #bc36c4;
}

.module.box-text-title ul {
	margin: 0;
	display: flex;
	justify-content: space-between;
}

.module.box-text-title .tb_text_wrap li {
	display: block;
	list-style: none;
	margin-bottom: 0;
}

.module.box-text-title .tb_text_wrap li:first-child {
	width: 80px;
	margin-right: auto;
	flex-shrink: 1;
}

.module.box-text-title .tb_text_wrap li:last-child {
	flex-grow: 1;
	padding-left: 20px;
}

.module.box-text-title .tb_text_wrap img {
	margin-bottom: 0;
	display: block;
	position: absolute;
	top: -15px;
	left: 20px;
}

.module_row.row--bg-sblue {
	background: #ecf1f5;
}

.module.home-bnr-img {
	border-radius: 10px 10px 0 0;
	-moz-border-radius: 10px 10px 0 0;
	-webkit-border-radius: 10px 10px 0 0;
	-o-border-radius: 10px 10px 0 0;
	overflow: hidden;
}

.module.home-bnr-button a {
	display: block;
	padding: 23px 70px 22px;
	background: #fff url(../../uploads/blue-right-button.png) no-repeat right 30px center;
	text-align: center;
	font-weight: bold;
	font-size: 25px;
	border-radius: 0 0 10px 10px;
	-moz-border-radius: 0 0 10px 10px;
	-webkit-border-radius: 0 0 10px 10px;
	-o-border-radius: 0 0 10px 10px;
}

.module.home-bnr-button a,
.module.home-bnr-button a:visited,
.module.home-bnr-button a:active,
.module.home-bnr-button a:focus,
.module.home-bnr-button a:hover {
	color: #2c2c2c;
}

.module.home-bnr-button a:hover {
	text-decoration: none;
}

.step-image {
	background: #ecf1f5;
	border-radius: 15px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	-o-border-radius: 15px;
	padding: 17px 160px 17px 17px;
	position: relative;
}

.module-image.image-right.step-image .image-wrap {
	margin: 0;
	position: absolute;
	right: 40px;
	bottom: 5px;
}

.step-image .image-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.step-image .image-title {
	margin-bottom: 0;
	position: relative;
	text-align: center;
	background: #fff;
	border-radius: 10px;
	padding: 18px 10px;
	min-width: 95px;
	box-sizing: border-box;
	color: var(--main-color);
	font-size: 35px;
	line-height: 1.1;
	flex-shrink: 1;
	margin-right: auto;
}

.step-image .image-title::before {
	content: "STEP";
	display: block;
	font-size: 16px;
	font-weight: bold;
	color: #2c2c2c;
}

.step-image .image-caption {
	flex-grow: 1;
	padding-left: 25px;
	font-size: 20px;
	font-weight: bold;
}

.col-count-3 .step-image {
	padding-right: 120px;
}

.col-count-3 .module-image.image-right.step-image .image-wrap {
	right: -5px;
}

.col-count-3 .module-image.image-right.step-image.step03 .image-wrap {
	right: 0px;
}

.module_row.home-row01>.row_inner {
	background: #ecf1f5;
	padding: 50px;
	border-radius: 15px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	-o-border-radius: 15px;
}

.module.white-text-box {
	text-align: center;
	background: #fff;
	font-weight: bold;
	padding: 11px 10px 9px;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
}

.module.payment-list ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.module.payment-list ul li {
	display: inline-block;
	margin-right: 10px;
}

.study-list .builder-posts-wrap .post-image img {
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
}

.study-list .post-image {
	margin-bottom: 20px;
}

.study-list .loops-wrapper.grid3 .post-title {
	margin-bottom: 0;
	font-size: 18px !important;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
}

.study-list .post-title a {
	text-decoration: underline;
}

.study-list .post-title a:hover {
	text-decoration: none;
}

.study-list .post-title a,
.study-list .post-title a:visited,
.study-list .post-title a:active,
.study-list .post-title a:focus,
.study-list .post-title a:hover {
	color: var(--main-color);
}

.study-list .loops-wrapper>.post {
	margin-bottom: 60px;
}

.blue-arrow-button .tf_inline_b {
	display: block;
}

.module.module-buttons.blue-arrow-button a.tb_default_color {
	background: var(--main-color);
	color: #fff;
	max-width: 374px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	display: block;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	font-size: 18px;
	font-weight: bold;
	padding: 0;
	line-height: 1.8;
	letter-spacing: 0.08em;
}

.module.module-buttons.blue-arrow-button a.tb_default_color span {
	display: block;
	padding: 18px 50px;
	margin: 0;
	background: url(../../uploads/white-arrow-right.png) no-repeat right 20px center;
}

.module-image.home-bnr-img .image-wrap img {
	border-radius: 10px 10px 0 0;
	-moz-border-radius: 10px 10px 0 0;
	-webkit-border-radius: 10px 10px 0 0;
	-o-border-radius: 10px 10px 0 0;
}

body #main-menu li.hide-menu {
	display: none;
}

.module_row.subpage-main-row {
	display: flex;
	align-items: center;
	min-height: 300px;
	padding: 48px 3%;
	background: linear-gradient(rgba(0, 79, 160, 0.46), rgba(0, 165, 226, 0.34)), image-set(url(assets/images/subpage-main-bg.avif) type("image/avif"), url(assets/images/subpage-main-bg.webp) type("image/webp"), url(assets/images/subpage-main-bg.jpg) type("image/jpeg")) no-repeat center center;
	background-size: cover;
	position: relative;
	box-sizing: border-box;
}

.module_row.subpage-main-row::before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: rgba(0, 79, 160, 0.14);
	pointer-events: none;
}

.module_row.subpage-main-row>.row_inner {
	position: relative;
	z-index: 1;
}

.module.subpage-main-name {
	text-align: center;
	color: #fff;
	font-weight: bold;
	font-size: 46px;
	line-height: 1.2;
	text-shadow: 0 3px 12px rgba(0, 45, 95, 0.55);
}

.module.subpage-main-name .tb_text_wrap {
	display: inline-block;
	padding: 16px 44px 15px;
	background: rgba(0, 79, 160, 0.58);
	backdrop-filter: blur(2px);
}

.radius-image .image-wrap img {
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
}

.business-content-images .image-wrap {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	overflow-x: auto;
	padding-bottom: 6px;
}

.business-content-images .image-wrap img {
	width: auto;
	height: 500px;
	max-width: none;
	border-radius: 6px;
	box-shadow: 0 6px 18px rgba(0, 79, 160, 0.12);
}

.module.blue-content-image .image-wrap img {
	border-radius: 10px 10px 0 0;
	-moz-border-radius: 10px 10px 0 0;
	-webkit-border-radius: 10px 10px 0 0;
	-o-border-radius: 10px 10px 0 0;
}

.module.blue-content-title {
	margin-bottom: 20px;
	text-align: center;
	background: var(--main-color);
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.8;
	border-radius: 0 0 10px 10px;
	-moz-border-radius: 0 0 10px 10px;
	-webkit-border-radius: 0 0 10px 10px;
	-o-border-radius: 0 0 10px 10px;
	padding: 9px 5px 5px;
}

.module.blue-content-text {
	margin-bottom: 40px;
}

.module.btm-line-title .module-title,
.module.btm-line-text .tb_text_wrap {
	margin-bottom: 30px;
	padding-bottom: 10px;
	color: var(--main-color);
	font-size: 20px;
	border-bottom: 1px solid var(--main-color);
	line-height: 1.8;
}

.module.policy-text {
	height: 230px;
	overflow-y: auto;
	padding-right: 30px;
}

.page-id-302 #body+.tb_layout_part_wrap {
	display: none
}

.page-id-302 #footerwrap {
	border-top: 2px solid #202c23;
}

.module.blue-circle-list ul {
	list-style: none;
	margin: 0;
	padding: 0;
	column-count: 2;
}

.module.blue-circle-list li {
	margin-bottom: 5px;
	padding: 0 0 0 20px;
	background: url(../../uploads/circle-dot-icon.png) no-repeat left top 7px;
	line-height: 1.8;
}

.module.gallery.info-gallery .gallery-caption {
	margin: 15px 0 0;
	line-height: 1.8;
	font-size: 15px;
	line-height: 1.6;
}

.text--size-20 {
	font-size: 20px;
}

.info-table tr th,
.info-table tr td {
	border-bottom: 1px dotted var(--main-color);
	vertical-align: top;
	padding: 18px 20px 16px;
}

.info-table tr th {
	font-weight: bold;
	color: var(--main-color);
	text-align: left;
}

.module.custom-anchor-list ul {
	list-style: none;
	margin: 0 auto;
	padding: 0;
}

.module.custom-anchor-list ul li {
	float: left;
	width: 17.5%;
	margin-right: 3.1%;
	margin-bottom: 32px;
}

.module.custom-anchor-list ul li:nth-child(5n) {
	clear: right;
	margin-right: 0;
}

.module.custom-anchor-list ul li a {
	display: block;
	position: relative;
	padding: 14px 18px;
	padding-right: 42px;
	text-align: center;
	background: var(--main-color);
	font-size: 15px;
	line-height: 1.8;
	font-weight: bold;
	white-space: nowrap;
	box-sizing: border-box;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
}

.module.custom-anchor-list ul li a::after {
	content: "\f078";
	position: absolute;
	top: 50%;
	right: 16px;
	transform: translateY(-50%);
	font-family: "Font Awesome 5 Free";
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
}

.module.custom-anchor-list ul li a,
.module.custom-anchor-list ul li a:visited,
.module.custom-anchor-list ul li a:active,
.module.custom-anchor-list ul li a:focus,
.module.custom-anchor-list ul li a:hover {
	color: #fff;
}

.module.custom-anchor-list ul li a:hover {
	text-decoration: none;
}

.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.themify_builder_content-383 .tb_has_section .module_subrow.subrow--width-900 {
	margin-top: 38px !important;
	margin-bottom: 48px !important;
}

.themify_builder_content-383 .tb_has_section .module.arrow-box-text {
	margin-top: 16px;
}

.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner>.sub_column {
	float: none;
	margin: 0;
	padding: 10px 10px 14px;
	background: #fff;
	border: 1px solid #d8edf8;
	border-radius: 8px;
	box-shadow: 0 8px 20px rgba(0, 79, 160, 0.08);
}

.themify_builder_content-383 .tb_has_section .subrow--width-900 .module-image {
	margin-bottom: 10px;
}

.themify_builder_content-383 .tb_has_section .subrow--width-900 .image-wrap {
	overflow: hidden;
	border-radius: 6px;
	aspect-ratio: 4 / 3;
}

.themify_builder_content-383 .tb_has_section .subrow--width-900 .image-wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.themify_builder_content-383 .tb_has_section .subrow--width-900 .module-text .tb_text_wrap {
	font-size: 14px;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
}

body .module.custom-anchor-list.service-anchor-list ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 22px 18px;
	max-width: 1040px;
	margin-left: auto;
	margin-right: auto;
}

body .module.custom-anchor-list.service-anchor-list ul li,
body .module.custom-anchor-list.service-anchor-list ul li:nth-child(2n),
body .module.custom-anchor-list.service-anchor-list ul li:nth-child(4n),
body .module.custom-anchor-list.service-anchor-list ul li:nth-child(5n) {
	float: none;
	clear: none;
	width: calc((100% - 36px) / 3);
	margin: 0;
}

body.page [id^="anc"] {
	scroll-margin-top: 90px;
}

@media screen and (max-width: 680px) {
	.module.subpage-main-name .tb_text_wrap {
		padding: 12px 24px 11px;
	}

	.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner {
		flex-direction: column;
		align-items: center;
		gap: 16px;
	}

	.themify_builder_content-383 .tb_has_section .module_subrow.subrow--width-900 {
		margin-top: 28px !important;
		margin-bottom: 36px !important;
	}

	.themify_builder_content-383 .tb_has_section .module.arrow-box-text {
		margin-top: 12px;
	}

	.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner>.sub_column {
		width: min(100%, 360px) !important;
	}

	body .module.custom-anchor-list.service-anchor-list ul {
		gap: 14px;
	}

	body .module.custom-anchor-list.service-anchor-list ul li,
	body .module.custom-anchor-list.service-anchor-list ul li:nth-child(2n),
	body .module.custom-anchor-list.service-anchor-list ul li:nth-child(4n),
	body .module.custom-anchor-list.service-anchor-list ul li:nth-child(5n) {
		width: min(100%, 360px);
	}
}

.module.price-table tr td {
	padding: 18px 20px;
	border-bottom: 1px dotted var(--main-color);
	line-height: 1.8;
}

.module.price-table tr td:last-child {
	text-align: right;
	color: var(--main-color);
}

.module.btm-line-title.title--btm-10 .module-title {
	margin-bottom: 10px;
}

.themify_builder_content-389 h3.module-title {
	margin-top: 30px;
}

.qa-content .ui.module-accordion.separate>li,
.qa-content .ui.module-accordion.separate>li:first-child {
	margin-bottom: 56px;
	border: 0;
}

.qa-content .tb_default_color.separate>li {
	background: none;
}

.qa-content .ui.module-accordion li:hover .accordion-title,
.qa-content .module-accordion.tb_default_color .accordion-title {
	background: none;
	font-size: 22px;
	line-height: 1.5;
}

.module.qa-content .ui.module-accordion .accordion-title a {
	display: flex;
	align-items: center;
	gap: 28px;
	position: relative;
	min-height: 96px;
	padding: 26px 82px 26px 32px;
	background: #ecf1f5;
	border-radius: 18px;
	color: var(--text-color);
	text-decoration: none;
	box-sizing: border-box;
}

.module.qa-content .ui.module-accordion .accordion-title a::before {
	content: "Q";
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 52px;
	width: 52px;
	height: 52px;
	background: #fff;
	border-radius: 10px;
	color: #004fa0;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 34px;
	font-weight: normal;
	line-height: 1;
	box-shadow: 0 3px 10px rgba(0, 79, 160, 0.08);
}

.module.qa-content .ui.module-accordion .accordion-title a::after {
	content: "+";
	position: absolute;
	right: 32px;
	top: 50%;
	transform: translateY(-50%);
	color: #004fa0;
	font-size: 32px;
	font-weight: bold;
	line-height: 1;
}

.module.qa-content .ui.module-accordion li.is-open>.accordion-title a::after {
	content: "-";
}

.module.qa-content .ui.module-accordion .accordion-title .tb_title_accordion {
	flex: 1;
	font-size: 24px;
	font-weight: bold;
	line-height: 1.55;
}

.qa-content .accordion-content {
	position: relative;
	padding: 28px 32px 4px 128px;
	line-height: 2;
	background: none;
	box-sizing: border-box;
}

.qa-content .accordion-content::before {
	content: "A";
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	left: 58px;
	top: 28px;
	width: 52px;
	height: 52px;
	background: #004fa0;
	border-radius: 10px;
	color: #fff;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 34px;
	font-weight: normal;
	line-height: 1;
}

.qa-content .accordion-content[aria-hidden="true"] {
	display: none;
}

.qa-content .accordion-content .tb_text_wrap p {
	font-size: 18px;
	line-height: 2;
}

.qa-content .accordion-content .tb_text_wrap p:last-of-type {
	margin-bottom: 0;
}

.module.custom-anchor-list.single-list ul li {
	width: 100%;
	margin-right: 0;
}

.subrow--width-900>.subrow_inner {
	max-width: 900px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.module.arrow-box-text .tb_text_wrap {
	display: block;
	max-width: 720px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding: 12px 10px;
	font-size: 20px;
	font-weight: bold;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-o-border-radius: 10px;
	-webkit-border-radius: 10px;
	position: relative;
	box-sizing: border-box;
}

.module.arrow-box-text .tb_text_wrap::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -24px;
	transform: translatex(-50%);
	border: 8px solid transparent;
}

.module.arrow-box-text.color-sblue .tb_text_wrap {
	background: #ecf1f5;
}

.module.arrow-box-text.color-white .tb_text_wrap {
	background: #fff;
}

.module.arrow-box-text.color-sblue .tb_text_wrap::after {
	border-top: 16px solid #ecf1f5;
}

.module.arrow-box-text.color-white .tb_text_wrap::after {
	border-top: 16px solid #fff;
}

.sblue-box-title .module-title {
	margin-bottom: 10px;
	color: var(--main-color);
	font-size: 15px;
	line-height: 1.8;
	background: #ecf1f5;
	border-radius: 15px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	-o-border-radius: 15px;
	padding: 6px 20px;
}

.module.arrow-box-text.color-sblue .tb_text_wrap {
	font-size: 16px;
}

body.single #layout {
	padding: 100px 0;
}

.post-ba-title .module-title {
	font-size: 20px;
	font-weight: bold;
	background: #ecf1f5;
	color: #2c2c2c;
	line-height: 1.8;
	padding: 17px 40px;
	border-radius: 15px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	-o-border-radius: 15px;
}

.module-gallery.post-gallery .gallery-item img {
	border-radius: 15px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	-o-border-radius: 15px;
}

.module-gallery-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 34px 32px;
	margin-top: 34px !important;
	margin-bottom: 46px !important;
}

.module-gallery-grid>* {
	width: 100% !important;
	max-width: 100%;
	margin: 0 !important;
}

.module-gallery-grid img {
	display: block;
	width: 100%;
	height: auto;
}

.voice-entry-content img {
	cursor: pointer;
}

.voice-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.86);
	padding: 60px 90px;
	box-sizing: border-box;
}

.voice-lightbox.is-active {
	display: flex;
}

.voice-lightbox-open {
	overflow: hidden;
}

.voice-lightbox__image {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
}

.voice-lightbox__close,
.voice-lightbox__prev,
.voice-lightbox__next {
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	padding: 0;
	background: rgba(255, 255, 255, 0.9);
	color: var(--main-color);
	cursor: pointer;
	line-height: 1;
	transition: 0.2s all linear;
}

.voice-lightbox__close:hover,
.voice-lightbox__prev:hover,
.voice-lightbox__next:hover {
	background: var(--main-color);
	color: #fff;
}

.voice-lightbox__close {
	top: 20px;
	right: 20px;
	width: 44px;
	height: 44px;
	padding: 0 0 4px;
	border-radius: 50%;
	font-size: 32px;
}

.voice-lightbox__prev,
.voice-lightbox__next {
	top: 50%;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	font-size: 0;
	transform: translateY(-50%);
}

.voice-lightbox__prev::before,
.voice-lightbox__next::before {
	content: "";
	display: block;
	width: 13px;
	height: 13px;
	border-top: 4px solid currentColor;
	border-left: 4px solid currentColor;
	box-sizing: border-box;
}

.voice-lightbox__prev::before {
	transform: rotate(-45deg);
	margin-left: 5px;
}

.voice-lightbox__next::before {
	transform: rotate(135deg);
	margin-right: 5px;
}

.voice-lightbox__prev {
	left: 20px;
}

.voice-lightbox__next {
	right: 20px;
}

.history-back-container a {
	background: var(--main-color) url(../../uploads/white-arrow-right.png) no-repeat right 20px center;
	color: #fff;
	max-width: 374px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	display: block;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	font-size: 18px;
	font-weight: bold;
	padding: 18px 50px;
	line-height: 1.8;
	letter-spacing: 0.08em;
	box-sizing: border-box;
}

.history-back-container a:hover {
	text-decoration: none;
}

body .pagenav {
	padding: 0 0 60px;
	text-align: center;
}

body .pagenav a,
body .pagenav span {
	border: 1px solid var(--main-color);
	background: none;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
	-o-border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	min-width: 42px;
	width: 42px;
	height: 42px;
	margin: 0 4px;
	padding: 0;
	box-sizing: border-box;
	transition: 0.2s all linear;
}

body .pagenav a,
body .pagenav a:visited,
body .pagenav a:active,
body .pagenav a:focus {
	color: var(--main-color);
}

body .pagenav a:hover,
body .pagenav span {
	background: var(--main-color);
	color: #fff;
	opacity: 1;
	text-decoration: none;
}


/* add shimajiri */
body #header.pagewidth {
	max-width: 100vw;
	position: fixed;
	z-index: 99;
	background-color: #fff;
	border-bottom: 1px solid #c4c4c4;
}

#body {
	padding-top: 81px;
}

.sp-footer-icons-container a svg {
	display: block;
	font-size: 16px;
	margin: 0 auto 8px;
}

#pagewrap #body .module .wpcf7-form th span {
	color: red;
	font-size: 12px;
}

#pagewrap #body .module .wpcf7 input[type=text],
#pagewrap #body .module .wpcf7 input[type=email],
#pagewrap #body .module .wpcf7 input[type="tel"] {
	width: 100%;
	max-width: 100%;
	border-radius: 0;
}

input.wpcf7-form-control.wpcf7-date,
select.wpcf7-form-control.wpcf7-select {
	display: inline;
	width: 40%;
	border-radius: 0;
	margin: 0 10px;
}

select.wpcf7-form-control.wpcf7-select {
	padding-top: 10px;
	padding-bottom: 10px;
}

.wpcf7 form table tr {
	border-bottom: 1px solid #ddd;
}

#body .module .wpcf7 input[type=submit] {
	margin-top: 40px;
	border-radius: 0;
	background-color: var(--main-color);
}

.wpcf7 table tr th,
.wpcf7 table tr td {
	padding: 15px;
}

textarea.wpcf7-form-control.wpcf7-textarea {
	border-radius: 0;
}

/* end shimajiri */

/*===================================================================
==============================     WIDTH 1024px     =================
===================================================================*/
@media screen and (max-width: 1024px) {

	/* Setting */
	body .sp-footer-icons-container a {
		background: var(--main-color);
		border-color: #fff;
		color: #fff;
		/* 		padding: 21px 0; */
	}

	body .sp-footer-icons-container a i {
		margin-bottom: 0;
	}

	#header.pagewidth,
	body .module_row.fullwidth>.row_inner,
	body .module_row.fullwidth.home-row02>.row_inner {
		max-width: 94%;
		margin-left: auto;
		margin-right: auto;
	}

	body .pagewidth {
		max-width: 100%;
	}

	.lb {
		padding-left: 0;
	}

	body #header.pagewidth {
		max-width: 94%;
	}

	.rb {
		padding-right: 35px;
	}

	.module.box-text-title {
		font-size: 16px;
		line-height: 2;
	}

	.module.payment-list ul li {
		margin-right: 5px;
	}

}

/* 1024px */
/*===================================================================
==============================     WIDTH 939px     =================
===================================================================*/
@media screen and (max-width: 939px) {

	/* Setting */
	hgroup {
		padding: 15px 0;
	}

	.lb,
	.rb {
		width: 100%;
		padding: 0;
		float: none;
		text-align: center;
	}

	body #site-logo {
		margin-bottom: 10px;
		top: 0;
	}

	body #site-logo a {
		display: inline-block;
	}

	body .sp-footer-icons-container {
		bottom: 0;
	}

	body .sp-footer-icons-container a {
		display: block;
		width: 33.33%;

		border-radius: 0;
		-moz-border-radius: 0;
		-webkit-border-radius: 0;
		-o-border-radius: 0;
		border-left: solid 1px #fff;
	}

	body .sp-footer-icons-container a:first-of-type {
		border-left: 0;
	}

	body .sp-footer-icons-container a i {
		color: #fff;
	}

	body #pagewrap {
		padding-bottom: 48px;
	}

	.head-button-contact a {
		padding: 10px 5px;
		font-size: 14px;
		border-radius: 5px;
	}

	body #header.header {
		flex-direction: column;
		padding: 10px 0;
		padding-bottom: 17px !important;
	}

	.lb,
	.rb {
		float: none;
		width: 100%;
	}

	body #site-logo {
		margin-bottom: 5px;
	}

	.text--size-30 .tb_text_wrap {
		font-size: 18px;
		line-height: 1.6;
	}

	body .module_row>.row_inner {
		max-width: 94%;
	}

	body .site {
		font-size: 13px;
	}

	.module.box-text-title ul {
		flex-direction: column;
	}

	.module.box-text-title .tb_text_wrap img {
		position: relative;
		top: -20px;
		left: 50%;
		transform: translateX(-50%);
	}

	.module.box-text-title .tb_text_wrap li:first-child {
		width: 100%;
		margin-bottom: -10px;
	}

	.module.box-text-title .tb_text_wrap li:last-child {
		padding-left: 0;
	}

	.module.box-text-title {
		padding: 10px 15px;
	}

	/* 	.module.box-text-title .tb_text_wrap img {
		left: 50%;
		transform: translateX(-50%);
	} */
	.module.box-text-title .tb_text_wrap li:first-child {
		width: 100%;
	}

	.module.box-text-title ul {
		flex-direction: column;
	}

	.module.box-text-title .tb_text_wrap li:last-child {
		flex-grow: 0;
		padding-left: 0;
	}

	.module.box-text-title {
		flex: 0;
		margin-bottom: initial;
	}

	.module.box-text-content {
		padding: 15px;
	}

	.text--size-40 .tb_text_wrap {
		font-size: 28px;
		line-height: 1.5;
	}

	.module.home-bnr-button a {
		font-size: 18px;
	}

	.study-list .loops-wrapper.grid3>.post:nth-of-type(2n+1) {
		clear: right;
	}

	.study-list .loops-wrapper.grid3>.post:nth-of-type(3n) {
		margin-left: 3.2%;
	}

	.study-list .loops-wrapper.grid3>.post {
		width: 31.2%;
	}

	.module.blue-content-title {
		font-size: 15px;
		margin-bottom: 10px;
	}

	.module.custom-anchor-list ul li:nth-child(4n) {
		margin-right: 0;
		clear: right;
	}

	.module.custom-anchor-list ul li:nth-child(5n) {
		clear: none;
		margin-right: 1.6%;
	}

	.module.custom-anchor-list ul li {
		width: 23.8%;
		margin-right: 1.6%;
		margin-bottom: 18px;
	}

	.module.custom-anchor-list ul li a {
		font-size: 13px;
	}
}

/* 939px */
/*===================================================================
==============================     WIDTH 680px     =================
===================================================================*/
@media screen and (max-width: 680px) {

	/* Setting */
	body .footer-nav li.menu-item-has-children {
		padding-left: 0;
	}

	body .footer-nav li.menu-item-has-children::before {
		display: none;
	}

	.module_row.home-main {
		background-size: cover;
	}

	.home-bnr-img .image-wrap {
		max-width: 374px;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}

	.module.home-bnr-button {
		max-width: 374px;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}

	.module-image.image-right.step-image .image-wrap {
		right: 0;
	}

	.step-image {
		padding-right: 30px;
	}

	.step-image .image-caption {
		font-size: 16px;
		padding-left: 15px;
		line-height: 1.5;
	}

	.step-image .image-title::before {
		font-size: 12px;
	}

	.step-image .image-title {
		font-size: 25px;
		min-width: 70px;
		padding: 10px 5px;
	}

	.module_row.home-row01>.row_inner {
		padding: 20px;
	}

	.module.payment-list ul li img {
		margin-bottom: 0;
	}

	.module.payment-list ul {
		margin-bottom: 20px;
	}

	.study-list .loops-wrapper.grid3 .post-title {
		font-size: 15px;
	}

	.study-list .post-image {
		margin-bottom: 10px;
		text-align: center;
	}

	body .module_row.fullwidth.contact-banner>.row_inner {
		max-width: 94%;
	}

	.module.contact-text {
		flex-direction: column;
	}

	.module.contact-text .module-title {
		margin-left: auto;
		margin-bottom: 15px;
		padding: 10px 25px 7px;
		font-size: 14px;
	}

	.module.contact-text .module-title::after {
		content: "";
		border: 7px solid transparent;
		border-top: 10px solid #fff;
		right: calc(50% - 7px);
		top: 100%;
	}

	.module.contact-text .tb_text_wrap {
		padding-left: 0;
	}

	.module.module-buttons.white-button a span {
		font-size: 16px;
		padding: 10px 50px 10px 20px;
	}

	.module.module-buttons.white-button a.tb_default_color {
		padding: 0;
	}

	.contact-banner .module.module-buttons.white-button a.tb_default_color {
		margin-right: auto;
		margin-left: auto;
	}

	.module.module-buttons.white-button a span {
		padding: 18px 50px;
		display: block;
		background-position: right 20px center;
	}

	.box-arrow-text {
		padding: 11px 15px 7px;
	}

	#footerwrap #footer {
		padding: 50px 3%;
	}

	.ft-info-details .ft-tel {
		padding-left: 0;
		margin-bottom: 5px;
	}

	.footer-content {
		font-size: 13px;
	}

	body .copyright-container .copyright {
		display: block;
		margin-right: 0;
		margin-bottom: 5px;
	}

	.study-list .loops-wrapper>.post {
		margin-bottom: 40px;
	}

	.module_row.subpage-main-row {
		min-height: 240px;
		padding: 40px 3%;
	}

	.module.blue-content-title {
		max-width: 271px;
		margin-left: auto;
		margin-right: auto;
		padding: 10px 5px 7px;
	}

	.module.policy-text {
		padding-right: 0;
	}

	.module.custom-anchor-list ul li {
		width: 49.2%;
		margin-bottom: 20px;
	}

	.module.custom-anchor-list ul li:nth-child(2n) {
		clear: right;
		margin-right: 0;
	}

	.module.btm-line-title .module-title,
	.module.arrow-box-text .tb_text_wrap {
		font-size: 16px;
	}

	.module.price-table tr td {
		padding: 15px 0px;
	}

	.text--size-20 {
		font-size: 16px;
	}

	.module.btm-line-title .module-title,
	.module.btm-line-text .tb_text_wrap {
		margin-bottom: 20px;
	}

	.post-ba-title .module-title {
		font-size: 16px;
		padding: 10px 15px;
	}

	.qa-content .ui.module-accordion li:hover .accordion-title,
	.qa-content .module-accordion.tb_default_color .accordion-title {
		font-size: 18px;
	}

	.module.qa-content .ui.module-accordion .accordion-title a {
		gap: 16px;
		min-height: 76px;
		padding: 18px 54px 18px 18px;
		border-radius: 14px;
	}

	.module.qa-content .ui.module-accordion .accordion-title a::before,
	.qa-content .accordion-content::before {
		width: 42px;
		height: 42px;
		font-size: 28px;
		border-radius: 8px;
	}

	.module.qa-content .ui.module-accordion .accordion-title a::before {
		flex-basis: 42px;
	}

	.module.qa-content .ui.module-accordion .accordion-title a::after {
		right: 20px;
		font-size: 28px;
	}

	.module.qa-content .ui.module-accordion .accordion-title .tb_title_accordion {
		font-size: 18px;
		line-height: 1.5;
	}

	.qa-content .accordion-content {
		padding: 20px 0 0 66px;
	}

	.qa-content .accordion-content::before {
		left: 8px;
		top: 20px;
	}

	.qa-content .accordion-content .tb_text_wrap p {
		font-size: 16px;
		line-height: 1.9;
	}

	.info-table tr th,
	.info-table tr td {
		padding: 10px 0;
	}

	.info-table tr th {
		width: 90px;
	}

	.module.gallery.info-gallery .gallery-caption {
		font-size: 12px;
	}

	/* 	add shimajiri */
	body #header.pagewidth {
		position: static;
	}

	.module.box-text-title .tb_text_wrap img {
		left: 10%;
		display: inline;
	}

	.module.box-text-title ul {
		flex-direction: unset;
	}

	#pagewrap #body .wpcf7 .wpcf7-form table th,
	#pagewrap #body .wpcf7 .wpcf7-form table td {
		display: block;
		line-height: 1.5;
	}

	.wpcf7 table tr th,
	.wpcf7 table tr td {
		padding: 10px 0px;
	}

	input.wpcf7-form-control.wpcf7-date,
	select.wpcf7-form-control.wpcf7-select {
		display: block;
		width: 100%;
		margin: 10px 0;
		height: 45px;
	}

	#pagewrap #body .module .wpcf7 input[type=text],
	#pagewrap #body .module .wpcf7 input[type=email],
	#pagewrap #body .module .wpcf7 input[type="tel"] {
		padding: 10px 5px;
	}

	.module.box-text-title .tb_text_wrap li:last-child {
		width: 100%;
		font-size: 20px;
		line-height: 1.5;
	}

	.module.box-text-title .tb_text_wrap li:first-child {
		width: 40%;
	}

	.module.box-text-title .tb_text_wrap img {
		left: 35%;
	}

	.sp-br br {
		display: none;
	}

	/* 	end shimajiri */
}

/* 680px */



/*******************************
Front Page Custom Fixes
*******************************/
#layout.pagewidth {
	max-width: none !important;
}

.module_row.home-main>.row_inner {
	max-width: 100% !important;
	width: 100% !important;
	padding: 0 !important;
}

@media screen and (min-width: 1201px) {
	.module_row:not(.home-main)>.row_inner {
		max-width: 1200px !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}
}

@media screen and (max-width: 939px) {
	#body {
		padding-top: 0 !important;
	}

	#headerwrap {
		margin-bottom: 0 !important;
	}

	#header {
		padding-bottom: 0 !important;
	}

	.module_row.home-main>.row_inner {
		padding: 0 !important;
		max-width: 100% !important;
		width: 100% !important;
	}

	.module_row.home-main {
		background-size: cover;
	}

	.sp-footer-icons-container a i {
		display: block;
		font-size: 18px;
		margin: 0 auto 5px;
	}
}

.head-button-contact a span {
	background: none !important;
	padding-left: 0 !important;
}

.head-button-contact a i {
	margin-right: 5px;
}

.contact-banner {
	background: #fff !important;
	color: #2c2c2c !important;
}

.contact-banner .text--color-white,
.contact-banner .tb_text_wrap,
.contact-banner .contact-text .tb_text_wrap,
.contact-banner .contact-tel-box {
	color: #2c2c2c !important;
}

.contact-banner .contact-tel-box {
	background: none !important;
	padding-left: 0 !important;
}

.contact-banner .contact-tel-box p::before {
	content: "\f095";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	margin-right: 10px;
}

.contact-banner .box-arrow-text {
	background: #ecf1f5 !important;
}

.contact-banner .box-arrow-text::after {
	border-top-color: #ecf1f5 !important;
}

/* Hamburger Menu Overrides */
#menu-button {
	background-color: var(--main-color) !important;
}

#menu-button .ham-lines span,
#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
	background-color: #fff !important;
}

#menu-button .ham-text {
	color: #fff !important;
}

/* Slide-in from right animation for mobile */
@media screen and (max-width: 1024px) {
	#main-menu-container,
	#main-menu-container:not(.is-active) {
		display: block !important;
		/* Override display: none */
		position: fixed !important;
		z-index: 700 !important;
		top: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		left: auto !important;
		width: 100% !important;
		background-color: #fff !important;
		transition: transform 0.4s cubic-bezier(0.77, 0, 0.175, 1), visibility 0.4s !important;
		transform: translateX(100%);
		visibility: hidden;
		pointer-events: none;
	}

	#main-menu-container.is-active {
		transform: translateX(0) !important;
		visibility: visible !important;
		pointer-events: auto !important;
	}

	/* Center main menu vertically on mobile */

	#main-menu-container.is-active,
	#main-menu-container {
		display: flex !important;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	#main-menu-container .main-menu {
		width: 100%;
	}

	#main-menu-container:not(.is-active) .main-menu {
		display: none !important;
		visibility: hidden !important;
		opacity: 0 !important;
	}

	#main-menu-container.is-active .main-menu {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
}

/* 修正: スマホでのボタンはみ出し防止 */
@media screen and (max-width: 767px) {
	.builder_button,
	.module-buttons a,
	.ui.builder_button {
		max-width: 100% !important;
		box-sizing: border-box !important;
		padding-left: 20px !important;
		padding-right: 20px !important;
		font-size: 14px !important;
		display: inline-flex !important;
		justify-content: center;
		align-items: center;
		text-align: center;
	}

	/* 修正: フッターロゴのはみ出し */
	.ft-logo img {
		max-width: 100% !important;
		height: auto !important;
	}
}

/* 修正: 明朝体をゴシック体に統一 */
body,
h1,
h2,
h3,
h4,
h5,
h6,
.text--font-HiraMin,
.title--font-HiraMin,
.subpage-main-name {
	font-family: var(--font-primary) !important;
}

/* スマホ版: 青色矢印ボタンのパディング調整 */
@media screen and (max-width: 767px) {
	.module.module-buttons.blue-arrow-button a.tb_default_color span {
		padding: 8px 50px !important;
	}

	/* スマホ版: 投稿ループ（グリッド）を幅100%（1列）に変更 */

	.builder-posts-wrap.loops-wrapper.grid3>.post,
	.builder-posts-wrap.loops-wrapper.grid3>article {
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		float: none !important;
	}

	/* スマホ版: サブロウ（2列カラム等）を縦並び（幅100%）に変更 */

	.subrow_inner.col-count-2>.sub_column,
	.subrow_inner.col-count-2>.module_column {
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		float: none !important;
	}
}

/* お問い合わせフォームへ ボタンのデザイン変更 */
.module-buttons.white-button a.builder_button,
.module-buttons.blue-arrow-button a.builder_button {
	background-color: var(--main-color) !important;
	border-radius: 9999px !important;
	color: #fff !important;
	font-weight: bold !important;
	padding: 15px 40px !important;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
	border: 2px solid #fff !important;
	/* 内側の白い枠線 */
	position: relative !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	text-decoration: none !important;
	transition: all 0.3s ease !important;
}

.module-buttons.white-button a.builder_button span::after,
.module-buttons.blue-arrow-button a.builder_button span::after {
	content: '\f054' !important;
	font-family: 'Font Awesome 5 Free' !important;
	font-weight: 900 !important;
	margin-left: 10px !important;
	font-size: 0.8em !important;
}

.module-buttons.white-button a.builder_button:hover,
.module-buttons.blue-arrow-button a.builder_button:hover {
	opacity: 0.8 !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15) !important;
}

/* Header lb padding adjustment */
.lb {
	padding-left: 20px !important;
}

/*******************************
PC Layout Adjustments (80% Vertical)
*******************************/
@media screen and (min-width: 1025px) {
	.section-pc-vertical>.row_inner {
		width: 80% !important;
		margin-left: auto !important;
		margin-right: auto !important;
		float: none !important;
		display: block !important;
	}

	.section-pc-vertical .module_subrow,
	.section-pc-vertical .subrow_inner {
		display: block !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.section-pc-vertical .sub_column {
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		margin-bottom: 50px !important;
		float: none !important;
		box-sizing: border-box !important;
		display: block !important;
	}
}

/*******************************
Icon Styling (5 Boxes)
*******************************/
.module.box-text-title .tb_text_wrap i {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 70px;
	height: 70px;
	background: #fff;
	border-radius: 50%;
	font-size: 32px;
	position: absolute;
	top: -35px;
	left: 20px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
	z-index: 10;
}

.border-box.border--color-red .module.box-text-title i {
	color: #fa4949;
	border: 2px solid #fa4949;
}

.border-box.border--color-orange .module.box-text-title i {
	color: #ff9000;
	border: 2px solid #ff9000;
}

.border-box.border--color-green .module.box-text-title i {
	color: #39bc3f;
	border: 2px solid #39bc3f;
}

.border-box.border--color-blue .module.box-text-title i {
	color: var(--main-color);
	border: 2px solid var(--main-color);
}

.border-box.border--color-pink .module.box-text-title i {
	color: #bc36c4;
	border: 2px solid #bc36c4;
}

/* Adjust list for icon positioning */
.module.box-text-title .tb_text_wrap li:first-child {
	min-height: 40px;
}

/*******************************
Flow Step Icon Styling
*******************************/
.step-image .image-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
}

.step-image .image-wrap i {
	font-size: 50px;
	color: var(--main-color);
	margin: 10px 0;
}

@media screen and (min-width: 1025px) {
	.step-image .image-wrap i {
		position: absolute;
		right: 40px;
		top: 50%;
		transform: translateY(-50%);
		font-size: 70px;
		opacity: 0.8;
	}

	/* 強みセクションのタイトル内改行調整（PCでは非表示、スマホで表示） */
	#home-strengths .box-text-title br {
		display: none;
	}

	/*******************************
	PC Width Adjustment (80%)
	*******************************/
	.pc-80-width>.row_inner {
		width: 80% !important;
		margin-left: auto !important;
		margin-right: auto !important;
		float: none !important;
	}

	#content>.type-page:not(#page-381)>.page-content>.themify_builder_content:not(.themify_builder_content-411)>.module_row:not(.subpage-main-row)>.row_inner {
		width: 80% !important;
		max-width: 1200px !important;
		margin-left: auto !important;
		margin-right: auto !important;
		float: none !important;
	}

	.themify_builder_content-393 .tb_1lej373>.row_inner {
		padding-top: 58px;
		padding-bottom: 62px;
	}

	.themify_builder_content-393 .tb_g2g0818 {
		margin-top: 22px;
		margin-bottom: 24px;
		line-height: 2;
	}

	.themify_builder_content-393 .tb_qjxq629 {
		margin-top: 18px;
	}

	.themify_builder_content-393 .tb_e38u71>.row_inner {
		padding-top: 58px;
		padding-bottom: 88px;
	}

	.themify_builder_content-393 .tb_e38u71 .tb_l0l9284 {
		margin-top: 38px !important;
		margin-bottom: 60px !important;
	}

	.themify_builder_content-393 .tb_e38u71 .tb_ww5b51 {
		margin-top: 0 !important;
	}

	.themify_builder_content-393 .info-table tr th,
	.themify_builder_content-393 .info-table tr td {
		padding-top: 22px;
		padding-bottom: 20px;
	}

	.themify_builder_content-393 .tb_zt6y53 {
		margin-bottom: 18px;
	}

	.themify_builder_content-393 .blue-circle-list li {
		margin-bottom: 10px;
		line-height: 1.95;
	}
}

@media screen and (max-width: 1024px) {
	#content>.type-page:not(#page-381)>.page-content>.themify_builder_content:not(.themify_builder_content-411)>.module_row:not(.subpage-main-row)>.row_inner {
		width: calc(100% - 32px) !important;
		margin-left: auto !important;
		margin-right: auto !important;
		float: none !important;
	}

	/*******************************
	Introduction Section Mobile Fix
	*******************************/
	#home-intro .subrow_inner>.sub_column.first {
		margin-bottom: 60px !important;
	}
}

/*******************************
Service List PC Fix (Ensure Row Alignment)
*******************************/
@media screen and (min-width: 1025px) {
	#home-services .subrow_inner {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
	}

	/*******************************
	Flow Section PC Fix
	*******************************/
	#home-flow .subrow_inner {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
	}

	#home-flow .step-image .image-wrap i {
		/* Reset positioning for multi-column layout */
		position: relative !important;
		right: auto !important;
		top: auto !important;
		transform: none !important;
		margin-bottom: 20px !important;
		opacity: 1 !important;
	}
}

/*******************************
Button Refinements
*******************************/
/* 「一覧を見る」ボタンの調整 */
.module-buttons.blue-arrow-button {
	text-align: center !important;
	display: block !important;
	width: 100% !important;
}

.module-buttons.blue-arrow-button a.builder_button {
	padding: 10px 30px !important;
	/* スリム化 */
	white-space: nowrap !important;
	/* 改行防止 */
}

/* 「お問い合わせフォームへ」ボタンの調整 */
.module-buttons.white-button a.builder_button {
	padding: 10px 30px !important;
	/* スリム化 */
	white-space: nowrap !important;
	/* 改行防止 */
}

/* ボタン内のテキストとアイコンが1行に収まるように調整 */
.module-buttons a.builder_button span {
	white-space: nowrap !important;
	display: inline-block !important;
}



/*******************************
Utility Classes
*******************************/
/* PC版で非表示にするクラス */
@media screen and (min-width: 1025px) {
	.pc-none {
		display: none !important;
	}
}

/* スマホ版で非表示にするクラス（必要に応じて） */
@media screen and (max-width: 1024px) {
	.sp-none {
		display: none !important;
	}

	/*******************************
	Mobile Font Size Adjustment
	*******************************/
	/* スマホ版での最小文字サイズを15pxに制限 */

	p,
	li,
	.module-text,
	.tb_text_wrap,
	.image-caption,
	.image-content {
		font-size: 15px !important;
		line-height: 1.6 !important;
	}

	/* ボタン文字なども小さすぎないように調整 */
	.builder_button,
	.module-buttons a {
		font-size: 15px !important;
	}

	/*******************************
	Intro Section Key Message Fix
	*******************************/
	/* 紹介セクションの青文字キャッチコピーをスマホ版で大きく表示 */

	#home-intro .text--size-30 p,
	#home-intro .text--size-30 span {
		font-size: 23px !important;
		line-height: 1.5 !important;
		display: inline-block !important;
		/* 改行の制御を安定させるため */
		width: 100% !important;
	}

	/*******************************
	Mobile Heading Size Adjustment
	*******************************/
	/* スマホ版での各セクション見出しを大きく表示 */

	.text--size-40,
	.text--size-40 p,
	.module-title,
	h2 {
		font-size: 28px !important;
		margin-bottom: 30px !important;
		line-height: 1.3 !important;
	}

	/* 紹介セクションなどの特定の見出し */
	#home-area .text--size-30 p,
	#home-intro .module-title {
		font-size: 24px !important;
	}

	/*******************************
	Footer Mobile Font Size Adjustment
	*******************************/
	/* フッターの文字サイズをスマホ版で15px以上に制限 */

	#footer,
	#footer p,
	#footer li,
	#footer a,
	.footer-text,
	.footer-widgets {
		font-size: 15px !important;
		line-height: 1.6 !important;
	}

	#footer .footer-logo-text {
		font-size: 18px !important;
		/* ロゴ周りは少し大きめに */
	}

	/*******************************
	Footer Aggressive Font Size Fix
	*******************************/
	/* フッター内の全テキストを15px以上に強制 */

	.footer-content,
	.ft-text,
	.ft-address,
	.copyright,
	.ft-info-details,
	.sp-footer-icons-container a {
		font-size: 15px !important;
	}

	/* 電話番号などは少し目立たせる */
	.ft-tel span {
		font-size: 20px !important;
	}

	/*******************************
	Flow Section Step Titles Fix
	******************************* /
	/* スマホ版でのステップ番号と見出しサイズを18pxに調整 */

	#home-flow .step-image .image-title,
	#home-flow .step-image .image-caption {
		font-size: 18px !important;
	}
}

/*******************************
Footer and Contact Alignment Fixes
*******************************/
/* フッター上部の余白を詰める */
@media screen and (min-width: 1025px) {
	#footerwrap #footer {
		padding-top: 25px !important;
	}

	/* セクション間の余白も全体的に少し詰める */
	.module_row {
		padding-bottom: 60px !important;
	}

	/* お問い合わせバナーの電話番号とボタンの横並び・中央揃え（PC版） */
	.contact-banner .module_subrow.tb_rkx795 .subrow_inner {
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
		gap: 40px !important;
	}

	.contact-banner .module_subrow.tb_rkx795 .sub_column {
		width: auto !important;
		float: none !important;
		margin: 0 !important;
	}

	.contact-banner .contact-tel-box p {
		font-size: 32px !important;
		font-weight: bold !important;
		margin-bottom: 0 !important;
	}

	/*******************************
	Contact Banner Spacing Adjustment
	*******************************/
	/* お問い合わせバナー下部の余白をさらに詰める（PC版） */
	.contact-banner.tb_d9xu553 {
		padding: 78px 3% !important;
	}

/*******************************
Header Adjustments
*******************************/
/* PC版でハンバーガーメニューを非表示にする */
    #menu-button {
        display: none !important;
    }

	/* Header responsive balance */
	.rb {
		display: flex;
		align-items: stretch;
		justify-content: flex-end;
		gap: 8px;
	}

	#main-menu-container {
		display: flex;
		align-items: center;
	}

	body #main-menu {
		display: flex;
		align-items: center;
		flex-wrap: nowrap;
	}

	body #main-menu li {
		float: none;
		padding-left: 9px;
		padding-right: 9px;
		white-space: nowrap;
	}

	.head-button-contact {
		flex: 0 0 190px;
		width: 190px;
	}

	.head-button-contact a {
		height: 100%;
		box-sizing: border-box;
		display: flex;
		align-items: center;
		justify-content: center;
	}
}

@media screen and (min-width: 1025px) and (max-width: 1320px) {
	body #main-menu li {
		font-size: 14px;
		padding-left: 7px;
		padding-right: 7px;
	}

	.head-button-contact {
		flex-basis: 180px;
		width: 180px;
	}

	.head-button-contact a {
		font-size: 16px;
	}
}

/*******************************
Blog Page
*******************************/
.blog-main-row {
	background-image: linear-gradient(rgba(0, 79, 160, 0.55), rgba(0, 79, 160, 0.45)), image-set(url(assets/images/home-image01-v2.avif) type("image/avif"), url(assets/images/home-image01-v2.webp) type("image/webp"), url(assets/images/home-image01-v2.jpg) type("image/jpeg")) !important;
	background-position: center center !important;
	background-size: cover !important;
}

.blog-lead-row {
	padding-bottom: 35px !important;
}

.blog-lead {
	max-width: 920px;
	margin: 0 auto;
	padding: 34px 40px;
	border-left: 6px solid var(--main-color);
	background: #f2f9ff;
	box-sizing: border-box;
}

.blog-lead-label {
	margin: 0 0 6px;
	color: var(--main-color);
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 0.08em;
}

.blog-lead h1 {
	margin: 0 0 12px;
	color: #004fa0;
	font-size: 30px;
	line-height: 1.45;
}

.blog-lead p:last-child {
	margin-bottom: 0;
}

.blog-list-row {
	padding-top: 20px !important;
}

.blog-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 34px 28px;
}

.blog-card {
	overflow: hidden;
	border: 1px solid #d9e8f5;
	border-radius: 8px;
	background: #fff;
	box-shadow: 0 8px 22px rgba(0, 79, 160, 0.08);
}

.blog-card-image {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: #ecf1f5;
}

.blog-card-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
}

.blog-card:hover .blog-card-image img {
	transform: scale(1.04);
}

.blog-card-body {
	padding: 22px 22px 24px;
}

.blog-card-date {
	display: inline-block;
	margin-bottom: 8px;
	color: var(--main-color);
	font-size: 13px;
	font-weight: bold;
	line-height: 1.4;
}

.blog-card-title {
	margin: 0 0 12px;
	font-size: 20px !important;
	line-height: 1.5 !important;
}

.blog-card-title a {
	color: #2c2c2c;
	text-decoration: none;
}

.blog-card-title a:hover {
	color: var(--main-color);
	opacity: 1;
}

.blog-card-excerpt {
	color: #4a4a4a;
	font-size: 15px;
	line-height: 1.8;
}

.blog-card-excerpt p {
	margin-bottom: 0;
}

.blog-card-more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 18px;
	padding: 8px 18px;
	border: 1px solid var(--main-color);
	border-radius: 9999px;
	color: var(--main-color);
	font-size: 14px;
	font-weight: bold;
	line-height: 1.5;
	text-decoration: none;
}

.blog-card-more::after {
	content: "\f054";
	margin-left: 8px;
	font-family: "Font Awesome 5 Free";
	font-size: 11px;
	font-weight: 900;
}

.blog-card-more:hover {
	background: var(--main-color);
	color: #fff;
	opacity: 1;
}

.blog-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	margin-top: 48px;
}

.blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	min-height: 40px;
	padding: 0 12px;
	border: 1px solid var(--main-color);
	border-radius: 8px;
	color: var(--main-color);
	font-weight: bold;
	line-height: 1;
	text-decoration: none;
	box-sizing: border-box;
}

.blog-pagination .page-numbers.current,
.blog-pagination a.page-numbers:hover {
	background: var(--main-color);
	color: #fff;
	opacity: 1;
}

.blog-empty {
	max-width: 720px;
	margin: 0 auto;
	padding: 34px 24px;
	border: 1px solid #d9e8f5;
	border-radius: 8px;
	background: #f2f9ff;
	text-align: center;
}

.blog-empty p {
	margin: 0;
	font-weight: bold;
}

@media screen and (max-width: 1024px) {
	.blog-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.blog-lead {
		padding: 28px 24px;
	}
}

@media screen and (max-width: 680px) {
	.blog-lead-row {
		padding-bottom: 25px !important;
	}

	.blog-lead {
		padding: 24px 18px;
		border-left-width: 4px;
	}

	.blog-lead h1 {
		font-size: 24px !important;
	}

	.blog-card-grid {
		grid-template-columns: 1fr;
		gap: 26px;
	}

	.blog-card-body {
		padding: 20px 18px 22px;
	}

	.blog-card-title {
		font-size: 18px !important;
		margin-bottom: 10px !important;
	}

	.blog-card-more {
		width: 100%;
		box-sizing: border-box;
	}
}

/*******************************
Mobile Service Page Polish
*******************************/
body {
	font-size: 17px;
}

#body .module-text:not(.subpage-main-name):not(.custom-anchor-list):not(.text--size-40):not(.text--size-30) .tb_text_wrap,
#body .module-text:not(.subpage-main-name):not(.custom-anchor-list):not(.text--size-40):not(.text--size-30) .tb_text_wrap p {
	font-size: 17px;
}

@media screen and (max-width: 767px) {
	body {
		font-size: 16px;
	}

	.module.subpage-main-name p {
		font-size: 23px !important;
	}

	.module.subpage-main-name .tb_text_wrap {
		padding: 14px 28px 13px;
	}

	.module.custom-anchor-list ul li a {
		min-height: 48px;
		font-size: 16px !important;
		line-height: 1.35;
	}

	#body .module-text:not(.subpage-main-name):not(.custom-anchor-list):not(.text--size-40):not(.text--size-30) .tb_text_wrap,
	#body .module-text:not(.subpage-main-name):not(.custom-anchor-list):not(.text--size-40):not(.text--size-30) .tb_text_wrap p {
		font-size: 16px !important;
		line-height: 1.9 !important;
	}

	.themify_builder_content-393 .tb_zt6y53 {
		margin-top: 34px !important;
		margin-bottom: 24px !important;
		text-align: center;
	}

	.themify_builder_content-393 .tb_zt6y53 .tb_text_wrap,
	.themify_builder_content-393 .tb_zt6y53 p,
	.themify_builder_content-393 .tb_zt6y53 span {
		font-size: 25px !important;
		line-height: 1.35 !important;
		text-align: center !important;
	}

	.themify_builder_content-383 .tb_has_section>.row_inner>.module_column>.tb-column-inner>.module-text.text--size-40 {
		width: 100vw !important;
		margin-left: calc(50% - 50vw) !important;
		margin-right: calc(50% - 50vw) !important;
		margin-bottom: 22px !important;
		padding: 16px 18px 15px !important;
		background: var(--main-color);
		color: #fff;
		box-sizing: border-box;
		text-align: center;
	}

	.themify_builder_content-383 .tb_has_section>.row_inner>.module_column>.tb-column-inner>.module-text.text--size-40 .tb_text_wrap,
	.themify_builder_content-383 .tb_has_section>.row_inner>.module_column>.tb-column-inner>.module-text.text--size-40 p {
		margin: 0 !important;
		color: #fff;
		font-size: 25px !important;
		line-height: 1.35 !important;
	}

	.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
		justify-content: flex-start !important;
		align-items: stretch !important;
		gap: 14px !important;
		overflow-x: auto;
		overflow-y: hidden;
		width: 100vw !important;
		max-width: none !important;
		margin-left: calc(50% - 50vw) !important;
		margin-right: calc(50% - 50vw) !important;
		padding: 0 16px 10px !important;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		box-sizing: border-box;
	}

	.themify_builder_content-383 .tb_has_section .subrow--width-900>.subrow_inner>.sub_column {
		flex: 0 0 74%;
		width: 74% !important;
		max-width: 270px;
		scroll-snap-align: start;
	}

	.themify_builder_content-383 .tb_has_section .subrow--width-900 .module-text .tb_text_wrap {
		font-size: 14px !important;
		line-height: 1.5 !important;
	}

	.module_row.contact-banner>.row_inner {
		padding: 50px 15px !important;
	}

	.sblue-box-title .module-title.room-head {
		font-size: 15px !important;
		margin-top: 30px;
		margin-bottom: 10px !important;
	}

	.lb {
		padding-left: 0 !important;
	}

	.voice-lightbox {
		padding: 55px 52px;
	}

	.voice-lightbox__close {
		top: 12px;
		right: 12px;
		width: 40px;
		height: 40px;
		padding: 0 0 4px;
		font-size: 28px;
	}

		.voice-lightbox__prev,
		.voice-lightbox__next {
			width: 40px;
			height: 40px;
		}

		.voice-lightbox__prev::before,
		.voice-lightbox__next::before {
			width: 10px;
			height: 10px;
			border-width: 3px 0 0 3px;
		}

		.voice-lightbox__prev {
			left: 8px;
		}

		.voice-lightbox__next {
			right: 8px;
		}

		.module-gallery-grid {
			grid-template-columns: 1fr;
			gap: 24px;
			margin-top: 28px !important;
			margin-bottom: 36px !important;
		}
	}

@media screen and (min-width: 768px) {
	.single-voice #content,
	.blog #content,
	.single-post #content {
		width: 100%;
	}
}

.builder-posts-wrap .post-image img {
	height: 260px;
	object-fit: cover;
}

ul.module-accordion {
	background: #fff;
}
