
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&display=swap');
/*
// <weight>: Use a value from 100 to 900
// <uniquifier>: Use a unique and descriptive class name

.noto-sans-jp-<uniquifier> {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.kosugi-maru-regular {
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
}
*/

h2,h3,h4,h5{
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
}

/*全体・リセット---------------------*/
header, nav, article, aside, section, footer {
	display:block;
}
.st2-page-title {
    padding: 0.5rem 20px 0;
    margin-bottom: 0.5rem;
}
.st2-page-title__heading__txt {
	font-size: 1.3rem;
	font-weight: normal;
}
.st2-main-container {
	padding-top: 0;
}
.st2-contents-wrapper>div>div {
	padding: 0;
}
a{
	color: #0048ab;
}
h2{
	margin:0;
}
p,ul,li,dl,dt,dd{
	margin: 0;
	padding: 0;
	line-height: 1.8;
}
li,ul{
	list-style: none;
}
a:hover  {
	text-decoration: none;
	opacity:0.6;
	transition:0.3s;
}
.red{
	color: #cd0808;
}
.yellow{
	color: #fffc1e;
}
.yellow .st2-icon-pdf{
	fill: #fffc1e;
}
.L01 {
	font-size: 200%;
}
.L02 {
	font-size: 120%;
}
.S01 {
	font-size: 75%;
}
#blk04 .S01 {
	font-size: 85%;
}
.S02 {
	font-size:50%;
}
.pa04 {
	padding-top: 4rem;
}
.indent {
	text-align: left;
	padding-left: 1.5rem;
	text-indent: -1.5rem;
	display: block;
	line-height: 1.8;
}
.box_ind {
	margin:0 2rem;
}
.ind_area {
	margin-top: 1rem;
}
.indent2 {
	text-align: left;
	padding-left: 2rem;
	text-indent: -2rem;
}
.mt_n {
	margin-top:0;
}
.mb_1 {
	margin-bottom:1rem;
}
.st2-color-layout {
    margin: 0 0 3rem;
}
a .st2-icon-newwin, a .st2-icon-pdf {
    vertical-align: baseline;
    width: 0.7em;
    height: 0.7em;
    fill: #0b499d;
}
dl{
	display: flex;
	padding-right: 0.5rem;
}

@media (min-width: 737px) {
	.pc_none{
		display:none;
	}
}

@media (max-width: 736px) {
	.S01 {
		font-size: 86%;
		line-height: 1.6;
	}
	.S02 {
		font-size: 75%;
		margin: 0;
	}
	.sp_none{
		display:none;
	}
	.st2-site-footer__page-to-top.this-active a {
		bottom:8rem;
	}
	.st2-page-title {
		padding: 0.5rem 0.5rem 0;
	}
	.st2-page-title__heading__txt {
        margin: 0;
		font-size: 1.0rem;
    }
	.box_ind {
		margin:0 2% 2rem;
	}
	.pa04 {
		padding-top: 1rem;
	}
	.indent {
		margin-bottom: 0.7rem;
	}
	.contact .ind_area {
		margin-bottom: -1rem;
	}
	dt{
		width: 5em;
	}
	.mail_area dt{
		width: 3em;
	}
	dd{
		flex: 1;
	}

}


/*各section共通---------------------*/
.blk_wrapper{
	padding: 0 20px;
}
#blk02 .blk_inner,
#blk03 .blk_inner{
	max-width: 1100px;
    position: relative;
    margin: 0 auto;
    font-size: 1.7rem;
    background-color: rgb(255 255 255 / 70%);
    backdrop-filter: blur(50px);
    box-sizing: border-box;
    padding:3rem 4rem 5rem;
    border-radius: 20px;
    box-shadow: 0px 0px 30px #00000061;
}
#blk04 .blk_inner{
	max-width: 1100px;
    position: relative;
    margin: 0 auto;
    font-size: 1.4rem;
    background-color: rgb(255 255 255 / 70%);
    backdrop-filter: blur(50px);
    box-sizing: border-box;
    padding:4rem 4rem 3rem;
    border-radius: 20px;
    box-shadow: 0px 0px 30px #00000061;
}

@media (max-width:1024px) {
}

@media (max-width: 736px) {
	.blk_wrapper{
		margin-top: 0;
		padding: 0 2.8205128205%;
	}
	.blk_inner {
		font-size: 1.2rem !important;
	}
	#blk02 .blk_inner,
	#blk03 .blk_inner,
	#blk04 .blk_inner{
		border-radius: 15px;
		padding:2rem 2.989%;
		box-sizing: border-box;
	}
	
	#blk02.contact .blk_inner{
		border-radius: 15px;
		padding:2rem;
		box-sizing: border-box;
	}
}


/*MV---------------------*/
#blk01 {
	margin-bottom: 10rem;
}
#top_img img{
	text-align: center;
	width: 100%;
	display: block;
	margin: 0 auto;
}
#blk01 p.text{
	margin:0;
	font-weight: 400;
	font-style: normal;
	font-size: 3.5rem;
	text-align: center;
	color: #fff;
	background: url(/highclass-sale/images/highclass-sale_bk_red.jpg) repeat;
}
#blk01 p.text span{
    font-size: 1.5rem;
    line-height: 1.2;
	padding: 0 0 1rem 0;
	display: block;
}

@media (max-width: 1024px) {
	#blk01 p.text{
		font-size: 2.5rem;
	}
}

@media (max-width: 736px) {
	#blk01 {
		background-size: 100%;
		margin-bottom: 5rem;
	}
	#top_img p{
		width: 100%;
		margin: 0 auto;
	}
	#blk01 p.text{
		font-size: 1.5rem;
	}
	#blk01 p.text span{	
		padding: 0.2rem;	
		border-radius: 2px;	
		margin-right: 1rem;	
		font-size: 1.0rem;	
	}
}


/*MV下---------------------*/
#main_txt{
	text-align: center;
	color: #ff3d00;
	margin: 0;
}
#main_txt .main_txt_01 {
	font-size: 2.5rem;
	margin: 0 -20px;
	padding: 2rem 2rem 1rem 2rem;
	line-height: 1.4;
	background-color: rgb(255 255 255 / 80%);
	font-family: "Kosugi Maru", sans-serif;
	font-weight: bold;
	font-style: normal;
}
#main_txt .main_txt_02 {
    font-size: 2.8rem;
    background:#fffc1e;
	max-width: 900px;
	padding: 1rem 0;
	border: 2px solid #03287c;
    margin: 0 auto;
	color: #03287c;
	font-weight: bold;
}
#main_txt .main_txt_03 {
    font-size: 1.6rem;
}
#main_txt .main_txt_03 {
    font-size: 1.8rem;
    line-height: 1.2;
	margin: 1rem 2rem;
}
#main_txt .main_txt_04 {
    font-size: 2.5rem;
    line-height: 1.2;
    font-weight: bold;
}

@media (max-width: 1024px) {
	#main_txt .main_txt_01 {
		font-size: 1.8rem;
		line-height: 1.4;
	}
}

@media (max-width: 736px) {
	#main_txt .main_txt_01 {
		font-size: 1.2rem;
		line-height: 2.0rem;
        margin-bottom: 1rem;
		text-align: left;
		padding:2rem 2.989%;
		margin: 2rem -2.989% 0;
	}
	#main_txt .main_txt_02 {
		font-size: 1.4rem;
		line-height: 1.2;
	}
	#main_txt .main_txt_03 {
		font-size: 1.2rem;
		margin-top: 0.5rem;
	}
	#main_txt .main_txt_04 {
		margin-top: 2rem;
        font-size: 1.5rem;
	}
}

/*back---------------------*/

.all_bk{
	background-color: #ffea00;
	padding-bottom: 5rem;
}

@media (max-width: 736px) {
	.all_bk{
		padding-bottom: 1rem;
	}
}

/*H2---------------------*/
h2{
	margin-bottom:3rem;
	text-align: center;
	padding: 1rem 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
h2 span{
	display: inline-block;
	font-weight: 600;
	font-style: normal;
	color: #5f1e00;
	font-size: 4.5rem;
	position: relative;
	line-height: 1.2;
}
h2 img{
	margin:0 15px;
}
.contact h2{
	display: block;
}
.contact h2 span{
	font-size: 3.5rem;
}

@media (max-width: 1024px) {
	h2 span{
		font-size: 3.5rem;
	}
}
@media (max-width: 736px) {
	h2{
		margin-bottom:1.5rem;
		background-size: 80%;
		padding: 0;
	}
	h2 img{
		margin: 0 8px;
		width: 60px;
	}
	h2 span{
		font-size: 1.8rem;
		line-height: 1.4;
	}
	.contact h2 span{
		font-size: 1.5rem;
	}
}

/*H3---------------------*/

h3 {
	color: #333333;
	border-left: #ff6000 solid 8px;
	font-size: 2.4rem;
	padding-left: 1.5rem;
	margin: 2.5rem 0 2rem;
}

#blk04 h3 {
    color: #333333;
    border-left: none;
    line-height: 1.5;
    font-size: 1.8rem;
    padding-left: 0;
    margin: 1.5rem 0 0.5rem;
}

@media (max-width: 1024px) {
	h3 {
		font-size: 2.3rem;
	}
}
@media (max-width: 736px) {
	h3 {
		font-size: 1.4rem;
		padding-left: 0.8rem;
		border-left: 5px solid #e60012;
		line-height: 1.5;
		margin: 0 0 1rem;
	}
	#blk04 h3 {
		font-size: 1.4rem;
	}

}


/*キャンペーン概要---------------------*/
#blk02 {
	margin-bottom: 7rem;
}
#blk02 .box_ind a {
	color: #0b499d;
	text-decoration: underline;
}
#blk02 .box_ind a:hover {
	text-decoration:none;
}

.st2-list__item {
	font-size: 1.4rem;
}
.ticket{
	border: 1px solid #afafaf;
	background-color: rgb(255 255 255 / 80%);
	padding: 1rem 2rem;
	margin: 1rem 1rem 2rem;
	font-size: 1.4rem;
}
.ticket dl{
	padding-left: 1em;
}
.process{
    margin: 3rem auto;
}
.process ul{
	display: flex;
	align-items: flex-end;
}
.process ul li{
	position: relative;
	margin-right: 37px;
}
.process ul li:last-child{
	margin-right:0;
}
.process ul li:before{
	content: url(/cpn/hatsuuri/line-cpn/images/line-cpn_process_arrow.png);
	position: absolute;
	display: block;
	bottom:86px;
	right: -35px;
}
.process ul li:last-child:before{
	display: none;
}
.process p{
	margin-top: 2rem;
}

@media (max-width: 736px) {
	#blk02 {
		margin-bottom: 6rem;
	}
	.ticket{
		padding: 0.5rem 1rem;
		margin:1rem 0 2rem;
		font-size: 1.0rem;
	}
	.ticket p{
		padding-bottom: 0.5rem;
	}
	.ticket dl{
		padding: 0;
	}
	.ticket dt,.ticket dd{
		line-height: 1.4;
	}
	.process{
		margin:2rem auto -1rem;
	}
	.process ul{
		align-items: flex-end;
		flex-wrap: wrap;
	}
    .process ul li {
        margin-right: 6%;
        width: 44%;
		margin-bottom: 2rem;
    }
	.process ul li:last-child{
	margin-right:0;
	}
	.process ul li:before {
		content: "";
        background-image: url(/cpn/hatsuuri/line-cpn/images/line-cpn_process_arrow.png);
        background-repeat: no-repeat;
        background-size: 15px;
        background-position: 0 0;
        bottom: 80px;
        right: -18px;
        position: absolute;
        display: block;
        width: 15px;
        height: 34px;
	}
	.process p{
		margin-top: -1rem;
		margin-bottom: 3rem;
	}

}


/*応募ボタン---------------------*/

.btn_box{
	max-width: 1110px;
	margin: 0 auto 16rem;
	padding: 0 2rem;
}
.blk_inner .btn_box{
	max-width: 1110px;
	margin: 6rem auto 0;
	padding: 0 2rem;
	border-top: dotted 4px #07af39;
}
.btn_box .btn_catch{
	font-size: 2.3rem;
	font-weight: bold;
	color: #5f1e00;
	text-align: center;
	margin-bottom: 0.5rem;
}
.blk_inner .btn_box .btn_catch{
	color: #07af38;
	padding-top:3rem;
}

.btn_box .btn a{
    background-color: #07af39;
    position: relative;
    border: #fff 3px solid;
    border-radius: 100px;
    padding: 1.5rem 3rem;
    box-sizing: border-box;
    width: 540px;
    box-shadow: 0px 10px 13px -6px #817600;
    margin: 0 auto;
	color: #fff;
	line-height: 1.2;
	font-size: 2.0rem;
	text-align: center;
	display: block;
}
.btn_box .btn.bt_yellow a{
    background-color:#ff6000;
    width: 800px;
	font-weight: bold;
	color: #fff;
	font-size: 3.0rem;
	line-height: 0.8;
	padding: 2rem 3rem 1.5rem;
}
.btn_box .btn.bt_yellow a span{
	font-size: 1.4rem;
	font-weight: normal;
}

.btn_box .btn a span{
	font-size: 1.4rem;
}
.btn_box .btn .st2-icon-right-arrow{
	width: 1.5rem;
    height: 1.5rem;
    position: absolute;
    fill: #fff;
    top: 50%;
    right: 10px;
    transform: translate(0, -50%);
}
.btn_box .btn.bt_yellow .st2-icon-right-arrow{
    fill: #fff;
}
.btn_box .btn_text{
    text-align: center;
    font-size: 1.7rem;
    color: #5f1e00;
    margin-top: 2rem;
    line-height: 1.4;
}
.blk_inner .btn_box .btn_text{
    color: #07af38;
}

.btn_box .btn_text a{
	font-weight: bold;
	color:#c30000;
	text-decoration: underline;
}
@media (max-width: 736px) {
	.btn_box {
		padding: 0 2.989%;
		margin: 0 auto 8rem;
	}
	.btn_box .btn.bt_yellow a{
		width: 100%;
		font-size:1.8rem;
		padding:1.4rem 2rem 1.0rem;
	}
	.btn_box .btn.bt_yellow a span {
		font-size: 1.0rem;
	}
	.btn_box .btn a {
		width: 94%;
		padding: 0.8rem 2rem;
		box-shadow: 0px 10px 13px -6px #817600;
		font-size: 1.3rem;
	}
	.btn_box .btn_catch {
		font-size: 1.4rem;
		line-height: 1.4;
	}
	.btn_box .btn_text {
		font-size: 1.2rem;
		margin-top: 1.0rem;
	}
	.blk_inner .btn_box{
		margin: 6rem auto 3rem;
		padding: 0;
	}
	.blk_inner .btn_box .btn_catch{
		padding-top:2rem;
	}
	.btn_box .btn .st2-icon-right-arrow{
		width: 1.3rem;
		height: 1.3rem;
	}

}


/*ご利用---------------------*/
#blk04{
	margin-bottom: 7rem;
}
#blk04 p{
	line-height: 1.6;
	margin-top: 1rem;
	margin-bottom: 1rem;
}
#blk04 ul {
    max-width: 1100px;
    margin: 0 auto;
}
#blk04 .con_blk {
	border: 1px solid #ccc;
	padding: 2rem 4rem;
	margin-bottom:6rem;
}
#blk04 .con_blk dl {
	font-size: 90%;
}
#blk04 .con_blk dt{
	font-weight: bold;
}
#blk04 .con_blk dd{
	margin-left: 2rem;
}
#blk04 .con_blk dd ul{
    padding-left: 1em;
}
#blk04 li{
	margin-bottom: 0.5rem;
	font-weight: normal;
	line-height: 1.4;
}
#blk04 .ind_area li{
	margin-bottom: 0.5rem;
}
#blk04 li p{
	margin: 0;
}

.st2-accordion--more__body[aria-hidden=true]::after{
	display: none;
}
.st2-api__accordion--more, .st2-accordion--more {
    margin-bottom: 0rem;
}
.st2-accordion--more__title{
	font-size: 1.6rem;
	padding-top: 1rem;
}
@media (max-width: 736px) {
	#blk04 p{
		margin-top: 0;
		margin-bottom:0;
	}
	#blk04 .st2-accordion--more__body p{
		margin-top: 0;
		margin-bottom:1rem;
	}
	#blk04 .con_blk {
		padding: 1rem;
		margin-bottom: 3rem;
	}
	#blk04 li{
		margin-bottom: 1.2rem;
	}
    #blk04 ul{
        padding-left:0;
    }
	.st2-accordion--more__title {
		font-size: 1.2rem;
	}
	#blk04 .st2-list {
		margin-bottom: -3rem;
	}
}

#blk04 .st2-list a{
	font-weight: normal;
	font-size: 1.4rem;
}
#blk04 .st2-list a:hover{
	text-decoration: none;
}

@media (max-width: 736px) {
	#blk04 .st2-list,
	#blk04 .blk_inner,
	#blk04 .st2-list a{
		font-size: 1.1rem !important;
	}
	#blk04 .st2-list__holder{
		padding-left: 0;
	}
}

/*お問い合わせ---------------------*/

#blk02 .text_b{
	margin-top: 2rem;
    font-weight: bold;
    font-size: 2.0rem;
}
@media (max-width: 736px) {
	#blk02 .text_b {
		margin-top: 0;
		line-height: 1.4;
		font-size: 1.3rem;
	}
}
/*関連---------------------*/
.st2-color-layout[data-color="1"]>div>div {
	padding: 6rem 0 7rem;
}

#other{
	margin:7rem auto 10rem;
}
#other p{
	color: #bd0100;
	font-size: 2.3rem;
}


@media (max-width:1024px) {
	#other img{
		width: 60%;
	}
}

@media (max-width: 736px) {
	#other{
		padding: 0 2.989%;
		margin:7rem auto 0;
	}
	#other p{
		font-size: 1.4rem;
		line-height: 1.4;
	}
	#other img{
		width: 100%;
	}

}

/*追従---------------------*/
.fix {
	position: fixed;
	bottom: 0;
	left: 50%;
	transform: translate(-50%, 0);
	width: 100%;
	z-index: 100;
	text-align: center;
}
.fix.tabbottomArea ul {
    justify-content: center;
    max-width: 1100px;
    margin: 0 auto;
    padding:0;
	display: flex;
}
.fix.tabbottomArea li{
	width: 100%;
	list-style: none;
	margin-right: 1%;
	vertical-align:bottom;
}
.fix.tabbottomArea li:last-child,
.fix.tabbottomArea li:nth-child(2n){
	margin-right: 0;
}

.fix.tabbottomArea a{
	display: block;
	padding: 1rem 0;
	border-radius: 20px 20px 0 0;
}
.fix.tabbottomArea a.bt_left{
	background-color: #07af39;
}
.fix.tabbottomArea a.bt_right{
	background-color: #ff6000;
}

.tabbottomArea a {
	flex: 1;
}
.tabbottomArea a:hover{
	opacity: 0.8;
	text-decoration: none;
}

@media screen and (max-width:1024px) {
}

@media screen and (max-width:820px) {
}

@media screen and (max-width:736px) {
	.fix {
		width: 95%;
	}
	.fix.tabbottomArea ul li {
		width: 94%;
		padding-bottom:0;
	}
	.fix.tabbottomArea ul li img {
		width: 80%;
	}
	.fix.tabbottomArea a{
		display: block;
		padding: 1rem 0;
		border-radius: 10px 10px 0 0;
	}
}



.st2-site-footer__page-to-top a{
	z-index: 1000;
}



/*終了時*/
.main_txt_05 {
    border: solid 2px #f6ff00;
    text-align: center;
    font-weight: bold;
    color:#f6ff00;
    margin: 0 auto;
    max-width: 820px;
    box-sizing: border-box;
    padding: 2rem;
    font-size: 2.5rem;
}
@media (max-width: 736px){
	.main_txt_05 {
		padding: 1rem 2rem;
		font-size: 1.4rem;
		line-height: 2.4rem;
	}
}

/*フェードアップ---------------------*/

.fadeUpTrigger{
opacity: 0;
}

.fadeUp {
    animation-name: fadeUpAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity: 0;
}
@keyframes fadeUpAnime{
from {
    opacity: 0;
    transform: translateY(100px);
}
to {
    opacity: 1;
    transform: translateY(0);
}

}




.d-blk{
	display:none;
}
.fix.tabbottomArea li.d-blk{
	width:80%;
	list-style: none;
	margin-right: 1%;
	vertical-align:bottom;
}

@media (max-width: 736px) {
	.fix.tabbottomArea li.d-blk{
		width:60%;
	}
}



