/**
* Template Name: Appland - v2.0.0
* Template URL: https://bootstrapmade.com/free-bootstrap-app-landing-page-template/
* Author: BootstrapMade.com
* License: https://bootstrapmade.com/license/
*/

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/
body {
  font-family: "Open Sans", sans-serif;
  color: #47536e;
}

a {
  color: #f892a4;
}

a:hover {
  color: #f08599;
}

button:focus {
  outline: 0;
}

.modal-content {
  border-radius: 6px;
}

.get-started a {
  background: #f892a4;
  color: #fff;
  border-radius: 50px;
  margin: 20px auto 15px;
  padding: 10px 25px;
  display: block;
  width: 200px;
}

.get-started a:hover {
  background: #f08599;
  color: #fff;
  text-decoration: none;
}

@import url(https://fonts.googleapis.com/css?family=Lobster);

a.to-contact-button {
  background-color: #ea537b;
  color: white;
  font-family: "Hiragino Sans", sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  padding: 20px;
  border-radius: var(--border-radius-S);
}

/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/
.back-to-top {
  position: fixed;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50px;
  right: 15px;
  bottom: 15px;
  background: #f892a4;
  color: #fff;
  transition: display 0.5s ease-in-out;
  z-index: 300;
}

.back-to-top i {
  font-size: 24px;
  position: absolute;
  top: 7px;
  left: 8px;
}

.back-to-top:hover {
  color: #fff;
  background: #f08599;
  transition: background 0.2s ease-in-out;
}

/* header */
#header {
  background: white;
}
@media (max-width: 991px) {
  #header {
    background: rgba(255, 255, 255, 0);
    box-shadow: none;
  }

  #header.always-shown,
  #header.header-scrolled,
  #header.shown {
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0px 3px 6px #00000029;
    transition: 0.5s;
  }

  #header:not(.always-shown) .navbar-brand {
    visibility: hidden;
  }

  #header.header-scrolled .navbar-brand,
  #header.shown .navbar-brand {
    visibility: visible;
  }
}

.navbar {
  max-width: 1140px;
  height: 76px; /* for big screen */
  display: flex;
  align-content: center;
}

@media (max-width: 991px) {
  .navbar {
    height: 69px; /* for small screen */
  }
}

.navbar-brand img.logo-image {
  height: 38px;
}

@media (max-width: 991px) {
  .navbar-brand img.logo-image {
    height: 24px;
  }
}

.navbar-light .navbar-nav .nav-link {
  color: #47536e;
  font-family: "Raleway", sans-serif;
}

.navbar-toggler {
  border: none;
}

/* Define the shape and color of the hamburger lines */
.navbar-toggler span {
  display: block;
  background-color: #707070;
  height: 2px;
  width: 26px;
  margin-top: 8px;
  margin-bottom: 8px;
  position: relative;
  left: 0;
  opacity: 1;
  transition: all 0.35s ease-out;
  transform-origin: center left;
}

/**
 * Animate collapse into X.
 */

/* top line rotates 45 degrees clockwise and moves up and in a bit to close the center of the X in the center of the button */
.navbar-toggler:not(.collapsed) span:nth-child(1) {
  transform: translate(15%, 40%) rotate(45deg);
}
/* center line goes transparent */
.navbar-toggler:not(.collapsed) span:nth-child(2) {
  opacity: 0;
}
/* bottom line rotates 45 degrees counter clockwise, in, and down a bit to close the center of the X in the center of the button  */
.navbar-toggler:not(.collapsed) span:nth-child(3) {
  transform: translate(15%, -40%) rotate(-45deg);
}

/**
 * Animate collapse open into hamburger menu
 */

/* top line moves back to initial position and rotates back to 0 degrees */
.navbar-toggler span:nth-child(1) {
  transform: translate(0%, 0%) rotate(0deg);
}
/* middle line goes back to regular color and opacity */
.navbar-toggler span:nth-child(2) {
  opacity: 1;
}
/* bottom line goes back to initial position and rotates back to 0 degrees */
.navbar-toggler span:nth-child(3) {
  transform: translate(0%, 0%) rotate(0deg);
}

@media (max-width: 991px) {
  .navbar-collapse ul.navbar-nav {
    position: fixed;
    left: 0;
    top: 69px;
    bottom: 0;

    width: 100vw;

    text-align: center;

    overflow: auto;
    overscroll-behavior: none;

    background-color: rgb(71, 83, 110, 0.85);
  }

  li.nav-item {
    padding: 8px 0;
  }

  ul.navbar-nav > li > a {
    color: white !important;
  }

  .navbar .collapsing {
    -webkit-transition: none;
    transition: none;
    display: none;
  }
}

.login-button {
  border-radius: 3px;
  background-color: #49536c !important;
  color: white !important;
  padding: 6px 20px;
}

@media (max-width: 991px) {
  .login-button {
    padding: 3px 15px;
  }
}

.login-button:hover {
  background-color: white !important;
  color: #49536c !important;
  transition: 0.5s;
}

#loginModal .modal-header {
  border-bottom: none;
}

#loginModal .menu-button {
  position: relative;
  border-radius: 80px;
  border: solid 3px #f892a4;
  color: #f892a4;
  padding: 10px;
  background-color: white;
  width: 350px;
  max-width: 100%;
	text-align: center;
  text-decoration: none;
}

#loginModal .menu-button:hover {
  color: white;
  background-color: #f892a4;
  transition: 0.6s;
}

#loginModal .menu-button i {
  position: absolute;
  display: flex;
  align-items: center;
  right: 15px;
  top: 0;
  bottom: 0;
}

/*--------------------------------------------------------------
# Section1
--------------------------------------------------------------*/
#section1 {
  position: relative;
  overflow: hidden;
  background-image: url(../img/kv@2x.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right;
  width: 100%;
  height: 560px;
  margin-top: 76px; /* header height */
  display: flex;
  justify-content: center;
}

#section1 .container {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  max-width: 1080px;
}

@media (max-width: 860px) {
  #section1 {
    background-image: url(../img/kv_sp_logo_center.png);
    margin-top: 0;
    height: 630px;
  }

  #section1 .container {
    justify-content: center;
    align-items: end;
    padding-bottom: 40px;
  }
}

@media (max-width: 575px) {
  #section1 {
    height: 600px;
    background-image: url(../img/kv_sp_logo_top.png);
  }
}

@media (max-width: 400px) {
  #section1 {
    height: 600px;
    background-image: url(../img/kv_sp_logo_top.png);
  }
}

@media (max-width: 374px) {
  #section1 {
    background-position: bottom;
  }
}

.cv-contents {
  padding: 0;
}

.head-no1-banner {
  margin: 48px 0 30px;
}

@media (max-width: 860px) {
  .head-no1-banner {
    width: 100%;
    max-width: 420px;
    height: auto;
    margin: 68px 0 0;
    padding: 0 4px;
  }
}

.heading-area .head-1 {
  text-shadow: 1px 1px 4px #E3576DB3;
  font-size: 18px;
  font-weight: 400;
  line-height: 26px;
}

.heading-area .head-2 {
  margin: 0 auto 12px;
  text-shadow: 1px 1px 4px #E3576DB3;
  font-size: 44px;
  font-weight: 600;
  line-height: 58px;
}

.heading-area .head-3 {
  text-shadow: 1px 1px 4px #E3576DB3;
  font-size: 22px;
  font-weight: 400;
  line-height: 34px;
}

@media (max-width: 860px) {
  .heading-area .head-1 {
    margin-top: 218px;
    font-size: 11px;
    line-height: 28px;
  }

  .heading-area .head-2 {
    margin-top: 2px;
    font-size: 28px;
    line-height: 35px;;
  }

  .heading-area .head-3 {
    font-size: 13px;
    line-height: 20px;
  }
}

@media (max-width: 374px) {
  .heading-area .head-1 {
    margin-top: 200px;
  }

  .heading-area .head-2 {
    font-size: 26px;
  }
}


.hero-button-area {
  margin-top: 20px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  max-width: 420px;
}

@media (max-width: 860px) {
  .hero-button-area {
    margin-top: 8px;
  }
}

#section1 .hero-button {
  padding: 14px 12px;
  box-shadow: 0px 3px 4px #CB405666;
  border-radius: 80px;
  font-family: "Hiragino Sans", sans-serif;
  font-weight: 500;
  width: 100%;
}

#section1 .contact-button {
  display: inline-block;
  background-color: #ffffff;
  color: #f84162;
  box-shadow: 0px 3px 4px #CB405666;
}

#section1 .contact-button-short {
  display: none;
  background-color: #ffffff;
  color: #f84162;
  box-shadow: 0px 3px 4px #CB405666;
}

#section1 .white-paper-button {
  display: inline-block;
  background-color: #f25c25;
  color: #ffffff;
  box-shadow: 0px 3px 4px #CB405666;
}

#section1 .white-paper-button-short {
  display: none;
  background-color: #f25c25;
  color: #ffffff;
  box-shadow: 0px 3px 4px #CB405666;
}

@media (max-width: 860px) {
  #section1 .contact-button {
    display: none;
  }

  #section1 .contact-button-short {
    display: inline-block;
  }

  #section1 .white-paper-button {
    display: none;
  }

  #section1 .white-paper-button-short {
    display: inline-block;
  }
}

@media (max-width: 860px) {
  #section1 .hero-button {
    padding: 14px 24px;
  }
}

@media (max-width: 374px) {
  #section1 .hero-button {
    padding: 14px 12px;
  }
}

#section1 .contact-button:hover {
  background-color: #fce9ee;
  transition: 0.4s;
}

#section1 .contact-button-short:hover {
  background-color: #fce9ee;
  transition: 0.4s;
}

#section1 .white-paper-button:hover {
  background-color: #f27243;
  transition: 0.4s;
}

#section1 .white-paper-button-short:hover {
  background-color: #f27243;
  transition: 0.4s;
}

.hero-button-chevron {
  margin-left: 4px;
}

.congrats-area {
  max-width: 420px;
  margin: 20px auto 0;
  padding: 12px 16px;
  background-color: white;
  border-radius: 12px;
  box-shadow: 0px 3px 4px #CB405666;
}

.congrats-area .congrats-1-image {
  width: 388px;
  height: 73px;
}

@media (max-width: 991px) {
  .congrats-area {
    margin-top: 12px;
  }

  .congrats-area .congrats-1-image {
    width: 283px;
    height: 53px;
  }
}

@media (max-width: 768px) {
  .congrats-area {
    max-width: 350px;
  }

  .congrats-area .congrats-1-image {
    width: 318px;
    height: 59px;
  }
}

@media (max-width: 374px) {
  .congrats-area .congrats-1-image {
    width: 100%;
    height: 100%;
  }
}

/*--------------------------------------------------------------
# Section2
--------------------------------------------------------------*/
#section2 {
  padding: 64px 0;
}

@media (max-width: 991px) {
  #section2 {
    padding: 32px 0;
  }
}

#section2 img.logo-image {
  height: 58px;
}

@media (max-width: 991px) {
  #section2 img.logo-image {
    height: 37.7px;
  }
}

#section2 .lead-text {
  line-height: 46px;
}

#section2 .boxed-text {
  display: inline-block;
}

/*--------------------------------------------------------------
# Section3
--------------------------------------------------------------*/
#section3 {
  background-color: #fcf7f8;
  padding: 71px 0;
}

@media (max-width: 991px) {
  #section3 {
    padding: 30px 0;
  }
}

#section3 .container {
  background-color: #ffffff;
  border-top: solid 8px #f892a4;
  border-radius: var(--border-radius-S);
}

@media (min-width: 992px) {
  #section3 .container {
    max-width: 975px;
  }
}

#section3 ul {
  list-style: none;
  padding: 0;
}

#section3 li {
  padding-left: 24px;
  margin-bottom: 0.6em;
  line-height: 2em !important;
}

#section3 li::before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c";
  color: #f892a4;
  display: inline-block;
  margin-left: -24px; /* same as padding-left set on li */
  margin-right: 8px;
  font-size: 24px;
}

@media (max-width: 991px) {
  #section3 li::before {
    font-size: 16px;
  }
}

#section3 li span {
  border-bottom: solid 3px #f892a4;
}

#section3 .bg-underline {
  position: relative;
  z-index: 1;
}

#section3 .bg-underline:before {
  content: "";
  z-index: -1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30%;
  background-color: #f892a4;
}

#section3 .down-arrow {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 38px 66px 0 66px;
  border-color: rgb(248, 146, 164, 0.6) transparent transparent transparent;
}
@media (max-width: 991px) {
  #section3 .down-arrow {
    border-width: 29px 51px 0 51px;
  }
}

#section3 .down-arrow.bottom {
  margin-top: -24px
}

@media (max-width: 991px) {
  #section3 .down-arrow.bottom {
    margin-top: -20px
  }
}

#section3 .underlined-box {
  border-bottom: 10px solid #f8a1b0;
}

@media (max-width: 991px) {
  #section3 .underlined-box {
    border-bottom: 6px solid #f8a1b0;
  }
}

#section3 img.logo-image {
  height: 44px;
}

@media (max-width: 991px) {
  #section3 img.logo-image {
    height: 35px;
  }
}

#section3 img.task-image {
  width: 316px;
}

@media (max-width: 991px) {
  #section3 img.task-image {
    width: 250px;
  }
}

/*--------------------------------------------------------------
# Section4
--------------------------------------------------------------*/
#section4 {
  padding: 100px 0;
}

@media (max-width: 991px) {
  #section4 {
    padding: 40px 0 0;
  }
}

#section4 img.logo-image {
  height: 44px;
}

@media (max-width: 991px) {
  #section4 img.logo-image {
    height: 37.7px;
  }
}

/*--------------------------------------------------------------
# Section5
--------------------------------------------------------------*/
#section5 {
  background-color: #fcf7f8;
  padding: 80px 0;
}

@media (max-width: 991px) {
  #section5 {
    padding: 50px 0;
  }
}

@media (min-width: 992px) {
  #section5 .container .pagi {
    max-width: 780px;
    margin-left: auto;
    margin-right: auto;
  }
}

#section5 .row {
  margin: 0;
}

#section5 .price-title {
  width: 37%;
  position: relative;
  text-align: center;
}

#section5 .price-title::after {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #e8e8e8;
  position: absolute;
  left: 100%;
}

#section5 .price-title p {
  width: 100%;
  padding: 0 5px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform : translate(-50%,-50%);
}

#section5 .price-data {
  width: 63%;
  padding: 0 10px;
  text-align: center;
}

#section5 .data-box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 10px 30px;
}

@media (max-width: 991px) {
  #section5 .data-box {
    padding: 10px 20px;
  }
}

@media (max-width: 768px) {
  #section5 .data-box {
    flex-flow: column;
    padding: 0 10px 10px;
  }
}

#section5 .data-box:not(:first-child) {
  border-top: 1px solid #e8e8e8;
}

@media (max-width: 768px) {
  #section5 .data-box:not(:first-child) {
    padding: 10px 10px 0;
  }
}

#section5 .unit {
  display: inline-block;
  width: 120px;
  padding: 3px;
  text-align: center;
  background-color: #f892a4;
  border-radius: 30px;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
}

@media (max-width: 575px) {
  #section5 .unit {
    width: 85px;
    height: 23px;
    font-size: 12px;
  }
}

#section5 ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  list-style: none;
  padding: 0;
}

#section5 li {
  width: 32%;
  height: 62px;
  margin-bottom: 20px;
  position: relative;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
  border: 2px solid #f892a4;
  font-size: 15px;
}

@media (max-width: 768px) {
  #section5 li {
    width: 48%;
    height: 56px;
    font-size: 13px;
  }
}

#section5 li p {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform : translate(-50%,-50%);
  padding: 0 5px;
}

#section5 img.price-image-pc {
  height: 122px;
  margin: 0 auto;
}
#section5 img.price-image-sp {
  display: none;
}

@media (max-width: 768px) {
  #section5 img.price-image-pc {
    width: 510px;
    height: auto;
  }
}

@media (max-width: 575px) {
  #section5 img.price-image-pc {
    display: none;
  }
  #section5 img.price-image-sp {
    display: block;
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
  }
}

/*--------------------------------------------------------------
# Section6
--------------------------------------------------------------*/
#white-paper-section {
  padding: 80px 0 70px;
}

@media (max-width: 991px) {
  #white-paper-section {
    padding: 40px 0;
  }
}

.section-header {
  margin: 0;
  padding: 0;
  font-size: 34px;
  font-weight: 600;
  color: #47536E;
  line-height: 1;
  text-align: center;
  font-family: "Hiragino Sans", sans-serif;
}

@media (max-width: 991px) {
  .section-header {
    font-size: 22px;
    font-weight: 500;
  }
}

.section-description {
  margin: 28px 0 0;
  padding: 0;
  font-size: 14px;
  color: #47536E;
  text-align: center;
}

@media (max-width: 991px) {
  .section-description {
    margin-top: 24px;
  }
}

.white-paper-list {
  max-width: 974px;
  margin: 28px auto 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, 314px);
  grid-gap: 16px;
}

@media (max-width: 991px) {
  .white-paper-list {
    grid-template-columns: repeat(auto-fit, 335px);
    max-width: 686px;
    margin: 0 auto;
    margin-top: 22px;
  }
}

@media (max-width: 800px) {
  .white-paper-list {
    flex-direction: column;
    align-items: center;
  }
}

@media (max-width: 686px) {
  .white-paper-list {
    grid-template-columns: 1fr;
    padding: 0 20px;
    gap: 4px;
    margin-top: 32px;
  }
}

.white-paper-element {
  cursor: pointer;
  position:relative;
  display: block;
  border: solid 1px #D3D3D3;
}

.white-paper-element p {
  font-size: 10px;
  color: #47536E;
}

@media (max-width: 991px) {
  .white-paper-element {
    margin-top: 12px;
  }
}

@media (max-width: 686px) {
  .white-paper-element {
    display: flex;
    border: none;
    border-bottom: solid 1px #D3D3D3;
    padding: 0 0 4px;
    margin-top: 0;
  }
}

.white-paper-dimmer {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}

.white-paper-caption-area {
  padding: 8px 12px;
  position: absolute;
  bottom: 0;
  background-color: white;
  opacity: 0.9;
  width: 100%;
  height: 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: border-radius 0.3s;
}

@media (max-width: 686px) {
  .white-paper-caption-area {
    height: unset;
  }
}
.white-paper-image {
  width: 100%;
}

@media (max-width: 686px) {
  .white-paper-caption-area {
    position: relative;
  }
}

@media (max-width: 991px) {
  .white-paper-image {
    height: 176.43px;
  }
}

@media (max-width: 686px) {
  .white-paper-image {
    width: 90px;
    height: 60px;
    object-fit: cover;
  }
}

.white-paper-caption-sub {
  font-size: 14px;
  color: #F25C25;
  display: block;
  font-family: "Hiragino Sans", sans-serif;
  font-weight: 400;
}

.white-paper-cpation-title {
  font-size: 16px;
  color: #F25C25;
  display: block;
  font-family: "Hiragino Sans", sans-serif;
  font-weight: 600;
}

.white-paper-element:hover > .white-paper-caption-area {
  border-radius: 0 60px 0 0;
}

.white-paper-element:hover > .white-paper-dimmer {
  background-color: black;
  opacity: 0.2;
}

/*--------------------------------------------------------------
# Section7
--------------------------------------------------------------*/
#section7 {
  padding: 70px 0;
}

@media (max-width: 991px) {
  #section7 {
    padding: 40px 0;
  }
}

@media (min-width: 992px) {
  #section7 .container .pagi {
    max-width: 780px;
    margin-left: auto;
    margin-right: auto;
  }
}

#section7 .item_date {
  color: #6C6C6C;
}

#section7 .item_type {
  border: 1px solid #6C6C6C;
  color: #6C6C6C;
  border-radius: 2px;
  padding: 0px 6px;
  line-height: 19px !important;
  margin-left: 6px;
}

#section7 .item_text {
  line-height: 19px !important;
  margin-top: 9px;
}

#section7 .list-group-item {
  padding: 16.5px 8px;
  border-bottom: 1px solid #707070;
  color: #47536E;
  text-decoration: none;
}

#section7 .list-group-item-with-link:hover {
  color: rgb(71, 83, 110, 0.6);
  transition: 0.3s;
}

#section7 .paginationjs {
  display: flex;
  justify-content: center;
  margin-top: 47px;
}

@media (max-width: 991px) {
  #section7 .paginationjs {
    margin-top: 28px;
  }
}

#section7 .paginationjs .paginationjs-pages li {
  border: none;
}

#section7 .paginationjs .paginationjs-pages li:first-child>a {
  margin-right: 5px;
}

#section7 .paginationjs .paginationjs-pages li:last-child>a {
  margin-left: 5px;
}

#section7 .paginationjs-pages li:last-child>a {
  color: #6C6C6C;
}

#section7 .paginationjs .paginationjs-pages li.active>a {
  background: #fff;
  color: #EA537B;
  height: 28px;
  line-height: 28px !important;
}

#section7 .brands a {
  height: 52.5px;
  display: flex;
  justify-content: center;
  padding-left: 12px;
  padding-right: 12px;
}

#section7 .brands a img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}



/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section {
  padding: 100px 0;
  overflow: hidden;
}

@media (max-width: 991px) {
  section {
    padding: 40px 0;
  }
}

.section-bg {
  background-color: #fcf7f8;
}

.section-bg2 {
  background-color: #f8f8f8;
}

.section-title {
  text-align: center;
  padding-bottom: 30px;
}

.section-title h2 {
  font-size: 32px;
  font-weight: 400;
  margin-bottom: 20px;
  padding-bottom: 0;
}

.section-title p {
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .section-title p {
    text-align: left;
  }
}

.section-title p span {
  color: #f08599;
}

.line-height-initial {
  line-height: initial !important;
}

/*--------------------------------------------------------------
# App Features
--------------------------------------------------------------*/
.features .content {
  padding: 30px 0;
}

.features .content .icon-box {
  margin-top: 25px;
}

.features .content .icon-box h4 {
  color: #47536e;
  font-size: 20px;
  font-weight: 700;
  margin: 5px 0 10px 50px;
}

.features .content .icon-box i {
  font-size: 34px;
  float: left;
  color: #f892a4;
}

.features .content .icon-box p {
  font-size: 14px;
  color: #979aa1;
  margin-left: 50px;
}

@media (max-width: 991px) {
  .features .image {
    text-align: center;
  }
  .features .image img {
    max-width: 80%;
  }
}

@media (max-width: 667px) {
  .features .image img {
    max-width: 100%;
  }
}

/*--------------------------------------------------------------
# Details
--------------------------------------------------------------*/
.details .content + .content {
  margin-top: 100px;
}

.details .content h3 {
  font-weight: 700;
  font-size: 32px;
  color: #47536e;
}

.details .content ul {
  list-style: none;
  padding: 0;
}

.details .content ul li {
  padding-bottom: 10px;
}

.details .content ul i {
  font-size: 20px;
  padding-right: 4px;
  color: #f892a4;
}

.details .content p:last-child {
  margin-bottom: 0;
}

/*--------------------------------------------------------------
# Gallery
--------------------------------------------------------------*/
.gallery {
  overflow: hidden;
}

.gallery .owl-nav,
.gallery .owl-dots {
  margin-top: 40px;
  text-align: center;
}

.gallery .owl-item {
  transition: 0.3s ease-in-out;
}

.gallery .owl-dot {
  display: inline-block;
  margin: 0 5px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #fff !important;
}

.gallery .owl-dot.active {
  background-color: #f892a4 !important;
}

.gallery .gallery-carousel {
  padding-top: 30px;
}

.gallery .gallery-carousel .owl-stage-outer {
  overflow: visible;
}

@media (min-width: 992px) {
  .gallery .gallery-carousel .center {
    border: 6px solid #f892a4;
    padding: 4px;
    background: #fff;
    z-index: 1;
    transform: scale(1.2);
    margin-top: 10px;
    border-radius: 25px;
  }
}

/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials .testimonial-wrap {
  padding: 0 20px;
}

.testimonials .testimonial-item {
  width: 960px !important;
  box-sizing: content-box;
  padding: 30px;
  margin: 30px 15px;
  min-height: 200px;
  box-shadow: 0px 2px 12px rgba(0, 0, 0, 0.08);
  position: relative;
  background: #fff;
  border-radius: 10px;
}
.testimonials .testimonial-item .testimonial-img {
  width: 100%;
}
.testimonials .testimonial-item h3 {
  font-size: 18px;
  font-weight: bold;
  margin: 10px 0;
  color: #111;
}

.testimonials .testimonial-item h4 {
  font-size: 14px;
  color: #999;
  margin: 0 0 10px;
}
.testimonials .testimonial-item h4 span {
  color: #f892a4;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
  color: #e8ecf5;
  font-size: 26px;
}

.testimonials .testimonial-item .quote-icon-left {
  display: inline-block;
  left: -5px;
  position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
  display: inline-block;
  right: -5px;
  position: relative;
  top: 10px;
}

.testimonials .testimonial-item p {
  font-style: normal;
  margin: 15px auto 15px auto;
}

.testimonials .owl-nav,
.testimonials .owl-dots {
  margin-top: 5px;
  text-align: center;
}

.testimonials .owl-dot {
  display: inline-block;
  margin: 0 5px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #fff !important;
}

.testimonials .owl-dot.active {
  background-color: #f892a4 !important;
}

/*---- add ---*/
/*
.owl-item {
  width: 1110px !important;
}
.testimonials-carousel > .cloned {
  display: none;
}:*/
.tm-arrow {
  width: 300px !important;
  margin: 0 auto;
}
.figure-box {
  border: solid 2px #ddd;
  border-radius: 10px;
  padding: 20px 30px;
  margin-bottom: 40px;
}
/*--- /add ---*/

@media (max-width: 768px) {
  .testimonials .testimonial-wrap {
    padding: 0;
    margin: 0;
  }
  .testimonials .testimonial-item {
    width: 100% !important;
    padding: 20px;
    margin: 0;
    box-sizing: inherit;
  }
  .testimonials .testimonial-item .testimonial-img {
    position: static;
    left: auto;
  }
  .tm-arrow {
    width: 100% !important;
    margin: 0 auto;
  }
  .figure-box {
    border: solid 2px #ddd;
    border-radius: 10px;
    padding: 10px 20px;
    margin-bottom: 40px;
  }
}

/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/
.pricing .row {
  padding-top: 40px;
}

.pricing .box {
  padding: 40px 20px 10px;
  margin-bottom: 30px;
  border: solid 1px #bcb8b8;
  border-radius: 12px;
  flex: 1;
  /* box-shadow: 0px 0px 30px rgba(73, 78, 92, 0.15); */
  background: #fff;
  text-align: center;
}

.pricing .section-title {
  padding-bottom: 0;
}

@media (min-width: 1000px) {
  .pricing .box:first-child {
    margin-right: 36px;
  }
}

.pricing .section-desc-block {
  padding: 0;
}

.pricing p.section-desc {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 1.5rem;
  font-weight: 500;
  color: #707070;
}

.pricing p.section-desc .highlight {
  color: #ea537b;
}

.pricing h4 {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 1.3rem;
  font-weight: 500;
  color: #707070;
  margin-bottom: 2px;
}

.pricing h5 {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 2.4rem;
  font-weight: 500;
  color: #f692a7;
  text-align: left;
  line-height: 1;
}

.pricing h5 span.prefix-unit {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  color: #f692a7;
  text-align: left;
  margin-bottom: 2px;
}

.pricing h5 span.suffix-unit {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: #f692a7;
}

.pricing .campaign-banner-image {
  margin: 0 auto;
}

.pricing ul {
  padding: 20px 0 0;
  list-style: none;
  color: #999;
  text-align: left;
}

.pricing ul li {
  padding-bottom: 12px;
  font-size: 80%;
  line-height: 1.1;
}

.pricing p {
  color: #999;
  font-size: 80%;
  padding-top: 20px;
}

.pricing ul i {
  color: #f892a4;
  font-size: 18px;
  padding-right: 4px;
}

.pricing ul .na {
  color: #ccc;
}

.pricing ul .na i {
  color: #ccc;
}

.pricing ul .na span {
  text-decoration: line-through;
}

.pricing .get-started-btn {
  background: #47536e;
  display: inline-block;
  padding: 6px 30px;
  border-radius: 20px;
  color: #fff;
  transition: none;
  font-size: 14px;
  font-weight: 400;
  transition: 0.3s;
}

.pricing .get-started-btn:hover {
  background: #f892a4;
}

.pricing .featured {
  z-index: 10;
  margin: -30px -5px 0 -5px;
}

.pricing .featured .get-started-btn {
  background: #f892a4;
}

.pricing .featured .get-started-btn:hover {
  background: #f08599;
}

/*---- add ---*/
.pricing-in {
  display: block;
}
/*--- /add ---*/

@media (max-width: 992px) {
  .pricing .box {
    max-width: 60%;
    margin: 0 auto 30px auto;
  }
}

@media (max-width: 768px) {
  .pricing .box {
    max-width: 80%;
    margin: 0 auto 30px auto;
  }
}

@media (max-width: 420px) {
  .pricing .box {
    max-width: 100%;
    margin: 0 auto 30px auto;
  }
}

/*--------------------------------------------------------------
# Frequently Asked Questions
--------------------------------------------------------------*/
.faq .accordion-list {
  padding: 0 100px;
}

.faq .accordion-list ul {
  padding: 0;
  list-style: none;
}

.faq .accordion-list li + li {
  margin-top: 15px;
}

.faq .accordion-list li {
  padding: 20px;
  background: #fff;
  border-radius: var(--border-radius-S);
  position: relative;
}

.faq .accordion-list a {
  display: block;
  position: relative;
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  padding: 0 30px;
  outline: none;
}

.faq .accordion-list .icon-help {
  font-size: 24px;
  position: absolute;
  right: 0;
  left: 20px;
  color: #b1c0df;
}

.faq .accordion-list .icon-show,
.faq .accordion-list .icon-close {
  font-size: 24px;
  position: absolute;
  right: 0;
  top: 0;
}

.faq .accordion-list p {
  margin-bottom: 0;
  padding: 10px 0 0 0;
}

.faq .accordion-list .icon-show {
  display: none;
}

.faq .accordion-list a.collapsed {
  color: #343a40;
}

.faq .accordion-list a.collapsed:hover {
  color: #f892a4;
}

.faq .accordion-list a.collapsed .icon-show {
  display: inline-block;
}

.faq .accordion-list a.collapsed .icon-close {
  display: none;
}

@media (max-width: 1200px) {
  .faq .accordion-list {
    padding: 0;
  }
}

/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
#contact {
  padding: 60px 0;
}

@media (max-width: 991px) {
  #contact {
    padding: 50px 0;
  }
}

.contact .info {
  padding: 20px 40px;
  background: #fff;
  color: #47536e;
  text-align: center;
  border: 1px solid #f8f8f8;
}

.contact .info i {
  font-size: 48px;
  color: #f892a4;
  margin-bottom: 15px;
}

.contact .info h4 {
  padding: 0;
  margin: 0 0 10px 0;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  font-family: "Poppins", sans-serif;
}

.contact .info p {
  font-size: 15px;
}

.contact .php-email-form {
  width: 100%;
}

.contact .php-email-form .validate {
  display: none;
  color: red;
  margin: 0;
  font-weight: 400;
  font-size: 13px;
}

.contact .php-email-form .error-message {
  display: none;
  color: #fff;
  background: #ed3c0d;
  text-align: center;
  padding: 15px;
  font-weight: 600;
}

.contact .php-email-form .sent-message {
  display: none;
  color: #fff;
  background: #18d26e;
  text-align: center;
  padding: 15px;
  font-weight: 600;
}

.contact .php-email-form .loading {
  display: none;
  background: #fff;
  text-align: center;
  padding: 15px;
}

.contact .php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid #18d26e;
  border-top-color: #eee;
  -webkit-animation: animate-loading 1s linear infinite;
  animation: animate-loading 1s linear infinite;
}

.contact .php-email-form label {
  font-family: "Poppins", sans-serif;
  margin-bottom: 5px;
  color: #8a8c95;
}

.contact .php-email-form input,
.contact .php-email-form textarea {
  border-radius: 0;
  box-shadow: none;
  font-size: 14px;
}

.contact .php-email-form input::focus,
.contact .php-email-form textarea::focus {
  background-color: #f892a4;
}

.contact .php-email-form input {
  padding: 20px 15px;
}

.contact .php-email-form textarea {
  padding: 12px 15px;
}

.contact .php-email-form button[type="submit"] {
  background: #fff;
  border: 2px solid #f892a4;
  padding: 10px 24px;
  color: #f892a4;
  transition: 0.4s;
  border-radius: 50px;
  margin-top: 5px;
}

.contact button[type="submit"]:hover {
  background: #f892a4;
  color: #fff;
}

.contact .phone-number {
  margin: 10px 0;
}

@media (max-width: 1024px) {
  .contact .php-email-form {
    padding: 30px 15px 15px 15px;
  }
}

@media (max-width: 768px) {
  .contact .php-email-form {
    padding: 15px 0 0 0;
  }
}

@-webkit-keyframes animate-loading {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes animate-loading {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/*---- add ---*/
.pre-regist {
  border-bottom: dotted 2px #ddd;
  margin-bottom: 60px;
}
.pre-regist img {
  padding-top: 30px;
}
/*--- /add ---*/

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
#footer {
  background: #fff;
  color: #47536e;
  font-size: 14px;
  background: #fcf7f8;
}

#footer .footer-newsletter {
  padding: 50px 0;
  background: #eff2f8;
  text-align: center;
  font-size: 15px;
}

#footer .footer-newsletter h4 {
  font-size: 24px;
  margin: 0 0 20px 0;
  padding: 0;
  line-height: 1;
  font-weight: 600;
  color: #47536e;
}

#footer .footer-newsletter form {
  margin-top: 30px;
  background: #fff;
  padding: 6px 10px;
  position: relative;
  border-radius: 50px;
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
  text-align: left;
}

#footer .footer-newsletter form input[type="email"] {
  border: 0;
  padding: 4px 8px;
  width: calc(100% - 100px);
}

#footer .footer-newsletter form input[type="submit"] {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  border: 0;
  background: none;
  font-size: 16px;
  padding: 0 20px;
  background: #f892a4;
  color: #fff;
  transition: 0.3s;
  border-radius: 50px;
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}

#footer .footer-newsletter form input[type="submit"]:hover {
  background: #415f9d;
}

#footer .footer-top {
  padding: 60px 0 30px 0;
  background: #fff;
}

#footer .footer-top .footer-contact {
  margin-bottom: 30px;
}

#footer .footer-top .footer-contact h4 {
  font-size: 22px;
  margin: 0 0 30px 0;
  padding: 2px 0 2px 0;
  line-height: 1;
  font-weight: 700;
  color: #47536e;
}

#footer .footer-top .footer-contact p {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 0;
  color: #8a8c95;
}

#footer .footer-top h4 {
  font-size: 16px;
  font-weight: bold;
  color: #47536e;
  position: relative;
  padding-bottom: 12px;
}

#footer .footer-top .footer-links {
  margin-bottom: 30px;
}

#footer .footer-top .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#footer .footer-top .footer-links ul i {
  padding-right: 2px;
  color: #9fb2d8;
  font-size: 18px;
  line-height: 1;
}

#footer .footer-top .footer-links ul li {
  padding: 10px 0;
  display: flex;
  align-items: center;
}

#footer .footer-top .footer-links ul li:first-child {
  padding-top: 0;
}

#footer .footer-top .footer-links ul a {
  color: #8a8c95;
  transition: 0.3s;
  display: inline-block;
  line-height: 1;
}

#footer .footer-top .footer-links ul a:hover {
  text-decoration: none;
  color: #f892a4;
}

#footer .footer-top .social-links a {
  font-size: 18px;
  display: inline-block;
  background: #f892a4;
  color: #fff;
  line-height: 1;
  padding: 8px 0;
  margin-right: 4px;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
}

#footer .footer-top .social-links a:hover {
  background: #f08599;
  color: #fff;
  text-decoration: none;
}

#footer .credits {
  float: right;
  text-align: center;
  font-size: 13px;
  color: #47536e;
}

#footer .nav-link {
  padding: 0;
}

.footer-contact-info {
  margin-bottom: 10px;
}

.footer-contact-info .title {
  padding-right: 0;
}

.footer-contact-info .phone-number {
  margin-bottom: 10px;
}

@media (max-width: 768px) {
  #footer .copyright,
  #footer .credits {
    float: none;
    text-align: center;
    padding: 5px 0;
  }
}

/*---- add ---*/
.attention {
  width: 60%;
  border: solid 1px #f892a4;
  padding: 20px 40px;
  margin: 0 auto 30px;
}
.attention ul {
  margin: 0;
  padding: 0;
}
.attention li {
  list-style-type: none;
  color: #f892a4;
  font-weight: bold;
  line-height: 1.8;
}
@media (max-width: 768px) {
  .attention {
    width: 100%;
    border: solid 1px #f892a4;
    padding: 20px;
    margin: 0 auto 30px;
  }
}

footer#life-support-footer {
  background: #fff;
  color: #47536e;
  font-size: 14px;
  background: #fcf7f8;
  padding: 12px 0;
}

footer#life-support-footer .container {
  max-width: 1140px;

  display: flex;
  justify-content: space-between;
  align-items: center;
}

footer#life-support-footer .copyright {
  color: #47536e;
  font-weight: 300;
}

footer#life-support-footer .copyright strong {
  font-weight: 700;
}

footer#life-support-footer .credits {
  font-size: 13px;
  color: #47536e;
}

footer#life-support-footer .credits a {
  text-decoration: none;
  color: #F892A4;
}

.footer-links-container {
  display: flex;
  flex-flow: row;
  list-style-type: none;
  margin: 0;
  padding: 4px;
}

.footer-link {
  font-family: "Hiragino Sans", sans-serif;
  font-size: 12px;
  font-weight: normal;
  color: #47536e;
  text-decoration: none;
  margin: 0 8px
}

.footer-link:hover {
  color: #F892A4;
  text-decoration: none;
  cursor: pointer;
}

@media (max-width: 800px) {
  #footer .container {
    flex-direction: column;
  }

  .footer-links-container {
    padding: 12px;
  }
}

/*---- add ---*/
.attention {
  width: 60%;
  border: solid 1px #f892a4;
  padding: 20px 40px;
  margin: 0 auto 30px;
}
.attention ul {
  margin: 0;
  padding: 0;
}
.attention li {
  list-style-type: none;
  color: #f892a4;
  font-weight: bold;
  line-height: 1.8;
}
@media (max-width: 768px) {
  .attention {
    width: 100%;
    border: solid 1px #f892a4;
    padding: 20px;
    margin: 0 auto 30px;
  }
}

/*===========================
  --- Contact ----
=========================== */

.validation {
  display: none;
  margin: 0 0 20px;
  font-weight: 400;
  font-size: 13px;
  color: #f892a4;
}

#sendmessage {
  display: none;
  text-align: center;
  padding: 15px 12px 15px;
  margin: 10px 0;
  font-weight: 600;
  margin-bottom: 30px;
}

#errormessage {
  display: none;
}

#sendmessage.show,
#errormessage.show,
.show {
  display: block;
}

#contact-form {
  position: relative;
}

#contact-form input[type="text"],
#contact-form input[type="email"],
#contact-form input[type="tel"],
.contactForm textarea {
  width: 100%;
  background: #fff;
  font-family: "Open Sans", sans serif;
  border: solid 1px #eee;
  font-size: 14px;
  text-align: left;
  vertical-align: middle;
  padding: 0 10px;
}
#contact-form input[type="text"]:focus,
#contact-form input[type="email"]:focus,
#contact-form input[type="tel"]:focus,
.contactForm textarea:focus {
  background: rgba(101, 106, 100, 1);
  color: #eff1ef;
  box-shadow: none;
  -moz-box-shadow: none;
  -webkit-box-shadow: none;
  transition: background 0.25 ease-in;
  -moz-transition: background 0.25 ease-in;
  -webkit-transition: background 0.25 ease-in;
}
#contact-form input[type="text"],
#contact-form input[type="email"],
#contact-form input[type="tel"] {
  height: 50px;
}
#contact-form input[type="submit"] {
  color: #fff;
  width: 185px;
  height: 60px;
  text-shadow: none;
  font-size: 14px;
  padding: 0.5em;
  letter-spacing: 0.05em;
  margin: 0 0 20px 0;
  display: block;
  border: 0;
  text-transform: none;
  border-radius: 0;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  box-shadow: none;
  -moz-box-shadow: none;
  -webkit-box-shadow: none;
}
#contact-form input[type="submit"]:hover,
#contact-form input[type="submit"]:active {
  background: #43413e !important;
}
#contact-form textarea {
  padding-top: 1em;
}

textarea.form-control {
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
}

div.cform-response-output {
  max-width: 60%;
  text-align: center;
  margin-left: 40% !important;
  margin-top: 0.5em !important;
  padding: 0.5em !important;
  border-radius: var(--border-radius-S);
  -moz-border-radius: var(--border-radius-S);
  -webkit-border-radius: var(--border-radius-S);
}
.cform-not-valid-tip {
  color: #888;
  border: 1px dotted #ad3729 !important;
  width: 100% !important;
  left: 0 !important;
  padding: 0.5em !important;
  font-family: "Open Sans", sans-serif;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  border-radius: var(--border-radius-S);
  -moz-border-radius: var(--border-radius-S);
  -webkit-border-radius: var(--border-radius-S);
}

.btn_send {
  background: #fff;
  border: 2px solid #f892a4;
  padding: 10px 24px;
  color: #f892a4;
  transition: 0.4s;
  border-radius: 50px;
  margin: 20px auto 0;
  text-align: center;
}

.btn-faq-category {
  background: #fff;
  border: 2px solid #fff;
  padding: 10px 24px;
  color: #000000;
  border-radius: 10px;
  margin: 10px;
  text-align: center;
  transition: 0.4s;
  box-shadow: 0px 0px 10px #00000029;
}

.btn-faq-category.active,
.btn-faq-category:hover {
  background: #f892a41a;
  border: 2px solid #f892a4;
  color: #f892a4;
}

.owl-carousel .owl-item img {
  display: block;
  /*width: 100%;*/
}
/*--- /add ---*/

/*--- slick ---*/
.slider {
  width: 100%;
  margin: 100px auto;
}

.slick-slide {
  margin: 10px;
}

.slick-slide img {
  width: 100%;
}

.slick-prev:before,
.slick-next:before {
  color: black;
}

.slick-slide {
  transition: all ease-in-out 0.3s;
  opacity: 0.2;
}

.slick-active {
  opacity: 0.5;
}

.slick-current {
  opacity: 1;
}

/*--- /slick ---*/

/*--- pages ---*/
.pages {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 140px 0 40px 0;
  background-image: url(../img/bg_network.png);
  background-repeat: repeat-x;
  z-index: 1;
  top: 12.5%;
}
.pages.no-background {
  background-image: unset;
}
.company__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  font-size: 14px;
  padding-top: 20px;
  width: 100%;
  margin: 0 auto;
}
.company__list .company__term {
  padding-right: 30px;
  color: #aaa;
  font-weight: normal;
}
.company__list .company__definition {
  margin-bottom: 10px;
}
.company__list .company__definition ul {
  list-style-type: none;
  padding: 0;
}
.cnt {
  width: 100%;
  margin-bottom: 100px;
}
.cnt p {
  font-size: 14px;
  margin: 20px 0;
}
.cnt dt {
  font-size: 14px;
  padding: 0 10px;
}
.cnt dd {
  color: #8a8c95;
  font-size: 12px;
  padding: 0 20px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .company__list {
    flex-direction: row;
    margin: 0 auto;
    width: 640px;
  }
  .company__list .company__term {
    border-bottom: 1px solid #eee;
    padding: 20px 0;
    width: 30%;
  }
  .company__list .company__definition {
    border-bottom: 1px solid #eee;
    margin-bottom: 0;
    padding: 20px 0;
    width: 70%;
  }
}
/*--- /pages ---*/

/*--- switch ---*/
.pc_cnt {
  display: block !important;
  margin: 0 auto;
}
.sp_cnt {
  display: none !important;
}

.pc_img {
  display: inline-block !important;
}

@media only screen and (max-width: 768px) {
  .pc_cnt {
    display: none !important;
  }
  .sp_cnt {
    display: block !important;
  }
}
/*--- /switch ---*/

.login-dropdown {
  padding: 5px 15px 12px;
}

.login-dropdown > button {
  padding: 2px 6px 2px 2px;
}

.login-dropdown > button:hover {
  background: #f892a4;
  color: #fff;
  border-color: #f892a4;
}

.login-dropdown > button:active {
  background: #f892a4 !important;
  color: #fff !important;
  border-color: #f892a4 !important;
}

.login-dropdown > button.dropdown-toggle:focus {
  background: #f892a4;
  color: #fff;
  border-color: #f892a4;
}

.mobile-login-nav-head {
  padding: 10px 20px;
  color: #8e8e8e;
}

.mobile-login-nav-item {
  margin-left: 12px;
}

.category-buttons {
  margin-bottom: 40px;
}

@media (min-width: 992px) {
  .category-buttons {
    margin-left: 50px;
    margin-right: 50px;
  }
}

.collapse-item {
  padding-bottom: 20px;
  display: none;
}

.show-collapse-item {
  display: block;
}

.collapse-title {
  position: relative;
  font-size: 16px;
  margin-bottom: 16px;
  padding-bottom: 10px;
  padding-left: 40px;
  padding-right: 40px;
  border-bottom: 1px solid #dddddd;
  cursor: pointer;
  -webkit-user-select: none; /* Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+/Edge */
  user-select: none; /* Standard */
}

@media (max-width: 992px) {
  .collapse-title {
    padding-bottom: 35px;
    padding-right: 3px;
  }
}

.collapse-title::before {
  content: " ";
  background: #47536e url(/static/assets/img/bx-question-mark.svg) no-repeat
    center;
  background-size: 10px 10px;
  height: 22px;
  width: 22px;
  border-radius: 50%;
  top: 2px;
  left: 5px;
  position: absolute;
}

.collapse-title::after {
  font-family: "Font Awesome 5 Free";
  content: "\f107";
  color: #f892a4;
  font-size: 25px;
  font-weight: bolder;
  top: -5px;
  right: 5px;
  position: absolute;
}

@media (max-width: 992px) {
  .collapse-title::after {
    top: unset;
    bottom: 0;
    right: unset;
    left: 50%;
  }
}

.collapse-title[aria-expanded="true"]::after {
  content: "\f106";
}

.collapse-body {
  font-size: 14px;
  background: #f7f7f7 0% 0% no-repeat padding-box;
  padding: 40px;
}

.banner-linkupjounarl {
  width: 290px;
}

/* lifesupport */

body.lifesupport {
  font-family: 'Noto Sans Japanese', sans-serif;
}

/* index-page */
.banner-lifesupport {
  width: 100%;
  max-width: 856px;
  border: 1px solid #B3B3B3;
  opacity: 1;
  margin : 0 auto;
  margin-top: 60px;
}

.banner-lifesupport:hover {
  opacity: 0.6;
}

@media only screen and (max-width: 768px) {
  body.lifesupport {
    max-width: 768px;
    margin: 0 auto;

  }

  .banner-lifesupport {
    width: 335px;
    height: 120px;
    margin-top: 40px;
  }
}

@media only screen and (max-width: 374px) {
  body.lifesupport {
    zoom: 0.853;
  }
}

@media screen and (min-width: 992px) {
  .banner-linkupjounarl {
    width: 100%;
  }
}

/* lifesupport-page */

/* section-top */
.lifesupport-top-img {
  position: relative;
  overflow: hidden;
  background-image: url(../img/life-support/lp_lifesupport_top_pc.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 0;
  padding-top: 43%;
  padding-bottom: 0;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.section-lifesupport-top {
  padding: 0;
}

.section-lifesupport-top div.container {
  padding: 0;
  max-width: 976px;
}

.section-lifesupport-top img.lifesupport-top {
  width: 975px;
  height: 346px;
  margin : 0 auto;
  margin-top: 32px;
  margin-bottom: 60px;
}

.section-lifesupport-top p.lifesupport-top {
  font-size: 20px;
  color: #585A61;
  letter-spacing: 0.8px;
  line-height: 29px;
}

.section-lifesupport-top div.row {
  width: 975px;
  margin: 0 auto;
}

.section-lifesupport-top div.row div.lifesupport-top {
  margin: 0 12px 12px 0;
}

.section-lifesupport-top img.lifesupport-top-menu {
  width: 234.75px;
  height: 132.05px;
  border-radius: var(--border-radius-S);
}

@media (max-width: 575px) {
  .lifesupport-top-img {
    padding-top: 200%;
    margin-bottom: -77%;
    background-image: url(../img/life-support/lp_lifesupport_top_sp.png);
    margin-top: 0;
  }
}

@media only screen and (max-width: 768px) {
  .section-lifesupport-top img.lifesupport-top {
    width: 375px;
    height: 414px;
    margin: 0 auto;
    margin-bottom: 32px;
  }

  .section-lifesupport-top div.row {
    width: 335px;
    margin: 0 auto;
  }

  .section-lifesupport-top div.row div.lifesupport-top.lifesupport-left {
    margin: 0 12px 12px 0;
  }

  .section-lifesupport-top div.row div.lifesupport-top.lifesupport-right {
    margin: 0;
  }

  .section-lifesupport-top p.lifesupport-top {
    font-size: 18px;
    color: #585A61;
    letter-spacing: 0.72px;
    line-height: 27px;
  }

  .section-lifesupport-top img.lifesupport-top-menu {
    width: 159.5px;
    height: 89.72px;
    border-radius: var(--border-radius-S);
  }
}

.lifeSupport-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, 235px);
  gap: 12px;
  justify-content: center;
}

.lifeSupport-element {
  background-color: #333;
  border-radius: 5px;
}

.lifeSupport-image {
  width: 235px;
  height: 132px;
  border-radius: var(--border-radius-S);
}

.lifeSupport-image:hover {
  opacity: .6;
  transition: opacity .4s;
}


/* section-center */
.section-lifesupport-center {
  padding: 0;
  margin-top: 36px;
  padding: 58.5px 0 48px 0;
  background: #FCE9EE;
}

.section-lifesupport-center div.container {
  padding: 0;
}

.section-lifesupport-center div.row {
  justify-content: center;
}

.section-lifesupport-center p.lifesupport-center.large {
  font-size: 24px;
  color: #585A61;
  letter-spacing: 0px;
  line-height: 48px;
  margin-bottom: 0px;
}

.section-lifesupport-center p.lifesupport-center.small {
  font-size: 14px;
  color: #47536E;
  letter-spacing: 0px;
  line-height: 20px;
  margin: 23.5px 0px 0px 0px;
}

.section-lifesupport-center p.lifesupport-center.middle {
  font-size: 18px;
  color: #47536E;
  letter-spacing: 0px;
  line-height: 27px;
  padding-top: 26.5px;
}

.section-lifesupport-center img {
  width: 162px;
  height: 216px;
  margin: 29.02px 0 0 18px;
  image-rendering: -webkit-optimize-contrast;
}

.section-lifesupport-center .contact-button {
  display: inline-block;
  font-size: 18px;
  padding: 20px 100px;
  background: #FFFFFF 0% 0% no-repeat padding-box;
  width: 319px;
  height: 68px;
  border: 2px solid #EA97A5;
  border-radius: 80px;
  opacity: 1;
  margin-top: 16px;
}

.section-lifesupport-center .contact-button:hover {
  color: #ffffff;
  background-color: #EA97A5;
}

.section-lifesupport-center br.br-sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .section-lifesupport-center {
    padding: 0;
    margin-top: 32px;
    padding: 32px 0;
    background: #FCE9EE;
    width: 100%;
    height: 534px;
    margin: 0 auto;
    margin-top: 32px;
  }

  .section-lifesupport-center div.container {
    text-align: center;
    height: 534px;
  }

  .section-lifesupport-center div.row {
    display: flex;
    flex-direction: column-reverse;
  }

  .section-lifesupport-center div.lifesupport-center-large {
    width: 335px;
    height: 157px;
    background: #fff;
    border-radius: var(--border-radius-M);
    padding: 33px 0;
  }

  .section-lifesupport-center img {
    width: 85px;
    height: 113px;
    margin: 0 auto;
    image-rendering: -webkit-optimize-contrast;
  }

  .section-lifesupport-center div.lifesupport-center-sentence {
    width: 375px;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    padding-top: 450px;
  }

  .section-lifesupport-center div.lifesupport-center-sentence div.lifesupport-center-large {
    margin-left: 20px;
  }

  .section-lifesupport-center div.lifesupport-center-img {
    top: 959px;
    left: 145px;
    z-index:1;
  }

  .section-lifesupport-center p.lifesupport-center.large {
    font-size: 16px;
    color: #585A61;
    letter-spacing: 0px;
    line-height: 36px;
    margin-bottom: 0px;
  }

  .section-lifesupport-center p.lifesupport-center.small {
    font-size: 14px;
    color: #47536E;
    letter-spacing: 0px;
    line-height: 38px;
  }

  .section-lifesupport-center p.lifesupport-center.middle {
    font-size: 14px;
    color: #47536E;
    letter-spacing: 0px;
    line-height: 20px;
    padding-top: 28px;
  }

  .section-lifesupport-center br.br-sp {
    display: block !important;
  }

}

/* section-under */
.section-lifesupport-under {
  padding: 0;
  margin: 48px 0;
}

.section-lifesupport-under img {
  width: 731px;
  height: 132px;
  margin-top: 32px;
  border: 1px solid #B3B3B3;
}

section.lifesupport-under img:hover {
  opacity: 0.6;
}

.section-lifesupport-under p.lifesupport-under.large {
  font-size: 24px;
  line-height: 36px;
  letter-spacing: 0px;
  color: #47536E;
  margin-bottom: 18px;
}

.section-lifesupport-under p.lifesupport-under.middle {
  font-size: 16px;
  line-height: 26px;
  letter-spacing: 0px;
  color: #47536E;
  margin-bottom: 0px;
}

.section-lifesupport-under br.br-sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .section-lifesupport-under {
    padding: 32px;
    margin: 0;
  }

  .section-lifesupport-under div.container{
    padding: 0;
  }

  .section-lifesupport-under p.lifesupport-under.large {
    font-size: 18px;
    line-height: 26px;
    text-align: center;
    letter-spacing: 0px;
    color: #47536E;
    margin-bottom: 16px;
  }

  .section-lifesupport-under p.lifesupport-under.middle {
    font-size: 14px;
    line-height: 26px;
    text-align: center;
    letter-spacing: 0px;
    color: #47536E;
  }

  .section-lifesupport-under img {
    margin-top: 32px;
    height: 176px;
    max-width: 100%;
    object-fit: contain;
    border: none;
  }

  .section-lifesupport-under br.br-sp {
    display: block !important;
  }
}

/* rb */
.page_lifesupport rb {
  position: relative;
}

.page_lifesupport rb::before {
  position: absolute;
  top: -15px;
}

.section-lifesupport-top p.lifesupport-top rb.rb1::before {
  content: 'げんざいていきょうちゅう';
  font-size: 10px;
  line-height: 15px;
  left: -17px;
  letter-spacing: 0;
  width: 150%;
}

p.lifesupport-top rb.rb2::before {
  content: 'らいふさぽーとめにゅー';
  font-size: 10px;
  line-height: 15px;
  letter-spacing: 6px;
  left: 20px;
}

p.lifesupport-center rb.rb1::before {
  content: 'しんきにゅうこく';
  font-size: 10px;
  line-height: 15px;
  left: 5px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb2::before {
  content: 'てんしょく';
  font-size: 10px;
  line-height: 15px;
  left: -2px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb3::before {
  content: 'ひ';
  font-size: 10px;
  line-height: 15px;
  left: 30px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb4::before {
  content: 'こ';
  font-size: 10px;
  line-height: 15px;
  left: 3px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb5::before {
  content: 'あ';
  font-size: 10px;
  line-height: 15px;
  left: 4px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb6::before {
  content: 'ひつよう';
  font-size: 10px;
  line-height: 15px;
  left: 4px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb7::before {
  content: 'さーびす';
  font-size: 10px;
  line-height: 15px;
  left: 15px;
  letter-spacing: 6px;
}

p.lifesupport-center rb.rb8::before {
  content: 'すべ';
  font-size: 10px;
  line-height: 15px;
  left: 2px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb9::before {
  content: 'ていきょう';
  font-size: 10px;
  line-height: 15px;
  left: -2px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb10::before {
  content: 'こじんけいやく・ほうじんけいやく';
  font-size: 10px;
  line-height: 15px;
  left: 2px;
  letter-spacing: 0px;
  width: 200%;
}

p.lifesupport-center rb.rb11::before {
  content: 'じょうきょう';
  font-size: 10px;
  line-height: 15px;
  left: -15px;
  letter-spacing: 0px;
  width: 250%;
}

p.lifesupport-center rb.rb12::before {
  content: 'ていあん';
  font-size: 10px;
  line-height: 15px;
  left: -10px;
  letter-spacing: 0px;
  width: 250%;
}

p.lifesupport-center rb.rb13::before {
  content: 'と';
  font-size: 10px;
  line-height: 15px;
  left: 1px;
  letter-spacing: 0px;
}

p.lifesupport-center rb.rb14::before {
  content: 'あ';
  font-size: 10px;
  line-height: 15px;
  left: 1px;
  letter-spacing: 0px;
}

@media only screen and (max-width: 768px) {
  .section-lifesupport-top p.lifesupport-top rb.rb1::before {
    content: 'げんざいていきょうちゅう';
    font-size: 10px;
    line-height: 15px;
    left: -12px;
    letter-spacing: 0;
    width: 150%;
  }

  p.lifesupport-top rb.rb2::before {
    content: 'らいふさぽーとめにゅー';
    font-size: 10px;
    line-height: 15px;
    letter-spacing: 6px;
    left: 20px;
  }

  p.lifesupport-center rb.rb1::before {
    content: 'しんきにゅうこく';
    font-size: 10px;
    line-height: 15px;
    left: -12px;
    letter-spacing: 0px;
    width: 150%;
  }

  p.lifesupport-center rb.rb2::before {
    content: 'てんしょく';
    font-size: 10px;
    line-height: 15px;
    left: -15px;
    letter-spacing: 0px;
    width: 200%;
  }

  p.lifesupport-center rb.rb3::before {
    content: 'ひ';
    font-size: 10px;
    line-height: 15px;
    left: 17px;
    letter-spacing: 0px;
  }

  p.lifesupport-center rb.rb4::before {
    content: 'こ';
    font-size: 10px;
    line-height: 15px;
    left: 3px;
    letter-spacing: 0px;
  }

  p.lifesupport-center rb.rb5::before {
    content: 'あ';
    font-size: 10px;
    line-height: 15px;
    left: 3px;
    letter-spacing: 0px;
  }

  p.lifesupport-center rb.rb6::before {
    content: 'ひつよう';
    font-size: 10px;
    line-height: 15px;
    left: -4px;
    letter-spacing: 0px;
    width: 150%;
  }

  p.lifesupport-center rb.rb7::before {
    content: 'さーびす';
    font-size: 10px;
    line-height: 15px;
    left: -10px;
    letter-spacing: 6px;
    width: 150%;
  }

  p.lifesupport-center rb.rb8::before {
    content: 'すべ';
    font-size: 10px;
    line-height: 15px;
    left: -4px;
    letter-spacing: 0px;
    width: 150%;
  }

  p.lifesupport-center rb.rb9::before {
    content: 'ていきょう';
    font-size: 10px;
    line-height: 15px;
    left: -10px;
    letter-spacing: 0px;
    width: 200%;
  }

  p.lifesupport-center rb.rb10::before {
    content: 'こじんけいやく・ほうじんけいやく';
    font-size: 10px;
    line-height: 15px;
    left: -45px;
    letter-spacing: 0px;
  }

  p.lifesupport-center rb.rb11::before {
    content: 'じょうきょう';
    font-size: 10px;
    line-height: 15px;
    left: -20px;
    letter-spacing: 0px;
    width: 250%;
  }

  p.lifesupport-center rb.rb12::before {
    content: 'ていあん';
    font-size: 10px;
    line-height: 15px;
    left: -20px;
    letter-spacing: 0px;
    width: 250%;
  }

  p.lifesupport-center rb.rb13::before {
    content: 'と';
    font-size: 10px;
    line-height: 15px;
    left: 1px;
    letter-spacing: 0px;
  }

  p.lifesupport-center rb.rb14::before {
    content: 'あ';
    font-size: 10px;
    line-height: 15px;
    left: 1px;
    letter-spacing: 0px;
  }
}

/*===========================
  --- CUSTOMS ----
=========================== */

.font-family-hiragino {
  font-family: "Hiragino Sans", sans-serif !important;
}

.font-weight-400 {
  font-weight: 400 !important;
}

.font-weight-500 {
  font-weight: 500 !important;
}

.font-weight-600 {
  font-weight: 600 !important;
}

.font-weight-700 {
  font-weight: 700 !important;
}

.font-weight-800 {
  font-weight: 800 !important;
}

.text-pink {
  color: #f892a4 !important;
}

.text-salmon {
  color: salmon !important;
}

.bg-pink {
  background-color: #f892a4 !important;
}

.bg-white {
  background-color: #fff !important;
}

.pink-border {
  border: 2px solid #f892a4 !important;
}

.doted-text {
  display: inline-block;
  position: relative;
}

.doted-text:before {
  content: ".";
  font-weight: bolder;
  display: inline-block;
  position: absolute;
  top: -1.2em;
  left: 0;
  text-align: center;
  width: 100%;
}

/*--- custom font sizes ---*/

.fs-b-10 {
  font-size: 10px !important;
  line-height: 20px !important;
}
.fs-b-11 {
  font-size: 11px !important;
  line-height: 21px !important;
}
.fs-b-12 {
  font-size: 12px !important;
  line-height: 22px !important;
}
.fs-b-13 {
  font-size: 13px !important;
  line-height: 23px !important;
}
.fs-b-14 {
  font-size: 14px !important;
  line-height: 24px !important;
}
.fs-b-15 {
  font-size: 15px !important;
  line-height: 25px !important;
}
.fs-b-16 {
  font-size: 16px !important;
  line-height: 26px !important;
}
.fs-b-17 {
  font-size: 17px !important;
  line-height: 27px !important;
}
.fs-b-18 {
  font-size: 18px !important;
  line-height: 28px !important;
}
.fs-b-19 {
  font-size: 19px !important;
  line-height: 29px !important;
}
.fs-b-20 {
  font-size: 20px !important;
  line-height: 30px !important;
}
.fs-b-22 {
  font-size: 22px !important;
  line-height: 32px !important;
}
.fs-b-24 {
  font-size: 24px !important;
  line-height: 34px !important;
}
.fs-b-26 {
  font-size: 26px !important;
  line-height: 36px !important;
}
.fs-b-28 {
  font-size: 28px !important;
  line-height: 38px !important;
}
.fs-b-30 {
  font-size: 30px !important;
  line-height: 40px !important;
}
.fs-b-32 {
  font-size: 32px !important;
  line-height: 42px !important;
}
.fs-b-34 {
  font-size: 34px !important;
  line-height: 44px !important;
}
.fs-b-36 {
  font-size: 36px !important;
  line-height: 46px !important;
}
.fs-b-38 {
  font-size: 38px !important;
  line-height: 48px !important;
}
.fs-b-40 {
  font-size: 40px !important;
  line-height: 50px !important;
}
.fs-b-42 {
  font-size: 42px !important;
  line-height: 52px !important;
}
.fs-b-44 {
  font-size: 44px !important;
  line-height: 54px !important;
}

/* for small screen */
@media screen and (max-width: 991px) {
  .fs-s-10 {
    font-size: 10px !important;
    line-height: 20px !important;
  }
  .fs-s-11 {
    font-size: 11px !important;
    line-height: 21px !important;
  }
  .fs-s-12 {
    font-size: 12px !important;
    line-height: 22px !important;
  }
  .fs-s-13 {
    font-size: 13px !important;
    line-height: 23px !important;
  }
  .fs-s-14 {
    font-size: 14px !important;
    line-height: 24px !important;
  }
  .fs-s-15 {
    font-size: 15px !important;
    line-height: 25px !important;
  }
  .fs-s-16 {
    font-size: 16px !important;
    line-height: 26px !important;
  }
  .fs-s-17 {
    font-size: 17px !important;
    line-height: 27px !important;
  }
  .fs-s-18 {
    font-size: 18px !important;
    line-height: 28px !important;
  }
  .fs-s-19 {
    font-size: 19px !important;
    line-height: 29px !important;
  }
  .fs-s-20 {
    font-size: 20px !important;
    line-height: 30px !important;
  }
  .fs-s-22 {
    font-size: 22px !important;
    line-height: 32px !important;
  }
  .fs-s-24 {
    font-size: 24px !important;
    line-height: 34px !important;
  }
  .fs-s-26 {
    font-size: 26px !important;
    line-height: 36px !important;
  }
  .fs-s-28 {
    font-size: 28px !important;
    line-height: 38px !important;
  }
  .fs-s-30 {
    font-size: 30px !important;
    line-height: 40px !important;
  }
  .fs-s-32 {
    font-size: 32px !important;
    line-height: 42px !important;
  }
  .fs-s-34 {
    font-size: 34px !important;
    line-height: 44px !important;
  }
  .fs-s-36 {
    font-size: 36px !important;
    line-height: 46px !important;
  }
  .fs-s-38 {
    font-size: 38px !important;
    line-height: 48px !important;
  }
  .fs-s-40 {
    font-size: 40px !important;
    line-height: 50px !important;
  }
  .fs-s-42 {
    font-size: 42px !important;
    line-height: 52px !important;
  }
  .fs-s-44 {
    font-size: 44px !important;
    line-height: 54px !important;
  }
}

/* for tiny screen */
@media screen and (max-width: 575px) {
  .fs-t-10 {
    font-size: 10px !important;
    line-height: 20px !important;
  }
  .fs-t-11 {
    font-size: 11px !important;
    line-height: 21px !important;
  }
  .fs-t-12 {
    font-size: 12px !important;
    line-height: 22px !important;
  }
  .fs-t-13 {
    font-size: 13px !important;
    line-height: 23px !important;
  }
  .fs-t-14 {
    font-size: 14px !important;
    line-height: 24px !important;
  }
  .fs-t-15 {
    font-size: 15px !important;
    line-height: 25px !important;
  }
  .fs-t-16 {
    font-size: 16px !important;
    line-height: 26px !important;
  }
  .fs-t-17 {
    font-size: 17px !important;
    line-height: 27px !important;
  }
  .fs-t-18 {
    font-size: 18px !important;
    line-height: 28px !important;
  }
  .fs-t-19 {
    font-size: 19px !important;
    line-height: 29px !important;
  }
  .fs-t-20 {
    font-size: 20px !important;
    line-height: 30px !important;
  }
  .fs-t-22 {
    font-size: 22px !important;
    line-height: 32px !important;
  }
  .fs-t-24 {
    font-size: 24px !important;
    line-height: 34px !important;
  }
  .fs-t-26 {
    font-size: 26px !important;
    line-height: 36px !important;
  }
  .fs-t-28 {
    font-size: 28px !important;
    line-height: 38px !important;
  }
  .fs-t-30 {
    font-size: 30px !important;
    line-height: 40px !important;
  }
  .fs-t-32 {
    font-size: 32px !important;
    line-height: 42px !important;
  }
  .fs-t-34 {
    font-size: 34px !important;
    line-height: 44px !important;
  }
  .fs-t-36 {
    font-size: 36px !important;
    line-height: 46px !important;
  }
  .fs-t-38 {
    font-size: 38px !important;
    line-height: 48px !important;
  }
  .fs-t-40 {
    font-size: 40px !important;
    line-height: 50px !important;
  }
  .fs-t-42 {
    font-size: 42px !important;
    line-height: 52px !important;
  }
  .fs-t-44 {
    font-size: 44px !important;
    line-height: 54px !important;
  }
}

/*--- custom margin ---*/

/* for big screen */
/* margin top */
.mt-b-0 {
  margin-top: 0px !important;
}
.mt-b-10 {
  margin-top: 10px !important;
}
.mt-b-14 {
  margin-top: 14px !important;
}
.mt-b-30 {
  margin-top: 30px !important;
}
.mt-b-34 {
  margin-top: 34px !important;
}
.mt-b-50 {
  margin-top: 50px !important;
}
.mt-b-60 {
  margin-top: 60px !important;
}
.mt-b-72 {
  margin-top: 72px !important;
}
/* margin bottom */
.mb-b-5 {
  margin-bottom: 5px !important;
}
.mb-b-10 {
  margin-bottom: 10px !important;
}
.mb-b-12 {
  margin-bottom: 12px !important;
}
.mb-b-30 {
  margin-bottom: 30px !important;
}
.mb-b-40 {
  margin-bottom: 40px !important;
}
.mb-b-44 {
  margin-bottom: 44px !important;
}
.mb-b-50 {
  margin-bottom: 50px !important;
}
.mb-b-80 {
  margin-bottom: 80px !important;
}
/* margin left */
.ml-b-5 {
  margin-left: 4px !important;
}
.ml-b-12 {
  margin-left: 12px !important;
}
/* margin right */
.mr-b-4 {
  margin-right: 4px !important;
}
.mr-b-12 {
  margin-right: 12px !important;
}

/* for small screen */
@media screen and (max-width: 991px) {
  /* margin top */
  .mt-s-0 {
    margin-top: 0px !important;
  }
  .mt-s-10 {
    margin-top: 10px !important;
  }
  .mt-s-14 {
    margin-top: 14px !important;
  }
  .mt-s-30 {
    margin-top: 30px !important;
  }
  .mt-s-34 {
    margin-top: 34px !important;
  }
  .mt-s-40 {
    margin-top: 40px !important;
  }
  .mt-s-48 {
    margin-top: 48px !important;
  }
  /* margin bottom */
  .mb-s-10 {
    margin-bottom: 10px !important;
  }
  .mb-s-12 {
    margin-bottom: 12px !important;
  }
  .mb-s-20 {
    margin-bottom: 20px !important;
  }
  .mb-s-30 {
    margin-bottom: 30px !important;
  }
  .mb-s-40 {
    margin-bottom: 40px !important;
  }
  .mb-s-50 {
    margin-bottom: 50px !important;
  }
  /* margin left */
  .ml-s-0{
    margin-left: 0px !important;
  }
  .ml-s-12 {
    margin-left: 12px !important;
  }
  /* margin right */
  .mr-s-4 {
    margin-right: 4px !important;
  }
  .mr-s-12 {
    margin-right: 12px !important;
  }
}

/*--- custom padding ---*/

/* for big screen */

/* padding top */
.pt-b-10 {
  padding-top: 10px !important;
}
.pt-b-20 {
  padding-top: 20px !important;
}
/* padding bottom */
.pb-b-10 {
  padding-bottom: 10px !important;
}
.pb-b-20 {
  padding-bottom: 20px !important;
}
/* padding left */
.pl-b-20 {
  padding-left: 20px !important;
}
/* padding right */
.pr-b-20 {
  padding-right: 20px !important;
}

/* for small screen */
@media screen and (max-width: 991px) {
  /* padding top */
  .pt-s-30 {
    padding-top: 30px !important;
  }
  /* padding bottom */
  .pb-s-30 {
    padding-bottom: 30px !important;
  }
  /* padding left */
  .pl-s-20 {
    padding-left: 20px !important;
  }
  /* padding right */
  .pr-s-20 {
    padding-right: 20px !important;
  }
}

/*--- line height ---*/

/* for big screen */
.lh-b-18 {
  line-height: 18px !important;
}
/* for small screen */
@media screen and (max-width: 991px) {
  .lh-b-18 {
    line-height: 18px !important;
  }
}

/* --- Privacy languages page ---*/
.privacies .cnt{
  max-width: 690px;
  text-align: justify;
  margin: 0 auto;
}
.privacies h5{
  text-transform: uppercase;
  font-weight: 700;
  font-size: 14px;
  color: #47536E;
}
.privacies li{
  font-size: 12px;
  color: #47536E;
}
.privacies ul{
  padding-left: 0;
  list-style-type: none;
}
.language-btn-wrapper {
  display: table;
  margin: 0 auto;
}
.language-btn-wrapper .btn-wrapper{
  display: inline-block;
  margin-right: 8px;
  margin-bottom: 8px;
}
.language-btn-wrapper .btn-wrapper:last-child{
  margin-right: 0;
}
.language-btn-wrapper span{
  width: 90px;
  line-height: 34px;
  white-space: nowrap;
  display: inline-block;
  text-align: center;
  color: #F892A4;
  border: 1px solid #F892A4;
  border-radius: var(--border-radius-S);
}
.language-btn-wrapper span:hover{
  cursor: pointer;
  opacity: 0.4;
}
.language-btn-wrapper span.active{
  background-color: #F892A4;
  color: #FFFFFF;
  opacity: 1;
}
.language-btn-wrapper span.active:hover{
  cursor: default;
}

@media screen and (max-width: 575px) {
  .language-btn-wrapper .btn-wrapper{
    width: 33.33%;
    margin: 0;
    padding-bottom: 8px;
    padding-right: 8px;
  }

  .language-btn-wrapper .btn-wrapper:nth-child(3n+3){
    padding-right: 0;
  }
  .language-btn-wrapper span{
    width: 100%;
  }
}

/* Cookie policy page */
.custom-table-wrapper {
  overflow: auto;
}

.custom-table thead {
  background-color: #f2f2f2;
}

.custom-table th,
.custom-table td {
  font-size: 14px;
  border: 1px solid #dee2e6;
}

/* --- お知らせ表示 ---*/
.head-notification-area-wrapper {
  position: relative;
  background-color: #F8AEC3;
  height: 88px;
  top: 76px;
  margin-bottom: -88px;
}

.head-notification-area {
  position: fixed;
  top: 76px;
  width: 100%;
  z-index: 10;
  text-align: center;
  padding: 8px;
  background-color: #ff5c86dd;
  color: #333333;
}

.head-notification-message {
  margin: 0;
}

.head-notification-message > a,
.head-notification-message-for-sp > a {
  color: #003ff5;
}

@media (max-width: 991px) {
  .head-notification-area-wrapper {
    display: none;
  }
}

.head-notification-area-wrapper-for-sp {
  display: none;
  padding: 0;
}

@media (max-width: 991px) {
  .head-notification-area-wrapper-for-sp {
    display: block !important;
  }
}

.head-notification-area-for-sp {
  width: 100%;
  text-align: center;
  padding: 18px;
  background-color: #ff5c86;
  color: white;
  line-height: 1.4;
}

.head-notification-message-for-sp {
  margin-bottom: 8px;
}

/*--------------------------------------------------------------
# ad LP
--------------------------------------------------------------*/
/*--- reset ---*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, 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, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin:0;
  padding:0;
  border:0;
  outline:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}


/*--- lp common ---*/
@media (max-width: 991px) {
  .br-pc {
    display: none;
  }
}
@media (min-width: 990px) {
  .br-tb {
    display: none;
  }
}
@media (min-width: 576px) {
  .br-sp {
    display: none;
  }
}

.arrow {
  font-family: 'boxicons' !important;
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  line-height: 1;
  display: inline-block;
  text-transform: none;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-right: 2px;
  color: #9fb2d8;
  font-size: 18px;
}
.list-arrow::before {
  content: '\ea1d';
}
.button-arrow {
  margin-left: 6px;
}
@media (max-width: 575px) {
  .button-arrow {
    margin-left: 1px;
  }
}

.text-underline {
  border-bottom: solid;
  border-color: #f299b1;
  border-width: 4px;
}

.text-emphasis {
  color: #f299b1;
}

.text-border {
  display: inline-block;
  margin-right: 5px;
  padding: 0 10px;
  border: 2px solid #f299b1;
  border-radius: 20px;
}
@media (max-width: 991px) {
  .text-border {
    border-radius: 10px;
  }
}

.lp-button-area {
  max-width: 450px;
  margin: 0 auto;
  padding: 10px 0;
  font-size: 18px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 575px) {
  .lp-button-area {
    font-size: 15px;
  }
}
@media (max-width: 330px) {
  .lp-button-area {
    display: block;
    font-size: 13px;
  }
}

.lp-button-area .document {
  display: inline-block;
  width: 205px;
  height: 58px;
  border-radius: 80px;
  background-color: #00838a;
  color: #fff;
  text-align: center;
  line-height: 58px;
}
.lp-button-area .document:hover {
  opacity: .8;
  text-decoration: none;
  transition: .3s;
}
@media (max-width: 575px) {
  .lp-button-area .document {
    width: 49%;
    height: 54px;
    border-radius: 80px;
    line-height: 54px;
  }
}

.lp-button-area .inquiry {
  display: inline-block;
  width: 205px;
  height: 58px;
  border-radius: 80px;
  background-color: #fff;
  color: #00838a;
  border: 2px solid #00838a;
  text-align: center;
  line-height: 54px;
}
.lp-button-area .inquiry:hover {
  opacity: .8;
  text-decoration: none;
  transition: .3s;
}
@media (max-width: 575px) {
  .lp-button-area .inquiry {
    width: 49%;
    height: 54px;
    border-radius: 80px;
    line-height: 50px;
  }
}

.balloon {
  display: inline-block;
  position: relative;
  padding: 7px 24px;
  background: #666;
  border-radius: 50px;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .balloon {
    font-size: 19px;
  }
}

.balloon::after {
  content: '';
  position: absolute;
  margin: 0;
  bottom: -20px;
  right: 30px;
  width: 0;
  height: 0;
  border-top: 30px solid #666;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  transform: rotate(-30deg);
}


/*--- lp header ---*/
.lp-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 200;
  background: white;
  box-shadow: 0px 3px 6px #00000029;
}

.lp-header nav {
  max-width: 1140px;
  height: 76px; /* for big screen */
  display: flex;
  align-content: center;
  position: relative;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
  padding: 8px 15px;
}
@media (max-width: 991px) {
  .lp-header nav {
    height: 69px;
  }
}

.lp-header .logo-image {
  height: 38px;
}
@media (max-width: 991px) {
  .lp-header .logo-image {
    height: 24px;
    margin-right: 20px;
  }
}

.lp-header ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 0;
  padding: 0;
}

.lp-header li {
  list-style: none;
}
.lp-header li:not(:last-child) {
  padding-right: 17px;
}

.lp-header li a {
  color: #47536e;
  background-color: transparent;
}

.lp-header li a:hover {
  opacity: .8;
  text-decoration: none;
  transition: .3s;
}


/*--- lp main ---*/

/*--- lp section1 ---*/
.lp-section1 {
  position: relative;
  width: 100%;
  height: 550px;
  margin-top: 76px;
}
@media (max-width: 991px) {
  .lp-section1 {
    height: 750px;
    margin-top: 69px;
  }
}
@media (max-width: 575px) {
  .lp-section1 {
    height: 575px;
    margin-top: 69px;
  }
}

.lp-section1 .cover {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(59, 68, 90, .3);
  z-index: 100;
}

.lp-section1 .kv {
  width: 100%;
  height: 550px;
  position: absolute;
  background: linear-gradient(to right, transparent 0%, transparent 90%, #fff 100%), url(../img/lp_kv_pc.png);
  background-repeat: no-repeat;
  background-size: auto 600px;
  overflow: hidden;
  object-fit: cover;
  z-index: 99;
}
@media (max-width: 1700px) {
  .lp-section1 .kv {
    right: 40%;
    background-position: right;
  }
}
@media (max-width: 1350px) {
  .lp-section1 .kv {
    right: 33%;
  }
}
@media (max-width: 991px) {
  .lp-section1 .kv {
    width: 100%;
    min-height: 100%;
    position: static;
    right: auto;
    background: linear-gradient(to bottom, transparent 0%, transparent 90%, #fff 100%), url(../img/lp_kv_tb.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top center;
    overflow: hidden;
    object-fit: contain;
  }
}
@media (max-width: 750px) {
  .lp-section1 .kv {
    background: linear-gradient(to bottom, transparent 0%, transparent 90%, #fff 100%), url(../img/lp_kv_sp.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top center;
    overflow: hidden;
    object-fit: contain;
  }
}

.lp-section1 .head-area {
  width: 60%;
  height: 100%;
  position: absolute;
  right: 0;
  margin: 0 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(45deg, rgba(255, 245, 229, .8) 0%,rgba(242, 153, 177, .8) 100%);
  clip-path: polygon(12% 0%, 100% 0%, 100% 100%, 0% 100%);
  z-index: 101;
}
@media (max-width: 991px) {
  .lp-section1 .head-area {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 150px 20px 40px;
    bottom: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    clip-path: polygon(0% 30%, 100% 0%, 100% 100%, 0% 100%);
  }
}

.lp-section1 .head-1 {
  margin-bottom: 40px;
  font-size: 37px;
  font-weight: bold;
  text-shadow: none;
}
@media (max-width: 1350px) {
  .lp-section1 .head-1 {
    margin-bottom: 30px;
    font-size: 30px;
  }
}
@media (max-width: 575px) {
  .lp-section1 .head-1 {
    margin-bottom: 30px;
    font-size: 22px;
  }
}

.lp-section1 .head-2 {
  margin-bottom: 40px;
  font-size: 27px;
  text-shadow: none;
}
@media (max-width: 1350px) {
  .lp-section1 .head-2 {
    margin-bottom: 30px;
    font-size: 20px;
  }
}
@media (max-width: 575px) {
  .lp-section1 .head-2 {
    margin-bottom: 30px;
    font-size: 15px;
  }
}


/*--- lp section2 ---*/
.lp-section2 {
  padding: 100px 0 200px;
  font-size: 22px;
}
@media (max-width: 991px) {
  .lp-section2 {
    padding: 50px 0 20%;
    font-size: 15px;
  }
}
@media (max-width: 575px) {
  .lp-section2 {
    padding: 50px 0 280px;
  }
}
@media (max-width: 400px) {
  .lp-section2 {
    padding: 50px 0 75%;
  }
}

.lp-section2 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 30px;
}

.lp-section2 .balloon {
  background: #f299b1;
}

.lp-section2 .balloon::after {
  border-top: 30px solid #f299b1;
  left: 45px;
}

.lp-section2 .content {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
@media (max-width: 575px) {
  .lp-section2 .content {
    display: block;
  }
}

.lp-section2 .box-1 {
  width: 40%;
}
@media (max-width: 575px) {
  .lp-section2 .box-1 {
    text-align: center;
    width: 90%;
    margin: 0 auto 30px;
  }
}

.lp-section2 .balloon {
  margin-bottom: 40px;
}

.lp-section2 .pc-image {
  width: 100%;
}

.lp-section2 .box-2 {
  width: 55%;
}
@media (max-width: 575px) {
  .lp-section2 .box-2 {
    width: 100%;
  }
}

.lp-section2 .head-1 {
  margin-bottom: 30px;
}
@media (max-width: 575px) {
  .lp-section2 .head-1 {
    text-align: center;
    margin-bottom: 20px;
  }
}

.lp-section2 .logo-image {
  height: 53px;
}
@media (max-width: 991px) {
  .lp-section2 .logo-image {
    height: 38px;
  }
}

.lp-section2 .head-1 > span {
  vertical-align: 15%;
  font-size: 36px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section2 .head-1 > span {
    font-size: 22px;
  }
}

.lp-section2 .head-2 {
  line-height: 50px;
  font-size: 22px;
}
@media (max-width: 991px) {
  .lp-section2 .head-2 {
    line-height: 35px;
    font-size: 15px;
  }
}

.lp-section2 .text-border {
  display: inline-block;
  margin: 5px 10px 5px 0;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section2 .text-border {
    margin: 5px 5px 5px 0;
    border-radius: 10px;
  }
}


/*--- lp section3 ---*/
.lp-section3 {
  padding: 80px 0 80px;
  background-color: #ebf4f5;
  overflow: visible;
}
@media (max-width: 991px) {
  .lp-section3 {
    padding: 50px 0 40px;
  }
}
@media (max-width: 575px) {
  .lp-section3 {
    padding: 80px 0 40px;
  }
}

.lp-section3 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 30px;
  position: relative;
}
@media (max-width: 575px) {
  .lp-section3 .wrapper {
    padding: 0;
  }
}

.lp-section3 .balloon {
  background: #66adb1;
  position: absolute;
  top: -55%;
  right: 30px;
  transform: translateY(-50%);
}
@media (max-width: 991px) {
  .lp-section3 .balloon {
    top: -56%;
    right: 30px;
  }
}
@media (max-width: 575px) {
  .lp-section3 .balloon {
    top: -94%;
    right: auto;
    left: 50%;
    transform: translate(-50%, 0);
  }
}
@media (max-width: 400px) {
  .lp-section3 .balloon {
    top: -100%;
    transform: translate(-50%, 0);
  }
}
@media (max-width: 350px) {
  .lp-section3 .balloon {
    top: -105%;
    transform: translate(-50%, 0);
  }
}

.lp-section3 .balloon::after {
  border-top: 30px solid #66adb1;
  right: 45px;
  transform: rotate(30deg);
}

.lp-section3 .content {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 575px) {
  .lp-section3 .content {
    display: block;
  }
}

.lp-section3 .box-1 {
  width: 55%;
}
@media (max-width: 575px) {
  .lp-section3 .box-1 {
    width: 100%;
    position: absolute;
    top: -35%;
    transform: translate(0, -50%);
    box-sizing: border-box;
    padding: 0 15px;
    text-align: center;
  }
}

.lp-section3 .head {
  margin-bottom: 40px;
  font-size: 34px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section3 .head {
    margin-bottom: 30px;
    font-size: 22px;
  }
}
@media (max-width: 575px) {
  .lp-section3 .head {
    margin-bottom: 20px;
  }
}
@media (max-width: 350px) {
  .lp-section3 .head {
    font-size: 20px;
  }
}

@media (max-width: 575px) {
  .lp-section3 .textballoon-wrapper {
    max-width: 350px;
    margin: 0 auto;
  }
}

.lp-section3 .textballoon-short {
  width: 100%;
}

.lp-section3 .textballoon {
  width: 100%;
}

@media (min-width: 576px) {
  .lp-section3 .textballoon-short {
    display: none;
  }
}
@media (max-width: 575px) {
  .lp-section3 .textballoon {
    display: none;
  }
}

@media (max-width: 575px) {
  .lp-section3 .box-2 {
    max-width: 400px;
    margin: 0 auto;
  }
}

.lp-section3 .person-image {
  width: 40%;
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  right: 30px;
}
@media (max-width: 575px) {
  .lp-section3 .person-image {
    width: 100%;
    padding: 0 30px;
    position: static;
    top: 0;
    right: 0;
    transform: translateY(0);
  }
}

.lp-section3 .contents-arrow {
  width: 0;
  height: 0;
  position: absolute;
  bottom: -115px;
  left: 50%;
  transform: translate(-50%, 0);
  border-style: solid;
  border-width: 38px 66px 0 66px;
  border-color: rgb(235, 244, 245, 1) transparent transparent transparent;
}
@media (max-width: 991px) {
  .lp-section3 .contents-arrow {
    bottom: -75px;
  }
}


/*--- lp section4 ---*/
.lp-section4 {
  padding: 180px 0 50px;
}
@media (max-width: 991px) {
  .lp-section4 {
    padding: 80px 0 20px;
  }
}

.lp-section4 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 30px;
  text-align: center;
}
@media (max-width: 575px) {
  .lp-section4 .wrapper {
    padding: 0 15px;
  }
}

.lp-section4 .balloon {
  background: #f299b1;
  margin-bottom: 50px;
}
@media (max-width: 991px) {
  .lp-section4 .balloon {
    margin-bottom: 30px;
  }
}

.lp-section4 .balloon::after {
  border-top: 30px solid #f299b1;
  left: 45px;
}

.lp-section4 .head-1 {
  margin-bottom: 50px;
  font-size: 34px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section4 .head-1 {
    margin-bottom: 30px;
    font-size: 22px;
  }
}

.lp-section4 .head-1 .text-emphasis {
  display: inline-block;
}

.lp-section4 .head-2 {
  margin-bottom: 60px;
  font-size: 20px;
}
@media (max-width: 991px) {
  .lp-section4 .head-2 {
    margin-bottom: 40px;
    font-size: 15px;
  }
}
@media (max-width: 575px) {
  .lp-section4 .head-2 {
    text-align: left;
  }
}

.lp-section4 .benefit-box {
  width: 100%;
  display: flex;
  justify-content: center;
}
@media (max-width: 575px) {
  .lp-section4 .benefit-box {
    display: block;
  }
}

.lp-section4 .benefit-item {
  width: 45%;
  margin-bottom: 50px;
}
@media (max-width: 575px) {
  .lp-section4 .benefit-item {
    width: 100%;
    margin-bottom: 30px;
  }
}

.lp-section4 .benefit-item:not(:last-child) {
  margin-right: 30px;
}
@media (max-width: 575px) {
  .lp-section4 .benefit-item:not(:last-child) {
    margin-right: 0;
  }
}

.lp-section4 .benefit-image {
  margin-bottom: 20px;
}
@media (max-width: 991px) {
  .lp-section4 .benefit-image {
    margin: 0 auto 10px;
    max-width: 400px;
  }
}

.lp-section4 .benefit-image img {
  width: 100%;
  border: 1px solid #b0b5b9;
}

.lp-section4 .text-1 {
  margin-bottom: 20px;
  font-size: 22px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section4 .text-1 {
    margin-bottom: 10px;
    font-size: 16px;
  }
}

.lp-section4 .text-2 {
  font-size: 16px;
}
@media (max-width: 991px) {
  .lp-section4 .text-2 {
    font-size: 15px;
  }
}
@media (max-width: 575px) {
  .lp-section4 .text-2 {
    max-width: 400px;
    margin: 0 auto;
    text-align: left;
  }
}


/*--- lp section5 ---*/
.lp-section5 {
  padding: 80px 0;
  background-color: #fcf7f8;
  overflow: visible;
}
@media (max-width: 991px) {
  .lp-section5 {
    padding: 40px 0;
  }
}
@media (max-width: 575px) {
  .lp-section5 {
    padding: 40px 0 230px;
  }
}

.lp-section5 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 90px;
  position: relative;
}
@media (max-width: 991px) {
  .lp-section5 .wrapper {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 30px;
  }
}

.lp-section5 .content {
  display: flex;
}
@media (max-width: 575px) {
  .lp-section5 .content {
    display: block;
  }
}

.lp-section5 .box-1 {
  width: 60%;
}
@media (max-width: 575px) {
  .lp-section5 .box-1 {
    width: 100%;
    text-align: center;
  }
}

.lp-section5 .head-1 {
  margin-bottom: 30px;
  font-size: 30px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section5 .head-1 {
    margin-bottom: 20px;
    font-size: 22px;
  }
}

.lp-section5 .head-2 {
  display: inline-block;
  margin-bottom: 20px;
  padding: 14px 20px;
  background-color: #fff;
  font-size: 22px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section5 .head-2 {
    margin-bottom: 15px;
    font-size: 16px;
  }
}
@media (max-width: 575px) {
  .lp-section5 .head-2 {
    display: block;
    padding: 10px;
  }
}

.lp-section5 .text-left {
  margin-right: 3px;
}

.lp-section5 .text-emphasis {
  display: inline-block;
  font-size: 30px;
}
@media (max-width: 991px) {
  .lp-section5 .text-emphasis {
    font-size: 22px;
  }
}

.lp-section5 .head-3 {
  font-size: 18px;
}
@media (max-width: 991px) {
  .lp-section5 .head-3 {
    font-size: 15px;
  }
}
@media (max-width: 575px) {
  .lp-section5 .head-3 {
    text-align: left;
  }
}

.lp-section5 .person-image {
  width: 35%;
  position: absolute;
  right: 90px;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 991px) {
  .lp-section5 .person-image {
    width: 35%;
    right: 30px;
  }
}
@media (max-width: 575px) {
  .lp-section5 .person-image {
    width: 100%;
    max-width: 250px;
    padding: 0 15px;
    left: 50%;
    top: 108%;
    transform: translate(-50%, 0);
  }
}


/*--- lp section6 ---*/
.lp-section6 {
  padding: 100px 0;
  background-color: #fff;
  background-image:  radial-gradient(#f4f4f4 2px, transparent 2px), radial-gradient(#f4f4f4 2px, #ffffff 2px);
  background-size: 20px 20px;
  background-position: 0 0, 10px 10px;
}
@media (max-width: 991px) {
  .lp-section6 {
    padding: 70px 0 50px;
  }
}
@media (max-width: 575px) {
  .lp-section6 {
    padding: 120px 0 50px;
  }
}

.lp-section6 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 15px;
}

.lp-section6 .title-area {
  margin-bottom: 40px;
  text-align: center;
}

.lp-section6 .head-1 {
  margin-bottom: 30px;
  font-size: 34px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section6 .head-1 {
    margin-bottom: 30px;
    font-size: 22px;
  }
}

.lp-section6 .text-underline {
  border-bottom: solid;
  border-color: #f299b1;
  border-width: 4px;
}
@media (max-width: 991px) {
  .lp-section6 .text-underline {
    font-size: 29px;
  }
}

.lp-section6 .text-emphasis {
  font-size: 40px;
  color: #f299b1;
}
@media (max-width: 991px) {
  .lp-section6 .text-emphasis {
    font-size: 32px;
  }
}

.lp-section6 .text-large {
  font-size: 71px;
}
@media (max-width: 991px) {
  .lp-section6 .text-large {
    font-size: 56px;
  }
}

.lp-section6 .head-2 {
  margin-bottom: 30px;
  font-size: 20px;
}
@media (max-width: 991px) {
  .lp-section6 .head-2 {
    margin-bottom: 30px;
    font-size: 15px;
  }
}

.lp-section6 .list-area {
  padding: 60px 40px;
  background: #f8f8f8;
}
@media (max-width: 575px) {
  .lp-section6 .list-area {
    padding: 30px 20px;
  }
}

.lp-section6 .list-title {
  display: flex;
  align-items: flex-end;
  margin-bottom: 30px;
  padding-bottom: 16px;
  border-bottom: 2px solid #47536e;
}
@media (max-width: 991px) {
  .lp-section6 .list-title {
    display: block;
  }
}

.lp-section6 .title-1 {
  margin: 0 16px 0 0;
  font-size: 22px;
  font-weight: bold;
}
@media (max-width: 575px) {
  .lp-section6 .title-1 {
    font-size: 16px;
  }
}

.lp-section6 .title-2 {
  font-size: 14px;
}
@media (max-width: 991px) {
  .lp-section6 .title-2 {
    margin-top: 10px;
  }
}
@media (max-width: 575px) {
  .lp-section6 .title-2 {
    font-size: 12px;
  }
}

.lp-section6 .list-box:not(:last-child) {
  margin-bottom: 50px;
}
@media (max-width: 575px) {
  .lp-section6 .list-box:not(:last-child) {
    margin-bottom: 30px;
  }
}

.lp-section6 .document-item {
  list-style: none;
  position: relative;
  margin-bottom: 6px;
  padding-left: 10px;
  font-size: 16px;
}
@media (max-width: 575px) {
  .lp-section6 .document-item {
    font-size: 14px;
  }
}

.lp-section6 .document-item::before {
  display: inline-block;
  content: '・';
  position: absolute;
  top: 0;
  left: -5px;
}


/*--- lp section for consulting service ---*/

.consulting-service-section {
  margin: 90px 0 40px;
  padding: 36px 24px 0;
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  place-items: center;
}

@media (max-width: 991px) {
  .consulting-service-section {
    padding-top: 85px;
  }
}

.consulting-banner-container {
  position: relative;
  border: 1px solid #9E9E9E;
  border-radius: 12px;
  background-image: url("/assets/img/bnr_consulting_1074x354.png");
  background-size: cover;
  width: 964px;
  height: 347px;
}

@media (max-width: 991px) {
  .consulting-banner-container {
    background-image: none;
    width: 100%;
    height: 301px;
  }
}

.consulting-banner-sticky {
  position: absolute;
  z-index: 30;
  top: -36px;
  left: calc(50% - 230px);
}

@media (max-width: 991px) {
  .consulting-banner-sticky {
    top: -85px;
    left: calc(50% - 181px);
  }
}

.consulting-banner-overlayer-background {
  position: absolute;
  z-index: 20;
  right: 0;
  top: 0;
  width: 616px;
  border-bottom: 345px solid white;
  border-left: 90px solid transparent;
  border-start-end-radius: 12px;
  border-end-end-radius: 12px;
}

@media (max-width: 991px) {
  .consulting-banner-overlayer-background {
    display: none;
  }
}

.consulting-banner-overlayer {
  position: absolute;
  z-index: 30;
  right: 46px;
  top: 0;
  height: 241px;
  margin-top: 74px;
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  place-items: center;
  gap: 13px;
}

@media (max-width: 991px) {
  .consulting-banner-overlayer {
    right: auto;
    width: 100%;
    margin-top: 30px;
  }
}

.consulting-banner-overlayer {
  color: #1F1F1F;
  font-weight: 600;
  text-align: center;
}

.consulting-service-logo {
  border-top: 1px solid #474747;
  border-bottom: 1px solid #474747;
  padding: 24px 0;
}

.consulting-service-logo-small {
  border-top: 1px solid #474747;
  border-bottom: 1px solid #474747;
  padding: 16px 8px;
  display: none;
  margin-bottom: 8px;
}

@media (max-width: 991px) {
  .consulting-service-logo {
    display: none;
  }

  .consulting-service-logo-small {
    display: block;
  }
}

.consulting-service-button {
  background-color: #103479;
  color: white;
  border-radius: var(--border-radius-M);
  box-shadow: 0 4px 4px 0 #00000040;
  padding: 18.5px 24px;
  font-weight: 600;
}

/*--- lp section7 ---*/
.lp-section7 {
  padding: 80px 0;
  background: #fce9ee;
}
@media (max-width: 991px) {
  .lp-section7 {
    padding: 40px 0;
  }
}

.lp-section7 .wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 15px;
  text-align: center;
}

.lp-section7 .logo-image {
  height: 53px;
  margin-bottom: 50px;
}
@media (max-width: 991px) {
  .lp-section7 .logo-image {
    height: 53px;
    margin-bottom: 30px;
  }
}

.lp-section7 .head-1 {
  margin-bottom: 30px;
  font-size: 34px;
  font-weight: bold;
}
@media (max-width: 991px) {
  .lp-section7 .head-1 {
    margin-bottom: 30px;
    font-size: 22px;
  }
}

.lp-section7 .head-2 {
  margin-bottom: 30px;
  font-size: 20px;
}
@media (max-width: 991px) {
  .lp-section7 .head-2 {
    margin-bottom: 30px;
    font-size: 15px;
  }
}


/*--- lp footer ---*/
.lp-footer {
  color: #47536e;
  font-size: 14px;
  background: #fcf7f8;
}

.lp-footer .top {
  background: #fff;
}

.lp-footer .container {
  max-width: 1140px;
  display: flex;
  align-content: center;
  position: relative;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 8px 15px;
}
@media (max-width: 991px) {
  .lp-footer .container {
    display: block;
    height: auto;
    padding: 30px 15px;
  }
}

.lp-footer .top-container {
  height: 140px;
  align-items: flex-end;
  justify-content: space-between;
}
@media (max-width: 991px) {
  .lp-footer .top-container {
    height: auto;
  }
}

@media (max-width: 991px) {
  .lp-footer .company {
    margin-bottom: 20px;
  }
}

.lp-footer .logo-image {
  height: 30px;
  margin-bottom: 15px;
}

.lp-footer .address {
  margin: 0;
}

.lp-footer ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 0;
  padding: 0;
}
@media (max-width: 991px) {
  .lp-footer ul {
    display: block;
  }
}

.lp-footer li {
  display: flex;
  align-items: center;
  list-style: none;
}

.lp-footer li:not(:last-child) {
  padding-right: 17px;
}
@media (max-width: 991px) {
  .lp-footer li:not(:last-child) {
    margin-bottom: 20px;
  }
}

.lp-footer li a {
  color: #8a8c95;
  transition: .3s;
}

.lp-footer li a:hover {
  color: #f299b1;
  text-decoration: none;
}

.lp-footer .under-container {
  height: auto;
  align-items: center;
  justify-content: center;
}
@media (max-width: 991px) {
  .lp-footer .under-container {
    text-align: center;
  }
}

.lp-footer .copyright {
  margin-right: 30px;
}
@media (max-width: 991px) {
  .lp-footer .copyright {
    margin: 0;
  }
}

.lp-footer .credits {
  padding: 15px 0;
}

.lp-footer .credits a {
  color: #f299b1;
}
.lp-footer .credits a:hover {
  text-decoration: underline;
}

/*--- lp-back-to-top ---*/
.lp-back-to-top {
  background-color: #f299b1;
}


/*--- chat button ---*/
.fb_dialog_content iframe {
  right: 50px !important;
  bottom: 17px !important;
}
