html {
  scroll-behavior: smooth;
  scroll-padding-top: 72px;
  font-family: "Noto Sans JP", sans-serif;
}
.pagetop {
    height: 50px;
    width: 50px;
    position: fixed;
    right: 30px;
    bottom: 30px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
    background:  linear-gradient(90deg, #011835 0%, #024B7E 100%);
}
.pagetop__arrow {
    height: 10px;
    width: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}
body {
  background: #F5F5F5;
  line-height: 1.5;
}
.js-box {
  opacity: 0;
  visibility: hidden;
  transform: translateY(50px);
  transition: opacity 1s,visibility 1s, transform 1s;
}
.bold {
  font-weight: bold;
}
.scroll {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}
@media screen and (max-width:767px) {
  .pc {
    display: none;
  }
}
@media screen and (min-width:768px) {
  .sp {
    display: none;
  }
}
/* img */
img {
  width: 100%;
  height: auto;
}
/* movie */
.fv-movie {
  width: 100vw;
  height: auto;
  vertical-align: bottom;
  margin: 0 calc(50% - 50vw);
}
/* loading */
/* Loading背景画面設定　*/
#splash {
/*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 1000000;
  background:#fff;
  text-align:center;
  color:#fff;
  top: 0;
}

/* Loading画像中央配置　*/
#splash_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#splash_logo img {
  width:260px;
}

/* fadeUpをするアイコンの動き */
.fadeUp{
animation-name: fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity: 0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}
/* ヘッダー */

.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 91%;
  max-width: 1440px;
  margin: 20px  auto 12px;
  position: relative;
}
@media screen and (min-width:1024px) and (max-width:1280px) {
  .header {
    width: 95%;
  }
}
@media screen and (max-width:480px) {
  .header {
    position: relative;
  }
}
.header-logo {
  width: 200px;
  height: auto;
}
@media screen and (max-width:480px) {
  .header-logo {
    /* width: 30%;
    margin: 0 auto; */
  }  
}

.header-logo img {
  width: 100%;
  display: block;
}

/* ヘッダー */

/* ナビ */

.header-nav {
  /* background-color: rgba(255, 255, 255, 0.7); */
  margin: 0 auto;
}

@media screen and (max-width:1023px) {
  .header-nav {
    display: none;
  }
}

.header-nav__item {
  width: 100%;
  margin: auto;
  display: flex;
  justify-content:space-around;
  align-items: center;
}
.header-nav.fixed-nav .header-nav__item {
  width: 90%;
}
.header-nav__item__child {
  list-style: none;
  font-size: 16px;
}
.header-nav__item__child.entry {
  background:  linear-gradient(93deg, #011835 0%, #024B7E 100%) 0% 0% ;
  color: #fff;
  padding: 12px 40px;
}
.header01__hamburger__item.entry {
  background: linear-gradient(90deg, #011835 0%, #024B7E 100%) ;
  color: #fff;
  padding: 2px 16px;
  margin-top: 16px;
}
.header01__hamburger__item.entry a {
  color: #fff;
}
.header-nav__item__child a {
  text-decoration: none;
  color: #011835;
  font-weight: 300;
  font-style: normal;
}
.header-nav__item__child.entry a {
  text-decoration: none;
  color: #fff;
  font-weight: 300;
  font-style: normal;
}

.header-nav__item__child:not(:last-child) {
  margin-right: 20px;
}
@media screen and (min-width:1024px) and (max-width:1280px) {
  .header-nav__item__child:not(:last-child) {
    margin-right: 12px;
  }
}

.fixed-nav {
  position: fixed;
  top: 0;
  left: 0;
  inset: 0;
  width: 100%;
  height: 42px;
  margin: 0 auto;
  z-index: 100;
  padding: 16px 0;
  background-color: #fff;
}

@media screen and (max-width:1023px) {
  .fixed-nav {
    display: none;
  }
}

.header01__hamburger__button,
.header01__hamburger__content {
    display: none;
}
.header01__hamburger__item a {
  text-decoration: none;
  font-weight: 300;
  font-style: normal;

}

@media screen and (max-width: 1023px) {
  .header01 {
    position: fixed;
  }

  .header01__navi {
        display: none;
  }

  .header01__hamburger__button {
    display: block;
    position: fixed;
    top: 12px;
    right: 15px;
    width: 42px;
    height: 42px;
    z-index: 10000;
    cursor: pointer;
    text-align: center;
  }
  .header01__hamburger__button span {
    display: block;
    position: absolute;
    width: 30px;
    height: 2px;
    left: 6px;
    background: black;
    transition: 0.2s ease-in-out;
  }
  .header01__hamburger__button span:nth-child(1) {
    top: 10px;
  }
  .header01__hamburger__button span:nth-child(2) {
    top: 20px;
  }
  .header01__hamburger__button span:nth-child(3) {
    top: 30px;
  }
  .header01__hamburger__button.active span {
    background: black;
  }
  .header01__hamburger__button.active span:nth-child(1) {
    top: 16px;
    left: 6px;
    transform: rotate(-45deg);
  }
  .header01__hamburger__button.active span:nth-child(2),
  .header01__hamburger__button.active span:nth-child(3) {
    top: 16px;
    transform: rotate(45deg);
  }
  .header01__hamburger__content {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    transform: translateX(100%);
    width: calc(100% - 30px);
    height: 100%;
    padding: 15px;
    transition: all 0.2s;
    background: #fff;
    background-size: cover;
  }
  .header01__hamburger__content.active {
    transform: translateX(0%);
  }

  .header01__hamburger__content.negative {
    transform: translateX(-100%);
}

  .header01__hamburger__item {
    text-align: center;
  }
  .header01__hamburger__item a {
    display: inline-block;
    padding: 16px;
    color: black;
  }
}

@media screen and (max-width: 599px) {
    .header01__container {
        padding-right: 15px;
        padding-left: 15px;
    }
    
    .header01__hamburger__button {
        right: 10px;
    }
}

.negative {
  transform: translateX(-100%);
}

/* ナビ */


/* フッター */

.footer {
  text-align: center;
  padding-bottom: 16px;
  background-color: #fff;
}

@media screen and (min-width:1024px) {
  .footer__contents {
    display: flex;
    justify-content: space-between;
    margin-top: 30px ;
  }
}

@media screen and (max-width:1023px) {
  .footer__contents {
    margin-top: 30px ;
  }
}

@media screen and (min-width:1024px) {
  .footer__content:first-of-type {
    width: 8%;
    margin-left: 30px;
  }
}

@media screen and (max-width:1023px) {
  .footer__content:first-of-type {
    width: 15%;
    margin: 0 auto;
  }  
}

@media screen and (min-width:1024px) {
  .footer__content:nth-of-type(2) {
    margin: auto 30px auto 0px;
  }
}


@media screen and (max-width:1023px) {
  .footer__content:nth-of-type(2) {
    margin-top: 20px;
    text-align: center;
    font-size: 18px;
  }
}

.footer__content__nav {
  align-items: center;
}

@media screen and (min-width:1024px) {
  .footer__content__nav__items {
    display: flex;
  }
}


@media screen and (max-width:1023px) {
  .footer__content__nav__item {
    margin-bottom: 20px;
  }  
}

.footer__content__nav__item a  {
  text-decoration: none;
  color: black;
}

@media screen and (min-width:1024px) {
  .footer__content__nav__item:nth-of-type(6) {
    margin-right: 10px!important;
  }
}

@media screen and (min-width:1024px) {
  .footer__content__nav__item:not(:last-of-type) {
    margin-right: 30px;
  }
}

@media screen and (min-width:1024px) {
  .footer__content__nav__item img {
    width: 20px;
  }
}

@media screen and (max-width:1023px) {
  .footer__content__nav__item img {
    width: 50px;  
  }  
}

.small {
  text-align: center;
}

@media screen and (max-width:1023px) {
  .small {
    display: block;
    text-align: center;
  }
}

@media screen and (max-width:480px) {
  .small {
    display: block;
    text-align: center;
    float: none;
    font-size: 16px;
  }
}

/* フッター */

/* hover */

a:hover {
  opacity: 0.7;
}

/* hover */

.tab li a:hover {
  cursor: pointer;
  transform: scale(1.2);
}


/*全て共通：hideエリアをはじめは非表示*/
.hide-area{
	display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after, 
.modaal-close:before{
	background:#ccc;	
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
	background:#666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title{
	font-size:1.2rem;
	text-align: center;
	margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-video .modaal-inner-wrapper{
	padding:0;
}
/* main */
.main {
  position: relative;
  z-index: 1;
}
.thanks-main {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 2;
  height: calc(100vh - 72.63px);
  background: none;
}
.thanks__title {
  font-size: 20px;
}
.thanks-main a {
  color: #1C1B17;
  font-size: 18px;
}
/* fv */
.fv {
  position: relative;
  max-width: 1440px;
  margin: auto;
}
.fv__title {
  position: absolute;
  top: 50%;
  left: 5%;
  transform: translateY(-50%) translateX(-5%);
  -webkit- transform: translateY(-50%) translateX(-5%);
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  font-weight: 400;
  font-style: normal;
}
@media screen and (max-width:1023px) {
  .fv__title {
    position: relative;
    width: 90%;
    left: 5%;
    transform: translateY(0%) translateX(0%);
    -webkit- transform: translateY(0%) translateX(0%);
    margin-top: 40px;
    color: #011835;
    padding-bottom: 48px;

  }
}
.fv__main-title {
  font-size: 50px;
  line-height: 1.56;
}
@media screen and (max-width:480px) {
  .fv__main-title {
    font-size: 32px;
  }
}
.fv__sub-title {
  font-size: 20px;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 32px;
}
.section-title-center {
  font-size: 32px;
  font-weight: 400;
  font-style: normal;
  text-align: center;
  padding-top: 32px;
  color: #011835;
}
@media screen and (max-width: 480px) {
  .section-title-center {
    font-size: 24px;
  }
}
.section-title-left {
  font-size: 32px;
  font-weight: 500;
  font-style: normal;
  color: #011835;
  text-align: left;
}
@media screen and (max-width: 480px) {
  .section-title-left {
    font-size: 24px;
  }
}
.subtitle-center {
  font-size: 18px;
  
  font-weight: 300;
  font-style: normal;
  color: #C6AD44;
  display: block;
  text-align: center;
  margin-top: 20px;
}
.subtitle-left {
  font-size: 18px;
  
  font-weight: 300;
  font-style: normal;
  color: #C6AD44;
  display: block;
  text-align: left;
}
.mission {
  margin-top: 32px;
}
.mission-text {
  margin-top: 32px;
  text-align: center;
  color: #111111;
  line-height: 1.5;

  font-weight: 400;
  font-style: normal;
}
@media screen and (max-width:480px) {
  .mission-text {
    padding: 0 16px;
    text-align: left;
  }
}
/* top-botton */
.top-botton {
  width: 320px;
  position: absolute;
  right: 80px;
  bottom: 20px;
  padding:42px 0;
  background:  linear-gradient(90deg, #011835 0%, #024B7E 100%);
}
@media screen and (max-width:1023px) {
  .top-botton {
    width: 100%;
    position: relative;
    right: 0;
    bottom: 0;
  }
}
.form-button__title {
  position: relative;
  color: #fff;
  font-size: 24px;
  text-align: center;
}
@media screen and (max-width:1023px) {
  .form-button__title {
    font-size: 20px;
  }
}

.form-button__title:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -18px;
  display: inline-block;
  width: 50px;
  height: 2px;
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%);
  background-color: #fff;
}

/* about */
.about {
  background-image: url(../img/about-back.png);
  background-size: cover;
}

.about__content {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 80px 0;

}
@media screen and (max-width:1023px) {
  .about__content {
    display: block;
  }
}
.about__content img {
  max-width: 574px;
  width: 50%;
  margin-left: 100px;
}
@media screen and (max-width:1023px) {
  .about__content img {
    max-width: 100%;
    width: 100%;
    margin-left: 0px;
    margin-top: 32px;
  }
}
.about__content__title {
  font-family: "Noto Serif JP", serif;
  font-size: 32px;
  font-style: normal;
  margin-top: 16px;
  margin-bottom: 30px;
  line-height: 1.4;
  color: #011835;
}
@media screen and (max-width:480px) {
  .about__content__title {
    font-size: 24px;
  }
}
.about__content-text {
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 2;
  text-align: justify;
  color: #011835;
}

/* attraction */
.attraction {
  padding: 78px 0;
}

.attraction__contents {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}
.attraction__content {
  display: flex;
  justify-content: space-between;
  margin: 80px auto 0;
}
@media screen and (max-width:1023px) {
  .attraction__content {
    display: block;
  }
}
@media screen and (max-width:1023px) {
  .attraction__content:nth-of-type(2) {
    display: flex;
    flex-direction: column-reverse;
  }
}

.attraction__content-right {
  margin-left: -20px;
}
@media screen and (max-width:1023px) {
  .attraction__content-right {
    margin-left: 0px;
  }
}
.attraction__content-right__title {
  margin-left: -108px;
  margin-top: 38px;
}
@media screen and (max-width:1023px) {
  .attraction__content-right__title {
    margin-left: 0px;
  }
}
@media screen and (max-width:1023px) {
  .attraction__content-left__title {
    margin-top: 38px;
  }
}
.attraction-right-img {
  max-width: 574px;
  width: 50%;
  margin-right: 80px;
}
@media screen and (max-width:1023px) {
  .attraction-right-img {
    max-width: 100%;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}
.attraction-left-img {
  max-width: 574px;
  width: 50%;
  margin-left: 100px;
  margin-right: 0px;
}
@media screen and (max-width:1023px) {
  .attraction-left-img {
    max-width: 100%;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

@media screen and (max-width:1023px) {
  .attraction__content img {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}
.attraction__content__title {
  position: relative;
  display: inline-block;
  font-size: 24px;
  font-weight: 500;
  font-style: normal;
  margin: 0px;
  line-height: 1.4;
  color: #011835;
  border: 1px solid #011835;
  background-color: #fff;
  padding: 6px 48px;
}
@media screen and (max-width:480px) {
  .attraction__content__title {
    font-size: 18px;
    padding: 6px 20px;
  }
}
.attraction__title {
  position: relative;
}
.attraction__title:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
  background-color: #011835; /*下線の色*/
}
.attraction__content-text {
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 2;
  text-align: justify;
  margin-top: 38px;
}
/* message */
.message {
  margin-top: 120px;
  position: relative;
}
.message::before {
  position: absolute;
  width: 90%;
  content: " ";
  background-color: #1C1B17;
  z-index: -1;
  width: 65%;
  max-width: 934px;
  height: 100%;
  right: 0;
}
@media screen and (max-width:1023px) {
  .message::before {
    width: 100%;
    max-width: 100%;
  }
}
.message__content {
  display: flex;
  justify-content: space-between;
  margin: 32px auto;
  max-width: 1000px;
  padding-bottom: 120px;
}
@media screen and (max-width:1023px) {
  .message__content {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
.message__content img {
  max-width: 400px;
  margin-right: 64px;
  aspect-ratio: 1/1;
}
@media screen and (max-width:1023px) {
  .message__content img {
    margin: auto;
  }
}
.message__content__title {
  font-size: 24px;

  font-style: normal;
  margin-bottom: 30px;
}
@media screen and (max-width:480px) {
  .message__content__title {
    font-size: 20px;
  }
}
.message__content-text {
  font-size: 16px;

  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  color: #C6AD44;
}
@media screen and (max-width:1023px) {
  .message__content-text {
    margin-top: 24px;
    padding: 0 5%;
  }
}
.form-botton {
  display: flex;
  justify-content: center;
  margin-top: 64px;
}
.form-botton__content {
  width: 168px;
  position: relative;
  display: block;
  background: #fff;
  color: #011835;
  margin: 40px auto 0;
  font-size: 16px;
  text-align: center;
  padding: 12px 0;
  text-decoration: none;
  font-style: normal;
  font-weight: 400;
  text-align: center;
}
@media screen and (max-width:480px) {
  .form-botton__content {
    padding: 22px 48px;
  }
}
/* welfare */
.welfare {
  position: relative;
  max-width: 1100px;
  width: 80%;
  margin: -160px 0;
  padding: 64px 0 64px 10%;
  background-color: #fff;
}
@media screen and (min-width:1441px) {
  .welfare {
    margin: -160px auto 0;
  }
}

@media screen and (max-width:1023px) {
  .welfare {
    margin: -108px 0;
  }
}

@media screen and (max-width:768px) {
  .welfare {
    width: 90%;
    margin-top: 32px;
    padding: 64px 0 64px 5%;
  }
}
.welfare-main__title {
  position: relative;
}
.welfare-main__title:before {
  content: '';
  position: absolute;
  left: 0%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  background-color: #011835; /*下線の色*/
}
.welfare__contents {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  margin: 78px auto;
}
@media screen and (max-width:1023px) {
  .welfare__contents {
    width: 100%;
    display: block;
  }
}
.welfare__content:nth-child(1) {
  max-width: 330px;
}
.welfare__content:nth-child(2) {
  max-width: 378px;
}
@media screen and (max-width:1023px) {
  .welfare__content:nth-child(1)  {
    max-width: 100%;
    padding-right: 10%;
  }
}
@media screen and (max-width:1023px) {
  .welfare__content:nth-child(2)  {
    max-width: 100%;
    padding-right: 10%;
  }
}
.welfare__content:nth-child(2) {
  margin-left: 112px;
}
@media screen and (max-width:1280px) {
  .welfare__content:nth-child(2) {
    margin-left: 72px;
  }
}
@media screen and (max-width:1023px) {
  .welfare__content:nth-child(2) {
    margin-left: 0px;
    margin-top: 32px;
  }
}
.welfare__content__title {
  font-size: 24px;
  font-style: normal;
  margin-top: 20px;
  margin-bottom: 30px;
}
@media screen and (max-width:480px) {
  .welfare__content__title {
    font-size: 20px;
  }
}
.welfare-text {
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 2;
  text-align: justify;
  margin-top: 32px;
}
.welfare__title {
  font-size: 24px;
  color: #fff;
  background-color: #011835;
  padding: 10px 16px;
  font-weight: 500;
  display: inline-block;
  line-height: 1.6;
}
@media screen and (max-width: 480px) {
  .welfare__title {
    font-size: 18px;
  }
}
.welfare-back-img {
  margin-top: 72px;
}
/* recruit */
.recruit {
  margin-top: 80px;
  padding-top: 70px;
  padding-bottom: 100px;
}
@media screen and (max-width: 1023px) {
  .recruit {
    width: 90%;
    margin-top: 40px;
    padding-top: 32px;
    margin-inline:auto ;
  }
}
.recruit__title {
  position: relative;
}
.recruit__title:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
  background-color: #011835; /*下線の色*/
}
.recruit-sub__title {
  background: #011835;
  color: #fff;
  font-size: 24px;
  text-align: center;
  max-width: 1000px;
  margin-inline: auto;
  padding: 8px 0;
  font-weight: 500;
  margin: 84px auto 0px;
}
@media screen and (max-width: 480px) {
  .recruit-sub__title {
    font-size: 18px;
  }

}
.recruit table {
  display: flex;
  justify-content: center;
  max-width: 1000px;
  margin-inline: auto;
  border-collapse:separate;
  border-spacing: 1px;
}
@media screen and (max-width:1023px) {
  .recruit table {
    width: 100%;
  }
}
.recruit tr {
  margin: 80px auto 0;
  line-height: 2.3;
  font-size: 16px;
}

@media screen and (max-width:1023px) {
  .recruit tr {
  margin: 80px auto 0;
  line-height: 2.3;
  font-size: 16px;
  }  
}

.recruit th {
  width: 250px;
  background: #EEEEEE;
  margin-top: 4px;
  padding: 13px 0 13px 32px ;
  text-align: left;
  font-weight: 400;
  font-style: normal;
}

@media screen and (max-width:1023px) {
  .recruit th {
  width: 200px;
  margin-left: 10px;
  padding: 13px 0 13px 16px ;
  }  
}

@media screen and (max-width:480px) {
  .recruit th {
    width: calc(100% - 24px);
    display: block;
    margin: 0 auto;  
    padding: 16px 12px;
  }  
}

.recruit td {
  background-color: #fff;
  margin-top: 4px;
  padding: 13px 13px 13px 32px ;

  font-weight: 400;
  font-style: normal;

}
@media screen and (max-width:480px) {
  .recruit td {
    width: calc(100% - 24px);
    display: block;
    margin: 0 auto;
    text-align: left;
    padding: 16px 12px;
  } 
}
.recruit td span {
  margin-right: 10px;
}
@media screen and (max-width:480px) {
  .recruit td span {
    display: none;
  } 
}
.recruit li {
  list-style: none;
  text-align: left;
}
/* voice */
.voice {
  max-width: 1000px;
  width: 90%;
  margin: 200px auto 0;
}
@media screen and (max-width:1023px) {
  .voice {
    margin: 160px auto 0;
  } 
}

.voice-detail-flex {
  display: flex;
}
@media screen and (max-width:1023px) {
  .voice-detail-flex {
    flex-direction: column;
  } 
}
.voice-detail-flex.others {
  justify-content: space-between;
}
@media screen and (max-width:1023px) {
  .voice-detail-flex.others {
    flex-direction: column;
  } 
}
.voice__title {
  position: relative;
}
.voice__title:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
  background-color: #011835; /*下線の色*/
}

.voice-detail__contents {
  margin-top: 96px;
}
.voice-detail-left {
  width: 100%;
  max-width: 372px;
  margin-right: 64px;
}
@media screen and (max-width:1023px) {
  .voice-detail-left {
    margin-bottom: 48px;
  } 
}
.voice-detail-right-title {
  font-size: 20px;
  line-height: 1.6;
  border-left: 4px solid #011835;
  padding: 12px 0 12px 18px;
  color: #011835;
}
@media screen and (max-width:1023px) {
  .voice-detail-right-title {
    font-size: 18px;
  }
}

.voice-detail-right-title:nth-of-type(2) {
  margin-top: 24px;
}
.voice-detail-right-title.bottom {
  margin-top: 24px;
}
.voice-detail-right-text {
  margin-top: 16px;
  line-height: 1.75;
  letter-spacing: 2.5px;
}
.voice-detail-name {
  position: relative;
  width: 80%;
  font-size: 24px;
  color: #fff;
  background-color: #011835;
  padding: 8px 0 8px 24px;
  margin-top: -16px;
  z-index: 10;
}
@media screen and (max-width:1023px) {
  .voice-detail-name {
    font-size: 18px;
  }
}
.voice-detail-others {
  position: relative;
  width: 43%;
  line-height: 1.75;
  padding: 0 34px;
}
@media screen and (max-width:1023px) {
  .voice-detail-others {
    width: calc(100% - 40px);
    margin-top: 32px;
    padding: 0 20px;
  } 
}
@media screen and (max-width:1023px) {
  .voice-detail-others:nth-of-type(2) {
    margin-top: 100px;
  } 
}
.voice-detail-name-others {
  position: relative;
  /* width: 160px; */
  display: inline-block;
  font-size: 20px;
  color: #fff;
  background-color: #011835;
  padding: 8px 24px 8px 24px;
  margin-bottom: 12px;
  z-index: 10;
}
@media screen and (max-width:1023px) {
  .voice-detail-name-others {
    font-size: 18px;
  }
}

/* .voice-detail-others::before {
  position: absolute;
  top: -28px;
  left: 0;
  content: "";
  background-image: url('../img/quotation-up.png');
  background-size: cover;
  width: 34px;
  height: 22px;
}
.voice-detail-others::after {
  position: absolute;
  bottom: -28px;
  right: 0;
  content: "";
  background-image: url('../img/quotation-bottom.png');
  background-size: cover;
  width: 34px;
  height: 22px;
} */
/*  */
.formrun div {
  display:flex;
  flex-direction: column;
  margin-top: 16px;
}
.formrun label {
  line-height:1.25;
}
.formrun input[type="text"] , select , .mail-confirm{
  max-width:350px;
  width:calc(100% - 16px);
  border: 1px solid #cccccc;
  padding: 8px;
  border-radius: 0.25rem;
}
.formrun textarea {
  width:100%;
}
.formrun button[type="submit"] {
  border-color: #1C1B17;
  background-color: #1C1B17;
  color: rgb(255, 255, 255);
  font-weight: 400;
  font-size: 20px;
  width: 100%;
  border-radius: 4px;
  border-width: 2px;
  border-style: solid;
  margin-top: 32px;

  font-weight: 400;
  font-style: normal;
  padding: 8px 0;
}
.privacy-policy {
	height: 100px;
	overflow-y: scroll;
	padding: 16px;
	border: 1px solid rgba(0,0,0,0.15);
	line-height: 1.5;
	margin-bottom:24px;
	background-color:#f4f4f4;
}
 .privacy-policy__item p {
	 margin-bottom: 16px;
	 line-height:1.5!important;
}
.privacy-policy-top {
  line-height:1.5!important;	
  margin-bottom: 24px!important;
}
/* flow */
.flow {
  margin-top: 160px;
}
@media screen and (max-width:1023px) {
  .flow {
    margin-top: 80px;
  }
}
.flow__contents {
  display: flex;
  justify-content: space-between;
  margin: 32px auto 0;
}
@media screen and (max-width:1023px) {
  .flow__contents {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
.flow__content {
  display: flex;
  flex-direction: column;
  width: 50%;
  background: #011835;
  padding: 32px 62px 32px 32px;
  align-items: center;
  justify-content: center;
  }
@media screen and (max-width:1023px) {
  .flow__content {
    margin-top: 32px;
    width: 100%;
    padding: 24px 0px 32px 0px;
  }
}
@media screen and (max-width:480px) {
  .flow__content {
    width: calc(100% - 48px);
    padding: 64px 24px 24px;
  }
}
.flow__content-img {
  width: 50%;
  margin-top: 80px;
  overflow: visible;
  height:400px
}
@media screen and (max-width:1023px) {
  .flow__content-img {
    width: 100%;
    margin-top: 0;
    height: auto;
  }
}
.flow-main__title {
  position: relative;
  width: 265px;
  display: flex;
  font-weight: 400;
  font-style: normal;
  line-height: 1.25;
  color: #fff;
}
.flow-main__title:before {
  content: '';
  position: absolute;
  left: 0%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(0%);
  -webkit-transform: translateX(0%);
  -ms-transform: translateX(0%);
  transform: translate(0%); /*位置調整*/
  background-color: #fff; /*下線の色*/
}

@media screen and (max-width:480px) {
  .flow__title {
    flex-direction: column;
  }
}
.flow-table {
  width: 265px;
  border-collapse:separate;
  border-spacing: 0 16px ;
  line-height: 1.4;
  color: #fff;
  font-weight: 400;
  font-style: normal;
  margin-top: 48px;
}
.flow-table th {
  width: 120px;
  text-align: left;
}
@media screen and (max-width:480px) {
  .flow-table th {
    width: 100%;
    display: block;
  }
}
.flow-table td {
  width: 200px;
  padding-left: 26px;
}
@media screen and (max-width:480px) {
  .flow-table td {
    width: 100%;
    display: block;
    padding-left: 0;
  }
}

/* br */
.mt-16 {
  display: block;
  content: "";
  margin-top: 16px;
}
.mt-24 {
  display: block;
  content: "";
  margin-top: 24px;
}

textarea {
    overflow: auto
}

[type="checkbox"],[type="radio"] {
    box-sizing: border-box;
    padding: 0
}

[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button {
    height: auto
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none
}


[role="button"] {
    cursor: pointer
}

a,area,button,[role="button"],input,label,select,summary,textarea {
    touch-action: manipulation
}

table {
    border-collapse: collapse;
    background-color: transparent
}

caption {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: #78909C;
    text-align: left;
    caption-side: bottom
}

th {
    text-align: left
}

label {
    display: inline-block;
    margin-bottom: .5rem
}

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color
}

input,button,select,textarea {
    line-height: inherit
}

input[type="radio"]:disabled,input[type="checkbox"]:disabled {
    cursor: not-allowed
}

input[type="date"],input[type="time"],input[type="datetime-local"],input[type="month"] {
    -webkit-appearance: listbox
}

textarea {
    resize: vertical
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0
}

legend {
    display: block;
    width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: 1.5rem;
    line-height: inherit
}

input[type="search"] {
    -webkit-appearance: none
}

output {
    display: inline-block
}

[hidden] {
    display: none !important
}

.form-control {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: 1rem;
    line-height: 1.5;
    color: #546E7A;
    background-color: #fff;
    background-image: none;
    background-clip: padding-box;
    border: 1px solid rgba(0,0,0,0.15);
    overflow: hidden;
    border-radius: 0.25rem
}

.form-control::-ms-expand {
    background-color: transparent;
    border: 0
}

.form-control:focus {
    color: #546E7A;
    background-color: #fff;
    border-color: #66afe9;
    outline: none
}

.form-control::placeholder {
    color: #999;
    opacity: 1
}

.form-control:disabled,.form-control[readonly] {
    background-color: #B0BEC5;
    opacity: 1
}

.form-control:disabled {
    cursor: not-allowed
}

select.form-control:not([size]):not([multiple]) {
    height: calc(2.5rem + 0.2rem - 2px)
}

select.form-control:focus::-ms-value {
    color: #546E7A;
    background-color: #fff
}

.form-control-file,.form-control-range {
    display: block
}



.tag {
    display: inline-block;
    padding: 0.25em 0.4em;
    font-size: 75%;
    font-weight: bold;
    line-height: 1;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 0.25rem
}

.tag-danger {
    background-color: #d9534f
}

.tag-danger[href]:focus,.tag-danger[href]:hover {
    background-color: #c9302c
}



a.text-warning:focus,a.text-warning:hover {
    color: #ec971f !important
}

.text-danger {
    color: #d9534f !important
}

a.text-danger:focus,a.text-danger:hover {
    color: #c9302c !important
}

.text-free-color {
    color: #88889f !important
}

a.text-free-color:focus,a.text-free-color:hover {
    color: #6d6d87 !important
}

.text-beginner-color {
    color: #88889f !important
}

a.text-beginner-color:focus,a.text-beginner-color:hover {
    color: #6d6d87 !important
}

.text-starter-color {
    color: #5cb85c !important
}

a.text-starter-color:focus,a.text-starter-color:hover {
    color: #449d44 !important
}

.text-professional-color {
    color: #00bcd4 !important
}

a.text-professional-color:focus,a.text-professional-color:hover {
    color: #008fa1 !important
}

.text-gray-dark {
    color: #37474F !important
}

a.text-gray-dark:focus,a.text-gray-dark:hover {
    color: #222c31 !important
}

.text-gray-light {
    color: #78909C !important
}

a.text-gray-light:focus,a.text-gray-light:hover {
    color: #5f7682 !important
}

.text-hide {
    font: 0/0 a;
    color: transparent;
    text-shadow: none;
    background-color: transparent;
    border: 0
}

.invisible {
    visibility: hidden !important
}

.hidden-xs-up {
    display: none !important
}

@media (max-width: 575px) {
    .hidden-xs-down {
        display:none !important
    }
}

@media (min-width: 576px) {
    .hidden-sm-up {
        display:none !important
    }
}

@media (max-width: 767px) {
    .hidden-sm-down {
        display:none !important
    }
}

@media (min-width: 768px) {
    .hidden-md-up {
        display:none !important
    }
}

@media (max-width: 991px) {
    .hidden-md-down {
        display:none !important
    }
}

@media (min-width: 992px) {
    .hidden-lg-up {
        display:none !important
    }
}

@media (max-width: 1199px) {
    .hidden-lg-down {
        display:none !important
    }
}

@media (min-width: 1200px) {
    .hidden-xl-up {
        display:none !important
    }
}

.hidden-xl-down {
    display: none !important
}

.visible-print-block {
    display: none !important
}

@media print {
    .visible-print-block {
        display: block !important
    }
}

.visible-print-inline {
    display: none !important
}

@media print {
    .visible-print-inline {
        display: inline !important
    }
}

.visible-print-inline-block {
    display: none !important
}

@media print {
    .visible-print-inline-block {
        display: inline-block !important
    }
}

@media print {
    .hidden-print {
        display: none !important
    }
}

#creator-preview .preview-device-frame .preview-titlebar,#creator-preview .fr-navbar .center .btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -js-display: flex
}

#creator-preview {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #f6f6fa
}

#creator-preview .fr-navbar .center {
    justify-content: center
}

#creator-preview .fr-navbar .center .btn {
    height: 38px;
    line-height: 100%;
    font-size: 24px;
    width: 50%;
    align-items: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    font-weight: normal;
    align-items: center;
    justify-content: center
}

#creator-preview .preview-device-frame {
    border: 1px solid #CFD8DC;
    margin: auto 0;
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    display: block;
    max-width: 100%;
    align-self: flex-start
}

#creator-preview .preview-device-frame.phone {
    width: 377px;
    height: 100%;
    max-width: 377px;
    max-height: 669px
}

#creator-preview .preview-device-frame.tablet {
    width: 1024px;
    height: 100%;
    max-width: 1024px;
    max-height: 767px
}

#creator-preview .preview-device-frame .preview-titlebar {
    width: 100%;
    height: 32px;
    border-bottom: 1px solid #CFD8DC;
    background-color: #fff;
    text-align: center;
    align-items: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    justify-content: center;
    font-size: 12px
}

#creator-preview .preview-device-frame #preview-iframe {
    position: absolute;
    border: none;
    background-color: #fff;
    top: 32px;
    left: 0;
    width: 100%;
    height: calc(100% - 32px);
    overflow: auto
}

.sf-btn {
    background-color: #ddd;
    display: inline-block;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    user-select: none;
    border: 1px solid transparent;
    padding: 0.25em 0.25em;
    font-size: 14px;
    line-height: 150%;
    border-radius: 4px
}

.sf-btn.sf-btn-block {
    display: block;
    width: 100%
}

.sf-btn.sf-btn-primary {
    background-color: #42B5D1;
    color: #fff
}

.sf-btn.sf-btn-primary:hover {
    background-color: #6bc5db
}

.sf-btn.sf-btn-primary:active {
    background-color: #2c99b4
}

.sf-btn.sf-btn-success {
    background-color: #5cb85c;
    color: #fff
}

.sf-btn.sf-btn-success:hover {
    background-color: #80c780
}

.sf-btn.sf-btn-success:active {
    background-color: #449d44
}

.sf-btn.sf-btn-info {
    background-color: #5bc0de;
    color: #fff
}

.sf-btn.sf-btn-info:hover {
    background-color: #85d0e7
}

.sf-btn.sf-btn-info:active {
    background-color: #31b0d5
}

.sf-btn.sf-btn-warning {
    background-color: #f0ad4e;
    color: #fff
}

.sf-btn.sf-btn-warning:hover {
    background-color: #f4c37d
}

.sf-btn.sf-btn-warning:active {
    background-color: #ec971f
}

.sf-btn.sf-btn-danger {
    background-color: #d9534f;
    color: #fff
}

.sf-btn.sf-btn-danger:hover {
    background-color: #e27c79
}

.sf-btn.sf-btn-danger:active {
    background-color: #c9302c
}

.sf-btn.sf-btn-dark {
    background-color: #455A64;
    color: #fff
}

.sf-btn.sf-btn-dark:hover {
    background-color: #5a7582
}

.sf-btn.sf-btn-dark:active {
    background-color: #303f46
}

.sf-btn.sf-btn-white {
    background-color: #ffffff;
    color: #fff
}

.sf-btn.sf-btn-white:hover {
    background-color: white
}

.sf-btn.sf-btn-white:active {
    background-color: #e6e6e6
}

.sf-btn.sf-btn-primary-outline {
    background-color: transparent;
    color: #42B5D1;
    border: 1px solid #42B5D1
}

.sf-btn.sf-btn-primary-outline:hover {
    background-color: #42B5D1;
    color: #fff
}

.sf-btn.sf-btn-primary-outline:active {
    background-color: #2c99b4
}

.sf-btn.sf-btn-success-outline {
    background-color: transparent;
    color: #5cb85c;
    border: 1px solid #5cb85c
}

.sf-btn.sf-btn-success-outline:hover {
    background-color: #5cb85c;
    color: #fff
}

.sf-btn.sf-btn-success-outline:active {
    background-color: #449d44
}

.sf-btn.sf-btn-info-outline {
    background-color: transparent;
    color: #5bc0de;
    border: 1px solid #5bc0de
}

.sf-btn.sf-btn-info-outline:hover {
    background-color: #5bc0de;
    color: #fff
}

.sf-btn.sf-btn-info-outline:active {
    background-color: #31b0d5
}

.sf-btn.sf-btn-warning-outline {
    background-color: transparent;
    color: #f0ad4e;
    border: 1px solid #f0ad4e
}

.sf-btn.sf-btn-warning-outline:hover {
    background-color: #f0ad4e;
    color: #fff
}

.sf-btn.sf-btn-warning-outline:active {
    background-color: #ec971f
}

.sf-btn.sf-btn-danger-outline {
    background-color: transparent;
    color: #d9534f;
    border: 1px solid #d9534f
}

.sf-btn.sf-btn-danger-outline:hover {
    background-color: #d9534f;
    color: #fff
}

.sf-btn.sf-btn-danger-outline:active {
    background-color: #c9302c
}

.sf-btn.sf-btn-dark-outline {
    background-color: transparent;
    color: #455A64;
    border: 1px solid #455A64
}

.sf-btn.sf-btn-dark-outline:hover {
    background-color: #455A64;
    color: #fff
}

.sf-btn.sf-btn-dark-outline:active {
    background-color: #303f46
}

.sf-btn.sf-btn-white-outline {
    background-color: transparent;
    color: #ffffff;
    border: 1px solid #ffffff
}

.sf-btn.sf-btn-white-outline:hover {
    background-color: #ffffff;
    color: #fff
}

.sf-btn.sf-btn-white-outline:active {
    background-color: #e6e6e6
}

.sf-btn.sf-btn-sm {
    padding: 0.25em 0.25em;
    font-size: 12px;
    line-height: 150%;
    border-radius: 4px
}

.sf-btn.sf-btn-lg {
    padding: 0.25em 0.25em;
    font-size: 20px;
    line-height: 150%;
    border-radius: 4px
}

.sf-btn.sf-btn-primary {
    border-color: #00bcd4;
    background-color: #00bcd4
}

.sf-btn.disabled {
    cursor: not-allowed;
    background-color: #d6dde2 !important;
    border-color: #d6dde2 !important
}

.sf-btn-group .sf-btn {
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 10px 0
}

.sf-btn-group .sf-btn-outline {
    flex: 1;
    text-align: center;
    border-radius: 0
}

.sf-btn-group .sf-btn-outline:not(:first-child) {
    margin-left: -1px
}

.sf-btn-group .sf-btn-outline:first-child {
    border-radius: 4px 0 0 4px
}

.sf-btn-group .sf-btn-outline:last-child {
    border-radius: 0 4px 4px 0
}

#sf-form-elements .sf-image-wrapper {
    position: relative
}

#sf-form-elements .sf-image-wrapper .col-xs-6 {
    margin-bottom: 8px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox {
    position: relative
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox input[type="checkbox"],#sf-form-elements .sf-image-wrapper .sf-image-checkbox input[type="radio"] {
    opacity: 0;
    position: absolute
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox input[type="checkbox"]:focus+label,#sf-form-elements .sf-image-wrapper .sf-image-checkbox input[type="radio"]:focus+label {
    box-shadow: 0 0 6px 0 #a3d7a3
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button {
    display: inline-block;
    width: 100%;
    height: 100%;
    margin-bottom: 0;
    box-sizing: border-box;
    border: 1px solid #D9D9D9;
    border-radius: 4px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button::before {
    position: absolute;
    display: block;
    content: "";
    padding-top: 100%
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .fcon-checkmark {
    display: none;
    color: #5cb85c;
    position: absolute;
    z-index: 2;
    font-size: 3rem;
    vertical-align: middle;
    text-align: center;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .fcon-checkmark::before {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button.checked {
    box-sizing: border-box;
    border-radius: 4px;
    border-width: 4px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button.checked .fcon-checkmark {
    display: block
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button.disabled {
    pointer-events: none;
    opacity: .35;
    cursor: not-allowed
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .sf-image-wrapper__image_frame {
    padding: 12px;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    top: 0;
    left: 0
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .sf-image-wrapper__image_frame .image-wraper {
    width: 100%;
    position: relative;
    border-bottom: 1px solid #EEEEEE;
    padding-bottom: 8px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .sf-image-wrapper__image_frame .image-wraper img {
    aspect-ratio: 1 / 1;
    pointer-events: none
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .sf-image-wrapper__image_frame .sf-image-wrapper-label {
    margin-top: 8px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #455A64;
    border-color: #455A64;
    font-weight: 600;
    font-size: 16px;
    min-width: 60%;
    max-width: 160px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn:focus,#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn:hover,#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn:disabled {
    background-color: #fff;
    color: #3D4F58;
    border-color: #3D4F58;
    opacity: 1
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn i::before {
    margin-right: 8px;
    font-size: 16px;
    position: relative;
    top: 1px
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn-focus {
    background-color: #fff;
    color: #3D4F58;
    border-color: #3D4F58
}

#sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .image-upload-btn-hover {
    background-color: #fff;
    color: #3D4F58;
    border-color: #3D4F58
}

@supports (object-fit: contain) {
    #sf-form-elements .sf-image-wrapper .sf-image-checkbox .sf-select-image-button .sf-image-wrapper__image_frame img {
        height:100%;
        width: 100%;
        object-fit: contain
    }
}

#sf-form-elements .has-danger .sf-image-wrapper .sf-image-checkbox .sf-select-image-button.uncheck {
    border: 1px solid #d9534f !important
}

#sf-form-elements .sf-date-dropdown .date-dropdown-select {
    display: flex;
    justify-content: space-between
}

@media (max-width: 544px) {
    #sf-form-elements .sf-date-dropdown .date-dropdown-select select {
        padding-right:8px;
        background-size: 12px
    }

    #sf-form-elements .sf-date-dropdown .date-dropdown-select select.month-select,#sf-form-elements .sf-date-dropdown .date-dropdown-select select.day-select {
        max-width: 100px
    }
}

#sf-form-elements .sf-date-dropdown .date-dropdown-select label {
    padding: 8px 10px 0;
    margin: 0
}

@media (max-width: 544px) {
    #sf-form-elements .sf-date-dropdown .date-dropdown-select label {
        padding:8px 5px 0
    }
}

#sf-form-elements .sf-opinion-wrapper {
    width: 100%;
    height: 58px;
    font-size: 1.0rem;
    display: flex;
    flex-direction: row;
    box-sizing: border-box;
    border-radius: 7px;
    overflow: hidden
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button {
    width: 100%;
    height: 100%;
    display: block;
    background-color: #E4ECF0
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button+.sf-opinion-radio-button {
    margin-left: 1px
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button label,#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button .box,#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button .count-box {
    width: 100%;
    height: 100%
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button label {
    margin-bottom: 0;
    cursor: pointer
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"] {
    opacity: 0;
    position: absolute
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"]:focus+label {
    box-shadow: 0 0 6px 0 #a3d7a3
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"]+.box {
    display: block;
    transition: color .25s ease
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"]+.box .count-box {
    display: flex;
    justify-content: space-around;
    align-items: center
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"]+.box .count {
    color: #455A64
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input.checked[type="radio"]+.box .count {
    color: white
}

#sf-form-elements .sf-opinion-wrapper .sf-opinion-radio-button input[type="radio"]:focus+.box {
    box-shadow: inset 0 0 4px 1px #fff
}

#sf-form-elements .sf-opinion-text-wrapper {
    margin-top: 8px;
    margin-bottom: 1rem
}

#sf-form-elements .sf-opinion-text-wrapper .sf-opinion-text-box {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    color: #455A64
}

#sf-form-elements .sf-opinion-text-wrapper .sf-opinion-text-box .sf-opinion-text.right {
    text-align: right
}

#sf-form-elements .sf-opinion-text-wrapper .sf-opinion-text-box .sf-opinion-text.center {
    text-align: center
}

#sf-form-elements .sf-opinion-text-wrapper .sf-opinion-text-box .sf-opinion-text.left {
    text-align: left
}

#sf-form-elements .has-danger .sf-opinion-wrapper {
    border: 1px solid #d9534f
}

#sf-form-elements .sf-rating-wrapper {
    display: flex;
    min-height: 38px;
    position: relative;
    z-index: 0
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button {
    display: block
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button+.sf-rating-radio-button {
    margin-left: 15px
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button label {
    margin-bottom: 0;
    cursor: pointer
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"] {
    opacity: 0
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box {
    display: inline-block
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon {
    display: block;
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    transition: color .25s ease;
    color: #AEBFC7
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon::before {
    font-size: 36px
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon.fcon-star-fill .count-box .count {
    color: #455A64
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon.fcon-square-fill .count-box {
    top: 47%
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon.fcon-heart-fill::before {
    font-size: 31px
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box i.radio-icon.fcon-heart-fill .count-box {
    top: 42%
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box .count-box {
    position: absolute;
    z-index: 2;
    color: white;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%)
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]+.box .count-box .count {
    color: white;
    font-size: 0.8rem
}

#sf-form-elements .sf-rating-wrapper .sf-rating-radio-button input[type="radio"]:focus+.box {
    box-shadow: 0 0 6px 0px #a3d7a3
}

#sf-form-elements .has-danger .sf-rating-wrapper {
    background: rgba(217,83,79,0.1);
    border-radius: 0.25rem
}

.fullscreen-body #sf-form-elements .has-danger .sf-rating-wrapper {
    background: rgba(217,83,79,0.5)
}

#sf-form-elements .flatpickr-input {
  background-color: #fff;

  font-weight: 400;
  font-style: normal;
}
@media screen and (max-width:480px) {
  #sf-form-elements .flatpickr-input {
    width: calc(100% - 1.5rem);
  }
}

#sf-form-elements .sf-select-button {
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 4px;
  padding: 8px;
  display: flex;
  align-items: center;
  height: 100%;
  box-sizing: border-box;
  margin-top: 4px;
  margin-bottom: 4px;
  word-break: break-all;
	max-width:350px;
	width:100%;
}

#sf-form-elements .sf-select-button .option-text {
    word-break: break-all;
    word-wrap: break-word;
    overflow-wrap: break-word
}

#sf-form-elements .sf-select-button input {
    margin-right: 8px;
    display: inline-block
}

#sf-form-elements .sf-button {
    color: #fff;
    padding: 8px;
    box-sizing: border-box;
    display: inline-block;
    text-align: center;
    font-weight: bold
}

#sf-form-elements .sf-button.button-block {
    display: block
}

#sf-form-elements select.form-control:focus {
    box-shadow: 0 0 6px 0px #a3d7a3
}

#sf-form-elements .sf-checkbox input[type="checkbox"] {
    opacity: 0;
    position: absolute
}

#sf-form-elements .sf-checkbox input[type="checkbox"]+.box {
    border-radius: 4px;
    margin-right: 8px;
    position: relative;
    width: 20px;
    height: 20px;
    display: block;
    border: 1px solid #90A4AE
}

#sf-form-elements .sf-checkbox input[type="checkbox"]+.box:after {
    content: "";
    transform: scale(0);
    transition: all .25s ease;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: 90%;
    background-position: 50% 50%;
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iMTAwcHgiIGhlaWdodD0iMTAwcHgiIHZpZXdCb3g9IjAgMCAxMDAgMTAwIiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgogICAgPCEtLSBHZW5lcmF0b3I6IFNrZXRjaCA0MC4zICgzMzgzOSkgLSBodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2ggLS0+CiAgICA8dGl0bGU+Y2hlY2ttYXJrPC90aXRsZT4KICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPgogICAgPGRlZnM+PC9kZWZzPgogICAgPGcgaWQ9IklDT04iIHN0cm9rZT0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIxIiBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiPgogICAgICAgIDxnIGlkPSJjaGVja21hcmsiIGZpbGw9IiNGRkZGRkYiPgogICAgICAgICAgICA8ZyBpZD0iQ2hlY2ttYXJrIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMS4wMDAwMDAsIDIyLjAwMDAwMCkiPgogICAgICAgICAgICAgICAgPGcgaWQ9IkxheWVyXzEiPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik03MS4yOTY3MDAxLDEuMzM2Njg5NzQgTDIyLjgzNTE2MTYsNTAuNTI1ODc4OSBMMjguMjQxNzYxNCw1MC41MjU4Nzg5IEw2LjcwMzI5OTkxLDI4LjY2NDAxNzEgQzUuMjMyMzk0MjYsMjcuMTcxMDI1OCAyLjgyOTY4MTA1LDI3LjE1MzEyMTggMS4zMzY2ODk3NCwyOC42MjQwMjc0IEMtMC4xNTYzMDE1NzUsMzAuMDk0OTMzMSAtMC4xNzQyMDU1NDksMzIuNDk3NjQ2MyAxLjI5NjcwMDA5LDMzLjk5MDYzNzYgTDIyLjgzNTE2MTYsNTUuODUyNDk5NSBDMjQuMzIxNTkxNiw1Ny4zNjEyNDgyIDI2Ljc1NTMzMTUsNTcuMzYxMjQ4MiAyOC4yNDE3NjE0LDU1Ljg1MjQ5OTUgTDc2LjcwMzI5OTksNi42NjMzMTAyNiBDNzguMTc0MjA1NSw1LjE3MDMxODk1IDc4LjE1NjMwMTYsMi43Njc2MDU3NCA3Ni42NjMzMTAzLDEuMjk2NzAwMDkgQzc1LjE3MDMxOSwtMC4xNzQyMDU1NDkgNzIuNzY3NjA1NywtMC4xNTYzMDE1NzUgNzEuMjk2NzAwMSwxLjMzNjY4OTc0IEw3MS4yOTY3MDAxLDEuMzM2Njg5NzQgWiIgaWQ9IlNoYXBlIj48L3BhdGg+CiAgICAgICAgICAgICAgICA8L2c+CiAgICAgICAgICAgIDwvZz4KICAgICAgICA8L2c+CiAgICA8L2c+Cjwvc3ZnPg==)
}

#sf-form-elements .sf-checkbox input[type="checkbox"]:checked+.box {
    border: 1px solid #00BCD4;
    background-color: #00BCD4
}

#sf-form-elements .sf-checkbox input[type="checkbox"]:checked+.box:after {
    transform: scale(1)
}

#sf-form-elements .sf-checkbox input[type="checkbox"]:focus+.box {
    box-shadow: 0 0 6px 0px #a3d7a3
}

#sf-form-elements .sf-radiobutton {
    display: block
}

#sf-form-elements .sf-radiobutton input[type="radio"] {
    opacity: 0;
    position: absolute
}

#sf-form-elements .sf-radiobutton input[type="radio"]+.box {
    border-radius: 20px;
    margin-right: 8px;
    position: relative;
    width: 20px;
    height: 20px;
    display: block;
    position: relative;
    transition: all .25s ease;
    transform: scale(1);
    border: 1px solid #90A4AE;
    float: left
}

#sf-form-elements .sf-radiobutton input[type="radio"]+.box:after {
    content: "";
    transform: scale(0);
    transition: all .25s ease;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: 90%;
    background-position: 50% 50%;
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iMTAwcHgiIGhlaWdodD0iMTAwcHgiIHZpZXdCb3g9IjAgMCAxMDAgMTAwIiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgogICAgPCEtLSBHZW5lcmF0b3I6IFNrZXRjaCA0MC4zICgzMzgzOSkgLSBodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2ggLS0+CiAgICA8dGl0bGU+bWFpbC1zZW5kIGNvcHk8L3RpdGxlPgogICAgPGRlc2M+Q3JlYXRlZCB3aXRoIFNrZXRjaC48L2Rlc2M+CiAgICA8ZGVmcz48L2RlZnM+CiAgICA8ZyBpZD0iSUNPTiIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+CiAgICAgICAgPGcgaWQ9Im1haWwtc2VuZC1jb3B5IiBmaWxsPSIjRkZGRkZGIj4KICAgICAgICAgICAgPGNpcmNsZSBpZD0iT3ZhbC0zIiBjeD0iNTAiIGN5PSI1MCIgcj0iMzYiPjwvY2lyY2xlPgogICAgICAgIDwvZz4KICAgIDwvZz4KPC9zdmc+)
}

#sf-form-elements .sf-radiobutton input[type="radio"]:checked+.box {
    border: 1px solid #00BCD4;
    background-color: #00BCD4
}

#sf-form-elements .sf-radiobutton input[type="radio"]:checked+.box:after {
    transform: scale(1)
}

#sf-form-elements .sf-radiobutton input[type="radio"]:focus+.box {
    box-shadow: 0 0 6px 0px #a3d7a3
}

#sf-form-elements .sf-form-section {
    border-top: 1px solid #CFD8DC;
    padding-bottom: 4px;
    padding-top: 32px;
    margin-top: 32px
}

#sf-form-elements .sf-form-section .title {
    margin: 0;
    color: #455A64
}

#sf-form-elements .sf-form-section .body {
    margin: 0;
    color: #78909C
}

#sf-form-elements .page-partition {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 0
}

#sf-form-elements .page-partition::before,#sf-form-elements .page-partition::after {
    content: '';
    border: none;
    border-top: 1px dashed #CFD8DC;
    color: #fff;
    background-color: #fff;
    height: 1px;
    width: 25%
}

#sf-form-elements .page-partition .title {
    width: 50%;
    text-align: center
}

#sf-form-elements .row.row-select-button-group {
    display: flex;
    flex-direction: none;
    flex-wrap: wrap
}

#sf-form-elements .row.row-gutter-xs {
    margin-left: -4px;
    margin-right: -4px
}

#sf-form-elements .row.row-gutter-xs div[class*='col-'] {
    padding: 0 4px
}

#sf-form-elements .sf-email-confirm-field {
    margin-top: .5rem
}

#sf-form-elements .editable--block-text.left {
    text-align: left
}

#sf-form-elements .editable--block-text.center {
    text-align: center
}

#sf-form-elements .editable--block-text.right {
    text-align: right
}

#sf-form-elements .confirm-value {
    padding-bottom: 8px
}

#sf-form-elements .confirm-value pre {
    display: inherit;
    margin-top: inherit;
    margin-bottom: inherit;
    font-size: inherit;
    font-family: inherit;
    color: inherit;
    white-space: pre-wrap
}

#sf-form-elements .hidden-field.hidden-field-editable {
    background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTMuNTc0IDIuMzY1YS44NTUuODU1IDAgMTAtMS4yMDkgMS4yMDlsMy4zMiAzLjMyYy0uMjQ0LjIxLS40Ny40MTktLjY3NC42MjdhMTYuMTEgMTYuMTEgMCAwMC0xLjEzOCAxLjI5NiAxNy43OCAxNy43OCAwIDAwLS44ODggMS4yMDljLS4yMjUuMzQxLS40MzYuNjg3LS42MzQgMS4wMzgtLjE5OC4zNTItLjMyNC41ODQtLjM3Ny42OThsLS4xMjcuMjcxLjIwMS40MjFjLjEzOC4yODUuMzUzLjY1My42NDQgMS4xMDIuMjkyLjQ1LjYzNy45NDcgMS4wMzUgMS40OTIuMzk5LjU0NS44OTEgMS4wOSAxLjQ3NiAxLjYzM2ExNS42NSAxNS42NSAwIDAwMS44NzMgMS40ODljLjY2My40NSAxLjQzNS44MTYgMi4zMTQgMS4wOTlhOC44MDUgOC44MDUgMCAwMDQuODY1LjE1MyA5LjQzNiA5LjQzNiAwIDAwMS45LS42OTVjLjI5NC0uMTQ4LjU4NC0uMzE0Ljg3MS0uNDk1bDMuNDAxIDMuNDAxYS44NTUuODU1IDAgMTAxLjIwOS0xLjIwOUwzLjU3NCAyLjM2NXptNi44NTcgOS4yNzVsMi4wMzMgMi4wMzNhMS44MyAxLjgzIDAgMDEtLjM2LjAzN2MtLjQ3MiAwLS44NzUtLjE2Ny0xLjIwOS0uNTAxQTEuNjQ3IDEuNjQ3IDAgMDExMC4zOTQgMTJjMC0uMTI1LjAxMy0uMjQ1LjAzNy0uMzZ6bTUuMTM1IDUuNDYzYTcuODU1IDcuODU1IDAgMDEtMS42MjYuNjM0IDYuOTkgNi45OSAwIDAxLTMuNjc0LjAwMyA3Ljc0MiA3Ljc0MiAwIDAxLTEuNjI2LS42MzEgOS40OCA5LjQ4IDAgMDEtMS40MTYtLjkzNWMtLjQ2MS0uMzY1LS44Ni0uNzI1LTEuMTk1LTEuMDc5YTE0Ljk4MyAxNC45ODMgMCAwMS0uOTc4LTEuMTQyIDE0LjkzNSAxNC45MzUgMCAwMS0uNzU1LTEuMDQ5IDE5LjQ4IDE5LjQ4IDAgMDEtLjUyOC0uODcyYy4xNjUtLjI5My4zNDEtLjU4Ny41MjgtLjg4MS4xODctLjI5NC40MzktLjY0Ny43NTUtMS4wNTkuMzE2LS40MTIuNjQzLS43OTYuOTc5LTEuMTU0LjI1My0uMjcuNTU0LS41NDUuODc4LS44MjFsMi4yMTggMi4yMThBMy4yOTIgMy4yOTIgMCAwMDguNjg0IDEyYzAgLjk0NC4zMzQgMS43NSAxLjAwMiAyLjQxOGEzLjI5NSAzLjI5NSAwIDAwMi40MTggMS4wMDJjLjYxNiAwIDEuMTY3LS4xNTcgMS42NjYtLjQ0MmwyLjAwMiAyLjAwMmMtLjA2OS4wNC0uMTM2LjA4Ni0uMjA2LjEyM3pNMjIuMTYxIDExLjU3MmExMS44MSAxMS44MSAwIDAwLS42NDQtMS4wOTggMzIuODk2IDMyLjg5NiAwIDAwLTEuMDM1LTEuNSAxMS44MTMgMTEuODEzIDAgMDAtMS40NzYtMS42NDMgMTUuNTQgMTUuNTQgMCAwMC0xLjg3My0xLjVjLS42NjMtLjQ1Mi0xLjQzNS0uODE5LTIuMzE0LTEuMTAyYTguODA1IDguODA1IDAgMDAtNi4xOS4yOTZsMS4zMzcgMS4zMzdjLjEwMi0uMDMyLjE5Ni0uMDcxLjMwMi0uMWE2LjkwNSA2LjkwNSAwIDAxMS44MzctLjI0N3YuMDAyYy42MjMgMCAxLjIzNi4wODMgMS44MzcuMjQ3YTcuOCA3LjggMCAwMTEuNjI2LjYzNCA5LjM1IDkuMzUgMCAwMTEuNDE2LjkzOGMuNDYxLjM2Ny44Ni43MjkgMS4xOTUgMS4wODUuMzM2LjM1Ni42NjIuNzM5Ljk3OCAxLjE0OS4zMTYuNDEuNTY4Ljc2MS43NTUgMS4wNTUuMTg3LjI5NC4zNjMuNTg1LjUyOC44NzUtLjE2NS4yOS0uMzQxLjU4Mi0uNTI4Ljg3NS0uMTg3LjI5My0uNDM5LjY0NS0uNzU1IDEuMDU1LS4yNDEuMzEzLS40OTQuNTk1LS43NDcuODc3bDEuMjA3IDEuMjA3Yy4yNDEtLjI2Ni40ODYtLjUyMi43MTgtLjgxMi4zNjctLjQ2MS42NjQtLjg2MS44ODgtMS4yMDIuMjI1LS4zNDEuNDM2LS42ODYuNjM0LTEuMDM1LjE5OC0uMzUuMzI0LS41ODEuMzc3LS42OTVsLjEyNy0uMjcxLS4yLS40Mjd6IiBmaWxsPSIjNDU1QTY0Ii8+PHBhdGggZD0iTTEyLjE5MSA4LjU4OGwzLjMyNSAzLjMyNWEzLjI4OSAzLjI4OSAwIDAwLS45OTQtMi4zMzEgMy4yODkgMy4yODkgMCAwMC0yLjMzMS0uOTk0eiIgZmlsbD0iIzQ1NUE2NCIvPjwvc3ZnPg==");
    background-repeat: no-repeat;
    background-size: 20px;
    background-position: 16px;
    background-color: #f6f6fa;
    padding: 8px
}

#sf-form-elements .hidden-field p {
    text-align: center;
    margin: 0;
    color: #455A64
}

.sf-text-left {
    text-align: left
}

.sf-text-center {
    text-align: center
}

.sf-text-right {
    text-align: right
}

.sf-icon-xsmall {
    width: 24px
}

.sf-icon-xsmall.is-circle {
    border-radius: 200px
}

.sf-icon-small {
    width: 32px
}

.sf-icon-small.is-circle {
    border-radius: 200px
}

.sf-icon-medium {
    width: 64px
}

.sf-icon-medium.is-circle {
    border-radius: 200px
}

.sf-icon-large {
    width: 80px
}

.sf-icon-large.is-circle {
    border-radius: 200px
}

.sf-icon-xlarge {
    width: 128px
}

.sf-icon-xlarge.is-circle {
    border-radius: 200px
}

.layout-nocover .sf-form-cover,.layout-fullscreen .sf-form-cover,.sf-form-cover .overlay-fullscreen {
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0
}

body {
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

* {
    -webkit-tap-highlight-color: rgba(0,0,0,0)
}

#sf-form-page {
    color: #455A64
}

#sf-form-page input:active,#sf-form-page input:focus,#sf-form-page textarea:active,#sf-form-page textarea:focus,#sf-form-page select:active,#sf-form-page select:focus {
    outline: none
}

#sf-form-page h1,#sf-form-page h2,#sf-form-page h3,#sf-form-page h4,#sf-form-page h5,#sf-form-page h6 {
    font-weight: normal;
    text-rendering: optimizeLegibility;
    margin: 0;
    margin-bottom: 8px;
    line-height: 150%
}

#sf-form-page h1.multi-line,#sf-form-page h2.multi-line,#sf-form-page h3.multi-line,#sf-form-page h4.multi-line,#sf-form-page h5.multi-line,#sf-form-page h6.multi-line {
    white-space: pre-wrap
}

#sf-form-page p {
    line-height: 165%
}

#sf-form-page h1 {
    font-size: 36px
}

#sf-form-page h2 {
    font-size: 30px
}

#sf-form-page h3 {
    font-size: 24px
}

#sf-form-page h4,#sf-form-page h5,#sf-form-page h6 {
    font-size: 18px
}

#sf-form-page div {
    box-sizing: border-box
}

#sf-form-page label div {
    display: inline-block
}

[class*="layout-"] [data-formrun-show-if-error]:not(.formrun-system-show),[class*="layout-"] [data-formrun-show-if-success]:not(.formrun-system-show) {
    display: none
}

.sf-container {
    padding: 0 16px
}

@media (max-width: 554px) {
    .sf-container {
        padding:0 8px
    }
}

.sf-personal-logo-wrap {
    width: 64px;
    height: 64px;
    position: relative
}

.sf-personal-logo-wrap .sf-personal-logo {
    width: 64px;
    height: 64px;
    border: 2px solid #fff;
    background-color: #fff;
    box-shadow: 0 6px 6px rgba(0,0,0,0.05);
    background-size: contain;
    overflow: hidden;
    z-index: 100
}

.sf-personal-logo-wrap .sf-personal-logo.square {
    border-radius: 8px
}

.sf-personal-logo-wrap .sf-personal-logo.circle {
    border-radius: 100px
}

.sf-personal-logo-wrap .sf-personal-logo img {
    width: 100%;
    max-width: 100%
}

.sf-form-cover {
    background-size: cover;
    background-position: 50% 50%;
    position: relative
}

.sf-form-cover .overlay-fullscreen {
    background-color: rgba(0,0,0,0.5)
}

.sf-form-title-top {
    margin-bottom: 32px;
    text-align: center
}

.sf-form-title-top .title {
    margin: 0
}

.sf-form-title-top .subtitle {
    margin: 0
}

.sf-form-title-top hr {
    border: none;
    border-top: 1px solid #CFD8DC;
    width: 100px;
    margin: 32px auto
}

.button-round .sf-btn {
    border-radius: 100px;
    border-width: 2px;
    border-style: solid;
    color: #fff
}

.button-rect .sf-btn {
    border-radius: 4px;
    border-width: 2px;
    border-style: solid;
    color: #fff
}

.button-rect .sf-back-btn {
    border-color: #90a5af;
    background: #fff;
    color: #7b919c
}

.button-rect-outline .sf-btn {
    font-weight: bold;
    border-radius: 4px;
    border-width: 2px;
    border-style: solid;
    background-color: transparent !important
}

.sf-form-legal-notice a {
    text-decoration: none
}

.sf-form-legal-notice a:hover {
    opacity: .9
}

.sf-footer {
    margin-top: 60px
}

.form-group .redactor-toolbar-wrapper,.sf-form-title-group .redactor-toolbar-wrapper {
    position: sticky;
    top: 0px;
    z-index: 1;
    padding: 20px;
    filter: drop-shadow(0 0 0.45rem #fff)
}

.form-group .redactor-toolbar-wrapper .redactor-toolbar,.sf-form-title-group .redactor-toolbar-wrapper .redactor-toolbar {
    padding: 0
}

.layout-fullscreen {
    left: 0;
    top: 0;
    overflow: hidden;
    position: absolute;
    height: 100%;
    width: 100%;
    padding: 16px
}

.layout-fullscreen label:not(.alert,.matrix-table__trash-icon),.layout-fullscreen h1:not(.alert,.matrix-table__trash-icon),.layout-fullscreen h2:not(.alert,.matrix-table__trash-icon),.layout-fullscreen h3:not(.alert,.matrix-table__trash-icon),.layout-fullscreen h4:not(.alert,.matrix-table__trash-icon),.layout-fullscreen h5:not(.alert,.matrix-table__trash-icon),.layout-fullscreen p:not(.alert,.matrix-table__trash-icon),.layout-fullscreen i:not(.alert,.matrix-table__trash-icon),.layout-fullscreen small:not(.alert,.matrix-table__trash-icon) {
    color: #fff
}

.layout-fullscreen .form-control-feedback {
    color: #fff
}

.layout-fullscreen .sf-form-unentered-fields-number-cover {
    padding: 0 12px
}

.layout-fullscreen .sf-form-unentered-fields-number {
    max-width: 376px
}

@media (max-width: 554px) {
    .layout-fullscreen .sf-form-unentered-fields-number {
        max-width:336px
    }
}

@media (max-width: 320px) {
    .layout-fullscreen .sf-form-unentered-fields-number {
        max-width:276px
    }
}

.layout-fullscreen .fullscreen-body {
    overflow: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    display: -ms-flexbox;
    -js-display: flex;
    flex-direction: column;
    align-items: center;
    -ms-flex-align: center;
    -webkit-overflow-scrolling: touch;
    -ms-touch-action: pan-y
}

@media (max-width: 554px) {
    .layout-fullscreen .fullscreen-body {
        display:block
    }
}

.layout-fullscreen .fullscreen-body .center-wrap {
    margin: auto;
    box-sizing: border-box;
    max-width: 100%
}

.layout-fullscreen .fullscreen-body .center-wrap.unentered-fields-number-padding {
    padding-top: 38px
}

.layout-fullscreen .fullscreen-body .center-wrap .center-body {
    padding: 32px 12px;
    width: 400px
}

@media (max-width: 554px) {
    .layout-fullscreen .fullscreen-body .center-wrap .center-body {
        display:block;
        margin: 0 auto;
        max-width: 360px;
        width: 100%
    }
}

@media (max-width: 320px) {
    .layout-fullscreen .fullscreen-body .center-wrap .center-body {
        display:block;
        margin: 0 auto;
        max-width: 300px;
        width: 100%
    }
}

.layout-fullscreen .sf-form-cover {
    background-size: cover;
    background-position: fixed
}

.layout-fullscreen .sf-personal-logo-wrap {
    margin: 0 auto;
    margin-bottom: 8px
}

.layout-fullscreen .sf-form-legal-notice {
    color: #fff
}

.layout-fullscreen .divider {
    border: none;
    border-top: 1px solid #fff;
    margin: 32px auto;
    width: 100px
}

.layout-fullscreen .fullscreen-contents {
    background-color: transparent;
    z-index: 1;
    margin: 0 auto;
    padding: 88px 44px;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    max-width: 100%;
    overflow: auto;
    display: flex;
    flex-direction: column;
    align-items: center
}

.layout-fullscreen .fullscreen-contents .fullscreen-contents-inner {
    margin: auto
}

.layout-fullscreen .fullscreen-contents .sf-form-content {
    max-width: 640px
}

.layout-fullscreen #sf-form-elements .page-partition .title {
    width: 45%;
    color: #fff
}

.layout-fullscreen #sf-form-elements .page-partition p {
    background-color: rgba(0,0,0,0.5)
}

.layout-fullscreen #sf-form-elements .sf-form-section .title,.layout-fullscreen #sf-form-elements .sf-form-section .body,.layout-fullscreen #sf-form-elements .sf-form-section p,.layout-fullscreen #sf-form-elements .sf-form-section small {
    color: #fff
}

.layout-fullscreen #sf-form-elements .sf-form-section .text-muted {
    color: rgba(255,255,255,0.8) !important
}

.layout-fullscreen #sf-form-elements .sf-form-group label,.layout-fullscreen #sf-form-elements .sf-form-group p,.layout-fullscreen #sf-form-elements .sf-form-group small,.layout-fullscreen #sf-form-elements .sf-form-group .sf-opinion-text,.layout-fullscreen #sf-form-elements .sf-form-group .sf-image-wrapper-label {
    color: #fff
}

.layout-fullscreen #sf-form-elements .sf-form-group .form-control {
    background-color: rgba(255,255,255,0.9)
}

.layout-fullscreen #sf-form-elements .sf-form-group .sf-select-button {
    background-color: rgba(255,255,255,0.9);
    color: #455A64
}

.layout-fullscreen #sf-form-elements .confirm-value {
    color: #fff
}

.layout-fullscreen #sf-form-elements .confirm-value pre {
    color: #fff
}

.layout-fullscreen .hint-text {
    color: #fff
}

.layout-fullscreen .entry-limit-countdown-remainder {
    color: #fff !important
}

.layout-fullscreen .description-text {
    color: #fff
}

#fons-form-edit .layout-fullscreen .editable.hint-text,#forms-edit-step2 .layout-fullscreen .editable.hint-text {
    color: #fff
}

#fons-form-edit .layout-fullscreen .editable--label,#forms-edit-step2 .layout-fullscreen .editable--label {
    color: #fff
}

#fons-form-edit .layout-fullscreen .editable.active.sf-form-group,#forms-edit-step2 .layout-fullscreen .editable.active.sf-form-group {
    background-color: rgba(255,255,255,0.1)
}

#fons-form-edit .layout-nocover .nocover-body,#forms-edit-step2 .layout-nocover .nocover-body {
    padding-top: 6px
}

.layout-vertical {
    height: 100%;
    width: 100%;
	background-color: #fff;
    padding: 36px 0;
    margin-top: 40px;
}

.layout-vertical .vertical-body {
    min-height: 100%
}

.layout-vertical .sf-form-cover {
    width: 100%;
    height: 160px;
    position: relative
}

.layout-vertical .sf-form-cover .overlay-vertical-single-mode {
    background-color: rgba(0,0,0,0.5);
    position: absolute;
    top: 24px;
    bottom: 24px;
    left: 24px;
    right: 24px;
    margin-left: auto;
    margin-right: auto
}

.layout-vertical .sf-form-cover+.sf-form-title-group {
    margin-top: 44px
}

.layout-vertical .sf-form-cover+.notitle-space {
    height: 24px
}

.layout-vertical .sf-personal-logo-wrap {
    margin: -32px auto 21.3333333333px auto;
    box-shadow: none
}

.layout-vertical .sf-form-unentered-fields-number-cover {
    padding: 0 16px
}

.layout-vertical .sf-form-unentered-fields-number {
    max-width: 608px
}

.layout-vertical .sf-form-title-group {
    padding: 0 16px;
    max-width: 640px;
    margin: 0 auto
}

.layout-vertical .sf-form-title-group .title {
    margin-bottom: 0
}

.layout-vertical .notitle-space {
    height: 0;
    padding: 0;
    margin: 0
}

.layout-vertical .sf-form-content {
    max-width: 640px;
    margin: 0 auto;
    padding: 16px;
    padding-top: 0
}

@media (min-width: 544px) {
    .layout-vertical .sf-form-content {
        padding:44px;
        padding-top: 0
    }
}
@media (min-width: 480px) {
    .layout-vertical .sf-form-content {
      padding: 16px 5%;
  }
}

.layout-vertical .description-text {
    color: #455A64
}

.embed .layout-vertical .vertical-body {
    min-height: auto
}

.layout-horizontal {
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0
}

.layout-horizontal.unentered-fields-number-padding .sf-form-cover {
    min-height: 254px;
    padding-top: 70px
}

@media (min-width: 554px) {
    .layout-horizontal.unentered-fields-number-padding .sf-form-cover {
        min-height:200px;
        padding: 16px
    }
}

.layout-horizontal .horizontal-body {
    min-height: 100%
}

.layout-horizontal .horizontal-body .sf-form-unentered-fields-number-cover {
    padding: 0 16px
}

@media (min-width: 554px) {
    .layout-horizontal .horizontal-body .sf-form-unentered-fields-number-cover {
        width:50%;
        left: 50%
    }
}

.layout-horizontal .sf-form-cover {
    position: relative;
    min-height: 200px;
    padding: 16px
}

@media (min-width: 554px) {
    .layout-horizontal .sf-form-cover {
        width:50%;
        height: 100%;
        position: absolute;
        display: grid;
        align-items: end;
        overflow-y: scroll
    }
}

.layout-horizontal .sf-form-cover .sf-form-title-group {
    text-align: left;
    position: relative
}

.layout-horizontal .sf-form-cover .sf-form-title-group .title {
    margin-bottom: 0;
    color: #fff
}

.layout-horizontal .sf-form-cover .sf-form-title-group .richtext-content {
    color: #fff
}

.layout-horizontal .sf-form-cover .sf-form-title-group .subtitle {
    color: #fff;
    opacity: .9
}

.layout-horizontal .sf-form-cover .sf-form-title-group .social-link {
    text-align: left
}

.layout-horizontal .sf-personal-logo-wrap {
    margin-bottom: 64px
}

@media (min-width: 554px) {
    .layout-horizontal .sf-personal-logo-wrap {
        margin:0
    }
}

.layout-horizontal .sf-form-content {
    position: relative;
    max-width: 600px;
    margin: 0 auto;
    width: 50%;
    max-width: 100%;
    left: 50%;
    position: absolute;
    overflow: auto;
    height: 100%;
    top: 0;
    margin: 0;
    padding: 16px 8px 16px;
    overflow-y: auto;
    display: flex
}

@media (min-width: 554px) {
    .layout-horizontal .sf-form-content {
        padding:64px
    }
}

.layout-horizontal .sf-form-content .sf-form-inner {
    width: 100%;
    margin: auto
}

@media (max-width: 554px) {
    .layout-horizontal .sf-form-content {
        position:relative;
        width: 100%;
        left: auto;
        overflow: visible;
        height: auto
    }
}

.layout-horizontal .sf-form-title-group .redactor-toolbar-wrapper {
    position: relative
}
.form-input-name {
  display: flex;
  flex-direction: initial!important;
}
/* .form-input-name input:first-of-type {
  margin-right: 12px;
  width: 100%;
} */
@media screen and (min-width:481px) {
  .input-date {
    width: 300px;
  }
}
.flex-checkbox {
  flex-direction: initial!important;
  flex-wrap: wrap;
}
@media screen and (min-width:481px) {
  .flex-checkbox .sf-select-button {
    width: calc(50% - 16px)!important;
  }
}
@media screen and (min-width:481px) {
  .flex-checkbox .sf-select-button:nth-child(odd) {
    margin-right: 16px!important;
  } 
}   
.contact {
  padding-top: 64px;
  background-color: #fff;
}
.contact__title {
  position: relative;
}
.contact__title:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -18px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
  background-color: #011835; /*下線の色*/
}
.form-input__contents-child{
  display: block;
  width: calc(100% - 12px);
  margin-right: 12px;
}
.formrun-system-show {
  margin-top:4px;
  color: #d9534f;
}
/* to-cta */
/* top-botton */
.to-cta-button .top-botton {
  position: relative;
  width: 100%;
  right: 0;
  bottom: 0;
  padding: 0;
}

@media screen and (max-width:1023px) {
  .to-cta-button .top-botton {
    width: 100%;
  }
}

.to-cta-button .form-botton__content {
  width: 100%;
  padding: 42px 0;
  background: linear-gradient(90deg, #011835 0%, #024B7E 100%);
  position: relative;
  color: #fff;
  display: block;
  margin: auto;
  font-size: 28px;
  text-align: center;
  text-decoration: none;
  font-style: normal;
  font-weight: 400;
  text-align: center;
}

@media screen and (max-width:480px) {
  .form-botton__content {
    padding: 22px 48px;
    font-size: 24px;
  }
}

.to-cta-button.second {
  margin-top: 120px;
}

@media screen and (max-width:480px) {
  .to-cta-button.second {
    margin-top: 48px;
  }
}