@charset "UTF-8";

/* ===============================
レイアウト
=============================== */
.header,
.container {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
@media (max-width: 1079px) {
  .header,
  .container {
    width: 1080px;
  }
}
@media (max-width: 1023px) {
  .header,
  .container {
    width: 100%;
  }
}

.content-wrapper {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  /* 個別に幅を指定する max-width */
}
@media (max-width: 1079px) {
  .content-wrapper {
    width: 1080px;
  }
}
@media (max-width: 1023px) {
  .content-wrapper {
    width: 100%;
  }
}


/* ===============================
ヘッダー
=============================== */
body {
  position: relative;
  padding-top: 125px;
}
@media (max-width: 1023px) {
  body {
    padding-top: 112px;
  }
}

.header {
  background: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 333;
}
.header a {
    text-decoration: none;
}

/* グローバルナビ上部 */
.gnav-above {
  width: 100%;
  height: 72px;
  border-bottom: 1px solid #dddddd;
  padding-left: 80px;
  display: flex;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
@media (max-width: 1023px) {
  .gnav-above {
    height: 112px;
    border-bottom: 2px solid #dddddd;
    padding-left: 30px;
  }
}
.gnav-above .logo {
  margin: 15px auto 15px 0;
}
@media (max-width: 1023px) {
  .gnav-above .logo {
    margin: 25px auto 25px 0;
  }
}
.gnav-above .logo a {
  display: block;
  width: 168px;
  height: 42px;
  background: url("../../image/logo.jpg") no-repeat;
}
@media (max-width: 1023px) {
  .gnav-above .logo a {
    display: block;
    width: 220px;
    height: 54px;
    background: url("../../image/sp/logo.jpg") no-repeat;
      background-size: cover
  }
}
.gnav-above .gnav-above-doc-request-bnr {
  width: 204px;
  height: 72px;
    position: relative;
    z-index:1;
}
@media (max-width: 1023px) {
  .gnav-above .gnav-above-doc-request-bnr {
    display: none;
  }
}
.gnav-above .gnav-above-tel-contact-bnr {
  width: 296px;
  height: 72px;
    position: relative;
    z-index:1;
}
@media (max-width: 1023px) {
  .gnav-above .gnav-above-tel-contact-bnr {
    display: none;
  }
}

/* グローバルナビ */
.gnav {
  width: 100%;
  border-bottom: 1px solid #dddddd;
  height: 53px;
  padding-left: 80px;
  padding-right: 80px;
  /* スマホ用メニュー・メニューボタン */
}
@media (max-width: 1023px) {
  .gnav {
    padding-left: 0;
    padding-right: 0;
    position: relative;
    border-bottom: none;
    height: auto;
  }
}
.gnav ul {
  display: flex;
}
@media (max-width: 1023px) {
  .gnav ul {
    flex-direction: column;
  }
}
@media (max-width: 1023px) {
  .gnav ul li {
    width: 100%;
    background: url(../../image/sp/menu-arrow.png) no-repeat right 29px center;
  }
}
.gnav ul li:first-child a {
  margin-left: 0;
}
.gnav ul li a {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1;
  color: #332424;
  font-weight: bold;
  display: block;
  padding: 19px 0 17px;
  margin: 0 20px;
}
@media (max-width: 1023px) {
  .gnav ul li a {
    font-size: 26px;
    font-size: 1.625rem;
    padding: 32px 33px 30px;
    margin-left: 0;
    border-bottom: 2px solid #dddddd;
  }
}
.gnav ul li a:hover, .gnav ul li a.active {
  color: #bf1139;
  border-bottom: 3px solid #bf1139;
}
@media (max-width: 1023px) {
  .gnav ul li a:hover, .gnav ul li a.active {
    color: #332424;
    border-bottom: 2px solid #dddddd;
  }
}
.gnav .toggle-btn-label,
.gnav #mc_toggle-btn {
  /* スマホ用メニューボタン */
  display: none;
}
.gnav .sp-bnr {
  /* スマホ用メニュー内バナー */
  display: none;
}
@media (max-width: 1023px) {
  .gnav .toggle-btn-label {
    cursor: pointer;
    display: inline-block;
    position: absolute;
    top: -114px;
    right: 0;
    width: 112px;
    height: 112px;
    background: url("../../image/sp/toggle-btn.jpg") no-repeat center center;
  }
  .gnav .menu {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 999;
    background: #ffffff;
      height:calc(100vh - 114px);
      overflow: scroll;
  }
  @keyframes show {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  .gnav #mc_toggle-btn:checked ~ .toggle-btn-label {
    background: url("../../image/sp/toggle-close-btn.jpg") no-repeat center center;
  }
  .gnav #mc_toggle-btn ~ .menu {
    display: none;
  }
  .gnav #mc_toggle-btn:checked ~ .menu {
    display: block;
    animation: show .3s;
  }
  .gnav .sp-bnr {
    display: block;
    padding-top: 61px;
    padding-bottom: 85px;
  }
  .gnav .sp-bnr .sp-bnr-title {
    font-size: 26px;
    font-size: 1.625rem;
    margin-bottom: 40px;
    text-align: center;
    font-weight: bold;
  }
  .gnav .sp-bnr .gnav-sp-tel-contact-bnr {
    margin: 0 auto 30px;
    width: 468px;
    height: 88px;
    background: url(../../image/sp/gnav-sp-tel-contact-bnr.jpg) no-repeat;
  }
  .gnav .sp-bnr .gnav-sp-tel-contact-bnr a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .gnav .sp-bnr .gnav-sp-doc-request-bnr {
    margin: 0 auto 63px;
    width: 468px;
    height: 88px;
    background: url(../../image/sp/gnav-sp-doc-request-bnr.jpg) no-repeat;
  }
  .gnav .sp-bnr .gnav-sp-doc-request-bnr a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .gnav .sp-bnr .gnav-sp-living-bnr {
    margin: 0 auto;
    width: 468px;
    height: 356px;
    background: url(../../image/sp/gnav-sp-living-bnr.jpg) no-repeat;
  }
  .gnav .sp-bnr .gnav-sp-living-bnr a {
    display: block;
    width: 100%;
    height: 100%;
  }
}

/* 大画面対応 */
@media (min-width: 1921px) {
  .gnav-above,
  .gnav {
    padding-left: 0px;
    padding-right: 0px;
  }
}

/* スクリーンリーダ用 文字は非表示
------------------------------- */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* グローバルナビスクロール時の表示 */
@media (min-width: 1024px) {
  .smaller .logo {
    display: none;
  }
}
@media (min-width: 1024px) {
  .smaller .gnav {
    position: absolute;
    top: 0;
    left: 0;
    border: none;
    height: 72px;
  }
  .smaller .gnav ul {
    width: 840px;
    flex-wrap: wrap;
  }
  .smaller .gnav ul li a {
    padding: 34px 0 21px;
    margin: 0 20px;
  }
}
@media (max-width: 1536px) {
  .smaller .gnav {
    padding-left: 15px;
  }
}
@media (max-width: 1340px) {
  .smaller .gnav ul {
    flex-wrap: wrap;
  }
  .smaller .gnav ul li a {
    margin: 0 10px;
  }
}
@media (min-width: 1024px) {
  .smaller .gnav-above .gnav-above-tel-contact-bnr {
    position: absolute;
    right: 204px;
  }
  .smaller .gnav-above .gnav-above-doc-request-bnr {
    position: absolute;
    right: 0;
  }
}


@media screen and ( min-width:1024px ) {
    .gnav-above-tel-contact-bnr,
    .fnav-tel-contact-bnr a,
    .about-shop-contact-bnr,
    .contact-bnr a {
        pointer-events: none;
        cursor: default;
    }
}