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

/*
	Tegalog skin by pipi
	https://pipi.noor.jp/t/
*/

/* reset css */
*,
*::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
}

nav ul {
	list-style-type: none;
	padding: 0
}

: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
}

:root {
	/* 色設定 */
	--body-bg: #f3f3f3;
	--sub-bg-color: #fff;
	--main-text-color: #333;
	--accent: #70a5ba;
	--red: #e53317;

	/* レイアウトボックスの角丸 */
	--radius: 10px;
	/* レイアウトボックスのドロップシャドウ */
	--shadow: 0px 2px 4px var(--text-color-20);
	/* メインのフォントファミリー */
	--main-font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Segoe UI", "Meiryo", sans-serif;
	/* コンテンツの最大横幅設定 */
	--article-width: 600px;

	/* 自動バリエーション設定（変更不要です） */
	--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);
	--accent-30: color-mix(in srgb, var(--accent) 30%, transparent);
	--accent-60: color-mix(in srgb, var(--accent) 60%, transparent);
	--radius-mini: calc(var(--radius) * 0.3);
}

/* 画像保存をしにくくする設定（不要なら削除OK、ここから） */
article a.imagelink,
article img.embeddedimage {
	pointer-events: none;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-moz-touch-callout: none;
	-moz-user-select: none;
	user-select: none;
}

/* 画像保存をしにくくする設定（ここまで） */

html {
	font-size: 100%;
}

body {
	accent-color: var(--accent);
	background: var(--body-bg);
	color: var(--main-text-color);
	font-family: var(--main-font-family);
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.8;
	margin: 0 5vw;
}

::marker {
	color: var(--text-color-50);
}

a {
	font-weight: bold;
}

a:hover {
	text-decoration: none;
}

img {
	object-position: top center;
	vertical-align: bottom;
}

textarea {
	font-size: 16px;
	/* iOS zoom対策 */
}


/* header -------------------------------------------- */
body>header {
	margin: 0 auto;
	max-width: var(--article-width);
	padding-block: 50px;
	text-align: center;

	h1 a,
	h2 a,
	.icons a {
		text-decoration: none;
	}

	h1 img {
		width: 72px;
	}

	h2.pagetitle {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.3;
		margin: 1rem 0 0.3rem;
	}

	p.pageinfo {
		font-size: 0.8rem;
		margin-bottom: 1em;
	}

	.category {
		margin-top: 1rem;
	}

	div.icons {
		display: flex;
		gap: 1rem;
		justify-content: center;
		line-height: 1;
		margin-top: 1rem;
	}

	div.icons a {
		color: var(--text-color-50);
		font-size: 0.7em;
		letter-spacing: 0.05em;
		opacity: 1;
		text-align: center;
	}

	div.icons button {
		background-color: transparent;
		border: none;
		color: var(--text-color-50);
		font-size: 0.7em;
		font-weight: bold;
		letter-spacing: 0.05em;
		padding: 0;
	}

	div.icons img {
		display: block;
		margin: 0 auto 5px;
		width: 30px;
	}

	div.icons i {
		display: block;
		margin: 0 auto;
		font-size: 30px;
	}

	details.postarea {
		background-color: var(--accent-30);
		border-radius: var(--radius);
		margin: 1rem auto 0;
		text-align: left;
	}

	summary {
		font-weight: bold;
		padding: 3.5% 5%;
	}
}

#popover::backdrop {
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(2px);
}

#popover {
	background-color: var(--sub-bg-color);
	border: none;
	border-radius: var(--radius);
	margin: auto;
	max-width: 400px;
	padding: 3rem;
	position: relative;
	text-align: right;
	width: 90%;

	button {
		position: absolute;
		right: 10px;
		top: 10px;
	}

	.searchinputs {
		display: flex;
	}
}

#popover,
#popover::backdrop {
	animation: fadeIn 0.5s ease;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.category li {
	display: inline-block;
	margin-right: 5px;
}

.category li:last-child {
	margin-right: 0;
}

.category a,
a.categorylink {
	background-color: var(--text-color-30);
	border-radius: var(--radius-mini);
	display: inline-block;
	font-size: 0.85rem;
	padding: 0 0.6em 0.1em;
	text-decoration: none;
	transition: background-color 0.3s ease-in-out;
}

.category a:hover,
a.categorylink:hover {
	background-color: var(--accent-60);
}

a.categorylink {
	margin-right: 5px;
}

.taglink+.num,
.catlink+.num,
.datelistlink+.num {
	display: none;
}


/* main-layout -------------------------------------------- */
.situation {
	color: var(--text-color-70);
	font-size: 0.9rem;
	margin-bottom: 1rem;
	text-align: center;
}

.situation:empty {
	display: none;
}

.situation::before {
	font-family: "Line Awesome Free";
	font-weight: 900;
	font-size: 1.4rem;
	vertical-align: text-top;
	margin-right: 5px;
	line-height: 1;
}

body.selected-tag .situation::before {
	content: "\f02c";
}

body.selected-cat .situation::before {
	content: "\f187";
}

body.search-result .situation::before {
	content: "\f002";
}

body.selected-date .situation::before {
	content: "\f133";
}

body.mode-gallery.nofiltering .situation {
	display: none;
}


/* ギャラリーモード用 */
body.mode-gallery .articlelist {
	display: grid;
	gap: 2rem 1rem;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	margin: 0 auto 5rem;
	max-width: var(--article-width);

	article {
		background-color: var(--sub-bg-color);
		border-radius: var(--radius);
		display: flex;
		flex-direction: column;
		/* box-shadow: var(--shadow); */
		height: 100%;
		margin-bottom: 0;
		padding: 0;
		position: relative;
	}

	article>a {
		aspect-ratio: 1 / 1;
		display: block;
		text-decoration: none;
	}

	.imagearea {
		aspect-ratio: 1 / 1;
		background-color: var(--text-color-30);
		border-radius: var(--radius);
		overflow: hidden;
		position: relative;
	}

	.imagearea img {
		aspect-ratio: 1 / 1;
		border-radius: var(--radius) var(--radius) 0 0;
		object-fit: cover;
	}

	.articleinfo {
		/* flex-grow: 1; */
		font-size: 0.85rem;
		/* line-height: 1.5; */
		/* padding: 0.7em 1em; */
	}

	div:has(> a.categorylink) {
		padding-top: 2px;
	}

	a.categorylink {
		font-size: 0.75rem;
		margin-bottom: 3px;
		padding: 0.1em 0.3em 0.2em;
	}

	.date {
		color: var(--text-color-70);
		font-size: 0.75rem;
		padding: 0 0.85rem 0.7em;
		display: flex;
		justify-content: space-between;
	}

	figure.nsfw {
		overflow: hidden;
		width: 100%;
	}

	figcaption {
		display: none;
	}

	article.logstatus-lock div.imagearea::before,
	div.imagearea:has(img.nsfw)::before {
		font-family: 'Line Awesome Free';
		font-size: 2rem;
		line-height: 1;
		margin: auto;
		position: absolute;
		top: calc(50% - 0.5em);
		left: calc(50% - 0.5em);
	}

	article.logstatus-lock div.imagearea::before {
		content: "\f023";
	}

	div.imagearea:has(img.nsfw)::before {
		content: "\f06a";
		z-index: 1000;
	}

	img.nsfw {
		filter: blur(10px);
		opacity: 0.5;
	}
}

body.mode-gallery .articlelist:has(> :nth-child(7)) {
	max-width: 1200px;
}

/* 何のモードも指定されていない状態 */
body.mode-view main {
	max-width: var(--article-width);
	margin: 0 auto;

	article {
		background-color: var(--sub-bg-color);
		border-radius: var(--radius);
		/* box-shadow: var(--shadow); */
		margin-bottom: 5rem;
		position: relative;
	}

	header {
		padding: 30px 30px 0;
	}

	header:empty {
		padding: 15px 30px 0;
	}

	article .comment {
		padding: 15px 30px 0;
		text-align: center;
	}

	article footer {
		display: flex;
		font-size: 0.8rem;
		gap: 1rem;
		justify-content: flex-end;
		margin-top: 2rem;
		padding: 0 30px 30px;
	}

	article footer a {
		text-decoration: none;
	}

	article footer span.reaction {
		flex-grow: 1;
	}

	article footer span.reaction img {
		width: 1rem;
	}

	.tooltip {
		position: relative;
	}

	.tooltip-text {
		display: inline-block;
		font-size: 0.8rem;
		left: 25px;
		line-height: 1.3;
		opacity: 0;
		padding: 5px;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		transition: 0.3s ease-in;
		visibility: hidden;
		white-space: nowrap;
	}

	.tooltip:hover .tooltip-text {
		opacity: 1;
		visibility: visible;
	}

	article.logstatus-lock:before {
		content: "\f023";
		font-family: 'Line Awesome Free';
		font-weight: 900;
		font-size: 1.3em;
		position: absolute;
		right: 1rem;
		top: -20px;
	}

	article.logstatus-fixed:before {
		content: "\f08d";
		font-family: 'Line Awesome Free';
		font-weight: 900;
		font-size: 1.3em;
		position: absolute;
		right: 1rem;
		top: -20px;
	}
}

nav.pagenums {
	text-align: center;
	font-weight: bold;

	a {
		background-color: var(--text-color-30);
		border-radius: var(--radius-mini);
		color: var(--main-text-color);
		display: inline-block;
		letter-spacing: 0;
		margin-bottom: 5px;
		min-width: 2em;
		padding: 0 0.3em 0.2em;
		text-decoration: none;
		transition: background-color 0.3s ease-in-out;
	}

	a:hover {
		background-color: var(--accent-60);
	}

	a.pagenumhere {
		background-color: var(--main-text-color);
		color: var(--sub-bg-color);
	}

	a.nextlink {
		clip-path: polygon(0 50%, 15% 0, 100% 0, 100% 100%, 15% 100%);
		padding-inline: 1.5em 1em;
	}

	a.prevlink {
		clip-path: polygon(0 0, 85% 0, 100% 50%, 85% 100%, 0 100%);
		padding-inline: 1em 1.5em;
	}
}

.one .pagenums {
	display: none;
}
body.onelog .pagenums { display: none; }

.nodata,
.nolist,
body.mode-gallery .recountlink {
	background-color: var(--sub-bg-color);
	border-radius: var(--radius);
	/* box-shadow: var(--shadow); */
	padding: 3rem 5%;
}

body.mode-view .recountlink {
	margin-top: 1rem;
	text-align: center;
}

.utilitylinks {
	font-size: 0.85rem;
	margin: -3rem 0 3rem;
}

.backto {
	font-size: 0.9rem;
	margin-top: 1rem;
	text-align: center;
}


/* article -------------------------------------------- */
body.mode-view article .comment {
	img.embeddedimage {
		display: block;
		margin: 0;
		width: 100%;
	}

	a.imagelink {
		display: block;
		line-height: 1;
		margin: 2rem -30px;
	}

	a.imagelink+a.imagelink {
		margin: -2rem -30px 2rem;
	}

	.decorationS a.imagelink {
		display: inline;
		margin: 0;
	}

	.decorationS img.embeddedimage {
		display: inline;
		margin: 3px 0;
		width: unset;
	}

	figcaption a {
		color: var(--text-color-70);
		font-weight: normal;
	}

	a:not(.cardlink)[target~="_blank"]::after {
		content: " \f35d";
		font-family: 'Line Awesome Free';
		font-weight: 900;
	}

	a.uc-btn,
	a.readmorebutton {
		background-color: var(--main-text-color);
		border-radius: var(--radius-mini);
		color: var(--sub-bg-color);
		display: inline-block;
		font-size: 0.9rem;
		margin: 3px 0;
		padding: 0.1em 0.6em 0.2em;
		text-decoration: none;
		transition: background-color 0.3s ease-in-out;
	}

	a.uc-btn:hover,
	a.readmorebutton:hover {
		background-color: var(--accent);
	}

	a.readmoreclose {
		background-color: transparent;
		border-top: 1px solid var(--text-color-20);
		color: var(--text-color-50);
		display: block;
		font-size: 0.8em;
		margin: 2rem 0;
		text-align: right;
	}

	a.readmoreclose:hover {
		background-color: transparent;
		color: var(--accent);
	}

	q.decorationQ {
		background-color: var(--text-color-15);
		padding: 1em 2em;
		font-size: 0.9rem;
		margin: 0.5em 0;
		position: relative;
	}

	q.decorationQ:before {
		content: "\f10d";
		font-family: 'Line Awesome Free';
		font-weight: 900;
		color: var(--text-color-70);
		position: absolute;
		left: 6px;
		top: 0;
	}

	q.decorationQ:after {
		content: "\f10e";
		font-family: 'Line Awesome Free';
		font-weight: 900;
		color: var(--text-color-70);
		position: absolute;
		right: 6px;
		bottom: 0;
	}

	figcaption {
		color: var(--text-color-70);
		font-size: 0.85rem;
		line-height: 1.5;
		margin: -1.5em 0 2em;
	}

	code {
		background-color: var(--text-color-20);
		border-radius: var(--radius-mini);
		font-size: 0.9em;
		padding: 0.2em 0.5em;
	}

	iframe.embeddedmovie {
		max-width: 100%;
	}

	.decoration1 {
		display: none;
		/* 汎用ボタン1：OGP画像の設定用 */
	}

	a.imagelink+br,
	.decorationL+br,
	.decorationQ+br {
		display: none;
	}

	/*-- 折り畳み機能対応 --*/
	details {
		margin-block: 0.5em;

		::marker {
			color: var(--text-color-70);
		}

		summary {
			background-color: var(--text-color-15);
			border-radius: var(--radius-mini);
			font-size: 0.9rem;
			font-weight: bold;
			padding: 0.1em 0.6em 0.2em;
		}

		.foldedarea {
			border-bottom: 5px solid var(--text-color-15);
			border-radius: var(--radius-mini);
			padding: 1em 0;
		}

		details {
			margin: 1em;
		}
	}
}


/* cardlink -------------------------------------------- */
.cardlink {
	display: inline-block;
	font-size: 0.9rem;
	font-weight: normal;
	margin: 0.5em auto;
	text-decoration: none;
	vertical-align: middle;
	text-align: center;
	width: 100%;
}

.cardlink::before {
	display: none;
}

.cardlinkbox {
	border: 1px solid var(--text-color-50);
	border-radius: var(--radius-mini);
	display: flex;
}

.cardlinkimage {
	aspect-ratio: 1.91 / 1;
	background-image: url(imgforskin/noimage.png);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	border-radius: var(--radius-mini) 0 0 var(--radius-mini);
	height: auto;
	width: 100%;
}

.cardlinktextbox {
	display: flex;
	flex-direction: column;
	padding: 0.7em 1em 1em;
}

.cardlinktitle,
.cardlinkdescription,
.cardlinkurl {
	display: -webkit-box;
	/* -webkit-line-clampを使うために必要な記述 */
	line-clamp: 1;
	/* 1行だけ見せる (将来的にはこれだけで実現可能かも) */
	overflow: hidden;
	/* 表示量を制限する場合に必須の記述 */
	text-overflow: ellipsis;
	/* 省略記号(三点リーダー) */
	-webkit-line-clamp: 1;
	/* 1行だけ見せる (今のブラウザにはこちらが必要) */
	-webkit-box-orient: vertical;
	/* -webkit-line-clampを使うために必要な記述 */
}

.cardlinktitle {
	font-weight: bold;
}

.cardlinkdescription {
	line-height: 1.4;
	color: var(--text-color-70);
	line-clamp: 2;
	-webkit-line-clamp: 2;
}

.cardlinkurl {
	border-top: 1px dotted var(--text-color-50);
	color: var(--text-color-70);
	font-size: 0.8em;
	margin-top: 0.5em;
	padding-top: 0.2em;
}

.cardsize-S {
	flex-direction: row;

	.cardlinkimage {
		border-radius: var(--radius-mini) 0 0 var(--radius-mini);
		height: 120px;
		width: unset;
	}

	.cardlinktextbox {
		border-left: 1px solid var(--text-color-50);
		flex: 1;
		justify-content: center;
		padding: 0em 1em;
	}
}

@media (max-width: 599px) {
	.cardsize-S {
		font-size: 0.85rem;
	}

	.cardsize-S .cardlinkimage {
		aspect-ratio: 1 / 1;
	}
}

.cardlink:has(.cardsize-L) {
	max-width: 450px;
}

.cardsize-L {
	flex-direction: column;

	.cardlinkimage {
		border-radius: var(--radius-mini) var(--radius-mini) 0 0;
	}

	.cardlinktextbox {
		border-top: 1px solid var(--text-color-50);
	}
}


/* parts -------------------------------------------- */
img.emoji,
.comment img.emoji {
	width: 1em;
	vertical-align: middle;
	margin: 0 3px 3px;
}

img.circle {
	border-radius: calc(infinity * 1px);
}

em,
.searchword {
	font-style: normal;
	font-weight: bold;
	margin-inline: 0.1em;
	text-decoration: underline;
	text-decoration-skip-ink: none;
	text-decoration-thickness: 0.5em;
	text-underline-offset: -0.2em;
}

em {
	filter: saturate(200%);
	text-decoration-color: var(--accent-30);
}

.searchword {
	background-color: transparent;
	color: currentColor;
	text-decoration-color: rgba(222, 222, 0, 0.5);
}

.decorationM {
	padding: 0 0.2em;
}

.decorationS,
.smalltext {
	font-size: 0.85rem;
}

.decorationT {
	font-size: 0.7rem;
}

ul.decorationL {
	list-style-type: disc;
	padding-left: 1.5rem;
	list-style-position: outside;
	margin: 0.5em 0;
}


/* input -------------------------------------------- */
select,
input.queryinput,
input.passkeyinput {
	background-color: transparent;
	border: 1px solid var(--main-text-color);
	border-radius: var(--radius-mini) 0 0 var(--radius-mini);
	color: var(--main-text-color);
	height: 2rem;
	width: calc(100% - 3rem);
}

input[type="submit"],
input[type="button"],
.postarea input[type="text"] {
	background-color: var(--main-text-color);
	border: none;
	border-radius: var(--radius-mini);
	color: var(--sub-bg-color);
	cursor: pointer;
	font-size: 0.9rem;
	height: 2rem;
	letter-spacing: 2px;
	padding: 0 0.5rem 0 0.6rem;
}

input[type="submit"]:hover,
input[type="button"]:hover {
	background-color: color-mix(in srgb, var(--accent) 50%, var(--main-text-color));
}

input[type="submit"] {
	border-radius: 0 var(--radius-mini) var(--radius-mini) 0;
}

form.passkeyform {
	margin: 2rem 0;

	span.passkeyguide {
		display: block;
		margin-bottom: 0.3em;
	}

	input.passkeyinput {
		padding-left: 0.5em;
		vertical-align: bottom;
		width: calc(100% - 7rem);
	}

	input.passkeysubmit {
		border-radius: 0 var(--radius-mini) var(--radius-mini) 0;
		padding: 0 0 2px;
		vertical-align: bottom;
		width: 7rem;
	}
}




/* postform -------------------------------------------- */
form.postform {
	padding: 0 5%;

	input {
		font-weight: normal;
		margin: 2px;
		vertical-align: inherit;
	}

	input[type="text"] {
		border-radius: var(--radius-mini) var(--radius-mini) 0 0;
		margin: 0;
	}

	textarea.tegalogpost {
		background-color: var(--sub-bg-color);
		border: none;
		border-radius: 0;
		color: var(--main-text-color);
		field-sizing: content;
		min-height: 10rem;
		padding: 0.2em 0.6em;
		resize: vertical;
		vertical-align: middle;
		width: 100%;
	}

	.submitcover {
		display: block;
		margin-bottom: 1em;
		text-align: right;
	}

	input.postbutton {
		background-color: var(--accent);
		border-radius: 0 0 var(--radius-mini) var(--radius-mini);
		font-size: 1rem;
		font-weight: bold;
		letter-spacing: 2px;
		margin: 0;
		width: 50%;
	}

	.line-control {
		font-size: 0.9rem;
	}

	input[type="button"] {
		letter-spacing: 1px;
	}

	input[type="checkbox"] {
		vertical-align: text-bottom;
		height: 1em;
	}

	select {
		margin: 2px 0 2px 2px;
		vertical-align: middle;
		width: unset;
	}

	select+input[type="button"] {
		border-radius: 0 var(--radius-mini) var(--radius-mini) 0;
		margin-left: 0;
		width: unset;
	}

	input[type="file"] {
		border: 1px solid var(--main-text-color);
		border-radius: var(--radius-mini);
		height: 2rem;
	}

	::file-selector-button {
		background-color: var(--main-text-color);
		border: none;
		color: var(--sub-bg-color);
		cursor: pointer;
		margin-right: 0.7em;
		padding: 0.7em;
		text-box-edge: cap alphabetic;
		text-box-trim: trim-both;
	}

	label:has(input[name="category"]) {
		background-color: var(--text-color-30);
		border-radius: var(--radius-mini);
		display: inline-block;
		font-weight: bold;
		margin: 2px 5px 2px 0;
		padding-inline: 5px;
	}

	.catChecks {
		margin-right: 1em;
	}

	.decoBtns {
		display: inline-block;
		margin: 0 0 5px;
		vertical-align: middle;
	}
}

div.QP_footer {
	padding: 0 5% 3.5%;
	text-align: right;
}


/* aside -------------------------------------------- */
aside {
	display: grid;
	gap: 0 3rem;
	grid-template-columns: repeat(2, 1fr);
	margin: 5rem auto 0;
	max-width: var(--article-width);

	section>div,
	section>nav:not(:empty),
	section form:not(:empty) {
		margin-bottom: 1rem;
	}

	.freespace {
		border: 1px solid var(--text-color-50);
		border-inline: none;
		font-size: 0.9rem;
		padding: 1em 0;

		.author {
			font-weight: bold;
		}
	}

	.freespace-edit {
		margin: -1rem 0 0;
		text-align: right;
	}

	h2 {
		font-size: 0.8rem;
		font-weight: normal;
		padding: 0 0 0.4em;
		text-align: left;
	}

	ul.depth2 {
		display: inline-block;
	}

	ul.depth2 li {
		margin-right: 0;
	}

	ul.depth2 a {
		background-color: var(--text-color-20);
		margin-left: 1px;
	}

	.catpullbox,
	.datelimitbox,
	.hashtagpullbox,
	.searchinputs {
		display: flex;
	}

	.hashtaglist li {
		display: inline-block;
		padding-right: 0.5em;
		font-size: 0.85rem;
		font-weight: bold;
	}

	.hashtaglist li:before {
		content: '#';
		color: var(--text-color-50);
	}

	.datelimitboxoptions {
		display: none;
	}

	table.calendar {
		width: 100%;
		border-collapse: collapse;
		text-align: center;
		line-height: 2;
		font-size: 0.8rem;
		margin-top: 1.5rem;
	}

	caption {
		line-height: 1;
		padding-bottom: 0.8em;
		text-align: left;
	}

	.calendar thead {
		background-color: var(--text-color-15);
	}

	.calendar tr {
		border-bottom: 1px solid var(--text-color-30);
	}

	.calendar tr:last-child {
		border-bottom: none;
	}

	.calendar .sun,
	.calendar .sat {
		background-color: var(--sub-bg-color);
	}

	.calendar .today {
		background-color: var(--accent-30);
	}

	.calendar a {
		font-weight: bold;
		display: block;
	}

	.calendar span.nolink {
		color: var(--text-color-50);
	}

	.calbtm {
		display: flex;
		font-size: 0.8rem;
		justify-content: space-between;
		margin-top: 0.3rem;
	}

	.calbtm a,
	.calendar a {
		text-decoration: none;
	}
}


/* footer -------------------------------------------- */
body>footer {
	font-size: 0.8rem;
	max-width: var(--article-width);
	margin: 2rem auto 5rem;
	text-align: center;
}


/* responsive -------------------------------------------- */
@media (max-width: 599px) {
	body {
		margin: 0 0;
	}

	body>header,
	body.mode-gallery main,
	body>aside,
	body>footer {
		padding-inline: 5vw;
	}

	details.postarea[open] {
		border-radius: 0;
		margin-inline: -5vw;
	}

	body.mode-view main article,
	body.mode-view .nodata,
	body.mode-view .nolist {
		border-radius: 0;
	}

	aside {
		display: block;
	}
}