@charset "UTF-8";
/* ---------- ---------- ----------

00. Common Setting
01. Component Setting
02. Page SettingPage Setting

---------- ---------- ---------- */

/* ---------- ---------- ----------
:: for large screen ::
@media only screen and (min-width: 1025px) {
}
:: for medium screen ::
@media only screen and (min-width: 641px) and (max-width: 1024px) {
}
:: for small screen ::
@media only screen and (max-width: 640px) {
}
---------- ---------- ---------- */

/* -- ------------------------------
    00. Common Setting
------------------------------ --*/
/* Reset
---------- ---------- */
.col3-Section .g-HeadingTitle__titleBlock__titleBox__title,
.col3-Section .g-HeadingTitle--v2__titleBlock__titleBox__title,
.col3-Section .g-PageTitle__titleBlock__titleBox__title,
.col3-Section .g-PageTitle--v2__titleBlock__titleBox__title {
  margin-bottom: 0;
}

.col3-Section .g-Section__inner {
  max-width: 1366px;
  margin: 0 auto;
}

.g-Area#area-Contents,
.col3-Section {
  overflow: visible !important;
}

.spp-Section .cmn-richtext {
  letter-spacing: .02em;
  font-family: sans-serif;
  color: #231815;
}

/* Background
---------- ---------- */
.col3-Section {
  background-size: 1366px auto;
  background-attachment: fixed;
}

@media only screen and (min-width: 641px) and (max-width: 1024px) {
  .col3-Section {
    background-size: 0 0;
  }
}

.col3-Section {
  background-color: #FFFCF2;
}

.col3-mainUnit {
  background-color: #fff;
}

.col3-Section .g-Column__cols--lg-w40p {
  box-shadow: 0px 0px 30px 0px #E6D6AD;
}

/* option */
.bg-col01 {
  background-color: #FEF8E5;
}

.bg-col02 {
  background-color: #E1DCEC;
}

.bg-col03 {
  background-color: #F8E9E0;
}

.bg-col04 {
  background-color: #F7D5C9;
}

.bg-col05 {
  background-color: #F8E7E0;
}

.bg-col07 {
  background-color: #E1EDEE;
}

.bg-col08 {
  background-color: #C7E2E6;
}

/* font
---------- ---------- */
/* font color */
.spp-fontcolor--01,
.spp-fontcolor--01 .cmn-richtext {
  color: #AD755C;
}

/* text decoration */
.opt-textD--01 {
  display: inline-block;
  font-size: 10px;
  padding: 2px 4px;
  border: 1px solid #000;
}

/* font size */
.opt-fontsize--18 {
  font-size: 18px;
}

/* fixed
---------- ---------- */
@media only screen and (max-width: 1024px) {

  .col3-l-Box,
  .col3-r-Box {
    display: none;
  }
}

/* 3 Column > Column Width */
@media only screen and (min-width: 1025px) {
  .col3-Section .g-Column__cols {
    width: 33.333%;
    max-width: 455.333px;
  }
}

@media only screen and (min-width: 641px) and (max-width: 1024px) {
  .col3-Section .g-Section__inner {
    max-width: 480px;
  }
}

@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .col3-Section .g-Column__cols--lg-w40p {
    width: 400px;
  }

  .col3-Section .g-Column__cols--lg-w30p {
    width: calc(50% - 200px);
  }
}

/* PC > Left, Right Column */
@media only screen and (min-width: 1025px) {

  .col3-l-Box,
  .col3-r-Box {
    position: sticky;
    top: 124px;
    border-color: transparent !important;
    z-index: 3;
  }
}

/* TB / SP (CTA) */
.col3-cta-wrap {
  position: sticky;
  top: 124px;
  border-color: transparent !important;
  z-index: 3;
}

@media only screen and (min-width: 641px) and (max-width: 1024px) {
  .col3-cta-wrap {
    top: 143px;
  }
}

.col3-cta-btn {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  flex-wrap: nowrap;
}

.col3-cta-btn .g-HeadingTitle--v2__titleBlock {
  width: 100px;
}

.col3-cta-btn .l-HeadingTitle--v2.is-link:hover {
  opacity: 1;
}

.col3-cta-btn .l-HeadingTitle--v2.is-link:hover .g-Image--v2 {
  opacity: .7;
}

@media only screen and (min-width: 1025px) {
  .col3-cta-wrap {
    display: none;
  }
}

/* -- ------------------------------
    01. Component Setting
------------------------------ --*/
/* PC > left */
.col3-pc-btn,
.col3-pc-logo {
  width: 70%;
  margin: 30px auto 0;
}

@media only screen and (min-width: 1025px) {

  .col3-pc-btn .l-HeadingTitle--v2.is-link:hover,
  .col3-pc-btn .l-HeadingTitle--v2.is-link:focus,
  .col3-pc-btn .l-HeadingTitle--v2.is-link:active {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
    opacity: 1;
  }

  .col3-pc-btn .l-HeadingTitle--v2.is-link:not(:first-child):hover .g-Image--v2,
  .col3-pc-btn .l-HeadingTitle--v2.is-link:not(:first-child):focus .g-Image--v2,
  .col3-pc-btn .l-HeadingTitle--v2.is-link:not(:first-child):active .g-Image--v2 {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
    transition: all .3s ease;
  }

  .spp-pc-top-btn::after {
    content: '';
    display: block;
    width: 0;
    height: 4px;
    border-radius: 2px;
    background-color: #EF6023;
  }

  .spp-pc-top-btn:hover::after,
  .spp-pc-top-btn:active::after {
    width: 40%;
    transition: all .3s ease;
  }
}

/* Group Box */
.spp-GroupBox01.g-GroupBox.is-background {
  padding-top: 200px;
}

/* Image & Text Pack (V) */
.spp-ImageTextVP--01 {
  margin: 40px 15px 10px;
  background-color: #fff;
  padding: 25px 15px;
}

.spp-ImageTextVP--01.triangle {
  margin-bottom: 50px;
  position: relative;
}

.spp-ImageTextVP--01.triangle::before {
  content: "";
  position: absolute;
  height: 30px;
  width: 100%;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  background-color: #fff;
  left: 0;
  bottom: -30px;
}

.spp-ImageTextVP--01 .g-HeadingTitle .g-Text {
  font-size: 14px;
  font-weight: bold;
}

.spp-ImageTextVP--01 .g-HeadingTitle__titleBlock__titleBox__title .cmn-richtext {
  font-size: 18px;
  font-weight: bold;
}

.spp-ImageTextVP--01 .g-HeadingTitle.l-HeadingTitle.is-titleBorder--visible {
  border-bottom: 1px solid #CBCBCB;
  padding-bottom: 7px;
}

.spp-ImageTextVP--01 .g-ImageTextVP--v2__contentsBlock__text .l-Text {
  font-size: 14px;
}

.spp-ImageTextVP--01 .g-ImageTextVP--v2__contentsBlock__text .l-Text .opt-fontsize--18 {
  font-weight: bold;
}

/* Image Carousel Pack */
.spp-ImageCarouselP--01 {
  margin: 40px 15px 10px;
  background-color: #fff;
  padding: 25px 15px 25px;
}

.spp-ImageCarouselP--01 .l-ImageCarouselP__nav__dot:before,
.spp-ImageCarouselP--01 .l-ImageCarouselP__nav__toggle:before,
.spp-ImageCarouselP--01 .l-ImageCarouselP__nextArrow:before,
.spp-ImageCarouselP--01 .l-ImageCarouselP__prevArrow:before {
  color: #7B7B7B;
}

.spp-ImageCarouselP--01 .g-ImageCarouselP__nav {
  margin: 15px 0 0;
}

.spp-ImageCarouselP--01 .slick-slider {
  margin-bottom: 0;
}

.spp-ImageCarouselP--01 .g-ImageCarouselP__nextArrow,
.spp-ImageCarouselP--01 .g-ImageCarouselP__prevArrow {
  bottom: -6px;
  margin-top: 0;
  padding: 0 3px;
}

.spp-ImageCarouselP--01 .l-ImageCarouselP__nextArrow:before,
.spp-ImageCarouselP--01 .l-ImageCarouselP__prevArrow:before {
  color: #7B7B7B;
  font-size: 28px;
}

/* 02 */
body:not(.is-authorring) .spp-ImageCarouselP--02 .g-GroupBox {
  position: static;
  left: 0;
  top: 0;
}

.spp-ImageCarouselP--02 {
  margin: 40px 15px 10px;
  background-color: #fff;
  padding: 25px 15px 25px;
}

.spp-ImageCarouselP--02 .spp-ImageTextVP--01 {
  margin: 0;
  padding: 0;
}

.spp-ImageCarouselP--02 .l-ImageCarouselP__nav__dot:before,
.spp-ImageCarouselP--02 .l-ImageCarouselP__nav__toggle:before,
.spp-ImageCarouselP--02 .l-ImageCarouselP__nextArrow:before,
.spp-ImageCarouselP--02 .l-ImageCarouselP__prevArrow:before {
  color: #7B7B7B;
}

.spp-ImageCarouselP--02 .g-ImageCarouselP__nav {
  margin: 0;
}

.spp-ImageCarouselP--02 .slick-slider {
  margin-bottom: 0;
}

.spp-ImageCarouselP--02 .g-ImageCarouselP__nextArrow,
.spp-ImageCarouselP--02 .g-ImageCarouselP__prevArrow {
  bottom: -6px;
  margin-top: 0;
  padding: 0 3px;
}

.spp-ImageCarouselP--02 .l-ImageCarouselP__nextArrow:before,
.spp-ImageCarouselP--02 .l-ImageCarouselP__prevArrow:before {
  color: #7B7B7B;
  font-size: 28px;
}

.spp-ImageCarouselP--02.triangle {
  position: relative;
  margin-bottom: 50px;
  overflow: visible;
}

.spp-ImageCarouselP--02.triangle::before {
  content: "";
  position: absolute;
  height: 30px;
  width: 100%;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  background-color: #fff;
  left: 0;
  bottom: -30px;
}

.spp-ImageCarouselP--02 .g-GroupBox {
    padding: 0 0 20px 0;
}

/* Movie Item */
.spp-Movie--01 {
  margin: 40px 15px 0;
}

.spp-Movie--01.is-borderColor--1 {
  border-color: #8B8B8B;
}

.l-Movie--v2__caption {
  margin: 8px;
  font-size: 14px;
  font-weight: bold;
}

/* Annotation List Pack */
.spp-AnnotationListP--01 {
  padding: 0 1em;
}