.fre.story {
	position: relative;
	overflow: hidden;
	text-align: center;
	padding: 4rem 0;
	min-height: 31.125rem;
}

@media screen and (min-width: 991px) {

	.fre.story {
		padding: 5.625rem 0;
		min-height: 46.625rem;
	}
}

.fre.story .story__bg {
	max-width: 90rem;
	pointer-events: none;
	position: absolute;
	z-index: 0;
	right: 0.125rem;
	bottom: 0.125rem;
	width: 191%;
}

@media screen and (min-width: 768px) {

	.fre.story .story__bg {
		width: 100%;
		right: 50%;
		transform: translateX(50%);
		bottom: 0;
	}
}

.fre.story .story__bg img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.fre.story article,
.fre.story .l-btn {
	position: relative;
	z-index: 1;
}

.fre.story article {
	max-width: 45.8125rem;
	margin: 0 auto 2.5rem;
}

@media screen and (min-width: 991px) {

	.fre.story article {
		margin: 0 auto 5rem;
	}
}

.fre.story article .h2 {
	margin-bottom: 1rem;
}

@media screen and (min-width: 991px) {

	.fre.story article .h2 {
		margin-bottom: 2rem;
	}
}

.fre.story article p,
.fre.story article li {
	font-size: 1.25rem;
	line-height: 1.3;
	font-weight: 500;
	font-family: "Kanit", sans-serif;
}

@media screen and (min-width: 991px) {

	.fre.story article p,
	.fre.story article li {
		font-size: 1.875rem;
	}
}

@media screen and (min-width: 991px) {

	.fre.story a.l-btn {
		padding: 0.5rem 3.625rem;
		font-size: 1.75rem;
		line-height: 1.5;
		border-radius: 0.75rem;
	}
}

.fre.analysis {
	padding: 4rem 0 2rem;
}

@media screen and (min-width: 991px) {

	.fre.analysis {
		padding: 5.625rem 0 6.5rem;
	}
}

.fre.analysis .h3 {
	text-align: center;
	margin-bottom: 2rem;
	max-width: 62.125rem;
	margin: 0 auto 2rem;
}

@media screen and (min-width: 991px) {

	.fre.analysis .h3 {
		font-size: 4.6875rem;
		line-height: 1;
		font-weight: 200;
		margin: 0 auto 3rem;
	}
}

.fre.analysis .analysis__layer {
	position: relative;
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer .analysis__layer__graphic {
		position: absolute;
		top: 0;
		left: 21%;
		aspect-ratio: 684 / 784;
		width: calc(684/1200 * 100%);
	}
}

.fre.analysis .analysis__layer .analysis__layer__graphic picture {
	aspect-ratio: 306 / 208;
	display: block;
	max-width: 19.0625rem;
	margin: 0 auto 2rem;
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer .analysis__layer__graphic picture {
		display: none;
	}
}

.fre.analysis .analysis__layer .analysis__layer__graphic picture img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fre.analysis .analysis__layer .analysis__layer__graphic .analysis__lottie {
	display: none;
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer .analysis__layer__graphic .analysis__lottie {
		display: block;
	}
}

.fre.analysis .analysis__layer .analysis__layer__graphic .analysis__lottie svg {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

@media screen and (min-width: 768px) {

	.fre.analysis .analysis__layer ul {
		display: flex;
	}
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer ul {
		display: grid;
		grid-template-columns: calc(224/1200 * 100%) calc(244/1200 * 100%);
		justify-content: space-between;
		margin-bottom: 7.5rem;
		padding-top: 3.625rem;
		row-gap: 6rem;
	}
}

@media screen and (min-width: 768px) {

	.fre.analysis .analysis__layer ul li {
		width: 33.33%;
	}
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer ul li {
		width: unset;
	}
}

.fre.analysis .analysis__layer ul li:not(:last-of-type) {
	margin-bottom: 1.875rem;
}

@media screen and (min-width: 768px) {

	.fre.analysis .analysis__layer ul li:not(:last-of-type) {
		margin-bottom: 0;
		margin-right: 1.875rem;
	}
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer ul li:not(:last-of-type) {
		margin-right: 0;
	}
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer ul li:nth-child(2) {
		grid-row: 1/3;
		grid-column: 2/3;
		padding-top: 5.3125rem;
	}
}

.fre.analysis .analysis__layer ul li .h5 {
	margin-bottom: 0.5rem;
	padding-bottom: 0.375rem;
	border-bottom: 0.125rem solid #1fe186;
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer ul li .h5 {
		border: none;
		padding: 0;
	}
}

.fre.analysis .analysis__layer ul li p,
.fre.analysis .analysis__layer ul li li {
	font-size: 0.9375rem;
	line-height: 1.3;
}

@media screen and (min-width: 991px) {

	.fre.analysis .analysis__layer ul li p,
	.fre.analysis .analysis__layer ul li li {
		font-size: 1.125rem;
	}
}

.fre.analysis .analysis__layer a.l-btn {
	display: none;
}

@media screen and (min-width: 1199px) {

	.fre.analysis .analysis__layer a.l-btn {
		display: inline-block;
		padding: 0.5rem 3.625rem;
		font-size: 1.75rem;
		line-height: 1.5;
		border-radius: 0.75rem;
	}
}

.fre.declaration {
	position: relative;
	padding: 2rem 0 2.0625rem;
}

@media screen and (min-width: 1199px) {

	.fre.declaration {
		min-height: 50rem;
		padding: 5.625rem 0 5rem;
	}
}

.fre.declaration picture.declaration__mobile {
	display: block;
	margin-left: -1.5rem;
	aspect-ratio: 270 / 82;
	max-width: 16.875rem;
	margin-bottom: 2.0625rem;
}

@media screen and (min-width: 1199px) {

	.fre.declaration picture.declaration__mobile {
		display: none;
	}
}

.fre.declaration picture.declaration__mobile img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fre.declaration picture.declaration__desktop {
	display: none;
}

@media screen and (min-width: 1199px) {

	.fre.declaration picture.declaration__desktop {
		position: absolute;
		z-index: 0;
		right: -17.875rem;
		top: 6.5625rem;
		display: block;
		aspect-ratio: 994 / 598;
	}
}

@media screen and (min-width: 1199px) {

	.fre.declaration picture.declaration__desktop img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}

.fre.declaration article {
	position: relative;
	z-index: 1;
}

@media screen and (min-width: 1199px) {

	.fre.declaration article {
		width: calc(582/1200 * 100%);
	}
}

.fre.declaration article .h2 {
	margin-bottom: 1rem;
}

@media screen and (min-width: 991px) {

	.fre.declaration article .h2 {
		margin-bottom: 2rem;
	}
}

.fre.declaration article p,
.fre.declaration article li {
	font-size: 0.9375rem;
	line-height: 1.3;
}

@media screen and (min-width: 991px) {

	.fre.declaration article p,
	.fre.declaration article li {
		font-size: 1.5rem;
	}
}

@media screen and (min-width: 1199px) {

	.fre.result + .result {
		margin-top: -0.9375rem;
	}
}

@media screen and (min-width: 1199px) {

	.fre.result {
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
}

@media screen and (min-width: 1199px) {

	.fre.result.result--flip {
		flex-direction: row-reverse;
	}

	.fre.result.result--flip picture {
		transform: translateX(-120px);
	}

	.fre.result.result--flip article {
		padding-right: 1%;
	}
}

.fre.result:not(:last-of-type) {
	margin-bottom: 1.5rem;
}

@media screen and (min-width: 1199px) {

	.fre.result:not(:last-of-type) {
		margin-bottom: 0;
	}
}

.fre.result picture {
	display: none;
}

@media screen and (min-width: 1199px) {

	.fre.result picture {
		display: block;
		aspect-ratio: 575 / 581;
		flex-basis: calc(575/1200 * 100%);
		transform: translateX(120px);
	}
}

.fre.result article {
	padding-right: 0.125rem;
}

@media screen and (min-width: 1199px) {

	.fre.result article {
		flex-basis: calc(582/1200 * 100%);
		padding: 4rem 0;
	}
}

.fre.result article .h3 {
	margin-bottom: 1rem;
}

@media screen and (min-width: 991px) {

	.fre.result article .h3 {
		margin-bottom: 1.5rem;
	}
}

.fre.result article p,
.fre.result article li {
	font-size: 0.9375rem;
	line-height: 1.3;
}

@media screen and (min-width: 991px) {

	.fre.result article p,
	.fre.result article li {
		font-size: 1.5rem;
	}
}

.fre.result article ul,
.fre.result article ol {
	padding-left: 1.375rem;
}

@media screen and (min-width: 991px) {

	.fre.result article ul,
	.fre.result article ol {
		padding-left: 2.1875rem;
	}
}

.fre.result article ul li,
.fre.result article ol li {
	list-style: disc;
}

.fre.result article ul li:not(:last-of-type),
.fre.result article ol li:not(:last-of-type) {
	margin-bottom: 0.3125rem;
}

.fre.result article ul li::marker,
.fre.result article ol li::marker {
	display: block;
	font-size: 0.5rem;
}

@media screen and (min-width: 991px) {

	.fre.result article ul li::marker,
	.fre.result article ol li::marker {
		font-size: 1rem;
	}
}
