/*--- var ---*/
.w100 {
  max-width: 100%;
  height: auto; }

.w100p {
  width: 100%;
  height: auto; }

/*--- reset ---*/
html {
  /*position:relative; min-height:100%;*/
  font-size: 10px; }

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, p, blockquote, hr, header, footer, nav, aside, section {
  margin: 0;
  padding: 0; }

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  font-size: 100%; }

address, caption, cite, code, dfn, h1, h2, h3, h4, th, var {
  font-style: normal;
  font-weight: normal; }

fieldset, img, abbr {
  border: 0; }

img {
  vertical-align: top; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0;
  margin: 0 auto; }

th, td {
  margin: 0;
  padding: 0; }

th, td {
  text-align: left;
  vertical-align: top; }

caption, th {
  text-align: left;
  margin: auto; }

object, embed {
  vertical-align: top; }

legend {
  display: none; }

header, footer, main, article, section, nav, aside {
  display: block; }

button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  margin: 0;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 400;
  font-style: normal;
  background-color: transparent;
  border: none;
  border-radius: 0;
  cursor: pointer; }
  button:focus {
    outline: none; }

hr {
  border: none;
  border-top: 1px #595757 solid; }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent; }
  *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }

a:link, a:focus, a:visited, a:hover {
  color: #595757;
  text-decoration: none;
  outline: none; }

body {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 400;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  color: #595757;
  font-size: 1.4rem;
  line-height: 1.7857;
  background-color: #f5f3f1; }

#wrapper {
  position: relative;
  width: 100%;
  max-width: 575px;
  margin: 0 auto;
  box-shadow: 0 0 20px #e0dad3; }

.header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%; }
  .header-innr {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 10px 20px 20px; }
  .header-logo {
    flex: 0 0 auto;
    width: 130px; }
    .header-logo__catch {
      display: block;
      margin-bottom: 4px;
      color: #215f87;
      font-size: 1rem;
      font-weight: 700;
      white-space: nowrap;
      letter-spacing: 0.1em;
      transform-origin: left center;
      transform: scaleX(0.84); }
  .header-therapist {
    flex: 0 0 auto; }
    .header-therapist__btn {
      display: flex;
      justify-content: center;
      align-items: center;
      position: relative;
      padding: 8px 12px;
      color: #fff !important;
      font-size: 1rem;
      line-height: 1;
      background: linear-gradient(to top, #4d9d88 0%, #cae50b 100%);
      border-radius: 50px;
      box-shadow: 4px 3px 5px rgba(89, 87, 87, 0.5); }
      .header-therapist__btn:before {
        content: '';
        display: block;
        position: absolute;
        top: 1px;
        right: 1px;
        bottom: 1px;
        left: 1px;
        background: linear-gradient(-10deg, #5abba1 0%, #cae50b 100%);
        border-radius: 50px; }
      .header-therapist__btn-label {
        flex: 0 0 auto;
        position: relative; }

.main {
  background-color: #fffaee; }

.fv {
  position: relative;
  width: 100%;
  height: 100vh;
  height: calc(var(--vh) * 100); }
  .fv-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none; }
    .fv-bg-swip {
      height: 100%; }
      .fv-bg-swip__img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 8s linear; }
        .swiper-slide-active .fv-bg-swip__img, .swiper-slide-prev .fv-bg-swip__img {
          transform: scale(1.1); }
  .fv-innr {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    width: 100%;
    height: 100%;
    padding: 66px 20px 60px; }
    .ptn-b .fv-innr {
      justify-content: flex-start;
      padding-top: 75px; }
      @media screen and (max-height: 628px) {
        .ptn-b .fv-innr {
          padding-top: 70px; } }
    @media screen and (max-height: 628px) {
      .fv-innr {
        padding-bottom: 50px; } }
  .fv-catch {
    flex: 0 0 auto;
    margin: auto 0; }
    .ptn-b .fv-catch {
      flex: 1 1 auto;
      display: flex;
      flex-direction: column;
      align-items: center;
      padding-bottom: 10px;
      margin-top: 0;
      margin-bottom: auto; }
    .fv-catch__first {
      display: block;
      margin-bottom: 1em;
      font-family: source-han-serif-japanese, serif;
      font-weight: 400;
      font-style: normal;
      font-size: 1.9rem;
      font-weight: 500;
      line-height: 1;
      opacity: 0;
      transform: translateY(20px);
      filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 4px #fff); }
      .ptn-b .fv-catch__first {
        font-size: 1.7rem; }
        @media screen and (max-height: 628px) {
          .ptn-b .fv-catch__first {
            font-size: 1.4rem; } }
      .wf-active .fv-catch__first {
        transition: opacity 0.4s 1.2s, transform 0.8s 1.2s cubic-bezier(0, 0, 0, 1);
        opacity: 1;
        transform: translateY(0); }
      @media screen and (max-height: 628px) {
        .fv-catch__first {
          margin-bottom: 0.7em;
          font-size: 1.7rem; } }
    .fv-catch__img-txt {
      display: block;
      width: 70.746268%;
      max-width: 350px;
      opacity: 0;
      transform: translateY(20px);
      filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 4px #fff); }
      .ptn-b .fv-catch__img-txt {
        flex: 0 0 auto;
        width: 88.9552%;
        margin-top: auto;
        margin-bottom: auto; }
      .wf-active .fv-catch__img-txt {
        transition: opacity 0.4s 2.3s, transform 0.8s 2.3s cubic-bezier(0, 0, 0, 1);
        opacity: 1;
        transform: translateY(0); }
      @media screen and (max-height: 628px) {
        .fv-catch__img-txt {
          width: 60.746268%; } }
  .fv-intro {
    flex: 0 0 auto;
    padding: 10px;
    margin-bottom: 12px;
    text-align: center;
    line-height: 1.5;
    background-color: rgba(255, 255, 255, 0.6);
    opacity: 0;
    transform: translateY(20px); }
    @media screen and (max-height: 628px) {
      .fv-intro {
        font-size: 1.2rem; } }
    .wf-active .fv-intro {
      transition: opacity 0.4s 3.5s, transform 0.8s 3.5s cubic-bezier(0, 0, 0, 1);
      opacity: 1;
      transform: translateY(0); }
    .fv-intro__ttl {
      display: flex;
      justify-content: center;
      align-items: center;
      height: 40px;
      margin-bottom: 4px;
      font-family: source-han-serif-japanese, serif;
      font-weight: 400;
      font-style: normal;
      font-size: 2.2rem;
      font-weight: 600; }
      .fv-intro__ttl-leave {
        flex: 0 0 auto; }
      .fv-intro__ttl-label {
        flex: 0 0 auto;
        margin: 0 8px; }
      @media screen and (max-height: 628px) {
        .fv-intro__ttl {
          height: 26px;
          font-size: 1.8rem; }
          .fv-intro__ttl-leave {
            height: 100%; }
            .fv-intro__ttl-leave .w100 {
              max-height: 100%;
              width: auto; } }
  .fv-point-present {
    margin-bottom: 14px;
    opacity: 0;
    transform: translateY(20px); }
    .wf-active .fv-point-present {
      transition: opacity 0.4s 3.7s, transform 0.8s 3.7s cubic-bezier(0, 0, 0, 1);
      opacity: 1;
      transform: translateY(0); }
    @media screen and (max-height: 628px) {
      .fv-point-present {
        width: 80%;
        margin: 0 auto 10px; } }
  .fv-cv {
    margin-right: -10px;
    margin-left: -10px;
    opacity: 0;
    transform: translateY(20px); }
    .wf-active .fv-cv {
      transition: opacity 0.4s 3.9s, transform 0.8s 3.9s cubic-bezier(0, 0, 0, 1);
      opacity: 1;
      transform: translateY(0); }
  .fv-scrolldown {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transform: translateY(20px); }
    .wf-active .fv-scrolldown {
      transition: opacity 0.4s 4.1s, transform 0.8s 4.1s cubic-bezier(0, 0, 0, 1);
      opacity: 1;
      transform: translateY(0); }
    .fv-scrolldown-anch {
      display: block;
      padding: 12px 0;
      font-family: source-han-serif-japanese, serif;
      font-weight: 400;
      font-style: normal;
      color: #fb7180 !important;
      font-size: 1.2rem;
      font-weight: 700;
      text-align: center;
      line-height: 1;
      letter-spacing: 0.05em;
      background-color: rgba(255, 255, 255, 0.6); }
      .fv-scrolldown-anch:before, .fv-scrolldown-anch:after {
        content: '';
        display: inline-block;
        width: 8px;
        height: 8px;
        margin: 0 12px;
        border: 2px solid #fb7180;
        border-top: none;
        border-left: none;
        transform-origin: center;
        transform: translateY(-2px) rotate(45deg); }

.cv-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 60px;
  background: linear-gradient(to top, #4d9d88 0%, #cae50b 100%);
  border-radius: 30px;
  box-shadow: 4px 4px 4px rgba(89, 87, 87, 0.6); }
  .cv-btn:before, .cv-btn:after {
    content: '';
    display: block;
    position: absolute;
    top: calc(50% - 1px);
    right: 20px;
    z-index: 1;
    width: 12px;
    height: 2px;
    background-color: #fff;
    border-radius: 1px;
    transform-origin: center right; }
  .cv-btn:before {
    transform: rotate(36deg); }
  .cv-btn:after {
    transform: rotate(-36deg); }
  .cv-btn__bg {
    display: block;
    position: absolute;
    top: 2px;
    right: 2px;
    bottom: 2px;
    left: 2px;
    background: linear-gradient(-10deg, #5abba1 0%, #cae50b 100%);
    border-radius: 30px; }
  .cv-btn__up, .cv-btn__bott {
    flex: 0 0 auto;
    position: relative;
    color: #fff;
    line-height: 1; }
  .cv-btn__up {
    margin-bottom: 6px;
    font-size: 1.3rem; }
  .cv-btn__bott {
    font-size: 2rem; }
  @media screen and (max-height: 628px) {
    .cv-btn {
      height: 50px; }
      .cv-btn__bott {
        font-size: 1.8rem; } }

.sec {
  padding: 40px 20px; }
  .sec--has-bgc {
    background-color: #5abba1; }
  .sec-ttl {
    padding-bottom: 12px;
    margin-bottom: 30px;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.05em;
    text-align: center; }
    .sec--has-bgc .sec-ttl {
      color: #fff; }
  .sec-pink-ttl {
    margin-bottom: 24px;
    font-family: source-han-serif-japanese, serif;
    font-weight: 400;
    font-style: normal;
    color: #fb7180;
    font-size: 2.6rem;
    font-weight: 600;
    text-align: center; }
  @media screen and (max-width: 320px) {
    .sec {
      padding: 40px 15px; }
      .sec-ttl {
        font-size: 1.8rem; }
      .sec-pink-ttl {
        font-size: 2.2rem; } }

.app-view-lead {
  margin-bottom: 20px;
  color: #fffaee;
  text-align: center; }
  .app-view-lead__marker {
    display: inline-block;
    position: relative;
    width: 235px; }
    .app-view-lead__marker:after {
      content: '';
      display: block;
      position: absolute;
      bottom: -4px;
      left: 0;
      width: 100%;
      height: 8px;
      background: url(../img/bg_ttl-under_235.svg) center top no-repeat; }
.app-view-swip {
  width: 308px;
  padding: 0 29px;
  margin: 0 auto; }
  @media screen and (max-height: 628px) {
    .app-view-swip {
      width: 100%; } }
  .app-view-swip:before, .app-view-swip:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    width: 20px; }
  .app-view-swip:before {
    left: 0;
    background: linear-gradient(to right, #5abba1, rgba(90, 187, 161, 0) 100%); }
  .app-view-swip:after {
    right: 0;
    background: linear-gradient(to right, rgba(90, 187, 161, 0), #5abba1 100%); }
  .app-view-swip .swiper-slide {
    text-align: center; }
  .app-view-swip-nav {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 3;
    width: 100%; }
    .app-view-swip-nav__btn {
      position: absolute;
      top: 0;
      width: 40px;
      height: 40px;
      background-color: #e4e4e4;
      border-radius: 50%;
      transform: translateY(-50%); }
      .app-view-swip-nav__btn:before, .app-view-swip-nav__btn:after {
        content: '';
        display: block;
        position: absolute;
        top: calc(50% - 1px);
        left: calc(50% - 6px);
        width: 12px;
        height: 2px;
        background-color: #fff;
        border-radius: 1px; }
      .app-view-swip-nav__btn.prev {
        left: 0; }
        .app-view-swip-nav__btn.prev:before, .app-view-swip-nav__btn.prev:after {
          transform-origin: left center; }
        .app-view-swip-nav__btn.prev:before {
          transform: rotate(-36deg); }
        .app-view-swip-nav__btn.prev:after {
          transform: rotate(36deg); }
      .app-view-swip-nav__btn.next {
        right: 0; }
        .app-view-swip-nav__btn.next:before, .app-view-swip-nav__btn.next:after {
          transform-origin: right center; }
        .app-view-swip-nav__btn.next:before {
          transform: rotate(-36deg); }
        .app-view-swip-nav__btn.next:after {
          transform: rotate(36deg); }

.ptn-b .medias {
  padding-top: 50px;
  padding-bottom: 90px; }
.medias-lead {
  margin-bottom: 24px;
  color: #fff;
  font-size: 1.5rem;
  text-align: center;
  line-height: 1.7;
  letter-spacing: 0.05em; }
  .ptn-b .medias-lead {
    margin-bottom: 50px;
    color: #595757; }
.medias-list {
  display: flex;
  flex-wrap: wrap;
  margin-right: -6px;
  margin-bottom: -12px;
  margin-left: -6px; }
  .medias-list__item {
    flex: 0 0 auto;
    width: 33.3333%;
    padding-right: 6px;
    padding-left: 6px;
    margin-bottom: 12px; }

.users-voice {
  padding-bottom: 0; }
  .ptn-b .users-voice {
    padding-top: 90px;
    padding-bottom: 90px; }
  .users-voice .sec-ttl {
    background: url(../img/bg_ttl-under_216.svg) center bottom no-repeat;
    background-size: 216px auto; }
    .ptn-b .users-voice .sec-ttl {
      margin-bottom: 90px; }
  .users-voice-swip {
    width: calc(266px + 40px);
    padding: 0 20px;
    margin: 0 auto 32px; }
    .users-voice-swip:before, .users-voice-swip:after {
      content: '';
      display: block;
      position: absolute;
      top: 0;
      bottom: 0;
      z-index: 2;
      width: 20px; }
    .users-voice-swip:before {
      left: 0;
      background: linear-gradient(to right, #fffaee, rgba(255, 250, 238, 0) 100%); }
    .users-voice-swip:after {
      right: 0;
      background: linear-gradient(to right, rgba(255, 250, 238, 0), #fffaee 100%); }
    .ptn-b .users-voice-swip:before {
      background: linear-gradient(to right, #5abba1, rgba(90, 187, 161, 0) 100%); }
    .ptn-b .users-voice-swip:after {
      background: linear-gradient(to right, rgba(90, 187, 161, 0), #5abba1 100%); }
    @media screen and (max-width: 320px) {
      .users-voice-swip {
        width: 100%; } }
    .users-voice-swip-nav {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      z-index: 3; }
      .users-voice-swip-nav__btn {
        position: absolute;
        top: 80px;
        width: 40px;
        height: 40px;
        background-color: #e4e4e4;
        border-radius: 50%;
        transform: translateY(-50%); }
        .users-voice-swip-nav__btn:before, .users-voice-swip-nav__btn:after {
          content: '';
          display: block;
          position: absolute;
          top: calc(50% - 1px);
          left: calc(50% - 6px);
          width: 12px;
          height: 2px;
          background-color: #fff;
          border-radius: 1px; }
        .users-voice-swip-nav__btn.prev {
          left: 0; }
          .users-voice-swip-nav__btn.prev:before, .users-voice-swip-nav__btn.prev:after {
            transform-origin: left center; }
          .users-voice-swip-nav__btn.prev:before {
            transform: rotate(-36deg); }
          .users-voice-swip-nav__btn.prev:after {
            transform: rotate(36deg); }
        .users-voice-swip-nav__btn.next {
          right: 0; }
          .users-voice-swip-nav__btn.next:before, .users-voice-swip-nav__btn.next:after {
            transform-origin: right center; }
          .users-voice-swip-nav__btn.next:before {
            transform: rotate(-36deg); }
          .users-voice-swip-nav__btn.next:after {
            transform: rotate(36deg); }
  .users-voice__face {
    position: relative;
    width: 60.1504%;
    padding: 10px;
    margin: 0 auto 18px;
    background: linear-gradient(-10deg, #5abba1 0%, #cae50b 100%);
    border-radius: 50%; }
    .ptn-b .users-voice__face {
      margin-bottom: 60px; }
    .users-voice__face:before {
      content: '';
      display: block;
      position: absolute;
      top: 4px;
      right: 4px;
      bottom: 4px;
      left: 4px;
      background-color: #fffaee;
      border-radius: 50%; }
    .users-voice__face-img {
      position: relative;
      width: 100%;
      height: auto;
      border-radius: 50%; }
  .users-voice__comm {
    display: block;
    text-align: center;
    line-height: 1.4; }
    .ptn-b .users-voice__comm {
      color: #fffaee;
      line-height: 1.9286; }

.outline {
  margin-right: -20px;
  margin-left: -20px; }
  .ptn-b .outline {
    margin-right: 0;
    margin-left: 0; }
  @media screen and (max-width: 320px) {
    .outline {
      margin-right: -15px;
      margin-left: -15px; }
      .ptn-b .outline {
        margin-right: 0;
        margin-left: 0; } }
  .outline-point {
    display: flex;
    justify-content: space-around;
    max-width: 410px;
    margin: 0 auto 40px; }
    .outline-point__item {
      flex: 0 0 auto; }
    .outline-point__img {
      width: 100px;
      margin: 0 auto 14px; }
    .outline-point__lead {
      display: block;
      font-family: source-han-serif-japanese, serif;
      font-weight: 400;
      font-style: normal;
      color: #fffaee;
      font-weight: 300;
      text-align: center;
      line-height: 1.3571; }
      .ptn-b .outline-point__lead {
        color: #595757; }
  .outline-message {
    position: relative;
    width: 92%;
    max-width: 320px;
    padding: 14px;
    margin: 0 auto 50px;
    border: 2px solid #595757;
    border-right: none; }
    .ptn-b .outline-message {
      margin-bottom: 24px; }
    .outline-message:before {
      content: '';
      display: block;
      position: absolute;
      top: 3px;
      right: 3px;
      bottom: 3px;
      left: 3px;
      border: 2px solid #595757;
      border-right: none; }
    .outline-message-leaves {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
      .outline-message-leaves__item {
        position: absolute; }
        .outline-message-leaves__item.lb {
          bottom: 2px;
          left: -16px; }
        .outline-message-leaves__item.rt {
          top: 8px;
          right: -18px; }
    .outline-message__txt {
      width: 225px;
      color: #fff;
      line-height: 2.2857;
      font-feature-settings: 'palt';
      letter-spacing: 0.05em; }
      .ptn-b .outline-message__txt {
        color: #595757; }
      @media screen and (max-width: 320px) {
        .outline-message__txt {
          font-size: 1.2rem; } }
    .outline-message__img {
      position: absolute;
      top: -21px;
      right: -13px;
      width: 133px; }
      @media screen and (max-width: 320px) {
        .outline-message__img {
          width: 113px; } }
  .outline-caution {
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin: 0 auto 16px;
    font-size: 1.1rem;
    line-height: 1.6364; }
  .outline-river {
    margin-right: -20px;
    margin-left: -20px;
    pointer-events: none; }
    @media screen and (max-width: 320px) {
      .outline-river {
        margin-right: -15px;
        margin-left: -15px; } }
    .outline-river-wrap {
      transition-timing-function: linear; }

.price {
  text-align: center; }
  .price .sec-ttl {
    background: url(../img/bg_ttl-under_216.svg) center bottom no-repeat;
    background-size: 216px auto; }
  .price-list {
    width: 300px;
    margin: 18px auto 0; }
    .ptn-b .price-list {
      margin-top: 48px;
      margin-bottom: 48px; }
    .price-list__g {
      display: flex;
      justify-content: center;
      align-items: center;
      padding-bottom: 2px;
      margin-bottom: 15px;
      background: linear-gradient(to right, #fb7180 0%, #fbc37b 100%); }
    .price-list__head, .price-list__body {
      flex: 0 0 auto;
      color: #fffaee;
      font-size: 1.9rem;
      font-weight: 500; }
    .price-list__head {
      position: relative;
      width: 6em;
      padding-right: .5em; }
      .price-list__head:after {
        content: ':';
        position: absolute;
        top: -.1em;
        right: .25em; }
    @media screen and (max-width: 320px) {
      .price-list {
        width: 100%; }
        .price-list__head, .price-list__body {
          font-size: 1.7rem; } }

.attention {
  margin-top: 20px;
  font-size: 1.1rem; }

.ptn-b .situation {
  padding-top: 50px;
  padding-bottom: 50px; }
.situation .sec-ttl {
  background: url(../img/bg_ttl-under_288.svg) center bottom no-repeat;
  background-size: 288px auto; }
  .ptn-b .situation .sec-ttl {
    margin-bottom: 50px; }
.situation-list {
  width: 300px;
  margin: 0 auto; }
  .situation-list__item:not(:nth-last-of-type(1)) {
    margin-bottom: 15px; }
  .situation-list__innr {
    display: flex;
    justify-content: space-around;
    align-items: center;
    width: 100%;
    height: 50px;
    background-color: #fffaee;
    border: 1px solid #595757; }
  .situation-list__img {
    flex: 0 0 auto;
    margin: 0 auto; }
  .situation-list__txt {
    flex: 0 1 auto;
    font-size: 1.5rem; }
  @media screen and (max-width: 320px) {
    .situation-list {
      width: 100%; }
      .situation-list__txt {
        font-size: 1.4rem; } }

.onlyu {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
  height: calc(var(--vh) * 100);
  padding: 40px; }
  .onlyu-bg {
    position: absolute;
    top: 20px;
    right: 20px;
    bottom: 20px;
    left: 20px; }
    .onlyu-bg__img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  .onlyu-ttl, .onlyu-body {
    flex: 0 0 auto;
    position: relative; }
  .onlyu-ttl {
    margin-right: -10px;
    margin-left: -5px;
    text-align: left;
    white-space: nowrap;
    letter-spacing: -.02em; }
    .onlyu-ttl .js_show__item {
      filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 4px #fff); }
  .onlyu-body {
    width: 100%; }
    .onlyu-body p {
      line-height: 1.7857; }
      .onlyu-body p:not(:nth-last-of-type(1)) {
        margin-bottom: 1em; }

.promise {
  color: #fff;
  line-height: 1.5; }
  .promise-ttl {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 30px;
    font-family: source-han-serif-japanese, serif;
    font-weight: 400;
    font-style: normal;
    color: #fffaee;
    font-size: 2.4rem;
    text-align: center;
    line-height: 1.4167; }
    .promise-ttl__leave {
      flex: 0 0 auto; }
    .promise-ttl__label {
      flex: 0 0 auto;
      margin: 0 8px; }
    @media screen and (max-width: 320px) {
      .promise-ttl {
        font-size: 2.2rem; } }
  .promise-insec:not(:nth-last-of-type(1)) {
    margin-bottom: 30px; }
  .promise-insec__img {
    margin-bottom: 14px; }
  .promise-insec-ttl {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 10px; }
    .promise-insec-ttl__icon {
      font-size: 0 0 auto;
      margin-right: 8px; }
    .promise-insec-ttl__label {
      font-size: 0 1px auto;
      color: #fffaee;
      font-size: 1.8rem;
      font-weight: 500; }

.comparison-table {
  table-layout: fixed;
  border-collapse: separate;
  border: 2px solid #595757;
  border-radius: 12px;
  overflow: hidden; }
  .comparison-table thead th, .comparison-table thead td {
    width: 25%;
    padding: 4px 8px;
    font-weight: 500;
    text-align: center;
    vertical-align: middle;
    line-height: 1.0714;
    border-bottom: 6px double #595757; }
  .comparison-table thead td {
    background-color: #5abba1;
    border-right: 2px solid #595757; }
  .comparison-table thead th {
    white-space: nowrap; }
    .comparison-table thead th.cl {
      color: #fffaee;
      background-color: #fb7180; }
    .comparison-table thead th:not(:nth-last-of-type(1)) {
      border-right: 2px solid #595757; }
    @media screen and (max-width: 320px) {
      .comparison-table thead th {
        font-size: 1.2rem; } }
  .comparison-table tbody th {
    padding: 6px 4px;
    color: #fffaee;
    font-weight: 500;
    text-align: center;
    vertical-align: middle;
    line-height: 1.1;
    white-space: nowrap;
    background-color: #5abba1;
    border-right: 2px solid #595757;
    border-bottom: 2px solid #595757; }
    .comparison-table tbody th span {
      font-size: 1rem; }
    @media screen and (max-width: 320px) {
      .comparison-table tbody th {
        font-size: 1.2rem; } }
  .comparison-table tbody td {
    padding: 8px 2px;
    font-size: 1.2rem;
    font-weight: 500;
    text-align: center;
    vertical-align: middle;
    line-height: 1.4167;
    border-right: 2px solid #595757;
    border-bottom: 2px solid #595757; }
    @media screen and (max-width: 320px) {
      .comparison-table tbody td {
        font-size: 1.1rem; } }
  .comparison-table tbody tr td:nth-of-type(1) {
    color: #fb7180; }
  .comparison-table tbody tr td:last-child {
    border-right: none; }
  .comparison-table tbody tr:last-child th, .comparison-table tbody tr:last-child td {
    border-bottom: none; }

.faq .sec-ttl {
  background: url(../img/bg_ttl-under_168.svg) center bottom no-repeat;
  background-size: 168px auto; }
.faq-list__g {
  font-weight: 300;
  border: 2px solid #595757;
  background-color: #fffaee;
  border-radius: 12px;
  overflow: hidden; }
  .faq-list__g:not(:nth-last-of-type(1)) {
    margin-bottom: 15px; }
.faq-list__q, .faq-list__a {
  position: relative; }
  .faq-list__q:before, .faq-list__a:before {
    display: block;
    position: absolute;
    top: 6px;
    left: 8px; }
.faq-list__q {
  padding: 8px 4px 8px 25px;
  border-bottom: 1px solid #595757; }
  .faq-list__q:before {
    content: 'Q.'; }
.faq-list__a {
  padding: 10px 12px 10px 25px;
  line-height: 1.5; }
  .faq-list__a:before {
    content: 'A.';
    top: 10px; }

.cta {
  padding-bottom: 20px;
  margin-bottom: -60px; }
  .cta-point {
    margin-bottom: 22px; }
  .cta-innr {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    height: calc(100vh - 40px);
    height: calc(var(--vh) * 100 - 40px);
    padding-bottom: 70px; }
    .cta-innr__bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
      .cta-innr__bg-img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
    .cta-innr__lead, .cta-innr__reg-free, .cta-innr__point {
      position: relative;
      flex: 0 0 auto;
      width: 100%; }
    .cta-innr__lead {
      padding: 22px 12px 0;
      filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 4px #fff); }
    .cta-innr__reg-free {
      margin-top: auto;
      margin-bottom: 12px;
      text-align: center;
      text-shadow: 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff; }

.sticky-cv {
  position: sticky;
  bottom: 0;
  z-index: 100;
  padding: 0 10px;
  opacity: 0;
  transform: translateY(80px); }
  .scrolled .sticky-cv {
    transition: transform 0.6s cubic-bezier(0, 0, 0, 1), opacity 1s;
    opacity: 1;
    transform: translateY(-20px); }

.footer {
  padding-top: 20px;
  background-color: #215f87; }
  .footer-nav {
    padding: 0 20px;
    margin-bottom: 60px; }
    .footer-nav__item:not(:nth-last-of-type(1)) {
      margin-bottom: 8px; }
    .footer-nav__anch {
      color: #fff !important;
      font-weight: 500; }
  .footer-copy {
    padding: 4px 0;
    color: #fff;
    font-weight: 500;
    text-align: center;
    background-color: #113045; }

.js_show__item {
  opacity: 0;
  transform: translateY(20px); }
  .is_show .js_show__item {
    transition: opacity 0.4s, transform 0.8s cubic-bezier(0, 0, 0, 1);
    opacity: 1;
    transform: translateY(0); }

/*# sourceMappingURL=style.css.map */
