@charset "utf-8";

#bwj_23tokyo{
	width: 100%;
	margin: 0 auto ;
	line-height: 1.8;
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	font-size: 14px;
	box-sizing: border-box;
	padding: 0;
}



#bwj_23tokyo img {
    width: 100%;
    height: auto;
}
#bwj_23tokyo table {
	border-collapse: collapse;
	border-spacing: 0;
}
#bwj_23tokyo a{text-decoration:none; display:block;}
#bwj_23tokyo a:hover{transition:.3s; opacity:0.7;}
#bwj_23tokyo a.touch,#bwj_23tokyo a.touch img{opacity:0.7;}

#bwj_23tokyo .text-center{
	text-align: center;
}


#bwj_23tokyo .mt20{
	margin-top: 20px;
}

@media screen and (min-width: 1200px){
	#bwj_23tokyo .container{width:1200px;}
}
@media screen and (max-width: 767px){
	body{ font-size:12px;}

}

/* ========= header sectionWrap ========= */

#header .mainimg{
	background:#cd5a93;
	position: relative;
}
#header .mainimg .container{
	padding:0;
}
#header h1{
	padding:0 15px;
}
#sectionWrap .sectionLayout{
	margin-top: 80px;
	margin-bottom: 80px;
}


#header .heroHeader{
	display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
}

#header .heroHeader__nav{
	max-width: 1000px;
	margin: 0 auto;
}

.globalNav__list {
    display: flex;
	justify-content: center;
}
.globalNav__listItem {margin: 0 20px;padding-top: 1%;}

.globalNav__listItem a{
	font-size: 14px;
	color: #fff;

}


@media screen and (max-width: 991px){
	#sectionWrap .sectionLayout{
		margin-top:40px;
	}
	
	.globalNav__listItem {margin-left: 2rem;}
	
}
@media screen and (max-width: 767px){
	#header .mainimg{
		border-top:none;
	}
	#header h1{
		padding:0;
	}
}

/* ========= btn variation ========= */

#bwj_23tokyo .btn{
	color:#FFF;
	border-radius:6px;
	white-space:normal;
	position:relative;
	line-height:1.3;
	padding:2.6%;
	background: rgb(199,169,87);
	background: linear-gradient(180deg, rgba(199,169,87,1) 0%, rgba(154,127,53,1) 100%);
}
#bwj_23tokyo .btn::after,
#bwj_23tokyo .btn2::after{
	content: "\f2d2";
    font-family: FontAwesome;
    position: absolute;
    right: 4%;
    top: 50%;
	transform: translateY(-50%);
	font-weight: normal;
}


#bwj_23tokyo #btnIG{
	z-index: 1;
	position: fixed;
	bottom: 50%;
	left: 60px;
}

#bwj_23tokyo #btnIG .btnripple{
	position: relative;
    /*波紋の形状*/
	display:inline-block;
	background:#333;
	width:70px;
	height:70px;
	border-radius: 50%;
	color:#ccc;
    outline: none;
    /*アニメーションの設定*/
    transition: all 3s;
}

/*hoverした際の背景色の設定*/
#bwj_23tokyo #btnIG .btnripple:hover{
	background:#666;	
}

/*波形を2つ設定*/
#bwj_23tokyo #btnIG .btnripple::after,
#bwj_23tokyo #btnIG .btnripple::before {
    content: '';
    /*絶対配置で波形の位置を決める*/
    position: absolute;
    left: -25%;
    top: -25%;
    /*波形の形状*/
    border: 1px solid #333;
    width: 150%;
    height: 150%;
    border-radius: 50%;
    /*はじめは不透明*/
    opacity: 1;
    /*ループするアニメーションの設定*/
    animation:1.5s circleanime linear infinite;
}

/*波形の2つ目は0.5秒遅らせてアニメーション*/
#bwj_23tokyo #btnIG .btnripple::before {
    animation-delay:1.5s; 
}

/*波形のアニメーション*/
@keyframes circleanime{
	0%{
	  transform: scale(0.68);
	}
	100%{
		transform: scale(1.2);
		opacity: 0;
	}
}

/*中央矢印*/
#bwj_23tokyo #btnIG .btnripple span::after {
    content: '';
    /*絶対配置で矢印の位置を決める*/
    position: absolute;
    top: 38%;
    left: 45%;
    /*矢印の形状*/
    border: 14px solid transparent;
    border-top-width: 10px;
    border-bottom-width: 10px;
    border-left-color: #fff;
}

/* ========= text variation ========= */

#bwj_23tokyo .f20{
	font-size: 20px;
}

#bwj_23tokyo .f38{
	font-size: 38px;
}
#bwj_23tokyo .info{
	font-size: 15px;
	text-align: center;
	padding: 1% 0 0;
}

#bwj_23tokyo .btn1{
	background:#1F3566;
	font-size:14px;
	padding:4% 24px 4% 24px;
}

#bwj_23tokyo #sectionWrap .container{
	width: 780px;
	margin: 6rem auto;
}


#bwj_23tokyo .bnrarea{
	margin-top: 40px;
}

#bwj_23tokyo .bnrarea .boothbox{
	border: 1px solid #e0e0e0;
	padding: 20px;
}

#bwj_23tokyo .bnrarea .f_pink{
	color: #f14794;
}

#bwj_23tokyo .bnrarea p:nth-child(1) {
	font-size: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 1.3;
}

#bwj_23tokyo .bnrarea p:nth-child(1) span:not(.hidden-xs) {
    display: block;
}

#bwj_23tokyo .bnrarea p:not(:nth-child(3)) {
    margin-bottom: 10px;
}
#bwj_23tokyo .btn_sm {
    background: #3C3C3C;
    font-size: 14px;
    padding-top: 2.4%;
    padding-bottom: 2.4%;
	border-radius: 4px;
}

#bwj_23tokyo .btn_sm2 {
    background: #D8397F;
    font-size: 15px;
    padding-top: 2%;
    padding-bottom: 2%;
	padding-bottom: 2.4%;
	border-radius: 4px;
}

#bwj_23tokyo .btn_sm2.btn::after{
	content: "\f107";
}

@media screen and (max-width: 767px){
	#bwj_23tokyo{font-size: 13px;}
	
	#bwj_23tokyo .f20{font-size: 18px;}
	#bwj_23tokyo #sectionWrap .container{max-width: 100%;margin-top: 58.88vw; margin-bottom: 4rem;}
	
	#header .heroHeader{top: 105%;}
	#header .heroHeader__nav{max-width: 100%;padding: 0 5px;}
	.globalNav__list{flex-direction: column;margin: 2% 0;}
	.globalNav__listItem{background: #D8397F;width: 100%;padding: 2%; margin: 0 0 9px;}
	
	#bwj_23tokyo .bnrarea > .col-xs-6{padding: 0 5px;}
	#bwj_23tokyo .bnrarea .boothbox{padding: 5%;}
	#bwj_23tokyo .bnrarea p:nth-child(1){font-size: 14px;}
	#bwj_23tokyo .btn{padding: 20px;}
	#bwj_23tokyo .btn_sm{font-size: 12px; padding: 2%;}
	#bwj_23tokyo .btn_sm2{font-size: 12px;padding: 2%;}
	
	
}





/* ============= #sec1 ============= */

#sec1 .bg{
	width: 100%;
	background: url(../img/sec_bgImg.jpg) no-repeat;
	background-position: center;
	background-size: cover;
	padding: 8rem 0;

}

#sec1 .container{
	width: 1100px;
	margin: 0 auto;
}

#sec1 .row{
	background-color: #fff;
	opacity: 0.9;
	box-shadow: 0px 0px 12px 0px #d1d1d1;
	border-radius: 0px;

}


#sec1 .row .row-bg-border{
	width: 980px;
	margin: 6rem auto;
	border: 1px solid #1F1F27;
	padding: 4rem;
	text-align: center;	
}

#sec1 .row h2{
	width: 226px;
    margin: 0 auto;

}

#sec1 .row .day{
	border-top: 1px solid #1F1F27;
    border-bottom: 1px solid #1F1F27;
    text-align: center;
    font-size: 20px;
    margin: 2rem auto;
	display: inline-block;
}

#sec1 .bg-gray{
	background-color: rgba(240,240,240,0.5);
	border-radius: 25px;
	padding: 8rem 0;
    margin: 8rem auto;
}

#sec1 .boothblock{
	display: flex;
	align-items: center;
	width:790px;
	justify-content: space-between;
    margin: 0 auto;
}

#sec1 .booth-img{
	width:375px;
	margin-right: 2rem;
}

#sec1 .booth-txt{
	width: calc(100% - 375px);
	font-weight: bold;
}

#sec1 .place{
	font-size: 28px;
	font-weight: 600;
	line-height: 1.6;
}

#sec1 .f38 {
	display: flex;
	align-items: center;
	background: #D3B467;
    color: #fff;
    justify-content: center;
	font-weight: 400;
}

#sec1 .f38 span{
	font-size: 24px;
	padding-right: 10px;
}

#sec1 .booth-img2{
	width: 790px;
	margin: 0 auto 2rem;
	display: block;
}

 
#sec1 .col-btn{
	display: flex;
	justify-content: space-between;
	width: 790px;
    margin: 0 auto;
}

#sec1 .btn{
	width: 50%;
	margin: 2% 8px 0;
}


#sec1 .btn::after{
	content: "\f2d2";
    font-family: FontAwesome;
	font-weight: normal;
}
@media screen and (max-width: 991px){
	#sec1 .row .row-bg-border{ width: calc(100% - 30px);}
	
	#sec1 .container{ width: calc(100% - 30px);}
	
	#sec1 .boothblock,#sec1 .booth-img2,#sec1 .col-btn{max-width: 100%;padding: 0 15px;}
	
	#sec1 .place{font-size: 22px;}
	#sec1 .f38{font-size: 28px;}
}
@media screen and (max-width: 767px){
	#sec1 .row .row-bg-border{ margin: 5% auto;}
	#sec1 .container{border-radius: 15px;}
	#sec1 .bg-gray{padding: 2rem 0;}
	#sec1 .boothblock{flex-direction: column;}
	
	#sec1 .booth-img{max-width: 100%;margin: 0;padding-bottom: 2%;}
	#sec1 .place{font-size: 20px;}
	#sec1 .booth-txt{width: 100%;}
	#sec1 .f38 span{font-size: 18px;}
	
	#sec1 .col-btn{
	flex-direction: column;
	gap:1rem;
	padding-top: 1rem;
	}
	
	#sec1 .btn{
	width: 100%;
    margin: 0 auto;
	padding: 20px;
	}
}





/* ============= #sec2 ============= */
#sec2{
	background: #F8F6F2;
	padding: 8rem 0 6rem;
}
#sec2 .container{
	padding-top: 2rem;
}
#sec2 h2{
	text-align:center;
	font-size:26px;
	letter-spacing: 0.09em;
	position: relative;
}


#sec2 h2::before{
	position: absolute;
	content: '';
	display: block;
	background: url(../img/point_mini.svg);
	background-repeat: no-repeat;
	width: 70px;
    height: 40px;
    background-size: contain;
    top: -50%;
    left: 50%;
    transform: translateX(-50%);
}

#sec2 h2 span{
	font-size: 38px;
	color: #EE1A1A;
}

#sec2 h3{
	display: flex;
	align-items: center;
	margin-top: 5px;
	color: #9A7F35;
}

#sec2 .point-ic{
	width: 80px;
}

#sec2 .point-ttl{
	width: calc(100% - 80px);
	padding-left: 10px;
	font-size: 22px;
}

#sec2 .cnt{
	width: 1100px;
	margin: 0 auto;	
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#sec2 .cnt .point-col{
	width: calc(100% / 3 - 2rem);
	margin-bottom: 2rem;

}

#sec2 .cnt .flex-last{
	width: 100%;
	margin-bottom: 0;
}

#sec2 .cnt1 .col-md-6 > p{
	padding-top: 5px;
}
@media screen and (max-width: 991px){
	#sec2{padding: 10rem 0 2rem;}
	#sec2 h2{font-size: 20px;}
	#sec2 h2::before{top: -50%;width: 56px;}
	#sec2 h2 span{font-size: 30px;}
	#sec2 .cnt{max-width: 100%;padding: 0 15px;gap:1rem;}
	#sec2 .cnt .point-col{width: calc(100% / 3 - 1rem);}
	#sec2 .cnt .flex-last{width: 100%;}
	#sec2 .point-ic{width: 54px;}
	#sec2 .point-ttl{width: calc(100% - 54px);font-size: 18px;}
	
	
}

@media screen and (max-width: 767px){
	#sec2 h2{font-size:16px;}
	#sec2 h2 span{font-size:26px;}
	#sec2 .cnt{padding: 0 10px;}
	
	#sec2 .cnt .point-col{
	width: calc(100% / 2 - 0.5rem);
	}
	#sec2 .cnt .flex-last{width: 100%;}
	
	#sec2 .point-ic{
		width: 40px;
	}
	
	#sec2 .point-ttl{
		width: calc(100% - 40px);
		font-size: 15px;
	}

}

/* ============= #sec3 ============= */
#sec3{
	background: #F7F7F7;
    padding: 8rem 0 6rem;
}

#sec3 h2{
	text-align:center;
	font-size:26px;
	letter-spacing: 0.09em;
	position: relative;
}

#sec3 h2::before{
	position: absolute;
	content: '';
	display: block;
	background: url("../img/stage_mini.svg");
	background-repeat: no-repeat;
	width: 70px;
    height: 40px;
    background-size: contain;
    top: -50%;
    left: 50%;
    transform: translateX(-50%);
}

#sec3 h2 span{
	font-size: 38px;
	color: #EE1A1A;
}

#sec3 .tab-area {
  display: flex;
  border: 1px solid #e0e0e0;
  cursor: pointer;
  margin-top: 2%;
  background: #fff;
  font-size: 18px;
}

#sec3 .tab {
  width: calc(100%/3);
  padding: 5px;
  text-align: center;
}

#sec3 .tab:nth-child(n+2) {
  border-left: 1px solid #e0e0e0;
}
#sec3 .tab.active {
  background: rgb(199,169,87);
  background: linear-gradient(180deg, rgba(199,169,87,1) 0%, rgba(154,127,53,1) 100%);
  color: #fff;
}

#sec3 .demo {
  display: none;
  text-align: center;
  background: #fff;
}
#sec3 .demo.active {display: block;}

#sec3 .demo ul{padding: 1% 0;width: 1000px;margin: 0 auto;}

#sec3 .demo ul li{
	width: 100%;
    display: flex;
    justify-content: space-between;
	border-bottom: 1px solid #e0e0e0;
	padding: 2% 0;
}

#sec3 .demo ul li:last-of-type{
	border-bottom: none;
}

#sec3 .demo ul li .demo-fboxL{
	display: flex;
	width: 40%;
	align-items: center;
	justify-content: space-between;
}

#sec3 .demo ul li .demo-fboxL div{
	width: calc(100% - 160px);
}

#sec3 .demo ul li .demo-fboxL figure{
	width: 150px;
}

#sec3 .demo ul li .demo-fboxL .time{
	font-size: 18px;
	font-weight: bold;
}

#sec3 .demo ul li .demo-fboxL .live-icon{
	background: rgb(56,63,162);
    background: linear-gradient(180deg, rgba(56,63,162,1) 0%, rgba(224,62,133,1) 100%);
    color: #fff;
    border-radius: 4px;
    padding: 4%;
	text-align: center;
}

#sec3 .demo ul li .demo-fboxR{
	width: 60%;	
	align-self: center;
}

#sec3 .demo ul li .demo-fboxR .demo--inner--logo{
	display: flex;
	align-items: flex-start;
}

#sec3 .demo ul li .demo-fboxR .demo--inner--logo img{
	width: 200px;
	
}

#sec3 .demo ul li .demo-fboxR .demo--inner--logo p{	
	text-align: left;
	width: calc(100% - 200px);
	padding-left: 5%;
}

#sec3 .demo ul li .demo-fboxR .demo--inner--logo p span{font-size: 18px;}	

#sec3 .demo ul li .demo-fboxR .demo--inner--logo + p{
	text-align: left;
	padding-top: 5px;
}

@media screen and (max-width: 991px){
	#sec3{padding: 10rem 0 2rem;}
	#sec3 h2{font-size: 20px;}
	#sec3 h2::before{top: -50%;width: 56px;}
	#sec3 h2 span{font-size: 30px;}
	#sec3 .tab-area{margin: 0 2%;}
	#sec3 .demo{margin: 0 2%;}
	#sec3 .demo ul{max-width: 100%;padding: 0 2%;}	
	#sec3 .demo ul li .demo-fboxL div{
		width: 60%;margin-right: 5%;
	}
	#sec3 .demo ul li .demo-fboxL figure{
		width: 35%;
	}
	#sec3 .demo ul li .demo-fboxR .demo--inner--logo p{width: 100%;}
	
	#sec3 .demo ul li .demo-fboxR .demo--inner--logo img{
		width: 30%;
	}
}

@media screen and (max-width: 767px){
	#sec3 h2{font-size:16px;}
	#sec3 h2::before{top: -32%;}
	#sec3 h2 span{font-size:26px;}
	#sec3 .demo ul li{flex-direction: column;padding: 4% 0 2%;}
	#sec3 .demo ul li .demo-fboxL,#sec3 .demo ul li .demo-fboxR{
		width: 100%;
	}
	#sec3 .demo ul li .demo-fboxL figure{width: 30%;}
	#sec3 .demo ul li .demo-fboxR .demo--inner--logo{flex-direction: column;}
	#sec3 .demo ul li .demo-fboxR .demo--inner--logo img{width: 40%;}
	#sec3 .demo ul li .demo-fboxR .demo--inner--logo p{padding: 0 5% 3%;}
	
}
/*------------------topへ------------------------*/
#bwj_23tokyo .scrollTop {
    position: fixed;
    right: 30px;
    bottom: 30px;
    transition: all 0.4s ease-in-out 0s;
	z-index: 5;
}

#bwj_23tokyo .scrollTop a {
  display: inline-block;
  text-decoration: none;
  background: #d83980;
  color: #FFF;
  width: 60px;
  height: 60px;
  line-height: 120px;
  border-radius: 50%;
  text-align: center;
  /*overflow: hidden;
  box-shadow: 0px 0px 0px 5px #a0a8bf;
  border: dashed 1px #FFF;
  transition: .4s;*/
  position: relative;
  opacity:0.7;
}
#bwj_23tokyo .scrollTop a:after {
    font-family: "FontAwesome";
    content: '\f077';
    position: absolute;
    top: -35px;
    left: 7px;
    font-size: 45px;
}

@media screen and (max-width: 480px){
#bwj_23tokyo .scrollTop {
    right: 20px;
    bottom: 20px;
}
#bwj_23tokyo .scrollTop a {
  width: 40px;
  height: 40px;

}
#bwj_23tokyo .scrollTop a:after {
    top: -44px;
    left: 4px;
    font-weight: 900;
    font-size: 30px;
}
}

/*------------------topへ------------------------*/
