@charset "UTF-8";

:root {
	--color-primary: #399D26;
	--color-secondary: #4C3F2F;
	--color-accent: #F3C404;
	--color-text: #4C3F2F;
	--color-text-gray: #666;
	--color-text-link: #F18869;
	--color-primary-bg: #FAF8F4;
	--color-secondary-bg: #fafbff;
	--color-border-1: rgba(76,63,47,.2);

	--fontSize: 16px;
	--font-2xs: calc(var(--fontSize) * 0.6875);/* 11px */
	--font-xs: calc(var(--fontSize) * 0.75);/* 12px */
	--font-s: calc(var(--fontSize) * 0.875);/* 14px */
	--font-ms: calc(var(--fontSize) * 0.875);/* 14px */
	--font-m: calc(var(--fontSize) * 1);/* 16px */
	--font-l: calc(var(--fontSize) * 1);/* 16px */
	--font-xl: calc(var(--fontSize) * 1.125);/* 18px */
	--font-xxl: calc(var(--fontSize) * 1.125);/* 18px */
	--font-2xl: calc(var(--fontSize) * 1.125);/* 18px */
	--font-3xl: calc(var(--fontSize) * 1.375);/* 22px */
	--font-4xl: calc(var(--fontSize) * 1.375);/* 22px */
	--font-5xl: calc(var(--fontSize) * 1.375);/* 22px */
	--font-6xl: calc(var(--fontSize) * 2);/* 32px */
	/*--primary-font: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;*/
	--primary-font: "Zen Kaku Gothic New", sans-serif;
	--accent-font: "Jost", sans-serif;

	--radius01: 20px;
	--radius02: 5px;
}

@media (min-width: 768px) {
	:root {
		--font-2xs: calc(var(--fontSize) * 0.6875);/* 11px */
		--font-xs: calc(var(--fontSize) * 0.75);/* 12px */
		--font-s: calc(var(--fontSize) * 0.875);/* 14px */
		--font-ms: calc(var(--fontSize) * 0.9735);/* 15px */
		--font-m: calc(var(--fontSize) * 1);
		--font-l: calc(var(--fontSize) * 1.125);/* 18px */
		--font-xl: calc(var(--fontSize) * 1.25);/* 20px */
		--font-xxl: calc(var(--fontSize) * 1.375);/* 22px */
		--font-2xl: calc(var(--fontSize) * 1.5);/* 24px */
		--font-3xl: calc(var(--fontSize) * 1.75);/* 28px */
		--font-4xl: calc(var(--fontSize) * 2);/* 32px */
		--font-5xl: calc(var(--fontSize) * 2.125);/* 34px */
		--font-6xl: calc(var(--fontSize) * 2.625);/* 42px */

		--radius01: 50px;
		--radius02: 10px;
	}
}
ol, ul, li {
	list-style: none;
}

a {
	margin: 0;
	padding: 0;
	border: 0;
	font-weight: normal;
	font-style: normal;
	text-decoration: none;
	vertical-align: baseline;
}
html,
body {
	height: 100%;
	margin: 0;
}
body {
	position: relative;
	font-size: var(--font-m);
	font-family: var(--primary-font);
	color: var(--color-text);
	line-height: 1.75;
	letter-spacing: 0.05em;
	-webkit-text-size-adjust: 100%;
	word-wrap: break-word;
	overflow-wrap: break-word;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	overflow-x: hidden;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	>* {
		position: relative;
		z-index: 2;
	}
	@media (min-width: 1000px) {
		font-size: var(--font-m);
	}
	@media (max-width: 330px) {
		font-size: var(--font-xs);
	}
}
@media (max-width: 1000px) {
	body * {
		font-weight: 500;
	}
}
main {
	flex: 1;
}
*,
*::before,
*::after {
	box-sizing: border-box;
}
p {
	line-height: 1.6;
}
a {
	color: inherit;
}
strong {
	font-weight: 600;
}
.ib {
	display: inline-block;
}
.mode_pc,
.mode_pc-ib {
	display: none;
}
.mode_sp {
	display: block;
}
.mode_sp-ib {
	display: inline-block;
}
.mover {
	transition: opacity 0.2s ease-out;
	backface-visibility: hidden;
	zoom: 1;
}
.mover:hover {
	opacity: 0.8;
}
.mover02 {
	transition: opacity 0.2s ease-out;
	backface-visibility: hidden;
	zoom: 1;
}
.mover02:hover {
	opacity: 0.9;
}
.inner,
.inner-min {
	padding: 0 4vw;
}
.inner {
	.inner-min {
		padding: 0;
	}
}
img {
	max-width: 100%;
}
.em {
	font-weight: 500;
	* {
		font-weight: 500;
	}
}
.em-color {
	font-weight: 500;
	font-size: var(--font-l);
	color: var(--color-primary);
	&.size-l {
		font-size: var(--font-xl);
	}
	&.pb {
		padding-bottom: .5em;
	}
	* {
		font-weight: 500;
	}
}
.text-link {
	color: var(--color-text-link);
}
.image-wrap {
	text-align: center;
}

@media (min-width: 1000px) {
	p {
		line-height: 1.75;
	}
	.inner {
		width: 90%;
		max-width: 1240px;
		margin: auto;
		padding: 0;
	}
	.inner-min {
		width: 90%;
		max-width: 1020px;
		margin: auto;
		padding: 0;
	}
	.mode_pc {
		display: block;
	}
	.mode_pc-ib {
		display: inline-block;
	}
	.mode_sp,
	.mode_sp-ib {
		display: none;
	}
}

#contentWrap {
	padding-top: 120px;
	.t-left {
		text-align: left;
	}
	@media (min-width: 768px) {
		padding-top: 86px;
	}
}
/*
header
---------------------------*/
header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	text-align: center;
	z-index: 20;
	transition: .5s ease;
	background-color: rgba(255,255,255,.95);
	filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.1));
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
	padding: 12px 3vw;
	#headerInner {
		text-align: left;
	}
	.siteNameBox {
		line-height: 1.4;
		font-size: var(--font-l);
		* {
			font-weight: 500;
		}
	}
	.topBtnContent {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding-top: 8px;
		.topBtn {
			display: inline-block;
			color: #fff;
			background-color: var(--color-primary);
			border-radius: 50px;
			margin-left: 2vw;
			a {
				display: inline-block;
				padding: 15px;
				span {
					position: relative;
					white-space: nowrap;
					padding-right: 12px;
					&:after {
						border-top: solid 1px #fff;
						border-right: solid 1px #fff;
						width: 8px;
						height: 8px;
						position: absolute;
						content: "";
						top: 0;
						bottom: 0;
						transform: rotate(45deg);
						right: 0;
						margin: auto;
						transition: all 0.3s ease-out;
					}
				}
				&:hover {
					span {
						&:after {
							right: -5px;
						}
					}
				}
			}
		}
		.note {
			color: var(--color-text-gray);
			font-size: var(--font-s);
			span {
				padding-right: .5em;
			}
		}
	}
	@media (min-width: 1000px) {
		padding: 20px;
		border-bottom-left-radius: 10px;
		border-bottom-right-radius: 10px;
		#headerInner {
			display: flex;
			align-items: center;
			justify-content: space-between;
		}
		&.is-fixed {
			position: fixed;
			background-color: rgba(255,255,255,.8);
			transition: all 1000ms;
			transform: translate(0, -5px);
			#contentNav {
				top: 0;
			}
		}
		.topBtnContent {
			justify-content: flex-end;
			padding-top: 0;
			.note {
				font-size: var(--font-m);
				padding-top: 0;
			}
		}
	}
}

/*
footer
---------------------------*/
footer {
	margin-top: auto;
	background-color: var(--color-secondary);
	text-align: center;
	padding: 15px;
}

footer .copy {
	font-size: var(--font-xs);
	font-family: var(--accent-font);
	color: #fff;
}

@media (min-width: 768px) {
	footer {
		padding: 20px;
	}
}

/*
.page_top
---------------------------*/
.page_top {
	display: none;
	position: fixed;
	z-index: 11;
	bottom: 0;
	right: 0;
	background-color: var(--color-secondary);
	opacity: 0.9;
	a {
		display: block;
		width: 40px;
		height: 40px;
	}
	&:before {
		content: '';
		width: 15px;
		height: 15px;
		border-top: solid 1px #fff;
		border-right: solid 1px #fff;
		transform: rotate(-45deg);
		position: absolute;
		bottom: 8px;
		right: 12px;
	}
	@media (max-width: 767px) {
		display: none!important;
	}
}
/*
.btnWrap
---------------------------*/
.btnWrap {
	text-align: center;
	&.left {
		text-align: left;
	}
	.btn {
		&+.btn {
			margin-top: 15px;
		}
	}
	@media (min-width: 1000px) {
		text-align: center;
		.btn {
			&+.btn {
				margin-top: 0;
				margin-left: 10px;
			}
		}
	}
}
/*
.btn
---------------------------*/
.btn {
	position: relative;
	top: 0;
	display: inline-block;
	line-height: 1.4;
	width: 300px;
	padding: 0;
	zoom: 1;
	transition: .2s ease-in-out;
	padding-top: 0;
	&:before,
	&:after {
		content: "";
		display: block;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
		pointer-events: none;
	}
	&:before {
		width: 36px;
		height: 36px;
		border-radius: 50px;
		background-color: #fff;
		right: 10px;
		z-index: 2;
		border: 1px solid var(--color-primary);
		transition: all 0.3s ease-out;
	}
	&:after {
		right: 22px;
		width: 12px;
		height: 12px;
		background-image: url(../img/common/icon-arrow-g.svg);
		background-size: cover;
		z-index: 3;
	}
	a, button, input {
		display: block;
		width: 100%;
		background-color: var(--color-primary);
		border: 1px solid var(--color-primary);
		color: #fff;
		font-size: var(--font-l);
		font-weight: 600;
		line-height: 1.4;
		text-align: left;
		border-radius: 50px;
		text-decoration: none;
		padding: 14px;
		cursor: pointer;
		transition: all 0.3s ease-out;
		box-shadow: 5px 5px 0px 0px var(--color-secondary-bg);
	}

	&:hover {
		a, span, button, input {
			background-color: #fff;
			color: var(--color-primary);
		}
		&:before {
			background-color: var(--color-primary);
		}
		&:after {
			background-image: url(../img/common/icon-arrow.svg);
		}
	}
	&.pdf {
		span {
			display: inline-block;
			position: relative;
			font-weight: 600;
			padding-left: 25px;
			&:before {
				content: "";
				display: block;
				background-image: url(../img/common/icon-pdf.svg);
				background-size: cover;
				width: 18px;
				height: 18px;
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				border: none;
				transform: none;
				margin: auto;
			}
		}
		&:hover {
			span {
				&:before {
					background-image: url(../img/common/icon-pdf-red.svg);
				}
			}
		}
	}
	&.back {
		a, button, input {
			background-color: #999;
			border: 1px solid #999;
		}
		&:after {
			transform:rotateY(180deg);
		}
		&:before {
			border: 1px solid #999;
		}
		&:hover {
			a, span, button, input {
				background-color: #fff;
				color: #999;
			}
			&:before {
				background-color: #999;
			}
		}
	}
	@media (min-width: 1000px) {
		width: 400px;
		min-width: inherit;
		&.pdf {
			width: 340px;
			a, button, input {
				padding: 15px;
			}
		}
		a, button, input {
			padding: 20px 20px;
		}
		&:before {
			right: 15px;
		}
		&:after {
			right: 28px;
		}
	}
	@media (max-width: 425px) {
		&.pdf {
			width: 100%;
		}
	}
	@media (max-width: 330px) {
		a, button, input {
			padding: 12px;
		}
	}
}

#topic {
	text-align: left;
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	padding: 15px 10px;
	overflow-y: scroll;
	p {
		font-size: var(--font-xs);
		font-weight: 500;
		color: var(--color-primary);
		white-space: nowrap;
		&+p {
			position: relative;
			padding-left: 20px;
			margin-left: 10px;
			&:before {
				border-top: solid 1px var(--color-primary);
				border-right: solid 1px var(--color-primary);
				width: 8px;
				height: 8px;
				position: absolute;
				content: "";
				top: 0;
				bottom: 0;
				transform: rotate(45deg);
				left: 0;
				margin: auto;
				transition: all 0.3s ease-out;
			}
		}
		a {
			color: var(--color-text);
		}
	}
	@media (min-width: 1000px) {
		overflow-y: default;
		padding: 15px;
		p {
			font-size: var(--font-s);
		}
	}
}
/*
flexContent
---------------------------*/
.flexContent-2 {
	>div {
		width: 100%;
		&+div {
			margin-top: 20px;
		}
	}
	@media (min-width: 1000px) {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		&.center {
			align-items: center;
		}
		>div {
			width: calc((100% - 32px) / 2);
			&+div {
				margin-top: 0;
			}
		}
		.od1 {
			order: 1;
		}
		.od2 {
			order: 2;
		}
	}
}
.flexContent-3 {
	>div {
		width: 70%;
		margin: auto;
		&+div {
			margin-top: 20px;
		}
	}
	@media (min-width: 1000px) {
		display: flex;
		justify-content: flex-start;
		align-items: stretch;
		flex-wrap: wrap;
		&.center {
			align-items: center;
		}
		>div {
			width: calc((100% - 64px) / 3);
			margin: inherit;
			margin-right: 32px;
			&+div {
				margin-top: 0;
			}
			&:nth-of-type(3n) {
				margin-right: 0;
			}
		}
		.od1 {
			order: 1;
		}
		.od2 {
			order: 2;
		}
	}
}
.circleTitle {
	position: relative;
	font-size: var(--font-xl);
	font-weight: 600;
	line-height: 1.4;
	padding-left: 22px;
	margin-bottom: 10px;
	* {
		font-weight: 600;
	}
	&.spaceType {
		margin-bottom: 20px;
	}
	&:before {
		content: "";
		display: block;
		width: 16px;
		height: 16px;
		border: 5px solid var(--color-primary);
		position: absolute;
		top: 5px;
		left: 0;
		margin: auto;
		border-radius: 50px;
	}
	@media (min-width: 1000px) {
		font-size: var(--font-3xl);
		padding-left: 32px;
		margin-bottom: 15px;
		&.spaceType {
			margin-bottom: 30px;
		}
		&:before {
			border: 8px solid var(--color-primary);
			width: 26px;
			height: 26px;
			top: 7px;
		}
	}
}

.circle {
	position: relative;
	font-size: var(--font-l);
	font-weight: 500;
	line-height: 1.4;
	padding-left: 24px;
	margin-bottom: 10px;
	&.spaceType {
		margin-bottom: 20px;
	}
	&:before {
		content: "";
		display: block;
		width: 16px;
		height: 16px;
		border: 5px solid var(--color-secondary);
		position: absolute;
		top: 3px;
		left: 0;
		margin: auto;
		border-radius: 50px;
	}
	@media (min-width: 1000px) {
		font-size: var(--font-xl);
		padding-left: 24px;
		&.spaceType {
			margin-bottom: 30px;
		}
		&:before {
			width: 18px;
			height: 18px;
			top: 5px;
		}
	}
}
.dotList {
	li {
		position: relative;
		line-height: 1.4;
		padding-left: 14px;
		&+li {
			margin-top: 10px;
		}
		&:before {
			content: "";
			display: block;
			width: 8px;
			height: 8px;
			background-color:  var(--color-primary);
			position: absolute;
			top: 8px;
			left: 0;
			margin: auto;
			border-radius: 50px;
		}
		.em {
			display: block;
			font-weight: 600;
			line-height: 1.4;
			padding-bottom: 8px;
		}
	}
}
/*
lowerMainVisual
---------------------------*/
#lowerMainVisual {
	position: relative;
	padding: 20px 20px 0;
	margin-bottom: 20px;
	.lowerMainVisualInner {
		background-color: var(--color-primary-bg);
		border-radius: var(--radius01);
		padding: 50px 4vw;
	}
	.pageTitle {
		position: relative;
		text-align: left;
		font-weight: 600;
		color: var(--color-secondary);
		font-size: var(--font-5xl);
		line-height: 1.5;
		.en {
			display: block;
			font-family: var(--accent-font);
			font-size: var(--font-xl);
			font-weight: 400;
			color: var(--color-primary);
			letter-spacing: .05em;
			padding-bottom: .5em;
		}
	}
	@media (min-width: 768px) {
		padding: 40px 40px 0;
	}
	@media (min-width: 1000px) {
		margin-bottom: 40px;
		.lowerMainVisualInner {
			background-color: var(--color-primary-bg);
			border-radius: var(--radius01);
			padding: 80px;
		}
		.pageTitle {
			font-size: min(3vw, var(--font-5xl));
		}
	}
}

/*
#bottomContact
---------------------------*/
#bottomContact {
	position: relative;
	text-align: center;
	margin-bottom: 60px;
	.contentBgBox {
		box-shadow: 10px 10px 0px 0px var(--color-secondary-bg);
	}
	.bottomContactBg {
		background-color: var(--color-primary-bg);
		padding: 15px 4vw;
		border-radius: var(--radius01);
	}
	.bottomContactInner {
		>div {
			padding: 15px 0;
			&+div {
				border-top: 1px solid var(--color-border-1);
			}
		}
	}
	.info {
		font-size: var(--font-2xl);
		font-weight: 500;
		line-height: 1.4;
		color: var(--color-primary);
		padding-top: 10px;
		* {
			font-weight: 500;
		}
	}
	.note {
		font-size: var(--font-s);
	}
	.tel {
		font-family: var(--accent-font);
		font-size: var(--font-3xl);
		a {
			position: relative;
			display: inline-block;
			font-weight: 500;
			padding-left: 40px;
			&:after {
				content: "";
				display: block;
				width: 30px;
				height: 30px;
				background-image: url(../img/common/icon-tel.svg);
				background-size: cover;
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				margin: auto;
			}
		}
	}
	ul {
		padding: 0 15px;
	}
	li {
		&+li {
			padding-top: .5em;
		}
	}
	dl {
		dt, dd {
			font-size: var(--font-xl);
			text-align: left;
			line-height: 1.6;
		}
		dt {
			position: relative;
			color: var(--color-primary);
			font-weight: 600;
			padding-left: 20px;
			margin-bottom: 10px;
			&:before {
				content: "";
				display: block;
				width: 16px;
				height: 16px;
				border: 5px solid var(--color-primary);
				position: absolute;
				top: 7px;
				left: 0;
				margin: auto;
				border-radius: 50px;
			}

		}
	}
	@media (min-width: 1000px) {
		margin-bottom: 120px;
		.bottomContactBg {
			padding: 45px 50px;
		}
		.bottomContactInner {
			display: flex;
			align-items: stretch;
			>div {
				width: 50%;
				padding: 20px 0;
				&+div {
					border-top: none;
					border-left: 1px solid var(--color-border-1);
				}
			}
		}
		.info {
			font-size: var(--font-3xl);
			padding-top: 0;
			padding-bottom: 1.5em;
		}
		.tel {
			font-family: var(--accent-font);
			font-size: var(--font-4xl);
			a {
				padding-left: 50px;
				&:after {
					width: 40px;
					height: 40px;
				}
			}
		}
		ul {
			display: inline-block;
		}
		dl {
			display: flex;
			align-items: center;
			dt, dd {
				line-height: 1.8;
			}
			dt {
				min-width: 140px;
				margin-bottom: 0;
				&:before {
					top: 12px;
				}
			}
		}
	}
}
/*
.speechBlock
---------------------------*/
.speechBlock {
	position: relative;
	text-align: center;
	margin-bottom: 15px;
	.speechBlockInner {
		background-color: #fff;
		border-top: 1px solid var(--color-primary);
		border-bottom: 1px solid var(--color-primary);
		padding: 15px 4%;
	}
	.speech {
		line-height: 1.8;
		font-size: var(--font-5xl);
		font-weight: 600;
		color: var(--color-secondary);
	}
	.line {
		position: relative;
		display: inline-block;
		margin-left: -13px;
		z-index: 3;
		&:after {
			content: "";
			display: block;
			position: absolute;
			left: 50%;
			bottom: 2px;
			width: 26px;
			height: 26px;
			background-color: #fff;
			border-top: 1px solid var(--color-primary);
			transform: rotate(-135deg);
		}
	}
	@media (min-width: 1000px) {
		margin-bottom: 40px;
		.speechBlockInner {
			padding: 30px;
		}
		.line {
			margin-left: -18px;
			&:after {
				bottom: -3px;
				width: 36px;
				height: 36px;
			}
		}
	}
}
/*
.read-content
---------------------------*/
.read-content {
	text-align: center;
	padding: 20px 0;
	&.shortType {
		padding: 0 0 20px;
	}
	.read-information {
		font-size: var(--font-l);
		text-align: left;
		line-height: 1.8;
		>* {
			font-weight: 500;
		}
		.info-em {
			background: linear-gradient(transparent 50%, rgb(243, 196, 4, .3) 0%);
		}
		&+.read-information {
			padding-top: 1em;
		}
	}
	@media (min-width: 1200px) {
		padding: 80px 0;
		&.shortType {
			padding: 0 0 40px;
		}
		.read-information {
			text-align: center;
			font-size: var(--font-xl);
		}
	}
}