@charset "utf-8";
/* -----------------------
  common
-------------------------- */
body {
	background-color: #00a0ac;
}
.content {
	background-color: #fff;
	padding: 12px;
	margin: 0 12px;
}
.wrapper {
	position: relative;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}
.wrapper--wide {
	max-width: 1000px;
}
.font-bold {
	font-weight: bold;
}
@media (min-width: 35.001em){
	.content {
		margin: 0 30px;
		padding: 20px;
	}
}
@media (min-width: 45.001em){
	.content {
		margin: 0 40px;
		padding: 30px;
	}
}
@media (min-width: 60.001em){
	.content {
		margin: 0 60px;
		padding: 30px;
	}
}

/* -----------------------
  header
-------------------------- */
.header {
	margin: 14px 12px;
}
.header__logo {
	width: 60%;
	margin: 0 auto;
}
@media (min-width: 35.001em){
	.header {
		margin: 14px 30px;
	}
	.header__logo {
		width: 50%;
	}
}
@media (min-width: 45.001em){
	.header {
		margin: 20px 40px;
	}
	.header__logo {
		width: 40%;
		margin: 0;
	}
}
@media (min-width: 60.001em){
	.header {
		margin: 30px 60px;
	}
	.header__logo {
		max-width: 400px;
	}
}

/* -----------------------
  main
-------------------------- */
.main {
	margin: 30px 0 60px;
}
@media (min-width: 45.001em){
	.main {
		margin: 45px 0 90px;
	}
}
@media (min-width: 60.001em){
	.main {
		margin: 60px 0 120px;
	}
}

/* -----------------------
  section
-------------------------- */
.section {
	margin-bottom: 50px;
}
.section__title {
	border-left: solid 5px #00a0ac;
	margin-bottom: 12px;
	padding: 0.25em 0.5em;
	color: #00a0ac;
	font-size: 2rem;
}
@media (min-width: 45.001em){
	.section {
		margin-bottom: 75px;
	}
	.section__title {
		margin-bottom: 18px;
	}
}
@media (min-width: 60.001em){
	.section {
		margin-bottom: 100px;
	}
	.section__title {
		margin-bottom: 24px;
		font-size: 2.4rem;
	}
}

/* -----------------------
  about
-------------------------- */
.movie__note {
	margin: 35px 0 20px;
	padding: 10px;
	background-color: #00a0ac;
	color: #fff;
}
.movie__title {
	width: 50%;
	min-width: 260px;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 25px;
	text-align: center;
}
.movie__box {
	margin-bottom: 25px;
	text-align: center;
	& a {
		display: inline-block;
		&:hover {
			opacity: .7;
		}
	}
}
.movie__btn {
	width: 70%;
	max-width: 300px;
	margin: 0 auto;
	text-align: center;
	& a {
		display: inline-block;
		&:hover {
			opacity: .7;
		}
	}
}
@media (min-width: 35.001em){
	.movie__title {
		width: 70%;
		max-width: 520px;
	}
}
@media (min-width: 45.001em){
	.movie__note {
		max-width: 720px;
		margin: 50px auto 30px;
	}
	.movie__title {
		margin-bottom: 35px;
	}
	.movie__box {
		margin-bottom: 35px;
	}
}
@media (min-width: 60.001em){
	.movie__note {
		margin: 70px auto 40px;
	}
	.movie__title {
		margin-bottom: 50px;
	}
	.movie__box {
		margin-bottom: 50px;
	}
}

/* -----------------------
  advantage
-------------------------- */
.advantage__wrap {
	margin-bottom: 35px;
}
.advantage__title {
	margin-bottom: 5px;
	color: #00a0ac;
	font-size: 2rem;
	font-weight: normal;
	& .marker {
		background: linear-gradient(transparent 40%, #ffffbc 40%);
		background-repeat: no-repeat;
		background-size: 0% 100%;
		transition: .5s;
		font-weight: bold;
		font-size: 1.2em;
	}
	& .marker.on {
		background-size: 100% 100%;
	}
}
.advantage__img {
	margin-bottom: 10px;
}
.advantage__note {
	padding: 10px 10px 0;
	background-color: #00a0ac;
	border-radius: 16px;
	text-align: center;
}
.advantage-note__text {
	margin-bottom: 0;
	color: #fff;
	font-size: 2rem;
	& span {
		color: #ffffbc;
		font-weight: bold;
		font-size: 2.6em;
	}
}
@media (min-width: 45.001em){
	.advantage__wrap {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		margin-right: -20px;
		margin-left: -20px;
		margin-bottom: 50px;
	}
	.advantage__wrap--reverse {
		flex-direction: row-reverse;
	}
	.advantage__img {
		flex-basis: 50%;
		max-width: 50%;
		padding: 0 20px;
	}
	.advantage__text {
		flex-basis: 50%;
		max-width: 50%;
		padding: 0 20px;
	}
	.advantage__note {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		max-width: 680px;
		margin: 0 auto;
		padding: 0 50px;
	}
	.advantage-note__text {
		flex-basis: 50%;
		max-width: 50%;
		padding: 0 20px;
	}
}
@media (min-width: 60.001em){
	.advantage__wrap {
		margin-bottom: 70px;
	}
	.advantage__title {
		margin-bottom: 10px;
		font-size: 2.4rem;
	}
}

/* -----------------------
  flow
-------------------------- */
.flow__box {
	margin-bottom: 15px;
}
.flow__case {
	padding: 1rem;
	background-color: #00a0ac;
	color: #fff;
	font-size: 1.8rem;
	& span {
		font-size: .8em;
	}
}
.flow__content {
	display: flex;
	flex-wrap: wrap;
	&:not(:last-child) {
		padding-bottom: 60px;
	}
}
.flow__img {
	flex-basis: 30%;
	max-width: 30%;
}
.flow__text {
	flex-basis: 70%;
	max-width: 70%;
}
.flow-text__title {
	margin-bottom: 5px;
	border-bottom: 1px solid #00a0ac;
	color: #00a0ac;
	font-size: 1.8rem;
}
.flow-text__explanation {
	margin-bottom: 0;
	& span {
		font-size: 0.8em;
	}
}
.flow__arrow {
	position: relative;
	&::after {
		position: absolute;
		bottom: 8%;
		left: 50%;
		background-color: #00a0ac;
		height: 26px;
		width: 80px;
		content: '';
		transform: translateX(-50%);
		clip-path: polygon(0 0, 100% 0, 50% 100%);
	}
}
.flow__note {
	margin-top: 30px;
	padding: 10px;
	background-color: #ccecee;
	& p {
		margin-bottom: 5px;
	}
}
@media (min-width: 45.001em){
	.flow__content {
		&:not(:last-child) {
			padding-bottom: 90px;
		}
	}
	.flow__img {
		flex-basis: 20%;
		max-width: 20%;
	}
	.flow__text {
		flex-basis: 80%;
		max-width: 80%;
	}
	.flow__arrow {
		&::after {
			bottom: 15%;
			height: 30px;
			width: 90px;
		}
	}
	.flow__note {
		margin-top: 45px;
	}
}
@media (min-width: 60.001em){
	.flow__box {
		margin-bottom: 30px;
	}
	.flow__content {
		&:not(:last-child) {
			padding-bottom: 120px;
		}
	}
	.flow__img {
		flex-basis: 15%;
		max-width: 15%;
	}
	.flow__text {
		flex-basis: 85%;
		max-width: 85%;
	}
	.flow-text__title {
		margin-bottom: 10px;
	}
	.flow__arrow {
		&::after {
			height: 35px;
			width: 106px;
		}
	}
	.flow__note {
		margin-top: 60px;
	}
}
/* アコーディオン */
.accordion-panel {
	display: none;
	margin-top: 15px;
	margin-bottom: 15px;
}
.accordion-trigger {
	position: relative;
}
.accordion-trigger:after {
	display: block;
	position: absolute;
	top: 40%;
	right: 25px;
	transform: rotate(135deg);
	width: 12px;
	height: 12px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transition: all .3s ease-in-out;
	content: '';
}
.accordion-trigger.open:after {
	top: 45%;
	transform: rotate(-45deg);
}

@media (width > 35.001em) {
/* アコーディオン */
	.accordion-trigger:after {
		top: 35%;
		right: 35px;
	}
}
@media (width > 60.001em) {
	/* アコーディオン */
	.accordion-panel {
		margin-top: 30px;
		margin-bottom: 30px;
	}
	}

/* -----------------------
  app
-------------------------- */
.app__img {
	text-align: center;
	& a {
		display: inline-block;
		&:hover {
			opacity: .7;
		}
	}
}
.app__wrap {
	margin-bottom: 35px;
}
.app__text {
	max-width: 300px;
	margin-right: auto;
	margin-left: auto;
	& a {
		color: #00a0ac;
		text-decoration: underline;
	}
}
@media (width < 45.001em) {
	.app__img {
		margin-bottom: 10px;
	}
}
@media (width > 45.001em) {
	.app__wrap {
		display: flex;
		flex-wrap: wrap;
		margin-right: -20px;
		margin-left: -20px;
		margin-bottom: 55px;
	}
	.app__img {
		flex-basis: 40%;
		max-width: 40%;
		padding: 0 20px;
		text-align: center;
	}
	.app__text {
		flex-basis: 60%;
		max-width: 60%;
		padding: 0 20px;
	}
}
@media (width > 60.001em) {
	.app {
		.inner {
			max-width: 828px;
			margin-right: auto;
			margin-left: auto;
		}
	}
	.app__wrap {
		margin-bottom: 75px;
	}
}

/* -----------------------
  footer
-------------------------- */
.footer {
	color: #fff;
}
.copyright {
	padding: 1em 0;
	font-size: 1.2rem;
	line-height: 1.4;
	text-align: center;
}

/* -------------------------------- *\
    Display
\* -------------------------------- */
/*
 * 要素の表示/非表示を制御する汎用クラス
 */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-inline { display: inline !important; }
.d-inline-block { display: inline-block !important; }
@media (min-width: 35.001em){
	.d-none-sm { display: none !important; }
	.d-block-sm { display: block !important; }
	.d-inline-sm { display: inline !important; }
	.d-inline-block-sm { display: inline-block !important; }
}
@media (min-width: 45.001em){
	.d-none-md { display: none !important; }
	.d-block-md { display: block !important; }
	.d-inline-md { display: inline !important; }
	.d-inline-block-md { display: inline-block !important; }
}
@media (min-width: 60.001em){
	.d-none-lg { display: none !important; }
	.d-block-lg { display: block !important; }
	.d-inline-lg { display: inline !important; }
	.d-inline-block-lg { display: inline-block !important; }
}

/* -------------------------------- *\
    Spaces
\* -------------------------------- */
.mx-auto, .mr-auto { margin-right: auto !important; }
.mx-auto, .ml-auto { margin-left: auto !important; }

/* Margin Top */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: var(--space-1) !important; }
.mt-2 { margin-top: var(--space-2) !important; }
.mt-3 { margin-top: var(--space-3) !important; }
.mt-4 { margin-top: var(--space-4) !important; }
.mt-5 { margin-top: var(--space-5) !important; }

/* Margin Right */
.mr-0 { margin-right: 0 !important; }
.mr-1 { margin-right: var(--space-1) !important; }
.mr-2 { margin-right: var(--space-2) !important; }
.mr-3 { margin-right: var(--space-3) !important; }
.mr-4 { margin-right: var(--space-4) !important; }
.mr-5 { margin-right: var(--space-5) !important; }

/* Margin bottom */
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: var(--space-1) !important; }
.mb-2 { margin-bottom: var(--space-2) !important; }
.mb-3 { margin-bottom: var(--space-3) !important; }
.mb-4 { margin-bottom: var(--space-4) !important; }
.mb-5 { margin-bottom: var(--space-5) !important; }

/* Margin left */
.ml-0 { margin-left: 0 !important; }
.ml-1 { margin-left: var(--space-1) !important; }
.ml-2 { margin-left: var(--space-2) !important; }
.ml-3 { margin-left: var(--space-3) !important; }
.ml-4 { margin-left: var(--space-4) !important; }
.ml-5 { margin-left: var(--space-5) !important; }

/* Padding top */
.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: var(--space-1) !important; }
.pt-2 { padding-top: var(--space-2) !important; }
.pt-3 { padding-top: var(--space-3) !important; }
.pt-4 { padding-top: var(--space-4) !important; }
.pt-5 { padding-top: var(--space-5) !important; }

/* Padding bottom */
.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: var(--space-1) !important; }
.pb-2 { padding-bottom: var(--space-2) !important; }
.pb-3 { padding-bottom: var(--space-3) !important; }
.pb-4 { padding-bottom: var(--space-4) !important; }
.pb-5 { padding-bottom: var(--space-5) !important; }