@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+JP&family=Lato&display=swap');

/* テンプレート + 作品展示用てがろぐスキン「ippen」 */
/* 共通css */

*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

details * {
	box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
img,
p,
ul,
ol,
li {
	margin: 0;
	padding: 0;
}

img {
	border: none;
}

/* -------------------- */
/* カスタム用色変更欄 */
/* -------------------- */
:root {
	--haikei-iro: #fafafa;
	/* 全体背景色 */
	--naiyou-iro: #fafafa;
	/* 記事内背景色 */
	--mozi-iro: #242424;
	/* メイン文字色 */
	--usu-mozi-iro: #aaaaaa;
	/* ↑よりちょっと薄い文字色 */
	--siro-mozi: #f5f5f5;
	/* 濃い背景に乗せる白文字色 */
	--koi-iro: #74b0a8;
	/* 濃いアクセント色 */
	--usu-iro: #c2dee5;
	/* ↑の濃い色にマウス乗せたときの色など */
	--link-iro: #4f638c;
	/* リンクの色など */
	--link-hover-iro: #7d97b8;
	/* リンクにマウス乗せたときの色と強調のマーカー色 */
	--iconfont: "remixicon";
	/* アイコンフォントの名前 */
	--titlefont: "Lato", "IBM Plex 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;
	overflow-wrap: break-word;
}

/* リンクの装飾 */
a {
	text-decoration: none;
	color: var(--link-iro);
}

a:hover {
	color: var(--link-hover-iro);
	text-decoration: underline;
}

/* 画像の基本設定 */
img {
	max-width: 100%;
}

/* リスト */
ul,
ol {
	margin-bottom: 1rem;
	padding-left: 1.5rem;
}

ul {
	list-style-type: square;
}

/* ヘッダーからフッターを囲むエリア */
.bodyarea {
	margin: 0;
	padding: 0;
	background-color: var(--haikei-iro);
	color: var(--mozi-iro);
	display: grid;
	/* ↓4行 フッターを下部固定する */
	grid-template-rows: auto 1fr auto;
	grid-template-columns: 100%;
	min-height: 100svh;
}

header {
	width: 100%;
	margin: 0;
	padding: 1.5rem;
	background-color: var(--koi-iro);
	text-align: center;
	line-height: 1.2;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
	position: relative;
}

header::after {
	content: "";
	position: absolute;
	left: 0;
	width: 100%;
	height: 1.5px;
	/* ステッチの太さ */
	background-image: linear-gradient(to right,
			white 50%,
			transparent 50%);
	background-size: 17px 5px;
	/* 点線の間隔と長さ */
}

/* 下のステッチ */
header::after {
	bottom: 5px;
}

/* ヘッダー画像 */
.headimg {
	width: 150px;
	/* 横幅(本文エリアに大きさを合わせたい場合は「100%」) */
	height: auto;
}

@media screen and (max-width:480px) {
	.headimg {
		width: 100px;
	}

	/* スマホのときのヘッダー画像の横幅(本文エリアに大きさを合わせたい場合は「100%」 */
}

/* ヘッダー画像を丸くする */
.maru {
	aspect-ratio: 1;
	border-radius: 50%;
	object-fit: cover;
}

/* サイトタイトル */
h1.maintitle {
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: bold;
	margin-top: 1rem;
	/* text-wrap: balance; */
	/* ←改行位置を調整する設定 お好みで使ってください */
}

.maintitlelink {
	color: var(--siro-mozi);
}

.maintitle a {
	text-decoration: none;
}

/* サイトの説明 */
.guide {
	color: var(--siro-mozi);
	margin: 0;
}

/* メニューとメインコンテンツを囲むエリア */
main {
	margin: 0;
	padding: 0;
}

/* メニュー */
.mainmenu {
	-webkit-tap-highlight-color: transparent;
	position: sticky;
	/* 上まで来たら固定 */
	top: 0;
	z-index: 110;
}

.mainmenu ul {
	background-color: var(--haikei-iro);
	list-style: none;
	margin: 0;
	padding: 0.5rem 1.3rem;
	font-size: 1rem;
	line-height: 1.5;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 1rem;
}

/* メニュー除いたメイン部分を囲むエリア(横幅を狭くする) */
.mainarea {
	width: min(100%, 1000px);
	/* メイン領域の横幅 */
	margin: 0 auto;
	padding: 2rem 1.3rem 3rem;
	line-height: 1.65;
}

/* ----------更新履歴部分(埋め込み用スキンの装飾も一緒)---------- */
/* 更新履歴(外枠) */
.kframe {
	display: block;
	border: 1px solid var(--usu-mozi-iro);
	width: min(600px, 100%);
	/* 外枠の幅 */
	height: 100px;
	/* 外枠の高さ */
	margin: 0 auto 3rem;
}

/* 埋め込み用スキン内部 */
.kousin-body {
	padding: 1rem;
	line-height: 1.65;
}

.kousin-body {

	/* 日付境界バー非表示 */
	.dateseparator {
		display: none;
	}

	/* 日付と記事タイトル横の余白 */
	.kdate,
	.ktitlelink {
		margin-right: 0.3rem;
	}

	/* カテゴリーの装飾 */
	.categories {
		margin: 0 10px 0 0;
	}

	.categorylink {
		display: inline-block;
		font-size: 0.7rem;
		color: var(--usu-mozi-iro);
		vertical-align: middle;
	}

	.categorylink:hover {
		color: var(--link-hover-iro);
	}

	/* カテゴリーリンクの項目前にアイコンを付ける */
	.categorylink::before {
		content: "\ED61";
		font-family: var(--iconfont);
		margin-right: 0.1rem;
	}

	/* カテゴリ間のセパレータ */
	.catseparator {
		display: inline-block;
		margin: 0 1px;
		/* 左右に1pxの余白 */
		color: var(--usu-mozi-iro);
		/* 文字色 */
	}

	/* Powered by */
	.kousinpb {
		font-size: 0.8rem;
		color: var(--usu-mozi-iro);
		margin-top: 1rem;
		text-align: right;
	}
}

/* ----------(更新履歴部分ここまで)---------- */

/* 各セクション(下に大きめの余白が入ります) */
section {
	margin-bottom: 5rem;
}

/* p(普通文章) */
p {
	margin: 0.5rem auto 1rem;
}

/* 中央寄せの普通文章 */
.center {
	text-align: center;
}

/* 右寄せの普通文章 */
.right {
	text-align: right;
}

/* 薄くて小さい文字 */
small {
	font-size: 0.8rem;
	color: var(--usu-mozi-iro);
}

/* 強調文字 */
em {
	font-style: normal;
	font-weight: bold;
	background: linear-gradient(transparent 60%, var(--link-hover-iro) 60%);
}

/* 大きい文字 */
.omozi,
.deco-omozi {
	font-size: 1.2rem;
	font-weight: bold;
}

/* 仕切り線 */
hr,
.deco-sen {
	display: block;
	width: 95%;
	border: none;
	border-bottom: 1px dotted var(--usu-mozi-iro);
	margin: 1.5rem auto;
	font-size: 0;
}

/* 見出し(てがろぐの方も共通) */
h2,
.deco-h2 {
	font-size: 1.3rem;
	border-bottom: 1px solid var(--usu-mozi-iro);
	padding: 0 0 0.2rem 0.2rem;
	margin-bottom: 1rem;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
	font-weight: bold;
}

h2::before,
.deco-h2::before {
	content: "»";
	margin-right: 0.2rem;
	color: var(--usu-iro);
}

h3,
.deco-h3 {
	width: fit-content;
	margin-bottom: 0.5rem;
	padding: 0.1rem 1rem;
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 0.9rem;
	font-weight: normal;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}

h4,
.deco-h4 {
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 0.5rem;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
}

h4::before,
.deco-h4::before {
	content: "-";
}

/* 枠線付きボックス */
.box1,
.deco-box1 {
	display: block;
	border: 1px solid var(--usu-mozi-iro);
	padding: 1.3rem;
	margin: 1rem auto 1.5rem;
}

/* 折りたたみ */
details {
	margin: 1rem 0 1.5rem;
}

summary {
	width: fit-content;
	padding: 0.2rem 0.5rem;
	cursor: pointer;
	background-color: var(--usu-mozi-iro);
	color: var(--siro-mozi);
}

summary:hover {
	background-color: var(--link-hover-iro);
}

/* 画像サムネイル */
.thumb,
.deco-thumb {
	margin: 1rem auto 1.5rem;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	/* 横幅100px以下で折り返す */
	gap: 0.5rem;
	align-items: start;
}

/* サムネを正方形にする */
.thumb img {
	aspect-ratio: 1;
	object-fit: cover;
	width: 100%;
}

/* 2カラム部分 */
.twocol {
	margin: 1rem auto 1.5rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
}

@media screen and (max-width:480px) {
	.twocol {
		display: block;
	}

	/* スマホのとき2カラムを解除 */
	.twodiv {
		margin-bottom: 1.5rem;
	}
}

/* 左詰め横並びにする */
.flex {
	display: flex;
	align-items: center;
	margin: 1rem 0 1.5rem;
	gap: 1rem;
}

@media screen and (max-width:480px) {
	.flex {
		flex-wrap: wrap;
	}

	/* スマホのとき横並び解除(折り返す) */
}

/* プロフィール画像を含むflexdivは縮めない */
.flexdiv:has(.profimg) {
	flex-shrink: 0;
}

/* プロフィール画像 */
img.profimg {
	width: 150px;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: 50%;
}

/* SNS等アイコンリンク */
.licon {
	margin: 1rem;
	line-height: 1.5;
}

.licon a {
	font-size: 1.5rem;
	margin-right: 0.8rem;
}

.licon a:hover {
	text-decoration: none;
}

/* 文字リンク並べるリスト */
.alink {
	margin: 1rem 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
}

.alink li a {
	padding: 0 0.5rem;
}

.alink li::after {
	content: "|";
	color: var(--usu-mozi-iro);
}

.alink li:last-child::after {
	content: "";
}

/* ボタン風リンク */
.lbutton,
.uc-lbutton {
	display: inline-block;
	border-radius: 0.3rem;
	background-color: var(--link-iro);
	color: var(--siro-mozi);
	margin: 0.2rem;
	padding: 0.2rem 0.8rem;
	vertical-align: middle;
}

.lbutton:hover,
.uc-lbutton:hover {
	background-color: var(--link-hover-iro);
	color: var(--siro-mozi);
	text-decoration: none;
}

/* メッセージフォームサンプル */
.sampleform {
	margin: 1rem 0 1.5rem;
}

.sampleform>* {
	display: block;
	margin-bottom: 1rem;
}

.sampleform input[type="text"] {
	width: min(500px, 100%);
	border: 1px solid var(--usu-mozi-iro);
	padding: 0.2rem 0.5rem;
	font-size: 1rem;
}

.sampleform textarea {
	width: min(500px, 100%);
	height: 150px;
	border: 1px solid var(--usu-mozi-iro);
	padding: 0.5rem;
	font-size: 1rem;
}

.sampleform input[type="submit"] {
	border: none;
	border-radius: 0.3rem;
	background-color: var(--link-iro);
	color: var(--siro-mozi);
	padding: 0.2rem 2rem;
	vertical-align: middle;
}

.sampleform input[type="submit"]:hover {
	background-color: var(--link-hover-iro);
	color: var(--siro-mozi);
	text-decoration: none;
	cursor: pointer;
}

/* フッター */
footer {
	background-color: var(--koi-iro);
	color: var(--siro-mozi);
	padding: 0.6rem 4rem 0.6rem 1rem;
	text-align: right;
	line-height: 1.5;
}

footer p {
	margin: 0;
}

/* 上に戻るボタン */
a.ue_btn {
	position: fixed;
	z-index: 100;
	display: grid;
	place-content: center;
	width: 40px;
	height: 40px;
	bottom: 0;
	right: 0;
	background: var(--koi-iro);
	color: var(--siro-mozi);
	font-size: 30px;
	line-height: 1;
	text-decoration: none;
}

.ue_btn:hover {
	background-color: var(--usu-iro);
}

.mainmenu {
	position: sticky;
	top: 0;
	z-index: 110;
}

.mainmenu ul {
	background-color: var(--haikei-iro);
	list-style: none;
	margin: 0;
	padding: 0.5rem 1.3rem;
	font-size: 1rem;
	line-height: 1.5;
	font-family: var(--titlefont);
	letter-spacing: 0.1rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 1rem;
}

/* タイトルだけ中央表示 */
.mainmenu .menu_sitetitle {
	background-color: var(--haikei-iro);
	width: 100%;
	text-align: center;
	margin-bottom: 5px;
	/* メインメニューとの余白 */
}

.mainmenu .menu_sitetitle a {
	font-size: 0.85rem;
	font-weight: bold;
	color: var(--moji-iro, #74b0a8);
	text-decoration: none;
	display: inline-block;
}

.mainmenu .menu_sitetitle a:hover {
	color: var(--accent-iro, #7bc2bd);
}

/* ▼メインリンク */
.mainmenu a {
	cursor: pointer;
	text-decoration: none;
	color: var(--moji-iro, #74b0a8);
	font-weight: 600;
	display: inline-block;
	padding: 0.3rem 0;
	transition: color .25s;
}

.mainmenu a:hover {
	color: var(--accent-iro, #74b0a8);
}

/* ▼ドロップダウン部分 */
.gnavi__list {
	position: relative;
}

.dropdown__lists {
	color: var(--moji-iro, #74b0a8);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform .25s ease;
	position: absolute;
	top: 100%;
	left: -50px;
	list-style: none;
	margin: 0;
	padding: 2px 0;
	background: var(--haikei-iro);
	border: 1px solid rgba(0, 0, 0, 0.05);
	min-width: 140px;
	z-index: 100;
}

/* ホバーで表示 */
.gnavi__list:hover .dropdown__lists {
	transform: scaleY(1);
}

/* ▼サブリンク */
.dropdown__lists li a {
	display: block;
	padding: 4px 10px;
	font-size: 0.9rem;
	color: var(--moji-iro, #74b0a8);
	transition: background .2s, color .2s;
	white-space: nowrap;
}

.dropdown__lists li a:hover {
	background: rgba(0, 0, 0, 0.03);
	color: var(--accent-iro, #7ba0c2);
}

/* ▼サブサブメニュー（横に出るやつ） */
.dropdown__lists li {
	text-align: center;
	display: block;
	width: 100%;
	position: relative;
	/* 基準 */
}

.dropdown__sub {
	position: absolute;
	top: 0;
	left: 100%;
	transform: scaleY(0);
	transform-origin: top left;
	transition: transform .25s ease;
	list-style: none;
	margin: 0;
	padding: 2px 0;
	background: var(--haikei-iro);
	border: 1px solid rgba(0, 0, 0, 0.05);
	min-width: 100px;
	z-index: 100;
}

/* ホバーで開く */
.dropdown__lists li:hover>.dropdown__sub {
	transform: scaleY(1);
}

/* サブサブメニュー内のリンク */
.dropdown__sub li a {
	white-space: nowrap;
	display: block;
	padding: 4px 10px;
	font-size: 0.9rem;
	color: var(--moji-iro, #74b0a8);
	transition: background .2s, color .2s;
}

.dropdown__sub li a:hover {
	background: rgba(0, 0, 0, 0.03);
	color: var(--accent-iro, #7ba0c2);
}

/* サファリ用：hover */
.gnavi__list:hover>.dropdown__lists {
	transform: scaleY(1);
}

/* Safari全対応：タップ or フォーカスで開く */
.gnavi__list:focus-within>.dropdown__lists {
	transform: scaleY(1);
}

/* PC用：hover */
.dropdown__lists li:hover>.dropdown__sub {
	transform: scaleY(1);
}

/* Safari全対応：タップ or フォーカスで開く */
.dropdown__lists li:focus-within>.dropdown__sub {
	transform: scaleY(1);
}

.fancy-5 {
	display: inline-flex;
	gap: 9px;
	align-items: center;
	color: #7bc2bd;
	text-decoration: none;
	font-weight: 600;
}

.fancy-5::after {
	content: "→";
	display: inline-block;
	transform: translateX(-6px);
	opacity: 0;
	transition: transform .25s cubic-bezier(.2, .8, .2, 1), opacity .2s;
}

.fancy-5:hover::after,
.fancy-5:focus::after {
	transform: translateX(0);
	opacity: 1;
}

.fancy-5:focus {
	outline: 3px solid rgba(11, 114, 185, 0.14);
}

.banner-frame {
	position: relative;
	display: inline-block;
	width: 200px;
	height: 40px;
	border: 2px solid rgba(255, 255, 255, 0.8);
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
	transition: transform .25s ease, box-shadow .25s ease;
}

.banner-frame img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	/* 画像を枠にフィット */
	object-position: center;
	/* 中央基準 */
	display: block;
}

.banner-frame:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}