@charset "utf-8";

/* フッタースタイル
----------------------------------------------------------- */

/*----- #footer_nav01 -----*/

#footer_nav01 {
	padding: 25px 10px 30px;
	background: #f0f0f0;
}

#footer_nav01 h2 {
	position: relative;
	margin: 30px 0 0;
	padding: 0 0 10px 20px;
	border-bottom: 2px solid #c8ccd0;
	font-size: 1.4rem;
	font-weight: bold;
}

#footer_nav01 h2:first-child {
	margin-top: 0;
}

#footer_nav01 h2 .icon {
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 14px;
	height: 10px;
	margin: -10px 0 0;
}

#footer_nav01 h2 .icon::before {
	display: block;
	width: 100%;
	height: 100%;
	content: url(/shared/svg/ttl_icon.svg);
	line-height: 0;
}

#footer_nav01 > ul > li > span {
	position: relative;
	display: block;
	border-bottom: 1px solid #c8ccd0;
	font-size: 1.3rem;
}

#footer_nav01 > ul > li > span::before,
#footer_nav01 > ul > li > span::after {
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	content: "";
}

#footer_nav01 > ul > li > span::before {
	width: 14px;
	height: 14px;
	margin: -7px 0 0;
	background: #326eb4;
	border-radius: 7px;
}

#footer_nav01 > ul > li > span::after {
	left: 6px;
	margin: -3px 0 0;
	border: 3px solid transparent;
	border-left: 4px solid #fff;
}

#footer_nav01 > ul > li > span > a {
	display: block;
	padding: 15px 0 15px 20px;
}

#footer_nav01 > ul > li > span > a::after {
	position: absolute;
	top: 50%;
	right: 0;
	display: block;
	content: "";
	width: 20px;
	height: 20px;
	margin: -10px 0 0;
	background: url(/shared/img/icon_open_sp.png) 0 0 no-repeat;
	background-size: 20px;
}

#footer_nav01 > ul > li.open > span > a::after {
	background: url(/shared/img/icon_close_sp.png) 0 0 no-repeat;
	background-size: 20px;
}

#footer_nav01 ul li ul {
	display: none;
	padding: 5px 0 15px 7px;
	border-bottom: 1px solid #c8ccd0;
}

#footer_nav01 ul li.open ul {
	display: block;
}

#footer_nav01 ul li:last-child ul {
	padding-bottom: 0;
	border-bottom: none;
}

#footer_nav01 ul li ul li {
	position: relative;
	margin: 5px 0 0;
}



/*----- #footer_inner01 -----*/

#footer_inner01 {
	margin: 20px;
}

#footer_inner01 p i {
	position: relative;
	top: 2px;
	margin: 0 2px 0 0;
	color: #55acee;
	font-size: 2.0rem;
}

#footer_inner01 p:last-child {
	position: relative;
	padding: 0 0 0 10px;
}

#footer_inner01 p:last-child a::before {
	position: absolute;
	top: 3px;
	left: 0;
	display: block;
	content: "";
	border: 3px solid transparent;
	border-left: 4px solid #666;
}


/*----- #footer_nav02 -----*/

#footer_nav02 ul li {
	position: relative;
	margin: 0 0 5px;
	padding: 0 0 0 10px;
	text-indent: -10px;
	line-height: 1.6;
}

#footer_nav02 ul li a {
	position: relative;
	padding: 0 0 0 10px;
}


#footer_nav02 ul li a::before {
	position: absolute;
	top: 3px;
	left: 0;
	display: block;
	content: "";
	border: 3px solid transparent;
	border-left: 4px solid #666;
}


/*----- #footer_inner02 -----*/

#footer_inner02 {
	margin: 20px;
	line-height: 1.6;
}

#footer_inner02 address a::before {
	position: relative;
	top: -1px;
	display: inline-block;
	content: "";
	margin: 0 0 0 5px;
	border: 3px solid transparent;
	border-left: 4px solid #666;
}

#footer_inner02 p {
	margin: 20px 0 0;
	font-size: .8rem;
	text-align: center;
}

#footer_inner02 small {
	color: #222;
}



/* フォーム用フッタースタイル
----------------------------------------------------------- */
.form footer {
	border-top: 1px solid #dce0e4;
}

.form #footer_nav01 {
	display: none;
}

.form #footer_inner01 {
	margin: 15px 20px 20px;
}


/* fontawsome 色を変える

#footer_inner01 p i.fa-xxxx-color {
	color: #xxxxx;
}
----------------------------------------------------------- */
#footer_inner01 p i.fa-twitter-color {
	color: #55acee;
}

#footer_inner01 p i.fa-facebook-color {
	color: #3b5998;
}
