@charset "UTF-8";
/*
  Josh's Custom CSS Reset
  https://www.joshwcomeau.com/css/custom-css-reset/
*/
*, *::before, *::after {
	box-sizing: border-box
}
* {
	margin: 0
}
html, body {
	height: 100%
}
body {
	line-height: 1.5;
	-webkit-font-smoothing: antialiased
}
img, picture, video, canvas, svg {
	display: block;
	max-width: 100%
}
input, button, textarea, select {
	font: inherit
}
p, h1, h2, h3, h4, h5, h6 {
	overflow-wrap: break-word
}
#root, #__next {
	isolation: isolate
}
html {
	font-size: 62.5%;
}
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
}
ul {
	margin: 0;
	padding: 0;
}
li {
	list-style-type: none;
}
.list-disc li {
	list-style: disc;
	margin-left: 1em;
}
.clearfix:after {
	content:" ";
  display:block;
  clear:both;
}
a:link {
	text-decoration: none;
}
a:hover, a:active {
	text-decoration: underline;
}
main p.main_bt a img:hover {
	opacity: 0.8;
}
table {
	border-collapse: collapse;
}
.text-tate {
	writing-mode: vertical-rl;
}
.w40{
	width: 40%
}
.w50{
	width: 50%
}
.w60{
	width: 60%
}
@media screen and (min-width: 768px) {
	.sp_only {
		display: none;
	}
	.page_bg {
		background: #f6f3e2;
	}
	.wrapper {
		position: relative;
		width: 90%;
		max-width: 1200px;
		margin: 0 auto;
	}
	.contents {
		width: 60%;
		margin: 30px auto;
		max-width: 500px;
	}
	.contents2 {
		width: 74%;
		margin: 0 auto;
		max-width: 888px;
	}
	.bg_white {
		background-color: #fff;
		padding: 00px 0px 0px;
	}
	.bg_green::before {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-top.png") 0 0 repeat-x;
		background-size: 1200px auto;
	}
	.bg_green.bg_green__top-white::before {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-top.jpg") 0 0 repeat-x;
		background-size: 1200px auto;
	}
	.bg_green::after {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-bottom.png") 0 0 repeat-x;
		background-size: 1200px auto;
	}
	.bg_green--last {
		background: #8ee27a;
	}
	.page_bg .bg_green::before {
		content: "";
		display: block;
		background: url("../images/common/bg-page-top.png") 0 0 repeat-x;
		background-size: 1200px auto;
		height: 143px;
	}
	.page_bg .bg_green::after {
		background: none;
	}
	.page_bg .bg_green__flower-right > div.bg_green__bottom {
		background: url("../images/common/bg-page-bottom.png") center bottom repeat-x;
		background-size: 1200px auto;
		padding-bottom: 50px;
	}
	.bg_green--header::after {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-bottom.png") 0 bottom repeat-x;
		background-size: 1200px auto;
	}
	.bg_green--header {
		margin-bottom: 100px;
	}
	.bg_green__inner {
		background: #8ee27a;
		padding: 0px 0 0 0;
	}
	.bg_green__inner_top {
		background: #8ee27a;
		padding: 50px 0 60px 0;
	}
	.bg_green__inner_top p:nth-of-type(1) {
		padding-bottom: 40px;
	}
	.bg_green__flower-left {
		background: url("../images/common/flowers.png") 1% 0 repeat-y;
		background-size: 115px auto;
	}
	.bg_green__flower-right {
		background: url("../images/common/flowers.png") 99% 0 repeat-y;
		background-size: 115px auto;
	}
	.bg_green .wrapper {
		padding-top: 100px;
	}
	.site-footer {
		background: #106b1b;
		padding: 100px 4% 20px 4%;
		color: #fff;
	}
	.site-footer a {
		color: #fff;
	}
	.site-footer__container {
		display: grid;
		grid-template-columns: 22% 26% 26% 26%;
		margin-bottom: 100px;
	}
	.site-footer__item {
		border-left: solid 1px #fff;
		padding: 0 30px;
		font-size: 1.6rem;
	}
	.site-footer__item:first-child {
		align-self: center;
		border: none;
	}
	.site-footer__item .site-footer__item__flower {
		padding-left: 30px;
		font-weight: bold;
	}
	.site-footer__item .site-footer__item__flower-pink {
		background: url("../images/common/flower-pink.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__item__flower-blue {
		background: url("../images/common/flower-blue.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__item__flower-yellow {
		background: url("../images/common/flower-yellow.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__title {
		width: 150px;
	}
	.site-footer__item > h4 {
		margin-bottom: 1.3em;
	}
	.site-footer__item ol {
		margin-left: calc(1em + 30px);
		padding: 0;
	}
	.site-footer__item ol li {
		list-style-type: decimal;
		margin-bottom: 10px;
	}
	.site-footer__copyright {
		font-size: 1.4rem;
		flex-direction: row-reverse;
	}
	.site-footer__copyright p:first-child {
		text-align: left;
	}
	.site-footer__copyright p:last-child {
		text-align: left;
	}
}
@media screen and (min-width: 980px) and (max-width:1200px) {
	.site-header__logo-area, .wrapper, .site-header__navi-area ul {
		width: 90%; 
		max-width: 1200px; 
	}
	.site-footer__item {
		border-left: solid 1px #fff;
		padding: 0 30px;
		font-size: 1.6rem;
	}
	.site-footer__item:first-child {
		padding: 0;
	}
	.site-footer__container {
		display: grid;
		grid-template-columns: 18% 27% 28% 27%;
		margin-bottom: 100px;
	}
	.site-footer__item:last-child {
		padding-right: 0;
	}
	.site-footer__copyright p:last-child {
		margin-right: 25px;
	}
	/* width: 980px-1200px */
}
@media screen and (max-width:980px) {
	.site-header__logo-area, .wrapper, .site-header__navi-area ul {
		width: 90%; /*pl*/
	}
	.site-footer {
		background: #106b1b;
		padding: 40px 4% 40px 4%;
		color: #fff;
	}
	.site-footer a {
		color: #fff;
	}
	.site-footer__container {
		display: grid;
		grid-template-columns: 31% 38% 31%;
		margin-bottom: 40px;
	}
	.site-footer__item {
		font-size: 1.3rem;
		border: none;
	}
	.site-footer__item:first-child {
		align-self: center;
		border-bottom: solid 1px #fff;
		grid-column-start: 1;
		grid-column-end: 4;
		margin-bottom: 20px;
		padding: 0 0 20px 0;
	}
	.site-footer__item:nth-child(3) {
		padding: 0 10px;
	}
	.site-footer__item .site-footer__item__flower {
		padding: 3px 0 3px 30px;
		font-weight: bold;
	}
	.site-footer__item .site-footer__item__flower-pink {
		background: url("../images/common/flower-pink.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__item__flower-blue {
		background: url("../images/common/flower-blue.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__item__flower-yellow {
		background: url("../images/common/flower-yellow.png") 0 0 no-repeat;
		background-size: 23px auto;
	}
	.site-footer__item .site-footer__title {
		width: 150px;
	}
	.site-footer__item > h4 {
		margin-bottom: 1.3em;
	}
	.site-footer__item ol {
		margin-left: calc(1em + 30px);
		padding: 0;
	}
	.site-footer__item ol li {
		list-style-type: decimal;
		margin-bottom: 10px;
	}
	.site-footer__copyright {
		font-size: 1.2rem;
	}
	.site-footer__copyright p:first-child {
		text-align: left;
	}
	.site-footer__copyright p:last-child {
		text-align: left;
	}
}
@media screen and (max-width: 767px) {
	.pc_only {
		display: none !important;
	}
	.wrapper {
		width: 92%;
		margin: 0 auto;
	}
	.site-header {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0;
		background: #fff;
		height: 60px;
		border-bottom: solid 1px #2887a7;
		position: fixed;
		width: 100%;
		z-index: 1;
	}
	.site-header__logo-area {
		width: 40%;
		padding: 10px 0 10px 10px;
	}
	.site-header__logo-area img {
		max-height: 40px;
		width: auto !important;
	}
	main {
		padding-top: 60px;
	}
	/* navigation */
	.drawer_hidden {
		display: none;
	}
	.drawer_open {
		display: flex;
		height: 60px;
		width: 60px;
		justify-content: center;
		align-items: center;
		position: relative;
		z-index: 100;
		cursor: pointer;
	}
	.drawer_open span, .drawer_open span:before, .drawer_open span:after {
		content: '';
		display: block;
		height: 3px;
		width: 25px;
		border-radius: 3px;
		transition: 0.5s;
		position: absolute;
		background: #613a30;
	}
	#drawer_input:checked ~ .drawer_open {
		background: #613a30;
	}
	.drawer_open span:before {
		bottom: 8px;
	}
	.drawer_open span:after {
		top: 8px;
	}
	#drawer_input:checked ~ .drawer_open span {
		background: rgba(255, 255, 255, 0);
	}
	#drawer_input:checked ~ .drawer_open span::before {
		bottom: 0;
		transform: rotate(45deg);
		background: #fff;
	}
	#drawer_input:checked ~ .drawer_open span::after {
		top: 0;
		transform: rotate(-45deg);
		background: #fff;
	}
	.nav_content {
		width: 60%;
		position: fixed;
		top: 59px;
		left: 100%;
		z-index: 999;
		background: #613a30;
		transition: .5s;
		padding: 20px 20px 30px 20px;
	}
	.nav_list li {
		border-top: solid 1px #4c2e27;
		border-bottom: solid 1px #866963;
	}
	.nav_list li:first-child {
		border-top: none;
	}
	.nav_list li:nth-child(2) {
		background: url("../images/common/flower-pink.png") 5px 50% no-repeat;
		padding-left: 25px;
		background-size: 15px;
	}
	.nav_list li:nth-child(3) {
		background: url("../images/common/flower-blue.png") 5px 50% no-repeat;
		padding-left: 25px;
		background-size: 15px;
	}
	.nav_list li:last-child {
		background: url("../images/common/flower-yellow.png") 5px 50% no-repeat;
		padding-left: 25px;
		background-size: 15px;
	}
	.nav_list li a {
		color: #fff;
		display: block;
		padding: 10px 0;
		font-family: 'Kosugi Maru', sans-serif;
		font-size: 1.6rem;
	}
	.nav_list li a:active {
		color: #e5caa4;
	}
	#drawer_input:checked ~ .nav_content {
		left: 40%;
	}
	.contents {
		width: 75%;
		margin: 30px auto;
	}
	.contents2 {
		width: 82%;
		margin: 0 auto;
		padding-bottom: 20px;
	}
	.bg_white {
		background-color: #fff;
		padding: 30px 0px 40px;
	}
	.bg_green::before {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-top.png") 0 0 repeat-x;
		background-size: 1200px auto;
	}
	.bg_green.bg_green__top-white::before {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-top.jpg") 0 0 repeat-x;
		background-size: 1200px auto;
	}
	.bg_green--last {
		background: #8ee27a;
	}
	.page_bg .bg_green::before {
		content: "";
		display: block;
		background: url("../images/common/bg-page-top.png") 0 0 repeat-x;
		background-size: 1200px auto;
		height: 143px;
	}
	.page_bg .bg_green::after {
		background: none;
	}
	.page_bg .bg_green__flower-right > div.bg_green__bottom {
		background: url("../images/common/bg-page-bottom.png") center bottom repeat-x;
		background-size: 1200px auto;
		padding-bottom: 50px;
	}
	.bg_green--header::after {
		content: "";
		display: block;
		height: 10px;
		background: url("../images/common/bg-green-bottom.png") 0 bottom repeat-x;
		background-size: 1200px auto;
	}
	.bg_green--header {
		margin-bottom: 100px;
	}
	.page_bg .bg_green--header::after {
		background: none;
		height: 0;
	}
	.page_bg .bg_green--header {
		margin-bottom: 30px;
	}
	.bg_green__inner {
		background: #8ee27a;
		padding: 50px 0 0 0;
	}
	.bg_green__inner_top {
		background: #8ee27a;
		padding: 20px 0 20px 0;
	}
	.bg_green__inner_top p:nth-of-type(1) {
		padding-bottom: 20px;
	}
	.bg_green__flower-left {
		background: url("../images/common/flowers.png") 1% 0 repeat-y;
		background-size: 115px auto;
	}
	.bg_green__flower-right {
		background: url("../images/common/flowers.png") 99% 0 repeat-y;
		background-size: 115px auto;
	}
	.bg_green .wrapper {
		padding-top: 100px;
	}
	.site-footer__mochida img {
		width: 35%;
		margin: 0 auto 50px auto;
	}
	/*max-width: 767px*/
}
@media screen and (max-width: 580px) {
	.wrapper {
		width: 100%;
	}
	.site-footer__container {
		display: grid;
		grid-template-columns: 50% 50%;
		margin-bottom: 40px;
	}
	.site-footer__item {
		font-size: 1.3rem;
		border: none;
	}
	.site-footer__item:first-child {
		align-self: center;
		border-bottom: solid 1px #fff;
		grid-column-start: 1;
		grid-column-end: 3;
		margin-bottom: 20px;
		padding: 0 0 20px 0;
	}
	.site-footer__item:nth-child(3) {
		padding: 0 10px;
	}
	.page_bg .bg_green::before {
		height: 100px;
	}
	.page_bg .bg_green {
		margin-top: 0px;
	}
	.site-footer__mochida img {
		width: 45%;
		margin: 0 auto 50px auto;
	}
}
.id_set {
	position: absolute;
	top: -60px;
	left: 0px;
}
.pagetop {
	width: 50px;
	position: fixed;
	bottom: 0px;
	right: 0px;
}
@media screen and (max-width:980px) {
	.pagetop {
		width: 40px;
		position: fixed;
		bottom: 0px;
		right: 0;
	}
}
@media screen and (max-width:780px) {
	.pagetop {
		width: 35px;
		position: fixed;
		bottom: 5px;
		right: 5px;
		opacity: 0.5;
	}
	.pagetop:hover {
		width: 35px;
		position: fixed;
		bottom: 5px;
		right: 5px;
		opacity: 1;
	}
}
