@charset "UTF-8";

html {
  font-size: 10px;
}

@media screen and (max-width: 1400px) {
  html {
    font-size: calc(10 * (100vw / 1400));
  }
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  box-sizing: border-box;
}

.l-footer {
  padding: 0;
}

.pc-footer {
  margin: 0;
}

#feature {
  box-sizing: border-box;
  color: #000;
  margin: 0 auto;
  overflow: clip;
  position: relative;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  width: 100%;
  font-feature-settings: "palt";
  background: #F3E7D4;
  padding-bottom: 170px;
}

#feature .feature__inner {
  width: 1400px;
  margin: auto;
  position: relative;
}

#feature a {
  color: #000;
  transition: all 0.3s ease-in-out;
  display: block;
  transform: none;
  text-decoration: none;
}

#feature a:hover {
  opacity: 0.7;
  transition: 0.3s;
}

#feature img,
svg,
video {
  width: 100%;
  height: auto;
  display: block;
}

.l-container {
  width: 100%;
  overflow: clip;
}

#feature figure {
  background: #fff;
}

/*-------------------------
 fade
-------------------------*/
.fadeIn {
  opacity: 0;
  transition: all 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.fadeIn.active {
  opacity: 1;
}

.hero-fadeIn {
  transition: opacity 2s cubic-bezier(0.77, 0, 0.175, 1), transform 3.8s cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0;
  transform: scale(1.07);
  transform-origin: top left;
}

.hero-fadeIn.active {
  opacity: 1;
  transform: scale(1);
}

/** mv **/
.hero__ttl {
  transition: opacity 1.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  opacity: 0;
  transition-delay: 1.6s;
}

.hero__ttl.active {
  opacity: 1;
}

/** pic **/
.blur {
  opacity: 0;
  filter: blur(30px) brightness(1.1);
}

.blur.active {
  animation: blurAnime 1.5s ease forwards;
}

@keyframes blurAnime {
  0% {
    filter: blue(30px) brightness(1.1);
    opacity: 0;
  }

  100% {
    opacity: 1;
    filter: blur(0) brightness(1);
  }
}

/** text **/
.fadeIn {
  opacity: 0;
  transition: 2.4s;
}

.fadeIn.active {
  opacity: 1;
  transform: none;
}

/** txt-slide **/
.txt-slide {
  transition: clip-path 2s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s;
  clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);
}

.txt-slide.active {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}

/*-------------------------
 hero
-------------------------*/
#feature .hero {
  margin: 0 auto;
  width: 1400px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

#feature .hero .hero__ttl {
  width: 766.0313px;
  position: absolute;
  bottom: 290px;
  left: 0;
  right: 0;
  margin: auto;
  background: transparent;
}

/*-------------------------
 content
-------------------------*/
#feature .sec01 .section__inner {
  display: flex;
  justify-content: space-between;
  gap: 0;
}

#feature .txt {
  font-size: 13px;
  line-height: 2.076;
  text-align: justify;
}

/** sec01 **/
#feature .sec01 {
  margin-top: 252px;
}

#feature .sec01 .section__inner {
  width: 1057.3125px;
  margin: auto;
}

#feature .sec01 .section__inner .block_area:first-child {
  margin-left: 12px;
}

#feature .sec01 .section__inner .block_area:last-child {
  margin-right: -12px;
}

#feature .img01 {
  width: 550px;
}

#feature .img02 {
  width: 330px;
  margin: 165px auto 0 64px;
}

#feature .sec01 .txt {
  width: 429.2681px;
  margin: 63px auto 0 0;
}

#feature .credit01 {
  width: 300px;
  margin: 32px auto 0;
  text-align: center;
}

#feature .sec01 .txt {
  letter-spacing: 0.079em;
}

/** sec02 **/
#feature .sec02 {
  margin: 242px auto 0;
}

#feature .sec02 .section__inner {
  width: 1015.5093px;
}

#feature .sec02 .section__inner {
  width: 1015.5093px;
  margin: auto;
  position: relative;
}

#feature .sec02 .flex_area {
  display: flex;
}

#feature .sec02 .txt {
  letter-spacing: 0.056em;
}


#feature .sec02 .ttl01 {
  width: 53.5px;
  position: absolute;
  top: 690px;
  right: -22px;
  background: transparent;
}

#feature .img03 {
  width: 630px;
  margin: auto;
  position: relative;
  z-index: 10;
}

#feature .pic01 {
  width: 530px;
  margin: -187px 0 0 -190px;
}

#feature .img04 {
  width: 465px;
  margin: -288px auto 0 276px;
}

#feature .sec02 .txt {
  width: 399.4238px;
  margin: 113px auto 0 85px;
}

#feature .credit02 {
  width: 424px;
  margin: 34px 124px 0 auto;
  text-align: center;
}

/** sec03 **/
#feature .sec03 {
  margin: 250px auto 0;
  position: relative;
  width: 1015.5093px;
}

#feature .sec03 .section__inner {
  width: 1015.5093px;
}

#feature .img05 {
  width: 880px;
  margin: 0 auto;
}

#feature .img06 {
  width: 550px;
  margin: 65px auto 0;
}

#feature .sec03 .section__inner {
  width: 880px;
  margin: auto;
}

#feature .sec03 .txt {
  width: 602px;
  margin: 60px auto 0;
  letter-spacing: 0.064em;
}

#feature .sec03 .txt span:first-child {
  letter-spacing: 0.085em;
}

#feature .sec03 .txt span:last-child {
  letter-spacing: 0.06em;
}

#feature .credit03 {
  width: 880px;
  margin: 33px auto 0;
  text-align: center;
}

#feature .credit04 {
  width: 550px;
  margin: 31px auto 0;
  text-align: center;
}


/** sec04 **/
#feature .sec04 {
  margin: 242px 0 0 auto;
}

#feature .sec04 .section__inner {
  width: 1092.5323px;
  margin: 0 0 0 306px;
  position: relative;
}

#feature .sec04 .flex_area {
  display: flex;
  flex-direction: row-reverse;
}

#feature .sec04 .txt {
  letter-spacing: 0.056em;
}


#feature .sec04 .ttl02 {
  width: 53.5px;
  position: absolute;
  top: 547px;
  left: -164px;
  background: transparent;
}

#feature .img07 {
  width: 634px;
  margin: 0 auto 0 0;
  position: relative;
  z-index: 10;
}

#feature .pic02 {
  width: 620px;
  margin: -410px 0 0 auto;
}

#feature .img08 {
  width: 500px;
  margin: -77px auto 0 144px;
}

#feature .sec04 .txt {
  width: 392.1938px;
  margin: 84px auto 0 3px;
}

#feature .credit05 {
  width: 298px;
  margin: 31px auto 0 88px;
  text-align: center;
}

/** sec05 **/
#feature .sec05 {
  margin: 250px auto 0;
  position: relative;

}

#feature .sec05 .section__inner {
  width: 1200px;
}

#feature .img09 {
  width: 1200px;
  margin: 0 auto;
}

#feature .img10 {
  width: 598.552px;
  margin: 78px auto 0;
}

#feature .sec05 .section__inner {
  width: 1200px;
  margin: auto;
}

#feature .sec05 .txt {
  width: 602.9033px;
  margin: 72px auto 0;
  letter-spacing: 0.09em;
}

#feature .sec05 .txt span:first-child {
  letter-spacing: 0.06em;
}

#feature .sec05 .txt span:nth-child(2) {
  letter-spacing: 0.06em;
}

#feature .sec05 .txt span:nth-child(3) {
  letter-spacing: 0.05em;
}

#feature .sec05 .txt span:nth-child(4) {
  letter-spacing: 0.06em;
}

#feature .credit06 {
  width: 880px;
  margin: 33px auto 0;
  text-align: center;
}

/*-------------------------
  credit
-------------------------*/
#feature .credit {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0 7.5px;
}

#feature .credit04 .credit ul {
  justify-content: left;
}

#feature .credit a {
  font-family: "nimbus-sans", sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 12px;
  line-height: 2;
  letter-spacing: 0.005em;
  text-decoration: underline;
  text-underline-offset: 2px;
}

#feature .btn {
  font-family: "nimbus-sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.035em;
  line-height: 1.4;
  text-align: center;
  margin: 162px auto 0;
  padding: 0 4px;
  width: 1400px;
}

#feature .btn a {
  border-bottom: solid 1px #000;
  width: 90px;
  margin: auto;
}
