@charset "UTF-8";

/*----------------------------------------------------
  #fv
----------------------------------------------------*/
.fv {
  width: 100%;
  height: auto;
  position: relative;
  padding: 0;
  margin-top: 80px;
}

.fv::before {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 47.25%;
}

.fv>svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
}

.fv>svg path {
  transform: scale(calc(1/1880), calc(1/1000));
}

.swiper1 {
  width: calc(100% - 40px);
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  clip-path: url(#mask);
}

.slide-img02::after {
  display: block;
  content: '';
  width: 70%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, .8), rgba(255, 255, 255, 0));
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

.mask-tab,
.mask-sp {
  display: none;
}

.slide-img {
  height: 100%;
}

.slide-img picture,
.slide-img img {
  height: 100%;
  object-fit: cover;
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img {
  animation: blur1 .5s linear 0s;
  animation-fill-mode: both;
}

@keyframes blur1 {
  0% {
    filter: blur(20px);
  }

  100% {
    filter: blur(0);
  }
}

.swiper1 .swiper-pagination {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 48px;
  height: auto;
  position: absolute;
  top: 45%;
  right: 2.5%;
  left: initial;
  bottom: initial;
  transform: translate(0, -50%);
  mix-blend-mode: difference;
  z-index: 2;
}

.swiper1 .swiper-pagination-bullet {
  box-sizing: border-box;
  display: block;
  opacity: 1;
  position: relative;
  transform: scale(.9);
  transition: transform .3s ease;
  width: 48px;
  height: 48px;
  border-radius: 0;
  margin: 10px 4px !important;
  padding: 13px 0;
  background-color: transparent;
  font-weight: 700;
  text-align: center;
  font-size: 1.2rem;
  color: #A7A7A7;
}

.swiper1 .swiper-pagination-bullet+.swiper-pagination-bullet {
  margin-top: 20px;
}

.swiper1 .swiper-pagination-bullet.swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper1 .swiper-pagination-bullet .circle {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

.circle1 {
  stroke-dasharray: 152px;
  stroke-dashoffset: 152px;
  stroke: #A7A7A7;
}

.swiper-pagination-bullet-active .circle {
  transform: scale(1) rotate(-90deg);
}

.swiper-pagination-bullet-active .circle1 {
  animation: sliderPagination 4s linear forwards;
}

@keyframes sliderPagination {
  100% {
    stroke-dashoffset: 0;
  }
}

.fv-ttl {
  width: 35%;
  height: auto;
  position: absolute;
  top: 50%;
  left: 55%;
  transform: translate(0, -50%);
  z-index: 1;
}

.fv-ttl-2 {
  width: 40%;
  top: 50%;
  left: 7.5%;
}

.fv-ttl>picture,
.fv-ttl>img {
  width: 85%;
  padding: 50px 0;
  margin: 0 auto;
  filter: drop-shadow(2px 2px 0px rgba(98, 72, 37, .2));
}

.fv-ttl-1>img {
  width: 75%;
}

.fv-ttl>p {
  display: flex;
  align-items: center;
  font-size: 1.6rem;
  color: #606060;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: .1em;
  padding-left: 5px;
  box-sizing: border-box;
}

.fv-ttl-sub__top::before {
  display: inline-block;
  content: '';
  width: calc(20px * .5);
  height: calc(28px * .5);
  background: url('../icon/icon-dia--orange.svg');
  background-repeat: no-repeat;
  background-position: center;
  margin-right: 8px;
}

.fv-ttl-sub__top::after {
  display: block;
  content: '';
  flex: 1;
  border-top: 4px dotted #FBEAD1;
  margin-left: 10px;
}

.fv-ttl-sub__bottom::after {
  display: inline-block;
  content: '';
  width: calc(20px * .5);
  height: calc(28px * .5);
  background: url('../icon/icon-dia--orange.svg');
  background-repeat: no-repeat;
  background-position: center;
  margin-left: 8px;
}

.fv-ttl-sub__bottom::before {
  display: block;
  content: '';
  flex: 1;
  border-top: 4px dotted #FBEAD1;
  margin-right: 10px;
}

.fv-ttl__1-sub {
  width: 70%;
  position: absolute;
  top: 65%;
  right: -20%;
}

.fv-deco {
  width: 17.5%;
  position: absolute;
  top: 55%;
  right: -7.5%;
  z-index: 2;
}

.fv-logo {
  width: 90%;
  height: auto;
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translate(-50%, 0);
  display: flex;
  align-items: center;
}

.fv-logo>a {
  display: block;
  width: auto;
  height: 46px;
}

.fv-logo>a>picture,
.fv-logo>a>picture>img {
  width: auto;
  height: 100%;
}

.fv-chara {
  width: 240px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  bottom: 5%;
  left: 5%;
  z-index: 1;
  filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, .1));
}

.fv-chara>img {
  width: 48px;
  animation: yurayura 3s linear infinite;
  transform-origin: bottom;
}

@keyframes yurayura {

  0%,
  100% {
    transform: rotate(5deg);
  }

  50% {
    transform: rotate(-5deg);
  }
}

.fv-chara>p {
  width: calc(100% - 62px);
  padding: 10px;
  box-sizing: border-box;
  border-radius: 10px;
  background: rgba(255, 255, 255, 8);
  font-size: 1rem;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  position: relative;
}

.fv-chara>p::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -16px;
  margin-top: -8px;
  border: 8px solid transparent;
  border-right: 8px solid rgba(255, 255, 255, 8);
}

.fv-chara>p>span {
  font-size: 2rem;
  font-weight: 700;
  color: #F4B860;
}

/*----------------------------------------------------
  #news
----------------------------------------------------*/
.news {
  position: relative;
  z-index: 1;
  padding: 120px 0 100px 0;
}

.news::after {
  display: block;
  content: '';
  width: calc(100% - 20px);
  height: calc(100% - 220px);
  position: absolute;
  top: 220px;
  left: 20px;
  background: linear-gradient(45deg, #FBF2E7, #FBF2E7);
  border-radius: 40px 0 0 40px;
}

.news .container {
  max-width: 1440px;
}

.news-col {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.news-box {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}

.news-ttlWrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1;
  margin-bottom: 50px;
}

.news-ttl {
  order: 2;
  margin-bottom: 0;
}

.news-ttl>h2 {
  display: flex;
  align-items: center;
}

.news-ttl>h2::before,
.news-ttl>h2::after {
  display: block;
  content: '';
  width: 24px;
  height: 24px;
  background: url('../img/common/icon-flower--ora.svg');
  background-size: contain;
  background-repeat: repeat;
}

.news-ttl>h2::before {
  margin-right: 10px;
}

.news-ttl>h2::after {
  margin-left: 10px;
}

.new-ttl__img {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  order: 1;
}

.new-ttl__img>img {
  width: 48px;
  margin-bottom: 10px;
}

.news-ttl__bg {
  width: 460px;
  height: auto;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translate(-50%, 0);
}

.bg-circle {
  display: block;
  width: 40%;
  height: auto;
  position: absolute;
  top: 70%;
  left: -10%;
  transform: translate(-0, -50%);
  opacity: .4;
}

.bg-circle::before {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 100%;
}

.bg-circle::after {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background: url("../img/common/bg-circle--ora.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
}

.news-listWrap {
  width: 100%;
  height: auto;
  box-sizing: border-box;
  position: relative;
}

.news-list {
  width: 100%;
  display: flex;
  justify-content: center;
}

.news-blk {
  width: 25%;
  display: flex;
  flex-direction: column;
  position: relative;
  margin: 0 calc(2%/3/2);
  z-index: 1;
}

.news-blk>a {
  display: flex;
  flex-direction: column;
  flex: 1;
  width: 100%;
}

.news-eyecatch {
  width: 100%;
  position: relative;
}

.news-eyecatch::after {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}

.news-eyecatch>img {
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
  border-radius: 20px 20px 0 0;
}

.news-inner {
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: 10px 20px 30px 20px;
  box-sizing: border-box;
  border-radius: 0 0 20px 20px;
  flex: 1;
  background: #fff;
}

.news-inner__ttl {
  display: flex;
  align-items: center;
  padding: 8px 0;
  margin-bottom: 10px;
  border-bottom: 1px solid #eee;
}

.news-inner__ttl>h3 {
  font-size: 1.5rem;
  line-height: 1.8;
  letter-spacing: 0;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}

.news-inner__txt {
  width: 100%;
  font-size: 1.3rem;
  margin-bottom: 20px;
  flex: 1;
}

.news-inner__txt>p {
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
}

.news-inner__taxonomy {
  width: 97.5%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.2rem;
  margin: auto auto 0 auto;
}

.news-category>span:not(:last-of-type) {
  margin-right: 5px;
}

.news-category>span {
  padding: 2.5px 14px;
  background: #201F1E;
  color: #fff;
  border-radius: 2px;
}

.news-date {
  color: #ccc;
}

/*----------------------------------------------------
  about
----------------------------------------------------*/
.about {
  padding-bottom: 0;
}

.about .container {
  z-index: 1;
}

.about-col {
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.about-box {
  width: 47.5%;
}

.about-ttl {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}

.about-ttl>img {
  width: 70px;
}

.about-ttl__inner {
  width: calc(100% - 80px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
}

.about-ttl__inner>h2 {
  width: 100%;
  font-size: 4rem;
  line-height: 1.2;
  margin-bottom: 5px;
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  text-align: right;
}

.about-ttl__inner>h2>img {
  width: 36px;
  height: auto;
  margin-right: 5px;
  position: relative;
}

.about-ttl__inner>h2>span {
  font-size: 6rem;
  color: #F4B860;
  margin-right: 8px;
}

.about-ttl__inner>div {
  display: flex;
  align-items: center;
  width: 100%;
}

.about-ttl__inner>div::before {
  display: block;
  content: '';
  flex: 1;
  border-top: 1px solid #ccc;
  margin-right: 20px;
}

.about-txt>p {
  font-size: 1.8rem;
}

.about-txt>p>span {
  font-size: 3rem;
  margin-right: 5px;
  line-height: 1;
}

.about-txt>p:not(:last-of-type) {
  margin-bottom: 30px;
}

.about-imgWrap {
  width: 40%;
  position: relative;
}

.about-imgWrap-sp {
  display: none;
}

.about-img2 {
  width: 50%;
  position: absolute;
  bottom: -20%;
  right: -25%;
  z-index: 1;
}

.about-circle {
  width: 120px;
  height: auto;
  position: absolute;
  top: -50px;
  right: -50px;
  z-index: 1;
}

.about-circle::after {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 100%;
}

.about-circle__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: 40s linear infinite rotation;
}

.about-circle__img>img {
  height: 100%;
  object-fit: cover;
}

.about-img {
  width: 100%;
  overflow: hidden;
  border-radius: 30px;
  position: relative;
}

.about-img::after {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 100%;
}

.about-img>picture {
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.about-img>picture img {
  height: 100%;
  object-fit: cover;
}

.about-deco {
  width: 40%;
  position: absolute;
  top: 40%;
  left: -20%;
}

.about-bg-circle {
  width: 40%;
  position: absolute;
  top: 30%;
  right: -5%;
  left: initial;
  opacity: .3;
}

.other-bg-circle {
  width: 50%;
  top: 0;
  left: -10%;
  transform: translate(0, 0);
  right: initial;
}

/*----------------------------------------------------
  #other
----------------------------------------------------*/
.other {
  padding: 80px 0 150px 0;
  background: #fff;
  position: relative;
  z-index: 1;
}

.other .container {
  width: 90%;
  max-width: 1100px;
  position: relative;
  z-index: 2;
}

.other .container::after {
  display: block;
  content: '';
  width: 90%;
  height: 75%;
  position: absolute;
  top: 25%;
  left: 20%;
  background: #FBEAD1;
  border-radius: 20px;
  opacity: .5;

}

.other-ttlWrap {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.other-ttlWrap::before,
.other-ttlWrap::after {
  display: block;
  content: '';
  width: 40px;
  height: 40px;
  background: url('../img/common/icon-flower--ora.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  margin-top: -40px;
}

.other-ttlWrap::before {
  margin-right: 10px;
}

.other-ttlWrap::after {
  margin-left: 10px;
}

.other-ttl>h2 {
  line-height: 1.4;
  margin-bottom: 10px;
}

.other-ttl>h2>span {
  font-size: 2.6rem;
}

.other-lead {
  font-size: 2rem;
  text-align: center;
  margin-bottom: 14px;
}

.other-col {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;

}

.other-img {
  width: 37.5%;
  height: auto;
  position: relative;
}

.other-img::after {
  display: block;
  content: '';
  width: 100%;
  height: 0;
  padding-top: 187.6%;
}

.other-img>picture {
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
}

.other-img>picture>img {
  height: 100%;
  object-fit: cover;
}

.other-inner {
  width: 50%;
}

.other-link,
.other-link__box {
  width: 100%;
}

.other-link__box.is-second {
  margin-bottom: 60px !important;
}

.other-link__lead {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  margin-bottom: 5px;
  font-size: 1.8rem;
}

.other-link__lead>p {
  font-size: 2.4rem;
}

.other-link__lead::before {
  display: block;
  content: '';
  width: 1.5px;
  height: 24px;
  border-radius: 50vh;
  background: #ccc;
  transform: rotate(-20deg);
  margin-right: 15px;
}

.other-link__lead::after {
  display: block;
  content: '';
  width: 1.5px;
  height: 24px;
  border-radius: 50vh;
  background: #ccc;
  transform: rotate(20deg);
  margin-left: 15px;
}

.other-link__box:not(:last-of-type) {
  margin-bottom: 20px;
}

.other-link__box>a {
  display: block;
}

@media screen and (max-width:1360px) {
  .fv-logo {
    top: 10px;
  }
}

@media screen and (max-width:1280px) {
  .fv-logo {
    padding: 0 10px;
    box-sizing: border-box;
  }

  .fv-logo>a>picture,
  .fv-logo>a>picture>img {
    height: auto;
    width: 160px;
  }
}

@media screen and (max-width:1200px) {

  .fv-logo>a>picture {
    width: 45%;
  }

  .fv-logo>a>picture>img {
    width: 100%;
  }

  .about-ttl__inner>h2>span {
    font-size: 5rem;
  }

  .about-txt>p:not(:last-of-type) {
    margin-bottom: 14px;
  }
}

@media screen and (max-width:1024px) {
  .fv::before {
    padding-top: 65%;
  }

  .fv-logo {
    top: 0;
  }

  .fv-logo>a>picture {
    width: 25%;
  }

  .fv-deco {
    width: 21.5%;
  }

  /*---about---*/
  .about {
    padding: 100px 0 0 0;
  }

  .about .container {
    width: 65%;
  }

  .about-col {
    flex-direction: column-reverse;
  }

  .about-box {
    width: 100%;
  }

  .about-imgWrap-pc {
    display: none;
  }

  .about-imgWrap-sp {
    display: block;
  }

  .about-imgWrap {
    width: 100%;
    margin-bottom: 40px;
  }

  .about-img::after {
    display: block;
    content: '';
    width: 100%;
    height: 0;
    padding-top: 70%;
  }

  .about-img2 {
    width: 40%;
    right: -17%;
  }

  .about-circle {
    right: initial;
    left: -50px;
  }

  .about-deco {
    display: none;
    width: 35%;
    position: absolute;
    top: -27%;
    left: -4.5%;
  }
}

@media screen and (max-width:896px) {
  .fv::before {
    padding-top: 75%;
  }

  .fv-deco {
    width: 25%;
    top: 65%;
  }

  /*---news---*/
  .news::after {
    display: block;
    content: '';
    width: 100%;
    height: 60%;
    position: absolute;
    top: 57.5%;
    right: 0;
    transform: translate(0, -50%);
    background: linear-gradient(45deg, #FBF2E7, #FBF2E7);
    border-radius: 40px 0 0 40px;
  }

  .news-col {
    flex-direction: column;
  }

  .news-box {
    width: 100%;
  }

  .news-ttlWrap {
    margin-bottom: 30px;
  }

  .news-ttl {
    padding-top: 0;
  }

  .new-ttl__img>img {
    width: 36px;
    margin-bottom: 5px;
  }

  .news-col {
    width: 100%;
  }

  .news-list {
    width: 140%;
  }

  .news-listWrap {
    width: 95vw;
    height: auto;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #F8D6A4 transparent;
    margin: 0 calc(50% - 50vw) 0 0;
    padding-left: 0;
    padding-right: 10%;
    padding-bottom: 40px;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
  }

  .news-listWrap::-webkit-scrollbar {
    width: 8px;
    background-color: #F8D6A4;
  }

  .news-listWrap::after {
    display: none;
  }

  .news-list {
    justify-content: flex-start;
  }

  .bg-circle {
    width: 60%;
    left: -20%;
    opacity: 0.2;
  }

  .news-ttl__bg {
    width: 420px;
    top: -36px;
  }

  /*---about---*/
  .about {
    padding-top: 0;
  }

  .about .container {
    width: 70%;
  }

  .about-deco {
    display: block;
    width: 43%;
    position: absolute;
    top: 32%;
    left: -7.5%;
  }
}

@media screen and (max-width:786px) {
  .fv-ttl>p {
    font-size: 1.2rem;
  }

  /*---news---*/
  .news-list {
    width: 150%;
  }

  .news-listWrap {
    height: auto;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 40px;
    box-sizing: border-box;
  }

  /*---about---*/
  .about .container {
    width: 80%;
  }

  /*---point---*/
  .point__body {
    width: 80%;
  }
}

@media screen and (max-width:680px) {

  .fv>svg path {
    transform: scale(calc(1/680), calc(1/1080));
  }

  .fv-logo {
    display: none;
  }

  .swiper1 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    clip-path: url(#mask-tab);
  }

  .mask-pc,
  .mask-sp {
    display: none;
  }

  .mask-tab {
    display: block;
  }

  .fv-ttl>p {
    font-size: 1rem;
  }

  /*---news---*/
  .news-list {
    width: 175%;
  }

  /*---about---*/
  .about .container {
    width: 90%;
  }

  .about-deco {
    width: 53%;
    position: absolute;
    top: 35%;
    left: -9.5%;
  }

  /*---other---*/
  .other .container {
    width: 75%;
  }

  .other .container::after {
    width: 100vw;
    left: 10%;
    top: 30%;
  }

  .other-col {
    flex-direction: column;
    align-items: center;
  }

  .other-img {
    width: 60%;
    margin-bottom: 60px;
  }

  .other-inner {
    width: 100%;
  }
}

@media screen and (max-width:480px) {
  #heading {
    top: calc(var(--vh, 1vh) * 105);
  }

  #heading>h1 {
    text-align: left;
    width: 80%;
  }

  #heading>h1>span {
    display: none;
  }

  .fv {
    height: calc(var(--vh, 1vh) * 105);
    margin-top: 60px;
  }

  /*----
  .fv::before {
    padding-top: 216%;
  }
  ---*/

  .fv>svg path {
    transform: scale(calc(1/390), calc(1/844));
  }

  .swiper1 {
    width: calc(100% - 20px);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 10px;
  }

  /*----
  .slide-img01::after,
  .slide-img02::after,
  .slide-img03::after {
    display: block;
    content: '';
    width: 100%;
    height: 70%;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, .6));
    position: absolute;
    top: initial;
    bottom: 0;
    left: 0;
  }
  ---*/

  .slide-img picture,
  .slide-img img {
    object-position: top center;
  }

  .slide-img02::after {
    display: none;
  }

  .slide-img01 picture,
  .slide-img01 img {
    object-position: top center !important;
  }

  .slide-img02 picture,
  .slide-img02 img {
    object-position: top 5% center !important;
  }


  .swiper1 .swiper-pagination {
    display: none;
  }

  .mask-pc,
  .mask-tab {
    display: none;
  }

  .mask-sp {
    display: block;
  }

  .fv-ttl {
    width: 90%;
    left: 50%;
    top: 47.5%;
    transform: translate(-50%, 0);
  }

  .fv-ttl>picture,
  .fv-ttl>img {
    width: 80%;
    padding: 40px 0 !important;
  }

  .fv-ttl-3>img {
    width: auto;
    max-width: 90%;
    height: 80px;
    object-fit: contain;
  }

  .fv-ttl-1>img {
    width: 72.5%;
  }

  .fv-ttl>p {
    font-size: 1rem;
  }

  .fv-ttl-sub__top::before,
  .fv-ttl-sub__bottom::after {
    width: calc(20px* .4);
    height: calc(28px* .4);
  }

  .fv-deco {
    width: 35%;
    top: 80%;
    right: -12.5%;
  }

  .fv-chara {
    width: 210px;
    left: 45%;
    bottom: 10%;
    transform: translateX(-50%);
  }

  .fv-chara>img {
    width: 40px;
  }

  .fv-chara>p {
    width: calc(100% - 62px);
  }

  /*---news---*/
  .news {
    padding: 80px 0;
  }

  .news::after {
    height: 75%;
    top: 55%;
    left: 10px;
    right: initial;
    border-radius: 30px 0 0 30px;

  }

  .news-listWrap::after {
    border-radius: 8px 0 0 8px;
  }

  .news-ttl>p {
    font-size: 1.4rem;
  }

  .news-ttl>h2::before {
    margin-right: 10px;
  }

  .news-ttl>h2::before,
  .news-ttl>h2::after {
    display: block;
    content: '';
    width: 20px;
    height: 20px;
  }

  .news-list {
    width: 300%;
  }

  .news-ttl__bg {
    width: 67.5%;
    top: -26px;
  }

  .new-ttl__img>img {
    width: 26px;
  }

  .bg-circle {
    top: 10%;
  }

  /*---about---*/
  .about-img::after {
    padding-top: 100%;
  }

  .about-img2 {
    width: 40%;
    right: -7%;
    bottom: -12%;
  }

  .about-ttl {
    margin-bottom: 30px;
  }

  .about-ttl>img {
    width: 46px;
  }

  .about-ttl__inner {
    width: calc(100% - 60px);
  }

  .about-ttl__inner>h2>img {
    width: 25px;
    height: auto;
    margin-right: 5px;
    top: 2px;
  }

  .about-ttl__inner>h2 {
    font-size: 2.2rem;
  }

  .about-ttl__inner>h2>span {
    font-size: 3rem;
  }

  .about-txt {
    width: 95%;
    margin: 0 auto;
  }

  .about-txt>p {
    font-size: 1.4rem
  }

  .about-circle {
    width: 120px;
    height: auto;
    position: absolute;
    top: -35px;
    left: -50px;
  }

  .about-bg-circle {
    width: 70%;
    left: initial;
    right: -10%;
  }

  .about-deco {
    width: 100%;
    top: 48%;
    left: -45.5%;
  }

  /*---other---*/
  .other {
    padding: 80px 0 100px 0;
  }

  .other-ttl>h2>span {
    font-size: 1.6rem;
  }

  .other-ttlWrap::before,
  .other-ttlWrap::after {
    margin-top: -30px;
  }

  .other .container {
    width: 85%;
  }

  .other-img {
    width: 70%;
    margin-bottom: 30px;
  }

  .other-link__box.is-second {
    margin-bottom: 20px !important;
  }

  .other-link__lead>p {
    font-size: 1.6rem;
  }

}