@charset "utf-8";

/*-----------------------------
 common
-------------------------------*/
:root{
	--base: #6FBA2C;
	--base-rgb : rgb(111, 186, 44);
	--backcolor: #FAF6F2; /*背景色 var(--backcolor)*/
	--second   : #FFF343; /*黄色 var(--second)*/
	
	--gray1    : #707070; /*濃グレーバック var(--gray1)*/
	--gray2    : #F7F7F7; /*薄グレーバック var(--gray2)*/
	--border   : #D3D3D3; /*ボーダー var(--border)*/
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 50px;
}
html[lang="ja"] {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", Meiryo, sans-serif;
	/*letter-spacing: 0.12em;
	word-spacing: 0.16em;*/
}
@media (min-width:768px) {
	html {
		font-size: 17px;
		scroll-padding-top: 120px;
	}
}
body {
	font-feature-settings: "palt";
	color: #000000;
	font-weight: 400;
	text-align: left;
	margin: 22% auto 0;
}
body.menu_open {
	height: 100%;
	overflow: hidden;
}
@media (min-width:768px) {
	body {
		margin: 120px auto 0;
	}
}

:focus {
	outline: none;
}
:focus-visible {
	outline: 1px #0017C7 solid;
}
div.pdfemb-viewer {
	z-index: 1;
}

#root {
	overflow: hidden;
}

.wrap {
	margin: 0 auto;
	margin-inline: auto;
	position: relative;
}
.wrap .mincho {
	font-family: 'Yu Mincho','YuMincho', serif;
}
.wrap * {
	box-sizing: border-box;
}
main {
	padding-bottom: 6%;
}
#home main {
  padding-bottom: 0;
}
.contentWrap {
	max-width: 700px;
	margin: 0 auto;
}
.contentWrap img {
	max-width: 100%;
	height: auto;
}
.contentWrap a,
.contentWrap a::before,
.contentWrap a::after,
.contentWrap a img {
	text-decoration: underline;
	color: #0017C7;
}
.contentWrap a:hover {
	text-decoration: none;
}
.contentWrap a:hover img {
	opacity: 0.8;
}
@media (min-width:769px) {
	.contentWrap a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}

.contentWrap p {
	line-height: 2;
	letter-spacing: 0.1em;
}
.contentWrap p + p {
	margin-top: 1em;
}
.contentWrap li > p {
	margin-top: 0;
	padding-top: 0;
}
.contentWrap em {
	font-style: normal;
	letter-spacing: 0.2em;
}
.contentWrap sup {
	font-size: 60%;
	vertical-align: text-top;
}
.contentWrap p small {
	font-size: 80%;
}
.contentWrap .center {
	text-align: center !important;
	& img {
		margin: auto;
	}
}
.contentWrap .left {
	text-align: left !important;
}
.contentWrap .right {
	text-align: right !important;
}
.contentWrap .note {
	font-size: 80%;
	text-align: left;
	margin-top: 1.5em;
}
.contentWrap .note li {
	margin-left: 1em;
	text-indent: -1em;
	line-height: 2.5;
}

.flex {
	display: flex;
}
.flex.item2 {
	flex-wrap: wrap;
	gap: 20px;
	& > li {
    width: calc((100% - 20px * 1) / 2);
	}
}
.flex.item3 {
	flex-wrap: wrap;
	gap: 19px;
	& > li {
    width: calc((100% - 19px * 2) / 3);
	}
}
.flex.item4 {
	flex-wrap: wrap;
	gap: 12px;
	& > li {
    width: calc((100% - 12px * 3) / 4);
	}
}
@media (max-width:768px) {
	.flex.item2.sp1 li,
	.flex.item3.sp1 li,
	.flex.item4.sp1 li {
		width: 100%
	}
	.flex.item3.sp2 li,
	.flex.item4.sp2 li {
		width: calc((100% - 19px * 1) / 2);
	}
}
.flex.btn {
	justify-content: center;
}
.flex.btn li {
	margin: 0 2%;
}
.imgArea > div {
	display: table-cell;
	vertical-align: middle;
	margin: 0;
}
.required {
	color: #EB0000;
	font-weight: 400;
}
.themecolor {
	color: var(--base);
}

.accordion dt {
	-webkit-transition: all 0.3s ease-out;
		 -moz-transition: all 0.3s ease-out;
			-ms-transition: all 0.3s ease-out;
			 -o-transition: all 0.3s ease-out;
					transition: all 0.3s ease-out;
}
.accordion dt:hover {
	opacity: 0.9;
	cursor: pointer;
}

.fixct {
	display: block;
	width: 124px;
	height: 113px;
	position: fixed;
	top: 30%;
	right: 0;
}
.fixct:hover {
	opacity: 0.8;
}
.pagetop {
  display: none;
  position: fixed;
  top: 60%;
  right: 50px;
  z-index: 5;
}
.pagetop a:hover {
  opacity: 0.8;
}

@media (max-width:768px) {
	html {
		font-size: calc(100vw / 375 * 16); /* 16px相当 */
	}
	.pc {
		display:none !important;
	}
	.contentWrap p {
		letter-spacing: 0;
	}
	.contentWrap em {
		letter-spacing: 0.1em;
	}
	.pagetop {
		top: 60%;
		right: 25px;
	}
}
@media (min-width:769px) {
	.sp {
		display:none !important;
	}
}



/*-----------------------------
Header
-------------------------------*/
#header {
  width: 100%;
	position: relative;
	position: fixed;
	top: 0;
	z-index: 6;
}
#header #fixed {
  position: fixed;
  top: 0;
  left: 0; right: 0;
  width: 100%;
	max-width: 1100px;
  z-index: 100;
}
#header #fixed .flex {
	align-items: center;
	justify-content: space-between;
	padding: 18px 0 10px;
}
#header #fixed .flex::after {
	content: "";
	display: block;
	background: rgba(255,255,255,0.6);
	width: 100vw;
	height: 120px;
	position: fixed;
	top: 0;
	left: 0; right: 0;
	z-index: -1;
}
#header #fixed #subitem {
	display: block;
	text-align: right;
}

#header #logo {
	width: 190px;
	padding:0;
	margin: 0;
	color: #000;
	line-height: 1;
	& span {
		display: block;
		font-size: 13px;
		font-weight: 600;
		text-align:justify;
		text-align-last:justify;
		padding-bottom: 0.5em;
	}
	& a {
		display: block;
	}
}

#header .tel {
	color: var(--base);
	font-size: 1.42em;
	font-weight: 900;
	display: inline-block;
}
#header .tel span {
	position:relative;
	display: inline-block;
	vertical-align: middle;
	background: var(--base);
	border-radius: 50%;
	width: 45px;
	height: 45px;
	-webkit-tap-highlight-color: transparent;
	z-index: 120;
	padding-top: 6px;
}
#header .tel.pc span {
	margin-right: 0.3em;
}
#header .tel span img {
	width: 68%;
	height: auto;
	margin: auto;
}

#header #menu {
  position: relative;
  display: block;
}
#header #menu .navgroup .flex {
	justify-content: space-between;
	align-items: center;
	width: 90%;
	margin: 0 auto 8%;
}
.menu_open #header #menu .navgroup {
	overflow-y: auto;
	background: url("../images/nav_foot.png") top center no-repeat var(--backcolor);
	background-size: 60% auto;
}
.menu_open #header #menu .navgroup .foot {
	width: 100%;
	background: url("../images/footer_bg_sp.svg") top center no-repeat;
	background-size: cover;
	padding: 2em 1em 1em;
	margin: auto;
	position: fixed;
	z-index: 1;
	bottom: 0;
	left: 0; right: 0;
	& p {
		text-align: center;
		color: #fff;
		font-size: 0.85em;
		line-height: 1.3;
	}
	& a {
		color: #fff;
	}
	& a.map {
		display: inline-block;
		background: #FFF100;
		border-radius: 5px;
		color: var(--base);
		font-weight: 600;
		padding: 0 1em;
		line-height: 2;
	}
}

@media screen and (min-width: 769px) {
	#header {
		background: #fff;
	}
	#header #menu #menuwrap {
		display: flex;
		justify-content: flex-end;
		width: 100%;
		padding-top: 2px;
	}
	#header #menu #menuwrap li {
		text-align: center;
		position: relative;
	}
	#header #menu #menuwrap li + li {
		margin-left: 1em;
	}
	#header #menu #menuwrap li a {
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		height: 100%;
		padding: 0.4em 1em;
		overflow: hidden;
		color: #000;
		font-size: 0.88rem;
		font-weight: 700;
		line-height: 2.2;
		text-align: center;
		text-decoration: none;
		background: transparent;
		letter-spacing: 0.04em;
	}
	#header #menu #menuwrap li a span {
	}
	#header #menu #menuwrap li a::after {
		position: absolute;
		bottom: 0;
		left: 0;
		display: block;
		width: 100%;
		height: 3px;
		content: "";
		transform: scaleX(0);
		transform-origin: right top;
	}
	#header #menu #menuwrap li a::after {
		background-color: var(--base);
	}
	@media (any-hover: hover) {
		#header #menu #menuwrap li a:hover {
			color: #7F7F7F;
		}
		#header #menu #menuwrap li a::after {
			transition: transform 0.2s cubic-bezier(0.19, 1, 0.22, 1);
		}
		#header #menu #menuwrap li a:hover::after {
			transition: transform 0.4s cubic-bezier(0.9, 0, 0, 1);
			transform: scaleX(1);
			transform-origin: left top;
		}
	}
	/*---------------------------current-------------------------------------*/
	#mgmt #header #menu #menuwrap li:nth-child(1),
	#every #header #menu #menuwrap li:nth-child(2),
	#staff #header #menu #menuwrap li:nth-child(3),
	#diary #header #menu #menuwrap li:nth-child(4),
	#terms #header #menu #menuwrap li:nth-child(5),
	#qanda #header #menu #menuwrap li:nth-child(6) {
		background: rgba(111, 186, 44, .2);
	}
}
@media screen and (max-width: 1100px) {
	#header #fixed .flex {
    padding: 2%;
  }
}
@media screen and (max-width: 768px) {
	#header #menu {
		overflow: hidden;
	}
	#header #logo span {
		font-size: 0.7rem;
	}
	#header #menu .navgroup ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		gap: 30px;
	}
	#header #menu .navgroup ul li {
		width: calc((100% - 30px * 1) / 2);
		margin-top: 1%;
		text-align: left;
		opacity: 0;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
		position: relative;
	}
	#header #menu #menuwrap li a {
		display: block;
		background: #fff;
		border-radius: 10px;
		position: relative;
		padding: 4em 0em 1em;
		overflow: hidden;
		color: var(--base);
		font-size: 0.9rem;
		font-weight: 700;
		text-align: center;
		line-height: 1;
		text-decoration: none;
	}
}


#header #menu_sp {
	position:relative;
	display: block;
	background: var(--base);
	border-radius: 50%;
	width: 45px;
	height: 45px;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
	z-index: 120;
}
#header #menu_sp span {
	position: absolute;
	display: block;
	left: calc(50% - 11px);
	width: 22px;
	height: 3px;
	background-color: #fff;
	-webkit-transition: top 0.2s 0.5s,bottom 0.2s 0.5s,-webkit-transform 0.5s;
	transition: top 0.2s 0.5s,bottom 0.2s 0.5s,-webkit-transform 0.5s;
	transition: transform 0.5s,top 0.2s 0.5s,bottom 0.2s 0.5s;
	transition: transform 0.5s,top 0.2s 0.5s,bottom 0.2s 0.5s,-webkit-transform 0.5s;
}
#header #menu_sp span:first-of-type {
	top: 13px;
}
#header #menu_sp span:nth-child(2) {
	top: 22px;
}
#header #menu_sp span:last-of-type {
	bottom: 12px;
}
.menu_open #header {
	border-bottom: none;
}
.menu_open #header #menu .navgroup {
	position: fixed;
}
.menu_open #header #menu .navgroup ul li {
	opacity: 1;
	position: relative;
}
.menu_open #header #menu .navgroup ul li::before {
	content: "";
	display: block;
	width: 50%;
	padding-top: 50%;
	position: absolute;
	margin: auto;
	bottom: 2.5em;
	left: 0; right: 0;
	z-index: 1;
	pointer-events:none;
}
.menu_open #header #menu .navgroup ul li:nth-of-type(1) {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s;
	&::before {
		background: url("../images/nav1.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu .navgroup ul li:nth-of-type(2) {
	-webkit-transition-delay: 0.4s;
	transition-delay: 0.4s;
	&::before {
		background: url("../images/nav2.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu .navgroup ul li:nth-of-type(3) {
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s;
	&::before {
		background: url("../images/nav3.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu .navgroup ul li:nth-of-type(4) {
	-webkit-transition-delay: 0.6s;
	transition-delay: 0.6s;
	&::before {
		background: url("../images/nav4.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu .navgroup ul li:nth-of-type(5) {
	-webkit-transition-delay: 0.7s;
	transition-delay: 0.7s;
	&::before {
		background: url("../images/nav5.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu .navgroup ul li:nth-of-type(6) {
	-webkit-transition-delay: 0.8s;
	transition-delay: 0.8s;
	&::before {
		background: url("../images/nav6.png") no-repeat;
		background-size: contain;
	}
}
.menu_open #header #menu_sp {
	background: #F8ECDD;
}
.menu_open #header #menu_sp span {
	background-color: var(--base);
	-webkit-transition: top 0.2s,bottom 0.2s,-webkit-transform 0.5s 0.2s;
	transition: top 0.2s,bottom 0.2s,-webkit-transform 0.5s 0.2s;
	transition: top 0.2s,bottom 0.2s,transform 0.5s 0.2s;
	transition: top 0.2s,bottom 0.2s,transform 0.5s 0.2s,-webkit-transform 0.5s 0.2s;
}
.menu_open #header #menu_sp span:first-of-type {
	top: 21px;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}
.menu_open #header #menu_sp span:nth-child(2) {
	opacity: 0;
}
.menu_open #header #menu_sp span:last-of-type {
	bottom: 21px;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
@media screen and (max-width: 768px) {
	#header #logo {
		width: 46%;
		position: relative;
		z-index: 92;
	}
	#header #fixed .flex {
		padding: 2% 5%;
		background: #fff;
	}
	#header #fixed .flex::after {
		content: "";
		display: none;
	}
	#header #menu .navgroup {
		width: 100%;
		overflow: hidden;
		display: block;
		position: absolute;
		top: 80px;
		left: 0;
		padding: 25% 5% 230px;
		height: 0;
		-webkit-transition: height 0.5s;
		transition: height 0.5s;
		z-index: 91;
	}
	#header #menuwrap {
		margin-bottom: 10%;
	}
	#header .btn {
		width: 100%;
		text-align: center;
	}
}





/*-----------------------------
Footer
-------------------------------*/
#footer {
	/*padding-top: 120px;*/
	background-image: linear-gradient(180deg, rgba(255, 255, 255, 1) 50%, rgba(111, 186, 44, 1) 50%);
}
#info #footer {
	background-image: linear-gradient(180deg, rgba(250, 246, 242, 1) 50%, rgba(111, 186, 44, 1) 50%);
}
#footer .role_inner {
	background: url("../images/footer_bg.svg") top center no-repeat;
	background-size: cover;
	padding: 65px 1% 0;
	color: #ffffff;
}
#home #footer .role_inner {
	background-color: #F4FBE3;
}
#footer .contentWrap {
	max-width: 1100px;
}
#footer #organization {
	text-align: center;
	& span {
		display: block;
		padding-bottom: 0.5em;
		color: #ffffff;
		font-size: 13px;
		font-weight: 600;
		text-align:justify;
		text-align-last:justify;
	}
}
#footer #organization img {
	max-width: 216px;
	margin: auto;
}
#footer #add {
	padding-top: 1.5em;
}
#footer #fnav {
	display: flex;
}
#footer #fnav ul + ul {
	margin-left: 2em;
}
#footer #copyright {
	background: var(--base);
	text-align: center;
  font-size: 0.875rem;
	color: #ffffff;
  letter-spacing: 0.04em;
	line-height: 2.857em;
}

#footer .wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
#footer .wrap a {
	color: #ffffff;
}
#footer .wrap ul {
	margin-bottom: 2em;
	padding-left: 1em;
	font-size: 0.875rem;
	border-left: 2px #fff dotted;
}
#footer .wrap ul li + li {
	margin-top: 0.4em;
}
#footer .wrap li a {
  text-align: left;
	text-decoration: none;
	color: #ffffff;
	font-weight: 400;
}
#footer .wrap li a:hover {
	text-decoration: underline;
}

#footer .wrap + .flex {
	margin-top: 1em;
	font-size: 18px;
	align-items: center;
	justify-content: space-between;
	flex-direction: row-reverse;
}
#footer .wrap + .flex a {
	margin-left: 1em;
}
#footer .flex img {
	vertical-align: middle;
}

@media screen and (min-width: 769px) {
	#footer #add {
		padding-right: 5em;
	}
}
@media screen and (max-width: 768px) {
  #footer {
  }
	#footer .role_inner {
		background: url("../images/footer_bg_sp.svg") top center no-repeat;
		background-size: cover;
		padding: 5% 8% 0;
	}
	#footer #organization {
		width: 60%;
		margin: auto;
		padding: 10% 0 5%;
		& span {
			font-size: 0.8rem;
		}
	}
	#footer #organization img {
		max-width: 100%;
		margin: auto;
	}
	#footer #add {
		text-align: center;
		padding: 0;
		margin-bottom: 2em;
	}
	#footer #copyright {
		font-size: 0.7rem;
	}
	#footer #fnav {
		padding-left: 2px;
	}
	#footer .wrap a {
		text-decoration: underline !important;
	}
	#footer .wrap div {
		width: 100%;
	}
	#footer .wrap ul {
		justify-content: center;
		width: 100%;
		margin-bottom: 2em;
	}
	#footer .wrap li a {
		font-size: 0.8rem;
	}
}





/*-----------------------------
mv
-------------------------------*/
#home .mv {
	background: var(--backcolor);
	padding: 0;
}
#home .mv .contentWrap {
	max-width: 1100px;
	padding: 0;
}
#home .mv dl {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#home .mv dl dt {
	width: 33%;
}
#home .mv dl dd {
	width: 66.5%;
	& img {
		margin-bottom: -10%;
	}
}
#home .mv h1 {
	padding: 1.5em 0 0;
	margin: 0 auto 1em;
	color: var(--base);
	font-size: 1.3529rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1.3;
	text-align: left;
	background: none;
	& em {
		font-size: 2.47rem;
		letter-spacing: 0.15em;
	}
}
#home .mv p {
	line-height: 1.65;
	font-weight: 700;
	letter-spacing: 0.18em;
}

@media (min-width: 769px) and (max-width: 1100px) {
}
@media screen and (max-width: 768px) {
	#home .mv h1 {
		padding: 0.5em 0 0;
		& em {
			font-size: 2rem;
		}
	}
	#home .mv dl {
		flex-direction: column-reverse;
	}
	#home .mv dl dt {
		width: 100%;
		padding: 0 7% 5%;
	}
	#home .mv dl dd {
		width: 100%;
		& img {
			max-width: 138%;
			margin: 0 -25% 0 -13%;
		}
	}
	#home .mv p {
		letter-spacing: 0.15em;
	}
}



/*-----------------------------
section setting
-------------------------------*/
section {
	padding: 0 5%;
}
main h1 {
	padding: 1.5em 1em;
	margin: 0 auto 15%;
	color: #fff;
	font-size: 1.7647rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	line-height: 1.2;
	text-align: center;
	word-break: keep-all;
	text-wrap: balance;
	background: url("../images/h1_bg.png") center center no-repeat;
	background-size: cover;
	position: relative;
}
main h1 span {
	display: inline-block;
}
main h1 img {
	height: auto;
	position: absolute;
	pointer-events:none;
}
#mgmt main h1 img {
	width: 460px;
	top: 50%;
	right: 60%;
}
#every main h1 img {
	width: 451px;
	top: 35%;
	right: 45%;
}
#staff main h1 img {
	width: 482px;
	top: 35%;
	right: 45%;
}
#diary main h1 img {
	width: 390px;
	top: 15%;
	right: 40%;
}
#terms main h1 img {
	width: 415px;
	top: 58%;
	right: 65%;
}
#qanda main h1 img {
	width: 451px;
	top: 58%;
	right: 62%;
}
#privacy main h1 img {
	width: 489px;
	top: 45%;
	right: 65%;
}
#info main h1 {
	padding: 3em 1em 1.5em;
	margin: 0 auto 1%;
	color: #000;
	background: none;
	& em {
		display: inline-block;
		text-align: center;
		font-style: normal;
		padding: 0.5em 3em;
		background: url("../images/notice1.png") center left no-repeat, url("../images/notice2.png") center right no-repeat;
	}
}
h2 {
	color: var(--base);
	font-size: 1.75rem;
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.15em;
	text-align: center;
	word-break: keep-all;
	margin-bottom: 2.75rem;
}
h2 span {
	display: inline-block;
	font-size: 73%;
}
h3 {
	color: var(--base);
	font-size: 1.1764rem;
	line-height: 1.75;
	letter-spacing: 0.15em;
	text-align: center;
	word-break: auto-phrase;
	margin-bottom: 1.875rem;
}
h3 span {
	background:linear-gradient(transparent 70%, #FFF56F 70%);
}
h3 img {
	margin: 0 auto 10px;
}
h4 {
	font-size: 1.25rem;
	line-height: 2.2;
	word-break: auto-phrase;
	margin-bottom: 0.625rem;
}

p.lead {
	font-size: 1.125rem;
}

.soon {
	padding: 50px 30px 100px;
	text-align: center;
}

@media screen and (max-width: 768px) {
	main h1 {
		font-size: 1.47rem;
		margin: 0 auto 35%;
	}
	#mgmt main h1 img {
		width: 70%;
		top: 80%;
		right: 38%;
	}
	#every main h1 img {
		width: 70%;
		top: 70%;
		right: auto;
		left: 36%;
	}
	#staff main h1 img {
		width: 70%;
		top: 70%;
		right: auto;
		left: 36%;
	}
	#diary main h1 img {
		width: 50%;
		top: 76%;
		right: auto;
		left: 45%;
	}
	#terms main h1 img {
		width: 70%;
		top: 74%;
		right: 45%;
	}
	#qanda main h1 img {
		width: 65%;
		top: 80%;
		right: 35%;
	}
	#privacy main h1 img {
		width: 70%;
		top: 70%;
		right: 40%;
	}
	h2 {
		font-size: 1.375rem;
		margin-bottom: 1.875rem;
	}
	h3 {
		font-size: 1.25rem;
	}
	h4 {
		font-size: 1.125rem;
	}
}

/* -----------------Margin---------------------- */
.mb10 {
	margin-bottom: 10px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mb50 {
	margin-bottom: 50px !important;
}
.mb60 {
	margin-bottom: 60px !important;
}
.mb100 {
	margin-bottom: 100px !important;
}
@media screen and (max-width: 768px) {
	.mb10 {
		margin-bottom: 4% !important;
	}
	.mb30 {
		margin-bottom: 10% !important;
	}
	.mb50 {
		margin-bottom: 13% !important;
	}
	.mb60 {
		margin-bottom: 20% !important;
	}
	.mb100 {
		margin-bottom: 26% !important;
	}
}
.mt10 {
	margin-top: 10px !important;
}
.mt30 {
	margin-top: 30px !important;
}
.mt50 {
	margin-top: 50px !important;
}
.mt60 {
	margin-top: 60px !important;
}
.mt100 {
	margin-top: 100px !important;
}
@media screen and (max-width: 768px) {
	.mt10 {
		margin-top: 4% !important;
	}
	.mt30 {
		margin-top: 10% !important;
	}
	.mt50 {
		margin-top: 13% !important;
	}
	.mt60 {
		margin-top: 20% !important;
	}
	.mt100 {
		margin-top: 26% !important;
	}
}



/* -----------------Button---------------------- */
a.btn {
	display: inline-block;
	text-align: left;
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none !important;
	padding: 1.2em 2em 1.2em 2em;
	background-color: var(--base);
	border-radius: 10px;
	position: relative;
}
a.btn:hover {
	cursor: pointer;
	opacity: 0.8;
}



.line {
	margin-top: 1.875rem;
	border-bottom: 1px var(--border) solid;
}
.linedot {
	margin-top: 1.875rem;
	border-bottom: 1px var(--border) dashed;
}
.txtbox {
	background-color: var(--gray2);
	padding: 1.25rem;
	margin-top: 1.875rem;
	& .header {
		background-color: var(--gray1);
		padding: 0.5em;
		color: #fff;
		font-weight: 700;
		line-height: 2.2;
	}
}
.table {
	margin-top: 1rem;
	border-collapse: collapse;
	border: 1px var(--border) solid;
	& th, & td {
		padding: 1em;
		border: 1px var(--border) solid;
		line-height: 2.2;
	}
	& thead th {
		background-color: var(--gray1);
		color: #fff;
	}
}
.table.striped {
	& th, & td {
		border-top: none;
		border-bottom: none;
	}
	& tr:nth-child(even) {
		background-color: var(--gray2);
	}
}
@media screen and (max-width: 768px) {
  .table {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
  }
  .table .fixed {
    position: sticky;
    left: 0;
  }
}

.imgbox {
	max-width: 900px;
	margin: 0.625rem auto 0;
}
.imgbox2 {
	display: flex;
	margin: 0.625rem auto 0;
	flex-wrap: wrap;
	gap: 20px;
	& > li {
    width: calc((100% - 20px * 1) / 2);
	}
}
.imgbox3 {
	display: flex;
	margin: 0.625rem auto 0;
	flex-wrap: wrap;
	gap: 19px;
	& > li {
    width: calc((100% - 19px * 2) / 3);
	}
}
.imgbox4 {
	display: flex;
	margin: 0.625rem auto 0;
	flex-wrap: wrap;
	gap: 12px;
	& > li {
    width: calc((100% - 12px * 3) / 4);
	}
}
.imgbox-txt-left,
.imgbox-txt-right {
	display: flex;
	margin: 0.625rem auto 0;
	flex-wrap: wrap;
	gap: 20px;
	& > li {
    width: calc((100% - 20px * 1) / 2);
	}
}
@media (max-width:768px) {
	.imgbox-txt-left li,
	.imgbox-txt-right li {
		width: 100%
	}
}


.float_img {
	overflow: hidden;
}
.img_left {
	float: left;
	margin-right: 1em;
	margin-bottom: 1em;
}
.img_right {
	float: right;
	margin-left: 1em;
	margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
	.img_left {
		display: block;
		width: 50%;
		height: auto;
		float: none;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 1em;
	}
	.img_right {
		display: block;
		width: 50%;
		height: auto;
		float: none;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 1em;
	}
}
.videowrap {
	max-width: 768px;
	margin: 0.625rem auto 0;
	& .video {
		width: 100%;
		aspect-ratio: 16 / 9;
		& iframe {
			width: 100%;
			height: 100%;
		}
	}
	& .caption {
		margin-top: 0;
		line-height: 2.2;
	}
}



/*-----------------------------
HOME
-------------------------------*/
#home {
}
#home .origin {
	padding: 200px 0 750px;
}
#home .origin .contentWrap {
	position: relative;
}
#home .origin .kiwi1 {
	width: 312px;
	position: absolute;
	bottom: 95%; left: -8%;
}
#home .origin .kiwi2 {
	width: 242px;
	position: absolute;
	top: 90%; left: -30%;
}
#home .origin .kiwi3 {
	width: 622px;
	position: absolute;
	top: 75%; right: -20%;
}
#home .origin .kodomo {
	width: 542px;
	position: absolute;
	margin: auto;
	left: 0; right: 0;
	top: 200%;
}
#home .place {
	padding: 0 0 5%;
}
@media screen and (max-width: 768px) {
	#home .origin {
		padding: 45% 5% 45%;
	}
	#home .origin .kiwi1 {
		width: 60%;
		position: absolute;
		bottom: 102%; left: 5%;
	}
	#home .origin .kiwi2 {
		width: 80%;
		position: absolute;
		top: 53%; left: 5%;
	}
	#home .origin .kiwi3 {
		width: 86%;
		position: absolute;
		top: 100%; right: 10%;
	}
	#home .origin .kodomo {
		width: 100%;
		position: relative;
		margin: 50% auto 0;
	}
	#home .place {
		padding: 0 5% 5%;
	}
	#home .place .center {
		padding: 0 10% 10%;
	}
}

#home .info {
	padding: 5% 0;
	background: var(--backcolor);
}
#home .info .contentWrap {
  max-width: 920px;
}
#home .info h2 {
	color: #000;
	& em {
		display: inline-block;
		text-align: center;
		padding: 0.5em 3em;
		background: url("../images/notice1.png") center left no-repeat, url("../images/notice2.png") center right no-repeat;
	}
}
#home .info .list {
	border-top: var(--base) 2px dashed;
}
#home .info .list dl {
	border-bottom: var(--base) 2px dashed;
	padding: 1.8em;
}
#home .info .list dl dt {
	float: left;
	clear: both;
	width: 8em;
}
#home .info .list dl dd {
	padding-left: 8em;
}
#home .info .list dl a {
	color: var(--base);
	font-weight: 700;
	letter-spacing: 0.1em;
}
#home .info a.btn {
	padding: 1em 2em 2em 2em;
}
#home .info a.btn img {
	position: absolute;
	top: 20px;
	left: 60%;
	pointer-events:none;
}
#home .info a.btn::after {
	content: "";
	display: inline-block;
  width: 32px;
	height: 14px;
  background-color: var(--second);
  clip-path: polygon(0 39.3%, 62.1% 39.3%, 62.1% 0, 100% 50%, 62.1% 100%, 62.1% 60.7%, 0 60.7%);
	position: absolute;
	margin: auto;
	left: 0; right: 0;
	bottom: 16px;
}
@media screen and (max-width: 768px) {
	#home .info {
		padding: 10% 5% 15%;
	}
	#home .info h2 em {
		font-size: 95%;
	}
	#home .info .list dl dt {
		float: none;
		width: 100%;
		text-align: center;
		padding-bottom: 0.5em;
	}
	#home .info .list dl dd {
		padding: 0;
	}
	#home .info a.btn img {
		width: 80%;
		top: 80%;
		left: 0;
		right: 0
	}
}

#home .access {
	padding: 100px 0 5%;
}
#home .access .contentWrap {
	max-width: 860px;
}
#home .access h3 {
	margin: 0 auto 1.5em;
	text-align: left;
}
#home .access .flex {
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 3.125em;
	position: relative;
	padding-top: 1em;
}
#home .access .flex .map {
	width: 60%;
}
#home .access .flex .contactbox {
	width: 36%;
}
#home .access .flex .contactbox p {
	width: 70%;
	margin-bottom: 1em;
}
#home .access dl {
	display: block;
	font-size: 80%;
	line-height: 1.6;
	margin-bottom: 1em;
}
#home .access dl.add {
	font-size: 90%;
}
#home .access dl dt {
	font-weight: 700;
}
#home .access dl.train {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
#home .access dl.train dt {
	width: 18%;
}
#home .access dl.train dd {
	width: 82%;
}
#home .access iframe {
	border: 1px var(--border) solid;
	width: 100%;
	height: auto;
	aspect-ratio: 5 / 4;
	max-width: 506px;
	display: block;
	margin: auto;
}
#home .access .relevance {
	display: flex;
	justify-content: space-between;
	gap: 22px;
}
#home .access .relevance li {
	width: calc((100% - 22px * 2) / 3);
}
#home .access .relevance a {
	display: block;
	background: url("../images/btn.png") center center no-repeat;
	background-size: contain;
	color: var(--base);
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 1.5em 1.2em 1.9em 1em;
}
#home .access .relevance a:hover {
	opacity: 0.6;
}

@media screen and (max-width: 768px) {
	#home .access {
		padding: 15% 5% 5%;
	}
	#home .access .contentWrap {
	}
	#home .access .flex .contactbox p {
		width: 60%;
		margin: 0 auto 1em;
	}
	#home .access .flex {
		flex-direction: column-reverse;
	}
	#home .access .flex .map {
		width: 100%;
	}
	#home .access .flex .contactbox {
		width: 90%;
		margin: 0 auto 1em;
	}
	#home .access .relevance {
		width: 70%;
		margin: auto;
		flex-direction: column;
	}
	#home .access .relevance li {
		width: 100%;
	}
}


#home .document {
	padding: 100px 0 7%;
	background: #F4FBE3;
}
#home .document h2 {
	font-size: 1.235rem;
	margin-bottom: 1rem;
}
#home .document h3 {
	font-size: 1.235rem;
	margin-bottom: 1rem;
}
#home .document ol {
	line-height: 2.5;
	list-style-type: decimal;
	font-size: 90%;
	margin-left: 1.4em;
}
#home .document a.pdf {
	font-weight: 600;
	color: #000000 !important;
	padding-right: 2em;
	background: url("../images/icon_blank.svg") center right no-repeat;
	background-size: auto 70%;
}
@media screen and (max-width: 768px) {
	#home .document {
		padding: 15% 5% 8%;
	}
}



/*-----------------------------
management
-------------------------------*/
#mgmt {}
#mgmt .contentWrap {
}
#mgmt .signature {
	text-align: right;
	margin-bottom: 10%;
}
#mgmt .signature em {
	font-size: 200%;
}
#mgmt .objectives {
	padding: 14% 5%;
	margin-bottom: 10%;
	background: url("../images/mgmt_back.svg") center center no-repeat;
	background-size: contain;
}
#mgmt .objectives .kiwi1 {
	width: 387px;
	position: absolute;
	top: 130%; left: 10%;
}
#mgmt .operation {
	background: var(--backcolor);
	margin-top: 5%;
	padding: 5% 0;
}
#mgmt .operation ul {
	border-top: var(--base) 1px dotted;
	position: relative;
}
#mgmt .operation ul::after {
	content: "";
	display: block;
	background: url("../images/mgmt_illust.png") no-repeat;
	background-size: contain;
	width: 340px;
	aspect-ratio: 1 / 1;
	position: absolute;
	top: 73%; left: 70%;
}
#mgmt .operation li {
	border-bottom: var(--base) 1px dotted;
	padding: 0.5em 1em;
	display: flex;
	align-items: center;
	& img {
		margin-right: 45px;
	}
	& p {
		line-height: 1.5;
	}
}
#mgmt .activity {
	margin-top: 5%;
	padding: 5% 5% 10%;
}
#mgmt .facility {
	background: var(--backcolor);
	margin-top: 5%;
	padding: 5% 0;
	position: relative;
}
#mgmt .facility dl {
	border-top: var(--base) 1px dotted;
}
#mgmt .facility dl dt {
	float: left;
	clear: both;
	width: 8em;
	padding: 1em;
	color: var(--base);
	font-weight: 600;
}
#mgmt .facility dl dd {
	padding: 1em 1em 1em 8em;
	border-bottom: var(--base) 1px dotted;
}
#mgmt .facility .kiwi2 {
	width: 419px;
	position: absolute;
	bottom: 85%; right: 52%;
	& img {
		height: auto;
	}
}
#mgmt .partner {
	padding: 10% 5% 5%;
}
#mgmt .partner strong {
	font-size: 120%;
}
#mgmt .partner a.pdf {
	font-weight: 600;
	color: var(--base);
	padding-right: 2em;
	background: url("../images/icon_blank.svg") center right no-repeat;
	background-size: auto 70%;
}


@media screen and (min-width: 769px) {
	#mgmt .activity .flex {
		justify-content: space-between;
		& p {
			width: 60%;
		}
		& figure {
			width: 36%;
			& img {
				max-width: 200%;
				margin-top: -30%;
			}
		}
	}
}
@media screen and (max-width: 768px) {
	#mgmt .objectives {
		padding: 50% 5%;
		background: url("../images/mgmt_back_sp.svg") top center no-repeat;
		background-size: cover;
	}
	#mgmt .objectives .kiwi1 {
		display: none;
	}
	#mgmt .operation {
		padding: 5% 0 50%;
	}
	#mgmt .operation li img {
		margin-right: 20px;
	}
	#mgmt .operation ul::after {
		width: 60%;
		top: 105%; left: 20%;
	}
	#mgmt .activity {
		margin-top: 20%;
		padding: 10% 5% 30%;
	}
	#mgmt .activity .flex {
		display: block;
		& figure {
			margin-top: 10%;
		}
	}
	#mgmt .facility {
		padding: 5% 0 15%;
	}
	#mgmt .facility dl dt {
		width: 7em;
	}
	#mgmt .facility dl dd {
		padding: 1em 1em 1em 7em;
	}
	#mgmt .facility .kiwi2 {
		width: 60%;
		position: absolute;
		bottom: 90%; right: 40%;
	}
}



/*-----------------------------
terms
-------------------------------*/
#terms {}
#terms .contentWrap {
}
#terms .flow  {
	padding: 0 5% 10%;
}
#terms .flow dl {
	background: var(--backcolor);
	border: var(--base) 1px dotted;
	border-radius: 20px;
	padding: 20px;
	position: relative;
	display: flex;
	& dt {
		width: 20%;
		& img {
			margin: -30px auto 0;
		}
	}
	& dd {
		width: 80%;
		line-height: 1.8;
		& span {
			display: inline-block;
			color: var(--base);
			width: 6em;
		}
	}
}
#terms .flow dl .kiwi1 {
	width: 124px;
	position: absolute;
	top: 80%; right: 10%;
	z-index: 1;
}
#terms .flow dl .kiwi2 {
	width: 100px;
	position: absolute;
	top: 50%; left: 10%;
	z-index: 1;
}
#terms .flow dl .kiwi3 {
	width: 134px;
	position: absolute;
	top: -20%; right: 5%;
	z-index: 1;
}
#terms .flow dl .kiwi4 {
	width: 100px;
	position: absolute;
	top: 70%; right: 2%;
	z-index: 1;
}
#terms .flow dl + dl {
	margin-top: 8%;
}
#terms .flow a {
	color: #000;
}
#terms .canuse {}
#terms .canuse ul {
	border-top: var(--base) 1px dotted;
	position: relative;
}
#terms .canuse li {
	border-bottom: var(--base) 1px dotted;
	padding: 0.5em 1em;
	display: flex;
	align-items: center;
	& img {
		margin-right: 20px;
	}
	& p {
		line-height: 1.5;
	}
}
#terms .canuse figure {
	position: relative;
}
#terms .canuse figure .kiwi5 {
	width: 430px;
	position: absolute;
	top: 66%; left: 75%;
}

#terms .usagefee {
	padding: 10% 5% 5%;
}
#terms .usagefee li {
	border-bottom: var(--base) 1px dotted;
	padding: 0.5em 1em;
	display: flex;
	align-items: center;
	& img {
		margin-right: 20px;
	}
	& p {
		line-height: 1.5;
	}
}


@media screen and (min-width: 769px) {
}
@media screen and (max-width: 768px) {
	#terms .flow {
		padding: 0 0 20%;
	}
	#terms .flow dl {
		border-radius: 0;
		display: block;
		& dd {
			width: 100%;
			& strong {
				display: block;
				padding-left: 25%;
				margin-top: -2.5em;
			}
		} 
	}
	#terms .flow dl .kiwi2 {
		display: none;
	}
	#terms .flow dl .kiwi3 {
		width: 30%;
		top: -40%; right: 3%;
	}
	#terms .flow dl .kiwi4 {
		width: 30%;
		top: 84%; right: 2%;
	}
	#terms .canuse figure .kiwi5 {
		width: 80%;
		top: 90%; left: 10%;
	}
	#terms .usagefee {
		padding: 30% 5% 5%;
	}
}





/*-----------------------------
privacy
-------------------------------*/
#privacy .other {
	padding-bottom: 5%;
}
#privacy .other h2 {
	font-size: 1.65rem;
	margin-bottom: 0.5em;
}
@media screen and (min-width: 769px) {
}
@media screen and (max-width: 768px) {
	#privacy .other h2 {
		font-size: 1.2rem;
	}
}




/*-----------------------------
information
-------------------------------*/
#info main {
	background: var(--backcolor);
}
#info .list {
	border-top: var(--base) 2px dashed;
}
#info .list dl {
	border-bottom: var(--base) 2px dashed;
	padding: 1.8em;
}
#info .list dl dt {
	float: left;
	clear: both;
	width: 8em;
}
#info .list dl dd {
	padding-left: 8em;
}
#info .list dl a {
	color: var(--base);
	font-weight: 700;
	letter-spacing: 0.1em;
}
#info a.btn {
	padding: 1em 2em 2em 2em;
}
#info .list + p a.btn {
	background: #fff;
	color: var(--base);
}
#info a.btn img {
	position: absolute;
	top: 20px;
	left: 60%;
	pointer-events:none;
}
#info a.btn::after {
	content: "";
	display: inline-block;
  width: 32px;
	height: 14px;
  background-color: var(--second);
  clip-path: polygon(0 39.3%, 62.1% 39.3%, 62.1% 0, 100% 50%, 62.1% 100%, 62.1% 60.7%, 0 60.7%);
	position: absolute;
	margin: auto;
	left: 0; right: 0;
	bottom: 16px;
}
#info .post h2 {
	color: var(--base);
	font-size: 1.34rem;
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.1em;
	margin-bottom: 2rem;
}
#info .post h2 span {
	display: block;
	font-size: 73%;
	font-weight: 400;
	color: #000;
	padding-bottom: 1em;
}
#info .post figure {
	margin-bottom: 5%;
}
@media screen and (max-width: 768px) {
	#info main {
		padding-bottom: 25%;
	}
	#info h2 em {
		font-size: 95%;
	}
	#info .list dl dt {
		float: none;
		width: 100%;
		text-align: center;
		padding-bottom: 0.5em;
	}
	#info .list dl dd {
		padding: 0;
	}
	#info a.btn img {
		width: 80%;
		top: 80%;
		left: 0;
		right: 0
	}
	#info .post h2 {
		font-size: 1.2rem;
	}
}
@media screen and (min-width: 769px) {
}
@media screen and (max-width: 768px) {
}


































