@charset "UTF-8";
.header {
  background: url("../img/bg_main.jpg") no-repeat 100% 50%;
  background-size: cover;
  position: relative;
  letter-spacing: .1rem; }
  @media only screen and (max-width: 767px) {
    .header {
      background-position: 50% 50%; } }
  .header-message {
    height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
    padding: 5rem; }
    @media only screen and (max-width: 767px) {
      .header-message {
        height: auto;
        padding: 8rem 2.5rem 5rem;
        align-items: center; } }
    .header-message-catch {
      font-size: 2.8rem;
      line-height: 1.8;
      padding-left: 2.5rem;
      padding-bottom: 1.5rem;
      text-align: left;
      font-weight: 700; }
      @media only screen and (max-width: 767px) {
        .header-message-catch {
          width: 100%;
          font-size: 2.4rem;
          padding: 0 0 1rem; } }
      .header-message-catch strong {
        color: #339999; }
      .header-message-catch b {
        color: #ff884e; }
    .header-message-txt {
      font-size: 1.8rem;
      padding-left: 2.5rem; }
      @media only screen and (max-width: 767px) {
        .header-message-txt {
          font-size: 1.5rem;
          padding-left: 0; }
          .header-message-txt br {
            display: none; } }
  .header-logo {
    width: 50.2rem;
    padding-bottom: 5rem; }
    @media only screen and (max-width: 767px) {
      .header-logo {
        width: 24rem;
        padding-bottom: 3rem; } }
  .header-bpo {
    width: 12.3rem;
    position: absolute;
    right: 2.5rem;
    top: 2.5rem; }
    @media only screen and (max-width: 767px) {
      .header-bpo {
        width: 9rem;
        right: 2rem;
        top: 2rem; } }
  .header-link {
    background: rgba(0, 102, 102, 0.9);
    padding: 4rem 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center; }
    @media only screen and (max-width: 767px) {
      .header-link {
        padding: 2rem; } }
    .header-link-fig {
      width: 9.7rem;
      flex-shrink: 0; }
      @media only screen and (max-width: 767px) {
        .header-link-fig {
          width: 6.8rem; } }
    .header-link-ttl {
      line-height: 1;
      display: flex;
      justify-content: flex-start;
      align-items: baseline; }
      .header-link-ttl span {
        font-size: 3.7rem;
        background: linear-gradient(135deg, #ff884e 0%, #f89978 20%, #339999 60%, #339999 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent; }
        @media only screen and (max-width: 767px) {
          .header-link-ttl span {
            font-size: 2.8rem; } }
      .header-link-ttl strong {
        font-size: 6rem;
        bottom: -.3rem;
        position: relative;
        background: linear-gradient(-45deg, #ff884e 0%, #f89978 20%, #339999 60%, #339999 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent; }
        @media only screen and (max-width: 767px) {
          .header-link-ttl strong {
            font-size: 5rem; } }
    .header-link-inner {
      width: 100%;
      padding-left: 1.5rem; }
    .header-link > p {
      font-size: 2.8rem;
      font-weight: 700;
      padding-bottom: 1rem;
      color: #fff;
      text-align: center; }
      @media only screen and (max-width: 767px) {
        .header-link > p {
          font-size: 2rem; } }
    .header-link a {
      max-width: 62rem;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: #fff;
      border-radius: 1.5rem;
      padding: 2rem; }
      @media only screen and (max-width: 767px) {
        .header-link a {
          padding: 1.5rem; } }
      .header-link a:hover {
        background: rgba(255, 255, 255, 0.8); }
      .header-link a p {
        font-size: 1.4rem;
        padding: .5rem 0 0;
        font-weight: 700; }
        @media only screen and (max-width: 767px) {
          .header-link a p {
            font-size: 1.2rem; } }

.container {
  letter-spacing: .1rem; }

.section-barriers {
  background: url("../img/bg_ai.jpg") no-repeat 50% 0%;
  background-size: 100% auto;
  padding: 10rem 0 0; }
  @media only screen and (max-width: 767px) {
    .section-barriers {
      padding: 5rem 0 2rem;
      background-size: 200% auto; } }
  .section-barriers-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 6rem; }
    @media only screen and (max-width: 767px) {
      .section-barriers-header {
        margin: 0 1.5rem 3rem; } }
    .section-barriers-header p {
      font-size: 1.8rem;
      text-align: center; }
      @media only screen and (max-width: 767px) {
        .section-barriers-header p {
          font-size: 1.6rem; } }
      .section-barriers-header p strong {
        color: #339999; }
    .section-barriers-header-en {
      color: #ff884e;
      font-size: 1.8rem;
      line-height: 1;
      font-weight: 500;
      padding-bottom: 1rem; }
    .section-barriers-header-ttl {
      font-size: 3.6rem;
      line-height: 1.3;
      padding-bottom: 3.5rem; }
      @media only screen and (max-width: 767px) {
        .section-barriers-header-ttl {
          font-size: 2.8rem;
          display: flex;
          flex-direction: column;
          align-items: center;
          padding-bottom: 2rem; } }
      .section-barriers-header-ttl mark {
        color: #434343;
        position: relative;
        z-index: 1;
        background: none; }
        .section-barriers-header-ttl mark:before {
          content: "";
          width: 100%;
          height: 1rem;
          background: #ff884e;
          position: absolute;
          left: 0;
          bottom: .5rem;
          z-index: -1; }
  .section-barriers-inner {
    max-width: 102.4rem;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    @media only screen and (max-width: 767px) {
      .section-barriers-inner {
        flex-direction: column;
        padding: 0 1.5rem; } }
    .section-barriers-inner .article-barriers {
      width: 44rem;
      border-radius: 1rem;
      margin: 0 1.7rem 5rem;
      position: relative; }
      @media only screen and (max-width: 767px) {
        .section-barriers-inner .article-barriers {
          width: 100%;
          margin: 0 0 3rem; } }
      .section-barriers-inner .article-barriers-header {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center; }
        .section-barriers-inner .article-barriers-header-num {
          font-size: 1.4rem;
          line-height: 2;
          font-weight: 600;
          color: #ff884e; }
          @media only screen and (max-width: 767px) {
            .section-barriers-inner .article-barriers-header-num {
              font-size: 1.3rem; } }
        .section-barriers-inner .article-barriers-header-ttl {
          font-size: 2.4rem;
          line-height: 1.2;
          text-align: center; }
          @media only screen and (max-width: 767px) {
            .section-barriers-inner .article-barriers-header-ttl {
              font-size: 2rem; } }
      .section-barriers-inner .article-barriers-fig {
        width: 100%;
        height: 20rem;
        background: rgba(51, 153, 153, 0.05);
        margin: 2rem 0;
        display: flex;
        justify-content: center;
        align-items: center; }
        @media only screen and (max-width: 767px) {
          .section-barriers-inner .article-barriers-fig {
            height: 15rem; } }
        .section-barriers-inner .article-barriers-fig img {
          width: auto;
          height: 20rem; }
          @media only screen and (max-width: 767px) {
            .section-barriers-inner .article-barriers-fig img {
              height: 15rem; } }
      .section-barriers-inner .article-barriers-txt {
        padding: 0 1rem; }
        .section-barriers-inner .article-barriers-txt p {
          font-size: 1.6rem; }
          @media only screen and (max-width: 767px) {
            .section-barriers-inner .article-barriers-txt p {
              font-size: 1.3rem; } }
          .section-barriers-inner .article-barriers-txt p strong {
            color: #339999; }
  .section-barriers-solution {
    padding: 15rem 0 10rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 1;
    background: #FAC2AE; }
    @media only screen and (max-width: 767px) {
      .section-barriers-solution {
        padding: 8rem 2rem 5rem; } }
    .section-barriers-solution:before, .section-barriers-solution:after {
      content: "";
      position: absolute;
      width: 100%;
      left: 0;
      top: 0;
      z-index: -1; }
    .section-barriers-solution:before {
      background: url("../img/bg_arrow.svg") no-repeat 0% 0%;
      background-size: 100% 100%;
      height: 9.7rem;
      top: -.2rem;
      z-index: 1; }
      @media only screen and (max-width: 767px) {
        .section-barriers-solution:before {
          height: 5rem; } }
    .section-barriers-solution:after {
      background: linear-gradient(180deg, #FD7B3A 0%, #FAC2AE 100%);
      height: 37.5rem;
      z-index: -1; }
      @media only screen and (max-width: 767px) {
        .section-barriers-solution:after {
          height: 16rem; } }
    .section-barriers-solution-mes {
      text-align: center;
      padding-bottom: 5rem; }
      @media only screen and (max-width: 767px) {
        .section-barriers-solution-mes {
          padding-bottom: 3rem; } }
      .section-barriers-solution-mes-txt {
        font-size: 1.8rem; }
        @media only screen and (max-width: 767px) {
          .section-barriers-solution-mes-txt {
            font-size: 1.6rem; } }
      .section-barriers-solution-mes-ttl {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding-bottom: 3rem; }
        @media only screen and (max-width: 767px) {
          .section-barriers-solution-mes-ttl {
            padding-bottom: 1.5rem; } }
        .section-barriers-solution-mes-ttl span {
          font-size: 3.2rem;
          font-weight: 700;
          color: #fff;
          display: flex;
          justify-content: center;
          align-items: center;
          margin-bottom: 1rem; }
          @media only screen and (max-width: 767px) {
            .section-barriers-solution-mes-ttl span {
              font-size: 2.4rem; } }
          .section-barriers-solution-mes-ttl span:before, .section-barriers-solution-mes-ttl span:after {
            content: "";
            width: .5rem;
            height: 6rem;
            background: #fff;
            margin: 0 1.5rem; }
            @media only screen and (max-width: 767px) {
              .section-barriers-solution-mes-ttl span:before, .section-barriers-solution-mes-ttl span:after {
                width: .3rem;
                height: 4rem; } }
          .section-barriers-solution-mes-ttl span:after {
            transform: rotate(35deg); }
          .section-barriers-solution-mes-ttl span:before {
            transform: rotate(-35deg); }
        .section-barriers-solution-mes-ttl mark {
          font-size: 3.2rem;
          line-height: 1;
          background: #fff;
          font-weight: 700;
          padding: .2rem 1.5rem;
          display: flex;
          justify-content: center;
          align-items: baseline;
          color: #434343; }
          @media only screen and (max-width: 767px) {
            .section-barriers-solution-mes-ttl mark {
              font-size: 2.8rem;
              flex-direction: column;
              align-items: center;
              padding: .8rem 1.5rem; } }
          .section-barriers-solution-mes-ttl mark strong {
            font-size: 4.8rem;
            bottom: -.3rem;
            background: linear-gradient(-45deg, #ff884e 0%, #f89978 20%, #339999 60%, #339999 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent; }
    .section-barriers-solution-inner {
      max-width: 102.4rem;
      margin: 0 auto;
      display: flex;
      justify-content: center;
      flex-wrap: wrap; }
      @media only screen and (max-width: 767px) {
        .section-barriers-solution-inner {
          flex-direction: column; } }
      .section-barriers-solution-inner .article-solution {
        width: 44rem;
        margin: 0 1.7rem 5rem;
        display: flex;
        flex-direction: column; }
        @media only screen and (max-width: 767px) {
          .section-barriers-solution-inner .article-solution {
            width: 100%;
            margin: 0 0 3rem; } }
        .section-barriers-solution-inner .article-solution-header {
          display: flex;
          flex-direction: column;
          align-items: center;
          padding-bottom: 1.5rem; }
          .section-barriers-solution-inner .article-solution-header-num {
            background: #ff884e;
            color: #fff;
            font-size: 1.4rem;
            font-weight: 600;
            border-radius: 5rem;
            margin: 0 auto .5rem;
            padding: .2rem 1.5rem; }
            @media only screen and (max-width: 767px) {
              .section-barriers-solution-inner .article-solution-header-num {
                font-size: 1.3rem; } }
          .section-barriers-solution-inner .article-solution-header-ttl {
            font-size: 2.4rem;
            line-height: 1.3; }
            @media only screen and (max-width: 767px) {
              .section-barriers-solution-inner .article-solution-header-ttl {
                font-size: 2rem; } }
        .section-barriers-solution-inner .article-solution-fig {
          background: #fff; }
        .section-barriers-solution-inner .article-solution-inner {
          height: 100%;
          background: rgba(255, 255, 255, 0.75);
          padding: 2rem 2.5rem; }
          @media only screen and (max-width: 767px) {
            .section-barriers-solution-inner .article-solution-inner {
              padding: 1.5rem 2rem; } }
          .section-barriers-solution-inner .article-solution-inner > p {
            font-size: 2rem;
            font-weight: 700;
            text-align: center;
            padding-bottom: 1.5rem; }
            @media only screen and (max-width: 767px) {
              .section-barriers-solution-inner .article-solution-inner > p {
                font-size: 1.8rem; } }
          .section-barriers-solution-inner .article-solution-inner ul li {
            display: flex;
            justify-content: flex-start;
            font-weight: 700;
            font-size: 1.6rem;
            padding-bottom: .6rem; }
            @media only screen and (max-width: 767px) {
              .section-barriers-solution-inner .article-solution-inner ul li {
                font-size: 1.4rem; } }
            .section-barriers-solution-inner .article-solution-inner ul li p {
              line-height: 1.4; }
            .section-barriers-solution-inner .article-solution-inner ul li strong {
              color: #339999; }
            .section-barriers-solution-inner .article-solution-inner ul li:before {
              content: "";
              width: 1.9rem;
              height: 1.9rem;
              border-radius: 50%;
              border: 0.4rem solid #339999;
              box-sizing: border-box;
              flex-shrink: 0;
              margin-right: .5rem;
              margin-top: .2rem; }
              @media only screen and (max-width: 767px) {
                .section-barriers-solution-inner .article-solution-inner ul li:before {
                  width: 1.6rem;
                  height: 1.6rem;
                  border-width: .3rem; } }
    .section-barriers-solution-catch {
      display: flex;
      justify-content: center;
      padding-top: 3rem; }
      @media only screen and (max-width: 767px) {
        .section-barriers-solution-catch {
          padding: 1rem 0 0 0; } }
      .section-barriers-solution-catch p {
        background: #FD5807;
        color: #fff;
        font-weight: 700;
        font-size: 2.8rem;
        padding: .8rem 2rem; }
        @media only screen and (max-width: 767px) {
          .section-barriers-solution-catch p {
            font-size: 2.4rem;
            line-height: 1.3;
            text-align: center; } }
.section-quality {
  padding: 10rem 0 12rem;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center; }
  @media only screen and (max-width: 767px) {
    .section-quality {
      padding: 4rem 2rem 6rem; } }
  .section-quality:before, .section-quality:after {
    content: "";
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 0; }
  .section-quality:before {
    height: 47rem;
    background: linear-gradient(180deg, rgba(248, 153, 120, 0) 0%, #f89978 100%);
    z-index: -1; }
    @media only screen and (max-width: 767px) {
      .section-quality:before {
        height: 30rem; } }
  .section-quality:after {
    background: url("../img/bg_arrow_ura.svg") no-repeat 100% 100%;
    background-size: 100% 100%;
    height: 7rem;
    bottom: -.2rem;
    z-index: 1; }
    @media only screen and (max-width: 767px) {
      .section-quality:after {
        height: 4rem; } }
  .section-quality-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 4rem; }
    @media only screen and (max-width: 767px) {
      .section-quality-header {
        padding: 0 0 2rem; } }
    .section-quality-header-en {
      font-size: 1.8rem;
      line-height: 1;
      font-weight: 600;
      color: #ff884e; }
      @media only screen and (max-width: 767px) {
        .section-quality-header-en {
          font-size: 1.4rem;
          margin-bottom: .3rem; } }
    .section-quality-header-ttl {
      font-size: 3.6rem; }
      @media only screen and (max-width: 767px) {
        .section-quality-header-ttl {
          font-size: 2.8rem;
          line-height: 1.3;
          text-align: center; } }
  .section-quality-keyword {
    background: #339999;
    color: #fff;
    border-radius: 10rem;
    padding: .8rem 3rem;
    font-weight: 700;
    font-size: 1.8rem;
    margin: 0 auto 4rem; }
    @media only screen and (max-width: 767px) {
      .section-quality-keyword {
        width: 100%;
        font-size: 1.4rem;
        margin-bottom: 2rem;
        padding: 1rem; } }
    .section-quality-keyword p {
      line-height: 1.3;
      text-align: center; }
    .section-quality-keyword strong {
      font-size: 2.8rem; }
      @media only screen and (max-width: 767px) {
        .section-quality-keyword strong {
          font-size: 1.6rem; } }
    .section-quality-keyword mark {
      color: #f89978;
      background: none; }
      @media only screen and (max-width: 767px) {
        .section-quality-keyword mark {
          font-size: 2rem; } }
  .section-quality-fig {
    max-width: 76.7rem;
    padding-bottom: 10rem; }
    @media only screen and (max-width: 767px) {
      .section-quality-fig {
        padding-bottom: 2rem; } }
  .section-quality-future {
    display: flex;
    flex-direction: column;
    align-items: center; }
    .section-quality-future-ttl {
      font-size: 2.8rem;
      line-height: 1.2;
      text-align: center;
      border-bottom: 0.4rem solid #ff884e;
      margin-bottom: 4rem; }
      @media only screen and (max-width: 767px) {
        .section-quality-future-ttl {
          font-size: 2rem;
          margin-bottom: 2rem; } }
    .section-quality-future ul {
      max-width: 90rem;
      margin: 0 auto; }
      .section-quality-future ul li {
        background: #fff;
        border-radius: 1rem;
        padding: 1.5rem;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        font-size: 1.8rem;
        font-weight: 700;
        line-height: 1.3;
        min-height: 7.5rem;
        margin-bottom: 1rem; }
        @media only screen and (max-width: 767px) {
          .section-quality-future ul li {
            font-size: 1.5rem;
            padding: 1rem; } }
        .section-quality-future ul li:before {
          content: "\f88b";
          width: 2.3rem;
          height: 2.3rem;
          font-size: 2rem;
          display: flex;
          justify-content: center;
          align-items: center;
          letter-spacing: 0;
          flex-shrink: 0;
          margin-right: 1rem;
          font-family: "material symbols Outlined", cursive;
          background: #eee;
          border-radius: .3rem;
          color: #ff884e; }
.section-friendly {
  padding: 4rem 0 10rem; }
  @media only screen and (max-width: 767px) {
    .section-friendly {
      padding: 4rem 2rem 5rem; } }
  .section-friendly-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 4rem; }
    @media only screen and (max-width: 767px) {
      .section-friendly-header {
        margin-bottom: 2rem; } }
    .section-friendly-header-icon {
      max-width: 22.6rem;
      margin-bottom: 1rem; }
      @media only screen and (max-width: 767px) {
        .section-friendly-header-icon {
          max-width: 16rem; } }
    .section-friendly-header-ttl {
      font-size: 3.6rem; }
      .section-friendly-header-ttl strong {
        color: #339999; }
      @media only screen and (max-width: 767px) {
        .section-friendly-header-ttl {
          font-size: 2.8rem;
          line-height: 1.2;
          text-align: center; } }
  .section-friendly-exam {
    display: flex;
    justify-content: center; }
    @media only screen and (max-width: 767px) {
      .section-friendly-exam {
        flex-direction: column; } }
    .section-friendly-exam div {
      width: 48rem;
      margin: 0 .7rem;
      padding: 2.5rem;
      border: .6rem solid;
      font-size: 1.8rem;
      font-weight: 700;
      text-align: center;
      padding-bottom: 3rem; }
      @media only screen and (max-width: 767px) {
        .section-friendly-exam div {
          width: 100%;
          margin: 0 0 2rem;
          padding: 1.5rem;
          border-width: .4rem; } }
      .section-friendly-exam div:nth-of-type(1) {
        border-color: #339999;
        background: rgba(51, 153, 153, 0.1); }
        .section-friendly-exam div:nth-of-type(1) dt {
          color: #339999; }
        .section-friendly-exam div:nth-of-type(1) dd {
          color: #339999; }
      .section-friendly-exam div:nth-of-type(2) {
        border-color: #ff884e;
        background: rgba(255, 136, 78, 0.1); }
        .section-friendly-exam div:nth-of-type(2) dt {
          color: #ff884e; }
        .section-friendly-exam div:nth-of-type(2) dd {
          color: #f89978; }
      .section-friendly-exam div dt {
        font-size: 2rem;
        padding-bottom: 1.5rem; }
        @media only screen and (max-width: 767px) {
          .section-friendly-exam div dt {
            font-size: 1.8rem;
            padding-bottom: .5rem; } }
      .section-friendly-exam div dd ul {
        display: flex;
        justify-content: center; }
        @media only screen and (max-width: 767px) {
          .section-friendly-exam div dd ul {
            flex-direction: column; } }
        .section-friendly-exam div dd ul li {
          width: 100%; }
          @media only screen and (max-width: 767px) {
            .section-friendly-exam div dd ul li {
              padding: 1rem; } }
          .section-friendly-exam div dd ul li p {
            font-size: 1.3rem;
            line-height: 1.3;
            text-align: center;
            font-weight: 700;
            min-height: 3.38rem;
            display: flex;
            align-items: center;
            justify-content: center; }
            @media only screen and (max-width: 767px) {
              .section-friendly-exam div dd ul li p {
                min-height: 0; } }
          .section-friendly-exam div dd ul li figure {
            padding-top: 1rem; }
            .section-friendly-exam div dd ul li figure img {
              max-width: none;
              width: auto;
              height: 23rem; }
      @media only screen and (max-width: 767px) {
        .section-friendly-exam div {
          font-size: 1.5rem; } }
  .section-friendly-txt {
    padding-top: 5rem; }
    @media only screen and (max-width: 767px) {
      .section-friendly-txt {
        padding-top: 2rem; } }
    .section-friendly-txt p {
      font-size: 2.4rem;
      line-height: 1.4;
      text-align: center;
      font-weight: 700; }
      @media only screen and (max-width: 767px) {
        .section-friendly-txt p {
          font-size: 1.8rem; } }
      .section-friendly-txt p strong {
        color: #339999; }
        @media only screen and (max-width: 767px) {
          .section-friendly-txt p strong {
            font-size: 2.2rem; } }
      .section-friendly-txt p b {
        color: #ff884e; }
.section-check {
  padding: 0 0 10rem 0;
  background: #339999; }
  @media only screen and (max-width: 767px) {
    .section-check {
      padding: 0 2rem 4rem; } }
  .section-check-header {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    position: relative;
    top: -4rem;
    margin-bottom: 2rem; }
    @media only screen and (max-width: 767px) {
      .section-check-header {
        margin-bottom: 0; } }
    .section-check-header-icon {
      width: 21.5rem;
      margin-bottom: 1.5rem; }
      @media only screen and (max-width: 767px) {
        .section-check-header-icon {
          width: 15rem;
          margin-bottom: 1rem; } }
    .section-check-header-ttl {
      display: flex;
      flex-direction: column;
      align-items: center;
      font-size: 2rem;
      line-height: 1.3;
      color: #fff;
      position: relative;
      padding-bottom: 1rem; }
      @media only screen and (max-width: 767px) {
        .section-check-header-ttl {
          font-size: 1.6rem;
          padding-bottom: 0; } }
      .section-check-header-ttl:before, .section-check-header-ttl:after {
        content: "";
        position: absolute;
        bottom: 0;
        width: .6rem;
        height: 10rem;
        background: rgba(255, 255, 255, 0.5); }
        @media only screen and (max-width: 767px) {
          .section-check-header-ttl:before, .section-check-header-ttl:after {
            width: .3rem;
            height: 7rem; } }
      .section-check-header-ttl:before {
        transform: rotate(-45deg);
        left: -5rem; }
        @media only screen and (max-width: 767px) {
          .section-check-header-ttl:before {
            left: -3rem;
            transform: rotate(-25deg); } }
      .section-check-header-ttl:after {
        transform: rotate(45deg);
        right: -5rem; }
        @media only screen and (max-width: 767px) {
          .section-check-header-ttl:after {
            right: -3rem;
            transform: rotate(25deg); } }
      .section-check-header-ttl strong {
        font-size: 3.6rem; }
        @media only screen and (max-width: 767px) {
          .section-check-header-ttl strong {
            font-size: 2.8rem; } }
        .section-check-header-ttl strong mark {
          color: #f89978;
          background: none; }
  .section-check-list {
    max-width: 102.4rem;
    display: flex;
    justify-content: center;
    margin: 0 auto 5rem; }
    @media only screen and (max-width: 767px) {
      .section-check-list {
        flex-direction: column;
        margin: 0; } }
    .section-check-list .dl-check {
      display: flex;
      flex-direction: column;
      margin: 0 2rem;
      position: relative; }
      @media only screen and (max-width: 767px) {
        .section-check-list .dl-check {
          margin: 0 0 4rem; } }
      .section-check-list .dl-check:after {
        content: '\e145';
        width: 4rem;
        font-family: "material symbols Outlined", cursive;
        position: absolute;
        height: 8rem;
        display: flex;
        justify-content: center;
        align-items: center;
        right: -4rem;
        top: 0;
        letter-spacing: 0;
        color: #fff;
        font-size: 2.4rem; }
        @media only screen and (max-width: 767px) {
          .section-check-list .dl-check:after {
            width: 100%;
            height: 4rem;
            right: 0;
            top: auto;
            bottom: -4rem; } }
      .section-check-list .dl-check:nth-last-of-type(1):after {
        display: none; }
      .section-check-list .dl-check dt {
        border-radius: 1rem;
        background: #fff;
        height: 8rem;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 2rem;
        color: #339999;
        margin-bottom: 1.5rem; }
        @media only screen and (max-width: 767px) {
          .section-check-list .dl-check dt {
            height: 6rem;
            font-size: 1.8rem; } }
      .section-check-list .dl-check dd {
        border-radius: 1rem;
        padding: 2.5rem;
        display: flex;
        flex-direction: column;
        align-items: center; }
        @media only screen and (max-width: 767px) {
          .section-check-list .dl-check dd {
            padding: 1.5rem; } }
        .section-check-list .dl-check dd:before {
          content: "";
          margin-bottom: 1.5rem;
          background-position: 50% 50%;
          width: 100%;
          height: 4rem;
          background-repeat: no-repeat; }
        .section-check-list .dl-check dd p {
          font-size: 1.8rem;
          line-height: 1.3;
          font-weight: 700;
          text-align: center;
          padding-bottom: 1.5rem; }
          @media only screen and (max-width: 767px) {
            .section-check-list .dl-check dd p {
              font-size: 1.6rem; } }
        .section-check-list .dl-check dd ul li {
          line-height: 1.3;
          display: flex;
          justify-content: flex-start;
          margin-bottom: .8rem; }
          .section-check-list .dl-check dd ul li:before {
            content: "■";
            flex-shrink: 0;
            margin-right: .5rem; }
      .section-check-list .dl-check-maru {
        background: rgba(255, 255, 255, 0.75);
        margin-bottom: 1rem; }
        .section-check-list .dl-check-maru:before {
          background-image: url("../img/icon_maru.png");
          background-size: 4rem auto; }
        .section-check-list .dl-check-maru ul li:before {
          color: #f89978; }
      .section-check-list .dl-check-batsu {
        background: rgba(67, 67, 67, 0.8);
        color: #fff; }
        .section-check-list .dl-check-batsu:before {
          background-image: url("../img/icon_batsu.png");
          background-size: 3.2rem auto; }
        .section-check-list .dl-check-batsu ul li:before {
          color: #339999; }
  .section-check-attention {
    max-width: 102.4rem;
    margin: 0 auto;
    border-radius: 1rem;
    border: 1px dashed rgba(255, 255, 255, 0.75);
    padding: 3rem;
    display: flex;
    align-items: center;
    justify-content: space-between; }
    @media only screen and (max-width: 767px) {
      .section-check-attention {
        padding: 1.5rem;
        flex-direction: column; } }
    .section-check-attention h5 {
      width: 40%;
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      font-size: 1.8rem;
      line-height: 1.3;
      color: #fff; }
      @media only screen and (max-width: 767px) {
        .section-check-attention h5 {
          width: 100%;
          font-size: 1.6rem;
          padding-bottom: 1.5rem; } }
      .section-check-attention h5 span {
        border-radius: 3rem;
        background: #fff;
        color: #ff884e;
        font-size: 1.5rem;
        font-weight: 700;
        padding: 0 1.3rem;
        margin-bottom: .8rem; }
        @media only screen and (max-width: 767px) {
          .section-check-attention h5 span {
            font-size: 1.3rem; } }
    .section-check-attention dl {
      width: 60%;
      background: rgba(255, 255, 255, 0.75);
      border-radius: 1rem;
      padding: 1.5rem;
      display: flex;
      flex-direction: column;
      align-items: center; }
      @media only screen and (max-width: 767px) {
        .section-check-attention dl {
          width: 100%; } }
      .section-check-attention dl dt {
        text-align: center;
        color: #339999;
        padding-bottom: 1.5rem; }
        @media only screen and (max-width: 767px) {
          .section-check-attention dl dt {
            line-height: 1.3;
            padding-bottom: 1rem; } }
      .section-check-attention dl dd {
        display: flex;
        justify-content: center; }
        .section-check-attention dl dd ul {
          display: flex;
          justify-content: center;
          flex-wrap: wrap;
          margin: 0 auto; }
          .section-check-attention dl dd ul li {
            width: 100%;
            max-width: 20rem;
            line-height: 1.3;
            display: flex;
            justify-content: flex-start;
            margin: 0 1rem .8rem; }
            .section-check-attention dl dd ul li:before {
              content: "■";
              flex-shrink: 0;
              margin-right: .5rem;
              color: #f89978; }
.section-must {
  padding: 8rem 2rem 10rem;
  background: rgba(238, 238, 238, 0.75); }
  @media only screen and (max-width: 767px) {
    .section-must {
      padding: 4rem 2rem; } }
  .section-must-header {
    margin-bottom: 4rem; }
    @media only screen and (max-width: 767px) {
      .section-must-header {
        margin-bottom: 2rem; } }
    .section-must-header-ttl {
      text-align: center;
      font-size: 3.2rem;
      line-height: 1.3; }
      @media only screen and (max-width: 767px) {
        .section-must-header-ttl {
          font-size: 2rem; } }
      .section-must-header-ttl strong {
        font-size: 3.6rem;
        display: flex;
        align-items: center;
        justify-content: center; }
        @media only screen and (max-width: 767px) {
          .section-must-header-ttl strong {
            font-size: 2.8rem; } }
        .section-must-header-ttl strong span {
          width: 4rem;
          height: 4rem;
          border-radius: 50%;
          color: #fff;
          font-size: 2.8rem;
          font-weight: 700;
          letter-spacing: 0;
          display: flex;
          justify-content: center;
          align-items: center;
          flex-shrink: 0;
          margin-right: .5rem;
          background: #339999; }
          @media only screen and (max-width: 767px) {
            .section-must-header-ttl strong span {
              width: 3rem;
              height: 3rem;
              font-size: 2.2rem; } }
  .section-must-exam {
    max-width: 82rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 auto; }
    @media only screen and (max-width: 767px) {
      .section-must-exam {
        flex-direction: column; } }
    .section-must-exam > div:nth-of-type(1) {
      width: 42.7rem; }
      @media only screen and (max-width: 767px) {
        .section-must-exam > div:nth-of-type(1) {
          width: 100%;
          margin-bottom: 1rem; } }
      .section-must-exam > div:nth-of-type(1) dt {
        background: #434343; }
        .section-must-exam > div:nth-of-type(1) dt sup {
          font-size: 1.2rem; }
          @media only screen and (max-width: 767px) {
            .section-must-exam > div:nth-of-type(1) dt sup {
              font-size: 1rem; } }
    .section-must-exam > div:nth-of-type(2) {
      width: 32rem; }
      @media only screen and (max-width: 767px) {
        .section-must-exam > div:nth-of-type(2) {
          width: 100%; } }
      .section-must-exam > div:nth-of-type(2) dt {
        font-size: 1.8rem;
        line-height: 1.3;
        border-radius: 1rem 1rem 0 0;
        margin-top: 2rem; }
        @media only screen and (max-width: 767px) {
          .section-must-exam > div:nth-of-type(2) dt {
            font-size: 1.6rem;
            margin-top: 1rem; } }
        .section-must-exam > div:nth-of-type(2) dt small {
          font-size: 1.2rem; }
          @media only screen and (max-width: 767px) {
            .section-must-exam > div:nth-of-type(2) dt small {
              font-size: 1rem; } }
        .section-must-exam > div:nth-of-type(2) dt:nth-of-type(1) {
          background: #339999; }
        .section-must-exam > div:nth-of-type(2) dt:nth-of-type(2) {
          background: #ff884e;
          flex-direction: column; }
      .section-must-exam > div:nth-of-type(2) dd {
        padding: 1.5rem;
        font-size: 3rem;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 0 0 1rem 1rem;
        margin-bottom: 2rem; }
        @media only screen and (max-width: 767px) {
          .section-must-exam > div:nth-of-type(2) dd {
            font-size: 2rem;
            margin-bottom: 1rem; } }
        .section-must-exam > div:nth-of-type(2) dd strong {
          font-size: 4rem;
          font-weight: 600; }
          @media only screen and (max-width: 767px) {
            .section-must-exam > div:nth-of-type(2) dd strong {
              font-size: 2.8rem; } }
        .section-must-exam > div:nth-of-type(2) dd sub {
          font-size: 1.2rem; }
          @media only screen and (max-width: 767px) {
            .section-must-exam > div:nth-of-type(2) dd sub {
              font-size: 1rem; } }
        .section-must-exam > div:nth-of-type(2) dd div {
          margin: 0 .5rem;
          font-weight: 600; }
          .section-must-exam > div:nth-of-type(2) dd div.bunsu {
            display: flex;
            flex-direction: column;
            font-size: 2.8rem; }
            @media only screen and (max-width: 767px) {
              .section-must-exam > div:nth-of-type(2) dd div.bunsu {
                font-size: 1.8rem; } }
            .section-must-exam > div:nth-of-type(2) dd div.bunsu span {
              padding: 0 .8rem;
              text-align: center; }
              .section-must-exam > div:nth-of-type(2) dd div.bunsu span:nth-of-type(1) {
                border-bottom: .3rem solid; }
                @media only screen and (max-width: 767px) {
                  .section-must-exam > div:nth-of-type(2) dd div.bunsu span:nth-of-type(1) {
                    border-width: .2rem; } }
        .section-must-exam > div:nth-of-type(2) dd:nth-of-type(1) {
          color: #339999; }
          .section-must-exam > div:nth-of-type(2) dd:nth-of-type(1) div span {
            border-color: #339999; }
        .section-must-exam > div:nth-of-type(2) dd:nth-of-type(2) {
          color: #ff884e; }
          .section-must-exam > div:nth-of-type(2) dd:nth-of-type(2) div span {
            border-color: #ff884e; }
    .section-must-exam > div dt {
      color: #fff;
      font-size: 2rem;
      height: 5.6rem;
      display: flex;
      justify-content: center;
      align-items: center; }
      @media only screen and (max-width: 767px) {
        .section-must-exam > div dt {
          font-size: 1.8rem;
          height: 4.8rem; } }
    .section-must-exam > div dd {
      background: #fff; }
  .section-must-attention {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 8rem; }
    @media only screen and (max-width: 767px) {
      .section-must-attention {
        padding-top: 1.5rem; } }
    .section-must-attention p {
      text-align: center;
      font-size: 2.4rem;
      font-weight: 700;
      padding-bottom: 3rem; }
      @media only screen and (max-width: 767px) {
        .section-must-attention p {
          font-size: 1.8rem;
          padding-bottom: 1.5rem; } }
      .section-must-attention p strong {
        color: #339999; }
      .section-must-attention p b {
        color: #ff884e; }
    @media only screen and (max-width: 767px) {
      .section-must-attention ul {
        font-size: 1.3rem; } }
    .section-must-attention ul li {
      line-height: 1.3;
      text-align: left; }
.section-flow {
  padding: 8rem 0;
  background: url("../img/bg_flow.jpg") no-repeat 50% 0%;
  background-size: cover; }
  @media only screen and (max-width: 767px) {
    .section-flow {
      padding: 4rem 2rem 2rem;
      background-size: 200% auto; } }
  .section-flow-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 6rem; }
    @media only screen and (max-width: 767px) {
      .section-flow-header {
        margin-bottom: 2rem; } }
    .section-flow-header-en {
      color: #ff884e;
      font-size: 1.8rem;
      font-weight: 600; }
      @media only screen and (max-width: 767px) {
        .section-flow-header-en {
          font-size: 1.4rem; } }
    .section-flow-header-ttl {
      display: flex;
      flex-direction: column;
      align-items: center;
      font-size: 3.6rem; }
      @media only screen and (max-width: 767px) {
        .section-flow-header-ttl {
          font-size: 2.8rem; } }
  .section-flow-inner {
    max-width: 90rem;
    margin: 0 auto; }
    .section-flow-inner .article-flow {
      padding: 3rem 0;
      border: 1px solid #dee9e9;
      background: #fff;
      margin-bottom: 4rem;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      @media only screen and (max-width: 767px) {
        .section-flow-inner .article-flow {
          padding: 6rem 1.5rem 1.5rem;
          flex-direction: column;
          position: relative;
          margin-bottom: 1.5rem; } }
      .section-flow-inner .article-flow-fig {
        width: 26rem;
        text-align: center;
        flex-shrink: 0; }
        @media only screen and (max-width: 767px) {
          .section-flow-inner .article-flow-fig {
            width: 20rem;
            margin: 0 auto 1rem; } }
        .section-flow-inner .article-flow-fig img {
          max-width: 20rem; }
          @media only screen and (max-width: 767px) {
            .section-flow-inner .article-flow-fig img {
              max-width: 16rem; } }
      .section-flow-inner .article-flow-wrap {
        width: 100%;
        padding-right: 3rem; }
        @media only screen and (max-width: 767px) {
          .section-flow-inner .article-flow-wrap {
            padding: 0; } }
        .section-flow-inner .article-flow-wrap p {
          font-size: 1.6rem;
          line-height: 1.5; }
          @media only screen and (max-width: 767px) {
            .section-flow-inner .article-flow-wrap p {
              font-size: 1.4rem; } }
      .section-flow-inner .article-flow-header {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        padding-bottom: 1rem; }
        @media only screen and (max-width: 767px) {
          .section-flow-inner .article-flow-header {
            flex-direction: column; } }
        .section-flow-inner .article-flow-header-ttl {
          font-size: 2.2rem; }
          @media only screen and (max-width: 767px) {
            .section-flow-inner .article-flow-header-ttl {
              font-size: 2rem; } }
        .section-flow-inner .article-flow-header-num {
          display: flex;
          align-items: baseline;
          color: #339999;
          font-size: 1.4rem;
          font-weight: 600;
          flex-shrink: 0;
          margin-right: 1.5rem; }
          @media only screen and (max-width: 767px) {
            .section-flow-inner .article-flow-header-num {
              font-size: 1rem;
              line-height: 1;
              flex-direction: column;
              align-items: center;
              position: absolute;
              width: 100%;
              left: 0;
              top: 1.5rem; } }
          .section-flow-inner .article-flow-header-num strong {
            font-size: 2.4rem;
            font-weight: 500; }
            .section-flow-inner .article-flow-header-num strong:before {
              content: ".";
              font-size: 1.4rem; }
              @media only screen and (max-width: 767px) {
                .section-flow-inner .article-flow-header-num strong:before {
                  display: none; } }
.section-case {
  padding: 8rem 0;
  background: rgba(255, 136, 78, 0.3); }
  @media only screen and (max-width: 767px) {
    .section-case {
      padding: 4rem 2rem .5rem; } }
  .section-case-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 6rem; }
    @media only screen and (max-width: 767px) {
      .section-case-header {
        margin-bottom: 3rem; } }
    .section-case-header-en {
      color: #ff884e;
      font-size: 1.8rem;
      font-weight: 600; }
      @media only screen and (max-width: 767px) {
        .section-case-header-en {
          font-size: 1.4rem; } }
    .section-case-header-ttl {
      display: flex;
      flex-direction: column;
      align-items: center;
      font-size: 3.6rem; }
      @media only screen and (max-width: 767px) {
        .section-case-header-ttl {
          font-size: 2.8rem; } }
  .section-case-inner {
    max-width: 102.4rem;
    margin: 0 auto; }
    .section-case-inner .article-case {
      border-radius: 1rem;
      background: #fff;
      margin-bottom: 5rem; }
      .section-case-inner .article-case-header {
        position: relative;
        padding: 5rem 2.5rem 2.5rem; }
        @media only screen and (max-width: 767px) {
          .section-case-inner .article-case-header {
            padding: 3rem 1.5rem 1.5rem; } }
        .section-case-inner .article-case-header-ttl {
          font-size: 2.2rem;
          line-height: 1.3;
          text-align: center; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-header-ttl {
              font-size: 1.8rem; } }
        .section-case-inner .article-case-header-num {
          width: 15rem;
          height: 3.6rem;
          border-radius: 5rem;
          margin: 0 auto;
          top: -1.8rem;
          left: 50%;
          margin-left: -7.5rem;
          background: #ff884e;
          color: #fff;
          display: flex;
          justify-content: center;
          align-items: baseline;
          font-size: 1.4rem;
          font-weight: 600;
          position: absolute;
          padding: .3rem 0 0 0; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-header-num {
              width: 12rem;
              height: 3rem;
              margin-left: -6rem;
              font-size: 1.1rem; } }
          .section-case-inner .article-case-header-num strong {
            font-size: 1.8rem;
            font-weight: 600; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-header-num strong {
                font-size: 1.4rem; } }
            .section-case-inner .article-case-header-num strong:before {
              content: ".";
              font-size: 1.4rem; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-header-num strong:before {
                  font-size: 1.1rem; } }
      .section-case-inner .article-case-wrap {
        overflow: hidden;
        border-radius: 0 0 1rem 1rem; }
      .section-case-inner .article-case-inner {
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: #eee; }
        @media only screen and (max-width: 767px) {
          .section-case-inner .article-case-inner {
            flex-direction: column;
            padding: 1.5rem; } }
        .section-case-inner .article-case-inner-point {
          width: 100%;
          display: flex;
          align-items: center;
          flex-direction: column;
          font-size: 2rem;
          line-height: 1.4;
          text-align: center;
          color: #006666;
          font-weight: 700; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-inner-point {
              font-size: 1.7rem; } }
          .section-case-inner .article-case-inner-point:before {
            content: "POINT!";
            color: #ff884e;
            font-weight: 600;
            font-size: 1.5rem; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-inner-point:before {
                font-size: 1.3rem; } }
        .section-case-inner .article-case-inner-info {
          width: 100%;
          padding: 2rem; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-inner-info {
              padding: 1rem 0 0; } }
          .section-case-inner .article-case-inner-info div {
            border-bottom: 1px solid #dcdcdc;
            padding: .8rem 0;
            display: flex;
            align-items: center;
            justify-content: flex-start;
            font-size: 1.6rem;
            font-weight: 700; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-inner-info div {
                font-size: 1.4rem; } }
            .section-case-inner .article-case-inner-info div:nth-last-of-type(1) {
              border: none; }
            .section-case-inner .article-case-inner-info div dt {
              width: 5em;
              text-align: center;
              color: #7d7d7d;
              flex-shrink: 0; }
            .section-case-inner .article-case-inner-info div dd {
              line-height: 1.3; }
              .section-case-inner .article-case-inner-info div dd ul li {
                line-height: 1.3;
                display: flex;
                justify-content: flex-start;
                margin: .2rem 0; }
                .section-case-inner .article-case-inner-info div dd ul li:before {
                  content: "・";
                  flex-shrink: 0;
                  margin-right: .3rem;
                  color: #7d7d7d; }
      .section-case-inner .article-case-works {
        background: #ff884e;
        padding: 3rem 4rem; }
        @media only screen and (max-width: 767px) {
          .section-case-inner .article-case-works {
            padding: 1.5rem; } }
        .section-case-inner .article-case-works > p {
          font-size: 2rem;
          line-height: 1.4;
          text-align: center;
          color: #fff;
          font-weight: 700;
          padding-bottom: 1.5rem; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-works > p {
              font-size: 1.7rem;
              padding-bottom: 1rem; } }
        .section-case-inner .article-case-works dl > div {
          background: #fff;
          display: flex;
          justify-content: space-between;
          margin-bottom: .5rem;
          border-radius: .3rem;
          padding: 1rem 0; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-works dl > div {
              flex-direction: column;
              padding: 1.5rem; } }
          .section-case-inner .article-case-works dl > div dt {
            width: 30rem;
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: flex-start;
            font-size: 1.6rem;
            padding: 0 1.5rem; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-works dl > div dt {
                width: 100%;
                font-size: 1.5rem;
                padding: 0 0 1rem;
                flex-direction: column; } }
            .section-case-inner .article-case-works dl > div dt span {
              width: 5rem;
              font-size: 1.4rem;
              color: #ff884e;
              flex-shrink: 0;
              margin-right: 1rem; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-works dl > div dt span {
                  font-size: 1.2rem;
                  margin: 0; } }
          .section-case-inner .article-case-works dl > div dd {
            width: 100%;
            padding-right: 2rem;
            font-size: 1.6rem; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-works dl > div dd {
                font-size: 1.3rem;
                padding: 0; } }
            .section-case-inner .article-case-works dl > div dd ul li {
              display: flex;
              justify-content: flex-start; }
              .section-case-inner .article-case-works dl > div dd ul li:before {
                content: "・";
                color: #f89978;
                margin-right: .2rem;
                flex-shrink: 0; }
        .section-case-inner .article-case-works > ul {
          display: flex;
          align-items: center;
          justify-content: center;
          font-weight: 700; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-works > ul {
              flex-direction: column; } }
          .section-case-inner .article-case-works > ul li {
            text-align: center; }
            .section-case-inner .article-case-works > ul li > p {
              font-size: 1.6rem;
              color: #fff; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-works > ul li > p {
                  font-size: 1.4rem;
                  padding-bottom: .5rem; } }
            .section-case-inner .article-case-works > ul li figure {
              border-radius: .3rem;
              padding: 2rem 1rem;
              display: flex;
              align-items: center;
              justify-content: center;
              flex-wrap: wrap;
              background: #fff;
              width: 21rem; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-works > ul li figure {
                  margin: 0 auto;
                  padding: 1rem; } }
              .section-case-inner .article-case-works > ul li figure span {
                height: 5.6rem;
                display: flex;
                justify-content: center;
                align-items: center;
                font-size: 4rem; }
              .section-case-inner .article-case-works > ul li figure figcaption {
                width: 100%;
                text-align: center;
                font-size: 1.6rem; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-works > ul li figure figcaption {
                    font-size: 1.4rem; } }
            .section-case-inner .article-case-works > ul li.now figure span {
              color: #006666; }
            .section-case-inner .article-case-works > ul li.now figure figcaption {
              color: #7d7d7d; }
            .section-case-inner .article-case-works > ul li.bpo figure {
              width: 24rem;
              background: #006666; }
              .section-case-inner .article-case-works > ul li.bpo figure span {
                color: #fff; }
              .section-case-inner .article-case-works > ul li.bpo figure strong span {
                font-size: 5rem; }
              .section-case-inner .article-case-works > ul li.bpo figure figcaption {
                font-size: 1.8rem;
                color: #ff884e; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-works > ul li.bpo figure figcaption {
                    font-size: 1.5rem; } }
            .section-case-inner .article-case-works > ul li.future figure span {
              color: #ff884e;
              font-size: 5rem; }
            .section-case-inner .article-case-works > ul li.future figure figcaption {
              color: #006666; }
            .section-case-inner .article-case-works > ul li.arrow {
              display: flex;
              flex-direction: column;
              align-items: center;
              font-size: 1.8rem;
              line-height: 1;
              color: #fff;
              text-align: center;
              margin: 0 1rem;
              flex-shrink: 0;
              padding-top: .8rem; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-works > ul li.arrow {
                  font-size: 1.5rem;
                  flex-direction: column-reverse;
                  padding-bottom: 1rem;
                  color: #006666; } }
              .section-case-inner .article-case-works > ul li.arrow span {
                color: #006666;
                font-weight: 700;
                font-size: 3.2rem; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-works > ul li.arrow span {
                    font-size: 2.4rem;
                    transform: rotate(90deg);
                    margin-top: .5rem; } }
      .section-case-inner .article-case-result {
        background: #006666;
        color: #fff;
        padding: 3rem 4rem;
        display: flex;
        flex-direction: column;
        align-items: center; }
        @media only screen and (max-width: 767px) {
          .section-case-inner .article-case-result {
            padding: 1.5rem; } }
        .section-case-inner .article-case-result > p {
          font-size: 2rem;
          line-height: 1.4;
          text-align: center;
          font-weight: 700;
          padding-bottom: 1.5rem; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-result > p {
              font-size: 1.7rem;
              padding-bottom: 1rem; } }
        .section-case-inner .article-case-result small {
          font-size: 1.2rem;
          font-weight: 400; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-result small {
              font-size: 1rem; } }
        .section-case-inner .article-case-result-wrap {
          display: flex;
          justify-content: center;
          align-items: center; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-result-wrap {
              flex-direction: column; } }
          .section-case-inner .article-case-result-wrap > p {
            font-size: 2rem;
            line-height: 1.4;
            text-align: center;
            font-weight: 700; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-result-wrap > p {
                font-size: 1.7rem; } }
          .section-case-inner .article-case-result-wrap figure {
            max-width: 35rem;
            margin: 0 2rem; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-result-wrap figure {
                margin-bottom: 1rem; } }
          .section-case-inner .article-case-result-wrap dl {
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 3rem; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-result-wrap dl {
                margin: 1rem 0;
                flex-direction: column; } }
            .section-case-inner .article-case-result-wrap dl div {
              background: #fff;
              color: #434343;
              border-radius: .3rem;
              padding: 3rem 1.5rem;
              text-align: center;
              font-weight: 700; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-result-wrap dl div {
                  padding: 1.5rem; } }
              .section-case-inner .article-case-result-wrap dl div dt {
                color: #339999;
                font-size: 1.8rem;
                padding-bottom: 1.5rem; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-result-wrap dl div dt {
                    font-size: 1.6rem;
                    padding-bottom: .5rem; } }
              .section-case-inner .article-case-result-wrap dl div dd {
                font-size: 1.6rem; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-result-wrap dl div dd {
                    font-size: 1.4rem; } }
              .section-case-inner .article-case-result-wrap dl div.gap {
                background: none;
                color: #fff;
                font-size: 1.8rem;
                line-height: 1;
                margin: 0 1.5rem;
                padding: 0; }
                @media only screen and (max-width: 767px) {
                  .section-case-inner .article-case-result-wrap dl div.gap {
                    font-size: 1.4rem;
                    margin: 1rem 0; } }
                .section-case-inner .article-case-result-wrap dl div.gap span {
                  color: #ff884e;
                  font-size: 4rem; }
                  @media only screen and (max-width: 767px) {
                    .section-case-inner .article-case-result-wrap dl div.gap span {
                      font-size: 3rem;
                      transform: rotate(90deg); } }
        .section-case-inner .article-case-result ul {
          margin: 1rem 2rem; }
          @media only screen and (max-width: 767px) {
            .section-case-inner .article-case-result ul {
              margin: .5rem 0; } }
          .section-case-inner .article-case-result ul li {
            font-size: 1.8rem;
            font-weight: 700;
            display: flex;
            justify-content: flex-start;
            margin: .3rem 0; }
            @media only screen and (max-width: 767px) {
              .section-case-inner .article-case-result ul li {
                font-size: 1.5rem; }
                .section-case-inner .article-case-result ul li p {
                  line-height: 1.3; } }
            .section-case-inner .article-case-result ul li:before {
              content: "\f88b";
              font-family: "material symbols Outlined", cursive;
              background: #fff;
              border-radius: .3rem;
              width: 2.1rem;
              height: 2.1rem;
              font-size: 2rem;
              letter-spacing: 0;
              display: flex;
              justify-content: center;
              align-items: center;
              color: #ff884e;
              flex-shrink: 0;
              margin-right: 1rem;
              margin-top: .3rem; }
              @media only screen and (max-width: 767px) {
                .section-case-inner .article-case-result ul li:before {
                  width: 1.7rem;
                  height: 1.7rem;
                  font-size: 1.7rem;
                  margin-top: .1rem; } }
.section-message {
  padding: 12rem 2rem 15rem;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: url("../img/bg_message.jpg") no-repeat 50% 50%;
  background-size: cover;
  position: relative;
  z-index: 1; }
  @media only screen and (max-width: 767px) {
    .section-message {
      padding: 6rem 2rem; } }
  .section-message:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0.8;
    background: #006666;
    z-index: -1; }
  .section-message-header {
    padding-bottom: 4rem; }
    @media only screen and (max-width: 767px) {
      .section-message-header {
        padding-bottom: 2rem; } }
    .section-message-header-logo {
      max-width: 27rem;
      margin: 0 auto 3rem; }
    .section-message-header-ttl {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #fff;
      font-size: 2.8rem;
      line-height: 1.3; }
      @media only screen and (max-width: 767px) {
        .section-message-header-ttl {
          font-size: 1.8rem; } }
      .section-message-header-ttl strong {
        font-size: 3.6rem; }
        @media only screen and (max-width: 767px) {
          .section-message-header-ttl strong {
            font-size: 2.7rem; } }
  .section-message-inner p {
    font-size: 1.7rem;
    line-height: 2.1;
    text-align: center;
    color: #fff; }
    @media only screen and (max-width: 767px) {
      .section-message-inner p {
        font-size: 1.5rem;
        text-align: left;
        line-height: 1.6; }
        .section-message-inner p br {
          display: none; } }

.aside-contact {
  padding: 6.5rem 0 4.4rem;
  position: relative;
  z-index: 1;
  background: #eee; }
  @media only screen and (max-width: 767px) {
    .aside-contact {
      padding: 2.5rem 2rem; } }
  .aside-contact-ttl {
    font-size: 3.2rem;
    text-align: center;
    padding-bottom: 1.5rem;
    color: #339999; }
    @media only screen and (max-width: 767px) {
      .aside-contact-ttl {
        font-size: 2rem; } }
  .aside-contact > p {
    font-size: 1.6rem;
    text-align: center;
    padding-bottom: 2rem; }
    @media only screen and (max-width: 767px) {
      .aside-contact > p {
        font-size: 1.4rem;
        padding-bottom: 1.5rem; } }
  .aside-contact dl {
    display: flex;
    justify-content: center; }
    @media only screen and (max-width: 767px) {
      .aside-contact dl {
        flex-direction: column; } }
    .aside-contact dl > div {
      width: 43rem;
      margin: 0 1rem;
      background: #fff;
      border-radius: .5rem;
      padding: 1.5rem 2rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center; }
      @media only screen and (max-width: 767px) {
        .aside-contact dl > div {
          width: 100%;
          margin: 0 0 1rem;
          padding: 1.5rem 1rem; } }
      .aside-contact dl > div dt {
        font-size: 2rem;
        line-height: 1.4;
        padding-bottom: 1.5rem; }
        @media only screen and (max-width: 767px) {
          .aside-contact dl > div dt {
            font-size: 1.6rem;
            padding-bottom: .5rem; } }
      .aside-contact dl > div dd {
        height: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center; }
        .aside-contact dl > div dd a.btn {
          width: 36rem;
          height: 5rem;
          display: flex;
          justify-content: center;
          align-items: center;
          background: #339999;
          color: #fff;
          font-weight: 700;
          font-size: 1.8rem;
          border-radius: 5rem; }
          @media only screen and (max-width: 767px) {
            .aside-contact dl > div dd a.btn {
              width: 24rem;
              font-size: 1.6rem; } }
          .aside-contact dl > div dd a.btn:hover {
            background: #ff884e; }
        .aside-contact dl > div dd a.tel {
          font-weight: 500;
          font-size: 4rem;
          display: flex;
          justify-content: center;
          align-items: center;
          line-height: 1.3; }
          .aside-contact dl > div dd a.tel span {
            font-size: 3.6rem;
            line-height: 1;
            color: #339999;
            margin-right: .5rem;
            position: relative;
            top: .2rem; }
            @media only screen and (max-width: 767px) {
              .aside-contact dl > div dd a.tel span {
                font-size: 3rem; } }
          @media only screen and (max-width: 767px) {
            .aside-contact dl > div dd a.tel {
              font-size: 3.2rem; } }
        .aside-contact dl > div dd p {
          font-size: 1.4rem; }
          @media only screen and (max-width: 767px) {
            .aside-contact dl > div dd p {
              font-size: 1.2rem; } }

/* --------------------------------------
		104 footer
-------------------------------------- */
.footer {
  width: 100%;
  height: auto;
  padding: 8rem 2rem 1.5rem;
  background: #0c6a6a;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  letter-spacing: .1rem; }
  @media only screen and (max-width: 767px) {
    .footer {
      padding: 5rem 2rem 1rem; } }
  .footer-logo {
    width: 14rem;
    padding-bottom: 3.5rem; }
    @media only screen and (max-width: 767px) {
      .footer-logo {
        width: 12.6rem;
        padding-bottom: 3rem; } }
  .footer-ad {
    padding-bottom: 6rem; }
    @media only screen and (max-width: 767px) {
      .footer-ad {
        padding-bottom: 3rem; } }
    .footer-ad p {
      text-align: center; }
      @media only screen and (max-width: 767px) {
        .footer-ad p {
          line-height: 1.3;
          padding-bottom: .5rem; } }
    .footer-ad ul {
      display: flex;
      justify-content: center;
      align-items: center; }
      @media only screen and (max-width: 767px) {
        .footer-ad ul {
          flex-direction: column; } }
      .footer-ad ul li {
        display: flex;
        justify-content: center;
        align-items: center;
        margin: 0 1rem;
        font-size: 1.8rem; }
        @media only screen and (max-width: 767px) {
          .footer-ad ul li {
            font-size: 1.6rem;
            line-height: 1.3;
            margin: 0; } }
        .footer-ad ul li a {
          color: #fff; }
        .footer-ad ul li span {
          font-size: 1.8rem;
          margin-right: .5rem; }
          @media only screen and (max-width: 767px) {
            .footer-ad ul li span {
              font-size: 1.6rem;
              margin-right: .3rem; } }
  .footer-security {
    padding-bottom: 2.5rem; }
    .footer-security ul {
      display: flex;
      justify-content: center;
      align-items: center; }
      .footer-security ul li {
        margin: 0 .5rem; }
    .footer-security p {
      font-size: 1.2rem;
      line-height: 1.2;
      padding-top: 1rem;
      text-align: center; }
      @media only screen and (max-width: 767px) {
        .footer-security p {
          font-size: 1rem; } }
  .footer-copy {
    font-size: 1.2rem; }
    @media only screen and (max-width: 767px) {
      .footer-copy {
        font-size: 1rem; } }
