.bmc-bike-model,
.bmc-character-list {
	max-width: 960px;
	margin: 0 auto;
}

.bmc-hero,
.bmc-section,
.bmc-character-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	padding: 20px;
	margin-bottom: 20px;
}

.bmc-title {
	margin-top: 0;
	margin-bottom: 12px;
}

.bmc-meta-line {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	color: #555;
	font-size: 14px;
}

.bmc-taxonomy-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 16px;
}

.bmc-chip {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	background: #f3f4f6;
	font-size: 12px;
}

.bmc-table-wrap {
	overflow-x: auto;
}

.bmc-spec-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 420px;
}

.bmc-spec-table th,
.bmc-spec-table td {
	padding: 10px;
	border-bottom: 1px solid #e5e7eb;
	text-align: left;
}

.bmc-list {
	margin: 0;
	padding-left: 20px;
}

.bmc-talk-box summary {
	cursor: pointer;
	font-weight: 600;
}

.bmc-talk-row + .bmc-talk-row {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid #e5e7eb;
}

.bmc-character-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}

.bmc-character-reading {
	font-size: 14px;
	color: #555;
}

@media (max-width: 640px) {
	.bmc-hero,
	.bmc-section,
	.bmc-character-card {
		padding: 16px;
		border-radius: 12px;
	}
}
