.contents {
  margin-top: 0
}

/* common */
#shaan {
  color: #272D3D;
  margin-bottom: 60px
}

html #shaan {
  scroll-behavior: smooth;
}

.shaan-indent,
.shaan-indent p {
  padding-left: 1em;
  text-indent: -1em;
}

.shaan-fs {
  font-size: .8em
}

.shaan-fss {
  font-size: .7em
}

.shaan-column {
  max-width: 60%;
  margin-left: auto;
  margin-right: auto;
  justify-content: flex-start;
}

.shaan-column div {
  line-height: normal!important;
}

.shaan_cs {
  margin-top: 30px;
  font-size: 1.6em;
  text-align: center;
}

.shaan-evtitle {
  margin: 30px 0 10px;
  font-size: 1.3em;
  font-weight: 700;
}

.shaan-s-title {
  margin-bottom: 20px;
  font-size: 2.25em;
  text-align: center;
}

.shaan-s-txt {
  font-size: 14px;
  text-align: left;
}

.shaan-notelist li {
  font-size: 12px;
  padding-left: 1.2rem;
  text-indent: -1.2rem;
}

.shaan-notelist li.no {
  padding-left: 2.2rem;
  text-indent: -2.2rem;
}

.shaan-clm-head p {
  margin-left: auto;
  margin-right: auto;
}

.shaan-clm-head .shaan-sup {
  display: block;
  margin-bottom: 10px;
  font-size: 2.2rem;
  text-align: center;
  line-height: 1;
}

.shaan-clm-head .shaan-main {
  font-size: 3.5rem;
  text-align: center;
  line-height: 1.6;
}

.shaan-clm-head .shaan-main span {
  position: relative;
  display: inline-block;
}

.shaan-clm-head .shaan-main span::before {
  display: block;
  content: "";
  position: absolute;
  bottom: 15px;
  width: 100%;
  height: 15px;
  background-color: #bbe2e8;
  z-index: -1;
}

.shaan-arrow {
  display: block;
  width: 65px;
  margin:0 auto 20px;
}

@media screen and (min-width: 767px) {
  .shaan-u-d-f {
    display: flex
  }

  .shaan-sp {
    display: none
  }
}

@media screen and (max-width: 767.499px) {
  #index .contents {
    order: -1!important;
  }

  .shaan-t-mg {
    margin-top: 40px
  }

  .shaan-s-title {
    font-size: 1.44em;
  }

  .shaan-column {
    max-width: 100%;
  }

  .shaan-clm-head .shaan-main {
    font-size: 2rem;
  }

  .shaan-clm-head .shaan-sup {
    font-size: 1.6rem;
  }

  .shaan-clm-head .shaan-main span::before {
    bottom: 8px;
    height: 10px;
  }
}

/* bg */
.shaan-bg-gray {
  background: #F9F9F9;
  padding: 0 0 6%
}

.shaan-box {
  margin: 0 15px
}

/* ---- shaan LP style ---- */
/* main */
#shaan-main-visual {
  background: url(/product/special/shaan/images/shaan.jpg) center top no-repeat;
  padding-top: 59%;
  background-size: cover;
}
@media screen and (max-width: 767.499px) {
  #shaan-main-visual {
    background: url(/product/special/shaan/images/shaan_sp.jpg) center top no-repeat;
    padding-top: 100%;
    background-size: cover;
  }
}

/* カウントダウン */
#shaan-countdownArea {
  display: flex;
  justify-content: center;
  position: relative;
  padding: 20px;
  margin-bottom: 100px;
  font-size: 1.3em
}

#shaan-countdownArea::before {
  display: block;
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 55%;
  height: 8px;
  background-color: #bbe2e8;
  transform: translateX(-50%);
}

#shaan-countdownArea>div {
  align-items: center;
  display: flex;
}

.shaan-release-day {
  max-width: 616px;
  width: 85%;
  margin: 0 auto 10px;
  padding: 8px 0;
  font-size: 1.8rem;
  text-align: center;
  color: #fff;
  background-color: #004B9E;
  line-height: 1;
}

.shaan-countdown {
  display: flex;
  flex-flow: wrap;
}

.shaan-countdown p:not(:last-child),
#shaan-countdownArea div {
  margin-right: 40px
}

.shaan-countdown>p {
  margin-bottom: 0;
}

.shaan-countdown p {
  text-align: center
}

#shaan-countdown-day,
#shaan-countdown-hour,
#shaan-countdown-min {
  font-size: 4em;
  line-height: 1em;
}

@media screen and (max-width: 767.499px) {

  #shaan-countdown-day,
  #shaan-countdown-hour,
  #shaan-countdown-min {
    font-size: 8vw;
  }

  #shaan-countdownArea::before {
    width: 85%;
  }

  #shaan-countdownArea div:first-child {
    margin-bottom: 15px
  }

  #shaan-countdownArea div {
    margin-right: 0 !important;
    justify-content: center;
  }
}

@media screen and (max-width: 400px) {

  #shaan-countdown-day,
  #shaan-countdown-hour,
  #shaan-countdown-min {
    font-size: 7vw;
  }
}

.shaan-logo {
  display: flex;
  flex-flow: wrap;
  justify-content: center;
  align-items: stretch
}

#shaan-nav li a {
  text-align: center;
  font-size: 1.3vw;
  line-height: 1.2em;
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
  flex: 1;
}

#shaan-nav li {
  display: flex;
  flex-direction: column;
}

#shaan-nav li a>* {
  flex-shrink: 0;
}

#shaan-nav li a i {
  margin-top: auto;
}

#shaan-nav li:not(:last-child) {
  margin-right: 16%;
}

#shaan-nav li>a img {
  max-width: 100%;
  height: auto;
}

@media screen and (min-width: 884px) {
  ul#shaan-nav {
    width: 48%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 767.499px) {
  #shaan-nav li>a {
    font-size: 1em;
    align-items: center;
    flex: 1;
  }

  #shaan-nav li:not(:last-child) {
    margin-right: 9%;
  }

  ul#shaan-nav {
    width: 67%;
    margin: 0 auto;
  }

  ul.shaan-logo {
    display: block;
    width: 70%;
    margin: 0 auto;
  }

  ul.shaan-logo li:not(:last-child) {
    margin-bottom: 40px;
  }

  ul.shaan-logo li img {
    width: 100%;
  }

  .shaan-logo-wrap {
    padding: 7% 5% !important
  }

  .shaan-nav-txt {
    display: none
  }
}

@media screen and (min-width: 767.3px) {
  ul#shaan-nav {
    width: 56%;
    margin: 0 auto;
  }
}

/* sub */
.shaan-sub-L {
  text-align: center;
}

@media screen and (min-width: 767px) {
  .shaan-sub-L {
    width: 27vw;
    font-size: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 50px;
  }

  .shaan-sub-R {
    width: 62.25vw;
    font-size: 1.4em
  }

  .shaan-sub-L img {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 767.499px) {
  .shaan-sub-L {
    font-size: 1.2em;
    margin-bottom: 20px
  }

  .shaan-sub-R {
    font-size: 1.3em;
  }

  .shaan-sub-L img {
    width: 68%;
    margin-bottom: 10px
  }
}

/* event */
.shaan-h2-title {
  font-size: 2em;
  font-family: "TBUDゴシック B", "TBUDGothic B";
}

h2.shaan-h2-title img {
  width: 90px;
  margin-right: 10px
}

.shaan-event-title {
  margin-bottom: 20px;
  text-align: center;
  line-height: 1;
}

.shaan-ev {
  border-radius: 30px;
  padding: 5% 6%
}

.shaan-w30 img,
.shaan-w70 img {
  width: 100%
}

.shaan-guest-contents div:first-child {
  margin-right: 4%
}

.shaan-guest-name {
  border-bottom: 1px solid #272D3D;
  margin-bottom: 15px
}

.shaan-guest-name span {
  font-size: 1.3em;
}

.shaan-btnwrap {
  max-width: 450px;
  width: 100%;
  margin: 0 auto 60px;
  text-align: center;
}

.shaan-btnwrap-title {
  margin-bottom: 20px;
}
.shaan-btnwrap-title img {
  width: 100%;
}

.shaaan-audiobtn {
  position: relative;
  width: 200px;
  cursor: pointer;
  background-color: #F9F9F9;
  /* border: 3px solid #00aeb9;
  padding: 20px 0;
  border-radius: 30px;
  font-size: 18px;
  line-height: 1;
  background-color: #fff; */
  transition: all .2s;
}

.shaaan-audiobtn img {
  max-width: 100%;
}

.shaaan-audiobtn:hover {
  /* border: 3px solid #00aeb9;
  background-color: #00aeb9;
  color: #fff; */
  opacity: 0.7;
}

.shaaan-audiobtn i {
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(0, -50%);
}

@media screen and (max-width: 767.499px) {
  .shaan-h2-title {
    text-align: center;
    margin-bottom: 30px;
    line-height: 1.1em;
  }

  .shaan-sp-title {
    justify-content: center
  }

  .u-ml100.u-font-xxl.shaan-ev-sp-f.u-mb30.u-sp-ma0 {
    font-size: 1.3em !important;
  }

  .shaan-w30 {
    width: 43%
  }

  .shaan-w70 {
    width: 48%
  }
}

@media screen and (min-width: 767px) {
  .shaan-h2-title img {
    width: 19%
  }

  .shaan-w30 {
    width: 26%
  }

  .shaan-w70 {
    width: 70%
  }

  .shaan-guest-name span {
    margin-left: 10px
  }
}

/* ribon title */
.shaan-ribbon {
  display: inline-block;
  position: relative;
  height: 50px;
  line-height: 50px;
  text-align: center;
  padding: 0 16%;
  font-size: 20px;
  background: #FED900;
  color: #272D3D;
  box-sizing: border-box;
  font-family: "TBUDゴシック B", "TBUDGothic B";
}

.shaan-ribbon:before,
.shaan-ribbon:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.shaan-ribbon:before {
  top: 0;
  left: 0;
  border-width: 25px 0px 25px 15px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}

.shaan-ribbon:after {
  top: 0;
  right: 0;
  border-width: 25px 15px 25px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}

/* product */
.product-contents {
  border: 1px solid #C5C5C5;
  border-radius: 30px;
  padding: 4% 4% 2%;
  margin-bottom: 20px
}

.product-contents div:first-child {
  text-align: center;
  font-size: 1.5em;
  justify-content: center;
  align-items: center;
}

.product-contents div:last-child {
  font-size: 1.5em;
  text-align: left;
  line-height: 1.5em;
  lign-items: center
}

.shaan-h3-imgtitle {
  margin-bottom: -80px;
  text-align: center;
}

.shaan-h3-imgtitle img {
  max-width: 800px;
  width: 95%;
}

.product-border {
  margin-bottom: 40px;
  padding: 80px 40px 40px;
  border: 1px solid #C5C5C5;
}

.product-border .product-contents:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 767.499px) {

  .product-contents div:last-child,
  .product-contents div:first-child {
    font-size: 1.2em;
    text-align: center
  }

  .product-contents {
    padding: 5% 4% 2%
  }

  .shaan-h3-imgtitle {
    margin-bottom: -10%;
  }

  .product-border {
    padding: 10% 20px 40px;
  }
}

.shaan-sp-img-width img {
  width: 67% !important;
}

.product-contents div>.btn {
  max-width: 92% !important;
}

/* special */
.shaan-img-80 {
  text-align: center
}

.shaan-img-80 img {
  width: 70%
}

.shaan-sp-title {
  display: flex;
  align-items: center;
}

.shaan-bg-yellow {
  background: #FDF8E5;
  padding: 60px 0
}

ul.shaan-logo li {
  flex-basis: 28%;
}

ul.shaan-logo li img {
  max-width: 100%;
  height: auto;
}

ul.shaan-logo li:not(:last-child) {
  margin-right: 20px
}

.shaan-logo-wrap {
  padding: 20px;
  margin-bottom: 40px;
  background: #fff;
  text-align: center
}

iframe {
  max-width: 100% !important;
}

.shaan-modal-move {
  position: relative;
  width: 60%;
  min-height: 100px;
  overflow-y: auto;
  margin: 0 auto;
}

div#cboxOverlay {
  background: #000;
}

#cboxClose {
  background: url(images/shaan-close.png) no-repeat 0 0 !important
}

@media screen and (min-width: 767px) {
  .shaan-sp-title {
    margin-bottom: 40px
  }

  .shaan-btn_close.shaan-move-close {
    right: 20%
  }

  .shaan-ev-move {
    width: 100%;
    margin: 0 auto
  }
}

@media screen and (max-width: 767.499px) {
  .shaan-sp-title p {
    margin-right: 18px;
  }

  .shaan-sp-img-width img {
    padding: 0 10%;
  }

  h3#kyousan-f {
    font-size: 1.9em !important;
  }

  .shaan-modal-move {
    width: 100%;
  }
}

/* 調査 */
@media screen and (min-width: 767px) {
  .shaan-investigation-h2-title {
    font-size: 4em;
    font-family: "TBUDゴシック B", "TBUDGothic B";
    font-weight: 800;
    color: #0068B7;
    text-align: center;
  }
  .shaan-investigation-bg {
    background-image: url(/product/special/shaan/images/shaan-investigation-bg.png);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
  }
  .shaan-investigation-bg .inner {
    max-width: 1160px;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 80px;
  }
  .shaan-investigation-box01 {
    display: flex;
    padding-bottom: 10px;
  }
  .shaan-investigation-box01 img {
    max-width: 100%;
  }
  .shaan-investigation-box01-inner01 {
    width: 57.5%;
  }
  .shaan-investigation-box01-inner02 {
    width: 42.5%;
    padding-left: 20px;
  }
  .shaan-investigation-box01-inner01-01 {
    display: flex;
    margin-bottom: 10px;
  }
  .shaan-investigation-box01-inner01-01-l {
    width: 55%;
  }
  .shaan-investigation-box01-inner01-01-r {
    width: 45%;
    padding-left: 20px;
  }
  .shaan-investigation-box01-inner01-02 {
  }

  .shaan-investigation-box02 {
    padding-bottom: 10px;
    display: flex;
  }
  .shaan-investigation-box02 img {
    max-width: 100%;
  }
  .shaan-investigation-box02-inner01 {
    width: 40.5%;
  }
  .shaan-investigation-box02-inner01 .img05 {
    padding-bottom: 10px;
  }
  .shaan-investigation-box02-inner02 {
    width: 59.5%;
    padding-left: 20px;
  }
  .shaan-investigation-box02-inner02-01 {
    padding-top: 10px;
    display: flex;
  }
  .shaan-investigation-box02-inner02-01 .shaan-investigation-box02-inner01-01-l {
    width: 41%;
  }
  .shaan-investigation-box02-inner02-01 .shaan-investigation-box02-inner01-01-r {
    width: 59%;
    padding-left: 20px;
  }

  .shaan-investigation-box03 {
    padding-bottom: 10px;
    display: flex;
  }
  .shaan-investigation-box03 img {
    max-width: 100%;
  }
  .shaan-investigation-box03-inner01 {
    width: 57.5%;
  }
  .shaan-investigation-box03-inner02 {
    width: 42.5%;
    padding-left: 20px;
  }
  .shaan-investigation-text {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767.499px) {
  .shaan-investigation-h2-title {
    font-size: 2.8em;
    line-height: 1.4;
    font-family: "TBUDゴシック B", "TBUDGothic B";
    font-weight: 800;
    color: #0068B7;
    text-align: center;
  }
  .shaan-investigation-bg {
    background-image: url(/product/special/shaan/images/shaan-investigation-bg-sp.png);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
  }
  .shaan-investigation-bg .inner {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 80px;
  }
  .shaan-investigation-box01-sp img {
    width: 100%;
    margin-bottom: 10px;
  }
  .shaan-investigation-text {
    font-size: 1.2rem;
  }
}

/* product */
@media screen and (min-width: 767px) {
  .shaan-product-title{
    max-width: 632px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 40px;
  }
  .shaan-product-title img {
    max-width: 100%;
  }
}
@media screen and (max-width: 767.499px) {
  .shaan-product-title{
    max-width: 80%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 60px;
  }
  .shaan-product-title img {
    max-width: 100%;
  }
}

/* メルマガ登録 */
.shaan-mm-bg {
  background: #F0F0F0;
}

/* ribon-white title */
.shaan-ribbon-white {
  display: inline-block;
  position: relative;
  height: 50px;
  line-height: 50px;
  text-align: center;
  padding: 0 16%;
  font-size: 20px;
  background: #fff;
  color: #272D3D;
  box-sizing: border-box;
  font-family: "TBUDゴシック B", "TBUDGothic B";
}

.shaan-ribbon-white:before,
.shaan-ribbon-white:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.shaan-ribbon-white:before {
  top: 0;
  left: 0;
  border-width: 25px 0px 25px 15px;
  border-color: transparent transparent transparent #F0F0F0;
  border-style: solid;
}

.shaan-ribbon-white:after {
  top: 0;
  right: 0;
  border-width: 25px 15px 25px 0px;
  border-color: transparent #F0F0F0 transparent transparent;
  border-style: solid;
}



/* cleaning */
@media screen and (min-width: 767px) {
  .shaan-cleaning-h2-title {
    font-size: 4em;
    font-family: "TBUDゴシック B", "TBUDGothic B";
    font-weight: 800;
    color: #0068B7;
    text-align: center;
  }
  .shaan-investigation-h3-title {
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .shaan-investigation-h3-title .shaan-investigation-h3-title-inner {
    background-color: #0068B7;
    font-size: 1.8em;
    line-height: 1.4;
    font-family: "TBUDゴシック B", "TBUDGothic B";
    font-weight: 500;
    color: #fff;
    padding: 6px 32px;
    border-radius: 28px;
  }
  .shaan-cleaning-bg {
    background-image: url(/product/special/shaan/images/shaan-investigation-bg.png);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
  }
  .shaan-cleaning-bg .inner {
    max-width: 1040px;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 80px;
  }
  .shaan-cleaning-bg .shaan-cleaning-box {
    width: 100%;
    position: relative;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-main {
    width: 100%;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number01 {
    position: absolute;
    top: 48%;
    left: 32%;
    width: 60px;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number01 img {
    width: 100%;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number02 {
    position: absolute;
    bottom: 5%;
    left: 39%;
    width: 60px;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number02 img {
    width: 100%;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number03 {
    position: absolute;
    bottom: 10%;
    right: 21%;
    width: 60px;
  }
  .shaan-cleaning-bg .shaan-cleaning-box .shaan-cleaning-box-number03 img {
    width: 100%;
  }
  .shaan-cleaning-text-box {
    padding: 24px;
    border-radius: 4px;
    background-color: rgba(255, 255, 255, 0.8);
  }

  /* トリガーのエリア */
  .shaan-cleaning-box-wrap {
    position: relative;
  }
  .trigger-area {
    cursor: pointer;
  }
  /* モーダルのスタイル */
  .special-shaan-modal {
    display: none;
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
  }
  .modal-content {
  }
  .modal-content01 {
    width: 260px;
  }
  .modal-content02 {
    width: 420px;
  }
  .modal-content03 {
    width: 420px;
  }

}

@media screen and (max-width: 767.499px) {
  .shaan-cleaning-h2-title {
    font-size: 2.8em;
    line-height: 1.4;
    font-family: "TBUDゴシック B", "TBUDGothic B";
    font-weight: 800;
    color: #0068B7;
    text-align: center;
  }
  .shaan-cleaning-bg {
    background-image: url(/product/special/shaan/images/shaan-investigation-bg-sp.png);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
  }
  .shaan-cleaning-bg .inner {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 80px;
  }
  .shaan-cleaning-text-box {
    padding: 10px;
    border-radius: 4px;
    background-color: rgba(255, 255, 255, 0.8);
  }
  .shaan-cleaning-bg .shaan-cleaning-box img {
    width: 100%;
  }
  .shaan-cleaning-wrap-sp {

  }
  .shaan-cleaning-box-sp {
    margin-top: 40px;
    padding: 40px 24px 24px;
    text-align: center;
    position: relative;
    border: 2px solid #0068B7;
    border-radius: 8px;
    background-color: #F2F7FC;
    box-shadow: 0, 0, 15px, rgba(0, 0, 0, 0.2);
  }
  .shaan-cleaning-box-sp-icon {
    width: 40px;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
  }
  .shaan-cleaning-box-sp-text {
    font-size: 1.8rem;
    font-weight: 700;
    color: #3252A4;
  }
  .shaan-cleaning-box-sp-text .shaan-cleaning-box-sp-text-26 {
    font-size: 2.6rem;
    font-weight: 800;
  }
  .shaan-cleaning-box-sp-text .shaan-cleaning-box-sp-text-08 {
    font-size: .8rem;
    font-weight: 700;
  }
  .shaan-cleaning-box-sp .shaan-cleaning-box-sp-img {
    width: 100%;
  }
}

/* reform */
@media screen and (min-width: 767px) {
  .shaan-reform-title {
    width: 70%;
    margin: 70px auto 0;
  }
  .shaan-reform-title img {
    width: 100%;
  }
  .shaan-reform {
    background-color: #F9F9F9;
  }
  .shaan-reform .inner {
    max-width: 1040px;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 90px;
  }
  .shaan-reform-box {
    position: relative;
  }
  .shaan-reform-box-icon {
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 150px;
    width: 300px;
    height: 300px;
    /* box-shadow: 0 0 25px rgba(0, 0, 0, 0.05);
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center; */
  }
  /* .shaan-reform-box-text {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.5;
    color: #3252A4;
  }
  .shaan-reform-box-text-large {
    font-size: 4rem;
    font-weight: 900;
  }
  .shaan-reform-box-text-large02 {
    font-size: 3.6rem;
    font-weight: 900;
  }
  .shaan-reform-box-text-line {
    position: relative;
    display: inline-block;
  }
  .shaan-reform-box-text-line:before {
    display: block;
    content: "";
    position: absolute;
    bottom: 15px;
    width: 100%;
    height: 15px;
    background-color: #bbe2e8;
    z-index: -1;
  } */
  .shaan-reform-box-img img {
    margin-top: 60px;
    width: 82%;
  }
  .shaan-reform-box-icon02 {
    position: absolute;
    top: 0;
    left: 0;
    width: 300px;
    height: 300px;
    border-radius: 150px;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .shaan-reform-box-img02 img {
    margin-top: 60px;
    width: 82%;
  }
  .shaan-reform-box-img02 {
    margin-top: 60px;
    text-align: right;
  }
}
@media screen and (max-width: 767.499px) {
  .shaan-reform-title {
    width: 90%;
    margin: 60px auto 0;
  }
  .shaan-reform-title img {
    width: 100%;
  }
  .shaan-reform {
    background-color: #F9F9F9;
  }
  .shaan-reform .inner {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 60px 20px 60px;
  }
  .shaan-reform-box {
    position: relative;
    margin: 40px 0 0;
  }
  .shaan-reform-box-icon {
    width: 88%;
    margin: -30px auto 0;
  }
  .shaan-reform-box-icon img {
    width: 100%;
    box-shadow: 0 0 25px rgba(0, 0, 0, 0.05);
  }
  .shaan-reform-box-img img {
    margin-top: 0px;
    width: 100%;
  }
  .shaan-reform-box-icon02 {
    width: 88%;
    margin: -30px auto 0;
  }
  .shaan-reform-box-icon02 img {
    width: 100%;
    box-shadow: 0 0 25px rgba(0, 0, 0, 0.05);
  }
  .shaan-reform-box-img02 img {
    margin-top: 0px;
    width: 100%;
  }
  .shaan-reform-box-img02 {
    text-align: right;
  }
}

/* wave */
svg.shaan-wave {
  width: 100%;
  vertical-align: bottom
}

.shaan-wave2 {
  background: #F9F9F9;
  width: 100%
}

.shaan-wave3 {
  background: #FDF8E5;
  width: 100%;
  vertical-align: bottom
}

/* Modal Base */
.shaan-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  z-index: 100;
}

.shaan-modal-bg {
  position: absolute;
  height: 100vh;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 101;
}

/* Modal Content */
.shaan-modal-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 95%;
  z-index: 102;
}

@media screen and (max-width: 640px) {
  .shaan-modal-content {
    width: 90vw;
  }
}

.shaan-modal-inner {
  position: relative;
  background: white;
  width: 100%;
  min-height: 100px;
  max-height: 84vh;
  overflow-x: hidden;
  overflow-y: auto;
}

/* Close Button */
.shaan-btn_close {
  display: block;
  position: absolute;
  top: -50px;
  right: 0;
  width: 40px;
  height: 40px;
  color: #fff;
  text-align: center;
  font-size: 30px;
  text-decoration: none;
  line-height: 35px;
  z-index: 105;
}

/* modal contents */
.shaan-modal-visual {
  padding: 7% 0;
  text-align: center;
}

.shaan-modal-visual img {
  width: 14%;
}

.shaan-modal-visual.shaan-modal-visual2 img {
  width: 10%;
}

.shaan-circle {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: inline-block;
  color: #fff;
  text-align: center;
  line-height: 58px;
  margin-right: 20px
}

.shaan-modal-title img {
  margin: 0 0 0 20px
}

.shaan-modal-title3 {
  color: #fff;
  padding: 20px 40px;
}

.shaan-modal-p {
  padding: 50px
}

.shaan-modal-w80 {
  width: 78%;
  margin-right: 3%
}

.shaan-modal-w80-2 {
  width: 78%;
  margin-left: 3%
}

@media screen and (max-width: 640px) {
  .shaan-modal-w80 {
    width: 100%
  }

  .shaan-modal-title3 {
    font-size: 3vw !important;
    padding: 15px 20px;
  }

  .shaan-modal-p {
    padding: 0 7% 7%;
  }
}

@media screen and (min-width: 1000px) {
  .shaan-nayami-title img {
    width: 50%
  }
}

@media screen and (min-width: 800px) and (max-width: 999px) {
  .shaan-nayami-title img {
    width: 55%
  }
}

/* modal kirei */
.shaan-modal-kirei-bg {
  background: #F1F3F4;
  padding: 10%
}

.shaan-bg-kirei {
  background: #004B9E;
  white-space: nowrap;
  font-size: 2vw;
}

.shaan-bg-kirei2 {
  background: #004B9E;
}

.frame-box-001 {
  padding: 30px;
  position: relative;
}

.frame-box-001::before,
.frame-box-001::after {
  content: '';
  width: 30px;
  height: 30px;
  position: absolute;
}

.frame-box-001::before {
  border-left: solid 10px #E3EAF1;
  border-top: solid 10px #E3EAF1;
  top: 0;
  left: 0;
}

.frame-box-001::after {
  border-right: solid 10px #E3EAF1;
  border-bottom: solid 10px #E3EAF1;
  bottom: 0;
  right: 0;
}

.frame-box-001.frame-red::before {
  border-left: solid 10px #F6F0E5;
  border-top: solid 10px #F6F0E5;
  top: 0;
  left: 0;
}

.frame-box-001.frame-red::after {
  border-right: solid 10px #F6F0E5;
  border-bottom: solid 10px #F6F0E5;
  bottom: 0;
  right: 0;
}

/* modal hiito */
.shaan-w50 {
  width: 47%
}

.shaan-modal-hiito-bg {
  background: #FDF8E5;
  padding: 10%
}

.shaan-bg-hiito {
  background: #E85400;
  white-space: nowrap;
  font-size: 2vw
}

.shaan-bg-hiito2 {
  background: #E85400;
}

.shaan-w50 div p {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
}

.shaan-w50 div>* {
  flex-shrink: 0;
}

.shaan-w50 div p {
  margin-top: auto;
}

.shaan-w50-txt {
  margin-top: 30px;
  font-size: 1.2em;
}

p.u-ta-c.shaan-w50-txt img {
  width: 50%;
}

@media screen and (max-width: 640px) {
  .shaan-w50 {
    width: 100%
  }
}


/* modal suimin */
.shaan-w33 {
  width: 33%
}

/* orangebutton*/
.btn2,
.btn3 {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60%;
  min-height: 60px;
  padding: 15px 25px;
  background: #E85400;
  color: #fff;
  text-align: center;
  line-height: 1.6;
  border-radius: 50px;
}

.btn2 .icon-fix-right,
.btn3 .icon-fix-right {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}

.btn2 .icon-fix-right,
.btn3 .icon-fix-right {
  right: 10px;
}

@media screen and (max-width: 530px) {
  .btn2 {
    width: 85%;
    font-size: 0.9em;
  }
}

@media screen and (max-width: 620px) and (min-width: 531px) {
  .btn2 {
    width: 80%;
    font-size: 1.1em;
  }
}

@media screen and (min-width: 621px) and (max-width: 830px) {
  .btn2 {
    width: 70%;
    font-size: 1.2em;
  }
}

@media screen and (min-width: 831px) {
  .btn2 {
    width: 60vw;
    font-size: 1.8em;
  }
}

@media screen and (min-width: 701px) {
  .btn3 {
    width: 64vw;
    font-size: 1.6em;
  }
}

@media screen and (max-width: 700px) and (min-width: 501px) {
  .btn3 {
    width: 80vw !important;
    font-size: 1.1em
  }
}

@media screen and (max-width: 500px) {
  .btn3 {
    width: 70vw;
  }
}

/*==================================================
じわっ
===================================*/

.blurTrigger.blur{
  animation-name:blurAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
  animation-delay: 0.3s;
}
.blurTrigger.blur.img01 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img02 {
  animation-delay: 0.5s;
}
.blurTrigger.blur.img03 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img04 {
  animation-delay: 0.7s;
}
.blurTrigger.blur.img05 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img06 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img07 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img08 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img09 {
  animation-delay: 0.5s;
}
.blurTrigger.blur.img10 {
  animation-delay: 0.3s;
}
.blurTrigger.blur.img11 {
  animation-delay: 0.5s;
}

@keyframes blurAnime{
  from {
  filter: blur(10px);
  transform: scale(1.02);
  opacity: 0;
  }

  to {
  filter: blur(0);
  transform: scale(1);
  opacity: 1;
  }
}
 
.blurTrigger{
    opacity: 0;
}