@charset "utf-8";
body {background: #000;}
img {
	width: auto;
	max-width: 100%;
	height: auto;
}
.center {text-align: center;}
.right {text-align: right;}

.flex_center {
	display: flex;
	justify-content: center;
}
.flex_start {
	display: flex;
	justify-content: start;
}

.link {
	color: #fff;
	display: inline-block;
}
._map {
	padding-left: min(1.5vw, 18px);
	position: relative;
	margin-left: .8em;
}
._map::before {
	content: '';
	display: block;
	width: min(1.25vw, 15px);
	height: min(1.35vw, 16.2px);
	background: url(../img/icon_map.svg) 0 0 no-repeat;
	background-size: cover;
	position: absolute;
	left: 0;
	top: calc(50% - min(.675vw, 8.1px));
}

@media screen and (min-width:641px) {
	.sp {display: none;}
}
@media screen and (max-width:640px) {
	.pc {display: none;}
	._map {padding-left: min(3.6vw, 27px);}
	._map::before {
		width: min(2.8vw, 21px);
		height: min(3.066vw, 23px);
		top: calc(50% - min(1.6vw, 12px));
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}


/*wpAll*/
/**********/
.wpAll {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	min-height: 100vh;
	padding-top: min(9.5vw, 114px);
	background-image:
		url(../img/bg02.svg),
		url(../img/bg01.svg);
	background-position: 
		min(-1.75vw, -21px) 0,
		calc(100% + min(2.75vw, 33px)) 0;
	background-repeat: no-repeat;
	background-size: min(13vw, 156px) auto;
}

#main {
	width: min(70vw, 840px);
	opacity: 0;
	animation: fadeIn 2.5s forwards linear 1.25s;
}
#main * {
	font-family: 'Noto Sans JP', sans-serif;
}

@media screen and (min-width:980px) {
	.wpAll {
		background-position: 
			min(-2.75vw, -33px) 0,
			calc(100% + min(2.75vw, 33px)) 0;
	}
}
@media screen and (max-width:640px) {
	.wpAll {
		background: none;
		padding-top: min(26.8vw, 200px);
	}
	#main {
		width: min(90vw, 675px);
	}
}

/*header*/
/************/
#header {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: min(9.25vw, 112px);
	opacity: 0;
	animation: fadeIn 2s forwards linear .25s;
}
#header .img {
	width: 100%;
	height: auto;
	display: block;
}
#header .site_name {
	width: min(66.75vw, 800px);
	height: auto;
	margin-bottom: min(5.5vw, 66px);
}
#header .date {
	width: min(41.25vw, 495px);
}


@media screen and (min-width:641px) {
}
@media screen and (min-width:768px) {
}
@media screen and (min-width:1150px) {
}

@media screen and (max-width:640px) {
	#header {
		margin-bottom: min(28.4vw, 214px);
	}
	#header .site_name {
		width: min(92vw, 690px);
		margin-bottom: min(10.8vw,80px);
	}
	#header .date {
		width: min(81.6vw, 612px);
	}
}



/*footer*/
/****************/
#footer {
	width: min(70vw, 840px);
	margin-top: min(2vw, 24px);
	padding: min(4.5vw, 54px) 0 min(1.75vw, 21px);
	position: relative;
	opacity: 0;
	animation: fadeIn 2s forwards linear 1.75s;
}
#footer::before,
#footer::after {
	content: '';
	position: absolute;
}
#footer::before {
	height: 1px;
	background-color: #fff;
	top: min(.75vw, 9px);
	z-index: 1;
	left: 1px;
	right: 1px;
}
#footer::after {
	width: 100%;
	height: min(1.5vw, 18px);
	background-image: 
		url(../img/deco01_l.svg),
		url(../img/deco01_r.svg);
	background-repeat: no-repeat;
	background-position: 0% 0%, 100% 0%;
	background-size: auto 100%;
	top: 0;
	left: 0;
	right: 0;
	z-index: 2;
}
#footer .sns_ul {
	display: flex;
	justify-content: center;
	align-items: center;
}
#footer .sns_li {
	margin: 0 min(1.25vw, 15px) min(1.75vw, 21px);
}
#footer .img_sns {
	display: block;
	width: min(2.5vw, 30px);
	height: auto;
}
#footer .copy {
	color: #a1a1a1;
	font-size: clamp(0.6rem, 1.226vw, 1.2rem);
	text-align: center;
}

@media screen and (min-width:641px) {

}
@media screen and (min-width:768px) {

}
@media screen and (min-width:1281px) {
}
@media screen and (max-width:640px) {
	#footer {
		width: min(90vw, 675px);
		padding: min(18.4vw, 138px) 0 min(6.8vw, 50px);
	}
	#footer::before {
		top: calc(min(3.2vw, 24px) / 2);
	}
	#footer::after {
		height: min(3.2vw, 24px);
	}
	#footer .sns_li {
		margin: 0 min(4.4vw, 33px) min(5.2vw, 40px);
	}
	#footer .img_sns {
		width: min(9.6vw, 72px);
	}
	#footer .copy {
		font-size: clamp(1.1rem, 2.865vw, 2.2rem);
	}
}

/*common*/
/****************/

/*txt*/
.txt_s,
.txt_m,
.txt {
	font-weight: 400;
}
.txt_s {}
.txt_m {}
.txt   {}

.kome {
	text-indent: -1em;
	padding-left: 1em;
}

.txt_s rt,
.txt_m rt,
.txt rt{
	font-weight: 400;
	font-size: 50%;
}
.txt .caution {
  color: #fac22e;
}

.mb0  {margin-bottom: 0;}
.mb05 {margin-bottom: 5px;}
.mb10 {margin-bottom: 10px;}
.mb15 {margin-bottom: 15px;}
.mb20 {margin-bottom: 20px;}
.mb25 {margin-bottom: 25px;}
.mb30 {margin-bottom: 30px;}

/*h2*/
.h2_ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: min(5vw, 60px);
	position: relative;
}
.h2_ttl::before,
.h2_ttl::after {
	content: '';
	position: absolute;
}
.h2_ttl::before {
	height: 1px;
	background-color: #fff;
	top: 50%;
	left: 1px;
	right: 1px;
	z-index: 1;
}
.h2_ttl::after {
	width: 100%;
	height: min(1.5vw, 18px);
	background-image: 
		url(../img/deco01_l.svg),
		url(../img/deco01_r.svg);
	background-repeat: no-repeat;
	background-position: 0% 0%, 100% 0%;
	background-size: auto 100%;
	top: calc(50% - min(.75vw, 9px));
	left: 0;
	right: 0;
	z-index: 2;
}
.h2_ttl .wp {
	padding: 0 min(2.75vw, 33px);
	background-color: #000;
	position: relative;
	z-index: 3;
}
.h2_ttl .h2_img {
	width: min(9.25vw, 111px);
}

/*h3*/
.h3_ttl {
}

/*h4*/
.h4_ttl {
}
/*h5*/
.h5_ttl {
}

.caution_top {
}


@media screen and (min-width:641px) {
}
@media screen and (max-width:640px) {
	.h2_ttl {
		margin-bottom: min(8vw, 60px);
	}
	.h2_ttl::after {
		height: min(3.2vw, 24px);
		top: calc(50% - min(1.6vw, 12px));
	}
	.h2_ttl .wp {
		padding: 0 min(3.2vw, 24px);
	}
	.h2_ttl .h2_img {
		width: min(22vw, 165px);
	}
}

/*info*/
/****************/
.info_dl {
	color: #fff;
	display: flex;
	flex-wrap: wrap;
}
.info_dt,
.info_dd {
	font-size: clamp(0.8rem, 1.634vw, 1.6rem);
	margin-bottom: min(2.75vw, 33px);
	line-height: 1.7;
}
.info_dt {
	font-weight: 500;
	padding: 1px 1.5em 3px;
	background-image: 
		url(../img/bg_ttl_l.png),
		url(../img/bg_ttl_r.png),
		url(../img/bg_ttl_c.png);
	background-position: 0 0, 100% 0 , 0 0;
	background-repeat: no-repeat, no-repeat, repeat-x;
	background-size: auto 100%;
}
.info_dd {
	font-weight: 400;
}
.info_dd .wp_1,
.info_dd .wp_2,
.info_dd .wp_3 {
	display: inline-block;
}
.info_dd .wp_3 {
	font-size: clamp(0.7rem, 1.43vw, 1.4rem);
}
.info_dd .ttl_date {
	font-weight: 700;
}
.info_dd .wp_date + .wp_date {
	margin-top: .5em;
}
.info_dd .kome {
	font-size: clamp(0.7rem, 1.43vw, 1.4rem);
	text-indent: -1em;
	padding-left: 1em;
}
.info_dd ._other {
	margin-left: 1em;
}

@media screen and (min-width:641px) {
	.info_dl {
		justify-content: space-between;
		align-items: flex-start;
	}
	.info_dd .wp_1 {
		margin-right: 1.2em;
	}

	.info_dd._w2 {
		width: calc(100% - 5.5em);
	}
	.info_dd._w3 {
		width: calc(100% - 6.5em);
	}
	.info_dd._w4 {
		width: calc(100% - 8.5em);
	}
	.info_dd._w5 {
		width: calc(100% - 9.5em);
	}
	.info_dd._w6 {
		width: calc(100% - 9.5em);
	}
	.info_dd._w7 {
		width: calc(100% - 10.5em);
	}
	.info_dd._w8 {
		width: calc(100% - 11.5em);
	}
	
}
@media screen and (max-width:640px) {
	.info_dl {
		flex-direction: column;
		align-items: flex-start;
		width: min(86.8vw, 651px);
		margin: auto;
	}
	.info_dt {
		font-size: clamp(1.3rem, 3.386vw, 2.6rem);
		margin-bottom: .6em;
	}
	.info_dd {
		font-size: clamp(1.3rem, 3.386vw, 2.6rem);
		line-height: 1.8;
		margin-bottom: 1.6em;
	}
	.info_dd .wp_1 {
		width: 100%;
	}
	.info_dd .kome,
	.info_dd .wp_3 {
		font-size: clamp(1.1rem, 2.865vw, 2.2rem);
	}
}


/*slider*/
.ft_slide_wp {
	overflow: hidden;
	width: 100vw;
}
.ft_slide {
	animation: ftslider 10s infinite linear .5s both;
}
.ft_slide .ft_slide_li {
	width: min(186.8vw, 1401px);
	transform: translateY(min(3.2vw,24px));
}
.ft_slide .slide_img {
	width: min(186.8vw, 1401px);
	height: min(16vw, 120px);
}
@keyframes ftslider {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

@media screen and (min-width:641px) {
	.ft_slide_wp {
		display: none;
	}
}

@media screen and (max-width:640px) {
	.ft_slide_wp {
		display: flex;
	}
}
@media screen and (min-width:768px) {
}

