@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600&display=swap');

/* ↓これらは見出し用のフォントです。不要なフォントがあれば削除するとロードが早くなります */
@import url('https://fonts.googleapis.com/css2?family=Playwrite+DK+Loopet:wght@200&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cinzel&display=swap');
@import url('https://fonts.googleapis.com/css2?family=UnifrakturMaguntia&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fugaz+One&display=swap');

*,*::before,*::after{box-sizing:border-box}*{margin:0}body{font-feature-settings:"palt" 1;overflow-wrap: anywhere;word-break: normal;line-break: strict;text-size-adjust:100%;-webkit-text-size-adjust:100%}picture,video,canvas{display:block;max-width:100%}input,button,textarea,select{font:inherit}img{max-width:100%;height:auto}ul{list-style-type:""}:where(:any-link) {color:currentColor;text-decoration-skip-ink:auto;text-decoration-color:color-mix(in srgb, currentcolor 30%, transparent);text-underline-offset: 0.2em}summary,button{cursor:pointer}em{font-style:normal}

:root {
	--main-bg-color: #fcf6ef;
	--main-text-color:#594237;
	--main-font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;

	--accent: #77ad1f;
	--red: #c33;
	--radius: 1rem;
	--shadow: 0px 2px 6px var(--text-color-30);

	--text-color-10: color-mix(in srgb, var(--main-text-color) 10%, transparent);
	--text-color-15: color-mix(in srgb, var(--main-text-color) 15%, transparent);
	--text-color-20: color-mix(in srgb, var(--main-text-color) 20%, transparent);
	--text-color-30: color-mix(in srgb, var(--main-text-color) 30%, transparent);
	--text-color-50: color-mix(in srgb, var(--main-text-color) 50%, transparent);
	--text-color-70: color-mix(in srgb, var(--main-text-color) 70%, transparent);
	--text-color-90: color-mix(in srgb, var(--main-text-color) 90%, transparent);
	--accent-15: color-mix(in srgb, var(--accent) 15%, transparent);
	--accent-30: color-mix(in srgb, var(--accent) 30%, transparent);
	--accent-50: color-mix(in srgb, var(--accent) 50%, transparent);
	--radius-mini: calc(var(--radius) * 0.3);
}

::marker{
	color: var(--text-color-50);
}
html{
	font-size: 100%;
	scroll-behavior: smooth;
}
body{
	accent-color: var(--accent);
	background: var(--main-bg-color) url(bg.jpg);
	color: var(--main-text-color);
	display: grid;
	font-family:var(--main-font-family);
	font-weight: 400;
	gap: 5vw;
	grid-template-columns: 1fr 3fr;
	letter-spacing: 0.05em;
	line-height: 1.8;
	margin: 5vw auto 100px;
	max-width: 1200px;
	min-height: 100dvh;
	padding-inline: 5vw;

	header,main{
		transition: 1s;
		opacity: 0;
	}
	header	{ animation: catch_anime 1s forwards 0.2s; }
	main	{ animation: catch_anime 1s forwards 0.4s; }
}
@keyframes catch_anime {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0px);
	}
}


/* MARK: header
--------------------------------------------*/
header{
	font-size: 0.85rem;
	height: 100%;
	position: relative;
	text-align: ;
	section{
		position: sticky;
		top: 5vw;
	}
	h1{
		line-height: 1.3;
		margin-block: 1rem;
	}
	img:not(.emoji){
		display: block;
		margin: 0 auto;
	}
	img.emoji{
		width: 3rem;
		height: 3rem;
	}
}


/* MARK: typography
--------------------------------------------*/
h2{
	border-top: 1px solid var(--main-text-color);
	color: color-mix(in srgb, var(--main-text-color) 50%, var(--main-bg-color));
	font-optical-sizing: auto;
	font-size: 3rem;
	font-style: normal;
	font-weight: 400;
	line-height: 1;
	margin-block: 3rem 1rem;
	padding-top: 3rem;
	text-box: trim-both cap alphabetic;
}
.deco + h2{
	border-top: none;
	padding-top: 0;
}
body.cursive h2{
	font-family: "Playwrite DK Loopet", cursive;
	font-weight: 200;
	letter-spacing: normal;
	margin-bottom: 1.3rem;
}
body.sans-serif h2{
	font-family: var(--main-font-family);
	font-weight: 600;
}
body.serif h2{
	font-family: "Cinzel", serif;
}
body.blackletter h2{
	font-family: "UnifrakturMaguntia", cursive;
}
body.sporty h2{
	font-family: "Fugaz One", sans-serif;
}
h2 + p.subtitle{
	font-weight: bold;
	margin-block: -0.5rem 2rem;
}
.deco{
	border: 1px solid var(--main-text-color);
	border-inline: none;
	border-width: 2px 0 1px;
	font-family: 'Times New Roman', Times, serif;
	font-size: 0.85rem;
	letter-spacing: 0.1em;
	margin-bottom: 3rem;
	padding-block: 1em;
	text-align: center;
	text-box: trim-both cap alphabetic;
}
.deco:empty{
	padding-block: 0.3em;
}
body.sporty .deco,
body.sans-serif .deco{
	font-family: unset;
}
footer .deco{
	border-width: 1px 0 2px;
	margin-block: 3rem 0;
}


/* MARK: common parts
--------------------------------------------*/
a{
	font-weight: 600;
}
a:hover{
	color: color-mix(in srgb, var(--accent) 70%, var(--main-text-color));
	text-decoration: none;
}
a img{
	transition: opacity 0.3s ease-in-out;
}
a:hover img{
	opacity: 0.7;
}
button{
	font-size: 0.9em;
	margin: 5px 0;
}
em{
	font-weight: 600;
	text-decoration: underline var(--accent-50) 0.5em;
	text-decoration-skip-ink: none;
	text-underline-offset: -0.2em;
}
hr{
	border: none;
	border-top: 1px solid var(--main-text-color);
	margin-block: 3rem;
}
img{
	box-shadow: var(--shadow)
}
img{
	margin-bottom: 10px;
}
p:not(:last-child){
	margin-bottom: 1em;
}
u{
	border: 1px solid color-mix(in srgb, currentColor 50%, transparent);
	display: inline-block;
	font-size: 1rem;
	line-height: 1.6;
	margin: 0 5px 5px;
	padding: 0 0.5em;
	text-decoration: none;
	vertical-align: middle;
}
ul{
	margin-bottom: 1em;
	padding-left: 1.3rem;
	li{
		list-style: outside disc;
		padding-bottom: 3px;
	}
}


/* MARK: named parts
--------------------------------------------*/
a.btn{
	background-color: var(--text-color-90);
	border-radius: var(--radius-mini);
	color: var(--main-bg-color);
	display: inline-block;
	font-size: 0.9em;
	margin-bottom: 5px;
	padding: 0.4em 1.5em 0.5em;
	text-decoration: none;
	transition: background-color 0.3s ease-in-out;
}
a.btn:hover{
	background-color: color-mix(in srgb, var(--accent) 70%, var(--main-text-color));
}
.accent{
	color: color-mix(in srgb, var(--accent) 70%, var(--main-text-color));
}
.btn-fit{
	display: flex;
	gap: 5px;
	a.btn{
		flex-grow: 1;
		padding-inline: 0;
		text-align: center;
	}
}
.book{
	display: grid;
	gap: 3rem clamp(1rem, 3vw, 3rem);
	grid-template-columns: 1fr 2fr;
	a.cover img{
		margin: 0;
	}
	h3{
		line-height: 1.5;
		margin-bottom: 1rem;
		text-box: trim-both text;
	}
}
h3 u{
	font-size: 0.85rem;
	margin: 0 5px 2px 0;
	padding: 0 0.3em;
}
.center{
	text-align: center;
}
.gallery{
	display: grid;
	grid-gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	margin-bottom: 2rem;
	padding-left: 0;
	a{
		font-size: 0.8rem;
		font-weight: 400;
		text-decoration: none;
	}
	img{
		aspect-ratio: 1 / 1;
		display: block;
		margin: 0;
		object-fit: cover;
		object-position: 50% 0%;
		width: 100%;
	}
	li{
		list-style: none;
	}
}
.gallery.aspect img{
	aspect-ratio: unset;
}
.grid2{
	display: grid;
	gap: 3rem clamp(1rem, 3vw, 3rem);
	grid-template-columns: 1fr 2fr;
	img{
		margin: 0;
	}
}
img.emoji{
	box-shadow: unset;
	height: 1em;
	margin: 0 3px 3px;
	vertical-align: middle;
	width: 1em;
}
img.noshadow{
	box-shadow: unset;
}
.info{
	background-size: 7px 7px;
	background-image: repeating-linear-gradient(135deg, var(--text-color-10) 0, var(--text-color-10) 3px, transparent 0, transparent 50%);
	color: var(--main-text-color);
	margin-bottom: 1.8em;
	padding: 3% 5%;
}
.lb-container{
	box-sizing: unset;
}
a.linkcard{
	background-color: var(--main-bg-color);
	border-radius: var(--radius-mini);
	box-shadow: var(--shadow);
	display: grid;
	font-weight: normal;
	grid-template-columns: 1fr 2fr;
	margin-bottom: 2rem;
	text-decoration: none;
	img{
		aspect-ratio: 1.91 / 1;
		border-radius: var(--radius-mini) 0 0 var(--radius-mini);
		box-shadow: none;
		height: 100%;
		margin: 0;
		object-fit: cover;
		object-position: 50% 0%;
		width: 100%;
	}
	div.emoji{
		background-color: var(--accent-30);
		display: grid;
		place-content: center;
	}
	img.emoji{
		aspect-ratio: 1 / 1;
		height: 4rem;
		width: 4rem;
	}
	div.text{
		padding: 3% 5%;
	}
	h3{
		text-box: trim-start text;
	}
}
.red{
	color: var(--red);
}
.small{
	font-size: 0.85em;
}
ul.characters{
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr 1fr 1fr;
	padding-left: 0;
	li{
		font-size: 0.85rem;
		list-style: "";
	}
	img{
		border-radius: calc(infinity * 1px);
		width: 5rem;
	}
}


/* MARK: footer
--------------------------------------------*/
.credit{
	color: var(--text-color-70);
	font-size: 0.75rem;
	padding-top: 3rem;
	text-align: center;
}


/* MARK: lightbox
--------------------------------------------*/
.lb-data .lb-close{
	display: none;
}
.lightbox .lb-image{
	border: none;
	border-radius: 0;
}
.lb-outerContainer{
	background-color: transparent;
}


/* MARK: responsive
--------------------------------------------*/
@media (max-width:800px) {
	body{
		grid-template-columns: 1fr;
	}
	header img:not(.emoji){
		width: 40%;
	}
	.book p{
		font-size: 0.9rem;
	}
}
@media (max-width:600px) {
	body{
		margin-top: 20vw;
	}
	header img:not(.emoji){
		width: 70%;
	}
	a.linkcard{
		grid-template-columns: 1fr;
		img{
			border-radius: var(--radius-mini) var(--radius-mini) 0 0;
		}
		div.emoji{
			aspect-ratio: 3 / 1;
		}
		p{
			font-size: 0.9rem;
		}
	}
	.gallery{
	    grid-gap: 1rem 0.5rem;
	    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
	}
	ul.characters{
		grid-template-columns: 1fr;
		img{
			float: left;
			margin-right: 1.5rem;
		}
	}
}


/* MARK: utility
--------------------------------------------*/
.mb0{	margin-bottom: 0 !important; }
.mb05{	margin-bottom: 0.5rem !important; }
.mb1{	margin-bottom: 1rem !important; }
.mb2{	margin-bottom: 2rem !important; }
.mb3{	margin-bottom: 3rem !important; }
.mb4{	margin-bottom: 4rem !important; }
.mt0{	margin-top: 0 !important; }
.mt05{	margin-top: 0.5rem !important; }
.mt1{	margin-top: 1rem !important; }
.mt2{	margin-top: 2rem !important; }
.mt3{	margin-top: 3rem !important; }
.mt4{	margin-top: 4rem !important; }