@charset "UTF-8";
*,
*::after,
*::before {
  box-sizing: border-box; }

body,
button,
input,
select,
textarea {
  font-family: "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif; }

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary,
div,
span,
p,
ul,
ol,
li,
dl,
dt,
dd,
table,
tr,
th,
td,
a,
img,
label,
form,
input,
textarea {
  margin: 0;
  padding: 0; }

ol,
ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

img {
  border: 0;
  height: auto;
  line-height: 1;
  vertical-align: bottom;
  max-width: 100%; }

a {
  background: transparent;
  cursor: pointer;
  outline: 0 none; }

html {
  display: flex;
  flex-direction: column;
  scroll-behavior: smooth; }

body {
  color: #333;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  line-height: 1.8; }

main {
  flex: 1 1 auto; }

.clearfix {
  display: block; }
  .clearfix::before, .clearfix::after {
    clear: both;
    content: "";
    display: block; }

@media (min-width: 769px), print {
  .pc_hide {
    display: none !important; } }

@media (max-width: 768px) {
  .sp_hide {
    display: none !important; } }

body {
  font-size: 1.25rem; }
  @media (max-width: 1240px) {
    body {
      font-size: 1.6129032258vw; } }
  @media (max-width: 768px) {
    body {
      font-size: 3.5897435897vw; } }

::placeholder {
  color: #ccc; }

a {
  color: #077fb9;
  text-decoration: underline;
  -webkit-text-decoration-skip: none;
  transition: .3s background-color ease, .3s border-color ease, .3s color ease, .3s opacity ease; }
  a:hover {
    color: #e97971; }
  @media (min-width: 769px), print {
    a[href^="tel:"] {
      pointer-events: none; } }

.wrap {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  width: 100%;
  max-width: 1200px; }

@media (min-width: 769px), print {
  .br_pc {
    display: inline-block; } }

@media (max-width: 768px) {
  .br_sp {
    display: inline-block; } }

.section {
  margin-bottom: 120px;
  padding: 0 20px; }
  @media (max-width: 1240px) {
    .section {
      margin-bottom: 9.6774193548vw;
      padding: 0 1.6129032258vw; } }
  @media (max-width: 768px) {
    .section {
      margin-bottom: 15.3846153846vw;
      padding: 0 5.1282051282vw; } }

.ttl {
  font-weight: 700;
  margin-bottom: 40px;
  text-align: center; }
  @media (max-width: 1240px) {
    .ttl {
      margin-bottom: 3.2258064516vw; } }
  @media (max-width: 768px) {
    .ttl {
      margin-bottom: 5.1282051282vw; } }
  .ttl h2 {
    font-size: 2.5rem;
    color: #e97971; }
    @media (max-width: 1240px) {
      .ttl h2 {
        font-size: 3.2258064516vw; } }
    @media (max-width: 768px) {
      .ttl h2 {
        font-size: 5.1282051282vw;
        line-height: 1.5; } }

footer {
  background: #f9f8f4; }

.foot_wrap {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  width: 100%;
  max-width: 1200px; }
  @media (min-width: 769px), print {
    .foot_wrap {
      align-items: center;
      display: grid;
      gap: 20px 3.75%;
      grid-template-columns: 23% auto;
      padding: 47px 30px 30px; } }
  @media (max-width: 1240px) {
    .foot_wrap {
      gap: 3.6290322581vw;
      padding: 3.7903225806vw ve(30); } }
  @media (max-width: 768px) {
    .foot_wrap {
      padding: 7.6923076923vw 5.1282051282vw 3.8461538462vw; } }
@media (max-width: 768px) {
  .foot_logo {
    margin: 0 auto 3.8461538462vw;
    width: 35.1282051282vw; } }
@media (max-width: 768px) {
  .foot_profile {
    margin: auto;
    width: fit-content; } }
.foot_profile dt {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 10px; }
  @media (max-width: 1240px) {
    .foot_profile dt {
      font-size: 1.4516129032vw; } }
  @media (max-width: 1240px) {
    .foot_profile dt {
      margin-bottom: 0.8064516129vw; } }
  @media (max-width: 768px) {
    .foot_profile dt {
      font-size: 3.5897435897vw;
      margin-bottom: 2.5641025641vw; } }
.foot_profile dd {
  font-size: 1rem; }
  @media (max-width: 1240px) {
    .foot_profile dd {
      font-size: 1.2903225806vw; } }
  @media (max-width: 768px) {
    .foot_profile dd {
      font-size: 3.5897435897vw; } }
@media (min-width: 769px), print {
  .foot_profile_list {
    column-gap: 30px;
    display: grid;
    grid-template-columns: auto 1fr; } }
@media (max-width: 1240px) {
  .foot_profile_list {
    column-gap: 2.4193548387vw; } }
.foot_copy {
  font-size: 0.875rem;
  font-weight: 700;
  text-align: center;
  grid-column-start: 1;
  grid-column-end: 3;
  grid-row-start: 2; }
  @media (max-width: 1240px) {
    .foot_copy {
      font-size: 1.1290322581vw; } }
  @media (max-width: 768px) {
    .foot_copy {
      font-size: 3.0769230769vw;
      margin-top: 3.8461538462vw; } }
.foot_btn {
  bottom: -17.9487179487vw;
  display: flex;
  position: sticky;
  right: 0;
  transition: bottom .3s ease;
  z-index: 10; }
  @media (min-width: 769px), print {
    .foot_btn {
      display: none !important; } }
  .foot_btn.active {
    bottom: 0; }
  .foot_btn li {
    display: block;
    height: 15.3846153846vw; }
  .foot_btn a {
    font-size: 4.1025641026vw;
    align-items: center;
    color: #fff;
    display: flex;
    font-weight: 700;
    height: 100%;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    padding: 1.2820512821vw; }
    .foot_btn a::before {
      mask-repeat: no-repeat;
      mask-size: contain;
      position: absolute;
      background-color: #fff;
      content: "";
      display: block;
      height: 1.2em;
      mask-position: center;
      position: relative;
      width: 1.2em; }
      @media (min-width: 769px), print {
        .foot_btn a::before {
          margin-bottom: .3em; } }
      @media (max-width: 768px) {
        .foot_btn a::before {
          margin-right: .5em; } }
  .foot_btn_mail a {
    aspect-ratio: 1/1;
    background: #496d8b;
    display: block;
    position: relative;
    width: 15.3846153846vw; }
    .foot_btn_mail a::before {
      mask-image: url("images/ico-mail.svg");
      left: 50%;
      position: absolute;
      top: 50%;
      transform: translate(-50%, -50%); }
  .foot_btn_tel {
    flex: 1 1 0%; }
    .foot_btn_tel a {
      background: #4e9242; }
      .foot_btn_tel a::before {
        mask-image: url("images/ico-phone.svg"); }

.contact {
  background-color: #fdf1f0;
  font-weight: 700;
  margin-bottom: 120px;
  padding: 0 20px; }
  @media (max-width: 1240px) {
    .contact {
      margin-bottom: 9.6774193548vw;
      padding: 0 1.6129032258vw; } }
  @media (max-width: 768px) {
    .contact {
      margin-bottom: 15.3846153846vw;
      padding: 0 5.1282051282vw; } }
  @media (min-width: 769px), print {
    .contact .wrap {
      background: url("images/contact-img01.svg") left center/189px auto no-repeat;
      padding: 60px 0 50px; } }
  @media (max-width: 1240px) {
    .contact .wrap {
      background-size: 15.2419354839vw auto;
      padding: 4.8387096774vw 0 4.0322580645vw; } }
  @media (max-width: 768px) {
    .contact .wrap {
      padding: 7.6923076923vw 0; } }
  .contact_txt {
    font-size: 1.75rem;
    margin: 0 auto 30px;
    position: relative;
    text-align: center;
    width: fit-content; }
    @media (max-width: 1240px) {
      .contact_txt {
        font-size: 2.2580645161vw; } }
    @media (max-width: 768px) {
      .contact_txt {
        font-size: 4.1025641026vw;
        margin-bottom: 3.8461538462vw; } }
    .contact_txt::before, .contact_txt::after {
      background-color: #333;
      bottom: 0;
      content: "";
      height: 36px;
      position: absolute;
      width: 3px; }
      @media (max-width: 1240px) {
        .contact_txt::before, .contact_txt::after {
          height: 2.9032258065vw;
          width: 0.2419354839vw; } }
      @media (max-width: 768px) {
        .contact_txt::before, .contact_txt::after {
          height: 5.641025641vw;
          width: 0.5128205128vw; } }
    .contact_txt::before {
      left: -35px;
      transform: rotate(-45deg); }
      @media (max-width: 1240px) {
        .contact_txt::before {
          left: -2.8225806452vw; } }
      @media (max-width: 768px) {
        .contact_txt::before {
          left: -5.1282051282vw; } }
    .contact_txt::after {
      right: -35px;
      transform: rotate(45deg); }
      @media (max-width: 1240px) {
        .contact_txt::after {
          right: -2.8225806452vw; } }
      @media (max-width: 768px) {
        .contact_txt::after {
          right: -5.1282051282vw; } }
  @media (min-width: 769px), print {
    .contact_box {
      align-items: flex-end;
      display: flex;
      gap: 30px;
      padding-left: 18%; } }
  @media (max-width: 1240px) {
    .contact_box {
      gap: 1.6129032258vw; } }
  .contact_tel {
    line-height: 1.2; }
    .contact_tel dt {
      font-size: 1.5rem;
      align-items: center;
      display: flex; }
      @media (max-width: 1240px) {
        .contact_tel dt {
          font-size: 1.935483871vw; } }
      @media (max-width: 768px) {
        .contact_tel dt {
          font-size: 3.5897435897vw;
          margin: auto;
          width: fit-content; } }
    @media (max-width: 768px) {
      .contact_tel dd {
        margin: 0 auto 5.1282051282vw;
        width: fit-content; } }
    .contact_tel dd a {
      font-size: 6.875rem;
      color: #4e9242;
      text-decoration: none; }
      @media (max-width: 1240px) {
        .contact_tel dd a {
          font-size: 8.8709677419vw; } }
      @media (max-width: 768px) {
        .contact_tel dd a {
          font-size: 9.4871794872vw;
          align-items: center;
          column-gap: 2.5641025641vw;
          display: flex;
          justify-content: center;
          margin-top: 1.2820512821vw; } }
    .contact_tel_ttl {
      background: #e97971;
      border-radius: 8px;
      color: #fff;
      display: block;
      margin-right: 20px;
      padding: 10px 20px; }
      @media (max-width: 1240px) {
        .contact_tel_ttl {
          border-radius: 0.6451612903vw;
          margin-right: 1.6129032258vw;
          padding: 0.564516129vw 1.2096774194vw; } }
      @media (max-width: 768px) {
        .contact_tel_ttl {
          border-radius: 1.0256410256vw;
          margin-right: 2.5641025641vw;
          padding: 1.2820512821vw 2.0512820513vw; } }
    .contact_tel_txt {
      font-size: 3.3333333333vw;
      background: #fff;
      border-radius: 30px;
      display: block;
      margin: 2.0512820513vw auto 0;
      padding: 2.5641025641vw 8.9743589744vw;
      position: relative;
      width: fit-content; }
      @media (min-width: 769px), print {
        .contact_tel_txt {
          display: none !important; } }
      .contact_tel_txt::before {
        border-bottom: 2.0512820513vw solid #fff;
        border-left: 1.5384615385vw solid transparent;
        border-right: 1.5384615385vw solid transparent;
        content: "";
        left: 50%;
        position: absolute;
        transform: translateX(-50%);
        top: -1.2820512821vw; }
    .contact_tel_btn {
      background: #4e9242;
      border-radius: 1.5384615385vw;
      box-shadow: 0 1.0256410256vw 0 #347428;
      display: block;
      height: 10.2564102564vw;
      position: relative;
      width: 10.2564102564vw; }
      @media (min-width: 769px), print {
        .contact_tel_btn {
          display: none !important; } }
      .contact_tel_btn::before {
        mask-repeat: no-repeat;
        mask-size: contain;
        position: absolute;
        background: #fff;
        mask-image: url("images/ico-phone.svg");
        content: "";
        height: 5.641025641vw;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 5.641025641vw; }
  @media (min-width: 769px), print {
    .contact_mail {
      margin-bottom: 15px;
      width: 15%; } }
  @media (max-width: 1240px) {
    .contact_mail {
      margin-bottom: 1.2096774194vw; } }
  @media (max-width: 768px) {
    .contact_mail {
      margin: auto;
      width: 80%; } }
  .contact_mail a {
    font-size: 1rem;
    border: 1px solid #496d8b;
    border-radius: 15px;
    color: #496d8b;
    display: block;
    padding: 10px;
    text-align: center;
    text-decoration: none; }
    @media (max-width: 1240px) {
      .contact_mail a {
        font-size: 1.2903225806vw; } }
    @media (max-width: 1240px) {
      .contact_mail a {
        border-radius: 1.2096774194vw;
        padding: 0.8064516129vw; } }
    @media (max-width: 768px) {
      .contact_mail a {
        font-size: 3.0769230769vw;
        background-position: right 2.5641025641vw center;
        background-size: 3.3333333333vw auto;
        border-radius: 50px;
        padding: 0.7692307692vw; } }
    .contact_mail a:hover {
      background-color: #2a4c68;
      color: #fff; }

.main {
  background: #f9f8f4;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative; }
  @media (min-width: 769px), print {
    .main {
      height: 100svh;
      max-height: 850px; } }
  @media (max-width: 1200px) and (min-width: 769px) {
    .main {
      max-height: 64.5161290323vw; } }
  @media (max-width: 768px) {
    .main {
      aspect-ratio: 75/134;
      height: 100%;
      width: 100%; } }
  .main::before, .main::after {
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    height: 85%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 205px;
    z-index: 2; }
    @media (min-width: 769px), print {
      .main::before, .main::after {
        content: ""; } }
    @media (max-width: 1240px) {
      .main::before, .main::after {
        width: 16.5322580645vw; } }
  .main::before {
    background-image: url("images/main-img01.svg");
    right: calc(50% + 380px); }
    @media (max-width: 1240px) {
      .main::before {
        right: calc(50% + 30vw); } }
  .main::after {
    background-image: url("images/main-img02.svg");
    left: calc(50% + 380px); }
    @media (max-width: 1240px) {
      .main::after {
        left: calc(50% + 30vw); } }
  .main_content {
    margin: auto;
    overflow: hidden;
    padding: 50px 20px; }
    @media (max-width: 1240px) {
      .main_content {
        padding: 4.0322580645vw 1.6129032258vw; } }
    @media (max-width: 768px) {
      .main_content {
        padding: 5.1282051282vw; } }
  .main_logo {
    margin: 0 auto 10px;
    max-width: 274px; }
    @media (max-width: 1240px) {
      .main_logo {
        margin-bottom: 0.8064516129vw;
        max-width: 22.0967741935vw; } }
    @media (max-width: 768px) {
      .main_logo {
        margin-bottom: 2.5641025641vw;
        max-width: 35.1282051282vw; } }
  .main_cp {
    font-size: 2.8125rem;
    margin-bottom: 20px;
    text-align: center; }
    @media (max-width: 1240px) {
      .main_cp {
        font-size: 3.6290322581vw; } }
    @media (max-width: 1240px) {
      .main_cp {
        margin-bottom: 1.6129032258vw; } }
    @media (max-width: 768px) {
      .main_cp {
        font-size: 5.641025641vw; } }
    .main_cp strong {
      font-size: 5rem;
      color: #e97971;
      line-height: 1.2; }
      @media (max-width: 1240px) {
        .main_cp strong {
          font-size: 6.4516129032vw; } }
      @media (max-width: 768px) {
        .main_cp strong {
          font-size: 8.7179487179vw; } }
    .main_cp_sub {
      font-size: 1.875rem;
      color: #e97971;
      font-weight: 700;
      margin-bottom: 1.2em;
      text-align: center; }
      @media (max-width: 1240px) {
        .main_cp_sub {
          font-size: 2.4193548387vw; } }
      @media (max-width: 768px) {
        .main_cp_sub {
          font-size: 3.8461538462vw;
          margin-bottom: 5.1282051282vw;
          padding-bottom: 71.7948717949vw;
          position: relative; }
          .main_cp_sub::before, .main_cp_sub::after {
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            bottom: 0;
            content: "";
            height: 66.6666666667vw;
            position: absolute;
            width: 20.5128205128vw;
            z-index: 2; }
          .main_cp_sub::before {
            background-image: url("images/main-img01.svg");
            right: 55%; }
          .main_cp_sub::after {
            background-image: url("images/main-img02.svg");
            left: 55%; } }
  .main_btn {
    margin: auto;
    max-width: 400px; }
    @media (max-width: 1240px) {
      .main_btn {
        max-width: 32.2580645161vw; } }
    @media (max-width: 768px) {
      .main_btn {
        max-width: 64.1025641026vw; } }
    .main_btn a {
      font-size: 1.875rem;
      background: #e97971;
      border-radius: 100px;
      box-shadow: 0 0.3em 0 #b55851;
      color: #fff;
      display: block;
      font-weight: 700;
      margin-bottom: .3em;
      padding: 15px;
      text-align: center;
      text-decoration: none; }
      @media (max-width: 1240px) {
        .main_btn a {
          font-size: 2.4193548387vw; } }
      @media (max-width: 1240px) {
        .main_btn a {
          padding: 1.2096774194vw; } }
      @media (max-width: 768px) {
        .main_btn a {
          font-size: 4.6153846154vw;
          box-shadow: 0 1.0256410256vw 0 #b55851;
          padding: 2.5641025641vw; } }
      .main_btn a:hover {
        background: #b55851; }
        @media (min-width: 769px), print {
          .main_btn a:hover {
            box-shadow: none;
            transform: translateY(0.3em); } }

.case_list {
  counter-reset: case 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px; }
  @media (max-width: 1240px) {
    .case_list {
      gap: 1.6129032258vw; } }
  @media (max-width: 768px) {
    .case_list {
      gap: 2.5641025641vw; } }
  .case_list li {
    font-size: 1.125rem;
    align-items: center;
    background: #f9f8f4;
    border-radius: 10px;
    cursor: pointer; }
    @media (max-width: 1240px) {
      .case_list li {
        font-size: 1.4516129032vw; } }
    @media (min-width: 769px), print {
      .case_list li {
        padding: 30px; } }
    @media (max-width: 1240px) {
      .case_list li {
        border-radius: 0.8064516129vw;
        padding: 2.4193548387vw; } }
    @media (max-width: 768px) {
      .case_list li {
        font-size: 3.5897435897vw;
        border-radius: 2.5641025641vw;
        padding: 5.1282051282vw; } }
  .case_list_top {
    align-items: center;
    display: flex;
    padding: 0 30px 0 10px;
    position: relative; }
    @media (max-width: 1240px) {
      .case_list_top {
        padding: 0 2.4193548387vw 0 0.8064516129vw; } }
    @media (max-width: 768px) {
      .case_list_top {
        padding: 0 5.1282051282vw 0 0; } }
    .case_list_top::before {
      mask-repeat: no-repeat;
      mask-size: contain;
      position: absolute;
      background-color: #e97971;
      content: "";
      height: 12px;
      mask-image: url("images/ico-arrow.svg");
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 24px; }
      @media (max-width: 1240px) {
        .case_list_top::before {
          height: 0.9677419355vw;
          width: 1.935483871vw; } }
      @media (max-width: 768px) {
        .case_list_top::before {
          height: 2.0512820513vw;
          width: 4.1025641026vw; } }
    .active .case_list_top::before {
      transform: translateY(-50%) rotate(180deg); }
    .case_list_top dl {
      font-weight: 700;
      flex: 1 1 0%; }
      .case_list_top dl dt {
        font-size: 1.5rem;
        line-height: 1.5; }
        @media (max-width: 1240px) {
          .case_list_top dl dt {
            font-size: 1.935483871vw; } }
        @media (max-width: 768px) {
          .case_list_top dl dt {
            font-size: 4.6153846154vw; } }
        .case_list_top dl dt::before {
          counter-increment: case 1;
          content: "事例" counter(case);
          margin-right: .5em; }
      .case_list_top dl dd {
        color: #e97971;
        margin-top: .5em; }
        @media (max-width: 768px) {
          .case_list_top dl dd {
            font-size: 3.5897435897vw; } }
  .case_list_img {
    height: 90px;
    margin-right: 20px;
    width: 90px; }
    @media (max-width: 1240px) {
      .case_list_img {
        height: 7.2580645161vw;
        margin-right: 1.6129032258vw;
        width: 7.2580645161vw; } }
    @media (max-width: 768px) {
      .case_list_img {
        height: 20.5128205128vw;
        margin-right: 2.5641025641vw;
        width: 20.5128205128vw; } }
    .case_list_img img {
      height: 100%;
      object-fit: contain;
      width: 100%; }
  .case_list_detail {
    display: none;
    padding: 10px; }
    @media (max-width: 1240px) {
      .case_list_detail {
        padding: 0.8064516129vw; } }
    @media (max-width: 768px) {
      .case_list_detail {
        padding: 0; } }
    .case_list_detail p {
      margin-top: 1em; }
      .case_list_detail p strong {
        color: #b7261b; }

.merit_list {
  display: grid;
  gap: 20px; }
  @media (max-width: 1240px) {
    .merit_list {
      gap: 1.6129032258vw; } }
  @media (max-width: 768px) {
    .merit_list {
      gap: 2.5641025641vw; } }
  .merit_list > li {
    align-items: center;
    background: #f9f8f4;
    border-radius: 10px;
    min-height: 300px;
    padding: 35px 50px 35px 60px; }
    @media (min-width: 769px), print {
      .merit_list > li {
        display: flex; } }
    @media (max-width: 1240px) {
      .merit_list > li {
        border-radius: 0.8064516129vw;
        min-height: 24.1935483871vw;
        padding: 2.8225806452vw 4.0322580645vw 2.8225806452vw 4.8387096774vw; } }
    @media (max-width: 768px) {
      .merit_list > li {
        border-radius: 2.5641025641vw;
        padding: 5.1282051282vw 5.1282051282vw 7.6923076923vw; } }
  .merit_list_num {
    font-size: 1.5rem;
    color: #e97971;
    font-weight: 700;
    line-height: 1;
    text-align: center; }
    @media (max-width: 1240px) {
      .merit_list_num {
        font-size: 1.935483871vw; } }
    @media (max-width: 768px) {
      .merit_list_num {
        font-size: 4.6153846154vw;
        margin-bottom: 3.8461538462vw; } }
    .merit_list_num strong {
      font-size: 3.75rem; }
      @media (max-width: 1240px) {
        .merit_list_num strong {
          font-size: 4.8387096774vw; } }
      @media (min-width: 769px), print {
        .merit_list_num strong {
          display: block; } }
      @media (max-width: 768px) {
        .merit_list_num strong {
          font-size: 10.2564102564vw; } }
  .merit_list_img {
    padding: 0 65px;
    width: 490px; }
    @media (max-width: 1240px) {
      .merit_list_img {
        padding: 0 5.2419354839vw;
        width: 39.5161290323vw; } }
    @media (max-width: 768px) {
      .merit_list_img {
        margin: 0 auto 3.8461538462vw;
        padding: 0;
        width: 76.9230769231vw; } }
  .merit_list_txt {
    flex: 1 1 0%; }
    .merit_list_txt p, .merit_list_txt ul {
      margin: .5em 0; }
      .merit_list_txt p strong, .merit_list_txt ul strong {
        background: linear-gradient(to bottom, transparent 60%, #fff280 60%); }
    .merit_list_txt ul li {
      padding-left: 1.5em;
      position: relative; }
      .merit_list_txt ul li::before {
        mask-repeat: no-repeat;
        mask-size: contain;
        position: absolute;
        background-color: #e97971;
        content: "";
        height: .9em;
        left: 0;
        mask-image: url("images/ico-check.svg");
        top: .5em;
        width: .9em; }

.about_intro {
  overflow: hidden; }
  @media (min-width: 769px), print {
    .about_intro {
      align-items: center;
      display: grid;
      gap: 4%;
      grid-template-columns: 1fr 32%; } }
  .about_intro_item {
    font-size: 1.125rem;
    display: grid;
    gap: 2em; }
    @media (max-width: 1240px) {
      .about_intro_item {
        font-size: 1.4516129032vw; } }
    @media (max-width: 768px) {
      .about_intro_item {
        font-size: 3.5897435897vw; } }
  .about_intro_txt p {
    margin-top: 1em; }
    .about_intro_txt p strong {
      background: linear-gradient(to bottom, transparent 60%, #fff280 60%); }
  .about_intro_ttl {
    font-size: 1.5rem;
    color: #2a4c68; }
    @media (max-width: 1240px) {
      .about_intro_ttl {
        font-size: 1.935483871vw; } }
    @media (max-width: 768px) {
      .about_intro_ttl {
        font-size: 4.1025641026vw; } }
  @media (max-width: 768px) {
    .about_intro_img {
      height: 51.2820512821vw;
      margin: 5.1282051282vw auto 0;
      width: 70%; } }
  .about_intro_img img {
    width: 100%; }
    @media (max-width: 768px) {
      .about_intro_img img {
        height: 100%;
        object-fit: cover;
        object-position: top center; } }
.about_profile {
  background: #fdf1f0;
  border-radius: 10px;
  padding: 50px; }
  @media (max-width: 1240px) {
    .about_profile {
      border-radius: 0.8064516129vw;
      padding: 4.0322580645vw; } }
  @media (max-width: 768px) {
    .about_profile {
      border-radius: 2.5641025641vw;
      padding: 7.6923076923vw 5.1282051282vw 5.1282051282vw; } }
  @media (min-width: 769px), print {
    .about_profile_box {
      align-items: center;
      display: flex;
      gap: 50px;
      margin-bottom: 30px; } }
  @media (max-width: 1240px) {
    .about_profile_box {
      gap: 4.0322580645vw;
      margin-bottom: 2.4193548387vw; } }
  @media (max-width: 768px) {
    .about_profile_box {
      margin-bottom: 5.1282051282vw; } }
  .about_profile_logo {
    width: 25%; }
    @media (max-width: 768px) {
      .about_profile_logo {
        margin: 0 auto 5.1282051282vw;
        width: 35.1282051282vw; } }
  .about_profile_txt {
    flex: 1 1 0%; }
    .about_profile_txt dt {
      font-size: 1.5rem;
      font-weight: 700;
      margin-bottom: 5px; }
      @media (max-width: 1240px) {
        .about_profile_txt dt {
          font-size: 1.935483871vw; } }
      @media (max-width: 1240px) {
        .about_profile_txt dt {
          margin-bottom: 0.4032258065vw; } }
      @media (max-width: 768px) {
        .about_profile_txt dt {
          font-size: 4.6153846154vw;
          margin-bottom: 1.2820512821vw;
          text-align: center; } }
    .about_profile_txt dd {
      font-size: 1.125rem; }
      @media (max-width: 1240px) {
        .about_profile_txt dd {
          font-size: 1.4516129032vw; } }
      @media (max-width: 768px) {
        .about_profile_txt dd {
          font-size: 3.5897435897vw; } }
  .about_profile_tbl {
    border: 1px solid #ccc; }
    .about_profile_tbl tr {
      background: #fff;
      border-bottom: 1px solid #ccc; }
      .about_profile_tbl tr:nth-of-type(odd) {
        background: #f9f8f4; }
    .about_profile_tbl th, .about_profile_tbl td {
      font-size: 1rem;
      padding: 16px 30px;
      text-align: left;
      vertical-align: top; }
      @media (max-width: 1240px) {
        .about_profile_tbl th, .about_profile_tbl td {
          font-size: 1.2903225806vw; } }
      @media (max-width: 1240px) {
        .about_profile_tbl th, .about_profile_tbl td {
          padding: 1.2903225806vw 2.4193548387vw; } }
      @media (max-width: 768px) {
        .about_profile_tbl th, .about_profile_tbl td {
          font-size: 3.5897435897vw;
          display: block;
          padding: 3.0769230769vw 3.8461538462vw;
          width: 100%; } }
    @media (min-width: 769px), print {
      .about_profile_tbl th {
        width: 25%; } }
    @media (max-width: 768px) {
      .about_profile_tbl th {
        padding-bottom: 0; } }
    @media (max-width: 768px) {
      .about_profile_tbl td {
        padding-top: 0; } }
  .about_profile_sub {
    font-size: 1rem;
    text-align: right; }
    @media (max-width: 1240px) {
      .about_profile_sub {
        font-size: 1.2903225806vw; } }
    @media (max-width: 768px) {
      .about_profile_sub {
        font-size: 3.0769230769vw; } }

.flow_list {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 50px; }
  @media (max-width: 1240px) {
    .flow_list {
      gap: 1.6129032258vw;
      margin-bottom: 2.4193548387vw; } }
  @media (max-width: 768px) {
    .flow_list {
      gap: 10.2564102564vw;
      grid-template-columns: 1fr;
      margin-bottom: 5.1282051282vw;
      margin-top: 10.2564102564vw; } }
  .flow_list > li {
    border: 3px solid #e97971;
    border-radius: 10px;
    margin-top: 50px;
    padding: 40px 27px;
    position: relative; }
    @media (max-width: 1240px) {
      .flow_list > li {
        border-width: 0.2419354839vw;
        border-radius: 0.8064516129vw;
        margin-top: 4.0322580645vw;
        padding: 3.2258064516vw 2.1774193548vw; } }
    @media (max-width: 768px) {
      .flow_list > li {
        align-items: center;
        border-width: 0.5128205128vw;
        border-radius: 2.5641025641vw;
        display: grid;
        gap: 2.5641025641vw;
        grid-template-columns: 30.7692307692vw 1fr;
        margin-top: 0;
        padding: 5.1282051282vw; } }
    .flow_list > li::after {
      background: linear-gradient(to bottom right, transparent 50%, #e97971 50%);
      border-bottom-right-radius: 3px;
      content: "";
      height: 28px;
      position: absolute;
      right: -25px;
      top: 50%;
      transform: rotate(-45deg) translateY(-50%);
      width: 28px; }
      @media (max-width: 1240px) {
        .flow_list > li::after {
          border-bottom-right-radius: 0.2419354839vw;
          height: 2.2580645161vw;
          right: -2.0161290323vw;
          width: 2.2580645161vw; } }
      @media (max-width: 768px) {
        .flow_list > li::after {
          bottom: -9.2307692308vw;
          border-bottom-right-radius: 0.7692307692vw;
          height: 7.1794871795vw;
          left: 50%;
          right: auto;
          transform: rotate(45deg) translateX(-50%);
          top: auto;
          width: 7.1794871795vw; } }
    .flow_list > li:last-of-type::after {
      display: none; }
  .flow_list_num {
    font-size: 1.5rem;
    color: #e97971;
    font-weight: 700;
    left: 10px;
    line-height: 1;
    position: absolute;
    top: -58px; }
    @media (max-width: 1240px) {
      .flow_list_num {
        font-size: 1.935483871vw; } }
    @media (max-width: 1240px) {
      .flow_list_num {
        left: 0.8064516129vw;
        top: -4.6774193548vw; } }
    @media (max-width: 768px) {
      .flow_list_num {
        font-size: 4.6153846154vw;
        left: auto;
        right: 1.2820512821vw;
        top: -9.7435897436vw; } }
    .flow_list_num strong {
      font-size: 3.75rem; }
      @media (max-width: 1240px) {
        .flow_list_num strong {
          font-size: 4.8387096774vw; } }
      @media (max-width: 768px) {
        .flow_list_num strong {
          font-size: 10.2564102564vw; } }
  .flow_list_img {
    text-align: center; }
    .flow_list_img img {
      height: 150px;
      margin-bottom: 20px;
      width: auto; }
      @media (max-width: 1240px) {
        .flow_list_img img {
          height: 12.0967741935vw;
          margin-bottom: 1.6129032258vw; } }
      @media (max-width: 768px) {
        .flow_list_img img {
          height: 100%;
          max-height: 30.7692307692vw;
          margin-bottom: 0;
          width: 100%;
          max-width: 30.7692307692vw; } }
  .flow_list_txt strong {
    background: linear-gradient(to bottom, transparent 60%, #fff280 60%); }
  .flow_list_att li {
    font-size: 1rem;
    padding-left: 1em;
    position: relative; }
    @media (max-width: 1240px) {
      .flow_list_att li {
        font-size: 1.2903225806vw; } }
    @media (max-width: 768px) {
      .flow_list_att li {
        font-size: 3.0769230769vw; } }
    .flow_list_att li::before {
      content: "※";
      left: 0;
      position: absolute; }
.flow_txt {
  font-weight: 700;
  text-align: center; }
  @media (max-width: 768px) {
    .flow_txt {
      font-size: 4.1025641026vw;
      text-align: left; } }

@media (min-width: 769px), print {
  .outro_list {
    display: grid;
    column-gap: 2.5%;
    grid-template-columns: repeat(3, 1fr);
    margin-bottom: 60px; } }
@media (max-width: 1240px) {
  .outro_list {
    margin-bottom: 4.8387096774vw; } }
@media (max-width: 768px) {
  .outro_list {
    align-items: center;
    display: flex;
    column-gap: 3%;
    flex-wrap: wrap;
    margin-bottom: 7.6923076923vw; } }
.outro_list li {
  align-items: center;
  aspect-ratio: 1/1;
  background: #fdf1f0 url("images/about-bg01.svg") center/90% no-repeat;
  border-radius: 100%;
  color: #e97971;
  display: flex;
  font-weight: 700;
  justify-content: center;
  text-align: center; }
  @media (max-width: 768px) {
    .outro_list li {
      width: 48.5%; }
      .outro_list li:first-of-type {
        margin: 0 25.75%; } }
.outro_list_item01 {
  font-size: 2.5rem;
  line-height: 1.2; }
  @media (max-width: 1240px) {
    .outro_list_item01 {
      font-size: 3.2258064516vw; } }
  @media (max-width: 768px) {
    .outro_list_item01 {
      font-size: 5.1282051282vw; } }
  .outro_list_item01 strong {
    font-size: 5rem; }
    @media (max-width: 1240px) {
      .outro_list_item01 strong {
        font-size: 6.4516129032vw; } }
    @media (max-width: 768px) {
      .outro_list_item01 strong {
        font-size: 10.2564102564vw; } }
.outro_list_item02 {
  font-size: 1.875rem;
  line-height: 1.2; }
  @media (max-width: 1240px) {
    .outro_list_item02 {
      font-size: 2.4193548387vw; } }
  @media (max-width: 768px) {
    .outro_list_item02 {
      font-size: 3.8461538462vw; } }
  .outro_list_item02 strong {
    font-size: 3.75rem; }
    @media (max-width: 1240px) {
      .outro_list_item02 strong {
        font-size: 4.8387096774vw; } }
    @media (max-width: 768px) {
      .outro_list_item02 strong {
        font-size: 7.6923076923vw; } }
.outro_list_item03 {
  line-height: 1.5;
  font-size: 2.5rem; }
  @media (max-width: 1240px) {
    .outro_list_item03 {
      font-size: 3.2258064516vw; } }
  @media (max-width: 768px) {
    .outro_list_item03 {
      font-size: 5.1282051282vw; } }
.outro_txt {
  font-size: 2.5rem;
  background: url("images/about-img02.svg") 10px top/168px auto no-repeat, url("images/about-img03.svg") right 20px top/213px auto no-repeat;
  font-weight: 700;
  text-align: center;
  padding: 70px 200px; }
  @media (max-width: 1240px) {
    .outro_txt {
      font-size: 3.2258064516vw; } }
  @media (max-width: 1240px) {
    .outro_txt {
      background-position: 0.8064516129vw top, right 1.6129032258vw top;
      background-size: 13.5483870968vw auto, 17.1774193548vw auto;
      padding: 5.6451612903vw 16.1290322581vw; } }
  @media (max-width: 768px) {
    .outro_txt {
      font-size: 4.6153846154vw;
      background-position: right 82% bottom, 82% bottom;
      background-size: auto 51.2820512821vw;
      padding: 0 0 56.4102564103vw; } }
