/* 251129 作成ファイル */
/* ------------

  max-width: 1023px

-----------------*/
@media screen and (max-width: 1023px) {
  .header__logo a {
    font-size: 24px;
  }

  .pc-only--tablet-none {
    display: none;
  }

  .sp-only--tablet {
    display: block;
  }

  
  /* SPメニュー本体（初期は非表示） */
  .header__sp-nav {
    display: block;
    position: fixed;
    top: 0;
    right: -100%;
    width: 70%;
    height: 100vh;
    transition: right .3s ease;
    padding: 100px 20px;
    z-index: 999;
    color: #fff;
    background: linear-gradient(90deg, #6A47BB 0%, #964497 100%);
    overflow-y: scroll;
  }

  /* 開いた状態 */
  .header__sp-nav.is-open {
    right: 0;
  }

  /* ハンバーガー本体 */
  .hamburger {
    width: 30px;
    height: 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
    z-index: 1000;
    position: relative;
  }

  .hamburger__line {
    display: block;
    width: 100%;
    height: 3px;
    background: #fff;
    transition: all .3s ease;
  }

  /* 開いたときのアニメーション（×に変形） */
  .hamburger.is-open .hamburger__line:nth-child(1) {
    transform: translateY(11px) rotate(45deg);
  }
  .hamburger.is-open .hamburger__line:nth-child(2) {
    opacity: 0;
  }
  .hamburger.is-open .hamburger__line:nth-child(3) {
    transform: translateY(-10px) rotate(-45deg);
  }

  /* SPメニューのリンク見た目 */
  .header__sp-nav {
    display: flex;
    align-items: flex-start; 
    justify-content: center;
    padding: 80px 24px;
    height: 100vh;
  }

  .sp-nav__items {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
  }

  .sp-nav__item a {
    font-size: 16px;
    text-decoration: none;
    cursor: pointer;
    color: #fff;
    white-space: nowrap;
  }

  /* ------------
  top about 1023px
-----------------*/

  .btn-group {
    display: flex;
    flex-direction: column;
    row-gap: 14px;
    align-items: center;
  }

  .btn.btn-border-d.btn-circle {
    width: 60%;
    border-radius: 30px;
  }

  .text-center .btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle) {
    border-top-right-radius: 30px;
    border-bottom-right-radius: 30px;
  }

  .text-center .btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
    border-radius: 30px;
  }

  .text-center .btn-group>.btn:last-child:not(:first-child) {
    border-top-left-radius: 30px;
    border-bottom-left-radius: 30px;
  }
  
  .free-trial__flex-items {
    grid-template-columns: repeat(1, 1fr);
    padding-inline: 0;
    
  }

  .free-trial__flex-item {
    padding-top: 80px;
    width: 90%;
    margin-inline: auto;
  }

  .free-trial__tag {
    font-size: 20px;
    padding: 4px 80px;
    width: 80%;
    left: -24%;
  }

  /* ------------
   データ入力代行のお問い合わせページ 1023pxまで
  -----------------*/
  .sub-data-entry-support__flow-section,
  .sub-data-entry-support__flow-section {
    width: 90%;
    padding-inline: 0;
  }

  .sub-square-heading {
    width: 90%;
  }

  .data-entry-support__flow-items {
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-left: 30px;

  }


}


/* ------------

  max-width: 768px

-----------------*/
@media screen and (max-width: 768px) {
  .tablet-br {
    display: block;
  }  


  /* ------------
    コンタクトフォーム 768pxまで
  -----------------*/
    .top-contact__heading {
      padding: 40px 0;
    }

  /* ------------
  footer 768pxまで
  -----------------*/

  /* ------------
   　　ハンバーガー768px以下
    -----------------*/

  .header__logo a {
    font-size: 20px;
  }


  /* ------------
  subpage　共通事項
-----------------*/
  .sub-page-container {
    padding-top: 100px;
    padding-bottom: 80px;
  }

  .sub-page-title {
    font-size: 32px;
  }

  .sub-page-section {
    padding-top: 40px;
  }

  .sub-page-section__section {
    padding-top: 14px;
  }

  .sub-page-section__section h3 {
    font-size: 22px;
  }

   /* ------------
   トップページレイアウト修正 768pxまで
  -----------------*/
  .top-nikkan-feature-img-wrap {
    max-width: 400px;
    width: 100%;
    margin-inline: auto;
  }


   /* ------------
    top-アニメーションまわり　786pxまで
    -----------------*/
    .top-fv .titan-title-size-4{
      margin-top: 100px;
      padding-left: 24px;
    }

  /* ------------
   データ入力代行のお問い合わせページ 768pxまで
    -----------------*/
    .sub-data-entry-support__flow-section {
        width: 80%;
    }

    .sub-square-heading {
      font-size: 20px;
      padding: 50px 0;
      width: 75%;
    }

    .data-entry-support__flow {
      margin: 76px 24px 0;
    }

    .data-entry-support__flow-items {
      margin-left: 80px;
    }

    .data-entry-support__flow-items li p {
      font-size: 14px;
    }

    .data-entry-support__flow-items li:not(:first-child) {
      padding-left: 96px;
    }

    .data-entry-support__flow-items li:not(:first-child)::before {
      width: 40px;
    }

    /* ここからフォーム */
    .sub-data-entry-support__questionnaire-section {
      padding-inline: 0;
    }

    .des-wrap {
      width: 90%;
    }

    .des-q {
      flex-direction: column;
    }

    .sub-data-entry-support__flow-section {
      width: 100%;
  }

  .des-q__text {
    width: 100%;
  }

  .des-q__right {
    margin-top: 14px;
    margin-left: 34px;
  }
  
}
  

/* ------------

 　max-width: 425px

-----------------*/
@media screen and (max-width: 425px) {
   .sp-br {
    display: block;
   }

   .sp-only {
    display: block;
   }

  /* ------------
  フリートライアル 425pxまで
    -----------------*/
    .free-trial__tag {
      left: -20%;
      width: 100%;
    }
  
  /* ------------
  コンタクトフォーム 425pxまで
    -----------------*/
    .top-contact {
      padding-top: 40px;
      padding-bottom: 40px;
    }

    .top-contact__heading {
      padding: 24px 0;
      font-size: 18px;
    }

  /* ------------
    thanksページ
  -----------------*/
  .thanks__container {
    padding-top: 80px;
    padding-bottom: 80px;
    padding-inline: 15px;
  }

      /* ------------
    footer 425pxまで
    -----------------*/
    .footer {
      text-align: left;
    }

    .footer__flex {
      flex-direction: column;
      padding: 40px 0 80px;
    }
    .footer__flex-right,
    .footer__flex-left {
      width: 100%;
    }

    .footer__heading {
      text-align: left;
    }

    .footer__info p {
      text-align: left;
    }

    .footer__nav-items {
      flex-direction: column;
    }

    

   /* ------------
    top-fv 425pxまで
    -----------------*/
    .top-fv__font-large {
      font-size: 32px;
    }

    /* ------------
      subpage　共通事項
    -----------------*/
    .sub-page-container {
      padding-top: 60px;
    }

    .sub-page-section__section-content {
      margin-left: 0;
      margin-top: 24px;
    }

    .sub-page-section__section h3 {
      font-size: 18px;
    }
  
      /* ------------
      subpage　プライバシーポリシー
    -----------------*/
    .privacy-policy__handling h2 {
      font-size: 24px;
    }

    .privacy-policy__intro ul {
      padding-left: 28px;
    }
      /* ------------
      subpage　利用規約　terms-of-service
    -----------------*/
    .terms-of-service__block .sub-page-section__list {
      padding-left: 28px;
    }

    /* ------------
      subpage　特定商取引法に基づく表示 legal-notice
    -----------------*/
    .legal-notice__dl-wrap dl {
      flex-wrap: wrap;
    } 

    .legal-notice__dl-wrap dl dt,
    .legal-notice__dl-wrap dl dd {
      width: 100%
    }

    .legal-notice__dl-wrap dl dd {
      margin-top: 4px;
      margin-left: 0;
    }

    /* ------------
      topページ 425paまでレイアウト修正
    -----------------*/
    .top-nikkan-feature-img {
      width: 100%;
    }

    .top-about div.large-text {
      font-size: 18px;
    }

    /* ------------
      topアニメーション 425pxまで
    -----------------*/
    .top-nikkan-feature-img-wrap {
      min-width: 280px;
      margin-top: -234px;
    }

     /* ------------
      データ入力代行のお問い合わせページ 425pxまで
    -----------------*/
    .des-wrap {
      padding: 0;
    }

    .sub-square-heading {
      font-size: 18px;
      padding: 30px 0;
      width: 90%;
    }

    .sub-square-heading.sub-square-heading--purple-bg br {
      display: block;
      padding-left: 0;
    }
    

    .data-entry-support__flow-items {
      margin-left: 0;
    }

    .data-entry-support__flow-items li .data-entry-flow-icon-wrap {
      width: 60px;
    }

    .data-entry-support__flow-items li:not(:first-child)::before {
      width: 32px;
    }

    .data-entry-support__flow-items li p {
      font-size: 12px;
      line-height: 1.15;
      justify-content: space-between;
    }

    .data-entry-support__flow-items li p br {
      display: block;
    }

    .des-radio input {
      width: 24px;
      height: 24px;
    }

    .data-entry-support__flow-text {
      padding-inline: 15px;
    }

    .des-q__right {
      width: 50%;
    }


  }

  /* ------------

 　max-width: 375px

-----------------*/
@media screen and (max-width: 425px) {
  .data-entry-support__flow-items li:not(:first-child) {
    padding-left: 68px;
  }
}
