@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: 0px;
}
.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) var(--radius) 0 0;
		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;
	}
	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;
	}
}
.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 0;
	text-decoration: none;
	vertical-align: middle;
	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;
	}
}