/* コメント */
.c-comment {
	--tcd-comment-base-font-size: 16px;
	--tcd-comment-base-margin: 40px;
	--tcd-comment-base-main-color: #000000;
	--tcd-comment-base-bg-color: #f6f6f6;
	--tcd-comment-base-border-color: #dddddd;
	display: flex;
	flex-direction: column;
	row-gap: var(--tcd-comment-base-margin);
	font-size: var(--tcd-comment-base-font-size);
	color: #000000;
}

@media (max-width: 991px) {
	.c-comment {
		--tcd-comment-base-margin: 30px;
		--tcd-comment-base-font-size: 14px;
	}
}

@media (max-width: 767px) {
	.c-comment {
		--tcd-comment-base-margin: 25px;
		--tcd-comment-base-font-size: 14px;
	}
}

/* コメントリスト */
.c-comment-list {
	display: grid;
	align-content: start;
}

.c-comment-list-item {
	display: grid;
	align-content: start;
	border: 1px solid var(--tcd-comment-base-border-color);
	margin-top: -1px;
}

.c-comment-list-item--parent {
	gap: calc(var(--tcd-comment-base-margin) - 10px);
	padding: var(--tcd-comment-base-margin);
}

.c-comment-list-item--child {
	gap: calc(var(--tcd-comment-base-margin) - 10px);
	padding: calc(var(--tcd-comment-base-margin) - 10px);
}

.c-comment-list-item-body {
	display: grid;
	align-content: start;
	gap: calc(var(--tcd-comment-base-margin) - 10px);
}

.c-comment-list-item__meta {
	display: flex;
	gap: 10px;
}

.c-comment-list-item__avater {
	flex: 0 0 40px;
	border-radius: 50%;
}

.c-comment-list-item__user {
	flex: 1;
	display: grid;
	align-content: start;
	gap: 10px;
}

.c-comment-list-item__user-name {
	font-weight: 600;
	line-height: 1.5;
	margin-block: -0.25em;
}

.c-comment-list-item__user-date {
	color: #999999;
	font-size: calc(var(--tcd-comment-base-font-size) - 2px);
}

.c-comment-list-item__moderation {
	font-size: calc(var(--tcd-comment-base-font-size) - 2px);
	padding: 0.4em 1em;
	line-height: 1.8;
	background: var(--tcd-comment-base-bg-color);
}

.c-comment-list-item__content {
	line-height: 1.8;
	margin-block: -0.4em;
}

.c-comment-list-item__action :where(a) {
	display: grid;
	place-items: center;
	height: 25px;
	min-width: 50px;
	padding-inline: 1em;
	font-size: 12px;
	line-height: 1;
	color: var(--tcd-comment-base-main-color);
	border: 1px solid var(--tcd-comment-base-main-color);
	border-radius: calc(infinity* 1px);
}

.c-comment-not-found {
	text-align: center;
	line-height: 1.6;
	padding: calc(var(--tcd-comment-base-margin) - 0.3em) var(--tcd-comment-base-margin);
	border: 1px solid var(--tcd-comment-base-border-color);
}

@media (any-hover: hover) {
	.c-comment-list-item__action :where(a):hover {
		color: #ffffff !important;
		background: var(--tcd-comment-base-main-color);
	}
}

@media (max-width: 767px) {
	.c-comment-list-item {
		padding: calc(var(--tcd-comment-base-margin) - 10px);
	}
}

/* コメントページャー */
.c-comment-pager {
	display: grid;
	grid-template-columns: repeat(auto-fit, 50px);
	grid-template-rows: 50px;
	column-gap: 10px;
	justify-content: center;
	font-size: 14px;
	font-family: Arial;
	text-align: center;
}

.c-comment-pager> :where(*) {
	display: grid;
	place-items: center;
	background: var(--tcd-comment-base-bg-color);
	border-radius: 50%;
}

.c-comment-pager> :where(.current) {
	color: #ffffff;
	background: var(--tcd-comment-base-main-color);
}

@media (any-hover: hover) {
	.c-comment-pager> :where(a):hover {
		color: #ffffff;
		background: var(--tcd-comment-base-main-color);
	}
}

@media (max-width: 767px) {
	.c-comment-pager {
		grid-template-columns: repeat(auto-fit, 40px);
		grid-template-rows: 40px;
	}
}

/* コメントフォーム */
.c-comment-post {
	padding: var(--tcd-comment-base-margin);
	border: 1px solid var(--tcd-comment-base-border-color);
	background: var(--tcd-comment-base-bg-color);
}

.c-comment-list :where(.c-comment-post) {
	padding: calc(var(--tcd-comment-base-margin) - 10px);
}

.c-comment-post-title {
	display: none;
}

/* ログアウトユーザー向けの文言 */
.c-comment-must-log-in {
	text-align: center;
	line-height: 1.6;
	margin-block: -0.3em;
}

/* ログイン中のユーザー向けの文言 */
.c-comment-logged-in-as {
	display: grid;
	grid-template-columns: 1fr auto;
	column-gap: 5px;
	line-height: 1.6;
	margin-block: -0.3em;
}

/* コメントリスト内では非表示 */
.c-comment-list .c-comment-logged-in-as {
	display: none;
}

/* コメントリスト内のみ表示 */
.c-comment-list :where(.c-comment-post-title) {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	margin-bottom: calc(var(--tcd-comment-base-margin) - 10px);
}

.c-comment-post-cancel {
	font-weight: normal;
}

/* フォーム */
.c-comment-form {
	display: flex;
	flex-direction: column;
	row-gap: var(--tcd-comment-base-margin);
}

/* コメントリスト内のみ表示 */
.c-comment-list :where(.c-comment-form) {
	row-gap: calc(var(--tcd-comment-base-margin) - 10px);
}

.c-comment-form-item {
	display: flex;
	flex-direction: column;
	row-gap: 15px;
}

/* form input */
.c-comment-form-item__label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 600;
}

.c-comment-form-item__label-required {
	display: grid;
	place-items: center;
	height: 25px;
	min-width: 50px;
	padding-inline: 1em;
	font-size: 12px;
	color: #ffffff;
	background: var(--tcd-comment-base-main-color);
	border-radius: calc(infinity * 1px);
}

.c-comment-form-item__input {
	font-size: 16px;
	border: none;
	height: 50px;
	padding: 0 1em;
	background: #ffffff;
}

.c-comment-form-item__textarea {
	font-size: 16px;
	border: none;
	padding: 1em;
	background: #ffffff;
}

/* cookies checkbox */
.comment-form-cookies-consent {
	line-height: 1.4;
	margin-block: -0.2em;
}

/* submit */
.c-comment-form-submit {
	color: #ffffff;
	text-align: center;
}

.c-comment-form-submit-button {
	display: inline-grid;
	place-items: center;
	min-width: 280px;
	height: 60px;
	border: none;
	background: var(--tcd-comment-base-main-color);
	border-radius: calc(infinity * 1px);
}

@media (any-hover: hover) {
	.c-comment-form-submit-button:hover {
		background: color-mix(in srgb, var(--tcd-comment-base-main-color) 70%, white);
	}
}

@media (max-width: 767px) {

	.c-comment-form-item {
		row-gap: 10px;
	}

	.c-comment-form-item__input {
		height: 40px;
	}

	.c-comment-form-item__label-required {
		height: 20px;
		min-width: 40px;
		font-size: 10px;
	}

	.c-comment-form-submit-button {
		min-width: 240px;
		height: 50px;
	}
}