@charset "UTF-8";
:root {
  --color-white: #fff;
  --color-contrast: #f9efeb;
  --color-contrast02: #f8f4ea;
  --color-contrast03: #f2f2f2;
  --color-contrast04: #fff2d5;
  --color-accent: #f25a5a;
  --color-accent02: #e72b31;
  --color-accent03: #ffed4d;
  --color-main: #32190e;
  --color-black: #222;
  --color-black02: #000;
  --color-link: #00f;
  --color-txt: #32190e;
  --color-gray: #ccc;
  --color-gray02: #707070;
  --color-gray03: #b2b2b2;
  --color-gray04: #808080;
  --color-gray05: #f2f2f2;
  --color-gray06: #9b9b9b;
  --color-gray07: #ebebeb;
}

/* =======================================================
基本設定
======================================================= */
@font-face {
  font-family: noto-sans-jp;
  font-weight: normal;
  src: url("../fonts/Noto-Sans-JP/NotoSansJP-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: noto-sans-jp;
  font-weight: 500;
  src: url("../fonts/Noto-Sans-JP/NotoSansJP-Medium.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: noto-sans-jp;
  font-weight: bold;
  src: url("../fonts/Noto-Sans-JP/NotoSansJP-Bold.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: noto-serif-jp;
  font-weight: normal;
  src: url("../fonts/Noto-Serif-JP/NotoSerifJP-Regular.woff") format("woff");
  font-display: swap;
}
* {
  padding: 0;
  margin: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  font-style: normal;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  overflow-wrap: break-word;
  outline: none;
  box-shadow: none;
  line-break: strict;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

*,
*:focus,
a:focus {
  outline: none;
}

html {
  font-size: min(calc(16 / 1464 * 100vw), 16px);
}

body {
  font-family: noto-sans-jp, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.0625rem;
  line-height: calc(25/17);
  color: var(--color-txt);
  letter-spacing: 0.04em;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
}

article,
aside,
figcaption,
figure,
picture,
footer,
main,
header,
nav,
section {
  display: block;
}

table {
  border-spacing: 0;
  border-collapse: separate;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

ul,
ol {
  list-style: none;
}

p,
li,
dt,
dd,
th,
td {
  -ms-line-break: strict;
  line-break: strict;
  overflow-wrap: anywhere;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
  image-rendering: optimize-contrast;
}

picture {
  line-height: 0;
}

input,
button,
select,
textarea {
  font-family: noto-sans-jp, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.0625rem;
  line-height: calc(25/17);
  color: var(--color-txt);
  cursor: pointer;
  background-color: transparent;
  border: none;
  border-radius: 0;
  outline: none;
  appearance: none;
}

::placeholder {
  font-family: noto-sans-jp, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: calc(25/17);
  color: var(--color-gray03);
}

input:-webkit-autofill {
  box-shadow: 0 0 0 62.5rem #fff inset;
}

input[type=checkbox] {
  display: none;
}

input[type=radio] {
  display: none;
}

button,
textarea {
  font-family: inherit;
  font-size: 100%;
}

summary {
  display: block;
  cursor: pointer;
}

summary::-webkit-details-marker {
  display: none;
}

/* PC SP */
.pc {
  display: initial;
}

.sp {
  display: none;
}

@media screen and (min-width: 751px) {
  /* PCのみホバー効果 */
  a,
  .hp-hover {
    transition: all 0.5s ease;
  }
  a:hover,
  .hp-hover:hover {
    opacity: 0.7;
  }
  label:hover {
    cursor: pointer;
  }
}
@media screen and (width <= 750px) {
  html {
    font-size: calc(16 / 750 * 100vw);
  }
  body,
  .ly-head,
  .ly-main,
  .ly-foot {
    width: 100%;
  }
  body {
    font-size: 1.75rem;
    line-height: 1.5;
  }
  input,
  button,
  select,
  textarea {
    font-size: 1.875rem;
    line-height: 1.5;
  }
  .sp {
    display: initial;
  }
  .pc {
    display: none;
  }
}
/* =============================
共通レイアウト
============================== */
/* 全体のWrapper */
.ly-all-wrapper {
  max-width: 125rem;
  margin: 0 auto;
  overflow: hidden;
}

.ly-main {
  padding-top: 8.125rem;
}

/* inner */
.ly-head-inner,
.ly-foot-inner,
.ly-cont,
.ly-cont-inner {
  position: relative;
  width: 91.5rem;
  height: 100%;
  padding: 0 2.5rem;
  margin-right: auto;
  margin-left: auto;
}

/* 2カラム */
.ly-cont--col {
  display: flex;
  flex-wrap: wrap;
  gap: 2.75rem;
  justify-content: space-between;
}

.ly-cont-main {
  width: 43.75rem;
}

.ly-cont-side {
  width: 17.5rem;
}

@media screen and (width <= 750px) {
  .ly-main {
    padding-top: 8rem;
  }
  /* inner */
  .ly-cont,
  .ly-cont-inner,
  .ly-foot-inner {
    width: 100%;
    padding: 0 1.875rem;
  }
  /* 2カラム */
  .ly-cont--col {
    gap: 5rem;
  }
  .ly-cont-main,
  .ly-cont-side {
    width: 100%;
  }
}
/* =============================
下層MV - パンくず
============================== */
.bl-lower-mv {
  max-width: 115.625rem;
  padding-left: 2.5rem;
  margin-left: auto;
}
.bl-lower-mv-inner {
  position: relative;
  display: grid;
  align-items: center;
  min-height: 15.125rem;
  padding-left: 4rem;
  background: var(--color-main);
  border-top-left-radius: 1.25rem;
  border-bottom-left-radius: 1.25rem;
}
.bl-lower-mv-box {
  position: relative;
  z-index: 2;
}
.bl-lower-mv-ttl {
  font-size: 2.5rem;
  color: var(--color-white);
  letter-spacing: 0.08em;
}
.bl-lower-mv-txt {
  font-size: 1.25rem;
  line-height: calc(42/20);
  color: var(--color-white);
  letter-spacing: 0.08em;
}
.bl-lower-mv-line {
  position: absolute;
  bottom: -2.5rem;
  left: 0;
  width: 100%;
  height: 16rem;
}
.bl-lower-mv-line .line {
  stroke-dasharray: 4000;
  stroke-dashoffset: 0;
  animation: flowLine 5s linear infinite;
}
@keyframes flowLine {
  0% {
    opacity: 0;
    stroke-dashoffset: -4000;
  }
  40% {
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}

/* パンくず */
.bl-breadcrumbs {
  position: relative;
  z-index: 2;
}

.bl-breadcrumbs-inner {
  display: flex;
  width: 100%;
  max-width: 111.625rem;
  padding: 1rem 2.5rem 0;
  margin-left: auto;
  overflow: hidden;
  white-space: nowrap;
}

.bl-breadcrumbs-inner > li {
  font-size: 0.875rem;
  line-height: calc(20/14);
}

.bl-breadcrumbs-inner > li:first-child {
  display: flex;
  align-items: center;
}

.bl-breadcrumbs-inner > li:not(:first-child) {
  display: flex;
  align-items: center;
}

.bl-breadcrumbs-inner > li:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bl-breadcrumbs-inner > li:first-of-type ~ li::before {
  width: 0.4375rem;
  height: 0.75rem;
  margin: 0.125rem 0.5rem 0;
  content: "";
  background: url("../images/common/bread-separate.svg") top center/contain no-repeat;
}

.bl-breadcrumbs-inner .home {
  display: flex;
  align-items: center;
  width: 1.375rem;
}

@media screen and (width <= 750px) {
  .bl-lower-mv-line {
    bottom: 1.5rem;
    height: 3.4375rem;
  }
  .bl-lower-mv-line .line {
    stroke-dasharray: 2000;
    stroke-dashoffset: 2000;
    animation: flowLine 5s linear infinite;
  }
  @keyframes flowLine {
    0% {
      opacity: 0;
      stroke-dashoffset: 2000;
    }
    10% {
      opacity: 1;
    }
    60% {
      opacity: 0;
    }
    100% {
      opacity: 0;
      stroke-dashoffset: 0;
    }
  }
  /* パンくず */
  .bl-breadcrumbs {
    padding: 1rem 0 0 2.5rem;
  }
  .bl-breadcrumbs-inner {
    flex-wrap: wrap;
    max-width: 43.125rem;
    padding: 0;
  }
  .bl-breadcrumbs-inner > li {
    font-size: 1.375rem;
    line-height: calc(33/22);
  }
  .bl-breadcrumbs-inner > li:first-of-type ~ li::before {
    margin: 0 0.75rem;
  }
  .bl-breadcrumbs-inner .home {
    width: 1.5rem;
  }
  .bl-breadcrumbs-inner > li:last-child {
    min-width: auto;
    overflow: visible;
  }
}
/* =============================
共通パーツ
============================== */
/* 各sectionメイン見出し */
.el-sec-mainTtl {
  position: relative;
  margin-bottom: 2rem;
  line-height: 1.5;
  text-align: center;
}

/* el_btn */
.el-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0.125rem;
}

.el-btn.more {
  font-size: 1.125rem;
  font-weight: bold;
}

.el-btn.more::after {
  position: absolute;
  top: 0;
  right: 0;
  content: "";
}

/* el_label */
.el-label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0.125rem;
  color: #fff;
  background: #000;
}

.bl-bullet-list {
  display: grid;
  gap: 0.5rem;
}
.bl-bullet-item {
  display: grid;
  grid-template-columns: auto 1fr;
}
.bl-bullet-item a {
  text-decoration: underline;
}
.bl-bullet-item::before {
  content: "・";
}

.bl-num-list {
  content: counter(num);
  counter-reset: num;
}
.bl-num-list.--bracket .bl-num-item::before {
  content: "（" counter(num) "）";
}
.bl-num-list.--single-bracket.--over-10 .bl-num-item {
  grid-template-columns: 2.3em 1fr;
}
.bl-num-list.--single-bracket .bl-num-item::before {
  content: counter(num) "）";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(1)::before {
  content: "①";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(2)::before {
  content: "②";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(3)::before {
  content: "③";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(4)::before {
  content: "④";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(5)::before {
  content: "⑤";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(6)::before {
  content: "⑥";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(7)::before {
  content: "⑦";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(8)::before {
  content: "⑧";
}
.bl-num-list.--circle .bl-num-item:nth-of-type(9)::before {
  content: "⑨";
}
.bl-num-item {
  display: grid;
  grid-template-columns: auto 1fr;
}
.bl-num-item::before {
  counter-increment: num;
}
.bl-num-item:not(:first-of-type) {
  margin-top: 0.25rem;
}

.bl-alphabet-list {
  margin-top: 0.5rem;
}
.bl-alphabet-item {
  display: grid;
  grid-template-columns: auto 1fr;
}
.bl-alphabet-item:not(:first-of-type) {
  margin-top: 0.25rem;
}
.bl-alphabet-item:first-of-type::before {
  content: "A．";
}
.bl-alphabet-item:nth-of-type(2)::before {
  content: "B．";
}
.bl-alphabet-item:nth-of-type(3)::before {
  content: "C．";
}
.bl-alphabet-item:nth-of-type(4)::before {
  content: "D．";
}
.bl-alphabet-item:nth-of-type(5)::before {
  content: "E．";
}

/* ※ */
.el-att {
  position: relative;
  display: flex;
  font-size: 0.875rem;
  line-height: calc(20/14);
}
.el-att.sp {
  display: none;
}

.el-att::before {
  flex: 0 1 auto;
  content: "※";
}

.el-att.--end {
  justify-content: end;
}

.el-att01,
.el-att02,
.el-att03 {
  padding-left: 2.5em;
}

.el-att01::before {
  content: "※1";
}

.el-att02::before {
  content: "※2";
}

.el-att03::before {
  content: "※3";
}

span.el-att {
  display: block;
}

.el-link {
  color: #00f;
  text-decoration: underline;
}

.el-txt {
  text-align: center;
}

@media screen and (width <= 750px) {
  /* ※ */
  .el-att {
    font-size: 1.5rem;
  }
  .el-att.sp {
    display: flex;
  }
  .bl-bullet-list {
    gap: 1rem;
  }
  .bl-num-item:not(:first-of-type) {
    margin-top: 0.375rem;
  }
  .bl-alphabet-list {
    margin-top: 0.75rem;
  }
  .bl-alphabet-item:not(:first-of-type) {
    margin-top: 0.375rem;
  }
}
/* =============================
ヘルプタグ
============================== */
/* ユニット */
.hp-unit {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

/* 明朝体 */
.hp-mincho {
  font-family: noto-serif-jp, "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 400;
}

/* bold */
.hp-bold {
  font-weight: bold !important;
}

.hp-normal {
  font-weight: 400;
}

/* italic */
.hp-italic {
  transform: skewX(-10deg);
}

/* 打ち消し線 */
.hp-strikethrough {
  padding: 0.1875rem 0 0 0.5rem;
  letter-spacing: 0;
  background-image: linear-gradient(#222, #222);
  background-repeat: repeat-x;
  background-position: 0 50%;
  background-size: 100% 0.0625rem;
}

/* opacity1 */
.hp-opacity1 {
  opacity: 1 !important;
}

/* 電話リンク */
.hp-tel {
  pointer-events: none;
}

/* アクセントカラー */
.hp-color--accent {
  color: var(--color-accent);
}

/* 影付き角丸白ボックス */
.hp-shadowRadiusWhiteBox {
  background: #fff;
  border-radius: 0.625rem;
  box-shadow: 0 0 0.5625rem 0 rgba(0, 0, 0, 0.35);
}

.hp-scroll-y {
  overflow-y: scroll;
  /* スクロールバー非表示（IE・Edge） */
  -ms-overflow-style: none;
  /* スクロールバー非表示（Firefox） */
  scrollbar-width: none;
}

/* スクロールバー非表示（Chrome・Safari） */
.hp-scroll-y::-webkit-scrollbar {
  display: none;
}

@media screen and (width <= 750px) {
  /* ユニット */
  .hp-unit {
    display: block;
  }
  /* 電話リンク */
  .hp-tel {
    pointer-events: auto;
  }
}
/* =============================
header
============================== */
.ly-head {
  position: fixed;
  top: 0;
  left: 50%;
  z-index: 9999;
  width: 100%;
  background: var(--color-white);
  transform: translateX(-50%);
}

.bl-head {
  display: flex;
  justify-content: space-between;
  width: calc(100% - 5rem);
  padding: 1.625rem 0;
}
.bl-head-logo {
  display: flex;
  width: 4.875rem;
}
.bl-head-logo-link {
  display: flex;
}
.bl-head-box {
  display: grid;
  place-content: center;
}
.bl-head-btn {
  display: grid;
  place-content: center;
  padding: 0.4375rem 1rem 0.5625rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  border: 0.0625rem solid var(--color-main);
}
.bl-head-btn-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: end;
  margin-bottom: 1rem;
}
.bl-head-btn.--reservation {
  grid-template-columns: auto 1fr;
  gap: 0.5rem;
}
.bl-head-btn.--reservation::before {
  width: 1.375rem;
  height: 0.9375rem;
  margin-top: 0.0625rem;
  content: "";
  background: url("../images/common/header-reservation-deco.svg") top center/contain no-repeat;
}
.bl-head-gnav {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1;
}
.bl-head-gnav-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: end;
}
.bl-head-gnav-item {
  display: flex;
}
.bl-head-gnav-item.sp {
  display: none;
}
.bl-head-sns-wrapper {
  display: none;
}

.bl-burger {
  display: none;
}

@media screen and (min-width: 751px) {
  .bl-head-btn.--reservation {
    color: var(--color-white);
    background: var(--color-accent);
    border: none;
  }
}
@media screen and (width <= 750px) {
  .ly-head {
    transition: background 0.3s ease;
  }
  .ly-head.--scroll {
    background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.4) 25%, rgba(255, 255, 255, 0.7) 50%, white 100%);
  }
  .bl-head {
    width: 43.125rem;
    height: 8rem;
    padding: 1.125rem 0 1.5rem;
  }
  .bl-head-box {
    position: fixed;
    top: 0;
    left: 0;
    display: grid;
    grid-template: "gnav-wrapper" "btn-wrapper" "sns-wrapper";
    grid-template-rows: auto auto 1fr;
    width: 100%;
    height: 100vh;
    padding: 12rem 6.5rem 3rem;
    background: var(--color-white);
    transition: all 0.5s ease;
    transform: translateX(100%);
  }
  .bl-head-box.--js-active {
    transform: none;
  }
  .bl-head-btn {
    padding: 1.0625rem 2.5rem 1.1875rem;
    font-size: 1.75rem;
    line-height: calc(40/28);
    letter-spacing: 0.08em;
    border-radius: 3.125rem;
  }
  .bl-head-btn-wrapper {
    display: grid;
    grid-template: "reservation" "guide" "questionaire";
    gap: 1rem;
    justify-content: start;
    margin-bottom: 7.5rem;
  }
  .bl-head-btn.--guide {
    grid-area: guide;
  }
  .bl-head-btn.--questionaire {
    grid-area: questionaire;
  }
  .bl-head-btn.--reservation {
    grid-area: reservation;
    grid-template-columns: auto;
    color: var(--color-main);
  }
  .bl-head-btn.--reservation::before {
    display: none;
  }
  .bl-head-gnav {
    font-size: 2rem;
    line-height: calc(40/32);
  }
  .bl-head-gnav-wrapper {
    grid-area: gnav-wrapper;
    margin-bottom: 4rem;
  }
  .bl-head-gnav-list {
    flex-direction: column;
    gap: 1.5rem;
    justify-content: start;
  }
  .bl-head-gnav-item.sp {
    display: flex;
  }
  .bl-head-sns {
    width: 4rem;
  }
  .bl-head-sns-wrapper {
    display: flex;
    grid-area: sns-wrapper;
    gap: 2rem;
    align-self: start;
  }
  .bl-burger {
    position: absolute;
    top: 2.6875rem;
    right: 0;
    z-index: 9999;
    display: grid;
    width: 3rem;
    height: auto;
    transition: all 0.3s ease;
  }
  .bl-burger.--js-active .bl-burger-bars::before {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .bl-burger.--js-active .bl-burger-bars::after {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .bl-burger.--js-active .bl-burger-bar {
    display: none;
  }
  .bl-burger-bars {
    position: relative;
    display: block;
    align-self: end;
    height: 2.25rem;
    transition: all 0.3s ease;
  }
  .bl-burger-bar,
  .bl-burger-bars::before,
  .bl-burger-bars::after {
    position: absolute;
    left: 50%;
    width: 100%;
    height: 0.25rem;
    content: "";
    background: var(--color-main);
    transition: all 0.3s ease;
    transform: translate(-50%, -50%);
  }
  .bl-burger-bars::before {
    top: 0;
  }
  .bl-burger-bars::after {
    top: 100%;
  }
  .bl-burger-bar {
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .bl-gnav-outer {
    position: fixed;
    top: 0;
    left: 0;
    display: grid;
    place-content: center;
    width: 100%;
    height: 100vh;
    transition: all 0.5s ease;
    transform: translateX(100%);
  }
  .bl-gnav-outer.--js-active {
    transform: translateX(0);
  }
  .bl-gnav-wrapper {
    margin-bottom: 4rem;
  }
  .bl-gnav-list {
    flex-direction: column;
    gap: 3rem;
    align-items: center;
  }
  .bl-gnav-item .bl-item-link {
    padding: 0;
    font-size: 2rem;
    line-height: calc(47/32);
  }
  .bl-gnav-item .bl-item-link::before {
    display: none;
  }
  .bl-gnav-item:last-of-type .bl-item-link::after {
    display: none;
  }
}
/* =============================
footer
============================= */
.ly-foot {
  background: var(--color-white);
}

.bl-foot {
  padding: 6.125rem 2.5rem 2.5rem;
}
.bl-foot-box {
  display: grid;
  grid-template: "info gnav-wrapper ." "info sns-wrapper btn-wrapper";
  grid-template-columns: auto 1fr auto;
  column-gap: 2.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 0.0625rem solid var(--color-gray02);
}
.bl-foot-info {
  grid-area: info;
  text-align: center;
}
.bl-foot-info .bl-info-logo {
  display: flex;
  width: 11.875rem;
  margin-bottom: 1rem;
}
.bl-foot-info .bl-info-address {
  font-size: 0.875rem;
  line-height: calc(17/14);
}
.bl-foot-info .bl-info-def {
  display: flex;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
  line-height: calc(17/14);
}
.bl-foot-info .bl-info-dttl {
  display: flex;
}
.bl-foot-info .bl-info-dttl::before {
  content: "【";
}
.bl-foot-info .bl-info-dttl::after {
  content: "】";
}
.bl-foot-info .bl-info-tel {
  font-size: 1.25rem;
  font-weight: 700;
}
.bl-foot-gnav {
  display: flex;
  gap: 0.25rem;
  align-items: center;
  font-size: 0.9375rem;
  line-height: calc(18/15);
}
.bl-foot-gnav-wrapper {
  grid-area: gnav-wrapper;
  margin-bottom: 3.3125rem;
}
.bl-foot-gnav-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}
.bl-foot-gnav::before {
  width: 0;
  height: 0;
  margin-top: 0.0625rem;
  content: "";
  border-color: transparent transparent transparent var(--color-gray04);
  border-style: solid;
  border-width: 0.3125rem 0 0.3125rem 0.5rem;
}
.bl-foot-sns {
  display: flex;
  width: 3.5rem;
}
.bl-foot-sns-wrapper {
  display: flex;
  flex-wrap: wrap;
  grid-area: sns-wrapper;
  gap: 1.8125rem;
}
.bl-foot-btn-wrapper {
  display: flex;
  grid-area: btn-wrapper;
  gap: 1.5rem;
  align-self: end;
}
.bl-foot-osakajutaku {
  width: 14rem;
}
.bl-foot-btn {
  display: flex;
  gap: 0.875rem;
  align-items: center;
  justify-content: center;
  width: 14rem;
  padding: 1.3125rem 0;
  font-size: 1rem;
  line-height: 1;
  border: 0.0625rem solid;
}
.bl-foot-btn::after {
  width: 0.5rem;
  height: 0.75rem;
  content: "";
  background: url("../images/common/btn-linearrow--main.svg") center center/cover no-repeat;
  transform: translateY(0.03125rem);
}
.bl-foot-banpaku {
  padding-top: 1.625rem;
}
.bl-foot-banpaku .bl-banpaku-imgouter {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-bottom: 1.5rem;
}
.bl-foot-banpaku .bl-banpaku-imgwrapper.--pavilion {
  width: 6.875rem;
}
.bl-foot-banpaku .bl-banpaku-imgwrapper.--expo {
  width: 17.1875rem;
}
.bl-foot-banpaku .bl-banpaku-txt {
  font-size: 0.875rem;
  line-height: calc(17/14);
}
.bl-foot-fixed-btn-wrapper {
  display: none;
}

/* コピーライト */
.bl-foot-copyright {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0 0.625rem;
  text-align: center;
  background: var(--color-main);
}

.bl-foot-copyright small {
  font-family: Verdana; /* Android */
  font-size: 0.75rem;
  line-height: calc(14/12);
  color: var(--color-white);
}

/* ページトップボタン */
.bl-pagetop {
  position: absolute;
  right: 2.5rem;
  bottom: 2.5rem;
  width: 6.5rem;
  height: 3.25rem;
  cursor: pointer;
  transition: all 0.5s ease;
}
@media (hover: hover) {
  .bl-pagetop:hover {
    opacity: 0.7;
  }
}

@media screen and (width <= 750px) {
  .ly-foot.--js-foot-fixed-btn {
    margin-bottom: 5rem;
  }
  .bl-foot {
    padding: 6rem 3.75rem 2.5rem;
  }
  .bl-foot-box {
    display: grid;
    grid-template: "gnav-wrapper" "sns-wrapper" "info" "btn-wrapper";
    grid-template-columns: auto;
    column-gap: 0;
    padding-bottom: 0;
    border-bottom: none;
  }
  .bl-foot-info {
    margin-bottom: 2.5rem;
  }
  .bl-foot-info .bl-info-logo {
    width: 15.875rem;
    margin: 0 auto 2rem;
  }
  .bl-foot-info .bl-info-address {
    font-size: 1.5rem;
  }
  .bl-foot-info .bl-info-def {
    justify-content: center;
    font-size: 1.5rem;
  }
  .bl-foot-info .bl-info-tel {
    font-size: 2rem;
  }
  .bl-foot-gnav {
    gap: 0.5rem;
    font-size: 1.75rem;
  }
  .bl-foot-gnav-wrapper {
    margin-bottom: 4rem;
  }
  .bl-foot-gnav-list {
    display: grid;
    grid-template: "foot-gnav-1 foot-gnav-5" "foot-gnav-2 foot-gnav-6" "foot-gnav-3 foot-gnav-7" "foot-gnav-4 foot-gnav-8" ". foot-gnav-9";
    grid-template-columns: 1fr auto;
    gap: 2rem 0;
    padding: 0 2.5rem;
  }
  .bl-foot-gnav-item:nth-of-type(1) {
    grid-area: foot-gnav-1;
  }
  .bl-foot-gnav-item:nth-of-type(2) {
    grid-area: foot-gnav-2;
  }
  .bl-foot-gnav-item:nth-of-type(3) {
    grid-area: foot-gnav-3;
  }
  .bl-foot-gnav-item:nth-of-type(4) {
    grid-area: foot-gnav-4;
  }
  .bl-foot-gnav-item:nth-of-type(5) {
    grid-area: foot-gnav-5;
  }
  .bl-foot-gnav-item:nth-of-type(6) {
    grid-area: foot-gnav-6;
  }
  .bl-foot-gnav-item:nth-of-type(7) {
    grid-area: foot-gnav-7;
  }
  .bl-foot-gnav-item:nth-of-type(8) {
    grid-area: foot-gnav-8;
  }
  .bl-foot-gnav-item:nth-of-type(9) {
    grid-area: foot-gnav-9;
  }
  .bl-foot-gnav::before {
    border-width: 0.5625rem 0 0.5625rem 0.875rem;
  }
  .bl-foot-sns {
    width: 3.75rem;
  }
  .bl-foot-sns-wrapper {
    gap: 2rem;
    justify-content: center;
    margin-bottom: 4rem;
  }
  .bl-foot-btn-wrapper {
    gap: 0.75rem;
    justify-content: center;
  }
  .bl-foot-osakajutaku {
    display: flex;
    width: 14.625rem;
  }
  .bl-foot-btn {
    gap: 0.5rem;
    width: 14.625rem;
    padding: 1.125rem 0;
    font-size: 1.25rem;
  }
  .bl-foot-btn::after {
    width: 0.625rem;
    height: 1.125rem;
    background-image: url("../images/common/btn-linearrow--main-sp.svg");
  }
  .bl-foot-banpaku {
    display: none;
  }
  .bl-foot-fixed-btn {
    display: flex;
    gap: 1.5rem;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    color: var(--color-white);
    border: 0.0625rem solid;
  }
  .bl-foot-fixed-btn-wrapper {
    position: fixed;
    bottom: 0;
    left: 50%;
    z-index: 9000;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
    height: 5rem;
    transform: translateX(-50%);
  }
  .bl-foot-fixed-btn::before {
    content: "";
    background: center center/cover no-repeat;
  }
  .bl-foot-fixed-btn.--entry {
    background-color: var(--color-main);
  }
  .bl-foot-fixed-btn.--entry::before {
    width: 1.5rem;
    height: 2.25rem;
    background-image: url("../images/common/foot-fixed-ico-entry.svg");
  }
  .bl-foot-fixed-btn.--reservation {
    background-color: var(--color-accent);
    border-left: none;
  }
  .bl-foot-fixed-btn.--reservation::before {
    width: 2.25rem;
    height: 1.5rem;
    background-image: url("../images/common/foot-fixed-ico-reservation.svg");
  }
  /* コピーライト */
  .bl-foot-copyright {
    padding: 1.1875rem 0 1.3125rem;
  }
  /* ページトップボタン */
  .bl-pagetop {
    right: 1.5625rem;
    bottom: 1.5625rem;
    width: 4.5rem;
    height: 7.3125rem;
  }
}
/* =============================
新着
============================== */
.c-post {
  border-bottom: 0.0625rem solid var(--color-main);
}
.c-post-wrapper {
  width: 100%;
  padding: 3rem 4rem;
  margin-bottom: 3.5rem;
  background: var(--color-white);
}
.c-post:first-of-type .c-post-link {
  padding-top: 0;
}
.c-post:last-of-type {
  border-bottom: none;
}
.c-post:last-of-type .c-post-link {
  padding-bottom: 0;
}
.c-post-link {
  display: grid;
  grid-template-columns: 18.75rem 1fr;
  padding: 2rem 0;
}
.c-post-header {
  display: flex;
  gap: 2.5rem;
  align-items: center;
}
.c-post-date {
  font-size: 1.125rem;
  line-height: 1;
}
.c-post-ttl {
  font-size: 1.125rem;
  font-weight: 400;
}

.el-cat {
  display: grid;
  place-content: center;
  min-width: 7.375rem;
  padding: 0.1875rem 0.5rem 0.375rem;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-white);
  background: var(--color-accent);
}

@media screen and (width <= 750px) {
  .c-post-wrapper {
    width: 46.875rem;
    padding: 3.75rem;
    margin-left: -1.875rem;
    background: linear-gradient(90deg, white 71%, rgba(255, 255, 255, 0) 100%);
  }
  .c-post-link {
    grid-template-columns: auto;
  }
  .c-post-header {
    margin-bottom: 1rem;
  }
  .c-post-date {
    font-size: 1.375rem;
  }
  .c-post-ttl {
    font-size: 1.75rem;
  }
  .el-cat {
    min-width: 6.625rem;
    padding: 0.125rem 0.5rem 0.375rem;
    font-size: 1.375rem;
    line-height: calc(24/22);
  }
}
/* =======================================================
c-article
======================================================= */
.c-article {
  position: relative;
  display: grid;
  place-content: center;
  height: 8.0625rem;
  padding: 0 0 0.0625rem;
  background: var(--color-white);
  border: 0.0625rem solid var(--color-accent);
}
.c-article-outer {
  padding-bottom: 5rem;
}
.c-article-wrapper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.c-article::after {
  position: absolute;
  right: 0.5rem;
  bottom: 0.5rem;
  width: 1.25rem;
  height: 1.25rem;
  content: "";
  background: url("../images/common/c-article-arrow.svg") top center/contain no-repeat;
}
.c-article-inner {
  display: block;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: calc(32/20);
  text-align: center;
}
.c-article-bracket, .c-article-deco {
  display: block;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 2;
}
.c-article-bracket::before {
  content: "（";
}
.c-article-bracket::after {
  content: "）";
}
.c-article-deco::before {
  content: "【";
}
.c-article-deco::after {
  content: "】";
}
.c-article-btn-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  margin-bottom: 2rem;
}
.c-article-link {
  display: inline-flex;
  gap: 0.25em;
  justify-content: center;
  line-height: calc(20/17);
  color: var(--color-link);
  border-bottom: 0.0625rem solid;
}
.c-article-link-wrapper {
  text-align: center;
}
.c-article-link::before {
  content: "＞";
}

@media screen and (width <= 750px) {
  .c-article {
    height: 12.5rem;
    border-width: 0.125rem;
  }
  .c-article-outer {
    padding: 5rem 0;
  }
  .c-article-wrapper {
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: 4rem;
  }
  .c-article::after {
    width: 1.375rem;
    height: 1.375rem;
  }
  .c-article-inner {
    font-size: 1.875rem;
  }
  .c-article-bracket, .c-article-deco {
    font-size: 1.3125rem;
    letter-spacing: 0.03em;
  }
  .c-article-btn-wrapper {
    margin-bottom: 3.5rem;
  }
  .c-article-link {
    font-size: 1.625rem;
    line-height: calc(38/26);
  }
}
/* =======================================================
c-btn
======================================================= */
.c-btn {
  display: grid;
  place-content: center;
  letter-spacing: 0.08em;
}
.c-btn.--normal {
  width: 19.375rem;
  padding: 1.0625rem 0 1.1875rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: calc(24/16);
  color: var(--color-white);
  background: var(--color-main);
}
.c-btn.--normal.--reverse {
  color: var(--color-main);
  background: var(--color-white);
  border: 1px solid var(--color-main);
}

@media screen and (max-width: 750px) {
  .c-btn-wrapper.--center {
    text-align: center;
  }
  .c-btn-wrapper.--right {
    text-align: right;
  }
  .c-btn.--normal {
    display: inline-block;
    width: auto;
    min-width: 22.5rem;
    padding: 1.375rem 1.5rem 1.625rem;
    font-size: 1.625rem;
    text-align: center;
  }
}
/* =======================================================
cta
======================================================= */
.ly-cta {
  padding: 4rem 0;
  background: url("../images/common/cta-bg.webp") top center/cover no-repeat;
}

.bl-cta-ttl {
  margin-bottom: 2rem;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: calc(45/32);
  color: var(--color-white);
  text-align: center;
  letter-spacing: 0.06em;
}
.bl-cta-lbl {
  display: inline-block;
  padding: 0.0625rem 1.25rem 0.25rem;
  margin-bottom: 0.75rem;
  font-weight: 700;
  color: var(--color-contrast03);
  background: var(--color-white);
  border: 0.0625rem solid;
}
.bl-cta-lbl-wrapper {
  text-align: center;
}
.bl-cta-def {
  display: flex;
  flex-wrap: wrap;
  gap: 3rem;
  justify-content: center;
  margin-bottom: 1.5rem;
}
.bl-cta-dwrap {
  display: flex;
  gap: 0.8125rem;
  align-items: end;
}
.bl-cta-dttl {
  margin-bottom: 0.1875rem;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: calc(36/24);
  color: var(--color-white);
  letter-spacing: 0.06em;
}
.bl-cta-ditem {
  font-size: 2rem;
  font-weight: 700;
  line-height: calc(47/32);
  color: var(--color-white);
}
.bl-cta-info {
  display: grid;
  place-content: center;
  margin-bottom: 1.5rem;
}
.bl-cta-info .bl-info-def {
  display: grid;
  gap: 0.5rem;
}
.bl-cta-info .bl-info-dwrap {
  display: flex;
  color: var(--color-white);
}
.bl-cta-address {
  color: var(--color-white);
  text-align: center;
}

@media screen and (width <= 750px) {
  .ly-cta {
    padding: 3.5rem 0 11.25rem;
    background: url("../images/common/cta-bg-sp.webp") top center/cover no-repeat;
  }
  .bl-cta-ttl {
    margin-bottom: 1rem;
    font-size: 2.5rem;
    line-height: calc(59/40);
  }
  .bl-cta-lbl {
    padding: 0.0625rem 1.375rem 0.125rem;
    margin-bottom: 2rem;
    border-width: 0.125rem;
  }
  .bl-cta-def {
    flex-direction: column;
    gap: 0;
    align-items: center;
    margin-bottom: 2rem;
  }
  .bl-cta-dwrap {
    gap: 0.5rem;
  }
  .bl-cta-dttl {
    margin-bottom: 0.5625rem;
    font-size: 1.75rem;
    line-height: calc(41/28);
  }
  .bl-cta-ditem {
    font-size: 2.5rem;
    line-height: calc(59/40);
  }
  .bl-cta-address {
    text-align: left;
  }
  .bl-cta-address-wrapper {
    display: grid;
    place-content: center;
  }
}
/* =======================================================
c-cat
======================================================= */
.c-cat-outer {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2rem;
  width: 100%;
  padding: 0.625rem 2rem 0.8125rem;
  background: var(--color-contrast02);
}
.c-cat-ttl {
  font-size: 1.125rem;
  font-weight: 700;
}
.c-cat-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

@media screen and (width <= 750px) {
  .c-cat-outer {
    grid-template-columns: auto;
    gap: 1rem;
    padding: 1.5rem 2rem 2rem;
  }
  .c-cat-ttl {
    font-size: 1.875rem;
  }
  .c-cat-wrapper {
    gap: 1.5rem;
  }
}
/* =======================================================
aside
======================================================= */
.bl-aside {
  border: 0.0625rem solid var(--color-accent);
}
.bl-aside-ttl {
  padding: 0.5rem 0 0.625rem;
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
  background: var(--color-accent);
}
.bl-aside-inner {
  background: var(--color-white);
}
.bl-aside-article {
  position: relative;
}
.bl-aside-article-wrapper {
  margin-bottom: 2rem;
}
.bl-aside-article::after {
  position: absolute;
  bottom: -0.03125rem;
  left: 50%;
  width: calc(100% - 2rem);
  height: 0.0625rem;
  content: "";
  background: var(--color-gray02);
  transform: translateX(-50%);
}
.bl-aside-article .bl-article-link {
  position: relative;
  display: block;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  line-height: 1.5;
}
.bl-aside-article .bl-article-link-inner {
  display: box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.bl-aside.--popular-column .bl-aside-article:last-of-type::after {
  display: none;
}
.bl-aside-btn {
  width: 11.25rem;
  padding: 0.5rem 1rem 0.6875rem;
  margin: 0 auto 2rem;
  background: var(--color-accent);
}

@media screen and (width <= 750px) {
  .bl-aside {
    border-width: 0.125rem;
  }
  .bl-aside-ttl {
    padding: 0.75rem 0 0.9375rem;
    font-size: 2rem;
  }
  .bl-aside-article-wrapper {
    margin-bottom: 3rem;
  }
  .bl-aside-article::after {
    bottom: -0.046875rem;
    width: calc(100% - 3rem);
    height: 0.09375rem;
  }
  .bl-aside-article .bl-article-link {
    padding: 1.5rem 2rem;
    font-size: 1.625rem;
  }
  .bl-aside-btn {
    width: 20rem;
    padding: 0.75rem 1.5rem 1.03125rem;
    margin: 0 auto 3rem;
  }
}
/* =======================================================
c-hgroup
======================================================= */
.c-hgroup {
  margin-bottom: 3.5rem;
  text-align: center;
}
.c-hgroup-ttl {
  margin-bottom: 1.5rem;
  font-size: 2.5rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.08em;
}
.c-hgroup-txt {
  position: relative;
  display: inline-block;
  padding-top: 0.5rem;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.08em;
}
.c-hgroup-txt::before, .c-hgroup-txt::after {
  position: absolute;
  top: 0;
  width: 50%;
  height: 0.0625rem;
  content: "";
}
.c-hgroup-txt::before {
  left: 0;
  background: var(--color-accent);
}
.c-hgroup-txt::after {
  right: 0;
  background: var(--color-main);
}

@media screen and (width <= 750px) {
  .c-hgroup {
    margin-bottom: 4rem;
  }
  .c-hgroup-ttl {
    margin-bottom: 1rem;
  }
  .c-hgroup-txt {
    font-size: 1.25rem;
  }
}
/* =======================================================
c-modelhouse-article
======================================================= */
.c-modelhouse-article {
  position: relative;
  width: 20rem;
  padding-top: 11.25rem;
  background: var(--color-white);
}
.c-modelhouse-article-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
}
.c-modelhouse-article.--new::before {
  position: absolute;
  top: 0.875rem;
  right: -0.375rem;
  z-index: 2;
  width: 5.875rem;
  height: 2.875rem;
  content: "";
  background: url("../images/common/modelhouse-new.svg") top center/contain no-repeat;
}
.c-modelhouse-article .c-article-num {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 3rem;
  height: 3rem;
  padding: 0.25rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: calc(19/16);
  color: var(--color-white);
  background: url("../images/common/modelhouse-article-num-bg.svg") top center/contain no-repeat;
}
.c-modelhouse-article .c-article-imgwrapper {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.c-modelhouse-article .c-article-imgwrapper > img {
  width: 20rem;
  height: 11.25rem;
  object-fit: cover;
}
.c-modelhouse-article .c-article-hgroup {
  margin: 1.0625rem 0;
  text-align: center;
}
.c-modelhouse-article .c-article-hgroup-ttl {
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: calc(24/20);
}
.c-modelhouse-article .c-article-hgroup-txt {
  padding: 0 1.5rem;
  line-height: calc(20/17);
}
.c-modelhouse-article .c-article-btn {
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0.3125rem 0.5625rem 0.4375rem 0;
  text-align: right;
}
.c-modelhouse-article .c-article-btn-wrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding: 0 1.5rem;
  margin-bottom: 1.5rem;
}
.c-modelhouse-article .c-article-btn::after {
  width: 0.5rem;
  height: 0.75rem;
  content: "";
}
.c-modelhouse-article .c-article-btn.--detail {
  gap: 0.4375rem;
  background: var(--color-white);
  border: 0.0625rem solid;
}
.c-modelhouse-article .c-article-btn.--detail::after {
  background: url("../images/common/btn-linearrow--main.svg") top center/cover no-repeat;
}
.c-modelhouse-article .c-article-btn.--reservation {
  gap: 0.9375rem;
  color: var(--color-white);
  background: var(--color-accent);
}
.c-modelhouse-article .c-article-btn.--reservation::after {
  background: url("../images/common/btn-linearrow--white.svg") top center/cover no-repeat;
}

@media screen and (width <= 750px) {
  .c-modelhouse-article {
    width: 20.75rem;
    padding-top: 11.6875rem;
  }
  .c-modelhouse-article-wrapper {
    gap: 1.5rem;
  }
  .c-modelhouse-article.--new::before {
    top: 1.5rem;
  }
  .c-modelhouse-article .c-article-num {
    width: 4.375rem;
    height: 4.375rem;
    padding: 0.5rem 0 0 0.25rem;
    font-size: 1.5rem;
    line-height: 1;
  }
  .c-modelhouse-article .c-article-imgwrapper > img {
    width: 20.75rem;
    height: 11.6875rem;
  }
  .c-modelhouse-article .c-article-hgroup {
    margin: 2rem 0 1.5rem;
  }
  .c-modelhouse-article .c-article-hgroup-ttl {
    font-size: 1.625rem;
  }
  .c-modelhouse-article .c-article-hgroup-txt {
    font-size: 1.375rem;
  }
  .c-modelhouse-article .c-article-btn {
    padding: 0.5rem 2rem 0.75rem 2.5rem;
    font-size: 1.5rem;
    text-align: center;
  }
  .c-modelhouse-article .c-article-btn-wrapper {
    grid-template-columns: auto;
    padding: 0;
    margin-bottom: 2rem;
  }
  .c-modelhouse-article .c-article-btn::after {
    width: 0.5625rem;
    height: 0.875rem;
    margin-top: 0.125rem;
  }
  .c-modelhouse-article .c-article-btn.--detail {
    gap: 1.5rem;
  }
  .c-modelhouse-article .c-article-btn.--reservation {
    gap: 1.5rem;
  }
}
/* =======================================================
corporatelogo
======================================================= */
.ly-corporatelogo {
  padding: 6.375rem 0 8.8125rem;
  background: var(--color-main);
}

.bl-corporatelogo-att {
  justify-content: end;
  margin: 0 1.1875rem 0.5rem 0;
  color: var(--color-white);
}
.bl-corporatelogo-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2.5rem 3.5rem;
}

@media screen and (width <= 750px) {
  .ly-corporatelogo {
    padding: 5.6875rem 0 8rem;
  }
  .bl-corporatelogo-att {
    margin: 0 0 1rem;
  }
  .bl-corporatelogo-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.375rem 1.3125rem;
  }
}
/* =======================================================
lower
======================================================= */
.ly-lower-inner {
  width: 69rem;
  padding: 0 2.5rem;
  margin: 0 auto;
}

@media screen and (max-width: 750px) {
  .ly-lower-inner {
    width: 100%;
    padding: 0 1.875rem;
  }
}
/* =======================================================
c-linkbox
======================================================= */
.c-linkbox {
  max-width: 64rem;
  margin: 0 auto;
}
.c-linkbox-link {
  display: flex;
  gap: 3rem;
  align-items: center;
  padding: 2.5rem 3.375rem;
  background: var(--color-white);
  border: 0.0625rem solid var(--color-main);
}
.c-linkbox-ttl {
  position: relative;
  padding: 2.125rem 3.375rem 2.125rem 0;
  font-size: 1.75rem;
  line-height: 1;
  letter-spacing: 0.08em;
}
.c-linkbox-ttl::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 0.0625rem;
  height: 100%;
  content: "";
  background: var(--color-main);
  transform: translateY(-50%);
}
.c-linkbox-txt {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2.375rem;
  align-items: center;
}
.c-linkbox-txt::after {
  width: 2.875rem;
  height: 2.875rem;
  content: "";
  background: url("../images/common/circle-arrow.svg") top center/contain no-repeat;
}

@media screen and (max-width: 750px) {
  .c-linkbox {
    max-width: 39.375rem;
  }
  .c-linkbox-link {
    display: block;
    padding: 3.1875rem 3rem 3.5rem;
  }
  .c-linkbox-ttl {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: 0 0 1.5rem;
    margin-bottom: 2rem;
    font-size: 2.25rem;
    border-bottom: 0.0625rem solid;
  }
  .c-linkbox-ttl::after {
    position: relative;
    top: initial;
    right: initial;
    width: 2.875rem;
    height: 2.875rem;
    content: "";
    background: url("../images/common/circle-arrow.svg") top center/contain no-repeat;
    transform: none;
  }
  .c-linkbox-txt {
    display: block;
  }
}
/* =======================================================
bnr-modelhouse
======================================================= */
.bl-bnr-modelhouse-wrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem;
  padding: 8rem 2.5rem;
}

@media screen and (max-width: 750px) {
  .bl-bnr-modelhouse-wrapper {
    grid-template-columns: auto;
    gap: 2.5rem;
    padding: 8rem 1.875rem;
  }
}
/* =======================================================
map
======================================================= */
.c-map {
  display: grid;
  grid-template-columns: 42.375rem 1fr;
  gap: 4rem;
  padding-left: 1.375rem;
  margin-bottom: 4rem;
}
.c-map-list {
  display: grid;
  grid-template-rows: repeat(15, auto);
  grid-auto-flow: column;
  gap: 0.5rem 2.5rem;
  align-self: center;
}
.c-map-item {
  content: counter(num);
  counter-increment: num;
}
.c-map-item-link {
  display: flex;
  gap: 0.4375rem;
  align-items: center;
}
.c-map-item-num {
  display: grid;
  place-content: center;
  width: 1.375rem;
  height: 1.375rem;
  padding: 0 0 0.125rem 0.0625rem;
  font-size: 0.875rem;
  line-height: 1;
  color: var(--color-white);
  content: counter(num);
  background: var(--color-accent02);
  border-radius: 50%;
}

@media screen and (max-width: 750px) {
  .c-map {
    grid-template-columns: auto;
    gap: 4rem;
    padding-left: 0;
    margin-bottom: 5rem;
  }
  .c-map-imgwrapper {
    width: 100%;
  }
  .c-map-list {
    gap: 0.75rem;
  }
  .c-map-item-link {
    gap: 0.65625rem;
    font-size: 1.5rem;
  }
  .c-map-item-num {
    width: 2.0625rem;
    height: 2.0625rem;
    padding: 0 0 0.1875rem 0.09375rem;
    font-size: 1.5rem;
  }
}
/* =======================================================
メーカー検索欄
======================================================= */
.bl-manufacturer {
  padding: 4rem 0;
  background: var(--color-contrast);
}
.bl-manufacturer-select {
  display: block;
  width: 40rem;
  padding: 0.6875rem 1rem 0.8125rem;
  margin: 3.5rem auto;
  background: var(--color-white) url("../images/common/icon-select-arrow.svg") center right 1rem/1.125rem 0.6875rem no-repeat;
  border: 0.0625rem solid var(--color-gray06);
}

@media screen and (max-width: 750px) {
  .bl-manufacturer-select {
    width: 39.375rem;
    padding: 1.03125rem 4rem 1.21875rem 1.5rem;
    background: var(--color-white) url("../images/common/icon-select-arrow.svg") center right 1.5rem/1.6875rem 1rem no-repeat;
  }
}
/* =======================================================
おすすめイベント
======================================================= */
.c-recommendedevents .c-recommendedevents-slide {
  width: 26.5rem;
  margin-right: 2.25rem;
}
.c-recommendedevents .c-recommendedevents-slide-wrapper {
  margin-bottom: 2rem;
}
.c-recommendedevents .c-recommendedevents-slide-pagination {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 2.75rem;
}
.c-recommendedevents .c-recommendedevents-slide-link > img {
  height: 18.75rem;
  object-fit: cover;
}
.c-recommendedevents .c-recommendedevents-slide-link-date {
  display: block;
  margin-top: 0.5rem;
  text-align: left;
}
.c-recommendedevents .c-recommendedevents-slide-link-ttl {
  display: block;
  font-size: 1.0625rem;
  font-weight: 700;
  text-align: left;
}
.c-recommendedevents .c-recommendedevents-btn {
  margin: 0 auto;
}
.c-recommendedevents .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.c-recommendedevents .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0;
}
.c-recommendedevents .swiper-pagination-bullet {
  width: 0.75rem;
  height: 0.75rem;
  background: var(--color-contrast);
  opacity: 1;
}
.c-recommendedevents .swiper-pagination-bullet-active {
  background: var(--color-accent);
}
.c-recommendedevents-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 9999;
  display: none;
  place-content: center;
  width: 100vw;
  height: 100vh;
  background: var(--color-contrast);
  transform: translate(-50%, -50%);
}
.c-recommendedevents-modal.--js-active {
  display: grid;
}
.c-recommendedevents-modal .c-modal-inner {
  position: relative;
  padding: 3.5rem 5.75rem;
  background: var(--color-white);
}
.c-recommendedevents-modal .c-modal-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  display: block;
  width: 3rem;
  cursor: pointer;
  transition: all 0.5s ease;
}
@media (hover: hover) {
  .c-recommendedevents-modal .c-modal-close:hover {
    opacity: 0.7;
  }
}
.c-recommendedevents-modal .c-modal-column {
  display: grid;
  grid-template-columns: 35.125rem 1fr;
  gap: 3.5rem;
}
.c-recommendedevents-modal .c-modal-imgwrapper > img {
  height: 24.875rem;
  object-fit: cover;
}
.c-recommendedevents-modal .c-modal-body {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
}
.c-recommendedevents-modal .c-modal-ttl {
  margin-bottom: 2.5rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.3;
}
.c-recommendedevents-modal .c-modal-date {
  margin-bottom: 1.5rem;
  font-size: 1.25rem;
}
.c-recommendedevents-modal .c-modal-conts {
  margin-bottom: 1rem;
  font-size: 1.25rem;
}
.c-recommendedevents-modal .c-modal-att-wrapper {
  align-self: end;
  margin-bottom: 1rem;
}
.c-recommendedevents-modal .c-modal-att a {
  text-decoration: underline;
}

@media screen and (width <= 750px) {
  .c-recommendedevents .c-recommendedevents-slide {
    width: 28.25rem;
    margin-right: 1.25rem;
  }
  .c-recommendedevents .c-recommendedevents-slide-wrapper {
    margin-bottom: 3.5rem;
  }
  .c-recommendedevents .c-recommendedevents-slide-pagination {
    gap: 1.5rem;
    margin-bottom: 4rem;
  }
  .c-recommendedevents .c-recommendedevents-slide-link > img {
    height: 20rem;
  }
  .c-recommendedevents .c-recommendedevents-slide-link-date {
    margin-top: 0.75rem;
  }
  .c-recommendedevents .c-recommendedevents-slide-link-ttl {
    font-size: 1.75rem;
  }
  .c-recommendedevents .c-recommendedevents-btn-wrapper {
    text-align: center;
  }
  .c-recommendedevents .swiper-pagination-bullet {
    width: 1.5rem;
    height: 1.5rem;
  }
  .c-recommendedevents-modal {
    place-content: center;
    overflow-y: scroll;
  }
  .c-recommendedevents-modal .c-modal-inner {
    padding: 8rem 1.875rem 4rem;
  }
  .c-recommendedevents-modal .c-modal-close {
    top: 2.25rem;
    right: 2.25rem;
    width: 4rem;
  }
  .c-recommendedevents-modal .c-modal-column {
    grid-template-columns: auto;
  }
  .c-recommendedevents-modal .c-modal-imgwrapper > img {
    height: 30.5rem;
  }
  .c-recommendedevents-modal .c-modal-ttl {
    font-size: 1.875rem;
  }
  .c-recommendedevents-modal .c-modal-ttl-manufacturer {
    font-size: 2.25rem;
  }
  .c-recommendedevents-modal .c-modal-date {
    font-size: 1.75rem;
  }
  .c-recommendedevents-modal .c-modal-conts {
    margin-bottom: 1.5rem;
    font-size: 1.875rem;
  }
  .c-recommendedevents-modal .c-modal-att-wrapper {
    margin-bottom: 0;
  }
}
/* =======================================================
hover
======================================================= */
.c-hover {
  transition: all 0.5s ease;
}
@media (hover: hover) {
  .c-hover.--opacity:hover {
    opacity: 0.7;
  }
}

/* =======================================================
c-post-single
======================================================= */
.c-post-single {
  padding: 6rem 0 8rem;
}
.c-post-single .ly-cont-inner {
  max-width: 80rem;
}
.c-post-single-ttl {
  padding: 1.0625rem 1rem 1.1875rem;
  margin-bottom: 1.5rem;
  font-size: 2rem;
  background: var(--color-contrast);
  border-top: 0.1875rem solid var(--color-accent);
}
.c-post-single-header {
  display: flex;
  gap: 3.125rem;
  align-items: center;
  margin-bottom: 1.5rem;
}
.c-post-single-date {
  font-size: 0.9375rem;
}
.c-post-single-cont {
  margin-bottom: 3.5rem;
  /* 記事内見出し */
  /* 記事内小見出し */
}
.c-post-single-cont .bl-post-h2 {
  padding: 0.8125rem 1rem 0.9375rem;
  font-size: 1.75rem;
}
.c-post-single-cont .bl-post-h3 {
  padding: 0 0 0.5rem 1.5rem;
  font-size: 1.5rem;
  border-bottom: 0.0625rem solid var(--color-accent);
}
.c-post-single-cont .bl-post-h3::before {
  width: 0.5rem;
  height: calc(100% - 0.5rem);
}
.c-post-single-cont .c-post-def {
  grid-template-columns: auto 1fr;
}
.c-post-single-cont .c-post-def .c-post-dttl {
  padding: 1.3125rem 2rem 1.4375rem;
  font-size: 1.25rem;
}
.c-post-single-cont .c-post-def .c-post-ditem {
  padding: 1.125rem 2rem 1.1875rem;
}
.c-post-single-cont .c-post-column {
  grid-template-columns: 20.625rem 1fr;
  gap: 2rem;
}
.c-post-single-cont .c-post-column .c-column-imgwrapper > img {
  height: 12.125rem;
}
.c-post-single-cont .bl-post-h4 {
  width: fit-content;
  padding-bottom: 0.25rem;
  font-size: 1.375rem;
  border-bottom: 0.0625rem solid var(--color-accent);
}
.c-post-single-cont p > img {
  width: fit-content;
  max-width: 50%;
}
.c-post-single-cont p > img.aligncenter {
  display: block;
  margin: 0 auto;
}
.c-post-single-cont p > img.alignright {
  display: block;
  margin-left: auto;
}
.c-post-single-cont p > iframe {
  display: block;
  margin: 0 auto;
}
.c-post-single-cont table:not(.def) thead th {
  padding: 0.9375rem 0 0.875rem;
  font-size: 1.125rem;
  border: 0.0625rem solid var(--color-gray02);
}
.c-post-single-cont table:not(.def) thead th span {
  font-size: 0.875rem;
}
.c-post-single-cont table:not(.def) tbody th,
.c-post-single-cont table:not(.def) tbody td {
  padding: 0.9375rem 1.5rem;
  border: 0.0625rem solid var(--color-gray02);
}
.c-post-single-cont table:not(.def) tbody td {
  padding-inline: 2rem;
}
.c-post-single-cont table:not(.def) tbody td p + p {
  margin-top: 0.5rem;
}
.c-post-single-cont table.def tbody tr th,
.c-post-single-cont table.def tbody tr td {
  padding: 1.5rem 2rem;
}
.c-post-single-cont table.def tbody tr th {
  font-size: 1.125rem;
  border: 0.0625rem solid var(--color-gray02);
}
.c-post-single-cont table.def tbody tr th span {
  font-size: 0.875rem;
}
.c-post-single-cont table.def tbody tr td {
  border: 0.0625rem solid var(--color-gray02);
}
.c-post-single .c-detail-btn {
  margin: 0 auto;
}
.c-post-single .c-detail-btn-wrapper {
  margin-bottom: 6rem;
}
.c-post-single-pager-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  align-items: center;
  justify-content: center;
}
.c-post-single-pager-link {
  display: block;
  width: 3.75rem;
  height: 3.75rem;
}
.c-post-single-pager-link.--next {
  transform: scale(-1, 1);
}

@media screen and (max-width: 750px) {
  .c-post-single-ttl {
    padding: 1.59375rem 1.5rem 1.78125rem;
    margin-bottom: 2rem;
    font-size: 2.5rem;
    border-width: 0.28125rem;
  }
  .c-post-single-header {
    margin-bottom: 2rem;
  }
  .c-post-single-date {
    font-size: 1.5625rem;
  }
  .c-post-single-cont {
    margin-bottom: 4rem;
    /* 記事内見出し */
    /* 記事内小見出し */
  }
  .c-post-single-cont .bl-post-h2 {
    padding: 1.21875rem 1.5rem 1.40625rem;
    font-size: 2.25rem;
  }
  .c-post-single-cont .bl-post-h3 {
    padding: 0 0 0.75rem 2.25rem;
    font-size: 2rem;
    border-width: 0.09375rem;
  }
  .c-post-single-cont .bl-post-h3::before {
    width: 0.75rem;
    height: calc(100% - 0.75rem);
  }
  .c-post-single-cont .c-post-def {
    grid-template-columns: auto;
  }
  .c-post-single-cont .c-post-def .c-post-dttl {
    font-size: 1.875rem;
  }
  .c-post-single-cont .c-post-def .c-post-dttl:not(:first-of-type) {
    border-top: none;
  }
  .c-post-single-cont .c-post-def .c-post-ditem:not(:first-of-type) {
    border-top: none;
  }
  .c-post-single-cont .c-post-column {
    grid-template-columns: auto;
  }
  .c-post-single-cont .c-post-column .c-column-imgwrapper > img {
    height: 24.25rem;
  }
  .c-post-single-cont .bl-post-h4 {
    padding-bottom: 0.375rem;
    font-size: 2rem;
  }
  .c-post-single-cont p > img {
    width: 100%;
    max-width: 100%;
  }
  .c-post-single-cont p > iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
  .c-post-single-cont table:not(.def) thead th {
    padding: 1.3125rem 0 1.375rem;
    font-size: 1.625rem;
    border-width: 0.125rem;
  }
  .c-post-single-cont table:not(.def) thead th span {
    font-size: 1.25rem;
  }
  .c-post-single-cont table:not(.def) tbody th,
  .c-post-single-cont table:not(.def) tbody td {
    padding: 1.375rem 2.5rem 1.5rem;
    border-width: 0.125rem;
  }
  .c-post-single-cont table:not(.def) tbody td {
    padding-inline: 2.5rem;
  }
  .c-post-single-cont table:not(.def) tbody td p + p {
    margin-top: 0.75rem;
  }
  .c-post-single-cont table.def tbody tr th,
  .c-post-single-cont table.def tbody tr td {
    padding: 2rem 2.5rem;
  }
  .c-post-single-cont table.def tbody tr th {
    font-size: 1.875rem;
    border-width: 0.125rem;
  }
  .c-post-single-cont table.def tbody tr th span {
    font-size: 1.5rem;
  }
  .c-post-single-cont table.def tbody tr td {
    border-width: 0.125rem;
  }
  .c-post-single-cont .bl-tbl-wrapper {
    width: 45rem;
    margin-top: 1em !important;
    overflow-x: scroll;
  }
  .c-post-single-cont .bl-tbl-wrapper table {
    width: max-content;
  }
  .c-post-single-cont .bl-tbl-wrapper table tbody tr td {
    font-size: 1.75rem;
  }
  .c-post-single-archive-link.--normal.--reverse {
    border-width: 0.125rem;
  }
  .c-post-single-pager-inner {
    gap: 3rem;
  }
  .c-post-single-pager-link {
    width: 5.625rem;
    height: 5.625rem;
  }
}
/* =======================================================
c-pagenavi
======================================================= */
.c-pagenavi {
  margin-top: 6rem;
}
.c-pagenavi .wp-pagenavi {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
}
.c-pagenavi .wp-pagenavi > * {
  display: grid;
  place-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding-bottom: 0.0625rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-accent);
  background: var(--color-white);
  border: 0.0625rem solid;
}
.c-pagenavi .wp-pagenavi > *.current {
  color: var(--color-white);
  background: var(--color-accent);
  border: none;
}

/* =======================================================
c-faq
======================================================= */
.c-faq-details-wrapper {
  display: grid;
  gap: 3rem;
}
.c-faq-details-summary {
  position: relative;
  background: var(--color-contrast);
}
.c-faq-details-summary::before {
  position: absolute;
  top: 0.4375rem;
  left: 2rem;
  width: 2.5rem;
  height: 2.5rem;
  content: "";
  background: url("../images/common/faq-q.svg") center center/cover no-repeat;
}
.c-faq-details-summary-inner {
  position: relative;
  display: block;
  padding: 0.75rem 5rem 0.8125rem;
  font-size: 1.25rem;
  line-height: calc(28/20);
}
.c-faq-details-summary-inner::before {
  position: absolute;
  top: 0.75rem;
  right: 1rem;
  width: 1.875rem;
  height: 1.875rem;
  content: "";
  background: var(--color-white);
}
.c-faq-details-summary-inner::after {
  position: absolute;
  top: 1.375rem;
  right: 1.5625rem;
  width: 0;
  height: 0;
  content: "";
  border-color: var(--color-accent) transparent transparent;
  border-style: solid;
  border-width: 0.625rem 0.375rem 0;
}
.c-faq-details-content-inner {
  padding-top: 2rem;
}
.c-faq-details-content-inner a {
  color: var(--color-accent);
  text-decoration: underline;
}
.c-faq-details[open] .c-faq-details-summary-inner::after {
  border-color: transparent transparent var(--color-accent);
  border-width: 0 0.375rem 0.625rem;
}

@media screen and (max-width: 750px) {
  .c-faq-details-wrapper {
    gap: 3.5rem;
  }
  .c-faq-details-summary::before {
    top: 0.65625rem;
    width: 3.75rem;
    height: 3.75rem;
  }
  .c-faq-details-summary-inner {
    padding: 1.125rem 7.5rem 1.21875rem;
    font-size: 1.875rem;
  }
  .c-faq-details-summary-inner::before {
    top: 1.125rem;
    right: 1.5rem;
    width: 2.8125rem;
    height: 2.8125rem;
  }
  .c-faq-details-summary-inner::after {
    top: 2.0625rem;
    right: 2.34375rem;
    border-width: 0.9375rem 0.5625rem 0;
  }
  .c-faq-details-content-inner {
    padding-top: 3rem;
  }
  .c-faq-details[open] .c-faq-details-summary-inner::after {
    border-width: 0 0.5625rem 0.9375rem;
  }
}
/* =======================================================
c-access
======================================================= */
.c-access-address {
  display: grid;
  grid-template-columns: 41.25rem 1fr;
  gap: 4rem;
  align-items: center;
  margin-bottom: 3rem;
}
.c-access-address .bl-address-iframe-wrapper {
  position: relative;
  display: flex;
  align-self: start;
}
.c-access-address .bl-address-iframe-wrapper::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  content: "";
  border: 1px solid var(--color-gray02);
  transform: translate(-50%, -50%);
}
.c-access-address .bl-address-iframe-wrapper > iframe {
  position: relative;
  z-index: 2;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9.5;
}
.c-access-address .bl-address-body > * + * {
  margin-top: 1rem;
}
.c-access-address .bl-address-txt a {
  color: var(--color-accent);
  text-decoration: underline;
}
.c-access-address .bl-address-def {
  display: grid;
  gap: 0.375rem;
}
.c-access-address .bl-address-dwrap {
  display: flex;
  grid-template-columns: auto 1fr;
}
.c-access-address .bl-address-dttl {
  display: flex;
}
.c-access-address .bl-address-dttl::after {
  content: "：";
}
.c-access-address .bl-address-btn {
  background: var(--color-accent);
}
.c-access-method {
  padding: 2.5rem 5rem;
  background: var(--color-white);
}
.c-access-method-wrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
}
.c-access-method.--car .bl-method-ttl::before {
  background: url("../images/common/icon-car.svg") top center/contain no-repeat;
}
.c-access-method.--train .bl-method-ttl::before {
  background: url("../images/common/icon-train.svg") top center/contain no-repeat;
}
.c-access-method .bl-method-ttl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 1.6875rem;
}
.c-access-method .bl-method-ttl::before {
  width: 1.875rem;
  height: 1.875rem;
  content: "";
}
.c-access-method .bl-method-txt {
  margin-bottom: 0.5rem;
  font-weight: 700;
}
.c-access-method .el-att {
  margin-bottom: 1rem;
}

@media screen and (max-width: 750px) {
  .c-access-address {
    grid-template-columns: auto;
    margin-bottom: 4rem;
  }
  .c-access-address .bl-address-iframe-wrapper > iframe {
    aspect-ratio: 16/10.5;
  }
  .c-access-address .bl-address-body {
    padding: 0 0 0 3.75rem;
  }
  .c-access-address .bl-address-body > * + * {
    margin-top: 2rem;
  }
  .c-access-address .bl-address-def {
    gap: 0;
  }
  .c-access-address .bl-address-txt.--btm {
    font-size: 1.25rem;
  }
  .c-access-method {
    padding: 3.75rem;
  }
  .c-access-method-wrapper {
    grid-template-columns: auto;
    gap: 2.5rem;
  }
  .c-access-method .bl-method-ttl {
    gap: 1rem;
    margin-bottom: 1.5rem;
  }
  .c-access-method .bl-method-ttl::before {
    width: 2.875rem;
    height: 2.875rem;
  }
  .c-access-method .bl-method-txt {
    margin-bottom: 1.5rem;
  }
  .c-access-method .el-att {
    margin-bottom: 2rem;
  }
}