@charset "UTF-8";

footer {
 	width: 100%;
	text-align: center;
	border-top: 1px solid #CCC;
	height: 100%;
	margin-top: 80px;
}

footer .row {
  margin-right: 0;
  margin-left: 0;
}

/* サイトマップ */
#footer_sitemaps{
	margin: 60px auto 0;
}
table#sitemap_table{
	border-collapse:separate;
	border-spacing: 30px 0px;
}
table#sitemap_table tr {
	width: 100%;
}
table#sitemap_table td.sitemap_default{
	font-size: 10px;
	text-align: left;
	text-decoration: none;
	padding: 10px 0px;
	height: 20px;
  width: 300px;
}
table#sitemap_table td.sitemap_default a{
	color: #666;
}
table#sitemap_table td.sitemap_title{
	border-bottom: solid 1px #CCC;
	font-weight: bold;
	padding-bottom: 10px;
}
#footer_sitemaps .card{
	border:none;
	padding: 5px;
	font-size: 10px;
	text-align: left;
	background-color: gray;
}
#footer_sitemaps .card .card-title{
	font-weight: bold;
	padding: 5px 0px;
	border-bottom: solid 1px #CCC;
}
#footer_sitemaps .card .card-body ul.list-group{
	border:none;
	background-color: pink;
}
#footer_sitemaps .card .card-body ul.list-group li{
	border:none;
	background-color: orange;
	padding: 0;
}
#footer_sp_sitemaps .footer_sp_sitemap_link{
	border-bottom: solid 1px #CCC;
	padding: 0;
}
#footer_sp_sitemaps .footer_sp_sitemap_link:nth-child(odd){
	border-right: solid 1px #CCC
}
#footer_sp_sitemaps .footer_sp_sitemap_link a{
	display: block;
	padding: 17px 0px;
	color: #000;
}
#footer_links {
	background-color: #3E3E3E;
	padding: 26px 0;
}
#footer_links ul{
	list-style-type: none;
}
#footer_links li{
	background-color: #3E3E3E;
	color: #FFF;
	padding: 0 18px;
}
#footer_links li a{
	display: block;
	padding: 0;
}
#footer_sp_sitemaps a {
  color: #666;
  font-size: 12px;
}
#footer_links a {
  color: #fff;
  font-size: 12px;
}

#footer_sitemaps .sitemap_column,
#footer_sitemaps .w-50 {
	margin-right: 36px;
}
#footer_sitemaps .sitemap_column:last-child,
#footer_sitemaps .w-50:last-child {
	margin-right: 0;
}

#footer_sitemaps .sitemap_column dl {
	margin-bottom: 60px;
}
#footer_sitemaps .sitemap_column dt {
    border-bottom: solid 1px #CCC;
    font-weight: bold;
    padding-bottom: 18px;
    color: #000;
	font-size: 14px;
	margin-bottom: 2px;
}
#footer_sitemaps .sitemap_column dd:first-child{
	padding: 14px 0 0;
}
#footer_sitemaps .sitemap_column dd {
    font-size: 10px;
    text-decoration: none;
    padding: 12px 0 0;
}
#footer_sitemaps .sitemap_column dd a {
    color: #666;
}
#footer_sitemaps .sitemap_column dt a {
	color: #000;
}

/* TOP移動 */
#pageTop {
  display: none;
  position: fixed;
  bottom: 30px;
  right: 30px;
  margin: 0;
}
#pageTop i {
  padding-top: 6px
}
#pageTop a {
  display: block;
  z-index: 999;
  padding: 8px 0 0;
  border-radius: 30px;
  width: 44px;
  height: 44px;
  background-color: #0080CA;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* footer links */
/*#footer_links{
	background-color: #3E3E3E;
	padding: 24px 0px;
  height: 66px;
}
#footer_links ul{
	margin: 0;
	list-style-type: none;
	padding-left: 0;
}
#footer_links ul li{
	display: inline;
}
#footer_links ul li a{
	color: #FFF;
	text-decoration: none;
	padding: 0px 20px;
	font-size: 12px;
  font-weight: 300;
}
#footer_links ul li a:hover {
	text-decoration: underline;
} */

/* copyright */
#copyrights{
	background-color: #000;
	color: #8D8D8D;
  font-family: 'Source Sans Pro', sans-serif;
	font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.3px;
	padding: 30px 0px;
	height: 77px;
	width: 100%;
	font-weight: bold;
}

/* smartPhone */
@media screen and (max-width: 768px) {
  /* フッター */
  footer {
  	border-top: 1px solid #CCC;
  	height: 100%;
  	margin-top: 0;
  }
  #footer {
	padding: 15px 0 0;
  }
  #footer_links li {
	  min-width: calc(100% / 2);
  }
  #footer_links li a{
	display: block;
	padding: 15px 0px;
  }
  /* TOP移動 */

  #pageTop {
	bottom: 10px;
	right: 10px;
  }
  #pageTop a {
	padding: 6px 0 0;
	border-radius: 20px;
	width: 40px;
	height: 40px;
  }
	/* copyright */
  #copyrights{
  	font-size: 9px;
    font-weight: 600;
    letter-spacing: 1px;
  	padding: 12px 0px;
  	height: 38px;
  	width: 100%;
  	font-weight: bold;
  }
}
