@charset "UTF-8";

header .logo svg {
  filter: none;
  -webkit-filter: none;
}
header .logo svg .st1 {
  fill: #fff;
}
header .logo svg .st0 {
  fill: #1A1311;
}


@media screen and (max-width: 768px) {

}
@media screen and (min-width: 769px) {

  header {
    background: #fff;
  }
  .header_inner {
    max-width: 1200px;
    height: 84px;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .header_inner nav ul:not(.child) {
    max-width: 1200px;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .header_inner nav ul:not(.child) > li {
    margin-left: 3em;
    position: relative;
  }
  .header_inner nav > ul > li>* {
    /* color: #fff; */
    cursor: pointer;
    display: block;
    font-size: 18px;
    padding: 10px 0;
    position: relative;
  }
  .header_inner nav > ul > li > *:after {
    content: "";
    position: absolute;
    bottom: 2px;
    left: 0;
    width: 0;
    height: 2px;
    background: #000;
    transition: all .3s;
    -webkit-transition: all .3s;
    -ms-transition: all .3s;
  }
  .header_inner nav > ul > li:hover > *:after {
    width: 100%;
  }


  .header_inner nav li ul.child {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: 100%;
    left: 0;
    width: 240%;
    left: -70%;
    height: 0;
    text-align: center;
    transition: all .3s;
    -webkit-transition: all .3s;
    -ms-transition: all .3s;
    background: rgba(255, 255, 255, .7);
}
  .header_inner nav li.has_child:hover ul {
    display: block;
    visibility: visible;
    opacity: 1;
    height: 160%;
    padding-top: .2em;
  }
  .header_inner nav li ul.child a {
    display: block;
    padding: .2em 0;
    color: #000 !important;
  }
  .header_inner nav li ul.child a:hover {}


  .header_inner .logo {
    width: 260px;
    max-width: none;
  }
  .header_inner .logo svg {
    height: 60px;
  }

}


@media screen and (max-width: 768px) {

}
@media screen and (min-width: 769px) {

  .inner_wrap {
    max-width: 1000px;
    width: 94%;
  }

}

@media screen and (min-width: 1500px) {}


main {
  margin-top: 0;
  color: #333;
  background-image: url(../images/common/message_bg.jpg);
  background-size: 380px auto;
}

/* -----------------------------------------------
mv_wrap
----------------------------------------------- */

.mv {
  position: static;
  background-image: url(../images/common/message_bg.jpg);
  background-size: 380px auto;
}
.mv_fx_cap h1 {
  font-weight: normal;
}
.mv_fx_wrap .mv_fx_img img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 5px;
}


@media screen and (max-width: 768px) {

  .mv {
    margin-top: 68px;
  }
  .mv_fx_wrap {
    padding-bottom: 50px;
  }
  .mv_fx_wrap .mv_fx_cap {
    padding: 50px 0 18px;
    text-align: center;
  }
  .mv_fx_cap h1 {
    font-size: 3rem;
    letter-spacing: .06em;
    margin-bottom: 22px;
  }
  .mv_fx_cap p {
    font-size: 1.4rem;
    letter-spacing: .01em;
    line-height: 1.8;
    display: inline-block;
    text-align: left;
  }

  .mv .inner_wrap,
  .brand_list_wrap.inner_wrap {
    width: 86.67%;
  }


}


@media screen and (min-width: 769px) {

  .mv {
    margin-top: 84px;
    padding: 50px 0;
  }
  .mv_fx_wrap.inner_wrap {
    max-width: 1100px;
  }
  .mv_fx_wrap {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
  }
  .mv_fx_wrap .mv_fx_cap {
    max-width: 520px;
    width: 47.273%;
    margin-bottom: 3%;
  }
  .mv_fx_cap h1 {
    font-size: 46px;
    letter-spacing: .06em;
    margin-bottom: .58em;
  }
  .mv_fx_cap p {
    font-size: 17px;
    letter-spacing: .01em;
    line-height: 2.4;
  }
  .mv_fx_wrap .mv_fx_img {
    max-width: 540px;
    width: 49.09%;
  }

}








/* -----------------------------------------------
brand_list_wrap
----------------------------------------------- */
.brand_list_wrap {}
.brand_item {
  background: #fff;
  border: 1px solid #DDDDDD;
  border-radius: 5px;
}
.brand_img {
  border-bottom: 1px solid #DDDDDD;
}
.brand_img picture,
.brand_img picture img {
  display: block;
  margin-inline: auto;
}
.brand_img picture img {
  width: 100%;
  height: auto;
}
ul.link_list {
  margin-inline: auto;
}
.link_list li {
  border: 1px solid #000;
}
.link_list a,
.link_list span {
  display: block;
  position: relative;
  transition: all .3s;
  padding-left: 1em;
}
.link_list .normal a {}
.link_list .fair a,
.link_list .fair span {
  background: #000;
  color: #fff;
}
.link_list .normal a::before,
.link_list .normal a::after {
  background: #000;
}
.link_list .fair a::before,
.link_list .fair a::after {
  background: #fff;
}

.link_list a::before,
.link_list a::after {
  content: '';
  position: absolute;
  background: #333;
  right: 5%;
}
.link_list a::before {
  top: 50%;
  width: 22px;
  height: 1px;
}
.link_list a::after {
  top: calc(50% - 2px);
  width: 6px;
  height: 1px;
  transform: rotate(35deg);
}
.link_list li:has(span) {
  border-color: #a3a3a3;
}
.link_list .fair span {
  pointer-events: none;
  background: #a3a3a3;
}
.link_list li:has(span.blank) {
  visibility: hidden;
}



@media screen and (max-width: 768px) {

  .brand_list_wrap {
    padding-bottom: 130px;
  }
  .brand_list .brand_item {
    width: 100%;
    margin-bottom: 25px;
    padding: 30px 30px 20px;
  }
  .brand_list picture {
    width: 47.63%;
    padding-bottom: 20px;
  }
  ul.link_list {
    width: 100%;
    margin-top: 18px;
  }
  .link_list li {
    margin-bottom: 10px;
  }
  .link_list li a,
  .link_list li span {
    line-height: 58px;
    font-size: 1.4rem;
  }

}


@media screen and (min-width: 769px) {

  .brand_list_wrap {
    padding-bottom: 130px;
  }
  .brand_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
  }
  .brand_list .brand_item {
    width: calc((100% - 40px) / 3);
    margin-bottom: 20px;
    padding: 28px;
  }
  .brand_item:not(:nth-child(3n)) {
    margin-right: 20px;
  }
  .brand_list picture {
    width: 48.63%;
    max-width: 126px;
    padding-bottom: 19px;
  }
  ul.link_list {
    width: 86%;
    max-width: 220px;
    margin-top: 18px;
  }
  .link_list li {
    margin-bottom: 10px;
  }
  .link_list li a,
  .link_list li span {
    line-height: 38px;
    font-size: 14px;
  }
  .link_list .fair a[href=""]::after {
    font-size: 14px;
    line-height: 36px;
  }
  .link_list .normal a:hover {
    color: #fff;
    background: #000;
  }
  .link_list .fair a:hover {
    color: #000;
    background: #fff;
  }
  .link_list .fair a:hover::before,
  .link_list .fair a:hover::after {
    background: #000;
  }
  .link_list .normal a:hover::before,
  .link_list .normal a:hover::after {
    background: #fff;
  }

}

