/* introduction visual slider */
body.intro-modal-open {
	overflow: hidden;
}

.intro-compare-expanded {
	position: relative;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 249, 255, 0.98) 58%, rgba(240, 251, 248, 0.98) 100%);
	overflow: hidden;
}

.intro-compare-expanded::before,
.intro-compare-expanded::after {
	content: '';
	position: absolute;
	border-radius: 999px;
	filter: blur(20px);
	opacity: 0.74;
	pointer-events: none;
}

.intro-compare-expanded::before {
	width: 220px;
	height: 220px;
	right: -76px;
	top: -96px;
	background: rgba(0, 104, 255, 0.12);
}

.intro-compare-expanded::after {
	width: 180px;
	height: 180px;
	left: -58px;
	bottom: -84px;
	background: rgba(8, 181, 164, 0.12);
}

.intro-compare-expanded-head,
.intro-compare-expanded-table {
	position: relative;
	z-index: 1;
}

.intro-compare-expanded-head {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
	gap: 24px;
	align-items: end;
	margin-bottom: 18px;
}

.intro-compare-expanded .intro-section-head {
	max-width: 760px;
}

.intro-compare-expanded-lead {
	margin: 14px 0 0;
	font-size: 16px;
	line-height: 1.72;
	color: #50607a;
	word-break: keep-all;
}

.intro-compare-expanded-points {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 12px;
}

.intro-compare-expanded-points li {
	display: grid;
	gap: 6px;
	padding: 16px 18px;
	border: 1px solid #d8e3f2;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.82);
	box-shadow: 0 12px 24px rgba(10, 28, 59, 0.05);
	backdrop-filter: blur(6px);
}

.intro-compare-expanded-points strong {
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: #163768;
}

.intro-compare-expanded-points span {
	font-size: 14px;
	line-height: 1.66;
	color: #4d5d77;
	word-break: keep-all;
}

.intro-compare-expanded-table {
	margin-top: 0;
	box-shadow: 0 12px 24px rgba(10, 28, 59, 0.04);
}

.intro-visual {
	position: relative;
	margin-top: 44px;
	padding: 34px;
	border: 1px solid #d9e3f1;
	border-radius: 28px;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.97) 0%, rgba(244, 249, 255, 0.98) 56%, rgba(240, 251, 248, 0.98) 100%);
	box-shadow: 0 24px 48px rgba(10, 28, 59, 0.08);
	overflow: hidden;
}

.intro-visual::before,
.intro-visual::after {
	content: '';
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
	filter: blur(18px);
	opacity: 0.72;
}

.intro-visual::before {
	width: 240px;
	height: 240px;
	right: -74px;
	top: -92px;
	background: rgba(0, 104, 255, 0.14);
}

.intro-visual::after {
	width: 200px;
	height: 200px;
	left: -70px;
	bottom: -96px;
	background: rgba(8, 181, 164, 0.13);
}

.intro-visual-head {
	position: relative;
	z-index: 1;
	margin-bottom: 22px;
}

.intro-visual-head .intro-kicker {
	margin-bottom: 12px;
}

.intro-visual-shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1.24fr) minmax(280px, 0.76fr);
	gap: 24px;
	align-items: stretch;
}

.intro-visual-stage {
	position: relative;
	min-width: 0;
}

.intro-visual-slider {
	position: relative;
	border-radius: 26px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.84) 0%, rgba(246, 250, 255, 0.98) 100%);
	border: 1px solid rgba(214, 225, 241, 0.95);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), 0 20px 40px rgba(12, 30, 61, 0.08);
	overflow: hidden;
	cursor: grab;
	touch-action: pan-y;
}

.intro-visual-slider:focus-visible {
	outline: 3px solid rgba(0, 104, 255, 0.18);
	outline-offset: 4px;
}

.intro-visual-track {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
	transition: transform 0.72s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: transform;
}

.intro-visual-slide {
	flex: 0 0 100%;
	min-width: 100%;
	opacity: 0.5;
	transition: opacity 0.45s ease;
}

.intro-visual-slide.is-active {
	opacity: 1;
}

.intro-visual-card {
	padding: 18px;
}

.intro-visual-media {
	position: relative;
	padding: 22px;
	border-radius: 22px 22px 18px 18px;
	background: linear-gradient(180deg, #edf4ff 0%, #ffffff 62%, #f8fbff 100%);
	border: 1px solid #dce6f4;
	overflow: hidden;
}

.intro-visual-chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 108px;
	height: 34px;
	padding: 0 14px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.14em;
	color: #0a4fc5;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid rgba(185, 205, 239, 0.92);
	box-shadow: 0 10px 24px rgba(12, 30, 61, 0.08);
}

.intro-visual-media img {
	display: block;
	width: 100%;
	height: clamp(280px, 40vw, 460px);
	margin-top: 18px;
	padding: 14px;
	box-sizing: border-box;
	object-fit: contain;
	object-position: center center;
	border-radius: 18px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(245, 249, 255, 0.96) 100%);
	border: 1px solid rgba(216, 227, 242, 0.95);
	box-shadow: 0 18px 34px rgba(13, 27, 55, 0.08);
	user-select: none;
	-webkit-user-drag: none;
	cursor: zoom-in;
	transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.intro-visual-media img:hover,
.intro-visual-media img:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(146, 179, 232, 0.95);
	box-shadow: 0 20px 40px rgba(13, 27, 55, 0.12);
	outline: none;
}

.intro-visual-caption {
	display: grid;
	gap: 10px;
	padding: 22px 22px 20px;
	background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
	border: 1px solid #dce6f4;
	border-top: none;
	border-radius: 0 0 22px 22px;
}

.intro-visual-caption strong {
	font-size: clamp(24px, 2.5vw, 32px);
	line-height: 1.18;
	letter-spacing: -0.02em;
	color: #111c31;
}

.intro-visual-caption p {
	margin: 0;
	font-size: 15px;
	line-height: 1.72;
	color: #4d5d77;
}

.intro-visual-aside {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 28px;
	border-radius: 24px;
	background: linear-gradient(180deg, rgba(8, 20, 44, 0.96) 0%, rgba(9, 42, 88, 0.97) 56%, rgba(7, 92, 102, 0.95) 100%);
	box-shadow: 0 22px 44px rgba(7, 20, 43, 0.24);
	color: #fff;
}

.intro-visual-overline {
	margin: 0;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.16em;
	color: rgba(167, 214, 255, 0.96);
}

.intro-visual-aside h3 {
	margin: 14px 0 0;
	font-size: clamp(28px, 2.5vw, 38px);
	line-height: 1.16;
	letter-spacing: -0.03em;
}

.intro-visual-lead {
	margin: 16px 0 0;
	font-size: 15px;
	line-height: 1.72;
	color: rgba(233, 241, 255, 0.86);
}

.intro-visual-meta {
	display: grid;
	gap: 18px;
	margin-top: 30px;
}

.intro-visual-progress {
	display: flex;
	align-items: center;
	gap: 12px;
}

.intro-visual-progress strong,
.intro-visual-progress em {
	font-style: normal;
	font-size: 34px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.03em;
}

.intro-visual-progress strong {
	color: #ffffff;
}

.intro-visual-progress em {
	color: rgba(212, 227, 255, 0.72);
}

.intro-visual-progress span {
	flex: 1 1 auto;
	height: 1px;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0.54) 0%, rgba(255, 255, 255, 0.08) 100%);
}

.intro-visual-timer {
	position: relative;
	height: 6px;
	border-radius: 999px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.08);
}

.intro-visual-timer-fill {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, #81b6ff 0%, #7ce0cf 100%);
	transform: scaleX(0);
	transform-origin: left center;
	opacity: 0.95;
}

.intro-visual-timer-fill.is-running {
	animation: intro-visual-timer-fill linear forwards;
	animation-duration: var(--intro-visual-autoplay, 4200ms);
}

.intro-visual-actions {
	display: flex;
	gap: 10px;
}

.intro-visual-arrow,
.intro-visual-modal-nav,
.intro-visual-modal-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 16px;
	cursor: pointer;
	transition: transform 0.24s ease, background-color 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease, opacity 0.24s ease;
}

.intro-visual-arrow {
	width: 52px;
	height: 52px;
	border: 1px solid rgba(198, 218, 255, 0.28);
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
	font-size: 22px;
}

.intro-visual-arrow:hover,
.intro-visual-arrow:focus-visible,
.intro-visual-modal-nav:hover,
.intro-visual-modal-nav:focus-visible,
.intro-visual-modal-close:hover,
.intro-visual-modal-close:focus-visible {
	transform: translateY(-2px);
	outline: none;
}

.intro-visual-arrow:hover,
.intro-visual-arrow:focus-visible {
	background: rgba(255, 255, 255, 0.15);
	border-color: rgba(215, 229, 255, 0.48);
}

.intro-visual-arrow:disabled,
.intro-visual-modal-nav:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	transform: none;
}

.intro-visual-pagination {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
	gap: 8px;
	margin-top: 28px;
}

.intro-visual-dot {
	position: relative;
	display: block;
	width: 100%;
	height: 10px;
	padding: 0;
	border: none;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.18);
	cursor: pointer;
	overflow: hidden;
	transition: transform 0.24s ease, background-color 0.24s ease;
}

.intro-visual-dot::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, #72a8ff 0%, #7ce7d0 100%);
	transform: scaleX(0.16);
	transform-origin: left center;
	opacity: 0;
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.intro-visual-dot:hover,
.intro-visual-dot:focus-visible {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.26);
	outline: none;
}

.intro-visual-dot.is-active::after {
	transform: scaleX(1);
	opacity: 1;
}

.intro-visual-notes {
	display: grid;
	gap: 10px;
	margin: 28px 0 0;
	padding: 0;
	list-style: none;
}

.intro-visual-notes li {
	position: relative;
	padding-left: 18px;
	font-size: 14px;
	line-height: 1.6;
	color: rgba(234, 242, 255, 0.82);
}

.intro-visual-notes li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 9px;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: linear-gradient(135deg, #77abff 0%, #79dccd 100%);
}

.intro-visual-modal[hidden] {
	display: none;
}

.intro-visual-modal {
	position: fixed;
	inset: 0;
	z-index: 1200;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.intro-visual-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(6, 16, 34, 0.72);
	backdrop-filter: blur(8px);
}

.intro-visual-modal-dialog {
	position: relative;
	z-index: 1;
	width: min(1080px, 100%);
	max-height: calc(100vh - 48px);
	padding: 18px 72px;
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 250, 255, 0.98) 100%);
	border: 1px solid rgba(214, 225, 241, 0.9);
	box-shadow: 0 28px 60px rgba(5, 16, 34, 0.28);
}

.intro-visual-modal-close {
	position: absolute;
	top: 18px;
	right: 18px;
	width: 46px;
	height: 46px;
	border: 1px solid #d6e1f1;
	background: rgba(255, 255, 255, 0.95);
	color: #11203a;
	font-size: 24px;
	line-height: 1;
}

.intro-visual-modal-close:hover,
.intro-visual-modal-close:focus-visible {
	background: #f2f7ff;
	box-shadow: 0 14px 24px rgba(12, 30, 61, 0.1);
}

.intro-visual-modal-nav {
	position: absolute;
	top: 50%;
	width: 52px;
	height: 52px;
	margin-top: -26px;
	border: 1px solid rgba(203, 216, 236, 0.95);
	background: rgba(255, 255, 255, 0.94);
	color: #102038;
	font-size: 22px;
	box-shadow: 0 14px 28px rgba(12, 30, 61, 0.1);
}

.intro-visual-modal-nav.is-prev {
	left: 18px;
}

.intro-visual-modal-nav.is-next {
	right: 18px;
}

.intro-visual-modal-nav:hover,
.intro-visual-modal-nav:focus-visible {
	background: #f2f7ff;
	border-color: rgba(169, 191, 228, 0.95);
	box-shadow: 0 18px 34px rgba(12, 30, 61, 0.14);
}

.intro-visual-modal-figure {
	display: grid;
	gap: 14px;
	margin: 0;
	max-height: calc(100vh - 84px);
}

.intro-visual-modal-image {
	display: block;
	width: 100%;
	max-width: 100%;
	max-height: calc(100vh - 180px);
	object-fit: contain;
	border-radius: 20px;
	background: linear-gradient(180deg, #ffffff 0%, #f4f8ff 100%);
	border: 1px solid #dce6f4;
	box-shadow: 0 20px 44px rgba(9, 26, 54, 0.14);
}

.intro-visual-modal-caption {
	font-size: 15px;
	line-height: 1.7;
	color: #42526b;
	text-align: center;
}

.intro-visual.is-dragging .intro-visual-track {
	transition: none;
}

@keyframes intro-visual-timer-fill {
	from {
		transform: scaleX(0);
	}

	to {
		transform: scaleX(1);
	}
}

@media (max-width: 1024px) {
	.intro-compare-expanded-head {
		grid-template-columns: 1fr;
	}

	.intro-visual {
		padding: 28px;
	}

	.intro-visual-shell {
		grid-template-columns: 1fr;
	}

	.intro-visual-aside {
		gap: 16px;
	}

	.intro-visual-pagination {
		grid-template-columns: repeat(7, minmax(0, 1fr));
	}

	.intro-visual-modal-dialog {
		padding: 18px 64px;
	}
}

@media (max-width: 680px) {
	.intro-compare-expanded-lead {
		font-size: 15px;
	}

	.intro-compare-expanded-points li {
		padding: 14px 16px;
		border-radius: 16px;
	}

	.intro-visual {
		margin-top: 28px;
		padding: 24px;
		border-radius: 22px;
	}

	.intro-visual-head {
		margin-bottom: 18px;
	}

	.intro-visual-slider,
	.intro-visual-aside {
		border-radius: 20px;
	}

	.intro-visual-card {
		padding: 12px;
	}

	.intro-visual-media {
		padding: 16px;
		border-radius: 18px 18px 16px 16px;
	}

	.intro-visual-chip {
		min-width: 92px;
		height: 30px;
		padding: 0 12px;
		font-size: 11px;
	}

	.intro-visual-media img {
		height: min(60vw, 320px);
		margin-top: 14px;
		padding: 10px;
		border-radius: 14px;
	}

	.intro-visual-caption {
		padding: 18px 18px 16px;
		border-radius: 0 0 18px 18px;
	}

	.intro-visual-caption strong {
		font-size: 24px;
	}

	.intro-visual-caption p {
		font-size: 14px;
	}

	.intro-visual-aside {
		padding: 14px 16px;
		gap: 0;
		justify-content: center;
	}

	.intro-visual-overline,
	.intro-visual-aside h3 {
		display: none;
	}

	.intro-visual-lead {
		display: none;
	}

	.intro-visual-meta {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		margin-top: 0;
	}

	.intro-visual-progress {
		flex: 0 0 auto;
		gap: 8px;
	}

	.intro-visual-progress strong,
	.intro-visual-progress em {
		font-size: 20px;
	}

	.intro-visual-progress span,
	.intro-visual-timer,
	.intro-visual-pagination,
	.intro-visual-notes {
		display: none;
	}

	.intro-visual-actions {
		flex: 0 0 auto;
		gap: 8px;
	}

	.intro-visual-arrow {
		width: 40px;
		height: 40px;
		font-size: 17px;
	}

	.intro-visual-modal {
		padding: 18px;
	}

	.intro-visual-modal-dialog {
		padding: 16px 50px;
		border-radius: 22px;
	}

	.intro-visual-modal-nav {
		width: 42px;
		height: 42px;
		margin-top: -21px;
		font-size: 18px;
	}

	.intro-visual-modal-nav.is-prev {
		left: 12px;
	}

	.intro-visual-modal-nav.is-next {
		right: 12px;
	}

	.intro-visual-modal-image {
		max-height: calc(100vh - 160px);
		border-radius: 16px;
	}

	.intro-visual-modal-caption {
		font-size: 14px;
	}
}

@media (max-width: 480px) {
	.intro-compare-expanded-points {
		gap: 10px;
	}

	.intro-compare-expanded-points li {
		padding: 12px 14px;
		border-radius: 14px;
	}

	.intro-compare-expanded-points strong {
		font-size: 14px;
	}

	.intro-compare-expanded-points span,
	.intro-compare-expanded-lead {
		font-size: 13px;
	}

	.intro-visual {
		padding: 18px;
		border-radius: 18px;
	}

	.intro-visual-shell {
		gap: 16px;
	}

	.intro-visual-card {
		padding: 10px;
	}

	.intro-visual-media {
		padding: 12px;
	}

	.intro-visual-media img {
		height: min(65vw, 268px);
		padding: 8px;
	}

	.intro-visual-caption {
		gap: 8px;
		padding: 16px 14px 14px;
	}

	.intro-visual-caption strong {
		font-size: 22px;
	}

	.intro-visual-caption p {
		font-size: 13px;
	}

	.intro-visual-aside {
		padding: 12px 14px;
		border-radius: 18px;
	}

	.intro-visual-meta {
		gap: 10px;
		margin-top: 0;
	}

	.intro-visual-progress {
		gap: 8px;
	}

	.intro-visual-progress strong,
	.intro-visual-progress em {
		font-size: 18px;
	}

	.intro-visual-actions {
		gap: 6px;
	}

	.intro-visual-arrow {
		width: 36px;
		height: 36px;
		font-size: 16px;
	}

	.intro-visual-modal {
		padding: 12px;
	}

	.intro-visual-modal-dialog {
		padding: 48px 12px 12px;
		border-radius: 18px;
	}

	.intro-visual-modal-close {
		top: 12px;
		right: 12px;
		width: 40px;
		height: 40px;
		border-radius: 14px;
		font-size: 22px;
	}

	.intro-visual-modal-nav {
		top: auto;
		bottom: 12px;
		margin-top: 0;
		width: 40px;
		height: 40px;
		font-size: 18px;
	}

	.intro-visual-modal-nav.is-prev {
		left: 12px;
	}

	.intro-visual-modal-nav.is-next {
		right: 12px;
	}

	.intro-visual-modal-figure {
		gap: 10px;
	}

	.intro-visual-modal-image {
		max-height: calc(100vh - 180px);
		border-radius: 14px;
	}

	.intro-visual-modal-caption {
		padding: 0 42px 34px;
		font-size: 13px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.intro-visual-track,
	.intro-visual-slide,
	.intro-visual-arrow,
	.intro-visual-dot,
	.intro-visual-timer-fill,
	.intro-visual-modal-nav,
	.intro-visual-modal-close,
	.intro-visual-media img {
		transition-duration: 0.01ms !important;
	}

	.intro-visual-timer-fill.is-running {
		animation: none;
		transform: scaleX(1);
	}
}
