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

/* -----------------------
  service
-------------------------- */
.service__box {
	display: flex;
	margin-bottom: 10px;
}
.service__num {
	flex-basis: 20%;
	background-color: #00a0ac;
	font-weight: bold;
	text-align: center;
	color: #fff;
	font-size: 1.8rem;
}
.service__content {
	flex-basis: 80%;
	padding-left: .5em;
}
.service__title {
	color: #00a0ac;
	font-size: 1.8rem;
}
.service__add {
	border: solid 1px #000;
	margin-top: 35px;
	padding: 10px;
}
@media (min-width: 45.001em){
	.service__wrap {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -4px;
	}
	.service__box {
		flex-basis: 50%;
		max-width: 50%;
		margin-bottom: 15px;
		padding: 0 4px;
	}
	.service__add {
		max-width: 90%;
		margin: 50px auto 0;
	}
}
@media (min-width: 60.001em){
	.service__box {
		margin-bottom: 20px;
	}
	.service__num {
		font-size: 2rem;
	}
	.service__title {
		font-size: 2rem;
	}
	.service__add {
		margin: 70px auto 0;
	}
}

/* -----------------------
  flow
-------------------------- */
.flow__box {
	display: flex;
	margin-bottom: 10px;
}
.flow__num {
	position: relative;
	flex-basis: 10%;
	font-weight: bold;
	text-align: center;
	color: #00a0ac;
}
.flow__num:after {
	position: absolute;
	top: 10%;
	left: 50%;
	display: block;
	content: '';
	border-left: solid 1px #00a0ac;
	height: 86%;
}
.flow__box:first-of-type .flow__num:after {
	top: 13%;
	height: 84%;
}
.flow__box:last-child .flow__num:after {
	top: 17%;
	height: 80%;
}
.flow__content {
	flex-basis: 90%;
	padding-left: .5em;
}
.flow__title {
	margin-bottom: .5em;
	color: #00a0ac;
	border-bottom: solid 1px #00a0ac;
	font-size: 1.8rem;
}
@media (min-width: 30.001em){
	.flow__num:after {
		top: 13%;
		height: 80%;
	}
	.flow__box:first-of-type .flow__num:after {
		top: 16%;
		height: 78%;
	}
	.flow__box:last-child .flow__num:after {
		top: 20%;
		height: 74%;
	}
}
@media (min-width: 35.001em){
	.flow__num:after {
		top: 15%;
	}
	.flow__box:first-of-type .flow__num:after {
		top: 18%;
	}
	.flow__box:last-child .flow__num:after {
		top: 22%;
	}
}
@media (min-width: 45.001em){
	.flow__box {
		margin-bottom: 15px;
	}
	.flow__num:after {
		top: 17%;
	}
	.flow__box:first-of-type .flow__num:after {
		top: 20%;
	}
	.flow__box:last-child .flow__num:after {
		top: 24%;
	}
}
@media (min-width: 60.001em){
	.flow__box {
		margin-bottom: 20px;
	}
	.flow__num:after {
		top: 19%;
	}
	.flow__box:first-of-type .flow__num:after {
		top: 22%;
	}
	.flow__box:last-child .flow__num:after {
		top: 26%;
	}
	.flow__title {
		font-size: 2rem;
	}
}

/* -----------------------
  fee
-------------------------- */
.fee__title {
	font-size: 1.8rem;
	color: #00a0ac;
}
.fee__table {
	width: 100%;
	max-width: 100%;
}
.fee__table th, .fee__table td {
	border: 1px solid #ccc;
}
.fee__table th {
	background-color: #f1f3f1;
}
.fee__table td {
	text-align: center;
}

/* -----------------------
  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; }
}