@charset "utf-8";

/* ────────────────────────────────────────────

max-width: 767px 

──────────────────────────────────────────── */


/* general framework */
.wrap {
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 100%;
}
.wrap div,
.wrap p,
.wrap li,
.wrap dt,
.wrap dd {
	font-size: 1.4rem; /*font-size : 14px と同等*/
	line-height: 2;
	font-weight: 500;
}

/* title */
/* font */
.content main h2.secTitle {
	font-size: 3.5rem;
}
.content main .titleSub {
	font-size: 1.8rem;
}
/* btn */
.content main .linkBtn {
	max-width: 345px;
	margin-inline: auto;
	border-radius: 50px;
	padding: 18px 20px;
	line-height: 1.4;
	font-size: 1.4rem;
}
.content main .linkBtn.iconSchool {
	padding: 10px 0 10px 80px;
}
.content main .linkBtn.iconSchool::before {
	width: 60px;
	height: 60px;
}
.content main .linkBtn.iconSchool span.fontS {
	font-size: 1.2rem;
	line-height: 1.5;
}
/* header */
header {
	position: fixed;
}
header #header{
	padding: 10px 0;
}
header #header .logo {
	width: 24.5%;
	max-width: 176px;
	min-width: 92px;
}
header #header .logo a{
	width: 100%;
}
nav:has(.breadcrumnbNavi) {
	margin-top: auto;
}
nav:has(.globalNavi) {
	display: none;
}
nav:has(.globalNavi.active) {
	display: block;
}
/* toggle */
/* globalNavi グローバルナビ
------------------------------------------------------------------ */
/* ハンバーガー */
#toggle,
#toggle span {
	transition: all .4s;
	box-sizing: border-box;
}
#toggle {
	float:right;
	position: relative;
	width: 20px;
	height: 20px;
	margin: 0 0 0 10px;
}
#toggle span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #E20A16;
	border-radius: 4px;
}
#toggle span:nth-of-type(1) {
	top: 0;
}
#toggle span:nth-of-type(2) {
	top: 8px;
}
#toggle span:nth-of-type(3) {
	bottom: 0;
}
#toggle.active span:nth-of-type(1) {
	-webkit-transform: translateY(8px) rotate(-315deg);
	transform: translateY(8px) rotate(-315deg);
}
#toggle.active span:nth-of-type(2) {
	opacity: 0;
}
#toggle.active span:nth-of-type(3) {
	-webkit-transform: translateY(-8px) rotate(315deg);
	transform: translateY(-8px) rotate(315deg);
}
/* ハンバーガーメニュー */
header #header .globalNavi {
	display: none;
	width: 100%;
	margin-inline: auto;
	padding: 0;
	letter-spacing: -.40em;
}
header #header .globalNavi li {
	letter-spacing: normal;
	width: 100%;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #FFF;
}
header #header .globalNavi li a{
	position: relative;
	font-size: 1.6rem;
	font-weight: bold;
	display: block;
	padding: 15px;
	color: #FFF;
	text-align: left;
	text-decoration: none;
	background-color: var(--mainRed);
	vertical-align: middle;
}
header #header .globalNavi li a:before{
	content: "";
	position: absolute;
	background: url(/assets/img/common/arrow_menu.svg) no-repeat;
	background-size: 100% 100%;
	width: 26px;
	height: 26px;
	right: 15px;
	top: 50%;
	transform: translate(0, -50%);
}
header #header .globalNavi li a:after{
	content:"　"attr(data-en) "";
	white-space:pre;
	font-size:12px;	
}
header #header .globalNavi.active {
	display: block;
	position: absolute;
	left: 0;
	z-index: 2;
}

header #header .guideLink li a {
	background: unset;
	border: none;
	padding: 0 0 0 27px;
	color: #454545;
	font-size: 1rem;
	line-height: 1.1;
}
header #header .guideLink li a::before {
	width: 25px;
	height: 25px;
}
header #header .guideLink li a.calendarLinkBtn::before {
	background: url(/assets/img/common/header_icon_calendar_sp.svg) no-repeat;
	left: 0;
}
header #header .guideLink li a.schoolLinkBtn::before {
	background: url(/assets/img/common/header_icon_school_sp.svg) no-repeat;
	left: 0;
}
#overLay {
	display: none;
	width: 100%;
	height: 100%;
	text-align: center;
	position: fixed;
	top: 0;
	z-index: 2;
	background: rgba(256, 256, 256, .9);
}

/* content 共通 */
.innerSp100 {
	width: 100%!important;
}
.content main section {
	padding: 50px 0;
}
.content main #prologue {
	border-radius: 20px 20px 0 0;
}
.content main .boxWrap.Two>div,
.content main .boxWrap.Three>div,
.content main .boxWrap.Four>div {
	margin-bottom: 20px;
}
.content main .boxWrap.Two>div:last-child,
.content main .boxWrap.Three>div:last-child,
.content main .boxWrap.Four>div:last-child {
	margin-bottom: 0;
}
.content main .whiteBox {
	padding: 40px 20px;
}
body:not(#top) .wrap .mainImg {
	margin-bottom: -20px;
}
body:not(#top) .wrap .mainImg .innerSp100.lowerPage {
	height: 160px;
	z-index: 0;
	position: relative;
}
.wrap .mainImg .innerSp100.lowerPage h1 {
	font-size: 4.3rem;
	padding-bottom: 22px;
	margin-left: 20px;
	margin-right: -50px;
	&::after {
		font-size: 2rem;
		left: 0;
		bottom: 0px;
	}
}
.wrap .mainImg .innerSp100.lowerPage figure {
	z-index: 5;
}
.headingRedBdr::before {
	width: 5px;
	height: 18px;
}
.content main .iconCaution::before {
	width: 33px;
	height: 30px;
}
.content main .iconCaution p {
	padding-left: 43px;
	line-height: 1.4;
}
.slider .slick-prev,
.slider .slick-next {
	width: 66px;
	height: 66px;
}
.slider .slick-prev::before,
	left: -36px;
}
.slider .slick-next::before{
	left: -36px;
}
.slider .slick-prev::before,
.slider .slick-next::before {
	width: 15px;
	height: 15px;
}
.slider .slick-dots {
	bottom: 12px;
}
/* トップページ用 */
#top .wrap .mainImg h1 span {
	padding: 10px 20px;
}
#top .wrap .mainImg h1 span.firstHalf {
	font-size: 1.8rem;
	top: 30px;
}
#top .wrap .mainImg h1 span.secondHalf {
	font-size: 1.4rem;
	top: 73px;
}
#top .content main section#latestNews {
	padding: 20px 0;
}
#top #latestNews .latestNewsList {
	border: 1px solid var(--mainRed);
}
#top #latestNews .latestNewsList dt {
	padding: 10px 0;
	font-size: 1.8rem;
	line-height: 1;
}
#top #latestNews .latestNewsList dd {
	padding: 20px;
	font-size: 1.4rem;
	line-height: 1.6;
}
#top .content main section#prologue {
	padding: 20px 0 40px;
}
#top #prologue .whiteBox {
	padding: 0 20px;
	margin: 20px auto;
}
#top #prologue .museumInfo div.iconArea div {
	border-bottom: 1px solid #E8E0DB;
	padding: 20px 0;
}
#top #prologue .museumInfo div.iconArea div dl {
	margin-left: 90px;
	line-height: 1.4;
	padding: 10px 0;
}
#top #prologue .museumInfo div.iconArea div::before {
	top: 50%;
	left: 0;
	transform: translate(0px, -50%);
}
#top #prologue .museumInfo div.iconArea dl dt {
	font-size: 2.6rem;
	line-height: 1;
	margin-bottom: 5px;
}
#top #prologue .museumInfo div.iconArea .closeDay dl dt {
	font-size: 2.2rem;
}
#top #prologue .museumInfo div.iconArea dl dt span,
#top #prologue .museumInfo div.iconArea dl dd {
	font-size: 1.2rem;
	line-height: 1.4;
}
#top #prologue .museumInfo div.noIconArea>div dl {
	display: flex;
	gap: 20px;
	padding-bottom: 20px;
}
#top #prologue .museumInfo div.noIconArea dl dt {
	font-size: 1.6rem;
	text-align: right;
	width: 70px;
	line-height: 1.4;
}
#top #prologue .museumInfo div.noIconArea dl dd {
	font-size: 1.6rem;
	line-height: 1.4;
}
#top #prologue .cautionArea {
	width: 100%;
	margin-inline: auto;
}
#top #prologue .cautionArea::before {
	width: 33px;
	height: 30px;
}
#top #prologue .cautionArea .cautionList {
	padding-left: 43px;
}
#top #prologue .cautionArea .cautionList li {
	line-height: 1.4;
}
#top #calendar figure.calendarIcon {
	width: 70px;
	margin: 0 auto 10px;
}
#top main #calendar h2.secTitle {
	font-size: 3.2rem;
}
#top #calendar .whiteBox {
	padding: 20px 0;
	box-shadow: none;
}
#top #information .informationList li {
	padding: 10px 0;
}
#top #information .informationList li dl dt,
#top #information .informationList li dl dd {
	line-height: 1.4;
}

/* #exhibition */
#exhibition .wrap .mainImg .innerSp100.lowerPage figure {
	width: 39.6%;
	max-width: 148px;
	margin: 38px -7px 0 -50px;
}
#exhibition .content main section:not(#prologue) {
	padding: 50px 0 0;
}
#exhibition main p.mainTxt {
	font-size: 2.4rem;
	line-height: 1.6;
}
#exhibition main .titleSub {
	padding-bottom: 20px;
}
#exhibition main section#prologue .areaGuide picture {
	margin-top: 40px;
}
#exhibition main .areaWrap {
	padding: 50px 0 ;
}
#exhibition main section:not(#prologue) .areaGuide p {
	line-height: 1.8;
}
#exhibition main .areaGuide .areaAttention {
	margin: 30px auto 40px;
}
#exhibition main section:not(#prologue) .areaGuide .areaAttention .shooting p {
	font-size: 1.2rem;
}
#exhibition main section#photoArea .areaGuide .areaAttention .shooting p {
	line-height: 1.2;
}
#exhibition main .areaGuide .areaAttention p {
	padding-left: 10px;
}
#exhibition main .areaGuide .areaAttention .otherAttention {
	margin-top: 10px;
}
#exhibition main .areaGuide .areaAttention .otherAttention p {
	line-height: 1.4;
}
#exhibition main .areaWrap .boxWrap {
	margin-bottom: 55px;
}
#exhibition main .areaWrap .boxWrap:last-child {
	margin-bottom: 0;
}
#exhibition main .areaWrap .figArea {
	margin-bottom: 55px;
}
#exhibition main #photoArea .areaWrap .figArea {
	margin-bottom: 62px;
}
#exhibition main .areaWrap .figArea:last-child {
	margin-bottom: 0;
}
#exhibition main .areaWrap .boxWrap:last-child .figArea:last-child {
	margin-bottom: 0;
}
#exhibition main .figArea h3 {
	font-size: 1.4rem;
}
#exhibition main .figWrap figure img {
	border-radius: unset;
}
#exhibition main .figArea .figWrap figcaption {
	line-height: 1.8;
	padding: 10px 20px 0;
}
#exhibition main .slider .slick-dots {
	bottom: 8px;
}
/* #shop */
#shop .slider .slick-dots {
	bottom: 50px;
}
#shop .wrap .mainImg .innerSp100.lowerPage figure {
	width: 37.4%;
	max-width: 140px;
	margin: 70px 5px 0 -50px;
}
#shop .mainImg .innerSp100.lowerPage figure {
	width: 35%;
	margin-right: 10px;
}
#shop main #prologue .areaGuide p {
	margin: 10px 20px 0;
}
#shop main #prologue .areaGuide p.attention {
	margin: 20px 20px 40px;
	line-height: 1.4;
	text-indent: -1em;
	padding-left: 1em;
}
#shop .content main .whiteBox {
	border-radius: 20px;
}
#shop main #prologue .whiteBox .shopInfo .openTime {
	margin-bottom: 20px;
}
#shop main #prologue .whiteBox .shopInfo .closeDay dd span.txtIndent {
	margin-top: 10px;
}
#shop main #prologue .whiteBox .paymentInfo dl dt {
	margin: 10px 0 10px 10px;
}
#shop main #prologue .whiteBox .shopInfo div dt {
	width: 80px;
	margin-right: 10px;
}
#shop main #prologue .whiteBox .shopInfo div dd {
	width: calc(100% - 80px);
	margin-right: 10px;
}
#shop main #prologue .whiteBox div dl dt,
#shop main #prologue .whiteBox div dl dd {
	font-size: 1.6rem;
	line-height: 1;
}
#shop main #prologue .whiteBox div dl dd span {
	font-size: 1.2rem;
	line-height: 1.4;
}
#shop main #prologue .whiteBox div dl dd li {
	font-size: 1.2rem;
	line-height: 1.4;
	margin-bottom: 10px;
}
#shop main #prologue .whiteBox div dl dd li:last-child {
	margin-bottom: 0;
}
#shop main .gridboxWrap .gridBox {
	display: grid;
	gap: 20px;
	margin-bottom: 40px;
}
#shop main .gridboxWrap .gridBox h2 {
	font-size: 2.4rem;
	line-height: 1.4;
}
#shop main .gridboxWrap .gridBox .gridImg.peroLogo {
	width: 80px;
}
#shop main .gridboxWrap .gridBox .gridImg.rider {
	width: 100%;
}
#shop main .gridboxWrap .gridBox .gridTxt ul {
	padding-top: 20px;
}

/* #access */
#access .wrap main #prologue iframe {
	height: 250px!important;
}
#access .wrap .mainImg .innerSp100.lowerPage figure {
	width: 28%;
	max-width: 106px;
	margin: -20px 30px 35px -50px;
}
#access main h2 {
	padding-bottom: 10px;
}
#access main .accessInfoWrap figure img {
	border-radius: 20px;
}
#access main ul.accessInfoList {
	margin-top: 30px;
}
#access main ul.accessInfoList li {
	padding: 0 0 30px 50px;
	line-height: 1.4;
}
#access main ul.accessInfoList li.iconBus span {
	line-height: 1.4;
}
#access main .accessInfoWrap.En dl.headingRedBdr::before {
	height: 34px;
}
/* #guide */
#guide .wrap .mainImg .innerSp100.lowerPage figure {
	width: 34.5%;
	max-width: 129px;
	margin: 25px -30px 0 -50px;
}
#guide main #prologue h2 span.forVisitor {
	font-size: 1.4rem;
	padding: 5px 38px;
	border-radius: 50px;
}
#guide main #prologue h2 span.threeWishes {
	font-size: 2.7rem;
}
#guide main #prologue h2 span.threeWishes span {
	font-size: 4.2rem;
}
#guide main #prologue .requestInfoWrap {
	margin-bottom: 60px;
}
#guide main #prologue .requestInfoWrap:last-child {
	margin-bottom: 0;
}
#guide main #prologue .boxWrap .whiteBox {
	margin-top: 20px;
}
#guide main #prologue .boxWrap .whiteBox dt {
	font-size: 1.8rem;
	line-height: 1;
	margin: 10px auto;
}
#guide main #prologue .boxWrap .whiteBox .wishList span.accessLink {
	display: block;
	margin-top: 5px;
}
#guide main #prologue h3,
#guide main #floorMap h3 {
	font-size: 2rem;
	line-height: 1.4;
}
#guide main #prologue .reservePoints {
	padding: 40px 20px;
}
#guide main #prologue .reservePoints .boxWrap .whiteBox {
	padding: 40px 20px;
}
#guide main #prologue .reservePoints .boxWrap .whiteBox span.fontS {
	font-size: 1.2rem;
	padding-top: 10px;
}
#guide main #floorMap .floorInfoWrap .whiteBox .iconCaution {
	position: relative;
	margin-bottom: 20px;
}
#guide main #floorMap .floorInfoWrap .whiteBox {
	margin: 40px auto;
}
#guide main #floorMap .shootGuideWrap {
	padding: 40px 20px;
	border-radius: 20px;
}
#guide main #floorMap .shootGuideWrap .shootGuideList li dt {
	border-radius: 5px;
	padding: 10px 10px 10px 35px;
}
#guide main #floorMap .shootGuideWrap .shootGuideList li dt::before {
	width: 20px;
	height: 15px;
}
#guide main #floorMap .floorInfoWrap .attentionLeft {
	margin-top: 10px;
	font-size: 1.2rem;
}
#guide main #faq .faqCateWrap h3 {
	font-size: 1.6rem;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail {
	padding: 10px;
	margin-bottom: 10px;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail:last-child {
	margin-bottom: 0;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail dt {
	line-height: 1.4;
	padding: 0 28px;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail dd {
	line-height: 1.6;
	padding: 0 28px;
	margin: 20px 0;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail dt::before {
	width: 20px;
	height: 26px;
}
#guide main #faq .faqCateWrap .faqWrap .faqDetail dd::before {
	width: 20px;
	height: 26px;
}
#guide main #contact .contactWrap dt {
	font-size: 1.6rem;
	margin-bottom: 10px;
	line-height: 1;
}
#guide main #contact .contactWrap dd {
	margin-bottom: 10px;
	line-height: 1.4;
}
#guide main #contact .contactWrap a.linkBtn {
	text-align: left;
}
#guide main #forVisitors .forVisitorsList dt {
	font-size: 1.6rem;
	line-height: 1.2;
}
#guide main #forVisitors .forVisitorsList dd {
	line-height: 1.2;
}
#guide main #forVisitors .forVisitorsList dd.shootDetail span {
	line-height: 1.6;
}
#guide main #forVisitors .forVisitorsList dd ul li {
	line-height: 1.6;
}

/* #message */
#message .wrap .mainImg .innerSp100.lowerPage figure {
	width: 37.4%;
	max-width: 140px;
	margin: 58px 5px 0 -50px;
}
#message main .messageWrap .messagesFrom {
	text-align: center;
}

/* #information お知らせ詳細ページ */
#information .informationMainArea {
	margin-bottom: 40px;
}
#information .informationMainArea h1 {
	font-size: 2.4rem;
	padding: 40px 20px 10px;
}
#information .informationMainArea .mainRead {
	margin-top: 20px;
}
#information .termBox {
	padding: 20px;
	border-radius: 20px;
}
#information .informationMainArea .termBox {
	margin: 20px auto;
}
#information .termBox p.infoAttention {
	font-size: 1.4rem;
}

#information .informationMainArea .fontSmallDate {
	font-size: 1.4rem;
	padding-bottom: 40px;
}
#information #prologue h2 {
	font-size: 2.4rem;
	margin-bottom: 20px;
}

#information .content main #prologue ol.informationDetail>li {
	margin-bottom: 40px;
}
#information .content main #prologue ol.informationDetail>li h3 {
	font-size: 1.6rem;
	margin-bottom: 10px;
}
#information .content main #prologue .informationDetail picture {
	margin-bottom: 10px;
}
#information .termBox dl dt.spFlex {
	display: flex;
	align-items: center;
}
#information .termBox dl dt.spFlex span{
	font-size: 1.4rem;
	font-weight: 300;
}

/* footer */
#footer .footerLogoArea .footerLogoWrap .footerLogo {
	width: 30px;
}
#footer .footerLogoArea .footerLogoWrap .footerAdress p {
	font-size: 1rem;
	line-height: 1.5;
}
#footer .footerLogoArea .snsLink {
	gap: 10px;
}
#footer .footerLogoArea .snsLink li.xLink img,
#footer .footerLogoArea .snsLink li.youtubeLink img {
	height: 30px;
	width: auto;
}

