@charset "UTF-8";
/* CSS Document */
#LibraryArea {
	width: 96.66%;
	margin: 0 auto;
}
.LibraryBlock li {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	flex-shrink: 0;
	width: 22.5vw;
	max-width: 270px;
	scroll-snap-align: start;
}
#LibraryIndex, #LibraryTitleArea {
	display: block;
	width: 91.66%;
	margin: 0 auto;
	overflow: hidden;
	position: relative;
}
/*240524修正*/
#LibraryIndex {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-flow: wrap;
	gap: 0 1em;
}
#LibraryIndex .MenuBlock {
	display: block;
	width: 100%;
	margin-bottom: 1em;
}
#LibraryIndex .MenuBlock.FullW {
	width: 100%;
	flex-shrink: 1;
}
#LibraryIndex .MenuBlock.HalfW {
	width: calc(50% - 0.5em);
}
#LibraryIndex h2 {
	transform: rotate(0.03deg);
	-moz-transform: rotate(0.03deg);
	-ms-transform: rotate(0.03deg);
	-o-transform: rotate(0.03deg);
	-webkit-transform: rotate(0.03deg);
}
/*#LibraryIndex ul {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-flow: wrap;
    gap: 2em;
    list-style: none;
    margin-bottom: 1em;
}
#LibraryIndex ul li {
	width: calc(100% / 3 - 1em);
}*/
#LibraryIndex .MenuBlock ul {
	width: 100%;
	position: relative;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-flow: wrap;
	gap: 1em;
	list-style: none;
}
#LibraryIndex .MenuBlock.FullW ul li {
	width: calc(100% / 4 - (3em / 4));
}
#LibraryIndex .MenuBlock.HalfW ul li {
	width: calc(100% /2 - 0.5em);
}
/*----*/
#LibraryIndex ul li a.Disabled, #LibraryArea ul li a.Disabled {
	display: block;
	position: relative;
	pointer-events: none;
}
#LibraryIndex ul li a.Disabled::after, #LibraryArea ul li a.Disabled::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: url("../images/t_library/bnr_disabled.png") no-repeat center center;
	background-size: contain;
}
#LibraryTitleArea h1 span {
	position: absolute;
	right: 0;
	font-size: 66.66%;
	font-weight: 400;
}
#LibraryTitleArea #Title {
	width: 100%;
	height: 36.66vw;
	max-height: 440px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-flow: column;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	color: #ffffff;
	font-size: 200%;
	line-height: 150%;
	font-weight: 700;
	text-align: center;
	margin: 0.5em auto;
}
#LibraryTitleArea #Title span.SubTitle {
	font-size: 60%;
	line-height: 150%;
	font-weight: 400;
}
#LibraryTitleArea #Title span.Date {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	/*231030修正*/
	/*font-weight: 300;*/
	font-weight: 400;
	line-height: 150%;
	position: absolute;
	right: 1em;
	bottom: 1em;
}
#LibraryTitleArea #Title span.Ribbon {
	display: inline-block;
	position: absolute;
	top: -8px;
	left: 10px;
	margin: 0;
	padding: 1em 0.5em 0.5em;
	width: auto;
	background: #6aaae4;
	text-align: center;
	color: #f9ed00;
	font-size: 66.66%;
	line-height: 150%;
	white-space: nowrap;
}
#LibraryTitleArea #Title span.Ribbon .LargeText {
	font-size: 200%;
}
#LibraryTitleArea #Title span.Ribbon:before {
	position: absolute;
	content: '';
	top: 0;
	right: -8px;
	border: none;
	border-bottom: solid 8px #0071ce;
	border-right: solid 8px transparent;
}
#LibraryContents {
	display: block;
	position: relative;
	width: 78.33vw;
	max-width: 940px;
	margin: 0 auto;
}
#LibraryContents h2 {
	color: #0071ce;
	font-size: 180%;
	line-height: 150%;
	margin: 2em auto 1em;
	text-align: center;
	text-decoration: underline; /* 下線 */
	text-decoration-thickness: 0.5em; /* 線の太さ */
	text-decoration-color: #f9ed00; /* 線の色 */
	text-underline-offset: -0.3em; /* 線の位置。テキストに重なるようにやや上部にする */
	text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}
#LibraryContents h3 {
	color: #0071ce;
	font-size: 125%;
	line-height: 150%;
	text-align: left;
	display: block;
	background: #fcf680;
	padding: 0.5em 1em;
	margin: 1em 0;
}
#LibraryContents p {
	font-size: 100%;
	line-height: 150%;
	margin: 1em auto;
	width: 90%;
}
#LibraryContents p.SmallText {
	font-size: 90%;
	line-height: 150%;
}
p.BodyCopy {
	color: #0071ce;
	text-align: center;
	font-size: 120%;
	line-height: 150%;
}
#PointBox {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 80%;
	border-top: solid 4px #92b4e7;
	border-bottom: solid 4px #92b4e7;
	margin: 2em auto;
	padding: 1em;
	position: relative;
	gap: 4em;
}
#PointBox img {
	width: 15vw;
	max-width: 180px;
	height: auto;
}
#PointBox div p {
	color: #0071ce;
	font-size: 120%;
	line-height: 150%;
	font-weight: 700;
	border-bottom: dotted 2px #f9ed00;
	margin: 0.25em 0 0.25em -1.25em;
	width: auto;
	text-indent: -1.25em;
}
#ProfileBox {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 1em;
	position: relative;
	color: #0071ce;
	margin: 3em 0 5em;
}
#ProfileBox #ProfilePhoto {
	width: 130px;
	height: auto;
}
#ProfileBox #ProfilePhoto img {
	width: 100%;
	height: auto;
	aspect-ratio: 1/1;
	object-fit: cover;
	border-radius: 50%;
}
#ProfileBox #ProfileText #ProfileTitle {
	display: inline-flex;
	justify-content: flex-start;
	align-items: center;
	height: 2em;
	width: auto;
	font-size: 80%;
	line-height: 100%;
	color: #ffffff;
	padding: 0.5em 1em;
	background-color: #0071ce;
	position: relative;
}
#ProfileBox #ProfileText #ProfileTitle::after {
	content: "";
	width: 0.5em;
	height: 100%;
	right: -0.5em;
	top: 0;
	position: absolute;
	background: linear-gradient(to bottom right, #0071ce 50%, transparent 50%) top left/ 100% 50% no-repeat, linear-gradient(to top right, #0071ce 50%, transparent 50%) bottom left / 100% 50% no-repeat;
}
#ProfileBox #ProfileText #ProfileTitle::before {
	content: "";
	width: 0.5em;
	height: 100%;
	left: -0.5em;
	top: 0;
	position: absolute;
	background: linear-gradient(to bottom left, #0071ce 50%, transparent 50%) top left/ 100% 50% no-repeat, linear-gradient(to top left, #0071ce 50%, transparent 50%) bottom left / 100% 50% no-repeat;
}
#ProfileBox #ProfileText #ProfileName {
	margin: 0.5em 0;
	font-weight: 700;
}
#ProfileBox #ProfileText p {
	margin: 0;
	width: auto;
	font-size: 80%;
}
#ColumnArea {
	display: grid;
	grid-template-columns: 28% 1fr;
	grid-template-rows: auto auto;
	grid-template-areas: "ColumnTitle ColumnTitle"
		"ColumnPhoto ColumnText";
	margin: 2em 0;
}
#ColumnTitle {
	grid-area: ColumnTitle;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	position: relative;
	padding: 1em 0 1em 28%;
	background: #0071ce;
	color: #ffffff;
	font-size: 120%;
	line-height: 150%;
	font-weight: 700;
}
#ColumnTitle span {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: -8px;
	padding: 0.25em 1em;
	background-color: #f9ed00;
	color: #0071ce;
	text-align: center;
}
#ColumnTitle span::before {
	position: absolute;
	bottom: 100%;
	left: 0;
	width: 0px;
	height: 0px;
	border: none;
	border-top: 8px solid transparent;
	border-right: 8px solid #f9b400;
	content: '';
}
#ColumnTitle span::after {
	content: "";
	width: 0.75em;
	height: 100%;
	right: -0.75em;
	top: 0;
	position: absolute;
	background: linear-gradient(to bottom right, #f9ed00 50%, transparent 50%) top left/ 100% 50% no-repeat, linear-gradient(to top right, #f9ed00 50%, transparent 50%) bottom left / 100% 50% no-repeat;
}
#ColumnPhoto {
	grid-area: ColumnPhoto;
	background: #e9f1fa;
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
#ColumnPhoto img {
	width: 16.66vw;
	max-width: 200px;
	margin: 1em;
	height: auto;
	aspect-ratio: 1/1;
	object-fit: cover;
	border-radius: 50%;
}
#ColumnText {
	grid-area: ColumnText;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	background: #e9f1fa;
	padding: 1em 2em 1em 0;
	color: #0071ce;
	font-size: 80%;
	line-height: 150%;
}
#FashionArea {
	display: block;
	width: 91.66%;
	margin: 0 auto;
	overflow: hidden;
	position: relative;
}
#FashionArea h3 {
	color: #fcf680;
	font-size: 150%;
	line-height: 150%;
	text-align: center;
	display: block;
	background: #0071ce;
	padding: 0.5em 1em;
	margin: 1em 0;
}
#FashionItemArea {
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	flex-flow: wrap;
	gap: 2em;
}
#FashionItemArea .FashionItemBox {
	display: block;
	width: calc(50% - 1em);
	position: relative;
}
#FashionItemArea .FashionItemBox .FashionItemRibbon {
	display: inline-block;
	position: absolute;
	top: -8px;
	left: 10px;
	margin: 0;
	padding: 0.5em;
	z-index: 2;
	width: auto;
	min-width: 5em;
	background: #6aaae4;
	text-align: center;
	color: #f9ed00;
	font-size: 80%;
	line-height: 150%;
	white-space: nowrap;
}
#FashionItemArea .FashionItemBox .FashionItemRibbon:before {
	position: absolute;
	content: '';
	top: 0;
	right: -8px;
	border: none;
	border-bottom: solid 8px #0071ce;
	border-right: solid 8px transparent;
}
#FashionItemArea .FashionItemBox figure {
	width: 100%;
	height: auto;
	aspect-ratio: 26/17;
	position: relative;
}
#FashionItemArea .FashionItemBox figure figcaption {
	display: block;
	position: absolute;
	bottom: 1em;
	right: 1em;
	background: #fcf680;
	font-size: 80%;
	;
	line-height: 100%;
	padding: 0.5em 1em;
}
#FashionItemArea .FashionItemBox p {
	font-size: 80%;
	line-height: 150%;
	color: #0071ce;
}
#Thoughts {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-flow: column;
	background: #e9f1fa;
	gap: 1em;
	margin: 3em auto 1em;
}
#Thoughts h3 {
	width: 100%;
	margin: 0;
}
#Thoughts p {
	width: 85%;
	margin: 1em auto;
	color: #0071ce;
	font-size: 80%;
	line-height: 150%;
}
#Thoughts .FigBlock {
	width: 85%;
	margin: 0em auto 1em;
}
#BottomText {
	margin-top: 3em;
	font-size: 90%;
	line-height: 150%;
	color: #0071ce;
}
.OnepointBox {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-flow: column;
	width: 100%;
	min-height: 80px;
	padding: 1em;
	padding-left: calc(1em + 80px + 2em + 1em);
	background: url("../images/t_library/onepoint_icon.png") no-repeat left 2em center #e9f1fa;
	background-size: 80px;
	border-radius: 1em;
	margin-top: 2em;
	margin-bottom: 3em;
}
.OnepointBox h4 {
	font-size: 120%;
	line-height: 150%;
	color: #0071ce;
	margin: 0;
	padding: 0;
}
.OnepointBox p {
	color: #0071ce;
	font-size: 80% !important;
	line-height: 150%;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}
#RealstoryEssayArea {
	display: block;
	width: 91.66%;
	margin: 0 auto;
	overflow: hidden;
	position: relative;
}
#RealstoryEssayBlock {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2em;
	position: relative;
	border: solid 2px #0071ce;
	border-radius: 1.5em;
	margin: 2em auto;
	padding: 3em;
}
#RealstoryEssayBlock h2 {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	margin: 0;
	padding: 0;
}
#RealstoryEssayBlock h2 span {
	position: relative;
	display: block;
	font-size: 125%;
	line-height: 100%;
	color: #f9ed00;
	background: #6aaae4;
	padding: 0.5em 1em;
}
#RealstoryEssayBlock h2 span::after {
	content: "";
	width: 0.75em;
	height: 100%;
	right: -0.75em;
	top: 0;
	position: absolute;
	background: linear-gradient(to bottom right, #6aaae4 50%, transparent 50%) top left/ 100% 50% no-repeat, linear-gradient(to top right, #6aaae4 50%, transparent 50%) bottom left / 100% 50% no-repeat;
}
#RealstoryEssayBlock h2 span::before {
	content: "";
	width: 0.75em;
	height: 100%;
	left: -0.75em;
	top: 0;
	position: absolute;
	background: linear-gradient(to bottom left, #6aaae4 50%, transparent 50%) top left/ 100% 50% no-repeat, linear-gradient(to top left, #6aaae4 50%, transparent 50%) bottom left / 100% 50% no-repeat;
}
#RealstoryEssayBlock #EssayIllustration {
	width: 38.33vw;
	max-width: 460px;
}
#RealstoryEssayBlock #EssayPhoto {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-flow: column;
	gap: 2em;
	width: 35vw;
	max-width: 420px;
}
#RealstoryEssayBlock #EssayPhoto img {
	border-radius: 1em;
	object-fit: cover;
}
/*SlickArea*/
#VideoSlideArea {
	position: relative;
	display: block;
	width: 100%;
}
#VideoSlideArea .Slider li {
	margin: 0 1em;
	pointer-events: none;
	opacity: 0.3;
	position: relative;
}
#VideoSlideArea .Slider li.slick-current {
	opacity: 1;
	pointer-events: auto;
}
#VideoSlideArea .Slider li a {
	display: block;
	aspect-ratio: 16/9;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	text-indent: -999em;
	position: relative;
}
#VideoSlideArea .Slider li.slick-current a::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: url("../images/t_library/btn_video_play.png") no-repeat center center;
	background-size: 25%;
}
#VideoSlideArea .slick-dots {
	position: initial !important;
}
#VideoSlideArea .Pager {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 0 1em;
	padding: 0;
	height: 3em;
	pointer-events: auto;
	cursor: pointer;
}
#VideoSlideArea .Pager li {
	display: inline-block;
	margin: 0 1em;
	pointer-events: auto;
	opacity: 1;
	cursor: pointer;
}
#VideoSlideArea .Pager li button {
	margin: 0;
	padding: 0;
	background-color: #b8b8b8;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	height: 3em;
	width: auto;
	aspect-ratio: 22/5;
	border: none;
	border-radius: 1.5em;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	text-indent: -9999em;
	cursor: pointer;
}
#VideoSlideArea .Pager li:nth-of-type(1) button {
	background-image: url("../images/t_library/btn_video_1_off.png");
}
#VideoSlideArea .Pager li:nth-of-type(2) button {
	background-image: url("../images/t_library/btn_video_2_off.png");
}
#VideoSlideArea .Pager li:nth-of-type(3) button {
	background-image: url("../images/t_library/btn_video_3_off.png");
}
#VideoSlideArea .Pager li.slick-active button {
	background-color: #0071ce;
}
#VideoSlideArea .Pager li:nth-of-type(1).slick-active button {
	background-image: url("../images/t_library/btn_video_1_on.png");
}
#VideoSlideArea .Pager li:nth-of-type(2).slick-active button {
	background-image: url("../images/t_library/btn_video_2_on.png");
}
#VideoSlideArea .Pager li:nth-of-type(3).slick-active button {
	background-image: url("../images/t_library/btn_video_3_on.png");
}
/*埋め込みmp4*/
.VideoBox {
	width: 100%;
	height: auto;
}
.VideoBox video {
	width: 100%;
}
/*タブレット*/
@media screen and (min-width:768px) and (max-width:1199px) {
	.LibraryBlock li {
		padding: 0.833vw;
	}
	.OnepointBox {
		min-height: 6.66vw;
		padding-left: calc(1em + 6.66vw + 2em + 1em);
		background-size: 6.66vw;
	}
	#VideoSlideArea .Pager {
		height: 2em;
	}
	#VideoSlideArea .Pager li button {
		height: 3vw;
		width: auto;
		aspect-ratio: 22/5;
		border-radius: 1.5vw;
	}
}
/*スマホ*/
@media screen and (max-width: 767px) {
	.LibraryBlock li {
		width: 40%;
		max-width: 40%;
	}
	.OnepointBox {
		min-height: 6.66vw;
		padding-left: calc(1em + 6.66vw + 2em + 1em);
		background-size: 6.66vw;
	}
	#LibraryContents {
		width: 91.66%;
		max-width: 91.66%;
	}
	#VideoSlideArea .Slider li {
		margin: 0 0.5em;
	}
	#PointBox {
		width: 90%;
	}
	#VideoSlideArea .Pager {
		height: 2.5em;
	}
	#VideoSlideArea .Pager li {
		margin: 0 0.25em;
	}
	#VideoSlideArea .Pager li button {
		height: 2em;
		width: auto;
		aspect-ratio: 22/5;
		border-radius: 1em;
	}
	/* 縦向きの場合のスタイル */
	@media screen and (max-aspect-ratio: 11/10) {
		/*240524修正*/
		/*#LibraryIndex ul li {
            width: calc(100% / 2 - 1em);
        }*/
		#LibraryIndex .MenuBlock.HalfW {
			width: 100%;
			flex-shrink: 1;
		}
		#LibraryIndex .MenuBlock.FullW ul li, #LibraryIndex .MenuBlock.FullW ul li {
			width: calc(100% / 2 - 0.5em);
		}
		/*----*/
		#LibraryTitleArea #Title {
			width: 100%;
			height: 80vmin;
			max-height: 80vmin;
		}
		/* スマホ表示時にタイトル画像の位置を調整 */
		/* 左に移動 */
		#LibraryTitleArea #Title.Left {
			background-position: left 25% center;
		}
		/* 右に移動 */
		#LibraryTitleArea #Title.Right {
			background-position: right 25% center;
		}
		#PointBox {
			width: 100%;
			flex-flow: column;
			gap: 1em;
		}
		#PointBox div p {
			font-size: 100%;
			line-height: 150%;
		}
		#ProfileBox {
			justify-content: center;
			flex-flow: column;
		}
		#ProfileBox #ProfileText #ProfileTitle {
			justify-content: center;
			align-items: center;
			padding-right: 1em;
			margin-left: auto;
			margin-right: auto;
		}
		#ProfileBox #ProfileText #ProfileName {
			text-align: center;
		}
		#ProfileBox #ProfileText p {
			text-align: center;
		}
		#ColumnArea {
			grid-template-columns: auto auto;
			grid-template-rows: auto auto;
			grid-template-areas: "ColumnTitle ColumnPhoto"
				"ColumnText ColumnText";
		}
		#ColumnTitle {
			padding: 3.5em 1em 1em;
		}
		#ColumnTitle span {
			top: 1em;
			transform: translateY(0);
		}
		#ColumnPhoto {
			background: #0071ce;
			align-items: center;
		}
		#ColumnPhoto img {
			width: 70%;
			max-width: 70%;
		}
		#ColumnText {
			padding: 1.5em;
		}
		#FashionItemArea {
			flex-flow: column;
		}
		#FashionItemArea .FashionItemBox {
			width: 100%;
		}
		.OnepointBox {
			padding: 1em;
			padding-left: 1em;
			padding-top: calc(10vw + 2em);
			background: url("../images/t_library/onepoint_icon.png") no-repeat center top 1em #e9f1fa;
			background-size: 10vw;
		}
		.OnepointBox h4 {
			width: 100%;
			text-align: center;
		}
		#RealstoryEssayBlock {
			flex-flow: column;
		}
		#RealstoryEssayBlock #EssayIllustration {
			width: 100%;
			max-width: 100%;
		}
		#RealstoryEssayBlock #EssayPhoto {
			width: 100%;
			max-width: 100%;
		}
		#VideoSlideArea .Pager {
			height: 2em;
		}
		#VideoSlideArea .Pager li button {
			height: 1.5em;
			width: auto;
			aspect-ratio: 22/5;
			border-radius: 1em;
		}
	}
}