@charset "UTF-8";

/*-----------------------------------

	base

-----------------------------------*/
html {
	overflow-y: auto;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	font-size: 62.5%;
	overflow-x: hidden;
}
body {
	font-family: "Noto Sans Japanese","メイリオ","Meiryo",verdana,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	font-size: 14px;
	font-size: 1.4em;
	color: #333434;
	line-height: 1.8em;
	letter-spacing:0.03rem;
	font-weight: 400;
	background: #fff;
	margin:0 !important;
	width: 100%;
	overflow: hidden;
	box-sizing: border-box;
	position: relative;
	z-index: 999;
}
.contents_inner{
	width: 1000px;
	margin: 0 auto;
}
img {
	max-width: 100%;
	height: auto;
}
a, a:link, a:visited {
	color:#333434;
	text-decoration:none;
	cursor: pointer;
}
a:hover {
	color:#333434;
	text-decoration:none;
}
a img{
	transition : 0.2s ;
	-webkit-transition : 0.2s ;
	-moz-transition    : 0.2s ;
	-o-transition      : 0.2s ;
	-ms-transition     : 0.2s ;
}
a:hover img {
	opacity: 0.7;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
}
#contents {
	display: block;
	margin: 0 auto;
}
.sp_mode {
	display:none;
}
.pc_mode {
	display:block;
}

@media screen and (max-width: 1200px) {

	.contents_inner{
		width: 95%;
		margin: 0 auto;
	}

}

@media screen and (max-width: 640px) {

	body {
		font-size: 13px;
		font-size: 1.3em;
		line-height: 1.6em;
		font-weight: normal;
		letter-spacing: 0.05rem;
	}
	.sp_mode {
		display:block;
	}
	.pc_mode {
		display:none;
	}
	.minus_t_40 {
		margin-top: 0;
	}

}

/*-----------------------------------

	clearfix

-----------------------------------*/
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
.clearfix {
	display: inline-block;
}
* html .clearfix {
	height: 1%;
}
.clearfix {
	display: block;
}


/*-----------------------------------

	header

-----------------------------------*/
#head_contents {
	/*height: 2000px;
	background: url(../img/bg_main01.png);*/
}
/*#head_contents .head_wrap {
	height: 2000px;
	background: url(../img/bg_main02.png) no-repeat;
	background-position: center 530px;
}*/
#head_contents header {
    padding: 20px 0;
    background: #fff;
    border-bottom: 2px solid #000;
}
#head_contents .head_logo h1 {
	width: 537px;
	margin: 0 auto;
}
#head_contents .head_logo a {
	/*float: left;*/
	display:inline-block;
	vertical-align:middle;
	margin-right: 24px;
}
#head_contents .head_logo a:last-child {
	margin-right: 0;
}
#head_contents .head_logo a:nth-child(2):hover {
	cursor: default;
	opacity: 1 !important;
}
#head_contents .head_logo a:nth-child(2) img:hover {
	opacity: 1 !important;
}

@media screen and (max-width: 840px) {

	#head_contents {
		height: auto;
	}
	#head_contents .head_wrap {
		height: 1640px;
		background-size: contain;
		background-position: center 58%;
	}
	#head_contents .position_area {
		width: 100%;
	}
	#head_contents .main_logo {
		width: 55%;
		left: 25px;
	}
	#head_contents .main_kv {
		width: 44%;
		right: 10px;
		top: 30px;
	}
	#head_contents .main_tokuten01 {
		width: 50%;
	}
	#head_contents .main_tokuten02 {
		width: 55%;
		top: 475px;
		left: 15px;
	}
	#head_contents .main_tokuten03 {
		width: 41%;
		right: 20px;
		top: 980px;
	}
	#head_contents .main_tokuten04 {
		width: 58%;
		top: 850px;
		left: 15px;
	}
	#chara_img {
		top: 870px;
	}

}

@media screen and (max-width: 680px) {

	#head_contents header {
		padding-top: 20px;
	}
	#head_contents, #head_contents .head_wrap {
		/*height: 1430px;*/
	}
	#head_contents .main_tokuten01 {
		top: 490px;
	}
	#head_contents .main_tokuten02 {
		top: 415px;
	}
	#head_contents .main_tokuten03 {
		top: 840px;
	}
	#head_contents .main_tokuten04 {
		width: 56%;
		top: 700px;
	}
	#head_contents .head_logo h1 {
		width: 100%;
	}
	#head_contents .head_logo a {
		width:31.333%;
		margin-right: 0;
		/*margin-right: 2%;
		width: 32%;*/
	}
	#head_contents .head_logo a img {
		margin: 0 auto;
		display: block;
	}

}

@media screen and (max-width: 640px) {

	header .text_box {
		margin: 30px 0 20px;
	}
	#head_contents,
	#head_contents .head_wrap {
		height: auto;
		/*padding-bottom: 20px;*/
	}
	#head_contents .position_area {
		position: relative;
		padding: 0 10px;
		box-sizing: border-box;
	}
	#head_contents .main_tokuten01 {
		position: static;
		width: 90%;
		margin: 0 auto 10px;
	}
	#head_contents .main_tokuten02 {
		position: static;
		width: 100%;
		margin-left: 1%;
		margin-bottom: 15px;
	}
	#head_contents .main_tokuten03 {
		position: static;
		width: 100%;
		text-align: center;
	}
	#head_contents .main_tokuten04 {
		position: static;
		width: 100%;
		margin-top: 10px;
	}
	#chara_img {
		width: 60px;
		left: 10px;
		top: 74%;
	}

}

/*-----------------------------------

	mainvisual

-----------------------------------*/
#mainvisual {
	background: black;	
	width:100%;	
}
#mainvisual .pc_mode {
	display: block;
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
}
/*#mainvisual .mainvisual_kv img{
	width: auto !important;
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    margin: 0 auto !important;
}*/
#mainvisual .sp_mode {
	display:none;
}

@media screen and (max-width: 840px) {
	
	#mainvisual .pc_mode {
		display: none;
	}
	#mainvisual .sp_mode {
		display:block;
	}
	#mainvisual {
		background:none;
		height:auto;
	}

}

/*-----------------------------------

	gnav

-----------------------------------*/

#gnav {
	background:#fff;
}
#gnav ul {
	overflow:hidden;
}
#gnav ul li{
	float:left;
}
#gnav ul li img{
	border-left:2px dotted #000;
}
#gnav ul .gnav_04 {
	border-right:2px dotted #000;
}
#gnav ul li a{
	display:block;
	padding:15px 0;
}
/*#gnav ul li a::after {
    position: absolute;
    bottom: 2px;
    left: 0;
    content: '';
    width: 100%;
    height: 4px;
    background-image: linear-gradient(to right, #000, #000 3px, transparent 3px, transparent 8px);
    background-size: 8px 5px;
    background-repeat: repeat-x;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
}*/

@media screen and (max-width: 1300px) {

	#gnav ul li {
		width: 25%;
	}

}

@media screen and (max-width: 1100px) {

	#gnav ul {
		width: 100%;
	}
	#gnav ul li a {
		padding: 10px 0;
	}
	#gnav ul .gnav_01{
		border-left:none;
	}
	#gnav ul .gnav_04 {
		border-right:none;
	}

}

/*-----------------------------------

	tokuten_block

-----------------------------------*/

#tokuten_block {
    background: url(../img/bg_main01.png) no-repeat;
	background-size: cover;
	padding:20px 0 50px 0;
}
#tokuten_block .bg_main02 {
    height: 780px;
    background: url(../img/bg_main02.png) no-repeat;
    background-position-Y: 60px;
    background-size: 65%;
}
#tokuten_block #position_area {
	position: relative;
	width: 1300px;
	margin: 0 auto;
}
#tokuten_block .main_logo {
	position: absolute;
	left: 80px;
	top: 40px;
	z-index: 2;
}
#tokuten_block .present_01 {
	position: absolute;
	right: 100px;
	top: 10px;
	z-index: 1;
	animation-duration: 1.5s;
	animation-delay: 1s;
}
#tokuten_block .tokuten_area {
	overflow:hidden;
	width:1010px;
	margin:0 auto;
}
#tokuten_block .main_tokuten01 {
	float:left;
    animation-duration: 1s;
    animation-delay: 1s;
}
#tokuten_block .main_tokuten02 {
	float:right;
	animation-duration: 1.5s;
	animation-delay: 1s;
}
#tokuten_block .main_tokuten03 {
	text-align:center;
	animation-duration: 1.5s;
	animation-delay: 1s;
}

@media screen and (max-width: 1200px) {

	#tokuten_block #position_area {
		width:100%;
	}
	#tokuten_block .main_logo {
		width: 55%;
		left: 25px;
	}
	#tokuten_block .present_01 {
		width:40%;
		right: 15px;
	}
	#tokuten_block .main_tokuten01 {
		width: 50%;
	}
	#tokuten_block .main_tokuten02 {
		width: 50%;
	}

}

@media screen and (max-width: 1020px) {

	#tokuten_block .tokuten_area {
		width:95%;
	}
}

@media screen and (max-width: 970px) {

	#tokuten_block .bg_main02 {
		height: 680px;
	}

}
@media screen and (max-width: 840px) {

	#tokuten_block .bg_main02 {
		height: 580px;
	}
	#tokuten_block #position_area {
		width: 100%;
	}
	#tokuten_block .main_logo {
		width: 55%;
		left: 25px;
	}
	#tokuten_block .present_01 {
		width:40%;
		right: 15px;
	}
	#tokuten_block .main_tokuten03 {
		top: 300px;
		left: 0;
		margin: 0 auto;
	}
}

@media screen and (max-width: 740px) {

	#tokuten_block .bg_main02 {
		height: 535px;
	}
}

@media screen and (max-width: 640px) {

	#tokuten_block {
		height: auto;
		padding:20px 0;
		background: url(../img/sp/bg_main01.png) no-repeat;
	}
	#tokuten_block .bg_main02 {
		background:none;
		height: auto;
	}
	#tokuten_block .main_logo {
		position:static;
		width: 90%;
    	margin: 0 auto 10px;
	}
	#tokuten_block .present_01 {
		position:static;
		width: 90%;
    	margin: 0 auto 10px;
	}
	#tokuten_block .main_tokuten01 {
		width: 100%;
		text-align: center;
		margin: auto 0 10px;
	}
	#tokuten_block .main_tokuten02 {
		width: 100%;
		text-align: center;
		margin: auto 0 10px;
	}

}

/*-----------------------------------

	contract_block

-----------------------------------*/

#contract_block {
	padding: 50px 0;
	background: url(../img/bg_main03.png) no-repeat;
    height: 1100px;
    background-size: cover;
}
#contract_block h3{
	position:relative;
	z-index:1;
}
#contract_block h3 img{
	display:block;
	margin:0 auto;
}
#contract_block .contract_left {
	position:absolute;
	left:-50px;
	top:0;
	z-index:-1;
}
#contract_block .contract_right {
	position:absolute;
	right:-50px;
	top:0;
	z-index:-1;
}
#contract_block .contract_img{
	position:relative;
	z-index:1;
}
#contract_block .contract_img img{
    margin: 0 auto;
    text-align: center;
    display: block;
}

@media screen and (max-width: 1100px) {

	#contract_block {
		height: auto;
	}
	#contract_block .contract_left {
		left:0;
	}
	#contract_block .contract_right {
		right:0;
	}

}
@media screen and (max-width: 640px) {

	#contract_block {
		padding: 20px 0;
	}

}
/*-----------------------------------

	subscription_block

-----------------------------------*/

#subscription_block{
	padding: 50px 0;
}
#subscription_block h3 {
    padding: 20px;
    background: #E50012;
    margin-bottom: 15px;
}
#subscription_block h3 img{
	display:block;
	margin:0 auto;
}
#subscription_block .subscription_bg {
	background:#DEF1FB;
	padding:0 0 50px 0;
}
#subscription_block .subscription_wrap {
	width:800px;
	margin:0 auto;
	position:relative;
}
#subscription_block .subscription_img {
	display:block;
	margin:0 auto;
}
#subscription_block .subscription_btn {
    position: absolute;
    right: 0;
    top: 3.3%;
}

@media screen and (max-width: 840px) {

	#subscription_block .subscription_wrap {
		width:90%;
	}
	#subscription_block .subscription_btn {
		width: 34%;
	}

}

@media screen and (max-width: 640px) {

	#subscription_block {
		padding: 20px 0;
	}
	#subscription_block .subscription_bg {
		padding: 0 0 20px 0;
	}
}

/*-----------------------------------

	hukuguruma_block

-----------------------------------*/

#hukuguruma_block {
	padding: 20px 0;
	background: url(../img/bg_main04.png) no-repeat;
    height: 3750px;
    background-size: cover;
}
#hukuguruma_block h3 {
	text-align: center;
	margin: 0 auto;
}
#car_list_01 {
	margin-top: 50px;
}
#car_list_01:first-of-type {
    margin-top: 20px;
}
.car_box {
	margin-bottom: 50px;
}
.car_box:last-child {
	margin-bottom: 0;
}
#hukuguruma_block p {
    text-align: center;
    padding: 20px 0 0 0;
}

@media screen and (max-width: 1100px) {

	#hukuguruma_block{
		height:auto;
	}
}

@media screen and (max-width: 640px) {

	#hukuguruma_block{
		padding: 25px 0;
	}
	#car_list_01 {
		margin-top: 20px;
	}
	.car_box {
		margin-bottom: 20px;
	}

}

/*----------------------------------------

	otoku

----------------------------------------*/

#otoku {
	padding-top: 40px;
}
#otoku .caption {
	display: inline-block;
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 170%;
	margin-bottom: 20px;
	letter-spacing: normal;
}
#otoku .line_box {
	border-top: solid 1px #000;
	padding: 20px 0;
}
#otoku .line_box:last-child {
	border-bottom: solid 1px #000;
}
#otoku .line_box p{
	font-size: 12px;
	font-size: 1.2rem;
	line-height:160%;
}
#otoku .line_box h3{
	font-size: 20px;
	font-size: 2.0rem;
	color:#E50012;
	margin-bottom:10px;
}



/*tyuuko_block*/
#tyuuko_block {
	background:#004DA0;
	padding:40px 0 180px 0;
	text-align:center;
	margin-top:60px;
}
#tyuuko_block p{
	color:#fff;
	font-size: 1.6em;
	font-size:16px;
	line-height:200%;
	margin:25px 0;
}

@media screen and (max-width: 1100px) {

	#tyuuko_block {
		padding: 40px 0 90px 0;
		margin-top: 30px;
	}

}

@media screen and (max-width: 640px) {

	#otoku {
		padding-top: 25px;
	}
	#tyuuko_block {
		padding: 40px 0;
		margin-top: 25px;
	}
	#tyuuko_block h3{
		width:200px;
		text-align:center;
		margin:0 auto;
	}
	#tyuuko_block p{
		font-size: 1.4em;
		font-size:14px;
	}

}

/*----------------------------------------

    pagetop

----------------------------------------*/
#fixed_box {
    position: absolute;
    left:50%;
    bottom: 0;
	width: 1000px;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
    z-index: 999;
}
#fixed_box.fixed {
	position: fixed;
	bottom: 30px;
}
#fixed_box .pagetop_btn {
    position: absolute;
    right: 0;
	bottom: 0;
    width: 60px;
    transition: .3s;
    cursor: pointer;
}
@media screen and (min-width: 1101px) {
	#fixed_box {
		position: fixed !important;
	}
}
@media screen and (max-width: 1100px) {
	#fixed_box {
		position: fixed;
		left: 0;
		width: 100%;
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
		transform: translateX(0);
	}
	#fixed_box .pagetop_btn {
		top: -60px;
	}
}


/*----------------------------------------

   footer

----------------------------------------*/
footer {
    background: #e8e8e8;
    padding: 50px 0 90px 0;
    margin-top: 60px;
}


@media screen and (max-width: 1300px) {

	footer {
		padding: 50px 0;
	}
	.footer_info .left,
	.footer_info .right{
		width:49%;
		text-align:center;
	}
	.footer_info .left{
		margin-right:2%;
	}

}

@media screen and (max-width: 640px) {

	footer {
		padding: 30px 0 80px;
		margin-top: 25px;
	}
	.footer_info .left,
	.footer_info .right{
		width:100%;
		text-align:center;
	}
	.footer_info .left{
		margin-right:0;
		margin-bottom:2%;
	}
}


address {
	clear: both;
	font-size: 13px;
	font-size: 1.3rem;
	font-style: normal;
	text-align: center;
	line-height:50px;
	margin-top: 20px;
}

@media screen and (max-width: 767px) {

	/*address {
		padding: 15px 0;
	}*/

}
