@charset "UTF-8";
@font-face { font-family: YuGothicM; src: local(Yu Gothic Medium); }

* { margin: 0; padding: 0; }
html { width: 100%; height: 100%; }
body { width: 100%; height: 100%; background-color: #ddd; color: #333; background-size: 750px auto; font-family: YuGothic,YuGothicM,Meiryo,'メイリオ','ＭＳ Ｐゴシック',sans-serif; font-size: 95%; line-height: 1.8; -webkit-text-size-adjust: 100%; }
img { border: 0; vertical-align: top; -ms-interpolation-mode: bicubic; }
a { outline: none; }
a:link { color: #03c; text-decoration: none; }
a:visited { color: #03c; text-decoration: none; }
a:hover { color: #03c; text-decoration: underline; }
a:hover img { opacity: 0.8; }
.clearfix:after { content: ''; display: block; clear: both; }
.centre { text-align: center; }
.right { text-align: right; }
.red { color: #f00; }


/* --------------------------------------------------
	GLOBAL HEADER
-------------------------------------------------- */
header#globalHeader { position: relative; }
header#globalHeader .inner { display: flex; align-items: center; justify-content: space-between; max-width: 100%; margin: 0 auto; padding: 15px 20px; }
header#globalHeader .logo img { width: 300px; height: auto; }
@media screen and (max-width : 767px) {
	header#globalHeader div.inner { padding: 25px 0 20px 20px; width: auto;  text-align: left; }
	header#globalHeader .logo img { width: 350px; }
}


/* --------------------------------------------------
	GLOBAL NAVIGATION
-------------------------------------------------- */
nav#globalNavi { background-color: transparent; padding: 0; z-index: 2; }
nav#globalNavi ul { display: flex; flex-wrap: wrap; gap: 1em; list-style: none; margin: 0; padding: 0; }
nav#globalNavi li { font-size: 90%; font-weight: 700; }
nav#globalNavi li a { color: #333; text-decoration: none; position: relative; padding: 0.5em; display: inline-block; }
nav#globalNavi li a::after { width: 100%; height: 1px; background: #333; position: absolute; left: 0; bottom: 0; content: ''; transform: scale(0, 1); transform-origin: center top; transition: transform .3s; }
nav#globalNavi li a:hover::after { transform: scale(1, 1); }
nav#globalNavi a.close { display: none; }

@media screen and (max-width : 767px) {
	nav#globalNavi { position: absolute; top: 100%; left: 0; width: 100vw; background: #000; z-index: 5; display: none; padding-bottom: 2em; }
	nav#globalNavi ul { flex-direction: column; width: 100%; }
	nav#globalNavi li { border-bottom: 1px solid #fff; text-align: center; }
	nav#globalNavi li a { color: #fff; display: block; padding: 1em; font-size: 100%; }
	nav#globalNavi li a::after { height: 0; }
	nav#globalNavi a.close { display: block; margin: 1em auto; background: #fff; color: #333; text-align: center; border-radius: 999px; padding: 0.5em 1.5em; width: fit-content; }
	nav#globalNavi a.close:hover { text-decoration: none; }
}

/* --------------------------------------------------
	MAIN
-------------------------------------------------- */
main { margin: 0 auto; padding: 10px 0; width: 100%; display: block; position: relative; }
main div#title { margin: 0 0 3em 0; text-align: center; line-height: 1.5; }
main div#title h1 { font-size: 140%; }
main div#title span { font-size: 90%; }
main .subtitle { position: relative; margin: 3em 0 2em; padding: 0; }
main .subtitle h2 { margin: 0; font-size: 140%; font-weight: 700; color: #222; text-align: left; position: relative; display: inline-block; padding-right: 1em; background: linear-gradient(to right, #000 0%, #000 40%, transparent 40%, transparent 100%); background-size: 100% 2px; background-repeat: no-repeat; background-position: bottom left; }
main .subtitle a { position: absolute; right: 0; bottom: 0; font-size: 90%; color: #666; text-decoration: none; transition: all 0.3s ease; }
main .subtitle a::after { content: ' →'; transition: transform 0.3s ease; }
main .subtitle a:hover { color: #000; }
main .subtitle a:hover::after { transform: translateX(3px); }
main h3 {}
main h4 {}
main p { margin: 1em 0; }
@media screen and (max-width : 767px) {
	main { padding: 0 15px 20px 15px; width: auto; }
	main div#title { margin: 0 0 2em 0; }
}

/* --------------------------------------------------
	GLOBAL FOOTER
-------------------------------------------------- */
footer#globalFooter { position: relative; z-index: 2; background-color: #dedede; margin-top: 50px; }
footer#globalFooter div.inner { margin: 0 auto; padding: 30px 0; width: 980px; text-align: center; }
footer#globalFooter span#link { display: block; margin-bottom: 20px; }
footer#globalFooter span#link a.first { padding-right: 20px; }
footer#globalFooter span#link img { width: 40px; }
footer#globalFooter span#history { display: block; }
footer#globalFooter select { margin: 0 0 1em 0; display: none; }
footer#globalFooter p#copyright { font-size: 90%; }
div#overlay { width: 100%; height: 0; background: url(../images/common/overlay.png); display: none; position: fixed; top: 0; left: 0; z-index: 2; }
a#spMenu { display: none; }
@media screen and (max-width : 767px) {
	footer#globalFooter div.inner { width: auto; }
	footer#globalFooter select { display: inline; }
	footer#globalFooter span#history { display: none; }
	a#spMenu { width: 45px; height: 45px; background: #000 url(../images/common/spMenu.png) center 5px no-repeat; background-size: 30px auto; border: solid 1px #fff; border-radius: 1px; color: #fff; font-size: 10px; text-align: center; line-height: 66px; display: block; position: fixed; top: 20px; right: 20px; z-index: 4; opacity: 0; transition: opacity 0.3s ease; pointer-events: none; }
	a#spMenu:hover { text-decoration: none; }
	a#spMenu.visible { opacity: 1; pointer-events: auto; }
}

.grecaptcha-badge{ z-index:9999; }


/* --------------------------------------------------
	COMMON
-------------------------------------------------- */
nav#globalNavi { margin: 0; }
main { padding: 20px 0 50px 0; }
main div#thanks { text-align: center; }
main div#thanks img.thanks { width: 800px; height: auto; }
section { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
section.show { opacity: 1; transform: translateY(0); }
@media screen and (max-width : 767px) {
	main { padding: 0 15px 20px 15px; }
	main div#thanks { width: 100%; text-align: center; }
	main div#thanks img.thanks { width: 100%; height: auto; }
}

/* --------------------------------------------------
	MAIN IMAGE
-------------------------------------------------- */
div#main { width: 100%;  }
div#main img.pcmain { width: 100%; height: auto; display: block;}
div#main img.spmain { width: 100%; height: auto; display: none; }
@media screen and (max-width : 767px) {
	div#main { padding-top: 20px;}
	div#main img.pcmain { width: 100%; height: auto; display: none;}
	div#main img.spmain { width: 100%; height: auto; display: block; }
}

/* --------------------------------------------------
	NEWS
-------------------------------------------------- */
section#news { margin: 0 auto 100px auto; padding: 0 5%; width: 100%; max-width: 1080px; }
section#news ul { list-style: none; margin: 0; padding: 0; border-top: none; }
section#news li { box-sizing: border-box; padding: 5px 10px; margin-bottom: 10px; background: #f9f9f9; border: 1px solid #000; border-left: 5px solid #000; /* ← ブルーに変更 */ transition: background-color 0.3s, box-shadow 0.3s; }
section#news li:hover { background-color: #eef6fb; box-shadow: 0 2px 5px rgba(0,0,0,0.05); }
section#news li span { display: block; font-size: 110%; color: #666; margin-bottom: 5px; }
section#news li p { margin: 0; font-size: 110%; font-weight: bold; color: #333; transition: color 0.3s; }
section#news li:hover p { color: #007acc; }
section#news li p, section#news li span { word-break: break-word; overflow-wrap: break-word; }
@media screen and (max-width: 767px) {
	section#news { padding: 0; }
	section#news li { padding: 10px; font-size: 95%; }
	section#news li span { font-size: 85%; }
	section#news li p { font-size: 100%; line-height: 1.6; word-break: break-word; }
}

/* --------------------------------------------------
	REPORT
-------------------------------------------------- */
section#report { padding: 0 5%; max-width: 1080px; margin: 0 auto 100px; width: 100%; }
section#report h2 { font-size: 140%; margin-bottom: 0.1em; font-weight: bold; color: #222; }
section#report h3 { font-size: 120%;margin-top: 1em; margin-bottom: 0.5em; font-weight: bold; padding-left: 10px; color: #333; }
section#report p { font-size: 110%; line-height: 1.5; margin: 0 0 1.5em 0; color: #333; }
section#report p.right { text-align: right; font-weight: bold; color: #444; }
section#report a { color: #007acc; text-decoration: underline; transition: color 0.3s; }
section#report a:hover { color: #005999;}
section#report p, section#about p.right { overflow-wrap: break-word; word-break: break-word; }
@media screen and (max-width: 767px) {
	section#report { padding: 0; }
}


/* --------------------------------------------------
	ABOUT
-------------------------------------------------- */
section#about { padding: 0 5%; max-width: 1080px; margin: 0 auto 100px; width: 100%; }
section#about h2 { font-size: 140%; margin-bottom: 0.1em; font-weight: bold; color: #222; }
section#about h3 { font-size: 120%;margin-top: 1em; margin-bottom: 0.5em; font-weight: bold; padding-left: 10px; color: #333; }
section#about p { font-size: 110%; line-height: 1.5; margin: 0 0 1.5em 0; color: #333; }
section#about p.right { text-align: right; font-weight: bold; color: #444; }
section#about a { color: #007acc; text-decoration: underline; transition: color 0.3s; }
section#about a:hover { color: #005999;}
section#about p, section#about p.right { overflow-wrap: break-word; word-break: break-word; }
@media screen and (max-width: 767px) {
	section#about { padding: 0; }
}

/* --------------------------------------------------
	artists
-------------------------------------------------- */
section#artists { padding: 0 5%; max-width: 1080px; margin: 0 auto 100px; width: 100%; }
ul#artists { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; padding: 0 5%; list-style: none; margin: 0 auto; max-width: 1080px; }
ul#artists li { flex: 0 0 calc(33.333% - 13.333px); /* 3列 × gap調整 */ box-sizing: border-box; height: auto; position: relative; }
ul#artists div.panel { position: relative; width: 100%; height: auto; }
ul#artists div.panel div { width: 100%; height: auto; position: relative; }
ul#artists div.panel img.artist { width: 100%; height: auto; border: solid 1px #fff; border-width: 20px; box-sizing: border-box; position: relative; z-index: 1; }
.img-wrapper { position: relative; width: 100%; height: auto; }
.img-wrapper img { width: 100%; height: auto; display: block; border: solid 1px #fff; border-width: 20px; box-sizing: border-box; z-index: 1; }
.name-overlay { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(0, 0, 0, 0.6); color: #fff; padding: 8px 0px; font-size: 100%; font-weight: bold; text-align: center; white-space: nowrap; opacity: 0; transition: opacity 0.3s; z-index: 2; border-radius: 4px; }
.panel:hover .name-overlay { opacity: 1; }
@media screen and (max-width : 767px) {
	section#artists { padding: 0; }
	ul#artists { width: auto; }
	ul#artists li { flex: 0 0 100%; margin-bottom: 15px; }
	ul#artists div.panel img.artist { height: auto; }
	.name-overlay { opacity: 1 !important; }
}

/* --------------------------------------------------
	ACCESS
-------------------------------------------------- */
section#access { margin-bottom: 100px;  padding: 0 5%; width: 100%; max-width: 1080px; margin-left: auto; margin-right: auto; }
section#access iframe { width: 100%; max-width: 100%; height: 400px; display: block; box-sizing: border-box; }
section#access p { font-size: 110%; }
.map-wrap { width: 100%; overflow: hidden; }
@media screen and (max-width: 767px) {
	section#access { padding: 0; }
	section#access iframe { height: 300px; width: 100%; }
}

/* --------------------------------------------------
	funding
-------------------------------------------------- */
section#funding { margin-bottom: 100px;  padding: 0 5%; width: 100%; max-width: 1080px; margin-left: auto; margin-right: auto; }
.funding-content { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 20px; margin-top: 20px; }
.campfire_iframe { flex: 0 0 245px; }
.campfire_comment { flex: 1; font-size: 110%; }
@media screen and (max-width : 767px) {
	section#funding { padding: 0;}
	.funding-content { flex-direction: column; }
	.campfire_iframe, .campfire_comment { width: 100%; }
}

/* --------------------------------------------------
	schedule
-------------------------------------------------- */
section#schedule { margin-bottom: 100px; padding: 0 5%; width: 100%; max-width: 1080px; margin-left: auto; margin-right: auto; }
section#schedule .time_img { width: 90%; }
@media screen and (max-width : 767px) {
	section#schedule { padding: 0; }
	section#schedule .time_img { width: 100%; }
}



/* --------------------------------------------------
	contact
-------------------------------------------------- */
section#contact { margin-bottom: 100px; padding: 0 5%; width: 100%; max-width: 1080px; margin-left: auto; margin-right: auto; }
section#contact p { font-size: 110%; }
section#contact dl { margin: 1.5em 0; }
section#contact dt { width: 220px; float: left; }
section#contact dt img { width: 200px; height: auto; }
section#contact dd { width: 760px; float: left; }
section#contact dd strong { margin: 0 0 0.5em 0; font-size: 110%; display: block; }
section#contact dd p { margin: 0; font-size: 110%; }

@media screen and (max-width : 767px) {
	section#contact { padding: 0; }
	section#contact dt { margin: 0 0 1em 0; width: auto; text-align: center; float: none; }
	section#contact dd { width: auto; float; none; }
	section#contact dd strong { margin: 0; }
}


/* --------------------------------------------------
	gallery
-------------------------------------------------- */
section#gallery { padding: 0 5%; max-width: 1080px; margin: 0 auto 100px; width: 100%; }
ul#gallery { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; padding: 0 5%; list-style: none; margin: 0 auto; max-width: 1080px; }
ul#gallery li { flex: 0 0 calc(33.333% - 13.333px); /* 3列 × gap調整 */ box-sizing: border-box; height: auto; position: relative; }
ul#gallery img { width: 100%; height: auto; border: solid 1px #fff; border-width: 20px; box-sizing: border-box; position: relative; z-index: 1; }
/*
ul#gallery div.panel { position: relative; width: 100%; height: auto; }
ul#gallery div.panel div { width: 100%; height: auto; position: relative; }
ul#gallery div.panel img.artist { width: 100%; height: auto; border: solid 1px #fff; border-width: 20px; box-sizing: border-box; position: relative; z-index: 1; }
.img-wrapper { position: relative; width: 100%; height: auto; }
.img-wrapper img { width: 100%; height: auto; display: block; border: solid 1px #fff; border-width: 20px; box-sizing: border-box; z-index: 1; }
.name-overlay { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(0, 0, 0, 0.6); color: #fff; padding: 8px 0px; font-size: 100%; font-weight: bold; text-align: center; white-space: nowrap; opacity: 0; transition: opacity 0.3s; z-index: 2; border-radius: 4px; }
.panel:hover .name-overlay { opacity: 1; }
*/
@media screen and (max-width : 767px) {
	section#gallery { padding: 0; }
	ul#gallery { width: auto; }
	ul#gallery li { flex: 0 0 100%; margin-bottom: 15px; }
	ul#gallery img { height: auto; }
	.name-overlay { opacity: 1 !important; }
}

/* --------------------------------------------------
	スライドショー
-------------------------------------------------- */
#main.slideshow { position: relative; width: 100%; height: auto; overflow: hidden; aspect-ratio: 16 / 9; }
.slide { opacity: 0; transform: scale(0.5); transition: opacity 1s ease, transform 3s ease; position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: contain; z-index: 0; }
.slide.active { opacity: 1; transform: scale(1); z-index: 1; }
#main.slideshow img { object-fit: contain; width: 100%; height: 100%; }
.origin-center        { transform-origin: center center; }
.origin-top-left      { transform-origin: top left; }
.origin-top-right     { transform-origin: top right; }
.origin-bottom-left   { transform-origin: bottom left; }
.origin-bottom-right  { transform-origin: bottom right; }


/* --------------------------------------------------
	News01
-------------------------------------------------- */
section#news01 { padding: 0 5%; max-width: 1080px; margin: 0 auto 100px; width: 100%; }
ul#news01 { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; padding: 0 5%; list-style: none; margin: 0 auto; max-width: 1080px; }
ul#news01 li { flex: 0 0 calc(50% - 10px); /* 3列 × gap調整 */ box-sizing: border-box; height: auto; position: relative; }
ul#news01 img.news01 { width: 100%; height: auto; box-sizing: border-box; position: relative; z-index: 1; }
@media screen and (max-width : 767px) {
	section#news01 { padding: 0; }
	ul#news01 { width: auto; }
	ul#news01 li { flex: 0 0 100%; margin-bottom: 15px; }
	ul#news01 div.panel img.news01 { height: auto; }
	.name-overlay { opacity: 1 !important; }
}