footer {
  background-color: #F4F4F4;
  padding-bottom: 40px; }

.footer-top {
  margin-bottom: 72px; }

.footer-mainnav {
  margin-bottom: 40px; }
  .footer-mainnav li {
    border-bottom: 1px solid #fff; }
  .footer-mainnav a {
    font-weight: bold;
    line-height: 55px;
    display: block;
    position: relative;
    margin: 0 16px; }
    .footer-mainnav a::after {
      content: "";
      display: block;
      width: 8px;
      height: 8px;
      border-top: 2px solid #000;
      border-right: 2px solid #000;
      -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
      transform: rotate(45deg);
      position: absolute;
      top: 22px;
      right: 4px; }

@media screen and (min-width: 768px) {
  .footer-nav a:hover {
    color: #F08300; } }

.footer-soba {
  margin-bottom: 24px; }

.footer-logolist {
  background-color: #fff;
  margin-bottom: 16px;
  padding: 24px 0; }
  .footer-logolist ul {
    width: 90%;
    margin: 0 auto;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
  .footer-logolist li {
    width: calc(100% / 3); }
    .footer-logolist li a {
      display: block;
      margin: 0 auto; }
  .footer-logolist li:first-of-type a {
    width: 75%; }
  .footer-logolist li:nth-of-type(2) a {
    width: 90%; }
  .footer-logolist li:last-of-type a {
    width: 38%; }
  .footer-logolist .footer-holdingslogo {
    width: 100%;
    margin: 0 auto 24px;
    border-bottom: 1px solid #F4F4F4; }
    .footer-logolist .footer-holdingslogo a {
      display: block;
      width: 30%;
      margin: 0 auto;
      padding-bottom: 24px; }

.footer-contact {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 40px; }

.footer-contactmail,
.footer-contacttel {
  width: 48%;
  background-color: #fff;
  border-radius: 4px;
  -webkit-box-shadow: 0px 0px 3px 3px rgba(0, 0, 0, 0.05);
  box-shadow: 0px 0px 3px 3px rgba(0, 0, 0, 0.05);
  height: 56px;
  position: relative; }
  .footer-contactmail::before,
  .footer-contacttel::before {
    display: inline-block;
    margin-right: 2px;
    position: absolute;
    top: 50%;
    left: 5%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%); }
  .footer-contactmail .footer-contactbtn,
  .footer-contactmail .footer-telbtn,
  .footer-contactmail h3,
  .footer-contacttel .footer-contactbtn,
  .footer-contacttel .footer-telbtn,
  .footer-contacttel h3 {
    font-size: 11px;
    text-align: center;
    position: relative;
    padding-left: 13%; }
    .footer-contactmail .footer-contactbtn span,
    .footer-contactmail .footer-telbtn span,
    .footer-contactmail h3 span,
    .footer-contacttel .footer-contactbtn span,
    .footer-contacttel .footer-telbtn span,
    .footer-contacttel h3 span {
      font-size: 9px;
      display: block; }
    .footer-contactmail .footer-contactbtn a,
    .footer-contactmail .footer-telbtn a,
    .footer-contactmail h3 a,
    .footer-contacttel .footer-contactbtn a,
    .footer-contacttel .footer-telbtn a,
    .footer-contacttel h3 a {
      display: block; }

.footer-contactmail::before {
  content: "";
  background-image: url(../img/footer/sp/ico-contact.svg);
  width: 16px;
  height: 12.8px; }

.footer-contactmail h3,
.footer-contactmail .footer-contactbtn {
  line-height: 56px; }

.footer-contacttel::before {
  content: "";
  background-image: url(../img/footer/ico-freedial.svg);
  width: 20px;
  height: 13.12px; }

.footer-contacttel h3,
.footer-contacttel .footer-telbtn {
  margin-top: 10px; }

@media screen and (max-width: 320px) {
  .footer-contactmail::before,
  .footer-contacttel::before {
    left: 6%; }
  .footer-contactmail .footer-contactbtn,
  .footer-contactmail .footer-telbtn,
  .footer-contacttel .footer-contactbtn,
  .footer-contacttel .footer-telbtn {
    font-size: 9.2px;
    padding-left: 18%; }
    .footer-contactmail .footer-contactbtn span,
    .footer-contactmail .footer-telbtn span,
    .footer-contacttel .footer-contactbtn span,
    .footer-contacttel .footer-telbtn span {
      font-size: 8px; } }

footer .footer-subnav {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  footer .footer-subnav li {
    width: 48%;
    margin-bottom: 16px; }
  footer .footer-subnav a {
    font-size: 12px;
    font-weight: bold;
    display: block; }

@media screen and (min-width: 768px) {
  footer {
    padding: 80px 0 40px; }
  .footer-left {
    width: 48%; }
  .footer-right {
    width: 48%; }
  .footer-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 21px; }
    .footer-nav ul {
      width: 50%; }
    .footer-nav li {
      margin-bottom: 4px; }
    .footer-nav a {
      font-size: 13px; }
  .footer-mainnav li {
    border-bottom: none; }
  .footer-mainnav a {
    font-weight: normal;
    line-height: 1.7;
    display: inline; }
    .footer-mainnav a::after {
      content: none; }
  footer .footer-subnav {
    display: none !important; }
  .footer-logolist {
    padding: 32px 0; }
    .footer-logolist ul {
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between;
      width: 85%; }
    .footer-logolist .footer-holdingslogo {
      margin: 0 auto 32px; }
      .footer-logolist .footer-holdingslogo a {
        width: 25%;
        padding-bottom: 32px; }
  .footer-contact {
    margin-bottom: 0; }
  .footer-contactmail,
  .footer-contacttel {
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    height: inherit;
    padding: 20px 0; }
    .footer-contactmail::before,
    .footer-contacttel::before {
      content: none; }
    .footer-contactmail h3,
    .footer-contacttel h3 {
      padding-left: 0;
      line-height: 1.7;
      margin-top: 0;
      font-size: 13px; }
  .footer-contactmail h3 {
    margin-bottom: 20px; }
  .footer-contactlink a {
    display: block;
    font-size: 11px;
    font-weight: bold;
    background-color: #000;
    color: #fff;
    width: 80%;
    height: 32px;
    line-height: 32px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    padding-left: 12px; }
    .footer-contactlink a:hover {
      opacity: 0.6; }
    .footer-contactlink a::before {
      content: "";
      background-image: url(../img/common/ico-contact.svg);
      width: 13px;
      height: 10.4px;
      display: inline-block;
      margin-right: 2px;
      position: absolute;
      top: 50%;
      left: 8%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%); }
  .footer-telnumber {
    text-align: center;
    font-weight: bold;
    font-size: 20px;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.05em;
    position: relative;
    padding-left: 24px;
    line-height: 1; }
    .footer-telnumber span {
      font-size: 29px; }
    .footer-telnumber::before {
      content: "";
      background-image: url(../img/footer/ico-freedial.svg);
      width: 22px;
      height: 15.12px;
      display: inline-block;
      margin-right: 2px;
      position: absolute;
      bottom: 0;
      left: 7%; }
  .footer-contacttel h3 {
    margin-bottom: 8px; }
    .footer-contacttel h3 span {
      font-family: 'Oswald', sans-serif;
      letter-spacing: 0.05em; } }

@media screen and (max-width: 961px) and (min-width: 768px) {
  .footer-contactlink a {
    font-size: 9.6px;
    padding-left: 15px; }
    .footer-contactlink a::before {
      left: 3%; }
  .footer-telnumber {
    font-size: 16px; }
    .footer-telnumber span {
      font-size: 22.4px; } }

.footer-sns {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  max-width: 260px;
  margin: 0 auto 64px; }

.footer-line,
.footer-facebook {
  width: 40px;
  height: 40px; }

.footer-twitter {
  width: 50px;
  height: 50px; }

.footer-youtube {
  width: 40px;
  height: 29px; }

.footer-logo {
  width: 62px;
  height: 59px;
  margin: 0 auto 24px; }

.footer-copyright {
  text-align: center;
  font-size: 11px; }
