@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:wght@500;600&display=swap");
@keyframes nav_show {
  0% {
    transform: translateY(-101%);
  }
  100% {
    transform: translateY(0%);
  }
}
@media print {
  a:hover {
    opacity: 0.6;
  }
  .breadcrumbs-wrapper > .inner {
    max-width: 940px;
    margin: 9px auto 0;
    font-size: 90%;
  }
  .breadcrumbs-wrapper > .inner a {
    color: #000;
    text-decoration: underline;
  }
  .breadcrumbs {
    margin: 0 5px;
  }
  body.is-sticky {
    padding-top: 0;
  }
  .p-tec-footer__pagetop {
    bottom: calc(2rem + 35px);
  }
  .p-tec-footer__pagetop.is_active {
    opacity: 0;
  }
  .p-tec-footer__pagetop.is_active.show {
    opacity: 1;
    z-index: 2;
  }
  .mainContents {
    font-family: "Noto Sans JP", sans-serif;
  }
  .mainContents * {
    box-sizing: border-box;
  }
  .mainContents abbr {
    text-decoration: none;
  }
  .mainContents a:focus, .mainContents button:focus {
    outline: 2px solid #0064D2;
    outline-offset: 2px;
  }
  .mainContents sup {
    font-size: 0.5em;
    font-weight: normal;
    vertical-align: super;
    top: auto;
  }
  .mainContents section {
    position: relative;
    padding: 0 2em;
    font-size: 66.6666666667%;
  }
  .mainContents section .anchor {
    position: absolute;
    top: 0;
  }
  .mainContents section .cv_btn {
    display: flex;
    width: 16.6666666667em;
    height: 3.3333333333em;
    border-radius: 0.2777777778em;
    background: #E61E1E;
    color: #fff;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-weight: 600;
    font-size: 18px;
    letter-spacing: 0.05em;
  }
  .mainContents section#mv {
    background: url(../img/hero.png) center/auto 100% no-repeat #64AADD;
    height: 54em;
  }
  .mainContents section#mv:before, .mainContents section#mv:after {
    content: "";
    display: block;
    position: absolute;
    width: 9em;
    height: 9em;
    box-sizing: border-box;
    z-index: 1;
  }
  .mainContents section#mv:before {
    border-left: #64AADD 4.5em solid;
    border-top: #64AADD 4.5em solid;
    border-right: transparent 4.5em solid;
    border-bottom: transparent 4.5em solid;
    left: 0;
    top: 0;
  }
  .mainContents section#mv:after {
    border-right: #0064D2 4.5em solid;
    border-bottom: #0064D2 4.5em solid;
    border-left: transparent 4.5em solid;
    border-top: transparent 4.5em solid;
    right: 0;
    bottom: 0;
  }
  .mainContents section#mv .texts {
    max-width: 930px;
    height: 100%;
    margin: 0 auto;
    position: relative;
    padding-top: 5.3em;
  }
  .mainContents section#mv .texts * {
    position: relative;
    z-index: 1;
  }
  .mainContents section#mv .texts:before, .mainContents section#mv .texts:after {
    content: "";
    display: block;
    position: absolute;
    box-sizing: border-box;
  }
  .mainContents section#mv .texts:before {
    width: calc(50vw - 10.5em);
    min-width: 53.5em;
    height: 100%;
    left: calc(50% - 50vw);
    top: 0;
    background: #fff;
  }
  .mainContents section#mv .texts:after {
    width: 27em;
    height: 100%;
    left: 36em;
    top: 0;
    border-left: #fff 27em solid;
    border-top: transparent 27em solid;
    border-bottom: transparent 27em solid;
  }
  .mainContents section#mv .texts .badge {
    position: absolute;
    left: 32em;
    width: 14em;
    height: 14em;
    top: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mainContents section#mv .texts .badge:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 9.9em;
    aspect-ratio: 1;
    transform: translate(-50%, -50%) rotate(45deg);
    background: #51B9BA;
  }
  .mainContents section#mv .texts .badge .inner {
    position: relative;
    display: block;
    width: fit-content;
    color: #fff;
    font-size: 2.4em;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-align: center;
    font-feature-settings: "palt";
    line-height: 1;
  }
  .mainContents section#mv .texts .badge .inner sup {
    position: absolute;
    font-size: 0.4166666667em;
    font-weight: normal;
    right: 0;
    margin-top: -0.3em;
  }
  .mainContents section#mv .texts .h1_lead {
    font-size: 2.8em;
    line-height: 1.6071428571;
    letter-spacing: 0.05em;
    margin-bottom: 0.6785714286em;
    font-weight: 900;
  }
  .mainContents section#mv .texts .main_title {
    font-size: 6em;
    line-height: 1.0833333333;
    letter-spacing: 0;
    font-weight: 900;
    padding-bottom: 0.3666666667em;
    white-space: nowrap;
    width: 8.4166666667em;
    border-bottom: #333333 0.1666666667em solid;
    font-feature-settings: "palt";
  }
  .mainContents section#mv .texts .h1_sub {
    font-size: 2.5em;
    line-height: 1;
    letter-spacing: 0.05em;
    margin-top: 0.92em;
    font-weight: 600;
  }
  .mainContents section#mv .texts .cv_btn {
    font-size: 1.8em;
    margin-top: 2.6666666667em;
  }
  .mainContents section#mv .texts .note {
    margin-top: 3.1818181818em;
    font-size: 1.1em;
    line-height: 1;
  }
  .mainContents section#nav_area {
    height: 9em;
    padding: 0;
    z-index: 2;
  }
  .mainContents section#nav_area .inner {
    display: block;
    position: absolute;
    height: 9em;
    width: 100%;
    background: #E2E8EC;
    padding: 0 2em;
    border-top: #A3B6C2 1px solid;
    border-bottom: #A3B6C2 1px solid;
  }
  .mainContents section#nav_area .nav_p {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 6em;
    margin: 1.5em auto 0;
    width: 100%;
    max-width: 930px;
  }
  .mainContents section#nav_area .nav_p li {
    display: block;
    width: fit-content;
    height: 6em;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mainContents section#nav_area .nav_p li a {
    width: fit-content;
    height: 4em;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #333333;
    font-size: 1.5em;
    font-weight: 600;
    position: relative;
  }
  .mainContents section#nav_area .nav_p li a:after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 5px);
    bottom: 0;
    width: 10px;
    height: 5px;
    box-sizing: border-box;
    border-top: #51B9BA 5px solid;
    border-left: transparent 5px solid;
    border-right: transparent 5px solid;
  }
  .mainContents section#nav_area.fixed .inner {
    position: fixed;
    height: 5em;
    top: 0;
    left: 0;
    animation: nav_show 0.5s ease both;
  }
  .mainContents section#nav_area.fixed .nav_p {
    height: 5em;
    margin-top: 0;
  }
  .mainContents section#nav_area.fixed .nav_p li {
    height: 5em;
  }
  .mainContents section#nav_area.fixed .nav_p li a {
    height: 3.3333333333em;
  }
  .mainContents section#nav_area.fixed .nav_p li a:after {
    bottom: 0.4em;
  }
  .mainContents section.cv_float {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 5px;
    z-index: 3;
    background: #93C3E7;
    color: #333333;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
    border-top: #64AADD 1px solid;
  }
  .mainContents section.cv_float:before {
    content: "";
    display: block;
    position: absolute;
    width: 26px;
    height: 26px;
    box-sizing: border-box;
    z-index: 1;
    border-left: #0064D2 13px solid;
    border-top: #0064D2 13px solid;
    border-right: transparent 13px solid;
    border-bottom: transparent 13px solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_float .text {
    width: fit-content;
    margin-right: 20px;
    font-weight: 600;
  }
  .mainContents section.cv_float .cv_btn {
    width: 14em;
    height: 2.6666666667em;
    border-radius: 5px;
    font-size: 15px;
  }
  .mainContents section.cv_float.show {
    opacity: 1;
    pointer-events: auto;
  }
  .mainContents section .section_title {
    font-size: 3.2em;
    line-height: 1.5625;
    text-align: center;
    font-weight: 600;
  }
  .mainContents section .inner_wrap {
    max-width: 930px;
    width: 100%;
    margin: 0 auto;
  }
  .mainContents section img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  .mainContents section .text_link {
    display: block;
    font-size: 1.7em;
    width: fit-content;
    margin: 0 auto;
    line-height: 30px;
    text-decoration: underline;
    color: #333333;
    font-weight: 600;
  }
  .mainContents section#intro {
    padding-top: 65px;
  }
  .mainContents section#intro .flex_wrap {
    margin: 35px auto -6.5em;
    background: #fff;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    position: relative;
  }
  .mainContents section#intro .flex_wrap .col {
    max-width: 210px;
    padding: 0;
  }
  .mainContents section#intro .flex_wrap .col .text {
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 600;
    text-align: center;
    margin-bottom: 0.8823529412em;
  }
  .mainContents section#intro .flex_wrap .col .pic {
    max-width: 150px;
    margin: 0 auto;
  }
  .mainContents section#intro .flex_wrap .col .text2 {
    margin: 1.25em auto 0;
    font-size: 1.6em;
    line-height: 1.875;
    font-weight: 500;
    color: #0064D2;
    text-align: center;
    width: fit-content;
    position: relative;
    padding: 1.5625em 0 4px;
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:before, .mainContents section#intro .flex_wrap .col .text2:after {
    content: "";
    display: block;
    position: absolute;
  }
  .mainContents section#intro .flex_wrap .col .text2:before {
    font-size: 1.25em;
    top: 0;
    left: calc(50% - 1em);
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:after {
    width: 100%;
    height: 1px;
    background: #64AADD;
  }
  .mainContents section#intro .border_text {
    padding: 96px 0 43px;
    width: 112.9032258065%;
    margin-left: -6.4516129032%;
    border: #0064D2 1px solid;
    text-align: center;
    color: #0064D2;
    font-size: 3em;
    line-height: 1.5;
    font-weight: 500;
    position: relative;
  }
  .mainContents section#intro .border_text:before, .mainContents section#intro .border_text:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#intro .border_text:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#intro .border_text:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
  .mainContents section#intro .text_link {
    margin-top: 45px;
  }
  .mainContents section .text {
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 400;
    margin: 0;
  }
  .mainContents section .text strong {
    font-weight: 600;
  }
  .mainContents section .text strong.marker {
    text-decoration: underline;
    text-decoration-color: rgba(250, 215, 55, 0.5);
    text-decoration-thickness: 1em;
    text-underline-offset: -0.5em;
  }
  .mainContents section .text.center {
    text-align: center;
  }
  .mainContents section .note {
    font-size: 1.3em;
    line-height: 1.5384615385;
    margin: 0;
  }
  .mainContents section .ac_set .ac_wrap {
    overflow: hidden;
    transition: height 0.3s ease;
  }
  .mainContents section .ac_set:not(.active) .ac_btn .icon {
    display: none !important;
  }
  .mainContents section .ac_set.active .ac_wrap {
    height: 0;
  }
  .mainContents section .ac_set:not(.open) a:not(.ac_btn) {
    pointer-events: none;
    user-select: none;
    display: none;
  }
  .mainContents section#what {
    margin: 90px auto 0;
    padding: 6.4em 5.9em 7.4em;
    position: relative;
    border: #0064D2 1px solid;
    background: #EFF6FC;
    max-width: 1050px;
  }
  .mainContents section#what .section_title {
    margin-bottom: 1.09375em;
  }
  .mainContents section#what .pic + .text {
    margin-top: 30px;
  }
  .mainContents section#what .note {
    margin-top: 5px;
    font-size: 1.1em;
    line-height: 20px;
  }
  .mainContents section#what .ac_set {
    margin-top: 20px;
  }
  .mainContents section#what .ac_inner {
    padding: 76px 0 75px;
  }
  .mainContents section#what .ac_inner .section_title {
    margin-bottom: 0.53125em;
  }
  .mainContents section#what .ac_inner .text {
    margin-bottom: 60px;
  }
  .mainContents section#what .ac_btn {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    width: 10.5882352941em;
    height: 3.5294117647em;
    border: #333333 2px solid;
    border-radius: 5px;
    font-size: 1.7em;
    line-height: 1.7647058824em;
    font-weight: 600;
    padding-left: 23px;
    margin: 0 auto;
    color: #333333;
  }
  .mainContents section#what .ac_btn .icon {
    display: block;
    position: absolute;
    right: 0.7647058824em;
    top: 0.7647058824em;
    width: 1.7647058824em;
    height: 1.7647058824em;
  }
  .mainContents section#what .ac_btn .icon:before, .mainContents section#what .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    width: 1.1764705882em;
    height: 2px;
    background: #333333;
    left: calc(50% - 0.5882352941em);
    top: calc(50% - 1px);
    transform-origin: center;
  }
  .mainContents section#what .ac_btn .icon:after {
    transform: rotate(90deg);
  }
  .mainContents section#what .ac_btn.btn_close {
    display: none;
  }
  .mainContents section#what .ac_btn.btn_close .icon:after {
    opacity: 0;
  }
  .mainContents section#what .ac_btn.btn_open {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_close {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_open {
    display: none;
  }
  .mainContents section.cv_section {
    background: #93C3E7;
    color: #333333;
    text-align: center;
    padding: 65px 0 75px;
  }
  .mainContents section.cv_section:before, .mainContents section.cv_section:after {
    content: "";
    display: block;
    position: absolute;
    width: 150px;
    height: 150px;
    box-sizing: border-box;
    z-index: 1;
  }
  .mainContents section.cv_section:before {
    border-left: #0064D2 75px solid;
    border-top: #0064D2 75px solid;
    border-right: transparent 75px solid;
    border-bottom: transparent 75px solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_section:after {
    border-right: #fff 75px solid;
    border-bottom: #fff 75px solid;
    border-left: transparent 75px solid;
    border-top: transparent 75px solid;
    right: 0;
    bottom: 0;
  }
  .mainContents section.cv_section .text {
    margin-top: 20px;
  }
  .mainContents section.cv_section .cv_btn {
    margin: 2.2222222222em auto 0;
  }
  .mainContents section.section {
    padding-top: 99px;
  }
  .mainContents section.section .section_title {
    font-size: 1em;
    text-align: center;
    padding-bottom: 30px;
    position: relative;
  }
  .mainContents section.section .section_title:after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 45px);
    bottom: 0;
    width: 90px;
    height: 6px;
    background: #333333;
  }
  .mainContents section.section .section_title .en {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    display: block;
    font-size: 1.5em;
    line-height: 2;
    color: #E61E1E;
    font-weight: 700;
    letter-spacing: 0.4em;
    padding-left: 0.4em;
    margin-bottom: 1.3333333333em;
  }
  .mainContents section.section .section_title .jp_s {
    display: block;
    font-size: 1.9em;
    line-height: 1.5789473684;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 0.2631578947em;
  }
  .mainContents section.section .section_title .jp {
    display: block;
    font-size: 4.4em;
    line-height: 1.3636363636;
    font-weight: 600;
    letter-spacing: 0;
  }
  .mainContents section.section .section_title + .text.center {
    margin-top: 30px;
  }
  .mainContents section#features {
    margin-top: 30px;
    margin-bottom: 120px;
  }
  .mainContents section#features .section_title {
    margin-bottom: 60px;
  }
  .mainContents section#features .features .row {
    width: 100%;
    position: relative;
    display: block;
    margin: 0;
    min-height: 27em;
  }
  .mainContents section#features .features .row .row_title {
    font-weight: 500;
    font-size: 2.8em;
    line-height: 1.6071428571;
    color: #0064D2;
    padding-left: 3.5714285714em;
    position: relative;
    margin-bottom: 1.0714285714em;
    width: 51.6129032258%;
    max-width: 450px;
  }
  .mainContents section#features .features .row .row_title .num {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 500;
    display: block;
    position: absolute;
    left: 0;
    top: calc(50% - 1.09375em);
    width: 2.1875em;
    text-align: center;
    height: 2.1875em;
    line-height: 2.1875em;
    font-size: 1.1428571429em;
    border: #0064D2 1px solid;
  }
  .mainContents section#features .features .row .row_title .num:before, .mainContents section#features .features .row .row_title .num:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#features .features .row .row_title .num:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#features .features .row .row_title .num:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
  .mainContents section#features .features .row .text {
    width: 51.6129032258%;
    max-width: 450px;
  }
  .mainContents section#features .features .row .pic {
    position: absolute;
    right: 0;
    top: 0;
    width: 45.1612903226%;
  }
  .mainContents section#features .features .row + .row {
    margin-top: 60px;
  }
  .mainContents section#merit {
    padding-bottom: 20px;
  }
  .mainContents section#merit .merit_table {
    margin: 60px auto 0;
    width: 100%;
  }
  .mainContents section#merit .merit_table th, .mainContents section#merit .merit_table td {
    border: #B3B3B3 1px solid;
  }
  .mainContents section#merit .merit_table th.blank, .mainContents section#merit .merit_table td.blank {
    border: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th {
    color: #fff;
    text-align: center;
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 600;
    padding: 0.8823529412em;
    border: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th:nth-child(2) {
    background: #BFBFBF;
    color: #333333;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th:nth-child(3) {
    background: #93C3E7;
    color: #333333;
    border-left: #fff 1px solid;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) th {
    text-align: center;
    font-size: 1.7em;
    line-height: 1.1764705882;
    font-weight: 600;
    padding: 2.9411764706em 0;
    width: 3.5294117647em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td {
    padding: 4.5em;
    vertical-align: top;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .main_text {
    display: block;
    font-size: 2.1em;
    line-height: 1.4285714286;
    font-weight: 600;
    margin-bottom: 0.7142857143em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .text {
    display: block;
    font-size: 1.7em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(2) {
    width: 30em;
    padding-bottom: 12em;
    background: url(../img/merit_label.png) center calc(100% - 4.6em)/9em auto no-repeat rgba(179, 179, 179, 0.1);
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) {
    background-position: calc(100% - 3em) calc(100% - 3em);
    background-size: 27em auto;
    background-repeat: no-repeat;
    background-color: #EFF6FC;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) .main_text {
    color: #0064D2;
  }
  .mainContents section#merit .merit_table tr:nth-child(2) td:nth-child(3) {
    background-image: url(../img/merit_color.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(3) td:nth-child(3) {
    background-image: url(../img/merit_size.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(4) td:nth-child(3) {
    background-image: url(../img/merit_position.png);
  }
  .mainContents section#merit .text_link {
    margin-top: 60px;
  }
  .mainContents section#merit .note {
    margin-top: 20px;
    text-align: center;
  }
  .mainContents section#cases {
    padding-bottom: 120px;
  }
  .mainContents section#cases .cases {
    margin: 60px auto 0;
  }
  .mainContents section#cases .cases .row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin: 0;
    position: relative;
  }
  .mainContents section#cases .cases .row .pic {
    width: 32.2580645161%;
  }
  .mainContents section#cases .cases .row .texts {
    width: 61.2903225806%;
  }
  .mainContents section#cases .cases .row .texts .category {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    font-size: 1.5em;
    line-height: 2;
    margin: 0 0 12px;
  }
  .mainContents section#cases .cases .row .texts .category .tag {
    font-weight: 600;
    display: flex;
    width: fit-content;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 10px;
    font-size: 0.9333333333em;
    letter-spacing: 0.05em;
    height: 1.7857142857em;
    background: #FAD737;
    margin-right: 15px;
  }
  .mainContents section#cases .cases .row .texts .row_title {
    font-weight: 500;
    font-size: 2.1em;
    line-height: 1.6666666667;
    margin: 0 0 15px;
  }
  .mainContents section#cases .cases .row + .row {
    margin-top: 60px;
  }
  .mainContents section#flow .steps {
    margin: 60px auto 0;
  }
  .mainContents section#flow .steps .row {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    margin: 0;
    position: relative;
    border: #64AADD 1px solid;
    background: #EFF6FC;
  }
  .mainContents section#flow .steps .row .row_title {
    width: 25.8064516129%;
    min-width: fit-content;
    color: #0064D2;
    background: #E0EEF8;
    border: #fff 1px solid;
    padding: 28px;
    font-size: 1.9em;
    line-height: 1.5789473684;
    font-weight: 600;
  }
  .mainContents section#flow .steps .row .row_title:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 12px;
    aspect-ratio: 1;
    box-sizing: border-box;
    border-left: #fff 6px solid;
    border-top: #fff 6px solid;
    border-right: transparent 6px solid;
    border-bottom: transparent 6px solid;
  }
  .mainContents section#flow .steps .row .text {
    border: #fff 1px solid;
    border-left: none;
    padding: 28px;
    font-size: 1.5em;
    line-height: 2;
    width: 74.1935483871%;
  }
  .mainContents section#flow .steps .row + .row {
    margin-top: 30px;
  }
  .mainContents section#flow .steps .row + .row:before {
    font-size: 10px;
    content: "";
    display: block;
    position: absolute;
    top: -2.7em;
    left: calc(50% - 1em);
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#faq {
    padding-bottom: 118px;
  }
  .mainContents section#faq .section_title {
    margin: 0 auto 67px;
  }
  .mainContents section#faq .faq {
    border-top: #64AADD 1px solid;
    border-bottom: #64AADD 1px solid;
    padding: 2px 0;
  }
  .mainContents section#faq .faq .ac_set {
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set .ac_btn {
    font-size: 1.9em;
    line-height: 1.5789473684;
    padding: 1.5789473684em 0;
    font-weight: 600;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    color: #333333;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon_q {
    width: 2.0454545455em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 1.1578947368em;
    line-height: 1.3636363636;
    color: #0064D2;
    display: block;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon {
    position: absolute;
    width: 20px;
    height: 20px;
    right: 20px;
    top: calc(50% - 10px);
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:before, .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 9px;
    width: 100%;
    height: 2px;
    background: #333333;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    transform-origin: center;
    transform: rotate(90deg);
  }
  .mainContents section#faq .faq .ac_set .ac_inner {
    padding: 0 45px 50px 0;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .icon_a {
    width: 2.0454545455em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 2.2em;
    line-height: 1.3636363636;
    color: #51B9BA;
    display: block;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .inner {
    width: calc(100% - 2.6470588235em);
  }
  .mainContents section#faq .faq .ac_set .ac_inner .cv_btn {
    background: transparent;
    font-size: 1.5em;
    width: 14em;
    height: 3em;
    border: #333333 1px solid;
    margin: 25px 0 0;
    color: #333333;
  }
  .mainContents section#faq .faq .ac_set:first-child {
    border-top: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set.open .ac_btn .icon:after {
    opacity: 0;
  }
}
@media screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
  a:hover {
    opacity: 0.6;
  }
  .breadcrumbs-wrapper > .inner {
    max-width: 940px;
    margin: 9px auto 0;
    font-size: 90%;
  }
  .breadcrumbs-wrapper > .inner a {
    color: #000;
    text-decoration: underline;
  }
  .breadcrumbs {
    margin: 0 5px;
  }
  body.is-sticky {
    padding-top: 0;
  }
  .p-tec-footer__pagetop {
    bottom: calc(2rem + 35px);
  }
  .p-tec-footer__pagetop.is_active {
    opacity: 0;
  }
  .p-tec-footer__pagetop.is_active.show {
    opacity: 1;
    z-index: 2;
  }
  .mainContents {
    font-family: "Noto Sans JP", sans-serif;
  }
  .mainContents * {
    box-sizing: border-box;
  }
  .mainContents abbr {
    text-decoration: none;
  }
  .mainContents a:focus, .mainContents button:focus {
    outline: 2px solid #0064D2;
    outline-offset: 2px;
  }
  .mainContents sup {
    font-size: 0.5em;
    font-weight: normal;
    vertical-align: super;
    top: auto;
  }
  .mainContents section {
    position: relative;
    padding: 0 2em;
    font-size: 66.6666666667%;
  }
}
@media screen and (min-width: 769px) and (max-width: 970px) {
  .mainContents section {
    font-size: 1.0309278351vw;
    font-size: 56.25%;
  }
}
@media screen and (min-width: 769px) {
  .mainContents section .anchor {
    position: absolute;
    top: 0;
  }
  .mainContents section .cv_btn {
    display: flex;
    width: 16.6666666667em;
    height: 3.3333333333em;
    border-radius: 0.2777777778em;
    background: #E61E1E;
    color: #fff;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-weight: 600;
    font-size: 18px;
    letter-spacing: 0.05em;
  }
  .mainContents section#mv {
    background: url(../img/hero.png) center/auto 100% no-repeat #64AADD;
    height: 54em;
  }
  .mainContents section#mv:before, .mainContents section#mv:after {
    content: "";
    display: block;
    position: absolute;
    width: 9em;
    height: 9em;
    box-sizing: border-box;
    z-index: 1;
  }
  .mainContents section#mv:before {
    border-left: #64AADD 4.5em solid;
    border-top: #64AADD 4.5em solid;
    border-right: transparent 4.5em solid;
    border-bottom: transparent 4.5em solid;
    left: 0;
    top: 0;
  }
  .mainContents section#mv:after {
    border-right: #0064D2 4.5em solid;
    border-bottom: #0064D2 4.5em solid;
    border-left: transparent 4.5em solid;
    border-top: transparent 4.5em solid;
    right: 0;
    bottom: 0;
  }
  .mainContents section#mv .texts {
    max-width: 930px;
    height: 100%;
    margin: 0 auto;
    position: relative;
    padding-top: 5.3em;
  }
  .mainContents section#mv .texts * {
    position: relative;
    z-index: 1;
  }
  .mainContents section#mv .texts:before, .mainContents section#mv .texts:after {
    content: "";
    display: block;
    position: absolute;
    box-sizing: border-box;
  }
  .mainContents section#mv .texts:before {
    width: calc(50vw - 10.5em);
    min-width: 53.5em;
    height: 100%;
    left: calc(50% - 50vw);
    top: 0;
    background: #fff;
  }
}
@media screen and (min-width: 769px) and (max-width: 1280px) {
  .mainContents section#mv .texts:before {
    left: -17.5em;
  }
}
@media screen and (min-width: 769px) {
  .mainContents section#mv .texts:after {
    width: 27em;
    height: 100%;
    left: 36em;
    top: 0;
    border-left: #fff 27em solid;
    border-top: transparent 27em solid;
    border-bottom: transparent 27em solid;
  }
  .mainContents section#mv .texts .badge {
    position: absolute;
    left: 32em;
    width: 14em;
    height: 14em;
    top: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mainContents section#mv .texts .badge:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 9.9em;
    aspect-ratio: 1;
    transform: translate(-50%, -50%) rotate(45deg);
    background: #51B9BA;
  }
  .mainContents section#mv .texts .badge .inner {
    position: relative;
    display: block;
    width: fit-content;
    color: #fff;
    font-size: 2.4em;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-align: center;
    font-feature-settings: "palt";
    line-height: 1;
  }
  .mainContents section#mv .texts .badge .inner sup {
    position: absolute;
    font-size: 0.4166666667em;
    font-weight: normal;
    right: 0;
    margin-top: -0.3em;
  }
  .mainContents section#mv .texts .h1_lead {
    font-size: 2.8em;
    line-height: 1.6071428571;
    letter-spacing: 0.05em;
    margin-bottom: 0.6785714286em;
    font-weight: 900;
  }
  .mainContents section#mv .texts .main_title {
    font-size: 6em;
    line-height: 1.0833333333;
    letter-spacing: 0;
    font-weight: 900;
    padding-bottom: 0.3666666667em;
    white-space: nowrap;
    width: 8.4166666667em;
    border-bottom: #333333 0.1666666667em solid;
    font-feature-settings: "palt";
  }
  .mainContents section#mv .texts .h1_sub {
    font-size: 2.5em;
    line-height: 1;
    letter-spacing: 0.05em;
    margin-top: 0.92em;
    font-weight: 600;
  }
  .mainContents section#mv .texts .cv_btn {
    font-size: 1.8em;
    margin-top: 2.6666666667em;
  }
  .mainContents section#mv .texts .note {
    margin-top: 3.1818181818em;
    font-size: 1.1em;
    line-height: 1;
  }
  .mainContents section#nav_area {
    height: 9em;
    padding: 0;
    z-index: 2;
  }
  .mainContents section#nav_area .inner {
    display: block;
    position: absolute;
    height: 9em;
    width: 100%;
    background: #E2E8EC;
    padding: 0 2em;
    border-top: #A3B6C2 1px solid;
    border-bottom: #A3B6C2 1px solid;
  }
  .mainContents section#nav_area .nav_p {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 6em;
    margin: 1.5em auto 0;
    width: 100%;
    max-width: 930px;
  }
  .mainContents section#nav_area .nav_p li {
    display: block;
    width: fit-content;
    height: 6em;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mainContents section#nav_area .nav_p li a {
    width: fit-content;
    height: 4em;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #333333;
    font-size: 1.5em;
    font-weight: 600;
    position: relative;
  }
  .mainContents section#nav_area .nav_p li a:after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 5px);
    bottom: 0;
    width: 10px;
    height: 5px;
    box-sizing: border-box;
    border-top: #51B9BA 5px solid;
    border-left: transparent 5px solid;
    border-right: transparent 5px solid;
  }
  .mainContents section#nav_area.fixed .inner {
    position: fixed;
    height: 5em;
    top: 0;
    left: 0;
    animation: nav_show 0.5s ease both;
  }
  .mainContents section#nav_area.fixed .nav_p {
    height: 5em;
    margin-top: 0;
  }
  .mainContents section#nav_area.fixed .nav_p li {
    height: 5em;
  }
  .mainContents section#nav_area.fixed .nav_p li a {
    height: 3.3333333333em;
  }
  .mainContents section#nav_area.fixed .nav_p li a:after {
    bottom: 0.4em;
  }
}
@media screen and (min-width: 769px) {
  .mainContents section.cv_float {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 5px;
    z-index: 3;
    background: #93C3E7;
    color: #333333;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
    border-top: #64AADD 1px solid;
  }
  .mainContents section.cv_float:before {
    content: "";
    display: block;
    position: absolute;
    width: 26px;
    height: 26px;
    box-sizing: border-box;
    z-index: 1;
    border-left: #0064D2 13px solid;
    border-top: #0064D2 13px solid;
    border-right: transparent 13px solid;
    border-bottom: transparent 13px solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_float .text {
    width: fit-content;
    margin-right: 20px;
    font-weight: 600;
  }
  .mainContents section.cv_float .cv_btn {
    width: 14em;
    height: 2.6666666667em;
    border-radius: 5px;
    font-size: 15px;
  }
  .mainContents section.cv_float.show {
    opacity: 1;
    pointer-events: auto;
  }
  .mainContents section .section_title {
    font-size: 3.2em;
    line-height: 1.5625;
    text-align: center;
    font-weight: 600;
  }
  .mainContents section .inner_wrap {
    max-width: 930px;
    width: 100%;
    margin: 0 auto;
  }
  .mainContents section img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  .mainContents section .text_link {
    display: block;
    font-size: 1.7em;
    width: fit-content;
    margin: 0 auto;
    line-height: 30px;
    text-decoration: underline;
    color: #333333;
    font-weight: 600;
  }
  .mainContents section#intro {
    padding-top: 65px;
  }
  .mainContents section#intro .flex_wrap {
    margin: 35px auto -6.5em;
    background: #fff;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    position: relative;
  }
  .mainContents section#intro .flex_wrap .col {
    max-width: 210px;
    padding: 0;
  }
  .mainContents section#intro .flex_wrap .col .text {
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 600;
    text-align: center;
    margin-bottom: 0.8823529412em;
  }
  .mainContents section#intro .flex_wrap .col .pic {
    max-width: 150px;
    margin: 0 auto;
  }
  .mainContents section#intro .flex_wrap .col .text2 {
    margin: 1.25em auto 0;
    font-size: 1.6em;
    line-height: 1.875;
    font-weight: 500;
    color: #0064D2;
    text-align: center;
    width: fit-content;
    position: relative;
    padding: 1.5625em 0 4px;
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:before, .mainContents section#intro .flex_wrap .col .text2:after {
    content: "";
    display: block;
    position: absolute;
  }
  .mainContents section#intro .flex_wrap .col .text2:before {
    font-size: 1.25em;
    top: 0;
    left: calc(50% - 1em);
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:after {
    width: 100%;
    height: 1px;
    background: #64AADD;
  }
  .mainContents section#intro .border_text {
    padding: 96px 0 43px;
    width: 112.9032258065%;
    margin-left: -6.4516129032%;
    border: #0064D2 1px solid;
    text-align: center;
    color: #0064D2;
    font-size: 3em;
    line-height: 1.5;
    font-weight: 500;
    position: relative;
  }
  .mainContents section#intro .border_text:before, .mainContents section#intro .border_text:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#intro .border_text:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#intro .border_text:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1050px) {
  .mainContents section#intro .border_text {
    width: 100vw;
    margin-left: calc(50% - 50vw);
  }
}
@media screen and (min-width: 769px) {
  .mainContents section#intro .text_link {
    margin-top: 45px;
  }
  .mainContents section .text {
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 400;
    margin: 0;
  }
  .mainContents section .text strong {
    font-weight: 600;
  }
  .mainContents section .text strong.marker {
    text-decoration: underline;
    text-decoration-color: rgba(250, 215, 55, 0.5);
    text-decoration-thickness: 1em;
    text-underline-offset: -0.5em;
  }
  .mainContents section .text.center {
    text-align: center;
  }
  .mainContents section .note {
    font-size: 1.3em;
    line-height: 1.5384615385;
    margin: 0;
  }
  .mainContents section .ac_set .ac_wrap {
    overflow: hidden;
    transition: height 0.3s ease;
  }
  .mainContents section .ac_set:not(.active) .ac_btn .icon {
    display: none !important;
  }
  .mainContents section .ac_set.active .ac_wrap {
    height: 0;
  }
  .mainContents section .ac_set:not(.open) a:not(.ac_btn) {
    pointer-events: none;
    user-select: none;
    display: none;
  }
  .mainContents section#what {
    margin: 90px auto 0;
    padding: 6.4em 5.9em 7.4em;
    position: relative;
    border: #0064D2 1px solid;
    background: #EFF6FC;
    max-width: 1050px;
  }
  .mainContents section#what .section_title {
    margin-bottom: 1.09375em;
  }
  .mainContents section#what .pic + .text {
    margin-top: 30px;
  }
  .mainContents section#what .note {
    margin-top: 5px;
    font-size: 1.1em;
    line-height: 20px;
  }
  .mainContents section#what .ac_set {
    margin-top: 20px;
  }
  .mainContents section#what .ac_inner {
    padding: 76px 0 75px;
  }
  .mainContents section#what .ac_inner .section_title {
    margin-bottom: 0.53125em;
  }
  .mainContents section#what .ac_inner .text {
    margin-bottom: 60px;
  }
  .mainContents section#what .ac_btn {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    width: 10.5882352941em;
    height: 3.5294117647em;
    border: #333333 2px solid;
    border-radius: 5px;
    font-size: 1.7em;
    line-height: 1.7647058824em;
    font-weight: 600;
    padding-left: 23px;
    margin: 0 auto;
    color: #333333;
  }
  .mainContents section#what .ac_btn .icon {
    display: block;
    position: absolute;
    right: 0.7647058824em;
    top: 0.7647058824em;
    width: 1.7647058824em;
    height: 1.7647058824em;
  }
  .mainContents section#what .ac_btn .icon:before, .mainContents section#what .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    width: 1.1764705882em;
    height: 2px;
    background: #333333;
    left: calc(50% - 0.5882352941em);
    top: calc(50% - 1px);
    transform-origin: center;
  }
  .mainContents section#what .ac_btn .icon:after {
    transform: rotate(90deg);
  }
  .mainContents section#what .ac_btn.btn_close {
    display: none;
  }
  .mainContents section#what .ac_btn.btn_close .icon:after {
    opacity: 0;
  }
  .mainContents section#what .ac_btn.btn_open {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_close {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_open {
    display: none;
  }
  .mainContents section.cv_section {
    background: #93C3E7;
    color: #333333;
    text-align: center;
    padding: 65px 0 75px;
  }
  .mainContents section.cv_section:before, .mainContents section.cv_section:after {
    content: "";
    display: block;
    position: absolute;
    width: 150px;
    height: 150px;
    box-sizing: border-box;
    z-index: 1;
  }
  .mainContents section.cv_section:before {
    border-left: #0064D2 75px solid;
    border-top: #0064D2 75px solid;
    border-right: transparent 75px solid;
    border-bottom: transparent 75px solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_section:after {
    border-right: #fff 75px solid;
    border-bottom: #fff 75px solid;
    border-left: transparent 75px solid;
    border-top: transparent 75px solid;
    right: 0;
    bottom: 0;
  }
  .mainContents section.cv_section .text {
    margin-top: 20px;
  }
  .mainContents section.cv_section .cv_btn {
    margin: 2.2222222222em auto 0;
  }
  .mainContents section.section {
    padding-top: 99px;
  }
  .mainContents section.section .section_title {
    font-size: 1em;
    text-align: center;
    padding-bottom: 30px;
    position: relative;
  }
  .mainContents section.section .section_title:after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 45px);
    bottom: 0;
    width: 90px;
    height: 6px;
    background: #333333;
  }
  .mainContents section.section .section_title .en {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    display: block;
    font-size: 1.5em;
    line-height: 2;
    color: #E61E1E;
    font-weight: 700;
    letter-spacing: 0.4em;
    padding-left: 0.4em;
    margin-bottom: 1.3333333333em;
  }
  .mainContents section.section .section_title .jp_s {
    display: block;
    font-size: 1.9em;
    line-height: 1.5789473684;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 0.2631578947em;
  }
  .mainContents section.section .section_title .jp {
    display: block;
    font-size: 4.4em;
    line-height: 1.3636363636;
    font-weight: 600;
    letter-spacing: 0;
  }
  .mainContents section.section .section_title + .text.center {
    margin-top: 30px;
  }
  .mainContents section#features {
    margin-top: 30px;
    margin-bottom: 120px;
  }
  .mainContents section#features .section_title {
    margin-bottom: 60px;
  }
  .mainContents section#features .features .row {
    width: 100%;
    position: relative;
    display: block;
    margin: 0;
    min-height: 27em;
  }
  .mainContents section#features .features .row .row_title {
    font-weight: 500;
    font-size: 2.8em;
    line-height: 1.6071428571;
    color: #0064D2;
    padding-left: 3.5714285714em;
    position: relative;
    margin-bottom: 1.0714285714em;
    width: 51.6129032258%;
    max-width: 450px;
  }
  .mainContents section#features .features .row .row_title .num {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 500;
    display: block;
    position: absolute;
    left: 0;
    top: calc(50% - 1.09375em);
    width: 2.1875em;
    text-align: center;
    height: 2.1875em;
    line-height: 2.1875em;
    font-size: 1.1428571429em;
    border: #0064D2 1px solid;
  }
  .mainContents section#features .features .row .row_title .num:before, .mainContents section#features .features .row .row_title .num:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#features .features .row .row_title .num:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#features .features .row .row_title .num:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
  .mainContents section#features .features .row .text {
    width: 51.6129032258%;
    max-width: 450px;
  }
  .mainContents section#features .features .row .pic {
    position: absolute;
    right: 0;
    top: 0;
    width: 45.1612903226%;
  }
  .mainContents section#features .features .row + .row {
    margin-top: 60px;
  }
  .mainContents section#merit {
    padding-bottom: 20px;
  }
  .mainContents section#merit .merit_table {
    margin: 60px auto 0;
    width: 100%;
  }
  .mainContents section#merit .merit_table th, .mainContents section#merit .merit_table td {
    border: #B3B3B3 1px solid;
  }
  .mainContents section#merit .merit_table th.blank, .mainContents section#merit .merit_table td.blank {
    border: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th {
    color: #fff;
    text-align: center;
    font-size: 1.7em;
    line-height: 1.7647058824;
    font-weight: 600;
    padding: 0.8823529412em;
    border: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th:nth-child(2) {
    background: #BFBFBF;
    color: #333333;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) th:nth-child(3) {
    background: #93C3E7;
    color: #333333;
    border-left: #fff 1px solid;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) th {
    text-align: center;
    font-size: 1.7em;
    line-height: 1.1764705882;
    font-weight: 600;
    padding: 2.9411764706em 0;
    width: 3.5294117647em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td {
    padding: 4.5em;
    vertical-align: top;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .main_text {
    display: block;
    font-size: 2.1em;
    line-height: 1.4285714286;
    font-weight: 600;
    margin-bottom: 0.7142857143em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .text {
    display: block;
    font-size: 1.7em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(2) {
    width: 30em;
    padding-bottom: 12em;
    background: url(../img/merit_label.png) center calc(100% - 4.6em)/9em auto no-repeat rgba(179, 179, 179, 0.1);
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) {
    background-position: calc(100% - 3em) calc(100% - 3em);
    background-size: 27em auto;
    background-repeat: no-repeat;
    background-color: #EFF6FC;
  }
}
@media screen and (min-width: 769px) and (max-width: 840px) {
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) {
    background-size: 40% auto;
  }
}
@media screen and (min-width: 769px) {
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) .main_text {
    color: #0064D2;
  }
  .mainContents section#merit .merit_table tr:nth-child(2) td:nth-child(3) {
    background-image: url(../img/merit_color.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(3) td:nth-child(3) {
    background-image: url(../img/merit_size.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(4) td:nth-child(3) {
    background-image: url(../img/merit_position.png);
  }
  .mainContents section#merit .text_link {
    margin-top: 60px;
  }
  .mainContents section#merit .note {
    margin-top: 20px;
    text-align: center;
  }
  .mainContents section#cases {
    padding-bottom: 120px;
  }
  .mainContents section#cases .cases {
    margin: 60px auto 0;
  }
  .mainContents section#cases .cases .row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin: 0;
    position: relative;
  }
  .mainContents section#cases .cases .row .pic {
    width: 32.2580645161%;
  }
  .mainContents section#cases .cases .row .texts {
    width: 61.2903225806%;
  }
  .mainContents section#cases .cases .row .texts .category {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    font-size: 1.5em;
    line-height: 2;
    margin: 0 0 12px;
  }
  .mainContents section#cases .cases .row .texts .category .tag {
    font-weight: 600;
    display: flex;
    width: fit-content;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 10px;
    font-size: 0.9333333333em;
    letter-spacing: 0.05em;
    height: 1.7857142857em;
    background: #FAD737;
    margin-right: 15px;
  }
  .mainContents section#cases .cases .row .texts .row_title {
    font-weight: 500;
    font-size: 2.1em;
    line-height: 1.6666666667;
    margin: 0 0 15px;
  }
  .mainContents section#cases .cases .row + .row {
    margin-top: 60px;
  }
}
@media screen and (min-width: 769px) {
  .mainContents section#flow .steps {
    margin: 60px auto 0;
  }
  .mainContents section#flow .steps .row {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    margin: 0;
    position: relative;
    border: #64AADD 1px solid;
    background: #EFF6FC;
  }
  .mainContents section#flow .steps .row .row_title {
    width: 25.8064516129%;
    min-width: fit-content;
    color: #0064D2;
    background: #E0EEF8;
    border: #fff 1px solid;
    padding: 28px;
    font-size: 1.9em;
    line-height: 1.5789473684;
    font-weight: 600;
  }
  .mainContents section#flow .steps .row .row_title:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 12px;
    aspect-ratio: 1;
    box-sizing: border-box;
    border-left: #fff 6px solid;
    border-top: #fff 6px solid;
    border-right: transparent 6px solid;
    border-bottom: transparent 6px solid;
  }
  .mainContents section#flow .steps .row .text {
    border: #fff 1px solid;
    border-left: none;
    padding: 28px;
    font-size: 1.5em;
    line-height: 2;
    width: 74.1935483871%;
  }
  .mainContents section#flow .steps .row + .row {
    margin-top: 30px;
  }
  .mainContents section#flow .steps .row + .row:before {
    font-size: 10px;
    content: "";
    display: block;
    position: absolute;
    top: -2.7em;
    left: calc(50% - 1em);
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#faq {
    padding-bottom: 118px;
  }
  .mainContents section#faq .section_title {
    margin: 0 auto 67px;
  }
  .mainContents section#faq .faq {
    border-top: #64AADD 1px solid;
    border-bottom: #64AADD 1px solid;
    padding: 2px 0;
  }
  .mainContents section#faq .faq .ac_set {
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set .ac_btn {
    font-size: 1.9em;
    line-height: 1.5789473684;
    padding: 1.5789473684em 0;
    font-weight: 600;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    color: #333333;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon_q {
    width: 2.0454545455em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 1.1578947368em;
    line-height: 1.3636363636;
    color: #0064D2;
    display: block;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon {
    position: absolute;
    width: 20px;
    height: 20px;
    right: 20px;
    top: calc(50% - 10px);
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:before, .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 9px;
    width: 100%;
    height: 2px;
    background: #333333;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    transform-origin: center;
    transform: rotate(90deg);
  }
  .mainContents section#faq .faq .ac_set .ac_inner {
    padding: 0 45px 50px 0;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .icon_a {
    width: 2.0454545455em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 2.2em;
    line-height: 1.3636363636;
    color: #51B9BA;
    display: block;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .inner {
    width: calc(100% - 2.6470588235em);
  }
  .mainContents section#faq .faq .ac_set .ac_inner .cv_btn {
    background: transparent;
    font-size: 1.5em;
    width: 14em;
    height: 3em;
    border: #333333 1px solid;
    margin: 25px 0 0;
    color: #333333;
  }
  .mainContents section#faq .faq .ac_set:first-child {
    border-top: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set.open .ac_btn .icon:after {
    opacity: 0;
  }
}
@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
  body.is-sticky {
    padding-top: 0;
  }
  .p-tec-footer__pagetop {
    bottom: calc(1rem + 60px);
  }
  .p-tec-footer__pagetop.is_active {
    opacity: 0;
  }
  .p-tec-footer__pagetop.is_active.show {
    opacity: 1;
    z-index: 2;
  }
  .bottomFixed {
    margin-bottom: 70px;
  }
  .mainContents {
    font-family: "Noto Sans JP", sans-serif;
  }
  .mainContents * {
    box-sizing: border-box;
  }
  .mainContents abbr {
    text-decoration: none;
  }
  .mainContents sup {
    font-size: 0.5em;
    font-weight: normal;
    vertical-align: super;
    top: auto;
  }
  .mainContents section {
    position: relative;
    padding: 0;
    font-size: 71.4285714286%;
  }
}
@media screen and (max-width: 768px) and (max-width: 374px) {
  .mainContents section {
    font-size: 2.6666666667vw;
    font-size: 64.2857142857%;
  }
}
@media screen and (max-width: 768px) {
  .mainContents section .anchor {
    position: absolute;
    top: 0;
  }
  .mainContents section .cv_btn {
    display: flex;
    width: 15em;
    height: 3em;
    border-radius: 0.3125em;
    background: #E61E1E;
    color: #fff;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-weight: 600;
    font-size: 1.6em;
    letter-spacing: 0;
  }
  .mainContents section#mv {
    background: url(../img/hero_sp.png) center bottom/100% auto no-repeat #64AADD;
    padding-bottom: 64%;
  }
  .mainContents section#mv .texts {
    width: 100%;
    margin: 0;
    background: #fff;
    position: relative;
    padding: 2.5em 5.3333333333% 1.2em;
  }
  .mainContents section#mv .texts * {
    position: relative;
    z-index: 1;
  }
  .mainContents section#mv .texts .badge {
    font-size: 2.6666666667vw;
    position: absolute;
    right: 0;
    width: 9em;
    height: 9em;
    top: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mainContents section#mv .texts .badge:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 6.4em;
    aspect-ratio: 1;
    transform: translate(-50%, -50%) rotate(45deg);
    background: #51B9BA;
  }
  .mainContents section#mv .texts .badge .inner {
    position: relative;
    display: block;
    width: fit-content;
    color: #fff;
    font-size: 1.6em;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-align: center;
    font-feature-settings: "palt";
    line-height: 1;
  }
  .mainContents section#mv .texts .badge .inner sup {
    position: absolute;
    font-size: 0.6em;
    font-weight: normal;
    right: 0.5em;
    margin-top: -0.5em;
  }
  .mainContents section#mv .texts .h1_lead {
    font-size: 4.8vw;
    line-height: 1.6666666667;
    letter-spacing: 0.05em;
    margin-bottom: 0.6111111111em;
    font-weight: 900;
  }
  .mainContents section#mv .texts .main_title {
    font-size: 10.1333333333vw;
    line-height: 1.1842105263;
    letter-spacing: 0;
    font-weight: 900;
    padding-bottom: 0.6052631579em;
    white-space: nowrap;
    border-bottom: #333333 0.2105263158em solid;
    font-feature-settings: "palt";
  }
  .mainContents section#mv .texts .h1_sub {
    font-size: 5.3333333333vw;
    line-height: 1;
    letter-spacing: 0.05em;
    margin-top: 0.6em;
    font-weight: 600;
  }
  .mainContents section#mv .texts .cv_btn {
    font-size: 1.8em;
    width: 14.6111111111em;
    height: 3em;
    border-radius: 0.3125em;
    margin-top: 1.3333333333em;
  }
  .mainContents section#mv .texts .note {
    margin: 2em 0 0;
    font-size: 1.1em;
    line-height: 1.8181818182;
  }
  .mainContents section .nav_p li {
    display: block;
    width: 100%;
  }
  .mainContents section .nav_p li a {
    width: 100%;
    height: 3.4285714286em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    color: #333333;
    font-size: 1.4em;
    font-weight: 600;
    position: relative;
    white-space: nowrap;
    padding-left: 2.5714285714em;
  }
  .mainContents section .nav_p li a:after {
    content: "";
    display: block;
    position: absolute;
    right: 2.2142857143em;
    top: calc(50% - 0.1785714286em);
    width: 0.7142857143em;
    height: 0.3571428571em;
    box-sizing: border-box;
    border-top: #51B9BA 0.3571428571em solid;
    border-left: transparent 0.3571428571em solid;
    border-right: transparent 0.3571428571em solid;
  }
  .mainContents section#nav_area .inner {
    display: block;
    position: relative;
    width: 100%;
    background: #E2E8EC;
    padding: 2.4em 0;
    border-top: #A3B6C2 1px solid;
    border-bottom: #A3B6C2 1px solid;
  }
  .mainContents section.sp_nav {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 1001;
    opacity: 0;
    transform: translateY(-101%);
    transition: transform 0.3s ease;
    pointer-events: none;
  }
  .mainContents section.sp_nav .nav_btn {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 12px 16px;
    font-size: 1.4em;
    line-height: 1.7142857143;
    color: #333333;
    font-weight: 600;
    background: #E2E8EC;
    z-index: 3;
    border-bottom: #A3B6C2 1px solid;
    transform: translateY(0);
  }
  .mainContents section.sp_nav .nav_btn:after {
    content: "";
    display: block;
    position: absolute;
    width: 9px;
    height: 9px;
    box-sizing: border-box;
    border-right: #333333 2px solid;
    border-bottom: #333333 2px solid;
    transform-origin: center;
    transform: rotate(45deg);
    right: 21px;
    top: calc(50% - 4.5px);
  }
  .mainContents section.sp_nav .inner {
    display: block;
    position: absolute;
    width: 100%;
    background: #E2E8EC;
    padding: 2.4em 0;
    border-bottom: #A3B6C2 1px solid;
    transform: translateY(-101%);
    pointer-events: none;
    transition: transform 0.3s ease;
  }
  .mainContents section.sp_nav.show {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0%);
  }
  .mainContents section.sp_nav.open .nav_btn {
    border-bottom: none;
  }
  .mainContents section.sp_nav.open .inner {
    transform: translateY(0%);
    pointer-events: auto;
  }
  .mainContents section.cv_float {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 0.5em 0.5em 0.5em 1.6em;
    z-index: 3;
    background: #93C3E7;
    border-top: #64AADD 1px solid;
    color: #333333;
    display: flex;
    justify-content: space-between;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
  }
  .mainContents section.cv_float:before {
    content: "";
    display: block;
    position: absolute;
    width: 1.6em;
    height: 1.6em;
    box-sizing: border-box;
    z-index: 1;
    border-left: #0064D2 0.8em solid;
    border-top: #0064D2 0.8em solid;
    border-right: transparent 0.8em solid;
    border-bottom: transparent 0.8em solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_float .text {
    width: fit-content;
    font-size: 1.3em;
    line-height: 1.5384615385;
    margin: 0;
    font-weight: 600;
  }
}
@media screen and (max-width: 768px) and (min-width: 530px) {
  .mainContents section.cv_float .text br {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .mainContents section.cv_float .cv_btn {
    min-width: 10.3846153846em;
    width: fit-content;
    height: auto;
    border-radius: 5px;
    font-size: 1.3em;
    line-height: 1.3846153846;
    padding: 0.3846153846em 0.7692307692em;
    display: block;
    text-align: center;
  }
}
@media screen and (max-width: 768px) and (min-width: 390px) {
  .mainContents section.cv_float .cv_btn br {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .mainContents section.cv_float.show {
    opacity: 1;
    pointer-events: auto;
  }
  .mainContents section .section_title {
    font-size: 2.2em;
    line-height: 1.3636363636;
    text-align: center;
    font-weight: 600;
  }
  .mainContents section .inner_wrap {
    width: 89.3333333333%;
    margin: 0 auto;
  }
  .mainContents section img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  .mainContents section .text_link {
    display: block;
    font-size: 1.4em;
    width: fit-content;
    margin: 0 auto;
    line-height: 1.7142857143;
    text-decoration: underline;
    color: #333333;
    font-weight: 600;
    text-align: center;
  }
  .mainContents section#intro {
    padding-top: 42px;
  }
  .mainContents section#intro .flex_wrap {
    margin: 48px auto;
    position: relative;
  }
  .mainContents section#intro .flex_wrap .col {
    width: 100%;
    padding: 0;
    margin: 0;
    position: relative;
    min-height: 120px;
    padding-left: 144px;
  }
  .mainContents section#intro .flex_wrap .col .text {
    font-size: 1.5em;
    line-height: 1.6;
    font-weight: 600;
    margin-bottom: 0.8em;
  }
  .mainContents section#intro .flex_wrap .col .pic {
    width: 120px;
    position: absolute;
    left: 0;
    top: calc(50% - 60px);
  }
  .mainContents section#intro .flex_wrap .col .text2 {
    margin: 0;
    font-size: 1.5em;
    line-height: 1.5;
    font-weight: 500;
    color: #0064D2;
    width: fit-content;
    position: relative;
    padding: 0 0 8px;
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:before, .mainContents section#intro .flex_wrap .col .text2:after {
    content: "";
    display: block;
    position: absolute;
  }
  .mainContents section#intro .flex_wrap .col .text2:before {
    font-size: 0.5333333333em;
    top: -1em;
    left: 7.875em;
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#intro .flex_wrap .col .text2:after {
    width: 100%;
    height: 1px;
    background: #64AADD;
    bottom: 2px;
  }
  .mainContents section#intro .flex_wrap .col + .col {
    margin-top: 48px;
  }
  .mainContents section#intro .border_text {
    padding: 26px 23px;
    width: 100%;
    margin: 0;
    border: #0064D2 1px solid;
    text-align: center;
    color: #0064D2;
    font-size: 1.9em;
    line-height: 1.5789473684;
    font-weight: 500;
    position: relative;
  }
  .mainContents section#intro .border_text:before, .mainContents section#intro .border_text:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#intro .border_text:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#intro .border_text:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
  .mainContents section#intro .text_link {
    margin-top: 24px;
  }
  .mainContents section .text {
    font-size: 1.4em;
    line-height: 1.7142857143;
    font-weight: 400;
    margin: 0;
  }
  .mainContents section .text strong {
    font-weight: 600;
  }
  .mainContents section .text strong.marker {
    text-decoration: underline;
    text-decoration-color: rgba(250, 215, 55, 0.5);
    text-decoration-thickness: 1em;
    text-underline-offset: -0.5em;
  }
  .mainContents section .text.center {
    text-align: center;
  }
  .mainContents section .note {
    font-size: 1.1em;
    line-height: 1.8181818182;
    margin: 0;
  }
  .mainContents section .ac_set .ac_wrap {
    overflow: hidden;
    transition: height 0.3s ease;
  }
  .mainContents section .ac_set:not(.active) .ac_btn .icon {
    display: none !important;
  }
  .mainContents section .ac_set.active .ac_wrap {
    height: 0;
  }
  .mainContents section .ac_set:not(.open) a:not(.ac_btn) {
    pointer-events: none;
    user-select: none;
    display: none;
  }
  .mainContents section#what {
    margin: 48px auto 0;
    padding: 42px 5.3333333333% 49px;
    position: relative;
    border-top: #0064D2 1px solid;
    border-bottom: #0064D2 1px solid;
    background: #EFF6FC;
  }
  .mainContents section#what .section_title {
    margin-bottom: 38px;
  }
  .mainContents section#what .pic + .text {
    margin-top: 24px;
  }
  .mainContents section#what .note {
    margin: 0;
  }
  .mainContents section#what .ac_set {
    margin-top: 27px;
  }
  .mainContents section#what .ac_inner {
    padding: 43px 0 48px;
  }
  .mainContents section#what .ac_inner .section_title {
    margin-bottom: 12px;
  }
  .mainContents section#what .ac_inner .text {
    margin-bottom: 24px;
  }
  .mainContents section#what .ac_btn {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    width: 13.6428571429em;
    height: 3.4285714286em;
    border: #333333 2px solid;
    border-radius: 5px;
    font-size: 1.4em;
    line-height: 1.7142857143;
    font-weight: 600;
    padding-left: 22px;
    margin: 0 auto;
    color: #333333;
  }
  .mainContents section#what .ac_btn .icon {
    display: block;
    position: absolute;
    right: 14px;
    top: calc(50% - 8px);
    width: 16px;
    height: 16px;
  }
  .mainContents section#what .ac_btn .icon:before, .mainContents section#what .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    width: 16px;
    height: 2px;
    background: #333333;
    left: calc(50% - 8px);
    top: calc(50% - 1px);
    transform-origin: center;
  }
  .mainContents section#what .ac_btn .icon:after {
    transform: rotate(90deg);
  }
  .mainContents section#what .ac_btn.btn_close {
    display: none;
  }
  .mainContents section#what .ac_btn.btn_close .icon:after {
    opacity: 0;
  }
  .mainContents section#what .ac_btn.btn_open {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_close {
    display: flex;
  }
  .mainContents section#what .ac_set.open .ac_btn.btn_open {
    display: none;
  }
  .mainContents section.section {
    padding-top: 84px;
  }
  .mainContents section.section .section_title {
    font-size: 1em;
    text-align: center;
    padding-bottom: 22px;
    position: relative;
  }
  .mainContents section.section .section_title:after {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 24px);
    bottom: 0;
    width: 48px;
    height: 4px;
    background: #333333;
  }
  .mainContents section.section .section_title .en {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    display: block;
    font-size: 1.3em;
    line-height: 1.8461538462;
    color: #E61E1E;
    font-weight: 700;
    letter-spacing: 0.4em;
    padding-left: 0.4em;
    margin-bottom: 1.3076923077em;
  }
  .mainContents section.section .section_title .jp_s {
    display: block;
    font-size: 1.3em;
    line-height: 1.8461538462;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 0.4615384615em;
  }
  .mainContents section.section .section_title .jp {
    display: block;
    font-size: 3em;
    line-height: 1.4;
    font-weight: 600;
    letter-spacing: 0;
  }
  .mainContents section.section .section_title + .text.center {
    margin-top: 41px;
  }
  .mainContents section#features {
    margin-top: 0;
    margin-bottom: 72px;
  }
  .mainContents section#features .section_title {
    margin-bottom: 47px;
  }
  .mainContents section#features .features .row {
    width: 100%;
    position: relative;
    display: block;
    margin: 0;
  }
  .mainContents section#features .features .row .row_title {
    font-weight: 500;
    font-size: 2em;
    line-height: 1.8;
    color: #0064D2;
    padding-left: 3.885em;
    position: relative;
    margin-bottom: 25px;
  }
  .mainContents section#features .features .row .row_title .num {
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 500;
    display: block;
    position: absolute;
    left: 0;
    top: calc(50% - 1.25em);
    width: 2.5em;
    text-align: center;
    height: 2.5em;
    line-height: 2.5em;
    font-size: 1.2em;
    border: #0064D2 1px solid;
  }
  .mainContents section#features .features .row .row_title .num:before, .mainContents section#features .features .row .row_title .num:after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border: #0064D2 1px solid;
    box-sizing: border-box;
  }
  .mainContents section#features .features .row .row_title .num:before {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    left: 2px;
    top: 2px;
  }
  .mainContents section#features .features .row .row_title .num:after {
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 5px;
    top: 5px;
  }
  .mainContents section#features .features .row .pic {
    margin-bottom: 24px;
  }
  .mainContents section#features .features .row + .row {
    margin-top: 48px;
  }
  .mainContents section .spnowrap {
    white-space: nowrap;
  }
  .mainContents section.cv_section {
    background: #93C3E7;
    color: #333333;
    text-align: center;
    padding: 48px 0 48px;
  }
  .mainContents section.cv_section:before, .mainContents section.cv_section:after {
    content: "";
    display: block;
    position: absolute;
    width: 56px;
    height: 56px;
    box-sizing: border-box;
    z-index: 1;
  }
  .mainContents section.cv_section:before {
    border-left: #0064D2 28px solid;
    border-top: #0064D2 28px solid;
    border-right: transparent 28px solid;
    border-bottom: transparent 28px solid;
    left: 0;
    top: 0;
  }
  .mainContents section.cv_section:after {
    border-right: #fff 28px solid;
    border-bottom: #fff 28px solid;
    border-left: transparent 28px solid;
    border-top: transparent 28px solid;
    right: 0;
    bottom: 0;
  }
  .mainContents section.cv_section .text {
    margin-top: 12px;
  }
  .mainContents section.cv_section .cv_btn {
    margin: 26px auto 0;
  }
  .mainContents section#merit {
    padding-bottom: 0;
  }
  .mainContents section#merit .merit_table {
    margin: 48px auto 0;
    width: 100%;
    display: block;
  }
  .mainContents section#merit .merit_table tbody, .mainContents section#merit .merit_table tr, .mainContents section#merit .merit_table th, .mainContents section#merit .merit_table td {
    display: block;
  }
  .mainContents section#merit .merit_table tr:nth-child(1) {
    display: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) {
    border: #B3B3B3 1px solid;
    padding: 1px;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) th {
    text-align: left;
    font-size: 1.6em;
    line-height: 1.5;
    font-weight: 600;
    padding: 10px 22px;
    margin-bottom: 1px;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) th br {
    display: none;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td {
    padding: 0 22px 25px;
    vertical-align: top;
    font-size: 1.4em;
    line-height: 1.7142857143;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .main_text {
    display: block;
    font-weight: 600;
    margin-bottom: 0;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td .text {
    display: block;
    font-size: 1em;
    line-height: 1.7142857143;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:before {
    display: flex;
    width: calc(100% + 44px);
    margin-left: -22px;
    justify-content: center;
    align-items: center;
    height: 2.5em;
    position: relative;
    color: #fff;
    font-weight: 600;
    font-size: 0.8571428571em;
    margin-bottom: 1.4166666667em;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(2) {
    background: url(../img/merit_label.png) calc(100% - 22px) calc(100% - 25px)/72px auto no-repeat rgba(179, 179, 179, 0.1);
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(2):before {
    content: "従来のソリューション";
    background: #BFBFBF;
    color: #333333;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) {
    padding-bottom: 142px;
    background-position: center calc(100% - 14px);
    background-size: auto 116px;
    background-repeat: no-repeat;
    background-color: #EFF6FC;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3):before {
    content: "A3カラープリンターRFIDソリューション";
    background: #93C3E7;
    color: #333333;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+2) td:nth-child(3) .main_text {
    color: #0064D2;
  }
  .mainContents section#merit .merit_table tr:nth-child(n+3) {
    margin-top: 24px;
  }
  .mainContents section#merit .merit_table tr:nth-child(2) td:nth-child(3) {
    background-image: url(../img/merit_color_sp.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(3) td:nth-child(3) {
    background-image: url(../img/merit_size_sp.png);
  }
  .mainContents section#merit .merit_table tr:nth-child(4) td:nth-child(3) {
    background-image: url(../img/merit_position_sp.png);
  }
  .mainContents section#merit .text_link {
    margin-top: 48px;
  }
  .mainContents section#merit .note {
    margin-top: 12px;
    font-size: 1.2em;
    line-height: 1.5;
    text-align: center;
  }
  .mainContents section#cases {
    padding-bottom: 72px;
  }
  .mainContents section#cases .cases {
    margin: 48px auto 0;
  }
  .mainContents section#cases .cases .row {
    width: 100%;
    display: block;
    margin: 0;
    position: relative;
  }
  .mainContents section#cases .cases .row .pic {
    margin-bottom: 17px;
  }
  .mainContents section#cases .cases .row .texts .category {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    font-size: 1.4em;
    line-height: 1.7142857143;
    margin: 0 0 6px;
  }
  .mainContents section#cases .cases .row .texts .category .tag {
    font-weight: 600;
    display: flex;
    width: fit-content;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 10px;
    font-size: 1em;
    letter-spacing: 0.05em;
    height: 1.7142857143em;
    background: #FAD737;
    margin-right: 12px;
  }
  .mainContents section#cases .cases .row .texts .row_title {
    font-weight: 500;
    font-size: 1.8em;
    line-height: 1.3333333333;
    margin: 0 0 6px;
  }
  .mainContents section#cases .cases .row + .row {
    margin-top: 48px;
  }
  .mainContents section#flow .steps {
    margin: 48px auto 0;
  }
  .mainContents section#flow .steps .row {
    width: 100%;
    display: block;
    margin: 0;
    position: relative;
    border: #64AADD 1px solid;
    background: #EFF6FC;
  }
  .mainContents section#flow .steps .row .row_title {
    color: #0064D2;
    background: #E0EEF8;
    border: #fff 1px solid;
    padding: 10px 22px;
    font-size: 1.6em;
    line-height: 1.5;
    font-weight: 600;
  }
  .mainContents section#flow .steps .row .row_title:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 10px;
    aspect-ratio: 1;
    box-sizing: border-box;
    border-left: #fff 5px solid;
    border-top: #fff 5px solid;
    border-right: transparent 5px solid;
    border-bottom: transparent 5px solid;
  }
  .mainContents section#flow .steps .row .text {
    border: #fff 1px solid;
    border-top: none;
    padding: 22px;
    font-size: 1.4em;
    line-height: 1.7142857143;
  }
  .mainContents section#flow .steps .row + .row {
    margin-top: 24px;
  }
  .mainContents section#flow .steps .row + .row:before {
    font-size: 8px;
    content: "";
    display: block;
    position: absolute;
    top: -21px;
    left: calc(50% - 1em);
    width: 2em;
    height: 1em;
    box-sizing: border-box;
    border-top: 1em #64AADD solid;
    border-left: transparent 1em solid;
    border-right: transparent 1em solid;
  }
  .mainContents section#faq {
    padding-bottom: 70px;
  }
  .mainContents section#faq .section_title {
    margin: 0 auto 48px;
  }
  .mainContents section#faq .faq {
    border-top: #64AADD 1px solid;
    border-bottom: #64AADD 1px solid;
    padding: 2px 0;
  }
  .mainContents section#faq .faq .ac_set {
    border-bottom: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set .ac_btn {
    font-size: 1.6em;
    line-height: 1.5;
    padding: 24px 0;
    padding-right: 36px;
    padding-left: 2.25em;
    font-weight: 600;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    color: #333333;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon_q {
    width: 1.8em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 1.25em;
    line-height: 1.2;
    color: #0064D2;
    display: block;
    position: absolute;
    left: 0;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon {
    position: absolute;
    width: 24px;
    height: 24px;
    right: 0;
    top: calc(50% - 12px);
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:before, .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    content: "";
    display: block;
    position: absolute;
    left: 4px;
    top: 11px;
    width: 16px;
    height: 2px;
    background: #333333;
  }
  .mainContents section#faq .faq .ac_set .ac_btn .icon:after {
    transform-origin: center;
    transform: rotate(90deg);
  }
  .mainContents section#faq .faq .ac_set .ac_inner {
    padding: 0 0 36px 0;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .icon_a {
    width: 1.8em;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-weight: 600;
    font-size: 2em;
    line-height: 1.2;
    color: #51B9BA;
    display: block;
  }
  .mainContents section#faq .faq .ac_set .ac_inner .inner {
    width: calc(100% - 3.6em);
  }
  .mainContents section#faq .faq .ac_set .ac_inner .cv_btn {
    background: transparent;
    font-size: 1.4em;
    width: 14.5em;
    height: 3em;
    border: #333333 1px solid;
    margin: 18px 0 0;
    color: #333333;
  }
  .mainContents section#faq .faq .ac_set:first-child {
    border-top: #64AADD 1px solid;
  }
  .mainContents section#faq .faq .ac_set.open .ac_btn .icon:after {
    opacity: 0;
  }
}