@charset "UTF-8";
.site-body-bottom {
  display: none;
}

.mia {
  margin-inline: auto;
}

.wfc {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.sme-br {
  height: 0;
}

.inner {
  max-width: calc(var(--gb-container-width) + 10%);
  min-width: auto;
  padding-left: 5%;
  padding-right: 5%;
}

@media screen and (max-width: 767px) {
  .inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}
body *, body p {
  letter-spacing: 0.05em;
  font-family: "Noto Sans JP", sans-serif;
}

h2 {
  font-size: 28px;
  border: 0;
}

@media screen and (max-width: 429px) {
  h2 {
    font-size: 24px;
  }
}
h3 {
  border-bottom: 0;
}

h3::after {
  display: none;
}

h4 {
  background: none;
  padding: 0;
}

p, figure, h2, h3, h4, h5, h6, a, span, div {
  margin: 0;
}

body p {
  font-size: 17px;
  font-weight: 400;
}

@media screen and (max-width: 429px) {
  body p {
    font-size: 15px;
  }
}
br {
  height: 0;
}

strong {
  line-height: normal;
}

a {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

a:hover {
  color: inherit;
  opacity: 0.7;
}

.fullwide {
  width: 100vw;
  margin-inline: calc(50% - 50vw);
}

@media screen and (max-width: 767px) {
  .fullwide-sp {
    margin-inline: calc(50% - 50vw);
    width: 100vw;
  }
}
@media screen and (max-width: 767px) {
  .d-contents-sp {
    display: contents;
  }
}
@media screen and (max-width: 429px) {
  /* .cta_wrap01 {
    flex-direction: column;
  } */
  .wsn_sp429 {
    white-space: nowrap;
  }
}
@media screen and (min-width: 430px) {
  .br_sp_430 {
    display: block;
  }
}
@media screen and (max-width: 429px) {
  .br_sp_430 {
    display: none;
  }
}
/* 装飾 */
.bg_navy_slush::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
  width: 100vw;
  height: 90%;
  background: #0F1B60;
  -webkit-clip-path: polygon(100% 0, 100% 60%, 0 100%, 0 40%);
          clip-path: polygon(100% 0, 100% 60%, 0 100%, 0 40%);
}

.marketing_list .tag {
  -webkit-clip-path: polygon(0 0, 100% 0, 90% 100%, 0 100%);
          clip-path: polygon(0 0, 100% 0, 90% 100%, 0 100%);
}

.under_triangle::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 30px;
  height: 14px;
  background: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.top_triangle::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -1px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 15px;
  height: 8px;
  background: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
}

@media screen and (max-width: 767px) {
  .marketing_list {
    margin-inline: calc(50% - 50vw);
    width: 100vw;
  }
}
.merit_list > div:nth-child(2) h3, .merit_list > div:nth-child(3) h3 {
  color: #0083B4;
}

.merit_list > div:nth-child(2) p, .merit_list > div:nth-child(3) p {
  background-color: #0083B4;
}

@media screen and (max-width: 767px) {
  .merit_list > div:nth-child(3) h3 {
    color: #3DB4E0;
  }
  .merit_list > div:nth-child(even) h3 {
    color: #0083B4;
  }
  .merit_list > div:nth-child(3) p {
    background-color: #3DB4E0;
  }
  .merit_list > div:nth-child(even) p {
    background-color: #0083B4;
  }
}
.hide_text { /* ご導入企業様の声 */
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.hide_text.is-open {
  max-height: 500px; /* 十分な高さにしておく */
  opacity: 1;
  padding-top: 16px;
}

.rotate_img {
  -webkit-transition: -webkit-transform 0.5s ease;
  transition: -webkit-transform 0.5s ease;
  transition: transform 0.5s ease;
  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
  cursor: pointer;
}

.rotate_img.rotated {
  -webkit-transform: translate(-50%, 50%) rotate(180deg);
          transform: translate(-50%, 50%) rotate(180deg);
}

.voice_list_item::before { /* その他の声 */
  content: "";
  display: inline-block;
  width: 21px;
  height: 13px;
  background-color: #001462;
  position: absolute;
  left: 26px;
  bottom: 0;
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%);
          clip-path: polygon(0 0, 100% 0, 100% 100%);
  z-index: -1;
}

.voice_list_item:nth-of-type(even)::before {
  background-color: #0083B4;
}

.voice_list_item:nth-of-type(even) h4 {
  color: #0083B4;
}

@media screen and (max-width: 767px) {
  .voice_list_item:nth-of-type(even)::before {
    background-color: #001462;
  }
  .voice_list_item:nth-of-type(even) h4 {
    color: #001462;
  }
  .voice_list_item:nth-of-type(2)::before, .voice_list_item:nth-of-type(3)::before, .voice_list_item:nth-of-type(6)::before {
    background-color: #0083B4;
  }
  .voice_list_item:nth-of-type(2) h4, .voice_list_item:nth-of-type(3) h4, .voice_list_item:nth-of-type(6) h4 {
    color: #0083B4;
  }
}
.faq_list.wp-block-snow-monkey-blocks-accordion { /* FAQ */
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

@media screen and (max-width: 767px) {
  .faq_list.wp-block-snow-monkey-blocks-accordion {
    grid-template-columns: 1fr;
    GAP: 16px;
  }
}
.smb-accordion > * + * {
  margin-top: 0;
}

.faq_list .smb-accordion__item {
  border-radius: 10px;
  overflow: hidden;
}

.faq_list .smb-accordion__item__title {
  font-size: 16px;
  letter-spacing: 0.01em;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  padding: 4px 20px;
  min-height: 55px;
  border-radius: 10px;
}

@media screen and (max-width: 767px) {
  .faq_list .smb-accordion__item__title {
    min-height: auto;
    padding: 15px 20px;
  }
}
.faq_list.smb-accordion .smb-accordion__item__control:checked + .smb-accordion__item__title {
  border-radius: 10px 10px 0 0;
}

.faq_list .smb-accordion__item__body {
  padding: 10px;
  border: 1px solid #0083B4;
  border-radius: 0 0 10px 10px;
}

.faq_list .smb-accordion__item__body p {
  font-size: 13px;
  color: #444;
  letter-spacing: 0.01em;
}

.faq_list .smb-accordion__item__title__icon {
  position: relative;
  background: url("http://clucla.jp/wp-content/uploads/2025/06/icon_down_white.png") no-repeat center/contain;
  width: 21px;
  height: 14px;
  margin-left: 10px;
}

.faq_list .smb-accordion__item__title__icon svg {
  display: none;
}

.wpcf7-form { /* お問い合わせフォーム */
  background: #fff;
  padding: 30px 60px 50px;
  border-radius: 0 0 10px 10px;
  border: 2px solid #78C8E6;
}

.wpcf7-response-output {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .wpcf7-form {
    padding: 30px;
  }
}
.form_container {
  margin: 0 auto;
  max-width: 575px;
}

.wpcf7 label {
  margin-bottom: 8px;
  text-align: center;
  font-size: 14px;
  font-weight: 300;
  display: block;
}

@media screen and (max-width: 767px) {
  .wpcf7 .wpcf7-checkbox label {
    text-align: left;
  }
}
.required {
  color: #CD0C0A;
}

.wpcf7 .form_item {
  margin-top: 16px;
}

.fz12 {
  font-size: 12px;
}

.wpcf7 input[type=text],
.wpcf7 input[type=email],
.wpcf7 input[type=tel],
.wpcf7 input[type=date],
.wpcf7 input[type=url],
.wpcf7 textarea,
.wpcf7 select {
  width: 100%;
  padding: 12px 16px;
  border: 0.5px solid #000;
  border-radius: 5px;
  font-size: 14px;
  background-color: #fff;
  text-align: left;
}

input[type=submit] {
  font-size: 1rem;
  border: none;
  background-color: #000000;
  color: #fff;
  width: 108px;
  height: 40px;
  padding: 0.2em 0.5em;
  border-radius: 5px;
  margin-top: 30px;
  margin-inline: auto;
  display: grid;
  place-items: center;
}

.wpcf7-not-valid-tip {
  font-size: 14px;
}

.wpcf7-list-item {
  margin: 0;
}

.tab_text {
  cursor: pointer;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
}

.tab_text.active-tab {
  background: #0083B4;
}

.payment_form .wpcf7-form { /* 決済フォーム用調整 */
  padding: 0;
  border: none;
}
@media screen and (max-width: 767px) {
  .payment_form .wpcf7-form {
    padding: 0;
  }
}
.payment_form .wpcf7-form .form_container {
  max-width: 640px;
}
.payment_form .wpcf7-form label {
  font-weight: 500;
  text-align: left;
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .payment_form .wpcf7-form label {
    font-size: 14px;
    text-align: center;
  }
}
.payment_form .wpcf7-form .wpcf7-list-item label {
  font-weight: 400;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .payment_form .wpcf7-form .wpcf7-list-item label {
    font-size: 14px;
    text-align: left;
  }
}
.payment_form .wpcf7-form input[type=submit] {
  font-size: 24px;
  width: 280px;
  height: 48px;
  margin-inline: auto;
  display: grid;
  place-items: center;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media screen and (max-width: 767px) {
  .payment_form .wpcf7-form input[type=submit] {
    font-size: 16px;
    width: 100px;
    height: 36px;
  }
}

.footer_fixed_btn {
  position: fixed;
  bottom: 0;
  left: 50%;
  z-index: 100;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: translate(-50%, 100%);
          transform: translate(-50%, 100%);
  padding-right: 15px;
  padding-left: 15px;
}
.page-id-174 .footer_fixed_btn {
	    bottom: 20px;
}

.footer_fixed_btn_payment {
  padding-bottom: 10px;
}

.footer_fixed_btn.visible {
  opacity: 1;
  visibility: visible;
          transform: translate(-50%, 0);
}

@media (max-width: 991px) {
  body.page-id-1560 .page_top_btn {
    bottom: 152px;
  }
}
@media (max-width: 600px) {
  body.page-id-2123 .page_top_btn, body.page-id-2246 .page_top_btn {
    bottom: 97px;
  }
}
/* 1439~768 レスポンシブ */
@media screen and (max-width: 1439px) and (min-width: 768px) {
  .footer_fixed_btn {
    padding-right: 5% !important;
    padding-left: 5% !important;
  }
  .cta_wrap01, .cta_wrap01 * {
    -webkit-box-pack: justify !important;
    -webkit-justify-content: space-between !important;
        -ms-flex-pack: justify !important;
            justify-content: space-between !important;
  }
  .cta_wrap01 .fz25_sp429 {
    font-size: max(38px, 38px + 17 * (100vw - 768px) / 671) !important;
  }
  .cta_wrap01 .fz10_sp429 {
    font-size: max(20px, 20px + 10 * (100vw - 768px) / 671) !important;
    line-height: 2.2;
  }
  .merit_list h3 {
    font-size: max(20px, 20px + 5 * (100vw - 768px) / 671) !important;
  }
  .cta_btn02 {
    padding-top: max(15px, 15px + 13 * (100vw - 768px) / 671) !important;
    padding-bottom: max(15px, 15px + 13 * (100vw - 768px) / 671) !important;
  }
  .phone_img {
    width: max(280px, 280px + 40 * (100vw - 768px) / 671) !important;
  }
  .what_text {
    width: max(500px, 500px + 45 * (100vw - 768px) / 671) !important;
  }
}
/* 389以下 レスポンシブ */
@media screen and (max-width: 389px) {
  body p {
    font-size: max(14px, 14px + 1 * (100vw - 320px) / 69);
  }
  .page-id-1560 h2 {
    font-size: max(20px, 20px + 4 * (100vw - 320px) / 69) !important;
  }
  .fv_bottom_text {
    margin-top: min(-150px, -150px + -30 * (100vw - 320px) / 69) !important;
  }
  .fz14_sp429 {
    font-size: max(12px, 12px + 2 * (100vw - 320px) / 69) !important;
  }
  .cta_wrap01 .fz25_sp429 {
    font-size: max(22px, 22px + 3 * (100vw - 320px) / 69) !important;
  }
  .cta_wrap01 .fz10_sp429 {
    line-height: 2.2;
  }
  .bg_navy_slush img {
    -o-object-fit: contain;
       object-fit: contain;
    min-width: 0;
  }
  .bg_navy_slush p {
    width: max(180px, 180px + 40 * (100vw - 320px) / 69);
    font-size: max(12px, 12px + 3 * (100vw - 320px) / 69);
  }
  .marketing_list img + p {
    font-size: max(14px, 14px + 2 * (100vw - 320px) / 69) !important;
  }
  .kadai_wrap p {
    font-size: max(14px, 14px + 2 * (100vw - 320px) / 69) !important;
  }
  .kadai_text {
    font-size: max(14px, 14px + 4 * (100vw - 320px) / 69) !important;
  }
  .kadai_text .sme-font-size {
    font-size: max(18px, 18px + 7 * (100vw - 320px) / 69) !important;
  }
  .phone_img {
    width: max(200px, 200px + 50 * (100vw - 320px) / 69) !important;
  }
  .what_text {
    width: max(170px, 170px + 38 * (100vw - 320px) / 69) !important;
  }
  .what_list p {
    font-size: max(14px, 14px + 2 * (100vw - 320px) / 69) !important;
  }
  .kinou_wrap {
    padding-right: max(15px, 15px + 17 * (100vw - 320px) / 69) !important;
    padding-left: max(15px, 15px + 17 * (100vw - 320px) / 69) !important;
  }
  .kinou_list p {
    font-size: max(13px, 13px + 2 * (100vw - 320px) / 69) !important;
  }
  .kinou_list .sme-font-size {
    font-size: max(12px, 12px + 2 * (100vw - 320px) / 69) !important;
  }
  .merit_list h3 {
    font-size: max(16px, 16px + 2 * (100vw - 320px) / 69) !important;
  }
  .merit_list p {
    font-size: max(14px, 14px + 2 * (100vw - 320px) / 69) !important;
  }
  .cta_btn02 p {
    font-size: max(20px, 20px + 4 * (100vw - 320px) / 69) !important;
  }
  .cta_btn02 img {
    width: 40px !important;
  }
  .voice_wrap {
    padding-right: max(20px, 20px + 20 * (100vw - 320px) / 69) !important;
    padding-left: max(20px, 20px + 20 * (100vw - 320px) / 69) !important;
  }
  .flow_list .number {
    width: max(45px, 45px + 10 * (100vw - 320px) / 69) !important;
    height: max(45px, 45px + 10 * (100vw - 320px) / 69) !important;
    left: min(-30px, -30px + -7.5 * (100vw - 320px) / 69) !important;
  }
  .flow_list .fz16_sp429 + p {
    font-size: max(14px, 14px + 1 * (100vw - 320px) / 69) !important;
  }
  .flow_list .fz16_sp429 {
    font-size: max(14px, 14px + 2 * (100vw - 320px) / 69) !important;
  }
  .cta_wrap03 .price {
    font-size: max(25px, 25px + 5 * (100vw - 320px) / 69) !important;
  }
  .wpcf7-form {
    padding-right: max(15px, 15px + 15 * (100vw - 320px) / 69) !important;
    padding-left: max(15px, 15px + 15 * (100vw - 320px) / 69) !important;
  }
  .payment_form .wpcf7-form {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
}
.faq_list_payment h3, .faq_list_payment p {
  padding: 15px 30px 15px 60px;
  border-radius: 36px;
  position: relative;
  line-height: 1.5;
  letter-spacing: 0;
}
@media screen and (max-width: 600px) {
  .faq_list_payment h3, .faq_list_payment p {
    padding: 8px 14px 8px 32px;
    border-radius: 12px;
  }
}
.faq_list_payment h3::before, .faq_list_payment p::before {
  position: absolute;
  left: 13px;
  top: 13px;
  font-size: 20px;
  font-weight: 500;
  width: 33px;
  height: 33px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 600px) {
  .faq_list_payment h3::before, .faq_list_payment p::before {
    left: 7px;
    top: 7px;
    font-size: 14px;
    width: 20px;
    height: 20px;
  }
}
.faq_list_payment h3 {
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  background: #111261;
  margin-bottom: 20px;
}
@media screen and (max-width: 600px) {
  .faq_list_payment h3 {
    font-size: 12px;
    margin-bottom: 10px;
  }
}
.faq_list_payment h3::before {
  content: "Q";
  color: #111261;
  background: #fff;
}
.faq_list_payment p {
  font-size: 18px;
  font-weight: 500;
  color: #111261;
  background: #fff;
  border: 2px solid #001462;
}
@media screen and (max-width: 600px) {
  .faq_list_payment p {
    font-size: 12px;
    line-height: 1.3;
  }
}
.faq_list_payment p::before {
  content: "A";
  color: #fff;
  background: #001462;
}

.faq_list_payment h3.one-line,
.faq_list_payment p.one-line {
  border-radius: 36px;
}

.faq_list_payment h3.multi-line,
.faq_list_payment p.multi-line {
  border-radius: 12px;
}

/**/
html{
    overflow-x: hidden;
}
body{
    overflow-x: hidden;
}
.gb-element-5f10d0c6,.gb-element-9aa6c7a9 {
    text-decoration: none;
    color: #132950;
}
.gb-element-f739dbbc,.gb-element-1f270c31,.gb-element-a5727f6b,.gb-element-f6df7f04,.gb-element-1fe03dd5,.gb-element-b903d69d ,.gb-element-c2a4b429{
    max-width: 950px!important;
}
.gb-element-45fecdfc {
    text-decoration: none;
}
.faq_list .smb-accordion__item {
    margin: 0;
}
.gb-element-11b4e9ba {
    background-color: #001462;
padding-bottom: 150px !important;
}
button.page-top {
    position: fixed;
    display: flex;
    align-items: center;
    justify-content: center;
    right: 20px;
    bottom: 17px;
    cursor: pointer;
    border: 0;
    background: none;
    transition: .2s;
    letter-spacing: 3px;
    width: 50px;
	    z-index: 11111111111111111111;
}

button.page-top span:before {
    position: absolute;
    top: -24px;
    left: 20px;
    transform: rotate(-45deg);
    display: block;
    width: 20px;
    height: 20px;
    content: "";
    border: 1px solid #fff;
    border-top-width: 1px;
    border-right-width: 1px;
    border-bottom-width: 1px;
    border-left-width: 1px;
    border-width: 2px 2px 0px 0px;
    z-index: 10;
}

button.page-top span:after {
    position: absolute;
    width: 50px;
    height: 50px;
    border: 1px solid #fff;
    content: "";
    border-radius: 100%;
    top: -43px;
    left: 5px;
    background: #373332;
}
.is-active {
    opacity: 1;
    visibility: visible;
}

/* ========== アニメーション ========== */
/* 初期状態 */
.fade-in,
.fade-in-up,
.fade-in-left,
.fade-in-right {
  opacity: 0;
  transition: opacity 0.6s, transform 0.6s;
}
.fade-in.is-visible,
.fade-in-up.is-visible,
.fade-in-left.is-visible,
.fade-in-right.is-visible {
  opacity: 1;
}

/* 下から上 */
.fade-in-up {
  transform: translateY(20px);
}
.fade-in-up.is-visible {
  transform: translateY(0);
}

/* 左から右 */
.fade-in-left {
  transform: translateX(-100px);
}
.fade-in-left.is-visible {
  transform: translateX(0);
}

/* 右から左 */
.fade-in-right {
  transform: translateX(100px);
}
.fade-in-right.is-visible {
  transform: translateX(0);
}


.gb-element-77aab70d {
    column-gap: 20px;
    display: grid
;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 32px;
    row-gap: 20px;
}
.fade-in.is-visible, .fade-in-up.is-visible, .fade-in-left.is-visible, .fade-in-right.is-visible {
    opacity: 1;
}
.fade-in-up.is-visible {
    transform: translateY(0);
}
.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}
.main-section, .site-body, .site-body-container, .site-footer, .sub-section {
    position: relative;
}
.alignfull, .alignfull:is(.swiper-container,.vk_slider,.wp-block-image,.wp-block-cover-image,.wp-block-cover) {
    width: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: 100vw;
}
@media screen and (max-width: 600px) {
	button.page-top{
    bottom: 160px;
}
}