@charset "utf-8";
/*=====================================
1.0 default
2.0 main
=====================================*/
/*--------------------------------------------------------------
1.0 default
--------------------------------------------------------------*/
:root {
    /* --main-color: #10234d;
    --secondary-color: rgba(16, 35, 77, .09);;
    --fv-text: #10234d;
    --fv-subtext: #10234d;
    --bg-text:rgba(16, 35, 77, .09);;
    */
    --text-color: #c5aa7f;
    --border-color: #b88c00;
}
body {
    margin: 0;
    font-size: clamp(0px,(100vw / 80), 16px);
    font-family: YakuHanJP,"Noto Serif JP","Noto Sans JP",sans-serif;
    font-weight: 400;
    line-height: 1.6;
    letter-spacing: .025em;
    color: var(--text-color);
    background-color: var(--background-color);
    -webkit-font-smoothing: antialiased;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  th {
    font-family: YakuHanJP,"Noto Serif JP","Noto Sans JP",sans-serif;
    font-weight: bold!important;
  }
  p {
    font-family: "Noto Sans JP",sans-serif;
  }
  * {
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    outline: none !important;
    list-style: none;
    text-decoration: none;
  }
  .is-sp {
    display: none;
  }
@media (max-width: 769px) {
  body {
    font-size: clamp(0px,(100vw / 25), 16px);
  }
  .is-pc {
    display: none;
   }
  .is-sp {
    display: block;
  }
}
/* 変数 */
:root {
    --checklist-bg-color: var(--main-color);
    --checklist-border-color: var(--main-color);
    --faq-q-color: var(--secondary-color);
    --faq-q-open-bg-color: var(--secondary-color);
    --faq-q-open-color: var(--main-color);
    --faq-toggle-bg-color: var(--main-color);
    --faq-a-bg-color: #f9f9f9;
    --cta-btn-bg-color: linear-gradient(90deg, #02C7FC 0%, #0166BF 100%);
    --cta-btn-color: #fff;
    --cta-border-color: #fff;
    --balloon-bg-color: var(--secondary-color);
    --voice-image-scroll-info-bg: var(--main-color);
    --voice-image-scroll-item-bg: var(--secondary-color);
    --voice-image-scroll-dot-active-bg : var(--main-color);
  }

/*--------------------------------------------------------------
2.0 main
--------------------------------------------------------------*/
.wrapper main article {
  background-color: var(--background-color);
}
.wrapper main article .mv {
  width: 100%;
}
.wrapper main article .mv img {
  display: block;
  width: 100%;
  object-fit: cover;
}
.wrapper main article .about {
  
}
.wrapper main article .about .top-image {
  width: 100%;
}
.wrapper main article .about .top-image img {
  display: block;
  width: 100%;
  object-fit: cover;
}
.wrapper main article .about .container {
  width: 92%;
  max-width: 1080px;
  margin: 0 auto;
}
.wrapper main article .about .container .row {
  display: flex;
  gap: 3em;
  margin: 2em 0 0 0;
}
.wrapper main article .about .container .row.info {

}
.wrapper main article .about .container .row figure {
  position: relative;
  margin: 0;
}
.wrapper main article .about .container .row figure::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  inset: 0;
  background: center / 100% 100% no-repeat url(../../../lp/assets/images/frame-rect.svg);
}
.wrapper main article .about .container .row figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: 1em .5em;
  border-radius: 3em;
}
.wrapper main article .about .container .row .column {
  width: 55em;
}
.wrapper main article .about .container .row .column .title {
  position: relative;
  font-size: 2em;
  margin: 1em 0 0 0;
  padding: 0 0 .5em 0;
  color: var(--text-color);
  text-align: center;
}
.wrapper main article .about .container .row .column .title::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: .03125em;
  background: var(--border-color);
  content: "";
}
.wrapper main article .about .container .row .column .text {
  margin: 1em 0 0 0;
  color: #c5aa7f;
}
.wrapper main article .about .container .row .column .text p {
  padding: 0;
}
.wrapper main article .about .container .gallery {
  display: flex;
  gap: .5em;
  justify-content: space-between;
  margin: 5em 0 0 0;
}
.wrapper main article .about .container .gallery.col-1 {
  margin: 2em 0 0 0;
}
.wrapper main article .about .container .gallery.col-1 figure {
  position: relative;
  display: block;
  flex: 1;
  width: 100%;
  max-width: auto;
  object-fit: cover;
  margin: 0;
}
.wrapper main article .about .container .gallery.col-1 figure img {
  display: block;
  width: 100%;
  object-fit: cover;
  padding: 0;
  border-radius: 0;
}
.wrapper main article .about .container .gallery.col-3 {
  margin: 2em 0 0 0;
}
.wrapper main article .about .container .gallery.col-3 figure {
  position: relative;
  display: block;
  flex: 1;
  width: 100%;
  max-width: calc(100% / 3 - 2em);
  object-fit: cover;
  margin: 0;
}
.wrapper main article .about .container .gallery.col-3 figure:before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  inset: 0;
  background: center / 100% 100% no-repeat url(../../../lp/assets/images/frame-sq.svg);
}
.wrapper main article .about .container .gallery.col-3 img {
  display: block;
  width: 100%;
  object-fit: cover;
  padding: .5em;
  border-radius: 2em;
}
.wrapper main article .about .container .gallery.col-4 {
  position: relative;
  margin: 3em 0 0 0;
  padding: 3em 0 0 0;
}
.wrapper main article .about .container .gallery.col-4::before,
.wrapper main article .about .container .gallery.col-4::after {
  position: absolute;
  background-color: var(--border-color);
  width: 25em;
  height: .03125em;
  top: 0;
  content: "";
}
.wrapper main article .about .container .gallery.col-4::before {
  left: 0;
}
.wrapper main article .about .container .gallery.col-4::after {
  right: 0;
}
.wrapper main article .about .container .gallery.col-4 figure {
  position: relative;
  display: block;
  flex: 1;
  width: 100%;
  max-width: calc(100% / 4 - 1em);
  object-fit: cover;
  margin: 0;
}
.wrapper main article .about .container .gallery.col-4 figure::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  inset: 0;
  background: center / 100% 100% no-repeat url(../../../lp/assets/images/frame-sq.svg);
}
.wrapper main article .about .container .gallery.col-4 figure img {
  display: block;
  width: 100%;
  object-fit: cover;
  border-radius: 1.5em;
}
@media (max-width: 769px) {
  .wrapper main article .about .container .row {
    flex-direction: column;
    gap: 0;
  }
  .wrapper main article .about .container .row figure {
    order: 2;
  }
  .wrapper main article .about .container .row .column {
    order: 1;
    width: 100%;
  }
  .wrapper main article .about .container .row .column .title {
    margin: 0;
    font-size: 1.5em;
  }
  .wrapper main article .about .container .gallery.col-3 figure {
    max-width: calc(100% / 3 - .5em);
  }
  .wrapper main article .about .container .gallery.col-3 img {
    padding: .25em;
    border-radius: .5em;
  }
  .wrapper main article .about .container .gallery.col-4 {
    flex-wrap: wrap;
    gap: .5em;
    justify-content: center;
  }
  .wrapper main article .about .container .gallery.col-4::before {
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
  }
  .wrapper main article .about .container .gallery.col-4::after {
    display: none;
  }
  .wrapper main article .about .container .gallery.col-4 figure {
    flex: auto;
    max-width: calc(100% / 4 - .5em);
  }
}
/*.split*/
.wrapper main article .split {
  position: relative;
  width: 100%;
  margin: 5em auto;
  padding: 0 7em;
}
.wrapper main article .split:before {
  position: absolute;
  top: 65%;
  transform: translateY(-50%);
  width: 6em;
  height: 6em;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  left: 4vw;
  background-image: url(../../../lp/assets/images/decor-l.svg);
  z-index: 1;
}
.wrapper main article .split::after {
  position: absolute;
  top: 65%;
  transform: translateY(-50%);
  width: 6em;
  height: 6em;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  right: 4vw;
  background-image: url(../../../lp/assets/images/decor-r.svg);
  z-index: 1;
}
.wrapper main article .split img {
  display: block;
  width: 100%;
}
@media (max-width: 769px) {
  .wrapper main article .split {
    margin: 2em auto;
    padding: 0 5em;
  }
  .wrapper main article .split:before {
    top: 100%;
    width: 4em;
    height: 4em;
  }
  .wrapper main article .split:after {
    top: 100%;
    width: 4em;
    height: 4em;
  }
}
/*.btn*/
.wrapper main article .btn {
  margin: 3em auto;
  width: 92%;
  max-width: 960px;
}
.wrapper main article .btn a {
  display: block;
}
.wrapper main article .btn img {
  display: block;
  width: 100%;
}
@media (max-width: 769px) {
  
}
/*.feature*/
.wrapper main article .feature {
  margin: 3em 0 5em;
}
.wrapper main article .feature .row {
  display: flex;
  justify-content: center;
  width: 92%;
  max-width: 1080px;
  margin: 0 auto;
  gap: 4em;
}
.wrapper main article .feature .row:not(:first-child) {
 margin: 4em auto 0;
}
.wrapper main article .feature .row .column {
  width: 27em;
  background-image: url(../../../lp/assets/images/feature_bg.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  text-align: center;
}
.wrapper main article .feature .row .column a {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 3em;
  height: 27em;
  color: #333;
}
.wrapper main article .feature .row .column a figure {
  width: 4em;
  margin: 0 auto;
}
.wrapper main article .feature .row .column a figure img {
  display: block;
  width: 100%;
}
.wrapper main article .feature .row .column a .num {
  position: relative;
  font-family: "Noto Serif JP",sans-serif;
  font-size: 2em;
  padding: 0 2.5em;
  margin: 0 auto;
}
.wrapper main article .feature .row .column a .num::before,
.wrapper main article .feature .row .column a .num::after {
  position: absolute;
  top: 50%;
  width: 2em;
  height: 100%;
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(-25%);
  content: "";
}
.wrapper main article .feature .row .column a .num::before {
  left: 0;
  background-image: url(../../../lp/assets/images/decor-l.svg);
}
.wrapper main article .feature .row .column a .num::after {
  right: 0;
  background-image: url(../../../lp/assets/images/decor-r.svg);
}
.wrapper main article .feature .row .column a .num span {
  padding: 0 .125em;
}
.wrapper main article .feature .row .column a .head {
  margin: 1em 0 0 0;
}
.wrapper main article .feature .row .column a .head .title {
  font-size: 1.5em;
  line-height: 1;
  margin: 0;
}
.wrapper main article .feature .row .column a .head .en-title {
  font-size: 1.25em;
}
.wrapper main article .feature .row .column a .text {
  margin: .5em 0 0 0;
}
.wrapper main article .feature .row .column a .text p {
  margin: 0;
}
@media (max-width: 769px) {
  .wrapper main article .feature .row {
    gap: 2em;
    font-size: .5em;
  }
  .wrapper main article .feature .row:not(:first-child) {
    margin: 2em auto 0;
  }
  .wrapper main article .feature .row .column {
    width: 22em;
    height: 22em;
  }
  .wrapper main article .feature .row .column::before {
    width: 22em;
    height: 22em;
  }
  .wrapper main article .feature .row .column a {
    height: 22em;
  }
}
/*.profile*/
.wrapper main article .profile {
  margin: 3em 0;
}
.wrapper main article .profile .row {
  display: flex;
  gap: 3em;
  margin: 0 auto;
  width: 92%;
  max-width: 1080px;
}
.wrapper main article .profile .row.info {

}
.wrapper main article .profile .row figure {
  position: relative;
  margin: 0;
}
.wrapper main article .profile .row figure:before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  inset: 0;
  background: center / 100% 100% no-repeat url(../../../lp/assets/images/frame-sq.svg);
}
.wrapper main article .profile .row figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: .5em;
  border-radius: 2.5em;
}
.wrapper main article .profile .row .column {
  width: 55em;
}
.wrapper main article .profile .row .column .head {
  position: relative;
  margin: 2.5em 0 0 0;
  padding: 0 0 1em 0;
  text-align: center;
}
.wrapper main article .profile .row .column .head::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: .03125em;
  background: var(--border-color);
  content: "";
}
.wrapper main article .profile .row .column .head .title {
  margin: 0;
  font-size: 2em;
  color: var(--text-color);
  line-height: 1;
}
.wrapper main article .profile .row .column .head .en-title {
  font-size: 1.875em;
  line-height: 1.4;
}
.wrapper main article .profile .row .column .text {
  margin: 1em 0 0 0;
  color: var(--text-color);
}
.wrapper main article .profile .row .column .text p {
  padding: 0;
}
@media (max-width: 769px) {
  .wrapper main article .profile .row {
    flex-direction: column;
    gap: 0;
  }
  .wrapper main article .profile .row figure {
    margin: 0 15%;
    width: 70%;
  }
  .wrapper main article .profile .row .column {
    width: 100%;
  }
  .wrapper main article .profile .row .column .head {
    margin: 1em 0 0 0;
  }
  .wrapper main article .profile .row .column .head .title {
    font-size: 1.5em;
  }
  .wrapper main article .profile .row .column .head .en-title {
    font-size: 1.25em;
  }
}
.wrapper main article .mv img .btn {
  margin: 2em auto 0;
  width: 92%;
  max-width: 1080px;
}
.wrapper main article .mv img .btn a {
  position: relative;
  display: block;
  font-size: 2em;
  color: var(--text-color);
  text-decoration: none;
  padding: 1em;
  text-align: center;
}
.wrapper main article .mv img .btn a::before {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  background: center / 100% 100% no-repeat url(../../../lp/assets/images/frame-rect.svg);
  content: "";
}
@media (max-width: 769px) {
  
}
/*.blog*/
.wrapper main article .blog {
  margin: 3em 0;
}
.wrapper main article .blog .container {
  margin: 0 auto;
  width: 92%;
  max-width: 1280px;
}
.wrapper main article .blog .container .title {
  position: relative;
  font-size: 2em;
  margin: 0 0 2em;
  padding: 0 0 .5em 0;
  color: var(--text-color);
  text-align: center;
}
.wrapper main article .blog .container .title::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: .03125em;
  background: var(--border-color);
  content: "";
}
.wrapper main article .blog .container .row {
  display: flex;
  flex-wrap: wrap;
}
.wrapper main article .blog .container .row .column {
  margin: 0 .75em 1.5em;
  width: calc(100% / 4 - 1.5em);
}
.wrapper main article .blog .container .row .column a {
  display: block;
  text-decoration: none;
  color: inherit;
}
.wrapper main article .blog .container .row .column figure {
  overflow: hidden;
  position: relative;
  margin: 0 0 .5em;
}
.wrapper main article .blog .container .row .column:hover figure {
  overflow: hidden;
  margin: 0 0 .5em;
}
.wrapper main article .blog .container .row .column figure:before {
    content:"";
    display: block;
    padding-top: 56.25%;
}
.wrapper main article .blog .container .row .column figure img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: #1a1a1a;
  object-fit: cover;
  transition-duration: 0.5s;
}
.wrapper main article .blog .container .row .column:hover figure img {
  transform: scale(1.125);
}
.wrapper main article .blog .container .row .column a .cat {

}
.wrapper main article .blog .container .row .column a .cat span {
  display: inline-block;
  padding: .125em .25em;
  font-size: .75em;
  color: #fff;
  background-color: #1a1a1a;  
}
.wrapper main article .blog .container .row .column a h2 {
  margin: .125em 0;
  font-size: 1em;
  line-height: 1.4;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.wrapper main article .blog .container .row .column a .meta {
  font-size: .75em;
}
@media (max-width: 769px) {
  .wrapper main article .blog .container .row .column {
    margin: 0 .75em 1.5em;
    width: calc(100% / 2 - 1.5em);
  }
  .wrapper main article .blog .container .row .column a h2 {
    -webkit-line-clamp: 2;
  }
}





/*footer*/
footer.site {
  background-color: var(--background-color) !important;
}