@charset "utf-8";
/* =============================================================
    common 共通
============================================*/
:root {
	--color_BLK : #231815;
	--color_RED : #ea5849;
	--color_BLU : #053c82;
	/* --color_YLW : #fbef04; */
	/* --color_PNK : #d31477; */
	/* --color_GRN : #44bc08; */
	--fontS : clamp(14px,2.2vw,22px);
	--fontM : clamp(16px,2.8vw,28px);
	--fontL : clamp(20px,4vw,38px);
	--gap_160px : clamp(54px, 10vw, 160px);
	--gap_96px : clamp(32px, 6vw, 96px);
	--gap_80px : clamp(27px, 5vw, 80px);
	--gap_64px : clamp(21px, 4vw, 64px);
	--gap_48px : clamp(16px, 3vw, 48px);
	--gap_32px : clamp(11px, 2.5vw, 32px);
	--gap_24px : clamp(8px, 2vw, 24px);
	--gap_16px : clamp(5px, 1.5vw, 16px);
	--gap_8px : clamp(3px, 1vw, 8px);
}

body {
	width: 100%;
}
body,figure,h1,h2,h3,h4,h5,h6,li,ol,p,ul,dl,dt,dd {
	margin: 0;
	padding: 0;
}
h1,h2,h3,h4,h5,h6,p {
	font-weight: normal;
}
li,ol,ul {
	list-style-type: none;
}

#page {
	font-size: clamp(16px, 2.2vw, 20px);
	margin: 0 auto;
    max-width: 1920px;
	color: var(--color_BLK);
	font-family: "Noto Sans CJK JP", Lato, "Noto Sans JP", "游ゴシック Medium", 游ゴシック体, "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.4;
	font-feature-settings: "palt" 1;
	-webkit-text-size-adjust: 100%;
	position: relative;	/* 背景fixed　safari対応 ←　これ使う場合は必要*/
}
#page * {
	box-sizing: border-box;
}
#page img {
	width: 100%;
	border: 0;
	vertical-align: top;
}
#page a {
	color: initial;
	/* transition: all 0.3s; */
	text-decoration: none;
}
/* #page a:hover {
	opacity: 0.7;
} */
#page a[tabindex*="-1"] {
	pointer-events: none;
	position: relative;
}
#page a[tabindex*="-1"]:hover {
	opacity: 1;
}
#page em {
	font-style: normal;
	font-weight: bold;
}
@media screen and (min-width: 768px) {
	a[href*="tel:"] {
	  pointer-events: none;
	  cursor: default;
	  text-decoration: none;
	}
}
@media screen and (max-width: 767px) {
	#page {
		font-size: clamp(14px, 3.2vw, 16px);
	}	
}

.serif {
	font-family: 'Shippori Mincho', serif;
	font-weight: 600;
}
.arial {
	font-family: Arial;
}
.font_yusei-magic {
	font-family: "Yusei Magic", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.font_awe::before,
.font_awe::after {
	font-family: "Font Awesome 6 Free","Font Awesome 6 Brands";
    font-weight: 900;
}
.red {
	color: var(--color_RED);
}
.blue {
	color: var(--color_BLU);
}

.flex {
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.inner_wrap {
	padding: 0 var(--gap_48px);
	margin: 0 auto;
	max-width: 1300px;
}
.pd_tb {
	padding-top: var(--gap_80px);
	padding-bottom: var(--gap_80px);
}
.pd_t {
	padding-top: var(--gap_80px);
}
.pd_b {
	padding-bottom: var(--gap_80px);
}
.disp_bk {
	display: block;
}

.block_title {
	font-size: clamp(18px,3.4vw,28px);
	font-weight: bold;
	color: #fff;
	text-align: center;
	padding: 0 0 var(--gap_32px);
}
.block_read p {
	margin: var(--gap_16px) auto;
}
.block_read p:not(.demo_btn) {
	padding-left: 1em;
	text-indent: -1em;
}
.ib {
	font-size: inherit !important;
	display: inline-block;
}

.btn_wrap {
	text-align: center;
}
.btn {
	font-size: 1.4em;
	font-weight: bold;
	padding: 0.8em var(--gap_24px);
	margin: 0 auto;
	line-height: 1.2;
	border-radius: clamp(4px, 1vw, 10px);
	transition: all 0.3s;
	display: inline-block;
}
#btn_pagetop {
    position: fixed;
	bottom: var(--gap_32px);
	/* bottom: clamp(4px, 3.4vw, 10px); */
	/* right: clamp(4px, 3.4vw, 10px); */
	right: 0;
    z-index: 500;
}
#btn_pagetop a {
	font-family: "Noto Sans CJK JP", Lato, "Noto Sans JP", "游ゴシック Medium", 游ゴシック体, "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: clamp(14px,2.2vw,16px);
	font-weight: bold;
	color: var(--color_BLK);
	text-align: center;
	text-decoration: none;
	line-height: 1;
	writing-mode: vertical-rl;
	padding: var(--gap_16px) 16px;
	background-color: #fff;
	box-shadow: 0 0 var(--gap_8px) #5783b7;
	display: block;
}
#btn_pagetop a i {
	line-height: 1;
	margin-bottom: var(--gap_8px);
}
/* #btn_pagetop a img {
  width: clamp(70px, 9vw, 100px);
} */

.mob {
	display: none;
}
@media screen and (max-width: 767px) {
	.mob {
		display: inline-block;
	}
}

/* =============================================================
    ページ内　共通
============================================*/
/* .page_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}
.page_bg:before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
	background: url(/expo/lib/2026/images/bg.jpg) center top -100px repeat-y;
} */
#page {
	background-color: #ddd;
}
#page .scale a,
#page .scale a img {
	transition: all 0.2s;
}
#page .scale a:hover {
	transform: scale(1.05);
	transition: all 0.2s;
}

.nav_wrap a[tabindex*="-1"] {
	color: rgb(37 37 37 / 60%) !important;
}
.nav_wrap a[tabindex*="-1"]::after {
	font-size: 0.6em;
	line-height: 1.1;
    content: "COMING SOON";
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-10deg);
    opacity: 1;
    color: #bdbdbd;
    /* text-shadow: 0 0 0.2em #fff, 0 0 0.2em #fff, 0 0 0.2em #fff, 0 0 0.3em #fff, 0 0 0.3em #fff; */
	z-index: -1;
}

.nav_item,
.intro_head,
.overlay_thumb .copy,
.btn_site,
.ev_about_head {
	font-family: 'Dela Gothic One', cursive;
    font-weight: 100;
	letter-spacing: 1px;
}
.lh {
	line-height: 0.5 !important;
}
.cmr {
	color: #0080cc;
}
.ck {
	color: #ea67a2;
}
.odf {
	color: #47824f;
}
.flex_item.row3 {
	width: calc(100% / 3);
}
.flex.col2 .flex_item {
	width: calc(96% / 2);
}
@media screen and (max-width: 767px) {
	.flex_item.row3 {
		width: calc(100% / 2);
	}
	.flex.col2 .flex_item {
		width: clamp(180px,100%,450px);
		margin: 0 auto;
	}
}

.bg_wrap {
	background: url("/expo/lib/2026/images/bg_ptn_page.jpg") center top repeat-y;
}
.cont_wrap_inner {
	padding: 0 var(--gap_48px);
}
.cont_wrap_inner > .box_wrap {
	max-width: 1200px;
    margin: 0 auto;
	padding-bottom: 180px;
	background-color: rgba(255,255,255,0.7);
}
.sec_wrap {
	position: relative;
	z-index: 300;
}
.bg_btm {
	width: 100%;
    height: 545px;
	margin-top: -260px;
	overflow: hidden;
    position: relative;
}
.bg_btm img {
	width: 1920px !important;
    position: absolute;
    right: 0;
    display: block;
}
@media screen and (max-width: 1279px) {
	.bg_wrap {
		background-size: 1280px;
	}
}
@media screen and (max-width: 767px) {
	.bg_wrap {
		background-size: 768px;
	}
	.cont_wrap_inner > .box_wrap {
		padding-bottom: 24vw;
	}
	.bg_btm {
		height: 37vw;
		margin-top: -30vw;
	}
	.bg_btm img {
		width: 130vw !important;
	}
}

/* =============================================================
      main コンテンツ
============================================*/
.logo_wrap {
	font-size: 0em;
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--gap_64px) 0 0;
}
.logo {
	background: url(/expo/lib/2026/images/logo.png) center center/contain no-repeat;
	padding-top: calc(316 / 1605 * 100%);
}

.ev_date {
	text-align: center;
	padding-bottom: var(--gap_64px);
}
.ev_date h2 {
	font-size: clamp(16px,4.8vw,48px);
	font-family: 'Dela Gothic One', cursive;
    font-weight: 100;
    letter-spacing: 1px;
	line-height: 1;
	margin-top: var(--gap_16px);
}
.ev_date h2 * {
	line-height: 1;
	display: inline-block;
}
.ev_date h2 small {
	font-size: 0.55em;
}
.ev_date h2 em {
	font-size: 1.4em;
}
.youbi {
	font-family: "Noto Sans CJK JP", Lato, "Noto Sans JP", "游ゴシック Medium", 游ゴシック体, "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight: bold;
	color: #fff;
	padding: var(--gap_8px);
	display: inline-block;
	transform: translateY(calc(var(--gap_8px) / 2 * -1));
	position: relative;
	z-index: 10;
}
.youbi::before {
	content: "";
	width: 1.5em;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	background-color: var(--color_BLK);
	position: absolute;
	top: 55%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: -1;
}
.ev_date > small {
	font-size: clamp(10px, 1.8vw, 16px);
	line-height: 1.1;
	margin-top: var(--gap_16px);
	display: inline-block;
}
.ev_date > small b {
	font-size: 1.1em;
	line-height: 1;
}

/* =============================================================
      cm動画
============================================*/
.cm_wrap.flex {
	justify-content: center;
}
.cm_item_wrap {
	/* width: calc(96% / 2); */
	width: 100%;
	max-width: 800px;
	padding-bottom: var(--gap_48px);
}
@media screen and (max-width: 767px) {
	.cm_wrap {
		justify-content: center;
	}
	.cm_item_wrap {
		width: min(100%,480px);
	}
}

/* =============================================================
      ナビ
============================================*/
.nav_wrap {
	border-top: solid calc(var(--gap_8px) / 2);
	border-bottom: solid 1px;
}
.nav_item {
	text-align: center;
	width: calc(100% / 4);
	border-right: solid 1px;
	position: relative;
}
.nav_item::after {
	content: "";
	position: absolute;
	right: 4px;
	bottom: 4px;
	border: solid var(--gap_8px);
	border-top-color: transparent;
	border-left-color: transparent;
}
.nav_item:last-of-type {
	border-right: 0;
}
.nav_item.single {
	width: 100%;
	border-bottom: solid 1px;
}
.nav_item a {
	font-size: var(--fontL);
	color: var(--color_BLK);
	line-height: 0.7;
	padding: var(--gap_32px) var(--gap_16px);
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.nav_item a:hover {
	color: #fff !important;
	background-color: var(--color_BLK);
}
.nav_item a * {
	display: inline-block;
	line-height: 1;
}
.nav_item small {
	font-size: 0.6em;
}
.nav_item.btn_map small.bd {
	border: solid 1px;
	padding: var(--gap_8px);
	margin: var(--gap_8px);
}

.p_top .navi_top,
.p_about .navi_about,
.p_stage .navi_stage {
	pointer-events: none;
	background-color: #fff;
	filter: drop-shadow(0px 0px var(--gap_16px) white);
	position: relative;
	z-index: 50;
}
.p_top .navi_top::after,
.p_about .navi_about::after {
	content: none;
}
@media screen and (max-width: 767px) {
	.nav_item {
		width: calc(100% / 2);
	}
	.nav_item:nth-child(2n) {
		border-right: 0;
	}
	.nav_item:nth-child(n + 3) {
		border-top: solid 1px;
	}
}

/* =============================================================
      3大イベント紹介
============================================*/
#sec_intro {
	text-align: center;
}
.intro_head {
	font-size: clamp(20px,4.6vw,46px);
	line-height: 1;
	padding: var(--gap_80px) 0 var(--gap_64px);
}
.intro_head em {
	font-size: 1.4em;
	font-weight: normal !important;
}
.intro_head mark {
	line-height: 1.1;
	display: inline-block;
	background: linear-gradient(0deg, #fdd000 30%, transparent 30%);
}
.intro_head small {
	font-size: 0.8em;
}
.intro_head.sub {
	font-size: clamp(18px,3.6vw,36px);
}

.flex.intro {
	justify-content: center;
	row-gap: var(--gap_64px);
}
.flex.intro .flex_item {
	border-right: solid 1px #fff;
	border-top: solid var(--gap_8px);
	overflow: hidden;
}
.flex.intro .flex_item:last-of-type {
	border-right: solid 1px transparent;
}
.flex.intro .flex_item.cmr {
	border-top-color: #0080cc;
}
.flex.intro .flex_item.ck {
	border-top-color: #ea67a2;
}
.flex.intro .flex_item.odf {
	border-top-color: #47824f;
}
.ev_logo {
	padding: var(--gap_24px) var(--gap_32px);
	background-color: #fff;
	display: block;
}
.flex.intro .ev_logo {
	display: -webkit-flex;
    display: flex;
    align-items: center;
	aspect-ratio: 1 / 0.65;
}

.ev_intro_mov_wrap {
	overflow: hidden;
}
.ev_intro_mov_wrap a:hover img {
	transform: scale(1.05);
}

.overlay_thumb,
.overlay_thumb img {
	position: relative;
	display: block;
}
.overlay_thumb::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 10;
	background-color: rgba(0,0,0,0.6);
}
.overlay_thumb .copy {
	font-size: clamp(16px,1.8vw,24px);
	color: #fff;
	position: absolute;
	width: 100%;
	line-height: 1;
	padding: 0 var(--gap_8px);
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 50;
}
.overlay_thumb .copy * {
	line-height: 1;
}
.overlay_thumb .copy i {
	font-size: clamp(28px,4vw,38px);
	margin-bottom: var(--gap_8px);
	display: block;
}
.ev_intro_mov_wrap a[tabindex*="-1"] .copy i {
	opacity: 0.6;
}
.overlay_thumb > .copy small {
	font-size: clamp(8px,1.1vw,12px);
	padding-top: 4px;
	display: block;
}
.btn_site {
	position: relative;
	z-index: 100;
}
.btn_site a {
	font-size: clamp(18px,2.2vw,28px);
	color: #fff !important;
	line-height: 1;
	padding: var(--gap_24px) var(--gap_16px);
	display: -webkit-flex;
	display: flex;
	align-items: center;
	justify-content: center;
}
.btn_site i {
	font-size: 0.6em;
	margin-right: var(--gap_8px);
}
.cmr .btn_site {
	background-color: #0080cc;
}
.ck .btn_site {
	background-color: #ea67a2;
}
.odf .btn_site {
	background-color: #47824f;
}
@media screen and (max-width: 767px) {
	.flex.intro .flex_item:nth-child(n + 2) {
		border-right: solid 1px transparent;
	}
}
@media screen and (max-width: 479px) {
	.flex.intro .flex_item {
		width: min(100%,300px);
	}
	.flex.intro .ev_logo {
		aspect-ratio: unset;
		margin-inline: auto;
        padding: var(--gap_64px);
	}
}

.ev_about_head {
	font-size: var(--fontL);
	line-height: 1;
	margin: var(--gap_24px) auto var(--gap_16px);
}
.ev_about_head * {
	line-height: 1;
}
.ev_about_head small {
	font-size: 0.5em;
}
.ev_about_read {
	font-size: 0.9em;
	line-height: 1.3;
}
.flex_item_inner {
	display: block;
}
.flex.intro.ev_about .flex_item {
	padding: var(--gap_32px) var(--gap_24px);
	background-color: #fff;
}

.flex.intro.ev_about a[tabindex*="-1"] {
	position: relative;
	height: 100%;
}
.flex.intro.ev_about a[tabindex*="-1"]::before {
	content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 10;
    background-color: rgba(0, 0, 0, 0.6);
}
.flex.intro.ev_about a[tabindex*="-1"]::after {
    font-size: 1.2em;
    line-height: 1.1;
    content: "COMING SOON";
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-25deg);
    opacity: 1;
    color: #fff;
    /* text-shadow: 0 0 0.2em #333, 0 0 0.2em #333, 0 0 0.2em #333, 0 0 0.3em #333, 0 0 0.3em #333; */
    z-index: 50;
}
@media screen and (min-width: 480px) {
	.flex.intro.ev_about .flex_item:not(:last-of-type) {
		border-color: var(--color_BLK);
	}
}
@media screen and (max-width: 767px) {
	.flex.intro.ev_about .flex_item:nth-child(n + 2) {
		border-right: solid 1px transparent;
	}
}


/* =============================================================
    【movie】ブロック　※Brightecoveの動画表示
============================================*/
.mfp-content .movie_wrap {
	width: 100%;
    max-width: 800px;
    margin: 0 auto;
    background-color: #fff;
    padding: var(--gap_32px);
	box-sizing: border-box;
}
#movie {
    position: relative;
    width: 100%;
    padding-top: calc(9 / 16 * 100%);
    margin: 0 auto;
    overflow: hidden;
}
.tvo-video {
	position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
}

/* =============================================================
    【overlay】ブロック　※ポップアップ表示
============================================*/
.overlay_wrap {
	margin: 0 auto;
}
.overlay_wrap a {
	flex: 0 0 32.333%;
	margin-bottom: 8px;
}
.overlay_item {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto;
}
.overlay_item img {
	width: 100%;
}
@media screen and (max-width: 767px) {
	.overlay_wrap a {
		flex: 0 0 48%;
	}
	.overlay_wrap a:first-child {
		flex: 0 0 98%;
	}
}


/* =============================================================
    下層ページ用
============================================*/
.sec_head,
.sec_title,
.flex.intro.ev_about a[tabindex*="-1"]::after,
.stage_day {
	font-family: 'Dela Gothic One', cursive;
    font-weight: 100;
	letter-spacing: 1px;
}

.sec_title_wrap {
	padding: var(--gap_64px) 0 var(--gap_48px);
}
.sec_title {
	color: #fff;
	line-height: 1.1;
	padding: var(--gap_16px) 4.5em var(--gap_16px) var(--gap_32px);
	background-color: var(--color_BLK);
	position: relative;
}
.sec_title::after {
	content: attr(data-text) "";
	color: #717171;
    font-size: clamp(12px, 1.8vw, 14px);
    display: block;
    position: absolute;
    right: var(--gap_32px);
    top: 50%;
    transform: translateY(-50%);
}

/* =============================================================
    aboutページ
============================================*/
.sec_head {
	font-size: var(--fontL);
	line-height: 1.2;
	text-align: center;
}
.sec_read.about p {
	text-align: center;
	line-height: 1.6;
	padding-top: var(--gap_24px);
}
.sec_read.about em {
	font-size: 1.1em;
}

.diagram_wrap {
	margin-top: var(--gap_96px);
	background-color: #fff;
}
.logo_text {
	width: clamp(200px,28vw,400px);
	margin: 0 auto;
}
.logo_text img {
    padding: var(--gap_16px);
	margin-top: calc(var(--gap_32px) * -1);
	border: solid 2px;
	background-color: #fff;
	box-shadow: 0 0 var(--gap_16px) #a4c4ed;
}
.flex.diagram .flex_item {
	overflow: hidden;
}
.flex.diagram a.ev_logo {
	display: -webkit-flex;
	display: flex;
    align-items: center;
}
.flex.diagram .cmr a.ev_logo,
.flex.diagram .odf a.ev_logo {
	aspect-ratio: 1 / 0.5;
}
@media screen and (max-width: 767px) {
	.sec_read.about p {
		line-height: 1.3;
	}
	.flex.diagram {
		justify-content: center;
	}
	.flex.diagram .cmr a.ev_logo,
	.flex.diagram .ck a.ev_logo {
		aspect-ratio: 1 / 0.65;
	}
}
@media screen and (max-width: 479px) {
	.diagram_wrap {
		padding-bottom: var(--gap_48px);
        margin-inline: auto;
		width: min(100%, 300px);
	}
	.flex.diagram .flex_item {
		width: 100%;
		padding: 0 var(--gap_32px);
	}
	.flex.diagram .flex_item a.ev_logo {
		padding: var(--gap_64px);
		aspect-ratio: unset !important;
	}
}

#sec_overview {
	padding: var(--gap_64px) 0 0;
}
#sec_overview dl {
	max-width: 1100px;
    margin: 0 auto var(--gap_16px);
	padding-bottom: var(--gap_8px);
    border-bottom: solid 1px #666;
    clear: both;
    overflow: hidden;
}
#sec_overview dl:last-of-type {
	margin-bottom: 0;
}
#sec_overview dt {
    font-weight: bold;
    width: 10em;
    margin-bottom: var(--gap_8px);
    float: left;
}
#sec_overview dd {
    width: calc(100% - 10em);
    margin-bottom: var(--gap_8px);
    float: right;
}
#sec_overview dd ul {
	padding: var(--gap_16px) var(--gap_24px);
}
#sec_overview dd ul:last-child {
	padding-bottom: 0;
}
/* #sec_overview dd ul.ev_name_list {
	padding-left: var(--gap_48px);
}
#sec_overview dd ul.ev_name_list li {
	list-style: disc;
} */

#sec_overview dd ul.ev_name_list li {
	padding-left: 1em;
    text-indent: -1em;
}
#sec_overview dd ul li.price {
	padding: var(--gap_8px) var(--gap_16px);
	background-color: #fff;
	border-radius: var(--gap_8px);
}
#sec_overview dd ul:not(.ev_name_list) li:not(:last-of-type) {
	margin-bottom: var(--gap_8px);
}
#sec_overview dd strong {
	padding-left: 1em;
    text-indent: -1em;
	display: block;
}
#sec_overview dd small {
	display: inline-block;
}
#sec_overview dd .db {
	font-size: 0.8em;
	display: block;
}
#sec_overview dd .t_link {
	font-size: 0.8em;
	text-decoration: underline;
	display: inline-block;
}
@media screen and (max-width: 767px) {
	#sec_overview dl {
		border: none;
	}
	#sec_overview dt,
	#sec_overview dd {
		width: 100%;
		float: none;
	}
	#sec_overview dt {
		padding: var(--gap_16px);
        margin-bottom: var(--gap_16px);
		border-bottom: solid 1px #ccc;
		border-top: solid 1px #ccc;
	}
}

/* =============================================================
    STAGEページ
============================================*/
.stage_list .flex_item {
	background-color: #fff;
	border: solid 1px;
}

.stage_day_wrap {
	font-size: clamp(20px, 2.8vw, 38px);
	position: relative;
}
.stage_day {
	line-height: 1;
	padding: var(--gap_16px) var(--gap_24px);
	border-top: solid 1px;
}
.stage_day small {
	font-size: 0.5em;
}
.stage_mc {
	font-size: 0.5em;
	padding: 0  var(--gap_24px) var(--gap_8px);
}
.opening {
	font-size: 0.5em;
	color: #fff;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
	background-color: var(--color_RED);
	position: absolute;
	top: calc(var(--gap_32px) * -1);
    right: var(--gap_24px);
    width: clamp(80px,16vw,130px);
    height: clamp(80px,16vw,130px);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
	transform: rotate(-10deg);
}

.stage_item_wrap {
	border-top: solid 1px;
}
.time_code {
	width: 100%;
}
.time_code em {
	font-size: clamp(16px, 1.8vw, 22px);
	color: #fff;
	padding: var(--gap_8px) var(--gap_16px);
	line-height: 1;
	background-color: var(--color_BLK);
	display: inline-block;
}
.stage_info {
	font-size: clamp(20px, 2.2vw, 32px);
	padding: var(--gap_16px) var(--gap_24px) var(--gap_24px);
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.stage_name,
.stage_thumb {
	width: 50%;
}
.stage_name {
	font-weight: bold;
	line-height: 1.1;
}
.stage_name.m {
	font-size: 0.9em;
	line-height: 1.2;
}
.stage_name.s {
	font-size: 0.75em;
	line-height: 1.3;
}
.stage_name small {
	font-size: 0.7em;
	padding: 4px 0;
	line-height: 1.3;
	display: block;
}
.stage_name small.m {
	font-size: 0.5em;
}
.stage_name small.s {
	font-size: 0.3em;
}
.stage_thumb {
	padding-left: var(--gap_24px);
}
#sec_stage .note {
	font-size: 0.8em;
	text-align: center;
	padding-top: var(--gap_48px);
}
@media screen and (max-width: 999px) {
    .stage_list.col2 .flex_item {
        width: clamp(180px, 100%, 550px);
        margin: 0 auto;
    }
	.stage_list.col2 .flex_item:not(:first-of-type) {
		margin-top: var(--gap_48px);
	}
	.stage_mc {
		padding-right: var(--gap_96px);
	}
	.stage_day_wrap {
		font-size: clamp(22px, 4.6vw, 38px);
	}
	.stage_info {
		font-size: clamp(20px, 3.8vw, 32px);
	}
}
@media screen and (max-width: 767px) {
    .stage_name {
		width: 60%;
	}
    .stage_thumb {
		width: 40%;
	}
}

/* =============================================================
    【photoswipe】ブロック　※ポップアップ表示
============================================*/
.swipe_wrap {
	margin: 0 auto;
	column-gap: 1%;
}
.swipe_wrap a {
	width: calc(98% / 3);
	margin-bottom: 1%;
}
@media screen and (max-width: 767px) {
	.swipe_wrap a {
		width: calc(99% / 2);
	}
	.swipe_wrap a:first-of-type {
		width: 100%;
	}
}