@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@500;700;800&display=swap');

.dir-uniform.sub-20th .main{
	font-family: "Shippori Mincho", serif;
	font-weight: 500;
	font-style: normal;
	background-color: #e5002d;
	 background-image: radial-gradient(at 95% 5%, rgba(229, 0, 45, 1), rgba(58, 0, 11, 1));
	padding-bottom: 0;
	position: relative;
}
.dir-uniform.sub-20th .uni-main{
	position: relative;
}
.dir-uniform.sub-20th .uni-main:before{
	content: "";
	background-image: url("../img/uni-bg.svg");
	background-size: cover;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	position: absolute;
	z-index: 0;
	opacity: 0.5;
	left: 0;
	top: 0;
}
.dir-uniform.sub-20th .main section{
	padding-bottom: 50px;
}
.dir-uniform.sub-20th .main .en{
font-family: "Crimson Text", serif;
font-optical-sizing: auto;
font-weight: 400;
font-style: normal;
}
.dir-uniform.sub-20th .main .text-yellow{
	color: #fff100;
}
.dir-uniform.sub-20th .main .uni-ttl{
	position: relative;
	color: #c29b61;
	padding-top: 15px;
	padding-bottom: 15px;
	margin-top: 0;
	margin-bottom: 25px;
}
.dir-uniform.sub-20th .main .uni-ttl > span{
	display: block;
	line-height: 1;
	font-size: 1.6rem;
	font-weight: normal;
	letter-spacing: 0.05em;
	color: #ffffff;
}
.dir-uniform.sub-20th .main .uni-ttl .en{
	font-size: 6.3rem;
	margin-bottom: 6px;
	letter-spacing: -0.1rem;
	font-weight: bold;
	color: #c29b61;
	letter-spacing: .5rem;
}
.dir-uniform.sub-20th .main .swiper-button-prev,.dir-uniform.sub-20th .main .swiper-button-next{
	background-image: none;
	width: auto;
	height: auto;
	border-radius: 0;
}
.dir-uniform.sub-20th .main .swiper-button-prev::after,.dir-uniform.sub-20th .main .swiper-button-next::after{
	width: 0;
  height: 0;
  border-style: solid;
  border-top: 30px solid transparent;
  border-bottom: 30px solid transparent;
  border-left: 40px solid #c39d61;
  border-right: 0;
}
.dir-uniform.sub-20th .main .swiper-button-next::after{
	-webkit-transform:rotate(0deg);
	transform:rotate(0deg);
}
.dir-uniform.sub-20th .main .swiper-button-prev::after{
	-webkit-transform:rotate(-180deg);
	transform:rotate(-180deg);
}
/*----------------------------
fadeIn ｜下から上へ出現
----------------------------*/
.fadeIn {
	transition: 0.8s ease-in-out;
	transform: translateY(30px);
	opacity: 0;
}
.fadeIn.on {
	transform: translateY(0);
	opacity: 1.0;
}

/*----------------------------
scroll_left ｜左から出現
----------------------------*/
.fadeIn_left {
	-webkit-transition: 0.8s ease-in-out;
	-moz-transition: 0.8s ease-in-out;
	-o-transition: 0.8s ease-in-out;
	transition: 0.8s ease-in-out;
	transform: translateX(-30px);
	opacity: 0;
	filter: alpha(opacity=0);
	-moz-opacity: 0;
}
.fadeIn_left.on {
	opacity: 1.0;
	filter: alpha(opacity=100);
	-moz-opacity: 1.0;
	transform: translateX(0);
}

/*----------------------------
scroll_right ｜右から出現
----------------------------*/
.fadeIn_right {
	-webkit-transition: 0.8s ease-in-out;
	-moz-transition: 0.8s ease-in-out;
	-o-transition: 0.8s ease-in-out;
	transition: 0.8s ease-in-out;
	transform: translateX(30px);
	opacity: 0;
	filter: alpha(opacity=0);
	-moz-opacity: 0;
}
.fadeIn_right.on {
	opacity: 1.0;
	filter: alpha(opacity=100);
	-moz-opacity: 1.0;
	transform: translateX(0);
}
.timing02 {transition-delay: .2s;}
.timing03 {transition-delay: .3s;}
.timing04 {transition-delay: .4s;}
.timing05 {transition-delay: .5s;}
.timing06 {transition-delay: .6s;}
.timing07 {transition-delay: .7s;}
.timing08 {transition-delay: .8s;}
.timing09 {transition-delay: .9s;}
.timing10 {transition-delay: 1.0s;}
.timing11 {transition-delay: 1.1s;}

.sec-outer{
	padding-top: 50px;
	padding-bottom: 50px;
}
.sec-inner{
	position: relative;
	z-index: 1;
}


/*----- ヘッダー -----*/

.header-20th{
	position: relative;
	background-image: url("../img/header.png");
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 80px;
}
.header-20th .header-inner{
	padding-left: 30px;
	padding-right: 30px;
	height: 80px;
}
.header-20th .logo20th{
	padding-top: 10px;
	padding-bottom: 10px;
	display: flex;
	align-items: center;
	height: 80px;
}
.header-20th .logo20th img{
	height: 65px;
}

/*----- ここまでヘッダー -----*/
/*----- セクション背景 -----*/

/*----- ここまでセクション背景 -----*/

.main-kv .main-kv_button{
	background-image: linear-gradient(90deg, #e5002d, #000000);
	padding-top: 30px;
	padding-bottom: 30px;
	padding-left: 50px;
	padding-right: 50px;
}
.main-kv .main-kv_button a{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	color: #FFFFFF;
	font-size: 2.3rem;
	font-weight: bold;
}
.main-kv .main-kv_button a .anc-r{
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 15px solid transparent;
	border-bottom: 15px solid transparent;
	border-left: 27px solid #ffffff;
	border-right: 0;
	display: inline-block;
	margin-left: 10px;
}
.main-text-20th{
	position: relative;
	overflow: hidden;
}
.main-text-20th:before{
	content: "";
	display: block;
	background-image: url("../img/mainbg.png");
	background-size: cover;
	width: 100%;
	height: 100%;
	background-position: top center;
	background-repeat: no-repeat;
	position: absolute;
	top: -25%;
	left: 0;
	opacity: .5;
}
.main-text-20th .head-text{
	margin-bottom: 0.7em;
	font-size: 5.0rem;
	font-weight: normal;
	line-height: 1.3;
	color: #fff;
	text-align: center;
}
.main-text-20th .description{
	font-size: 2.0rem;
	color: #FFFFFF;
	text-align: center;
	line-height: 1.3;
}
.main-text-20th .description + .description{
	margin-top: 25px;
}
.main-text-20th .bottom-text{
	font-size: 5.0rem;
	font-weight: normal;
	line-height: 1.3;
	color: #fff;
	text-align: center;
	margin-top: 55px;
}
.gallery-20th{
	padding-bottom: 30px;
}
.gallery-20th .swiper .swiper-wrapper{
  transition-timing-function: linear;
}
#movie .movie-area{
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}
#movie .movie-area iframe{
	position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
#design .design-inner{
	background-color: #FFFFFF;
	padding: 2em;
}
#design .design-inner .design-info_box{
	margin-bottom: 30px;
}
#design .design-inner .design-info{
	display: flex;
	justify-content: space-between;
}
#design .design-inner .design-info .img{
	width: 50%;
}
#design .design-inner .design-info .text{
	width: 48%;
}
#design .design-inner .design-info .text h3{
	font-size: 2.5rem;
	border-bottom: 1px solid #000000;
	margin-bottom: 8px;
	margin-top: 0;
}
#design .design-inner .design-info .text p{
	margin-bottom: 0;
}
#design .design-inner .design-info + .design-info{
	margin-top: 25px;
}
#design .design-inner .design-img_cate{
	display: flex;
	justify-content: space-between;
	margin-top: 25px;
}
#design .design-inner .design-img_cate > div{
	width: 48.5%;
}
#design .content {
	display: none;
}
#design .content.show {
	display: block;
}
#design .design-tab {
	margin-top: 35px;
}
#design .design-tab .tab-container{
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
}
#design .design-tab .tab-container > div{
	width: 24%;
	background-color: #c39d61;
	color: #000000;
	text-align: center;
	font-size: 1.8rem;
	padding: 1em;
}
#design .design-tab .tab-container > div:nth-child(1){
	border-bottom: 5px solid #e50038;
}
#design .design-tab .tab-container > div:nth-child(2){
	border-bottom: 5px solid #FFFFFF;
}
#design .design-tab .tab-container > div:nth-child(3){
	border-bottom: 5px solid #bf8136;
}
#design .design-tab .tab-container > div:nth-child(4){
	border-bottom: 5px solid #6196c1;
}
#design .design-tab .content-container{
	background-color: #FFFFFF;
	padding: 2em;
}
#design .design-tab .design-tab_inner{
	display: flex;
	justify-content: space-between;
	position: relative;
}
#design .design-tab .design-tab_inner .swiper{
	width: 500px;
	margin: 0;
}
#design .design-tab .design-tab_inner .design-tab_text{
	width: calc(100% - 530px);
	padding-top: 15px;
	padding-bottom: 15px;
	padding-left: 20px;
}
#design .design-tab .design-tab_inner h2{
	margin-top: 0;
	margin-bottom: 15px;
	font-size: 1.6rem;
}
#design .design-tab .design-tab_inner h2 span{
	display: block;
	border-bottom: 1px solid #000000;
	margin-bottom: 5px;
	padding-bottom: 5px;
}
#design .design-tab .design-tab_inner h2 em{
	font-style: normal;
	font-size: 2.2rem;
}
#design .design-tab .design-tab_inner .design-tab_text .size span{
	display: inline-block;
	background-color: #cccccc;
	text-align: center;
	vertical-align: middle;
	padding: 5px 15px;
	margin-right: 15px;
}
#design .design-tab .design-tab_inner .design-tab_text .price dt{
	font-size: 1.3rem;
	line-height: 1;
}
#design .design-tab .design-tab_inner .design-tab_text .price dd{
	margin-left: 0;
	font-size: 3.0rem;
}
#design .design-tab .design-tab_inner .design-tab_text .price dd span{
	font-size: 1.8rem;
}
#design .design-tab .design-tab_inner .design-tab_text .price-button{
	margin-top: 20px;
}
#design .design-tab .design-tab_inner .design-tab_text .price-button a{
	background-color: #c39d61;
	color: #000000;
	border-radius: 8px;
	display: block;
	padding: 10px;
	text-align: center;
	font-size: 1.8rem;
}
#schedule .schedule-box{
	border: 1px solid #c29b61;
	padding: 2em;
	color: #FFFFFF;
	font-size: 1.8rem;
}
#schedule .schedule-box + .schedule-box{
	margin-top: 25px;
}
#schedule .schedule-box div{
	margin: 0;
	margin-bottom: 15px;
}
#schedule .schedule-box div > p{
	display: inline-block;
	margin-top: 0;
	padding-bottom: 10px;
	border-bottom: 2px solid #c29b61;
}
#schedule .schedule-box div > p span{
	display: inline-block;
	border: 1px solid #c29b61;
	color: #c29b61;
	text-align: center;
	padding: .5rem;
	margin-left: 15px;
	font-size: 1.4rem;
	font-weight: bold;
}
#schedule .schedule-box p{
	margin: 0;
}
#size .size-img{
	margin-top: 25px;
}
#size .size-img_box{
	display: flex;
	justify-content: space-between;
	margin-bottom: 25px;
}
#size .size-img_box > div{
	width: 49%;
}
#font{
	color: #FFFFFF;
}
#font .font-item + .font-item{
	margin-top: 25px;
}
#font .font-description{
	margin-top: 25px;
	padding: 1em;
	border: 1px solid #c29b61;
}
#font .font-description dl{
	display: flex;
	margin-top: 0;
align-items: baseline;
}
#font .font-description dl:last-child{
	margin-bottom: 0;
}
#font .font-description dl dt{
	background-color: #c29b61;
	color: #FFFFFF;
	text-align: center;
	padding: 5px 10px;
	width: 100px;
	min-width: 100px;
}
#font .font-description dl dd{
	margin-left: 15px;
	font-size: 1.8rem;
}
#partner .partner-list{
	margin-top: 25px;
}
#partner .partner-list ul{
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
#partner .partner-list ul li{
	margin-left: 10px;
	width: calc(33.333% - 7px);
	margin-bottom: 10px;
}
#partner .partner-list ul li:nth-child(3n + 1){
	margin-left: 0;
}
.uni-footer{
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url("../img/header.png");
	background-size: cover;
	width: 100%;
	height: 90px;
	background-repeat: no-repeat;
	position: relative;
	z-index: 1;
}
.uni-footer a{
	display: block;
	color: #FFFFFF;
	font-size: 2.8rem;
}
.dir-uniform .main #partner{
	display: block;
}
#partner{
	display: none;
}
#concept .concept-inner h2{
	font-size: 4.0rem;
	color: #FFFFFF;
	font-weight: bold;
	text-align: center;
	margin-top: 0;
	margin-bottom: 25px;
}
#concept .concept-inner .text{
	margin-top: 25px;
	margin-bottom: 0;
	color: #FFFFFF;
}



@media only screen and (max-width: 768px) {
	.header-20th{
		height: 60px;
	}
	.header-20th .header-inner{
		height: 60px;
		padding-left: 15px;
		padding-right: 15px;
	}
	.header-20th .logo20th{
		height: 60px;
	}
	.header-20th .logo20th img{
		height: 40px;
	}
	.dir-uniform.sub-20th .main{
		padding-top: 0;
	}
	.sec-outer{
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.dir-uniform.sub-20th .main section{
		padding-bottom: 30px;
	}
	.dir-uniform.sub-20th .main .uni-ttl{
		margin-bottom: 15px;
		padding-top: 5px;
		padding-bottom: 5px;
	}
	.dir-uniform.sub-20th .main .uni-ttl .en{
		font-size: 4.6rem;
			letter-spacing: .2rem;
	}
	.dir-uniform.sub-20th .main .uni-ttl > span{
		font-size: 1.4rem;
	}
	
	.main-kv .main-kv_button{
		padding: 25px;
	}
	.main-kv .main-kv_button a{
		font-size: 1.7rem;
	}
	.main-kv .main-kv_button a .anc-r{
		border-top: 13px solid transparent;
		border-bottom: 13px solid transparent;
		border-left: 20px solid #ffffff;
	}
	.main-text-20th:before{
		top: 0;
	}
	.main-text-20th .head-text{
		font-size: 2.4rem;
		margin-bottom: 30px;
	}
	.main-text-20th .bottom-text{
		font-size: 2.4rem;
		margin-top: 45px;
	}
	.main-text-20th .description{
		font-size: 1.5rem;
		line-height: 1.7;
	}
	.main-text-20th .description + .description{
		margin-top: 20px;
	}
	.dir-uniform.sub-20th .main .swiper-button-prev, .dir-uniform.sub-20th .main .swiper-rtl .swiper-button-next{
		left: 5px;
	}
	.dir-uniform.sub-20th .main .swiper-button-next, .dir-uniform.sub-20th .main .swiper-rtl .swiper-button-prev{
		right: 5px;
	}
	.dir-uniform.sub-20th .main .swiper-button-prev::after, .dir-uniform.sub-20th .main .swiper-button-next::after{
		border-top: 15px solid transparent;
		border-bottom: 15px solid transparent;
		border-left: 25px solid #c39d61;
	}
	#design .design-tab .tab-container > div{
	padding: 1rem;
}
	#design .design-inner{
		padding: 1.5em 1em;
	}
	#design .design-inner .design-info-box{
	margin-bottom: 15px;
	position: relative;
		border: 1px solid #c29b61;
		padding-bottom: 15px;
}
#design .design-inner .design-info-box .swiper-pagination-bullet-active{
	background-color: #c29b61;
}

#design .design-inner .design-info-box .text{
	padding: 1.5rem;
}
#design .design-inner .design-info-box .text h3{
	border-bottom: 1px solid #000000;
	margin-top: 0;
	text-align: center;
	font-size: 1.7rem;
	line-height: 1.3;
	margin-bottom: 0;
}

	#design .design-inner .design-info-box .text p{
		font-size: 1.4rem;
		line-height: 1.3;
		margin-bottom: 0;
	}

	#design .design-inner .design-img_cate{
		margin-top: 15px;
	}
	#design .design-tab .content-container{
		padding: 1.5em 1em;
	}
	#design .design-tab .design-tab_inner{
		display: block;
	}
	#design .design-tab .design-tab_inner .swiper{
		width: 100%;
	}
	#design .design-tab .design-tab_inner .design-tab_text{
		padding-left: 0;
		width: 100%;
	}
	#design .design-tab .design-tab_inner h2{
		font-size: 1.3rem;
	}
	#design .design-tab .design-tab_inner h2 em{
		font-size: 1.7rem;
	}
	#schedule .schedule-box{
		padding: 1em;
		font-size: 1.6rem;
	}
	#schedule .schedule-box div{
		margin-bottom: 10px;
	}
	#schedule .schedule-box div > p span{
		margin-left: 8px;
	font-size: 1.3rem;
}
	#schedule .schedule-box + .schedule-box{
		margin-top: 15px;
	}
	#font .font-description dl dt{
		width: 80px;
		font-size: 1.3rem;
	}
	#font .font-description dl dd{
		font-size: 1.5rem;
		margin-left: 10px;
		width: calc(100% - 90px);
	}
	#partner .partner-img{
		width: 90%;
		margin-bottom: 30px;
	}
	.uni-footer a{
		font-size: 2.0rem;
	}
	#concept .concept-inner h2{
	font-size: 2.4rem;
	margin-bottom: 15px;
}
	#concept .concept-inner .text{
		margin-top: 15px;
	}
	
}

@media only screen and (min-width: 769px) {
	.dir-uniform.sub-20th .container,.main-kv_button_inner{
		max-width: 950px;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}
	#partner .partner-main{
	width: 700px;
	margin-left: auto;
	margin-right: auto;
}
	#partner .partner-list{
		width: 700px;
		margin-left: auto;
		margin-right: auto;
	}

	
	
	
}