@charset "UTF-8";


/*--------------------------------------------
TOKYO MODERNISM 2025
--------------------------------------------*/
#lineup-font-size-sampler {display: none;}
.tm * {letter-spacing: 0.02em;}
.tm, .tm a, .remodal .tm, 
.tm p, .interview__body, 
.profile__wrap, .interview__profile .profile__wrap .shopName .kana, .remodal-wrapper {
font-family:"YakuHanJP", "Helvetica Neue", Helvetica, dnp-shuei-gothic-kin-std, sans-serif; 
}
p, .interview__body {color: #000; font-size: 1.4rem;}

.tm .rd, 
.tm h2, .tm h3, .tm h4, .tm h5, .tm h6,
.venue__name, .profile__wrap .shopName, .tm .modBtn, .tmNav a,
#ticketSection .type, #ticketSection .price,
#ticketSection .hoursList li, 
.remodal__ttl, .remodalFlow__title {
font-family: new-atten-round, atten-round-new, dnp-shuei-mgothic-std, san-serif; 
font-weight: 800;
letter-spacing: 0.02em;
font-variant-numeric:normal;
}

.hero__img.is-show .hero__bg {}
.tm .aside {border: 1px solid #ddd; padding: 30px;}


.tm .event__title {font-family:swiss-721-bt-rounded, sans-serif; font-weight: 900;}

.venue__wrap .venue__name, .profile__wrap .shopName, .tm .tmNav a,
#tm__show #ticketSection .type, 
#tm__show #ticketSection .price,
#tm__show #ticketSection .hoursList li,
.tm .eventName {
font-weight: 600;
letter-spacing: 0.04em;
}

.tm h2, .tm h3 {text-align: center;}
.tm section h3 {margin:100px auto 50px; font-size: 3rem;}
.tm .modBtn {font-size: 1.5rem; font-weight: bold; border: 2px solid #999;}
.tm .modBtn:hover {border-color: #444;}
.hero__wrap .paragraph {margin-bottom: 1.3em; color: #000; }
.hero__wrap .link__arrow {margin-top: 40px;}

.tm .notes { font-size: 0.9em; font-weight: normal !important; color: #777 !important;}

.lowerfoot__nav {margin-top: 10px; padding: 0 5%;}
.lowerfoot__nav ul .modBtn {margin: 60px auto 0;}

@media screen and (min-width: 768px) {
.hero__wrap .modBtn {margin: 0 auto;}
.tm section h3 {margin:100px auto 30px; font-size: 3.6rem;}
.title__link {margin-top: 60px;}
.lowerfoot__nav ul .modBtn {margin: 60px auto 0;}

.s_img {display: flex; justify-content: space-between;}
}


@media screen and (max-width: 767px) {
.tm section h3 {margin:100px auto 50px; font-size: 2.4rem;}
.tm, .remodal .tm p {font-size: 13px;}
.tm .hero__bg {width:90%; margin: 0 auto;}
.tm .hero__desc {margin: 30px auto 60px; text-align: left;}
.hero__wrap {margin-top: 30px;}
.hero__wrap .link__arrow {margin-top:20px;}
.title__link {margin-top: 40px;}
}

/*tmNav*/

.tmNav h5 { margin-bottom: 8px;
padding: 1px 0 0 0.5em;
font-size: 1.8rem;
color: #fff; background-color: #000;}

.tmNav ul a {color: #000; font-weight: bold;}
.tmNav ul a:hover {color: #555;}
.tmNav ul a:before {padding: 0 6px 0 0;
    font-family: FontAwesome;
    content: "\f105";
    font-size: 12px;}
.tmNav .btn_category_top {margin-top: 80px;}

.tmNav ul li:nth-of-type(2) a:hover {color: #0c909a;}
.tmNav ul li:nth-of-type(3) a:hover {color: #0A6991;}
.tmNav ul li:nth-of-type(4) a:hover {color: #0b318f;}

@media screen and (min-width: 768px) {
.tmNav {margin-top: 120px;}
.tmNav ul {display: flex; 
align-items: flex-start;
justify-content: flex-start; 
flex-wrap: wrap;}
.tmNav ul li {margin-right: 40px; font-size: 1.7rem;}
}

@media screen and (max-width: 767px) {
.tmNav {margin-top: 80px;}
.tmNav ul {margin-top: 15px;}
.tmNav ul li {margin-top: 0.4em; font-size: 1.5rem;}

}







/*index*/



.indexNav h5 {margin-bottom: 0.45em; font-size: 1.5rem; line-height: 1.1;}
.indexNav > li > h4, 
.indexNav > li > p {max-width: 720px; margin: 10px auto;}
.indexNav .s_img p {line-height: 1.65;}
.indexNav .profile {display: flex; justify-content: space-between; max-width: 720px; margin: 40px auto ;}
.indexNav .profile h6 {margin-bottom: 0.4em; font-size: 1.3rem;}
.indexNav .profile dd p {font-size: 1.3rem; line-height: 1.5;}

@media screen and (min-width: 768px){
.hero__desc.notitle {margin-top: 0px;}
.indexNav {max-width: 960px; margin: 0 auto;}
.indexNav > li:not(:first-of-type) {margin-top: 120px;}
.indexNav li .paragraph {margin: 30px auto;}
.indexNav > li > .modBtn {display: block; width: 100%; margin:30px auto 10px;}

.indexNav #ticketSection {max-width: 720px; margin: 30px auto;}
.indexNav #ticketSection .ticket_info {width:100%; margin: 0 0 30px; }
.indexNav #ticketSection #hours { width:100%; display: flex; justify-content: space-between;}
.indexNav #ticketSection #hours .hoursbox {width:50%;}
.indexNav #ticketSection #hours .venuebox {width:38%;}

.indexNav .s_img {
max-width: 720px; margin: 0 auto 40px; }
.indexNav .s_img dt {width:50%;}
.indexNav .s_img dd {width:46%;}
#tm_pers h4 {margin-bottom: 0.45; font-size: 1.6rem; line-height: 1.3;}
.indexNav .profile dt {width:16%;}
.indexNav .profile dd {width:81%; }

#tm_pers .reverse {flex-direction: row-reverse;}
}

@media screen and (max-width: 767px){
#tm__index .leadBlock {margin:120px auto 40px;}

.indexNav > li:nth-of-type(n+2) {margin-top: 80px;}
.indexNav li h3 {margin-bottom: 30px;}
.indexNav > li > h4 {margin: 1.2em 0 0.4em 0; line-height: 1.3;}
.indexNav .modBtn {margin-top: 1.5em;}
.indexNav .s_img dt {margin: 30px auto; }
.indexNav #ticketSection .modBtn {margin-top: 0;}
.indexNav #ticketSection h5 {margin: 1.8em 0 0.4em 0;}


.indexNav .profile dt {width: 18%;}
.indexNav .profile dd {width: 79%;}
}



/* index::anime */
.js-scrollAnimation > * {
  opacity: 0;
}


.is-show > :first-child {
  -webkit-animation: fade 1s linear 0s forwards;
          animation: fade 1s linear 0s forwards;
}

.is-show > :nth-child(2){  
  -webkit-animation: fade 1s linear .5s forwards;
          animation: fade 1s linear .5s forwards;}


.is-show > :nth-child(3){
  -webkit-animation: fade 1s linear 1.0s forwards;
          animation: fade 1s linear 1.0s forwards;
}


.is-show > :nth-child(4){
  -webkit-animation: fade 1s linear 1.5s forwards;
          animation: fade 1s linear 1.5s forwards;
}

.is-show > :nth-child(5){
  -webkit-animation: fade 1s linear 1.9s forwards;
          animation: fade 1s linear 1.9s forwards;
}

.is-show > :nth-child(6){
  -webkit-animation: fade 1s linear 2.3s forwards;
          animation: fade 1s linear 2.3s forwards;
}

.is-show > :nth-child(7){
  -webkit-animation: fade 1s linear 2.5s forwards;
          animation: fade 1s linear 2.5s forwards;
}

.is-show > :nth-child(8){
  -webkit-animation: fade 1s linear 2.7s forwards;
          animation: fade 1s linear 2.7s forwards;
}


.fin {
  opacity: 0.4 !important;
}

/***************************************
Common
****************************************/

.mod_tm_header {background-color: #f5f4ee;}
.mod_tm_header img {width:375px; margin: 0 auto;}

.event__title span {display: block; margin-top: 0.4em; font-size: 66%;}

@media screen and (min-width: 768px){

.event__title {margin-bottom: 1em; font-size:4.8rem;}
.event__title .event__term {font-size:60%;}
.event__title .event__place {font-size:55%;}
.lowerfoot__nav ul {display: flex; justify-content: center;
margin-top: 80px;}
}

@media screen and (max-width: 767px){

.event__title {margin-bottom: 1em; font-size:2.8rem;}
}



/***************************************
 Show
****************************************/

#tm__show .event__title {color: #0c909a;}

.fee {margin-top: 40px;}
.fee .pricelist {margin: 0.8em auto 2em;}
.hero__wrap .pricelist .link__arrow {margin: 0.2em 0 0 1.5em;}
#floorguide {margin-top: 60px;}


.areaMap area:hover {cursor: pointer;}
.venue__list {display: flex; flex-wrap: wrap; justify-content: flex-start;}
.venue__list a {color: #222;}
.venue__list a:hover {opacity: 0.9;}
.tm .pref__icon {display: inline-block; margin-top: 1em; padding:0.26em 0.36em;
border: 1px solid #ccc; border-radius: 3px; 
font-size: 1.0rem; color: #555; line-height: 1;}
#tm__show section h3 {margin:100px auto 50px;}
#ticketSection .ticket_info .feeList li  {display: flex; justify-content: space-between; align-items: center;
padding: 10px 0; border-bottom: 1px dashed #ccc;}
#ticketSection .ticket_info > .notes li {margin-top: 0.4em; font-size: 12px; color: #666; line-height: 1.1;}
#ticketSection .ticket_info > .notes {margin-top: 2em;}
#ticketSection .type .notes {display: block; margin-top: 0.4em;
font-family:"YakuHanJP", "Helvetica Neue", Helvetica, "Yu Gothic", YuGothic, sans-serif;
font-size: 1.1rem; font-weight: normal; color: #666;}
#ticketSection .modBtn:hover {background-color: #222;}
#ticketSection #hours a {color: #333; }
#ticketSection #hours a:hover {color: #000; text-decoration: underline;}
#ticketSection .hoursList li {margin-bottom: 16px; padding-bottom: 6px; 
line-height: 1.25;border-bottom:1px dashed #ccc; }

@media screen and (min-width: 768px) {

.contentWrap#tm__show .hero__desc {margin-bottom: 80px;}
#tm__show .bgWrap {background-color: #f5f5f5; padding: 30px;}
#tm__show .bgWrap .inner {display: flex; justify-content: space-between;
max-width: 930px; margin: 0 auto;}

#ticketSection .ticket_info {width:62%; margin-right: 0; }
#ticketSection h5 { margin-bottom: 0.4em; font-size: 2.4rem; line-height: 1; }
#ticketSection .feeList li:last-of-type {margin-bottom: 0;}

#ticketSection .type {width: 35%; font-size: 1.7rem; line-height: 1; }
#ticketSection .price {width:14%; font-size: 1.9rem;}
#ticketSection .modBtn {width:38%; min-width: 200px; padding: 10px 10px 10px 25px;
background-color: #000; color: #fff; border: none;}
#ticketSection .modBtn:before {color:#fff;} 

#ticketSection #hours {width:30%; margin-right: 0;}
#ticketSection .hoursList li {font-size: 1.5rem;}
#tm__show #ticketSection .venuebox h5 {margin-top: 30px;}
#tm__show .aside#limitedItem {margin: 40px auto; padding: 30px; max-width: 940px;}
#tm__show #limitedItem .s_img {}
#tm__show #limitedItem dt {width: 32%;}
#tm__show #limitedItem dd { width: 65%; line-height: 1.6;}
#tm__show #limitedItem h4 {margin-bottom: 0.5em;}
#tm__show #limitedItem h4 .jp {font-size: 88%;}

.areaMap {width:960px; margin: 0 auto 30px;}

#tm__show .venue {margin-top: 120px;}

.venue__list > li {width:31%; margin-right: 3.5%; margin-top: 50px;}
.venue__list > li:nth-of-type(3n) {margin-right:0;}
.venue__list > li:nth-of-type(n+4) {margin-top:50px;}
.venue__title {margin: 100px auto 0px; text-align: center;}
.venue__block { display: flex; justify-content: space-between;
padding-top: 80px;}

.venue__thumb {}
.venue__disc { width: 48%;}
.venue__name {margin-top: 0.4em; font-size: 1.9rem;}
}



@media screen and (max-width: 767px) {

#tm__show .bgWrap {margin-top: 60px; background-color: #f5f5f5; padding: 20px 6vw;}

#ticketSection h5 { margin-bottom: 0.8em; 
font-size: 2.2rem; line-height: 1; }

#ticketSection .type {width: 38%; font-size: 1.6rem; line-height: 1; }
#ticketSection .type .note {font-size: 1.1rem; line-height: 1.2;}
#ticketSection .price {width:19%; font-size: 1.8rem;}
#ticketSection .modBtn {width:37%; padding: 1.2em 2px 1.2em 11px; background-color: #000; color: #fff; border: none;}
#ticketSection .modBtn:before {left: 10px;}
#ticketSection #hours {margin-top: 30px;}
#ticketSection .hoursList li {margin-bottom: 10px; padding-bottom: 10px;  font-size: 1.5rem;}


#tm__show .aside#limitedItem {margin: 40px auto; padding: 20px; width:90%;}
#tm__show #limitedItem .s_img {}
#tm__show #limitedItem dt { width: 100%;}
#tm__show #limitedItem dd { width: 100%; }
#tm__show #limitedItem h4 {margin:20px 0 0.5em;}
#tm__show #limitedItem h4 .jp {font-size: 88%;}

.venue__list > li {width:48%; margin-right: 4%;}
.venue__list > li:nth-of-type(2n) {margin-right :0;}
.venue__list > li:nth-of-type(n+3) { margin-top: 30px;}
.venue__title {margin: 80px auto 40px; text-align: center;}
.venue__thumb {}
.venue__name {margin-top: 0.4em; font-size: 1.6rem;}


}




/* ------------------------
Interiew detail
--------------------------*/

.interview__desc {margin-top: 80px;
text-align: center;}
#gallery__interview {font-variant-numeric: normal;}
#gallery__interview .section__title {
margin: 0 auto 80px; 
font-family: new-atten-round, atten-round-new, Zen Maru Gothic, vdl-v7marugothic, tbudrgothic-std, san-serif; 
font-weight: 800;
letter-spacing: 0.05em;
font-variant-numeric:normal;
text-align: center;
}

#gallery__interview .section__title .subTitle {
display: block; 
margin-bottom: 1.1em; 
font-size: 65%;
color: #777;}

.interview__lead, .interview__body {
font-size: 14px;
font-weight: normal;
line-height: 1.8;
text-align: left;}

.interview__scene {margin:0 auto;}
.interview__scene.photo_s {max-width: 800px;} 
.txt__wrap {margin: 60px auto 60px;}

.txt__wrap .itemName {
margin-bottom: 0.6em;
font-size: 1.12em; font-weight: bold;
line-height: 1.5;}

.txt__wrap .question {margin-bottom: 20px; 
color: #000; line-height: 1.5; font-weight: bold;}
.txt__wrap .question:nth-of-type(n+2) {margin-top: 50px;}

.question:before {
    content: "";
    display: block;
    float: left;
    margin: 0.65em 6px 0 0; 
    border-top: 1px solid #999;
    width: 20px;
}

.answer { margin-bottom: 20px; color: #000;}

#gallery__interview .spec {margin-bottom: 1em;}

.interview__caption {
margin-top: 20px;
font-size: 90%; 
color: #777; 
line-height: 1.5;}

#gallery__interview .section__stitle {margin-bottom: 1.6em; font-size: 22px; text-align: center;}
#gallery__interview .section__stitle span {display: block; margin-bottom: 0.6em; 
font-size: 70%; color: #777; letter-spacing: 0.08em;}

.photo_caption {margin-top: 10px; font-size: 1.0rem; color: #777; line-height: 1;}

.interview__profile .modBtn {display: block;  margin: 0 auto;}

.profile__wrap {overflow: hidden; background-color: #f5f5f5;}
.interview__profile .profile__link:nth-of-type(n+2) {margin-top: 6px;}

/* PC */

@media screen and (min-width: 768px) {

	
.hero {
max-width: 1060px;
margin: 0 auto;
margin-top: 80px;}
.hero__img {
/*  max-width: 77.5vw;*/
}
#gallery__interview .interview__desc .notes {margin-top: -40px;}
#gallery__interview .section__title .subTitle {line-height: 1.3;}
.interview__lead {margin:0 80px 30px;}
.interview__body {margin-top: 80px;}
.interview__scene {margin:0 auto 10px;}
.interview__scene.narrow {width:75%;}


.txt__wrap {max-width: 800px;
margin: 60px auto 60px;}

.profile__wrap {
max-width: 900px;
margin: 120px auto ;
padding: 25px;
}

.profile__wrap dt {
float: left; 
margin-right: 3%; 
width: 28%;}

.profile__wrap dd {
width:68%; 
line-height: 1.5;}

.interview__profile .profile__wrap .shopName {
margin:4px 0 0.8em 0; 
font-size: 18px; 
line-height: 1;
letter-spacing: 0.09em;
text-align: left;}

.interview__profile .profile__wrap .shopName .kana {
display: block;
margin-top: 0.4em;
font-size: 65%; }

.profile__txt {
margin-bottom: 1.0em; 
font-size: 13px;}
.profile__link { }

.interview__profile .profile__wrap .profile__linkBlock {}

.profile__linkBlock li {
margin-top: 0.4em; 
line-height: 1.35;}

.profile__wrap h5 {margin-top: 1.8em;}

.interviewNav__title {margin-bottom: 40px; 
padding-top: 40px; 
text-align: center;}

.itemDetail {max-width:900px; margin: 0 auto;}

}




/* MOBILE */

@media screen and (max-width: 767px) {

.hero {margin-top: 17.33vw;}

.section__inner {
padding: 0 8vw;
}
	#gallery__interview .section__title {
margin: 0 auto 40px; }
.interview__lead {margin:0 auto 20px;}
.interview__body {margin-top: 40px;}
.interview__body .interview__scene:not(:first-of-type) {margin-top: 10px;}
.interview__scene.narrow {width:90%;}


.profile__wrap {
display: block;
margin: 100px auto ;
padding: 25px;
}

.profile__wrap dt {
margin:0px auto 20px ; 
width: 100%;
background-color: #fff;}

.profile__wrap dt img {width: 70%; margin: 0 auto;}

.profile__wrap dd {}

.interview__desc {margin:50px 20px 30px;}
.section__title {
margin: 0 auto 40px; 
}

.interview__profile .profile__wrap .shopName {
margin:24px 0 0 0; 
font-size: 18px; 
line-height: 1;}

.interview__profile .profile__wrap .shopName .kana {
display: block;
margin-top: 0.5em; 
font-size: 70%; }

.profile__txt {
clear: both; 
margin:1em 0 1.4em; 
font-size: 13px; 
line-height: 1.6;}

.profile__link { }

.profile__linkBlock li {
margin-top: 0.7em; 
line-height: 1.4;}

.profile__wrap h5 {margin-top: 1.8em;}

.interviewNav__title {
margin-bottom: 40px; 
padding-top: 40px; 
text-align: center;}

.interview__list li {
width: 47%; 
margin-bottom: 30px;}

.interview__list .artistList__text{margin-top: 12px; text-align: center;}

.interview__list .shopName {
margin-top:1.2em;
font-size:15px;
text-align: center;}

.interview__list .shopName .job {
display: block;
font-size: 80%;
}
}


/* TABLET */

@media screen and (max-width: 1024px) and (min-width: 767px) {
  .section__inner {
	padding: 0 5vw;
  }
}




/***************************************
 Experience
****************************************/

#tm_exp .eventWrap {margin-right: auto; margin-left: auto;}
.eventWrap:last-of-type {border: none; padding-bottom: 0;}
#tm_exp .eventName {margin-bottom: 0.5em; letter-spacing: 0.05em; line-height: 1.4;}
#tm_exp .eventName span {display: block; margin-bottom: 0.3em; font-size: 75%; color: #0b318f;}
#tm_exp .eventDetail {margin-top: 20px;}

#tm_exp .eventDesc .modBtn {margin-top: 20px;}


/* PC */
@media screen and (min-width: 960px) {
#tm_exp .eventWrap {display: flex; justify-content: space-between; 
width:100%; max-width: 1000px;}
#tm_exp .eventWrap {margin-top: 40px; padding-bottom: 40px; border-bottom: 1px dotted #ccc;}

.eventWrap .eventImg {width:52.5%;}
.eventWrap .eventDesc {width:44%;}
#tm_exp .eventName {font-size: 1.8rem;}
.eventBody, .eventDetail {font-size: 13px; line-height: 1.6;}
.eventWrap .eventDesc .modBtn {max-width: 240px;}
#tm_exp .eventDetail li {margin-top: 0.1em;}
}



/* MOBILE */

@media screen and (max-width: 959px) {

#tm_exp .eventWrap { margin-top: 30px; margin-bottom: 30px; padding-bottom: 30px; border-bottom: 1px dotted #ccc;}
#tm_exp .eventWrap .eventImg {width:100%;}
#tm_exp .eventWrap .eventDesc {width:100%; margin-top: 20px; font-size: 13px; line-height: 1.4;}
#tm_exp .eventName {}
#tm_exp .eventWrap .eventDesc .modBtn {max-width: 80%; margin: 20px auto 0;}
#tm_exp .eventDetail li {margin-top: 0.2em;}



}
