@charset "UTF-8";

/* *****************************************************
 *	container
 *	main_visual
 *	contents
 *	media queries
 * *****************************************************/

/* *****************************************************
 *  container
 * *****************************************************/
div.container figure {
    line-height: 0;
}

div.container figure img {
    max-width: 100%;
    height: auto;
}

.sp-block {
	display: none;
}


/* *****************************************************
 *  contents
 * *****************************************************/
div.contents{
	padding: 0 30px;
}

div.contents h2 {
	position: relative;
	font-size: 2.4rem;
	font-weight: bold;
	font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
	margin: 0 -30px 35px;
	padding: 0 30px;
	letter-spacing: 0.1em;
	line-height: 60px;
	color: #fff;
	text-align: left;
	padding-left: 30px;
	background: #1083c6;
}

div.contents h2::before {
	content: "";
	position: absolute;
	width: 15px;
	height: 100%;
	background: #009be4;
	top: 0;
	left: 0;
}

/* contents_message
-------------------------------------------------------*/
div.contents_message > h3 {
    margin-bottom: 16px;
    font-family: "游明朝","YuMincho","ヒラギノ明朝 ProN W6","Hiragino Mincho ProN","Hiragino Mincho Pro","ＭＳ 明朝",serif;
    font-size: 2.5rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.1em;
}

div.contents_message h4 {
    margin-bottom: 10px;
    color: #0781c8;
    line-height: 1.7;
    font-family: "游明朝","YuMincho","ヒラギノ明朝 ProN W6","Hiragino Mincho ProN","Hiragino Mincho Pro","ＭＳ 明朝",serif;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 0.1em;
}

div.contents_message p {
    line-height: 1.8;
    font-size: 1.4rem;
}

div.contents_message > p {
    margin-bottom: 58px;
    font-size: 1.7rem;
	font-weight: bold;
    text-align: center;
}

div.contents_message ul {
    margin-bottom: 110px;
}

div.contents_message li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

div.contents_message li:not(:last-child) {
    position: relative;
    padding-bottom: 74px;
}

div.contents_message li:not(:last-child)::after {
    content: "";
    position: absolute;
    bottom: 33px;
    left: 50%;
    display: block;
    width: 816px;
    height: 8px;
    margin-left: -408px;
    background: url("../images/border01.png") left top repeat-x;
}

div.contents_message figure {
    width: 310px;
    margin: 6px 0 0 20px;
}

/* summary
-------------------------------------------------------*/
div.summary {
    position: relative;
    -webkit-flex: 1;
    flex: 1;
}

div.summary a {
    display: block;
    position: relative;
    width: 200px;
    margin: 0 10px 0 auto;
	padding: 9px 0 7px;
    background: #0781c8;
    color: #fff;
    font-weight: bold;
    -webkit-transition: 0.7s ease;
	-moz-transition: 0.7s ease;
	-ms-transition: 0.7s ease;
	-o-transition: 0.7s ease;
	transition: 0.7s ease;
	text-align: center;
	line-height: 0;
}

div.summary a:hover {
    background:#3dabea;
}

div.summary a > span::before {
	content: "";
    position: relative;
    top: -3px;
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-right: 6px;
    border-top: 1px #fff solid;
    border-right: 1px #fff solid;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    line-height: 0;
}

div.summary a > span img {
	width: 170px;
	height: auto;
	image-rendering: -webkit-crisp-edges;
    image-rendering: -moz-crisp-edges;
    image-rendering: pixelated;
    -ms-interpolation-mode: nearest-neighbor;
}

div.summary a::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 3px;
    width: 100%;
    height: 30px;
    max-width: 200px;
    background: #98a5ad;
    -webkit-transform: rotate(1deg);
    -moz-transform: rotate(1deg);
    transform: rotate(1deg);
    z-index: -1;
}

/* contents_steps
-------------------------------------------------------*/
div#step {
	margin-top: -20px;
	padding-top: 20px;
}

div.contents_steps {
    margin-bottom: 80px;
}

div.contents_steps > h3 {
    margin-bottom: 25px;
    font-family: "游明朝","YuMincho","ヒラギノ明朝 ProN W6","Hiragino Mincho ProN","Hiragino Mincho Pro","ＭＳ 明朝",serif;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.1em;
}

div.contents_steps > ul > li{
	display:-webkit-box;
	display: -webkit-flex;
	display:flex;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-box-align:center;
	-ms-flex-align:center;
	align-items:center;
	position: relative;
	padding: 20px;
	background: #f0f0f0;
}

div.contents_steps > ul > li:first-child{
	background: #f9e4ee;
}

div.contents_steps > ul > li:first-child .num{
	background: #e17880;
}

div.contents_steps > ul > li:first-child dl dt{
	color: #e17880;
}

div.contents_steps > ul > li:first-child:before{
	content: "";
	position: absolute;
	right: 40px;
	bottom: 0;
	width: 130px;
	height: 143px;
	background: url(/guardian/images/illust_step1.svg) no-repeat;
	background-size: contain;
}

div.contents_steps > ul > li:nth-child(2){
	background: #f9dfb8;
}

div.contents_steps > ul > li:nth-child(2) .num{
	background: #d89440;
}

div.contents_steps > ul > li:nth-child(2) dl dt{
	color: #d89440;
}

div.contents_steps > ul > li:nth-child(2) dl dd ul li::before{
	color: #d07a12;
}

div.contents_steps > ul > li:nth-child(2):before{
	content: "";
	position:absolute;
	top: 35px;
	right: 45px;
	width: 100px;
	height: 100px;
	margin-top: -10px;
	background: url(/guardian/images/icon_step2.svg) no-repeat;
	background-size: contain;
}


div.contents_steps > ul > li:nth-child(3){
	background: #e9efc3;
}

div.contents_steps > ul > li:nth-child(3) .num{
	background: #6ab359;
}

div.contents_steps > ul > li:nth-child(3) dt{
	color: #6ab359;
}

div.contents_steps > ul > li:nth-child(4){
	background: #ddf0fa;
}

div.contents_steps > ul > li:nth-child(4) .num{
	background: #1d78b6;
}

div.contents_steps > ul > li:nth-child(4) dt{
	color: #1d78b6;
}

div.contents_steps > ul > li:nth-child(4):before{
	content: "";
	position:absolute;
	-webkit-transform: translate(0,-50%);
	transform: translate(0,-50%);
	top: 50%;
	right: 40px;
	width: 214px;
	height: 175px;
	margin-top: -10px;
	background: url(/guardian/images/illust_step4.svg) no-repeat;
	background-size: contain;
}

div.contents_steps > ul > li:nth-child(5){
	background: #e3e0ef;
}

div.contents_steps > ul > li:nth-child(5) .num{
	background: #534993;
}

div.contents_steps > ul > li:nth-child(5) dt{
	color: #534993;
}

div.contents_steps > ul > li:nth-child(5) dl dd ul li::before{
	color: #1d2974;
}



div.contents_steps > ul > li > .num{
	display:-webkit-box;
	display: -webkit-flex;
	display:flex;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-justify-content:center;
	justify-content:center;
	-webkit-box-align:center;
	-ms-flex-align:center;
	align-items:center;
	margin-right: 30px;
	width: 100px;
	height: 100px;
	color: #fff;
	border-radius: 50%;
	background: #ccc;
	text-align: center;
	line-height: 1.25;
}

div.contents_steps > ul > li > .num span{
	padding-top: 10px;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
}

div.contents_steps > ul > li > .num span em{
	display: block;
	width: 100%;
	font-size: 36px;
	font-size: 3.6rem;
	font-style: normal;
	font-weight: bold;
}

div.contents_steps > ul > li:not(:last-child){
	margin-bottom: 20px;
}

div.contents_steps > ul > li dl dt{
	margin-bottom: 5px;
	font-size: 24px;
	font-size: 2.4rem;
	font-weight: bold;
}

div.contents_steps > ul > li dl dd{
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.6;
}

div.contents_steps > ul > li dl dd ul li{
	position: relative;
}

div.contents_steps > ul > li dl dd ul li:before{
	content: "●";
}

/* *****************************************************
 *  media queries
 * *****************************************************/
@media screen and (max-width: 768px){
/* ------------------------------------------------------*/
/* container
-------------------------------------------------------*/
.sp-block {
	display: block;
}

.sp-none {
	display: none;
}

div.contents{
	padding: 0 15px;
}

div.contents h2 {
	font-size: 20px;
	font-size: 2.0rem;
	margin: 0 -0 25px;
	padding: 0 0 0 30px;
	line-height: 40px;
}

/* contents_message
-------------------------------------------------------*/
div.contents_message li:not(:last-child)::after {
	left: 0;
    width: 100%;
    margin-left: 0;
}

div.contents_message > h3 {
	font-size: 1.8rem;
    line-height: 1.6;
}

div.contents_message h4 {
	font-size: 1.8rem;
}

div.contents_message > p {
	margin-bottom: 25px;
	font-size: 1.6rem;
	line-height: 1.6;
}

div.contents_message ul {
	margin-bottom: 60px;
}

div.contents_message ul li:nth-child(2) div p {
	margin-bottom: 10px;
}

div.contents_message ul li:nth-child(2) div a {
	margin-bottom: 10px;
	padding: 14px 0 12px;
}

div.contents_message ul li:nth-child(2) div a::after {
	height: 40px;
}

div.contents_message figure {
	width: auto;
	margin: 0 auto;
	padding-top: 15px;
}

/* summary
-------------------------------------------------------*/
div.summary {
	-webkit-flex: none;
    flex: none;
	width: 100%;
}

/* contents_steps
-------------------------------------------------------*/
div.contents_steps {
	margin-bottom: 60px;
}

div.contents_steps > h3 {
	font-size: 1.8rem;
}

div.contents_steps > ul > li{
	padding: 15px 15px 25px;
}

div.contents_steps > ul > li > .num{
	margin: 0 auto 25px;
	width: 100%;
	height: 65px;
	border-radius: 0;
}

div.contents_steps > ul > li > .num span{
	font-size: 16px;
	font-size: 1.6rem;
}

div.contents_steps > ul > li > .num span em{
	font-size: 24px;
	font-size: 2.4rem;
}

div.contents_steps > ul > li:first-child:before,
div.contents_steps > ul > li:nth-child(2):before,
div.contents_steps > ul > li:nth-child(4):before {
	display: none;
}

div.contents_steps > ul > li:nth-child(4):before{
	display: none;
}

div.contents_steps > ul > li dl{
	width: 100%;
}

div.contents_steps > ul > li dl dt{
	margin-bottom: 15px;
	text-align: center;
}

div.contents_steps > ul > li dl dd{
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
}

div.contents_steps > ul > li dl dd ul li:before{
	position: absolute;
	top: -1px;
	left: 0;
}

div.contents_steps > ul > li dl dd ul li{
	padding-left: 16px;
}

div.contents_steps > ul > li dl dd ul li:not(:last-child){
	margin-bottom: 3px;
}

/* ------------------------------------------------------*/
}
