@charset "utf-8";

/* ========================================================
	index.css => index用CSS
======================================================== */

/* main
============================================================================================================ */
#main {
	position: relative;
	height: 400px;
	padding-top: 125px;
	background: #6eb92b url(../images/main_bg.png) 50% 0;
	text-align: center;
	z-index: 2;
}
#main::after {
	background-color: #fff;
}

@media screen and (min-width: 769px), print {
	#main {
	}
	#main h1 {
		margin-top: 40px;
		color: #ffffff;
		font-size: 5rem;
	}
}
@media screen and (max-width: 768px) {
	#main {
		height: auto;
		padding:30px 0 40px 0;
		background-repeat: no-repeat;
		background-position: 50% 20%;
		-webkit-background-size: 140%;
		background-size: 140%;
	}
	#main h1 {
		color: #ffffff;
		font-size: 1.8rem;
	}
}





/* after_skew
============================================================================================================ */
.after_skew {
	position: relative;
	overflow: hidden;
}
.after_skew::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	right: -100px;
	height: 50px;
	-webkit-transform-origin: 0 0;
	-moz-transform-origin: 0 0;
	-ms-transform-origin: 0 0;
	-o-transform-origin: 0 0;
	transform-origin: 0 0;
	-webkit-transform: skewX(-45deg);
	-ms-transform: skewX(-45deg);
	-o-transform: skewX(-45deg);
	transform: skewX(-45deg);
}
@media screen and (max-width: 768px) {
	.after_skew::after {
		height: 25px;
	}
}




/* information_contents
============================================================================================================ */
.information_contents {
	position: relative;
	padding: 60px 0 120px;
}
.information_contents::before {
	content: "";
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	height: 50%;
	z-index: -1;
}

.information_contents::after {
	background-color: #6eb92b;
}
.information_contents .box {
	padding: 10px 40px;
}
.information_contents h2{
	text-align: center;
	font-size: 3.5rem;
	line-height: 1;
}
.information_contents h2 span{
	font-size: 2rem;
}

.information_contents ul.keibajo li.obihi {
	background-color: #c55a11;
}
.information_contents ul.keibajo li.monbe {
	background-color: #7030a0;
}
.information_contents ul.keibajo li.morio {
	background-color: #4472c4;
}
.information_contents ul.keibajo li.mizusa {
	background-color: #4472c4;
}
.information_contents ul.keibajo li.urawa {
	background-color: #7f7f7f;
}
.information_contents ul.keibajo li.funaba {
	background-color: #7f7f7f;
}
.information_contents ul.keibajo li.ooi {
	background-color: #7f7f7f;
}
.information_contents ul.keibajo li.kawasa {
	background-color: #7f7f7f;
}
.information_contents ul.keibajo li.kanaza {
	background-color: #00b0f0;
}
.information_contents ul.keibajo li.kasama {
	background-color: #ff40ff;
}
.information_contents ul.keibajo li.nagoya {
	background-color: #00b050;
}
.information_contents ul.keibajo li.sonoda {
	background-color: #d883ff;
}
.information_contents ul.keibajo li.himezi {
	background-color: #d883ff;
}
.information_contents ul.keibajo li.kouchi {
	background-color: #ffc000;
}
.information_contents ul.keibajo li.saga {
	background-color: #ff0000;
}
.information_contents ul.keibajo li.etc {
	background-color: #ffff00;
	color: #000000;
}

.information_contents ul.caution {
	padding-left: 10px;
}
.information_contents ul.caution li {
	list-style-type: disc;
}


@media screen and (min-width: 769px), print {
	.information_contents div.widh{
		width: 50%;
		vertical-align: top;
	}
	.information_contents div.widhh{
		width: 45%;
		vertical-align: top;
	}

	.information_contents ul.keibajo li {
		width: 11.7%;
		display: inline-block;
		color: #ffffff;
		text-align: center;
		font-size: 2.5rem;
		margin-bottom: 10px;
	}

	.information_contents div.w {
		margin-top: 20px;
	}

	.information_contents div.w1 p {
		font-size: 2rem;
		font-weight: bold;
		margin-bottom: 10px;
	}

	.information_contents div.w1 {
		background-color: #e0f0d0;
		padding-left: 10px;
/*		display: inline-block;*/
		width: 850px;
	}

	.information_contents div.w2 p {
		font-size: 2rem;
		font-weight: bold;
		margin-bottom: 40px;
	}

	.information_contents div.w2 p.omo {
		font-size: 1rem;
		font-weight: bold;
		margin-bottom: 0px;
	}

	.information_contents div.w2 {
		background-color: #e0f0d0;
		padding-left: 10px;
		padding-right: 10px;
/*		display: inline-block;*/
		width: 150px;
		height: auto;
		margin-left: 10px;
	}

	.information_contents div.w2 li {
		width: 48%;
		display: inline-block;
		color: #000000;
		text-align: center;
		font-size: 1rem;
	}

	.information_contents ul.keibajo li.list_jo {
		width: 100%;
		margin: 0;
		padding: 3px;
	}

	.information_contents div.eventtbl table{
		width: 100%;
		height: 100%;
		line-height: 1.2;
	}
	.information_contents div.eventtbl td{
		height: 100%;
		padding: 10px;
	}
	.information_contents td.tbl_jo {
		width: 120px;
	}
	.information_contents td.tbl_re {
		width: 30px;
	}
	.information_contents td.tbl_tx {
/*		width: 100px;*/
	}

	.information_contents dl.raceinfo_pc {
		margin-bottom: 10px;
	}
}
@media screen and (max-width: 768px) {
	.information_contents {
		padding: 30px 0 60px;
	}
	.information_contents .box {
		padding: 5px 20px;
	}
	
	.information_contents ul.keibajo li {
/*		width: 49%;*/
		width: 15%;
		display: inline-block;
		color: #ffffff;
		text-align: center;
		font-size: 2rem;
		margin-bottom: 10px;
		line-height: 1.2;
	}

	.information_contents div.w {
		margin-top: 20px;
	}

	.information_contents div.w1 p {
		font-size: 2rem;
		font-weight: bold;
		margin-bottom: 10px;
	}

	.information_contents div.w1 {
		background-color: #e0f0d0;
		padding-left: 5px;
/*		display: inline-block;*/
	}

	.information_contents div.w2 p {
		font-size: 2rem;
		font-weight: bold;
		margin-bottom: 10px;
	}

	.information_contents div.w2 p.omo {
		font-size: 1rem;
		font-weight: bold;
		margin-bottom: 0px;
	}

	.information_contents div.w2 {
		background-color: #e0f0d0;
		padding-left: 5px;
		padding-right: 5px;
/*		display: inline-block;*/
		width: 75px;
		height: auto;
		margin-left: 10px;
	}

	.information_contents div.w2 li {
		width: 100%;
		display: inline-block;
		color: #000000;
		text-align: center;
		font-size: 1rem;
	}

	.information_contents ul.keibajo li.list_jo {
		width: 100%;
		margin: 0;
		padding: 3px;
	}

	.information_contents div.eventtbl table{
		width: 100%;
		height: 100%;
		line-height: 1.2;
	}
	.information_contents div.eventtbl td{
		height: 100%;
		padding: 5px;
	}
	.information_contents td.tbl_jo {
		width: 80px;
	}
	.information_contents td.tbl_re {
		width: 35px;
	}
	.information_contents td.tbl_tx {
/*		width: 100px;*/
	}

	.information_contents dl.raceinfo_sp {
		margin-bottom: 10px;
	}
}



/* howto_contents
============================================================================================================ */
.howto_contents {
	padding: 60px 0 15px;
}
.howto_contents::after {
	background-color: #ffffff;
}
.howto_contents li {
	position: relative;
	margin-bottom: 70px;
}
.howto_contents li::before {
	content: "";
	position: absolute;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 5;
}
.howto_contents li.howto01bg::before {
	background-image: url(../images/howto_bg01.png);
	background-position: left bottom;
}
.howto_contents li.howto02bg::before {
	background-image: url(../images/howto_bg02.png);
}
.howto_contents li.howto02 {
	position: relative;
	display: block;
	text-decoration: none;
	background-color: rgba(255,255,255,.1);
	color: #fff;
	text-align: center;
	font-size: 3.6rem;
	line-height: 1.3;
	font-weight: bold;
}
.howto_contents li.howto02::before {
	content: "";
	background-repeat: no-repeat;
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
}
.howto_contents li.howto01 a::before {
	
}
.howto_contents li.howto02 a::before {
	
}
.howto_contents li.howto02 span {
	display: block;
}
.howto_contents li .box {
	position: relative;
	border: 10px solid #fff;
	z-index: 3;
}
.howto_contents .more {
	position: relative;
	z-index: 3;
}
.howto_contents .more a {
	margin-left: auto;
}
@media screen and (min-width: 769px), print {
	.howto_contents {
		padding-left: 20px;
		padding-right: 20px;
	}
	.howto_contents ul {
		max-width: 1400px;
		margin: auto;
	}
	.howto_contents li.howto01::before {
		top: -80px;
		right: 0;
		bottom: -70px;
		width: 520px;
	}
	.howto_contents li.howto02::before {
		top: -70px;
		left: -52px;
		bottom: -80px;
		width: 540px;
	}

	.howto_contents li.howto02 {
		padding: 70px 40px;
	}
	.howto_contents li.howto02::before {
		position: absolute;
		top: 0;
		bottom: 0;
		max-width: 800px;
		width: 58%;
	}
	.howto_contents li.howto01 a::before {
		left: 0;
	}
	.howto_contents li.howto02 a::before {
		right: 0;
	}
	.howto_contents li .box {
		max-width: 640px;
		width: 45%;
		height: 360px;
		padding-top: 40px;
		margin-right: 30px;
	}
	.howto_contents li.howto01 .box {
		margin-left: auto;
	}
	.howto_contents li .how {
		font-size: 2.4rem;
		line-height: 1;
	}
	.howto_contents li .num {
		margin-bottom: 20px;
		font-size: 11.2rem;
		line-height: 1;
		padding-left: .1em;
		letter-spacing: .1em;
	}

	.howto_contents p.howto03 {
		width: 50%;
		line-height: 2.5;
	}

	.howto_contents div.tokuten {
		width: 1080px;
		margin: 0px auto 100px auto;
	}
	.howto_contents a.w100{
		margin-right: 20px;
	}
}
@media screen and (max-width: 768px) {
	.howto_contents {
		padding: 30px 0 60px;
	}
	.howto_contents li {
		margin-bottom: 30px;
	}
	.howto_contents li::before {
		bottom: -30px;
		right: -20px;
		left: -20px;
		height: 220px;
		background-repeat: no-repeat;
		-webkit-background-size: auto 100%;
		background-size: auto 100%;
	}
	.howto_contents li.howto01::before {
		 background-position: 100%;
	}
	.howto_contents li.howto02::before {
		 background-position: 0;
	}
	.howto_contents li.howto02 {
		text-align: center;
		font-size: 1.8rem;
		line-height: 1.3;
	}
	.howto_contents li.howto02::before {
		display: block;
		height: 220px;
	}
	.howto_contents li .box {
		padding: 20px 0;
		border-width: 5px;
	}
	.howto_contents li .how {
		font-size: 1.4rem;
		line-height: 1;
	}
	.howto_contents li .num {
		margin-bottom: 5px;
		font-size: 6rem;
		line-height: 1;
		padding-left: .1em;
		letter-spacing: .1em;
	}
	.howto_contents a.w100{
		width: 100%;
	}



	.box_btn.xs,
	a.box_btn.xs,
	a .box_btn.xs {
	background-color: #2b7900;
	border: 2px solid #2b7900;
	padding: 0px 0px 0px 0px;
	}

	button.box_btn.xs:hover,
	a.box_btn.xs:hover,
	a:hover .box_btn.xs,
	div.nav a.current {
		background-color: #fff;
		color: #2b7900;
	}
	.box_btn.xs,
	div.nav a.current :hover::after {
		border-color: #2b7900;
	}
	div.nav {
		margin: 0px auto 0px auto;
	}
	.nav ul {
		table-layout: fixed;
		text-align: center;
		width: 100%;
		margin-top: 10px;
	}
	.nav ul li {
		display: inline-block;
		margin-bottom: 0px;
	}
	.nav ul li a{
		height: 30px;
		width: 50px;
/*		width: 10%;*/
		display: table-cell;
		vertical-align: middle;
	}
	.nav ul li.mid {
		padding: 10px;
	}
	.nav ul span.year{
		height: 30px;
		width: 768px;
		display: table-cell;
		vertical-align: middle;
		font-size: 1.6rem;
		font-weight: bold;
	}

	.nav ul li a.clr {
	background-color: #bbbbbb;
	border: 2px solid #777777;
	padding: 0px 0px 0px 0px;
		height: 30px;
		width: 200px;
	}
	.nav ul li a.clr:hover {
		background-color: #fff;
	}
	.nav ul li a.clr:hover::after {
		border-color: #777777;
	}
}

@media screen and (min-width: 769px) {
	.box_btn.xs,
	a.box_btn.xs,
	a .box_btn.xs {
	background-color: #2b7900;
	border: 2px solid #2b7900;
	padding: 0px 0px 0px 0px;
	}

	button.box_btn.xs:hover,
	a.box_btn.xs:hover,
	a:hover .box_btn.xs,
	div.nav a.current {
		background-color: #fff;
		color: #2b7900;
	}
	.box_btn.xs,
	div.nav a.current :hover::after {
		border-color: #2b7900;
	}
	div.nav {
		width: 1080px;
		margin: 0px auto 0px auto;
		line-height: 0;
	}
	.nav ul {
		table-layout: fixed;
		text-align: center;
		width: 100%;
		margin-top: 10px;
	}
	.nav ul li {
		display: inline-block;
		margin-bottom: 0px;
	}
	.nav ul li a{
		height: 50px;
		width: 70px;
		display: table-cell;
		vertical-align: middle;
	}
	.nav ul li.mid {
		padding: 10px;
	}
	.nav ul span.year{
		height: 50px;
		width: 70px;
		display: table-cell;
		vertical-align: middle;
		font-size: 1.6rem;
		font-weight: bold;
	}

	.nav ul li a.clr {
	background-color: #bbbbbb;
	border: 2px solid #777777;
	padding: 0px 0px 0px 0px;
		height: 30px;
		width: 200px;
	}
	.nav ul li a.clr:hover {
		background-color: #fff;
	}
	.nav ul li a.clr:hover::after {
		border-color: #777777;
	}
}


.information_contents ul.keibajo li.bt1:hover,li.bt2:hover,ul.keibajo li.select {
	background-color: #fff !important;
	color: #000 !important;
    -webkit-transition: background .2s, border .2s, color .2s;
    -o-transition: background .2s, border .2s, color .2s;
    transition: background .2s, border .2s, color .2s;
}
div.nav a.select {
	background-color: #fff;
	color: #2b7900;
}
div.nav a.box_no {
	background-color: #ccc !important;
	color: #fff !important;
}
.information_contents ul.keibajo li.bt1:hover,li.bt2:hover,a.bt3:hover,a.clr:hover,ul.keibajo li.select {
    -webkit-transition: background .2s, border .2s, color .2s;
    -o-transition: background .2s, border .2s, color .2s;
    transition: background .2s, border .2s, color .2s;
}
