/**
 * Kuchikomi Review - Front Styles
 *
 * @package Kuchikomi_Review
 */

/* ==========================================================================
   Utility
   ========================================================================== */
.p-kuchikomi-flex { display: flex; }
.p-kuchikomi-flex-center { display: flex; align-items: center; justify-content: center; }
.p-kuchikomi-flex-align { display: flex; align-items: center; }
.p-kuchikomi-flex-wrap { display: flex; flex-wrap: wrap; }

/* ==========================================================================
   Star Rating
   ========================================================================== */
.p-kuchikomi-star {
	display: inline-flex;
	align-items: center;
	font-size: 16px;
	color: #bababa;
}
.p-kuchikomi-star__icon {
	position: relative;
}
.p-kuchikomi-star__icon + .p-kuchikomi-star__icon {
	margin-left: -0.1em;
}
.p-kuchikomi-star__icon.is-active::before {
	content: '\2605';
	position: absolute;
	inset: 0;
	margin: auto;
	color: var(--kuchikomi-star-color, #ff7f00);
}
.p-kuchikomi-star__icon.is-last::before {
	clip-path: inset(0 50% 0 0);
}
.p-kuchikomi-star__total {
	font-size: 14px;
	font-weight: 600;
	color: #000;
	margin: 0 0 -2px 5px;
}

/* ==========================================================================
   Ranking Label (Badge)
   ========================================================================== */
.p-kuchikomi-ranking-label {
	display: block;
	overflow: hidden;
	height: 45px;
	position: relative;
	font-weight: 600;
	font-size: 16px;
	width: 40px;
}
.p-kuchikomi-ranking-label__number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 35px;
	position: relative;
	z-index: 1;
	color: #000;
	background: #eee;
	padding-top: 3px;
	font-family: 'Arial', sans-serif;
}
.p-kuchikomi-ranking-label::before,
.p-kuchikomi-ranking-label::after {
	content: '';
	position: absolute;
	width: 23px;
	height: 23px;
	background: #eee;
	bottom: 4px;
}
.p-kuchikomi-ranking-label::before {
	transform: rotate(160deg);
	left: -5px;
}
.p-kuchikomi-ranking-label::after {
	transform: rotate(-160deg);
	right: -5px;
}
.p-kuchikomi-ranking-label--1::before,
.p-kuchikomi-ranking-label--1::after,
.p-kuchikomi-ranking-label--1 .p-kuchikomi-ranking-label__number {
	color: #fff;
	background: var(--kuchikomi-ranking1-color, #b28c08);
}
.p-kuchikomi-ranking-label--2::before,
.p-kuchikomi-ranking-label--2::after,
.p-kuchikomi-ranking-label--2 .p-kuchikomi-ranking-label__number {
	color: #fff;
	background: var(--kuchikomi-ranking2-color, #8f9396);
}
.p-kuchikomi-ranking-label--3::before,
.p-kuchikomi-ranking-label--3::after,
.p-kuchikomi-ranking-label--3 .p-kuchikomi-ranking-label__number {
	color: #fff;
	background: var(--kuchikomi-ranking3-color, #7a4905);
}

@media (max-width: 767px) {
	.p-kuchikomi-ranking-label {
		width: 35px;
		height: 40px;
		font-size: 14px;
	}
	.p-kuchikomi-ranking-label__number {
		height: 33px;
		padding-top: 2px;
	}
	.p-kuchikomi-ranking-label::before,
	.p-kuchikomi-ranking-label::after {
		width: 20px;
		height: 20px;
		bottom: 3px;
	}
}

/* ==========================================================================
   Category Badge
   ========================================================================== */
.p-kuchikomi-category {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 100px;
	height: 50px;
	padding: 0 1em;
	font-size: 14px;
	line-height: 1.6;
	color: #000;
	text-decoration: none;
	background: rgba(255, 255, 255, 0.72);
	z-index: 1;
	transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease;
}
.p-kuchikomi-category:hover {
	background: #000;
	color: #fff;
	transform: scale(1.06);
}
.p-kuchikomi-category--round {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 100px;
	height: 30px;
	padding: 0 15px;
	font-size: 12px;
	line-height: 1.6;
	color: #000;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 50px;
	transition: color 0.3s ease;
}

@media (max-width: 767px) {
	.p-kuchikomi-category {
		font-size: 12px;
		height: 40px;
	}
}

/* ==========================================================================
   Review Counts
   ========================================================================== */
.p-kuchikomi-counts {
	color: #999;
	display: inline-flex;
	align-items: center;
}
.p-kuchikomi-counts__icon {
	font-size: 12px;
}
.p-kuchikomi-counts__number {
	font-size: 14px;
	margin-left: 5px;
}

/* ==========================================================================
   Single - Header
   ========================================================================== */
.p-kuchikomi-single {
	max-width: 900px;
	margin: 0 auto;
	padding: 40px 20px;
}
.p-kuchikomi-single__header {
	margin-bottom: 20px;
}
.p-kuchikomi-single__header-info {
	display: flex;
}
.p-kuchikomi-single__header-meta {
	width: 100%;
}
.p-kuchikomi-single__rank {
	width: 100px;
	min-width: 100px;
	padding-right: 35px;
	text-align: center;
}
.p-kuchikomi-single__rank + .p-kuchikomi-single__header-meta {
	width: calc(100% - 100px);
}
.p-kuchikomi-single__rank .p-kuchikomi-ranking-label {
	margin: 0 auto;
}
.p-kuchikomi-single__rank-desc {
	font-size: 12px;
	line-height: 1.5;
	margin-top: 10px;
}
.p-kuchikomi-single__title {
	font-size: 24px;
	line-height: 1.5;
	margin: 0 0 10px;
}
.p-kuchikomi-single__header-stats {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 15px 0 0;
	padding: 0;
}
.p-kuchikomi-single__header-stats a {
	color: inherit;
	text-decoration: none;
}

@media (max-width: 767px) {
	.p-kuchikomi-single {
		padding: 20px 15px;
	}
	.p-kuchikomi-single__rank {
		width: 70px;
		min-width: 70px;
		padding-right: 15px;
	}
	.p-kuchikomi-single__rank + .p-kuchikomi-single__header-meta {
		width: calc(100% - 70px);
	}
	.p-kuchikomi-single__title {
		font-size: 20px;
	}
}

/* ==========================================================================
   Single - Header Media (Gallery / Video / YouTube)
   ========================================================================== */
.p-kuchikomi-single__header-media {
	margin-top: 40px;
	position: relative;
}
.p-kuchikomi-single__images-main {
	background: #f5f5f5;
}
.p-kuchikomi-single__images-main img {
	width: 100%;
	height: auto;
}
.p-kuchikomi-single__images-sub-list {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0 0 0 -10px;
	padding: 0;
}
.p-kuchikomi-single__images-sub-item {
	cursor: pointer;
	width: calc(20% - 10px);
	aspect-ratio: 1 / 1;
	margin: 10px 0 0 10px;
	transition: opacity 0.2s ease;
	background: #f5f5f5;
	overflow: hidden;
}
.p-kuchikomi-single__images-sub-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.p-kuchikomi-single__images-sub-item.is-active {
	pointer-events: none;
	opacity: 0.5;
}
.p-kuchikomi-single__images-sub-item:hover {
	opacity: 0.5;
}
.p-kuchikomi-single__video video {
	width: 100%;
	height: auto;
	background: #333;
}
.p-kuchikomi-single__youtube {
	position: relative;
	padding-top: 56.25%;
	background: #333;
}
.p-kuchikomi-single__youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

@media (max-width: 767px) {
	.p-kuchikomi-single__header-media {
		margin-top: 25px;
	}
	.p-kuchikomi-single__images-sub-list {
		margin: 0;
		flex-wrap: nowrap;
		overflow-x: auto;
	}
	.p-kuchikomi-single__images-sub-item {
		width: 95px;
		min-width: 95px;
		aspect-ratio: 1 / 1;
		margin: 8px 0 0 8px;
	}
}

/* ==========================================================================
   Single - Content
   ========================================================================== */
.p-kuchikomi-single__content {
	margin-top: 30px;
}
.p-kuchikomi-single__entry {
	line-height: 2;
	font-size: 16px;
}
.p-kuchikomi-single__entry img {
	max-width: 100%;
	height: auto;
}

/* ==========================================================================
   Single - Table
   ========================================================================== */
.p-kuchikomi-table {
	margin-top: 40px;
}
.p-kuchikomi-table__table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid #ddd;
	font-size: 16px;
	line-height: 1.6;
}
.p-kuchikomi-table__table th,
.p-kuchikomi-table__table td {
	padding: 15px 20px;
	border-top: 1px solid #ddd;
	vertical-align: middle;
}
.p-kuchikomi-table__table th {
	width: 25%;
	text-align: center;
	background: #f5f5f5;
	border-right: 1px solid #ddd;
	font-weight: normal;
}
.p-kuchikomi-table__table td {
	width: 75%;
}
.p-kuchikomi-table__tags {
	margin-top: 20px;
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}
.p-kuchikomi-table__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 60px;
	height: 30px;
	font-size: 12px;
	padding: 0 10px;
	background: #eee;
	border-radius: 5px;
	color: inherit;
	text-decoration: none;
	transition: background 0.3s ease, color 0.3s ease;
}
.p-kuchikomi-table__tag:hover {
	background: #333;
	color: #fff;
}
.p-kuchikomi-table__cta {
	margin-top: 30px;
	text-align: center;
}
.p-kuchikomi-table__cta-btn {
	display: inline-block;
	padding: 12px 40px;
	font-size: 16px;
	color: #fff;
	background: #333;
	border-radius: 5px;
	text-decoration: none;
	transition: opacity 0.3s ease;
}
.p-kuchikomi-table__cta-btn:hover {
	opacity: 0.7;
}

@media (max-width: 767px) {
	.p-kuchikomi-table__table {
		font-size: 14px;
	}
	.p-kuchikomi-table__table th,
	.p-kuchikomi-table__table td {
		padding: 12px 15px;
	}
}

/* ==========================================================================
   Single - Overall Rating
   ========================================================================== */
.p-kuchikomi-rating {
	padding: 40px;
	border: 1px solid #ddd;
	margin-top: 40px;
	display: flex;
}
.p-kuchikomi-rating__total {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 180px;
	text-align: center;
}
.p-kuchikomi-rating__total-label {
	font-size: 14px;
	margin-bottom: 10px;
}
.p-kuchikomi-rating__total-number {
	font-size: 40px;
	font-weight: 700;
}
.p-kuchikomi-rating__total .p-kuchikomi-star {
	margin-top: 10px;
}
.p-kuchikomi-rating__total .p-kuchikomi-counts {
	margin-top: 10px;
}
.p-kuchikomi-rating__split {
	display: flex;
	gap: 24px;
	width: 100%;
	align-items: center;
}
.p-kuchikomi-rating__list-col {
	flex: 0 0 55%;
}
.p-kuchikomi-rating__matrix-col {
	flex: 1;
	min-width: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
.p-kuchikomi-matrix {
	width: 100%;
	max-width: 260px;
}
.p-kuchikomi-rating__list {
	width: 100%;
	list-style: none;
	margin: 0;
	padding: 0;
}
.p-kuchikomi-rating__item + .p-kuchikomi-rating__item {
	margin-top: 40px;
}
.p-kuchikomi-rating__item-info {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.p-kuchikomi-rating__item-label {
	font-size: 16px;
	padding-left: 10px;
}
.p-kuchikomi-rating__item-score {
	margin-top: 20px;
	width: 100%;
	height: 8px;
	background: #ddd;
	border-radius: 8px;
	overflow: hidden;
}
.p-kuchikomi-rating__item-score-bar {
	display: block;
	width: 0%;
	height: 100%;
	background: var(--kuchikomi-star-color, #ff7f00);
	transition: width 1s 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}

@media (max-width: 767px) {
	.p-kuchikomi-rating {
		flex-direction: column;
		padding: 40px 20px;
		border-left: none;
		border-right: none;
	}
	.p-kuchikomi-rating__split {
		flex-direction: column;
	}
	.p-kuchikomi-rating__list-col {
		flex: none;
		width: 100%;
	}
	.p-kuchikomi-rating__matrix-col {
		width: 100%;
		margin-top: 24px;
	}
	.p-kuchikomi-rating__list {
		width: 100%;
		margin-top: 0;
	}
	.p-kuchikomi-rating__item-label {
		padding-left: 0;
	}
	.p-kuchikomi-rating__item-score {
		margin-top: 15px;
		height: 7px;
	}
}

/* ==========================================================================
   Single - Comment List
   ========================================================================== */
.p-kuchikomi-comments {
	margin-top: 40px;
}
.p-kuchikomi-comments__headline {
	font-size: 18px;
	line-height: 1.6;
	color: #fff;
	text-align: center;
	position: relative;
	padding: 15px 40px;
	background: #333;
	margin: 0;
}
.p-kuchikomi-comments__headline-count {
	position: absolute;
	top: 0;
	right: 30px;
	height: 100%;
	display: flex;
	align-items: center;
}
.p-kuchikomi-comments__headline-count .p-kuchikomi-counts {
	color: #fff;
}
.p-kuchikomi-comments__item {
	padding: 40px;
	border: 1px solid #ddd;
	margin-top: -1px;
}
.p-kuchikomi-comments__item-title {
	font-size: 18px;
	line-height: 2;
	margin: 0;
	font-weight: 600;
}
.p-kuchikomi-rating__list--mini .p-kuchikomi-rating__item + .p-kuchikomi-rating__item {
	margin-top: 16px;
}
.p-kuchikomi-rating__list--mini .p-kuchikomi-rating__item-label {
	font-size: 13px;
	padding-left: 0;
}
.p-kuchikomi-rating__list--mini .p-kuchikomi-rating__item-score {
	margin-top: 8px;
	height: 6px;
}
.p-kuchikomi-comments__item-rating-split {
	display: flex;
	gap: 20px;
	align-items: center;
	margin-top: 15px;
}
.p-kuchikomi-comments__item-rating-split .p-kuchikomi-comments__item-rating,
.p-kuchikomi-comments__item-rating-split .p-kuchikomi-rating__list--mini {
	flex: 0 0 55%;
	width: auto;
	margin-top: 0;
}
.p-kuchikomi-comments__item-rating-matrix {
	flex: 1;
	min-width: 0;
	display: flex;
	justify-content: center;
}
.p-kuchikomi-matrix--comment {
	width: 100%;
	max-width: 200px;
}
@media (max-width: 767px) {
	.p-kuchikomi-comments__item-rating-split {
		flex-direction: column;
	}
	.p-kuchikomi-comments__item-rating-split .p-kuchikomi-comments__item-rating,
	.p-kuchikomi-comments__item-rating-split .p-kuchikomi-rating__list--mini {
		flex: none;
		width: 100%;
	}
}
.p-kuchikomi-comments__item-rating {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	margin-top: 20px;
	font-size: 14px;
	color: #999;
}
.p-kuchikomi-comments__item-rating-entry {
	display: flex;
	gap: 5px;
	white-space: nowrap;
}
.p-kuchikomi-comments__item-rating-value {
	color: #000;
	font-weight: 600;
}
.p-kuchikomi-comments__item-desc {
	font-size: 14px;
	line-height: 2.2;
	margin-top: 15px;
}
.p-kuchikomi-comments__item-images {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 10px;
	margin-top: 25px;
}
.p-kuchikomi-comments__item-images a {
	position: relative;
	aspect-ratio: 1;
	background-color: #f6f6f6;
	display: block;
}
.p-kuchikomi-comments__item-images img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.p-kuchikomi-comments__item-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	font-size: 14px;
	color: #999;
	margin-top: 15px;
	list-style: none;
	padding: 0;
}
.p-kuchikomi-comments__item-like {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: #666;
	margin-top: 25px;
}
.p-kuchikomi-comments__item-like-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 28px;
	font-size: 12px;
	background: #f5f5f5;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: background 0.3s ease, color 0.3s ease;
}
.p-kuchikomi-comments__item-like-btn.is-liked {
	color: #fff;
	background: #333;
}
.p-kuchikomi-comments__item-like-count {
	color: #333;
	font-weight: 600;
}
.p-kuchikomi-comments__no-comments {
	font-size: 16px;
	text-align: center;
	padding: 40px 20px;
	border: 1px solid #ddd;
	border-top: none;
}

/* Reply comments */
.p-kuchikomi-comments .children .p-kuchikomi-comments__item {
	padding: 25px;
	margin-top: 30px;
}

@media (max-width: 767px) {
	.p-kuchikomi-comments__headline {
		font-size: 16px;
		padding: 12px 20px;
	}
	.p-kuchikomi-comments__item {
		padding: 25px 20px;
	}
	.p-kuchikomi-comments__item-title {
		font-size: 16px;
	}
	.p-kuchikomi-comments__item-images {
		grid-template-columns: repeat(3, 1fr);
		margin-top: 20px;
	}
	.p-kuchikomi-comments__no-comments {
		font-size: 14px;
	}
}

/* ==========================================================================
   Single - Sort Filter
   ========================================================================== */
.p-kuchikomi-comments__sort {
	display: flex;
	justify-content: center;
	font-size: 14px;
	text-align: center;
	margin: 30px 0;
}
.p-kuchikomi-comments__sort-btn {
	cursor: pointer;
	display: flex;
	align-items: center;
	padding: 0 20px;
	height: 30px;
	transition: color 0.3s ease;
	background: none;
	border: none;
	font-size: inherit;
}
.p-kuchikomi-comments__sort-btn input {
	display: none;
}
.p-kuchikomi-comments__sort-btn.is-active {
	pointer-events: none;
	font-weight: 600;
}
.p-kuchikomi-comments__sort-btn + .p-kuchikomi-comments__sort-btn {
	border-left: 1px solid #ddd;
}

@media (max-width: 767px) {
	.p-kuchikomi-comments__sort {
		margin: 20px 0;
		overflow-x: auto;
		font-size: 13px;
	}
	.p-kuchikomi-comments__sort-btn {
		white-space: nowrap;
		padding: 0 1em;
	}
}

/* ==========================================================================
   Single - Write Review Button
   ========================================================================== */
.p-kuchikomi-write-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #ddd;
	height: 60px;
	margin-top: 40px;
	cursor: pointer;
	font-size: 16px;
	background: none;
	width: 100%;
	transition: color 0.3s ease;
}
.p-kuchikomi-write-btn:hover {
	color: #999;
}

@media (max-width: 767px) {
	.p-kuchikomi-write-btn {
		height: 50px;
	}
}

/* ==========================================================================
   Single - Comment Form
   ========================================================================== */
.p-kuchikomi-form-wrapper {
	display: grid;
	grid-template-rows: 0fr;
	margin-top: -1px;
	transition: grid-template-rows 0.5s ease;
}
.p-kuchikomi-form-wrapper.is-active {
	grid-template-rows: 1fr;
}
.p-kuchikomi-form-wrapper-inner {
	overflow: hidden;
}
.p-kuchikomi-form {
	background: #f5f5f5;
}
.p-kuchikomi-form__header {
	font-size: 18px;
	line-height: 1.6;
	padding: 15px 40px;
	color: #fff;
	background: #333;
	margin: 0;
}
.p-kuchikomi-form__body {
	border: 1px solid #ddd;
	border-top: none;
}
.p-kuchikomi-form__item {
	padding: 40px;
}
.p-kuchikomi-form__item + .p-kuchikomi-form__item {
	border-top: 1px solid #ddd;
}
.p-kuchikomi-form__label {
	display: block;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.6;
	margin-bottom: 15px;
}
.p-kuchikomi-form__label + .p-kuchikomi-form__label {
	margin-top: 40px;
}
.p-kuchikomi-form__required,
.p-kuchikomi-form__any {
	display: inline-block;
	min-width: 50px;
	height: 25px;
	line-height: 25px;
	text-align: center;
	font-size: 12px;
	padding: 0 10px;
	margin-left: 10px;
	color: #fff;
	font-weight: 500;
	border-radius: 25px;
}
.p-kuchikomi-form__required {
	background: #000;
}
.p-kuchikomi-form__any {
	background: #7f7f7f;
}
.p-kuchikomi-form__text {
	width: 100%;
	height: 50px;
	padding: 0 20px;
	border: none;
	background: #fff;
}
.p-kuchikomi-form__text:disabled {
	background: #e0e0e0;
	color: #333;
	opacity: 1;
	cursor: default;
	border: 1px solid #bbb;
}
.p-kuchikomi-form__item--loggedin-note {
	padding-top: 0 !important;
	border-top: none !important;
}
.p-kuchikomi-form__loggedin-note {
	font-size: 13px;
	color: #555;
	margin: 0;
	padding: 0 40px 20px;
}
.p-kuchikomi-form__loggedin-note a {
	color: #333;
	text-decoration: underline;
}
.p-kuchikomi-form__textarea {
	width: 100%;
	min-height: 260px;
	padding: 15px 20px;
	border: none;
	background: #fff;
	line-height: 1.6;
}
.p-kuchikomi-form__desc {
	font-size: 14px;
	line-height: 1.8;
	margin-top: 15px;
}
.p-kuchikomi-form__submit {
	margin-bottom: 40px;
	text-align: center;
}
.p-kuchikomi-form__submit-btn {
	border: none;
	padding: 12px 40px;
	font-size: 16px;
	cursor: pointer;
	background: #333;
	color: #fff;
	border-radius: 5px;
}
.p-kuchikomi-form__submit-btn:hover {
	opacity: 0.7;
}

/* Star rating in form */
.p-kuchikomi-form__rating-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 20px 30px;
	background: #fff;
	font-weight: 600;
	font-size: 16px;
}
.p-kuchikomi-form__rating-item + .p-kuchikomi-form__rating-item {
	margin-top: 20px;
}
.p-kuchikomi-form__rating-head-label {
	margin-right: auto;
}
.p-kuchikomi-form__rating-stars-value {
	display: flex;
	align-items: center;
	margin-left: auto;
}
.p-kuchikomi-form__rating-stars-input {
	display: none;
}
.p-kuchikomi-form__rating-stars-icon {
	cursor: pointer;
	font-size: 24px;
	color: #bababa;
}
.p-kuchikomi-form__rating-stars-icon.is-checked {
	color: var(--kuchikomi-star-color, #ff7f00);
}
.p-kuchikomi-form__rating-position-value {
	display: flex;
	align-items: center;
	margin-left: auto;
}
.p-kuchikomi-form__rating-position-input {
	display: none;
}
.p-kuchikomi-form__rating-position-icon {
	cursor: pointer;
	font-size: 0;
	line-height: 1;
	padding: 4px;
	user-select: none;
}
.p-kuchikomi-form__rating-position-icon::before {
	content: '○';
	font-size: 28px;
	color: #bababa;
}
.p-kuchikomi-form__rating-position-icon.is-checked::before {
	content: '●';
	color: #333;
}

/* Caution area */
.p-kuchikomi-form__caution-headline {
	font-size: 16px;
	color: #b20000;
	font-weight: 600;
	text-align: center;
	margin: 0 0 15px;
}
.p-kuchikomi-form__caution-desc {
	font-size: 14px;
	line-height: 2.2;
}
.p-kuchikomi-form__caution-desc a {
	color: #1578d6;
}
.p-kuchikomi-form__caution-desc a:hover {
	text-decoration: underline;
}

@media (max-width: 767px) {
	.p-kuchikomi-form__header {
		font-size: 16px;
		text-align: center;
		padding: 12px 20px;
	}
	.p-kuchikomi-form__item {
		padding: 30px 20px;
	}
	.p-kuchikomi-form__text {
		height: 45px;
		padding: 0 15px;
	}
	.p-kuchikomi-form__rating-head {
		padding: 15px;
	}
	.p-kuchikomi-form__rating-item {
		padding: 15px;
		font-size: 14px;
	}
	.p-kuchikomi-form__rating-stars-icon {
		font-size: 20px;
	}
}

/* Image upload in form */
.p-kuchikomi-form__upload-label {
	cursor: pointer;
	display: block;
	width: fit-content;
}
.p-kuchikomi-form__upload-preview {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 10px;
	margin-top: 20px;
}
.p-kuchikomi-form__upload-preview:empty {
	display: none;
}
.p-kuchikomi-form__upload-preview li {
	position: relative;
	aspect-ratio: 1;
	border: 1px solid #ddd;
}
.p-kuchikomi-form__upload-preview img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.p-kuchikomi-form__upload-preview button {
	cursor: pointer;
	position: absolute;
	top: 2px;
	right: 2px;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #fff;
	border: 1px solid #ddd;
	font-size: 14px;
	line-height: 1;
}
.p-kuchikomi-form__upload-errors {
	font-size: 14px;
	color: #b20000;
	line-height: 1.6;
	margin-top: 15px;
	list-style: none;
	padding: 0;
}
.p-kuchikomi-form__upload-errors:empty {
	display: none;
}

@media (max-width: 767px) {
	.p-kuchikomi-form__upload-preview {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ==========================================================================
   Filter Navigation
   ========================================================================== */
.p-kuchikomi-nav {
	margin: 24px 0;
	border: 1px solid #e8e4db;
	border-radius: 8px;
	padding: 14px 18px;
	background: #fafaf8;
}
.p-kuchikomi-nav .p-producer-nav__row {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-bottom: 10px;
}
.p-kuchikomi-nav .p-producer-nav__row:last-child {
	margin-bottom: 0;
}
.p-kuchikomi-nav .p-producer-nav__label {
	flex-shrink: 0;
	width: 4.5em;
	font-size: 0.72rem;
	font-weight: bold;
	color: #999;
	padding-top: 5px;
	letter-spacing: 0.03em;
}
.p-kuchikomi-nav .p-producer-nav__items {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.p-kuchikomi-nav .p-producer-nav__item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.93rem;
	color: #555;
	background: #fff;
	border: 1px solid #d8d4cc;
	border-radius: 20px;
	padding: 6px 18px;
	text-decoration: none;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
	white-space: nowrap;
}
.p-kuchikomi-nav .p-producer-nav__item:hover {
	background: #f0ece5;
	border-color: #b8b0a0;
	color: #333;
}
.p-kuchikomi-nav .p-producer-nav__item.is-active {
	background: #8b6914;
	border-color: #8b6914;
	color: #fff;
}
.p-kuchikomi-nav .p-producer-nav__count {
	font-size: 0.75em;
	opacity: 0.7;
}
.p-kuchikomi-nav .p-producer-nav__item.is-active .p-producer-nav__count {
	opacity: 0.85;
}
.p-kuchikomi-nav .p-producer-nav__row--sub {
	margin-top: -4px;
}
.p-kuchikomi-nav .p-producer-nav__item--sub {
	font-size: 0.85rem;
	padding: 5px 14px;
	border-style: dashed;
	color: #666;
}
.p-kuchikomi-nav .p-producer-nav__item--sub:hover {
	border-style: solid;
}
.p-kuchikomi-nav .p-producer-nav__item--sub.is-active {
	border-style: solid;
	background: #6a5010;
	border-color: #6a5010;
	color: #fff;
}
/* hidden 属性を CSS の display:flex より優先 */
.p-producer-nav__row--sub.js-pnav-sub[hidden],
.js-pnav-brand[hidden] {
	display: none !important;
}
/* ブランド行ラベル */
.p-kuchikomi-nav .p-producer-nav__row--brand .p-producer-nav__label {
	color: #b8a070;
}
/* ブランドパネル表示時の下余白 */
.js-pnav-brand:not([hidden]) {
	margin-bottom: 10px;
}
/* 子タームを持つ親アイテム: ▾ インジケーター */
.p-kuchikomi-nav .p-producer-nav__item[data-pnav-id]::after {
	content: '▾';
	font-size: 10px;
	margin-left: 2px;
	opacity: 0.45;
	vertical-align: middle;
}
.p-kuchikomi-nav .p-producer-nav__item[data-pnav-id]:hover::after {
	opacity: 0.7;
}
/* トグルアイコン（スマホ用展開、リンク内に配置） */
.p-producer-nav__toggle-icon {
	display: none;
	font-size: 13px;
	line-height: 1;
	margin-left: 3px;
	color: #999;
	cursor: pointer;
	vertical-align: middle;
	transition: transform 0.25s ease, color 0.15s;
}
.p-producer-nav__toggle-icon[aria-expanded="true"] {
	transform: rotate(180deg);
	color: #8b6914;
}
@media (max-width: 600px) {
	/* l-inner の中央寄せを打ち消し、左右均等・全幅 */
	.p-kuchikomi-nav {
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		padding: 12px 10px;
		box-sizing: border-box;
	}
	.p-kuchikomi-nav .p-producer-nav__row {
		flex-direction: column;
		gap: 6px;
	}
	.p-kuchikomi-nav .p-producer-nav__label {
		width: auto;
		padding-top: 0;
	}
	/* スマホではトグルアイコンを表示、CSS ::after インジケーターを非表示 */
	.p-kuchikomi-nav .p-producer-nav__item[data-pnav-id]::after {
		display: none;
	}
	.p-producer-nav__toggle-icon {
		display: inline-block;
	}
}

/* ==========================================================================
   Archive Item Badges (region / category)
   ========================================================================== */
.p-producer-loop__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	margin-bottom: 6px;
}
.p-producer-loop__badge {
	display: inline-block;
	font-size: 10px;
	color: #555;
	background: #f0ece5;
	border-radius: 3px;
	padding: 2px 7px;
	text-decoration: none;
	line-height: 1.6;
	transition: background 0.15s, color 0.15s;
	cursor: pointer;
	position: relative;
	z-index: 1;
}
.p-producer-loop__badge:hover {
	background: #8b6914;
	color: #fff;
}
.p-producer-loop__badge--region {
	background: #e8f0e8;
}
.p-producer-loop__badge--region:hover {
	background: #4a7a4a;
	color: #fff;
}
.p-producer-loop__badge--producer {
	background: #eaecf5;
}
.p-producer-loop__badge--producer:hover {
	background: #3a4a8a;
	color: #fff;
}

/* ==========================================================================
   Pagination
   ========================================================================== */
.p-kuchikomi-pager {
	margin-top: 30px;
	text-align: center;
}
.p-kuchikomi-pager .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	margin: 0 6px;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 4px;
	font-size: 14px;
	color: #333;
	text-decoration: none;
	transition: background 0.3s ease, color 0.3s ease;
}
.p-kuchikomi-pager .page-numbers.current,
.p-kuchikomi-pager .page-numbers:hover {
	background: #333;
	color: #fff;
	border-color: #333;
}

/* ==========================================================================
   Archive
   ========================================================================== */
.p-kuchikomi-archive {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

/* Archive Tax Description */
.p-kuchikomi-archive__tax-desc {
	margin-bottom: 20px;
}
.p-kuchikomi-archive__title {
	font-size: 28px;
	margin: 0;
	line-height: 1.4;
}
.p-kuchikomi-archive__desc {
	font-size: 16px;
	margin-top: 15px;
	line-height: 1.8;
}

/* Archive Search */
.p-kuchikomi-archive__search {
	margin-top: 20px;
	margin-bottom: 30px;
	text-align: center;
}
.p-kuchikomi-archive__search .c-search-form {
	max-width: 700px;
}

/* Producer archive header search — same wider width */
.p-page-header__search .c-search-form {
	max-width: 700px;
}

/* Archive List */
.p-kuchikomi-archive__list {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: -1px;
}
.p-kuchikomi-archive__item {
	position: relative;
	background: #fff;
	width: calc(100% / 3);
	border-bottom: 1px solid #ddd;
}
.p-kuchikomi-archive__item:not(:nth-of-type(3n)) {
	border-right: 1px solid #ddd;
}
.p-kuchikomi-archive__item-link {
	display: block;
	padding: 40px;
}
.p-kuchikomi-archive__item-stretched-link {
	color: inherit;
	text-decoration: none;
}
.p-kuchikomi-archive__item-stretched-link::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	cursor: pointer;
}
.p-kuchikomi-archive__item-rank {
	position: absolute;
	left: 30px;
	top: -20px;
	z-index: 2;
}
.p-kuchikomi-archive__item-image {
	width: 100%;
	aspect-ratio: 1 / 1;
	position: relative;
	overflow: hidden;
}
.p-kuchikomi-archive__item-image .p-kuchikomi-category {
	z-index: 2;
}
.p-kuchikomi-archive__item-image-bg {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transition: transform 0.3s ease;
}
.p-kuchikomi-archive__item:hover .p-kuchikomi-archive__item-image-bg {
	transform: scale(1.05);
}
.p-kuchikomi-archive__item-image-bg--noimage {
	background-color: #f5f5f5;
}
.p-kuchikomi-archive__item-cat-only {
	margin-bottom: 15px;
}
.p-kuchikomi-archive__item-content {
	padding-top: 30px;
}
.p-kuchikomi-archive__item-title {
	font-size: 18px;
	line-height: 1.6;
	margin: 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.p-kuchikomi-archive__item-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 15px;
	list-style: none;
	padding: 0;
}
.p-kuchikomi-archive__item-excerpt {
	font-size: 14px;
	line-height: 2;
	margin-top: 15px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Archive Rating Type 2 */
.p-kuchikomi-archive__rating-type2 {
	margin-top: 20px;
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	font-size: 14px;
	color: #999;
	list-style: none;
	padding: 0;
}
.p-kuchikomi-archive__rating-type2-item {
	display: flex;
	gap: 5px;
	white-space: nowrap;
}
.p-kuchikomi-archive__rating-type2-value {
	color: #000;
	font-weight: 600;
}

/* Archive Rating Type 3 */
.p-kuchikomi-archive__rating-type3 {
	margin-top: 20px;
	display: grid;
	gap: 1px;
	grid-template-columns: 1fr 1fr;
	font-size: 12px;
	color: #666;
	background: #ddd;
	list-style: none;
	padding: 0;
}
.p-kuchikomi-archive__rating-type3-item {
	display: flex;
	gap: 3px;
	padding: 1em;
	background: #fff;
}
.p-kuchikomi-archive__rating-type3-label {
	flex: 1;
	min-width: 0;
	line-height: 1.4;
}
.p-kuchikomi-archive__rating-type3-value {
	color: #000;
	font-weight: 600;
}

/* Archive Pager */
.p-kuchikomi-archive__pager {
	margin-top: 40px;
	margin-bottom: 40px;
	text-align: center;
}
.p-kuchikomi-archive__pager .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	margin: 0 6px;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 4px;
	font-size: 16px;
	color: #333;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}
.p-kuchikomi-archive__pager .page-numbers.current,
.p-kuchikomi-archive__pager .page-numbers:hover {
	background: #333;
	color: #fff;
	border-color: #333;
}
.p-kuchikomi-archive__no-post {
	text-align: center;
	font-size: 16px;
	padding: 60px 20px;
	color: #999;
}

@media (max-width: 1024px) {
	.p-kuchikomi-archive__item-link {
		padding: 25px;
	}
	.p-kuchikomi-archive__item-image {
		aspect-ratio: 1 / 1;
	}
	.p-kuchikomi-archive__item-content {
		padding-top: 25px;
	}
	.p-kuchikomi-archive__item-title {
		font-size: 16px;
	}
}

@media (max-width: 767px) {
	.p-kuchikomi-archive {
		padding: 0 15px;
	}
	.p-kuchikomi-archive__title {
		font-size: 22px;
	}
	.p-kuchikomi-archive__item {
		width: 50%;
	}
	.p-kuchikomi-archive__item:not(:nth-of-type(3n)) {
		border-right: none;
	}
	.p-kuchikomi-archive__item:not(:nth-of-type(2n)) {
		border-right: 1px solid #ddd;
	}
}

@media (max-width: 599px) {
	.p-kuchikomi-archive__item {
		width: 100%;
		border-right: none !important;
	}
}

/* ==========================================================================
   Single - Reputation (世界の評価・評判)
   ========================================================================== */
.p-kuchikomi-reputation {
	margin-top: 40px;
	border: 1px solid #e0dbd0;
	border-radius: 6px;
	overflow: hidden;
}
.p-kuchikomi-reputation__heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0;
	padding: 14px 24px;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.5;
	color: #3d2e00;
	background: #f5f0e4;
	border-bottom: 1px solid #e0dbd0;
}
.p-kuchikomi-reputation__heading-icon {
	font-size: 18px;
	line-height: 1;
}
.p-kuchikomi-reputation__body {
	padding: 24px 28px;
	font-size: 15px;
	line-height: 2;
	color: #333;
	background: #fff;
}
.p-kuchikomi-reputation__body p {
	margin: 0 0 1em;
}
.p-kuchikomi-reputation__body p:last-child {
	margin-bottom: 0;
}

@media (max-width: 767px) {
	.p-kuchikomi-reputation__heading {
		padding: 12px 18px;
		font-size: 15px;
	}
	.p-kuchikomi-reputation__body {
		padding: 18px 18px;
		font-size: 14px;
	}
}

/* ==========================================================================
   Single - Awards (受賞歴)
   ========================================================================== */
.p-kuchikomi-awards {
	margin-top: 40px;
	border: 1px solid #d4cdb8;
	border-radius: 6px;
	overflow: hidden;
}
.p-kuchikomi-awards__heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0;
	padding: 14px 24px;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.5;
	color: #3d2e00;
	background: #f5f0e4;
	border-bottom: 1px solid #d4cdb8;
}
.p-kuchikomi-awards__heading-icon {
	font-size: 18px;
	line-height: 1;
}
.p-kuchikomi-awards__body {
	padding: 0;
	background: #fff;
}
.p-kuchikomi-awards__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.p-kuchikomi-awards__table thead th {
	background: #f5f5f5;
	color: #333;
	font-size: 0.85em;
	font-weight: 600;
	padding: 10px 16px;
	text-align: left;
	white-space: nowrap;
	border-bottom: 2px solid #ddd;
}
.p-kuchikomi-awards__table tbody td {
	padding: 10px 16px;
	border-bottom: 1px solid #eee;
	vertical-align: middle;
	color: #333;
}
.p-kuchikomi-awards__table td a,
.p-kuchikomi-awards__table td a:visited {
	color: #222 !important;
	text-decoration: none;
}
.p-kuchikomi-awards__table td a:hover {
	color: #8b6914 !important;
	text-decoration: underline;
}
.p-kuchikomi-awards__table td {
	white-space: nowrap;
}
.p-kuchikomi-awards__table tbody tr:last-child td {
	border-bottom: none;
}
.p-kuchikomi-awards__grade {
	display: inline-block;
	font-size: 0.82em;
	font-weight: bold;
	padding: 2px 10px;
	border-radius: 3px;
	background: #f0f0f0;
	color: #555;
}
.p-kuchikomi-awards__grade--gold {
	background: #fef3d0;
	color: #8a6d00;
}
.p-kuchikomi-awards__grade--silver {
	background: #eee;
	color: #555;
}
.p-kuchikomi-awards__grade--bronze {
	background: #f5e6da;
	color: #7a4a2a;
}
.p-kuchikomi-awards__grade--platinum {
	background: #e0eaf5;
	color: #2c5282;
}

@media (max-width: 767px) {
	.p-kuchikomi-awards__heading {
		padding: 12px 18px;
		font-size: 15px;
	}
	.p-kuchikomi-awards__table thead th,
	.p-kuchikomi-awards__table tbody td {
		padding: 8px 12px;
		font-size: 13px;
	}
}

/* ==========================================================================
   Footer Bar
   ========================================================================== */
.p-kuchikomi-footer-bar {
	position: fixed;
	left: 0;
	bottom: 30px;
	width: 100%;
	z-index: 99;
	pointer-events: none;
}
.p-kuchikomi-footer-bar__inner {
	display: flex;
	justify-content: center;
}
.p-kuchikomi-footer-bar__list {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 100%;
	height: 60px;
	padding: 0 40px;
	border-radius: 60px;
	background: #000;
	pointer-events: auto;
	list-style: none;
	margin: 0;
}
.p-kuchikomi-footer-bar__item {
	font-size: 16px;
}
.p-kuchikomi-footer-bar__item + .p-kuchikomi-footer-bar__item {
	margin-left: 35px;
}
.p-kuchikomi-footer-bar__link {
	color: #fff;
	background: transparent;
	border: none;
	cursor: pointer;
	font-size: inherit;
	display: flex;
	align-items: center;
	text-decoration: none;
	transition: opacity 0.3s ease;
}
.p-kuchikomi-footer-bar__link:hover {
	opacity: 0.7;
}
.p-kuchikomi-footer-bar__icon {
	margin-right: 5px;
}
.p-kuchikomi-footer-bar__link.is-copied .p-kuchikomi-footer-bar__icon--share {
	display: none;
}

@media (max-width: 767px) {
	.p-kuchikomi-footer-bar {
		bottom: 0;
		background: #000;
		pointer-events: auto;
	}
	.p-kuchikomi-footer-bar__list {
		height: 50px;
		padding: 0 20px;
		border-radius: 0;
		width: 100%;
	}
	.p-kuchikomi-footer-bar__item {
		font-size: 14px;
	}
	.p-kuchikomi-footer-bar__item + .p-kuchikomi-footer-bar__item {
		margin-left: 30px;
	}
	.p-kuchikomi-footer-bar__space {
		width: 100%;
		height: 50px;
	}
}

/* ==========================================================================
   Comment Posted Message
   ========================================================================== */
.p-kuchikomi-message {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	padding: 10px 20px;
	display: none;
	z-index: 101;
	background: #20C563;
	font-size: 14px;
	min-height: 50px;
	line-height: 1.5;
	text-align: center;
	color: #fff;
	font-weight: 600;
	align-items: center;
	justify-content: center;
}
.p-kuchikomi-message.is-active {
	display: flex;
}
