@charset "utf-8";

/* トップページ（index.html） */


/*-------------------------------------------------
#mv
------------------------------------------------*/
#mv {
	text-align: center;
}
#mv .mv_img {
	width: 1040px;
	padding-bottom: 20px;
}
.btn-wrap {
	margin-bottom: 15px;
	margin-top: 10px;
}
.btn-wrap a.btn01 {
	width: 600px;
	margin: 0 auto;
}
.btn-wrap .ttl01 {
	font-size: 2rem;
	margin-bottom: 1em;
	font-weight: 600;
}
.btn-wrap .ttl02 {
	font-size: 2.2rem;
	margin-bottom: 1em;
	font-weight: 800;
}
.btn-wrap .ttl02 a{
	color: #45b035;
	border-bottom:solid 2px;
}

#mv .inner {
	width: 1040px;
	margin: 0 auto;
	margin-bottom: 30px;
}

#mv h2 {
	margin-bottom: 30px;
	padding-bottom: 20px;
	border-bottom: 6px dotted #45b035;
	color: #45b035;
	font-size: 3.0rem;
	line-height: 1.4;
	text-align: left;
}
#mv p {
	margin-bottom: 15px;
	font-size: 1.6rem;
	line-height: 1.5;
	text-align: left;
}
#mv p.mb00 {
	margin-bottom: 0px;
}
#mv h3 {
	margin-bottom: 25px;
	padding: 10px;
	color: #fff;
	background-color: #45b035;
	font-size: 3.0rem;
	line-height: 1.4;
	text-align: left;
}
#mv h4 {
	margin-bottom: 30px;
	padding-bottom: 10px;
	padding-top: 30px;
	border-bottom: 1px solid #45b035;
	font-size: 2.2rem;
	line-height: 1.4;
	text-align: left;
}
#mv .mv_gridbox {
	display: grid;
	grid-template-columns: 260px 1fr 1fr;
	grid-template-rows: 140px 1fr 1fr;
}
#mv .block {
	padding: 10px 15px 10px 15px;
	margin-top: 20px;
	box-sizing: border-box;
	background-color: #f3f3f3;
	border: solid 1px #464646;
	color: #464646;
}
#mv .gridbox01 {
	grid-column-start: 2;
	grid-column-end: 4;
	grid-row-start: 1;
	grid-row-end: 2;
}
#mv .gridbox02 {
	grid-column-start: 1;
	grid-column-end: 2;
	grid-row-start: 1;
	grid-row-end: 4;
	padding-right: 40px;
}
#mv .gridbox02 img{
	border: solid 1px #464646;
}
#mv .gridbox03 {
	grid-column-start: 2;
	grid-column-end: 4;
	grid-row-start: 2;
	grid-row-end: 4;
}
#mv .indent01 {
	text-indent: -1.5em;
	padding-left: 1.5em;
}

/*-------------------------------------------------
#bn
------------------------------------------------*/
#bn {
	text-align: center;
}
#bn img {
	width: 1040px;
	padding:2em 0;
}
#bn .btn-wrap .ttl01 {
	font-size: 2.4rem;
	margin-bottom: 4em;
	font-weight: 600;
}
#bn .btn-wrap .ttl01 a{
	color: #45b035;
	border-bottom:solid 2px #45b035;
}
#bn .btn-wrap .ttl01 a:hover {
	color: #e9546b;
	border-bottom:solid 2px #e9546b;
}


/*-------------------------------------------------
#app-dl
------------------------------------------------*/
#app-dl {
	padding: 100px 0;
	background-color: #fffbc7;
}
#app-dl .box01 {
	box-sizing: border-box;
	width: 1040px;
	margin: 0 auto;
	padding: 40px;
	border: 1px solid #1b1b1b;
	border-radius: 20px;
	box-shadow: 12px 12px #4b4b4b;
	background-color: #fff;
}
#app-dl .box01 h2 {
	margin-bottom: 40px;
	font-size: 3.0rem;
	text-align: center;
}
#app-dl .box01 ul {
	display: flex;
	justify-content: space-between;
}
#app-dl .box01 li {
	display: flex;
}
#app-dl .box01 p {
	margin-top: 10px;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 600;
}
#app-dl .box01 li a img {
	margin-right: 30px;
}
#app-dl .box01 li img {
	height: 100px;
}



/*-------------------------------------------------
#parallax
------------------------------------------------*/
#parallax {
	height: 380px;
	margin-bottom: 100px;
	background-image: url(/imgs/top/parallax_img01.jpg);
	background-size: cover;
	background-position: center bottom;
	background-repeat: no-repeat;
	background-attachment: fixed;
	z-index: -1;
}
#parallax.tab {
	background-position: center 90%;
	background-attachment: scroll;
}
#parallax .inner {
	display: flex;
	align-items: flex-end;
	width: 1040px;
	height: 380px;
	margin: 0 auto;
}
#parallax .chara {
	margin-left: auto;
	width: 228px;
	padding-bottom: 50px;
}




/*-------------------------------------------------
#about
------------------------------------------------*/
#about {
	margin: 0 auto 100px;
}
#about .inner {
	position: relative;
	display: flex;
	align-items: center;
	width: 1040px;
	margin: 0 auto;
}
#about .inner.bg::before {
	margin-right: -100px;
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 0;
	background-color: #f3f3f3;
	width: 630px;
	height: 310px;
	z-index: -1;
}
#about .box01 {
	width: 551px;
}
#about .box01 h2 {
	margin-bottom: 30px;
	padding-bottom: 20px;
	border-bottom: 6px dotted #45b035;
	color: #45b035;
	font-size: 3.0rem;
	line-height: 1.4;
	text-align: left;
}
#about .box01 p {
	margin-bottom: 40px;
	font-size: 1.6rem;
	line-height: 2.6;
}
#about .box01 a.btn01 {
	width: 300px;
}
#about .box02 {
	width: 489px;
}



/*-------------------------------------------------
#news
------------------------------------------------*/
#news {
	margin: 0 auto;
	background-color: #f3f4f5;
}
#news .inner {
	box-sizing: border-box;
	width: 1040px;
	margin: 0 auto;
	padding: 50px 0;
}
#news .box01 {
	padding: 60px;
	margin-bottom: 50px;
	background-color: #fff;
	border-radius: 20px;
}
#news .box01 h2 {
	width: 9em;
	margin: 0 auto 30px;
	padding-bottom: 20px;
	border-bottom: 6px dotted #45b035;
	color: #45b035;
	font-size: 3.0rem;
	line-height: 1.4;
	text-align: center;
}
#news .box01 li + li {
	margin-top: 30px;
}
#news .box01 li:nth-child(1){
	margin-top: 40px;
}
#news .box01 li dl {
	display: flex;
	padding-bottom: 30px;
	border-bottom: 1px solid #ddd;
}
#news .box01 li dt {
	margin-right: 60px;
	color: #6b6b6b;
	line-height: 1.9;
	font-size: 1.3rem;
}
#news .box01 li dd {
	line-height: 1.6;
	font-size: 1.6rem;
}
#news .box02 {
	padding: 60px;
	margin-top: 50px;
	background-color: #fff;
	border-radius: 20px;
}
#news .box02 h2 {
	width: 18em;
	margin: 0 auto 30px;
	padding-bottom: 20px;
	border-bottom: 6px dotted #45b035;
	color: #45b035;
	font-size: 3.0rem;
	line-height: 1.4;
	text-align: center;
}
#news .box02 h3 {
	margin-bottom: 5px;
	font-size: 2.0rem;
	font-weight: 600;
	line-height: 1.5;
}
#news .box02 p {
	font-size: 1.6rem;
	line-height: 1.6;
	margin-top: 20px;
}
#news .box02 .th {
	margin-top: 10px;
	margin-bottom: 30px;
}
#news .box02 ul {
	padding: 20px;
	text-align: center;
}
#news .box02 ul li {
	display: inline-block;
}
#news .box02 ul li div {
	display: inline-block;
	vertical-align: middle;
}
#news .box02 ul li div:first-child {
	width: 90px;
	margin-right: 20px;
}
#news .box02 ul li div:nth-child(2) {
	font-size: 2.2rem;
	line-height: 1.6;
	margin-right: 60px;
	text-align: left;
}
#news .box02 ul li div p {
	font-size: 1.6rem;
	line-height: 1.2;
	margin-top: 0.6rem;
}



/*//////////////////////////////////////////////////////////////

SmartPohne

//////////////////////////////////////////////////////////////*/
@media screen and (max-width: 767px) {

/*-------------------------------------------------
#mv
------------------------------------------------*/
#mv {
	padding: 0 3%;
}
#mv .mv_img {
	width: auto;
}
.btn-wrap a.btn01 {
	width: auto;
}
#mv .inner {
	position: static;
	flex-flow: column-reverse nowrap;
	width: auto;
}
#mv h2 {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 4px dotted #45b035;
	font-size: 5.314vmin;
	letter-spacing: 0.03em;
	text-align: center;
}
#mv p {
	margin-bottom: 20px;
	font-size: 3.864vmin;
	line-height: 1.6;
}
#mv h3 {
	margin-bottom: 15px;
	padding: 5px;
	font-size: 5.314vmin;
	text-align: center;
}
#mv h4 {
	margin-bottom: 15px;
	padding: 5px;
	font-size: 5.314vmin;
	text-align: center;
}
#mv .mv_gridbox {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: auto;
}
#mv .gridbox01 {
	grid-column-start: 1;
	grid-column-end: 2;
	grid-row-start: 1;
	grid-row-end: 2;
}
#mv .gridbox02 {
	grid-column-start: 1;
	grid-column-end: 2;
	grid-row-start: 2;
	grid-row-end: 3;
	padding: 10px 60px;
}
#mv .gridbox02 img{
	margin-bottom:10px;
}
#mv .gridbox03 {
	grid-column-start: 1;
	grid-column-end: 2;
	grid-row-start: 3;
	grid-row-end: 4;
}


/*-------------------------------------------------
#bn
------------------------------------------------*/
#bn {
	padding: 0 3%;
	margin:-30px auto;
}
#bn img {
	width: auto;
	padding: 2em 0 1em;
}
#bn .btn-wrap .ttl01 {
	font-size: 1.8rem;
}



/*-------------------------------------------------
#app-dl
------------------------------------------------*/
#app-dl {
	padding: 30px 6% 30px 3%;
}
#app-dl .box01 {
	width: auto;
	padding: 20px;
	border-radius: 10px;
	box-shadow: 8px 8px #4b4b4b;
}
#app-dl .box01 h2 {
	margin-bottom: 20px;
	font-size: 4.347vmin;
	line-height: 1.4;
}
#app-dl .box01 ul {
	display: block;
	justify-content: flex-start;
}
#app-dl .box01 li + li {
	margin-top: 20px;
}
#app-dl .box01 li div:nth-child(1) {
	width: 70%;
	margin-right: 6%;
}
#app-dl .box01 li div:nth-child(2) {
	width: 24%;
}
#app-dl .box01 p {
	font-size: 3.623vmin;
}
#app-dl .box01 li a img {
	margin-right: 0;
}
#app-dl .box01 li img {
	height: auto;
}
	
	
	
/*-------------------------------------------------
.parallax
------------------------------------------------*/
#parallax {
	height: 170px;
	margin-bottom: 30px;
	background-attachment: scroll;
}
#parallax .inner {
	width: auto;
	height: 170px;
}
#parallax .chara {
	width: 30%;
	padding: 0 3% 12px;
}
	
	

/*-------------------------------------------------
#about
------------------------------------------------*/
#about {
	margin: 0 auto 30px;
}
#about .inner {
	position: static;
	flex-flow: column-reverse nowrap;
	width: auto;
	padding: 0 3%;
}
#about .box01 {
	width: auto;
	margin-top: 10px;
}
#about .box01 h2 {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 4px dotted #45b035;
	font-size: 5.314vmin;
	text-align: center;
}
#about .box01 p {
	margin-bottom: 20px;
	font-size: 3.864vmin;
	line-height: 2.0;
}
#about .box01 a.btn01 {
	width: 100%;
}
#about .box02 {
	width: auto;
}
	
	

/*-------------------------------------------------
#news
------------------------------------------------*/
#news {
	margin: 0 auto;
}
#news .inner {
	width: auto;
	padding: 30px 3%;
}
#news .box01 {
	padding: 30px 10px 20px;
	border-radius: 10px;
}
#news .box01 h2 {
	padding-bottom: 10px;
	border-bottom: 4px dotted #45b035;
	font-size: 5.314vmin;
}
#news .box01 li + li {
	margin-top: 20px;
}
#news .box01 li:nth-child(1){
	margin-top: 20px;
}
#news .box01 li dl {
	display: block;
	padding-bottom: 20px;
}
#news .box01 li dt {
	margin-right: 0;
	margin-bottom: .4em;
	line-height: 1;
	font-size: 3.14vmin;
}
#news .box01 li dd {
	font-size: 3.864vmin;
}
#news .box02 {
	padding: 30px 10px 20px;
	border-radius: 10px;
}
#news .box02 h2 {
	width: 9em;
	padding-bottom: 10px;
	border-bottom: 4px dotted #45b035;
	font-size: 5.314vmin;
}
#news .box02 h3 {
	margin-bottom: 6px;
	font-size: 4.83vmin;
}
#news .box02 p {
	font-size: 3.864vmin;
	line-height: 1.6;
}
#news .box02 ul li div:first-child {
	width: 100px;
	margin-bottom: 20px;
}
#news .box02 ul li div:nth-child(2) {
	text-align:left;
	font-size: 2.4rem;
	line-height: 1.6;
	width: 200px;
}
#news .box02 ul li div p {
	font-size: 1.8rem;
}




}/* / @media*/
