/* -------------------------------------------------- */
/* ナビゲーション */
/* -------------------------------------------------- */

@container(min-width:1000px) {

/* ナビゲーション */
.global-nav__list.flex.flex-column { background-color:transparent;}

}

/* -------------------------------------------------- */
/* ファーストビュー */
/* -------------------------------------------------- */

/* ベース */
.fv { aspect-ratio:5/10; background-image:none; position:relative; height:auto; width:100vw; z-index:1; }
.fv .movie-area { aspect-ratio:5/10; overflow:hidden; position:relative; top:0; left:0; max-width:100vw; width:100vw; z-index:-1; }
.fv .movie-area video { height:100%; }

/* 画像 */
.fv-deco { aspect-ratio:344/427; background-image:url('../img/top/fv/fv-sp-1.png'); transform:translate(-50%,-50%); position:absolute; top:50%; left:50%; height:auto; max-width:80%; width:100%; z-index:2; }

@container( min-width:429px ) {

/* ベース */
.fv { aspect-ratio:3/4; }
.fv .movie-area { aspect-ratio:3/4; }

/* 画像 */
.fv-deco { max-width:60%; }

}

@container( min-width:769px ) {

/* ベース */
.fv { aspect-ratio:16/9; overflow:hidden; height:80vh; }
.fv .movie-area { aspect-ratio:16/9; height:100%; width:100%; }
.fv .movie-area video { object-fit:cover; height:100%; width:100%; }

/* 画像 */
.fv-deco { aspect-ratio:887/377; background-image:url('../img/top/fv/fv-pc.png'); transform:translate(-50%,-50%); top:55%; left:50%; max-width:65%; }

/* ボタン */
ul.fv-btn { top:50%; }

}

@media( max-height:699px ) {

/* ボタン */
ul.fv-btn li.pc-only a img { height:150px; max-width:auto; width:auto; }

}

/* -------------------------------------------------- */
/* お知らせ */
/* -------------------------------------------------- */

/* ベース */
.note { background-image:url('../img/top/note/note.png'); background-position:right bottom; background-size:191px 163px; display:block; padding:36px 0 20px 0; margin-bottom:25px; }

/* 見出し */
.note h2 { font-size:32px; font-weight:600; padding:0 20px; margin-bottom:14px; }

/* リスト */
.note ul { border-left:10px solid var(--gr-3); gap:28px; padding:10px 20px; }

@container( min-width:1000px ) {

/* ベース */
.note { background-image:none; padding:72px 0 112px 0; }
.note .pc-layout { align-items:flex-start; display:flex; justify-content:center; margin:auto; max-width:1000px; width:100%; }

/* 見出し */
.note h2 { font-size:65px; line-height:normal; padding:0 40px 0 0; margin-bottom:0; width:200px; }

/* リスト */
.note ul { border-left:7px solid var(--gr-3); gap:30px; padding:20px 40px; width:calc(100% - 200px); } 
.note ul li time, .note ul li p { font-size:18px; }

}

/* -------------------------------------------------- */
/* 歓迎メッセージ */
/* -------------------------------------------------- */

/* ベース */
.message { background-color:var(--gr); padding:30px 0 150px 0; }

/* 見出し */
.message h2 { font-size:35px; font-weight:600; display:block; transform:translateY(-50px); margin:auto; }

/* 未入稿 */
p.msg { text-align:left; line-height:38px; letter-spacing:1.2px; padding:0 20px; }
p.msg.center { font-size:24px; font-weight:600; text-align:center; }

@container( min-width:1000px ) {

/* 見出し */
.message h2 { font-size:65px; display:inline-block; position:relative; left:50%; transform:translateY(-50px) translateX(-70%); max-width:1000px; width:100%; }
.message h2::after { aspect-ratio:176/150; background-image:url('../img/top/message/kaminarimon.png'); position:absolute; top:50%; transform:translateY(-50%); margin-left:10vw; height:auto; width:176px; }

/* 未入稿 */
p.msg { font-size:20px; padding:30px 0 0 0; margin:auto; max-width:1000px; width:70%; }
p.msg.center { font-size:36px; }

}

/* -------------------------------------------------- */
/* スケジュール */
/* -------------------------------------------------- */

/* ベース */
.schedule { background-color:var(--bl-3); padding:25px 0 50px 0; }

/* 背景画像 */
.sc-back { pointer-events:none; position:relative; top:0; left:0; height:100%; width:100%; z-index:1; }
.sc-back::before { aspect-ratio:454/461; background-image:url('../img/top/schedule/gunpai.png'); top:200px; right:27px; position:absolute; height:185px; width:185px; z-index:1; }
.sc-back::after { aspect-ratio:135/170; background-image:url('../img/top/schedule/fuji.png'); position:absolute; left:-9px; top:
610px; height:170px; width:135px; z-index:1; }

/* 見出し */
.schedule hgroup { align-items:center; justify-content:center; margin-bottom:25px; }
.schedule hgroup h2 { font-size:35px; font-weight:600; position:relative; }
.schedule hgroup h2::before { aspect-ratio:66/130; background-image:url('../img/top/schedule/tower.png'); top:-90px; left:-70px; position:absolute; height:130px; width:66px; }
.schedule hgroup h3 { color:#9d9d9d; font-size:20px; font-weight:600; transform:translateY(-5px); }

/* タブ切り替え部分：タブリスト */
.tab-buttons { gap:33px; justify-content:center; margin-bottom:20px; }
.tab-buttons li { box-sizing:border-box; cursor:pointer; gap:-10px; justify-content:center; padding:5px; height:60px; width:80px; }
.tab-buttons li.active { background-color:var(--gr-2); }
.tab-buttons li span { color:var(--bl); line-height:1; }
.tab-buttons li span.day { font-size:24px; font-weight:600; }
.tab-buttons li span.nmb { font-size:16px; font-weight:400; }

/* タブ切り替え部分：内容 */
.tab-panel { display:none; margin:0 20px; }
.tab-panel.active { display:block; }
.tab-panel ul li { border-bottom:1px solid var(--gr-4); padding:10px 20px 20px 20px; }
.tab-panel ul li time { font-size:19px; font-weight:500; line-height:38px; letter-spacing:0.95px; }
.tab-panel ul li p { font-size:16px; line-height:30px; letter-spacing:0.8px; }

@container( min-width:1000px ) {

/* ベース */
.schedule { padding:120px 0 150px 0; }

/* 背景画像 */
.sc-back::before { top:150px; right:0; height:461px; width:454px; }
.sc-back::after { aspect-ratio:247/311; left:100px; top:490px; height:247px; width:311px; }

/* 見出し */
.schedule hgroup { margin-bottom:50px; }
.schedule hgroup h2 { font-size:65px; }
.schedule hgroup h2::before { top:-200px; left:-20vw; height:230px; width:116px; }
.schedule hgroup h3 { font-size:35px; transform:translateY(5px); }

/* タブ切り替え部分 */
.tab-contents { margin:auto; max-width:900px; width:100%; }

/* タブ切り替え部分：タブリスト */
.tab-buttons { gap:175px; justify-content:space-around; margin:auto; margin-bottom:75px; max-width:900px; width:100%; }
.tab-buttons li.flex.flex-column { align-items:flex-end; flex-direction:row; gap:10px; justify-content:center; height:auto; width:auto; }
.tab-buttons li { border-bottom:8px solid transparent; }
.tab-buttons li.active { background-color:transparent; border-bottom:8px solid var(--gr-3); }
.tab-buttons li span.day { font-size:35px; }
.tab-buttons li span.nmb { font-size:18px; }

/* タブ切り替え部分：内容 */
.tab-panel ul li { align-items:flex-start; display:flex; justify-content:flex-start; gap:30px; }
.tab-panel ul li time, .tab-panel ul li p { font-size:24px; line-height:38px; letter-spacing:1.2px; }
.tab-panel ul li p { max-width:80%; width:100%; }

}

/* -------------------------------------------------- */
/* イベント */
/* -------------------------------------------------- */

/* ベース */
.event { background-color:var(--gr); padding:40px 0 20px 0; }

/* 見出し */
.event h2 { font-size:35px; font-weight:600; transform:translateY(-55px); }
.event h3.event-title { margin-bottom:18px; }
.event h3.event-title img { height:auto; width:250px; }
.event .box .box-1-midashi img { height:auto; max-width:300px; width:100%; }

/* マップ */
div.map { aspect-ratio:16/9; margin-bottom:31px; height:auto; max-width:100%; width:100%; }
div.map iframe { height:100%; width:100%; }

/* 写真 */
.event-ph { aspect-ratio:390/478; background-image:url('../img/top/event/soracity-pc.jpg'); background-position:center left; background-size:cover; display:block; margin-bottom:31px; height:auto; width:100%; }
.event-ph .pc-only { display:none; }

/* テキスト */
p.history { padding:0 20px; margin-bottom:30px; }
p.history img { height:auto; max-width:100%; width:100%; }
div.out-text { margin:0 20px; margin-bottom:30px; }

/* 展開メニュー：ボタン */
.acc-trigger { cursor:pointer; display:block; margin-bottom:40px; width:100%; }
.acc-trigger img { margin:auto; max-width:260px; width:100%; }

/* 展開メニュー：中身 */
.acc-content { transition:.3s; overflow:hidden; visibility:hidden; max-height:0; height:0; }
.accordion.is-open .acc-content { transition:.3s; visibility:visible; max-height:100%; height:100%; }
.pc-bg { display:flex; flex-direction:column; gap:30px; }
.acc-text-1 { padding:0 20px; margin-bottom:40px; }
.acc-text-1 p { font-size:18px; text-align:left; line-height:38px; letter-spacing:0.54px; }
.tourism-block { background-color:rgba(255,255,255,0.7); gap:40px; padding:24px 16px; }
.tourism-block .block-box.pc-only { display:none; }
.tourism-block .block-box p { font-size:16px; text-align:left; line-height:28px; letter-spacing:0.8px; }
.tourism-ph img { height:auto; max-width:100%; }
.tourism-block .block-box .box { display:flex; flex-direction:column; gap:30px; margin-bottom:30px; }

@container( min-width:1000px ) {

/* ベース */
.event { padding:100px 0 36px 0; position:relative; z-index:0; }

/* 見出し */
.event h2 { font-size:65px; transform:translateY(-120px); }
.event h3.event-title img { height:auto; width:323px; }
.block-box.pc-only h3.box-1-midashi img { width:611px; }

/* マップ */
div.map { aspect-ratio:3/2; background-color:rgba(228, 241, 250, 0.80); border-radius:10px; box-sizing:border-box; padding:20px; position:absolute; top:100px; left:50%; transform:translateX(-50px); margin-bottom:0; max-width:500px; width:40vw; z-index:1; }
div.map iframe { height:100%; width:100%; }

/* 写真 */
.event-ph { aspect-ratio:12/7; background-position:center; position:relative; margin-bottom:75px; z-index:0; }
.event-ph .pc-only { display:flex; gap:20px; }
.event-ph-children { background-color:rgba(228,241,250,0.8); border-radius:10px; transform:translateY(-50%); padding:20px; position:absolute; top:50%; right:100px; max-width:425px; }
.event-ph-children img { height:auto; max-width:100%; width:100%; }

/* テキスト */
div.out-text { margin:auto; margin-bottom:30px; max-width:1000px; width:100%; }
p.history { margin:auto; margin-bottom:26px; max-width:1000px; }
p.history img { max-width:630px; width:100%; }

/* 展開メニュー：ボタン */
.acc-trigger { text-align:right; margin:auto; margin-bottom:36px; max-width:1000px; width:100%; }
.acc-trigger img { margin-right:0; }

/* 展開メニュー：中身 */
.acc-text-1 { padding:0; margin:auto; margin-bottom:50px; max-width:1000px; width:100%; }
.tourism-block { background-color:transparent; }
.pc-bg { background-color:rgba(255,255,255,0.7); gap:50px; padding:100px 60px; margin:auto; max-width:1200px; }
.tourism-block .block-box { align-items:center; display:flex; justify-content:flex-start; }
.tourism-block .block-box.sp-only { display:none; }
.tourism-block .block-box.pc-only { align-items:flex-start; display:flex; flex-direction:column; gap:30px; }
.tourism-block .block-box:nth-child(2) { flex-direction:row-reverse; }
.tourism-block .block-box .box { width:45%; }
.tourism-block .block-box.pc-only .box { align-items:center; display:flex; flex-direction:row; width:100%; }
.tourism-block .block-box.pc-only .tourism-ph { width:45%; }
.tourism-block .block-box p { padding-left:30px; width:65%; }
.tourism-block .block-box:nth-child(2) p { padding-left:0; padding-right:30px; }
}

/* -------------------------------------------------- */
/* 宿泊施設 */
/* -------------------------------------------------- */

/* ベース */
.accomodation { background-color:var(--bl-3); padding:35px 0 50px 0; }

/* 見出し */
.accomodation h2 { font-size:35px; font-weight:600; margin-bottom:10px; }
.accom h3 img { height:auto; max-width:250px; width:100%; }

/* コンテンツ配置 */
.accom { flex-direction:column; gap:12px; margin:0 20px 24px 20px; }
.accom .accom-box { gap:10px; }
.accom address { font-size:16px; line-height:32px; letter-spacing:0.8px; }
.accom p.link-url { font-size:18px; font-weight:400; }
.accom .view-button { justify-content:center; }
.accom .view-button button, .accom .view-button a { align-items:center; border:1px solid var(--bk); border-radius:100px; justify-content:center; width:190px; height:40px; }

/* リスト */
.accomo-list-1 { margin:0 20px; }
.accomo-list-1 { flex-direction:column; gap:24px; }
.accomo-list-1 li img, .accomo-list-1 li iframe { aspect-ratio:350/205; height:auto; max-width:100%; width:100%; }

/* モーダルウインドウ */
.modal-window { align-items:center; background-color:rgba(0,0,0,0.7); display:none; justify-content:center; top:0; left:0; position:fixed; height:100vh; width:100%; z-index:1000; }
.modal-window.is-active { display:flex; }
.modal-content { background-color:var(--wh); border-radius:30px; overflow-y:scroll; padding:24px 16px; position:relative; max-height:80vh; width:90%; }
button.modal-close.js-close-modal { font-weight:600; position:absolute; top:10px; right:20px; }
button.modal-close.js-close-modal p { font-size:32px; }
.modal-head { flex-direction:column; }
.modal-head h2 img { margin:auto; height:auto; max-width:100%; width:100%; }
.modal-content ul.accomo-list-1 { margin:auto; }
.btn-flex { flex-direction:column; gap:20px; margin-top:20px; }
.flex-reversible { gap:20px; margin-top:20px; }

@container(min-width:1000px){

/* ベース */
.accomodation { padding:60px 0 85px 0; }

/* 見出し */
.accomodation h2 { font-size:65px; margin-bottom:50px; }

/* コンテンツ配置 */
.accom { align-items:center; flex-direction:row; gap:100px; justify-content:center; }
.accom address { display:none; }

/* リスト */
.accomo-list-1 { flex-direction:row; margin:0 auto; max-width:1000px; width:100%; }
.accomo-list-1 li { flex:1; }

/* モーダルウインドウ */
.modal-content { padding:40px; height:auto; width:auto; }
.modal-head { align-items:center; flex-direction:row; justify-content:center; }
.modal-head h2 { text-align:center; margin-bottom:0; width:50%; }
.modal-head h2 img { max-width:285px; }
.modal-content address { display:block; }
.modal-head .modal-head-parts { width:50%; }
.btn-flex { flex-direction:row; gap:20px; justify-content:center; }
.flex.flex-column.flex-reversible { flex-direction:column; }

}

@container(min-width:1000px){

.modal-content .accomo-list-1 {
    display: grid;
    grid-template-columns: 350px 1fr;   /* 左：小画像縦2個分、右：大きいiframe */
    grid-template-rows: auto auto;      /* 小画像1, 小画像2 */
    gap: 24px;
    margin: 0 auto;
    max-width: 1000px;
    width: 100%;
    align-items: stretch;
  }

  /* 左カラム */
.modal-content .accomo-list-1 li:nth-child(1) {
    grid-column: 1;
    grid-row: 1;       /* 上の小さい画像 */
  }
.modal-content .accomo-list-1 li:nth-child(2) {
    grid-column: 1;
    grid-row: 2;       /* 下の小さい画像 */
  }

  /* 右カラム。縦に2マス分を占有 */
.modal-content .accomo-list-1 li:nth-child(3) {
    grid-column: 2;
    grid-row: 1 / 3;   /* 上下2行にまたがる */
    height: 100%;
  }

  /* 中の iframe を縦方向いっぱいに伸ばしたい場合 */
.modal-content .accomo-list-1 li:nth-child(3) iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
  }
}

/* -------------------------------------------------- */
/* スポンサー */
/* -------------------------------------------------- */

/* ベース */
.sponsors { background-color:var(--bl-2); padding:24px 0; }

/* 見出し */
.sponsors h2 { font-size:30px; font-weight:600; transform:translateY(12.5px); }

/* リスト */
.sponsors div.list-area { background-color:var(--wh); border-radius:24px; display:flex; flex-direction:column; gap:20px; padding:40px 20px 24px 20px; margin:0 20px; }
.sponsors ul { align-items:center; flex-direction:column; gap:32px; justify-content:center; }
.sponsors ul li { height:auto; max-width:100%; width:100%; }
.sponsors ul li.flex { align-items:center; gap:10px; justify-content:center; }
.sponsors ul li img { pointer-events:none; max-width:100%; }
.sponsors ul li img.big-sizing { transform:scale(0.8); }
.sponsors ul li img.big-sizing.chosei-1 { transform:scale(1.4); }

/* アンカーを基準に擬似要素を配置 */
/* .sponsors ul li.flex a {
	position: relative;
	display: inline-flex;
	justify-content: center;
	text-decoration: none;
	padding-bottom: 6px;
} */

/* 初期状態：下線は幅33% */
/*  .sponsors ul li.flex a::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 33%;
	height: 2px;
	background-color: var(--bl);
	transition: width 0.3s ease;
} */

/* hover時：下線をli全幅に */
/* .sponsors ul li.flex:hover a::after {
	width: 100%;
} */

/* 既存のhover効果と併用 */
/* .sponsors ul li.flex a:hover {
	opacity: 0.7;
	transition: opacity 0.3s;
} */


@container( min-width:1000px ) {

/* ベース */
.sponsors { padding:70px 0 160px 0; }

/* 見出し */
.sponsors h2 { font-size:65px; transform:translateY(12.5px); z-index:1; }

/* リスト */
.sponsors div.list-area { border-radius:100px; box-shadow:0 10px 10px rgba(0,0,0,0.15); padding:100px 25px; margin:0 auto; max-width:1200px; width:calc( 100% - 100px ); }
.sponsors div.list-area p.right { font-size:18px; margin-bottom:20px; }
.sponsors div.list-area p.center { font-size:20px; font-weight:500; margin-top:50px; }
.sponsors ul { flex-direction:row; flex-wrap:wrap; justify-content:flex-start; flex:1; gap:30px 10px; }
.sponsors ul li { box-sizing:border-box; width:calc( 33% - 20px ); }
.sponsors ul li.flex { gap:50px; }
.sponsors ul li.flex a:hover { opacity:0.7; transition:.3s; }
.sponsors ul li img { max-height:60px; }
.sponsors ul li img.big-sizing, .sponsors ul li img.big-sizing.chosei-1 { transform:scale(1.2); }
.sponsors ul li.flex.cube-logo { gap:10px; }
.sponsors ul li.flex.cube-logo img { max-height:100%; height:120px; width:auto; }

}
