@charset "UTF-8";
@import url("global.css");
body:not(.is-scroll) #header .header_logo a svg {
  fill: #fff;
}
body:not(.is-scroll) #header #headnavi #headtel {
  color: #fff;
}

#bodyarea {
  background-color: #FBF7F3;
  padding-top: 1px;
}

.parallax {
  overflow: hidden;
}
.parallax p {
  position: relative;
}

#concept_page_title {
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  position: relative;
}
#concept_page_title .ph {
  width: 100%;
  height: 100%;
  height: calc(var(--vh, 1vh) * 100);
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
}
#concept_page_title .ph img {
  object-position: 80% center;
}
#concept_page_title .ontext {
  position: absolute;
  z-index: 1;
  bottom: 6vw;
  left: 12vw;
  color: #fff;
}
#concept_page_title .ontext .catch {
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 28px;
  line-height: 2;
}

#intro {
  margin-top: 100px;
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}
#intro .textarea {
  order: 2;
  margin-left: 8%;
  margin-bottom: 40px;
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  position: relative;
  transition-duration: 1s;
}
#intro .textarea .sub {
  position: relative;
  font-size: 15px;
  padding-left: 40px;
}
#intro .textarea .sub::before {
  content: "";
  background-color: #444;
  width: 30px;
  height: 1px;
  position: absolute;
  left: 0;
  top: 14px;
}
#intro .textarea p + p {
  margin-top: 25px;
}
#intro .textarea .lead {
  font-size: 25px;
  line-height: 1.7;
  margin-top: 15px;
  margin-bottom: 35px;
}
#intro .textarea .illust {
  position: absolute;
  width: 165px;
  top: -20px;
  right: -40px;
}
#intro .ph {
  flex-shrink: 0;
  width: 60%;
  margin-left: -20%;
}
#intro .ph div {
  display: flex;
}
#intro .ph div:first-child {
  align-items: flex-end;
}
#intro .ph div:last-child {
  align-items: flex-start;
}
#intro .ph div p {
  margin: 12px;
  opacity: 0;
  transition: all 1s linear;
  filter: blur(10px);
}
#intro .ph div p.is-active {
  filter: blur(0);
  opacity: 1;
}
#intro .ph div p.img1 {
  margin-left: -50px;
  transition-duration: .8s;
}
#intro .ph div p.img2 {
  transition-duration: .8s;
}
#intro .ph div p.img3 {
  transition-duration: 1s;
}
#intro .ph div p.img4 {
  transition-duration: .8s;
  transition-delay: .3s;
}

#policy {
  margin-top: 140px;
}
#policy .toparea {
  position: relative;
  height: 500px;
}
#policy .toparea .ph {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#policy .toparea .wrapper {
  position: relative;
  height: 100%;
}
#policy .toparea .title {
  position: absolute;
  z-index: 1;
  left: 70px;
  top: -50px;
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
}
#policy .toparea .title span {
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
  text-orientation: upright;
  display: inline-block;
  letter-spacing: .4em;
  background-color: #fff;
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 26px;
  letter-spacing: .1em;
  margin-right: 5px;
  padding: .5em .1em;
}
#policy .wrapper.wide {
  max-width: 1500px;
}
#policy .content {
  margin-top: 90px;
}
#policy .content .item {
  display: flex;
}
#policy .content .item + .item {
  margin-top: 100px;
}
#policy .content .item .ph {
  flex-shrink: 0;
  order: -1;
  width: 60%;
  margin-right: 5%;
}
#policy .content .item .textarea {
  position: relative;
}
#policy .content .item .textarea::before, #policy .content .item .textarea::after {
  content: "";
  background-color: #C1C1C1;
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
}
#policy .content .item .textarea::before {
  top: 0;
}
#policy .content .item .textarea::after {
  bottom: 0;
}
#policy .content .item .textarea .num {
  position: absolute;
  display: inline-block;
  background-color: #FBF7F3;
  font-family: "Lateef", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 21px;
  top: -10px;
  left: 0;
  padding-right: 20px;
  line-height: 1;
}
#policy .content .item .textarea .inner {
  display: flex;
  justify-content: center;
  flex-direction: column;
  height: 100%;
}
#policy .content .item .textarea .inner .title {
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 20px;
}

#footer {
  transform: none;
  opacity: 1;
  filter: none;
}

/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-1 (1400px)

------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 1400px) {
  #intro .ph {
    width: 55%;
    margin-left: 0;
  }
  #intro .textarea {
    margin-left: 5%;
  }
}
/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-2 ( 1300px )

------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 1300px) {
  #concept_page_title .ontext {
    left: 9vw;
  }

  #intro .textarea .illust {
    display: none;
  }
  #intro .textarea p {
    font-size: 14px;
  }
  #intro .ph div p {
    margin: 5px;
  }

  #policy .toparea {
    height: 430px;
  }
  #policy .content .item > .item {
    margin-top: 70px;
  }
  #policy .content .item .ph {
    width: 55%;
    min-height: 470px;
  }
  #policy .content .item .textarea .inner p {
    font-size: 14px;
  }
}
/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-3 ( 960px )

------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 959px) {
  #intro {
    display: block;
    margin-top: 60px;
  }
  #intro .textarea {
    margin: 0;
  }
  #intro .ph {
    width: auto;
    margin: 30px 0 0;
  }
  #intro .ph div p.img1 {
    margin-left: -6vw;
  }
  #intro .ph div p.img4 {
    margin-right: -6vw;
  }
}
/* ------------------------------------------------------------------------------------------------------------------------

 Responsive-Breakpoint-4 ( 644px )
 
------------------------------------------------------------------------------------------------------------------------ */
@media only screen and (max-width: 644px) {
  #concept_page_title {
    height: calc(var(--vh, 1vh) * 80);
  }
  #concept_page_title .ph {
    height: calc(var(--vh, 1vh) * 80);
  }
  #concept_page_title .ph img {
    object-position: 50% center;
  }
  #concept_page_title .ontext {
    bottom: 10vw;
  }
  #concept_page_title .ontext .catch {
    font-size: 22px;
    line-height: 1.6;
  }

  #intro {
    margin-top: 40px;
  }
  #intro .textarea .sub {
    font-size: 13px;
    padding-left: 35px;
  }
  #intro .textarea .sub::before {
    top: 10px;
    width: 25px;
  }
  #intro .textarea .lead {
    font-size: 19px;
    font-weight: 500;
    margin: 10px 0;
  }
  #intro .textarea p {
    font-size: 13px;
  }
  #intro .textarea p + p {
    margin-top: 15px;
  }
  #intro .ph div p {
    margin: 3px;
  }
  #intro .ph div p.img1 {
    margin-left: -3px;
  }
  #intro .ph div p.img4 {
    margin-right: -3px;
  }

  #policy {
    margin-top: 100px;
  }
  #policy .toparea {
    height: 50vw;
  }
  #policy .toparea .ph img {
    object-position: 78% center;
  }
  #policy .toparea .title {
    left: 30px;
    top: -30px;
  }
  #policy .toparea .title span {
    font-size: 18px;
  }
  #policy .content {
    margin-top: 50px;
  }
  #policy .content .item {
    display: block;
  }
  #policy .content .item + .item {
    margin-top: 60px;
  }
  #policy .content .item .ph {
    width: auto;
    margin: 0 0 15px;
    min-height: initial;
  }
  #policy .content .item .textarea::before, #policy .content .item .textarea::after {
    display: none;
  }
  #policy .content .item .textarea .num {
    position: static;
    margin-bottom: 12px;
    font-size: 16px;
    border-bottom: 1px solid #444;
    padding: 0 0 3px;
  }
  #policy .content .item .textarea .inner .title {
    font-size: 17px;
    margin-bottom: 12px;
  }
  #policy .content .item .textarea .inner p {
    font-size: 13px;
  }
}
