@charset "UTF-8";
/*----------------------------------------
media query
----------------------------------------*/
/*----------------------------------------

	Default CSS
	default setting

-----------------------------------------*/
body,
div,
dl,
dt,
dd,
th,
td,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
p,
form,
figure {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6,
strong,
em,
p {
  font-size: 100%;
  font-style: normal;
  font-weight: normal;
}

th {
  text-align: left;
  font-weight: normal;
}

li {
  list-style: none;
  vertical-align: bottom;
}

li img {
  vertical-align: top;
}

img,
table,
th,
td {
  border: 0;
}

hr {
  display: none;
}

input,
textarea,
select {
  color: #333333;
  font-size: 100%;
  font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "Osaka", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS P Gothic,sans-serif", sans-serif;
}

/*----------------------------------------
	body setting
-----------------------------------------*/
body {
  background-color: #fff;
  font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "Osaka", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS P Gothic,sans-serif", sans-serif;
}

/*----------------------------------------
	link setting
-----------------------------------------*/
a:link,
a:visited {
  color: #111;
  text-decoration: none;
}

a:hover,
a:active {
  color: #111;
  text-decoration: none;
}

/*----------------------------------------
	clearfix
-----------------------------------------*/
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  height: 0px;
  font-size: 0.1px;
  line-height: 0.1px;
}

.clearfix {
  display: inline-block;
  position: relative;
  /* DW */
}

/* Hides from IE-mac \*/
.clearfix {
  display: block;
}

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

/* End hide from IE-mac */
/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  box-sizing: border-box;
}
input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}
input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

input:not([type=radio]),
textarea {
  /*-webkit-appearance: none;*/
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

html,
body {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
  background: url(../img/common/common_bg-origin.png) repeat-y center top/100% auto;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.7rem;
  line-height: 1.4;
  font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
  font-weight: 500;
  color: #907647;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 1.4rem;
  }
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

section {
  position: relative;
}

h1 {
  font-size: 2.4rem;
  font-weight: bold;
}
@media screen and (max-width: 1023px) {
  h1 {
    font-size: 1.7rem;
  }
}

h2 {
  font-size: 2.3rem;
  font-weight: bold;
}
@media screen and (max-width: 1023px) {
  h2 {
    font-size: 1.7rem;
  }
}

h3 {
  font-size: 1.7rem;
  font-weight: bold;
}
@media screen and (max-width: 1023px) {
  h3 {
    font-size: 1.4rem;
  }
}

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

a:link,
a:visited,
a:hover {
  color: #231815;
  text-decoration: none;
}

a:hover {
  opacity: 0.6;
}

:focus {
  outline: none;
}

[v-cloak] {
  display: none;
}

.l-container {
  width: 100%;
  padding-top: 32px;
  padding-bottom: 32px;
  padding-left: 24px;
  padding-right: 24px;
  margin: 0 auto;
  text-align: center;
  max-width: 500px;
}
@media screen and (min-width: 768px) {
  .l-container {
    padding-top: 50px;
    padding-bottom: 50px;
    padding-left: 32px;
    padding-right: 32px;
    max-width: 540px;
  }
}
@media screen and (min-width: 1024px) {
  .l-container {
    max-width: 1240px;
    padding-top: 96px;
    padding-bottom: 96px;
    padding-left: 48px;
    padding-right: 48px;
  }
}

.l-container-fluid {
  width: 100%;
  padding: 110px 0px;
  min-width: 1024px;
}
@media screen and (max-width: 1023px) {
  .l-container-fluid {
    padding: 50px 0px;
    text-align: center;
    min-width: 320px;
  }
}

@media screen and (max-width: 1023px) {
  .l-tb-container-fluid {
    width: 100%;
    padding-left: 0px;
    padding-right: 0px;
  }
}

@media screen and (max-width: 767px) {
  .l-sp-container-fluid {
    width: 100%;
    padding-left: 0px;
    padding-right: 0px;
  }
}

.l-seciton {
  position: relative;
}

.l-wrapper {
  min-height: 100%;
  position: relative;
  overflow: hidden;
}
.l-main {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1024px) {
  .l-main {
    padding-top: 80px;
  }
}

.l-nav {
  position: fixed;
  display: none;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100vh;
  opacity: 0;
  transition: all 0.3s;
}
.l-nav.is-active {
  display: block;
  opacity: 1;
  animation: fadein 0.3s linear;
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.c-button.back img {
  width: auto;
  height: 31px;
}
@media screen and (min-width: 1024px) {
  .c-button.back img {
    width: auto;
    height: 45px;
  }
}

a.c-link {
  font-size: 1.4rem;
  color: #231815;
  font-weight: bold;
}
a.c-link:link,
a.c-link :visited {
  color: #231815;
}
a.c-link.blue {
  color: #143473;
}
a.c-link.blue:link,
a.c-link.blue :visited {
  color: #143473;
}
a.c-link.blue:hover {
  color: rgba(20, 52, 115, 0.6);
}
a.c-link.plane {
  font-weight: normal;
  opacity: 1;
}
a.c-link:hover {
  color: #143473;
  opacity: 1;
}

.ic {
  width: 13px;
  height: 1em;
  margin-right: 4px;
  display: inline-block;
  border-radius: 0;
  vertical-align: middle;
}
.ic.account-gr {
  background: url("../images/icon_account_gr.svg") no-repeat left center/contain;
}
.ic.account {
  background: url("../images/icon_account_gr.svg") no-repeat left center/contain;
}
.ic.account-bl {
  background: url("../images/icon_account_bl.svg") no-repeat left center/contain;
}
.ic.manage-account {
  padding-right: 16px;
  background: url("../images/icon_account_manage.svg") no-repeat left center/contain;
}
.ic.e-learning {
  background: url("../images/icon_e-learning.svg") no-repeat left center/contain;
}
.ic.e-learning-record {
  background: url("../images/icon_e-learning-record.svg") no-repeat left center/contain;
}
.ic.history {
  background: url("../images/icon_history.svg") no-repeat left center/contain;
}
.ic.link {
  background: url("../images/icon_link.svg") no-repeat left center/contain;
}
.ic.support {
  background: url("../images/icon_support.svg") no-repeat left center/contain;
}
.ic.report {
  background: url("../images/icon_report.svg") no-repeat left center/contain;
}
.ic.schedule {
  background: url("../images/icon_schedule.svg") no-repeat left center/contain;
}
.ic.trialsite {
  background: url("../images/icon_trial-site.svg") no-repeat left center/contain;
}
.ic.manual {
  background: url("../images/icon_manual.svg") no-repeat left center/contain;
}
.ic.faq {
  background: url("../images/icon_faq.svg") no-repeat left center/contain;
}
.ic.pdf {
  background: url("../images/icon_pdf.svg") no-repeat left center/contain;
}
.ic.md {
  width: 16px;
  margin-right: 8px;
}
@media screen and (max-width: 767px) {
  .ic--sp.e-learning {
    background: url("../images/icon_e-learning_bl.svg") no-repeat left center/contain;
  }
  .ic--sp.e-learning-record {
    background: url("../images/icon_e-learning_record_bl.svg") no-repeat left center/contain;
  }
  .ic--sp.history {
    background: url("../images/icon_history_bl.svg") no-repeat left center/contain;
  }
  .ic--sp.link {
    background: url("../images/icon_link_bl.svg") no-repeat left center/contain;
  }
}

.c-flex {
  display: flex;
  flex-wrap: wrap;
}
.c-flex--nw {
  flex-wrap: nowrap;
}
.c-flex__col-1 {
  flex-basis: 8.3333333333%;
  max-width: 8.3333333333%;
}
.c-flex__col-2 {
  flex-basis: 16.6666666667%;
  max-width: 16.6666666667%;
}
.c-flex__col-3 {
  flex-basis: 25%;
  max-width: 25%;
}
.c-flex__col-4 {
  flex-basis: 33.3333333333%;
  max-width: 33.3333333333%;
}
.c-flex__col-5 {
  flex-basis: 41.6666666667%;
  max-width: 41.6666666667%;
}
.c-flex__col-6 {
  flex-basis: 50%;
  max-width: 50%;
}
.c-flex__col-7 {
  flex-basis: 58.3333333333%;
  max-width: 58.3333333333%;
}
.c-flex__col-8 {
  flex-basis: 66.6666666667%;
  max-width: 66.6666666667%;
}
.c-flex__col-9 {
  flex-basis: 75%;
  max-width: 75%;
}
.c-flex__col-10 {
  flex-basis: 83.3333333333%;
  max-width: 83.3333333333%;
}
.c-flex__col-11 {
  flex-basis: 91.6666666667%;
  max-width: 91.6666666667%;
}
.c-flex__col-12 {
  flex-basis: 100%;
  max-width: 100%;
}
@media screen and (max-width: 1023px) {
  .c-flex__col-1--sm {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .c-flex__col-2--sm {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .c-flex__col-3--sm {
    flex-basis: 25%;
    max-width: 25%;
  }
  .c-flex__col-4--sm {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .c-flex__col-5--sm {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .c-flex__col-6--sm {
    flex-basis: 50%;
    max-width: 50%;
  }
  .c-flex__col-7--sm {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .c-flex__col-8--sm {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .c-flex__col-9--sm {
    flex-basis: 75%;
    max-width: 75%;
  }
  .c-flex__col-10--sm {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .c-flex__col-11--sm {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .c-flex__col-12--sm {
    flex-basis: 100%;
    max-width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .c-flex__col-1--md {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .c-flex__col-2--md {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .c-flex__col-3--md {
    flex-basis: 25%;
    max-width: 25%;
  }
  .c-flex__col-4--md {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .c-flex__col-5--md {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .c-flex__col-6--md {
    flex-basis: 50%;
    max-width: 50%;
  }
  .c-flex__col-7--md {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .c-flex__col-8--md {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .c-flex__col-9--md {
    flex-basis: 75%;
    max-width: 75%;
  }
  .c-flex__col-10--md {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .c-flex__col-11--md {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .c-flex__col-12--md {
    flex-basis: 100%;
    max-width: 100%;
  }
}

.c-grid--col-12, .c-grid--col-11, .c-grid--col-10, .c-grid--col-9, .c-grid--col-8, .c-grid--col-7, .c-grid--col-6, .c-grid--col-5, .c-grid--col-4, .c-grid--col-3, .c-grid--col-2 {
  display: grid;
}

.c-grid--col-2 {
  grid-template-columns: repeat(2, 1fr);
}
.c-grid--col-3 {
  grid-template-columns: repeat(3, 1fr);
}
.c-grid--col-4 {
  grid-template-columns: repeat(4, 1fr);
}
.c-grid--col-5 {
  grid-template-columns: repeat(5, 1fr);
}
.c-grid--col-6 {
  grid-template-columns: repeat(6, 1fr);
}
.c-grid--col-7 {
  grid-template-columns: repeat(7, 1fr);
}
.c-grid--col-8 {
  grid-template-columns: repeat(8, 1fr);
}
.c-grid--col-9 {
  grid-template-columns: repeat(9, 1fr);
}
.c-grid--col-10 {
  grid-template-columns: repeat(10, 1fr);
}
.c-grid--col-11 {
  grid-template-columns: repeat(11, 1fr);
}
.c-grid--col-12 {
  grid-template-columns: repeat(12, 1fr);
}
@media screen and (max-width: 767px) {
  .c-grid--col-1--sm {
    grid-template-columns: repeat(1, 1fr);
  }
  .c-grid--col-2--sm {
    grid-template-columns: repeat(2, 1fr);
  }
  .c-grid--col-3--sm {
    grid-template-columns: repeat(3, 1fr);
  }
  .c-grid--col-4--sm {
    grid-template-columns: repeat(4, 1fr);
  }
  .c-grid--col-5--sm {
    grid-template-columns: repeat(5, 1fr);
  }
  .c-grid--col-6--sm {
    grid-template-columns: repeat(6, 1fr);
  }
  .c-grid--col-7--sm {
    grid-template-columns: repeat(7, 1fr);
  }
  .c-grid--col-8--sm {
    grid-template-columns: repeat(8, 1fr);
  }
  .c-grid--col-9--sm {
    grid-template-columns: repeat(9, 1fr);
  }
  .c-grid--col-10--sm {
    grid-template-columns: repeat(10, 1fr);
  }
  .c-grid--col-11--sm {
    grid-template-columns: repeat(11, 1fr);
  }
  .c-grid--col-12--sm {
    grid-template-columns: repeat(12, 1fr);
  }
}
@media screen and (max-width: 1023px) {
  .c-grid--col-1--md {
    grid-template-columns: repeat(1, 1fr);
  }
  .c-grid--col-2--md {
    grid-template-columns: repeat(2, 1fr);
  }
  .c-grid--col-3--md {
    grid-template-columns: repeat(3, 1fr);
  }
  .c-grid--col-4--md {
    grid-template-columns: repeat(4, 1fr);
  }
  .c-grid--col-5--md {
    grid-template-columns: repeat(5, 1fr);
  }
  .c-grid--col-6--md {
    grid-template-columns: repeat(6, 1fr);
  }
  .c-grid--col-7--md {
    grid-template-columns: repeat(7, 1fr);
  }
  .c-grid--col-8--md {
    grid-template-columns: repeat(8, 1fr);
  }
  .c-grid--col-9--md {
    grid-template-columns: repeat(9, 1fr);
  }
  .c-grid--col-10--md {
    grid-template-columns: repeat(10, 1fr);
  }
  .c-grid--col-11--md {
    grid-template-columns: repeat(11, 1fr);
  }
  .c-grid--col-12--md {
    grid-template-columns: repeat(12, 1fr);
  }
}

.c-grid-g20 {
  gap: 20px;
}

.c-grid-g30 {
  gap: 30px;
}

.c-grid-g40 {
  gap: 40px;
}

.c-grid-g50 {
  gap: 50px;
}

.c-grid-g60 {
  gap: 60px;
}

.c-grid-g70 {
  gap: 70px;
}

.c-grid-g80 {
  gap: 80px;
}

.c-grid-g90 {
  gap: 90px;
}

.c-grid-g100 {
  gap: 100px;
}

.c-menu-button {
  color: #CABB89;
  width: 40px;
  height: 50px;
  display: block;
  text-align: center;
  position: relative;
}
.c-menu-button span {
  display: block;
  width: 100%;
  border-top: solid 2px #CABB89;
  transition: all cubic-bezier(0.445, 0.05, 0.55, 0.95) 200ms;
  transform-origin: 50% 50%;
  position: absolute;
}
.c-menu-button span:nth-of-type(1) {
  top: 0;
  left: 0;
}
.c-menu-button span:nth-of-type(2) {
  top: 8px;
  left: 0;
}
.c-menu-button span:nth-of-type(3) {
  top: 16px;
  left: 0;
}
.c-menu-button:after {
  content: "MENU";
  display: block;
  font-size: 1.2rem;
  text-align: center;
  color: #CABB89;
  position: absolute;
  width: 100%;
  top: 23px;
  left: 0;
}
.c-menu-button.open span:nth-of-type(1) {
  top: 20%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(315deg);
}
.c-menu-button.open span:nth-of-type(2) {
  opacity: 0;
}
.c-menu-button.open span:nth-of-type(3) {
  top: 20%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}

.c-divider {
  background: url(../img/common/common_blue_bg@2x.webp) no-repeat center center/cover;
  height: 45px;
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.5);
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1024px) {
  .c-divider {
    background: url(../img/common/common_blue_bg@2x.webp) no-repeat center center/cover;
    height: 90px;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.5);
    position: relative;
    z-index: 1;
  }
}

.header {
  background: url(../img/common/common_blue_bg@2x.webp) no-repeat center center/cover;
  z-index: 2;
}
.header__inner {
  padding: 16px 24px 16px 24px;
  display: flex;
  justify-content: center;
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.5);
}
.header__logo {
  position: relative;
  z-index: 2;
  text-align: center;
}
.header__logo img {
  width: 240px;
}
.header__menu {
  position: fixed;
  top: 16px;
  right: 8px;
  z-index: 97;
}
.header__menu .c-menu-button {
  display: none;
}
.header__menu .c-menu-button.open {
  display: block;
}
.header__menu img {
  width: 40px;
}
.header__sp-nav {
  display: flex;
  text-align: center;
  background: black;
  gap: 1px;
}
.header__sp-nav-item {
  flex-basis: 25%;
  border-left: solid 1px #CABB89;
}
.header__sp-nav-item:first-of-type {
  border-left: none;
}
.header__sp-nav-item a {
  display: block;
  height: 48px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #CABB89;
  font-size: 1rem;
}
.header__sp-nav-item a:link, .header__sp-nav-item a:visited {
  color: #CABB89;
}
.header__sp-nav-item a.disabled {
  opacity: 0.6;
}
.header__sp-nav-item.entry a {
  background: #5f0d12;
}
.header__sp-nav-item.exclusive a {
  background: #65581d;
}
.header__sp-nav-item.tel a {
  background: black;
}
.header__sp-nav-item.tel img {
  width: 19px;
}
.header__sp-nav-item.menu-sp a {
  background: black;
}
.header__sp-nav-item.menu-sp img {
  width: 25px;
}
@media screen and (min-width: 1024px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: url(../img/common/common_blue_bg@2x.webp) no-repeat center center/cover;
    z-index: 2;
  }
  .header__inner {
    padding: 24px 40px 24px 40px;
    display: flex;
    justify-content: space-between;
    box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.5);
  }
  .header__logo {
    position: relative;
    z-index: 2;
  }
  .header__logo img {
    max-width: none;
    width: 300px;
  }
  .header__menu {
    position: fixed;
    top: 28px;
    right: 48px;
    z-index: 97;
  }
  .header__menu .c-menu-button {
    display: block;
  }
  .header__menu img {
    width: 40px;
  }
}

@media screen and (min-width: 1024px) {
  .home .header {
    opacity: 0;
    transition: all 0.3s;
  }
  .home.is-scrolled .header {
    opacity: 1;
  }
}

.is-scrolled_sp .header__sp-nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 95;
}

.plan-detail .header {
  display: none;
}
.plan-detail .header__menu {
  display: none;
}

.footer {
  position: relative;
  background: white;
}
.footer__guidance {
  color: white;
  background: #071D50;
}
.footer__guidance .l-container {
  padding-top: 32px;
  padding-bottom: 32px;
}
.footer__guidance-item {
  margin-bottom: 48px;
}
.footer__guidance-item:last-of-type {
  margin-bottom: 0;
}
.footer__guidance-item img {
  max-width: 300px;
}
@media screen and (min-width: 1024px) {
  .footer__guidance .l-container {
    padding-top: 48px;
    padding-bottom: 48px;
  }
  .footer__guidance-items {
    display: flex;
    justify-content: space-between;
  }
  .footer__guidance-item {
    margin-bottom: 0;
    flex-basis: 31%;
  }
}
.footer__notice {
  padding: 32px 24px;
  color: #231815;
  font-size: 1rem;
  line-height: 1.8;
  border-bottom: solid 1px black;
}
.footer__notice-pre {
  margin-bottom: 24px;
}
.footer__notice-pre span {
  display: inline-block;
  padding: 0 8px;
  margin-right: 8px;
  border: solid 1px #231815;
  margin-bottom: 8px;
}
@media screen and (min-width: 1024px) {
  .footer__notice-pre {
    margin-bottom: 24px;
  }
  .footer__notice-pre span {
    display: inline-block;
    padding: 0 8px;
    margin-right: 8px;
    border: solid 1px #231815;
  }
  .footer__notice {
    padding: 32px 64px;
    color: #231815;
    font-size: 1.2rem;
    line-height: 1.8;
    border-bottom: solid 1px black;
  }
}
.footer__company {
  padding: 32px 24px;
  display: flex;
  gap: 16px;
  color: #333333;
}
.footer__company-item {
  flex-basis: calc(50% - 8px);
}
.footer__company-item h3 {
  font-size: 1.1rem;
  margin-bottom: 8px;
}
.footer__company-item p {
  display: block;
  font-size: 1rem;
}
.footer__company-heading {
  display: flex;
  margin-bottom: 8px;
  align-items: center;
  gap: 8px;
}
.footer__company-logo img {
  width: auto;
  height: 22px;
}
.footer__company-instagram img {
  width: 18px;
}
@media screen and (min-width: 1024px) {
  .footer__company {
    padding: 32px;
    display: flex;
    gap: 40px;
    color: #333333;
  }
  .footer__company-item {
    flex-basis: auto;
  }
  .footer__company-item h3 {
    font-size: 1.2rem;
    margin-bottom: 8px;
  }
  .footer__company-item p {
    display: block;
    font-size: 1rem;
  }
  .footer__company-heading {
    display: flex;
    margin-bottom: 8px;
    align-items: center;
    gap: 8px;
  }
  .footer__company-logo img {
    width: auto;
    height: 28px;
  }
  .footer__company-instagram img {
    width: 22px;
  }
}
.footer__copyright {
  background: #F4F4F4;
  color: #231815;
  font-size: 1rem;
  text-align: center;
  margin: 0;
  padding: 16px 0;
}
@media screen and (min-width: 1024px) {
  .footer__copyright {
    background: #F4F4F4;
    color: #231815;
    font-size: 1.2rem;
    text-align: center;
    margin: 0;
    padding: 23px 0;
  }
}

.plan-detail .footer {
  display: none;
}

.menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0;
  height: 100%;
  overflow: scroll;
  background: black;
}
.menu.active {
  z-index: 96;
  animation: fadeIn 0.3s cubic-bezier(0.5, 1, 0.89, 1) forwards;
}
.menu.deactive {
  z-index: -1;
  animation: fadeOut 0.3s cubic-bezier(0.5, 1, 0.89, 1) forwards;
}
.menu__header {
  background: url(../img/common/menu_bg-origin.jpg) no-repeat center bottom/cover;
  flex-basis: 30%;
  margin: 0 auto;
  padding: 32px 32px 24px 32px;
}
.menu__logo {
  margin-bottom: 20px;
  text-align: center;
}
.menu__logo img {
  width: 240px;
}
.menu__cta {
  display: flex;
  gap: 16px;
  text-align: center;
  justify-content: center;
}
.menu__cta-item {
  width: 100%;
  max-width: 250px;
}
.menu__cta-item a.disabled {
  opacity: 0.5;
}
.menu__contents {
  background: black;
  padding: 32px;
}
.menu__contents-inner {
  max-width: 1024px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 80px;
}
.menu__items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  row-gap: 32px;
  max-width: 516px;
  margin: 0 auto;
}
.menu__item {
  position: relative;
  flex-basis: calc(50% - 16px);
  text-align: center;
  font-size: 1.4rem;
  color: white;
}
.menu__item.small {
  font-size: 1.4rem;
}
.menu__item.small a {
  letter-spacing: 0em;
}
.menu__item a {
  color: white;
  letter-spacing: 0.1em;
  font-weight: bold;
  line-height: 1.2;
  display: block;
  border-bottom: solid 1px #CABB89;
  padding-bottom: 8px;
}
.menu__item a:link, .menu__item a:visited {
  color: white;
}
.menu__item a span {
  font-size: 1rem;
  letter-spacing: 0.1em;
  color: #CABB89;
  display: inline-block;
}
.menu__item a.disabled {
  opacity: 0.5;
}
.menu__new {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  text-align: center;
  background: #94252A;
  color: white;
  font-weight: bold !important;
  padding: 2px 5px;
  font-size: 1rem !important;
}
.menu__close {
  position: fixed;
  top: 0;
  right: 0;
}
.menu__close img {
  width: 48px;
}
@media screen and (min-width: 1024px) {
  .menu {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    align-items: center;
    z-index: -1;
    opacity: 0;
    overflow: auto;
  }
  .menu.active {
    z-index: 96;
    animation: fadeIn 0.3s cubic-bezier(0.5, 1, 0.89, 1) forwards;
  }
  .menu.deactive {
    z-index: -1;
    animation: fadeOut 0.3s cubic-bezier(0.5, 1, 0.89, 1) forwards;
  }
  .menu__header {
    background: url(../img/common/menu_bg-origin.jpg) no-repeat center bottom/cover;
    flex-basis: 30%;
    margin: 0 auto;
    height: 100%;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .menu__logo {
    margin-bottom: 40px;
    text-align: center;
  }
  .menu__logo img {
    width: 176px;
    max-width: none;
  }
  .menu__cta {
    display: block;
    text-align: center;
  }
  .menu__cta-item {
    margin-bottom: 16px;
    width: 250px;
  }
  .menu__cta-item a.disabled {
    opacity: 0.5;
  }
  .menu__contents {
    flex-basis: 70%;
    background: black;
    height: 100vh;
    overflow: scroll;
    padding: 64px;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .menu__contents::-webkit-scrollbar {
    display: none;
  }
  .menu__contents-inner {
    max-width: 1024px;
    height: 100%;
    min-height: 640px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 80px;
  }
  .menu__items {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 80px;
    max-width: none;
  }
  .menu__item {
    position: relative;
    flex-basis: 32%;
    text-align: center;
    align-items: center;
    font-size: 2.2rem;
    color: white;
    border-bottom: none;
  }
  .menu__item.w50 {
    flex-basis: 50%;
  }
  .menu__item.small {
    font-size: 2rem;
  }
  .menu__item.small a {
    letter-spacing: 0em;
  }
  .menu__item a {
    color: white;
    letter-spacing: 0.1em;
    font-weight: bold;
    line-height: 1;
    display: inline-block;
    border-bottom: none;
    padding-bottom: 0;
  }
  .menu__item a:link, .menu__item a:visited {
    color: white;
  }
  .menu__item a span {
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    color: #CABB89;
    display: inline-block;
  }
  .menu__item a.disabled {
    opacity: 0.5;
  }
  .menu__new {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    text-align: center;
    background: #94252A;
    color: white;
    font-weight: bold !important;
    padding: 2px 5px;
    font-size: 1.2rem !important;
  }
  .menu__close {
    position: fixed;
    top: 0;
    right: 0;
  }
  .menu__close img {
    width: 48px;
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.p-page-heading {
  padding: 48px 0 32px 0;
}
.p-page-heading .l-container {
  padding-top: 0;
  padding-bottom: 0;
}
.p-page-heading h1 {
  font-size: 2.8rem;
  margin-bottom: 4px;
  letter-spacing: 0.2em;
}
.p-page-heading p {
  font-size: 1.4rem;
  letter-spacing: 0.25em;
  font-weight: bold;
}
@media screen and (min-width: 1024px) {
  .p-page-heading {
    padding: 96px 0 32px 0;
  }
  .p-page-heading .l-container {
    padding-top: 0;
    padding-bottom: 0;
  }
  .p-page-heading h1 {
    font-size: 4.5rem;
    margin-bottom: 4px;
    letter-spacing: 0.2em;
  }
  .p-page-heading p {
    font-size: 2rem;
    letter-spacing: 0.25em;
    font-weight: bold;
  }
}

.heading {
  margin-bottom: 16px;
}
.heading h2 {
  font-size: 2.6rem;
  border-bottom: solid 1px #E0E1E3;
  padding-bottom: 6px;
  font-weight: normal;
}
.heading--small {
  margin-bottom: 16px;
}
.heading--small h2 {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 8px;
}
@media screen and (min-width: 1024px) {
  .heading {
    margin-bottom: 24px;
  }
  .heading h2 {
    font-size: 2.8rem;
    border-bottom: solid 1px #E0E1E3;
    padding-bottom: 6px;
    font-weight: normal;
  }
  .heading--small {
    margin-bottom: 16px;
  }
  .heading--small h2 {
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 8px;
  }
}

.p-cta {
  background: white;
}
.p-cta .l-container {
  text-align: center;
  padding-top: 32px;
  padding-bottom: 32px;
}
.p-cta__heading {
  margin-bottom: 20px;
}
.p-cta__heading p {
  margin-bottom: 8px;
  letter-spacing: 0.1em;
  font-weight: 500;
  font-size: 1rem;
}
.p-cta__heading h2 {
  font-size: 2.4rem;
  border-bottom: solid 1px #CABB89;
  padding-bottom: 8px;
  letter-spacing: 0;
  display: inline-block;
  color: #94252A;
}
.p-cta__item {
  margin-bottom: 8px;
}
.p-cta__item a.disabled {
  opacity: 0.35;
}
.p-cta__item img {
  width: 210px;
}
@media screen and (min-width: 1024px) {
  .p-cta {
    background: white;
  }
  .p-cta .l-container {
    text-align: center;
    padding-top: 64px;
    padding-bottom: 64px;
  }
  .p-cta__heading {
    margin-bottom: 24px;
  }
  .p-cta__heading p {
    margin-bottom: 8px;
    letter-spacing: 0.1em;
    font-weight: 500;
    font-size: 1.4rem;
  }
  .p-cta__heading h2 {
    font-size: 3.2rem;
    border-bottom: solid 1px #CABB89;
    padding-bottom: 8px;
    letter-spacing: 0.2em;
    display: inline-block;
    color: #94252A;
  }
  .p-cta__item {
    margin-bottom: 16px;
  }
  .p-cta__item a.disabled {
    opacity: 0.35;
  }
  .p-cta__item img {
    width: 280px;
  }
}

.p-topics .l-container {
  padding-top: 32px;
  padding-bottom: 40px;
}
.p-topics__inner {
  display: flex;
  flex-direction: column;
  gap: 40px;
  justify-content: center;
}
.p-topics__block {
  flex-basis: 100%;
}
.p-topics__block h2 {
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  font-size: 1.8rem;
}
.p-topics__items {
  text-align: left;
}
.p-topics__items #news_block dl {
  display: flex;
  flex-wrap: wrap;
  letter-spacing: 0.1em;
  row-gap: 12px;
  font-size: 1.2rem;
}
.p-topics__items #news_block dt {
  flex-basis: 80px;
  flex-shrink: 0;
  color: #907647;
  font-weight: bold;
}
.p-topics__items #news_block dd {
  flex-basis: calc(100% - 80px);
}
.p-topics__items #news_block dd a {
  color: #907647;
  font-weight: bold;
}
.p-topics__items #news_block dd a:link, .p-topics__items #news_block dd a:visited {
  color: #907647;
}
.p-topics__items #event_block ul {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  row-gap: 24px;
}
.p-topics__items #event_block li {
  flex-basis: calc(50% - 8px);
}
.p-topics__items #event_block a {
  display: block;
  text-align: center;
}
.p-topics__items #event_block a p {
  font-weight: bold;
  font-size: 1.2rem;
  margin-top: 8px;
  text-align: center;
  padding: 6px 16px;
  display: inline-block;
  border: solid 1px #907647;
  color: #907647;
}
@media screen and (min-width: 1024px) {
  .p-topics .l-container {
    padding-top: 64px;
    padding-bottom: 40px;
  }
  .p-topics__inner {
    display: flex;
    flex-direction: row;
    gap: 48px;
    justify-content: center;
  }
  .p-topics__block {
    flex-basis: calc(50% - 24px);
  }
  .p-topics__block h2 {
    margin-bottom: 24px;
    letter-spacing: 0.1em;
    font-size: 2.4rem;
  }
  .p-topics__items {
    text-align: left;
  }
  .p-topics__items #news_block dl {
    display: flex;
    flex-wrap: wrap;
    letter-spacing: 0.1em;
    row-gap: 16px;
    font-size: 1.5rem;
  }
  .p-topics__items #news_block dt {
    flex-basis: 100px;
    flex-shrink: 0;
    color: #907647;
    font-weight: bold;
  }
  .p-topics__items #news_block dd {
    flex-basis: calc(100% - 100px);
  }
  .p-topics__items #news_block dd a {
    color: #907647;
    font-weight: bold;
  }
  .p-topics__items #news_block dd a:link, .p-topics__items #news_block dd a:visited {
    color: #907647;
  }
  .p-topics__items #event_block ul {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    row-gap: 24px;
  }
  .p-topics__items #event_block li {
    flex-basis: calc(50% - 12px);
  }
  .p-topics__items #event_block a {
    display: block;
    text-align: center;
  }
  .p-topics__items #event_block a p {
    font-weight: bold;
    font-size: 1.4rem;
    margin-top: 16px;
    text-align: center;
    padding: 6px 24px;
    display: inline-block;
    border: solid 1px #907647;
    color: #907647;
  }
}

a.btn {
  display: block;
  text-decoration: none;
}

figure[data-caps] {
  position: relative;
}

figure[data-caps]::after {
  content: attr(data-caps) "";
  position: absolute;
  bottom: 0;
  right: 0;
  line-height: 1;
  font-size: 10px;
  padding: 1em;
  z-index: 2;
  color: #fff;
}

figure[data-caps].invert::after {
  color: #333;
}

figure[data-caps].icon::after {
  background-color: rgb(83, 115, 136);
}

.staging .typeWriter > span {
  opacity: 1;
}

.standby .typeWriter > span {
  opacity: 0;
}

.typeWriter > span:nth-child(1) {
  transition: opacity ease-in 1000ms;
}

.typeWriter > span:nth-child(2) {
  transition: opacity ease-in 1000ms 50ms;
}

.typeWriter > span:nth-child(3) {
  transition: opacity ease-in 1000ms 100ms;
}

.typeWriter > span:nth-child(4) {
  transition: opacity ease-in 1000ms 150ms;
}

.typeWriter > span:nth-child(5) {
  transition: opacity ease-in 1000ms 200ms;
}

.typeWriter > span:nth-child(6) {
  transition: opacity ease-in 1000ms 300ms;
}

.typeWriter > span:nth-child(7) {
  transition: opacity ease-in 1000ms 350ms;
}

.typeWriter > span:nth-child(8) {
  transition: opacity ease-in 1000ms 400ms;
}

.typeWriter > span:nth-child(9) {
  transition: opacity ease-in 1000ms 450ms;
}

.typeWriter > span:nth-child(10) {
  transition: opacity ease-in 1000ms 500ms;
}

.typeWriter > span:nth-child(11) {
  transition: opacity ease-in 1000ms 550ms;
}

.typeWriter > span:nth-child(12) {
  transition: opacity ease-in 1000ms 600ms;
}

.typeWriter > span:nth-child(13) {
  transition: opacity ease-in 1000ms 650ms;
}

.typeWriter > span:nth-child(14) {
  transition: opacity ease-in 1000ms 700ms;
}

.typeWriter > span:nth-child(15) {
  transition: opacity ease-in 1000ms 750ms;
}

.typeWriter > span:nth-child(16) {
  transition: opacity ease-in 1000ms 800ms;
}

.typeWriter > span:nth-child(17) {
  transition: opacity ease-in 1000ms 850ms;
}

.typeWriter > span:nth-child(18) {
  transition: opacity ease-in 1000ms 900ms;
}

.typeWriter > span:nth-child(19) {
  transition: opacity ease-in 1000ms 950ms;
}

.typeWriter > span:nth-child(20) {
  transition: opacity ease-in 1000ms 1000ms;
}

.typeWriter > span:nth-child(21) {
  transition: opacity ease-in 1000ms 1050ms;
}

.typeWriter > span:nth-child(22) {
  transition: opacity ease-in 1000ms 1100ms;
}

.typeWriter > span:nth-child(23) {
  transition: opacity ease-in 1000ms 1150ms;
}

.typeWriter > span:nth-child(24) {
  transition: opacity ease-in 1000ms 1200ms;
}

.typeWriter > span:nth-child(25) {
  transition: opacity ease-in 1000ms 1250ms;
}

.typeWriter > span:nth-child(26) {
  transition: opacity ease-in 1000ms 1300ms;
}

.typeWriter > span:nth-child(27) {
  transition: opacity ease-in 1000ms 1350ms;
}

.typeWriter > span:nth-child(28) {
  transition: opacity ease-in 1000ms 1400ms;
}

.typeWriter > span:nth-child(29) {
  transition: opacity ease-in 1000ms 1450ms;
}

.typeWriter > span:nth-child(30) {
  transition: opacity ease-in 1000ms 1500ms;
}

.typeWriter > span:nth-child(31) {
  transition: opacity ease-in 1000ms 1550ms;
}

.typeWriter > span:nth-child(32) {
  transition: opacity ease-in 1000ms 1600ms;
}

.typeWriter > span:nth-child(33) {
  transition: opacity ease-in 1000ms 1650ms;
}

.typeWriter > span:nth-child(34) {
  transition: opacity ease-in 1000ms 1700ms;
}

.typeWriter > span:nth-child(35) {
  transition: opacity ease-in 1000ms 1750ms;
}

.typeWriter > span:nth-child(36) {
  transition: opacity ease-in 1000ms 1800ms;
}

.typeWriter > span:nth-child(37) {
  transition: opacity ease-in 1000ms 1850ms;
}

.typeWriter > span:nth-child(38) {
  transition: opacity ease-in 1000ms 1900ms;
}

.typeWriter > span:nth-child(39) {
  transition: opacity ease-in 1000ms 1950ms;
}

.typeWriter > span:nth-child(40) {
  transition: opacity ease-in 1000ms 2000ms;
}

.tbl-list {
  display: table;
}

.tbl-list > * {
  display: table-cell;
  vertical-align: top;
}

.tbl-style-01,
.tbl-style-02 {
  width: 100%;
  border-collapse: separate;
  border-spacing: 1px;
  background-color: rgba(156, 114, 103, 0.2);
}

.tbl-style-01 tr th,
.tbl-style-02 tr th {
  border-top: 0 none transparent;
  border-right: 0 none transparent;
  border-left: 0 none transparent;
  border-bottom: 1px solid #fff;
  padding: 1em;
  text-align: center;
  vertical-align: middle;
  font-weight: 600;
  color: #58331b;
}

.tbl-style-01 tr td,
.tbl-style-02 tr td {
  border-top: 0 none transparent;
  border-right: 0 none transparent;
  border-left: 0 none transparent;
  border-bottom: 1px solid #f6f6f6;
  background-color: #fff;
  padding: 1em;
  font-weight: 400;
  text-align: center;
}

.tbl-style-01 thead th,
.tbl-style-02 thead th {
  text-align: center;
  background-color: #678b9c;
  width: 10em;
  color: #fff;
}

.ttl-style-01 {
  font-size: 125%;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0.3em;
  color: #696457;
}

.ttl-style-01 span {
  display: block;
  font-size: 230%;
  color: #696457;
}

.ttl-style-02 {
  border-bottom: 1px solid rgb(83, 115, 136);
  margin-bottom: 1em;
  padding-bottom: 0.25em;
  font-size: 100%;
  font-family: "Cinzel", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  letter-spacing: 0.3em;
  color: rgb(83, 115, 136);
}

.ttl-style-02 span {
  margin-right: 1em;
  font-size: 175%;
  color: rgb(83, 115, 136);
}

.lead {
  font-family: "Cinzel", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  text-align: center;
  line-height: 2.5;
}

.lead > span {
  display: inline-block;
  white-space: nowrap;
}

.loader {
  position: fixed;
  top: calc(50% - 32px);
  left: calc(50% - 32px);
  width: 64px;
  height: 64px;
  z-index: -1;
}

.loader div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  box-sizing: border-box;
  opacity: 0.8;
}

.one {
  border-top: 1px solid #8fb259;
  animation: rotate-left 1s linear infinite;
}

.two {
  border-right: 1px solid #cccc52;
  animation: rotate-right 1s linear infinite;
}

.three {
  border-bottom: 1px solid #ffd933;
  animation: rotate-right 1s linear infinite;
}

.four {
  border-left: 1px solid #ff7f00;
  animation: rotate-right 1s linear infinite;
}

.pathmove {
  position: relative;
  overflow: hidden;
  background-color: rgb(83, 115, 136);
  width: 1px;
  height: 2em;
  margin: 0 auto;
}

.pathmove span {
  animation: pathmove 1.5s both cubic-bezier(0.15, 0.31, 0.24, 0.88) infinite;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 2;
  background-color: #fff;
  width: 1px;
  text-indent: -999em;
}

.vbox-item {
  position: relative;
}

.vbox-item::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 2em;
  height: 2em;
  background: #fff url("../img/common/icon_search.svg") no-repeat 50%/50% auto;
  filter: invert(1);
  opacity: 0.8;
}

.figlio {
  max-width: 1200px !important;
  margin: 0 auto;
}

.btn-content-01 {
  background: #fff url("../img/common/icon-arrow-circle-next.webp") no-repeat calc(100% - 1em) calc(100% - 1em)/3.5em auto;
  padding: 2em;
}

.btn-content-01 figure img {
  max-width: 21.5625em;
  margin: 0 auto;
}

.btn-content-01 figure + p {
  padding-top: 0.5em;
  font-size: 125%;
  color: #696457;
}

.btn-content-01 figure + p small {
  position: relative;
  padding-left: 2em;
  display: block;
  font-size: 65%;
  color: #696457;
}

.btn-content-01 figure + p small::before {
  content: "";
  border-top: 1px solid #696457;
  width: 1.5em;
  position: absolute;
  top: 50%;
  left: 0;
}

.btn-content-02 {
  background: #fff url("../img/common/icon-arrow-circle-next.webp") no-repeat calc(100% - 1em) calc(100% - 1em)/3.5em auto;
  padding: 2em;
}

.btn-content-02 figure img {
  max-width: 49.125em;
  margin: 0 auto;
}

.btn-content-02 figure + p {
  padding-top: 0.5em;
  font-size: 125%;
  color: #696457;
}

.btn-content-02 figure + p small {
  position: relative;
  padding-left: 2em;
  display: block;
  font-size: 65%;
  color: #696457;
}

.btn-content-02 figure + p small::before {
  content: "";
  border-top: 1px solid #696457;
  width: 1.5em;
  position: absolute;
  top: 50%;
  left: 0;
}

.btn-content-02 figure + p span {
  display: block;
  padding-top: 1em;
  font-size: 84%;
  line-height: 2.32;
}

@media only screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
  a.btn {
    transition: opacity cubic-bezier(0.445, 0.05, 0.55, 0.95) 200ms;
    cursor: pointer;
  }
  a.btn:hover {
    opacity: 0.75;
  }
  .cf:after,
  .cf::after {
    content: "";
    display: table;
    clear: both;
  }
  .cf > .left {
    float: left;
  }
  .cf > .right {
    float: right;
  }
  .grid-list-wrap {
    overflow: hidden;
  }
  .grid-list {
    display: flex;
    align-items: stretch;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .column-list-wrap {
    overflow: hidden;
  }
  .column-list {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
  }
}
/* =====
* LAYOUT :: SP
=================================================================== */
@media only screen and (max-width: 767px) {
  /* -----
  /*    Module
    -------------------------------------- */
  .cf > .left,
  .cf > .right {
    float: none;
  }
  .tbl-style-01 {
    display: block;
    border-top: 3px solid #eaf1f3;
    background-color: transparent;
  }
  .tbl-style-01 tr {
    display: block;
    border-bottom: 3px solid #eaf1f3;
  }
  .tbl-style-01 thead {
    display: none;
  }
  .tbl-style-01 tbody {
    display: block;
  }
  .tbl-style-01 tr th {
    display: block;
    font-weight: 600;
    text-align: center;
    padding: 0;
    background-color: transparent;
  }
  .tbl-style-01 tr td {
    display: block;
    position: relative;
    min-height: 1.5em;
    font-weight: 200;
    border-bottom: 1px solid rgba(156, 114, 103, 0.2);
    background-color: #fff;
    padding: 1em;
    width: auto;
    text-align: right;
  }
  .tbl-style-01 tr td:first-child {
    text-align: left;
    background-color: #678b9c;
    color: #fff;
  }
  .tbl-style-01 tr td:last-child {
    border-bottom: 0 none transparent;
  }
  .tbl-style-01 tr td::before {
    content: attr(aria-label);
    font-weight: 600;
    display: block;
    position: absolute;
    top: 1em;
    left: 1em;
  }
  .tbl-style-01 tr td:nth-child(2)::before {
    color: #0058a2;
  }
  .tbl-style-01 tr td:nth-child(3)::before {
    color: #0089cb;
  }
  .ttl-style-01 {
    margin-bottom: 0.75em;
    letter-spacing: 0;
  }
  .ttl-style-01 span {
    font-size: 125%;
  }
  .ttl-style-02 {
    padding-bottom: 0.75em;
    margin-bottom: 1.5em;
    letter-spacing: 0;
  }
  .ttl-style-02 span {
    display: block;
  }
  .lead {
    line-height: 2;
  }
  .scroller {
    overflow-x: scroll;
    position: relative;
  }
  .scroller::before {
    content: "";
    display: block;
    transition: opacity cubic-bezier(0.445, 0.05, 0.55, 0.95) 500ms;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: transparent url("../img/common/icon_swipe.svg") no-repeat 50% 50%;
    background-size: 20% auto;
    z-index: 3;
  }
  .scroller::after {
    content: "";
    display: block;
    transition: opacity cubic-bezier(0.445, 0.05, 0.55, 0.95) 500ms;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.2);
    width: 150%;
    padding: 3%;
    z-index: 2;
  }
  .scroller.on::before,
  .scroller.on::after {
    opacity: 0;
  }
  .scroller img {
    width: 150%;
    padding: 3%;
    opacity: 0.5;
    transition: opacity cubic-bezier(0.445, 0.05, 0.55, 0.95) 100ms;
  }
  .scroller.on img {
    opacity: 1;
  }
  .scroller::-webkit-scrollbar {
    -webkit-appearance: none !important;
    height: 10px !important;
    background: #eaeaea !important;
  }
  .scroller::-webkit-scrollbar-thumb {
    background: #cdcdcd !important;
  }
}
.p-quality {
  background: transparent url("https://sunpark-mansion.com/wp/wp-content/themes/sunpark/img/common/bg-02.webp") no-repeat 50% 50%;
  background-size: cover;
  padding: 4em 0;
  position: relative;
  font-size: 16px;
}

.p-quality .slider-common-concept {
  overflow: hidden;
}

.p-quality .slider-common-concept .swiper-wrapper {
  transition-timing-function: linear;
}

.p-quality .slider-common-concept .swiper-slide {
  width: auto !important;
}

.p-quality .slider-common-concept .grid-list {
  margin: 0;
  width: 55.125em;
}

.p-quality .slider-common-concept .grid-list .btn-content-01,
.p-quality .slider-common-concept .grid-list .btn-content-02 {
  margin: 1em;
  background-image: url("../img/common/icon-arrow-circle-next.webp");
}

@media only screen and (max-width: 767px) {
  .p-quality {
    padding: 3em 0;
  }
  .p-quality .slider-common-concept .grid-list.pickup {
    width: 27.5625em;
  }
  .p-quality .slider-common-concept .grid-list .btn-content-02 figure {
    overflow: hidden;
    max-height: 11.563em;
  }
  .p-quality .slider-common-concept .grid-list .btn-content-02 figure + p {
    letter-spacing: 0;
  }
  .p-quality .slider-common-concept .grid-list .btn-content-02 figure + p span {
    display: none;
  }
  .p-quality .slider-common-concept .grid-list .btn-content-02 figure img {
    max-width: 21.5625em;
    margin: 0 auto;
  }
  .p-quality .slider {
    font-size: 3vw;
  }
  .p-quality .grid-list {
    display: flex;
    align-items: stretch;
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.visible-xs {
  display: none;
}
@media screen and (max-width: 767px) {
  .visible-xs {
    display: block;
  }
}

.home .main {
  position: relative;
}
.home .main .l-container {
  height: 100%;
  position: relative;
  padding-top: 0;
}
.home .main__visual {
  height: 142vw;
  background: url(../img/top/main_bg_sp-hq@2x.webp) no-repeat center center/cover;
  text-align: center;
}
.home .main__visual img {
  padding-top: 8vw;
  width: 54vw;
}
.home .main__catch {
  font-size: 6rem;
  letter-spacing: 0.2em;
  font-weight: bold;
}
.home .main__attention {
  color: white;
  font-size: 1rem;
  position: absolute;
  top: calc(142vw - 2em);
  width: 100%;
  padding-left: 3vw;
  text-shadow: 0 0 10px black;
}
.home .main__feature {
  background: url(../img/top/main_feature_top@2x.webp) no-repeat center top/100% auto, url(../img/top/main_feature_bg_sp.webp) no-repeat center center/cover;
  text-align: center;
  padding: 6vw 0 32px 0;
}
.home .main__feature img {
  width: 84%;
  max-width: 382px;
}
@media screen and (min-width: 1024px) {
  .home .main {
    position: relative;
    height: 60vw;
    background: url(../img/top/main_bg-hq@2x.webp) no-repeat center center/cover;
  }
  .home .main .l-container {
    height: 100%;
    position: relative;
    padding-top: 0;
  }
  .home .main__logo {
    position: absolute;
    top: 32px;
    left: 48px;
    z-index: 95;
  }
  .home .main__logo img {
    width: 178px;
  }
  .home .main__visual {
    background: none;
    padding-top: 10.5vw;
    padding-left: 41%;
    height: auto;
    text-align: center;
  }
  .home .main__visual img {
    padding-top: 0;
    width: 31vw;
  }
  .home .main__catch {
    font-size: 6rem;
    letter-spacing: 0.2em;
    font-weight: bold;
  }
  .home .main__attention {
    color: white;
    font-size: 1.2rem;
    position: absolute;
    top: auto;
    bottom: 9vw;
    width: 100%;
    padding-left: 4vw;
  }
  .home .main__feature {
    background: none;
    position: absolute;
    bottom: 2vw;
    width: 100%;
    text-align: center;
    padding: 0;
  }
  .home .main__feature img {
    width: 92%;
    max-width: none;
  }
}
.home .cta {
  background: none;
}
.home .cta .l-container {
  padding-top: 24px;
  padding-bottom: 24px;
}
.home .cta__catch {
  font-size: 1.8rem;
  margin-bottom: 32px;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
@media screen and (min-width: 1024px) {
  .home .cta {
    background: none;
  }
  .home .cta .l-container {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .home .cta__catch {
    font-size: 3rem;
    margin-bottom: 48px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.4;
  }
}
.home .concept {
  background: url(../img/top/concept_bg_btm@2x.webp) no-repeat center bottom/100% auto, url(../img/top/concept_bg@2x.webp) no-repeat center center/cover;
  color: #CABB89;
}
.home .concept .l-container {
  text-align: center;
}
.home .concept__heading {
  margin-bottom: 32px;
}
.home .concept__heading h2 {
  font-size: 1rem;
  letter-spacing: 0.1em;
  margin-bottom: 24px;
}
.home .concept__heading h3 img {
  max-width: 280px;
}
.home .concept__heading p {
  font-size: 5.2rem;
  letter-spacing: 0.1em;
  font-weight: bold;
}
.home .concept__desc {
  font-size: 1.2rem;
  line-height: 2;
  margin-bottom: 2vw;
}
.home .concept__desc p {
  font-weight: bold;
  letter-spacing: 0.2em;
}
.home .concept__image {
  margin-top: 16px;
  text-align: center;
}
.home .concept__image img {
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .home .concept {
    background: url(../img/top/concept_bg_btm@2x.webp) no-repeat center bottom/100% auto, url(../img/top/concept_bg@2x.webp) no-repeat center center/cover;
    color: #CABB89;
  }
  .home .concept .l-container {
    text-align: center;
  }
  .home .concept__heading {
    margin-bottom: 48px;
  }
  .home .concept__heading h2 {
    font-size: 2rem;
    letter-spacing: 0.1em;
    margin-bottom: 72px;
  }
  .home .concept__heading h3 img {
    max-width: 475px;
  }
  .home .concept__heading p {
    font-size: 5.2rem;
    letter-spacing: 0.1em;
    font-weight: bold;
  }
  .home .concept__desc {
    font-size: 2rem;
    line-height: 2;
    margin-bottom: 2vw;
  }
  .home .concept__desc p {
    font-weight: bold;
    letter-spacing: 0.2em;
  }
  .home .concept__image {
    margin-top: 32px;
    text-align: center;
  }
  .home .concept__image img {
    width: 85%;
  }
}
.home .detail h2 {
  display: none;
}
.home .detail__item {
  padding: 24px 0 56px 0;
}
.home .detail__item h3 {
  display: flex;
  font-size: clamp(1.4rem, 4.5vw, 2rem);
  letter-spacing: 0.1em;
  line-height: 2;
  margin-bottom: 24px;
  text-align: left;
}
.home .detail__item h3 span {
  font-size: 5.4rem;
  transform: translateY(-0.4em);
  line-height: 1;
  font-weight: normal;
}
.home .detail__item.right h3 {
  justify-content: flex-end;
}
.home .detail__item.right .detail__inner {
  padding-left: 0;
}
.home .detail__item.right .detail__contents {
  order: 1;
}
.home .detail__item.right .detail__image {
  margin: 0 12px 0 -24px;
}
.home .detail__inner {
  display: flex;
  flex-direction: column;
  padding-left: 0px;
  gap: 24px;
}
.home .detail__contents {
  text-align: left;
  flex-shrink: 0;
  font-size: 1.4rem;
  line-height: 2;
  order: 1;
  padding-left: 12px;
}
.home .detail__logo {
  text-align: center;
  margin-top: 32px;
}
.home .detail__logo img {
  width: 100px;
}
.home .detail__image {
  margin: 0 -24px 0 12px;
  flex-grow: 1;
}
.home .detail__attention {
  text-align: left;
  margin-top: 8px;
  font-weight: bold;
  font-size: 1rem;
  padding-left: 16px;
}
@media screen and (min-width: 1024px) {
  .home .detail h2 {
    display: none;
  }
  .home .detail__item {
    padding: 80px 0;
    margin: 0;
  }
  .home .detail__item h3 {
    display: flex;
    font-size: 2.7rem;
    letter-spacing: 0.2em;
    line-height: 2;
    margin-bottom: 56px;
    text-align: left;
  }
  .home .detail__item h3 span {
    font-size: 10rem;
    transform: translateY(-0.3em);
    line-height: 1;
    font-weight: normal;
  }
  .home .detail__item.right {
    margin: 0;
  }
  .home .detail__item.right h3 {
    justify-content: flex-end;
  }
  .home .detail__item.right .detail__inner {
    padding-left: 0;
  }
  .home .detail__item.right .detail__contents {
    order: 1;
  }
  .home .detail__item.right .detail__image {
    margin: 0;
  }
  .home .detail__inner {
    display: flex;
    padding-left: 40px;
    flex-direction: row;
    gap: 48px;
  }
  .home .detail__contents {
    text-align: left;
    flex-shrink: 0;
    font-size: 1.7rem;
    line-height: 2;
    order: 0;
    padding-left: 0;
    letter-spacing: 0;
  }
  .home .detail__logo {
    text-align: center;
    margin-top: 56px;
  }
  .home .detail__logo img {
    width: 240px;
  }
  .home .detail__image {
    margin: 0;
    flex-grow: 1;
  }
  .home .detail__attention {
    text-align: left;
    margin-top: 8px;
    font-weight: bold;
    font-size: 1.2rem;
    padding-left: 0;
  }
}
.home .navi h2 {
  display: none;
}
.home .navi__item {
  display: flex;
  flex-wrap: wrap;
}
.home .navi__contents {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: url(../img/top/navi_bg@2x.webp) no-repeat center center/cover;
  flex-basis: 100%;
  padding: 12px 0 48px 0;
  color: white;
  text-align: center;
  order: 1;
}
.home .navi__heading {
  margin-bottom: 32px;
}
.home .navi__heading p {
  font-size: 2rem;
  margin-bottom: 8px;
  color: #CABB89;
  letter-spacing: 0.1em;
}
.home .navi__heading h3 {
  font-size: 1.4rem;
  letter-spacing: 0.2em;
}
.home .navi__button {
  padding: 5px 50px 5px 20px;
  color: white;
  font-size: 1.4rem;
  font-weight: bold;
  background: #b09c53 url(../img/top/navi_arrow.svg) no-repeat right 10px center/auto 10px;
}
.home .navi__button:link, .home .navi__button:visited {
  color: white;
}
.home .navi__button.disabled {
  padding: 5px 20px;
  background: #b09c53;
}
.home .navi__button.disabled:hover {
  opacity: 1;
}
.home .navi__image {
  position: relative;
  flex-basis: 100%;
  height: 64vw;
  max-height: 400px;
}
.home .navi__image img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
.home .navi__attention {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 8px;
  width: 100%;
  font-size: 1rem;
  color: white;
  text-shadow: 0 0 3px black;
}
.home .navi__attention.right {
  text-align: right;
}
.home .navi__attention.back {
  color: black;
  text-shadow: none;
}
.home .navi__attention.stroke {
  text-shadow: 1px 1px 0 black, -1px -1px 0 black, -1px 1px 0 black, 1px -1px 0 black, 0px 1px 0 black, -1px 0 black, -1px 0 0 black, 1px 0 0 black;
}
@media screen and (min-width: 1024px) {
  .home .navi h2 {
    display: none;
  }
  .home .navi__item {
    height: 33vw;
    max-height: 512px;
    display: flex;
    flex-wrap: nowrap;
  }
  .home .navi__item.right .navi__contents {
    order: 1;
  }
  .home .navi__contents {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    background: url(../img/top/navi_bg@2x.webp) no-repeat center center/cover;
    flex-basis: 50%;
    padding: 50px;
    color: white;
    text-align: center;
    order: 0;
  }
  .home .navi__heading {
    margin-bottom: 40px;
  }
  .home .navi__heading p {
    font-size: 3.6rem;
    margin-bottom: 16px;
    color: #CABB89;
    letter-spacing: 0.1em;
  }
  .home .navi__heading h3 {
    font-size: 2.2rem;
    letter-spacing: 0.2em;
  }
  .home .navi__button {
    padding: 5px 50px 5px 20px;
    color: white;
    font-size: 1.4rem;
    font-weight: bold;
    background: #b09c53 url(../img/top/navi_arrow.svg) no-repeat right 10px center/auto 10px;
  }
  .home .navi__button:link, .home .navi__button:visited {
    color: white;
  }
  .home .navi__button.disabled {
    padding: 5px 20px;
    background: #b09c53;
  }
  .home .navi__button.disabled:hover {
    opacity: 1;
  }
  .home .navi__image {
    position: relative;
    flex-basis: 50%;
    height: auto;
    max-height: none;
  }
  .home .navi__image img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center center;
       object-position: center center;
  }
  .home .navi__attention {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 8px 16px;
    width: 100%;
    font-size: 1.2rem;
    color: white;
  }
}

.location .page-heading {
  background: url(../img/location/header_bg@2x.webp) no-repeat center center/cover;
  padding: 0vw 0 10vw 0;
  color: #614c3c;
}
.location .page-heading h1 {
  font-size: 2.4rem;
  letter-spacing: 0.2em;
}
.location .page-heading p {
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}
.location .page-heading__attention {
  position: absolute;
  bottom: 8px;
  left: 12px;
  font-size: 1rem !important;
  color: white;
  letter-spacing: 0 !important;
  text-shadow: 0 0 10px black;
}
@media screen and (min-width: 1024px) {
  .location .page-heading {
    background: url(../img/location/header_bg@2x.webp) no-repeat center center/cover;
    padding: 3vw 0 10vw 0;
    color: #614c3c;
  }
  .location .page-heading h1 {
    font-size: 3rem;
    margin-bottom: 16px;
    letter-spacing: 0.2em;
  }
  .location .page-heading p {
    font-size: 3.7rem;
    letter-spacing: 0.2em;
  }
  .location .page-heading__attention {
    position: absolute;
    bottom: 8px;
    left: 24px;
    font-size: 1.2rem !important;
    color: white;
    letter-spacing: 0 !important;
  }
}
.location .loc {
  background: #f5f2e9;
}
@media screen and (max-width: 1023px) {
  .location .loc .l-container {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
  }
}
.location .loc__heading {
  margin-bottom: 8px;
}
.location .loc__heading h2 {
  font-size: 1.8rem;
  margin-bottom: 16px;
  letter-spacing: 0.1em;
  font-weight: normal;
}
.location .loc__heading p {
  font-size: 1.4rem;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.location .loc__images {
  overflow-x: scroll;
  overflow-y: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.location .loc__images::-webkit-scrollbar {
  display: none;
}
.location .loc__images img {
  width: 640px;
}
.location .loc__slide-notice img {
  max-width: 400px;
}
.location .loc__facilities {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 640px;
  margin: 0 auto;
  padding: 0 24px 48px 24px;
}
.location .loc__facility {
  flex-basis: calc(50% - 4px);
}
.location .loc__facility figure {
  padding: 0;
  margin: 0;
}
.location .loc__facility figcaption {
  text-align: left;
  font-size: 1.2rem;
  margin: 4px 0;
}
.location .loc__facility figcaption span {
  font-size: 1rem;
}
@media screen and (min-width: 640px) {
  .location .loc__slide-notice {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .location .loc {
    background: #f5f2e9;
  }
  .location .loc__heading {
    margin-bottom: 24px;
  }
  .location .loc__heading h2 {
    font-size: 2.8rem;
    margin-bottom: 16px;
    letter-spacing: 0.1em;
    font-weight: normal;
  }
  .location .loc__heading p {
    font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.1em;
  }
  .location .loc__images {
    margin: 0;
  }
  .location .loc__images img {
    width: 100%;
  }
}
.location .life-info {
  padding: 0 24px;
  background: white;
}
.location .life-info__heading-sp {
  text-align: center;
  padding-top: 24px;
  max-width: 640px;
  margin: 0 auto;
}
.location .life-info__heading-sp h2 {
  text-align: center;
  margin-bottom: 24px;
  letter-spacing: 0.1em;
  font-weight: 600;
  font-size: 1.6rem;
}
.location .life-info__gmap {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  height: 120vw;
  max-height: 640px;
}
.location .life-info__gmap iframe {
  position: absolute;
  top: -70px;
  left: 0;
  width: 100%;
  height: calc(100% + 70px);
}
.location .life-info__contents {
  padding: 24px 0;
  max-width: 640px;
  margin: 0 auto;
}
.location .life-info__contents h2 {
  text-align: center;
  margin-bottom: 24px;
  letter-spacing: 0.1em;
  font-weight: 600;
  font-size: 1.6rem;
}
.location .life-info__navi {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 10px;
       column-gap: 10px;
  row-gap: 8px;
  margin-bottom: 16px;
}
.location .life-info__navi-item {
  text-align: center;
  flex-basis: calc(50% - 5px);
}
.location .life-info__navi-item a {
  display: block;
  padding: 6px 0;
  border: solid 1px #143473;
  font-size: 1.3rem;
  color: #143473;
}
.location .life-info__navi-item a:link, .location .life-info__navi-item a:visited {
  color: #143473;
}
.location .life-info__navi-item a.active {
  background: #143473;
  color: white;
}
.location .life-info__navi-item a:hover {
  background: #143473;
  color: white;
  opacity: 1;
}
.location .life-info__items {
  margin-bottom: 40px;
}
.location .life-info__item {
  color: #231815;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: clamp(14px, 1.5vw, 2rem);
  margin-bottom: 8px;
}
.location .life-info__name {
  display: flex;
}
.location .life-info__name span {
  flex-shrink: 0;
  border-radius: 50%;
  color: white;
  width: 1.5em;
  height: 1.5em;
  background: #143473;
  display: inline-block;
  text-align: center;
  font-size: 1.2rem;
  margin-right: 8px;
  margin-top: 4px;
}
.location .life-info__arrival {
  flex-shrink: 0;
}
.location .life-info__arrival .means {
  display: inline-block;
  width: 2em;
}
.location .life-info__arrival .min {
  display: inline-block;
  width: 1.5em;
  text-align: right;
}
.location .life-info__arrival .distance {
  display: inline-block;
  width: 3em;
  text-align: right;
}
.location .life-info__images {
  color: #231815;
  max-width: 320px;
  margin: 0 auto;
}
.location .life-info__image {
  flex-basis: calc(33.3% - 6px);
  margin-bottom: 16px;
}
.location .life-info__image figure {
  padding: 0;
  margin: 0;
}
.location .life-info__image figcaption {
  text-align: left;
  font-size: 1.2rem;
  margin: 4px 0;
}
@media screen and (min-width: 640px) {
  .location .life-info__images {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    color: #231815;
    max-width: none;
  }
  .location .life-info__image {
    flex-basis: calc(33.3% - 6px);
    margin-bottom: 0;
  }
  .location .life-info__image figure {
    padding: 0;
    margin: 0;
  }
  .location .life-info__image figcaption {
    text-align: left;
    font-size: 1rem;
    margin: 4px 0;
  }
}
@media screen and (min-width: 1024px) {
  .location .life-info {
    background: white;
    padding: 0;
  }
  .location .life-info__inner {
    display: flex;
  }
  .location .life-info__gmap {
    flex-basis: 50%;
    position: relative;
    overflow: hidden;
    height: auto;
    max-width: none;
    max-height: none;
    margin: 0;
  }
  .location .life-info__gmap iframe {
    position: absolute;
    top: -70px;
    left: 0;
    width: 100%;
    height: calc(100% + 70px);
  }
  .location .life-info__contents {
    flex-basis: 50%;
    padding: 48px 56px;
    max-width: 720px;
    margin: 0 auto;
  }
  .location .life-info__contents h2 {
    text-align: center;
    margin-bottom: 48px;
    letter-spacing: 0.1em;
    font-weight: 600;
    font-size: 2.3rem;
  }
  .location .life-info__navi {
    display: flex;
    flex-wrap: wrap;
    -moz-column-gap: 20px;
         column-gap: 20px;
    row-gap: 16px;
    margin-bottom: 24px;
  }
  .location .life-info__navi-item {
    text-align: center;
    flex-basis: calc(50% - 10px);
  }
  .location .life-info__navi-item a {
    display: block;
    padding: 8px 0;
    border: solid 1px #143473;
    font-size: 1.8rem;
    color: #143473;
  }
  .location .life-info__navi-item a:link, .location .life-info__navi-item a:visited {
    color: #143473;
  }
  .location .life-info__navi-item a.active {
    background: #143473;
    color: white;
  }
  .location .life-info__navi-item a:hover {
    background: #143473;
    color: white;
    opacity: 1;
  }
  .location .life-info__items {
    margin-bottom: 40px;
  }
  .location .life-info__item {
    color: #231815;
    display: flex;
    justify-content: space-between;
    gap: 24px;
    font-size: clamp(14px, 1.5vw, 2rem);
    margin-bottom: 8px;
  }
  .location .life-info__name {
    display: flex;
  }
  .location .life-info__name span {
    flex-shrink: 0;
    border-radius: 50%;
    color: white;
    width: 1.5em;
    height: 1.5em;
    background: #143473;
    display: inline-block;
    text-align: center;
    font-size: 1.3rem;
    margin-right: 8px;
    margin-top: 4px;
  }
  .location .life-info__arrival {
    flex-shrink: 0;
  }
  .location .life-info__arrival .means {
    display: inline-block;
    width: 2em;
  }
  .location .life-info__arrival .min {
    display: inline-block;
    width: 1.5em;
    text-align: right;
  }
  .location .life-info__arrival .distance {
    display: inline-block;
    width: 3em;
    text-align: right;
  }
  .location .life-info__images {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    color: #231815;
  }
  .location .life-info__image {
    flex-basis: calc(33.3% - 10px);
  }
  .location .life-info__image figure {
    padding: 0;
    margin: 0;
  }
  .location .life-info__image figcaption {
    text-align: left;
    font-size: 1.2rem;
    margin: 4px 0;
  }
}
.location .access .l-container {
  max-width: 640px;
}
@media screen and (max-width: 1023px) {
  .location .access .l-container {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
  }
}
.location .access__heading {
  margin-bottom: 24px;
}
.location .access__heading h2 {
  font-size: 1.6rem;
  margin-bottom: 16px;
  letter-spacing: 0.1em;
}
.location .access__heading p {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.6;
}
.location .access__desc {
  margin-bottom: 16px;
  font-size: 1.4rem;
  line-height: 1.8;
}
.location .access__map {
  overflow-x: scroll;
  overflow-y: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
  margin-bottom: 32px;
}
.location .access__map::-webkit-scrollbar {
  display: none;
}
.location .access__map img {
  width: 590px;
}
.location .access__slide-notice img {
  max-width: 400px;
}
.location .access__inner {
  max-width: 640px;
  margin: 0 auto;
  padding: 0 24px;
}
.location .access__monorail {
  margin-bottom: 12px;
  display: flex;
  flex-wrap: wrap;
  background: white;
  padding: 12px;
}
.location .access__monorail-heading {
  flex-basis: 100%;
  padding: 4px 0 12px 0;
  font-size: 1.4rem;
  font-weight: bold;
}
.location .access__monorail-heading span {
  font-size: 1.8rem;
}
.location .access__monorail-image {
  flex-basis: 40%;
}
.location .access__monorail-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center top;
     object-position: center top;
}
.location .access__monorail-desc {
  flex-basis: 60%;
  padding: 0px 12px;
  text-align: left;
}
.location .access__traffic {
  display: flex;
  gap: 12px;
}
.location .access__traffic-airport {
  flex-basis: 54%;
}
.location .access__traffic-airport img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.location .access__traffic-station {
  flex-basis: 46%;
}
.location .access__traffic-station img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 640px) {
  .location .access__slide-notice {
    display: none;
  }
  .location .access__map img {
    width: 590px;
  }
}
@media screen and (min-width: 1024px) {
  .location .access .l-container {
    max-width: 810px;
  }
  .location .access__heading {
    margin-bottom: 32px;
  }
  .location .access__heading h2 {
    font-size: 2rem;
    margin-bottom: 24px;
    letter-spacing: 0.1em;
  }
  .location .access__heading p {
    font-size: 2.8rem;
    font-weight: bold;
    letter-spacing: 0.2em;
    line-height: 1.6;
  }
  .location .access__desc {
    margin-bottom: 48px;
    font-size: 1.8rem;
    line-height: 1.8;
  }
  .location .access__map {
    margin-bottom: 32px;
  }
  .location .access__map img {
    width: 100%;
  }
  .location .access__inner {
    max-width: none;
    padding: 0;
  }
  .location .access__monorail {
    margin-bottom: 32px;
    display: flex;
    align-items: center;
    background: white;
    border-radius: 20px;
    padding: 0;
  }
  .location .access__monorail-heading {
    flex-basis: 30%;
    padding: 20px;
    font-size: 1.6rem;
    font-weight: bold;
  }
  .location .access__monorail-heading span {
    font-size: 2rem;
  }
  .location .access__monorail-image {
    flex-basis: 30%;
  }
  .location .access__monorail-desc {
    flex-basis: 40%;
    padding: 20px;
    text-align: left;
  }
  .location .access__traffic {
    display: flex;
    gap: 16px;
  }
  .location .access__traffic-airport {
    flex-basis: 54%;
  }
  .location .access__traffic-airport img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .location .access__traffic-station {
    flex-basis: 46%;
  }
  .location .access__traffic-station img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.plan .page-heading {
  background: url(../img/plan/header_bg@2x.webp) no-repeat center center/cover;
  padding: 3vw 0 3vw 0;
  color: white;
  box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.5);
}
.plan .page-heading h1 {
  font-size: 2.4rem;
  margin-bottom: 8px;
  letter-spacing: 0.2em;
  text-shadow: 0px 0px 10px black;
}
.plan .page-heading p {
  font-size: 1.2rem;
  letter-spacing: 0.2em;
  font-weight: bold;
  text-shadow: 0px 0px 10px black;
}
@media screen and (min-width: 1024px) {
  .plan .page-heading {
    background: url(../img/plan/header_bg@2x.webp) no-repeat center center/cover;
    padding: 3vw 0 3vw 0;
    color: white;
    box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.5);
  }
  .plan .page-heading h1 {
    font-size: 2.9rem;
    margin-bottom: 48px;
    letter-spacing: 0.2em;
    text-shadow: 0px 0px 10px black;
  }
  .plan .page-heading p {
    font-size: 3.7rem;
    letter-spacing: 0.2em;
    font-weight: bold;
    text-shadow: 0px 0px 10px black;
  }
}
.plan .contents h2 {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-bottom: 24px;
  font-weight: bold;
}
.plan .contents__items {
  display: flex;
  justify-content: center;
  gap: 16px;
}
.plan .contents__item {
  border: solid 1px #231815;
  background: white;
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.2);
}
.plan .contents__item-heading {
  background: #373c4f;
  color: white;
  padding: 8px;
}
.plan .contents__item h3 {
  font-size: 3.2rem;
  font-weight: 400;
  border-bottom: solid 1px #CABB89;
}
.plan .contents__item h3 span {
  margin-left: 5px;
  font-size: 1.4rem;
}
.plan .contents__item-spec {
  font-size: 1.2rem;
  color: #c7b8aa;
  padding: 8px 0;
  line-height: 1.2;
  border-bottom: solid 1px #CABB89;
}
.plan .contents__item-spec span {
  font-size: 2.7rem;
}
.plan .contents__item-size {
  font-size: 1.8rem;
}
.plan .contents__item-size span {
  font-size: 3.2rem;
}
.plan .contents__item-note {
  font-size: 1rem;
}
.plan .contents__item-button {
  display: block;
  max-width: 180px;
  text-align: center;
  background: url(../img/common/arrow_bl.svg) no-repeat right 20px center/8px auto;
  color: #373c4f;
  padding: 8px 30px;
  font-weight: bold;
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .plan .contents h2 {
    font-size: 3.2rem;
    letter-spacing: 0.1em;
    margin-bottom: 56px;
    font-weight: bold;
  }
  .plan .contents__items {
    display: flex;
    justify-content: center;
    gap: 96px;
  }
  .plan .contents__item {
    border: solid 1px #231815;
    background: white;
    box-shadow: 20px 20px 20px rgba(0, 0, 0, 0.2);
  }
  .plan .contents__item-heading {
    background: #373c4f;
    color: white;
    padding: 20px;
  }
  .plan .contents__item h3 {
    font-size: 5.3rem;
    font-weight: 400;
    border: none;
  }
  .plan .contents__item h3 span {
    margin-left: 5px;
    font-size: 2rem;
  }
  .plan .contents__item-spec {
    font-size: 2.2rem;
    color: #c7b8aa;
    border: none;
    padding: 0;
    line-height: 1.4;
  }
  .plan .contents__item-spec span {
    font-size: 2.7rem;
  }
  .plan .contents__item-size {
    font-size: 2.1rem;
  }
  .plan .contents__item-size span {
    font-size: 2.8rem;
  }
  .plan .contents__item-note {
    font-size: 1rem;
  }
  .plan .contents__item-image {
    padding: 48px 0;
    border-bottom: solid 5px #727171;
    margin-bottom: 48px;
  }
  .plan .contents__item-button {
    margin: 24px auto 0 auto;
    display: block;
    max-width: 180px;
    text-align: center;
    background: #373c4f url(../img/common/arrow.svg) no-repeat right 20px center/10px auto;
    color: white;
    padding: 4px 30px;
    font-weight: bold;
  }
}

.plan-detail {
  padding: 16px 24px 32px 24px;
  text-align: center;
  max-width: 904px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .plan-detail {
    padding: 32px 48px 72px 48px;
    text-align: center;
    max-width: 904px;
    margin: 0 auto;
  }
}
.plan-detail .plan__inner {
  display: flex;
  gap: 24px;
}
.plan-detail .plan__floor {
  margin-top: 20px;
  flex-basis: 156px;
}
.plan-detail .plan__heading {
  text-align: left;
}
.plan-detail .plan__heading h1 {
  font-weight: normal;
  font-size: 2rem;
  margin-bottom: 0px;
}
.plan-detail .plan__heading h1 span {
  margin-right: 4px;
  font-size: 5.6rem;
}
.plan-detail .plan__heading p {
  font-size: clamp(1.2rem, 4vw, 3.2rem);
  border-top: solid 1px #907647;
  border-bottom: solid 1px #907647;
  font-weight: normal;
}
.plan-detail .plan__heading p span {
  font-size: clamp(2.8rem, 6vw, 6rem);
}
.plan-detail .plan__spec {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 12px;
       column-gap: 12px;
  font-size: 2rem;
  margin-bottom: 32px;
  align-items: baseline;
}
.plan-detail .plan__spec-size {
  display: flex;
  gap: 8px;
  align-items: last baseline;
}
.plan-detail .plan__spec-size dt {
  font-weight: bold;
  font-size: 1.6rem;
}
.plan-detail .plan__spec-size dd span {
  font-size: 2rem;
}
.plan-detail .plan__spec-size dd .large {
  font-size: 4rem;
}
.plan-detail .plan__spec-items {
  text-align: left;
}
.plan-detail .plan__spec-item {
  text-align: left;
  font-size: 1.4rem;
}
.plan-detail .plan__spec-note {
  flex-basis: 100%;
  font-size: 1rem;
  text-align: left;
  text-indent: -1em;
  padding-left: 1em;
}
.plan-detail .plan__image {
  margin-bottom: 32px;
  text-align: center;
}
.plan-detail .plan__image img {
  max-width: 800px;
}
.plan-detail .plan__close a {
  background: url(../img/common/common_blue_bg.webp) no-repeat center center/cover;
  display: inline-block;
  padding: 4px 20px;
  min-width: 180px;
  font-size: 1.6rem;
  color: white;
}
.plan-detail .plan__close a:link, .plan-detail .plan__close a:visited {
  color: white;
}
@media screen and (min-width: 768px) {
  .plan-detail .plan__inner {
    display: flex;
    gap: 56px;
  }
  .plan-detail .plan__floor {
    margin-top: 24px;
    flex-basis: 168px;
  }
  .plan-detail .plan__heading {
    text-align: left;
  }
  .plan-detail .plan__heading h1 {
    font-weight: normal;
    font-size: 3.9rem;
    margin-bottom: 16px;
  }
  .plan-detail .plan__heading h1 span {
    margin-right: 8px;
    font-size: 7.3rem;
  }
  .plan-detail .plan__heading p {
    font-size: clamp(1.6rem, 4vw, 3.9rem);
    border-top: solid 1px #907647;
    border-bottom: solid 1px #907647;
    font-weight: normal;
  }
  .plan-detail .plan__heading p span {
    font-size: clamp(3rem, 6vw, 6rem);
  }
  .plan-detail .plan__spec {
    display: flex;
    flex-wrap: wrap;
    -moz-column-gap: 32px;
         column-gap: 32px;
    font-size: 2.1rem;
    margin-bottom: 64px;
    align-items: baseline;
  }
  .plan-detail .plan__spec-size {
    display: flex;
    gap: 16px;
    align-items: last baseline;
  }
  .plan-detail .plan__spec-size dt {
    font-weight: bold;
    font-size: 2.1rem;
  }
  .plan-detail .plan__spec-size dd span {
    font-size: 3rem;
  }
  .plan-detail .plan__spec-size dd .large {
    font-size: 5.6rem;
  }
  .plan-detail .plan__spec-items {
    text-align: left;
  }
  .plan-detail .plan__spec-item {
    text-align: left;
    font-size: 1.8rem;
  }
  .plan-detail .plan__spec-note {
    flex-basis: 100%;
    font-size: 1.4rem;
    text-align: left;
    text-indent: -1em;
    padding-left: 1em;
  }
  .plan-detail .plan__image {
    margin-bottom: 56px;
    text-align: center;
  }
  .plan-detail .plan__image img {
    max-width: 800px;
  }
  .plan-detail .plan__close a {
    background: url(../img/common/common_blue_bg.webp) no-repeat center center/cover;
    display: inline-block;
    padding: 8px 20px;
    min-width: 180px;
    font-size: 2rem;
    color: white;
  }
  .plan-detail .plan__close a:link, .plan-detail .plan__close a:visited {
    color: white;
  }
}

.outline .contents .l-container {
  padding-top: 0;
}

@media screen and (max-width: 1023px) {
  #property_block {
    color: #333333;
  }
  #property_block table {
    text-align: left;
    color: #333333;
  }
  #property_block table tbody {
    width: 100%;
    display: table-cell;
  }
  #property_block table tr {
    width: 100%;
    display: table;
  }
  #property_block table th,
  #property_block table td {
    padding: 12px;
    display: block;
  }
  #property_block table th {
    width: 100%;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    background: #f4f4f4;
    font-weight: bold;
  }
  #property_block table td {
    width: auto;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    background: white;
  }
  #property_block table .info_terms td {
    background: none;
    padding-left: 0;
    padding-bottom: 24px;
  }
}
@media screen and (min-width: 1024px) {
  #property_block {
    color: #333333;
  }
  #property_block table {
    text-align: left;
    color: #333333;
  }
  #property_block table th,
  #property_block table td {
    padding: 16px;
  }
  #property_block table th {
    width: 30%;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    background: #f4f4f4;
  }
  #property_block table td {
    width: 70%;
    border-bottom: 1px solid #ddd;
    border-right: 1px solid #ddd;
    background: white;
  }
  #property_block table .info_terms td {
    background: none;
    padding-left: 0;
    padding-bottom: 24px;
  }
}

.map .contents .l-container {
  padding-top: 0;
}
.map .contents__map {
  margin-bottom: 24px;
}
.map .contents__map img {
  max-width: 808px;
}
.map .contents__address {
  margin-bottom: 32px;
  font-size: 1.4rem;
  font-weight: bold;
}
.map .contents__button a {
  font-size: 1.4rem;
  display: block;
  max-width: 188px;
  margin: 0 auto;
  color: white;
  font-weight: bold;
  background: #1f3844;
  padding: 8px 20px;
  margin-bottom: 8px;
}
.map .contents__button a:link, .map .contents__button a:visited {
  color: white;
}
@media screen and (min-width: 1024px) {
  .map .contents .l-container {
    padding-top: 0;
  }
  .map .contents__map {
    margin-bottom: 24px;
  }
  .map .contents__map img {
    max-width: 808px;
  }
  .map .contents__address {
    margin-bottom: 32px;
    font-size: 2rem;
    font-weight: bold;
  }
  .map .contents__button a {
    font-size: 2.3rem;
    display: block;
    max-width: 188px;
    margin: 0 auto;
    color: white;
    font-weight: bold;
    background: #1f3844;
    padding: 6px 20px;
    margin-bottom: 16px;
  }
  .map .contents__button a:link, .map .contents__button a:visited {
    color: white;
  }
}

.login .block-login-01 {
  position: relative;
}
.login .block-login-01 .l-container {
  padding-top: 32px;
}
.login .block-login-01 p {
  line-height: 1.8;
  margin-bottom: 48px;
}
.login .block-login-01 form input[type=text] {
  padding: 1em;
  border-radius: 0px;
  border: 1px solid #ddd;
  width: 16em;
  line-height: 1;
  font-size: 1.4rem;
}
.login .block-login-01 form button[type=submit] {
  padding: 1em;
  border-radius: 0px;
  border: 1px solid #b09c53;
  background: #b09c53;
  line-height: 1;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #fff;
  font-size: 1.5rem;
}
.login .block-login-02 {
  text-align: center;
  position: relative;
  background: #fafafa url(../img/login/bg_03.webp) repeat 50% 0/cover;
  background-blend-mode: multiply;
}
.login .block-login-02 h3 {
  margin-bottom: 1em;
  text-align: center;
  font-size: 150%;
  line-height: 1.25;
}
.login .block-login-02 h3::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  border-width: 1em 2em 0;
  border-color: #f8f6f1 transparent transparent;
  border-style: solid;
}
.login .block-login-02 p {
  line-height: 1.8;
  margin-bottom: 48px;
}
.login .block-login-02 .btn {
  margin: 1.5em auto 0;
  padding: 1.5em;
  max-width: 16em;
  border-top: 1px solid #1f3844;
  border-bottom: 1px solid #1f3844;
  background: #1f3844;
  color: #fff;
}

.request .contents .l-container {
  padding-top: 32px;
  max-width: 1024px;
}
.request .contents .satori__custom_form {
  color: #907647;
  background: none;
  font-size: 1.4rem;
}
.request .contents .satori__custom_form .satori__input_group {
  text-align: left;
}
.request .contents .satori__custom_form .satori__input_group input[type=text],
.request .contents .satori__custom_form .satori__input_group input[type=tel],
.request .contents .satori__custom_form .satori__input_group input[type=email],
.request .contents .satori__custom_form .satori__input_group textarea {
  width: 100%;
  border: solid 1.5px #dddddd;
  border-radius: 5px;
  padding: 8px;
  box-sizing: border-box;
  box-shadow: none;
  background: rgba(255, 255, 255, 0.7);
}
.request .contents .satori__custom_form .satori__input_group input[type=text]:focus,
.request .contents .satori__custom_form .satori__input_group input[type=tel]:focus,
.request .contents .satori__custom_form .satori__input_group input[type=email]:focus,
.request .contents .satori__custom_form .satori__input_group textarea:focus {
  border: solid 1.5px #CABB89;
}
.request .contents .satori__custom_form .satori__input_group input[type=checkbox]:checked + label,
.request .contents .satori__custom_form .satori__input_group input[type=radio]:checked + label {
  color: #907647;
}
.request .contents .satori__custom_form a,
.request .contents .satori__custom_form a:visited {
  color: #907647;
  font-weight: bold;
  text-decoration: underline;
}
.request .contents .satori__custom_form .satori__btn {
  background: #1f3844;
  color: white;
  padding: 16px 20px;
  min-width: 264px;
}
.request .contents .satori__require {
  background: #94252A;
  color: white;
  font-size: 1.2rem;
  padding: 5px 6px;
}
.request .contents .satori__not_require {
  background: #CABB89;
  color: white;
  font-size: 1.2rem;
  padding: 5px 6px;
}
.request .contents .sunpremier {
  margin-top: 40px;
}
.request .contents .sunpremier p {
  color: #666;
  line-height: 1.8;
}
.request .contents .sunpremier small {
  display: block;
  margin-top: 16px;
}
.request .contents .sunpremier em {
  display: block;
  border: solid 1px #dcdcdc;
  padding: 8px 24px;
  max-width: 264px;
  margin: 8px auto 0 auto;
}
.request .contents .sunpremier a {
  text-decoration: underline;
}
@media screen and (min-width: 1024px) {
  .request .contents .l-container {
    padding-top: 32px;
    max-width: 1024px;
  }
  .request .contents .satori__custom_form {
    color: #907647;
    background: none;
    font-size: 1.6rem;
  }
  .request .contents .satori__custom_form .satori__input_group {
    text-align: left;
  }
  .request .contents .satori__custom_form .satori__input_group input[type=text],
  .request .contents .satori__custom_form .satori__input_group input[type=tel],
  .request .contents .satori__custom_form .satori__input_group input[type=email],
  .request .contents .satori__custom_form .satori__input_group textarea {
    width: 100%;
    border: solid 1.5px #dddddd;
    border-radius: 5px;
    padding: 10px;
    box-sizing: border-box;
    box-shadow: none;
    background: rgba(255, 255, 255, 0.7);
  }
  .request .contents .satori__custom_form .satori__input_group input[type=text]:focus,
  .request .contents .satori__custom_form .satori__input_group input[type=tel]:focus,
  .request .contents .satori__custom_form .satori__input_group input[type=email]:focus,
  .request .contents .satori__custom_form .satori__input_group textarea:focus {
    border: solid 1.5px #CABB89;
  }
  .request .contents .satori__custom_form .satori__input_group input[type=checkbox]:checked + label,
  .request .contents .satori__custom_form .satori__input_group input[type=radio]:checked + label {
    color: #907647;
  }
  .request .contents .satori__custom_form a,
  .request .contents .satori__custom_form a:visited {
    color: #907647;
    font-weight: bold;
    text-decoration: underline;
  }
  .request .contents .satori__custom_form .satori__btn {
    background: #1f3844;
    color: white;
    padding: 16px 20px;
    min-width: 264px;
  }
  .request .contents .satori__require {
    background: #94252A;
    color: white;
    font-size: 1.2rem;
    padding: 5px 6px;
  }
  .request .contents .satori__not_require {
    background: #CABB89;
    color: white;
    font-size: 1.2rem;
    padding: 5px 6px;
  }
  .request .contents .sunpremier {
    margin-top: 40px;
  }
  .request .contents .sunpremier p {
    color: #666;
    line-height: 1.8;
  }
  .request .contents .sunpremier small {
    display: block;
    margin-top: 16px;
  }
  .request .contents .sunpremier em {
    display: block;
    border: solid 1px #dcdcdc;
    padding: 8px 24px;
    max-width: 264px;
    margin: 8px auto 0 auto;
  }
  .request .contents .sunpremier a {
    text-decoration: underline;
  }
}

.requestend .message .l-container {
  padding-top: 24px;
  letter-spacing: 0.1em;
}
.requestend .message h2 {
  font-size: 1.8rem;
  margin-bottom: 16px;
  letter-spacing: 0.2em;
}
.requestend .message__thanks {
  font-size: 3.8rem;
  letter-spacing: 0.15em;
  font-weight: 600;
  margin-bottom: 24px;
}
.requestend .message__text {
  margin-bottom: 24px;
  line-height: 1.8;
}
.requestend .message__note {
  text-align: left;
  display: inline-block;
  font-size: 1.2rem;
}
@media screen and (min-width: 1024px) {
  .requestend .message .l-container {
    padding-top: 32px;
    max-width: 1024px;
    letter-spacing: 0.1em;
  }
  .requestend .message h2 {
    font-size: 2.4rem;
    margin-bottom: 24px;
    letter-spacing: 0.2em;
  }
  .requestend .message__thanks {
    font-size: 4.8rem;
    letter-spacing: 0.15em;
    font-weight: 600;
    margin-bottom: 32px;
  }
  .requestend .message__text {
    margin-bottom: 24px;
    line-height: 1.8;
  }
  .requestend .message__note {
    font-size: 1.4rem;
  }
}
.requestend .sunpremier .l-container {
  border-top: solid 1px #CABB89;
  color: rgb(45, 54, 109);
}
.requestend .sunpremier .l-container h4 {
  margin-bottom: 24px;
}
.requestend .sunpremier .l-container h4 img {
  max-width: 320px;
}
.requestend .sunpremier .l-container p {
  font-weight: bold;
  line-height: 1.8;
  margin-bottom: 24px;
}
.requestend .sunpremier .l-container .cv {
  border-radius: 10px;
  overflow: hidden;
  max-width: 760px;
  margin: 0 auto 32px auto;
}
.requestend .sunpremier .l-container .pmark {
  text-align: left;
}
.requestend .sunpremier .l-container .pmark a {
  margin: 1.5em auto 0;
  max-width: 27em;
  display: flex;
  gap: 1em;
  align-items: center;
  font-size: 1.1rem;
  color: #333;
  line-height: 1.6;
}
.requestend .sunpremier .l-container .pmark a img {
  width: 4em;
}
@media screen and (min-width: 1024px) {
  .requestend .sunpremier .l-container {
    border-top: solid 1px #CABB89;
    color: rgb(45, 54, 109);
  }
  .requestend .sunpremier .l-container h4 {
    margin-bottom: 24px;
  }
  .requestend .sunpremier .l-container h4 img {
    max-width: 400px;
  }
  .requestend .sunpremier .l-container p {
    font-weight: bold;
    line-height: 1.8;
    margin-bottom: 24px;
  }
  .requestend .sunpremier .l-container .cv {
    border-radius: 10px;
    overflow: hidden;
    max-width: 760px;
    margin: 0 auto 32px auto;
  }
  .requestend .sunpremier .l-container .pmark {
    text-align: left;
  }
  .requestend .sunpremier .l-container .pmark a {
    margin: 1.5em auto 0;
    max-width: 27em;
    display: flex;
    gap: 1em;
    justify-content: space-between;
    align-items: center;
    font-size: 1.4rem;
    color: #333;
    line-height: 1.6;
  }
  .requestend .sunpremier .l-container .pmark a img {
    width: 6em;
  }
}

.u-font-ryumin, body, .plan .contents__item-button, .login .block-login-01 form input[type=text], .login .block-login-01 form button[type=submit] {
  font-family: "a-otf-ryumin-pr6n", serif;
  font-weight: 400;
  font-style: normal;
}

.u-font-minion, .c-menu-button:after, .menu__item a span, .menu__new, .p-page-heading h1, .p-cta__heading p, .p-topics__block h2, .ttl-style-01, .home .concept__heading h2, .home .navi__heading p, .location .page-heading h1, .plan .page-heading h1, .plan-detail .plan__heading, .plan-detail .plan__spec-size dd span, .requestend .message__thanks {
  font-family: minion-pro, serif;
  font-weight: 400;
  font-style: normal;
}

.u-font-gothic, .footer__notice, .footer__company, .location .life-info__heading-sp, .location .life-info__contents, .location .access__heading h2 {
  font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.u-font-times, .plan .contents__item {
  font-family: "times-new-roman", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.u-mt0 {
  margin-top: 0px;
}

.u-mt10 {
  margin-top: 10px;
}

.u-mt20 {
  margin-top: 20px;
}

.u-mt30 {
  margin-top: 30px;
}

.u-mt40 {
  margin-top: 40px;
}

.u-mt50 {
  margin-top: 50px;
}

.u-mt60 {
  margin-top: 60px;
}

.u-mt70 {
  margin-top: 70px;
}

.u-mt80 {
  margin-top: 80px;
}

.u-mt90 {
  margin-top: 90px;
}

.u-mt100 {
  margin-top: 100px;
}

@media screen and (max-width: 767px) {
  .u-sm-mt0 {
    margin-top: 0px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt10 {
    margin-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt20 {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt30 {
    margin-top: 30px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt40 {
    margin-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt50 {
    margin-top: 50px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt60 {
    margin-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt70 {
    margin-top: 70px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt80 {
    margin-top: 80px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt90 {
    margin-top: 90px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mt100 {
    margin-top: 100px;
  }
}

.u-mb0 {
  margin-bottom: 0px;
}

.u-mb10 {
  margin-bottom: 10px;
}

.u-mb20 {
  margin-bottom: 20px;
}

.u-mb30 {
  margin-bottom: 30px;
}

.u-mb40 {
  margin-bottom: 40px;
}

.u-mb50 {
  margin-bottom: 50px;
}

.u-mb60 {
  margin-bottom: 60px;
}

.u-mb70 {
  margin-bottom: 70px;
}

.u-mb80 {
  margin-bottom: 80px;
}

.u-mb90 {
  margin-bottom: 90px;
}

@media screen and (max-width: 767px) {
  .u-sm-mb0 {
    margin-bottom: 0px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb10 {
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb20 {
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb30 {
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb40 {
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb50 {
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb60 {
    margin-bottom: 60px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb70 {
    margin-bottom: 70px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb80 {
    margin-bottom: 80px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb90 {
    margin-bottom: 90px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-mb100 {
    margin-bottom: 100px;
  }
}

.u-pt0 {
  padding-top: 0px;
}

.u-pt10 {
  padding-top: 10px;
}

.u-pt20 {
  padding-top: 20px;
}

.u-pt30 {
  padding-top: 30px;
}

.u-pt40 {
  padding-top: 40px;
}

.u-pt50 {
  padding-top: 50px;
}

.u-pt60 {
  padding-top: 60px;
}

.u-pt70 {
  padding-top: 70px;
}

.u-pt80 {
  padding-top: 80px;
}

.u-pt90 {
  padding-top: 90px;
}

@media screen and (max-width: 767px) {
  .u-sm-pt0 {
    padding-top: 0px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt10 {
    padding-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt20 {
    padding-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt30 {
    padding-top: 30px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt40 {
    padding-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt50 {
    padding-top: 50px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt60 {
    padding-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt70 {
    padding-top: 70px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt80 {
    padding-top: 80px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt90 {
    padding-top: 90px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pt100 {
    padding-top: 100px;
  }
}

.u-pb0 {
  padding-bottom: 0px;
}

.u-pb10 {
  padding-bottom: 10px;
}

.u-pb20 {
  padding-bottom: 20px;
}

.u-pb30 {
  padding-bottom: 30px;
}

.u-pb40 {
  padding-bottom: 40px;
}

.u-pb50 {
  padding-bottom: 50px;
}

.u-pb60 {
  padding-bottom: 60px;
}

.u-pb70 {
  padding-bottom: 70px;
}

.u-pb80 {
  padding-bottom: 80px;
}

.u-pb90 {
  padding-bottom: 90px;
}

@media screen and (max-width: 767px) {
  .u-sm-pb0 {
    padding-bottom: 0px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb10 {
    padding-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb20 {
    padding-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb30 {
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb40 {
    padding-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb50 {
    padding-bottom: 50px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb60 {
    padding-bottom: 60px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb70 {
    padding-bottom: 70px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb80 {
    padding-bottom: 80px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb90 {
    padding-bottom: 90px;
  }
}

@media screen and (max-width: 767px) {
  .u-sm-pb100 {
    padding-bottom: 100px;
  }
}

.u-text-primary {
  color: #231815;
}

.u-text-secondary {
  color: #4caf50;
}

.u-text-bold {
  font-weight: bold;
}

.u-text-small {
  font-size: 1rem;
}

.u-text-center {
  text-align: center;
}

.u-text-left {
  text-align: left;
}

.u-text-right {
  text-align: right;
}

.u-bold {
  font-weight: bold;
}

.u-bg-primary {
  background: #143473;
}

.u-bg-secondary {
  background: #4caf50;
}

.u-bg-tertiary {
  background: #ffc107;
}

.u-pos--relative {
  position: relative;
}
.u-pos--absolute {
  position: absolute;
}

.u-dn-sm {
  display: none !important;
}
@media screen and (min-width: 768px) {
  .u-dn-sm {
    display: inherit !important;
  }
}

.u-dn-lg {
  display: none !important;
}
@media screen and (max-width: 1023px) {
  .u-dn-lg {
    display: inherit !important;
  }
}

.u-dn-md {
  display: none !important;
}
@media screen and (min-width: 1024px) {
  .u-dn-md {
    display: inherit !important;
  }
}