* {
	box-sizing: border-box;
	word-break: break-all;
}

html {
	overflow-x: hidden;
	font-size: 62.5%;
}

body {
	overflow-x: hidden;
	background-color: #fff;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.8rem;
	font-weight: 500;
	color: #333;
	letter-spacing: 1px;
	line-height: 2;
}

body.home.bg-light {
	padding-top: 0 !important;
	background-color: #fff;
}

@media screen and (max-width: 768px) {
	
	body {
		font-size: 1.6rem;
	}
	
}


p {
	margin-bottom: 2rem;
}

ul,
ol {
	margin-bottom: 2rem;
}


.zen {
	font-family: "Zen Maru Gothic", sans-serif;
	font-style: normal;
	font-weight: 700;
}


.inner {
	width: 100%;
	max-width: 1380px;
	margin: 0 auto;
	padding: 0 4rem;
}

.inner--small {
	max-width: 1080px;
}

@media screen and (max-width: 768px) {
	
	.inner {
		padding: 0 2rem;
	}
	
}


.section {
	padding-top: 8rem;
	padding-bottom: 8rem;
}

@media screen and (max-width: 768px) {
	
	.section {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}
	
}


.radius { border-radius: 8rem;}

@media screen and (max-width: 768px) {
	
	.radius { border-radius: 4rem;}

}


/* --------------------------------------------------

	images

-------------------------------------------------- */

img {
	max-width: 100%;
	height: auto;
	transition: .2s;
}


/* --------------------------------------------------

	space

-------------------------------------------------- */

.d-block { display: block;}
.d-none { display: none;}
.d-flex { display: flex;}

@media screen and (max-width: 1024px) {
	
	.d-md-block { display: block;}
	.d-md-none { display: none;}
	.d-md-flex { display: flex;}
	
}

@media screen and (max-width: 768px) {
	
	.d-xs-block { display: block;}
	.d-xs-none { display: none;}
	.d-xs-flex { display: flex;}
	
}


/* --------------------------------------------------

	space

-------------------------------------------------- */

.mt-0 { margin-top: 0 !important;}
.mt-1 { margin-top: 1rem !important;}
.mt-2 { margin-top: 2rem !important;}
.mt-4 { margin-top: 4rem !important;}
.mt-8 { margin-top: 8rem !important;}
.mt-10 { margin-top: 10rem !important;}

.mb-0 { margin-bottom: 0 !important;}
.mb-1 { margin-bottom: 1rem !important;}
.mb-2 { margin-bottom: 2rem !important;}
.mb-4 { margin-bottom: 4rem !important;}
.mb-8 { margin-bottom: 8rem !important;}
.mb-10 { margin-bottom: 10rem !important;}


.pt-0 { padding-top: 0 !important;}
.pt-2 { padding-top: 2rem !important;}
.pt-4 { padding-top: 4rem !important;}
.pt-8 { padding-top: 8rem !important;}
.pt-10 { padding-top: 10rem !important;}

.pb-0 { padding-bottom: 0 !important;}
.pb-2 { padding-bottom: 2rem !important;}
.pb-4 { padding-bottom: 4rem !important;}
.pb-8 { padding-bottom: 8rem !important;}
.pb-10 { padding-bottom: 10rem !important;}


/* --------------------------------------------------

	Grid system

-------------------------------------------------- */

.row {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -2rem -8rem;
}

[class^="col"] {
	margin-bottom: 8rem;
	padding: 0 2rem;
}

@media screen and (max-width: 768px) {
	
	.row {
		margin-bottom: -4rem;
	}

	[class^="col"] {
		margin-bottom: 4rem;
	}
	
}


.col-1 { width: 8.3333333%;}
.col-2 { width: 16.6666667%;}
.col-3 { width: 25%;}
.col-4 { width: 33.33333333%;}
.col-5 { width: 41.6666667%;}
.col-6 { width: 50%;}
.col-7 { width: 58.33333333%;}
.col-8 { width: 66.66666667%;}
.col-9 { width: 75%;}
.col-10 { width: 83.33333333%;}
.col-11 { width: 91.6666667%;}
.col-12 { width: 100%;}

@media screen and (max-width: 768px) {

	.col-xs-1 { width: 8.3333333%;}
	.col-xs-2 { width: 16.6666667%;}
	.col-xs-3 { width: 20%;}
	.col-xs-4 { width: 25%;}
	.col-xs-5 { width: 41.6666667%;}
	.col-xs-6 { width: 50%;}
	.col-xs-7 { width: 58.33333333%;}
	.col-xs-8 { width: 66.66666667%;}
	.col-xs-9 { width: 75%;}
	.col-xs-10 { width: 83.33333333%;}
	.col-xs-11 { width: 91.6666667%;}
	.col-xs-12 { width: 100%;}

}


.flex-row-reverse { flex-direction: row-reverse;}

@media screen and (max-width: 768px) {
	
	.flex-xs-row { flex-direction: row;}
	
}


.align-items-center { align-items: center;}
.align-items-end { align-items: flex-end;}

.justify-content-between { justify-content: space-between;}
.justify-content-center { justify-content: center;;}


/* --------------------------------------------------

	badge

-------------------------------------------------- */

.badge {
	display: inline-block;
	padding: 1rem 2rem;
	background-color: #fff;
	border: 2px solid #EF6F26;
	border-radius: 999px;
	color: #EF6F26;
	font-size: 1.4rem;
	line-height: 1;
	text-align: center;
	vertical-align: baseline;
}

.badge--block {
	display: block;
	max-width: 100%;
}

a.badge {
	background-color: #EF6F26;
	color: #fff;
}

a.badge:hover {
	background-color: #fff;
	color: #EF6F26;
}


/* --------------------------------------------------

	text

-------------------------------------------------- */

.text-left { text-align: left;}
.text-center { text-align: center;}
.text-right { text-align: right;}


/* --------------------------------------------------

	color

-------------------------------------------------- */

a { color: #EF6F26; word-break: break-all; transition: .2s;}
a:hover { color: #f1931B;}

.text-primary { color: #EF6F26;}
.text-secondary { color: #804545;}
.text-dark { color: #412626;}
.text-light { color: #F3F2F0;}
.text-white { color: #fff;}

.bg-primary { background-color: #EF6F26; color: #fff;}
.bg-secondary { background-color: #804545; color: #fff;}
.bg-dark { background-color: #412626; color: #fff;}
.bg-light { background-color: #F3F2F0;}
.bg-white { background-color: #fff;}

.icon-primary { fill: #EF6F26;}
.icon-white { fill: #fff;}


/* --------------------------------------------------

	Heading

-------------------------------------------------- */

.h2 {
	margin: 0 0 4.8rem;
	font-size: 4.8rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 700;
	line-height: 1.52;
}

@media screen and (max-width: 768px) {
	
	.h2 {
		margin: 0 0 3.2rem;
		font-size: 2.8rem;
	}
	
}


.h3 {
	margin: 0 0 2rem;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.52;
}

.privacy-box .h3 {
	margin-top: 4rem;
}

.h4 {
	margin: 2rem 0 1.6rem;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.52;
} 


.key {
	padding-top: 8rem;
	padding-bottom: 4rem;
	background: url("../images/common/footer.svg") no-repeat right bottom;
	background-size: 960px auto;
}

.key__title-en {
	margin: 0 0 1rem;
	font-size: 10rem;
	font-weight: 700;
	line-height: 1.4;
	text-transform: capitalize;
}

.key__title {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.4;
}

@media screen and (max-width: 1080px) {
	
	.key {
		background-size: 590px auto;
	}
	
}

@media screen and (max-width: 768px) {

	.key {
		padding-top: 4rem;
		padding-bottom: 12rem;
	}
	
	.key__title-en {
		margin-bottom: 0;
		font-size: 4rem;
	}

	.key__title {
		font-size: 1.6rem;
	}
	
}


/* --------------------------------------------------

	link

-------------------------------------------------- */

.icon-blank {
	position: relative;
	display: inline-block;
	padding-right: 2.4rem;
}

.icon-blank::after {
	content: '';
	position: absolute;
	bottom: 4px;
	right: 0;
	display: block;
	width: 2rem;
	height: 2rem;
	background: url("../images/common/icon-blank.svg") no-repeat center center;
	background-size: contain;
	line-height: 1;
}


/* --------------------------------------------------

	Buttons

-------------------------------------------------- */

.btn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-width: 32rem;
	max-width: 42rem;
	padding: 2.4rem 2rem;
	border-radius: 2rem;
	background-color: #EF6F26;
	color: #fff;
	text-align: left;
	vertical-align: middle;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.4;
	cursor: pointer;
	user-select: none;
	box-shadow: 0.6rem 0.6rem 0 #AD9080;
	transition: 0.3s ease-in-out;
}

.btn:hover {
	box-shadow: 0 0 0 #AD9080;
	transform: translate(0.6rem, 0.6rem);
	color: #fff;
}

.btn__text {
	display: flex;
	align-items: center;
	column-gap: 1rem;
	width: calc(100% - 4rem);
}

.btn__icon {
	fill: #fff;
}


.btn__arrow {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 4rem !important;
	height: 4rem;
	background-color: #fff;
	border-radius: 2rem;
}

.btn__arrow svg {
	width: 16px;
	height: 14px;
}

.btn__arrow-right {
	fill: #EF6F26;
}

.btn--small {
	padding: 2rem;
}


.btn--white {
	background-color: #fff;
	color: #EF6F26;
}

.btn--white:hover {
	color: #EF6F26;
}

.btn--white .btn__arrow {
	background-color: #EF6F26;
}

.btn--white .btn__arrow-right {
	fill: #fff;
}

@media screen and (max-width: 768px) {
	
	.btn {
		min-width: 24rem;
	}
	
}


.text-btn {
	position: relative;
	display: flex;
	align-items: center;
	column-gap: 1rem;
	padding: 0;
	color: #fff;
	line-height: 1;
}

.text-btn::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -1.6rem;
	width: 100%;
	height: 3px;
	background-color: #fff;
}

.text-btn__icon {
	fill: #fff;
}


/* --------------------------------------------------

	Breadcrumbs

-------------------------------------------------- */

.breadcrumbs {
	margin-top: 4rem;
	padding-bottom: 2rem;
	font-size: 1.4rem;
}

.breadcrumbs .inner > span {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: flex-end;
	margin: 0;
	padding: 0;
}

.breadcrumbs .inner > span > span + span:before {
	content: '>';
	display: inline-block;
	padding: 0 1rem;
}

@media screen and (max-width: 768px) {
	
	.breadcrumbs {
		margin-top: 4rem;
	}

}


/* --------------------------------------------------

	Header

-------------------------------------------------- */

.header {
	position: fixed;
	top: 0;
	z-index: 10000;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	padding: 3.2rem;
	transition: .2s;
}

.header.is-active,
.header.is-fixed {
	padding: 1.6rem;
	background-color: rgba(255, 255, 255, 0.95);
}

@media screen and (max-width: 1024px) {
	
	.header {
		padding: 1rem;
	}
	
}

.header__contact {
	margin: 0 0 0 2rem;
}

.header-logo {
	display: block;
	color: #333;
}

.header-logo__sup {
	display: block;
	margin: 0 0 1rem;
	font-size: 1.6rem;
	line-height: 1;
}

.header-logo__photo img {
	display: block;
	width: 240px;
	line-height: 1;
}

.header.is-fixed .header-logo__photo img {
	width: 160px;
}

@media screen and (max-width: 1280px) {
	
	.header__logo {
		width: 200px;
	}
	
}

@media screen and (max-width: 1024px) {
	
	.header-logo__sup {
		margin: 0 0 1rem;
		font-size: 1.2rem;
	}

	.header-logo__photo img {
		width: 120px;
	}
	
	.header.is-fixed .header-logo__photo img {
		width: 100px;
	}
	
}


.header__nav {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	margin: 0;
}

.header-nav {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0;
	list-style: none;
}

.header-nav > li {
	position: relative;
}

.header-nav a {
	display: block;
	padding: 1rem 1.6rem;
	color: #333;
	font-weight: 700;
	line-height: 1.4;
}

.header-nav a:hover {
	color: #f1931B;
}

.header-nav__child {
	overflow: hidden;
	position: absolute;
	top: 120%;  /* 親aタグの下に表示 */
	left: 0;
	z-index: 1000;
	min-width: 180px;
	padding: 0;
	margin: 0;
	background: #fff;
	border-radius: 1rem;
	box-shadow: 0px 0px 1rem -0.5rem #666;
	list-style: none;
	visibility: hidden;
	opacity: 0;
	transition: all 0.3s ease;
}

.header-nav__child li a {
	display: block;
	padding: 1.6rem;
	text-decoration: none;
	color: #333;
	white-space: nowrap; /* 長い文字も折り返さない */
}

.header-nav__child li a:hover {
	background: #F3F2F0;
}

/* ホバーで表示 */
.header-nav li:hover > ul {
	opacity: 1;
	visibility: visible;
	top: 100%;
}

.btn-conatct {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20rem;
	height: 56px;
	padding: 0 1rem;
	border-radius: 2rem;
	background-color: #EF6F26;
	color: #fff;
	font-weight: 700;
	font-size: 1.8rem;
	cursor: pointer;
	user-select: none;
	box-shadow: 0.6rem 0.6rem 0 #AD9080;
}

.btn-conatct svg {
	width: auto;
	height: 2rem;
}

.btn-conatct:hover {
	box-shadow: 0 0 0 #AD9080;
	transform: translate(0.6rem, 0.6rem);
	color: #fff;
}


.btn-conatct__text {
	padding: 0 0 0 1rem;
}

.header-tel-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background-color: #EF6F26;
	border-radius: 50%;
	box-shadow: 0.6rem 0.6rem 0 #AD9080;
}

.header-tel-btn svg {
	width: 24px;	
}

.header-tel-btn:hover {
	box-shadow: 0 0 0 #AD9080;
	transform: translate(0.6rem, 0.6rem);
	color: #fff;
}

@media screen and (max-width: 1280px) {
	
	.header-nav a {
		padding: 1rem;
	}
	
}

@media screen and (max-width: 1024px) {
	
	.header__nav {
		display: none;
	}
	
}


.cls-1 {
	fill: #fff;
}


/* --------------------------------------------------

	お問い合わせ

-------------------------------------------------- */

.snow-monkey-form {
	padding: 8rem;
}

.smf-action {
	padding: 2rem 0 0;
}

@media screen and (max-width: 768px) {
	
	.snow-monkey-form {
		padding: 2rem 2rem 4rem;
	}
	
}


.smf-item {
	margin: 0 0 3.2rem;
}

.form-day .smf-checkboxes-control {
	display: grid;
	align-items: center;
    grid-template-columns: 6rem 1fr;
}

.form-day .smf-control-fieldset {
	display: contents;
}


.smf-item__label {
	margin: 0 0 1rem;
	font-weight: 700;
}

.is-required {
	display: inline-block;
	margin: 0 1rem 0 0;
	padding: .4rem;
	background-color: #ce5252;
	border: 2px solid #ce5252;
	border-radius: 999px;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1;
	text-align: center;
	vertical-align: baseline;
}

::placeholder {
	color: #B4B4B4;
}

.smf-item__description {
	font-size: 1.4rem;
}

.smf-form .smf-text-control__control {
	width: 100%;
	padding: 1.6rem;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 1rem;
	font-size: 1.6rem;
	line-height: 1.5;
	box-shadow: none;
}

.smf-form .smf-textarea-control__control {
	width: 100%;
	padding: 1.6rem;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 1rem;
	font-size: 1.6rem;
	line-height: 1.5;
	box-shadow: none;
}

.smf-form .smf-select-control {
	display: block;
	width: 100%;
}

.smf-form .smf-select-control__control {
	display: block;
	width: 100%;
	padding: 1.6rem;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 1rem;
	font-size: 1.6rem;
	line-height: 1.5;
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.smf-form .smf-select-control__toggle {
	display: none !important;
}


.smf-checkbox-control,
.smf-radio-button-control {
	line-height: 1.4;
}

.smf-placeholder {
	margin-top: 1rem;
}

.smf-action {
	display: flex;
	align-items: center;
	column-gap: 2rem;
}

.smf-action .smf-button-control__control {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-width: 32rem;
	max-width: 42rem;
	padding: 2.4rem 2rem;
	border-radius: 2rem;
	background: #EF6F26 none;
	border: none;
	color: #fff;
	text-align: left;
	vertical-align: middle;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.4;
	cursor: pointer;
	user-select: none;
	box-shadow: 0.6rem 0.6rem 0 #AD9080;
	transition: 0.3s ease-in-out;
	appearance: none;
}

.smf-action .smf-button-control__control:hover {
	box-shadow: 0 0 0 #AD9080;
	transform: translate(0.6rem, 0.6rem);
	color: #fff;
}

.smf-action .smf-button-control__control[data-action="back"] {
	/* 戻るボタン専用のデザイン */
	min-width: 16rem;
	background-color: #535353;
	box-shadow: 0.6rem 0.6rem 0 #333;
}

@media screen and (max-width: 768px) {
	
	.smf-action {
		flex-direction: column-reverse;
		column-gap: 0;
		margin-bottom: -2rem;
	}
	
	.smf-action .smf-button-control {
		width: 100%;
		margin: 0 0 2rem !important;
	}

	.smf-action .smf-button-control__control,
	.smf-action .smf-button-control__control[data-action="back"] {
		min-width: 100%;
		max-width: 100%;
	}
	
}


.smf-sending {
	display: none !important;
}

.snow-monkey-form[data-screen="confirm"] .form-confirm-none {
	display: none;
}


/* --------------------------------------------------

	Footer

-------------------------------------------------- */

.footer {
	padding-top: 8rem;
	padding-bottom: 24rem;
	background: #412626 url("../images/common/footer.svg") no-repeat center calc(100% - 2rem);
	border-radius: 8rem 8rem 0 0;
}

.footer-contact-wrap {
	position: relative;
	margin-bottom: 12rem;
	padding-bottom: 12rem;
}

.footer-contact-wrap::after {
	content: 'CONTACT';
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 1;
	display: block;
	-webkit-text-fill-color: transparent; /* （順序に関係なく）色を上書きする */
	-webkit-text-stroke: 1px #775A5A;
	font-family: "Zen Maru Gothic", sans-serif;
	font-style: normal;
	font-weight: 700;
	font-size: 26rem;
	line-height: 1;
	white-space: nowrap;
}

.footer-contact {
	position: relative;
	z-index: 2;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 -6rem;
}

.footer-contact__head {
	padding: 0 6rem;
}

.footer-contact__title {
	margin: 0 0 2.4rem;
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 1.4;
}

.footer-contact__sup {
	font-size: 2rem;
	line-height: 2.4;
}

.footer-contact__head > :last-child {
	margin-bottom: 0;
}

.footer-contact__btn {
	padding: 0 6rem;
}

.footer-contact__btn > :last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 1024px) {
	
	.footer-contact {
		justify-content: space-between;
		margin: 0 -2rem;
	}

	.footer-contact__head {
		padding: 0 2rem;
	}

	.footer-contact__btn {
		padding: 0 2rem;
	}
	
}

@media screen and (max-width: 768px) {
	
	.footer {
		padding-top: 4rem;
		padding-bottom: 12rem;
		background-size: auto 8rem;
		border-radius: 4rem 4rem 0 0;
	}

	.footer-contact-wrap::after {
		left: 0;
		right: auto;
		font-size: 10rem;
	}

	.footer-contact {
		flex-direction: column;
	}

	.footer-contact__head {
		margin-bottom: 2rem;
		padding: 0;
		text-align: center;
	}

	.footer-contact__title {
		font-size: 2rem;
	}
	
	.footer-contact__sup {
		font-size: 1.6rem;
		line-height: 2;
	}

}


.footer-row {
	display: flex;
	justify-content: space-between;
	margin: 0 -1rem;
}

.footer-company {
	padding: 0 1rem;
	font-size: 1.6rem;
}

.footer-company dl {
	margin-bottom: 3.2rem;
}

.footer-company dt {
	margin: 0 0 3.2rem;
}

.footer-company__logo img {
	width: 200px;
}

.footer-company a {
	color: #fff;
}

.footer-company ul {
	margin: 0 0 3.2rem;
	padding: 0;
	list-style: none;
}

.banner-row {
	display: flex;
	align-items: center;
	margin: 0 -1rem;
}

.banner-col {
	padding: 0 1rem;
}

.banner-taktas { width: 200px;}
.banner-tcj { width: 89px;}


@media screen and (max-width: 768px) {

	.banner-taktas { width: 100px;}
	.banner-tcj { width: 45px;}
	
}


.footer-nav-box {
	padding: 0 1rem;
	font-size: 1.6rem;
}

.footer-nav {
	display: flex;
	margin: 0 -2rem;
}

.footer-nav ul {
	margin: 0;
	padding: 0 2rem;
	list-style: none;
}

.footer-nav li {
	margin-bottom: 2rem;
}

.footer-nav a {
	color: #fff;
}

.footer-copyright {
	padding: 0 1rem;
}

.copyright {
	margin: 0;
	font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
	
	.footer-row {
		flex-direction: column;
	}

	.footer-company {
		order: 2;
		width: 100%;
	}
	
	.footer-company__logo img {
		width: 160px;
	}
	
	.footer-nav-box {
		order: 1;
		width: 100%;
		margin-bottom: 4rem;
	}
	
	.footer-nav ul {
		width: 50%;
	}

	.footer-copyright {
		order: 3;
		width: 100%;
		margin-top: 4rem;
	}
	
}


.btn-pagetop {
	position: fixed;
	right: 1rem;
	bottom: 1rem;
	display: none; /* 最初は非表示 */
	z-index: 1000;
	width: 100px;
}

.btn-pagetop a {
	display: block;
	text-align: center;
}

.btn-pagetop__text {
	margin: 0 0 1rem;
	color: #EF6F26;
	line-height: 1;
	font-size: 1.6rem;
}

.btn-pagetop__photo {
	margin: 0;
}

.btn-pagetop__photo img {
	display: block;
	width: 30px;
	margin: 0 auto;
}

@media screen and (max-width: 768px) {
	
	.btn-pagetop {
		width: auto;
	}

	.btn-pagetop__text {
		font-size: 1.2rem;
	}

	.btn-pagetop__photo img {
		width: 16px;
	}
	
}


/* --------------------------------------------------

	sp

-------------------------------------------------- */

.btn-spnav {
	position: relative;
	display: none;
	width: 50px;
	height: 50px;
	cursor: pointer;
}

.btn-spnav span {
	display: inline-block;
	position: absolute;
	left: 14px;
	width: 45%;
	height: 3px;
	background-color: #EF6F26;
	border-radius: 2px;
	transition: all .3s;
}

.btn-spnav span:nth-of-type(1) {
	top: 15px;
}

.btn-spnav span:nth-of-type(2) {
	top: 23px;
}

.btn-spnav span:nth-of-type(3) {
	top: 31px;
}

.btn-spnav.is-active span:nth-of-type(1) {
	top: 18px;
	left: 18px;
	width: 30%;
	transform: translateY(6px) rotate(-45deg);
}

.btn-spnav.is-active span:nth-of-type(2) {
	opacity: 0;
}

.btn-spnav.is-active span:nth-of-type(3){
	top: 30px;
	left: 18px;
	width: 30%;
	transform: translateY(-6px) rotate(45deg);
}

@media screen and (max-width: 1024px) {
	
	.btn-spnav {
		display: block;
	}
	
}


.sp-nav {
	position: fixed;
	z-index: 9999;
	top: -200%;
	left: 0;
	width: 100%;
	height: 100vh;
	transition: all .3s;
}

.sp-nav.is-active {
	top: 0;
}

.sp-nav.is-active .sp-nav__body {
	position: fixed;
	z-index: 999;
	overflow: auto;
	width: 100%;
	height: 100vh;
	-webkit-overflow-scrolling: touch;
}

.sp-nav__contents {
	width: 100%;
	margin: 0;
	padding: 10rem 2rem 4rem;
}

.nav-sp {
	margin: 0 0 4rem;
	padding: 0;
	list-style: none;
}

.nav-sp > li {
	border-bottom: 1px solid #fff;
}

.nav-sp a,
.has-submenu__title {
	display: block;
	width: 100%;
	padding: 1.6rem 0;
	color: #fff;
	text-decoration: none;
	text-transform: uppercase;
}

.has-submenu a {
	padding: 1rem 0;
}

.has-submenu__title {
	position: relative;
}

.has-submenu__title::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 1rem;
	display: block;
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: translateY(-50%) rotate(135deg);
}

.has-submenu.is-active .has-submenu__title::after {
	transform: translateY(-50%) rotate(315deg);
}

.nav-sp .submenu {
	display: none;
	list-style: none;
}

.nav-sp-contact {
	text-align: center;
}

.sp-nav__tel {
	margin: 0 0 3.2rem;
}

.sp-nav__tel dl {
	margin: 0;
	padding: 0;
	text-align: center;
}

.sp-nav__tel dt {
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 1rem;
	margin: 0 0 0.8rem;
	padding: 0;
	color: #fff;
	font-size: 2.8rem;
	font-weight: 700;
}

.sp-nav__tel dt a {
	color: #fff;
}

.sp-nav__tel dt svg {
	width: auto;
	height: 3.2rem;
	line-height: 1;
}

.sp-nav__tel dd {
	margin: 0;
	padding: 0;
}

.btn-sp-contact {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	padding: 2rem 1rem;
	border-radius: 2rem;
	background-color: #fff;
	color: #EF6F26;
	text-align: left;
	vertical-align: middle;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.4;
	cursor: pointer;
	user-select: none;
	box-shadow: 0.6rem 0.6rem 0 #AD9080;
	transition: 0.3s ease-in-out;
}

.btn-sp-contact svg {
	width: auto;
	height: 2rem;
}

.btn-sp-contact__text {
	display: inline-block;
	padding: 0 0 0 1rem;
}




/* --------------------------------------------------

	ホーム

-------------------------------------------------- */

.top-key {
	padding-top: 10rem;
}

.top-key::after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	display: block;
	width: 100vw;
	height: 100vh;
	background-color: #F3F2F0;
}

.top-key__inner {
	margin: 0 auto;
	padding: 0 4rem;
}

.top-key__inner-header {
	background: url("../images/common/top-key.png") no-repeat right bottom;
	background-size: contain;
}

.top-key__text {
	margin-bottom: 8rem;
	font-weight: 700;
}

.top-key__text > :last-child {
	margin-bottom: 0;
}

.top-key__title {
	margin: 0 0 4rem;
	font-size: 5.2rem;
	font-weight: 700;
	line-height: 1.43333;
}

.top-key__photo {}

@media screen and (max-width: 1799px) {
	
	.top-key__inner-header {
		background-size: 70% auto;
	}
	
}

@media screen and (max-width: 1180px) {
	
	.top-key {
		padding-top: 4rem;
		padding-bottom: 14rem;
		background: url("../images/common/top-key.png") no-repeat center bottom;
		background-size: 100% auto;
	}
	
	.top-key__text {
		margin-bottom: 4rem;
	}
	
	.top-key__inner-header {
		padding-bottom: 0;
		background: none;
	}
	
	.top-key__title {
		margin: 0 0 2rem;
		font-size: 4rem;
	}
	
}

@media screen and (max-width: 768px) {
	
	.top-key::after {
		height: 70vh;
	}
	
	.top-key__inner {
		padding: 0 2rem;
	}
	
	.top-key__text {
		margin-bottom: 4rem;
	}
	
	.top-key__title {
		margin: 0 0 2rem;
		font-size: 3.2rem;
	}

}


.section-message {
	position: relative;
	padding-bottom: 16rem;
}

.section-message::after {
	content: 'MESSAGE';
	position: absolute;
	right: 0;
	bottom: -2rem;
	z-index: -1;
	display: block;
	-webkit-text-fill-color: transparent; /* （順序に関係なく）色を上書きする */
	-webkit-text-stroke: 1px #D5CEC0;
	font-family: "Zen Maru Gothic", sans-serif;
	font-style: normal;
	font-weight: 700;
	font-size: 26rem;
	line-height: 1;
	white-space: nowrap;
}

@media screen and (max-width: 768px) {
	
	.section-message::after {
		left: 0;
		right: none;
		font-size: 12rem;
	}
	
}


.message-box-wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.footer-contact-wrap {
	position: relative;
	margin-bottom: 12rem;
	padding-bottom: 12rem;
}

.message-box__title {}

.message-box__text {
	font-size: 2rem;
	line-height: 3;
}

.message-box__text > :last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 768px) {
	
	.section-message {
		padding-bottom: 8rem;
	}

	.section-message::after {
		font-size: 10rem;
	}
	
	.message-box__title {
		margin: 0 0 3.2rem;
		font-size: 3.2rem;
	}

	.message-box__text {
		font-size: 1.6rem;
		line-height: 2.4;
	}
	
	.footer-contact-wrap {
		margin-bottom: 8rem;
		padding-bottom: 4rem;
	}

}


.section-about {
	position: relative;
	margin-bottom: 10rem;
	padding-top: 16rem;
	color: #fff;
}

.section-about::after {
	content: '';
	position: absolute;
	z-index: 1;
	display: block;
	width: calc(100% - 8rem);
	top: 0;
	bottom: 0;
	left: 0;
	background-color: #EF6F26;
	border-radius: 0 8rem 8rem 0;
}

.section-about .inner {
	position: relative;
	z-index: 2;
	padding: 0 12rem;
}

.section-about-row {
	display: flex;
	justify-content: space-between;
	margin-bottom: 4rem;
}

.section-about-head {
	width: 32.8125%;
}

.section-about-body {
	width: 58.6875%;
}

.section-about-body__box + .section-about-body__box {
	margin-top: 5.2rem;
}

.section-about__title {
	position: relative;
	display: inline-block;
	margin-bottom: 8rem;
	font-size: 4.8rem;
	line-height: 1.5;
}

.section-about__title::after {
	content: '';
	position: absolute;
	top: -12rem;
	right: -12rem;
	display: block;
	width: 202px;
	height: 140px;
	background: url("../images/common/heart.svg") no-repeat center center;
	background-size: contain;
}

.section-about__sub-title {
	margin: 0 0 3.2rem;
	font-size: 2.4rem;
	line-height: 1.52;
}

@media screen and (max-width: 1024px) {
	
	.section-about {
		margin-bottom: 4rem;
		padding-top: 8rem;
	}

	.section-about::after {
		width: calc(100% - 1rem);
		border-radius: 0 4rem 4rem 0;
	}

	.section-about .inner {
		padding: 0 2rem;
	}

	.section-about-row {
		flex-direction: column;
	}

	.section-about-head {
		width: 100%;
	}

	.section-about-body {
		width: 100%;
	}

	.section-about-body__box + .section-about-body__box {
		margin-top: 4rem;
		margin-bottom: 4rem;
	}

	.section-about__title {
		margin-bottom: 3.2rem;
		font-size: 3.2rem;
	}

	.section-about__title::after {
		top: -4rem;
		right: -4rem;
		width: 100px;
		height: 60px;
	}
	
}


.slick-list {
	overflow: visible !important;
}

.slick-slide-box {
	margin: 0 2rem;
	text-align: center;
}

@media screen and (max-width: 768px) {
	
	.slick-slide-box {
		margin: 0 1rem;
	}
	
}


.section-business {
	position: relative;
	margin-bottom: 10rem;
}

.section-business::after {
	content: '';
	position: absolute;
	z-index: 1;
	display: block;
	width: calc(100% - 8rem);
	top: 0;
	bottom: 0;
	right: 0;
	background-color: #F3F2F0;
	border-radius: 8rem 0 0 8rem;
}

.section-business .inner {
	position: relative;
	z-index: 2;
	padding: 0 12rem;
}

@media screen and (max-width: 768px) {
	
	.section-business::after {
		width: calc(100% - 1rem);
		border-radius: 4rem 0 0 4rem;
	}

	.section-business .inner {
		padding: 0 2rem;
	}
	
}


.business-box {
	overflow: hidden;
	display: flex;
	margin: 0 0 4rem;
	background-color: #fff;
}

.business-box__text {
	width: 50%;
	padding: 4rem;
}

.business-box__text > :last-child {
	margin-bottom: 0;
}

.business-box__photo {
	width: 50%;
}

.business-box--small .business-box__text {
	width: calc(100% - 38.709677%);
}

.business-box--small .business-box__photo {
	width: 38.709677%;
}

@media screen and (max-width: 768px) {

	.business-box {
		flex-direction: column-reverse;
	}

	.business-box__text {
		width: 100%;
		padding: 4rem;
	}

	.business-box__photo {
		width: 100%;
	}

	.business-box--small .business-box__text {
		width: 100%;
	}

	.business-box--small .business-box__photo {
		width: 100%;
	}
	
}


.business-box__num {
	margin: 0 0 2rem;
	font-size: 8rem;
	font-weight: 700;
	line-height: 1;
}

.business-box__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.section-business-btn {
	display: flex;
	justify-content: center;
}

@media screen and (max-width: 768px) {
	
	.business-box__num {
		font-size: 3.2rem;
	}
	
	.business-box__photo img {
		aspect-ratio: 16 / 9;
	}
	
}


.section-news {
	margin-bottom: -8rem;
	padding-bottom: 16rem;
	border-radius: 8rem 8rem 0 0;
}

@media screen and (max-width: 768px) {
	
	.section-news {
		margin-bottom: -4rem;
		padding-bottom: 8rem;
		border-radius: 4rem 4rem 0 0;
	}
	
}


/* --------------------------------------------------

	会社紹介

-------------------------------------------------- */

.president-box {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	justify-content: space-between;
}

.president-box__photo {
	width: 44.8%;
}

.president-box__text {
	width: 50%;
}

.president-box__body {
	margin-bottom: 3.2rem;
	line-height: 3;
}

.president-box__body > :last-child {
	margin-bottom: 0;
}

.president-name {
	display: flex;
	align-items: center;
}

.president-name__position {
	margin: 0 4rem 0 0;
	font-size: 2rem;
	font-weight: 400;
	letter-spacing: 2px;
}

.president-name__name {
	margin: 0 2rem 0 0;
	font-size: 2.4rem;
}

.president-name__en {
	font-size: 1.4rem;
	color: #EF6F26;
}

@media screen and (max-width: 768px) {
	
	.president-box {
		flex-direction: column-reverse;
	}

	.president-box__photo {
		width: 44.8%;
	}

	.president-box__text {
		width: 100%;
		margin-bottom: 4rem;
	}

	.president-name {
		flex-wrap: wrap;
	}

	.president-name__position {
		width: 100%;
		margin: 0;
		font-size: 1.6rem;
	}
	
}


.philosophy-box {
	position: relative;
	overflow: hidden;
	padding: 8rem 2rem;
	background-color: #F3F2F0;
	border-radius: 4rem;
}

.philosophy-box::after {
    content: 'PHILOSOPHY';
    position: absolute;
    right: 2rem;
    bottom: 1rem;
    z-index: 1;
    display: block;
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: 1px #D5CEC0;
    font-family: "Zen Maru Gothic", sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 12rem;
    line-height: 1;
    white-space: nowrap;
}

.philosophy-box ul {
	position: relative;
	z-index: 2;
	margin: 0;
	padding: 0;
	list-style: none;
}

.philosophy-box li {
	font-size: 2rem;
	text-align: center;
}

.philosophy-box li + li {
	margin-top: 2rem;
}

@media screen and (max-width: 768px) {
	
	.philosophy-box {
		padding: 4rem;
	}
	
	.philosophy-box::after {
		left: 0;
		right: auto;
		font-size: 10rem;
    }

	.philosophy-box li {
		font-size: 1.6rem;
	}

}


.company-overview {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 -1px;
	border: 1px solid #D5CEC0;
	border-radius: 4rem;
	overflow: hidden;
}

.company-overview dt {
	width: 240px;
	padding: 2rem 3.2rem;
	background-color: #F3F2F0;
	border-right: 1px solid #D5CEC0;
}

.company-overview dd {
	width: calc(100% - 240px);
	padding: 2rem 3.2rem;
}

.company-overview dt:not(:last-of-type),
.company-overview dd:not(:last-of-type) {
	border-bottom: 1px solid #D5CEC0;
}

@media screen and (max-width: 768px) {
	
	.company-overview dt {
		width: 100%;
		padding: 2rem 2rem 0;
		border-right: none;
		border-bottom: none !important;
	}

	.company-overview dd {
		width: 100%;
		padding: 2rem;
	}
	
}


.google-map {
	margin-bottom: 4rem;
}

.google-map iframe {
	overflow: hidden;
	width: 100%;
	aspect-ratio: 16/9;
	border-radius: 4rem;
}


/* --------------------------------------------------

	REKができること

-------------------------------------------------- */

.service-box {
	position: relative;
	max-width: 1080px;
	width: 100%;
	margin: 0;
}

.service-box::after {
	position: absolute;
	bottom: -8rem;
	z-index: -1;
	display: block;
	-webkit-text-fill-color: transparent;
	-webkit-text-stroke: 1px #D5CEC0;
	font-family: "Zen Maru Gothic", sans-serif;
	font-style: normal;
	font-weight: 700;
	font-size: 20rem;
	line-height: 1;
	white-space: nowrap;
}

.service-box--consulting::after {
	content: 'CONSULTING';
	left: 25%;
}

.service-box--brokerage::after {
	content: 'BROKERAGE';
	right: 25%;
}
.service-box--management::after {
	content: 'MANAGEMENT';
	left: 25%;
}

.service-box + .service-box {
	margin-top: 12rem;
}

.service-box--even {
	margin-left: auto;
}

.service-box__photo {
	margin-bottom: 3.2rem;
}

.service-box__text {
	display: flex;
	justify-content: space-between;
	margin: 0 -2rem;
}

.service-box__head {
	width: 40%;
	padding: 0 1rem 0 4rem;
}

.service-box__title {
	font-size: 2.8rem;
	line-height: 1.72;
	font-weight: 700;
}

.service-box__head > :last-child {
	margin-bottom: 0;
}

.service-box__body {
	width: 60%;
	padding: 0 1rem;
}

.service-box__body > :last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 768px) {
	
	.service-box + .service-box {
		margin-top: 4rem;
	}
	
	.service-box::after {
		font-size: 10rem;
	}
	
	.service-box--consulting::after {
		left: 0;
	}

	.service-box--brokerage::after {
		right: 0;
	}
	
	.service-box--management::after {
		left: 0;
	}

	.service-box__photo {
		margin-bottom: 2rem;
	}

	.service-box__text {
		flex-direction: column;
	}

	.service-box__head {
		width: 100%;
		margin-bottom: 2rem;
		padding: 0 2rem;
	}

	.service-box__title {
		font-size: 2rem;
	}

	.service-box__body {
		width: 100%;
		padding: 0 2rem;
	}

}


.case-box {
	display: flex;
	margin: 0 -2rem;
}

.case-box + .case-box {
	margin-top: 8rem;
}

.case-box__photo {
	width: 30.769231%;
	padding: 0 2rem;
}

.case-box__text {
	width: calc(100% - 30.769231%);
	padding: 0 2rem;
}

.case-box__title {
	margin: 0 0 2.4rem;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.72;
}

.case-box__sub-title {
	margin: 0 0 2rem;
	font-size: 2rem;
    font-weight: 700;
	line-height: 1;
}

.case-box__badge {
	display: inline-block;
	padding: 1rem;
}

@media screen and (max-width: 768px) {
	
	.case-box {
		flex-direction: column;
	}

	.case-box + .case-box {
		margin-top: 4rem;
	}
	
	.case-box__photo {
		width: 50%;
		margin: 0 auto 2rem;
		padding: 0 2rem;
	}

	.case-box__text {
		width: 100%;
	}

	.case-box__title {
		font-size: 2rem;
	}

	.case-box__sub-title {
		font-size: 1.8rem;
    }
	
}


/* --------------------------------------------------

	よくある質問

-------------------------------------------------- */

.faq-list {
	border-radius: 4rem;
	overflow: hidden;
	border: 1px solid transparent;
}

.faq-list.is-active {
	border-color: #D5CEC0;
}

.faq-list + .faq-list {
	margin-top: 4rem;
}

.faq-list dt {
	position: relative;
	padding: 2rem 6rem 2rem 4rem;
	background-color: #F3F2F0;
	cursor: pointer;
}

.faq-list dt::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 2rem;
	display: block;
	width: 40px;
	height: 40px;
	background: #EF6F26 url("../images/common/arrow-down--white.svg") no-repeat center center;
	background-size: 16px 14px;
	border-radius: 50%;
	transform: translateY(-50%);
	transition: .2s;
}

.faq-list.is-active dt::after {
	transform: translateY(-50%) rotate(-180deg);
}

.faq-list dd {
	display: none;
	padding: 2rem 4rem;
}

.faq-list dd > :last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 768px) {
	
	.faq-list + .faq-list {
		margin-top: 2rem;
	}
	
	.faq-list dt {
		padding-right: 5.2rem;
		padding-left: 2rem;
	}

	.faq-list dt::after {
		right: 1rem;
		width: 28px;
		height: 28px;
		background-size: 12px 9px;
	}

	.faq-list dd {
		padding-right: 2rem;
		padding-left: 2rem;
	}

}


/* --------------------------------------------------

	お知らせ・ブログ

-------------------------------------------------- */

.news-entry-row + .news-entry-row {
	margin-top: 3.2rem;
}

.news-entry {
	position: relative;
	display: flex;
	padding: 4rem 0 4rem 7.2rem;
	background-color: #F3F2F0;
	color: #333;
}

.bg-secondary .news-entry {
	background-color: #fff;
}

.news-entry__date {
	width: 120px;
	margin: 0;
}

.news-entry__cat {
	width: 200px;
	margin: 0;
	padding: 0 2rem;
}

.news-entry__title {
	width: calc(100% - 320px);
	margin: 0;
}

.news-entry__arrow {
	position: absolute;
	top: 50%;
	right: 4rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	background-color: #EF6F26;
	border-radius: 50%;
	transform: translateY(-50%);
}

.news-entry__arrow .news-entry__arrow-right {
	fill: #fff;
}

@media screen and (max-width: 768px) {
	
	.news-entry {
		flex-wrap: wrap;
		padding: 2rem;
	}
	
	.news-entry__date {
		width: auto;
	}

	.news-entry__cat {
		width: auto;
	}
	
	.news-entry__cat .badge {
		display: inline-block;
		width: auto;
	}
	
	.news-entry__title {
		width: 100%;
		margin-top: 2rem;
	}

	.news-entry__arrow {
		display: none;
	}
	
}


.pagination {
	margin-top: 8rem;
	margin-bottom: 8rem;
}

.screen-reader-text {
	display: none !important;
}


.pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	margin-bottom: -8px;
}

.page-numbers {
	display: block;
	width: 68px;
	height: 68px;
	margin: 0 8px 8px;
	background-color: #F3F2F0;
	border-radius: 4rem;
	line-height: 66px;
	text-align: center;
}

@media screen and (max-width: 768px) {
	
	.pagination {
		margin-top: 4rem;
		margin-bottom: 4rem;
	}
	
}


.page-numbers.current {}
.page-numbers.prev {}
.page-numbers.next {}


/* --------------------------------------------------

	お知らせ・ブログ Detail

-------------------------------------------------- */

.news-detail-head {
	margin: 0 0 4rem;
}

.news-detail-head__title {
	margin: 0 0 1.6rem;
	font-size: 4rem;
	line-height: 1.4;
}

.news-detail-head__meta {
	display: flex;
	align-items: center;
	margin: 0 -1rem;
}

.news-detail-head__date {
	margin: 0;
	padding: 0 1rem;
}

.news-detail-head__cat {
	padding: 0 1rem;
}

@media screen and (max-width: 768px) {
	
	.news-detail-head__title {
		font-size: 3.2rem;
	}
	
}


.page-nav {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 8rem -2rem 0;
}

.page-nav__col {
	padding: 0 2rem;
}

.page-nav__col--next {}
.page-nav__col--home {}
.page-nav__col--prev {}

@media screen and (max-width: 768px) {
	
	.page-nav {
		margin-top: 4rem;
	}
	
}