@charset "utf-8";
/* =============================================================
    common 共通
============================================*/
:root {
	--color_BLK : #252525;
	--color_RED : #e01006;
	--color_BLU : #0856f5;
	--color_YLW : #fce429;
	--color_GRN : #44bc08;
	--gap_96px : clamp(32px, 12vw, 96px);
	--gap_80px : clamp(27px, 10vw, 80px);
	--gap_64px : clamp(21px, 8vw, 64px);
	--gap_48px : clamp(16px, 6vw, 48px);
	--gap_32px : clamp(11px, 4vw, 32px);
	--gap_24px : clamp(8px, 3vw, 24px);
	--gap_16px : clamp(5px, 2vw, 16px);
	--gap_8px : clamp(3px, 1vw, 8px);
}

body {
	width: 100%;
	position: relative;
}

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-size: inherit;
	font-weight: 500;
}
li,ol,ul {
	list-style-type: none;
}
table {
	width: 100%;
}

#page {
	font-size: clamp(18px, 2.2vw, 20px);
	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.6;
	margin: 0 auto;
	/* max-width: 1920px; */
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt" 1;
	position: relative;
}

.top__bg {
position: relative;
}

.top__bg::before {
	content: "";
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	top: 0;
	background-color: var(--color_BLU);
	background-image: linear-gradient(90deg, #fff 1px, transparent 1px), linear-gradient(#fff 1px, transparent 1px);
	background-position: 10px 10px;
	background-size: 31px 31px;
	z-index: -2;
}


#page * {
	box-sizing: border-box;
}
#page img {
	max-width: 100%;
-o-object-fit: cover;
object-fit: cover;
}

#page a {
	transition: all 0.3s;
	text-decoration: none;
}
#page a[tabindex*="-1"] {
	pointer-events: none;
}
#page a[tabindex*="-1"]:hover {
	opacity: 1;
}
/* リンクとボタンのoutlineを非表示にする */
#page a,
#page button {
	outline: none;
	cursor: pointer;
}
/* ボタンとリンクにフォーカスした時にoutlineが表示されるようにする */
#page a:focus-visible {
	outline: #3683BF solid 2px;
	outline-offset: 2px;
}
#page button:focus-visible {
	outline: #3683BF solid 2px;
	outline-offset: 1px;
}
#page a:hover {
	cursor: pointer;
	text-decoration: none;
	opacity: 0.7;
}
#page label {
	cursor: pointer;
}

#page em {
	font-style: normal;
	font-weight: bold;
}

#page picture { display: block;}

/* #page section:nth-of-type(4),
#page section:last-of-type { margin-bottom: 0;} */

/* #page section {
padding-top: 10px;
margin-top: -10px;
} */

.pc {
display: block;
}

.sp {
display: none;
}


.ib {
	font-size: inherit !important;
	display: inline-block;
}

#page_top {
position: fixed;
right: 0.5%;
bottom: 2%;
display: block;
width: min(20vw,100px);
z-index: 999;
}

#page_top img { width: 100%;}

.top__movie {
margin: var(--gap_24px) auto;
}

.movie {
position: relative;
max-width: 900px;
aspect-ratio: 16/9;
margin: 0 auto var(--gap_32px);
overflow: hidden;
}

.tver_area {
	text-align: center;
	text-shadow: 0 0 0.2em #fff,0 0 0.2em #fff,0 0 0.3em #fff,0 0 0.3em #fff,0 0 0.3em #fff;
	/* margin: var(--gap_64px) auto var(--gap_32px); */
	/* width: clamp(250px, 50vw, 450px); */
}

.tver_info {
	margin-bottom: var(--gap_8px);
}

.tver_info em {
	font-size: 1.3em;
}

.tver_area .tver_info_btm {
	color: inherit;
	margin: var(--gap_16px) auto 0;
	text-align: center;
	line-height: 1.2;
}

.tvo-video {
position: absolute;
width: 100%;
height: 100%;
top: 0;
right: 0;
}

	@media not screen and (min-width: 767px) {
	#page_top {
		z-index: 800;
	}
}


/*================================
共通パーツ
================================*/
.inner_wide {
	padding-inline: min(5vw,80px);
}

.inner_contents {
	max-width: min(85vw,1355px);
	margin-inline: auto;
	padding-inline: 25px;
}

@media not screen and (min-width: 768px) {
	.inner {
	width: 94%;
	padding-inline: calc((16/750)*100vw);
	}

	.inner_wide, .inner_contents {
	max-width: 94%;
	padding-inline: 3vw;
	margin-inline: auto;
	}

	.pc {
	display: none;
	}
	
	.sp {
	display: block;
	}
}

.sub_title {
	margin-bottom: var(--gap_48px);
}


/* =============================================================
	main コンテンツ
============================================*/
.mv__img img {
	width: 100%;
}


/* =============================================================
	contents
============================================*/
.contents {
	background-image: url("/sp/expo_mitokana/images/main_bg.png");
	background-attachment: fixed;
	background-size: 100% auto;
	background-position: center;
	padding: var(--gap_80px) 0 0;
}

@media only screen and (max-width: 767px) {
	.contents {
		background-size: cover;
	}
}

.contents__bg {
	background: #fff;
	box-shadow: 0 0 20px #696969;
	padding: var(--gap_64px) var(--gap_48px);
	margin: var(--gap_80px) auto;
	text-align: center;
	border-radius: var(--gap_48px);
}

/* =============================================================
	about
============================================*/
.about .sub_title {
	width: min(70%,380px);
	margin: 0 auto var(--gap_48px);
}

.about .sub_title.title02 {
	width: min(55%,263px);
}

.about__text01{
	line-height: 2em;
	margin-bottom: var(--gap_48px);
}

.about__text01.mb30  {
	margin-top: var(--gap_32px);
}

.about__text01 .red {
	font-size: 1.4em;
	color: var(--color_RED);
}

.about__streaming {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--gap_48px);
	margin: var(--gap_64px) auto var(--gap_80px);
}

.tver_area, .youtube_area {
	width: 45%;
}

.about__lieup {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--gap_48px);
	max-width: 1000px;
	margin: 0 auto;
}

.about__lieup > li {
	width: 43%;
}


/* =============================================================
	spot
============================================*/
.spot__contents:not(:last-of-type) {
	background: url(/sp/expo_mitokana/images/line.png) no-repeat center bottom / 100% auto;
	padding-bottom: var(--gap_80px);
	margin-bottom: var(--gap_64px);
}

.spot__contents--title {
	margin-bottom: var(--gap_48px);
}

.spot__contents--title.title03 {
	margin-bottom: var(--gap_16px);
}

.spot__contents--text {
	font-weight: 700;
	margin-bottom: var(--gap_48px);
}

.spot__img01 img, .spot__img02 img {
	box-shadow: 0 0 20px #696969;
}

.spot__img01 {
	margin-bottom: var(--gap_48px);
}

.spot__img02 {
	display: flex;
	justify-content: space-between;
	align-items: center;

}

.spot__img02 > li {
	width: 23%;
}


/* =============================================================
    【movie】ブロック　※Brightecoveの動画表示
============================================*/
.movie_wrap {
	width: 100%;
    max-width: 900px;
    margin: var(--gap_64px) auto 0;
}
#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;
}

.tver_wrap {
    margin: var(--gap_64px) auto 0;
}
.bnr_tver {
    margin: 0 auto;
    max-width: 800px;
}
.bnr_tver img {
    box-shadow: 0 0 10px #4d869e;
}
.tver_wrap .limit_text {
    font-weight: bold;
    text-align: center;
    line-height: 1.3;
    margin: 12px auto 0;
}
.tver_wrap .limit_text small {
    font-size: 16px;
    font-weight: normal;
}


@media not screen and (min-width: 768px) {
/* =============================================================
	about
============================================*/
.about__text01 {
	font-size: .9em;
	line-height: 1.7em;
}

.about__text01 .red {
	font-size: 1.2em;
}

.about__streaming {
	display: block;
	margin: var(--gap_64px) auto var(--gap_80px);
}

.tver_area, .youtube_area {
	width: 80%;
	margin-inline: auto;
}

.tver_area {
	margin-bottom: var(--gap_48px);
}


.about__lieup {
	display: block;
}

.about__lieup > li {
	width: 80%;
	margin-inline: auto;
}

.about__lieup > li:not(:last-child) {
	margin-bottom: var(--gap_32px);
}


/* =============================================================
	spot
============================================*/
	.spot__contents--title {
		width: 96%;
		margin-inline: auto;
	}

	.spot__contents--title.title02 {
		width: 75%;
	}

	.spot__contents:not(:last-of-type) {
		background: url(/sp/expo_mitokana/images/line_sp.png) no-repeat center bottom / 100% auto;
	}

	.spot__img02 {
		display: block;

	}

	.spot__img02 > li {
		width: 100%;
	}

	.spot__img02 > li:not(:last-child) {
		margin-bottom: var(--gap_48px);
	}









}