:root {
	--bg-gradient: linear-gradient(140deg, #f6f8fc 0%, #edf2f7 45%, #e2ebf5 100%);
	--panel-gradient: linear-gradient(135deg, #14b8a6 0%, #34d399 45%, #60a5fa 100%);
	--color-accent: #14b8a6;
	--color-accent-strong: #0f766e;
	--color-accent-soft: rgba(20, 184, 166, 0.18);
	--color-text-primary: #1f2937;
	--color-text-muted: #4b5563;
	--color-surface: rgba(255, 255, 255, 0.88);
	--color-surface-strong: rgba(255, 255, 255, 0.95);
	--radius-lg: 28px;
	--radius-md: 18px;
	--shadow-soft: 0 24px 50px -28px rgba(15, 23, 42, 0.45);
	--shadow-card: 0 26px 70px -40px rgba(15, 23, 42, 0.55);
	--shadow-hover: 0 30px 90px -50px rgba(14, 116, 144, 0.55);
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Segoe UI", sans-serif;
	background: var(--bg-gradient);
	color: var(--color-text-primary);
	line-height: 1.8;
	letter-spacing: 0.01em;
}

a {
	color: inherit;
	text-decoration: none;
}

a:focus-visible,
button:focus-visible {
	outline: 3px solid rgba(20, 184, 166, 0.4);
	outline-offset: 4px;
}

.container {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 28px;
}

header {
	position: relative;
	background: var(--color-surface);
	backdrop-filter: blur(18px);
	border-bottom: 1px solid rgba(148, 163, 184, 0.22);
	box-shadow: 0 18px 30px -28px rgba(15, 23, 42, 0.45);
}

header .container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 22px 0;
}

header h1 {
	margin: 0;
	font-size: clamp(1.3rem, 1.2vw + 1.1rem, 1.9rem);
	font-weight: 700;
	letter-spacing: 0.05em;
}

.site-nav ul {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0;
	padding: 0;
}

.site-nav a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 20px;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 500;
	color: var(--color-text-muted);
	transition: all 0.25s ease;
}

.site-nav a:hover {
	color: var(--color-accent-strong);
	border-color: rgba(20, 184, 166, 0.4);
	background: rgba(20, 184, 166, 0.12);
	box-shadow: 0 16px 30px -22px rgba(15, 118, 110, 0.6);
}

.site-nav a.is-active {
	color: #0f172a;
	background: rgba(20, 184, 166, 0.16);
	border-color: rgba(20, 184, 166, 0.45);
	box-shadow: 0 18px 55px -35px rgba(14, 116, 144, 0.6);
}

.breadcrumb {
	border-bottom: 1px solid rgba(148, 163, 184, 0.14);
	background: rgba(248, 250, 252, 0.72);
	backdrop-filter: blur(10px);
}

.breadcrumb .container {
	padding: 12px 28px;
}

.breadcrumb ol {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.92rem;
	color: var(--color-text-muted);
}

.breadcrumb li::after {
	content: ">";
	margin-left: 8px;
	color: rgba(148, 163, 184, 0.7);
}

.breadcrumb li:last-child::after {
	content: "";
	margin: 0;
}

.breadcrumb [aria-current="page"] {
	color: var(--color-accent-strong);
	font-weight: 600;
}

main {
	padding: 70px 0 90px;
}

section + section {
	margin-top: 40px;
}

.hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 4vw + 2rem, 4.8rem) clamp(2.4rem, 3vw + 1.6rem, 4.4rem);
	border-radius: clamp(24px, 3vw, 36px);
	background: rgba(15, 23, 42, 0.92);
	color: #f8fafc;
	box-shadow: var(--shadow-card);
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
}

.hero::after {
	background: linear-gradient(140deg, rgba(15, 23, 42, 0.4), rgba(14, 116, 144, 0.6)), radial-gradient(circle at 20% 20%, rgba(248, 250, 252, 0.18), transparent 55%), radial-gradient(circle at 80% 30%, rgba(248, 250, 252, 0.16), transparent 60%);
	mix-blend-mode: lighten;
	opacity: 0.95;
}


.hero-content {
	position: relative;
	z-index: 2;
}

.hero h2 {
	margin: 18px 0 18px;
	font-size: clamp(2.2rem, 2.6vw + 1.2rem, 3rem);
	line-height: 1.3;
}

.hero p {
	max-width: 620px;
	margin: 0 0 28px;
	font-size: 1.02rem;
	color: rgba(248, 250, 252, 0.86);
}

.cta-button {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	border-radius: 999px;
	background: #fff;
	color: var(--color-accent-strong);
	font-weight: 600;
	box-shadow: 0 22px 45px -30px rgba(8, 145, 178, 0.85);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.cta-button::after {
	content: "→";
	font-size: 1.1em;
	transition: transform 0.25s ease;
}

.cta-button:hover {
	transform: translateY(-3px);
	box-shadow: 0 28px 60px -30px rgba(8, 145, 178, 0.9);
}

.cta-button:hover::after {
	transform: translateX(4px);
}

.category-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
	content-visibility: auto;
	contain-intrinsic-size: 720px;
}

.category-card {
	position: relative;
	display: grid;
	grid-template-rows: auto 1fr;
	gap: 20px;
	padding: 28px 26px;
	border-radius: var(--radius-lg);
	background: var(--color-surface-strong);
	border: 1px solid var(--color-accent-soft);
	box-shadow: var(--shadow-soft);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.category-card:hover {
	transform: translateY(-10px);
	box-shadow: var(--shadow-hover);
}

.category-media {
	position: relative;
	overflow: hidden;
	border-radius: calc(var(--radius-lg) - 10px);
	aspect-ratio: 16 / 10;
	background: rgba(15, 23, 42, 0.08);
}

.category-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease, filter 0.4s ease;
	filter: saturate(1.1);
}

.category-card:hover .category-media img {
	transform: scale(1.05);
	filter: saturate(1.25);
}

.category-body {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.category-body p {
	margin: 0;
	color: var(--color-text-muted);
}

.category-body .ghost-link {
	margin-top: auto;
	align-self: flex-start;
}

.category-card h3 {
	margin: 0 0 14px;
	font-size: 1.3rem;
}

.category-card p {
	margin: 0;
	color: var(--color-text-muted);
}

.ghost-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 0;
	font-weight: 600;
	color: var(--color-accent-strong);
	border-bottom: 2px solid rgba(20, 184, 166, 0.35);
	transition: gap 0.2s ease, border-color 0.2s ease;
}

.ghost-link::after {
	content: "↗";
	font-size: 1.05em;
	transform: translateY(-1px);
}

.ghost-link:hover {
	gap: 14px;
	border-color: rgba(20, 184, 166, 0.6);
}

.info-section {
	margin-top: 60px;
	padding: clamp(2.6rem, 3vw + 1.6rem, 3.8rem) clamp(2rem, 3vw, 3rem);
	border-radius: var(--radius-lg);
	background: var(--color-surface-strong);
	border: 1px solid rgba(148, 163, 184, 0.2);
	box-shadow: var(--shadow-card);
	backdrop-filter: blur(12px);
	content-visibility: auto;
	contain-intrinsic-size: 680px;
}

.info-header {
	max-width: 760px;
	margin-bottom: 34px;
}

.info-header h2 {
	margin: 0 0 16px;
	font-size: clamp(2rem, 2.4vw, 2.6rem);
	color: #0f172a;
}

.info-header p {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 1.02rem;
	line-height: 1.85;
}

.info-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.info-card {
	position: relative;
	padding: 26px 24px 28px;
	border-radius: var(--radius-md);
	background: rgba(248, 250, 252, 0.95);
	border: 1px solid rgba(148, 163, 184, 0.16);
	box-shadow: var(--shadow-soft);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.info-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(120deg, rgba(125, 211, 252, 0.12), transparent 55%);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
}

.info-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow-hover);
}

.info-card:hover::after {
	opacity: 1;
}

.info-card h3 {
	margin: 0 0 14px;
	font-size: 1.25rem;
	color: #0f3d4c;
}

.info-card p {
	margin: 0 0 16px;
	color: var(--color-text-muted);
}

.info-card ul {
	margin: 0;
	padding-left: 18px;
	color: var(--color-text-muted);
}

.info-card li {
	margin-bottom: 6px;
}

.reference-box {
	margin-top: 36px;
	padding: 24px 26px;
	border-radius: var(--radius-md);
	background: rgba(15, 23, 42, 0.04);
	border: 1px solid rgba(148, 163, 184, 0.22);
	box-shadow: 0 18px 40px -40px rgba(15, 23, 42, 0.6);
}

.reference-box h3 {
	margin: 0 0 14px;
	font-size: 1.15rem;
	color: #0f172a;
}

.reference-box ol {
	margin: 0;
	padding-left: 20px;
	display: grid;
	gap: 10px;
	color: var(--color-text-muted);
}

.reference-box a {
	color: var(--color-accent-strong);
	font-weight: 500;
	word-break: break-word;
	text-decoration: underline;
	text-decoration-thickness: 1.5px;
	text-decoration-color: rgba(20, 184, 166, 0.3);
}

.reference-box a:hover {
	text-decoration-color: rgba(20, 184, 166, 0.6);
}

.methodology-section {
	--timeline-color: rgba(20, 184, 166, 0.35);
}

.methodology-layout {
	display: grid;
	grid-template-columns: minmax(0, 340px) minmax(0, 1fr);
	gap: 28px;
	align-items: flex-start;
}

.methodology-primary {
	position: sticky;
	top: 140px;
}

.methodology-card {
	padding: 28px 26px;
}

.methodology-card h3 {
	margin-bottom: 18px;
}

.methodology-card--steps {
	background: rgba(15, 23, 42, 0.04);
	border: 1px solid rgba(14, 116, 144, 0.18);
}

.step-summary {
	margin: 0 0 18px;
	color: var(--color-text-muted);
	font-size: 0.96rem;
	line-height: 1.7;
}

.methodology-secondary {
	display: grid;
	gap: 24px;
}

.step-list {
	counter-reset: step;
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 16px;
}

.step-list li {
	position: relative;
	counter-increment: step;
	padding: 16px 18px 16px 72px;
	border-radius: 18px;
	background: rgba(248, 250, 252, 0.95);
	border: 1px solid rgba(148, 163, 184, 0.22);
	box-shadow: 0 18px 40px -36px rgba(15, 23, 42, 0.6);
}

.step-list li::before {
	content: counter(step, decimal-leading-zero);
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: rgba(20, 184, 166, 0.18);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	letter-spacing: 0.06em;
	color: var(--color-accent-strong);
}

.step-list li::after {
	content: "";
	position: absolute;
	left: 40px;
	bottom: -18px;
	width: 2px;
	height: 18px;
	background: var(--timeline-color);
	opacity: 0.5;
}

.step-list li:last-child::after {
	display: none;
}

.step-list h4 {
	margin: 0 0 6px;
	font-size: 1.05rem;
	color: #0f172a;
}

.step-list p {
	margin: 0;
	color: var(--color-text-muted);
	line-height: 1.7;
}

.methodology-card--matrix .table-wrapper {
	margin-top: 14px;
}

.guideline-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 12px;
}

.guideline-list li {
	position: relative;
	padding-left: 28px;
	color: var(--color-text-muted);
}

.guideline-list li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	top: 2px;
	font-size: 0.9rem;
	color: var(--color-accent-strong);
}

.pcp-section {
	background: rgba(15, 23, 42, 0.06);
	border-style: dashed;
	border-color: rgba(14, 116, 144, 0.25);
}

.pcp-formula {
	margin: 18px 0;
	padding: 16px 18px;
	border-radius: var(--radius-md);
	background: rgba(14, 116, 144, 0.12);
	font-family: "Fira Code", "Consolas", "SFMono-Regular", monospace;
	font-size: 0.95rem;
	line-height: 1.6;
	overflow-x: auto;
}

.note-inline {
	margin-top: 16px;
	font-size: 0.9rem;
}

.methodology-card .note {
	margin-top: 20px;
}

.note {
	margin-top: 16px;
	padding: 12px 16px;
	border-radius: 12px;
	background: rgba(20, 184, 166, 0.08);
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.note a {
	color: var(--color-accent-strong);
	text-decoration: underline;
}

.criteria-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.95rem;
	color: var(--color-text-muted);
}

.criteria-table th,
.criteria-table td {
	padding: 10px 12px;
	border-bottom: 1px solid rgba(148, 163, 184, 0.2);
}

.criteria-table th {
	text-align: left;
	color: #0f172a;
	font-weight: 600;
	background: rgba(148, 163, 184, 0.1);
}

.criteria-table tr:last-child td {
	border-bottom: none;
}

.faq-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.faq-card {
	padding: 26px 24px 28px;
	border-radius: var(--radius-md);
	background: rgba(248, 250, 252, 0.95);
	border: 1px solid rgba(148, 163, 184, 0.18);
	box-shadow: var(--shadow-soft);
}

.faq-card h3 {
	margin: 0 0 16px;
	font-size: 1.2rem;
	color: #0f3d4c;
}

.faq-card dl {
	margin: 0;
	display: grid;
	gap: 18px;
}

.faq-card dt {
	font-weight: 700;
	color: #0f172a;
}

.faq-card dd {
	margin: 6px 0 0;
	color: var(--color-text-muted);
}

.faq-card a {
	color: var(--color-accent-strong);
	font-weight: 600;
	text-decoration: underline;
}

.related-links {
	margin-top: 36px;
	padding: 22px 24px;
	border-radius: var(--radius-md);
	background: rgba(15, 23, 42, 0.05);
	border: 1px solid rgba(148, 163, 184, 0.22);
}

.related-links h3 {
	margin: 0 0 14px;
	font-size: 1.1rem;
}

.related-links ul {
	margin: 0;
	padding-left: 20px;
	color: var(--color-text-muted);
}

.related-links li {
	margin-bottom: 10px;
}

.related-links a {
	color: var(--color-accent-strong);
	font-weight: 500;
	text-decoration: underline;
}

.page-header {
	position: relative;
	padding: 44px clamp(1.8rem, 2.2vw, 2.6rem);
	margin-bottom: 34px;
	border-radius: var(--radius-lg);
	background: var(--color-surface-strong);
	border: 1px solid var(--color-accent-soft);
	box-shadow: var(--shadow-card);
	overflow: hidden;
}

.page-header::before,
.page-header::after {
	content: "";
	position: absolute;
	inset: -6%;
	pointer-events: none;
}

.page-header::before {
	background-image: var(--page-image);
	background-size: cover;
	background-position: center;
	opacity: 0.36;
	filter: saturate(1.1);
}

.page-header::after {
	background: linear-gradient(160deg, rgba(20, 184, 166, 0.2), rgba(15, 23, 42, 0.1));
	opacity: 0.6;
}

.page-header * {
	position: relative;
	z-index: 1;
}

.page-tag {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 18px;
	padding: 6px 14px;
	border-radius: 999px;
	background: rgba(20, 184, 166, 0.1);
	color: var(--color-accent-strong);
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.page-header h2 {
	margin: 0 0 18px;
	font-size: clamp(2rem, 2vw + 1.4rem, 2.6rem);
	color: #102a43;
}

.page-lead {
	margin: 0;
	max-width: 720px;
	color: var(--color-text-muted);
	font-size: 1.05rem;
}

.table-wrapper {
	background: var(--color-surface);
	border: 1px solid rgba(148, 163, 184, 0.18);
	border-radius: var(--radius-md);
	padding: 24px 26px;
	box-shadow: var(--shadow-soft);
	backdrop-filter: blur(12px);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 26px;
	font-size: 0.97rem;
}

.ranking-table {
	min-width: 560px;
}

.criteria-table {
	min-width: 100%;
}

th,
td {
	border: 1px solid rgba(148, 163, 184, 0.28);
	padding: 12px 16px;
	text-align: left;
	vertical-align: top;
}

thead th {
	background: rgba(15, 118, 110, 0.08);
	font-weight: 600;
	color: #0f3d4c;
}

tbody tr:nth-child(even) {
	background: rgba(226, 232, 240, 0.35);
}

tbody tr:hover {
	background: rgba(125, 211, 252, 0.28);
}

table a {
	color: var(--color-accent-strong);
	font-weight: 600;
}

.product-card {
	position: relative;
	overflow: hidden;
	background: var(--color-surface-strong);
	border: 1px solid rgba(148, 163, 184, 0.22);
	border-radius: var(--radius-lg);
	padding: 32px clamp(1.6rem, 2.2vw, 2.8rem) 36px;
	margin-bottom: 32px;
	box-shadow: var(--shadow-card);
	backdrop-filter: blur(14px);
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.product-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(155deg, rgba(20, 184, 166, 0.16), transparent 55%);
	opacity: 0.7;
	pointer-events: none;
}

.product-card * {
	position: relative;
	z-index: 1;
}

.product-rank {
	padding: 6px 16px;
	border-radius: 999px;
	background: rgba(15, 118, 110, 0.9);
	color: #f8fafc;
	font-weight: 700;
	letter-spacing: 0.08em;
	align-self: flex-start;
	margin-bottom: 6px;
}

.product-card img {
	width: 100%;
	max-width: 160px;
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.6);
	padding: 12px;
	align-self: flex-start;
}

.product-card h4 {
	margin: 0 0 12px;
	font-size: 1.35rem;
	color: #0f172a;
}

.product-card p {
	margin: 0 0 14px;
	color: var(--color-text-muted);
}

.product-card ul {
	margin: 0 0 16px;
	padding-left: 1.1rem;
	color: var(--color-text-muted);
}

.product-card li {
	margin-bottom: 6px;
}

.amazon-button {
	justify-self: start;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	border-radius: 999px;
	background: linear-gradient(135deg, #ff9900 0%, #ffb347 100%);
	color: #fff;
	font-weight: 700;
	text-transform: none;
	box-shadow: 0 20px 45px -25px rgba(217, 119, 6, 0.75);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.amazon-button::after {
	content: "→";
	font-size: 1.15em;
}

.amazon-button:hover {
	transform: translateY(-3px);
	box-shadow: 0 28px 60px -32px rgba(217, 119, 6, 0.85);
}

footer {
	text-align: center;
	padding: 32px 20px 40px;
	font-size: 0.85rem;
	color: rgba(71, 85, 105, 0.85);
}

footer p {
	margin: 6px 0;
}

@media (max-width: 1024px) {
	.category-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.category-media {
		aspect-ratio: 16 / 9;
	}

	.info-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.methodology-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	.methodology-primary {
		position: static;
	}

	.faq-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.product-card {
		padding: 32px 28px 32px;
		gap: 20px;
	}

	.product-card img {
		max-width: 200px;
	}
}

@media (max-width: 768px) {
	header .container {
		justify-content: center;
		text-align: center;
		padding: 14px 0 18px;
	}

	.info-grid,
	.faq-grid,
	.methodology-layout,
	.category-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.container {
		padding: 0 20px;
	}

	main {
		padding: 48px 0 64px;
	}

	.methodology-layout {
		gap: 22px;
	}

	.methodology-primary {
		position: static;
	}

	.step-list li {
		padding: 16px 16px 16px 64px;
	}

	.step-list li::before {
		left: 16px;
		width: 36px;
		height: 36px;
	}

	.step-list li::after {
		left: 33px;
	}

	header h1 {
		font-size: 1.3rem;
	}

	.site-nav ul {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}

	.site-nav a {
		width: 100%;
		padding: 10px 16px;
		justify-content: center;
	}

	.hero {
		text-align: center;
		padding: 2.6rem 1.8rem;
		border-radius: 24px;
	}

	.hero h2 {
		font-size: clamp(1.9rem, 4vw + 1.1rem, 2.3rem);
	}

	.hero p {
		margin-left: auto;
		margin-right: auto;
		font-size: 0.98rem;
	}

	.cta-button {
		width: 100%;
		justify-content: center;
	}

	.category-card {
		padding: 24px 22px;
	}

	.category-media {
		aspect-ratio: 3 / 2;
	}

	.info-section {
		padding: 2.3rem 1.6rem;
	}

	.info-card,
	.methodology-card {
		padding: 24px 20px;
	}

	.table-wrapper {
		padding: 18px 20px;
	}

	.table-wrapper table {
		font-size: 0.9rem;
	}

	.breadcrumb .container {
		padding: 10px 20px;
	}

	.breadcrumb ol {
		font-size: 0.85rem;
	}

	.product-card {
		padding: 30px 24px 30px;
	}

	.product-card img {
		margin: 0 auto 18px;
	}

	.amazon-button {
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 640px) {
	.criteria-table thead {
		display: none;
	}

	.criteria-table tbody,
	.criteria-table tr,
	.criteria-table td {
		display: block;
		width: 100%;
	}

	.criteria-table tr {
		padding: 16px 0;
		border-bottom: 1px solid rgba(148, 163, 184, 0.2);
	}

	.criteria-table td {
		padding: 6px 0;
		border: none;
	}

	.criteria-table td::before {
		content: attr(data-label);
		display: block;
		margin-bottom: 4px;
		font-weight: 600;
		color: #0f172a;
	}

	.criteria-table tr:last-child {
		border-bottom: none;
	}

	.table-wrapper {
		padding: 16px 18px;
	}

	.page-header {
		padding: 32px 20px;
	}

	.page-header h2 {
		font-size: clamp(1.7rem, 4vw + 1rem, 2.2rem);
	}

	.page-lead {
		font-size: 0.96rem;
		line-height: 1.7;
	}
}

@media (max-width: 540px) {
	body {
		letter-spacing: 0.005em;
	}

	.container {
		padding: 0 18px;
	}

	.hero {
		padding: 2.4rem 1.6rem;
	}

	.hero p {
		font-size: 0.95rem;
	}

	.info-section {
		padding: 2rem 1.4rem;
	}

	.category-card,
	.info-card,
	.methodology-card {
		padding: 22px 18px;
	}

	.product-card {
		padding: 28px 20px 28px;
		gap: 16px;
	}

	.step-list li {
		padding-left: 56px;
	}

	.step-list li::before {
		width: 32px;
		height: 32px;
		font-size: 0.85rem;
	}

	.step-list li::after {
		left: 28px;
	}

	.breadcrumb .container {
		padding: 8px 18px;
	}
}
