@charset "UTF-8";
/* ============================
    reset
============================*/
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated:2010-09-17
Author:Richard Clark - http://richclarkdesign.com 
Twitter:@rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video,
button {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  line-height: 1;
}

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

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  color: initial;
}

a:active, a:hover {
  outline-width: 0;
}

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

img {
  max-width: 100%;
  height: auto;
  width: auto;
  border: 0;
  border-style: none;
  vertical-align: top;
}

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

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  box-sizing: border-box;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

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

/*color*/
/* ブランシエラカラー */
/*font-family*/
/*filler color*/
/*text-shadow*/
/*box-shadow*/
/*media query break point*/
/*mainBP*/
/*gHeader用*/
/*innerの片側はみ出し用*/
/*cubic*/
/* media query */




/* ==========================================================
 font size
========================================================== */
html {
  font-size: 62.5%;
}
@media only screen and (max-width: 1080px) {
  html {
    font-size: 0.9267840593vw;
  }
}
@media only screen and (max-width: 767px) {
  html {
    font-size: 2.6041666667vw;
  }
}

/* ==========================================================
 base body style
========================================================== */
body {
  color: #231815;
  font-family: YakuHanMP, "Noto Serif", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-weight: 400;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.7;
  overflow-y: scroll;
  overflow-x: hidden;
}
@media only screen and (max-width: 767px) {
  body {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  body {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 767px) {
  body {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  body {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  body {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 767px) {
  body.js-nav-open {
    overflow: hidden;
  }
}

main {
  letter-spacing: 0.1em;
}

.contents {
  margin-top: 12.8rem;
}
@media only screen and (max-width: 767px) {
  .contents {
    margin-top: 7.8rem;
  }
}

/* ==========================================================
 slideIn anime
========================================================== */
/* ==========================================================
 other resets
========================================================== */
i,
em {
  font-style: normal;
}

i {
  display: inline-block;
}

body.js-open-header {
  overflow-y: hidden;
}
.p-loc__nav {
  display: none;
}

.l-header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
}
.l-header__hamburger {
  display: none;
  width: 4rem;
  height: 4.3rem;
}
@media only screen and (max-width: 767px) {
  .l-header__hamburger {
    display: flex;
    flex-direction: column;
    position: relative;
  }
}
.l-header__hamburger__icon {
  display: block;
  width: 100%;
  height: 4rem;
  position: relative;
  transition: 0.3s;
}
.l-header__hamburger__icon i {
  display: block;
  position: absolute;
  height: 1px;
  width: 100%;
  background: #fff;
  border-radius: 2px;
  opacity: 1;
  left: 0;
  transition: all 0.8s ease;
}
.l-header__hamburger__icon i:nth-child(1) {
  top: 0;
}
.l-header__hamburger__icon i:nth-child(2) {
  top: 50%;
  transform: translateY(-50%);
}
.l-header__hamburger__icon i:nth-child(3) {
  bottom: 0;
}
body.js-open-header .l-header__hamburger .l-header__hamburger__icon {
  transform: translateY(-0.5rem) scaleX(-100%);
}
body.js-open-header .l-header__hamburger .l-header__hamburger__icon i:nth-child(1) {
  top: 50%;
  transform: rotate(45deg);
}
body.js-open-header .l-header__hamburger .l-header__hamburger__icon i:nth-child(2) {
  opacity: 0;
  transform: rotate(45deg);
}
body.js-open-header .l-header__hamburger .l-header__hamburger__icon i:nth-child(3) {
  top: 50%;
  transform: rotate(-45deg);
}
.l-header__hamburger__txt {
  display: block;
  width: 100%;
  height: 2rem;
  position: relative;
  padding-top: 1.2em;
  font-size: 1rem;
  letter-spacing: 0.3em;
}
.l-header__hamburger__menu {
  display: block;
  text-align: center;
  line-height: 0;
  transition: 0.5s;
  color: #fff;
}
body.js-open-header .l-header__hamburger__menu {
  letter-spacing: -1em;
  opacity: 0;
}
.l-header__hamburger__close {
  display: block;
  text-align: center;
  line-height: 0;
  transition: 0.5s;
  opacity: 0;
  color: #fff;
}
body.js-open-header .l-header__hamburger__close {
  opacity: 1;
  letter-spacing: 0.1em;
}
.l-header__wrap {
  width: 100%;
  width: 90%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: min-content 1fr;
  align-items: flex-end;
  align-items: center;
  gap: 2rem;
  position: relative;
  padding-top: 2rem;
}
@media only screen and (max-width: 767px) {
  .l-header__wrap {
    width: 100%;
    padding: 2rem 1.2rem 1.5rem;
    grid-template-columns: 1fr 5.6rem;
    gap: 2rem;
  }
}
.l-header__wrap::after {
  content: "";
  width: 100vw;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #001d50;
  z-index: -1;
}
body.js-open-header .l-header__wrap.l-header__wrap::after {
  box-shadow: 0px 0px 2px #6e8aac, 0px 0px 2px #6e8aac, 0px 0px 4px #6e8aac, 0px 0px 8px #6e8aac;
}
.l-header__wrap__shadow {
  content: "";
  width: 100vw;
  height: 100%;
  pointer-events: none;
  position: fixed;
  top: 0%;
  left: 0%;
  background: hsla(0, 0%, 20%, 0);
  z-index: -1;
  transition: 0.5s;
}
body.js-open-header .l-header__wrap .l-header__wrap__shadow {
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  transition: 0.5s;
  pointer-events: all;
  background: rgba(56, 56, 56, 0.75);
}
.l-header__logo {
  display: block;
  width: 100%;
  max-width: 30rem;
  min-width: 25rem;
  height: auto;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-header__logo:hover {
    opacity: 0.8;
  }
}
.l-header__logo__inner {
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
  display: block;
}
.l-header__logo__img {
  width: 100%;
  height: auto;
  display: block;
}
.l-header__inner {
  display: block;
  height: -moz-fit-content;
  height: fit-content;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 2.6rem;
}
@media only screen and (max-width: 767px) {
  .l-header__inner {
    right: -100%;
    position: fixed;
    transition: 0.6s ease;
    z-index: -1;
  }
}
@media only screen and (max-width: 767px) {
  body.js-open-header .l-header .l-header__inner {
    right: 0;
    opacity: 1;
  }
  body.js-open-header .l-header .l-header__inner .l-header__listbtm {
    filter: blur(0px);
    opacity: 1;
  }
}
.l-header__listtop {
  height: 3.5rem;
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
  align-items: center;
  font-size: 1.3rem;
}
@media only screen and (max-width: 767px) {
  .l-header__listtop {
    display: none;
  }
}
.l-header__listtop__item {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  height: 100%;
  line-height: 1.5;
  display: flex;
  align-items: center;
}
.l-header__listtop__item__a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 0.5em;
  margin-right: 1rem;
  color: #fff;
  position: relative;
}
.l-header__listtop__item__a .u-arw-next {
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-header__listtop__item__a:hover {
    opacity: 0.8;
  }
  .l-header__listtop__item__a:hover .u-arw-next {
    transform: translateX(-5%) rotate(45deg);
  }
}
.l-header__listtop__item__a .-new {
  font-size: 0.6em;
  letter-spacing: 0.15em;
  white-space: nowrap;
  background: #982529;
  padding: 0 0.5em;
}
.l-header__listtop__item-navy {
  width: 18rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #001d50;
  border: solid 1px #001d50;
  color: #fff;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-header__listtop__item-navy:hover {
    color: #B4A379;
    background: #fff;
  }
}
.l-header__listtop__item-gold {
  width: 18rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #B4A379;
  border: solid 1px #B4A379;
  color: #fff;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-header__listtop__item-gold:hover {
    color: #B4A379;
    background: #fff;
  }
}
.l-header__listbtm {
  display: flex;
  font-size: 1.2rem;
  letter-spacing: 0;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm {
    overflow-y: scroll;
    padding-top: 3rem;
    padding-bottom: 3rem;
    font-size: 0.6rem;
    background-image: url(../../images/common/nav_bg-pc.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    width: 90vw;
    flex-direction: column;
    opacity: 0;
    transition: 0.3s;
    filter: blur(10px);
    position: relative;
    z-index: 0;
  }
}
.l-header__listbtm__item {
  width: 11.1111111111%;
  display: block;
  position: relative;
  text-align: center;
  border-left: 1px solid #cccccc;
}
.l-header__listbtm__item:last-of-type {
  border-right: 1px solid #cccccc;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item {
    width: 100%;
    border: none;
    height: 8em;
  }
}
.l-header__listbtm__item-2col {
  display: none;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item-2col {
    display: grid;
    grid-template-columns: 1fr min-content 1fr;
    align-items: center;
    gap: 2rem;
    width: -moz-fit-content;
    width: fit-content;
    height: -moz-fit-content;
    height: fit-content;
    border: none !important;
    padding: 1rem 1rem 1rem 3rem !important;
  }
  .l-header__listbtm__item-2col a {
    display: grid;
    padding: 0.5em 0 !important;
    text-align: center;
    width: 100%;
    height: 100%;
    display: block;
    text-align: center;
  }
  .l-header__listbtm__item-2col span {
    display: inline-block;
    width: 1px;
    height: 50%;
    background: #fff;
  }
}
.l-header__listbtm__item-entrybtm {
  display: none;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item-entrybtm {
    display: grid;
    grid-template-columns: 1fr;
    width: 90%;
    gap: 0.5rem;
    border: none !important;
    padding: 1rem !important;
    margin-top: 3rem;
    margin-inline: auto;
  }
  .l-header__listbtm__item-entrybtm a {
    display: grid;
    place-content: center;
    padding: 0.5em 1em !important;
    text-align: center;
    width: 100%;
    display: block;
    text-align: center;
  }
}
.l-header__listbtm__item a {
  display: block;
  width: 100%;
  color: #fff;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item a {
    letter-spacing: 0.2em;
    display: flex;
    align-items: center;
    gap: 1rem;
    height: 100%;
    padding-left: 3rem;
    color: #fff;
    font-size: 1rem;
  }
  .l-header__listbtm__item a.-jp {
    font-size: 1.5rem;
  }
}
.l-header__listbtm__item a.-coming {
  pointer-events: none;
}
.l-header__listbtm__item a.-coming span {
  opacity: 0.5;
}
.l-header__listbtm__item span,
.l-header__listbtm__item i {
  font-family: "EB Garamond", "Noto Serif", serif;
}
.l-header__listbtm__item span.-new,
.l-header__listbtm__item i.-new {
  font-size: 0.6em;
  letter-spacing: 0.15em;
  white-space: nowrap;
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #982529;
  padding: 0 0.5em;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item span.-new,
  .l-header__listbtm__item i.-new {
    font-size: 0.8rem;
    transform: translateX(0);
    position: relative;
    bottom: unset;
    left: unset;
  }
}
.l-header__listbtm__item span.-coming,
.l-header__listbtm__item i.-coming {
  opacity: 0.5;
}
.l-header__listbtm__item span.-comingTxt,
.l-header__listbtm__item i.-comingTxt {
  font-size: 0.6em;
  letter-spacing: 0.15em;
  white-space: nowrap;
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #B4A379;
  padding: 0 0.5em;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item span.-comingTxt,
  .l-header__listbtm__item i.-comingTxt {
    font-size: 0.8rem;
    transform: translateX(0);
    position: relative;
    bottom: unset;
    left: unset;
  }
}
.l-header__listbtm__item::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  background: #B4A379;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-header__listbtm__item:hover.-coming::after {
    display: none;
  }
  .l-header__listbtm__item:hover::after {
    content: "";
    width: 50%;
    height: 2px;
  }
}
@media only screen and (hover: hover) and (pointer: fine) and (max-width: 767px) {
  .l-header__listbtm__item:hover::after {
    display: none;
  }
}
.l-header__listbtm__item.is-current::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 50%;
  height: 2px;
  background: #B4A379;
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item.is-current::after {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .l-header__listbtm__item.is-current a {
    background: #9C8D69;
    pointer-events: none;
  }
}
.l-header__listbtm__item__pc {
  font-size: 1.5em;
}
.l-header__listbtm__item__btn-gold {
  background-color: #9C8D69;
}
@media only screen and (max-width: 767px) {
  .l-header__spbtmwrap {
    display: block;
    width: 100%;
    height: -moz-fit-content;
    height: fit-content;
    position: fixed;
    bottom: 0;
    left: 0;
  }
}
.l-header__spbtm {
  display: none;
}
@media only screen and (max-width: 767px) {
  .l-header__spbtm {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: #fff;
    border-top: 1px solid #fff;
    z-index: 2;
  }
}
.l-header__spbtm__item {
  width: 100%;
  height: 100%;
}
.l-header__spbtm__item__a {
  display: block;
  padding: 0.8rem;
  background: #001d50;
  font-size: 1.3rem;
  color: #fff;
  text-align: center;
}
.l-header__spbtm__item__a-gold {
  background: #9C8D69;
}
.l-header__spbtm__item__a__icon {
  width: 100%;
  height: 2rem;
}

.l-footer {
  background: #fff;
}
.l-footer__pagetop {
  position: fixed;
  z-index: 10;
  bottom: 2rem;
  right: 2rem;
  width: 5rem;
  height: 5rem;
  background-color: #333;
  color: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 2.4rem;
  display: flex;
  opacity: 0;
  pointer-events: none;
  justify-content: center;
  align-items: center;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  transition: 0.3s;
}
.l-footer__pagetop.is-show {
  opacity: 0.5;
  pointer-events: all;
}
@media (hover: hover) and (pointer: fine) {
  .l-footer__pagetop:hover {
    background-color: #555;
  }
}
@media only screen and (max-width: 767px) {
  .l-footer__pagetop {
    right: 1rem;
    bottom: 7rem;
  }
}
.l-footer__nav {
  margin-bottom: 30px;
  padding: 0 0 2rem;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .l-footer__nav {
    padding: 0 0 2rem;
  }
}
.l-footer__nav__list {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 1px;
  padding: 0;
  margin: 0;
  list-style: none;
}
@media only screen and (max-width: 767px) {
  .l-footer__nav__list {
    justify-content: flex-start;
    gap: 1px;
  }
}
.l-footer__nav__list__item {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .l-footer__nav__list__item {
    justify-content: center;
    width: calc(50% - 1px);
  }
}
.l-footer__nav__list__item:first-of-type .l-footer__nav__list__item__link, .l-footer__nav__list__item:first-of-type .l-footer__nav__list__item__link--spGold {
  border-left: 1px solid #fff;
}
@media only screen and (max-width: 767px) {
  .l-footer__nav__list__item:first-of-type .l-footer__nav__list__item__link, .l-footer__nav__list__item:first-of-type .l-footer__nav__list__item__link--spGold {
    border-left: none;
  }
}
.l-footer__nav__list__item__link, .l-footer__nav__list__item__link--spGold {
  font-family: "EB Garamond", "Noto Serif", serif;
  font-size: 1rem;
  text-align: center;
  width: 100%;
  background: #b5b5b6;
  padding: 1rem 1rem;
  font-size: 1.4rem;
  color: #fff;
  transition: 0.3s;
  position: relative;
  border-right: 1px solid #fff;
}
.l-footer__nav__list__item__link.md-gold, .md-gold.l-footer__nav__list__item__link--spGold {
  background: #9b8c69;
}
@media only screen and (max-width: 767px) {
  .l-footer__nav__list__item__link, .l-footer__nav__list__item__link--spGold {
    border-bottom: 1px solid #fff;
    background: #DCDDDD;
    background: linear-gradient(0deg, rgb(220, 221, 221) 0%, rgb(181, 181, 182) 50%, rgb(220, 221, 221) 100%);
  }
}
@media only screen and (max-width: 767px) {
  .l-footer__nav__list__item__link--spGold {
    background: #B4A379;
    background: linear-gradient(0deg, rgb(180, 163, 121) 0%, rgb(156, 141, 105) 50%, rgb(180, 163, 121) 100%);
  }
}
@media (hover: hover) and (pointer: fine) {
  .l-footer__nav__list__item__link:hover, .l-footer__nav__list__item__link--spGold:hover {
    background: #001d50;
  }
}
.l-footer__nav__list__item.is-current a {
  pointer-events: none;
}
.l-footer__contact {
  padding: 2rem 2rem;
  text-align: center;
  color: #fff;
  background-image: url(../../images/common/bg_base.jpg);
  background-size: cover;
  background-repeat: repeat-y;
}
.l-footer__contact__txt {
  color: #231815;
  font-size: 1.3rem;
}
.l-footer__contact__txt--business {
  font-size: 1.3rem;
}
.l-footer__contact__tel {
  display: inline-flex;
  align-items: center;
  font-size: 4.5rem;
  line-height: 1.4;
  font-family: "Roboto", "Noto Serif", sans-serif;
}
@media only screen and (max-width: 767px) {
  .l-footer__contact__tel {
    font-size: 3rem;
  }
}
.l-footer__contact__freedial {
  margin-right: 10px;
}
.l-footer__contact__freedial .svgIcon {
  width: 40px;
  height: auto;
}
.l-footer__corporate {
  padding: 2rem 2rem;
  color: #fff;
}
.l-footer__corporate__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.l-footer__corporate__list {
  padding: 0;
  margin: 0;
  display: flex;
}
.l-footer__corporate__list__item {
  width: 16.5rem;
  height: auto;
  margin-bottom: 1rem;
}
.l-footer__corporate__list__item__a {
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .l-footer__corporate__list__item__a:hover {
    opacity: 0.8;
  }
}
.l-footer__corporate__list__item img {
  max-width: 100%;
  height: auto;
  display: block;
}
.l-footer__corporate__corporateList {
  width: auto;
  height: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4rem;
  padding: 0;
  margin: 0;
  list-style: none;
}
@media only screen and (max-width: 767px) {
  .l-footer__corporate__corporateList {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 1rem 1.5rem;
  }
}
.l-footer__corporate__corporateList__item {
  text-align: center;
}
.l-footer__corporate__corporateList__item__link {
  transition: 0.3s;
}
.l-footer__corporate__corporateList__item__link:hover {
  opacity: 0.7;
}
.l-footer__corporate__corporateList__item__link .role {
  display: block;
  font-size: 12px;
  margin-bottom: 5px;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .l-footer__corporate__corporateList__item__link .role {
    font-size: 10px;
    margin-bottom: 3px;
  }
}
.l-footer__corporate__corporateList__logo img {
  display: block;
  width: auto;
  height: 4rem;
}
@media only screen and (max-width: 767px) {
  .l-footer__corporate__corporateList__logo img {
    height: 2.8rem;
  }
}
.l-footer__copyright {
  color: #fff;
  background: #293855;
  border-top: 1px solid #444;
  margin-top: 30px;
  text-align: center;
  font-size: 12px;
  padding-top: 3rem;
  padding-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .l-footer__copyright {
    padding-bottom: 10rem;
  }
}
.l-footer__copyright__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
  color: #fff;
  transition: 0.3s;
}
.l-footer__copyright__link__logo {
  width: 20rem;
}
.l-footer__copyright__link:hover {
  opacity: 0.7;
}
.l-footer__copyright__txt {
  font-size: 1.2rem;
  display: block;
  font-family: YakuHanMP, "Noto Serif", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}
.l-footer-cap {
  padding-top: 5rem;
  padding-bottom: 5rem;
  background: #fff;
  font-size: 13px;
  font-size: 1.3rem;
}
@media only screen and (max-width: 767px) {
  .l-footer-cap {
    font-size: 11px;
  }
}
@media only screen and (max-width: 767px) {
  .l-footer-cap {
    font-size: 1.1rem;
  }
}
@media only screen and (max-width: 767px) {
  .l-footer-cap {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}

/* ------------------------------------------------------------
    下層メインビジュアル・イントロ
------------------------------------------------------------ */
.c-mv {
  width: 100%;
  height: calc(100vh - 14.3rem);
  position: relative;
  z-index: 4;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .c-mv {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
  }
}
.c-mv__img {
  width: 100%;
  height: 100%;
  opacity: 1;
  transition: 1.5s cubic-bezier(0.49, 0, 0.16, 0.99);
}
.c-mv__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.c-mv__img img.c-mv-in {
  -o-object-fit: contain;
     object-fit: contain;
}
@media only screen and (max-width: 767px) {
  .c-mv__img {
    width: 100%;
    height: 100%;
  }
  .c-mv__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.c-mv__heading {
  width: 100%;
  font-size: 36px;
  font-size: 3.6rem;
  letter-spacing: 0.15em;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .c-mv__heading {
    font-size: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .c-mv__heading {
    font-size: 3rem;
  }
}
.c-mv__heading small {
  font-size: 0.6em;
  line-height: 1.6;
  display: inline-block;
}
.c-mv__heading small span {
  display: inline-block;
}
.c-mv__heading small.voice {
  font-size: 0.5em;
  letter-spacing: 0.05em;
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .c-mv__heading small.voice {
    font-size: 0.4em;
  }
}
.c-mv__heading small.voice::before, .c-mv__heading small.voice::after {
  content: "";
  display: inline-block;
  width: 3rem;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.5);
}

.u-sp_scr_box {
  width: 100%;
  height: 100%;
  touch-action: pan-x;
  -webkit-overflow-scrolling: touch;
  /* iOS向け */
  overflow-x: auto;
  overflow-y: hidden;
}
.u-sp_scr_box::-webkit-scrollbar {
  height: 5px;
}
.u-sp_scr_box::-webkit-scrollbar-track {
  background: transparent;
}
.u-sp_scr_box::-webkit-scrollbar-thumb {
  cursor: pointer;
  background: #8d8d8d;
  border-radius: 10px;
}
@media only screen and (max-width: 767px) {
  .u-sp_scr_box {
    overflow-x: auto;
    white-space: nowrap;
    overflow-y: hidden;
    aspect-ratio: 1/1;
  }
}

.u-sp_scr_con {
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 767px) {
  .u-sp_scr_con img {
    max-width: unset;
    width: -moz-fit-content;
    width: fit-content;
    height: 100%;
  }
}

.c-ttl__wrap {
  width: 100%;
  height: 400px;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 767px) {
  .c-ttl__wrap {
    width: 100%;
    height: 100%;
    aspect-ratio: 16/9;
  }
}
.c-ttl__wrap-02 {
  margin: 0 auto;
  width: -moz-fit-content;
  width: fit-content;
  height: 300px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .c-ttl__wrap-02 {
    height: 130px;
  }
}
.c-ttl__wrap-02 .c-ttl__img {
  width: 45%;
}
.c-ttl__wrap-02 .c-ttl__txt02 {
  width: -moz-fit-content;
  width: fit-content;
}
.c-ttl__bg {
  width: 100%;
  height: auto;
  position: absolute;
  top: 0%;
  left: 50%;
  z-index: 1;
  transform: translate(-50%, 0%);
  aspect-ratio: 390/287;
}
.c-ttl__bg__img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: top center;
     object-position: top center;
}
.c-ttl__txtw, .c-ttl__txtw--wh {
  font-size: 56px;
  font-size: 5.6rem;
  font-family: "EB Garamond", "Noto Serif", serif;
  color: #231815;
  text-align: center;
  position: relative;
  z-index: 1;
  line-height: 1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  position: absolute;
}
@media only screen and (max-width: 767px) {
  .c-ttl__txtw, .c-ttl__txtw--wh {
    font-size: 37px;
  }
}
@media only screen and (max-width: 767px) {
  .c-ttl__txtw, .c-ttl__txtw--wh {
    font-size: 3.7rem;
  }
}
.c-ttl__txtw--wh {
  color: #fff;
}
.c-ttl__txtw__main {
  position: relative;
  margin-top: 1rem;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 0.5rem;
  display: block;
  margin-inline: auto;
}
.c-ttl__txtw__main::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
.c-ttl__txtw__sm {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 0.5rem;
  font-size: 0.75em;
  display: block;
  margin-inline: auto;
}
.c-ttl__txtw__sm::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
.c-ttl__txt02 {
  display: block;
  font-size: 56px;
  font-size: 5.6rem;
  font-family: "EB Garamond", "Noto Serif", serif;
  color: #231815;
  text-align: center;
  position: relative;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .c-ttl__txt02 {
    font-size: 33px;
  }
}
@media only screen and (max-width: 767px) {
  .c-ttl__txt02 {
    font-size: 3.3rem;
  }
}
.c-ttl__txt02.md-wh {
  color: #fff !important;
}
.c-ttl__txt02-main {
  position: relative;
  margin-top: 1rem;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 0.5rem;
  display: block;
  margin-inline: auto;
  font-size: 1.2em;
}
.c-ttl__txt02-sm {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 0.5rem;
  font-size: 0.65em;
  display: block;
  margin-inline: auto;
}
.c-ttl__img {
  width: auto;
  height: 150px;
}
@media only screen and (max-width: 767px) {
  .c-ttl__img {
    height: 80px;
  }
}
.c-ttl__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.c-lead {
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
  padding-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .c-lead {
    font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  .c-lead {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width: 767px) {
  .c-lead {
    padding-bottom: 2rem;
  }
}
.c-lead-wh {
  color: #fff;
}
.c-lead__cap {
  font-size: 0.7em;
  display: block;
}

.c-secTxt {
  font-size: 16px;
  font-size: 1.6rem;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .c-secTxt {
    font-size: 13px;
  }
}
@media only screen and (max-width: 767px) {
  .c-secTxt {
    font-size: 1.3rem;
  }
}
.c-bnr {
  width: 90%;
  max-width: 800px;
  margin-inline: auto;
  padding-block: 3rem;
}
.c-bnr a {
  width: 100%;
  display: block;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-bnr a:hover {
    opacity: 0.8;
  }
}

.c-content-summary__heading {
  text-align: center;
  font-size: 28px;
  font-size: 2.8rem;
  letter-spacing: 0.15em;
}
@media only screen and (max-width: 767px) {
  .c-content-summary__heading {
    font-size: 24px;
  }
}
@media only screen and (max-width: 767px) {
  .c-content-summary__heading {
    font-size: 2.4rem;
  }
}
.c-content-summary__catch {
  text-align: center;
  margin-top: 2rem;
  font-size: 24px;
  font-size: 2.4rem;
}
@media only screen and (max-width: 767px) {
  .c-content-summary__catch {
    font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  .c-content-summary__catch {
    font-size: 1.8rem;
  }
}
.c-content-summary__subcatch {
  text-align: center;
  margin-top: 2rem;
  font-size: 20px;
  font-size: 2rem;
}
@media only screen and (max-width: 767px) {
  .c-content-summary__subcatch {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .c-content-summary__subcatch {
    font-size: 1.6rem;
  }
}
.c-content-summary__lead {
  text-align: center;
  margin-top: 2rem;
  font-size: 16px;
  font-size: 1.6rem;
}
@media only screen and (max-width: 767px) {
  .c-content-summary__lead {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .c-content-summary__lead {
    font-size: 1.4rem;
  }
}

.c-location-localnav {
  max-width: 1000px;
  width: 90%;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .c-location-localnav {
    gap: 0.5rem;
  }
}
.c-location-localnav__item {
  width: 100%;
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  background-color: #b3a56c;
  color: #fff;
  font-size: 2.4rem;
  padding: 0.25rem;
  transition: 0.3s;
}
@media only screen and (max-width: 767px) {
  .c-location-localnav__item {
    font-size: 1.6rem;
  }
}
.c-location-localnav__item__inner {
  display: block;
  width: 100%;
  height: 100%;
  border: solid 1px rgba(255, 255, 255, 0.5);
  padding: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .c-location-localnav__item__inner {
    padding: 0.5rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .c-location-localnav__item:hover {
    background-color: #fff;
  }
}
.c-location-localnav__item--active {
  position: relative;
  pointer-events: none;
}
.c-location-localnav__item--active:after {
  content: "";
  position: absolute;
  bottom: -1.5rem;
  left: calc(50% - 1rem);
  display: inline-block;
  width: 2rem;
  height: 1.5rem;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}
.c-location-localnav__item--ft-active {
  position: relative;
  pointer-events: none;
}
.c-location-localnav__item--ft-active:after {
  content: "";
  position: absolute;
  top: -1.5rem;
  left: calc(50% - 1rem);
  display: inline-block;
  width: 2rem;
  height: 1.5rem;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
}

/* ------------------------------------------------------------
    display
------------------------------------------------------------ */
.c-pc {
  display: block;
}
@media only screen and (max-width: 767px) {
  .c-pc {
    display: none;
  }
}

.c-sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .c-sp {
    display: block;
  }
}

/* ------------------------------------------------------------
    flex layout
------------------------------------------------------------ */
.c-flex {
  width: 100%;
  display: flex;
}
.c-flex.flex-btw {
  justify-content: space-between;
}
.c-flex.flex-btw-basis {
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .c-flex.flex-btw-basis {
    flex-direction: column;
  }
}
.c-flex.flex-ard {
  justify-content: space-around;
}
.c-flex.flex-row {
  flex-direction: row;
}
.c-flex.flex-row-reverse {
  flex-direction: row-reverse;
}
.c-flex.flex-col {
  flex-direction: column;
}
.c-flex.flex-col-reverse {
  flex-direction: column-reverse;
}
.c-flex.flex-wrap {
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .c-flex.sm_flex-row {
    flex-direction: row;
  }
  .c-flex.sm_flex-row-reverse {
    flex-direction: row-reverse;
  }
  .c-flex.sm_flex-col {
    flex-direction: column;
  }
  .c-flex.sm_flex-col-reverse {
    flex-direction: column-reverse;
  }
  .c-flex.sm_flex-wrap {
    flex-wrap: wrap;
  }
}

/* ------------------------------------------------------------
    grid layout
------------------------------------------------------------ */
.c-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
}
.c-grid.gap5 {
  gap: 0.5rem;
}
.c-grid.gap10 {
  gap: 1rem;
}
.c-grid.gap15 {
  gap: 1.5rem;
}
.c-grid.gap20 {
  gap: 2rem;
}
.c-grid.gap25 {
  gap: 2.5rem;
}
.c-grid.gap30 {
  gap: 3rem;
}
.c-grid.gap35 {
  gap: 3.5rem;
}
.c-grid.gap40 {
  gap: 4rem;
}
.c-grid.gap45 {
  gap: 4.5rem;
}
.c-grid.gap50 {
  gap: 5rem;
}
.c-grid__col50 {
  grid-column: span 6;
}
.c-grid__col25 {
  grid-column: span 3;
}
.c-grid__col75 {
  grid-column: span 9;
}
.c-grid__col100 {
  grid-column: span 12;
}
.c-grid__c1 {
  grid-column: span 1;
}
.c-grid__c2 {
  grid-column: span 2;
}
.c-grid__c3 {
  grid-column: span 3;
}
.c-grid__c4 {
  grid-column: span 4;
}
.c-grid__c5 {
  grid-column: span 5;
}
.c-grid__c6 {
  grid-column: span 6;
}
.c-grid__c7 {
  grid-column: span 7;
}
.c-grid__c8 {
  grid-column: span 8;
}
.c-grid__c9 {
  grid-column: span 9;
}
.c-grid__c10 {
  grid-column: span 10;
}
.c-grid__c11 {
  grid-column: span 11;
}
.c-grid__c12 {
  grid-column: span 12;
}
@media only screen and (max-width: 1080px) {
  .c-grid.gap5--sp {
    gap: 0.5rem !important;
  }
  .c-grid.gap10--sp {
    gap: 1rem !important;
  }
  .c-grid.gap15--sp {
    gap: 1.5rem !important;
  }
  .c-grid.gap20--sp {
    gap: 2rem !important;
  }
  .c-grid.gap25--sp {
    gap: 2.5rem !important;
  }
  .c-grid.gap30--sp {
    gap: 3rem !important;
  }
  .c-grid.gap35--sp {
    gap: 3.5rem !important;
  }
  .c-grid.gap40--sp {
    gap: 4rem !important;
  }
  .c-grid.gap45--sp {
    gap: 4.5rem !important;
  }
  .c-grid.gap50--sp {
    gap: 5rem !important;
  }
  .c-grid__col50--md {
    grid-column: span 6;
  }
  .c-grid__col25--md {
    grid-column: span 3;
  }
  .c-grid__col75--md {
    grid-column: span 9;
  }
  .c-grid__col100--md {
    grid-column: span 12;
  }
  .c-grid__c1--md {
    grid-column: span 1;
  }
  .c-grid__c2--md {
    grid-column: span 2;
  }
  .c-grid__c3--md {
    grid-column: span 3;
  }
  .c-grid__c4--md {
    grid-column: span 4;
  }
  .c-grid__c5--md {
    grid-column: span 5;
  }
  .c-grid__c6--md {
    grid-column: span 6;
  }
  .c-grid__c7--md {
    grid-column: span 7;
  }
  .c-grid__c8--md {
    grid-column: span 8;
  }
  .c-grid__c9--md {
    grid-column: span 9;
  }
  .c-grid__c10--md {
    grid-column: span 10;
  }
  .c-grid__c11--md {
    grid-column: span 11;
  }
  .c-grid__c12--md {
    grid-column: span 12;
  }
}
@media only screen and (max-width: 767px) {
  .c-grid.gap5--sp {
    gap: 0.5rem !important;
  }
  .c-grid.gap10--sp {
    gap: 1rem !important;
  }
  .c-grid.gap15--sp {
    gap: 1.5rem !important;
  }
  .c-grid.gap20--sp {
    gap: 2rem !important;
  }
  .c-grid.gap25--sp {
    gap: 2.5rem !important;
  }
  .c-grid.gap30--sp {
    gap: 3rem !important;
  }
  .c-grid.gap35--sp {
    gap: 3.5rem !important;
  }
  .c-grid.gap40--sp {
    gap: 4rem !important;
  }
  .c-grid.gap45--sp {
    gap: 4.5rem !important;
  }
  .c-grid.gap50--sp {
    gap: 5rem !important;
  }
  .c-grid__col50--sp {
    grid-column: span 6;
  }
  .c-grid__col25--sp {
    grid-column: span 3;
  }
  .c-grid__col75--sp {
    grid-column: span 9;
  }
  .c-grid__col100--sp {
    grid-column: span 12;
  }
  .c-grid__c1--sp {
    grid-column: span 1;
  }
  .c-grid__c2--sp {
    grid-column: span 2;
  }
  .c-grid__c3--sp {
    grid-column: span 3;
  }
  .c-grid__c4--sp {
    grid-column: span 4;
  }
  .c-grid__c5--sp {
    grid-column: span 5;
  }
  .c-grid__c6--sp {
    grid-column: span 6;
  }
  .c-grid__c7--sp {
    grid-column: span 7;
  }
  .c-grid__c8--sp {
    grid-column: span 8;
  }
  .c-grid__c9--sp {
    grid-column: span 9;
  }
  .c-grid__c10--sp {
    grid-column: span 10;
  }
  .c-grid__c11--sp {
    grid-column: span 11;
  }
  .c-grid__c12--sp {
    grid-column: span 12;
  }
}

/* ------------------------------------------------------------
    txt
------------------------------------------------------------ */
.c-txtBr {
  display: inline-block;
}

.c-f_small {
  font-size: 80%;
}

.c-f_large {
  font-size: 160%;
}

.c-t_c {
  text-align: center !important;
}

.c-t_l {
  text-align: left !important;
}

.c-t_r {
  text-align: right !important;
}

@media only screen and (max-width: 767px) {
  .c-t_c-sp {
    text-align: center !important;
  }
  .c-t_l-sp {
    text-align: left !important;
  }
  .c-t_r-sp {
    text-align: right !important;
  }
}
/* ------------------------------------------------------------
    text size
------------------------------------------------------------ */
.c-f18 {
  font-size: 18px;
  font-size: 1.8rem;
}
@media only screen and (max-width: 767px) {
  .c-f18 {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .c-f18 {
    font-size: 1.6rem;
  }
}

.c-f14 {
  font-size: 14px;
  font-size: 1.4rem;
}
@media only screen and (max-width: 767px) {
  .c-f14 {
    font-size: 12px;
  }
}
@media only screen and (max-width: 767px) {
  .c-f14 {
    font-size: 1.2rem;
  }
}

.c-f12 {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .c-f12 {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .c-f12 {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 767px) {
  .c-f12 {
    font-size: 10px;
    font-size: 1rem;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  .c-f12 {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  .c-f12 {
    font-size: 1.4rem;
  }
}

.c-f11 {
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .c-f11 {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .c-f11 {
    font-size: 1rem;
  }
}

.c-f10 {
  line-height: 1.4;
  font-size: 10px;
  font-size: 1rem;
}
@media only screen and (max-width: 767px) {
  .c-f10 {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .c-f10 {
    font-size: 1rem;
  }
}

.c-cap {
  position: absolute;
  left: 0.5rem;
  bottom: 0.5rem;
  width: calc(100% - 10px);
  text-align: right;
  font-size: 11px;
  font-size: 1.1rem;
  letter-spacing: 0;
  line-height: 1.4;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 767px) {
  .c-cap {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .c-cap {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 767px) {
  .c-cap {
    font-size: 10px;
    font-size: 1rem;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  .c-cap {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  .c-cap {
    font-size: 1.4rem;
  }
}

/* ------------------------------------------------------------
	image caption
------------------------------------------------------------ */
.c-imgBox {
  position: relative;
}
.c-imgBox .c-imgBox__cap, .c-imgBox .c-imgBox__cap--under, .c-imgBox .c-imgBox__cap--L {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 1rem;
  color: #fff;
  background: rgba(0, 0, 0, 0.6);
  line-height: 1;
  padding: 2px 3px;
}
.c-imgBox .c-imgBox__cap--wh {
  color: rgba(255, 255, 255, 0.6);
  color: #231815;
}
.c-imgBox .c-imgBox__cap--L {
  right: unset;
  left: 0;
}
.c-imgBox .c-imgBox__cap--under {
  bottom: -1.5em;
}
.c-imgBox img {
  width: 100%;
}

/* ------------------------------------------------------------
    block
------------------------------------------------------------ */
.c-container {
  width: 90%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.c-container_mx {
  width: 90%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.c-container_1 {
  width: 85%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

/* ------------------------------------------------------------
    btn
------------------------------------------------------------ */
.c-link_tel {
  cursor: default;
  pointer-events: none;
}
@media only screen and (max-width: 767px) {
  .c-link_tel {
    pointer-events: initial;
    cursor: pointer;
  }
}

/* ==========================================================
    ローディングアニメーション
========================================================== */
.c-loader {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  background-color: #001d50;
  display: flex;
  justify-content: center;
  align-items: center;
}
.c-loader__anime {
  font-size: 10px;
  margin: 50px auto;
  text-indent: -9999em;
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  background: #ffffff;
  background: linear-gradient(to right, #ffffff 10%, #001d50 42%);
  position: relative;
  animation: load 1.4s infinite linear;
  transform: translateZ(0);
}
.c-loader__anime:before {
  width: 50%;
  height: 50%;
  background: #ffffff;
  border-radius: 100% 0 0 0;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
}
.c-loader__anime:after {
  background-color: #001d50;
  width: 85%;
  height: 85%;
  border-radius: 50%;
  content: "";
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

@keyframes load {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* ==========================================================
    間取りリスト・詳細
========================================================== */
.c-plan-list, .c-plan-list--col2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
  margin-top: -20rem;
  padding-top: 20rem;
}
@media only screen and (max-width: 767px) {
  .c-plan-list, .c-plan-list--col2 {
    grid-template-columns: 1fr;
    margin-top: -10rem;
    padding-top: 10rem;
  }
}
.c-plan-list--col2 {
  grid-template-columns: repeat(2, 33.33%);
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .c-plan-list--col2 {
    grid-template-columns: 1fr;
    margin-top: -10rem;
    padding-top: 10rem;
  }
}
.c-plan-list__item--lmd a {
  opacity: 0.7;
}
.c-plan-list__item__spec {
  display: flex;
  justify-content: center;
  gap: 2rem;
}
.c-plan-list__item__type {
  padding-bottom: 0.5rem;
}
.c-plan-list__item__limited {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  border-radius: 0 0 3px 3px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  color: #fff;
  font-size: 1.7rem;
  line-height: 1.4;
  transition: 0.3s;
  padding: 0.5rem 0;
}
.c-plan-list__item a {
  position: relative;
  display: block;
  padding: 2rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  border: 1px solid #eee;
  border-radius: 3px;
  text-align: center;
  color: #231815;
  font-size: min(2.4rem, 1.8vw);
  transition: 0.3s cubic-bezier(0.49, 0, 0.16, 0.99);
}
@media only screen and (max-width: 1080px) {
  .c-plan-list__item a {
    font-size: 20px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 1080px) and (max-width: 767px) {
  .c-plan-list__item a {
    font-size: 24px;
  }
}
@media only screen and (max-width: 1080px) and (max-width: 767px) {
  .c-plan-list__item a {
    font-size: 2.4rem;
  }
}
.c-plan-list__item a em {
  font-size: 1.5em;
}
@media (hover: hover) and (pointer: fine) {
  .c-plan-list__item a:hover:hover {
    background-color: rgba(243, 242, 238, 0.4);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0);
  }
  .c-plan-list__item a:hover:hover .c-plan-list__item__limited {
    background-color: rgba(255, 255, 255, 0.95);
  }
}
.c-plan-list__item__more {
  font-size: 1.4rem;
  line-height: 1;
  padding: 0.8rem;
  width: 50%;
  margin: 1rem auto 0;
  color: #fff;
  border-radius: 2em;
  border: 1px solid #ddd;
  transition: 0.3s;
}

.c-plan-point__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
@media only screen and (max-width: 767px) {
  .c-plan-point__list {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
.c-plan-point__list__item {
  position: relative;
  background-color: #866a25;
  color: #fff;
  text-align: center;
  padding: 1.5rem;
  font-size: 24px;
  font-size: 2.4rem;
}
@media only screen and (max-width: 767px) {
  .c-plan-point__list__item {
    font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  .c-plan-point__list__item {
    font-size: 1.8rem;
  }
}
.c-plan-point__list__item::after {
  content: "";
  display: block;
  border: 1px solid rgba(255, 255, 255, 0.5);
  width: calc(100% - 1rem);
  height: calc(100% - 1rem);
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
}

.c-plan-detail__inner {
  width: 90%;
  max-width: 950px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 10rem;
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 1080px) {
  .c-plan-detail__inner {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 5rem;
  }
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__inner {
    padding: 5rem 0;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.c-plan-detail__spec {
  font-size: 36px;
  font-size: 3.6rem;
  text-align: center;
  width: calc(100% - 630px);
  padding-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec {
    font-size: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 1080px) {
  .c-plan-detail__spec {
    width: auto;
    padding-top: 0;
  }
}
.c-plan-detail__spec em {
  font-size: 1.5em;
}
.c-plan-detail__spec__type {
  position: relative;
  line-height: 1;
  background-size: 100% 1px;
  background-repeat: no-repeat;
  background-position: left 1.25em;
}
.c-plan-detail__spec__rooms {
  line-height: 1;
}
.c-plan-detail__spec__area {
  line-height: 1.2;
}
.c-plan-detail__spec__area span {
  font-size: 1.4rem;
  display: block;
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec__area span {
    display: inline-block;
  }
}
.c-plan-detail__spec__other {
  line-height: 1.2;
  font-size: 14px;
  font-size: 1.4rem;
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec__other {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec__other {
    font-size: 1.4rem;
  }
}
.c-plan-detail__spec__other span {
  font-size: 1.5em;
}
@media only screen and (max-width: 767px) {
  .c-plan-detail__spec__other span {
    display: inline-block;
  }
}
.c-plan-detail__point {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.c-plan-detail__point__item {
  display: grid;
  grid-template-columns: 1.6em auto;
  font-size: 1.4rem;
  text-align: left;
}
.c-plan-detail__img {
  width: 600px;
}
@media only screen and (max-width: 1080px) {
  .c-plan-detail__img {
    width: auto;
  }
}

.c-plan-cap {
  width: 90%;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.2rem;
}
.c-plan-cap__note {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.c-plan-cap__note__item {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.c-plan-cap__note__icon {
  height: 1em;
  width: 3em;
}

.c-planDetail-btns {
  width: 90%;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: center;
  gap: 2rem;
}
.c-planDetail-btns a {
  background-color: #fff;
  width: 300px;
  padding: 1rem;
  text-align: center;
  color: #231815;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-planDetail-btns a:hover:hover {
    background-color: #fff;
  }
}

.js-zoomable-img {
  user-drag: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: auto;
  cursor: grab;
  transition: transform 0.1s ease;
  transform-origin: center center;
  will-change: transform;
}

.c-zoo-controls {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.c-zoo-controls .c-zoom-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 8px 12px;
  font-size: 16px;
  cursor: pointer;
  border-radius: 4px;
}

.c-pageLinks {
  padding: 2.5rem 0 !important;
}
.c-pageLinks__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  max-width: 800px;
  margin-inline: auto;
}
@media only screen and (max-width: 767px) {
  .c-pageLinks__list {
    gap: 0;
  }
}
.c-pageLinks__item a {
  font-size: 24px;
  font-size: 2.4rem;
  text-align: center;
  display: block;
  width: 100%;
  height: 100%;
  color: #fff;
  position: relative;
  transition: 0.3s;
  padding: 1rem 0;
}
@media only screen and (max-width: 767px) {
  .c-pageLinks__item a {
    font-size: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .c-pageLinks__item a {
    font-size: 2rem;
  }
}
.c-pageLinks__item a.md-first {
  background: linear-gradient(45deg, rgb(0, 29, 80) 0%, rgb(38, 33, 39) 60%, rgb(35, 24, 21) 100%);
}
.c-pageLinks__item a.md-second {
  background: linear-gradient(90deg, rgb(102, 119, 150) 0%, rgb(89, 87, 87) 100%);
}
@media (hover: hover) and (pointer: fine) {
  .c-pageLinks__item a:hover {
    opacity: 0.6;
  }
}
.c-pageLinks__item a i.-right {
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 0.4em solid transparent;
  border-bottom: 0.4em solid transparent;
  border-left: 0.7em solid #fff;
  border-right: 0;
  position: absolute;
  top: 50%;
  left: calc(100% - 1.4em);
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .c-pageLinks__item a i.-right {
    left: calc(100% - 1.2em);
  }
}
.c-pageLinks__item a i.-left {
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 0.4em solid transparent;
  border-bottom: 0.4em solid transparent;
  border-right: 0.7em solid #fff;
  border-left: 0;
  position: absolute;
  top: 50%;
  left: 1em;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .c-pageLinks__item a i.-left {
    left: 0.5em;
  }
}

/* ------------------------------------------------------------
    グロナビの高さ分mainを下げる
------------------------------------------------------------ */
.u-main-top {
  margin-top: 7rem;
}
@media only screen and (max-width: 1080px) {
  .u-main-top {
    margin-top: 6.4rem;
  }
}
@media only screen and (max-width: 767px) {
  .u-main-top {
    margin-top: 6.5rem;
  }
}

/* ------------------------------------------------------------
    responsive display 主に<br>で使用
------------------------------------------------------------ */
.u-pc {
  display: block !important;
}
@media only screen and (max-width: 767px) {
  .u-pc {
    display: none !important;
  }
}

.u-sp {
  display: none !important;
}
@media only screen and (max-width: 767px) {
  .u-sp {
    display: block !important;
  }
}

.u-pci {
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .u-pci {
    display: none;
  }
}

.u-spi {
  display: none;
}
@media only screen and (max-width: 767px) {
  .u-spi {
    display: inline-block;
  }
}

.u-pcf {
  display: flex !important;
}
@media only screen and (max-width: 767px) {
  .u-pcf {
    display: none !important;
  }
}

.u-spf {
  display: none !important;
}
@media only screen and (max-width: 767px) {
  .u-spf {
    display: flex !important;
  }
}

/* ------------------------------------------------------------
object-fit
------------------------------------------------------------ */
.u-obf-cov {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ------------------------------------------------------------
    wrapper width　主に使用
------------------------------------------------------------ */
.u-inner {
  width: 90%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.u-inner-pc {
  width: 90%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 767px) {
  .u-inner-pc {
    width: 100% !important;
  }
}
.u-inner-sp {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .u-inner-sp {
    width: 90%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
  }
}

.u-inner__95 {
  width: 95%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.u-inner__mx800 {
  width: 90%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  margin-inline: auto;
}

.u-pad-in-30 {
  padding-inline: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-pad-in-30 {
    padding-inline: 1.5rem;
  }
}

.u-inner__wh {
  background: #fff;
  padding-inline: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-inner__wh {
    padding-inline: 1.5rem;
  }
}
.u-inner__wh-top {
  background: #fff;
  padding-top: 6rem;
  padding-inline: 3rem;
  border-radius: 2.5rem 2.5rem 0 0;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 767px) {
  .u-inner__wh-top {
    padding-inline: 1.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .u-inner__wh-sp {
    padding-inline: 1.5rem;
  }
}
.u-inner__wh-sp-top {
  background: #fff;
  padding-inline: 3rem;
  border-radius: 2.5rem 2.5rem 0 0;
}
@media only screen and (max-width: 767px) {
  .u-inner__wh-sp-top {
    padding-inline: 1.5rem;
  }
}
.u-inner__wh-pc {
  background: #fff;
  padding-inline: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-inner__wh-pc {
    padding-inline: 0rem;
  }
}
.u-inner__gold {
  background: #f7f6f2;
  padding-inline: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-inner__gold {
    padding-inline: 1.5rem;
  }
}
.u-inner__gold-top {
  background: #f7f6f2;
  padding-inline: 3rem;
  border-radius: 2.5rem 2.5rem 0 0;
}
@media only screen and (max-width: 767px) {
  .u-inner__gold-top {
    padding-inline: 1.5rem;
  }
}
.u-inner__gold-d {
  background: #9C8D69;
  padding-inline: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-inner__gold-d {
    padding-inline: 1.5rem;
  }
}
.u-inner__gold-d-top {
  background: #9C8D69;
  padding-inline: 3rem;
  border-radius: 2.5rem 2.5rem 0 0;
}
@media only screen and (max-width: 767px) {
  .u-inner__gold-d-top {
    padding-inline: 1.5rem;
  }
}

/* ------------------------------------------------------------
    flex layout 微調整時のみ使用
------------------------------------------------------------ */
.u-flex {
  width: 100%;
  display: flex !important;
}
.u-flex.flex-btw {
  justify-content: space-between;
}
.u-flex.flex-center {
  justify-content: center;
}
.u-flex.flex-btw-basis {
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .u-flex.flex-btw-basis {
    flex-direction: column;
  }
}
.u-flex.flex-ard {
  justify-content: space-around;
}
.u-flex.flex-row {
  flex-direction: row;
}
.u-flex.flex-row-reverse {
  flex-direction: row-reverse;
}
.u-flex.flex-col {
  flex-direction: column;
}
.u-flex.flex-col-reverse {
  flex-direction: column-reverse;
}
.u-flex.flex-wrap {
  flex-wrap: wrap;
}
.u-flex.flex-alin-c {
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .u-flex.sm_flex-row {
    flex-direction: row;
  }
  .u-flex.sm_flex-row-reverse {
    flex-direction: row-reverse;
  }
  .u-flex.sm_flex-col {
    flex-direction: column;
  }
  .u-flex.sm_flex-col-reverse {
    flex-direction: column-reverse;
  }
  .u-flex.sm_flex-wrap {
    flex-wrap: wrap;
  }
}

/* ------------------------------------------------------------
    margin top, margin bottom
------------------------------------------------------------ */
.u-mt-5 {
  margin-top: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-5--sp {
    margin-top: 0.5rem !important;
  }
}

.u-mb-5 {
  margin-bottom: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-5--sp {
    margin-bottom: 0.5rem !important;
  }
}

.u-ml-5 {
  margin-left: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-5--sp {
    margin-left: 0.5rem !important;
  }
}

.u-mr-5 {
  margin-right: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-5--sp {
    margin-right: 0.5rem !important;
  }
}

.u-pt-5 {
  padding-top: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-5--sp {
    padding-top: 0.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-5 {
  padding-bottom: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-5--sp {
    padding-bottom: 0.5rem !important;
  }
}

.u-mt-10 {
  margin-top: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-10--sp {
    margin-top: 1rem !important;
  }
}

.u-mb-10 {
  margin-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-10--sp {
    margin-bottom: 1rem !important;
  }
}

.u-ml-10 {
  margin-left: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-10--sp {
    margin-left: 1rem !important;
  }
}

.u-mr-10 {
  margin-right: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-10--sp {
    margin-right: 1rem !important;
  }
}

.u-pt-10 {
  padding-top: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-10--sp {
    padding-top: 1rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-10 {
  padding-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-10--sp {
    padding-bottom: 1rem !important;
  }
}

.u-mt-15 {
  margin-top: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-15--sp {
    margin-top: 1.5rem !important;
  }
}

.u-mb-15 {
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-15--sp {
    margin-bottom: 1.5rem !important;
  }
}

.u-ml-15 {
  margin-left: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-15--sp {
    margin-left: 1.5rem !important;
  }
}

.u-mr-15 {
  margin-right: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-15--sp {
    margin-right: 1.5rem !important;
  }
}

.u-pt-15 {
  padding-top: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-15--sp {
    padding-top: 1.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-15 {
  padding-bottom: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-15--sp {
    padding-bottom: 1.5rem !important;
  }
}

.u-mt-20 {
  margin-top: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-20--sp {
    margin-top: 2rem !important;
  }
}

.u-mb-20 {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-20--sp {
    margin-bottom: 2rem !important;
  }
}

.u-ml-20 {
  margin-left: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-20--sp {
    margin-left: 2rem !important;
  }
}

.u-mr-20 {
  margin-right: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-20--sp {
    margin-right: 2rem !important;
  }
}

.u-pt-20 {
  padding-top: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-20--sp {
    padding-top: 2rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-20 {
  padding-bottom: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-20--sp {
    padding-bottom: 2rem !important;
  }
}

.u-mt-25 {
  margin-top: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-25--sp {
    margin-top: 2.5rem !important;
  }
}

.u-mb-25 {
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-25--sp {
    margin-bottom: 2.5rem !important;
  }
}

.u-ml-25 {
  margin-left: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-25--sp {
    margin-left: 2.5rem !important;
  }
}

.u-mr-25 {
  margin-right: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-25--sp {
    margin-right: 2.5rem !important;
  }
}

.u-pt-25 {
  padding-top: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-25--sp {
    padding-top: 2.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-25 {
  padding-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-25--sp {
    padding-bottom: 2.5rem !important;
  }
}

.u-mt-30 {
  margin-top: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-30--sp {
    margin-top: 3rem !important;
  }
}

.u-mb-30 {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-30--sp {
    margin-bottom: 3rem !important;
  }
}

.u-ml-30 {
  margin-left: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-30--sp {
    margin-left: 3rem !important;
  }
}

.u-mr-30 {
  margin-right: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-30--sp {
    margin-right: 3rem !important;
  }
}

.u-pt-30 {
  padding-top: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-30--sp {
    padding-top: 3rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-30 {
  padding-bottom: 3rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-30--sp {
    padding-bottom: 3rem !important;
  }
}

.u-mt-35 {
  margin-top: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-35--sp {
    margin-top: 3.5rem !important;
  }
}

.u-mb-35 {
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-35--sp {
    margin-bottom: 3.5rem !important;
  }
}

.u-ml-35 {
  margin-left: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-35--sp {
    margin-left: 3.5rem !important;
  }
}

.u-mr-35 {
  margin-right: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-35--sp {
    margin-right: 3.5rem !important;
  }
}

.u-pt-35 {
  padding-top: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-35--sp {
    padding-top: 3.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-35 {
  padding-bottom: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-35--sp {
    padding-bottom: 3.5rem !important;
  }
}

.u-mt-40 {
  margin-top: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-40--sp {
    margin-top: 4rem !important;
  }
}

.u-mb-40 {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-40--sp {
    margin-bottom: 4rem !important;
  }
}

.u-ml-40 {
  margin-left: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-40--sp {
    margin-left: 4rem !important;
  }
}

.u-mr-40 {
  margin-right: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-40--sp {
    margin-right: 4rem !important;
  }
}

.u-pt-40 {
  padding-top: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-40--sp {
    padding-top: 4rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-40 {
  padding-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-40--sp {
    padding-bottom: 4rem !important;
  }
}

.u-mt-45 {
  margin-top: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-45--sp {
    margin-top: 4.5rem !important;
  }
}

.u-mb-45 {
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-45--sp {
    margin-bottom: 4.5rem !important;
  }
}

.u-ml-45 {
  margin-left: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-45--sp {
    margin-left: 4.5rem !important;
  }
}

.u-mr-45 {
  margin-right: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-45--sp {
    margin-right: 4.5rem !important;
  }
}

.u-pt-45 {
  padding-top: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-45--sp {
    padding-top: 4.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-45 {
  padding-bottom: 4.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-45--sp {
    padding-bottom: 4.5rem !important;
  }
}

.u-mt-50 {
  margin-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-50--sp {
    margin-top: 5rem !important;
  }
}

.u-mb-50 {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-50--sp {
    margin-bottom: 5rem !important;
  }
}

.u-ml-50 {
  margin-left: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-50--sp {
    margin-left: 5rem !important;
  }
}

.u-mr-50 {
  margin-right: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-50--sp {
    margin-right: 5rem !important;
  }
}

.u-pt-50 {
  padding-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-50--sp {
    padding-top: 5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-50 {
  padding-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-50--sp {
    padding-bottom: 5rem !important;
  }
}

.u-mt-55 {
  margin-top: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-55--sp {
    margin-top: 5.5rem !important;
  }
}

.u-mb-55 {
  margin-bottom: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-55--sp {
    margin-bottom: 5.5rem !important;
  }
}

.u-ml-55 {
  margin-left: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-55--sp {
    margin-left: 5.5rem !important;
  }
}

.u-mr-55 {
  margin-right: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-55--sp {
    margin-right: 5.5rem !important;
  }
}

.u-pt-55 {
  padding-top: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-55--sp {
    padding-top: 5.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-55 {
  padding-bottom: 5.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-55--sp {
    padding-bottom: 5.5rem !important;
  }
}

.u-mt-60 {
  margin-top: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-60--sp {
    margin-top: 6rem !important;
  }
}

.u-mb-60 {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-60--sp {
    margin-bottom: 6rem !important;
  }
}

.u-ml-60 {
  margin-left: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-60--sp {
    margin-left: 6rem !important;
  }
}

.u-mr-60 {
  margin-right: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-60--sp {
    margin-right: 6rem !important;
  }
}

.u-pt-60 {
  padding-top: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-60--sp {
    padding-top: 6rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-60 {
  padding-bottom: 6rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-60--sp {
    padding-bottom: 6rem !important;
  }
}

.u-mt-65 {
  margin-top: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-65--sp {
    margin-top: 6.5rem !important;
  }
}

.u-mb-65 {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-65--sp {
    margin-bottom: 6.5rem !important;
  }
}

.u-ml-65 {
  margin-left: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-65--sp {
    margin-left: 6.5rem !important;
  }
}

.u-mr-65 {
  margin-right: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-65--sp {
    margin-right: 6.5rem !important;
  }
}

.u-pt-65 {
  padding-top: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-65--sp {
    padding-top: 6.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-65 {
  padding-bottom: 6.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-65--sp {
    padding-bottom: 6.5rem !important;
  }
}

.u-mt-70 {
  margin-top: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-70--sp {
    margin-top: 7rem !important;
  }
}

.u-mb-70 {
  margin-bottom: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-70--sp {
    margin-bottom: 7rem !important;
  }
}

.u-ml-70 {
  margin-left: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-70--sp {
    margin-left: 7rem !important;
  }
}

.u-mr-70 {
  margin-right: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-70--sp {
    margin-right: 7rem !important;
  }
}

.u-pt-70 {
  padding-top: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-70--sp {
    padding-top: 7rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-70 {
  padding-bottom: 7rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-70--sp {
    padding-bottom: 7rem !important;
  }
}

.u-mt-75 {
  margin-top: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-75--sp {
    margin-top: 7.5rem !important;
  }
}

.u-mb-75 {
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-75--sp {
    margin-bottom: 7.5rem !important;
  }
}

.u-ml-75 {
  margin-left: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-75--sp {
    margin-left: 7.5rem !important;
  }
}

.u-mr-75 {
  margin-right: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-75--sp {
    margin-right: 7.5rem !important;
  }
}

.u-pt-75 {
  padding-top: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-75--sp {
    padding-top: 7.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-75 {
  padding-bottom: 7.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-75--sp {
    padding-bottom: 7.5rem !important;
  }
}

.u-mt-80 {
  margin-top: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-80--sp {
    margin-top: 8rem !important;
  }
}

.u-mb-80 {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-80--sp {
    margin-bottom: 8rem !important;
  }
}

.u-ml-80 {
  margin-left: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-80--sp {
    margin-left: 8rem !important;
  }
}

.u-mr-80 {
  margin-right: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-80--sp {
    margin-right: 8rem !important;
  }
}

.u-pt-80 {
  padding-top: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-80--sp {
    padding-top: 8rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-80 {
  padding-bottom: 8rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-80--sp {
    padding-bottom: 8rem !important;
  }
}

.u-mt-85 {
  margin-top: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-85--sp {
    margin-top: 8.5rem !important;
  }
}

.u-mb-85 {
  margin-bottom: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-85--sp {
    margin-bottom: 8.5rem !important;
  }
}

.u-ml-85 {
  margin-left: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-85--sp {
    margin-left: 8.5rem !important;
  }
}

.u-mr-85 {
  margin-right: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-85--sp {
    margin-right: 8.5rem !important;
  }
}

.u-pt-85 {
  padding-top: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-85--sp {
    padding-top: 8.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-85 {
  padding-bottom: 8.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-85--sp {
    padding-bottom: 8.5rem !important;
  }
}

.u-mt-90 {
  margin-top: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-90--sp {
    margin-top: 9rem !important;
  }
}

.u-mb-90 {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-90--sp {
    margin-bottom: 9rem !important;
  }
}

.u-ml-90 {
  margin-left: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-90--sp {
    margin-left: 9rem !important;
  }
}

.u-mr-90 {
  margin-right: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-90--sp {
    margin-right: 9rem !important;
  }
}

.u-pt-90 {
  padding-top: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-90--sp {
    padding-top: 9rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-90 {
  padding-bottom: 9rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-90--sp {
    padding-bottom: 9rem !important;
  }
}

.u-mt-95 {
  margin-top: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-95--sp {
    margin-top: 9.5rem !important;
  }
}

.u-mb-95 {
  margin-bottom: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-95--sp {
    margin-bottom: 9.5rem !important;
  }
}

.u-ml-95 {
  margin-left: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-95--sp {
    margin-left: 9.5rem !important;
  }
}

.u-mr-95 {
  margin-right: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-95--sp {
    margin-right: 9.5rem !important;
  }
}

.u-pt-95 {
  padding-top: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-95--sp {
    padding-top: 9.5rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-95 {
  padding-bottom: 9.5rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-95--sp {
    padding-bottom: 9.5rem !important;
  }
}

.u-mt-100 {
  margin-top: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-mt-100--sp {
    margin-top: 10rem !important;
  }
}

.u-mb-100 {
  margin-bottom: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-mb-100--sp {
    margin-bottom: 10rem !important;
  }
}

.u-ml-100 {
  margin-left: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-ml-100--sp {
    margin-left: 10rem !important;
  }
}

.u-mr-100 {
  margin-right: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-mr-100--sp {
    margin-right: 10rem !important;
  }
}

.u-pt-100 {
  padding-top: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-pt-100--sp {
    padding-top: 10rem !important;
  }
}

.u-pt-0 {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .u-pt-0--sp {
    padding-top: 0 !important;
  }
}

.u-pb-100 {
  padding-bottom: 10rem;
}
@media only screen and (max-width: 767px) {
  .u-pb-100--sp {
    padding-bottom: 10rem !important;
  }
}

/* ------------------------------------------------------------
    section space
------------------------------------------------------------ */
.u-sec-spa {
  padding-top: 12rem;
}
@media only screen and (max-width: 767px) {
  .u-sec-spa {
    padding-top: 6rem;
  }
}

.u-inpd0 {
  padding-inline: 0;
}
@media only screen and (max-width: 767px) {
  .u-inpd0 {
    padding-inline: 0;
  }
}

.u-p-r {
  position: relative;
}

.u-d-b {
  display: block;
}

/* ------------------------------------------------------------
    text関連 微修正時のみ使用
------------------------------------------------------------ */
.u-inlB {
  display: inline-block;
}

.u-t_c {
  text-align: center !important;
}

.u-t_l {
  text-align: left !important;
}

.u-t_r {
  text-align: right !important;
}

.u-t_j {
  text-align: justify !important;
}

@media only screen and (max-width: 767px) {
  .u-t_c-sp {
    text-align: center !important;
  }
  .u-t_u-sp {
    text-align: center !important;
  }
  .u-t_l-sp {
    text-align: left !important;
  }
  .u-t_r-sp {
    text-align: right !important;
  }
  .u-t_j-sp {
    text-align: justify !important;
  }
}
.u-t-en {
  font-family: "EB Garamond", "Noto Serif", serif;
}

.u-t-ja {
  font-family: YakuHanMP, "Noto Serif", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}

/* ------------------------------------------------------------
    text size　微修正時のみ使用
------------------------------------------------------------ */
.u-f16 {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .u-f16 {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f16 {
    font-size: 1.4rem;
  }
}

.u-f14 {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .u-f14 {
    font-size: 12px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f14 {
    font-size: 1.2rem;
  }
}

.u-f12 {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .u-f12 {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f12 {
    font-size: 1rem;
  }
}

.u-f11 {
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .u-f11 {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f11 {
    font-size: 1rem;
  }
}

.u-f10 {
  line-height: 1.4;
  font-size: 10px;
  font-size: 1rem;
}
@media only screen and (max-width: 767px) {
  .u-f10 {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f10 {
    font-size: 1rem;
  }
}

.u-f20 {
  line-height: 1.5;
  font-size: 20px;
  font-size: 2rem;
}
@media only screen and (max-width: 767px) {
  .u-f20 {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .u-f20 {
    font-size: 1.6rem;
  }
}

/* ------------------------------------------------------------
    文中※
------------------------------------------------------------ */
.u-sup {
  display: inline-block;
  font-size: 10px;
  vertical-align: text-top;
  color: currentColor;
  transform: translateY(-2px);
}
@media only screen and (max-width: 767px) {
  .u-sup {
    transform: translateY(-5px);
  }
}
.u-sup--mgn5 {
  margin: 0 -5px;
}
.u-sup--mgn10 {
  margin: 0 -10px;
}
.u-sup-btm {
  vertical-align: text-bottom;
}

.u-img-cap, .u-img-cap-l {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 11px;
  font-size: 1.1rem;
  color: #fff;
  background: rgba(0, 0, 0, 0.6);
  line-height: 1;
  padding: 2px 3px;
  padding-inline: 1rem;
  text-align: right;
}
@media only screen and (max-width: 767px) {
  .u-img-cap, .u-img-cap-l {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .u-img-cap, .u-img-cap-l {
    font-size: 1rem;
  }
}
.u-img-cap-wh {
  background: #fff;
  color: #231815;
}
.u-img-cap.-nobg, .-nobg.u-img-cap-l {
  background: unset !important;
  color: #231815;
}
.u-img-cap-l {
  right: unset;
  left: 0;
}
.u-img-cap-l-sp {
  right: unset;
  left: 0;
}
@media only screen and (max-width: 767px) {
  .u-img-cap-scl {
    bottom: 0rem;
  }
}

.u-t-lh-25 {
  line-height: 2.5;
}
.u-t-lh-25-pc {
  line-height: 2.5;
}
@media only screen and (max-width: 767px) {
  .u-t-lh-25-pc {
    line-height: 1.7 !important;
  }
}
.u-t-lh-20 {
  line-height: 2;
}
.u-t-lh-20-pc {
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  .u-t-lh-20-pc {
    line-height: 1.7 !important;
  }
}

.u-t_num {
  font-family: "Libre Caslon Text", "Noto Serif", serif;
}

.u-btn-arrow {
  position: relative;
  display: flex;
  align-items: center;
}
.u-btn-arrow i {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  width: 0.6em;
  height: 0.6em;
  border: 1px solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  margin-left: 0.5em;
  transform: translateX(-25%) rotate(45deg);
  transition: 0.3s;
}
.u-btn-arrow:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: currentColor;
  opacity: 0.7;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .u-btn-arrow:hover:hover:after {
    width: 100%;
  }
}

.u-btn-readmore {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 4rem;
  margin-inline: auto;
  border: 1px solid #fff;
  width: -moz-fit-content;
  width: fit-content;
  overflow: hidden;
  transition: all 0.3s;
  font-size: 20px;
  font-size: 2rem;
  min-width: 300px;
}
@media only screen and (max-width: 767px) {
  .u-btn-readmore {
    font-size: 13px;
  }
}
@media only screen and (max-width: 767px) {
  .u-btn-readmore {
    font-size: 1.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .u-btn-readmore {
    min-width: unset;
    width: 100%;
    padding: 0.5rem 0;
  }
}
.u-btn-readmore > span {
  z-index: 1;
}
.u-btn-readmore i {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  width: 0.6em;
  height: 0.6em;
  border: 1px solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  margin-left: 0.5em;
  transform: translateX(-25%) rotate(45deg);
  transition: 0.3s;
  z-index: 1;
}
.u-btn-readmore:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  transform: translateX(-100%);
  transition: 0.3s;
}
.u-btn-readmore-gold {
  border: solid 1px #9C8D69;
  background: #9C8D69;
  color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .u-btn-readmore-gold:hover {
    background: #fff;
    color: #9C8D69;
  }
  .u-btn-readmore-gold:hover i {
    border: 1px solid #9C8D69;
    border-left: 0;
    border-bottom: 0;
  }
  .u-btn-readmore-gold:hover:after {
    transform: translateX(0);
  }
}

.u-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  overflow: hidden;
  transition: all 0.3s;
}
.u-btn > span {
  z-index: 1;
}
.u-btn i {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  width: 0.6em;
  height: 0.6em;
  border: 1px solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  margin-left: 0.5em;
  transform: translateX(-25%) rotate(45deg);
  transition: 0.3s;
  z-index: 1;
}
.u-btn:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  transform: translateX(-100%);
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .u-btn:hover:hover {
    color: #fff;
  }
  .u-btn:hover:hover i {
    border: 1px solid #fff;
    border-left: 0;
    border-bottom: 0;
  }
  .u-btn:hover:hover:after {
    transform: translateX(0);
  }
}
.u-btn--entry {
  background: rgb(105, 3, 0);
  background: linear-gradient(0deg, rgb(105, 3, 0) 0%, rgb(201, 47, 25) 100%);
  border: none;
  color: #fff;
}
.u-btn--limited {
  background: rgb(94, 69, 12);
  background: linear-gradient(0deg, rgb(94, 69, 12) 0%, rgb(183, 140, 57) 100%);
  border: none;
  color: #fff;
}
.u-btn--gold {
  color: #fff;
}
.u-btn--gold:after {
  background-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .u-btn--gold:hover:hover {
    color: #231815;
  }
}

.u-bgimg-blue {
  background-image: url(../../images/common/bg_base.jpg);
  background-repeat: repeat-y;
  background-size: 100% auto;
}
.u-bgimg-blue-2 {
  background-image: url(../../images/common/bg_blue-2.jpg);
  background-repeat: repeat-y;
  background-size: 100% auto;
}
.u-bgimg-gold {
  background-image: url(../../images/common/bg_gold.jpg);
  background-repeat: repeat-y;
  background-size: 100% auto;
}

.u-bg-wh {
  background: #fff;
  padding-block: 1px;
}
.u-bg-wh-opc {
  background: rgba(255, 255, 255, 0.8);
  padding-block: 1px;
}
.u-bg-blue {
  background: linear-gradient(90deg, rgb(0, 0, 24) 0%, rgb(0, 0, 49) 100%);
  padding-block: 1px;
}
.u-bg-limi {
  background-color: rgba(180, 163, 121, 0.4);
}

.u-arw-cont {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  position: relative;
  width: 0.65em;
  height: 0.65em;
  background-color: #fff;
  clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
}
.u-arw-next {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  position: relative;
  width: 0.65em;
  height: 0.65em;
  transform: translateX(-25%) rotate(45deg);
}
.u-arw-next::after, .u-arw-next::before {
  content: "";
  position: absolute;
  background: currentColor;
  border-radius: 0.1em;
}
.u-arw-next::before {
  top: 0;
  left: 0;
  right: 0;
  height: 0.1em;
}
.u-arw-next::after {
  top: 0;
  right: 0;
  bottom: 0;
  width: 0.09em;
}
.u-arw-next--nav {
  transform: translateX(0) rotate(135deg);
}
.u-arw-right {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  position: relative;
  width: 3em;
  height: 0.1em;
  background: currentColor;
}
.u-arw-right::before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  border: 0.1em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  position: absolute;
  top: 50%;
  right: -0.05em;
  box-sizing: border-box;
}
.u-arw-up {
  display: inline-block;
  vertical-align: middle;
  color: currentColor;
  line-height: 1;
  position: relative;
  width: 0.65em;
  height: 0.65em;
  transform: translateY(25%) rotate(315deg);
}
.u-arw-up::after, .u-arw-up::before {
  content: "";
  position: absolute;
  background: currentColor;
  border-radius: 0.1em;
}
.u-arw-up::before {
  top: 0;
  left: 0;
  right: 0;
  height: 0.1em;
}
.u-arw-up::after {
  top: 0;
  right: 0;
  bottom: 0;
  width: 0.09em;
}
.u-arw-up--nav {
  transform: translateX(0) rotate(135deg);
}

.is-anime.mask {
  clip-path: inset(0 100% 0 0);
  transition: 1s ease-in-out;
}
.is-anime.mask.active {
  clip-path: inset(0 0 0 0);
}
.is-anime.mask.slow {
  transition: 1.5s ease-in-out;
}
.is-anime.fade {
  filter: blur(20px);
  opacity: 0;
  transform: translateY(5rem);
  transition: 1s;
}
.is-anime.fade.active {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.u-w100 {
  width: 100%;
}

/* ------------------------------------------------------------
    txt letter-spacing
------------------------------------------------------------ */
.u-txt_space30 {
  letter-spacing: 0.3em;
}

.u-txt_space10 {
  letter-spacing: 0.1em;
}

.u-txt_space5 {
  letter-spacing: 0.05em;
}

.u-txt_space0 {
  letter-spacing: 0;
}

.u-txt_space-2 {
  letter-spacing: -0.02em;
}

.u-txt_space-5 {
  letter-spacing: -0.05em;
}

/* ==========================================================
 swipe icon
========================================================== */
.u-swipeIcon {
  display: none;
  position: absolute;
  top: calc(50% - 5rem);
  left: calc(50vw - 7.5rem);
  width: 10rem;
  height: 10rem;
  animation: floating-X 1.2s ease-in-out infinite alternate-reverse;
  background-size: cover;
  background-position: center;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22Layer_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20400%20400%22%20style%3D%22enable-background%3Anew%200%200%20400%20400%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23353535%3Bfill-opacity%3A0.8%3B%7D%20.st1%7Bfill%3Anone%3Bstroke%3A%23FFFFFF%3Bstroke-width%3A13%3Bstroke-linecap%3Around%3Bstroke-miterlimit%3A10%3B%7D%20.st2%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpath%20class%3D%22st0%22%20d%3D%22M356.6%2C368.6H43.4c-6.6%2C0-12-5.4-12-12V43.4c0-6.6%2C5.4-12%2C12-12h313.2c6.6%2C0%2C12%2C5.4%2C12%2C12v313.2%20C368.6%2C363.2%2C363.2%2C368.6%2C356.6%2C368.6z%22%2F%3E%3Cg%3E%20%3Cg%3E%20%3Cg%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%2276.9%22%20y1%3D%22154.4%22%20x2%3D%22206.6%22%20y2%3D%22154.4%22%2F%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%2276.9%22%20y1%3D%22156.6%22%20x2%3D%22120.3%22%20y2%3D%22200%22%2F%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%2278.5%22%20y1%3D%22151.9%22%20x2%3D%22121.9%22%20y2%3D%22108.5%22%2F%3E%20%3C%2Fg%3E%20%3Cg%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%22323.1%22%20y1%3D%22154.4%22%20x2%3D%22193.4%22%20y2%3D%22154.4%22%2F%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%22323.1%22%20y1%3D%22151.9%22%20x2%3D%22279.7%22%20y2%3D%22108.5%22%2F%3E%20%3Cline%20class%3D%22st1%22%20x1%3D%22321.5%22%20y1%3D%22156.6%22%20x2%3D%22278.1%22%20y2%3D%22200%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%20%3Cg%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M135.9%2C245.5h-8v-1.8c0-1.8-0.4-3.4-1.3-4.7s-2.3-2-4.3-2c-1.1%2C0-2%2C0.2-2.7%2C0.6c-0.7%2C0.4-1.2%2C0.9-1.6%2C1.6%20c-0.4%2C0.7-0.7%2C1.4-0.9%2C2.3c-0.2%2C0.9-0.2%2C1.8-0.2%2C2.7c0%2C1.1%2C0%2C2%2C0.1%2C2.7s0.3%2C1.4%2C0.6%2C1.9c0.3%2C0.6%2C0.8%2C1.1%2C1.4%2C1.5s1.4%2C0.8%2C2.5%2C1.2%20l6.1%2C2.4c1.8%2C0.7%2C3.2%2C1.5%2C4.3%2C2.4s1.9%2C2%2C2.6%2C3.2c0.6%2C1.2%2C1%2C2.7%2C1.2%2C4.2c0.2%2C1.6%2C0.3%2C3.4%2C0.3%2C5.4c0%2C2.3-0.2%2C4.5-0.7%2C6.5%20s-1.2%2C3.7-2.3%2C5.1c-1.1%2C1.5-2.5%2C2.6-4.3%2C3.4s-3.9%2C1.2-6.5%2C1.2c-1.9%2C0-3.7-0.3-5.4-1c-1.7-0.7-3.1-1.6-4.3-2.8%20c-1.2-1.2-2.1-2.6-2.8-4.2c-0.7-1.6-1.1-3.3-1.1-5.2v-3h8v2.5c0%2C1.5%2C0.4%2C2.8%2C1.3%2C3.9c0.9%2C1.2%2C2.3%2C1.8%2C4.3%2C1.8%20c1.4%2C0%2C2.4-0.2%2C3.2-0.6c0.8-0.4%2C1.3-0.9%2C1.8-1.7c0.4-0.7%2C0.7-1.6%2C0.7-2.6s0.1-2.1%2C0.1-3.4c0-1.5-0.1-2.7-0.2-3.6s-0.3-1.7-0.6-2.3%20c-0.4-0.6-0.8-1-1.4-1.4s-1.4-0.8-2.4-1.2l-5.7-2.3c-3.4-1.4-5.7-3.3-6.9-5.6c-1.2-2.3-1.8-5.2-1.8-8.7c0-2.1%2C0.3-4.1%2C0.9-5.9%20c0.6-1.9%2C1.4-3.5%2C2.6-4.8c1.1-1.4%2C2.5-2.4%2C4.2-3.2s3.7-1.2%2C6-1.2c2%2C0%2C3.8%2C0.4%2C5.4%2C1.1c1.6%2C0.7%2C3.1%2C1.7%2C4.2%2C2.9%20c2.4%2C2.5%2C3.6%2C5.4%2C3.6%2C8.6V245.5z%22%2F%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M167.1%2C269.2v3.4c0%2C1.7-0.3%2C3.3-1%2C4.9c-0.7%2C1.5-1.5%2C2.9-2.7%2C4.1c-1.1%2C1.2-2.5%2C2.1-4%2C2.8%20c-1.5%2C0.7-3.2%2C1.1-5%2C1.1c-1.5%2C0-3-0.2-4.6-0.6s-3-1.1-4.2-2.2c-1.2-1-2.3-2.4-3.1-4s-1.2-3.7-1.2-6.3v-30.6c0-1.8%2C0.3-3.5%2C0.9-5.1%20c0.6-1.6%2C1.5-2.9%2C2.7-4.1c1.1-1.1%2C2.5-2%2C4.1-2.7c1.6-0.6%2C3.3-1%2C5.3-1c3.7%2C0%2C6.8%2C1.2%2C9.1%2C3.7c1.1%2C1.2%2C2%2C2.6%2C2.7%2C4.2%20c0.6%2C1.6%2C1%2C3.4%2C1%2C5.3v3.1h-8v-2.7c0-1.6-0.4-2.9-1.3-4.1c-0.9-1.1-2.1-1.7-3.6-1.7c-2%2C0-3.3%2C0.6-3.9%2C1.8c-0.7%2C1.2-1%2C2.8-1%2C4.6%20v28.4c0%2C1.6%2C0.4%2C3%2C1.1%2C4.1c0.7%2C1.1%2C2%2C1.6%2C3.8%2C1.6c0.5%2C0%2C1.1-0.1%2C1.7-0.3c0.6-0.2%2C1.2-0.5%2C1.7-0.9s0.9-1%2C1.2-1.7s0.5-1.6%2C0.5-2.7%20v-2.7h7.8V269.2z%22%2F%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M173.6%2C285v-55.5h12.8c9.4%2C0%2C14%2C5.4%2C14%2C16.3c0%2C3.3-0.5%2C6.1-1.5%2C8.3c-1%2C2.3-2.8%2C4.1-5.3%2C5.5l8.6%2C25.3h-8.4%20l-7.4-23.7h-4.8V285H173.6z%20M181.6%2C237v17.3h4.5c1.4%2C0%2C2.5-0.2%2C3.4-0.6c0.8-0.4%2C1.5-0.9%2C1.9-1.7c0.4-0.7%2C0.7-1.6%2C0.9-2.7%20c0.2-1.1%2C0.2-2.3%2C0.2-3.7s-0.1-2.6-0.2-3.7c-0.2-1.1-0.5-2-0.9-2.8c-1-1.5-2.9-2.2-5.6-2.2L181.6%2C237L181.6%2C237z%22%2F%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M206.4%2C242.6c0-2.2%2C0.4-4.2%2C1.2-5.9s1.8-3.1%2C3.1-4.3c1.2-1.1%2C2.7-1.9%2C4.2-2.5s3.2-0.9%2C4.8-0.9%20s3.2%2C0.3%2C4.8%2C0.9c1.6%2C0.6%2C3%2C1.4%2C4.3%2C2.5c1.2%2C1.1%2C2.3%2C2.6%2C3%2C4.3c0.8%2C1.7%2C1.2%2C3.7%2C1.2%2C5.9v29.3c0%2C2.3-0.4%2C4.3-1.2%2C6s-1.8%2C3-3%2C4.1%20c-1.3%2C1.1-2.7%2C2-4.3%2C2.6s-3.2%2C0.9-4.8%2C0.9s-3.2-0.3-4.8-0.9s-3-1.4-4.2-2.6c-1.3-1.1-2.3-2.5-3.1-4.1c-0.8-1.7-1.2-3.7-1.2-6%20V242.6z%20M214.3%2C271.9c0%2C1.9%2C0.5%2C3.3%2C1.6%2C4.2c1.1%2C0.9%2C2.3%2C1.4%2C3.8%2C1.4s2.7-0.5%2C3.8-1.4s1.6-2.3%2C1.6-4.2v-29.3%20c0-1.9-0.5-3.3-1.6-4.2s-2.3-1.4-3.8-1.4s-2.7%2C0.5-3.8%2C1.4s-1.6%2C2.3-1.6%2C4.2V271.9z%22%2F%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M240%2C285v-55.5h8V277h15.8v8H240z%22%2F%3E%20%3Cpath%20class%3D%22st2%22%20d%3D%22M268.9%2C285v-55.5h8V277h15.8v8H268.9z%22%2F%3E%20%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  z-index: 1;
}
@keyframes floating-X {
  0% {
    transform: translateX(-10%);
  }
  100% {
    transform: translateX(10%);
  }
}
.u-swipeIcon--design {
  display: block;
  left: 50%;
}
@media only screen and (max-width: 767px) {
  .u-swipeIcon--design {
    left: calc(50vw - 4.5rem);
  }
}
@media only screen and (max-width: 767px) {
  .u-swipeIcon {
    display: block;
    background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22Layer_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20400%20400%22%20style%3D%22enable-background%3Anew%200%200%20400%20400%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23757474%3Bfill-opacity%3A0.8%3B%7D%20.st1%7Bfill%3A%23333333%3B%7D%20.st2%7Bfill%3Anone%3Bstroke%3A%23333333%3Bstroke-width%3A10.4097%3Bstroke-linecap%3Around%3Bstroke-miterlimit%3A10%3B%7D%20.st3%7Bfill%3Anone%3Bstroke%3A%23333333%3Bstroke-width%3A10.2492%3Bstroke-linecap%3Around%3Bstroke-miterlimit%3A10%3B%7D%20.st4%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpath%20class%3D%22st0%22%20d%3D%22M356.6%2C368.6H43.4c-6.6%2C0-12-5.4-12-12V43.4c0-6.6%2C5.4-12%2C12-12h313.2c6.6%2C0%2C12%2C5.4%2C12%2C12v313.2%20C368.6%2C363.2%2C363.2%2C368.6%2C356.6%2C368.6z%22%2F%3E%3Cg%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M180.4%2C204c0-23.7%2C0-46.6%2C0-69.7c0-10%2C5.5-17.5%2C14.3-19.8c12.7-3.4%2C24.7%2C5.8%2C25%2C19.3c0.2%2C7.1%2C0%2C14.2%2C0%2C21.4%20c0%2C1.4%2C0%2C2.8%2C0%2C4.4c10.1-2.6%2C18.1-0.3%2C23.9%2C7.9c13.3-5.8%2C26.2-0.7%2C29.9%2C14.6c3.1-0.3%2C6.1-1%2C9.1-0.8c11.3%2C1%2C18.4%2C8.9%2C18.4%2C20.6%20c0.1%2C16.2-0.9%2C32.5%2C0.3%2C48.6c1%2C14.6-2%2C27.2-12.2%2C37.7c-3.9%2C4.1-4.9%2C8.9-4.6%2C14.4c0.3%2C6.1%2C0.1%2C12.2%2C0.1%2C18.4c0%2C5-2.2%2C7.3-7.3%2C7.4%20c-26%2C0.1-52%2C0.1-78%2C0c-4.8%2C0-7-2.4-7.1-7.2c-0.1-7.7%2C0.1-15.4-0.1-23c-0.1-2.3-0.8-4.8-2-6.7c-13.6-21.4-27.2-42.5-41-63.7%20c-6.1-9.6-5.1-20.3%2C2.8-26.8c8.1-6.7%2C18.4-5.9%2C26.8%2C2.1C179.1%2C203.2%2C179.4%2C203.4%2C180.4%2C204z%20M272.2%2C315.7c0-7.2-0.3-14%2C0.1-20.8%20c0.2-2.6%2C1-5.6%2C2.5-7.9c3.9-6.1%2C8.4-11.9%2C12.5-17.9c0.9-1.2%2C1.5-2.8%2C1.5-4.2c0.1-21.2%2C0.1-42.4%2C0-63.5c0-5.1-3.2-8-7.9-7.9%20c-4.6%2C0.1-7.3%2C3-7.4%2C8c-0.1%2C4.7%2C0.1%2C9.4-0.1%2C14.1c-0.1%2C4.4-3.2%2C7.1-7.1%2C6.4c-3.9-0.8-5.1-3.6-5.1-7.2c0-9.4%2C0-18.8%2C0-28.1%20c0-6.2-2.6-9.4-7.4-9.3c-4.8%2C0.1-7.2%2C3.2-7.3%2C9.6c0%2C6.2%2C0.1%2C12.5%2C0%2C18.8c-0.1%2C4.6-2.6%2C7.6-6.3%2C7.4c-3.6-0.2-5.8-3-5.8-7.4%20c0-9%2C0-17.9%2C0-26.8c0-4.9-3.2-8.2-7.3-8.2c-4.4%2C0-7.2%2C3.2-7.2%2C8.2c-0.1%2C8.6%2C0%2C17.3%2C0%2C26c0%2C5.1-2.2%2C8.1-6.1%2C8.3%20c-3.9%2C0.2-6.4-3-6.5-8.3c0-12%2C0-24.2%2C0-36.2c0-11.5%2C0.1-23.1%2C0-34.5c0-5.4-3.3-8.5-8.3-7.9c-4.1%2C0.5-6.3%2C3.7-6.3%2C9.1%20c0%2C29.6%2C0%2C59.1%2C0%2C88.7c0%2C3.7-0.8%2C6.6-4.5%2C7.7c-3.7%2C1-5.8-1.2-7.6-4c-3.3-5.1-6.6-10.2-10.2-15.2c-1.1-1.5-3.3-3.4-5-3.3%20c-2.4%2C0.1-5.2%2C1.3-6.8%2C3.1c-2.1%2C2.4-1.2%2C5.5%2C0.6%2C8.2c14.3%2C22%2C28.6%2C44%2C42.7%2C66.2c1.5%2C2.5%2C2.4%2C5.7%2C2.6%2C8.6c0.3%2C6.7%2C0.1%2C13.5%2C0.1%2C20.3%20C227.2%2C315.7%2C249.3%2C315.7%2C272.2%2C315.7z%22%2F%3E%20%3Cg%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%2291.7%22%20y1%3D%22133.3%22%20x2%3D%22138.9%22%20y2%3D%22133.3%22%2F%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%2291.7%22%20y1%3D%22134.1%22%20x2%3D%22107.5%22%20y2%3D%22149.9%22%2F%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%2292.3%22%20y1%3D%22132.4%22%20x2%3D%22108.1%22%20y2%3D%22116.6%22%2F%3E%20%3C%2Fg%3E%20%3Cg%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%22308.3%22%20y1%3D%22133.3%22%20x2%3D%22261.1%22%20y2%3D%22133.3%22%2F%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%22308.3%22%20y1%3D%22132.4%22%20x2%3D%22292.5%22%20y2%3D%22116.6%22%2F%3E%20%3Cline%20class%3D%22st2%22%20x1%3D%22307.7%22%20y1%3D%22134.1%22%20x2%3D%22291.9%22%20y2%3D%22149.9%22%2F%3E%20%3C%2Fg%3E%20%3Cpath%20class%3D%22st3%22%20d%3D%22M170.3%2C164.4c-7.6-7.6-12.3-18.1-12.3-29.7s4.7-22.1%2C12.3-29.7c7.6-7.6%2C18.1-12.3%2C29.7-12.3%20s22.1%2C4.7%2C29.7%2C12.3c7.6%2C7.6%2C12.3%2C18.1%2C12.3%2C29.7s-4.7%2C22.1-12.3%2C29.7%22%2F%3E%20%3Cpath%20class%3D%22st4%22%20d%3D%22M272.2%2C315.7c0-7.2-0.3-14%2C0.1-20.8c0.2-2.6%2C1-5.6%2C2.5-7.9c3.9-6.1%2C8.4-11.9%2C12.5-17.9%20c0.9-1.2%2C1.5-2.8%2C1.5-4.2c0.1-21.2%2C0.1-42.4%2C0-63.5c0-5.1-3.2-8-7.9-7.9c-4.6%2C0.1-7.3%2C3-7.4%2C8c-0.1%2C4.7%2C0.1%2C9.4-0.1%2C14.1%20c-0.1%2C4.4-3.2%2C7.1-7.1%2C6.4c-3.9-0.8-5.1-3.6-5.1-7.2c0-9.4%2C0-18.8%2C0-28.1c0-6.2-2.6-9.4-7.4-9.3c-4.8%2C0.1-7.2%2C3.2-7.3%2C9.6%20c0%2C6.2%2C0.1%2C12.5%2C0%2C18.8c-0.1%2C4.6-2.6%2C7.6-6.3%2C7.4c-3.6-0.2-5.8-3-5.8-7.4c0-9%2C0-17.9%2C0-26.8c0-4.9-3.2-8.2-7.3-8.2%20c-4.4%2C0-7.2%2C3.2-7.2%2C8.2c-0.1%2C8.6%2C0%2C17.3%2C0%2C26c0%2C5.1-2.2%2C8.1-6.1%2C8.3c-3.9%2C0.2-6.4-3-6.5-8.3c0-12%2C0-24.2%2C0-36.2%20c0-11.5%2C0.1-23.1%2C0-34.5c0-5.4-3.3-8.5-8.3-7.9c-4.1%2C0.5-6.3%2C3.7-6.3%2C9.1c0%2C29.6%2C0%2C59.1%2C0%2C88.7c0%2C3.7-0.8%2C6.6-4.5%2C7.7%20c-3.7%2C1-5.8-1.2-7.6-4c-3.3-5.1-6.6-10.2-10.2-15.2c-1.1-1.5-3.3-3.4-5-3.3c-2.4%2C0.1-5.2%2C1.3-6.8%2C3.1c-2.1%2C2.4-1.2%2C5.5%2C0.6%2C8.2%20c14.3%2C22%2C28.6%2C44%2C42.7%2C66.2c1.5%2C2.5%2C2.4%2C5.7%2C2.6%2C8.6c0.3%2C6.7%2C0.1%2C13.5%2C0.1%2C20.3C227.2%2C315.7%2C249.3%2C315.7%2C272.2%2C315.7z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  }
}
/*# sourceMappingURL=../../map/common/common.css.map */