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

/* スキン「aien」配布用 */

*,*::before,*::after { box-sizing: inherit;}
html { box-sizing: border-box; scroll-behavior: smooth;}
h1,h2,h3,h4,h5,img,p,ul,ol { margin: 0; padding: 0;}
img { border: none;}

/* -------------------- */
/* カスタム用色変更欄 */
/* -------------------- */
:root{
	--haikei-iro: #f4f4f4; /* 全体背景色 */
	--naiyou-iro: #f4f4f4; /* コンテンツエリアの背景色 */
	--koi-iro: #000000; /* 濃いアクセント色 */
	--usu-iro: #cbaca7; /* 薄いアクセント色 */
	--mozi-iro: #3e3c3c; /* メイン文字色 */
	--usu-mozi-iro: #a5a0a0; /* ↑よりちょっと薄い文字色など */
	--siro-mozi: #fefefe; /* 濃い背景に乗せる白文字色 */
	--link-iro: #758b74; /* リンクの色など */
	--link-hover-iro: #576756; /* リンクにマウス乗せたときの色と強調の下線色 */
	--iconfont: "remixicon"; /* アイコンフォントの名前 */
	--titlefont: 'Raleway','Noto Sans JP',sans-serif; /* タイトルなどのフォントの名前 */
}

/* 全体共通装飾 */
body {
	font-size: 0.9rem;
	line-height: 1;
	font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
	margin: 0;
	padding: 0;
	background-color: var(--haikei-iro);
	color: var(--mozi-iro);
	overflow-wrap: break-word;
}

/* リンクの装飾 */
a { text-decoration: none; color: var(--link-iro); }
a:hover { color: var(--link-hover-iro);}

/* E:強調(Emphasis) */
.decorationE {
	font-style: normal;
	font-weight: bold;
	background: linear-gradient(transparent 60%, #7bbdbd 60%);
}

/* I:斜体(Italic) */
.decorationI {
	font-family: 'Hiragino Kaku Gothic ProN','游ゴシック';
	font-style: italic;		/* 斜体 */
}

/* Q:引用(Quote) */
.decorationQ {
	margin: 1rem;
	padding: 1.3rem;
	border: 2px solid var(--link-iro);
	border-left: 15px groove var(--link-iro);
	display: block;	/* ※Ver 2.2.0以降必須の記述 */
}
.decorationQ::before,.decorationQ::after { content: ''; } /* 標準で付加されてしまう引用符を無効にする */
.decorationQ + br { display: none; } /* 引用直後の改行を無効化する */

/* T:極小文字(Tiny) */
.decorationT { font-size: 0.6rem;}

/* URLが書かれた場合の装飾 */
.url { word-break:break-all;} /* 自動リンクのはみ出しを防ぐ */

/* 埋め込み画像 */
div.imagebox{ margin: 0; padding: 0; line-height:1; font-size: 0;} /* 画像の下の謎の空白を消す */

/* 画像ボックス(FIGオプション指定時) */
.embeddedpictbox {
	margin: 0;
	padding: 0;
	display: inline-table;
	border-collapse: collapse;
	border: none;
	vertical-align: top;
}

/* キャプション */
.embeddedpictbox figcaption {
	padding: 0.2rem;
	display: table-caption;	
	caption-side: bottom;
	font-size: 0.8rem;
	color: var(--usu-mozi-iro);
	line-height: 1.5;
}

/* 画像ボックスに含まれる画像 */
.embeddedpictbox img { vertical-align: middle;}

/* 画像リンク */
.imagelink {
	display: inline-block;
	line-height: 1;	/* 表示形態によっては画像の下に余計な空白が出るのを防ぐ対策 */
/* vertical-align: inherit;	同上 */
	font-size: 0;
	vertical-align: top;
}

/* 画像そのもの */
.embeddedimage {
	max-width: 100%;	/* 横方向にはみ出ないようにする */
	height: auto;	/* 高さを固定したい場合を除いて、ここは auto のままにするのがお勧め */
}

/* フラグ付き画像 (※設定や採用記法によって出力パターンが複数あるため、あらゆるパターンに対応させるべく同じスタイルを2重に指定しています。) */
figure.nsfw {
	overflow: hidden;	/* ぼかし領域がfigureのボックスからはみ出ないようにする */
	position: relative;
}
.imagelink.nsfw {
	overflow: hidden;	/* ぼかし領域がfigureのボックスからはみ出ないようにする */
	position: relative;
}
img.nsfw {
	filter: blur(30px) brightness(0.5);	/* ぼかして暗くする */
	width: 200px; /* NSFW画像のサイズ */
	height: 200px;
	object-fit: cover;
}

/* NSFWマークを重ねる */
.imagelink.nsfw::after{
	content:"\EA20";
	font-family: var(--iconfont);
	font-size: 60px;      
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
}

/* 埋め込み動画 */
.embeddedmovie{
	display: inline-block;
	aspect-ratio: 16 / 9;
	width: 100%;
	max-width: 500px;
	height: auto;
}

/* 埋め込みTweet(埋め込み前処理用) */
blockquote.twitter-tweet {
	background-color: #f8f8f8;
	border: 1px dashed #ddd;
	border-radius: 9px;
	margin: 0.3rem 0;
	padding: 1rem;
	font-size: 0.95rem;
	color: #999;
	text-shadow: 1px 1px 1px #fff;
}

/* 埋め込みツイートの横幅を強制的に制限 */
div.twitter-tweet { max-width: 350px !important;}

/* 検索語のハイライト */
.searchword { font-weight: bold; text-decoration: underline 2px double var(--link-hover-iro);}

/* ホームと管理ボタン固定タブ */
.toptab {
	position: fixed;
	top: 0;
	z-index: 50;
	width: min(800px,100%);
	margin: 0 auto;
	padding: 0;
	pointer-events: none;
}
.toptab a {
	margin: 0.2rem 0 0.2rem auto;
	display: block;
	width: fit-content;
	padding: 1rem 0.2rem 1rem 0.5rem;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 1.2rem;
	border-radius: 50% 0 0 50%;
	pointer-events: auto;
}
.toptab a:hover { background-color: var(--usu-iro);}

/* サイトホームボタンのテキスト消してアイコン入れる */
.homelink a { font-size: 0;}
.homelink a::before {
	content: '\EE1C';
	font-family: var(--iconfont);
	font-size: 1.2rem;
}

/* header,mainarea,footerまとめたエリア */
.bodyarea{
	margin: 0 auto;
	padding: 0;
	width: min(100%,800px);
	position: relative;
	background-color: var(--naiyou-iro);
}

/* ページ最上部(ヘッダ)領域 */
header {  
	position: relative;
	margin: 0 auto 3.5rem;
	padding: 1.8rem 1.5rem 1rem;
	width: 250px;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
	text-align: center;
	color: var(--siro-mozi);
	background: var(--koi-iro);
}

header::after {/* 旗形状の下の三角部分 */
	content: '';
	position: absolute;
	left: 0;
	top: 100%;
	height: 0;
	width: 0;
	border-left: 125px solid transparent;
	border-right: 125px solid transparent;
}

/* ヘッダー画像の横幅 */
.headimg {
	display: block;
	width: 180px;
	margin: 0 auto;
}
.headimglink { display: inline-block;}

/* タイトル部分 */
.headtitle {
	margin-top: 1rem;
	line-height: 1.3;
	overflow-wrap: break-word;/*↓2行 日本語改行タイミングの調整 */
	word-break: keep-all;
}
.maintitle { font-size: 1.5rem;}
.maintitlelink { color: var(--siro-mozi);}
.subtitle { font-size: 0.8rem; font-weight: bold; }
.mainguide { font-size: 0.8rem; margin-top: 0.7rem;}
.subtitle,.mainguide { &:empty { display: none;}}

/* メイン領域 */
.mainarea { margin: 0 auto; padding: 0;}

/* QUICKPOST装飾 */
.postform {
	border: 1px solid var(--usu-mozi-iro);
	margin: 0 1.5rem 1.5rem;
	padding: 1rem;
}

/* 本文入力欄 */
textarea.tegalogpost {
	border: 1px var(--usu-mozi-iro) solid;
	background-color: #fefefe;
	color: #242424;
	padding: 0.5rem;
	box-sizing: border-box;
	width: 100%;
	height: 4.3rem;
	overflow-wrap: break-word;
	overflow: auto;
	font-size: 1rem;
	font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
	line-height: 1.5;
}

/* 投稿コントロール部分(ボタンや字数カウンタなど) */

/* 投稿ボタン */
.postbutton {
	display: inline-block;		/* インラインブロック化 */
	background: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 0.9rem;
	text-decoration: none;
	padding: 5px 15px;
	border: none;
	cursor: pointer;
}

/* 投稿ボタンにマウスが載ったとき */
.postbutton:hover { background-color: var(--usu-iro);}

/* 文字装飾ボタン群 */
/* 掲載領域全体 */ .decoBtns { display: inline-block; margin-top: 5px; }
/* 全ボタン装飾 */ 
.decoBtns input {
	min-width: 32px;
	min-height: 28px;
	margin:1px;
	color: #242424;
	background-color: #fefefe;
	border: 1px solid var(--usu-mozi-iro);
	cursor: pointer;
	border-radius: 3px;
	font-size: 0.8rem;
	vertical-align: middle;
}
/* マウス載る際 */ .decoBtns input:hover{ border: 1px dotted var(--usu-mozi-iro);}
/* 太字  :B */ .decoBtnB { font-weight: bold; }
/* 取消線:D */ .decoBtnD { text-decoration: line-through;}
/* 強調  :E */ .decoBtnE { font-weight: bold; background: linear-gradient(transparent 60%, var(--link-hover-iro) 60%); }
/* 斜体  :I */ .decoBtnI { font-style: italic; font-family: 'Hiragino Kaku Gothic ProN','游ゴシック';}
/* 極小  :T */ .decoBtnT { font-size: 11px !important; }
/* 下線  :U */ .decoBtnU { text-decoration: underline;}
/* 文字色:C */ .decoBtnC { color: red !important; }
/* 背景色:M */ .decoBtnM { background-color: greenyellow !important; }

/* カテゴリ選択チェックボックス群 */
.catChecks { font-size:0.9rem; padding-top: 0.5rem; }
.catChecks label { display:inline-block; cursor:pointer; margin:0 0.75rem 0 0; }
.catChecks label:hover { text-decoration:underline; }
.catChecks input { min-width:0; min-height:0; margin-right:0.2rem; }

/* 投稿欄下部：「鍵付き」チェックボックスと「個別鍵」ボタンの間を詰める一時的なスタイル */
.funcUIs .catChecks { margin:0 0.75rem 0 0; }
.funcUIs .catChecks label { margin: 0; }

/*プルダウンの装飾*/
select {
	border:1px solid var(--usu-mozi-iro);
	border-radius: 3px;
	padding: 5px;
	background: #fefefe;
	color: #242424;
	box-shadow: none;
	cursor: pointer;
}

/*検索窓エリア*/
.searchboxarea { margin: 0 1.5rem 1.5rem; text-align: right;}
.queryinput {
	font-size: 1rem;
	vertical-align: middle;
	border: 1px solid var(--usu-mozi-iro);
	height: 1.8rem;
}
.searchbox .submitbutton {
	padding: 0 0.8rem;
	height: 1.8rem;
	border: 0px;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	cursor: pointer;
  }
.searchbox .submitbutton:hover { background-color: var(--usu-iro);}
.searchoption{ font-size: 0.8rem; color: var(--usu-mozi-iro);}

/* 表示対象の限定時などの「限定条件」表示行 */
.situation {
	margin: 0 1.8rem 1rem 1.8rem;
	font-size: 0.8rem;
	line-height: 1.3;
	color: var(--usu-mozi-iro);
}
.situation:empty { display: none;}
.nodata,.recountlink { margin: 0 1.8rem; line-height: 1.3;}

/* 日付境界バー(フリースペースのタイトル装飾も一緒に) */
.dateseparator,.fstitle { padding: 2rem 4rem 1rem;}
.datetitle,.fixedlabel,.fstitle {
	display:flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	color: var(--koi-iro);
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;

	&::before,&::after {
	content: "";
	flex-grow:1;
	height: 8px;
	background-image: repeating-linear-gradient(45deg, var(--koi-iro) 0, var(--koi-iro) 2px, transparent 0, transparent 50%);
	background-size: 8px 8px;}

	&::before { margin-right: 1rem;}
	&::after { margin-left: 1rem;}
}
/* 時系列順とファイル出力リンク(文字を消してアイコンを入れる) */
.datefunclinks {
	display: block;
	margin-top: 0.3rem;
	text-align: right;
}
.datereverse,.dateexport {
	font-size: 0;
	&::before {
	font-family: var(--iconfont);
	font-size: 20px;
	margin-right: 0.5rem;
	display: inline-block;}
}
.datereverse::before { content: "\EE16";}/* 時系列順アイコン */
.dateexport::before { content: "\ED5F";}/* ファイル出力アイコン */

/* 投稿ボックス(一発言)ごとの表示 */
.onelogbox,.galmainbox {/* ギャラリーモードの全体エリアも同じ装飾に */
	margin: 0 auto;
	padding: 1.5rem 1.8rem;
	border-bottom: 1px dashed var(--koi-iro);
	width: 100%;
}

/* 本文エリア */
.comment{
	margin-bottom: 1rem;
	line-height: 1.65;
	ul,ol { margin: 0.3rem 0; padding-left: 1rem;}
}

/* 投稿日時やカテゴリ名などの情報表示 */
.oneloginfo { line-height: 1.3; text-align: right;}
.datelink {
	display: inline-block;
	color: var(--usu-mozi-iro);
	margin-right: 0.5rem;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}
.editlink { font-size: 1.4rem; color: var(--koi-iro);}

/* 1記事内のカテゴリーの装飾 */
.categorylink { margin-right: 0.5rem;}

/* 記事内とリストのカテゴリーリンクの項目前にアイコンを付ける */
.categorylink::before,.catlink::before {
	content:"\ED89";
	font-family: var(--iconfont);
	margin-right: 0.1rem;
}

/* カテゴリ間のセパレータ */
.catseparator {
	display: inline-block;
	margin: 0 1px;			/* 左右に1pxの余白 */
	color: var(--usu-mozi-iro);			/* 文字色 */
}

/*続きを読むボタンと鍵フォーム送信ボタン*/
a.readmorebutton,.passkeysubmit {
	display: inline-block;
    border: 0px;
    color: var(--siro-mozi);
    background-color: var(--koi-iro);
    text-align: center;
    padding: 0.3rem 0.5rem;
	vertical-align: middle;
	cursor: pointer;
	&:hover { background-color: var(--usu-iro);}
}
.readmorebutton { margin: 0.2rem;}

/* 鍵付き(パスワード保護)投稿に表示される鍵入力フォームの装飾 */
.passkeyform {
	display: block;
	margin: 0;
	padding: 0.6rem;
}

/* 鍵違いエラーの表示 */
.passkeyerror {
	display: block;
	color: var(--siro-mozi);
	background-color: var(--koi-iro);
	font-weight: bold;
	line-height: 1.3;
	margin-bottom: 1rem;
	padding: 0.3rem 0.5rem;
}
.passkeybox { display: block; }/* 入力フォーム枠 */
.passkeyguide { display: block; margin-bottom: 1rem; } /* 入力欄前のガイド文 */
.passkeyinput { /* 鍵入力欄 */
	border: 1px solid var(--usu-mozi-iro);
	width: 10rem;
	height: 1.8rem;
	vertical-align: middle;
	font-size: 1rem;
	background-color: #fefefe;
	color: #242424;
}

/* 1記事下のユーティリティリンク群 */
.utilitylinks {
	padding: 1.5rem 1.8rem 2.5rem;
	line-height: 1.65;
}
.utilitylinks ul { padding-left: 1rem;}

/* ページナビゲーション領域 */
.pagenavi {
	margin-bottom: 1.5rem;
	padding: 1.5rem 1.8rem;
	text-align: center;
}

/* ページリンク */
.pagelinks {/* ページ番号と次前リンクを横並び */
	margin-bottom: 1.5rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 1px;
}
.prevlink,.nextlink,.pagenumlink,.omitmark {/* ページ番号の装飾 */
	display: block;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	min-width: 35px;
	height: 30px;
	line-height: 30px;
	text-align: center;
}
.prevlink,.nextlink { width: fit-content; padding: 0 0.8rem;}

 /* 現在のページ番号とマウスオーバー時の装飾 */	
.pagenumhere { background-color: var(--usu-iro); color: var(--siro-mozi);}
.prevlink,.nextlink,.pagenumlink {
	&:hover { background-color: var(--usu-iro); color: var(--siro-mozi);}
}

/* フリースペース */
.fstitle {
	padding-top: 0;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}
.fscont {
	padding: 0 1.8rem 1.5rem;
	line-height: 1.65;
}

/* ページ最下部(フッタ)領域 */
footer {
	padding: 1rem 2rem 3.5rem;
	text-align: center;
}
.poweredby { font-size: 0.8rem;}
footer i { font-size: 1.2rem; margin-right: 0.5rem; vertical-align: sub;}

/* 先頭固定記事の装飾 */
.onelogbox.logstatus-fixed .comment::before {
	content: '\EAE2';/* 固定記事につけるアイコン */
	font-family: var(--iconfont);
	font-size: 1.8rem;
	color: var(--koi-iro);
	display: block;
	line-height: 1;
	text-align: right;
	padding-right: 0.8rem;
	margin-bottom: 0.3rem;
	margin-top: -0.8rem;
}

/* 下固定メニュー */
.menuarea {
	width: min(800px,100%);
	position: fixed;
	bottom: 0;
	z-index: 100;
	min-height: 40px;
	backdrop-filter: blur(15px);
	margin: 0 auto;
	display: flex;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}
.menutab {
	flex-grow: 1;
	list-style: none;
	padding: 0.2rem;
	display: flex;
	align-items: center;
	justify-content: space-evenly;
	flex-wrap: wrap;
	gap: 0.2rem;
}
.menutab li a {
	display: block;
	text-align: center;
	color: var(--koi-iro);
	background-color: var(--naiyou-iro);
	padding: 0.2rem 0.5rem;
}
.menutab li a:hover { background-color: var(--koi-iro); color: var(--siro-mozi);}

/* 上に戻るボタン */
.ue_btn {
	display: grid;
	place-content: center;
	width: 40px;
	height: 40px;
	background: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 30px;
	flex-shrink: 0;
	align-self: flex-end;
}
.ue_btn:hover{ background-color: var(--usu-iro); color: var(--siro-mozi);}

/* モーダルメニュー */
/* モーダル全体(非表示にしておく) */
.modalw {
	position: fixed;
	inset: 0;
	z-index: 200;
	opacity: 0;
	visibility: hidden;
	transition: opacity .2s, visibility .2s;
	padding: 1.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* クリックしたとき表示される */
.modalw:target {
	opacity: 1;
	visibility: visible;
	transition: opacity .2s, visibility .2s;
}

/* 半透明黒背景 */
.modalbg {
	position: absolute;
	inset: 0;
	z-index: 199;
	background: rgba(0, 0, 0, 0.5)
}

/* モーダル中身 */
.modalnaka {
	position: relative;
	max-width: 600px;
	max-height: 80%;
	overflow-y: auto;
	z-index: 201;
	background-color: var(--naiyou-iro);
	padding: 2rem;
}

/* モーダル中身の閉じるボタン */
.modalclose {
	position: absolute;
	top: 0;
	right: 0;
	background-color: var(--link-iro);
	color: var(--siro-mozi);
	width: 30px;
	height: 30px;
	font-size: 1.3rem;
	display: grid;
	place-content: center;
}
.modalclose:hover { color: var(--siro-mozi); background-color: var(--link-hover-iro);}

/* モーダル中身のリストとかの装飾 */
.modalnaka {
/* カテゴリリスト */
.catmenu { margin: 0 auto 1.5rem; width: fit-content;}
.cattree {
	list-style: none;
	font-size: 1rem;
	padding-left: 1.3rem;
	line-height: 2;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}

/* ハッシュタグリスト */
.hashtaglist {
	margin-bottom: 1.5rem;
	line-height: 1.8;
	font-size: 1rem;
	text-align: center;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}
.hashtaglist li {
	display: inline-block;
	list-style: none;
	margin-right: 5px;
}
.taglink::before { content: '\23';}/* シャープ付ける */
.num { font-size: 0.8rem; color: var(--usu-mozi-iro);}/* 記事数まとめて装飾 */

/* 全年月リスト */
.datelimitbox .submitbutton {
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	padding: 5px 0.8rem;
	border: none;
	cursor: pointer;
}
.datelimitbox .submitbutton:hover { background-color: var(--usu-iro);}

/* 年月リストオプション非表示 */
.datelimitbox { text-align: center;}
.datelimitboxoptions,.datelimitlist .datelimitsublist .year { display: none;}
}
/* モーダル中身ここまで */
