@charset "UTF-8";
html {
  font-size: 10px;
}

body,
td,
th,
input,
textarea {
  color: #000000;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ W6", "Hiragino Kaku Gothic W6", "ヒラギノ角ゴ W3", "Hiragino Kaku Gothic W3", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif !important;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
}

body {
  overflow-wrap: break-word;
}

a {
  color: #000000;
  text-decoration: none;
  /*
  filter: alpha(opacity=80);
  -ms-filter: "alpha(opacity=80)";
  opacity: .80;
*/
}

a:hover {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

.img_ck {
  font-size: 0.1rem;
  line-height: 0;
}

/* clearfix (micro) */
.clearfix:before,
.clearfix:after {
  content: ' ';
  display: table;
}

.clearfix:after {
  clear: both;
}

/* For IE 6/7 only */
.clearfix {
  *zoom: 1;
}

* {
  margin: 0;
  padding: 0;
  word-break: break-word;
  -moz-box-sizing: border-box;
       box-sizing: border-box;
}

*::before, *::after {
  -moz-box-sizing: border-box;
       box-sizing: border-box;
}

iframe {
  border: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
}

ul,
ol,
li {
  list-style: none;
}

input,
select,
textarea,
button {
  outline: none;
}

picture {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6,
div,
p,
ul,
ol,
li,
dl,
dt,
dd,
figure,
img,
nav {
  margin: 0;
  padding: 0;
}

@media screen and (min-width: 769px), print {
  .show_sp {
    display: none !important;
  }
  .container {
    min-width: 1200px;
    margin: 0 auto;
    overflow: hidden;
  }
  .row {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
  }
  a[href^=tel] {
    pointer-events: none;
    text-decoration: none;
    opacity: 1 !important;
    cursor: default !important;
  }
  a {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  a:hover {
    opacity: 0.7;
  }
  /*======= COMMON =========*/
}

@media screen and (max-width: 768px) {
  body {
    font-size: 2.73438vw;
  }
  .container {
    overflow: hidden;
    min-width: 320px;
  }
  .show_pc {
    display: none !important;
  }
  .row {
    padding-left: 3.90625vw;
    padding-right: 3.90625vw;
  }
  .row_inner {
    padding-left: 3.90625vw;
    padding-right: 3.90625vw;
  }
  a[href^=tel] {
    text-decoration: none;
  }
  /*======= COMMON =========*/
  header {
    background-color: #231815;
  }
  header.fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 999;
  }
  header .bHeader {
    padding: 3.25521vw 3.90625vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header .bHeader__logo {
    line-height: 0;
  }
  header .bHeader__logo a {
    display: inline-block;
    line-height: 0;
  }
  header .bHeader__logo a img {
    width: 38.67188vw;
    height: auto;
  }
  header .bHeader__right__iconNav {
    width: 6.51042vw;
    height: 6.51042vw;
    position: relative;
    -webkit-transform: rotate(0deg);
       -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
            transform: rotate(0deg);
    cursor: pointer;
    z-index: 100;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    z-index: 999;
  }
  header .bHeader__right__iconNav span {
    display: block;
    position: absolute;
    height: 0.52083vw;
    width: 6.51042vw;
    background: #fff;
    opacity: 1;
    left: 0;
    -webkit-transform: rotate(0deg);
       -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
            transform: rotate(0deg);
    -webkit-transition: .25s ease-in-out;
    -moz-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
  }
  header .bHeader__right__iconNav span:nth-child(1) {
    top: 0.65104vw;
  }
  header .bHeader__right__iconNav span:nth-child(2) {
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  header .bHeader__right__iconNav span:nth-child(3) {
    bottom: 0.65104vw;
  }
  header .bHeader__right__iconNav.open span:nth-child(1) {
    top: 2.86458vw;
    -webkit-transform: rotate(135deg);
       -moz-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
            transform: rotate(135deg);
    background-color: #231815;
  }
  header .bHeader__right__iconNav.open span:nth-child(2) {
    opacity: 0;
  }
  header .bHeader__right__iconNav.open span:nth-child(3) {
    bottom: 3.25521vw;
    background-color: #231815;
    -webkit-transform: rotate(-135deg);
       -moz-transform: rotate(-135deg);
        -ms-transform: rotate(-135deg);
            transform: rotate(-135deg);
  }
  header .bHeader__right .nav {
    background-color: #fff;
    padding: 13.02083vw 0 6.51042vw;
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 99;
    visibility: hidden;
    -webkit-backface-visibility: hidden;
       -moz-backface-visibility: hidden;
            backface-visibility: hidden;
    opacity: 0;
    -webkit-transition: all 0.35s linear;
    -moz-transition: all 0.35s linear;
    transition: all 0.35s linear;
    overflow-y: scroll;
  }
  header .bHeader__right .nav.open {
    opacity: 1;
    visibility: visible;
  }
  header .bHeader__right .nav ul li a {
    font-size: 3.90625vw;
    line-height: 1;
    font-weight: 500;
    color: #000;
    padding: 3.90625vw 0;
    display: block;
    font-weight: 500;
    text-align: center;
  }
  footer {
    background-color: #000;
    padding-bottom: 29.6875vw;
  }
  footer .bScroll {
    position: fixed;
    bottom: -29.6875vw;
    right: 0;
    width: 100%;
    z-index: 98;
    -webkit-transition: bottom 0.6s ease-out;
    -moz-transition: bottom 0.6s ease-out;
    transition: bottom 0.6s ease-out;
    text-align: right;
  }
  footer .bScroll a {
    display: inline-block;
  }
  footer .bScroll a img {
    width: 61.06771vw;
    height: auto;
  }
  footer .bScroll.active {
    bottom: 0;
  }
  footer .bFooter {
    text-align: center;
    padding: 7.8125vw 0 5.20833vw;
  }
  footer .bFooter__logoFt {
    line-height: 0;
    margin-bottom: 3.90625vw;
  }
  footer .bFooter__logoFt a {
    line-height: 0;
    display: inline-block;
  }
  footer .bFooter__logoFt a img {
    width: 52.08333vw;
    height: auto;
  }
  footer .bFooter__tel {
    color: #fff;
    font-size: 3.90625vw;
    font-weight: bold;
    letter-spacing: 0.13021vw;
    margin-bottom: 3.25521vw;
  }
  footer .bFooter__tel a {
    color: #fff;
  }
  footer .bFooter__listSocial {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 5.20833vw;
  }
  footer .bFooter__listSocial li:not(:last-child) {
    margin-right: 2.60417vw;
  }
  footer .bFooter__listSocial li a img {
    width: 5.85938vw;
    height: auto;
  }
  footer .bFooter__address {
    display: block;
    font-style: normal;
    font-size: 3.125vw;
    color: #fff;
    line-height: 4.42708vw;
  }
  footer .bFooter__copyRight {
    font-size: 2.60417vw;
    line-height: 1;
    color: #fff;
    margin-top: 3.90625vw;
    letter-spacing: 0.13021vw;
  }
}
