@charset "UTF-8";

/* base */

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}

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

html {
	font-size: calc(0.4375rem + (1vw - 3.75px) * 1.8182);
}

body {
	font-family: "Kiwi Maru", sans-serif;
	font-weight: 500;
	background: #F5F3E9;
	color: #000;
	word-wrap: break-word;
}

a {
	color: inherit;
}

img {
	max-width: 100%;
	height: auto;
}

input,
textarea,
select,
button {
	font: inherit;
	color: inherit;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
}

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

button {
	cursor: pointer;
}

/* for development */

pre {
	padding: 15px;
	background: #eee;
	font-size: 1.2rem;
	line-height: 1.2;
}

/* Tools */

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

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

.display-block {
	display: block;
}

.hidden {
	display: none !important;
	visibility: hidden;
}

.clearfix::before,
.clearfix::after {
	content: "";
	display: table;
}

.clearfix::after {
	clear: both;
}

.clear {
	clear: both;
}

/* show only  SP/PC
-------------------------------*/

.sp-only {
	display: none !important;
}

.sp-only-2 {
	display: none !important;
}

.pc-only {
	display: block !important;
}

.pc-only-2 {
	display: inline-block !important;
}

/* font
-------------------------------*/

.bold {
	font-weight: bold;
}

/* margin
-------------------------------*/

/* padding
-------------------------------*/

/* Layout */

.l-body {
	width: 100%;
	position: relative;
}

.l-body.is-fixed {
	position: fixed;
}

.l-main {
	background: #FFF;
	border-radius: 1.7rem 1.7rem 0 0;
}

.l-fixed-btn-area {
	position: relative;
}

.l-sub-1 {
	display: none;
}

.l-sub-2 {
	display: none;
}

.l-wrapper {
	position: relative;
	width: 79.6%;
	margin-left: auto;
	margin-right: auto;
}

/* Module */

.noscript {
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
	padding: 1em;
	border: 3px solid red;
}

.noscript span {
	color: red;
}

.mainvisual {
	background: -webkit-gradient(linear, left top, right top, from(#E8C5C5), color-stop(31.3%, #E8C5C5), color-stop(68.7%, #9EC1D0), to(#9EC1D0));
	background: linear-gradient(to right, #E8C5C5 0%, #E8C5C5 31.3%, #9EC1D0 68.7%, #9EC1D0 100%);
	height: 100vh;
	height: 100svh;
	padding: 4rem 0 8.8rem;
	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;
	position: relative;
}

.mainvisual__title {
	width: 82%;
	height: 42.509941%;
	margin: 1rem auto 4.5rem;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
	opacity: 0;
	-webkit-transform: translateY(40px) scale(0.6);
	-ms-transform: translateY(40px) scale(0.6);
	transform: translateY(40px) scale(0.6);
}

.mainvisual__title img {
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
}

.mainvisual__title.is-visible {
	opacity: 1;
	-webkit-transform: translateY(0) scale(1);
	-ms-transform: translateY(0) scale(1);
	transform: translateY(0) scale(1);
	-webkit-transition: opacity 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38), -webkit-transform 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38);
	transition: opacity 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38), -webkit-transform 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38);
	transition: opacity 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38), transform 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38);
	transition: opacity 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38), transform 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38), -webkit-transform 0.5s cubic-bezier(0.77, 0.39, 0.56, 1.38);
}

.mainvisual__links {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 42.752407%;
}

.mainvisual__links__item {
	width: 50%;
	opacity: 0;
	-webkit-transform: translateY(40px) scale(0.6);
	-ms-transform: translateY(40px) scale(0.6);
	transform: translateY(40px) scale(0.6);
}

.mainvisual__links__item.is-visible {
	opacity: 1;
	-webkit-transform: translateY(0) scale(1);
	-ms-transform: translateY(0) scale(1);
	transform: translateY(0) scale(1);
	-webkit-transition: opacity 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18), -webkit-transform 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18);
	transition: opacity 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18), -webkit-transform 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18);
	transition: opacity 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18), transform 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18);
	transition: opacity 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18), transform 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18), -webkit-transform 0.35s cubic-bezier(0.55, 1.16, 0.82, 1.18);
}

.mainvisual__links__item img {
	display: block;
	margin-left: auto;
	margin-right: auto;
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
	height: 100%;
}

.fixed-btn-wrap {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10000;
	pointer-events: none;
}

.fixed-btn {
	display: block;
	z-index: 1000;
	text-decoration: none;
	background: #000;
	color: #ffffff;
	text-align: center;
	padding: 2.2rem 0;
	width: 100%;
	font-size: 2.4rem;
	border-radius: 0.68rem 0.68rem 0 0;
	pointer-events: auto;
	position: absolute;
	bottom: 0;
	left: 0;
	-webkit-transition: opacity 0.4s;
	transition: opacity 0.4s;
}

.fixed-btn span::after {
	content: "";
	width: 1.9rem;
	height: 1.2rem;
	display: inline-block;
	background: url(../img/arrow_white.svg) no-repeat center/contain;
	margin-left: 1.2rem;
	vertical-align: middle;
}

.fixed-btn.is-hide {
	opacity: 0;
	visibility: hidden;
}

.about {
	position: relative;
	padding: 9rem 0 18rem;
}

.about::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: calc(100% + 82.7rem);
	display: block;
	background: linear-gradient(153.7858deg, #ffffff 7.2%, #e8ded8);
}

.about__logo {
	width: 78%;
	margin: 0 auto 5.8rem;
}

.about__logo img {
	-webkit-transform: translateX(1.6%);
	-ms-transform: translateX(1.6%);
	transform: translateX(1.6%);
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.about__heading {
	position: relative;
	font-size: 3.5rem;
	letter-spacing: 0.075em;
	text-align: center;
}

.about__heading span {
	display: inline-block;
	background: -webkit-gradient(linear, left top, right top, from(#E8C5C5), to(#9EC1D0));
	background: linear-gradient(to right, #E8C5C5, #9EC1D0);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.about__image {
	position: relative;
	width: 79.6%;
	margin: 10rem auto 5.5rem;
}

.about__image::before {
	position: absolute;
	top: -3rem;
	right: -2rem;
	content: "";
	width: 19.6rem;
	height: 9.8rem;
	display: block;
	background: url(../img/deco_about_01.svg) no-repeat center/contain;
}

.about__text {
	position: relative;
	font-size: 1.8rem;
	letter-spacing: 0.075em;
	line-height: 2.42;
	text-align: center;
}

.about__text__frame {
	display: inline-block;
	border: 0.2rem solid #000;
	border-radius: 0.5rem;
	background: #FFF;
	line-height: 1.7;
	padding: 0 0.3em 0 0.4em;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	margin: 0 0.3em 0 0;
}

.about__text__pink {
	color: #E8C5C5;
	padding: 0 0.3em;
}

.about__text__blue {
	color: #9EC1D0;
}

.about__gallery {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 6.2rem 0 -4.3rem;
}

.about__gallery__item {
	width: 53%;
	margin-bottom: 4.3rem;
}

.about__gallery__item:nth-child(odd) {
	margin-top: 7.2rem;
	margin-right: -6%;
}

.about__gallery__item--deco-1 {
	position: relative;
}

.about__gallery__item--deco-1::before {
	position: absolute;
	bottom: calc(100% - 1.6rem);
	left: 1.8rem;
	content: "";
	width: 16.7rem;
	height: 8.5rem;
	display: block;
	background: url(../img/deco_about_02.svg) no-repeat center/contain;
}

.about__gallery__item--deco-2 {
	position: relative;
}

.about__gallery__item--deco-2::before {
	position: absolute;
	bottom: calc(100% - 3.5rem);
	right: 3.5rem;
	content: "";
	width: 19.6rem;
	height: 9.8rem;
	display: block;
	background: url(../img/deco_about_01.svg) no-repeat center/contain;
}

.team {
	position: relative;
	background: #f5f3e9;
}

.team::before {
	position: absolute;
	bottom: 100%;
	left: 0;
	content: "";
	width: 100%;
	height: 9.5rem;
	display: block;
	background: -webkit-gradient(linear, left top, right bottom, color-stop(50%, transparent), color-stop(50%, #f5f3e9));
	background: linear-gradient(to right bottom, transparent 50%, #f5f3e9 50%);
}

.team__inner {
	padding: 5.6rem 0 17.9rem;
}

.team__inner::before {
	position: absolute;
	bottom: 8.3rem;
	left: 0;
	content: "";
	width: 37.9rem;
	height: 6.9rem;
	display: block;
	background: url(../img/deco_team.svg) no-repeat center/contain;
}

.team__heading {
	position: absolute;
	bottom: calc(100% - 1.5rem);
	left: 0;
	width: 35.6rem;
}

.team__heading img {
	width: 100%;
}

.voice {
	position: relative;
	padding: 0 0 13rem;
}

.voice__inner {
	width: 79.6%;
	margin-left: auto;
	margin-right: auto;
}

.voice__heading {
	position: absolute;
	top: 0.5%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	text-align: center;
	z-index: 10;
	width: 23.7rem;
}

.voice__heading img {
	width: 100%;
}

.create {
	position: relative;
	padding: 9.7rem 0 10.4rem;
}

.create::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: calc(100% + 72rem);
	display: block;
	background: linear-gradient(170.797deg, #E8C5C5 67%, #9EC1D0 79%);
}

.create__heading {
	position: relative;
	width: 30rem;
	margin-bottom: 15rem;
}

.create__heading::before {
	position: absolute;
	top: 4.2rem;
	left: 1rem;
	content: "";
	width: 41.6rem;
	height: 22.2rem;
	display: block;
	background: url(../img/deco_learn_01.svg) no-repeat center/contain;
}

.create__heading img {
	width: 100%;
}

.create__smartphone {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 36vw;
	margin: 4rem 0 9.5rem;
}

.create__smartphone__item {
	position: relative;
	padding: 2.6rem 0 0;
}

.create__smartphone__image {
	position: relative;
	padding: 0.8rem 0 0.5rem;
	height: 100%;
}

.create__smartphone__image::before {
	content: "";
	display: block;
	width: 100%;
	padding-top: 208.7%;
}

.create__smartphone__image img {
	position: absolute;
	bottom: 0.5rem;
	left: 0;
	width: 100%;
	height: calc(100% - 1.3rem);
	-o-object-fit: cover;
	object-fit: cover;
}

.create__smartphone__image::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 106.2%;
	height: 100.5%;
	display: block;
	background: url(../img/frame_smartphone.png) no-repeat center/contain;
}

.create__smartphone__label {
	position: absolute;
	top: 0;
	left: -3.6%;
	width: 30.8%;
}

.create__smartphone__label img {
	width: 100%;
}

.create__smartphone .swiper-button-prev.swiper-button-disabled {
	opacity: 0;
}

.create__smartphone .swiper-button-next.swiper-button-disabled {
	opacity: 0;
}

.create__smartphone .swiper-button-prev,
.create__smartphone .swiper-button-next {
	top: 51%;
	width: 3rem;
	height: 3rem;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	margin: 0;
}

.create__smartphone .swiper-button-prev::after,
.create__smartphone .swiper-button-next::after {
	content: "";
	width: 100%;
	height: 100%;
	background: url(../img/arrow_swiper.svg) no-repeat center/contain;
}

.create__smartphone .swiper-button-prev {
	left: auto;
	right: calc(50% + 12.7rem);
}

.create__smartphone .swiper-button-next {
	right: auto;
	left: calc(50% + 12.7rem);
}

.create__smartphone .swiper-button-next::after {
	-webkit-transform: scale(-1);
	-ms-transform: scale(-1);
	transform: scale(-1);
}

.create__desktop {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 36vw;
	margin: 5.7rem 0;
}

.create__desktop__item {
	position: relative;
}

.create__desktop__label {
	position: absolute;
	top: 0;
	left: -2.8%;
	width: 20.7%;
}

.create__desktop__label img {
	width: 100%;
}

.create__desktop__image {
	position: relative;
	padding: 3.8rem 0 2.5rem;
}

.create__desktop__image::before {
	position: absolute;
	bottom: -3rem;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 158.6%;
	height: 112.7%;
	display: block;
	background: url(../img/frame_desktop.png) no-repeat center/contain;
}

.create__desktop__image::after {
	content: "";
	width: 100%;
	display: block;
	padding-top: 62.8%;
}

.create__desktop__image img {
	position: absolute;
	bottom: 2.5rem;
	left: 0;
	width: 100%;
	height: calc(100% - 6.3rem);
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
}

.create__desktop .swiper-button-prev.swiper-button-disabled {
	opacity: 0;
}

.create__desktop .swiper-button-next.swiper-button-disabled {
	opacity: 0;
}

.create__desktop .swiper-button-prev,
.create__desktop .swiper-button-next {
	top: 51%;
	width: 3rem;
	height: 3rem;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	margin: 0;
}

.create__desktop .swiper-button-prev::after,
.create__desktop .swiper-button-next::after {
	content: "";
	width: 100%;
	height: 100%;
	background: url(../img/arrow_swiper.svg) no-repeat center/contain;
}

.create__desktop .swiper-button-prev {
	left: auto;
	right: calc(50% + 18.5rem);
}

.create__desktop .swiper-button-next {
	right: auto;
	left: calc(50% + 18.5rem);
}

.create__desktop .swiper-button-next::after {
	-webkit-transform: scale(-1);
	-ms-transform: scale(-1);
	transform: scale(-1);
}

.learn {
	position: relative;
	padding: 13.3rem 0 21rem;
}

.learn::before {
	position: absolute;
	bottom: 1.6rem;
	right: 2rem;
	content: "";
	width: 19.6rem;
	height: 9.8rem;
	display: block;
	background: url(../img/deco_white.svg) no-repeat center/contain;
	z-index: 1;
}

.learn__heading {
	position: relative;
	width: 32.5rem;
	margin-left: auto;
	margin-right: 0;
	-webkit-transform: translateX(1rem);
	-ms-transform: translateX(1rem);
	transform: translateX(1rem);
	margin-bottom: 12.5rem;
}

.learn__heading::before {
	position: absolute;
	top: 5rem;
	right: 0.8rem;
	content: "";
	width: 41.6rem;
	height: 22.2rem;
	display: block;
	background: url(../img/deco_learn_02.svg) no-repeat center/contain;
}

.learn__heading img {
	width: 100%;
}

.learn__movie {
	margin: 4.2rem 0 5.3rem;
}

.learn__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	border-top: 0.2rem solid #000;
	border-left: 0.2rem solid #000;
	margin-top: 10.2rem;
}

.learn__item {
	position: relative;
	width: 50%;
	border-right: 0.2rem solid #000;
	border-bottom: 0.2rem solid #000;
	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;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: 2.4rem 0 2.4rem;
}

.learn__item__num {
	position: absolute;
	top: -0.2rem;
	left: -0.2rem;
	width: 5.3rem;
}

.learn__item__num img {
	display: block;
	width: 100%;
}

.learn__item__heading {
	font-size: 1.8rem;
	line-height: 1.33;
	text-align: center;
	color: #ffffff;
	margin-bottom: 0.3rem;
	min-height: 2.66em;
	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;
}

.learn__item__image {
	width: 70%;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.plan {
	position: relative;
	padding: 16.5rem 0;
	margin-top: -9.5rem;
}

.plan__heading {
	width: 37rem;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 4.5rem;
}

.plan__heading img {
	width: 100%;
}

.plan__item {
	border: 0.2rem solid #000;
	border-radius: 1rem;
	overflow: hidden;
}

.plan__item:not(:last-child) {
	margin-bottom: 5rem;
}

.plan__item__heading {
	background: #e8ded8;
	font-size: 3.1rem;
	line-height: 1.42;
	text-align: center;
	padding: 1.4rem 0;
	border-bottom: 0.2rem solid #000;
}

.plan__item__content {
	background: #ffffff;
}

.plan__price-1 {
	font-size: 2.8rem;
	padding: 1.5rem 0 2.3rem;
	text-align: center;
}

.plan__price-1__sm {
	display: block;
	font-size: 1.6rem;
}

.plan__price-1__lg {
	font-size: 4.811rem;
}

.plan__price-1--pd-lg {
	padding: 2.5rem 0 3rem;
}

.plan__price-2 {
	font-size: 2.8rem;
	padding: 1.7rem 0 1.7rem 2rem;
}

.plan__price-2:not(:last-child) {
	border-bottom: 0.2rem solid #000;
}

.plan__price-2__sm {
	font-size: 1.8rem;
}

.plan__price-2__lg {
	font-size: 3.6rem;
}

.flow {
	background: linear-gradient(159.007deg, #e8ded8 44.9%, #ffffff 93.4%);
	margin-top: -11rem;
	padding: 10.4rem 0 13rem;
	-webkit-clip-path: polygon(0 10.4rem, 100% 0%, 100% 100%, 0% 100%);
	clip-path: polygon(0 10.4rem, 100% 0%, 100% 100%, 0% 100%);
}

.flow__heading {
	position: relative;
	width: 25.9rem;
	margin-left: auto;
	margin-right: auto;
}

.flow__heading::before {
	position: absolute;
	top: calc(100% - 1.8rem);
	left: 47%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 39.4rem;
	height: 7.5rem;
	display: block;
	background: url(../img/deco_team.svg) no-repeat center/contain;
}

.flow__heading img {
	width: 100%;
}

.flow__list {
	margin-top: 8.5rem;
}

.flow__item {
	position: relative;
	border: 0.2rem solid #000;
	border-radius: 1rem;
	background: #fff;
}

.flow__item:not(:last-child) {
	margin-bottom: 6.8rem;
}

.flow__item:not(:last-child)::after {
	position: absolute;
	content: "";
	left: 4rem;
	bottom: -4rem;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0.99507rem 0.91082rem 0 0.91082rem;
	border-color: #000000 transparent transparent transparent;
}

.flow__head {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border-bottom: 0.2rem solid #000;
	background: linear-gradient(280deg, transparent 76%, #000 24%);
	border-radius: 0.7rem 0 0 0;
}

.flow__head__step {
	width: 25%;
	-ms-flex-negative: 0;
	flex-shrink: 0;
	padding: 1.3rem 0.6rem 0.4rem 1.2rem;
}

.flow__head__step img {
	height: 2.5rem;
}

.flow__head__text {
	width: 75%;
	font-size: 2.2rem;
	padding: 1rem 0 1rem 0.5rem;
}

.flow__text {
	font-size: 1.6rem;
	line-height: 1.75;
	padding: 2.5rem 2rem 2.7rem 2.5rem;
	letter-spacing: 0.075em;
	text-align: justify;
}

.faq {
	position: relative;
	background: #ededed;
	padding: 2rem 0 17.5rem;
}

.faq::before {
	position: absolute;
	bottom: 100%;
	left: 0;
	content: "";
	width: 100%;
	height: 9.5rem;
	display: block;
	background: -webkit-gradient(linear, left top, right bottom, color-stop(50%, transparent), color-stop(50%, #ededed));
	background: linear-gradient(to right bottom, transparent 50%, #ededed 50%);
}

.faq::after {
	position: absolute;
	top: -6rem;
	left: 2.5rem;
	content: "";
	width: 16.7rem;
	height: 8.5rem;
	display: block;
	background: url(../img/deco_faq.svg) no-repeat center/contain;
}

.faq__heading {
	width: 14.7rem;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 4rem;
}

.faq__heading img {
	width: 100%;
}

.faq__content {
	position: relative;
}

.faq__content::before {
	position: absolute;
	bottom: -18rem;
	right: -4.5rem;
	content: "";
	width: 19.6rem;
	height: 9.8rem;
	display: block;
	background: url(../img/deco_white.svg) no-repeat center/contain;
	z-index: 1;
}

.faq__item {
	border: 0.2rem solid #000;
	border-radius: 1rem;
	overflow: hidden;
}

.faq__item:not(:last-child) {
	margin-bottom: 2.7rem;
}

.faq__question button {
	border: none;
	margin: 0;
	background: #e0e0e0;
	padding: 2.25rem 2.5rem 2.25rem 1.5rem;
	font-size: 2rem;
	line-height: 1.4;
	text-align: left;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 100%;
	min-height: 8rem;
}

.faq__question__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.faq__question__inner span {
	padding-right: 1.5rem;
}

.faq__answer {
	display: none;
	border-top: 0.2rem solid #000;
	background: #ffffff;
	padding: 1.8rem 2.3rem 2.4rem;
	font-size: 1.6rem;
	letter-spacing: 0.075em;
	line-height: 1.75;
	text-align: justify;
}

.contact {
	background: #e8ded8;
	-webkit-clip-path: polygon(0 9.5rem, 100% 0%, 100% 100%, 0% 100%);
	clip-path: polygon(0 9.5rem, 100% 0%, 100% 100%, 0% 100%);
	padding: 16.6rem 0 4.5rem;
	margin-top: -9.5rem;
}

.contact__heading {
	width: 32.7rem;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 8rem;
}

.contact__heading img {
	width: 100%;
}

.contact__form {
	position: relative;
	background: #f5f3e9;
	border-radius: 1.47rem;
	padding: 6.1rem 4.5rem 5.5rem;
}

.contact__form__heading {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	font-size: 2.2rem;
}

.line-area {
	position: relative;
	display: block;
	background: #ffffff;
	border-radius: 1rem;
	padding: 5.5rem 2.6rem 4.4rem;
	margin-bottom: 15rem;
	text-decoration: none;
}

.line-area__heading {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	font-size: 2.2rem;
}

.line-area__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.line-area__image-wrap {
	position: relative;
	width: 49%;
	margin-right: 9.5%;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.line-area__image {
	position: absolute;
	top: 0;
	left: 0;
}

.line-area__main {
	padding: 1.3rem 0 0;
}

.line-area__qrcode {
	width: 11.3rem;
	margin-bottom: 5.6rem;
}

.line-area__info {
	font-size: 1.1rem;
	line-height: 1.75;
	margin-bottom: 1.8rem;
	text-indent: -0.5em;
	padding-left: 0.2em;
}

.line-area__note {
	font-size: 1.1rem;
	font-weight: 300;
	line-height: 1.45;
	padding-left: 0.2em;
}

.form__item {
	margin-bottom: 2.2rem;
}

.form__label {
	display: block;
	font-size: 1.6rem;
	margin-bottom: 1.2rem;
}

.form__label span {
	font-size: 1.2rem;
	padding-left: 0.5em;
}

.form .input,
.form .textarea {
	border: 0.2rem solid #000;
	border-radius: 1rem;
	background: #ffffff;
	width: 100%;
	height: 4.5rem;
	font-size: 1.6rem;
	padding: 1rem;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.form .input.is-error,
.form .textarea.is-error {
	border-color: red;
}

.form .textarea {
	height: 19.4rem;
	resize: none;
	line-height: 1.5;
}

.form__error-msg {
	display: none;
	color: red;
	padding-top: 1em;
	font-size: 1.4rem;
}

.form__button-wrap {
	margin-top: 3.7rem;
}

.form__announce {
	display: none;
	color: red;
	text-align: center;
	margin-bottom: 1em;
	font-size: 1.4rem;
}

.form__button {
	background: #000;
	border: none;
	width: 100%;
	height: 4.8rem;
	color: #ffffff;
	font-size: 1.5rem;
	border-radius: 1rem;
	cursor: pointer;
}

.form__button:focus-visible {
	outline: auto;
}

.form__button[disabled] {
	opacity: 0.3;
	color: rgba(255, 255, 255, 0.4);
	cursor: auto;
}

.copyright {
	text-align: center;
}

.footer {
	background: #e8ded8;
	padding: 5.7rem 0;
	margin-top: -0.1rem;
}

.top-contact {
	border: 0.2rem solid #000;
	border-radius: 1.4rem;
	padding: 1.7rem 10.9% 2.4rem;
	margin-bottom: 2rem;
}

.top-contact__heading {
	font-size: 2rem;
	text-align: center;
	margin-bottom: 1.2rem;
}

.top-contact .form__item {
	margin-bottom: 1.8rem;
}

.top-contact .form__label {
	margin-bottom: 0.8rem;
}

.top-contact .form .input {
	height: 4rem;
}

.top-contact .form .textarea {
	height: 18rem;
}

.top-contact .form__button-wrap {
	margin-top: 2rem;
}

.top-contact .form__button {
	height: 4rem;
}

.top-movie {
	position: relative;
	border: 0.2rem solid #000;
	border-radius: 1.4rem;
	padding-top: 52.5%;
	overflow: hidden;
}

.top-movie::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: rgba(0, 0, 0, 0.2);
	z-index: 1;
}

.top-movie::after {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	content: "";
	width: 6.2rem;
	height: 6.2rem;
	display: block;
	background: url(../img/icon_play.svg) no-repeat center/contain;
	z-index: 1;
}

.top-movie iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.comment-swipe-wrap {
	position: relative;
}

.comment-swipe-wrap .swiper-button-prev.swiper-button-disabled {
	opacity: 0;
}

.comment-swipe-wrap .swiper-button-next.swiper-button-disabled {
	opacity: 0;
}

.comment-swipe-wrap .swiper-button-prev,
.comment-swipe-wrap .swiper-button-next {
	top: 16.5rem;
	width: 3rem;
	height: 3rem;
	margin: 0;
}

.comment-swipe-wrap .swiper-button-prev::after,
.comment-swipe-wrap .swiper-button-next::after {
	content: "";
	width: 100%;
	height: 100%;
	background: url(../img/arrow_swiper.svg) no-repeat center/contain;
}

.comment-swipe-wrap .swiper-button-prev {
	left: 0;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.comment-swipe-wrap .swiper-button-next {
	right: 0;
	-webkit-transform: translate(50%, -50%);
	-ms-transform: translate(50%, -50%);
	transform: translate(50%, -50%);
}

.comment-swipe-wrap .swiper-button-next::after {
	-webkit-transform: scale(-1);
	-ms-transform: scale(-1);
	transform: scale(-1);
}

.comment-swipe__image-wrap {
	position: relative;
	margin-bottom: 3.5rem;
}

.comment-swipe__info-1 {
	position: absolute;
	top: 2.1rem;
	left: 0.3rem;
	font-size: 1.8rem;
}

.comment-swipe__info-2 {
	position: absolute;
	bottom: 0.5rem;
	right: 0.5rem;
	font-size: 2.2rem;
}

.comment-swipe__text {
	font-size: 1.8rem;
	letter-spacing: 0.075em;
	line-height: 1.78;
	text-align: justify;
}

.comment-swipe .swiper-button-prev.swiper-button-disabled {
	opacity: 0;
}

.comment-swipe .swiper-button-next.swiper-button-disabled {
	opacity: 0;
}

.comment-swipe .swiper-button-prev,
.comment-swipe .swiper-button-next {
	top: 10.4vw;
	width: 2.9rem;
	height: 2.9rem;
}

.comment-swipe .swiper-button-prev::after,
.comment-swipe .swiper-button-next::after {
	content: "";
	width: 100%;
	height: 100%;
	background: url(../img/arrow_swiper.svg) no-repeat center/contain;
}

.comment-swipe .swiper-button-prev {
	left: 0;
}

.comment-swipe .swiper-button-next {
	right: 0;
}

.comment-swipe .swiper-button-next::after {
	-webkit-transform: scale(-1);
	-ms-transform: scale(-1);
	transform: scale(-1);
}

.cv-area__heading {
	font-size: 2.4rem;
	text-align: center;
	margin-bottom: 3.7rem;
}

.cv-area__heading::before,
.cv-area__heading::after {
	content: "";
	width: 0.2rem;
	height: 3rem;
	display: inline-block;
	background: #000;
	vertical-align: middle;
}

.cv-area__heading::before {
	-webkit-transform: rotate(-27deg) translateY(-0.4rem);
	-ms-transform: rotate(-27deg) translateY(-0.4rem);
	transform: rotate(-27deg) translateY(-0.4rem);
	margin-right: 1.8rem;
}

.cv-area__heading::after {
	-webkit-transform: rotate(27deg) translateY(-0.4rem);
	-ms-transform: rotate(27deg) translateY(-0.4rem);
	transform: rotate(27deg) translateY(-0.4rem);
	margin-left: 1.8rem;
}

.cv-area__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border: 0.2rem solid #000;
}

.cv-area__item {
	width: 50%;
	background: #e8ded8;
}

.cv-area__item:nth-child(odd) {
	border-right: 0.2rem solid #000;
}

.cv-area__item a {
	text-decoration: none;
	font-size: 2.4rem;
	line-height: 1.125;
	text-align: center;
	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;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: 3rem 0 2.2rem;
	height: 100%;
}

.cv-area__text {
	min-height: 2.25em;
	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;
	margin-bottom: 1rem;
}

.cv-area__icon {
	width: 6.2rem;
}

.bg-blue {
	background: #9EC1D0;
	overflow: hidden;
}

.bg-beige {
	background: linear-gradient(127.347deg, #eee6da, #ffffff);
	-webkit-clip-path: polygon(0 9.5rem, 100% 0%, 100% 100%, 0% 100%);
	clip-path: polygon(0 9.5rem, 100% 0%, 100% 100%, 0% 100%);
}

.text {
	font-size: 1.8rem;
	letter-spacing: 0.075em;
	line-height: 1.78;
	text-align: center;
	color: #ffffff;
}

.feature {
	margin: 6.9rem 0 0;
}

.feature__head {
	border: 0.2rem solid #000;
	border-radius: 1.2rem;
	background: #fff;
}

.feature__head__inner {
	padding: 3.1rem 2.9rem 2.8rem;
}

.feature__heading {
	font-size: 2.4rem;
	letter-spacing: 0.025em;
}

.feature__lead {
	margin-top: 2.5rem;
	font-size: 1.8rem;
	letter-spacing: 0.075em;
	font-weight: 500;
}

.feature__lists {
	margin-top: 1.2rem;
}

.feature__list {
	position: relative;
	font-size: 1.3rem;
	line-height: 1.5;
	padding-left: 1.9rem;
}

.feature__list:not(:last-child) {
	margin-bottom: 0.7rem;
}

.feature__list::before {
	position: absolute;
	content: "";
	background: #969696;
	height: 1.2rem;
	width: 1.2rem;
	left: 0;
	top: 0.4rem;
}

.feature__message {
	position: relative;
	padding: 2.4rem 1.5rem 2rem;
	text-align: center;
}

.feature__message::before {
	position: absolute;
	content: "";
	background-image: -webkit-gradient(linear, left top, right top, from(#000), color-stop(0.3rem, #000), color-stop(0.3rem, transparent), color-stop(0.4rem, transparent));
	background-image: linear-gradient(to right, #000, #000 0.3rem, transparent 0.3rem, transparent 0.4rem);
	background-repeat: repeat-x;
	background-size: 0.6rem 0.2rem;
	background-position: left bottom;
	width: 100%;
	height: 0.2rem;
	left: 0;
	top: 0;
}

.feature__message__regular {
	display: block;
	font-size: 1.7rem;
	letter-spacing: 0.075em;
}

.feature__message__wrap {
	margin-top: 1.4rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.feature__message__large {
	font-size: 3.6rem;
}

.feature__message__pink {
	color: #E8C5C5;
}

.feature__message__blue {
	color: #9EC1D0;
}

.feature__message__small {
	font-size: 1.5rem;
	line-height: 1.2;
}

.feature__2col {
	margin-top: 1rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.feature__item {
	width: 49%;
	border: 0.2rem solid #000;
	border-radius: 1.2rem;
	padding: 2.3rem 1.2rem 1rem;
}

.feature__item--01 {
	background: #E8C5C5;
}

.feature__item--02 {
	background: #9EC1D0;
}

.feature__heading-2 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin-bottom: 1.8rem;
}

.feature__heading-2__text {
	text-align: center;
	color: #fff;
	font-size: 1.5rem;
	line-height: 1.2;
}

.feature__number {
	padding-top: 0.3rem;
	padding-right: 1.7rem;
}

.feature__inner {
	padding: 0 0.2rem;
}

.feature__text {
	margin-top: 1.4rem;
	font-size: 1.1rem;
	letter-spacing: 0.075em;
	line-height: 1.3636;
	text-align: justify;
}

.feature__text--ls {
	letter-spacing: 0;
}

.feature__link {
	position: relative;
	margin-top: 2.1rem;
	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;
	height: 4.7rem;
	border-radius: 0.4rem;
	border: 0.2rem solid #000;
	background: #e8ded8;
	font-size: 1.2rem;
	text-align: center;
	line-height: 1.25;
	text-decoration: none;
	padding-right: 1.2rem;
}

.feature__link::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 1.3rem;
	width: 0.41em;
	height: 0.41em;
	border-top: 0.2rem solid #000;
	border-right: 0.2rem solid #000;
	-webkit-transform: translateY(-50%) rotate(45deg);
	-ms-transform: translateY(-50%) rotate(45deg);
	transform: translateY(-50%) rotate(45deg);
}

.feature__link--01 {
	padding-right: 2.5rem;
}

.logo {
	padding: 3.6rem 0 0 0.8rem;
}

.logo img {
	display: block;
	width: 45.91%;
}

.announce {
	position: relative;
	width: 100%;
	height: 100vh;
	padding: 25.7rem 0;
}

.announce__logo {
	position: absolute;
	top: 3.5rem;
	left: 3.5rem;
}

.announce__heading {
	font-size: 3rem;
	line-height: 1.37;
	text-align: center;
	margin-bottom: 7.3rem;
}

.announce__text {
	font-size: 1.8rem;
	font-weight: 300;
	line-height: 1.78;
	text-align: center;
}

.announce__text p:not(:last-child) {
	margin-bottom: 1.78em;
}

.announce__button {
	display: block;
	margin-top: 10.3rem;
	font-size: 1.5rem;
	background: #ffffff;
	border: 0.1rem solid #000;
	border-radius: 1rem;
	max-width: 32rem;
	padding: 1.2rem 0;
	margin-left: auto;
	margin-right: auto;
	text-decoration: none;
	text-align: center;
}

.js-scrollin {
	opacity: 0;
	-webkit-transform: translateY(40px);
	-ms-transform: translateY(40px);
	transform: translateY(40px);
}

.js-scrollin.is-visible {
	opacity: 1;
	-webkit-transform: translateY(0);
	-ms-transform: translateY(0);
	transform: translateY(0);
	-webkit-transition: opacity 0.7s, -webkit-transform 0.7s;
	transition: opacity 0.7s, -webkit-transform 0.7s;
	transition: opacity 0.7s, transform 0.7s;
	transition: opacity 0.7s, transform 0.7s, -webkit-transform 0.7s;
}

.js-fadein {
	opacity: 0;
}

.js-fadein.is-visible {
	opacity: 1;
	-webkit-transition: opacity 0.7s;
	transition: opacity 0.7s;
}

/**
 * Swiper 10.2.0
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: August 17, 2023
 */

@font-face {
	font-family: "swiper-icons";
	src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
	font-weight: 400;
	font-style: normal;
}

:root {
	--swiper-theme-color: #007aff; /*
		--swiper-preloader-color: var(--swiper-theme-color);
		--swiper-wrapper-transition-timing-function: initial;
		*/
	--swiper-navigation-size: 40.4rem; /*
		--swiper-navigation-top-offset: 50%;
		--swiper-navigation-sides-offset: 1rem;
		--swiper-navigation-color: var(--swiper-theme-color);
		*/
}

:host {
	position: relative;
	display: block;
	margin-left: auto;
	margin-right: auto;
	z-index: 1;
}

.swiper {
	margin-left: auto;
	margin-right: auto;
	position: relative;
	overflow: hidden;
	overflow: clip;
	list-style: none;
	padding: 0; /* Fix of Webkit flickering */
	z-index: 1;
	display: block;
}

.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;
	-webkit-transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
	transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
}

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

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

.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;
	display: block;
}

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

/* Auto Height */

.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;
}

/* 3D Effects */

.swiper-3d.swiper-css-mode .swiper-wrapper {
	-webkit-perspective: 120rem;
	perspective: 120rem;
}

.swiper-3d .swiper-wrapper {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}

.swiper-3d {
	-webkit-perspective: 120rem;
	perspective: 120rem;
}

.swiper-3d .swiper-slide,
.swiper-3d .swiper-cube-shadow {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}

/* CSS Mode */

.swiper-css-mode > .swiper-wrapper {
	overflow: auto;
	scrollbar-width: none; /* For Firefox */
	-ms-overflow-style: none; /* For Internet Explorer and Edge */
}

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

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

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

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

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
	-ms-scroll-snap-type: none;
	scroll-snap-type: none;
}

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

.swiper-css-mode.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-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
	scroll-snap-align: center center;
	scroll-snap-stop: always;
}

.swiper-css-mode.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-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
	height: 100%;
	min-height: 0.1rem;
	width: var(--swiper-centered-offset-after);
}

.swiper-css-mode.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-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
	width: 100%;
	min-width: 0.1rem;
	height: var(--swiper-centered-offset-after);
}

/* Slide styles start */

/* 3D Shadows */

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
	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-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

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

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

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

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

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .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;
}

/* Slide styles end */

.swiper-button-prev,
.swiper-button-next {
	position: absolute;
	top: var(--swiper-navigation-top-offset, 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-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
	opacity: 0.35;
	cursor: auto;
	pointer-events: none;
}

.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
	opacity: 0;
	cursor: auto;
	pointer-events: none;
}

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

.swiper-button-prev svg,
.swiper-button-next svg {
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	-webkit-transform-origin: center;
	-ms-transform-origin: center;
	transform-origin: center;
}

.swiper-rtl .swiper-button-prev svg,
.swiper-rtl .swiper-button-next svg {
	-webkit-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	transform: rotate(180deg);
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
	left: var(--swiper-navigation-sides-offset, 1rem);
	right: auto;
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
	right: var(--swiper-navigation-sides-offset, 1rem);
	left: auto;
}

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

/* Navigation font start */

.swiper-button-prev:after,
.swiper-button-next: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:after,
.swiper-rtl .swiper-button-next:after {
	content: "prev";
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
	right: var(--swiper-navigation-sides-offset, 1rem);
	left: auto;
}

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

/* Navigation font end */

.youtube-modal-btn {
	border: none;
	background: none;
	padding: 0;
}

.youtube-modal-btn span {
	position: relative;
	display: block;
	border-radius: 0.65rem;
	overflow: hidden;
}

.youtube-modal-btn span::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: rgba(0, 0, 0, 0.2);
}

.youtube-modal-btn span::after {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	content: "";
	width: 5.2rem;
	height: 5.2rem;
	display: block;
	background: url(../img/icon_play.svg) no-repeat center/contain;
}

.youtube-modal {
	position: relative;
	z-index: 10000;
}

.youtube-modal__overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.5);
	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;
}

.youtube-modal__container {
	position: relative;
	padding: 0;
	width: 90%;
	max-width: 1000px;
	max-height: calc(90% - 3rem);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-overflow-scrolling: touch;
}

.youtube-modal__container::before {
	content: "";
	display: block;
	padding-top: 56.25%;
}

.youtube-modal__container iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.youtube-modal__close {
	background: none;
	border: 0;
	padding: 0;
	position: absolute;
	top: -5rem;
	right: 0;
	width: 4rem;
	height: 4rem;
}

.youtube-modal__close span {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 3.5rem;
	height: 0.2rem;
	display: block;
	background: #ffffff;
}

.youtube-modal__close span:first-child {
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	-ms-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg);
}

.youtube-modal__close span:nth-child(2) {
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	-ms-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg);
}

/**************************\
	Demo Animation Style
\**************************/

.micromodal-slide {
	display: none;
}

.micromodal-slide.is-open {
	display: block;
}

.micromodal-slide[aria-hidden=false] .youtube-modal__overlay {
	-webkit-animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
	animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=false] .youtube-modal__container {
	-webkit-animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
	animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=true] .youtube-modal__overlay {
	-webkit-animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
	animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=true] .youtube-modal__container {
	-webkit-animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
	animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide .youtube-modal__container,
.micromodal-slide .youtube-modal__overlay {
	will-change: transform;
}

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

html { /* pc */
	font-size: calc(0.625rem + (1vw - 15px) * 0.6667);
}

.l-body { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

.l-main { /* pc */
	-webkit-box-ordinal-group: 3;
	-ms-flex-order: 2;
	order: 2;
	width: 36%;
	margin: 5.2rem auto 7.6rem;
	-webkit-filter: drop-shadow(1.28712rem 1.28712rem 0.39604rem rgba(0, 0, 0, 0.3));
	filter: drop-shadow(1.28712rem 1.28712rem 0.39604rem rgba(0, 0, 0, 0.3));
}

.l-sub-1 { /* pc */
	display: block;
	-webkit-box-ordinal-group: 2;
	-ms-flex-order: 1;
	order: 1;
	width: 32%;
	position: sticky;
	top: 0;
}

.l-sub-1.is-window-long {
	top: -17rem;
}

.l-sub-2 { /* pc */
	display: block;
	-webkit-box-ordinal-group: 4;
	-ms-flex-order: 3;
	order: 3;
	width: 32%;
	padding: 19.5rem 0 0;
	position: sticky;
	top: 0;
}

.l-sub-2.is-window-long {
	top: -17rem;
}

.l-sub-inner { /* pc */
	width: 86.3%;
	margin-left: auto;
	margin-right: auto;
	padding: 0 0 2rem;
}

.l-wrapper { /* pc */
	max-width: 1000px;
}

.mainvisual { /* pc */
	border-radius: 1.7rem 1.7rem 0 0;
	height: calc(100vh - 5.2rem);
	height: calc(100svh - 5.2rem);
}

.mainvisual__links__item a { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.mainvisual__links__item a:hover {
	opacity: 0.6;
}

.fixed-btn-wrap { /* pc */
	left: 32%;
	width: 36%;
}

.fixed-btn { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.fixed-btn:hover {
	opacity: 0.6;
}

.line-area { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.line-area:hover {
	opacity: 0.6;
}

.form__button { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.form__button:not([disabled]):hover {
	opacity: 0.6;
}

.cv-area__item a { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.cv-area__item a:hover {
	opacity: 0.6;
}

.announce__button { /* pc */
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.announce__button:hover {
	opacity: 0.6;
}

}

@media screen and (max-width: 980px) {

.sp-only { /* sp */
	display: block !important;
}

.sp-only-2 { /* sp */
	display: inline-block !important;
}

.pc-only { /* sp */
	display: none !important;
}

.pc-only-2 { /* sp */
	display: none !important;
}

.create__smartphone { /* sp */
	width: 100vw;
}

.create__desktop { /* sp */
	width: 100vw;
}

}

@-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);
}

}

@-webkit-keyframes mmfadeIn {

from {
	opacity: 0;
}

to {
	opacity: 1;
}

}

@keyframes mmfadeIn {

from {
	opacity: 0;
}

to {
	opacity: 1;
}

}

@-webkit-keyframes mmfadeOut {

from {
	opacity: 1;
}

to {
	opacity: 0;
}

}

@keyframes mmfadeOut {

from {
	opacity: 1;
}

to {
	opacity: 0;
}

}

@-webkit-keyframes mmslideIn {

from {
	-webkit-transform: translateY(15%);
	transform: translateY(15%);
}

to {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

}

@keyframes mmslideIn {

from {
	-webkit-transform: translateY(15%);
	transform: translateY(15%);
}

to {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

}

@-webkit-keyframes mmslideOut {

from {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

to {
	-webkit-transform: translateY(-10%);
	transform: translateY(-10%);
}

}

@keyframes mmslideOut {

from {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

to {
	-webkit-transform: translateY(-10%);
	transform: translateY(-10%);
}

}

