@charset "utf-8";

article {
	font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	color: #292929;
	font-size: 16px;
	line-height: 1.618;
	padding: 0;
}

.tx_pink{
	color: #f53d7e;
}
.btn:hover,
.btn:focus{
	color: #ffffff;
	outline: none;
}
ul,ol,li{
	list-style-type: none;
}

#main_visual{
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
	position: relative;
}
#main_visual h1{
	max-width: 1920px;
	margin: 0 auto;
}
#main_visual h1 img{
	width: 100%;
	height: auto;
}
.under_mv{
	background: #1c1c1c;
	color: #fff;
	font-weight: bold;
	padding: 12px 0;
}
/*-------メインコンテンツ-------*/
.content{
	padding: 32px 0;
	overflow: hidden;
}
.content:nth-child(2n){
	background: #F3F3F3;
}
.content:nth-child(2n-1){
	background: #EBEBEB;
}
#howto p{
	font-size: 18px;
	font-weight: bold;
	padding: 16px 0;
}
#steps h2{
	margin-bottom: 56px;
}
.step_box{
	align-items: stretch;
}
.step{
	position: relative;
	height: 100%;
	background: #fff;
	border: 2px solid #1c1c1c;
	text-align: center;
	padding: 56px 16px 16px;
}
.step .pos_abs{
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
}
.step h3{
	font-size: 20px;
	font-weight: bold;
	display: table;
	position: relative;
	padding-top: 32px;
	margin: 0 auto 24px;
}
.step h3 span{
	font-size: 16px;
	color: #019B65;
	position: absolute;
	display: block;
	width: 100vw;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0%);
}
.step h3:before,.step h3:after{
	content: '';
	display: block;
	position: absolute;
	width: 4px;
	height: 1.414em;
	border-radius: 2px;
	background: #1c1c1c;
}
.step h3:before{
 left: -24px;
 bottom: 0;
 transform: rotate(-15deg);
}
.step h3:after{
 right: -24px;
 bottom: 0;
 transform: rotate(15deg);
}
.step p{
	margin-bottom: 16px;
}
.yellow_btn{
	background: #F9DD00;
	color: #1c1c1c;
	border: 2px solid #1c1c1c;
	font-size: 16px;
	font-weight: bold;
	padding: 10px 24px;
	display: table;
	position: relative;
	margin: 0px auto 16px;
	width: clamp(200px,75%,248px);
	transition: 0.24s ease;
	text-align: center;
}
.yellow_btn:after{
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%) rotate(90deg);
	width: 8px;
	height: 14px;
	background: url(/static/img/campaign/beginner/icon_guide.svg) 50% 50% no-repeat;
	background-size: contain;
}
.yellow_btn:hover{
	filter: brightness(1.05);
	text-decoration: none;
	color: #1c1c1c;
}
.step_box .col-md-2{
	height: 120px;
	position: relative;
}
.step_box .guide{
	display: block;
	position: absolute;
	top: 16px;
	left: 50%;
	transform: translateX(-50%) rotate(90deg);
	width: 21px;
	height: 36px;
	background: url(/static/img/campaign/beginner/icon_guide.svg) 50% 50% no-repeat;
}
.step_box .guide::before{
	content: '';
	display: block;
	position: absolute;
	top: 0px;
	left: 32px;
	width: 21px;
	height: 36px;
	background: url(/static/img/campaign/beginner/icon_guide.svg) 50% 50% no-repeat;
}
#prices h2{
	position: relative;
	display: table;
	margin: 0 auto 40px;
	padding: 0 16px 12px 64px;
	text-align: left;
	font-size: 18px;
	font-weight: bold;
	border-bottom: 2px dashed #1c1c1c;
}
#prices h2:before{
	content: '';
	position: absolute;
	width: 40px;
	height: 32px;
	background: url(/static/img/campaign/beginner/fing.png) 50% 50% no-repeat;
	background-size: contain;
	left: 8px;
	top: 4px;
}
h3.black{
	position: relative;
	background: #1c1c1c;
	color: #fff;
	font-weight: bold;
	font-size: 16px;
	width: 100%;
	height: 56px;
	padding-left: 148px;
	margin-bottom: 40px;
	display: flex;
	align-items: center;
}
h3.black:after{
	content: '';
	display: block;
	position: absolute;
	border-top: 30px solid #1c1c1c;
	border-left: 9px solid transparent;
	border-right: 8px solid transparent;
	bottom: -30px;
	right: 100px;
}
h3.black img{
	width: 140px;
	height: auto;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
h3.black + img{
	width: 100%;
}
.seat_name{
	padding: 8px 0;
	font-size: 15px;
	font-weight: bold;
	display: flex;
	align-items: baseline;
}
.seat_name .small{
	font-weight: bold;
}
.seat_name .price{
	color: #FB6868;
	font-size: 24px;
	flex: auto;
	text-align: right;
}
.seat_name .price i{
	font-size: 16px;
}
.dep{
	margin: 24px 0;
	padding: 24px 24px 8px;
	border-top: 1px dashed #1c1c1c;
	border-bottom: 1px dashed #1c1c1c;
	position: relative;
}
.dep h4{
	background: #1c1c1c;
	color: #fff;
	position: absolute;
	display: table;
	height: 30px;
	padding: 6px 16px;
	font-size: 14px;
	font-weight: bold;
	top: 0;
	left: 0;
	transform: translateY(-50%);
}
.dep h4:after{
	content: '';
	display: block;
	position: absolute;
	border: 15px solid transparent;
	border-left-color: #1c1c1c;
	top: 0;
	right: -30px;
}
.point{
	display: flex;
	align-items: flex-start;
	padding: 0 24px;
}
.point img{
	width: 56px;
	height: 56px;
}
.point p{
	padding: 8px 0 0 16px;
	font-size: 14px;
	margin-bottom: 24px;
}
.point p strong{
	color: #FB6868;
}
#prices .yellow_btn{
	width: 100%;
	padding: 16px 24px 16px 16px;
}
#prices .yellow_btn:after{
	transform: translateY(-50%) rotate(0deg);
}
#prices .col-md-6{
	margin-bottom: 48px;
}
.hotel_set h3{
	display: table;
	margin: 0 auto 16px;
	font-size: 18px;
	font-weight: bold;
	position: relative;
}
.hotel_set h3:before,.hotel_set h3:after{
	content: '';
	display: block;
	position: absolute;
	width: 4px;
	height: 1.414em;
	border-radius: 2px;
	background: #1c1c1c;
}
.hotel_set h3:before{
 left: -24px;
 bottom: 0;
 transform: rotate(-20deg);
}
.hotel_set h3:after{
 right: -24px;
 bottom: 0;
 transform: rotate(20deg);
}
.green_btn{
	background: #019B65;
	color: #fff;
	border: 2px solid #1c1c1c;
	font-size: 16px;
	font-weight: bold;
	padding: 10px 24px;
	display: table;
	position: relative;
	margin: 0px auto 16px;
	width: 100%;
	padding: 16px 24px 16px 16px;
	transition: 0.24s ease;
	text-align: center;
}
.green_btn:after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%) rotate(0deg);
	width: 8px;
	height: 14px;
	background: url(/static/img/campaign/beginner/icon_guide.svg) 50% 50% no-repeat;
	background-size: contain;
	filter: brightness(10);
}
.green_btn:hover{
	filter: brightness(1.05);
	text-decoration: none;
	color: #fff;
}
.mayotta h3{
	display: table;
	margin: 32px auto 16px;
	padding: 0 4px 0 8px;
	font-size: 18px;
	font-weight: bold;
	border-bottom: 5px solid #F9DD00;
}
.more_points li{
	text-align: center;
	margin-bottom: 16px;
}
.more_points li div{
	background: #fff;
	border: 2px solid #1c1c1c;
	padding: 40px 32px 24px;
	position: relative;
}
.more_points li div:before{
	content: '';
	display: block;
	position: absolute;
	border-top: 30px solid #F9DD00;
	border-right: 32px solid transparent;
	border-left: 32px solid transparent;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
.points{
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 16px;
}
.more_points p:not(.points){
	font-size: 14px;
	margin-bottom: 12px;
}
#blog_posts h2{
	position: relative;
	display: table;
	margin: 0 auto 24px;
	padding: 8px 16px 16px 64px;
	text-align: left;
	font-size: 18px;
	font-weight: bold;
	border-bottom: 2px dashed #1c1c1c;
}
#blog_posts h2:before{
	content: '';
	position: absolute;
	width: 40px;
	height: 32px;
	background: url(/static/img/campaign/beginner/fing.png) 50% 50% no-repeat;
	background-size: contain;
	left: 8px;
	top: 4px;
}
#blog_posts div{
	margin-bottom: 16px;
}
#blog_posts div a{
	display: block;
	background: #fff;
	padding: 16px 16px 24px;
	box-shadow: 0px 2px 8px -4px rgba(0,0,0,0.2);
	transition: 0.24s ease;
}
#blog_posts div a:hover{
	filter: brightness(1.05);
	box-shadow: 0px 2px 4px -2px rgba(0,0,0,0.4);
	text-decoration: none;
}
#blog_posts div a img{
	width: 100%;
	height: 186px;
	object-fit: cover;
	object-position: center center;
	margin-bottom: 16px;
}
#blog_posts div a p{
	color: #1c1c1c;
	text-decoration: none;
	font-size: 14px;
}





@media (max-width:350px) {/*Narrow SP*/
	article,article p{
		font-size: 14px;
	}
}

@media (min-width:768px) {/*Tablet*/
	.content{
		padding: 64px 0;
	}
	.step{
		padding: 56px 8px 16px;
	}
	.step .pos_abs{
		width: 160px;
		height: auto;
	}
	.step h3{
		font-size: 18px;
	}
	.step_box .col-md-2{
		height: auto;
	}
	.step_box .guide{
		top: 50%;
		transform: translate(-50%, -50%) rotate(0deg);
	}
	.step_box .guide:after {
		content: '';
		display: block;
		position: absolute;
		top: 0px;
		right: 32px;
		width: 21px;
		height: 36px;
		background: url(/static/img/campaign/beginner/icon_guide.svg) 50% 50% no-repeat;
	}
	#prices .col-md-6 {
		display: flex;
		flex-direction: column;
		padding-bottom: 64px;
		position: relative;
	}
	#prices .col-md-6 .yellow_btn{
		position: absolute;
		bottom: 0;
		margin-bottom: 0;
		width: 90%;
		max-width: 328px;
	}
	#prices h2{
		padding: 0 8px 12px;
	}
	#prices h2:before{
		left: -48px;
		top: 0px;
	}
	.dep{
		margin-bottom: 16px;
		padding: 24px 16px 8px;
	}
	.point{
		padding: 0 16px;
	}
	.green_btn{
		width: 440px;
	}
	.more_points{
		align-items: stretch;
	}
	.more_points li div{
		height: 100%;
		padding: 40px 8px 24px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: space-between;
	}
	.points{
		margin-bottom: 8px;
	}
	.more_points p:not(.points){
		font-size: 12px;
	}
	#blog_posts div a{
		height: 100%;
	}
}
@media (min-width:992px) {
	.dep{
		height: 86px;
	}
	#prices .col-md-6 .yellow_btn{
		font-size: 14px;
	}
}
@media (min-width:1200px) {

}
