@charset "utf-8";
.mb05{
	margin-bottom: 5px;
}
.mb10{
	margin-bottom: 10px;
}
.mb15{
	margin-bottom: 15px;
}
.mb20{
	margin-bottom: 20px;
}
.mb25{
	margin-bottom: 25px;
}
.mb30{
	margin-bottom: 30px;
}
.ui_tac{
	text-align: center;
}
.ui_df_ac{
	align-items: center!important;
}
.ui_por{
	position: relative;
	z-index: 2;
}
.pcNone{
	display: none;
}
.kv_gif{
	position: absolute;
	top: 73px;
	left: 41.5%;
	width: 134px;
	height: 134px;
}
.ui_totop_wp{
	position: fixed;
	left: calc(50% + 490px);
	bottom: 20px;
	z-index: 99;
}
.ui_totop{
	width: 40px;
	height: 40px;
	border-radius: 20px;
	background: rgba(0,0,0,0.5);
}
.ui_totop::after{
	content: "";
	position: absolute;
	top: calc(50% - 4px);
	left: calc(50% - 6px);
	width: 12px;
	height: 12px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(-45deg);
}
.ui_totop.is_on{
    opacity: 1;
}
.ui_totop.is_on:hover{
	opacity: 0.6;
}

@media only screen and (min-width: 0) and (max-width: 767px) {
	.ui_menu_wp{
		display: flex;
		justify-content: space-between;
		align-items: center;
		color: #fff;
		font-family: YuGothic, "Yu Gothic", "Yu Gothic Medium" , "Hiragino Kaku Gothic ProN", sans-serif;
		font-weight: bold;
	}
	.ui_menu{
		transition: 0.6s cubic-bezier(0.25,0.1,0.25,1);
	}
	.ui_menu_list{
		display: flex;
	}
	.ui_menu_list>li{
		position: relative;
		padding: 0 25px;
		text-align: left;
	}
	.ui_menu_list>li:last-child a,
	.ui_menu_list>li:last-child span{
		border-bottom: none;
	}
	.ui_menu_list>li>a,.ui_menu_list>li>span{
		position: relative;
		display: block;
		padding: 9px 0 7px;
		color: #000;
		text-decoration: none;
		border-bottom: 1px solid #fff;
	}
	.ui_menu_list>li>a::after{
		content: "";
		position: absolute;
		top: 50%;
		right: 5px;
		width: 8px;
		height: 8px;
		border-top: 2px solid currentColor;
		border-right: 2px solid currentColor;
		transform: translateY(-50%) rotate(45deg);
	}
	.ui_menu_list>li>a:hover,.ui_menu_list>li>span:hover{
		opacity:1;
	}
	.ui_menu_btn{
		position: fixed;
		right: 8vw;
		top: 14px;
		z-index: 99;
		width: 2.5em;
		height: 2.5em;
		font-size: 1.38em;
		cursor: pointer;
		border: 1px solid #000;
		background: #fff;
	}
	.ui_menu_btn span{
		width: 1.4em;
	    height: 2px;
	    background-color: #000;
	    position: absolute;
	    left: calc(50% - 0.7em);
	    transition: all 0.3s ease;
	    opacity: 1;
	}
	.ui_menu_btn span:nth-child(1){
		top: 0.8em;
	}
	.ui_menu_btn span:nth-child(2){
		top: 1.2em;
	}
	.ui_menu_btn span:nth-child(3){
		top: 1.6em;
	}
	.is_open.ui_menu_wp .ui_menu{
		z-index: 98;
		opacity: 1;
		transition: 0.6s cubic-bezier(0.25,0.1,0.25,1);
	}
	.is_open .ui_menu_btn span:nth-child(1) {
		top: 1.2em;
		transform: rotate(45deg);
	}
	.is_open .ui_menu_btn span:nth-child(2) {
		opacity: 0;
	}
	.is_open .ui_menu_btn span:nth-child(3) {
		top: 1.2em;
		transform: rotate(-45deg);
	}
	.is_open .ui_menu_btn{
		border-color: transparent;
	}
	.ui_menu{
		margin: 0!important;
		width: 280px!important;
		max-height: 100vh;
		overflow: auto;
		padding: 2px;
		position: fixed;
		right: 6.5vw;
		top: 12px;		
		background: rgba(222,177,101);
		opacity: 0;
		z-index: -1;
		text-align: center;
	}
	.ui_menu_in{
		padding: 60px 0 20px;
		color: #000;
	}
	.ui_menu_list{
		display: block;
	}
	.ui_menu h4{
		margin-bottom: 5px;
	}
	.ui_menu h4 img{
		width: 44px;
	}
	.ui_totop_wp{
		left: auto;
		right: 10px;
		bottom: 10px;
	}
	
	
}
.ui_open_btn.btn_tit01::before{
	border-top: 3px solid #e60012;
	border-right: 3px solid #e60012;
}
.ui_open_close::before{
	content: '';
	display: inline-block;
	vertical-align: middle;
	margin-top: 0;
	margin-right: 5px;
	width: 0;
	height: 0;
	border: none;
	border-style: solid;
	border-color: currentColor transparent transparent transparent;
	border-width: 11px 8px 0 8px;
	transform: rotate(180deg) !important;
}
.ui_open_close img{
	width: auto;
	height: 18px;
}
.ui_open_btn.is_on::after{
	margin-top: 0;
	transform: rotate(180deg);
}
.ui_open_btn.is_on{
	display: none;
}
.ui_open_box{
	padding-top: 10px;
	display: none;
}
.open_fade{
	opacity: 0;
}
.ui_fade,.ui_fade_i{
	transition: all 1000ms;
	opacity: 0;
	visibility: hidden;
	transform: translate(0px, 50px);
}
.ui_fadein{
	opacity: 1;
	visibility: visible;
	transform: translate(0px, 0px);
}


/* == / modal == */
.ui_modal_wp,.ui_modal_over{
	position: fixed;
	z-index: 100;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.ui_modal_wp{
	display: none;
	opacity: 0;
}
.ui_modal_over{
	background: rgba(255,255,255,0.9);
}
.ui_modal_container{
	padding: 20px 15px 10px;
	position: relative;
	z-index: 101;
	max-height: 86vh;
    max-width: 754px;
	width: calc(100% - 30px);
	display: flex;
	flex-direction: column;
	background: url(../images/bg_mod_pc.png) repeat-y;
	background-size: 100% auto;
	font-size: 1.4rem;
	line-height: 1.4;
}
.ui_modal_container::before{
    content: '';
    position: absolute;
    z-index: 1;
    top: -44px;
    left: -1px;
    width: calc(100% + 2px);
    height: 45px;
    background: url(../images/bg_mod01_pc.png) no-repeat;
    background-size: 100% auto;
}
.ui_modal_container::after {
    content: '';
    position: absolute;
    z-index: 1;
    bottom: -44px;
    left: -1px;
    width: calc(100% + 2px);
    height: 45px;
    background: url(../images/bg_mod02_pc.png) no-repeat center bottom;
    background-size: 100% auto;
}
.mod_bg2 .ui_modal_container{
	background-image: url(../images/bg_mod_b_pc.png);
	color: #231815;
}
.mod_bg2 .ui_modal_container::before{
	background-image: url(../images/bg_mod_b01_pc.png);
}
.mod_bg2 .ui_modal_container::after{
	background-image: url(../images/bg_mod_b02_pc.png);
}
.mod_bg2 .ui_modal_close{
	background-image: url(../images/mod_close_b.png);
}
.mod_bg2 .ui_modal_body{
	margin: -40px 0 -20px;
}
.ui_modal_s{
	max-width: 500px;
	max-height: 250px;
}
.ui_modal_head{
	position: relative;
	z-index: 102;
}
.ui_modal_head h4{
	margin: 0;	
}
.ui_modal_close{
	position: absolute;
	z-index: 102;
	right: 10px;
	top: -45px;
	width: 32px;
	height: 43px;
	cursor: pointer;
	background: url(../images/mod_close_b.png);
	background-size: 100% 100%;
}
.ui_modal_close:before{
	transform: rotate(45deg);
}
.ui_modal_close:after{
	transform: rotate(-45deg);
}
.ui_modal_content{
	display: none;
}
.ui_modal_body{
	padding: 1px 13px;
	overflow-y: auto;
    position: relative;
	z-index: 3;
}


@media only screen and (min-width: 768px) {
	.mod_bg1 .ui_modal_body{
		overflow: visible;
		padding-top: 20px;
	}
	.ui_modal_body::-webkit-scrollbar {
	  width: 2px;
	}
	.ui_modal_body::-webkit-scrollbar-thumb {
	  background: linear-gradient(to bottom right, #b3abac 0%, #b3abac 100%);
	  border-radius: 5px;
	}
	.ui_modal_body::-webkit-scrollbar-track {
	  background-color: #efedec;
	  border: 1px solid #efedec;
	}
	.ui_modal_body::-webkit-scrollbar-button {
	  background-color: #efedec;
	  border-radius: 5px;
	  height: 0;
	}
	.ui_modal_body::-webkit-scrollbar-button:hover {
	  background-color: #efedec;
	}
}

@media only screen and (min-width: 0) and (max-width: 767px) {
	.ui_modal_over{
		background: #b1dcd5;
		height: calc(100% + 60px);
	}
	.ui_modal_container{
		margin-bottom: auto;
		padding: 0 0 0;
		background: #b1dcd5;
		max-height: none;
		height: 100vh;
		font-size: 1.5rem;
	}
	.ui_modal_container::before,.ui_modal_container::after{
		display: none !important;
	}
	.ui_modal_close{
		right: 0;
		top: 15px;
	}
	.ui_modal_head{
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 70px;
		background: rgba(231,0,18,0);
	}
	.ui_modal_body{
		margin-bottom: auto;
		padding: 70px 0 0;
	}
	.mod_bg2 .ui_modal_over,
	.mod_bg2 .ui_modal_container{
		background: #f8c7cd;
	}
	.mod_bg2 .ui_modal_head{
		background: rgba(232,219,237,0);
	}
	
}

/* == / modal == */

@media only screen and (min-width: 768px) {  /*  PC  */
	.ui_open.is_sp .ui_open_box{
		display: block;
	}
	.ui_open.is_sp .ui_open_btn{
		pointer-events: none;
	}
	.hatc_wp .ui_open.is_sp .ui_open_btn,
	.hatc_wp .ui_open.is_sp .ui_open_close{
		display: none;
	}
	.hatc_wp .ui_open_box{
		padding-top: 0;
	}
	
}

.hat_wrap{
	max-width: 940px;
	margin: 0 auto;
	font-family: 'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',Arial,Helvetica,sans-serif;
	font-size: 1.3rem;
	line-height: 1.4;
	background: #fff url(../images/bg_wrap_pc.jpg) repeat-y center top;
	background-size: 100% auto;
}
.hat_wrap a:hover{
	opacity: 0.7;
}
.ui_font_Yu{
	font-family: YuGothic, "Yu Gothic", "Yu Gothic Medium" , "Hiragino Kaku Gothic ProN", sans-serif;
}
.ui_df{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
}
.hat_wide{
	max-width: 752px;
	width: 100%;
	margin: 0 auto;
}
.hat_wide_s{
	max-width: 654px;
	width: 100%;
	margin: 0 auto;
}
.hat_ctop{
	margin-bottom: 20px;
	padding: 20px 20px 20px;
	background: #fff9b1;
	border-radius: 40px;
	text-align: center;
}
.hat_more{
	position: relative;
	display: block;
	z-index: 3;
	width: 282px;
	margin: 10px auto 0;
	cursor: pointer;
	text-align: center;
}
.hat_more:hover{
	opacity: 0.7;
}
.hat_ctop .hat_more::before{
	border-color: #e6121e;
}
.hata_wp{
	overflow: hidden;
	position: relative;
	z-index: 2;
	margin-bottom: 20px;
	padding: 20px 25px;
	background: url(../images/bg_a_pc.png) repeat-y;
	background-size: 100% auto;
	color: #fff;
}
.hata_wp>*{
	position: relative;
	z-index: 3;
}
.hata_wp::before{
	content: '';
	position: absolute;
	z-index: 1;
	top: -1px;
	left: -1px;
	width: calc(100% + 2px);
	height: 45px;
	background: url(../images/bg_a01_pc.png) no-repeat;
	background-size: 100% 100%;
}
.hata_wp::after{
	content: '';
	position: absolute;
	z-index: 1;
	bottom: -1px;
	left: -1px;
	width: calc(100% + 2px);
	height: 48px;
	background: url(../images/bg_a02_pc.png) no-repeat center bottom;
	background-size: 100% 100%;
}
.hat_col0101{
	margin-bottom: 25px;
	position: relative;
	width: 100%;
}
.hat_col0201{
	margin-bottom: 15px;
	position: relative;
	width: 48.7%;
}
.hata_text{
	position: absolute;
	left: 2%;
	top: 68%;
	width: 96%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	line-height: 1.2;
}
.hata_text h4{
	margin-bottom: 7px;
	width: 100%;
	text-align: center;
}
.hata_text_col01{
	position: relative;
	width: 40%;
	padding-left: 1%;
	transform:scale(0.95 , 1);
}
.hata_text_col01::after{
	content: '';
	position: absolute;
	right: -1%;
	top: 0;
	width: 1px;
	height: 100%;
	background: #fff;
}
.hata_text_col02{
	width: 60%;
	transform:scale(0.95 , 1);
}
.hata_title{
	padding: 10px 0 10px;
	font-size: 2.2rem;
	font-weight: bold;
	text-align: center;
}
.hata_list{
	margin-bottom: 20px;
	display: flex;
	justify-content: space-between;
}
.hata_list li{
	width: 24.5%;
	text-align: center;
}
.hata_list li img{
	width: 75px;
}
.hata_list li h4{
	margin-top: 2px;
	margin-left: -5px;
	margin-right: -5px;
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 38px;
	font-size: 1.4rem;
	line-height: 1.1;
	font-weight: bold;
}
.hatb_wp{
	position: relative;
	overflow: hidden;
	z-index: 2;
	margin-bottom: 20px;
	padding: 20px 25px;
	background: url(../images/bg_b_pc.png) repeat-y;
	background-size: 100% auto;
	color: #fff;
}
.hatb_wp>*{
	position: relative;
	z-index: 3;
}
.hatb_wp::before{
	content: '';
	position: absolute;
	z-index: 1;
	top: -1px;
	left: -1px;
	width: calc(100% + 2px);
	height: 45px;
	background: url(../images/bg_b01_pc.png) no-repeat;
	background-size: 100% auto;
}
.hatb_wp::after{
	content: '';
	position: absolute;
	z-index: 1;
	bottom: -1px;
	left: -1px;
	width: calc(100% + 2px);
	height: 45px;
	background: url(../images/bg_b02_pc.png) no-repeat center bottom;
	background-size: 100% auto;
}
.hat_imgb08{
	margin-top: -9px;
}
.hatb_box{
	margin-bottom: 20px;
	padding: 22px 0 16px;
	display: flex;
	justify-content: center;
	border: 2px solid #fff;
	border-radius: 30px;
}
.hatb_col01{
	width: 40%;
	margin-left: 2%;
}
.hatb_col02{
	margin-left: 3%;
	width: 46%;
}
.hatb_col01 h4{ 
	margin-bottom: 12px;
	position: relative;
	z-index: 3;
	font-size: 1.8rem;
}
.hatb_col01_01{
	margin-top: auto;
	margin-bottom: 10px;
	width: 62%;
}
.hatb_col01_02{
	margin-top: -30px;
	margin-right: 6%;
	width: 26.5%;
}
.hatc_wp{
	margin-bottom: 20px;
	padding: 29px 29px 5px;
	border-radius: 40px;
	background: #fff9b1;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
}
.hat_white{
	padding: 20px 15px 10px;
	background: #fff;
	border-radius: 40px;
}
.hatc_wp .hat_col0201{
	display: flex;
	flex-direction: column;
}
.hatc_item03{
	height: 100%;
}
.hatc_item02{
	margin-top: auto;
}
.hatc_movie{
	text-align: center;
}
.hat_imgc13{
	position: relative;
}
.hat_imgc13 a{
	position: absolute;
	bottom: 0;
	left: 4%;
	width: 92%;
	height: 15%;
}
.hat_imgc13 a:hover{
	background: rgba(255,255,255,0.3);
}

.hat_foot{
	padding: 18px;
	text-align: center;
	line-height: 1;
}
.hat_foot img{
	width: 275px;
}
.hata_notes{
	margin: 0 0 35px;
	text-align: right;
	font-size: 1.2rem;
}
.hat_note{
	font-size: 1.3rem;
	line-height: 1.6;
}
.hat_note_box{
	margin: 0 2.5% 25px;
}
.hat_mb .hat_note_box{
	margin-left: 0;
	margin-right: 0;
	color: #000;
}
.hatb_wp .hat_note_box{
	margin-left: 1%;
	margin-right: 1%;
}
.hat_mbox{
	position: relative;
	padding-bottom: 56px;
	margin-top: 18px;
	background: url(../images/bg_m01_pc.png) repeat-y center top;
	background-size: 100% auto;
}
.hat_mbox::after{
	content: '';
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 100%;
	height: 56px;
	background: url(../images/bg_m02_pc.png) no-repeat center bottom;
	background-size: 100% 100%;
}
.hatb_wp .hata_text{
	top: 67.3%;
}
.hatb_wp .hata_text_col01{
	width: 61.5%;
	padding-left: 0;
}
.hatb_wp .hata_text_col02{
	width: 38%;
}
@media only screen and (min-width: 768px) {
	
	.hatb_wp .hat_col0101 .hata_text{
		top: 50%;
		left: 53%;
		width: 44%;
	}
	.hatb_wp .hat_col0101 .hata_text_col01{
		transform: scale(1);
		width: 56%;
	}
	.hatb_wp .hat_col0101 .hata_text_col02{
		transform: scale(1);
		width: 41%;
	}
	.hatb_wp .hat_col0101 .hata_arr{
		top: 88px;
		left: 76px;
	}
}

@media only screen and (min-width: 0) and (max-width: 767px) {
	.ui_open_btn{
		position: relative;
		z-index: 3;
		pointer-events: auto;
	}
	.ui_screen{
		display: inline;
	}
	.spNone{
		display: none!important;
	}
	.pcNone{
		display: block;
	}
	.mb0sp{
		margin-bottom: 0!important;
	}
	.mb10sp{
		margin-bottom: 10px!important;
	}
	.mb15sp{
		margin-bottom: 15px!important;
	}
	.mb20sp{
		margin-bottom: 20px!important;
	}
	.ui_df{
		display: block;
	}
	.ui_df_sp{
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-between;
		align-items: stretch;
	}
	.hat_wrap{
		padding: 0 6.5vw;
		background-image: url(../images/bg_wrap_sp.jpg);
		line-height: 1.27;
		font-size: 3.35vw;
	}
	.hat_ctop{
		margin-bottom: 15px;
		padding: 5vw 2.5vw 3vw;
	}
	.hat_more{
		margin-top: 4vw;
		width: 75vw;
		display: flex;
		justify-content: center;
		align-items: center;
		color: #e50110;
	}
	.hat_more::before{
		width: 11px;
		height: 11px;
	}
	.hat_more:hover{
		opacity: 1;
	}
	.hat_wrap a:hover{
		opacity: 1;
	}
	.hata_wp,.hatb_wp{
		position: relative;
		z-index: 2;
		overflow: hidden;
		margin-bottom: 20px;
		padding: 7vw 2.5vw 7vw;
	}
	.hata_wp{
		background-image: url(../images/bg_a_sp.png);
	}
	.hatb_wp{
		background-image: url(../images/bg_b_sp.png);
	}
	.hata_wp::before{
		background-image: url(../images/bg_a01_sp.png);
	}
	.hata_wp::after{
		background-image: url(../images/bg_a02_sp.png);
	}
	.hatb_wp::before{
		background-image: url(../images/bg_b01_sp.png);
	}
	.hatb_wp::after{
		background-image: url(../images/bg_b02_sp.png);
	}
	.hat_col0201{
		margin-bottom: 15px;
		width: 100%;
	}
	.ui_open_box{
		padding-top: 15px;
	}
	.hata_text{
		left: 2%;
		top: 68%;
		width: 96%;
		line-height: 1.24;
	}
	.hata_add{
		margin-left: 22% !important;
	}
	.hata_title{
		padding-top: 10px;
		font-size: 4.8vw;
	}
	.hata_list{
		margin-bottom: 5px;
		flex-wrap: wrap;
	}
	.hata_list li{
		margin-bottom: 10px;
		width: 49%;
		font-size: 3.733vw;
	}
	.hata_list li h4{
		margin-left: -0.5em;
		margin-right: -0.5em;
		font-size: 3.733vw;
	}
	.hata_li4>p{
		margin-left: -0.5em;
		margin-right: -0.5em;
	}
	.hata_li5{
		padding: 5px 0 15px;
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
		width: 100% !important;
		text-align: left !important;
	}
	.hata_li5 h4{
		justify-content: flex-start !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	.hat_imgb10{
		width: 44px;
		margin-left: 10%;
	}
	.hat_imgb10 + div{
		width: calc(82% - 44px);
	}
	.hata_list li h4{
		padding: 5px 0;
		min-height: auto;
	}
	.hatb_wp .hata_text{
		left: 3%;
		top: 68.3%;
		width: 94%;
	}
	.hatb_wp .hata_text_col01{
		width: 59%;
	}
	.hatb_wp .hata_text_col02{
		width: 40%;
	}
	.hat_col0101 .hata_text{
		top: 72%;
	}
	.hatb_item03 .hata_text{
		top: 67.5%;
	}
	.hatb_box{
		margin-top: 10px;
		padding: 5vw 2.5vw 4.2vw;
		display: block;
		height: auto;
	}
	.hatb_col01{
		width: 100%;
		display: flex;
	}
	.hatb_col01_01sp{
		margin-right: -5%;
		width: 70%;
		font-size: 3.6vw;
	}
	.hatb_col01_01{
		margin-bottom: 2vw;
		width: 100%;
	}
	.hatb_col01_02{
		margin: -1vw 0 -1vw 0;
		width: 31%;
	}
	.hatb_col02{
		width: 100%;
	}
	.hatb_col01 h4{
		margin-bottom: 2vw;
		font-size: 3.9vw;
	}
	.hatc_wp{
		display: block;
		padding: 2.5vw 2.5vw 2.5vw;
	}
	.hat_white{
		margin-bottom: 10px;
		padding: 2vw;
		border-radius: 30px;
	}
	.hat_imgc13 a{
		bottom: 3%;
		height: 13%;
	}
	.hat_imgc13 a:hover{
		opacity: 1;
	}
	.hatc_movie{
		margin: 0 auto;
		width: 70%;
	}
	.hat_white .hat_more::before{
		border-color: #e6121e;
	}
	#anc_04{
		margin-bottom: 0;
	}
	#anc_05{
		margin-top: 10px;
		padding-top: 10px;
	}
	.hata_notes{
		margin: 15px 0 25px;
		text-align: left;
	}
}


/* animation */

.hat_main{
	position: relative;
	width: 100%;
}
.hat_main_2026{
	position: absolute;
	z-index: 3;
	left: 14.5%;
	top: 7.9%;
	width: 24.2%;
}
.hat_main_2026_in{
	padding-top: 149%;
	position: relative;
	overflow: hidden;
}
.hat_main_2026 video{
	position: absolute;
	left: -1px;
	top: -1px;
	width: calc(100% + 5px);
	height: calc(100% + 5px);
	border: none;
	outline: none;
}
.hat_ctop_box{
	position: relative;
}
.hat_ctop_01{
	position: absolute;
	z-index: 3;
	left: 3.2%;
	top: 35%;
	opacity: 0;
}
.hat_ctop_02{
	position: absolute;
	z-index: 3;
	left: 25.7%;
	top: 40.5%;
	opacity: 0;
}
.ui_fade_cir{
	opacity: 0;
}
.ui_fade_cir.ui_fadein{
	animation:anim_scale 0.6s 0.3s forwards;
}
.hat_ctop_02.ui_fadein{
	animation:anim_scale 0.6s 0.7s forwards;
}
@keyframes anim_scale {
	0%   {opacity: 0; transform: scale(0.5);}
	60% {opacity: 1; transform: scale(1.05);}
	100% {opacity: 1; transform: scale(1);}
}

.ui_light{
	animation: tlight 0.9s ease-in-out infinite alternate;
}
@keyframes tlight {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0.3;
  }
}
.is_sp.is_open .ui_light{
	animation:none;
}
.hata_arr{
	position: absolute;
	top: 85px;
	left: 76px;
	width: 139px;
	opacity: 1;
	background: url(../images/arr_bg01.png) no-repeat;
	background-size: 100% 100%;
}
.hata_arr img{
	animation: poyopoyo 2s ease-out infinite;
}
.hatb_wp .hata_arr{
	top: 80px;
	background-image: url(../images/arr_bg02.png);
}
@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.95);
  }
}

@media only screen and (min-width: 0) and (max-width: 767px) {
	.hat_main{
		width: auto;
		min-height: 168vw;
		margin-left: -1vw;
		margin-right: -1vw;
	}
	.hat_main_2026{
		position: absolute;
		z-index: 3;
		left: 22.5vw;
		top: 15vw;
		width: 41.5vw;
	}
	.hat_main_2026_in{
		padding-top: 150%;
	}
	.hat_main_2026 video{
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}
	.hat_logo{
		position: absolute;
		z-index: 5;
		top: 4.5%;
		left: 5%;
		width: 30.5%;
	}
	.hat_ctop_01{
		left: 0;
		top: 43.5%;
		width: 50%;
	}
	.hat_ctop_02{
		left: auto;
		right: 0;
		top: 37.5%;
		width: 49.5%;
	}
	.hata_arr{
		left: 21.5vw !important;
		top: 23.5vw !important;
		width: 37.5vw !important;
	}
	.hat_col0101 .hata_arr{
		top: 23vw !important;
	}
	
}

/*2026_hatsuni*/
.hat_ma{
	position: relative;
	z-index: 2;
}
.hat_mod_btn{
	position: absolute;
	bottom: 20px;
	left: 50%;
	max-width: 100%;
	transform: translateX(-50%);
	line-height: 0;
	cursor: pointer;
}
.hat_ma .hat_mod_btn{
	bottom: 23px;
}
.hat_mb{
	margin-bottom: 20px;
	padding-bottom: 24px;
	background: url(../images/bg_mb01_pc.png) repeat-y center top;
	background-size: 100% auto;
}
.hat_mb::after{
	content: '';
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 100%;
	height: 24px;
	background: url(../images/bg_mb02_pc.png) no-repeat center bottom;
	background-size: 100% 100%;
}
.hat_mb>*{
	position: relative;
	z-index: 3;
}
.hat_mb .hat_more{
	position: relative;
	z-index: 2;
	color: #E60012;
}
.hat_mb01{
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: flex-end;
}
.hat_mb .hat_mod_btn{
	position: static;
	max-width: 281px;
	margin: 10px auto 20px;
	transform: translateX(0);
}

.moda_flex{
	display: flex;
	justify-content: space-between;
}
.moda_flex + .hat_note{
	margin-top: 30px;
	text-align: center;
}
.moda_item{
	width: 30.7%;
	letter-spacing: -0.04em;
	order: 1;
}
.moda_item2{
	width: 34.7%;
	order: 2;
}
.moda_item2 .moda_item_pic + p{
	padding-left: 5px;
	padding-right: 5px;
}
.moda_note4{
	display: inline-block;
	vertical-align: middle;
	padding-left: 4em;
	text-indent: -4em;
}
.moda_note{
	display: inline-block;
	vertical-align: middle;
	padding-left: 4.5em;
	text-indent: -4.5em;
}
.moda_item3{
	order: 3;
}
.moda_item_pic{
	position: relative;
	margin-bottom: 10px;
}
.moda_mark1{
	position: absolute;
	z-index: 9;
	right: -55px;
	bottom: 1px;
}
.moda_mark2{
	position: absolute;
	z-index: 9;
	right: -35px;
	bottom: 1px;
}
.modb_flex{
	padding: 0 8px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.modb_item{
	margin-bottom: 10px;
	width: 47.4%;
}
.modb_ac{
	margin-left: auto;
	margin-right: auto;
}
.modb_flex_s{
	display: flex;
	justify-content: space-between;
}
.modb_flex_s .modb_item>div{
	margin: 10px 0 6px;
}
.hat_shop{
	margin-top: 28px;
}
.hat_shop_pic{
	position: relative;
	margin-top: 10px;
}
.hat_mb_wide{
	padding: 0 25px;
}
.hat_shop_btn{
	position: absolute;
	left: 0;
	bottom: 20px;
	width: 100%;
	display: flex;
	justify-content: center;
}
.pic_mod_a03{
	margin-top: -60px;
}
.mod_btn1_t{
	position: absolute;
	left: calc(50% - 50px);
	top: calc(50% - 9px);
	margin-left: 10px;
	width: 99px;
	height: 18px;
	line-height: 0;
}
.mod_btn2_t{
	position: absolute;
	left: calc(50% - 72px);
	top: calc(50% - 9px);
	margin-left: 10px;
	width: 145px;
	height: 18px;
	line-height: 0;
}
.img_more01_t{
	position: absolute;
	left: calc(50% - 61px);
	top: calc(50% - 9px);
	margin-left: 10px;
	width: 122px;
	height: 18px;
	line-height: 0;
}


@media only screen and (min-width: 768px) and (max-width: 940px) {
	.hat_mb .hat_mod_btn img,
	.hat_wrap img{
		max-width: 100%;
	}
	.hat_wide{
		padding-left: 6vw;
		padding-right: 6vw;
	}
}

@media only screen and (min-width: 0) and (max-width: 767px) {
	.hat_ma{
		padding-top: 1vw;
		margin-top: 0;
	}
	.hat_mod_btn{
		bottom: 8.4vw !important;
		width: 68vw;
	}
	.hat_mb {
	    position: relative;
	    z-index: 2;
	    overflow: hidden;
		border: none;
	    margin-bottom: -7vw;
		padding-bottom: 26px;
		background: url(../images/bg_mb01_sp.png) repeat-y;
		background-size: 100% auto;
		color: #fff;
	}
	.hat_mb::before {
	    content: '';
	    position: absolute;
	    z-index: 1;
	    top: -1px;
	    left: -1px;
	    width: calc(100% + 2px);
	    height: 45px;
	    background: url(../images/bg_mb01_sp.png) no-repeat;
	    background-size: 100% auto;
	}
	.hat_mb::after {
	    content: '';
	    position: absolute;
	    z-index: 1;
	    bottom: -1px;
	    left: -1px;
	    width: calc(100% + 2px);
	    height: 48px;
	    background: url(../images/bg_mb02_sp.png) no-repeat center bottom;
	    background-size: 100% auto;
	}
	.hat_mb .hat_col0201{
		margin-top: 2vw;
	}
	.hat_mb .hat_mod_btn{
		width: 68vw;
		left: 8.4vw;
		bottom: 8.5vw !important;
	}
	.hat_mb .hat_mod_btn img{
		max-width: 100%;
	}
	.hat_mb .ui_open_close{
		margin-bottom: 0;
	}
	.ui_open_close{
		background: none !important;
		color: #fff;
		padding-left: 0;
		padding-right: 3vw;
	}
	.ui_open_close::after{
		margin-left: 0;
		margin-right: 5px;
	}
	.hat_btn_app{
		margin-bottom: 15px;
	}
	.hatb_wp .hata_arr{
		top: 22.5vw !important;
	}
	.moda_flex{
		display: block;
		padding-bottom: 7vw;
	}
	.moda_item,.modb_item{
		margin-bottom: 5vw;
		width: 100%;
		order: 1;
	}
	.modb_flex{
		padding: 0 0 12vw;
	}
	.moda_mark1,.moda_mark2{
		display: none;
	}
	.modb_item_sp4{
		order: 4;
	}
	.hat_note_box{
		padding-top: 5px;
		margin: 0 0 15px !important;
	}
	.moda_flex + .hat_note{
		padding-top: 15px;
		padding-bottom: 60px;
	}
	.hat_mbox{
		padding-bottom: 1px;
		margin: 20px -2.4vw 0;
		background: #f5e6cf;
	}
	.hat_mbox::after{
		display: none;
	}
	.hat_mbg_sp{
		position: relative;
		margin-bottom: 20px;
		padding-bottom: 13vw;
		background: url(../images/bg_m01_sp.png) repeat-y center top;
		background-size: 100%;
	}
	.hat_mbg_sp::after{
		content: '';
		position: absolute;
		left: 0;
		bottom: -2px;
		width: 100%;
		height: 13vw;
		background: url(../images/bg_m02_sp.png) repeat-y center top;
		background-size: 100%;
	}
	.hat_wide_s{
		max-width: 77vw;
	}
	.hat_mtit{
		margin-bottom: -1px;
	}
	.hat_mb_wide{
		padding: 0 4.5vw;
	}
	.hata_wp.hat_wide_s,.hatb_wp.hat_wide_s{
		max-width: 86vw;
	}
	.hat_shop{
		margin-top: 10px;
		padding: 0 5vw;

	}
	.hat_shop_btn{
		left: 6%;
		bottom: 8vw;
		width: 88%;
	}
	.hata_text h4{
		margin-bottom: 2.5vw;
	}
	.hat_col0101 .hata_text_col01>p{
		transform: scale(1.05);
		transform-origin: 0 0;
	}
	.pic_mod_a03{
		margin-top: -50px;
	}
	.moda_item2 .moda_item_pic + p{
		padding-left: 0;
		padding-right: 0;
	}
	.hat_mb .hat_more{
		width: 68vw;
	}
	.mod_btn1_t{
		left: calc(50% - 13.2vw);
		top: calc(50% - 2.3vw);
		margin-left: 2.67vw;
		width: 26.4vw;
		height: 5vw;
	}
	.mod_btn2_t{
		left: calc(50% - 19.33vw);
		top: calc(50% - 2.3vw);
		margin-left: 2.67vw;
		width: 38.66vw;
		height: 5vw;
	}
	.img_more01_t {
	    left: calc(50% - 16.2vw);
	    top: calc(50% - 2.4vw);
	    margin-left: 2.67vw;
	    width: 32.4vw;
	    height: 5vw;
	}
	
}

