@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+2:wght@600&display=swap');

/* スキン「hokan」配布用 */
/* 「てがろぐ標準スキン for Ver 4.1.0以降」を改変したスキンです */

*,*::before,*::after { box-sizing: inherit;}

html { box-sizing: border-box;}

h1,h2,h3,h4,h5,img,p { margin: 0; padding: 0;}

img { border: none;}

/* -------------------- */
/* カスタム用色変更欄 */
/* -------------------- */
:root{
	--haikei-iro:#5cbfcc; /* 全体背景色 */
	--mainarea-iro: #f2f2f2; /* コンテンツエリアの背景 */
	--mozi-iro: #272727; /* メイン文字色 */
	--usu-mozi-iro: #adadad; /* ↑よりちょっと薄い文字色、カテゴリリンクの色など */
	--siro-mozi: #fefefe; /* 濃い背景に乗せる白文字色 */
	--koi-iro: #2e5f66; /* 濃いアクセント色 */
	--usu-iro:  #f2f2f2; /* 薄いアクセント色 */
	--link-iro: #0068b7; /* リンクの色など */
	--link-hover-iro:#fcc800/* リンクにマウス乗せたときの色と強調のマーカー色 */
}

/* フォント指定 */
.maintitle,.onelogtitle,.freespacetitle,.ichititle,.deco-midasi1 {
	font-family: 'M PLUS 2', sans-serif;
}

/* ■全体共通装飾 */
body {
	font-size: 0.9rem;
	line-height: 1.5rem;
	font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
	margin: 0;
	padding: 0;
	background-color: var(--haikei-iro);
	color: var(--mozi-iro);
}

/* ▼リンクの装飾 */
a { text-decoration: none; color: var(--link-iro); }
a:hover { color: var(--link-hover-iro); }

/* リストの装飾(余白調整) */
ul,ol{ margin: 0.3rem 0; padding-left: 1.5rem;}

	/* E:強調(Emphasis) */
	.decorationE {
		font-style: normal;
		font-weight: bold;
		background: linear-gradient(transparent 60%, var(--link-hover-iro) 60%);
	}

	/* I:斜体(Italic) */
	.decorationI {
		font-family: 'Hiragino Kaku Gothic ProN','游ゴシック';
		font-style: italic;		/* 斜体 */
	}

	/* Q:引用(Quote) */
	.decorationQ {
		margin: 1rem;
		padding: 0.5rem;
		border: 1px solid var(--link-iro);
		border-left-width: 10px;
		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 5px;
			display: table-caption;	
			caption-side: bottom;
			font-size: 0.7rem;
			color: var(--usu-mozi-iro);
			line-height: 1rem;
		}

/* 画像ボックスに含まれる画像 */
.embeddedpictbox img { vertical-align: middle;}

	/* ▽画像リンク */
	.imagelink {
		display: inline-block;
		line-height: 1; /* 表示形態によっては画像の下に余計な空白が出るのを防ぐ対策 */
/* 		vertical-align: inherit;	同上 */
		vertical-align: top;
		font-size: 0; /*画像下の謎の隙間埋め*/
	}

	/* ▽画像そのもの */
	.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;
		aspect-ratio: 1;
		object-fit: cover;
}

      /* NSFWマークを重ねる */
	.imagelink.nsfw::after{
	content:"\EA20";
	font-family: "remixicon";
	font-size: 50px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--siro-mozi);
	}

	/* ▼埋め込み動画 */
	.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;
		background-color: var(--link-hover-iro);
	}

/* ヘッダーからフッターを囲むエリア */
.bodyarea {
	margin: 0 auto;
	padding: 0;
	width: min(100%,900px);
	display: grid;/* ↓4行 中身少なくてもフッターを下部固定する */
	grid-template-rows: auto 1fr auto;
	grid-template-columns: 100%;
	min-height: 100svh;
}

/* メイン領域 */
main { margin: 0; padding: 0; background-color: var(--mainarea-iro);}

/* ヘッダーメニュー装飾 */
header { position: sticky; position: -webkit-sticky; top: 0; z-index: 2000;}
.headmenu { margin: 0; padding: 0; overflow-x: auto;}
.maintitle { font-size: 1.5rem;}
.headmenu ul {
	background-color: var(--koi-iro);
	width: 100%;
	height: 45px;
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.headmenu li {
	display: flex;
	min-width: max-content;
	height: 100%;
	align-items: center;
	justify-content: center;
	background-color: var(--koi-iro);
}

.headmenu a {

	width: 100%;
	min-width: 45px;
	height: 100%;
	padding: 8px;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	color: var(--siro-mozi);
}
.headmenu a:hover { color: var(--link-hover-iro);}
.headmenu i { font-size: 20px; font-weight: normal;}

.headmenu select {
	padding: 8px;
	height: 50px;
	border: none;
	outline: none;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	font-weight: bold;
	cursor: pointer;
}

.headmenu li:first-child { margin-right: auto; border-left: 10px solid var(--koi-iro);}
.headmenu li:not(:first-child){ border-left: 1px solid var(--siro-mozi);}

/* HOMEへ戻るリンクのテキストを消してアイコンを挿入 */
.headmenu .homelink { font-size: 0;}
.headmenu .homelink a::before{
	content:'\EE1C';
	display: inline-block;
	font-family: "remixicon";
	font-size: 20px;
	font-weight: normal;
}

/* タグリストないけどリスト入れたいときのための先頭シャープ */
ul.hashtaglist .taglink::before{ content: '\23';}

/* ヘッダー画像 */
.headimgarea {
	margin: 0;
	width: 100%;
	aspect-ratio: 4 / 1;
	height: auto;
	background-image: url(/top/top.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
}

/* サブタイと概要文 */
.headtitle {
	position: absolute;
	top: 50%;
	right: 1.5rem;
	transform: translate(0%, -50%);
	text-align: right;
	color: var(--siro-mozi);
	text-shadow: 0 0 3px rgb(0, 0, 0); 
}
.subtitle{ font-weight: bold;}
.mainguide{ font-size: 0.8rem;}

/* ヘッダー画像を抜いたメイン領域　クイックポストからフリースペースまで */
.mainarea {
	width: 100%;
	margin: 0 auto;
	padding: 1rem 1rem;
}

/* QUICKPOST装飾 */
.postform { border: 1px solid var(--usu-mozi-iro); margin: 0 auto 1rem; padding: 1rem;}
.postform p { margin: 0;}

	/* ▼本文入力欄 */
	textarea.tegalogpost {
		border: 1px var(--usu-mozi-iro) solid;	/* 枠線 */
		background-color: #fefefe;	/* 背景色 */
		padding: 0.5rem;				/* 内側の余白量 */
		box-sizing: border-box;		/* サイズ解釈方法 */
		width: 100%;				/* 横幅 */
		height: 4.3rem;				/* 高さ */
		overflow-wrap: break-word;	/* 折り返し方法 */
		overflow: auto;				/* はみ出した場合の処理 */
		font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
		font-size: 1rem;
		line-height: 1.3rem;
	}

	/* ▼投稿ボタン */
	.postbutton {
		display: inline-block;		/* インラインブロック化 */
		background: var(--koi-iro);
		color: var(--siro-mozi);
		font-size: 0.9rem;
		text-decoration: none;
		padding: 5px 15px;
		border: none;
		border-radius: 3px;	
		cursor: pointer;
	}

	/* ▼投稿ボタンにマウスが載ったとき */
	.postbutton:hover { background-color: var(--usu-iro);}

	/* ▼文字装飾ボタン群 */
	/* 掲載領域全体 */ .decoBtns { display: inline-block; margin-top: 5px; }
	/* 全ボタン装飾 */ 
	.decoBtns input {
		min-width: 32px;
		min-height: 28px;
		color: #242424;
		margin:1px;
		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; }

/*プルダウンの装飾*/
.postarea select {
	border:1px solid var(--usu-mozi-iro);
	padding: 5px;
	background: #fefefe;
	box-shadow: none;
	cursor: pointer;
  }

  /* 更新履歴エリア */
.latestlistarea {
	width: min(100%,700px);
	margin: 0 auto 2rem;
	font-size: 0.8rem;
}
.latestlisttitle {font-weight: bold;padding-left:20px;}
.latestlist {
	padding: 0.5rem;
	border: solid var(--usu-mozi-iro);
	border-width: 1px 0;
	line-height: 1.3rem;
}
.latestlist span,.latestlist a { display: inline-block;}
.latestlist .catname {
	display: inline-block;
	margin-right: 3px;
	font-size: 0.7rem;
	color: var(--usu-mozi-iro);
	vertical-align: middle;
}

/*検索窓エリア*/
.searchboxarea { margin: 0 auto 1rem; text-align: right;}

.searchinputs{
	border: 1px solid var(--usu-mozi-iro);
	padding: 5px;
	overflow: hidden;
  }

.queryinput {
	width: 180px;
	border: 0px;
	outline: none;
	font-size: 1rem;
	vertical-align: middle;
	background-color: transparent;
	color: var(--mozi-iro);
}
.searchoption{ font-size: 0.8rem; color: var(--usu-mozi-iro);}
  
.searchinputs::before {
content:"\F0D1";
font-family: "remixicon";
font-size: 20px;
vertical-align: middle;
}

.searchbox .submitbutton {
	margin: 0 0 0 5px;
	padding: 3px 5px;
	border: 0px;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	cursor: pointer;
  }
.searchbox .submitbutton:hover { background-color: var(--usu-iro);}

	/* ▼表示対象の限定時などの「限定条件」表示行 */
	.situation {
		margin: 0 0 1rem 1rem;
		font-size: 0.8rem;
		color: var(--usu-mozi-iro);
	}
	.situation:empty { display: none; }
	.situation-postno { display: none;}

/* 日付境界バー非表示 */
.dateseparator { display: none;}

/* ■投稿ボックス(一発言)ごとの表示 */
.onelogbox {
	width: 100%;
	margin: 0 auto 0; 
}

/*続きを読むボタンと鍵フォーム送信ボタン*/
a.readmorebutton,.passkeysubmit {
	display: inline-block;
    margin: 5px;
    border: 0px;
    font-size: 100%;
    text-decoration: none;
    color: var(--siro-mozi);
    background-color:var(--koi-iro);
    text-align: center;
    padding: 0px 10px;
	cursor: pointer;
}
.readmorebutton:hover,.passkeysubmit:hover { background-color: var(--usu-iro);}

/* 1記事内の投稿日時と編集リンク */
.oneloginfo {
	margin-top: 1rem;
	font-size: 0.8rem;
	text-align: right;
}

.oneloginfo :where(.kizino,.postdate) { color: var(--usu-mozi-iro); display: inline-block; margin-right: 0.5rem;}
.editlink { font-size: 20px; color: var(--mozi-iro);}

/* 1記事内のカテゴリーの装飾 */
.onelogcats { margin-bottom: 0.5rem; text-align: right;}
.categorylink {
	display: inline-block;
	background-color: var(--usu-mozi-iro);
	color: var(--siro-mozi);
	font-size: 0.6rem;
	margin: 0 2px 0 0;
	padding: 0 4px;
}
.categorylink:hover { background-color: var(--link-hover-iro); color: var(--siro-mozi);}

/* カテゴリーリンクの項目前にアイコンを付ける */
.categorylink::before,.catlink::before,.latestlist .catname::before {
	content:"\ED61";
	font-family: "remixicon";
	font-size: 0.8rem;
	vertical-align: middle;
	margin-right:2px;
}

/* ▽カテゴリ間のセパレータ */
.catseparator {
	display: inline-block;
	margin: 0 1px;			/* 左右に1pxの余白 */
	color: var(--usu-mozi-iro);			/* 文字色 */
}

/* ■鍵付き(パスワード保護)投稿に表示される鍵入力フォームの装飾 */
.passkeyform {
	display: inline-block;
	margin: 0;
	padding: 0.6rem;
}

	/* ▼鍵違いエラーの表示 */
	.passkeyerror {
		display: block;
		color: var(--siro-mozi);
		background-color: var(--usu-iro);
		font-weight: bold;
		line-height: 1;
		margin: 0 0 0.5rem 0;
		padding: 0.3rem 0.5rem;
	}
	
	.passkeybox { display: block; }/* ▼入力フォーム枠 */
	.passkeyguide { margin-right: 0.1rem; } /* ▼入力欄前のガイド文 */
	.passkeyinput { /* ▼鍵入力欄 */
		width: 10rem;
		margin: 0 0.25rem 3px 0;
		font-size: 1rem;
		vertical-align: middle;
	}

	.utilitylinks { display: none;} /*ユーティリティリンク枠を非表示*/
	
/* ■ページナビゲーション領域 */
.pagenavi { text-align: center; }
.pagenavi p { margin-bottom: 0.7rem;}

/* ▼ページ番号リンクの数字 */
	a.pagenumlink {
		display: inline-block;
		width: 25px;
		height: 25px;
		text-decoration: none;
		color: var(--siro-mozi);
		background-color: var(--koi-iro);
		line-height: 25px;
		margin-top: 5px;
	}

 /* 現在のページ番号とマウスオーバー時の装飾 */	
	a.pagenumhere,.pagenumlink:hover {	background-color: var(--usu-iro); }

/* フリースペース */
.freespacearea { margin: 0 auto 2rem;}
.freespacearea p { margin-top: 1rem; text-align: right;}

/* ■ページ最下部(フッタ)領域 */
footer {
	width: 100%;
	margin: 0 auto;
	padding: 0.5rem 1rem;
	text-align: right;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
}
footer a{
--link-iro: #FFF; /* リンクの色など */
}


footer i { font-size: 20px;}
footer .kanri { margin-right: 0.8rem;}
.poweredby { font-size: 0.8rem; margin-right: 3rem;}

/*上に戻るボタンの装飾*/
a.ue_btn {
	position: fixed;
	z-index: 5000;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	bottom: 0;
	right: 0;
	background: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 30px;
	text-decoration: none;
	text-align: center;
  }
.ue_btn:hover{ background-color: var(--usu-iro);}

/* 前のページに戻るボタンの装飾 */
.back_btnlink { font-size: 20px; color: var(--mozi-iro);}
  
/* ---------- */
/* 状況別表示切り替え指定ゾーン */
/* 先頭固定投稿では日付、カテゴリ、戻るボタンを非表示 */
.logstatus-fixed :is(.postdate,.onelogcats,.back_btn) { display: none;}

/* トップ以外ヘッダー画像、クイックポスト、更新履歴、フリースペースを非表示 */
body:not(.home) :where(.headimgarea,.postarea,.latestlistarea,.freespacearea) { display: none;}

:where(body.home,body.onelog) .pageln { display: none;} /* トップと単独ページではページナビを非表示 */

/* 表示制限なし(トップページ)では先頭固定投稿以外非表示 */
body.nofiltering :where(.onelogbox:not(.logstatus-fixed),.ichiran) { display: none;}

/* 表示制限あり、単独表示じゃないとき(一覧)は単独記事とキャプションを非表示 */
body:not(.nofiltering):not(.onelog) :where(.tandoku,figcaption) { display: none;}

/* 単独表示のときは一覧を非表示 */
body.onelog .ichiran { display: none;}
/* ---------- */


/* -------------- */
/* おまけの自由装飾 */
/* -------------- */

/* 見出し1(単独記事タイトルとフリースペースのタイトルも一緒) */
.onelogtitle,
.freespacetitle,
.deco-midasi1 {
	display: block;
	font-size: 1.5rem;
	line-height: 1.8rem;
	margin-bottom: 1rem;
	padding: 0.2rem 0.5rem 0.5rem 0.8rem;
	border: solid var(--koi-iro);
	border-width: 0 0 1px 5px;
	overflow-wrap: break-word;/*↓2行 日本語改行タイミングの調整 */
	word-break: keep-all;
}

/* 見出し2 */
.deco-midasi2 {
	display: block;
	width: fit-content;
	color: var(--siro-mozi);
	padding: 0.1rem 0.8rem;
	background-color: var(--usu-mozi-iro);
}

/* 大文字 */
.deco-omozi { font-size: 1.2rem; line-height: 1.8rem;}

/* 画像サムネイル */
.deco-thumb {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px,1fr));
	gap: 5px;
}
.deco-thumb :where(.embeddedimage,.imagelink) {
	aspect-ratio: 1;
	object-fit: cover;
	width: 100%;
}

/* 小説本文 */
.deco-novel {
	display: block;
	max-width: 650px;
	margin: 0 auto;
	line-height: 1.8rem;
}

/* 縦書き */
.deco-tate {
	display: block;
	width: min(650px,100%);
	height: min(650px,80vh);
	margin: 0 auto;
	padding: 1.5rem;
	writing-mode: vertical-rl;
	text-orientation: upright;
	font-size: 1rem;
	font-family: serif;
	line-height: 1.8rem;
	overflow-x: auto;
	scrollbar-color: var(--usu-mozi-iro) var(--mainarea-iro);
}
.deco-tate::-webkit-scrollbar { height: 8px; background: var(--mainarea-iro);}
.deco-tate::-webkit-scrollbar-thumb { background:var(--usu-mozi-iro); border-radius: 4px;}

/* 仕切り線 */
.deco-sen { display: block; border-bottom: 1px solid var(--usu-mozi-iro);}

/* 中央寄せ */
.deco-center { display: block; text-align: center;}

/* 右寄せ */
.deco-right { display: block; text-align: right;}

/* ボタン(リンクは自由装飾の中に貼ってください) */
.deco-button a {
	display: inline-block;
	min-width: 5rem;
	margin: 3px;
	padding: 0.3rem 1rem;
	background-color: var(--link-iro);
	border-radius: 5px;
	color: var(--siro-mozi);
	text-align: center;
	font-weight: bold;
	box-shadow: 2px 2px 2px rgb(0, 0, 0, 0.2);
}
.deco-button a:hover { background-color: var(--link-hover-iro); box-shadow: 0 0;}

/* ボックス1 */
.deco-box1 {
	display: block;
	margin: 0 auto;
	width: fit-content;
	border: 1px solid var(--link-iro);
	padding: 1.3rem;
	position: relative;
}
.deco-box1::after {
	position: absolute;
	content: '';
	right: -1px;
	top: -1px;
	border-style: solid;
	border-width: 0 20px 20px 0;
	border-color: var(--link-iro) var(--mainarea-iro) var(--link-iro);
}




