footer {
  color: #fff;
  background: #1a1a1a;
  padding: 90px 0 30px;
}

footer a {
  transition: .5s;
}

#footerBox01,
#footerBox02 {
  max-width: 1320px;
  padding: 0 20px;
  margin: 0 auto;
}

#footerBox01 > ul,
#footerBox02 > ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
footer {
  padding: 65px 0;
}
}


/*===================================================
ロゴ
===================================================*/
#footerLogo {
  width: 220px;
  height: 154px;
  text-indent: 100%;
  background: url("../../images/foot_logo.svg") no-repeat center 0  / contain;
  margin: 0 auto 90px;
  white-space: nowrap;
  overflow: hidden;
}

@media (max-width: 768px) {
#footerLogo {
  width: 150px;
  height: 105px;
  margin: 0 auto 50px;
}
}


/*===================================================
フッターリンク
===================================================*/
#footerBox01 > ul > li {
  font-size: 14px;
  line-height: 1;
}

#footerBox01 > ul > li a {
  display: block;
  color: #fff;
}
#footerBox01 > ul > li a:hover {
  opacity: .5;
}

#footSelect select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  letter-spacing: 0.1em;
  color: #fff;
  border: none;
  background: url("../../images/arrow-down.svg") #1a1a1a no-repeat right center / 18px 9px;
  border-bottom: 1px solid #fff;
  border-radius: 0;
  padding: 10px 15px 10px 5px;
  outline: none;
}

#footSearch {
  display: none;
}

/*
#footSearch {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 105px 0 35px;
}

#footSearch dt {
  width: calc(100% - 40px);
  height: 20px;
}
#footSearch dt input {
  width: 100%;
  height: 100%;
  background-color: #fff;
  border: none;
  border-radius: 10px;
  box-shadow: none;
  outline: none;
}

#footSearch dd {
  width: 20px;
  height: 20px;
  margin: 0 0 0 20px;
}
#footSearch dd button {
  width: 20px;
  height: 20px;
  font-size: 0;
  line-height: 0;
  vertical-align: top;
  text-indent: 100%;
  background: url("../../images/search.svg") no-repeat 0 0 / 20px;
  border: none;
  overflow: hidden;
}
#footSearch dd button:hover {
  cursor: pointer;
  opacity: .5;
}
*/

#footSNS {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 105px 0 0;
}

#footSNS li {
  width: 30px;
}
#footSNS li:nth-of-type(n+2) {
  margin: 0 0 0 30px !important;
}

#footSNS li a {
  width: 30px;
  height: 30px;
  text-indent: 100%;
  background: url("../../images/head_icon02_w.svg") no-repeat 0 0 / 30px;
  padding: 0 !important;
  overflow: hidden;
  white-space: nowrap;
}
#footSNS li:nth-of-type(2) a {
  background-image: url("../../images/head_icon03_w.svg");
}
#footSNS li:nth-of-type(3) a {
  background-image: url("../../images/head_icon05_w.svg");
}
#footSNS li a:hover {
  opacity: .5;
}

@media print, screen and ( min-width: 769px) {
#footerBox01 > ul > li > ul > li:nth-of-type(n+2) {
  margin-top: 2em;
}

#footerBox01 > ul > li > ul > li > ul li {
  margin-top: 1em;
}
#footerBox01 > ul > li > ul > li > ul li a {
  position: relative;
  padding-left: 1em;
}
#footerBox01 > ul > li > ul > li > ul li a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 1px;
  background-color: #fff;
  transform: translate(0,-50%);
}

#footerBox01 > ul > li > ul > li > ul li ul {
  margin-left: 1em;
}

#footerBox01 > ul > li:last-of-type {
  width: 195px;
}
}

@media (max-width: 768px) {
#footerBox01 > ul > li {
  width: 100%;
  font-size: 12px;
}
#footerBox01 > ul > li:nth-last-of-type(n+2) {
  border-top: 1px solid #fff;
}

#footerBox01 > ul > li a {
  text-align: center;
  padding: 8px 5px;
}

#footerBox01 > ul > li > ul,
#footerBox01 > ul > li > ul > li > ul {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

#footerBox01 > ul > li > ul > li {
  padding: 7px 0;
}

#footerBox01 > ul > li:first-of-type > ul > li,
#footerBox01 > ul > li:nth-of-type(3) > ul > li {
  width: 50%;
}
#footerBox01 > ul > li:first-of-type > ul > li:nth-of-type(odd) > a,
#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(odd) > a {
  border-right: 1px solid #fff;
}

#footerBox01 > ul > li:nth-of-type(2) > ul > li {
  width: 100%;
  padding: 0;
}
#footerBox01 > ul > li:nth-of-type(2) > ul > li > a {
  padding: 15px 5px;
}
#footerBox01 > ul > li:nth-of-type(2) > ul > li > ul > li {
  width: calc((100% - 2px) / 3);
  border-top: 1px dashed #fff;
  padding: 7px 0;
}
#footerBox01 > ul > li:nth-of-type(2) > ul > li > ul > li:not(:nth-of-type(3n)) a {
  border-right: 1px dashed #fff;
}
#footerBox01 > ul > li:nth-of-type(2) > ul > li > ul > li:last-of-type a {
  padding: 0 0 5px 0;
}
#footerBox01 > ul > li:nth-of-type(2) > ul > li > ul > li ul a {
  font-size: 10px;
  padding: 0;
}

#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(n+3) {
  border-top: 1px solid #fff;
}
#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(2) {
  display: flex;
  flex-wrap: wrap;
}
#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(2) > a,
#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(2) > ul {
  width: 50%;
}
#footerBox01 > ul > li:nth-of-type(3) > ul > li:nth-of-type(2) > ul li {
  width: 100%;
  border-left: 1px dashed #fff;
}

#footerBox01 > ul > li:nth-of-type(4) > ul {
  position: relative;
  flex-direction: column;
  margin: 20px 0;
}
#footerBox01 > ul > li:nth-of-type(4) > ul li {
  padding: 0;
}
#footerBox01 > ul > li:nth-of-type(4) > ul li a {
  text-align: left;
  padding: 10px 5px;
}
#footerBox01 > ul > li:nth-of-type(4) > ul > li:nth-of-type(-n+2) {
  width: 18.5em;
}
#footerBox01 > ul > li:nth-of-type(4) > ul > li:nth-of-type(n+3) {
  position: absolute;
  top: 0;
  left: 18.5em;
}
#footerBox01 > ul > li:nth-of-type(4) > ul > li:nth-of-type(4) {
  top: calc(1em + 20px);
}
#footerBox01 > ul > li:nth-of-type(4) > ul > li:nth-of-type(5) {
  top: calc(2em + 40px);
}
#footerBox01 > ul > li:nth-of-type(4) > ul ul {
  flex-direction: column;
}
#footerBox01 > ul > li:nth-of-type(4) > ul ul a {
  position: relative;
  display: inline-block;
  padding: 5px 5px 5px 20px;
}
#footerBox01 > ul > li:nth-of-type(4) > ul ul a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 5px;
  width: 10px;
  height: 1px;
  background-color: #fff;
  transform: translate(0,-50%);
}

/*
#footSearch {
  margin: 20px 0 40px;
}

#footSearch dt,
#footSearch dd {
  height: 30px;
}
#footSearch dd button {
  height: 30px;
  background-position: center;
}
*/

#footSNS li {
  padding: 0 !important;
}
#footSNS li:nth-of-type(2) {
  margin: 0 0 0 25px !important;
}
}


/*===================================================
フッターボトム
===================================================*/
#footerBox02 {
  margin: 60px auto 20px;
}

#footerBox02 > ul {
  align-items: center;
}

#footerBox02 > ul > li {
  font-size: 14px;
}
#footerBox02 > ul > li span {
  font-size: 17px;
	font-feature-settings: normal;
}

#footerBox02 > ul > li:first-of-type {
  line-height: 64px;
}
#footerBox02 > ul > li:first-of-type > span {
  display: inline-block;
  background: url("../../images/teshigoto.svg") no-repeat 0 center / 70px 64px;
  padding-left: 100px;
}

@media (max-width: 768px) {
#footerBox02 {
  margin: 40px auto 30px;
}

#footerBox02 > ul > li {
  width: 100%;
  font-size: 12px;
  text-align: center;
}
#footerBox02 > ul > li span {
  font-size: 14px;
}

#footerBox02 > ul > li:first-of-type {
  line-height: 54px;
}
#footerBox02 > ul > li:first-of-type > span {
  background-size: 59px 54px;
  padding-left: 70px;
}

#footerBox02 > ul > li:nth-of-type(2) {
  margin: 30px 0 15px;
}
}


/*===================================================
コピーライト
===================================================*/
#copyright {
  font-size: 12px;
  line-height: 1;
  letter-spacing: .2em;
  text-align: center;
}

@media (max-width: 768px) {
#copyright {
  font-size: 10px;
}
}