@charset "UTF-8";

/*! destyle.css v1.0.14 | MIT License | https://github.com/nicolas-cusan/destyle.css */
* {
	box-sizing: border-box;
}

:before,
:after {
	box-sizing: inherit;
}

html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: transparent;
}

body {
	margin: 0;
}

main {
	display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
	margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
	margin: 0;
}

ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

dt {
	font-weight: 700;
}

dd {
	margin-left: 0;
}

hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
	border: 0;
	border-top: 1px solid;
	margin: 0;
	clear: both;
	color: inherit;
}

pre {
	font-family: monospace, monospace;
	font-size: inherit;
}

address {
	font-style: inherit;
}

a {
	background-color: transparent;
	text-decoration: none;
	color: inherit;
}

abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

b,
strong {
	font-weight: bolder;
}

code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: inherit;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

img {
	border-style: none;
	vertical-align: bottom;
}

embed,
object,
iframe {
	border: 0;
	vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none;
	appearance: none;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	border: 0;
	background: transparent;
	padding: 0;
	margin: 0;
	outline: 0;
	border-radius: 0;
	text-align: inherit;
}

[type="checkbox"] {
	-webkit-appearance: checkbox;
	appearance: checkbox;
}

[type="radio"] {
	-webkit-appearance: radio;
	appearance: radio;
}

button,
input {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
	cursor: default;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

select::-ms-expand {
	display: none;
}

option {
	padding: 0;
}

fieldset {
	margin: 0;
	padding: 0;
	border: 0;
	min-width: 0;
}

legend {
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

progress {
	vertical-align: baseline;
}

textarea {
	overflow: auto;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

label[for] {
	cursor: pointer;
}

details {
	display: block;
}

summary {
	display: list-item;
}

[contenteditable] {
	outline: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

caption {
	text-align: left;
}

td,
th {
	vertical-align: top;
	padding: 0;
}

th {
	text-align: left;
	font-weight: 700;
}

template {
	display: none;
}

[hidden] {
	display: none;
}

.has-text-align-left {
	text-align: left;
}

.has-text-align-center {
	text-align: center;
}

.has-text-align-right {
	text-align: right;
}

.has-minimum-font-size {
	font-size: 0.6875rem;
}

.has-extra-small-font-size {
	font-size: 1.2rem;
}

.has-small-font-size {
	font-size: 1.3rem;
}

.has-normal-font-size {
	font-size: 1.5rem;
}

.has-large-font-size {
	font-size: 1.7rem;
}

.has-extra-large-font-size {
	font-size: 2rem;
}

.has-huge-font-size {
	font-size: 2.4rem;
}

.has-maximum-font-size {
	font-size: 3rem;
}

@media print,
only screen and (min-width: 768px) {
	.has-minimum-font-size {
		font-size: 1.1rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-extra-small-font-size {
		font-size: 1.2rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-small-font-size {
		font-size: 1.4rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-normal-font-size {
		font-size: 1.6rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-large-font-size {
		font-size: 1.8rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-extra-large-font-size {
		font-size: 2.1rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-huge-font-size {
		font-size: 2.6rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.has-maximum-font-size {
		font-size: 3.2rem;
	}
}

.default-max-width {
	max-width: 100%;
	padding: 0 3rem;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.default-max-width {
		max-width: 130rem;
		padding: 0 20px;
		margin: auto;
	}
}

.small-max-width {
	max-width: 100%;
	padding: 0 3rem;
}

@media print,
only screen and (min-width: 768px) {
	.small-max-width {
		max-width: 118rem;
		padding: 0 20px;
		margin: auto;
	}
}

.full-max-width {
	max-width: 100%;
	padding: 0 2.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.full-max-width {
		padding: 0 20px;
	}
}

.js-fade {
	opacity: 0;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	-webkit-transform: translateY(3rem);
	-ms-transform: translateY(3rem);
	transform: translateY(3rem);
	-webkit-transition: all 0.8s;
	transition: all 0.8s;
}

.js-fade.is-show {
	opacity: 1;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
	-webkit-transform: translate(0);
	-ms-transform: translate(0);
	transform: translate(0);
}

html {
	width: 100%;
	height: 100%;
	font-size: calc((14px + (200vw - 640px) / 55) * 0.625);
}

@media (min-width: 375px) {
	html {
		font-size: calc((16px * 0.625));
	}
}

@media (min-width: 768px) {
	html {
		font-size: 0.72875vw;
	}
}

@media (min-width: 1200px) {
	html {
		font-size: calc((14px + (200vw - 2400px) / 240) * 0.625);
	}
}

@media (min-width: 1400px) {
	html {
		font-size: calc((16px * 0.625));
	}
}

body {
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	color: #000;
	font-family:
		Yu Gothic,
		"游ゴシック",
		"メイリオ",
		Hiragino Kaku Gothic ProN,
		Hiragino Sans,
		sans-serif;
	line-height: 1.8;
	font-weight: 400;
	letter-spacing: normal;
	word-wrap: break-word;
	position: relative;
	font-feature-settings: "palt";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

main {
	position: relative;
	overflow: hidden;
	font-size: 1.4rem;
	opacity: 0;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	-webkit-animation: wrapFade 1s 0.5s ease-in-out forwards;
	animation: wrapFade 1s 0.5s ease-in-out forwards;
}

* {
	box-sizing: border-box;
}

a {
	cursor: pointer;
	color: #000;
	text-underline-offset: 2px;
	text-decoration-skip-ink: all;
	text-decoration: none;
}

a:hover {
	text-decoration: none;
	text-decoration-skip-ink: none;
}

img {
	vertical-align: bottom;
	-ms-interpolation-mode: bicubic;
	max-width: 100%;
	height: auto;
	object-position: center;
}

video {
	width: 100%;
	height: auto;
}

.wrap {
	position: relative;
	padding-top: 5rem;
}

@media print,
only screen and (min-width: 768px) {
	.wrap {
		padding-top: 8rem;
	}
}

@-webkit-keyframes floatUpDown {

	0%,
	100% {
		-webkit-transform: rotate(var(--rotate)) translateY(0);
		transform: rotate(var(--rotate)) translateY(0);
	}

	50% {
		-webkit-transform: rotate(var(--rotate)) translateY(-1.2rem);
		transform: rotate(var(--rotate)) translateY(-1.2rem);
	}
}

@keyframes floatUpDown {

	0%,
	100% {
		-webkit-transform: rotate(var(--rotate)) translateY(0);
		transform: rotate(var(--rotate)) translateY(0);
	}

	50% {
		-webkit-transform: rotate(var(--rotate)) translateY(-1.2rem);
		transform: rotate(var(--rotate)) translateY(-1.2rem);
	}
}

@media only screen and (max-width: 767px) {
	@-webkit-keyframes floatUpDown {

		0%,
		100% {
			-webkit-transform: rotate(var(--rotate)) translateY(0);
			transform: rotate(var(--rotate)) translateY(0);
		}

		50% {
			-webkit-transform: rotate(var(--rotate)) translateY(-0.6rem);
			transform: rotate(var(--rotate)) translateY(-0.6rem);
		}
	}

	@keyframes floatUpDown {

		0%,
		100% {
			-webkit-transform: rotate(var(--rotate)) translateY(0);
			transform: rotate(var(--rotate)) translateY(0);
		}

		50% {
			-webkit-transform: rotate(var(--rotate)) translateY(-0.6rem);
			transform: rotate(var(--rotate)) translateY(-0.6rem);
		}
	}
}

.float-updown {
	-webkit-animation: floatUpDown 3s ease-in-out infinite;
	animation: floatUpDown 3s ease-in-out infinite;
}

@-webkit-keyframes wrapFade {
	0% {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		-webkit-transform: translateY(2rem);
		transform: translateY(2rem);
	}

	100% {
		opacity: 1;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@keyframes wrapFade {
	0% {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		-webkit-transform: translateY(2rem);
		transform: translateY(2rem);
	}

	100% {
		opacity: 1;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@-webkit-keyframes headFade {
	0% {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		-webkit-transform: translateY(-1rem);
		transform: translateY(-1rem);
	}

	100% {
		opacity: 1;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@keyframes headFade {
	0% {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		-webkit-transform: translateY(-1rem);
		transform: translateY(-1rem);
	}

	100% {
		opacity: 1;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

.js-scroll-fade {
	opacity: 0;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
}

.js-scroll-fade.is-show {
	-webkit-animation: wrapFade 1s ease-in-out forwards;
	animation: wrapFade 1s ease-in-out forwards;
}

.js-scroll-side {
	opacity: 0;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
}

@media only screen and (max-width: 767px) {
	@font-face {
		font-family: swiper-icons;
		src: url(data:application/font-woff;charset=utf-8;base64,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);
	}

	:root {
		--swiper-theme-color: #007aff;
	}

	.swiper {
		margin-left: auto;
		margin-right: auto;
		position: relative;
		overflow: hidden;
		list-style: none;
		padding: 0;
		z-index: 1;
	}

	.swiper-vertical>.swiper-wrapper {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.swiper-wrapper {
		position: relative;
		width: 100%;
		height: 100%;
		z-index: 1;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-transition-property: -webkit-transform;
		transition-property: -webkit-transform;
		transition-property: transform;
		transition-property:
			transform,
			-webkit-transform;
		box-sizing: content-box;
	}

	.swiper-android .swiper-slide,
	.swiper-wrapper {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}

	.swiper-pointer-events {
		-ms-touch-action: pan-y;
		touch-action: pan-y;
	}

	.swiper-pointer-events.swiper-vertical {
		-ms-touch-action: pan-x;
		touch-action: pan-x;
	}

	.swiper-slide {
		-ms-flex-negative: 0;
		flex-shrink: 0;
		width: 100%;
		height: 100%;
		position: relative;
		-webkit-transition-property: -webkit-transform;
		transition-property: -webkit-transform;
		transition-property: transform;
		transition-property:
			transform,
			-webkit-transform;
	}

	.swiper-slide-invisible-blank {
		visibility: hidden;
	}

	.swiper-autoheight,
	.swiper-autoheight .swiper-slide {
		height: auto;
	}

	.swiper-autoheight .swiper-wrapper {
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-transition-property:
			height,
			-webkit-transform;
		transition-property:
			height,
			-webkit-transform;
		transition-property: transform, height;
		transition-property:
			transform,
			height,
			-webkit-transform;
	}

	.swiper-backface-hidden .swiper-slide {
		-webkit-transform: translateZ(0);
		transform: translateZ(0);
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.swiper-3d,
	.swiper-3d.swiper-css-mode .swiper-wrapper {
		-webkit-perspective: 1200px;
		perspective: 1200px;
	}

	.swiper-3d .swiper-cube-shadow,
	.swiper-3d .swiper-slide,
	.swiper-3d .swiper-slide-shadow,
	.swiper-3d .swiper-slide-shadow-bottom,
	.swiper-3d .swiper-slide-shadow-left,
	.swiper-3d .swiper-slide-shadow-right,
	.swiper-3d .swiper-slide-shadow-top,
	.swiper-3d .swiper-wrapper {
		-webkit-transform-style: preserve-3d;
		transform-style: preserve-3d;
	}

	.swiper-3d .swiper-slide-shadow,
	.swiper-3d .swiper-slide-shadow-bottom,
	.swiper-3d .swiper-slide-shadow-left,
	.swiper-3d .swiper-slide-shadow-right,
	.swiper-3d .swiper-slide-shadow-top {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		pointer-events: none;
		z-index: 10;
	}

	.swiper-3d .swiper-slide-shadow {
		background: rgba(0, 0, 0, 0.15);
	}

	.swiper-3d .swiper-slide-shadow-left {
		background-image: -webkit-linear-gradient(right, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-right {
		background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-top {
		background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-bottom {
		background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-css-mode>.swiper-wrapper {
		overflow: auto;
		scrollbar-width: none;
		-ms-overflow-style: none;
	}

	.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
		display: none;
	}

	.swiper-css-mode>.swiper-wrapper>.swiper-slide {
		scroll-snap-align: start start;
	}

	.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
		-ms-scroll-snap-type: x mandatory;
		scroll-snap-type: x mandatory;
	}

	.swiper-vertical.swiper-css-mode>.swiper-wrapper {
		-ms-scroll-snap-type: y mandatory;
		scroll-snap-type: y mandatory;
	}

	.swiper-centered>.swiper-wrapper:before {
		content: "";
		-ms-flex-negative: 0;
		flex-shrink: 0;
		-webkit-box-ordinal-group: 10000;
		-ms-flex-order: 9999;
		order: 9999;
	}

	.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
		-webkit-margin-start: var(--swiper-centered-offset-before);
		margin-inline-start: var(--swiper-centered-offset-before);
	}

	.swiper-centered.swiper-horizontal>.swiper-wrapper:before {
		height: 100%;
		min-height: 1px;
		width: var(--swiper-centered-offset-after);
	}

	.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
		-webkit-margin-before: var(--swiper-centered-offset-before);
		margin-block-start: var(--swiper-centered-offset-before);
	}

	.swiper-centered.swiper-vertical>.swiper-wrapper:before {
		width: 100%;
		min-width: 1px;
		height: var(--swiper-centered-offset-after);
	}

	.swiper-centered>.swiper-wrapper>.swiper-slide {
		scroll-snap-align: center center;
		scroll-snap-stop: always;
	}

	@font-face {
		font-family: swiper-icons;
		src: url(data:application/font-woff;charset=utf-8;base64,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);
	}

	:root {
		--swiper-theme-color: #007aff;
	}

	.swiper {
		margin-left: auto;
		margin-right: auto;
		position: relative;
		overflow: hidden;
		list-style: none;
		padding: 0;
		z-index: 1;
	}

	.swiper-vertical>.swiper-wrapper {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.swiper-wrapper {
		position: relative;
		width: 100%;
		height: 100%;
		z-index: 1;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-transition-property: -webkit-transform;
		transition-property: -webkit-transform;
		transition-property: transform;
		transition-property:
			transform,
			-webkit-transform;
		box-sizing: content-box;
	}

	.swiper-android .swiper-slide,
	.swiper-wrapper {
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}

	.swiper-pointer-events {
		-ms-touch-action: pan-y;
		touch-action: pan-y;
	}

	.swiper-pointer-events.swiper-vertical {
		-ms-touch-action: pan-x;
		touch-action: pan-x;
	}

	.swiper-slide {
		-ms-flex-negative: 0;
		flex-shrink: 0;
		width: 100%;
		height: 100%;
		position: relative;
		-webkit-transition-property: -webkit-transform;
		transition-property: -webkit-transform;
		transition-property: transform;
		transition-property:
			transform,
			-webkit-transform;
	}

	.swiper-slide-invisible-blank {
		visibility: hidden;
	}

	.swiper-autoheight,
	.swiper-autoheight .swiper-slide {
		height: auto;
	}

	.swiper-autoheight .swiper-wrapper {
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
		-webkit-transition-property:
			height,
			-webkit-transform;
		transition-property:
			height,
			-webkit-transform;
		transition-property: transform, height;
		transition-property:
			transform,
			height,
			-webkit-transform;
	}

	.swiper-backface-hidden .swiper-slide {
		-webkit-transform: translateZ(0);
		transform: translateZ(0);
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.swiper-3d,
	.swiper-3d.swiper-css-mode .swiper-wrapper {
		-webkit-perspective: 1200px;
		perspective: 1200px;
	}

	.swiper-3d .swiper-cube-shadow,
	.swiper-3d .swiper-slide,
	.swiper-3d .swiper-slide-shadow,
	.swiper-3d .swiper-slide-shadow-bottom,
	.swiper-3d .swiper-slide-shadow-left,
	.swiper-3d .swiper-slide-shadow-right,
	.swiper-3d .swiper-slide-shadow-top,
	.swiper-3d .swiper-wrapper {
		-webkit-transform-style: preserve-3d;
		transform-style: preserve-3d;
	}

	.swiper-3d .swiper-slide-shadow,
	.swiper-3d .swiper-slide-shadow-bottom,
	.swiper-3d .swiper-slide-shadow-left,
	.swiper-3d .swiper-slide-shadow-right,
	.swiper-3d .swiper-slide-shadow-top {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		pointer-events: none;
		z-index: 10;
	}

	.swiper-3d .swiper-slide-shadow {
		background: rgba(0, 0, 0, 0.15);
	}

	.swiper-3d .swiper-slide-shadow-left {
		background-image: -webkit-linear-gradient(right, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-right {
		background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-top {
		background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-3d .swiper-slide-shadow-bottom {
		background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.5), transparent);
		background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent);
	}

	.swiper-css-mode>.swiper-wrapper {
		overflow: auto;
		scrollbar-width: none;
		-ms-overflow-style: none;
	}

	.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
		display: none;
	}

	.swiper-css-mode>.swiper-wrapper>.swiper-slide {
		scroll-snap-align: start start;
	}

	.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
		-ms-scroll-snap-type: x mandatory;
		scroll-snap-type: x mandatory;
	}

	.swiper-vertical.swiper-css-mode>.swiper-wrapper {
		-ms-scroll-snap-type: y mandatory;
		scroll-snap-type: y mandatory;
	}

	.swiper-centered>.swiper-wrapper:before {
		content: "";
		-ms-flex-negative: 0;
		flex-shrink: 0;
		-webkit-box-ordinal-group: 10000;
		-ms-flex-order: 9999;
		order: 9999;
	}

	.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
		-webkit-margin-start: var(--swiper-centered-offset-before);
		margin-inline-start: var(--swiper-centered-offset-before);
	}

	.swiper-centered.swiper-horizontal>.swiper-wrapper:before {
		height: 100%;
		min-height: 1px;
		width: var(--swiper-centered-offset-after);
	}

	.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
		-webkit-margin-before: var(--swiper-centered-offset-before);
		margin-block-start: var(--swiper-centered-offset-before);
	}

	.swiper-centered.swiper-vertical>.swiper-wrapper:before {
		width: 100%;
		min-width: 1px;
		height: var(--swiper-centered-offset-after);
	}

	.swiper-centered>.swiper-wrapper>.swiper-slide {
		scroll-snap-align: center center;
		scroll-snap-stop: always;
	}

	.swiper-virtual .swiper-slide {
		-webkit-backface-visibility: hidden;
		-webkit-transform: translateZ(0);
		transform: translateZ(0);
	}

	.swiper-virtual.swiper-css-mode .swiper-wrapper:after {
		content: "";
		position: absolute;
		left: 0;
		top: 0;
		pointer-events: none;
	}

	.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after {
		height: 1px;
		width: var(--swiper-virtual-size);
	}

	.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after {
		width: 1px;
		height: var(--swiper-virtual-size);
	}

	:root {
		--swiper-navigation-size: 44px;
	}

	.swiper-button-next,
	.swiper-button-prev {
		position: absolute;
		top: 50%;
		width: calc(var(--swiper-navigation-size) / 44 * 27);
		height: var(--swiper-navigation-size);
		margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
		z-index: 10;
		cursor: pointer;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		color: var(--swiper-navigation-color, var(--swiper-theme-color));
	}

	.swiper-button-next.swiper-button-disabled,
	.swiper-button-prev.swiper-button-disabled {
		opacity: 0.35;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=35)";
		cursor: auto;
		pointer-events: none;
	}

	.swiper-button-next.swiper-button-hidden,
	.swiper-button-prev.swiper-button-hidden {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		cursor: auto;
		pointer-events: none;
	}

	.swiper-navigation-disabled .swiper-button-next,
	.swiper-navigation-disabled .swiper-button-prev {
		display: none !important;
	}

	.swiper-button-next:after,
	.swiper-button-prev:after {
		font-family: swiper-icons;
		font-size: var(--swiper-navigation-size);
		text-transform: none !important;
		letter-spacing: 0;
		font-variant: initial;
		line-height: 1;
	}

	.swiper-button-prev,
	.swiper-rtl .swiper-button-next {
		left: 10px;
		right: auto;
	}

	.swiper-button-prev:after,
	.swiper-rtl .swiper-button-next:after {
		content: "prev";
	}

	.swiper-button-next,
	.swiper-rtl .swiper-button-prev {
		right: 10px;
		left: auto;
	}

	.swiper-button-next:after,
	.swiper-rtl .swiper-button-prev:after {
		content: "next";
	}

	.swiper-button-lock {
		display: none;
	}

	.swiper-pagination {
		position: absolute;
		text-align: center;
		-webkit-transition: 0.3s opacity;
		transition: 0.3s opacity;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		z-index: 10;
	}

	.swiper-pagination.swiper-pagination-hidden {
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	}

	.swiper-pagination-disabled>.swiper-pagination,
	.swiper-pagination.swiper-pagination-disabled {
		display: none !important;
	}

	.swiper-horizontal>.swiper-pagination-bullets,
	.swiper-pagination-bullets.swiper-pagination-horizontal,
	.swiper-pagination-custom,
	.swiper-pagination-fraction {
		bottom: 10px;
		left: 0;
		width: 100%;
	}

	.swiper-pagination-bullets-dynamic {
		overflow: hidden;
		font-size: 0;
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
		-webkit-transform: scale(0.33);
		-ms-transform: scale(0.33);
		transform: scale(0.33);
		position: relative;
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
		-webkit-transform: scale(1);
		-ms-transform: scale(1);
		transform: scale(1);
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
		-webkit-transform: scale(1);
		-ms-transform: scale(1);
		transform: scale(1);
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
		-webkit-transform: scale(0.66);
		-ms-transform: scale(0.66);
		transform: scale(0.66);
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
		-webkit-transform: scale(0.33);
		-ms-transform: scale(0.33);
		transform: scale(0.33);
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
		-webkit-transform: scale(0.66);
		-ms-transform: scale(0.66);
		transform: scale(0.66);
	}

	.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
		-webkit-transform: scale(0.33);
		-ms-transform: scale(0.33);
		transform: scale(0.33);
	}

	.swiper-pagination-bullet {
		width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
		height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
		display: inline-block;
		border-radius: 50%;
		background: var(--swiper-pagination-bullet-inactive-color, #000);
		opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=NaN)";
	}

	button.swiper-pagination-bullet {
		border: none;
		margin: 0;
		padding: 0;
		box-shadow: none;
		-webkit-appearance: none;
		appearance: none;
	}

	.swiper-pagination-clickable .swiper-pagination-bullet {
		cursor: pointer;
	}

	.swiper-pagination-bullet:only-child {
		display: none !important;
	}

	.swiper-pagination-bullet-active {
		opacity: var(--swiper-pagination-bullet-opacity, 1);
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=NaN)";
		background: var(--swiper-pagination-color, var(--swiper-theme-color));
	}

	.swiper-pagination-vertical.swiper-pagination-bullets,
	.swiper-vertical>.swiper-pagination-bullets {
		right: 10px;
		top: 50%;
		-webkit-transform: translate3d(0, -50%, 0);
		transform: translate3d(0, -50%, 0);
	}

	.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
	.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
		margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
		display: block;
	}

	.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
	.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
		top: 50%;
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		transform: translateY(-50%);
		width: 8px;
	}

	.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
	.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
		display: inline-block;
		-webkit-transition:
			0.2s transform,
			0.2s top;
		transition:
			0.2s transform,
			0.2s top;
	}

	.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
	.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
	}

	.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
	.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
		left: 50%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
		white-space: nowrap;
	}

	.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
	.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
		-webkit-transition:
			0.2s transform,
			0.2s left;
		transition:
			0.2s transform,
			0.2s left;
	}

	.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
		-webkit-transition:
			0.2s transform,
			0.2s right;
		transition:
			0.2s transform,
			0.2s right;
	}

	.swiper-pagination-progressbar {
		background: rgba(0, 0, 0, 0.25);
		position: absolute;
	}

	.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
		background: var(--swiper-pagination-color, var(--swiper-theme-color));
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		-webkit-transform: scale(0);
		-ms-transform: scale(0);
		transform: scale(0);
		-webkit-transform-origin: left top;
		-ms-transform-origin: left top;
		transform-origin: left top;
	}

	.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
		-webkit-transform-origin: right top;
		-ms-transform-origin: right top;
		transform-origin: right top;
	}

	.swiper-horizontal>.swiper-pagination-progressbar,
	.swiper-pagination-progressbar.swiper-pagination-horizontal,
	.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
	.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
		width: 100%;
		height: 4px;
		left: 0;
		top: 0;
	}

	.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
	.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
	.swiper-pagination-progressbar.swiper-pagination-vertical,
	.swiper-vertical>.swiper-pagination-progressbar {
		width: 4px;
		height: 100%;
		left: 0;
		top: 0;
	}

	.swiper-pagination-lock {
		display: none;
	}

	.swiper-scrollbar {
		border-radius: 10px;
		position: relative;
		-ms-touch-action: none;
		background: rgba(0, 0, 0, 0.1);
	}

	.swiper-scrollbar-disabled>.swiper-scrollbar,
	.swiper-scrollbar.swiper-scrollbar-disabled {
		display: none !important;
	}

	.swiper-horizontal>.swiper-scrollbar,
	.swiper-scrollbar.swiper-scrollbar-horizontal {
		position: absolute;
		left: 1%;
		bottom: 3px;
		z-index: 50;
		height: 5px;
		width: 98%;
	}

	.swiper-scrollbar.swiper-scrollbar-vertical,
	.swiper-vertical>.swiper-scrollbar {
		position: absolute;
		right: 3px;
		top: 1%;
		z-index: 50;
		width: 5px;
		height: 98%;
	}

	.swiper-scrollbar-drag {
		height: 100%;
		width: 100%;
		position: relative;
		background: rgba(0, 0, 0, 0.5);
		border-radius: 10px;
		left: 0;
		top: 0;
	}

	.swiper-scrollbar-cursor-drag {
		cursor: move;
	}

	.swiper-scrollbar-lock {
		display: none;
	}

	.swiper-zoom-container {
		width: 100%;
		height: 100%;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		text-align: center;
	}

	.swiper-zoom-container>canvas,
	.swiper-zoom-container>img,
	.swiper-zoom-container>svg {
		max-width: 100%;
		max-height: 100%;
		object-fit: contain;
	}

	.swiper-slide-zoomed {
		cursor: move;
	}

	.swiper-lazy-preloader {
		width: 42px;
		height: 42px;
		position: absolute;
		left: 50%;
		top: 50%;
		margin-left: -21px;
		margin-top: -21px;
		z-index: 10;
		-webkit-transform-origin: 50%;
		-ms-transform-origin: 50%;
		transform-origin: 50%;
		box-sizing: border-box;
		border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
		border-radius: 50%;
		border-top-color: transparent;
	}

	.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,
	.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
		-webkit-animation: swiper-preloader-spin 1s infinite linear;
		animation: swiper-preloader-spin 1s infinite linear;
	}

	.swiper-lazy-preloader-white {
		--swiper-preloader-color: #fff;
	}

	.swiper-lazy-preloader-black {
		--swiper-preloader-color: #000;
	}

	@-webkit-keyframes swiper-preloader-spin {
		0% {
			-webkit-transform: rotate(0deg);
			transform: rotate(0deg);
		}

		100% {
			-webkit-transform: rotate(360deg);
			transform: rotate(360deg);
		}
	}

	@keyframes swiper-preloader-spin {
		0% {
			-webkit-transform: rotate(0deg);
			transform: rotate(0deg);
		}

		100% {
			-webkit-transform: rotate(360deg);
			transform: rotate(360deg);
		}
	}

	.swiper .swiper-notification {
		position: absolute;
		left: 0;
		top: 0;
		pointer-events: none;
		opacity: 0;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
		z-index: -1000;
	}

	.swiper-free-mode>.swiper-wrapper {
		-webkit-transition-timing-function: ease-out;
		transition-timing-function: ease-out;
		margin: 0 auto;
	}

	.swiper-grid>.swiper-wrapper {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.swiper-grid-column>.swiper-wrapper {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.swiper-fade.swiper-free-mode .swiper-slide {
		-webkit-transition-timing-function: ease-out;
		transition-timing-function: ease-out;
	}

	.swiper-fade .swiper-slide {
		pointer-events: none;
		-webkit-transition-property: opacity;
		transition-property: opacity;
	}

	.swiper-fade .swiper-slide .swiper-slide {
		pointer-events: none;
	}

	.swiper-fade .swiper-slide-active,
	.swiper-fade .swiper-slide-active .swiper-slide-active {
		pointer-events: auto;
	}

	.swiper-cube {
		overflow: visible;
	}

	.swiper-cube .swiper-slide {
		pointer-events: none;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		z-index: 1;
		visibility: hidden;
		-webkit-transform-origin: 0 0;
		-ms-transform-origin: 0 0;
		transform-origin: 0 0;
		width: 100%;
		height: 100%;
	}

	.swiper-cube .swiper-slide .swiper-slide {
		pointer-events: none;
	}

	.swiper-cube.swiper-rtl .swiper-slide {
		-webkit-transform-origin: 100% 0;
		-ms-transform-origin: 100% 0;
		transform-origin: 100% 0;
	}

	.swiper-cube .swiper-slide-active,
	.swiper-cube .swiper-slide-active .swiper-slide-active {
		pointer-events: auto;
	}

	.swiper-cube .swiper-slide-active,
	.swiper-cube .swiper-slide-next,
	.swiper-cube .swiper-slide-next+.swiper-slide,
	.swiper-cube .swiper-slide-prev {
		pointer-events: auto;
		visibility: visible;
	}

	.swiper-cube .swiper-slide-shadow-bottom,
	.swiper-cube .swiper-slide-shadow-left,
	.swiper-cube .swiper-slide-shadow-right,
	.swiper-cube .swiper-slide-shadow-top {
		z-index: 0;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.swiper-cube .swiper-cube-shadow {
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 100%;
		opacity: 0.6;
		-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
		z-index: 0;
	}

	.swiper-cube .swiper-cube-shadow:before {
		content: "";
		background: #000;
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		right: 0;
		filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feGaussianBlur stdDeviation="50" /></filter></svg>#filter');
		filter: blur(50px);
	}

	.swiper-flip {
		overflow: visible;
	}

	.swiper-flip .swiper-slide {
		pointer-events: none;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		z-index: 1;
	}

	.swiper-flip .swiper-slide .swiper-slide {
		pointer-events: none;
	}

	.swiper-flip .swiper-slide-active,
	.swiper-flip .swiper-slide-active .swiper-slide-active {
		pointer-events: auto;
	}

	.swiper-flip .swiper-slide-shadow-bottom,
	.swiper-flip .swiper-slide-shadow-left,
	.swiper-flip .swiper-slide-shadow-right,
	.swiper-flip .swiper-slide-shadow-top {
		z-index: 0;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.swiper-creative .swiper-slide {
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		overflow: hidden;
		-webkit-transition-property:
			opacity,
			height,
			-webkit-transform;
		transition-property:
			opacity,
			height,
			-webkit-transform;
		transition-property: transform, opacity, height;
		transition-property:
			transform,
			opacity,
			height,
			-webkit-transform;
	}

	.swiper-cards {
		overflow: visible;
	}

	.swiper-cards .swiper-slide {
		-webkit-transform-origin: center bottom;
		-ms-transform-origin: center bottom;
		transform-origin: center bottom;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		overflow: hidden;
	}
}

.site-header {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	gap: 1.6rem;
	padding: 0.6rem 0.6rem 0.6rem 1rem;
	background: #fff;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
	position: relative;
	z-index: 30;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	min-height: 5rem;
	position: fixed;
	z-index: 100;
	width: 100%;
	left: 0;
	top: 0;
	opacity: 0;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	-webkit-animation: headFade 1s 0.5s ease-in-out forwards;
	animation: headFade 1s 0.5s ease-in-out forwards;
}

@media print,
only screen and (min-width: 768px) {
	.site-header {
		padding: 1.2rem 12rem;
		min-height: 8rem;
	}
}

.site-logo {
	max-width: 13.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.site-logo {
		max-width: 21.5rem;
	}
}

.site-logo a {
	display: block;
}

.site-navigation-lists {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.site-navigation-lists {
		gap: 1.6rem;
	}
}

.site-navigation-lists__link {
	display: block;
	border-radius: 0.4rem;
	background-color: #345bfb;
	color: #fff;
	padding: 0.8rem 2.4rem 0.8rem 1.6rem;
	font-size: 1.2rem;
	line-height: 1.8;
	font-weight: 700;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.site-navigation-lists__link {
		padding: 1.1rem 1.6rem;
		text-align: center;
		width: 20rem;
		font-size: 1.4rem;
		box-shadow: 1px 2px 4px 0 rgba(0, 0, 0, 0.25);
		-webkit-transition: all 0.5s;
		transition: all 0.5s;
	}

	.site-navigation-lists__link:hover {
		box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
	}
}

.site-navigation-lists__link.is-info {
	background-color: #16c677;
}

.site-navigation-lists__link:after {
	content: "";
	position: absolute;
	width: 1.6rem;
	height: 1.6rem;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M1 9L5 5L1 1" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round"/></svg>');
	background-size: 0.6rem auto;
	background-repeat: no-repeat;
	background-position: center;
	z-index: 1;
	top: 0;
	bottom: 0.2rem;
	right: 0.8rem;
	margin: auto;
}

@media print,
only screen and (min-width: 768px) {
	.site-navigation-lists__link:after {
		width: 1.2rem;
		height: 1.2rem;
		background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 3.5C0.723858 3.5 .5 3.72386 .5 4C0.5 4.27614 .723858 4.5 1 4.5L1 3.5ZM11.3536 4.35355C11.5488 4.15829 11.5488 3.84171 11.3536 3.64645L8.17157 .464467C7.97631 .269205 7.65973 .269205 7.46447 .464467C7.2692 .659729 7.2692 .976311 7.46447 1.17157L10.2929 4L7.46447 6.82843C7.2692 7.02369 7.2692 7.34027 7.46447 7.53553C7.65973 7.7308 7.97631 7.7308 8.17157 7.53553L11.3536 4.35355ZM1 4L1 4.5L11 4.5L11 4L11 3.5L1 3.5L1 4Z" fill="%23fff"/></svg>');
		background-size: 1.2rem auto;
		background-repeat: no-repeat;
		background-position: center;
		right: 1.5rem;
		bottom: 0;
	}
}

.site-footer {
	padding: 2.4rem 2.4rem 4.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.site-footer {
		padding: 10.2rem 12rem 11.8rem;
		position: relative;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}
}

.footer__logo {
	max-width: 21.5rem;
	margin: 0 auto 2.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.footer__logo {
		max-width: 18rem;
		margin: 0;
	}
}

.footer-nav {
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 2.4rem;
	padding: 0;
	margin: 0;
	list-style: none;
}

@media print,
only screen and (min-width: 768px) {
	.footer-nav {
		text-align: left;
	}
}

.footer-nav__item a {
	font-size: 1.4rem;
	line-height: 1.2;
	display: block;
}

@media print,
only screen and (min-width: 768px) {
	.footer-nav__item a {
		font-size: 1.6rem;
	}

	.footer-nav__item a:hover {
		text-decoration: underline;
	}
}

.mainvisual {
	padding: 2.4rem 1.6rem;
	background-image:
		url(../../assets/img/bg-noise.png),
		-webkit-linear-gradient(350deg, #edfdfc 0, #d0dfff 100%);
	background-image: url(../../assets/img/bg-noise.png), linear-gradient(100deg, #edfdfc 0, #d0dfff 100%);
	background-size: contain;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual {
		padding: 4.3rem 1.6rem 4rem;
	}
}

.mainvisual-contents {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents {
		gap: 6rem;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		max-width: 115rem;
		margin: 0 auto;
	}
}

.mainvisual-contents__detail {
	display: contents;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__detail {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
		display: block;
	}
}

.mainvisual-contents__logo {
	max-width: 25.4rem;
	margin: 0 auto;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__logo {
		max-width: 39rem;
		margin: 0;
	}
}

@media only screen and (max-width: 767px) {
	.mainvisual-contents__logo {
		-webkit-box-ordinal-group: 1;
		-ms-flex-order: 0;
		order: 0;
	}
}

.mainvisual-contents__text {
	font-size: 2.1rem;
	line-height: 1.7;
	font-weight: 700;
	text-align: center;
	margin-bottom: 0.8rem;
	letter-spacing: 0.05em;
}

@media only screen and (max-width: 767px) {
	.mainvisual-contents__text {
		-webkit-box-ordinal-group: 2;
		-ms-flex-order: 1;
		order: 1;
	}
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__text {
		font-size: 2.6rem;
		text-align: left;
		margin-bottom: 3.2rem;
	}
}

.mainvisual-contents__text span {
	font-size: 2.6rem;
	color: #345bfb;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__text span {
		font-size: 3.2rem;
	}
}

.mainvisual-contents__text em {
	display: none;
	font-style: normal;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__text em {
		display: inline-block;
	}
}

.mainvisual-contents-buttons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents-buttons {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: flex-start;
	}
}

@media only screen and (max-width: 767px) {
	.mainvisual-contents-buttons {
		-webkit-box-ordinal-group: 4;
		-ms-flex-order: 3;
		order: 3;
	}
}

.mainvisual-contents__button {
	display: block;
	background-color: #345bfb;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.8;
	font-weight: 700;
	padding: 0.9rem 2rem;
	max-width: 31rem;
	position: relative;
	text-align: center;
	border-radius: 100vmax;
	width: 100%;
	box-shadow: 1px 2px 4px 0 rgba(0, 0, 0, 0.25);
	margin: 0 auto;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__button {
		margin: 0;
		border-radius: 0.4rem;
		max-width: 20rem;
		font-size: 1.4rem;
		padding: 1.1rem;
		-webkit-transition: all 0.5s;
		transition: all 0.5s;
	}

	.mainvisual-contents__button:hover {
		box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
	}
}

.mainvisual-contents__button.is-info {
	background-color: #16c677;
}

.mainvisual-contents__button:after {
	content: "";
	position: absolute;
	width: 1.6rem;
	height: 1.6rem;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M1 9L5 5L1 1" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round"/></svg>');
	background-size: 0.6rem auto;
	background-repeat: no-repeat;
	background-position: center;
	z-index: 1;
	top: 0;
	bottom: 0;
	right: 2.2rem;
	margin: auto;
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__button:after {
		width: 1.3rem;
		height: 1.3rem;
		background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 3.5C0.723858 3.5 .5 3.72386 .5 4C0.5 4.27614 .723858 4.5 1 4.5L1 3.5ZM11.3536 4.35355C11.5488 4.15829 11.5488 3.84171 11.3536 3.64645L8.17157 .464467C7.97631 .269205 7.65973 .269205 7.46447 .464467C7.2692 .659729 7.2692 .976311 7.46447 1.17157L10.2929 4L7.46447 6.82843C7.2692 7.02369 7.2692 7.34027 7.46447 7.53553C7.65973 7.7308 7.97631 7.7308 8.17157 7.53553L11.3536 4.35355ZM1 4L1 4.5L11 4.5L11 4L11 3.5L1 3.5L1 4Z" fill="%23fff"/></svg>');
		background-size: 1.3rem auto;
		background-repeat: no-repeat;
		background-position: center;
		right: 1.5rem;
	}
}

.mainvisual-contents__image {
	margin: 2.4rem auto 1.6rem;
	max-width: 18rem;
}

@media only screen and (max-width: 767px) {
	.mainvisual-contents__image {
		-webkit-box-ordinal-group: 3;
		-ms-flex-order: 2;
		order: 2;
	}
}

@media print,
only screen and (min-width: 768px) {
	.mainvisual-contents__image {
		margin: 0;
		max-width: 42rem;
	}
}

.worries {
	padding: 3.2rem 0.6rem 2.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries {
		padding: 4.8rem 1.6rem 5.6rem;
	}
}

.worries-head {
	text-align: center;
	margin-bottom: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries-head {
		margin-bottom: 2.4rem;
	}
}

.worries-head__main {
	color: #345bfb;
	font-size: 2rem;
	line-height: 1.5;
	margin: 0 0 1rem;
	font-weight: 700;
}

@media print,
only screen and (min-width: 768px) {
	.worries-head__main {
		font-size: 3.2rem;
		margin-bottom: 1.6rem;
	}
}

.worries-head__main span {
	font-family: sans-serif;
}

.worries-head__sub {
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.8;
}

@media print,
only screen and (min-width: 768px) {
	.worries-head__sub {
		font-size: 2.4rem;
	}
}

.worries-head__sub span {
	color: #345bfb;
}

.worries-contents {
	aspect-ratio: 363 / 301;
	position: relative;
	max-width: 36.5rem;
	margin: 0 auto;
}

@media print,
only screen and (min-width: 768px) {
	.worries-contents {
		max-width: 111.6rem;
		aspect-ratio: 1116.13 / 532.41;
	}
}

.worries-contents__image {
	position: absolute;
	z-index: 1;
	max-width: 13rem;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}

@media print,
only screen and (min-width: 768px) {
	.worries-contents__image {
		max-width: 27rem;
	}
}

.worries-item {
	position: absolute;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-size: cover;
	font-size: 1.2rem;
	line-height: 1.7;
	font-weight: 700;
	width: 100%;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item {
		font-size: 1.6rem;
		line-height: 1.8;
	}
}

.worries-item--01 {
	z-index: 3;
	aspect-ratio: 143 / 129;
	background-image: url(../../assets/img/worries-item01.png);
	max-width: 14.5rem;
	padding-top: 1rem;
	left: 0;
	bottom: 1rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item--01 {
		bottom: auto;
		max-width: 26.7rem;
		top: 12.8rem;
	}
}

.worries-item--02 {
	z-index: 2;
	aspect-ratio: 150 / 97;
	background-image: url(../../assets/img/worries-item02.png);
	max-width: 15.2rem;
	left: 1rem;
	bottom: 12.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item--02 {
		max-width: 30.7rem;
		left: 17.7rem;
		bottom: auto;
		top: 3.8rem;
	}
}

.worries-item--03 {
	z-index: 4;
	aspect-ratio: 148 / 133;
	background-image: url(../../assets/img/worries-item03.png);
	max-width: 15rem;
	left: 0;
	right: 0;
	margin: auto;
	top: 0;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item--03 {
		left: 4.5rem;
		max-width: 24.4rem;
	}
}

.worries-item--04 {
	z-index: 5;
	aspect-ratio: 139 / 128;
	background-image: url(../../assets/img/worries-item04.png);
	max-width: 14.1rem;
	right: 1.6rem;
	bottom: 10rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item--04 {
		bottom: auto;
		right: 16.8rem;
		top: 3rem;
		max-width: 27.2rem;
	}
}

.worries-item--05 {
	z-index: 1;
	aspect-ratio: 144 / 130;
	background-image: url(../../assets/img/worries-item05.png);
	max-width: 14.6rem;
	right: 0;
	bottom: 0;
	padding-top: 2rem;
}

@media print,
only screen and (min-width: 768px) {
	.worries-item--05 {
		padding-top: 3rem;
		bottom: auto;
		top: 14.5rem;
		max-width: 24.4rem;
	}
}

.solution-contents {
	padding: 1.6rem 1.6rem 4.8rem;
	position: relative;
	background-image:
		url(../../assets/img/bg-noise.png),
		-webkit-linear-gradient(350deg, #edfdfc 0, #d0dfff 100%);
	background-image: url(../../assets/img/bg-noise.png), linear-gradient(100deg, #edfdfc 0, #d0dfff 100%);
	background-size: contain;
}

@media print,
only screen and (min-width: 768px) {
	.solution-contents {
		padding: 0.5rem 1.6rem 10.7rem;
	}
}

.solution-contents:before {
	content: "";
	width: 8.1rem;
	aspect-ratio: 81.03 / 64;
	display: block;
	margin: 0 auto 2.2rem;
	background-image: url(../../assets/img/arrow-down.png);
	background-size: cover;
}

@media print,
only screen and (min-width: 768px) {
	.solution-contents:before {
		width: 11.2rem;
		margin-bottom: 3.2rem;
	}
}

.solution-head {
	margin: 0 auto 2rem;
	text-align: center;
	position: relative;
	max-width: -webkit-fit-content;
	max-width: fit-content;
}

@media print,
only screen and (min-width: 768px) {
	.solution-head {
		max-width: 100rem;
	}
}

.solution-head:before {
	content: "";
	position: absolute;
	width: 4.6rem;
	aspect-ratio: 46.15 / 51.67;
	background-image: url(../../assets/img/icon-box.png);
	background-size: cover;
	top: -12rem;
	left: -1.2rem;
	z-index: 1;
	--rotate: -16deg;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s ease-in-out infinite;
	animation: floatUpDown 3s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.solution-head:before {
		width: 11.1rem;
		left: 1.2rem;
		top: -23rem;
	}
}

.solution-head:after {
	content: "";
	position: absolute;
	width: 3.8rem;
	aspect-ratio: 38.68 / 51.67;
	background-image: url(../../assets/img/icon-graph.png);
	background-size: cover;
	top: -9rem;
	right: -2.2rem;
	z-index: 1;
	--rotate: 0;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s 1s ease-in-out infinite;
	animation: floatUpDown 3s 1s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.solution-head:after {
		width: 9.3rem;
		top: -19.5rem;
		right: 1.1rem;
	}
}

.solution-head__main {
	max-width: 23.1rem;
	margin: 0 auto 1.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.solution-head__main {
		max-width: 41.7rem;
		margin-bottom: 2rem;
	}
}

.solution-head__sub {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.7;
}

@media print,
only screen and (min-width: 768px) {
	.solution-head__sub {
		font-size: 2.4rem;
	}
}

.solution-head__sub span {
	color: #345bfb;
}

.solution__image {
	max-width: 34rem;
	margin: 0 auto;
	position: relative;
	filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feGaussianBlur in="SourceAlpha" stdDeviation="20" /><feOffset dx="1" dy="1" result="offsetblur" /><feFlood flood-color="rgba(52,91,251,.2)" /><feComposite in2="offsetblur" operator="in" /><feMerge><feMergeNode /><feMergeNode in="SourceGraphic" /></feMerge></filter></svg>#filter');
	filter: drop-shadow(0 0 20px rgba(52, 91, 251, 0.2));
}

@media print,
only screen and (min-width: 768px) {
	.solution__image {
		max-width: 76.8rem;
	}
}

.solution__image:before {
	content: "";
	position: absolute;
	width: 6.7rem;
	aspect-ratio: 67.59 / 69;
	left: 0;
	bottom: 10.4rem;
	z-index: 1;
	background-image: url(../../assets/img/solution-ec.png);
	background-size: cover;
}

@media print,
only screen and (min-width: 768px) {
	.solution__image:before {
		width: 14.1rem;
		left: -5.7rem;
		bottom: auto;
		top: 1.8rem;
	}
}

.solution__image:after {
	content: "";
	position: absolute;
	width: 4.6rem;
	aspect-ratio: 46.17 / 44;
	right: 0;
	bottom: 10.1rem;
	z-index: 1;
	background-image: url(../../assets/img/solution-line.png);
	background-size: cover;
}

@media print,
only screen and (min-width: 768px) {
	.solution__image:after {
		width: 12.7rem;
		bottom: 5.5rem;
		right: -5.1rem;
	}
}

.solution__detail {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	text-align: center;
	font-size: 1.2rem;
	line-height: 1.5;
	gap: 1.6rem;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	max-width: 34rem;
	margin: 0.6rem auto 2.4rem;
	padding-right: 1.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.solution__detail {
		max-width: 80.4rem;
		font-size: 1.4rem;
		margin: -3rem auto 3.2rem;
		padding-right: 1rem;
	}

	.solution__detail span:first-of-type {
		-webkit-transform: translateX(1rem);
		-ms-transform: translateX(1rem);
		transform: translateX(1rem);
	}
}

.solution__detail span:last-of-type {
	-webkit-transform: translateX(-1rem);
	-ms-transform: translateX(-1rem);
	transform: translateX(-1rem);
}

@media print,
only screen and (min-width: 768px) {
	.solution__detail span:last-of-type {
		-webkit-transform: translateX(-0.5rem);
		-ms-transform: translateX(-0.5rem);
		transform: translateX(-0.5rem);
	}
}

.solution__catch {
	text-align: center;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: 700;
	text-decoration: underline;
}

@media print,
only screen and (min-width: 768px) {
	.solution__catch {
		font-size: 2.4rem;
	}
}

.solution__catch span {
	color: #345bfb;
}

.cta {
	padding: 4rem 0 4.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.cta {
		padding: 8rem 1.6rem;
	}
}

.cta__title {
	background: -webkit-linear-gradient(352deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	background: linear-gradient(98deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 2.6rem;
}

@media print,
only screen and (min-width: 768px) {
	.cta__title {
		font-size: 3.2rem;
		margin-bottom: 4rem;
	}
}

.cta-lists {
	padding-bottom: 3.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.cta-lists {
		padding-bottom: 4rem;
		max-width: 120rem;
		margin: 0 auto;
	}
}

@media print,
only screen and (min-width: 768px) {
	.cta-lists .swiper-wrapper {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 2.4rem;
	}
}

.cta-lists .swiper-pagination {
	bottom: 0;
	height: 1.8rem;
}

.cta-lists .swiper-pagination .swiper-pagination-bullet {
	width: 1.6rem;
	height: 1.6rem;
	margin: 0 0.4rem;
	opacity: 1;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
	background-color: #d9d9d9;
}

.cta-lists .swiper-pagination .swiper-pagination-bullet-active {
	background-color: #345bfb;
}

.cta-list-item {
	border-radius: 0.8rem;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
	padding: 2.4rem 1.2rem;
	height: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list-item {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
		padding: 3.2rem 2.4rem 4rem;
	}
}

.cta-list__image {
	max-width: 18rem;
	margin: 0 auto 1.6rem;
}

.cta-list__title {
	font-size: 2rem;
	line-height: 1.6;
	font-weight: 700;
	text-align: center;
	margin: 1.6rem 0 0.8rem;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__title {
		font-size: 2.4rem;
	}
}

.cta-list__title span {
	font-size: 2.4rem;
	background: -webkit-linear-gradient(352deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	background: linear-gradient(98deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	line-height: 1;
	display: inline-block;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__title span {
		font-size: 3.2rem;
	}
}

.cta-list__title strong {
	font-size: 3.2rem;
	line-height: 1;
	display: inline-block;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__title strong {
		font-size: 4rem;
	}
}

.cta-list__title em {
	position: absolute;
	z-index: 1;
	font-size: 0.8rem;
	line-height: 1.8;
	font-style: normal;
	top: -0.5rem;
	left: 60%;
	font-weight: 400;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__title em {
		left: calc(50% + 4.4rem);
	}
}

.cta-list__text {
	font-size: 1.4rem;
	text-align: center;
	font-weight: 500;
	line-height: 1.6;
	margin: 0.8rem 0;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__text {
		margin: 0.8rem 0 1.6rem;
		font-size: 1.6rem;
	}
}

.cta-list__text em {
	font-size: 0.8rem;
	line-height: 1.8;
	font-style: normal;
	font-weight: 400;
	-webkit-transform: translate(-0.7rem, -0.5rem);
	-ms-transform: translate(-0.7rem, -0.5rem);
	transform: translate(-0.7rem, -0.5rem);
	display: inline-block;
}

.cta-list__suppl {
	font-size: 0.8rem;
	line-height: 1.6;
	font-weight: 500;
	padding: 0 0.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.cta-list__suppl {
		padding: 0 1.6rem;
	}
}

.cta-bottom {
	margin: 2.4rem auto 0;
	max-width: 55.4rem;
	text-align: center;
}

@media print,
only screen and (min-width: 768px) {
	.cta-bottom {
		margin: 0 auto;
	}
}

.cta-bottom__title {
	font-size: 1.6rem;
	font-weight: 700;
	margin: 0 0 0.4rem;
	color: #345bfb;
}

@media print,
only screen and (min-width: 768px) {
	.cta-bottom__title {
		font-size: 2.4rem;
		margin-bottom: 2rem;
	}
}

.cta-bottom__title span {
	font-family: sans-serif;
}

.cta-butttons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 0.8rem;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding: 0 3.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.cta-butttons {
		gap: 2.4rem;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		padding: 0;
	}
}

.cta-butttons__item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	padding: 0.8rem;
	gap: 0.2rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.8;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	background-color: #345bfb;
	color: #fff;
	border-radius: 100vmax;
	box-shadow: 1px 2px 4px 0 rgba(0, 0, 0, 0.25);
	position: relative;
	max-width: 31rem;
	margin: 0 auto;
	width: 100%;
}

@media print,
only screen and (min-width: 768px) {
	.cta-butttons__item {
		border-radius: 0.4rem;
		display: block;
		padding: 1.1rem;
		font-size: 1.6rem;
		-webkit-transition: all 0.5s;
		transition: all 0.5s;
		margin: 0;
		max-width: 100%;
	}

	.cta-butttons__item:hover {
		box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
	}
}

.cta-butttons__item:after {
	content: "";
	position: absolute;
	right: 2.2rem;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 1.6rem;
	height: 1.6rem;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6" height="10" viewBox="0 0 6 10" fill="none"><path d="M1 9L5 5L1 1" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round"/></svg>');
	background-position: center;
	background-size: 0.6rem auto;
	background-repeat: no-repeat;
}

@media print,
only screen and (min-width: 768px) {
	.cta-butttons__item:after {
		background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8" fill="none"><path d="M1 3.5C0.723858 3.5 .5 3.72386 .5 4C0.5 4.27614 .723858 4.5 1 4.5L1 3.5ZM11.3536 4.35355C11.5488 4.15829 11.5488 3.84171 11.3536 3.64645L8.17157 .464467C7.97631 .269205 7.65973 .269205 7.46447 .464467C7.2692 .659729 7.2692 .976311 7.46447 1.17157L10.2929 4L7.46447 6.82843C7.2692 7.02369 7.2692 7.34027 7.46447 7.53553C7.65973 7.7308 7.97631 7.7308 8.17157 7.53553L11.3536 4.35355ZM1 4L1 4.5L11 4.5L11 4L11 3.5L1 3.5L1 4Z" fill="%23fff"/></svg>');
		background-size: 1.4rem auto;
		background-repeat: no-repeat;
		background-position: center;
		width: 1.4rem;
		height: 1.4rem;
		right: 3rem;
		margin: auto;
		z-index: 1;
	}
}

.cta-butttons__item:last-of-type {
	background-color: #16c677;
}

.why {
	padding: 4rem 0;
	background-image:
		url(../../assets/img/bg-noise.png),
		-webkit-linear-gradient(350deg, #edfdfc 0, #d0dfff 100%);
	background-image: url(../../assets/img/bg-noise.png), linear-gradient(100deg, #edfdfc 0, #d0dfff 100%);
	background-size: contain;
}

@media print,
only screen and (min-width: 768px) {
	.why {
		padding: 8rem 1.6rem;
	}
}

.why-head {
	text-align: center;
	margin: 0 auto 4.6rem;
	max-width: -webkit-fit-content;
	max-width: fit-content;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.why-head {
		margin-bottom: 3.2rem;
		max-width: 105.6rem;
	}
}

.why-head:before {
	content: "";
	position: absolute;
	width: 4.9rem;
	aspect-ratio: 49.14 / 44.96;
	background-image: url(../../assets/img/icon-good.png);
	background-size: cover;
	top: -1.2rem;
	left: -4.6rem;
	z-index: 1;
	--rotate: 8deg;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s ease-in-out infinite;
	animation: floatUpDown 3s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.why-head:before {
		width: 11.8rem;
		left: 4.2rem;
		top: -7.2rem;
	}
}

.why-head:after {
	content: "";
	position: absolute;
	width: 5.3rem;
	aspect-ratio: 53.82 / 58.56;
	background-image: url(../../assets/img/icon-pc.png);
	background-size: cover;
	top: -5.1rem;
	right: -4.4rem;
	z-index: 1;
	--rotate: 8deg;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s 1.2s ease-in-out infinite;
	animation: floatUpDown 3s 1.2s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.why-head:after {
		width: 13rem;
		top: -15.4rem;
		right: 3.5rem;
	}
}

.why-head__main {
	max-width: 10rem;
	margin: 0 auto 0.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-head__main {
		max-width: 18.3rem;
		margin-bottom: 2.2rem;
	}
}

.why-head__sub {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
}

@media print,
only screen and (min-width: 768px) {
	.why-head__sub {
		font-size: 2.4rem;
	}
}

.why-lists {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 6.4rem;
	padding: 0 1.6rem;
	margin-bottom: 4.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-lists {
		gap: 4rem;
		max-width: 105.6rem;
		margin: 0 auto 6.4rem;
	}
}

.why-list-item {
	-webkit-transition: all 1s;
	transition: all 1s;
	-webkit-transform: translateX(-4rem);
	-ms-transform: translateX(-4rem);
	transform: translateX(-4rem);
	-webkit-transition-delay: 0.7s;
	transition-delay: 0.7s;
}

@media print,
only screen and (min-width: 768px) {
	.why-list-item {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		gap: 5.6rem;
	}

	.why-list-item:nth-of-type(odd) {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse;
	}
}

.why-list-item:nth-of-type(odd) {
	-webkit-transform: translateX(4rem);
	-ms-transform: translateX(4rem);
	transform: translateX(4rem);
}

.why-list-item.is-show {
	opacity: 1;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0);
}

@media print,
only screen and (min-width: 768px) {
	.why-list-item-detail {
		width: calc((100% - 5.6rem) / 2);
	}
}

.why-list-item__image {
	max-width: 40rem;
	margin: 0 auto;
}

.why-list-item__num {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 1.6rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 1.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-list-item__num {
		margin-bottom: 2rem;
	}
}

.why-list-item__num span {
	display: inline-block;
	max-width: 10rem;
	line-height: 1;
}

.why-list-item__num:after {
	content: "";
	width: 100%;
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	height: 1px;
	background-color: #345bfb;
}

.why-list-item__title {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-list-item__title {
		font-size: 2.4rem;
	}
}

.why-list-item__text {
	font-size: 1.6rem;
	line-height: 1.8;
	margin-bottom: 1.6rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-list-item__text {
		margin-bottom: 0;
	}
}

.why-bottom__catch {
	text-align: center;
	font-size: 2rem;
	line-height: 1.6;
	font-weight: 700;
	margin-bottom: 2.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom__catch {
		font-size: 3.2rem;
		margin-bottom: 4.4rem;
	}
}

.why-bottom__catch span {
	color: #345bfb;
}

.why-bottom-lists {
	padding-bottom: 3.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom-lists {
		padding-bottom: 0;
	}
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom-lists .swiper-wrapper {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 5.5rem 4rem;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		max-width: 105.4rem;
		margin: 0 auto;
	}
}

.why-bottom-lists .swiper-pagination {
	bottom: 0;
	height: 1.8rem;
}

.why-bottom-lists .swiper-pagination .swiper-pagination-bullet {
	width: 1.6rem;
	height: 1.6rem;
	margin: 0 0.4rem;
	opacity: 1;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
	background-color: #d9d9d9;
}

.why-bottom-lists .swiper-pagination .swiper-pagination-bullet-active {
	background-color: #345bfb;
}

.why-bottom-item {
	border-radius: 3.2rem;
	background-color: #fff;
	height: auto;
	position: relative;
	padding: 4rem 2.8rem;
	box-shadow: 0 0 50px 0 rgba(52, 91, 251, 0.2);
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom-item {
		width: calc((100% - 4rem) / 2);
		padding: 3.2rem 3.8rem 4rem;
	}
}

.why-bottom-item:before {
	content: "";
	position: absolute;
	width: 68%;
	height: 0.4rem;
	background-color: #345bfb;
	left: 0;
	right: 0;
	top: 0;
	margin: auto;
	z-index: 1;
}

.why-bottom__title {
	border-radius: 0.8rem 0.8rem 0 0;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 3.2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 0.8rem;
	min-height: 7.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom__title {
		font-size: 2.4rem;
		gap: 0.6rem;
		min-height: 9rem;
		margin-bottom: 2rem;
	}
}

.why-bottom__title span {
	display: inline-block;
	max-width: 7.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom__title span {
		max-width: 9rem;
	}
}

.why-bottom-detail {
	padding-top: 3.2rem;
	background-image: url(../../assets/img/line-dots.png);
	background-repeat: repeat-x;
	background-size: auto 0.5rem;
	background-position: left top;
}

.why-bottom-detail dt {
	font-size: 1.6rem;
	color: #345bfb;
	font-weight: 700;
	line-height: 1.5;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom-detail dt {
		font-size: 1.8rem;
	}
}

.why-bottom-detail dd {
	font-size: 1.4rem;
	line-height: 1.5;
}

@media only screen and (max-width: 767px) {
	.why-bottom-detail dd {
		font-size: 1.6rem;
	}
}

.why-bottom-detail dd:not(:last-of-type) {
	margin-bottom: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.why-bottom-detail dd:not(:last-of-type) {
		margin-bottom: 1.2rem;
	}
}

.company {
	padding: 0 1.6rem 3.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.company {
		padding-bottom: 8rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.company-inner {
		max-width: 105.6rem;
		margin: 0 auto;
	}
}

.company-head {
	padding: 4.5rem 0 2.1rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-head {
		padding: 8rem 0 5.2rem;
	}
}

.company-head__main {
	max-width: 22.7rem;
	margin: 0 auto 0.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-head__main {
		max-width: 40.8rem;
		padding-bottom: 2rem;
	}
}

.company-head__sub {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	margin: 0;
	text-align: center;
}

@media print,
only screen and (min-width: 768px) {
	.company-head__sub {
		font-size: 2.4rem;
	}
}

.company-info {
	margin-bottom: 3.2rem;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.company-info {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 5.6rem;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		margin-bottom: 5.6rem;
	}
}

.company-info:after {
	content: "";
	position: absolute;
	aspect-ratio: 1;
	width: 29rem;
	background-image: url(../../assets/img/icon-bg.png);
	background-size: cover;
	z-index: -1;
	left: -8.8rem;
	bottom: 3.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-info:after {
		width: 37.2rem;
		left: auto;
		right: -7.8rem;
		bottom: auto;
		top: -12.3rem;
	}
}

.company-info__image {
	max-width: 26rem;
	margin: 0 auto 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-info__image {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
		max-width: 100%;
		margin: 0;
		text-align: center;
	}

	.company-info__image img {
		max-width: 30.4rem;
	}
}

.company-info__detail {
	text-align: center;
}

@media print,
only screen and (min-width: 768px) {
	.company-info__detail {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
		text-align: left;
	}
}

.company-info__name {
	font-size: 1.6rem;
	font-weight: 500;
	margin: 0 0 2rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-info__name {
		font-size: 2.4rem;
		font-weight: 700;
		margin-bottom: 0.9rem;
	}
}

.company-info-item:not(:last-of-type) {
	margin-bottom: 0.8rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-info-item:not(:last-of-type) {
		margin: 0;
	}
}

@media print,
only screen and (min-width: 768px) {
	.company-info-item {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 0.8rem;
	}
}

.company-info-item dt {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 2;
}

@media print,
only screen and (min-width: 768px) {
	.company-info-item dt {
		width: 12.8rem;
		font-size: 2.4rem;
		font-weight: 400;
	}
}

.company-info-item dd {
	font-size: 1.6rem;
	line-height: 2;
}

@media print,
only screen and (min-width: 768px) {
	.company-info-item dd {
		font-size: 2.4rem;
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}
}

.company-info-item dd small {
	display: block;
	font-size: 1rem;
}

@media print,
only screen and (min-width: 768px) {
	.company-info-item dd small {
		font-size: 1.6rem;
		display: inline-block;
		margin-left: 0.5rem;
	}
}

.company-cards {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 2.4rem;
	list-style: none;
}

@media print,
only screen and (min-width: 768px) {
	.company-cards {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		gap: 5.6rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.company-cards-item {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}
}

.company-cards__title {
	margin: 1.6rem 0 0;
	font-size: 2rem;
	line-height: 1.8;
	font-weight: 700;
}

.company-cards__text {
	margin: 0;
	font-size: 1.6rem;
	line-height: 1.9;
	letter-spacing: 0.01em;
}

.contact {
	padding: 4.8rem 1.6rem;
	background-image: url(../../assets/img/bg-noise.png);
	background-color: #f7f9fb;
	background-size: contain;
	position: relative;
	z-index: 2;
}

@media print,
only screen and (min-width: 768px) {
	.contact {
		padding: 8rem 1.6rem;
	}
}

.contact-head {
	margin: 0 auto 4.8rem;
	max-width: -webkit-fit-content;
	max-width: fit-content;
	position: relative;
}

@media print,
only screen and (min-width: 768px) {
	.contact-head {
		margin-bottom: 5.9rem;
		max-width: 105.6rem;
	}
}

.contact-head:before {
	content: "";
	position: absolute;
	width: 3.9rem;
	aspect-ratio: 39.33 / 45.64;
	background-image: url(../../assets/img/icon-mail.png);
	background-size: cover;
	top: -5rem;
	left: -3.8rem;
	z-index: 1;
	--rotate: -4deg;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s ease-in-out infinite;
	animation: floatUpDown 3s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.contact-head:before {
		width: 9.5rem;
		left: 2.2rem;
		top: -11.6rem;
	}
}

.contact-head:after {
	content: "";
	position: absolute;
	width: 4.5rem;
	aspect-ratio: 45.12 / 48.47;
	background-image: url(../../assets/img/icon-message.png);
	background-size: cover;
	bottom: -3.6rem;
	right: -3.3rem;
	z-index: 1;
	--rotate: -11deg;
	-webkit-transform: rotate(var(--rotate));
	-ms-transform: rotate(var(--rotate));
	transform: rotate(var(--rotate));
	-webkit-animation: floatUpDown 3s 0.8s ease-in-out infinite;
	animation: floatUpDown 3s 0.8s ease-in-out infinite;
}

@media print,
only screen and (min-width: 768px) {
	.contact-head:after {
		width: 10.9rem;
		top: -3.7rem;
		right: 7.6rem;
		bottom: auto;
	}
}

.contact-head__main {
	max-width: 21.4rem;
	margin: 0 auto 0.4rem;
}

@media print,
only screen and (min-width: 768px) {
	.contact-head__main {
		max-width: 38.6rem;
		margin-bottom: 2rem;
	}
}

.contact-head__sub {
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
}

@media print,
only screen and (min-width: 768px) {
	.contact-head__sub {
		font-size: 2.4rem;
	}
}

.page-top {
	display: none;
}

@media print,
only screen and (min-width: 768px) {
	.page-top {
		display: block;
		position: absolute;
		z-index: 1;
		width: 9rem;
		right: 9.6rem;
		bottom: -1rem;
	}

	.page-top:hover {
		cursor: pointer;
	}
}

@media print,
only screen and (min-width: 768px) {
	.contact-form {
		max-width: 105.6rem;
		margin: 0 auto;
		position: relative;
	}
}

.contact-row-item {
	margin-bottom: 1.2rem;
}

@media print,
only screen and (min-width: 768px) {
	.contact-row-item {
		margin-bottom: 2.8rem;
	}
}

.contact-row-item.is-flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 1.6rem;
}

@media print,
only screen and (min-width: 768px) {
	.contact-row-item.is-flex {
		gap: 3.2rem;
	}
}

.contact-row-item label {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 0.4rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 0.4rem;
}

.contact-row-item label span {
	color: #fff;
	background-color: #345bfb;
	border-radius: 100vmax;
	padding: 0.1rem 0.8rem 0;
	line-height: 1.6;
}

.contact-row-item input {
	display: block;
}

.contact-item__input input {
	background-color: #fff;
	width: 100%;
	padding: 0.8rem;
	border-radius: 0.4rem;
	font-size: 1.6rem;
	font-weight: 700;
}

@media print,
only screen and (min-width: 768px) {
	.contact-item__input input {
		padding: 0.8rem 1.6rem;
	}
}

.contact-item__input input::-webkit-input-placeholder {
	color: #e0e0e0;
}

.contact-item__input input:-ms-input-placeholder {
	color: #e0e0e0;
}

.contact-item__input input::placeholder {
	color: #e0e0e0;
}

.contact-item__input textarea {
	background-color: #fff;
	width: 100%;
	padding: 0.8rem;
	border-radius: 0.4rem;
	font-size: 1.6rem;
	font-weight: 700;
	resize: none;
	min-height: 18rem;
}

@media print,
only screen and (min-width: 768px) {
	.contact-item__input textarea {
		padding: 0.8rem 1.6rem;
	}
}

.contact-row-item__half {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
}

.contact-form__text {
	padding: 3.2rem 1.6rem 2.4rem;
	font-size: 1.4rem;
	line-height: 1.7;
}

@media print,
only screen and (min-width: 768px) {
	.contact-form__text {
		padding: 2.2rem 0 2.4rem;
		max-width: 67rem;
		margin: 0 auto;
	}
}

.contact-form__check label {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 0.4rem;
}

.contact-form__check span {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 0.4rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-weight: 700;
	font-size: 1.6rem;
}

.contact-form__check span:after {
	content: "必須";
	display: block;
	color: #fff;
	background-color: #345bfb;
	border-radius: 100vmax;
	padding: 0 0.7rem;
	line-height: 1.6;
}

.contact-form__check input[type="checkbox"] {
	position: relative;
	width: 1.4rem;
	height: 1.4rem;
	border: 1px solid #000;
	-webkit-appearance: none;
	appearance: none;
	-webkit-transform: translateY(-0.1rem);
	-ms-transform: translateY(-0.1rem);
	transform: translateY(-0.1rem);
}

@media print,
only screen and (min-width: 768px) {
	.contact-form__check input[type="checkbox"] {
		-webkit-transform: translateY(-0.2rem);
		-ms-transform: translateY(-0.2rem);
		transform: translateY(-0.2rem);
	}
}

.contact-form__check input[type="checkbox"]:checked {
	background-color: #345bfb;
	border: 1px solid #345bfb;
}

.contact-form__check input[type="checkbox"]:checked:before {
	position: absolute;
	inset: 0;
	background-image: url(../../assets/img/icon-check.png);
	background-size: 120% auto;
	background-position: center bottom;
	content: "";
}

.contact-form__button {
	-webkit-appearance: none;
	appearance: none;
	display: block;
	width: 100%;
	margin: 1.2rem auto 0;
	max-width: 26.5rem;
	text-align: center;
	color: #fff;
	padding: 1.3rem;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: 700;
	border-radius: 0.4rem;
	box-shadow: 1px 2px 4px 0 rgba(0, 0, 0, 0.25);
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
	background-color: #777;
	pointer-events: none;
}

@media print,
only screen and (min-width: 768px) {
	.contact-form__button:hover {
		box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
	}
}

.contact-form__button.is-active {
	background-color: #345bfb;
	pointer-events: initial;
}

.thanks-message {
	font-size: 1.6rem;
	font-weight: 700;
	color: #345bfb;
	text-align: center;
	margin-top: 1.8rem;
	display: none;
}

@media print,
only screen and (min-width: 768px) {
	.thanks-message {
		font-size: 2.4rem;
		margin-top: 2.4rem;
	}
}

.information {
	background: -webkit-linear-gradient(350deg, #edfdfc 0, #d0dfff 100%);
	background: linear-gradient(100deg, #edfdfc 0, #d0dfff 100%);
	padding: 4rem 1.6rem;
}

@media print,
only screen and (min-width: 768px) {
	.information {
		padding: 7.2rem 1.6rem 6.4rem;
	}
}

.information-contents {
	max-width: 120rem;
	margin: 0 auto;
}

@media print,
only screen and (min-width: 768px) {
	.information-contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 4rem;
	}
}

.information-banner {
	margin-bottom: 4rem;
	line-height: 0;
}

@media print,
only screen and (min-width: 768px) {
	.information-banner {
		margin-bottom: 0;
		max-width: 83rem;
	}
}

.information-form {
	border-radius: 1.6rem;
	background-color: #fff;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

@media print,
only screen and (min-width: 768px) {
	.information-form {
		max-width: 33rem;
	}
}

.information-form__title {
	border-radius: 1.6rem 1.6rem 0 0;
	background: -webkit-linear-gradient(352deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	background: linear-gradient(98deg, rgba(22, 198, 119, 0.8) -3.84%, rgba(52, 91, 251, 0.8) 98.02%);
	color: #fff;
	padding: 0.8rem;
	text-align: center;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 2;
}

.information-form-inner {
	padding: 2.4rem 2.4rem 4rem;
}

@media print,
only screen and (min-width: 768px) {
	.information-form-inner {
		padding: 2.4rem 1.6rem 4rem;
	}
}

@media print,
only screen and (min-width: 768px) {
	.information-form-inner .contact-row-item {
		margin-bottom: 1.6rem;
	}
}

.information-form-inner .contact-item__input input {
	border: 1px solid #345bfb;
}

.information-form-inner .contact-form__text {
	padding: 2.4rem 0;
}

.hidden {
	display: none !important;
}

@media only screen and (max-width: 767px) {
	.sm\:hidden {
		display: none !important;
	}
}

@media print,
only screen and (min-width: 768px) {
	.md\:hidden {
		display: none !important;
	}
}

.bg-none {
	background: none;
}

.br-none br {
	display: none;
}

@media only screen and (max-width: 767px) {
	.sm\:br-none br {
		display: none;
	}
}

@media print,
only screen and (min-width: 768px) {
	.md\:br-none br {
		display: none;
	}
}

/* Footer company info - Updated */
.footer-company {
	text-align: center;
	padding: 2rem 0;
	margin-top: 2rem;
	width: 100%;
}

.footer-company p a {
	text-decoration: underline;
}

@media print,
only screen and (min-width: 768px) {
	.site-footer {
		flex-wrap: wrap;
	}

	.footer-company {
		position: absolute;
		bottom: 3rem;
		left: 0;
		right: 0;
		padding: 2.5rem 0;
		margin-top: 0;
	}

	.footer-company p {
		font-size: 1.3rem;
	}

	.footer-company p a {
		text-decoration: underline;
	}
}

/* Legal Document Styling for Terms of Service */
.legal-document {
	padding: 4rem 2rem;
	background-color: #f8f9fa;
	min-height: calc(100vh - 13rem);
}

@media print,
only screen and (min-width: 768px) {
	.legal-document {
		padding: 6rem 2rem;
	}
}

.legal-document-contents {
	background-color: #fff;
	border-radius: 0.8rem;
	padding: 3rem 2rem;
}

@media print,
only screen and (min-width: 768px) {
	.legal-document-contents {
		padding: 5rem 6rem;
	}
}

.legal-document__title {
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 3rem;
	color: #333;
	text-align: center;
	padding-bottom: 1.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.legal-document__title {
		font-size: 3.2rem;
		margin-bottom: 4rem;
	}
}

.legal-document__body {
	font-size: 1.4rem;
	line-height: 1.8;
	color: #444;
}

@media print,
only screen and (min-width: 768px) {
	.legal-document__body {
		font-size: 1.6rem;
		line-height: 2;
	}
}

.legal-document__body h2 {
	font-size: 1.8rem;
	font-weight: 700;
	margin: 3rem 0 1.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.legal-document__body h2 {
		font-size: 2rem;
		margin: 4rem 0 2rem;
	}
}

.legal-document__body p {
	margin-bottom: 1.5rem;
}

.legal-document__body ol,
.legal-document__body ul {
	margin: 1.5rem 0;
	padding-left: 2rem;
}

.legal-document__body li {
	margin-bottom: 0.8rem;
	list-style-type: decimal;
}

.legal-document__body ul li {
	list-style-type: disc;
}

.legal-document__date {
	font-size: 1.2rem;
	color: #666;
	text-align: center;
	margin-bottom: 2.5rem;
}

@media print,
only screen and (min-width: 768px) {
	.legal-document__date {
		font-size: 1.4rem;
		margin-bottom: 3rem;
	}
}

.legal-table {
	width: 100%;
	margin: 2rem 0;
	border-collapse: collapse;
	border: 1px solid #ddd;
}

.legal-table thead {
	background-color: #f5f5f5;
}

.legal-table th,
.legal-table td {
	padding: 1rem;
	text-align: left;
	border: 1px solid #ddd;
	font-size: 1.4rem;
	line-height: 1.6;
}

.legal-table th {
	font-weight: 700;
	background-color: #f5f5f5;
}

.legal-table tbody tr:hover {
	background-color: #fafafa;
}

@media (max-width: 767px) {
	.legal-table {
		font-size: 1.2rem;
		margin: 1.5rem 0;
	}

	.legal-table th,
	.legal-table td {
		padding: 0.8rem;
		font-size: 1.2rem;
	}
}
