/*
Theme Name: Shimesan-Theme
Author: Shimesan
Version: 1.0
*/

img {
	max-width: 100%;
	height: auto;
}

header {
	padding: 0px;
	text-align: center;
	background: #fff;
	border-bottom: 1px solid #eee;
}

header img {
	max-height: 80px;
}

@media (max-width: 600px) {
	header img {
		max-height: 60px;
	}
}

header a:hover {
	background-color: #fff;
	opacity: 0.6;
}

.navi-area {
	text-align: center;
	color: #ccc;
	font-size: 15px;
	margin: 2px 0 -10px 0;
	padding: 5px 0 0 0;
}

.navi-area a {
	display: inline-block;
	padding: 0 5px;
	line-height: 1.5em;
	margin: 0 5px;
}

.navi-area a:hover {
	color: #fff;
	background-color: #528fae;
	transition: all 0.3s;
	border-radius: 2px;
}


body {
	font-family: 'Quicksand', 'IBM Plex Sans JP', -apple-system, BlinkMacSystemFont, 'Hiragino Kaku Gothic ProN', 'Yu Gothic', sans-serif;
	color: #444;
	line-height: 1.8;
	font-size: 18px;
	margin: 0;
	padding: 0;
	background-color: #fbfbfb;
}

@media (max-width: 600px) {
	body {
		line-height: 1.8;
		font-size: 16px;
	}
}

strong {
	color: #111;
}

a {
	color: #176a93;
	text-decoration: none;
}

a:hover {
	color: #fff;
	background-color: #528fae;
	transition: all 0.3s;
}

.container {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
	background-color: #fff;
}

@media (max-width: 600px) {
	header .container {
		padding: 12px;
	}
}



.top-concept {
	margin: -20px 0px 30px 0px;
}

.top-concept img {
	object-fit: cover;
	vertical-align: bottom;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	opacity: 0.8;
}

h1 {
	margin: 30px 0;
	margin-bottom: 30px;
	word-wrap: break-word;
	font-size: 36px;
	font-weight: 400;
	line-height: 54px;
	position: relative;
	padding-bottom: 22px;
}

h1::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 120px;
	height: 4px;
	background-color: #86afc4;
}

h2 {
	position: relative;
	padding: 0 0 32px 0;
	font-size: 30px;
	line-height: 38px;
	font-weight: 400;
	margin: 60px 0 30px 0;
	color: #176a93;
}

h2::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 82px;
	height: 3px;
	background-color: #86afc4;
}

h3 {
	position: relative;
	padding: 0 0 15px 0;
	font-size: 24px;
	font-weight: 500;
	margin: 50px 0 20px 0;
	color: #176a93;
}

h3::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 82px;
	height: 1px;
	background-color: #86afc4;
}

h4,
h5,
h6 {
	padding: 10px 0 5px 0;
	font-size: 22px;
	font-weight: 500;
	margin: 50px 0 20px 0;
	color: #176a93;
}

.post-subtitle {
	line-height: 28px;
	color: #2886B5;
margin: 9px 0 30px 0;
}

.paragraph-af {
	display: block;
	font-size: 12px;
	padding-left: 10%;
	padding-right: 10%;
	margin-bottom: 20px;
	padding-top: 15px;
	padding-bottom: 15px;
	color: #fff;
	border-radius: 5px;
	background-color: #bfd0d9;
}

@media (max-width: 600px) {
	h1 {
		margin: 20px 0;
		word-wrap: break-word;
		font-size: 28px;
		font-weight: 400;
		line-height: 40px;
		position: relative;
		padding-bottom: 22px;
	}

	h1::after {
		content: '';
		position: absolute;
		bottom: 0;
		left: 0;
		width: 82px;
		height: 4px;
		background-color: #86afc4;
	}

	.paragraph-af {
		display: block;
		font-size: 11px;
		padding-left: 7%;
		padding-right: 7%;
		margin: 0px;
		padding-top: 11px;
		padding-bottom: 11px;
		color: #fff;
		border-radius: 5px;
		background-color: #bfd0d9;
		line-height: 16px;
	}
	
	.post-subtitle {
		line-height: 26px;
	}
	h2,
	h3 {
		font-size: 28px;
		line-height: 38px;
	}
}

ol li,
ul li {
	font-weight: bold;
	color: #4c768c;
}

.wp-caption {
	text-align: center;
	max-width: 100%;
	vertical-align: top;
}

.alignnone {
	display: inline-block;
}

.wp-caption-text,
.wp-caption-dd {
	text-align: left;
	margin: 0 0 35px 0;
	font-size: 16px;
	font-weight: 400;
	line-height: 24px;
	color: #666;
}

blockquote {
	color: #666;
	font-size: 16px;
	line-height: 24px;
	background-color: #f2f8fb;
	border-left: 2px solid #176a93;
	margin: 40px 5px;
	padding: 6px 20px;
}

pre {
	background-color: #4b626d;
	border-radius: 10px;
	color: #fff;
	padding: 20px 30px;
	font-size: 15px;
	line-height: 1.5em;
	overflow-x: auto;
}

@media (max-width: 600px) {
	pre {
		padding: 15px 10px;
		font-size: 14px;
		line-height: 1.4em;
	}
}

span.dropcap {
	float: left;
	display: block;
	font-size: 50px;
	line-height: 60px;
	background-color: #94b3c4;
	color: white;
	text-align: center;
	margin: 6px 13px 0 0;
	padding: 10px;
	text-transform: uppercase;
	min-width: 62px;
	min-height: 62px;
	border-radius: 2px;
}

span.dropcap.dropcap2 {
	background-color: #fff;
	color: #4B4B4B;
	font-size: 79px;
	line-height: 69px;
	margin: 0;
	padding: 3px 12px 13px;
}

@media (max-width: 600px) {
	span.dropcap {
		padding: 8px 10px 8px;
	}

	span.dropcap.dropcap2 {
		padding: 3px 10px 13px;
	}
}

.td_text_highlight_marker,
.txt_highlight {
	padding: 3px 1px 4px 1px;
	margin: 0 12px 0 12px;
}

.td_text_highlight_marker_yellow,
.txt_highlight_blue {
	background-color: #396fa8;
	box-shadow: 8px 0 0 #396fa8, -12px 0 0 #396fa8;
	color: #fff;
}

.td_text_highlight_marker_pink,
.txt_highlight_code {
	background-color: #dee3e6;
	box-shadow: 8px 0 0 #dee3e6, -12px 0 0 #dee3e6;
	color: #31393c;
}

.td_text_highlight_marker_yellow strong,
.txt_highlight strong {
	color: white;
}

.vc_btn {
	cursor: pointer;
	display: inline-block;
	text-decoration: none !important;
	border-radius: 4px;
}

.vc_btn strong {
	color: #fff;
}

.vc_btn-default {
	background-color: #76b0cc;
	color: #fff !important;
	border: 1px solid #76b0cc;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.vc_btn-lg {
	padding: 9px 16px;
	font-size: 16px;
	margin-bottom: 20px !important;
}

.vc_btn-sm {
	padding: 6px 12px;
	font-size: 14px;
	margin-bottom: 20px;
}

.vc_btn-default:hover {
	background-color: #528fae;
	border: 1px solid #528fae;
	transition: all 0.2s ease;
	transform: translateY(-3px);
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
}

.right-align {
	display: flex;
	justify-content: flex-end;
}


.td-paragraph-padding-2,
.paragraph-1 {
	display: block;
	padding-left: 10%;
	padding-right: 10%;
	border: 4px solid #bdd7e4;
	margin: 40px 0 60px 0;
	padding-top: 20px;
	padding-bottom: 25px;
	line-height: 2em;
	color: #176a93;
	border-radius: 16px;
}

.paragraph-1 strong,
ul li strong{
	color: #4babd9;
}

.paragraph-1 .td_text_highlight_marker_yellow strong,
.paragraph-1 .txt_highlight strong {
	color: white;
}

.td-paragraph-3,
.paragraph-2 {
	display: block;
	padding-left: 10%;
	padding-right: 10%;
	margin: 40px 0 60px 0;
	padding-top: 15px;
	padding-bottom: 25px;
	line-height: 1.6em;
	color: #fff;
	border-radius: 10px;
	background-color: #add3e6;
}

.td-paragraph-padding-2 h6,
.paragraph-1 h6,
.td-paragraph-3 h6,
.paragraph-2 h6 {
	margin: 0;
}

table {
	width: 100%;
	font-size: 14px;
	margin: 40px 0;
	border-collapse: collapse;
}

table th {
	text-align: left;
	border: 1px solid #bdbdbd;
	padding: 6px 10px;
	background-color: #f1f1f1;
	font-weight: normal;
}

table thead td {
	font-weight: bold;
	padding: 6px 10px;
}

table thead td.plus {
	background-color: #E3F0C2;
}

table td {
	border: 1px solid #bdbdbd;
	padding: 6px 10px;
}

@media (max-width: 600px) {
	table td {
		border: 1px solid #bdbdbd;
		padding: 6px 3px;
	}
}

table tbody td {
	background-color: #fdfdfd;
}

table tbody tr:nth-child(2n) td {
	background-color: #f7f7f7;
}

table .odd td {
	background-color: #f8f8f8;
}

table td.odd {
	background-color: #ccc;
}

table tbody tr td.plus {
	background-color: #dfecf2;
	font-weight: bold;
}

/* =========================================
	カエレバ
   ========================================= */

.cstmreba,
.cstmreba2 {
	padding: 10px 10px 0px 10px;
	margin-bottom: 30px;
}

@media (max-width: 600px) {

	.cstmreba,
	.cstmreba2 {
		padding: 10px 0px 0px 0px;
		margin-bottom: 30px;
	}
}

.cstmreba:before,
.cstmreba:after,
.cstmreba2:before,
.cstmreba2:after {
	display: table;
	content: '';
	line-height: 0;
}

.cstmreba:after,
.cstmreba2:after {
	clear: both;
}

.cstmreba2 .kaerebalink-detail {
	display: none;
}

.cstmreba2 .td-animation-stack-type0-1 {
	margin: 0 !important;
}

.cstmreba2 .kaerebalink-info {
	margin-top: 0;
}

.kaerebalink-image,
.booklink-image {
	float: left;
	width: 32%;
	margin-right: 2%;
	text-align: center;
}

.kaerebalink-image a:hover,
.booklink-image a:hover {
	background-color: #fff;
	opacity: 0.8;
}

.kaerebalink-image img,
.booklink-image img {
	display: inline-block;
	margin: 0;
}


.kaerebalink-info,
.booklink-info {
	float: left;
	width: 65%;
}

@media (max-width: 600px) {

	.kaerebalink-image,
	.booklink-image {
		float: none;
		width: 100%;
		text-align: center;
	}

	.kaerebalink-info,
	.booklink-info {
		float: none;
		width: auto;
		margin: 15px 10px;
		padding: 0;
	}
}

.kaerebalink-powered-date,
.booklink-powered-date {
	font-size: 10px;
	text-align: right;
}

.kaerebalink-detail,
.booklink-detail {
	font-size: 12px;
}


.kaerebalink-name p {
	margin-bottom: 0;
}

@media (max-width: 600px) {
	.kaerebalink-name p {
		text-align: center;
		margin: 20px 0 0 0;
	}
}


.kaerebalink-link1,
.booklink-link2 {
	margin: 10px 0 15px 0;
	text-align: right;
}

@media (max-width: 600px) {

	.kaerebalink-link1,
	.booklink-link2 {
		text-align: center;
	}
}

.shoplinkamazon,
.shoplinkrakuten,
.shoplinkyahoo,
.shoplinkbk1,
.shoplinkseven {
	display: inline-block;
	margin: 0;
}

.shoplinkamazon a,
.shoplinkrakuten a,
.shoplinkyahoo a,
.shoplinkbk1 a,
.shoplinkseven a {
	background-color: #6aa5c1;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	text-decoration: none !important;
	border-radius: 2px;
	padding: 4px 6px;
	font-size: 12px;
	margin: 0px 1px 10px 0px !important;
	letter-spacing: 0;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
}


.shoplinkamazon a:hover {
	color: #fff !important;
	background-color: #fc9a18;
	text-decoration: none !important;
	transition: all 0.3s;
	transform: translateY(-2px);
}

.shoplinkrakuten a:hover {
	color: #fff !important;
	background-color: #bf0000;
	text-decoration: none !important;
	transition: all 0.3s;
	transform: translateY(-2px);
}

.shoplinkyahoo a:hover {
	color: #fff !important;
	background-color: #ff0033;
	text-decoration: none !important;
	transform: translateY(-2px);
	transition: all 0.3s;
}

.shoplinkseven a:hover {
	color: #fff !important;
	background-color: #1d3a77;
	transform: translateY(-2px);
	text-decoration: none !important;
	transition: all 0.3s;
}

.shoplinkbk1 a:hover {
	color: #fff !important;
	background-color: #2570c6;
	transform: translateY(-2px);
	text-decoration: none !important;
	transition: all 0.3s;
}

.shoplinkamazon img,
.shoplinkrakuten img,
.shoplinkyahoo img,
.shoplinkseven img,
.shoplinkbk1 img,
{
margin: 0 !important;
}

.booklink-link2:after,
.booklink-footer:after,
.kaerebalink-link1:after {
	content: "";
	clear: both;
	display: block;
}

.kaereba-comment,
.book-comment {
	font-size: small;
	line-height: 1.5em;
	padding: 0;
}

/* =========================================
   ブログカード
   ========================================= */
.blogcard-link,
.linkcard {
	display: block;
	border: 1px solid #b9b9b9;
	border-radius: 8px;
	background: #fff;
	overflow: hidden;
	text-decoration: none;
	margin: 45px 0 60px 0;
	transform: translateY(-2px);
	transition: opacity 0.2s;
}

.blogcard-link:hover,
.linkcard:hover {
	color: #444;
	background-color: #f1f6f9;
	border-color: #528fae;
	transition: 0.2s;
	transform: translateY(-2px);
}

.blogcard-link a,
.linkcard a {
	color: #444;
}

.blogcard-link a:hover,
.linkcard a:hover {
	color: #111;
	background-color: #f1f6f9;
}

.blogcard {
	display: flex;
	height: 120px;
}

.lkc-external-wrap,
.lkc-internal-wrap {
	overflow: hidden;
	height: 120px;
}

.lkc-external-wrap:hover,
.lkc-internal-wrap:hover {
	opacity: 0.8;
	color: #222;
	background-color: #f1f6f9;
	border-color: #528fae;
	transition: 0.2s;
}

.blogcard-thumb {
	width: 180px;
	flex-shrink: 0;
	background-size: cover;
	background-position: center;
	background-color: #f0f0f0;
}

.lkc-thumbnail-img {
	width: 180px;
	background-size: cover;
	background-position: center;
	background-color: #f0f0f0;
	float: left;
}

.blogcard-content {
	padding: 15px;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	overflow: hidden;
}

.blogcard-title {
	font-weight: bold;
	font-size: 16px;
	line-height: 1.4;
	margin-bottom: 5px;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.lkc-title {
	padding: 15px 15px 0 15px;
	font-weight: bold;
	font-size: 16px;
	line-height: 1.4;
	margin-bottom: 5px;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.blogcard-excerpt {
	font-size: 12px;
	color: #777;
	line-height: 1.4;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.lkc-url cite,
.lkc-favicon {
	display: none
}

.lkc-excerpt {
	display: block;
	font-size: 12px;
	color: #777;
	line-height: 1.4;
	padding: 0 15px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.blogcard-footer {
	font-size: 10px;
	color: #999;
	text-align: right;
	margin-top: 5px;
}

.lkc-info {
	font-size: 10px;
	color: #999;
	text-align: right;
	margin-top: 15px;
	padding: 0 15px;
}

@media (max-width: 600px) {
	.blogcard {
		height: auto;
	}

	.blogcard-thumb {
		width: 100px;
		height: 100px;
	}

	.lkc-thumbnail-img {
		width: 100px;
	}

	.blogcard-content {
		padding: 10px;
	}

	.blogcard-title {
		font-size: 14px;
	}

	.blogcard-excerpt,
	.lkc-excerpt {
		display: none;
	}

	.lkc-external-wrap,
	.lkc-internal-wrap {
		height: 100px;
	}
}

	.post-tags-list{
		margin: 0 0 30px 0;
  padding: 15px 0 0 0;
	}
	
	.post-tags-list a{	
display: inline-block;
  padding: 4px 12px;
  background: #f5f5f5;
  color: #aaa;
  text-decoration: none;
  border-radius: 6px;
  font-size: 10px;
	}
	.post-tags-list a:hover{		
		background-color: #e4eff5;
	}

.post-meta-top {
	margin-bottom: 15px;
}

.post-meta-info {
	color: #888;
	font-size: 0.9em;
	margin-bottom: 20px;
}

.post-views {
	margin-left: 10px;
}

.cat-label:hover {
	opacity: 0.8;
}

.post-tags {
	font-size: 0.9em;
}

.tags-title {
	font-weight: bold;
	margin-right: 10px;
	color: #555;
}

.tag-label {
	display: inline-block;
	border: 1px solid #ccc;
	color: #555;
	padding: 2px 8px;
	margin-right: 5px;
	margin-bottom: 5px;
	text-decoration: none;
	border-radius: 15px;
	font-size: 12px;
	transition: background 0.2s;
}

.tag-label:hover {
	background: #e4eff5;
	color: #176a93;
	border: 1px solid #86afc4
}

.related-area .tag-label {
	border: 1px solid #86afc4;
	color: #176a93;
	padding: 0px 10px;
	margin-right: 5px;
	margin-bottom: 0;
	margin-top: 2px;
	border-radius: 10px;
	font-size: 11px;
	transition: background 0.2s;
	vertical-align: text-top;
	line-height: 18px;
}

.related-area {
	margin-top: 60px;
	border-top: 1px solid #ddd;
}

.related-heading,
.all-tags-area h3 {
	font-size: 20px;
	margin-bottom: 20px;
}

.cat-label {
	display: inline-block;
	background: #396fa8;
	color: #fff;
	font-size: 11px;
	padding: 3px 10px;
	margin-right: 5px;
	text-decoration: none;
	border-radius: 2px;
	vertical-align: middle;
}

.related-card {
	display: flex;
	text-decoration: none;
	color: #333;
	margin-bottom: 20px;
	align-items: center;
	padding: 10px;
	border-radius: 5px;
	transition: background 0.2s;
}

.related-card:hover {
	background: #e4eff5;
	color: #176a93;
}

.related-thumb {
	width: 120px;
	height: 80px;
	flex-shrink: 0;
	margin-right: 15px;
	background: #eee;
}

.related-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.related-title {
	display: block;
	font-size: 16px;
	line-height: 1.5;
	margin-top: 3px;
	font-weight: normal;
}

.related-date {
	font-size: 12px;
	color: #888;
	margin-top: 5px;
}

.all-tags-area {
	margin-top: 80px;
}

@media (max-width: 600px) {
	.related-card {
		align-items: flex-start;
	}

	.related-title {
		font-size: 14px !important;
	}
}

.archive-header {
	text-align: center;
	margin-bottom: 40px;
	padding: 20px;
	background: #f5f5f5;
	border-radius: 8px;
}

.archive-title {
	font-size: 24px;
	margin: 0;
	color: #176a93;
	line-height: 1.5em;
	padding: 20px 10px;
}

h1.archive-title::after {
	width: 0;
	height: 0;
}

h2.archive-item-title {
	position: relative;
	padding: 0 0 15px 0;
	font-weight: 400;
	margin: 60px 0 30px 0;
	color: #176a93;
	font-size: 22px;
	margin: 0;
	line-height: 1.5em;
}

h2.archive-item-title::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 82px;
	height: 3px;
	background-color: #86afc4;
}

.archive-item {
	margin-bottom: 30px;
}

.archive-link {
	display: flex;
	text-decoration: none;
	color: #333;
	background: #fff;
	border: 1px solid #b9b9b9;
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.2s,
}

.archive-link:hover {
	color: #444;
	background-color: #f1f6f9;
	border-color: #528fae;
	transition: 0.2s;
	transform: translateY(-2px);
}


.archive-thumb {
	width: 200px;
	flex-shrink: 0;
}

.archive-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	vertical-align: bottom;
}

.archive-body {
	padding: 15px 20px;
	flex: 1;
}

.archive-meta {
	font-size: 0.85em;
	color: #888;
	margin-bottom: 10px;
}

.archive-cat {
	margin-left: 10px;
	background: #eee;
	padding: 2px 6px;
	border-radius: 3px;
}

.archive-excerpt,
.archive-description {
	font-size: 16px;
	line-height: 1.5;
	margin-top: 3px;
	font-weight: normal;
	color: #666;
	text-align: left;
}

.pagination {
	margin: 40px 0;
	text-align: center;
}

.nav-links .page-numbers {
	display: inline-block;
	padding: 8px 12px;
	margin: 2px;
	border: 1px solid #ddd;
	color: #333;
	text-decoration: none;
	border-radius: 4px;
}


.nav-links .page-numbers:hover {
	background: #e4eff5;
	color: #176a93;
	border: 1px solid #86afc4
}

.nav-links .current {
	background: #176a93;
	color: #fff;
	border-color: #176a93;
}

.site-footer {
	text-align: center;
	padding: 15px;
	background: #e3eaee;
	font-size: 12px;
	color: #666;
}

.footer-menu {
	font-size: 14px;
	margin-bottom: 10px;
	border-bottom: 1px solid #bdbdbd;
	padding-bottom: 10px;
}

@media (max-width: 600px) {
	.archive-link {
		display: block;
	}

	.archive-thumb {
		width: 100%;
		height: 180px;
	}

	h2.archive-item-title {
		font-size: 20px;
		;
		line-height: 1.4em;
	}

	.archive-excerpt,
	.archive-description {
		font-size: 14px;
	}

	.related-card {
		align-items: flex-start;
	}

	.related-thumb {
		width: 90px;
		height: 60px;
	}

	.related-title {
		font-size: 14px;
	}

	.footer-menu {
		font-size: 13px;
	}
}

.container-wide {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
	background-color: #fff;
}

.container-wide img {
	border-radius: 6px;
}

.container-wide h1.entry-title {
	margin: 20px 0 25px 0;
	font-size: 28px;
	letter-spacing: 2px;
	padding-bottom: 20px;
}

.container-wide h1.entry-title::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 120px;
	height: 2px;
	background-color: #86afc4;
}

.media-exif {
	background: #f1f5f7;
	padding: 5px 15px;
	border-radius: 8px;
	font-size: 0.9em;
	color: #bbb;
	margin: 10px 0 30px 0;
	text-align: right;
	line-height: 1.5em;
}

.media-exif span {
	margin-right: 15px;
	color: #66818f;
	display: inline-block;
}

.author-box {
	margin: 60px 0 30px 0;
	padding: 30px;
	background: #f0f0f0;
	border-radius: 8px;
	display: flex;
	align-items: center;
	gap: 20px;
}

.author-avatar img {
	border-radius: 50%;
	object-fit: cover;
}

.author-name {
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 10px;
}

.author-text p {
	font-size: 14px;
	line-height: 1.5em;
	color: #666;
}

.author-sns {
	margin-top: 15px;
}

.author-sns a {
	margin: 0 10px 10px 0;
	;
}

.sns-btn {
	padding: 4px 16px;
	font-size: 12px;
	font-weight: bold;
	text-decoration: none;
	border-radius: 50px;
	transition: opacity 0.2s, transform 0.1s;
	color: #fff;
}

.sns-btn:hover {
	opacity: 0.8;
	transform: translateY(-2px);
}

.sns-yt:hover {
	border: 1px solid #d75a5a;
	background-color: #d75a5a;
}

.sns-x:hover {
	border: 1px solid #000;
	background-color: #000;
}

@media (max-width: 768px) {
	.author-box {
		flex-direction: column;
		text-align: center;
	}

}

.media-related-area {
	margin-top: 80px;
	border-top: 1px solid #ddd;
	padding-top: 40px;
				}
				
.related-tag-lg{
text-align: center;
  margin: 0 0 30px 0;
				}
				
.related-tag-lg.post-tags-list a{	
  padding: 4px 16px;
  background: #eee;
  color: #626262;
  text-decoration: none;
  border-radius: 6px;
  font-size: 14px;
				}
				
.related-tag-lg.post-tags-list a:hover {
  background-color: #e4eff5;
				}
.related-heading-lg {
	font-size: 24px;
	text-align: center;
	font-weight: 100;
					padding: 0 0 15px 0;
  letter-spacing: 2px;
  margin-bottom: 15px;
}

h3.related-heading-lg::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 82px;
	height: 1px;
	background-color: #86afc4;
}

.media-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;

}

.media-grid-item {
	text-decoration: none;
	border-radius: 6px;
	color: #333;
	margin: 0 0 20px 0;
	transition: opacity 0.3s;
}

.media-grid-item:hover {
	opacity: 0.8;
	background-color: #fff;
}

.media-grid-thumb {
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 6px;
	margin-bottom: 10px;
	position: relative;
}

.media-grid-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.media-grid-title {
	font-size: 16px;
	line-height: 1.4;
	margin: 0;
	padding: 0;
	text-align: center;
}

h2.media-grid-title::after {
	width: 0px;
	height: 0px;
}

.media-grid-time {
	font-size: 12px;
	color: #666;
	margin-top: 5px;
	text-align: center;
}


.archive-movie-play-icon {
	position: absolute;
	top: 18%;
	left: 90%;
	transform: translate(-50%, -50%);
	color: #ffffff80;
	font-size: 40px;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

@media (max-width: 768px) {
	.media-grid {
		grid-template-columns: 1fr;
	}

	.author-box {
		flex-direction: column;
		text-align: center;
	}

	.author-avatar img {
		max-width: 50%;
	}
}

.home-section,
{
padding-top: 20px;
margin-bottom: 20px;
}

.section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.section-header h2 {
	margin: 30px 0 30px 0;
}


.more-link {
	border: 1px solid #86afc4;
	color: #176a93;
	padding: 10px;
	margin: 2px 5px 0 0;
	border-radius: 5px;
	font-size: 16px;
	transition: background 0.2s;
	line-height: 18px;
}

.more-link:hover {
	background: #e4eff5;
	color: #176a93;
}

.contact-form-box {
	max-width: 600px;
	margin: 0 auto;
	padding: 20px;
}

.form-item {
	margin-bottom: 25px;
}

.form-label {
	display: block;
	font-weight: bold;
	font-size: 14px;
	margin-bottom: 8px;
	color: #333;
}

.form-label::after {
	content: '';
	color: #e74c3c;
	margin-left: 5px;
}

.wpcf7-form-control-wrap input,
.wpcf7-form-control-wrap textarea {
	width: 100%;
	padding: 12px 15px;
	font-size: 16px;
	border: 1px solid #ddd;
	border-radius: 8px;
	background: #f9f9f9;
	box-sizing: border-box;
	transition: all 0.3s ease;
}

.wpcf7-form-control-wrap input:focus,
.wpcf7-form-control-wrap textarea:focus {
	background: #fff;
	border-color: #3498db;
	box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.2);
	outline: none;
}

.wpcf7-form-control-wrap textarea {
	resize: vertical;
	min-height: 150px;
}

.wpcf7-submit {
	display: block;
	width: 100%;
	max-width: 300px;
	margin: 30px auto 0;
	padding: 15px;
	background: linear-gradient(135deg, #839ab3 0%, #396fa8 100%);
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	transition: transform 0.1s, opacity 0.2s;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.wpcf7-submit:hover {
	opacity: 0.9;
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}

.wpcf7-submit:active {
	transform: translateY(0);
}

@media (max-width: 600px) {
	.contact-form-box {
		padding: 0;
	}

	.wpcf7-submit {
		width: 100%;
		max-width: none;
	}
				}
				
.entry-content iframe[src*="youtube"],
.entry-content iframe[src*="youtu.be"] {		
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 16 / 9;
}

@supports not (aspect-ratio: 16 / 9) {
	.entry-content iframe {
		height: 56.25vw;
	}
	}
								
.ad-wrapper{
					margin:30px 0 45px 0;
				}
				
/* reCAPTCHAバッジを非表示にする */
.grecaptcha-badge { visibility: hidden; }