@charset "UTF-8";
/* ==========================================================================
   Configuration
   ========================================================================== */
/* ==========================================================================
   Base & Helpers
   ========================================================================== */
picture {
  display: block;
}
picture img {
  width: 100%;
  max-width: 100%;
}

._lcl-ff-serif {
  font-family: "Noto Serif JP",serif;
}

.-lcl-scroll-item {
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
  opacity: 0 !important;
  -webkit-transition: opacity 2s ease,-webkit-transform 2s ease;
  transition: opacity 2s ease,-webkit-transform 2s ease;
  transition: opacity 2s ease,transform 2s ease;
  transition: opacity 2s ease,transform 2s ease,-webkit-transform 2s ease;
}

.-lcl-scroll-item-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1 !important;
}

.lcl-asset-lifespan._lcl-section-arrow,.lcl-cv._lcl-section-arrow {
  position: relative;
  padding-top: 100px !important;
}
.lcl-asset-lifespan._lcl-section-arrow:before,.lcl-cv._lcl-section-arrow:before {
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border-color: #fff transparent transparent;
  border-style: solid;
  border-width: 50px 213px 0;
  content: "";
}

.section-intro {
  background: -webkit-gradient(linear, left top, left bottom, from(#ddd), color-stop(30%, hsla(0, 0%, 86.7%, 0)));
  background: linear-gradient(180deg, #ddd 0, hsla(0, 0%, 86.7%, 0) 30%);
}

/* ==========================================================================
   Components
   ========================================================================== */
/* Typography ------------------------------------------------------------ */
.lcl-ttl {
  margin-bottom: 20px !important;
  color: #48170f;
  font-family: "Noto Serif JP",serif;
  font-size: .36rem !important;
  font-weight: 600;
}
.lcl-ttl--large {
  font-size: .44rem;
}

.lcl-ttl-lv3 {
  margin-top: 40px;
  font-size: .3rem !important;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
}

.lcl-ttl-arrow,.lcl-ttl-lv3 {
  color: #48170f;
  font-family: "Noto Serif JP",serif;
}

.lcl-ttl-arrow {
  gap: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 30px;
  font-size: .24rem;
}
.lcl-ttl-arrow>span {
  display: block;
  width: 49px;
  height: 107px;
  background-image: url(../images/ttl_arrow.svg);
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
}

.lcl-list li {
  padding-left: 1em;
  font-size: .18rem;
  line-height: 1.5555555556;
  text-indent: -1em;
}

/* Keyframes (Animations) ------------------------------------------------ */
@-webkit-keyframes sweep-clip {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  40%,60% {
    -webkit-clip-path: inset(0 0 0 0);
            clip-path: inset(0 0 0 0);
  }
  to {
    -webkit-clip-path: inset(0 0 0 100%);
            clip-path: inset(0 0 0 100%);
  }
}
@keyframes sweep-clip {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  40%,60% {
    -webkit-clip-path: inset(0 0 0 0);
            clip-path: inset(0 0 0 0);
  }
  to {
    -webkit-clip-path: inset(0 0 0 100%);
            clip-path: inset(0 0 0 100%);
  }
}
@-webkit-keyframes arrow-slide-right {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  40% {
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
    opacity: 0;
  }
  41% {
    -webkit-transform: translateX(-20px);
            transform: translateX(-20px);
    opacity: 0;
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
@keyframes arrow-slide-right {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  40% {
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
    opacity: 0;
  }
  41% {
    -webkit-transform: translateX(-20px);
            transform: translateX(-20px);
    opacity: 0;
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
/* Buttons --------------------------------------------------------------- */
.lcl-button__container {
  gap: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 460px;
  margin: 40px auto 0;
}
.lcl-button__container .ttl {
  color: #fff;
  font-family: "Noto Serif JP",serif;
  font-size: .28rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.lcl-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  position: relative;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  max-width: 660px;
  margin: auto;
  overflow: hidden;
  border: 2px solid #908466;
  font-family: "Noto Serif JP",serif;
  font-size: .3rem;
  text-decoration: none;
  cursor: pointer;
}
.lcl-button,.lcl-button:active,.lcl-button:focus,.lcl-button:focus-visible {
  background-color: #846e30;
  background-image: -webkit-gradient(linear, left top, right top, from(#846e30), color-stop(#937d3b), to(#725e25));
  background-image: linear-gradient(90deg, #846e30, #937d3b, #725e25);
}
.lcl-button .btn-label {
  z-index: 1;
  position: relative;
  width: 100%;
  height: 100%;
  padding: 16px;
  color: #fff;
  line-height: 1.2;
  white-space: nowrap;
}
.lcl-button .btn-label,.lcl-button .btn-label:before {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.lcl-button .btn-label:before {
  inset: 0;
  z-index: 2;
  position: absolute;
  padding: 0 40px;
  background-color: #fff;
  background-image: url(../images/arrow_gold.svg);
  background-position: right 30px center;
  background-repeat: no-repeat;
  background-size: 26px 10px;
  color: #846e30;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  content: attr(data-text);
  pointer-events: none;
  -webkit-transition: all .4s ease-in-out;
  transition: all .4s ease-in-out;
}
.lcl-button .btn-label:after {
  display: block;
  position: absolute;
  right: 30px;
  width: 26px;
  height: 10px;
  background-color: #fff;
  content: "";
  -webkit-mask-image: url(../images/arrow.svg);
          mask-image: url(../images/arrow.svg);
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}

/* Layout: Grid ---------------------------------------------------------- */
.lcl-grid {
  gap: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 20px;
}
.lcl-grid__item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.33333% - 13.33333px);
          flex: 0 0 calc(33.33333% - 13.33333px);
}

/* Layout: Media Block --------------------------------------------------- */
.lcl-media-block {
  gap: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-top: 80px;
}
.lcl-media-block:first-of-type {
  margin-top: 100px;
}
.lcl-media-block__visual {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 580px;
          flex: 1 1 580px;
}
.lcl-media-block__visual img {
  max-width: 100%;
}
.lcl-media-block__content {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 620px;
          flex: 1 1 620px;
}
.lcl-media-block__heading {
  position: relative;
  margin-bottom: 20px;
  color: #48170f;
  font-family: "Noto Serif JP",serif;
  font-size: .3rem !important;
  font-weight: 600;
  line-height: 1.5;
}
.lcl-media-block__heading:before {
  display: block;
  z-index: -1;
  position: absolute;
  top: -21px;
  left: -30px;
  width: 80px;
  height: 80px;
  background-color: #efecec;
  content: "";
}

.lcl-media-block2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.lcl-media-block2__visual {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 100%;
          flex: 1 1 100%;
}
.lcl-media-block2__visual img {
  max-width: 100%;
}
.lcl-media-block2__content {
  height: 100%;
  padding: 20px;
}
.lcl-media-block2__content._lcl-bg-white {
  background-color: #fff;
}
.lcl-media-block2__heading {
  font-size: .2rem !important;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
}

.lcl-media-block3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  height: 100%;
}
.lcl-media-block3 .lcl-media-block2__content {
  width: 100%;
  padding: 14px;
}
.lcl-media-block3__visual {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 160px;
          flex: 1 1 160px;
  max-width: 160px;
}
.lcl-media-block3__visual img {
  max-width: 100%;
}
.lcl-media-block3__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  height: 100%;
  padding: 20px;
  background-color: #fff;
}
.lcl-media-block3__heading {
  color: #48170f;
  font-family: "Noto Serif JP",serif;
  font-size: .24rem !important;
  font-weight: 700;
}
/* Swiper Customization -------------------------------------------------- */
.swiper-nav {
  gap: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 20px;
}
.swiper-button-next,.swiper-button-prev {
  position: relative !important;
  width: 44px;
  height: 44px;
  margin: 0;
  border: 1px solid #48170f;
  background: #fff url(../images/swiper-arrow.svg) no-repeat 50%/10px 20px;
}
.swiper-button-next {
  -webkit-transform: scale(-1);
          transform: scale(-1);
}
.swiper-pagination {
  gap: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative !important;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.swiper-pagination .swiper-pagination-bullet {
  width: 14px;
  height: 14px;
}
.swiper-pagination .swiper-pagination-bullet-active {
  background: rgba(72, 23, 15, .5);
}

/* ==========================================================================
   Sections
   ========================================================================== */
/* 1. Main Visual -------------------------------------------------------- */
/************ メインビジュアルアニメーション（アニメーション含む） START ************/
.-lcl-local-mainvisual-h1-text {
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  opacity: 0;
}
.-lcl-local-mainvisual-h1-text-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
  -webkit-transition: opacity 2s ease,-webkit-transform 2s ease;
  transition: opacity 2s ease,-webkit-transform 2s ease;
  transition: opacity 2s ease,transform 2s ease;
  transition: opacity 2s ease,transform 2s ease,-webkit-transform 2s ease;
}

.-lcl-local-mainvisual-img01 {
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  opacity: 0;
  -webkit-transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease,-webkit-transform 2.8s ease;
}
.-lcl-local-mainvisual-img01-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.-lcl-local-mainvisual-img02 {
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px);
  opacity: 0;
  -webkit-transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease,-webkit-transform 2.8s ease;
}
.-lcl-local-mainvisual-img02-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.-lcl-local-mainvisual-img03 {
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  opacity: 0;
  -webkit-transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease,-webkit-transform 2.8s ease;
}
.-lcl-local-mainvisual-img03-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.-lcl-local-mainvisual-img04 {
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  opacity: 0;
  -webkit-transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,-webkit-transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease;
  transition: opacity 2s ease,transform 2.8s ease,-webkit-transform 2.8s ease;
}
.-lcl-local-mainvisual-img04-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.-lcl-local-mainvisual {
  background-color: #481710 !important;
  background-image: url(../images/kv-bk-pc.jpg) !important;
  background-position: 50% !important;
  background-repeat: no-repeat !important;
  background-size: auto;
}
.-lcl-local-mainvisual-h1 {
  max-width: 1240px;
  height: 510px;
  margin: 0 auto;
}
.-lcl-local-mainvisual-h1,.-lcl-local-mainvisual-h1-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.-lcl-local-mainvisual-h1-text {
  width: 50%;
  min-width: 475px;
  margin-top: 118px;
}
.-lcl-local-mainvisual-h1-img {
  position: relative;
  width: 50%;
}
.-lcl-local-mainvisual-img01 {
  position: absolute;
  top: 0;
  left: 0;
}
.-lcl-local-mainvisual-img02 {
  position: absolute;
  top: 0;
  left: 112px;
}
.-lcl-local-mainvisual-img03 {
  position: absolute;
  top: 0;
  left: 456px;
}
.-lcl-local-mainvisual-img04 {
  display: none;
}

/* タブレット帯だけ専用（例：768〜1023） */
/************ メインビジュアル（アニメーション含む） END ************/
/* Fixed Banner ---------------------------------------------------------- */
.lcl-fixed-banner__content {
  z-index: 2;
  position: fixed;
  right: 0;
  bottom: 100px;
  width: 256px;
  padding: 20px;
  border-radius: 4px;
  background: #48170f;
  -webkit-box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .16);
          box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .16);
  opacity: 0;
  pointer-events: none;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}
.lcl-fixed-banner__content .lcl-button .btn-label {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 8px;
  font-size: .18rem;
}
.lcl-fixed-banner__content .lcl-button .btn-label:before {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 8px;
  background-position: right 10px center !important;
}
.lcl-fixed-banner__content .lcl-button .btn-label:after {
  right: 10px !important;
}
.lcl-fixed-banner__content .lcl-button-banner {
  display: block;
  max-width: 343px;
}
.lcl-fixed-banner.-is-visible .lcl-fixed-banner__content {
  opacity: 1;
  pointer-events: auto;
}
.lcl-fixed-banner__heading {
  color: #fff;
  font-family: "Noto Serif JP",serif;
  line-height: 1.3333333333;
  text-align: center;
}
.lcl-fixed-banner__picture {
  display: block;
  margin-top: 20px;
}
.lcl-fixed-banner__picture img {
  max-width: 100%;
}

/* 2. Asset Lifespan Area -------------------------------------------------- */
.lcl-asset-lifespan {
  z-index: 0;
  position: relative;
  background-color: #efecec;
}
.lcl-asset-lifespan ._mt {
  margin-top: 52px !important;
}
.lcl-asset-lifespan>.container {
  max-width: 1209px;
}
.lcl-asset-lifespan:after {
  inset: 0;
  z-index: -1;
  position: absolute;
  background: url(../images/bg_section.png) no-repeat 0 0/cover;
  content: "";
}
.lcl-asset-lifespan__lead {
  margin-top: 40px;
  font-family: "Noto Serif JP",serif;
  font-size: .24rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.lcl-asset-lifespan .lcl-list li {
  font-size: .14rem;
}

/* 3. Conversion Area ---------------------------------------------------- */
.lcl-cv {
  padding-block: 60px;
  background: url(../images/bg_section2.png) no-repeat 0 0/cover, -webkit-gradient(linear, left top, right top, from(#48170f), color-stop(51%, #642b22), to(#48170f));
  background: url(../images/bg_section2.png) no-repeat 0 0/cover, linear-gradient(90deg, #48170f, #642b22 51%, #48170f);
  background-blend-mode: multiply;
}
.lcl-cv .lcl-ttl {
  color: #fff;
}
.lcl-cv__lead {
  margin-top: 40px;
  color: #48170f;
  font-family: "Noto Serif JP",serif;
  font-size: .24rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.lcl-cv__items {
  gap: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 40px;
}
.lcl-cv__item {
  min-width: 0;
  max-width: 540px;
  height: auto;
}
.lcl-cv__detail {
  gap: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.lcl-cv__description {
  color: #fff !important;
}
.lcl-cv__ttl {
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid #fff;
  font-family: "Noto Serif JP",serif;
  font-size: .26rem;
  text-align: left;
}

.block.-bottom {
  overflow: hidden;
}

/* 4. Wealth Management Solutions ---------------------------------------- */
.lcl-wm {
  margin-top: 30px;
  padding: 30px;
  background-image: url(../images/wm_bg.jpg);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
}
.lcl-wm__ttl {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto 26.22px;
}
.lcl-wm__infographics {
  max-width: 1068px;
  margin: auto;
}
.lcl-wm__solution {
  margin-top: 30px;
  padding: 20px;
  background: #efecec;
}
.lcl-wm__solution__ttl {
  color: #48170f;
  font-family: "Noto Serif JP",serif;
  font-size: .24rem;
  line-height: 1.5;
  text-align: center;
}

/* 5. Related Links ------------------------------------------------------ */
.lcl-related-links {
  padding-top: 60px;
  padding-bottom: 60px;
  background: #efecec;
}
.lcl-related-links a {
  font-weight: 700;
  text-decoration: none;
}
.lcl-related-links a:visited {
  color: #333;
}

.section._lcl-adjust {
  padding: 40px calc(12.5% - 80px) 100px;
}

@media screen and (min-width:768px) {
  ._lcl-center-pc {
    text-align: center;
  }
  .lcl-grid._lcl-grid-2x2-pc .lcl-grid__item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(50% - 10px);
            flex: 0 0 calc(50% - 10px);
  }
  .lcl-media-block2._lcl-block2-pc {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .lcl-media-block2._lcl-block2-pc .lcl-media-block2__content {
    width: 100%;
    padding: 14px;
  }
  .lcl-media-block3 {
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  .lcl-media-block3__visual {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-item-align: stretch;
        -ms-grid-row-align: stretch;
        align-self: stretch;
  }
  .lcl-media-block3__visual img,.lcl-media-block3__visual picture {
    display: block;
    width: 100%;
    height: 100%;
  }
  .lcl-media-block3__visual img {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: right top;
       object-position: right top;
  }
  .lcl-cv__items {
    gap: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  .lcl-cv__item {
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: 540px;
  }
  .lcl-cv__detail,.lcl-cv__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
  }
  .lcl-cv__detail {
    gap: 20px;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .lcl-cv .lcl-button__container {
    width: 100%;
    max-width: 460px;
    margin-top: auto;
    margin-right: auto;
    margin-left: auto;
    padding-top: 40px;
  }
  .lcl-related-links .swiper-container {
    margin-top: 40px;
  }
}

@media screen and (max-width:767px) {
  .to-top {
    bottom: 120px;
  }
  .section-intro {
    background: -webkit-gradient(linear, left top, left bottom, from(#ddd), color-stop(10%, hsla(0, 0%, 86.7%, 0)));
    background: linear-gradient(180deg, #ddd 0, hsla(0, 0%, 86.7%, 0) 10%);
  }
  .lcl-ttl {
    font-size: .24rem !important;
    text-align: center;
  }
  .lcl-ttl--large {
    font-size: .3rem !important;
  }
  .lcl-ttl-lv3 {
    margin-top: 30px;
    font-size: .2rem !important;
  }
  .lcl-ttl-arrow {
    margin-top: 20px;
    font-size: .18rem !important;
    line-height: 1.5;
    text-align: center;
  }
  .lcl-ttl-arrow>span {
    width: 38px;
    height: 107px;
    background-image: url(../images/ttl_arrow_sp.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .lcl-list li {
    font-size: .16rem;
  }
  .lcl-button__container {
    margin: 30px auto 0;
  }
  .lcl-button__container .ttl {
    font-size: .2rem;
  }
  .lcl-button .btn-label {
    padding: 10px;
    font-size: .22rem;
    line-height: 1.6363636364;
  }
  .lcl-grid {
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .lcl-grid,.lcl-media-block {
    -webkit-box-orient: vertical;
  }
  .lcl-media-block {
    gap: 20px;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    margin-top: 60px;
  }
  .lcl-media-block:first-of-type {
    margin-top: 80px;
  }
  .lcl-media-block__content,.lcl-media-block__visual {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .lcl-media-block__heading:before {
    top: -16px;
    left: -16px;
    width: 60px;
    height: 60px;
  }
  .lcl-media-block__heading {
    font-size: .2rem !important;
  }
  .lcl-media-block2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lcl-media-block2._lcl-block2-sp {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .lcl-media-block2._lcl-block2-sp .lcl-media-block2__content {
    width: 100%;
    padding: 14px;
  }
  .lcl-media-block2__visual {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
  .lcl-media-block2__content {
    padding: 0 0 0 10px;
  }
  .lcl-media-block2__heading {
    font-size: .16rem !important;
    line-height: 1.6875 !important;
    text-align: left;
  }
  .lcl-media-block3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .lcl-media-block3 .lcl-media-block2__content {
    width: 100%;
    padding: 14px;
  }
  .lcl-media-block3__visual {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    max-width: 100%;
  }
  .lcl-media-block3__content {
    width: 100%;
    padding: 14px;
  }
  .lcl-media-block3__heading {
    font-size: .18rem !important;
    font-weight: 700;
    line-height: 1.6;
  }
  .-lcl-local-mainvisual-h1-text {
    -webkit-transform: translateY(-30px);
            transform: translateY(-30px);
    opacity: 0;
  }
  .-lcl-local-mainvisual-h1-text-visible {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
  .-lcl-local-mainvisual {
    background-image: url(../images/kv-bk-sp.jpg) !important;
    background-size: cover !important;
  }
  .-lcl-local-mainvisual-h1 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
  .-lcl-local-mainvisual-h1-text {
    width: 100%;
    min-width: inherit;
    margin-top: 35px;
    padding-right: 30px;
    padding-left: 30px;
  }
  .-lcl-local-mainvisual-h1-img {
    width: 100%;
    margin-top: 30px;
    margin-bottom: 10px;
  }
  .-lcl-local-mainvisual-img01,.-lcl-local-mainvisual-img02,.-lcl-local-mainvisual-img03 {
    display: none;
  }
  .-lcl-local-mainvisual-img04 {
    display: block;
  }
  .lcl-fixed-banner__content {
    gap: 6px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 100%;
    padding: 18px 16px;
    border-radius: 0;
    background: rgba(72, 23, 15, .9);
  }
  .lcl-fixed-banner__content .lcl-button .btn-label {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0 33px 0 0;
    font-size: .16rem;
  }
  .lcl-fixed-banner__content .lcl-button {
    position: absolute;
    right: 18px;
    bottom: 16px;
    left: 165px !important;
    width: auto;
    padding: 0;
  }
  .lcl-fixed-banner__heading {
    font-size: .16rem;
  }
  .lcl-fixed-banner__picture {
    width: 150px;
    margin-top: 0;
  }
  .lcl-asset-lifespan ._mt {
    margin-top: 30px !important;
  }
  .lcl-asset-lifespan:after {
    background: url(../images/bg_section_sp.png) no-repeat 0 0/cover;
  }
  .lcl-asset-lifespan__lead {
    font-size: .2rem;
    text-align: left;
  }
  .lcl-cv {
    padding-block: 80px;
  }
  .lcl-cv .lcl-ttl {
    margin-inline: -.5em;
    margin-bottom: 30px !important;
    font-size: .24rem !important;
  }
  .lcl-cv__lead {
    font-size: .2rem;
  }
  .lcl-cv__items {
    gap: 30px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lcl-cv__detail,.lcl-cv__items {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .lcl-cv__detail img {
    width: 100%;
  }
  .lcl-cv__ttl {
    font-size: .2rem;
    line-height: 1.5;
    text-align: left;
  }
  .lcl-wm {
    padding: 20px;
    background-position: 100% 0;
  }
  .lcl-wm__ttl {
    margin: 0 auto 10px;
  }
  .lcl-wm__ttl,.lcl-wm__ttl img {
    width: 100%;
  }
  .lcl-wm__solution__ttl {
    font-size: .18rem;
  }
  .lcl-related-links {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .lcl-related-links .lcl-ttl {
    font-size: .2rem !important;
  }
  .section._lcl-adjust {
    padding: 30px 16px 56px;
  }
}

@media (hover:hover) and (pointer:fine) {
  .lcl-button:hover .btn-label:before {
    -webkit-clip-path: inset(0 0 0 0);
            clip-path: inset(0 0 0 0);
  }
  .lcl-button:hover .btn-label:after {
    -webkit-animation: arrow-slide-right .4s ease-in-out forwards;
            animation: arrow-slide-right .4s ease-in-out forwards;
  }
  a.lcl-media-block2:hover {
    opacity: .8;
  }
}

@media screen and (min-width:768px) and (max-width:1024px) {
  .-lcl-local-mainvisual-h1-text {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 55%;
  }
  .-lcl-local-mainvisual-h1-img {
    margin-left: -142px;
  }
  .-lcl-local-mainvisual-h1-text img {
    max-width: 380px;
    margin: 0 auto;
  }
}

@media screen and (min-width:1291px) {
  .lcl-cv__ttl {
    white-space: nowrap;
  }
}