@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Antic+Didone&Bellota&family=Kiwi+Maru:wght@300&display=swap");

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

エントランス

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.index {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 100px;
	padding: 40px;
}

.entrance {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: url("../images/entrance.png") no-repeat center center;
	background-size: contain;
	width: -moz-fit-content;
	width: fit-content;
	min-width: 300px;
	min-height: 300px;
	text-align: center;
}

.entrance .sitename a {
	text-shadow: 0px 0px 0px #fff;
	text-align: center;
	text-decoration: none;
	font-size: 4rem;
	letter-spacing: 6px;
	transition: 0.4s;
	-webkit-transition: 0.4s;
	-moz-transition: 0.4s;
	-ms-transition: 0.4s;
}

.entrance .sitename a:hover {
	filter: blur(8px);
	-webkit-filter: blur(6px);
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

更新履歴

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.update {
	height: 150px;
	overflow-y: auto;
	padding-right: 20px;
	margin: 0px 10px;
}

.update__item {
	display: flex;
	gap: 24px;
	padding: 8px 10px;
}

.update__item:not(:last-child) {
	border-bottom: 2px dashed #f5cf70;
}

.update__item time {
	color: #a5b553;
}

/* スマホ */
@media screen and (max-width: 520px) {
	.update {
		margin: 0;
	}

	.update__item {
		flex-direction: column;
		gap: 4px;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

トピック一覧

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.topiclist__item {
	container-type: inline-size;
	margin-bottom: 40px;
	padding: 20px;
}

.topiclist__item:last-child {
	margin: 0;
}

.topiclist__item .grid {
	gap: 20px;
	text-decoration: none;
	align-items: flex-start;
}

.topiclist__item .grid img {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.topiclist__item .grid p {
	margin: 0;
}

@container (max-width: 600px) {
	.grid {
		gap: 10px;
		grid-template-columns: 1fr;
	}
}

/* スマホ */
@media screen and (max-width: 520px) {
	.topiclist__item {
		padding: 0;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

 ABOUT

 －－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
/*－－－－－－－－－－ Profile －－－－－－－－－－*/
.profile {
	display: flex;
	gap: 2rem;
	margin-left: 2vw;
}

.profile__img {
	padding: 0 40px;
}

.profile__img img {
	border-radius: 50%;
	margin: auto;
}

.profile__img2 {
	width: 30vw;
	padding: 0 10px;
	display: flex;
}

.profile__img2 img {
	border-radius: 50%;
	margin: auto;
}

.profile_text {
	padding: 30px 1px;
}

@media (max-width: 800px) {

	.profile {
		display: block;
		text-align: center;
		margin-left: auto;
	}

	.profile__img2 {
		width: 70%;
		margin: auto;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

LINK

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

 CONTACT

 －－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.mailform input {
	width: max(50%, 400px);
}

.mailform textarea {
	width: 100%;
}

/* タブレット、スマホ */
@media screen and (max-width: 768px) {

	.mailform input,
	.mailform textarea {
		max-width: 100%;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

 NOVEL

 －－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
/*－－－－－－－－－－  小説一覧ページ －－－－－－－－－－*/
.novellist {
	margin-top: 20px;
}

.novellist.--2column {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	/* スマホ */
}

.novellist.--2column .novellist__item {
	margin: 0;
}

.novellist.--2column> :last-child {
	margin-bottom: 0;
}

.novellist.--2column .novellist__text {
	margin-left: 0px;
}

@media screen and (max-width: 520px) {
	.novellist.--2column {
		grid-template-columns: 1fr;
	}
}

.novellist__item {
	margin-bottom: 40px;
}

.novellist__item a {
	-webkit-text-decoration: underline solid #fff4f6;
	text-decoration: underline solid #fff4f6;
	text-underline-offset: 4px;
}

.novellist__item .grid {
	grid-template-columns: repeat(auto-fill, minmax(20px, 1fr));
	gap: 20px;
}

/* 小説のタイトル */
.novellist__title {
	font-size: clamp(1.6rem, 1.56rem + 0.2vw, 1.8rem);
	background: linear-gradient(transparent 60%, #fff4f6 60%);
	width: -moz-fit-content;
	width: fit-content;
}

.novellist__title+* {
	margin-left: 20px;
}

.short .novellist__title {
	font-size: clamp(1.4rem, 1.36rem + 0.2vw, 1.6rem);
}

/* 数字プラス小タイトルの数字の色 */
.novellist__number {
	color: #FCC0CB;
	margin-right: 10px;
}

/* 短編小説の説明文 */
.novellist__text {
	display: block;
	font-size: 0.8em;
	margin: 10px;
	margin-left: 20px;
}

/*－－－－－－－－－－ 長編小説ページ －－－－－－－－－－*/
.longnovel .longnovel__title {
	font-weight: normal;
	margin: 60px 0;
}

.longnovel .novellist .novellist__item {
	margin-bottom: 30px;
}

.longnovel .novellist> :last-child {
	margin-bottom: 0;
}

.longnovel .novellist.--2column .novellist__item {
	margin: 0;
}

/*－－－－－－－－－－ 小説のページ －－－－－－－－－－*/
.novelpage__inner {
	max-width: 800px;
	margin: auto;
	padding: 80px 0;
}

.novelpage__title {
	margin-bottom: 80px;
}

/* 前後ページへのナビ */
.pagenav {
	justify-content: center;
	align-items: center;
	gap: 40px;
	margin: 80px 0;
}

.pagenav__item a {
	display: flex;
	align-items: center;
	text-decoration: none;
}

.pagenav__item a i {
	opacity: 0;
	transition: 0.2s;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-ms-transition: 0.2s;
	-moz-transition: 0.2s;
}

.pagenav__item a:hover i {
	opacity: 1;
	transition: 0.2s;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-ms-transition: 0.2s;
	-moz-transition: 0.2s;
	-o-transition: 0.2s;
}

.pagenav__item.--prev a i {
	margin-right: 10px;
}

.pagenav__item.--prev a:hover i {
	transform: translateX(-6px);
	-webkit-transform: translateX(-6px);
	-moz-transform: translateX(-6px);
	-ms-transform: translateX(-6px);
	-o-transform: translateX(-6px);
}

.pagenav__item.--next a i {
	margin-left: 10px;
}

.pagenav__item.--next a:hover i {
	transform: translateX(6px);
	-webkit-transform: translateX(6px);
	-moz-transform: translateX(6px);
	-ms-transform: translateX(6px);
	-o-transform: translateX(6px);
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

GALLERY

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.gallerylist {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 40px 10px;
}

.gallerylist__item {
	width: calc((100% - 50px) / 5);
	height: auto;
}

@media screen and (max-width: 1024px) {
	.gallerylist__item {
		width: calc((100% - 40px) / 4);
	}
}

@media screen and (max-width: 767px) {
	.gallerylist__item {
		width: calc((100% - 30px) / 3);
	}
}

@media screen and (max-width: 520px) {
	.gallerylist__item {
		width: calc((100% - 20px) / 3);
	}
}

.gallerylist__item a {
	position: relative;
	display: block;
}

.gallerylist__item a::before {
	content: "";
	display: block;
	padding-top: 120%;
	/*100%=親要素の横幅*/
}

.gallerylist__item a img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}


/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－
flex　自作ギャラリー


－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.galleryflex {
	column-count: 4;
	column-gap: 1em;
}

.galleryflex__item {
	background-color: #eee;
	margin: 0 0 1em;
	width: 100%;
}

.galleryflex__item a img {
	border-radius: 10px;
	object-fit: cover;
	position: text-shadow;
	border: 1px solid #fff;
	flex-grow: 1;
	object-fit: cover;
}

/* Masonry on large screens */
@media screen and (min-width: 1024px) {
	.galleryflex {
		column-count: 4;
	}
}

/* Masonry on medium-sized screens */
@media screen and (max-width: 1023px) and (min-width: 768px) {
	.galleryflex {
		column-count: 2;
	}
}

/* Masonry on small screens */
@media screen and (max-width: 767px) and (min-width: 40px) {
	.galleryflex {
		column-count: 1;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

COMIC

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
/*－－－－－－－－－－ 漫画タイトル一覧ページ －－－－－－－－－－*/
.comiclist__item {
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	margin-bottom: 40px;
}

.comiclist__item .comiclist__img {
	position: relative;
	width: 100%;
	height: 100%;
}

.comiclist__item .comiclist__img img {
	position: absolute;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.comiclist__item .comiclist__body .comiclist__title {
	background: linear-gradient(transparent 60%, #fff4f6 60%);
}

/* スマホ */
@media screen and (max-width: 520px) {
	.comiclist__item {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.comiclist__item .comiclist__img img {
		position: relative;
		max-height: 40vh;
	}

	.comiclist__item .comiclist__body {
		padding-top: 0;
	}

	.comiclist__item .comiclist__body .comiclist__title {
		position: static;
		width: 100%;
		margin: 20px 0;
	}
}

/*－－－－－－－－－－ 漫画表紙ページ －－－－－－－－－－*/
/* メイン画像 */
.comic__mainvisual {
	position: relative;
	margin-bottom: 40px;
}

.comic__mainvisual img {
	width: 100%;
	height: 15vw;
	object-fit: cover;
}

/**スマホ**/
@media screen and (max-width: 1024px),
print {
	.comic__mainvisual img {
		width: 100%;
		height: 40vw;
		object-fit: cover;
	}
}

/* タイトル */
.comic__title {
	position: absolute;
	right: 0;
	bottom: 0.1px;
	font-size: clamp(2.4rem, 2.08rem + 1.6vw, 4rem);
	text-shadow: 0px 0px 0px #fff;
}

.comic__title .marker {
	background: linear-gradient(transparent 40%, #fff4f6 40%);
}

/*－－－－－－－－－－ キャラクター紹介 －－－－－－－－－－*/
/* キャラクター名一覧 */
.charanamelist {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
}

.charanamelist .charanamelist__item {
	cursor: pointer;
}

/* キャラクタープロフィール部分 */
.charalist--3 {
	margin-bottom: 40px;
}

.charalist--3 .charalist__item {
	position: relative;
	height: 100%;
	display: none;
	margin-top: 20px;
}

.charalist--3 .charalist__item .charalist__img {
	width: 40%;
	height: 100%;
	max-height: 100vh;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center top;
	object-position: center top;
}

.charalist--3 .charalist__item .charalist__body {
	width: calc(60% - 20px);
}

.charalist--3 .charalist__item .charalist__body> :first-child {
	margin-top: 0;
}

.charalist--3 .charalist__item .charalist__body .charalist__name {
	font-size: clamp(2rem, 1.422rem + 2.37vw, 3.2rem);
}

.charalist--3 .charalist__item.show {
	display: flex;
}

/* スマホ */
@media screen and (max-width: 768px) {
	.charalist--3 .charalist__item {
		display: none;
	}

	.charalist--3 .charalist__item.flex .charalist__img {
		width: 60%;
		margin: 10px auto;
		height: auto;
		margin-bottom: 10px;
		-o-object-fit: contain;
		object-fit: contain;
	}

	.charalist--3 .charalist__item.flex .charalist__img img {
		width: 100%;
		height: auto;
	}

	.charalist--3 .charalist__item.flex .charalist__body {
		width: 100%;
	}
}



/*－－－－－－－－－－ 連載一覧 －－－－－－－－－－*/
.cardlist {
	container-type: inline-size;
}

.cardlist a {
	text-decoration: none;
}

.cardlist .cardlist__item {
	width: calc((100% - 60px) / 4);
}

.cardlist .cardlist__item a .cardlist__img {
	height: 200px;
	-o-object-fit: cover;
	object-fit: cover;
}

@container (max-width: 800px) {
	.cardlist .cardlist__item {
		width: calc((100% - 40px) / 3);
	}
}

@container (max-width: 600px) {
	.cardlist {
		gap: 10px;
	}

	.cardlist .cardlist__item {
		width: calc((100% - 20px) / 2);
	}

	.cardlist .cardlist__item a .cardlist__img {
		width: 100%;
		height: 140px;
	}
}

/*－－－－－－－－－－ 漫画のページ －－－－－－－－－－*/
.comicpage__main img {
	width: 70%;
	margin: auto;
	margin-bottom: 20px;
}

.episodelist {
	margin: 40px 0;
	padding: 20px 40px;
	background-color: #fff4f6;
}

@media screen and (max-width: 1024px) {
	.comicpage__main img {
		width: 100%;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

OFFLINE

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.off-list {
	gap: 60px;
	margin-bottom: 80px;
}

.storelist {
	gap: 10px;
	margin: 20px 0;
}

/* タブレット */
@media screen and (min-width: 769px) and (max-width: 1024px) {
	.off-list {
		gap: 20px;
	}
}

/*－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－

GALLERY

－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－－*/
.rakugaki {
	line-height: 0;
	-webkit-column-count: 3;
	-webkit-column-gap: 0px;
	-moz-column-count: 3;
	-moz-column-gap: 0px;
	column-count: 3;
	column-gap: 0px;

}

.rakugaki a {
	width: 100% !important;
	height: auto !important;
}

.rakugaki img {
	width: 100%;
	height: auto;
}

@media (max-width: 1200px) {
	.rakugaki {
		-moz-column-count: 4;
		-webkit-column-count: 4;
		column-count: 4;
	}
}

@media (max-width: 1000px) {
	.rakugaki {
		-moz-column-count: 3;
		-webkit-column-count: 3;
		column-count: 3;
	}
}

@media (max-width: 800px) {
	.rakugaki {
		-moz-column-count: 2;
		-webkit-column-count: 2;
		column-count: 2;
	}
}

@media (max-width: 400px) {
	.rakugaki {
		-moz-column-count: 1;
		-webkit-column-count: 1;
		column-count: 1;
	}
}



.tyuuou {
	justify-content: center;
}