@charset "UTF-8";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  margin: 0;
  padding: 0; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: none; }

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

button {
  padding: 0;
  margin: 0;
  border: none; }

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden; }

.clearfix {
  display: inline-block; }

/* Hides from IE Mac */
* html .clearfix {
  height: 1%; }

.clearfix {
  display: block; }

/* ---------- 初期 ---------- */
body {
  letter-spacing: 0.01em;
  font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  -webkit-text-size-adjust: 100%; }

img {
  width: 100%;
  max-width: 100%;
  height: auto;
  pointer-events: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-touch-callout: none;
  -moz-user-select: none;
  user-select: none; }

a {
  text-decoration: none; }

strong {
  font-weight: bold; }

/* ---------- /共通部分 ---------- */
#jougetyuou {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  margin: auto; }

#kadomaru {
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px; }

#resbtn {
  -webkit-appearance: none; }

.ancr {
  position: relative;
  transition: 0.5s; }

.anca {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 10;
  cursor: pointer; }

.ancr:hover {
  opacity: 0.75;
  transition: 0.5s;
  cursor: pointer; }

/* ---------- /参考タグ部分 ---------- */
.wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

/*フォント*/
.font_zenkaku {
  font-family: "Zen Kaku Gothic New", sans-serif; }

.notosans {
  font-family: "Noto Sans JP", sans-serif; }

button {
  cursor: pointer; }

@keyframes infinity-scroll-left {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-100%); } }
/* PC */
@media screen and (min-width: 840px) {
  .sponly {
    display: none !important; }

  body {
    background: #000; }

  header {
    width: 75%;
    background: #000;
    position: fixed;
    left: 0;
    top: 0;
    border-radius: 15px;
    z-index: 10; }
    header .header_inner {
      width: 95%;
      max-width: 1826px;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      header .header_inner .logo {
        width: 191px; }
      header .header_inner .header_btn {
        width: 400px;
        display: flex;
        justify-content: space-between; }
        header .header_inner .header_btn a {
          display: block;
          width: 193px;
          font-size: 15px;
          letter-spacing: 0.03em;
          line-height: 1.5em;
          font-weight: 600;
          color: #fff;
          text-align: center;
          padding: 8px 0;
          border-radius: 5px;
          border: solid 2px #fff; }

  .content {
    width: 100%;
    max-width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    height: auto;
    position: relative; }
    .content .content_inner {
      width: 75%;
      max-width: 75%;
      width: 100%;
      margin-top: 0;
      position: relative;
      /*display: flex;
      justify-content: center;
      align-items: flex-start;
      flex-direction: column;*/ }
      .content .content_inner.content_inner::-webkit-scrollbar {
        display: none; }

  #mv {
    width: 100%;
    max-width: 100%;
    position: relative;
    padding-top: 81px; }
    #mv .mv_img {
      width: 100%; }
    #mv .mv_box {
      width: 100%;
      height: 89.24%;
      position: absolute;
      top: 0;
      left: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: center; }
      #mv .mv_box .mv_btn {
        width: 43.75%;
        max-width: 43.75%;
        display: flex;
        justify-content: space-between; }
        #mv .mv_box .mv_btn .btn.dl {
          width: 52%; }
        #mv .mv_box .mv_btn .btn.contact {
          width: 42.85%; }
        #mv .mv_box .mv_btn .btn a {
          display: block;
          width: 100%; }
          #mv .mv_box .mv_btn .btn a img {
            filter: drop-shadow(8px 8px 0 #0BA4B4);
            transition: 0.3s; }
          #mv .mv_box .mv_btn .btn a:hover img {
            filter: none;
            transform: translate(8px, 8px); }

  #intro {
    width: 100%;
    max-width: 100%;
    padding: 50px 0;
    background: #fff; }
    #intro .intro_scroll {
      width: 100%;
      display: flex;
      justify-content: space-between;
      overflow: hidden; }
      #intro .intro_scroll .intro_logo {
        flex-shrink: 0;
        display: flex;
        justify-content: space-between;
        animation: infinity-scroll-left 70s infinite linear 0.5s both; }
        #intro .intro_scroll .intro_logo img {
          width: auto;
          height: 5.2vw;
          margin: 0 40px; }
      #intro .intro_scroll:nth-of-type(2) {
        margin-top: 13px; }
        #intro .intro_scroll:nth-of-type(2) .intro_logo {
          flex-shrink: 0;
          display: flex;
          justify-content: space-between;
          animation: infinity-scroll-left 74.8s infinite linear 0.5s both; }

  #worry {
    width: 100%; }
    #worry .inner {
      width: 95%;
      max-width: 1080px;
      margin: 100px auto 150px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #worry .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 55px; }
        #worry .inner .sec_ttl h2 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 15px; }
        #worry .inner .sec_ttl .line {
          width: 100%;
          height: 8px;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #worry .inner .worry_cont {
        width: 100%;
        text-align: center;
        border-radius: 20px;
        background: #fff;
        position: relative; }
        #worry .inner .worry_cont .worry_boxes {
          max-width: 1000px;
          margin: 0 auto;
          display: flex;
          justify-content: space-between; }
          #worry .inner .worry_cont .worry_boxes .worry_box {
            width: 31.8%;
            box-sizing: border-box;
            padding: 0 5px; }
            #worry .inner .worry_cont .worry_boxes .worry_box .worry_box_img {
              margin: 0 auto 20px; }
        #worry .inner .worry_cont.cont01 {
          padding: 70px 0;
          margin-bottom: 85px; }
          #worry .inner .worry_cont.cont01::before {
            position: absolute;
            content: "";
            width: 35.555%;
            height: 51px;
            bottom: -49px;
            left: 50%;
            transform: translateX(-50%);
            background: url("../img/studio/worry_cont_arrow.png") no-repeat center top;
            background-size: contain; }
          #worry .inner .worry_cont.cont01 .worry_box .worry_box_img {
            width: 57.23%; }
          #worry .inner .worry_cont.cont01 .worry_box .worry_box_txt {
            font-size: 27px;
            line-height: 1.57em;
            font-weight: 900; }
            #worry .inner .worry_cont.cont01 .worry_box .worry_box_txt .small {
              display: inline-block;
              font-size: 20px;
              line-height: 1.7em; }
        #worry .inner .worry_cont.cont02 {
          padding: 55px 0 97px;
          margin-bottom: 85px; }
          #worry .inner .worry_cont.cont02 h3 {
            font-size: 45px;
            letter-spacing: 0.02em;
            line-height: 1.4em;
            font-weight: 500;
            margin-bottom: 45px; }
          #worry .inner .worry_cont.cont02 .worry_box .worry_box_img {
            width: 79.874%; }
          #worry .inner .worry_cont.cont02 .worry_box .worry_box_txt {
            font-size: 20px;
            line-height: 1.8em;
            font-weight: bold; }
            #worry .inner .worry_cont.cont02 .worry_box .worry_box_txt span {
              text-decoration: underline #FFFF01 5px;
              text-underline-offset: -1px; }
      #worry .inner .point {
        box-sizing: border-box;
        padding: 55px 0;
        background: #B2ECF3;
        border-radius: 20px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center; }
        #worry .inner .point h3 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          margin-bottom: 47px; }
          #worry .inner .point h3 span {
            font-size: 48px; }
        #worry .inner .point .point_box {
          width: 92.592%;
          margin: 0 auto; }
          #worry .inner .point .point_box .num {
            line-height: 0; }
          #worry .inner .point .point_box .bg {
            box-sizing: border-box;
            background: #fff;
            border-radius: 20px;
            display: flex;
            justify-content: space-between;
            align-items: center; }
            #worry .inner .point .point_box .bg .point_box_right {
              text-align: left; }
              #worry .inner .point .point_box .bg .point_box_right h4 {
                font-size: 40px;
                letter-spacing: 0.02em;
                line-height: 1.4em;
                font-weight: 500;
                background: linear-gradient(90deg, #00CADF, #0C7680);
                -webkit-background-clip: text;
                -webkit-text-fill-color: transparent;
                margin-bottom: 20px; }
              #worry .inner .point .point_box .bg .point_box_right .point_box_txt {
                font-size: 16px;
                letter-spacing: 0;
                line-height: 1.8em;
                font-weight: bold; }
                #worry .inner .point .point_box .bg .point_box_right .point_box_txt span {
                  color: #007A87;
                  border-bottom: solid 3px #007A87; }
              #worry .inner .point .point_box .bg .point_box_right .point_box_btn {
                width: 265px;
                margin-top: 19px; }
                #worry .inner .point .point_box .bg .point_box_right .point_box_btn a {
                  display: block;
                  width: 100%; }
          #worry .inner .point .point_box.point01 {
            margin-bottom: 32px; }
            #worry .inner .point .point_box.point01 .num {
              box-sizing: border-box;
              padding-left: 18px;
              text-align: left; }
              #worry .inner .point .point_box.point01 .num img {
                width: 241px; }
            #worry .inner .point .point_box.point01 .bg {
              /*width: 930px;*/
              padding: 44px 35px; }
              #worry .inner .point .point_box.point01 .bg .point_box_img {
                width: 33.548%; }
              #worry .inner .point .point_box.point01 .bg .point_box_right {
                width: 60.637%; }
          #worry .inner .point .point_box.point02 {
            margin-bottom: 32px; }
            #worry .inner .point .point_box.point02 .num {
              box-sizing: border-box;
              padding-right: 18px;
              text-align: right; }
              #worry .inner .point .point_box.point02 .num img {
                width: 255px; }
            #worry .inner .point .point_box.point02 .bg {
              /*width: 920px;*/
              padding: 44px 40px;
              flex-direction: row-reverse; }
              #worry .inner .point .point_box.point02 .bg .point_box_img {
                width: 33.913%; }
              #worry .inner .point .point_box.point02 .bg .point_box_right {
                width: 62.5%; }
          #worry .inner .point .point_box.point03 .num {
            box-sizing: border-box;
            padding-left: 18px;
            text-align: left; }
            #worry .inner .point .point_box.point03 .num img {
              width: 259px; }
          #worry .inner .point .point_box.point03 .bg {
            /*width: 938px;*/
            padding: 44px 31px; }
            #worry .inner .point .point_box.point03 .bg .point_box_img {
              width: 33.262%; }
            #worry .inner .point .point_box.point03 .bg .point_box_right {
              width: 61.3%; }
              #worry .inner .point .point_box.point03 .bg .point_box_right .point_box_txt {
                width: 98%; }
      #worry .inner .dl_btn {
        width: 464px;
        margin: 55px auto 0; }
        #worry .inner .dl_btn a {
          display: block;
          width: 100%;
          transition: 0.3s; }
          #worry .inner .dl_btn a:hover {
            filter: brightness(1.2); } }
@media screen and (min-width: 840px) and (max-width: 1140px) {
  #worry .inner h2 {
    font-size: 45px !important; }
  #worry .inner h3 {
    font-size: 45px !important; }
    #worry .inner h3 span {
      font-size: 35px !important; }
  #worry .inner h4 {
    font-size: 28px !important; } }
@media screen and (min-width: 840px) {
  /*問い合わせ系のモーダル*/
  .modal03 {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
    z-index: 11; }
    .modal03 .modal-bg {
      position: absolute;
      height: 100vh;
      width: 100%;
      background: rgba(0, 0, 0, 0.4); }
    .modal03 .modal-content {
      width: 100%;
      height: 100%;
      display: flex;
      justify-content: center;
      flex-direction: column;
      align-items: center; }
      .modal03 .modal-content .modal_inner {
        width: 900px;
        max-width: 100%;
        height: 95vh;
        box-sizing: border-box;
        padding: 39px 0 80px;
        background: #fff;
        border-radius: 20px;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        flex-direction: column;
        position: relative;
        z-index: 12;
        overflow: scroll; }
        .modal03 .modal-content .modal_inner .btn {
          width: 100%;
          max-width: 100%;
          height: 25px;
          margin-bottom: 20px;
          display: flex;
          justify-content: flex-end;
          box-sizing: border-box;
          padding-right: 43px; }
          .modal03 .modal-content .modal_inner .btn button {
            color: #333;
            font-size: 25px;
            background: transparent;
            padding: 0;
            margin: 0;
            border: none; }
        .modal03 .modal-content .modal_inner h5 {
          font-size: 43px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          background: linear-gradient(90deg, #00CADF, #0C7680);
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent;
          margin-bottom: 60px; }
          .modal03 .modal-content .modal_inner h5 span {
            font-size: 34px; }
        .modal03 .modal-content .modal_inner .modal_box_01 {
          max-width: 95%;
          max-width: 766px;
          margin: 0 auto 60px;
          display: flex;
          justify-content: space-between;
          align-items: center;
          flex-direction: row-reverse; }
          .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_img {
            width: 48.17%; }
          .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right {
            width: 49.347%; }
            .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p {
              font-size: 14px;
              line-height: 2em;
              font-weight: bold; }
              .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p:nth-of-type(2) {
                margin: 15px 0; }
              .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p.small {
                font-size: 10px;
                line-height: 1.8em; }
        .modal03 .modal-content .modal_inner .modal_box_02 {
          max-width: 95%;
          max-width: 766px;
          margin: 0 auto 60px;
          display: flex;
          justify-content: space-between;
          align-items: center; }
          .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_img {
            width: 26.631%; }
          .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_right {
            width: 66.579%; }
            .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_right h6 {
              font-size: 30px;
              line-height: 1.4em;
              font-weight: 500;
              background: linear-gradient(90deg, #00CADF, #0C7680);
              -webkit-background-clip: text;
              -webkit-text-fill-color: transparent;
              margin-bottom: 7px; }
            .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_right p {
              font-size: 14px;
              line-height: 2em;
              font-weight: bold; }
        .modal03 .modal-content .modal_inner .modal_box_03 {
          max-width: 95%;
          max-width: 766px;
          margin: 0 auto 60px; }
        .modal03 .modal-content .modal_inner .modal_close_btn {
          width: 112px;
          margin: 0 auto;
          text-align: center;
          cursor: pointer; }
          .modal03 .modal-content .modal_inner .modal_close_btn div {
            font-size: 16px;
            letter-spacing: 0.03em;
            line-height: 1.5en;
            font-weight: bold;
            padding: 9px 0;
            border-radius: 5px;
            border: solid 2px #000; }

  #studio {
    width: 100%; }
    #studio .inner {
      width: 95%;
      max-width: 1000px;
      margin: 0 auto 150px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #studio .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 70px; }
        #studio .inner .sec_ttl h2 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 15px; }
        #studio .inner .sec_ttl .line {
          width: 100%;
          height: 8px;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #studio .inner .stuido_img_01 {
        width: 100%;
        padding-top: 56.2%;
        position: relative;
        margin-bottom: 70px; }
        #studio .inner .stuido_img_01 iframe {
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0; }
      #studio .inner .studio_box {
        padding: 40px 0;
        background: #fff;
        border-radius: 20px; }
        #studio .inner .studio_box h3 {
          font-size: 38px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          margin-bottom: 40px;
          background: linear-gradient(90deg, #00CADF, #0C7680);
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent;
          padding: 0 10px; }
        #studio .inner .studio_box .studio_box_img {
          width: 90%;
          margin: 0 auto 40px; }
        #studio .inner .studio_box .studio_box_txt {
          width: 80%;
          margin: 0 auto;
          font-size: 16px;
          letter-spacing: 0;
          line-height: 1.8em;
          font-weight: bold;
          text-align: center; }
      #studio .inner .hukidashi {
        width: 540px;
        margin: 105px auto 7px; }
      #studio .inner .dl_btn {
        width: 436px;
        margin: 0 auto 0; }
        #studio .inner .dl_btn a {
          display: block;
          width: 100%;
          transition: 0.3s; }
          #studio .inner .dl_btn a:hover {
            filter: brightness(1.2); } }
@media screen and (min-width: 840px) and (max-width: 1140px) {
  #studio h2 {
    font-size: 45px !important; }
  #studio h3 {
    font-size: 30px !important; } }
@media screen and (min-width: 840px) {
  #example {
    width: 100%;
    overflow: hidden; }
    #example .inner {
      width: 100%;
      margin: 0 auto 150px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #example .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 55px; }
        #example .inner .sec_ttl h2 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 15px; }
        #example .inner .sec_ttl .line {
          width: 100%;
          height: 8px;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #example .inner .example_slider {
        width: 100%; }
        #example .inner .example_slider .example_slider_box {
          margin: 0 22px; } }
@media screen and (min-width: 840px) and (max-width: 1140px) {
  #example h2 {
    font-size: 45px !important; } }
@media screen and (min-width: 840px) {
  #flow {
    width: 100%; }
    #flow .inner {
      width: 95%;
      max-width: 1205px;
      margin: 0 auto 150px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #flow .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 70px; }
        #flow .inner .sec_ttl h2 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 15px; }
        #flow .inner .sec_ttl .line {
          width: 100%;
          height: 8px;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #flow .inner .flow_img {
        width: 100%; } }
@media screen and (min-width: 840px) and (max-width: 1140px) {
  #flow h2 {
    font-size: 45px !important; } }
@media screen and (min-width: 840px) {
  #faq {
    width: 100%; }
    #faq .inner {
      width: 95%;
      max-width: 1000px;
      margin: 0 auto 150px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #faq .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 70px; }
        #faq .inner .sec_ttl h2 {
          font-size: 58px;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 15px; }
        #faq .inner .sec_ttl .line {
          width: 100%;
          height: 8px;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #faq .inner .faq_boxes {
        width: 100%;
        border-top: solid 2px #14E3F9; }
        #faq .inner .faq_boxes .faq_box {
          width: 100%;
          border-bottom: solid 2px #14E3F9; }
          #faq .inner .faq_boxes .faq_box button {
            width: 100%;
            border: none;
            background: none;
            box-sizing: border-box;
            padding: 20px 0;
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: relative; }
            #faq .inner .faq_boxes .faq_box button::before {
              position: absolute;
              content: "";
              width: 18px;
              height: 4px;
              right: 5px;
              top: 50%;
              transform: translateY(-50%);
              background: #fff; }
            #faq .inner .faq_boxes .faq_box button::after {
              position: absolute;
              content: "";
              width: 18px;
              height: 4px;
              right: 5px;
              top: 50%;
              transform: translateY(-50%) rotate(-90deg);
              background: #fff;
              transition: 0.3s; }
            #faq .inner .faq_boxes .faq_box button.open::after {
              transform: translateY(-50%) rotate(0); }
            #faq .inner .faq_boxes .faq_box button div {
              width: calc( 100% - 75px );
              display: flex;
              justify-content: space-between;
              align-items: center; }
              #faq .inner .faq_boxes .faq_box button div .icon {
                width: 30px;
                margin-right: 16px; }
              #faq .inner .faq_boxes .faq_box button div p {
                flex: 1;
                font-size: 18px;
                letter-spacing: 0.05em;
                line-height: 1.5em;
                font-weight: 900;
                color: #fff;
                text-align: left; }
            #faq .inner .faq_boxes .faq_box button i {
              font-size: 35px;
              margin-left: 40px;
              color: #fff; }
          #faq .inner .faq_boxes .faq_box .a_cont {
            display: none;
            box-sizing: border-box;
            padding: 0 0 25px; }
            #faq .inner .faq_boxes .faq_box .a_cont .a_box {
              display: flex;
              justify-content: space-between;
              align-items: center; }
              #faq .inner .faq_boxes .faq_box .a_cont .a_box .icon {
                width: 30px;
                margin-right: 16px; }
              #faq .inner .faq_boxes .faq_box .a_cont .a_box .a_txt {
                flex: 1;
                font-size: 18px;
                letter-spacing: 0.05em;
                line-height: 1.6em;
                font-weight: 600;
                color: #fff; } }
@media screen and (min-width: 840px) and (max-width: 1140px) {
  #faq h2 {
    font-size: 45px !important; } }
@media screen and (min-width: 840px) {
  /*問い合わせ系のモーダル*/
  .modal02 {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
    z-index: 11; }
    .modal02 .modal-bg {
      position: absolute;
      height: 100vh;
      width: 100%;
      background: rgba(0, 0, 0, 0.4); }
    .modal02 .modal-content {
      width: 100%;
      height: 100%;
      display: flex;
      justify-content: center;
      flex-direction: column;
      align-items: center; }
      .modal02 .modal-content .modal_inner {
        width: 560px;
        max-width: 100%;
        height: 90vh;
        box-sizing: border-box;
        padding: 24px;
        background: #fff;
        border-radius: 16px;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        flex-direction: column;
        position: relative;
        z-index: 12;
        box-shadow: 0px 6px 15px rgba(0, 0, 0, 0.2); }
        .modal02 .modal-content .modal_inner .btn {
          width: 100%;
          max-width: 100%;
          height: 20px;
          display: flex;
          justify-content: flex-start;
          align-items: flex-end;
          flex-direction: column; }
          .modal02 .modal-content .modal_inner .btn button {
            color: #333;
            font-size: 24px;
            background: transparent;
            padding: 0;
            margin: 0;
            border: none; }
        .modal02 .modal-content .modal_inner h1 {
          font-size: 20px;
          letter-spacing: 0;
          line-height: 1.4em;
          font-weight: 600;
          color: #333;
          padding-bottom: 16px;
          text-align: center; }
        .modal02 .modal-content .modal_inner .modal_form {
          width: 541px;
          max-width: 100%;
          height: 88%; }
          .modal02 .modal-content .modal_inner .modal_form iframe {
            width: 100%;
            height: 100%; }
    .modal02.contact {
      width: 100%; }
      .modal02.contact .modal-content .modal_inner {
        width: auto; }
        .modal02.contact .modal-content .modal_inner h1 {
          padding-bottom: 8px; }
        .modal02.contact .modal-content .modal_inner .modal_form {
          height: 100%; }
    .modal02.dl {
      width: 100%; }
      .modal02.dl .modal-content .modal_inner {
        /*margin-top: 80px;*/
        height: 90vh; }
        .modal02.dl .modal-content .modal_inner .modal_form {
          /*height: 88%;*/
          flex: 1; }

  footer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding-bottom: 15px; }
    footer .footer_line {
      max-width: 1714px;
      width: 98%;
      margin: 0 auto;
      height: 2px;
      background: #12E3F9; }
    footer .footer_inner {
      width: 98%;
      max-width: 1000px;
      margin: 0 auto 39px;
      padding: 60px 0px 0;
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 40px; }
      footer .footer_inner .footer_left {
        width: auto;
        max-width: 100%; }
        footer .footer_inner .footer_left .footer_logo {
          width: 143px;
          margin-bottom: 33px; }
        footer .footer_inner .footer_left .footer_menu {
          width: auto;
          display: flex;
          justify-content: flex-start; }
          footer .footer_inner .footer_left .footer_menu dl {
            width: auto;
            max-width: calc(100% - 58px);
            margin-right: 58px; }
            footer .footer_inner .footer_left .footer_menu dl dt {
              font-size: 15px;
              letter-spacing: 0.03em;
              line-height: 1.4em;
              font-weight: bold;
              color: #fff; }
            footer .footer_inner .footer_left .footer_menu dl dd {
              font-size: 13px;
              letter-spacing: 0.03em;
              line-height: 1.4em;
              font-weight: 500;
              margin-top: 13px; }
              footer .footer_inner .footer_left .footer_menu dl dd a {
                color: #fff; }
      footer .footer_inner .footer_right {
        width: auto;
        max-width: 100%;
        padding-top: 20px; }
        footer .footer_inner .footer_right a {
          display: block;
          width: 231px;
          max-width: 100%;
          height: 44px;
          font-size: 16px;
          letter-spacing: 0.02em;
          line-height: 44px;
          font-weight: 900;
          color: #045A60;
          text-align: center;
          margin-bottom: 11px;
          cursor: pointer;
          transition: 0.3s; }
          footer .footer_inner .footer_right a:hover {
            filter: brightness(1.2); }
    footer .copyright {
      font-size: 12px;
      line-height: 2em;
      color: #fff;
      text-align: center; }

  /*side*/
  #side {
    width: 25%;
    max-width: 25%;
    height: 100vh;
    box-sizing: border-box;
    padding: 30px 16px 16px 16px;
    display: flex;
    justify-content: flex-start;
    align-content: center;
    align-items: center;
    flex-direction: column;
    background: #d7f2f7;
    left: auto;
    position: fixed;
    right: 0px;
    top: 0;
    transform-origin: center center;
    z-index: 2; }
    #side h1 {
      font-size: 20px;
      letter-spacing: 0;
      line-height: 1.3em;
      font-weight: 500;
      text-align: center;
      padding-bottom: 8px; }
    #side .side_form {
      width: 100%;
      max-width: 100%;
      height: auto;
      flex: 1;
      position: relative;
      z-index: 0; }
      #side .side_form iframe {
        width: 100%;
        height: 100%; }

  .float_btn {
    display: none !important; } }
/* SP */
@media screen and (max-width: 839px) {
  .pconly {
    display: none !important; }

  html {
    font-size: calc(1vw * 100 / 375); }

  body {
    background: #000; }

  .content {
    width: 100%;
    max-width: 100%;
    display: flex;
    align-items: flex-start;
    flex-direction: row;
    height: auto;
    justify-content: center; }
    .content .content_inner {
      width: 100%;
      max-width: 100%;
      margin-top: 0;
      position: relative;
      display: flex;
      align-items: center;
      flex-direction: column; }
      .content .content_inner.content_inner::-webkit-scrollbar {
        display: none; }

  header {
    width: 96%;
    height: auto;
    position: fixed;
    left: 50%;
    top: 9rem;
    transform: translateX(-50%);
    z-index: 10;
    background: #000000;
    border-radius: 5rem; }
    header .header_inner {
      width: 94.44%;
      padding: 3rem 0 2rem;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      header .header_inner .logo {
        width: 98rem; }
      header .header_inner .header_btn {
        width: 194rem;
        display: flex;
        justify-content: space-between; }
        header .header_inner .header_btn a {
          display: block;
          width: 94rem;
          font-size: 8rem;
          letter-spacing: 0.03em;
          line-height: 1.5em;
          font-weight: 600;
          color: #fff;
          box-sizing: border-box;
          padding: 7rem 0;
          text-align: center;
          border-radius: 3rem;
          border: solid 1rem #fff; }

  #mv {
    width: 100%;
    max-width: 100%;
    position: relative; }
    #mv .mv_img {
      width: 100%; }
    #mv .mv_box {
      width: 100%;
      height: 94.85%;
      position: absolute;
      top: 0;
      left: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: center; }
      #mv .mv_box .mv_btn {
        width: 65.6%;
        max-width: 65.6%;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        flex-direction: column; }
        #mv .mv_box .mv_btn .btn.dl {
          width: 100%;
          margin-bottom: 19rem; }
        #mv .mv_box .mv_btn .btn.contact {
          width: 84.163%; }
        #mv .mv_box .mv_btn .btn a {
          display: block;
          width: 100%; }
          #mv .mv_box .mv_btn .btn a img {
            filter: drop-shadow(5rem 5rem 0 #0BA4B4);
            transition: 0.3s; }
          #mv .mv_box .mv_btn .btn a:hover img {
            filter: none;
            transform: translate(8rem, 8rem); }

  #intro {
    width: 100%;
    max-width: 100%;
    padding: 40rem 0;
    background: #fff; }
    #intro .intro_scroll {
      width: 100%;
      display: flex;
      justify-content: space-between;
      overflow: hidden; }
      #intro .intro_scroll .intro_logo {
        flex-shrink: 0;
        display: flex;
        justify-content: space-between;
        animation: infinity-scroll-left 40s infinite linear 0.5s both; }
        #intro .intro_scroll .intro_logo img {
          width: auto;
          height: 45rem;
          margin: 0 18rem; }
      #intro .intro_scroll:nth-of-type(2) {
        margin: 13rem 0; }
        #intro .intro_scroll:nth-of-type(2) .intro_logo {
          flex-shrink: 0;
          display: flex;
          justify-content: space-between;
          animation: infinity-scroll-left 40s infinite linear 0.5s both; }
      #intro .intro_scroll:nth-of-type(3) .intro_logo {
        flex-shrink: 0;
        display: flex;
        justify-content: space-between;
        animation: infinity-scroll-left 40.3s infinite linear 0.5s both; }

  #worry {
    width: 100%; }
    #worry .inner {
      width: 93.333%;
      margin: 50rem auto 100rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #worry .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 10rem; }
        #worry .inner .sec_ttl:nth-of-type(3) {
          margin-bottom: 30rem; }
        #worry .inner .sec_ttl h2 {
          font-size: 27rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 7rem; }
        #worry .inner .sec_ttl .line {
          width: 100%;
          height: 4rem;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #worry .inner .worry_cont {
        width: 100%;
        text-align: center;
        border-radius: 20rem;
        background: #fff;
        position: relative; }
        #worry .inner .worry_cont .worry_boxes {
          max-width: 318rem;
          margin: 0 auto; }
          #worry .inner .worry_cont .worry_boxes .worry_box .worry_box_img {
            margin: 0 auto; }
        #worry .inner .worry_cont.cont01 {
          padding: 40rem 0;
          margin-bottom: 85rem; }
          #worry .inner .worry_cont.cont01::before {
            position: absolute;
            content: "";
            width: 330rem;
            height: 51rem;
            bottom: -49rem;
            left: 50%;
            transform: translateX(-50%);
            background: url("../img/studio/worry_cont_arrow.png") no-repeat center top;
            background-size: contain; }
          #worry .inner .worry_cont.cont01 .worry_box:nth-child(n+2) {
            margin-top: 22rem; }
          #worry .inner .worry_cont.cont01 .worry_box .worry_box_img {
            width: 182rem; }
          #worry .inner .worry_cont.cont01 .worry_box .worry_box_txt {
            font-size: 22rem;
            line-height: 1.57em;
            font-weight: 900; }
            #worry .inner .worry_cont.cont01 .worry_box .worry_box_txt .small {
              display: inline-block;
              font-size: 16rem;
              line-height: 1.7em; }
        #worry .inner .worry_cont.cont02 {
          padding: 55rem 0 40rem;
          margin-bottom: 85rem; }
          #worry .inner .worry_cont.cont02 h3 {
            font-size: 24rem;
            letter-spacing: 0.02em;
            line-height: 1.4em;
            font-weight: 500;
            margin-bottom: 28rem; }
          #worry .inner .worry_cont.cont02 .worry_box:nth-child(n+2) {
            margin-top: 26rem; }
          #worry .inner .worry_cont.cont02 .worry_box:nth-child(1) .worry_box_img {
            width: 182rem; }
          #worry .inner .worry_cont.cont02 .worry_box:nth-child(2) .worry_box_img {
            width: 254rem; }
          #worry .inner .worry_cont.cont02 .worry_box:nth-child(3) .worry_box_img {
            width: 178rem; }
          #worry .inner .worry_cont.cont02 .worry_box .worry_box_txt {
            font-size: 16rem;
            line-height: 1.8em;
            font-weight: bold; }
            #worry .inner .worry_cont.cont02 .worry_box .worry_box_txt span {
              text-decoration: underline #FFFF01 6rem;
              text-underline-offset: -1rem; }
      #worry .inner .point {
        box-sizing: border-box;
        padding: 55rem 0;
        background: #B2ECF3;
        border-radius: 20rem; }
        #worry .inner .point h3 {
          font-size: 34rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          margin-bottom: 30rem; }
          #worry .inner .point h3 span {
            font-size: 29rem;
            line-height: 1.4em; }
        #worry .inner .point .point_box {
          width: 94.285%;
          margin: 0 auto; }
          #worry .inner .point .point_box .num {
            line-height: 0; }
          #worry .inner .point .point_box .bg {
            box-sizing: border-box;
            background: #fff;
            border-radius: 20rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-direction: column;
            padding: 44rem 0; }
            #worry .inner .point .point_box .bg .point_box_img {
              width: 256rem;
              margin-bottom: 40rem; }
            #worry .inner .point .point_box .bg .point_box_right {
              text-align: left;
              width: 92.424%;
              width: 90.909%; }
              #worry .inner .point .point_box .bg .point_box_right h4 {
                font-size: 30rem;
                letter-spacing: 0.02em;
                line-height: 1.4em;
                font-weight: 500;
                background: linear-gradient(90deg, #00CADF, #0C7680);
                -webkit-background-clip: text;
                -webkit-text-fill-color: transparent;
                margin-bottom: 20px; }
              #worry .inner .point .point_box .bg .point_box_right .point_box_txt {
                width: 101.3333%;
                font-size: 16rem;
                letter-spacing: 0;
                line-height: 1.8em;
                font-weight: bold; }
                #worry .inner .point .point_box .bg .point_box_right .point_box_txt span {
                  color: #007A87;
                  border-bottom: solid 3rem #007A87; }
              #worry .inner .point .point_box .bg .point_box_right .point_box_btn {
                width: 265rem;
                margin-top: 20rem; }
                #worry .inner .point .point_box .bg .point_box_right .point_box_btn a {
                  display: block;
                  width: 100%; }
          #worry .inner .point .point_box.point01 {
            margin-bottom: 32rem; }
            #worry .inner .point .point_box.point01 .num {
              box-sizing: border-box;
              padding-left: 17rem;
              text-align: left; }
              #worry .inner .point .point_box.point01 .num img {
                width: 169rem; }
            #worry .inner .point .point_box.point01 .bg .point_box_img {
              width: 236rem; }
          #worry .inner .point .point_box.point02 {
            margin-bottom: 32rem; }
            #worry .inner .point .point_box.point02 .num {
              box-sizing: border-box;
              padding-left: 15rem; }
              #worry .inner .point .point_box.point02 .num img {
                width: 178rem; }
          #worry .inner .point .point_box.point03 .num {
            box-sizing: border-box;
            padding-left: 15rem;
            text-align: left; }
            #worry .inner .point .point_box.point03 .num img {
              width: 181rem; }
      #worry .inner .dl_btn {
        width: 278rem;
        margin: 30rem auto 0; }

  /*そもそもYOUTRUSTとはのモーダル*/
  .modal03 {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
    z-index: 11; }
    .modal03 .modal-bg {
      position: absolute;
      height: 100vh;
      width: 100%;
      background: rgba(0, 0, 0, 0.4); }
    .modal03 .modal-content {
      width: 100%;
      height: 100%;
      display: flex;
      justify-content: center;
      flex-direction: column;
      align-items: center; }
      .modal03 .modal-content .modal_inner {
        width: 365rem;
        max-width: 100%;
        height: 95vh;
        box-sizing: border-box;
        padding: 28rem 0 50rem;
        background: #fff;
        border-radius: 20rem;
        position: relative;
        z-index: 12;
        overflow: scroll; }
        .modal03 .modal-content .modal_inner .btn {
          width: 100%;
          max-width: 100%;
          height: 25rem;
          margin-bottom: 3rem;
          display: flex;
          justify-content: flex-end;
          box-sizing: border-box;
          padding-right: 27rem; }
          .modal03 .modal-content .modal_inner .btn button {
            color: #333;
            font-size: 25rem;
            background: transparent;
            padding: 0;
            margin: 0;
            border: none; }
        .modal03 .modal-content .modal_inner h5 {
          font-size: 21rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          background: linear-gradient(90deg, #00CADF, #0C7680);
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent;
          margin-bottom: 40rem; }
          .modal03 .modal-content .modal_inner h5 span {
            font-size: 17rem; }
        .modal03 .modal-content .modal_inner .modal_box_01 {
          width: 330rem;
          margin: 0 auto 40rem; }
          .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_img {
            width: 310rem;
            margin-bottom: 18rem; }
          .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p {
            font-size: 14rem;
            line-height: 2em;
            font-weight: bold; }
            .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p:nth-of-type(2) {
              margin: 15px 0; }
            .modal03 .modal-content .modal_inner .modal_box_01 .modal_box_right p.small {
              font-size: 10rem;
              line-height: 1.8em; }
        .modal03 .modal-content .modal_inner .modal_box_02 {
          width: 330rem;
          margin: 0 auto 40rem; }
          .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_img {
            width: 204rem;
            margin: 0 auto 51rem; }
          .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_right h6 {
            font-size: 18rem;
            line-height: 1.4em;
            font-weight: 500;
            background: linear-gradient(90deg, #00CADF, #0C7680);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            margin-bottom: 7rem; }
          .modal03 .modal-content .modal_inner .modal_box_02 .modal_box_right p {
            font-size: 14rem;
            line-height: 2em;
            font-weight: bold; }
        .modal03 .modal-content .modal_inner .modal_box_03 {
          width: 350rem;
          margin: 0 auto 40rem; }
        .modal03 .modal-content .modal_inner .modal_close_btn {
          width: 112rem;
          margin: 0 auto;
          text-align: center;
          cursor: pointer; }
          .modal03 .modal-content .modal_inner .modal_close_btn div {
            font-size: 16rem;
            letter-spacing: 0.03em;
            line-height: 1.5em;
            font-weight: 600;
            padding: 9rem 0;
            border-radius: 5rem;
            border: solid 2rem #000; }

  #studio {
    width: 100%; }
    #studio .inner {
      width: 93.333%;
      margin: 0 auto 100rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #studio .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 50rem; }
        #studio .inner .sec_ttl h2 {
          font-size: 29rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 8rem; }
        #studio .inner .sec_ttl .line {
          width: 100%;
          height: 4rem;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #studio .inner .stuido_img_01 {
        width: 100%;
        padding-top: 56.42%;
        position: relative;
        margin-bottom: 50rem; }
        #studio .inner .stuido_img_01 iframe {
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0; }
      #studio .inner .studio_box {
        padding: 40rem 0;
        background: #fff;
        border-radius: 20rem; }
        #studio .inner .studio_box h3 {
          font-size: 26rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          text-align: center;
          margin-bottom: 40rem;
          background: linear-gradient(90deg, #00CADF, #0C7680);
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent; }
        #studio .inner .studio_box .studio_box_img {
          width: 83.474%;
          margin: 0 auto 40rem; }
        #studio .inner .studio_box .studio_box_txt {
          font-size: 16rem;
          letter-spacing: 0;
          line-height: 1.8em;
          font-weight: bold;
          text-align: center; }
      #studio .inner .hukidashi {
        width: 324rem;
        margin: 70rem auto 4rem; }
      #studio .inner .dl_btn {
        width: 262rem;
        margin: 0 auto 0; }
        #studio .inner .dl_btn a {
          display: block;
          width: 100%; }

  #example {
    width: 100%;
    overflow: hidden; }
    #example .inner {
      width: 93.333%;
      margin: 0 auto 100rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #example .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 50rem; }
        #example .inner .sec_ttl h2 {
          font-size: 29rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 8rem; }
        #example .inner .sec_ttl .line {
          width: 100%;
          height: 4rem;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #example .inner .example_boxes {
        width: 100%; }
        #example .inner .example_boxes .example_slider_box:nth-child(n+2) {
          margin-top: 15rem; }

  #flow {
    width: 100%; }
    #flow .inner {
      width: 93.333%;
      margin: 0 auto 100rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #flow .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 50rem; }
        #flow .inner .sec_ttl h2 {
          font-size: 29rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 8rem; }
        #flow .inner .sec_ttl .line {
          width: 100%;
          height: 4rem;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #flow .inner .flow_img {
        width: 100%; }

  #faq {
    width: 100%; }
    #faq .inner {
      width: 93.333%;
      margin: 0 auto 100rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      #faq .inner .sec_ttl {
        display: inline-block;
        margin-bottom: 50rem; }
        #faq .inner .sec_ttl h2 {
          font-size: 29rem;
          letter-spacing: 0.02em;
          line-height: 1.4em;
          font-weight: 500;
          color: #fff;
          margin-bottom: 8rem; }
        #faq .inner .sec_ttl .line {
          width: 100%;
          height: 4rem;
          background: linear-gradient(to right, #0EE3F9, #CCECEF); }
      #faq .inner .faq_boxes {
        width: 100%;
        border-top: solid 2rem #14E3F9; }
        #faq .inner .faq_boxes .faq_box {
          width: 100%;
          border-bottom: solid 2rem #14E3F9; }
          #faq .inner .faq_boxes .faq_box button {
            width: 100%;
            border: none;
            background: none;
            box-sizing: border-box;
            padding: 20rem 0;
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: relative; }
            #faq .inner .faq_boxes .faq_box button::before {
              position: absolute;
              content: "";
              width: 18rem;
              height: 4rem;
              right: 2rem;
              top: 50%;
              transform: translateY(-50%);
              background: #fff; }
            #faq .inner .faq_boxes .faq_box button::after {
              position: absolute;
              content: "";
              width: 18rem;
              height: 4rem;
              right: 2rem;
              top: 50%;
              transform: translateY(-50%) rotate(-90deg);
              background: #fff;
              transition: 0.3s; }
            #faq .inner .faq_boxes .faq_box button.open::after {
              transform: translateY(-50%) rotate(0); }
            #faq .inner .faq_boxes .faq_box button div {
              width: calc( 100% - 51rem );
              display: flex;
              justify-content: space-between;
              align-items: center; }
              #faq .inner .faq_boxes .faq_box button div .icon {
                width: 30rem;
                margin-right: 16rem; }
              #faq .inner .faq_boxes .faq_box button div p {
                flex: 1;
                font-size: 16rem;
                letter-spacing: 0.05em;
                line-height: 1.5em;
                font-weight: 900;
                color: #fff;
                text-align: left; }
          #faq .inner .faq_boxes .faq_box .a_cont {
            display: none;
            box-sizing: border-box; }
            #faq .inner .faq_boxes .faq_box .a_cont .a_box {
              display: flex;
              justify-content: space-between;
              align-items: center;
              padding-bottom: 20rem; }
              #faq .inner .faq_boxes .faq_box .a_cont .a_box .icon {
                width: 30rem;
                margin-right: 16rem; }
              #faq .inner .faq_boxes .faq_box .a_cont .a_box .a_txt {
                flex: 1;
                font-size: 14rem;
                letter-spacing: 0.05em;
                line-height: 1.6em;
                font-weight: 600;
                color: #fff; }
                #faq .inner .faq_boxes .faq_box .a_cont .a_box .a_txt span {
                  display: inline-block;
                  color: #14e3f9;
                  text-decoration: underline; }

  /*問い合わせ系のモーダル*/
  .modal02 {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 11; }
    .modal02 .modal-bg {
      position: absolute;
      height: 100vh;
      width: 100%;
      background: rgba(0, 0, 0, 0.4); }
    .modal02 .modal-content {
      width: 100%;
      height: 100%;
      display: flex;
      justify-content: center;
      flex-direction: column;
      align-items: center; }
      .modal02 .modal-content .modal_inner {
        width: 100%;
        max-width: 100%;
        height: 100%;
        height: 90vh;
        box-sizing: border-box;
        padding: 16rem;
        background: #fff;
        border-radius: 16rem;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        flex-direction: column;
        position: relative;
        z-index: 12;
        box-shadow: 0rem 6rem 15rem rgba(0, 0, 0, 0.2); }
        .modal02 .modal-content .modal_inner .btn {
          width: 100%;
          max-width: 100%;
          height: 20rem;
          display: flex;
          justify-content: flex-start;
          align-items: flex-end;
          flex-direction: column; }
          .modal02 .modal-content .modal_inner .btn button {
            color: #333;
            font-size: 24rem;
            background: transparent;
            padding: 0;
            margin: 0;
            border: none; }
        .modal02 .modal-content .modal_inner h1 {
          font-size: 18rem;
          letter-spacing: 0;
          line-height: 1.4em;
          font-weight: 900;
          color: #333;
          padding-bottom: 16rem;
          text-align: center;
          display: flex;
          justify-content: center;
          align-items: center; }
        .modal02 .modal-content .modal_inner .modal_form {
          width: 541rem;
          max-width: 100%;
          height: 88%; }
          .modal02 .modal-content .modal_inner .modal_form iframe {
            width: 100%;
            height: 100%; }
    .modal02.contact {
      width: 100%; }
      .modal02.contact .modal-content .modal_inner {
        width: 95%;
        max-width: 95%;
        margin: 24rem 0;
        height: calc(100% - 48rem);
        padding: 16rem; }
        .modal02.contact .modal-content .modal_inner .modal_ttl {
          font-size: 18rem;
          height: calc(5% - 20rem);
          padding-bottom: 8rem;
          margin: 0rem 0rem 20rem 0rem;
          max-width: 100%; }
        .modal02.contact .modal-content .modal_inner .modal_form {
          width: 541rem;
          height: 95%; }
    .modal02.dl {
      width: 100%; }
      .modal02.dl .modal-content .modal_inner h1 {
        height: 5%; }
      .modal02.dl .modal-content .modal_inner .modal_form {
        height: 88%;
        flex: 1; }

  footer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 46rem 0px 17rem; }
    footer .footer_inner {
      width: 84.533%;
      margin: 0 auto 70px;
      border-bottom: solid 1px #E1E5E5; }
      footer .footer_inner .footer_left {
        width: 100%;
        margin-bottom: 70rem; }
        footer .footer_inner .footer_left .footer_logo {
          width: 132rem;
          margin: 0 auto 69rem; }
        footer .footer_inner .footer_left .footer_menu {
          width: 72.87%;
          margin: 0 auto; }
          footer .footer_inner .footer_left .footer_menu dl {
            margin-bottom: 25rem; }
            footer .footer_inner .footer_left .footer_menu dl:last-child {
              margin-bottom: 0; }
            footer .footer_inner .footer_left .footer_menu dl dt {
              font-size: 15rem;
              letter-spacing: 0.03em;
              line-height: 1.4em;
              font-weight: bold;
              color: #fff; }
            footer .footer_inner .footer_left .footer_menu dl dd {
              font-size: 13rem;
              letter-spacing: 0.03em;
              line-height: 1.4em;
              font-weight: 500;
              margin-top: 13rem; }
              footer .footer_inner .footer_left .footer_menu dl dd a {
                color: #fff; }
      footer .footer_inner .footer_right {
        width: 72.87%;
        margin: 0 auto 69rem; }
        footer .footer_inner .footer_right a {
          display: block;
          width: 100%;
          margin-bottom: 11rem;
          cursor: pointer; }
          footer .footer_inner .footer_right a:last-child {
            margin-bottom: 0; }
    footer .copyright {
      font-size: 12rem;
      line-height: 2em;
      color: #fff;
      text-align: center; }

  /*side*/
  #side {
    display: none !important; } }

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