@import url('https://fonts.googleapis.com/css2?family=Baskervville:wght@500&family=Noto+Sans+JP:wght@100..900&family=Shippori+Mincho:wght@600;700&display=swap');
@import url("default.css");

* {-webkit-text-size-adjust:100%;}
a:link {text-decoration:none; color:#000;}
a:visited{text-decoration:none; color:#000;}
a:hover{text-decoration:none; color:#000;}
a:active{text-decoration:none; color:#000;}

.grecaptcha-badge { opacity: 0; pointer-events: none; }
.full-width { margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }
.allWrapper { overflow: hidden; }
.container-fluid { max-width: 360px; padding-left: 20px; padding-right: 20px; }

body { font-size: 15px; line-height: 1.8; color: #000; background-color: #fff; font-family: "Noto Sans JP", sans-serif; font-weight: 400; }
header { position: fixed; right: 0; top: 0; width: calc(50% - 180px); height: 100vh; background-color: #000; background-image: url(../images/fixed_mask.png); background-size: cover; display: flex; align-items: center; justify-content: center; padding: 30px; z-index: 999; }
header .gnav { margin: 0 auto; }
header .gnav li { text-align: right; margin-bottom: 25px; }
header .gnav li:last-child { margin-bottom: 0; }
header .menu-trg-area { position: absolute; top: 6px; right: 15px; margin: auto; display: none; width: 40px; height: 40px; border-radius: 3px; cursor: pointer; z-index: 999;}
header .menu-trigger,
header .menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box;}
header .menu-trigger { position: absolute; top: 13px; width: 30px; height: 17px; z-index: 2; left: 0; right: 0; margin: auto;}
header .menu-trigger span { position: absolute; left: 0; width: 100%; height: 1px; background-color: #fff;}
header .menu-trigger span:nth-of-type(1) { top: 0;}
header .menu-trigger span:nth-of-type(2) { top: 8px;}
header .menu-trigger span:nth-of-type(3) { bottom: 0;}
header .menu-trigger.active span:nth-of-type(1) { -webkit-transform: translateY(20px) rotate(-45deg); transform: translateY(20px) rotate(-45deg); top: -13px;}
header .menu-trigger.active span:nth-of-type(2) { left: 50%; opacity: 0; -webkit-animation: active-menu-bar02 .8s forwards; animation: active-menu-bar02 .8s forwards;}
header .menu-trigger.active span:nth-of-type(3) { -webkit-transform: translateY(-20px) rotate(45deg); transform: translateY(-20px) rotate(45deg); bottom: -11px;}

header { position: fixed; left: 0; right: 0; top: 0; width: 100%; height: 57px; padding: 9px; display: block; z-index: 1000; max-width: 360px; margin: 0 auto; }
header .gnav { position: fixed; left: 0; top: 0; width: 100%; top: 0px; background: rgba(255,255,255,.9); height: 100%; opacity: 0; visibility: hidden; transition: .3s; background-color: #000; background-image: url(../images/fixed_mask.png); background-size: cover; overflow: auto; padding: 80px 20px 50px; z-index: 3; }
header .gnav.active { opacity: 1; visibility: visible; }
header .gnav .logo { text-align: center; }
header .gnav ul { max-width: 100%; width: 280px; margin-left: auto; margin-right: auto; }

footer { padding: 36px 0 16px; background-color: #000; background-image: url(../images/footer_mask.png); background-size: cover; width: 360px; margin: 0 auto; position: relative; z-index: 1; }
footer .logo { margin-bottom: 25px; text-align: center; }
footer .logo img { width: 136px; }
footer .copyright { text-align: center; font-size: 9px; letter-spacing: .03em; color: #fff; }
.mincho { font-family: "Shippori Mincho", serif; font-weight: 600; }
.semibold { font-weight: 600; }
.fixed_left { position: fixed; left: 0; top: 0; width: calc(50% - 180px); height: 100vh; background-color: #000; background-image: url(../images/fixed_mask.png); background-size: cover; display: flex; align-items: center; justify-content: center; padding: 30px; }
.fixed_left .logo { margin-bottom: 50px; }
.fixed_right { position: fixed; right: 0; top: 0; width: calc(50% - 180px); height: 100vh; background-color: #000; background-image: url(../images/fixed_mask.png); background-size: cover; display: flex; align-items: center; justify-content: center; padding: 30px; z-index: 999; }
.fixed_right ul { margin: 0 auto; }
.fixed_right ul li { text-align: right; margin-bottom: 25px; }
.fixed_right ul li:last-child { margin-bottom: 0; }

main { width: 360px; max-width: 100%; margin-left: auto; margin-right: auto; background-color: #BAA324; min-height: 100vh; padding-bottom: 1px; position: relative; z-index: 1; }
section { position: relative; padding-top: 20px; }
.bg { pointer-events: none; }
.s_title { text-align: center; margin-bottom: 30px; }
.s_title .jp { margin-top: 10px; font-size: 11px; letter-spacing: .04em; }
.s_title_min { text-align: center; margin-bottom: 35px; }
.s_firstview { padding-top: 0; margin-bottom: 100px; }
.s_concept { margin-bottom: 90px; }
.s_concept .bg { position: absolute; left: 0; width: 100%; top: -70px; }
.s_concept p { font-size: 15px; line-height: 2.1; text-align: center; }
.s_exhibitorlist { margin-bottom: 100px; }
.s_exhibitorlist .bg { position: absolute; left: 0; width: 100%; top: -70px; }
.exhibitorlist-list { display: flex; flex-wrap: wrap; margin: 0 -6px; }
.exhibitorlist-list li { width: 50%; padding: 0 6px; margin-bottom: 20px; }
.artist-card { display: block; }
.artist-card .photo { position: relative; margin-bottom: 5px; }
.artist-card .photo .plus { position: absolute; right: 7px; bottom: 7px; }
.artist-card .tags { display: flex; flex-wrap: wrap; margin: 0 -2px 5px; }
.artist-card .tag { margin: 2px; font-size: 10px; padding: 2px 5px 3px; line-height: 1; background-color: #000; color: #fff; font-family: "Baskervville", serif; }
.artist-card .name { font-size: 12px; }
.artist-card .from { font-size: 9px; margin-top: 0; }
.button-arrow { position: relative; display: inline-block; }
.button-arrow:before { content: ""; width: 250px; height: 50px; position: absolute; left: 2px; top: 5px; background-color: #fff; border-radius: 100px; border: 2px solid #000; transition: .3s; }
.button-arrow span { width: 250px; position: relative; left: 0; top: 0; border: 2px solid #000; margin: 0 auto; display: flex; align-items: center; justify-content: center; position: relative; height: 50px; background-color: #fff; border-radius: 100px; letter-spacing: .05em; font-size: 14px; transition: .3s; }
.button-arrow .arrow { position: absolute; right: 20px; top: 0; bottom: 0; margin: auto 0; }
.button-arrow:hover span { left: 2px; top: 5px; }
.s_giftcollection { position: relative; margin-bottom: 30px; }
.s_giftcollection .bg { position: absolute; left: 0; width: 100%; top: -75px; }
.tril-card { position: relative; background-color: #fff; margin-top: 20px; padding: 10px 20px 35px; box-shadow: 0 3px 5px rgba(0,0,0,.3); }
.tril-card:before { content: ""; width: 100%; height: 20px; background: #fff; clip-path: polygon(50% 0, 0 100%, 100% 100%); position: absolute; left: 0; bottom: calc(100% - 0.2px); }
.tril-card .s_title { margin-bottom: 35px; }
.tril-card .jp-title { text-align: center; font-size: 22px; font-weight: 700; letter-spacing: .02em; line-height: 1.4; margin-bottom: 16px; }
.tril-card .detail { font-size: 13px; letter-spacing: .03em; line-height: 1.7; text-align: center; font-weight: 600; }
.button-cube { height: 53px; width: 100%; background-color: #BAA324; display: flex; align-items: center; justify-content: center; font-size: 14px; letter-spacing: .04em; font-weight: 600; position: relative; cursor: pointer; }
.button-cube .arrow { content: ""; position: absolute; right: 20px; top: 0; bottom: 0; margin: auto 0; }
.button-cube.red { background: #A4001D; color: #fff!important; }
.s_market { margin-bottom: 30px; }
.s_workshop { margin-bottom: 30px; }
.s_tree { margin-bottom: 45px; }
.dl-tables dl + dl { margin-top: 45px; }
.dl-tables dl dt { border-bottom: 1px solid #000; font-weight: 500; margin-bottom: 15px; font-family: "Baskervville", serif; }
.dl-tables dl dd p { font-size: 13px; letter-spacing: .03em; }
.dl-tables dl dd strong { font-size: 18px; font-weight: 400; }
.bg-wrapper { position: relative; overflow: hidden; }
.bg-wrapper .bg { position: absolute; left: 0; width: 100%; top: 0; }
.s_message { margin-bottom: 80px; }
.s_message p { font-size: 13px; }
.sub_title { font-size: 13px; line-height: 1.53; font-weight: 600; }
.s_logomark { margin-bottom: 80px; }
.s_logomark p { font-size: 13px; }
.dls dl { display: flex; }
.dls dl + dl { margin-top: 12px; line-height: 1.69; }
.dls dl dt { font-size: 13px; font-weight: 600; width: 46px; }
.dls dl dd { font-size: 13px; width: calc(100% - 46px); }
.dls.full dl { display: block; }
.dls.full dl + dl { margin-top: 25px; }
.dls.full dl dt { width: 100%; margin-bottom: 2px; }
.dls.full dl dd { width: 100%; }
.button-simple { display: inline-block; padding: 5px 30px; background-color: #000; color: #fff!important; border-radius: 100px; font-size: 11px; font-weight: 600; letter-spacing: .03em; }
.s_access { margin-bottom: 100px; }
.s_credit { padding-bottom: 120px; }
.single-page { padding-top: 100px!important; }
.single-page .dl-tables .jp { line-height: 1.333; font-size: 18px; }
.single-page .dl-tables .jp strong { line-height: 1.333; }
.single-page .dl-tables .en { margin-top: 10px; font-size: 13px; }
.single-page .dl-tables .small { font-size: 11px; letter-spacing: .04em; color: #525151; }
.tag-title { margin: 2px; font-size: 20px; padding: 2px 5px 3px; line-height: 1; background-color: #000; color: #fff; font-family: "Baskervville", serif; display: inline-block; }
.accordion-gift { padding-top: 13px; }
.accordion-gift ul li a { display: flex; border-top: 1px solid #000000; align-items: center; padding: 10px 0 8px; }
.accordion-gift ul li:last-child a { border-bottom: 1px solid #000000; }
.accordion-gift .place { font-size: 7px; width: 35px; padding: 0 6px; }
.accordion-gift .name { font-size: 11px; width: calc(100% - 35px); text-decoration: underline; }
.hide-button { text-align: right; padding: 15px 15px 0; }
.hide-button .arrow { transform: rotate(180deg); cursor: pointer; }
.toggle-gift.active .arrow,
.toggle-market.active .arrow { transform: rotate(180deg); }
.accordion-market { padding-top: 25px; }
.accordion-market ul li a { display: flex; border-top: 1px solid #000000; align-items: center; padding: 10px 0 8px; }
.accordion-market ul li:last-child a { border-bottom: 1px solid #000000; }
.accordion-market .place { font-size: 7px; width: 35px; padding: 0 6px; }
.accordion-market .name { font-size: 11px; width: calc(100% - 35px); text-decoration: underline; }
.accordion-market .market-header { margin-bottom: 15px; }
.page_prev { position: fixed; left: 0; right: 310px; bottom: 20px; width: 21px; height: 21px; display: block; margin: 0 auto; z-index: 2; }
.page_next { position: fixed; right: 0; left: 310px; bottom: 20px; width: 21px; height: 21px; display: block; margin: 0 auto; z-index: 2; }

@media (max-width: 767px) {
	body { min-width: 375px; }
	header { max-width: 375px; }
	main { width: 375px; }
	.fixed_left { width: 100%; }
	.fixed_right { display: none; }
	.single-page { padding-top: 100px!important; }
	header .menu-trg-area { display: block; }
}
