@charset "UTF-8";
/* Scss Document */
/* ==============================================================
*  ベース
* ============================================================ */
html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p, div, span, img, a, table, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

article, header, footer, aside, figure, figcaption, nav, section {
  display: block; }

html {
  font-size: 62.5%; }
  @media screen and (max-width: 970px) {
    html {
      font-size: 54.69%; } }
  @media screen and (max-width: 750px) {
    html {
      font-size: 46.88%; } }

body {
  line-height: 1;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

ol, ul {
  list-style: none;
  list-style-type: none; }

a {
  display: block;
  text-decoration: none; }

button {
  background: none;
  background-color: transparent;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0; }

input[type="text"] {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none; }

input[type="radio"] {
  display: none; }

input[type="checkbox"] {
  display: none; }

textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  resize: none;
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
  font-family: inherit;
  line-height: inherit; }

body {
  font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif;
  font-weight: 600;
  font-size: 1.4rem;
  width: 100%;
  height: 100%; }

body,
html {
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch; }

h1, h2, h3, h4, h5 {
  font-weight: normal; }

iframe {
  box-sizing: border-box;
  border: none; }

img {
  vertical-align: bottom; }
  @media screen and (max-width: 1170px) {
    img {
      width: 100%; } }

.pc {
  display: block; }
  @media screen and (max-width: 750px) {
    .pc {
      display: none; } }

.tab {
  display: none; }
  @media screen and (max-width: 970px) {
    .tab {
      display: block !important; } }

.sp {
  display: none; }
  @media screen and (max-width: 750px) {
    .sp {
      display: block; } }

.sp_small {
  display: none; }
  @media screen and (max-width: 400px) {
    .sp_small {
      display: block; } }

.container {
  max-width: 1024px;
  width: 90%;
  margin: 0 auto; }

/* テキスト ****************************/
/* キャプション */
.caption {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.8;
  font-family: "Noto Sans CJK JP", "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif; }

/* リンク ****************************/
a {
  color: #FFF; }

/* ボタン ****************************/
/* 資料請求・来場予約 */
.btn-req,
.btn-res,
.btn-online {
  text-align: center;
  color: #FFF;
  font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif;
  letter-spacing: 0.05em;
  font-size: 1.4rem;
  line-height: 1.2; }
  .btn-req a,
  .btn-res a,
  .btn-online a {
    color: #FFF; }
  .btn-req p,
  .btn-res p,
  .btn-online p {
    font-family: "EB Garamond", serif;
    letter-spacing: 0.1em;
    font-size: calc(12px + 2 * ((100vw - 1170px) / 750));
    font-weight: 500;
    margin-bottom: .5rem; }

/* 資料請求 */
.btn-req a {
  position: relative;
  z-index: 1;
  background: #6b5e46;
  background: linear-gradient(90deg, #6b5e46 0%, #bc9c60 100%);
  transition: all 0.3s ease 0s; }
  .btn-req a p {
    color: #E2D6BF; }
  .btn-req a:hover::before {
    opacity: 1; }
  .btn-req a:hover {
    opacity: 0.8; }

/* 来場予約 */
.btn-res a {
  position: relative;
  z-index: 1;
  background: #3e656a;
  background: linear-gradient(120deg, #3e656a 0%, #045964 100%);
  transition: all 0.3s ease 0s; }
  .btn-res a p {
    color: #8AB0B5; }
  .btn-res a:hover::before {
    opacity: 1; }
  .btn-res a:hover {
    opacity: 0.8; }

/* オンライン相談予約 */
.btn-online a {
  position: relative;
  z-index: 1;
  background: #092068;
  background: linear-gradient(90deg, #092068 0%, #4b5284 100%); }
  .btn-online a p {
    color: #BCBFCE; }
  .btn-online a:hover::before {
    opacity: 1; }
  .btn-online a:hover {
    opacity: 0.8; }

/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#092068+0,757ba4+100 */
/* 印刷する等のボタン */
.btn-link {
  text-align: center;
  border: solid 1px #7E7E7E;
  font-size: 1.6rem;
  overflow: hidden;
  position: relative;
  z-index: 1; }
  .btn-link a {
    display: block;
    padding: 2.5rem;
    color: #FFF;
    position: relative; }
    .btn-link a::before {
      font-family: "Material Icons";
      position: absolute;
      font-size: 3.0rem;
      right: 1rem;
      top: 26%;
      content: '';
      color: #FFF; }
    .btn-link a::after {
      background: #FFF;
      position: absolute;
      top: 0;
      left: 0;
      content: '';
      width: 100%;
      height: 100%;
      transform: scale(0, 1);
      transform-origin: left top;
      transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
      z-index: -1; }
    .btn-link a:hover {
      color: #333; }
      .btn-link a:hover::after {
        transform: scale(1, 1); }
      .btn-link a:hover::before {
        color: #333; }
  .btn-link.googlemap {
    max-width: 370px;
    width: 70%;
    margin: 3rem auto 0; }
    .btn-link.googlemap a::before {
      font-family: "Material Icons";
      position: absolute;
      font-size: 2.2rem;
      right: 1rem;
      top: 30%;
      content: '';
      font-weight: 500; }

/* 下層ページ ****************************/
/* ページタイトル */
.page-title {
  position: relative;
  height: 150px;
  padding-top: 12rem;
  background-size: cover !important;
  /* h2 */ }
  @media screen and (max-width: 750px) {
    .page-title {
      height: 80px;
      padding-top: 11rem; } }
  .page-title .h2-wrap {
    text-align: center;
    letter-spacing: 0.2em; }
    @media screen and (max-width: 970px) {
      .page-title .h2-wrap {
        margin-top: 5rem; } }
    @media screen and (max-width: 750px) {
      .page-title .h2-wrap {
        margin-top: 0; } }
    .page-title .h2-wrap .sub {
      color: #FFF;
      font-size: 1.4rem;
      margin-top: 1.5rem; }
  .page-title .h2-common {
    font-weight: normal;
    font-family: "EB Garamond", serif;
    font-size: 4.0rem;
    color: #C8BDA8; }
  .page-title .img-cap {
    position: absolute;
    bottom: 1rem;
    right: 1rem; }

/* パンくず */
.breadcrumbs {
  margin: 3rem auto 6rem; }
  @media screen and (max-width: 1170px) {
    .breadcrumbs {
      margin: 3rem auto 5rem; } }
  .breadcrumbs ol {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex; }
    .breadcrumbs ol li {
      font-size: 1.2rem;
      color: #FFF; }
      .breadcrumbs ol li a {
        text-decoration: underline;
        display: inline-block; }
      .breadcrumbs ol li span {
        margin: 0 1rem;
        color: #797e89;
        font-weight: 600; }

/* h3 */
.h3-wrap .text {
  color: #FFF;
  font-size: 1.6rem;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 2.4;
  margin: 3.5rem auto;
  width: 90%; }
  @media screen and (max-width: 750px) {
    .h3-wrap .text {
      text-align: left;
      margin: 2rem auto; } }

.h3-common {
  text-align: center;
  width: 90%;
  margin: 0 auto;
  font-size: 2.8rem;
  line-height: 1.6;
  color: #A89F8D; }
  @media screen and (max-width: 750px) {
    .h3-common {
      font-size: 2.4rem;
      line-height: 1.8; } }
  .h3-common.en {
    font-family: "EB Garamond", serif;
    letter-spacing: .1em;
    margin-bottom: 2.5rem; }

/* image photoキャプション */
.img {
  position: relative; }
  .img-cap {
    font-size: 1.2rem;
    font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif;
    position: absolute;
    bottom: 2rem;
    right: 1rem; }
    .img-cap.wh {
      color: #fff;
      text-shadow: 2px 2px 3px #000; }
    .img-cap.bk {
      color: #000; }
  .img-cap-bg {
    background: rgba(0, 0, 0, 0.8);
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 0.5rem;
    color: #FFF;
    font-size: 1.2rem; }

/* ==============================================================
*  レイアウト
* ============================================================ */
/*---------------------------------
headerレイアウト
---------------------------------*/
body.fixed {
  position: fixed;
  width: 100%; }

header {
  border-bottom: 3px solid #A89F8D;
  position: fixed;
  z-index: 20;
  width: 100%; }
  @media screen and (max-width: 1280px) {
    header {
      width: 100%; } }
  header .header {
    font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif;
    background: #000;
    height: 60px; }
    @media screen and (max-width: 1280px) {
      header .header {
        width: 100%;
        z-index: 20; } }

.header-wrapper {
  width: 100%;
  margin: 0 auto;
  position: relative;
  background: #000;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  -webkit-justify-content: space-between;
  align-items: center;
  -webkit-align-items: center; }
  @media screen and (max-width: 1280px) {
    .header-wrapper {
      width: 95%;
      padding: 0; } }
  .header-wrapper .header-h1-gnav {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    -webkit-align-items: center;
    width: 70%;
    max-width: 1150px; }
    @media screen and (max-width: 1280px) {
      .header-wrapper .header-h1-gnav {
        width: 100%;
        background: #000; } }
    .header-wrapper .header-h1-gnav img {
      max-width: 100%; }
    .header-wrapper .header-h1-gnav .head-h1 {
      margin: 0 5rem 0 2rem;
      max-width: 210px;
      /*width: 16.5%;*/
      z-index: 20; }
      @media screen and (max-width: 1280px) {
        .header-wrapper .header-h1-gnav .head-h1 {
          margin: 0 5rem 0 2rem; } }
      @media screen and (max-width: 1280px) {
        .header-wrapper .header-h1-gnav .head-h1 {
          margin: 10px 0 0 0; } }
  .header-wrapper .head-link {
    width: 30%;
    max-width: 535px;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center; }
    @media screen and (max-width: 1700px) {
      .header-wrapper .head-link {
        max-width: inherit; } }
    @media screen and (max-width: 1280px) {
      .header-wrapper .head-link {
        display: none; } }
    .header-wrapper .head-link .sub {
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      flex-wrap: wrap;
      flex-wrap: -webkit-wrap;
      font-size: calc(9px + 3 * ((100vw - 1170px) / 750));
      width: 43%; }
      .header-wrapper .head-link .sub li {
        margin-right: 1.5rem; }
        .header-wrapper .head-link .sub li:first-child {
          margin-bottom: .5rem; }
        .header-wrapper .head-link .sub li a {
          color: #FFF;
          transition: all 0.3s ease 0s; }
          .header-wrapper .head-link .sub li a:before {
            font-family: 'Material Icons';
            content: ' ';
            vertical-align: bottom; }
    .header-wrapper .head-link .btns_res-req {
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      justify-content: space-between;
      -webkit-justify-content: space-between;
      width: 57%; }
      .header-wrapper .head-link .btns_res-req .btn-res,
      .header-wrapper .head-link .btns_res-req .btn-req,
      .header-wrapper .head-link .btns_res-req .btn-online {
        width: 50%;
        font-size: calc(10px + 6 * ((100vw - 1170px) / 750));
        display: flex; }
        .header-wrapper .head-link .btns_res-req .btn-res a,
        .header-wrapper .head-link .btns_res-req .btn-req a,
        .header-wrapper .head-link .btns_res-req .btn-online a {
          width: 100%;
          height: 60px;
          padding: 1.2rem 0;
          display: flex;
          justify-content: center;
          align-items: center; }
          @media screen and (max-width: 1280px) {
            .header-wrapper .head-link .btns_res-req .btn-res a,
            .header-wrapper .head-link .btns_res-req .btn-req a,
            .header-wrapper .head-link .btns_res-req .btn-online a {
              height: 45px; } }
          .header-wrapper .head-link .btns_res-req .btn-res a:hover,
          .header-wrapper .head-link .btns_res-req .btn-req a:hover,
          .header-wrapper .head-link .btns_res-req .btn-online a:hover {
            box-shadow: none !important; }

.head-gnav .close-sp {
  display: none;
  		/*@include max-screen($breakpoint-lg){
  			display: block;
  			text-align: center;
  			background:#000;
        cursor: pointer;
  			p{
  				color:#FFF;
  				padding: 1.5rem 0;
  				width: 60%;
  				margin: 0 auto;
  			}
  			p:before{
  				font-family: 'Material Icons';
  				content: ' '; 
  			}
  		}*/ }

/* ハンバーガーボタン　*/
.btn-hamburger {
  display: none; }
  @media screen and (max-width: 1280px) {
    .btn-hamburger {
      display: block;
      z-index: 20;
      position: absolute;
      top: -0.2rem;
      right: 0;
      margin-left: 0;
      width: 30px;
      height: 30px;
      cursor: pointer; } }
  .btn-hamburger .menu {
    display: none; }
    @media screen and (max-width: 1280px) {
      .btn-hamburger .menu {
        display: block;
        color: #A89F8D;
        font-size: 1.1rem;
        text-align: center;
        position: absolute;
        top: 40px;
        left: -1px;
        font-family: "EB Garamond", serif; } }
    @media screen and (max-width: 750px) {
      .btn-hamburger .menu {
        left: 1px; } }
  @media screen and (max-width: 1280px) {
    .btn-hamburger .line {
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 30px;
      height: 3px;
      background: #A89F8D;
      -webkit-transition: all 0.3s ease-out;
      transition: all 0.3s ease-out; } }
  @media screen and (max-width: 1280px) {
    .btn-hamburger .line_01 {
      top: 16px; } }
  @media screen and (max-width: 1280px) {
    .btn-hamburger .line_02 {
      top: 24px; } }
  @media screen and (max-width: 1280px) {
    .btn-hamburger .line_03 {
      top: 32px; } }

@media screen and (max-width: 1280px) {
  .btn-hamburger.is-active .line_01 {
    top: 24px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg); } }
@media screen and (max-width: 1280px) {
  .btn-hamburger.is-active .line_02 {
    opacity: 0; } }
@media screen and (max-width: 1280px) {
  .btn-hamburger.is-active .line_03 {
    top: 24px;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg); } }

/*---------------------------------
gnav
---------------------------------*/
@media screen and (max-width: 1280px) {
  .head-gnav .nav {
    width: 100%;
    background: none;
    position: fixed;
    transform: translateY(-100%);
    transition: opacity 1.8s ease-out,transform 0.6s,background 0.3s;
    z-index: 15;
    top: 0;
    left: 0;
    overflow: auto;
    height: 92%;
    -webkit-overflow-scrolling: touch;
    opacity: 0; } }
@media screen and (max-width: 1280px) {
  .head-gnav .nav.is-active {
    transform: translateY(63px);
    opacity: 1;
    background: #000; } }
.head-gnav .nav ul {
  margin: 0 auto;
  position: relative;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  -webkit-justify-content: space-between;
  align-items: center;
  -webkit-align-items: center;
  flex-wrap: wrap;
  flex-wrap: -webkit-wrap; }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav ul {
      height: auto;
      z-index: 99; } }
.head-gnav .nav li {
  color: #838383;
  /*width : calc(100% / 7);*/
  margin-right: 2.8rem;
  font-size: calc(9px + 3 * ((100vw - 1170px) / 750));
  position: relative; }
  .head-gnav .nav li:last-child {
    margin-right: 0; }
  @media screen and (max-width: 1400px) {
    .head-gnav .nav li {
      margin-right: 2rem; } }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav li {
      margin-right: 0;
      font-size: 1.7rem;
      line-height: 1.4;
      width: calc(100% / 2);
      text-align: center;
      border-bottom: 1px solid #555;
      background: #000;
      text-align: center; } }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav li#nav_brand {
      display: none; } }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav li#nav_location, .head-gnav .nav li#nav_plan, .head-gnav .nav li#nav_equipment, .head-gnav .nav li#nav_brand, .head-gnav .nav li#nav_brand_sp, .head-gnav .nav li#nav_map_sp {
      border-left: 1px solid #555; } }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav li#nav_outline_sp {
      border-right: 1px solid #555; } }
  .head-gnav .nav li.tab {
    display: none; }
    @media screen and (max-width: 1280px) {
      .head-gnav .nav li.tab {
        display: block;
        /*border: none;*/
        /*&::before{
          font-family: 'Material Icons';
          content: ' ';
          vertical-align: bottom;
          -webkit-transform: translate(0, -50%) scale(0.6, 1);
          left: 0;
        }*/ } }
  .head-gnav .nav li a {
    display: block;
    transition: all 0.3s ease 0s; }
    @media screen and (max-width: 1280px) {
      .head-gnav .nav li a {
        /*padding:2.5rem 0;*/
        color: #FFF;
        height: 45px;
        display: -webkit-box;
        display: -moz-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        align-items: center;
        -webkit-align-items: center;
        justify-content: center;
        -webkit-justify-content: center; } }
    .head-gnav .nav li a:hover {
      color: #A89F8D; }
    .head-gnav .nav li a.disabled {
      pointer-events: none;
      color: #555; }
  .head-gnav .nav li.here {
    /*&:after{
      position: absolute;
      bottom: -12px;
      left: 0;
      content: '';
      width: 30%;
      left: 50%;
      margin-left: -15%;
      height: 2px;
      background:#ab9453;
      @include max-screen($breakpoint-lg){
        height: 0;
      }
    }*/ }
    .head-gnav .nav li.here a {
      color: #A89F8D;
      position: relative; }
  @media screen and (max-width: 1280px) {
    .head-gnav .nav li.btn-req, .head-gnav .nav li.btn-res, .head-gnav .nav li.btn-online {
      color: #FFF;
      justify-content: center;
      -webkit-justify-content: center;
      font-size: 2rem;
      width: 100%;
      border-bottom: none; }
      .head-gnav .nav li.btn-req::before, .head-gnav .nav li.btn-res::before, .head-gnav .nav li.btn-online::before {
        content: none; }
      .head-gnav .nav li.btn-req a, .head-gnav .nav li.btn-res a, .head-gnav .nav li.btn-online a {
        font-size: 1.8rem;
        color: #FFF;
        display: block;
        font-size: 2.2rem;
        height: 60px;
        padding: 21px; }
        .head-gnav .nav li.btn-req a:hover, .head-gnav .nav li.btn-res a:hover, .head-gnav .nav li.btn-online a:hover {
          box-shadow: none !important; } }
  .head-gnav .nav li.btn-line {
    border-bottom: none; }
    .head-gnav .nav li.btn-line::before {
      content: none; }
    @media screen and (max-width: 1280px) {
      .head-gnav .nav li.btn-line {
        padding-top: 10px;
        width: 100%; } }
    .head-gnav .nav li.btn-line a {
      height: auto; }
    @media screen and (max-width: 1280px) {
      .head-gnav .nav li.btn-line img {
        width: 30%;
        margin: 0 auto; } }
    @media screen and (max-width: 750px) {
      .head-gnav .nav li.btn-line img {
        width: 50%; } }

/*---------------------------------
コンバージョンブロック
---------------------------------*/
.foot_cv-btn {
  background: #3C3C3C;
  text-align: center;
  padding: 5rem 0; }
  @media screen and (max-width: 750px) {
    .foot_cv-btn {
      padding: 6rem 0 7rem; } }
  .foot_cv-btn .btns {
    max-width: 900px;
    width: 90%;
    margin: 0 auto;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    flex-wrap: -webkit-wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between; }
    .foot_cv-btn .btns .btn-req,
    .foot_cv-btn .btns .btn-res,
    .foot_cv-btn .btns .btn-online {
      max-width: 400px;
      width: 80%;
      margin: 0 auto 2rem;
      font-size: 2.0rem;
      /*border-top:1px solid #BC9C60;*/ }
      .foot_cv-btn .btns .btn-req a,
      .foot_cv-btn .btns .btn-res a,
      .foot_cv-btn .btns .btn-online a {
        padding: 2.2rem 0; }

/*---------------------------------
キャプション
---------------------------------*/
.block-caption {
  padding: 9rem 0 3rem; }
  .block-caption .caption {
    color: #FFF; }

/*---------------------------------
footer
---------------------------------*/
footer {
  font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif; }
  footer .sitemap {
    background: #FFF;
    padding: 2rem 0;
    border-bottom: 1px solid #E8E9ED; }
    @media screen and (max-width: 750px) {
      footer .sitemap {
        background: #F2F2F2;
        padding: 0; } }
    footer .sitemap ul {
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      justify-content: space-between;
      -webkit-justify-content: space-between;
      flex-wrap: wrap;
      flex-wrap: -webkit-wrap; }
      @media screen and (max-width: 750px) {
        footer .sitemap ul {
          width: 100%; } }
      footer .sitemap ul li {
        color: #404a5e;
        font-size: 1.4rem; }
        @media screen and (max-width: 1170px) {
          footer .sitemap ul li {
            padding: 0 1.5rem; } }
        @media screen and (max-width: 750px) {
          footer .sitemap ul li {
            width: 50%;
            font-size: 1.4rem;
            text-align: center;
            padding: 1.5rem 0;
            border-bottom: 1px solid #E8E9ED; }
            footer .sitemap ul li:nth-child(odd) {
              border-right: 1px solid #E8E9ED; }
            footer .sitemap ul li:first-child {
              border-left: none; } }
        footer .sitemap ul li a {
          color: #333; }
          footer .sitemap ul li a.disabled {
            pointer-events: none;
            opacity: .3; }
  footer .footer-wrapper {
    margin: 0 auto;
    padding: 2rem 0;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center; }
    @media screen and (max-width: 750px) {
      footer .footer-wrapper {
        display: block; } }
    footer .footer-wrapper img {
      width: 100%; }
    @media screen and (max-width: 750px) {
      footer .footer-wrapper .tel .text {
        text-align: center; } }
    footer .footer-wrapper .tel .wrapper {
      margin-top: .7rem;
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      align-items: center;
      -webkit-align-items: center;
      flex-wrap: wrap;
      flex-wrap: -webkit-wrap; }
      @media screen and (max-width: 750px) {
        footer .footer-wrapper .tel .wrapper .img {
          width: 90%;
          margin: 0 auto; } }
      footer .footer-wrapper .tel .wrapper .sub {
        font-size: 1.2rem;
        margin-left: 1.5rem;
        line-height: 1.4; }
        @media screen and (max-width: 750px) {
          footer .footer-wrapper .tel .wrapper .sub {
            width: 80%;
            margin: 1rem auto 0;
            text-align: center; } }
    @media screen and (max-width: 750px) {
      footer .footer-wrapper .deve {
        width: 80%;
        margin: 0 auto; } }
    footer .footer-wrapper .deve-marimo {
      max-width: 195px; }
      @media screen and (max-width: 750px) {
        footer .footer-wrapper .deve-marimo {
          margin: 3rem auto 0; } }

/* 外部フッターデータの打消し */
.f_copy {
  background: #000; }
  @media screen and (max-width: 1170px) {
    .f_copy {
      padding: 1.5rem 0;
      margin-bottom: 52.05px; } }
  .f_copy .wrap {
    max-width: 1024px;
    width: 90%;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center;
    flex-wrap: wrap;
    flex-wrap: -webkit-wrap; }
    @media screen and (max-width: 1170px) {
      .f_copy .wrap {
        width: 100%; } }
  .f_copy .fNav {
    padding: 1.5rem 0;
    margin-bottom: 0; }
    @media screen and (max-width: 750px) {
      .f_copy .fNav {
        width: 100%;
        margin: 0 auto;
        padding: 0; } }
    .f_copy .fNav ul {
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      justify-content: space-between;
      -webkit-justify-content: space-between;
      flex-wrap: wrap;
      flex-wrap: -webkit-wrap;
      font-size: 1.2rem;
      font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif; }
      .f_copy .fNav ul li {
        padding-left: 20px;
        background: none; }
        .f_copy .fNav ul li:first-child {
          padding-left: 0; }
        @media screen and (max-width: 750px) {
          .f_copy .fNav ul li {
            width: calc(100% / 2);
            padding: 1rem 0; } }
        .f_copy .fNav ul li a {
          color: #FFF;
          display: block; }
  .f_copy .copyright {
    font-family: "Noto Serif CJK JP", "Noto Serif JP", YuMincho, "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", -apple-system, blinkMacSystemFont, serif;
    color: #FFF;
    font-size: 1.0rem; }
    @media screen and (max-width: 1170px) {
      .f_copy .copyright {
        width: 100%; } }
    @media screen and (max-width: 750px) {
      .f_copy .copyright {
        padding-top: 2rem; } }

/*ページTOP*/
.btn-page-top {
  background: #262626;
  padding: 1rem 0;
  font-family: "EB Garamond", serif; }
  .btn-page-top a {
    text-decoration: none;
    color: #fff;
    text-align: center;
    display: block;
    border-radius: 50%;
    font-size: 1.2rem; }
    .btn-page-top a p {
      text-align: center; }
      @media screen and (max-width: 1170px) {
        .btn-page-top a p {
          max-width: 63px;
          margin: 0 auto; } }

/* スマホ用固定CVボタン */
.foot-nav_sp {
  position: fixed;
  width: 100%;
  bottom: 0;
  z-index: 2; }
  .foot-nav_sp ul {
    background: #FFF;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between; }
    .foot-nav_sp ul li {
      color: #333;
      font-size: 1.3rem;
      line-height: 1.2;
      width: calc(100% / 3);
      text-align: center;
      display: -webkit-box;
      display: -moz-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      align-items: center;
      -webkit-align-items: center;
      justify-content: center; }
      .foot-nav_sp ul li a {
        color: #333;
        display: block;
        padding: 0.5rem 0; }
        .foot-nav_sp ul li a:before {
          color: #9E8A5E; }
      .foot-nav_sp ul li.map, .foot-nav_sp ul li.map_02 {
        border-right: 1px solid #ccc; }
        .foot-nav_sp ul li.map a:before, .foot-nav_sp ul li.map_02 a:before {
          display: block;
          margin-bottom: 0.5rem;
          font-size: 3.2rem;
          font-family: 'Material Icons';
          content: ""; }
      .foot-nav_sp ul li.tel {
        border-right: 1px solid #ccc; }
        .foot-nav_sp ul li.tel a:before {
          display: block;
          margin-bottom: 0.5rem;
          font-size: 3.2rem;
          font-family: 'Material Icons';
          content: ""; }
      .foot-nav_sp ul li.res a:before {
        display: block;
        margin-bottom: 0.5rem;
        font-size: 3.2rem;
        font-family: 'Material Icons';
        content: ""; }
      .foot-nav_sp ul li.line a span {
        display: block;
        width: 25px;
        margin: 0 auto .5rem; }
      .foot-nav_sp ul li.req {
        border-right: 1px solid #ccc; }
        .foot-nav_sp ul li.req a:before {
          display: block;
          margin-bottom: 0.5rem;
          font-size: 3.2rem;
          font-family: 'Material Icons';
          content: ""; }
      .foot-nav_sp ul li.online {
        border-left: 1px solid #ccc; }
        .foot-nav_sp ul li.online a:before {
          display: block;
          margin-bottom: 0.5rem;
          font-size: 3.2rem;
          font-family: 'Material Icons';
          content: "\e30c"; }

/* ==============================================================
*  モジュール（汎用的に使用できるスタイル）
* ============================================================ */
