:root {
  --w-full: 1366px;
  --w-wrap: 1012px;
  --w-full-sp: 375px;
  --w-wrap-sp: 84vw;
  --h-header: 70px;
  --h-header-sp: min(16vw, 60px);
  --c-co: #004f9b;
  --c-acnt: #FFEE00;
  --c-dark:#00316C;
  --c-bg: #E4EFF9;
  --c-txt: #333;
}

:root:has(:modal) {
  overflow: hidden;
  scrollbar-gutter: stable;
}

html, body {
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

html {
  scroll-margin-block-start: var(--h-header);
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
}
@media (width < 740px) {
  html {
    scroll-margin-block-start: var(--h-header-sp);
  }
}

body {
  width: 100%;
  min-height: 100dvh;
  height: 100%;
  position: relative;
  z-index: 1;
}
body.is-stop {
  overflow: hidden;
}

h1, h2, h3, h4, h5 {
  line-height: 1;
}

p, a, li {
  line-height: 1;
}

p {
  text-align: justify;
}

img {
  display: block;
  width: 100%;
  height: auto;
}

@media (any-hover: hover) and (pointer: fine) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
.l__content {
  contain: content;
}
.l__wrapper {
  width: 100%;
  overflow: hidden;
}
.l__container {
  width: min(100vw - 80px, var(--w-wrap));
  margin-inline: auto;
}
@media (width < 740px) {
  .l__container {
    width: var(--w-wrap-sp);
  }
}
.l__fixed-bg {
  position: relative;
}
.l__fixed-bg::before {
  content: "";
  width: 100%;
  height: 100vh;
  background-image: url(../img/bg-absolute.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
  position: fixed;
  inset: 0;
  z-index: -1;
}
@media (width < 740px) {
  .l__fixed-bg::before {
    background-image: url(../img/bg-absolute_sp.jpg);
  }
}

.m__fv {
  height: calc(100dvh - var(--h-header));
  height: calc(100vh - var(--h-header));
  position: relative;
  z-index: 1;
  -webkit-margin-before: var(--h-header);
          margin-block-start: var(--h-header);
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  background-color: #fff;
}
@media (width < 740px) {
  .m__fv {
    height: 130.13vw;
    -webkit-margin-before: var(--h-header-sp);
            margin-block-start: var(--h-header-sp);
  }
}
.m__fv_slider {
  grid-area: 1/1/2/2;
  width: 100%;
  height: 100%;
}
.m__fv_slider .splide, .m__fv_slider .splide__track, .m__fv_slider .splide__list, .m__fv_slider .splide__slide {
  width: 100%;
  height: 100%;
}
.m__fv_slider .splide__slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.m__heading_fv {
  grid-area: 1/1/2/2;
  width: max(754px, 62.96vw);
  aspect-ratio: 860 / 171;
  background-color: var(--c-co);
  font-size: 1.61vw;
  color: #fff;
  -webkit-padding-before: 1.8181818182em;
          padding-block-start: 1.8181818182em;
  -webkit-padding-after: 1.1818181818em;
          padding-block-end: 1.1818181818em;
  -webkit-padding-start: 1.8181818182em;
          padding-inline-start: 1.8181818182em;
  -webkit-padding-end: 1.2727272727em;
          padding-inline-end: 1.2727272727em;
  display: grid;
  grid-template-columns: -webkit-max-content 1fr;
  grid-template-columns: max-content 1fr;
  gap: 0.6818181818em 0.8636363636em;
  align-items: center;
  align-self: end;
  -webkit-margin-after: 137px;
          margin-block-end: 137px;
}
@media (width < 900px) {
  .m__heading_fv {
    width: min(84vw, 754px);
    font-size: 2.38vw;
  }
}
@media (width < 740px) {
  .m__heading_fv {
    grid-template-columns: 1fr;
    font-size: min(4.53vw, 1.7rem);
    padding-inline: min(5.33vw, 20px);
    -webkit-padding-before: min(6.13vw, 23px);
            padding-block-start: min(6.13vw, 23px);
    -webkit-padding-after: min(4vw, 15px);
            padding-block-end: min(4vw, 15px);
    -webkit-margin-after: min(14.13vw, 53px);
            margin-block-end: min(14.13vw, 53px);
  }
}
.m__heading_fv .-img1 {
  grid-area: 1/1/2/3;
}
.m__heading_fv .-img2 {
  grid-area: 2/1/3/2;
  width: max(169px, 9.4090909091em);
}
@media (width < 740px) {
  .m__heading_fv .-img2 {
    width: min(47.2vw, 177px);
  }
}
.m__heading_fv .-txt {
  font-size: max(1.8rem, 1em);
  font-weight: 500;
  letter-spacing: 0.09em;
  grid-area: 2/2/3/3;
}
@media (width < 740px) {
  .m__heading_fv .-txt {
    grid-area: 3/1/4/2;
    font-size: min(4.53vw, 1.8rem);
  }
}
.m__heading_block {
  font-size: clamp(2.4rem, 3.66vw, 4rem);
  -webkit-margin-after: 1.75em;
          margin-block-end: 1.75em;
}
@media (width < 740px) {
  .m__heading_block {
    font-size: min(6.4vw, 2.4rem);
  }
}
.m__heading_block p {
  font-size: 16px;
  color: var(--c-co);
  display: block;
  -webkit-padding-start: 0.625em;
          padding-inline-start: 0.625em;
  border-left: 3px solid var(--c-co);
  -webkit-margin-after: 0.9375em;
          margin-block-end: 0.9375em;
  font-weight: 900;
  letter-spacing: 0.05em;
}
.m__heading_block h2 {
  font-weight: 700;
  line-height: 1.4;
}
.m__heading_block.-wt {
  -webkit-margin-after: 1em;
          margin-block-end: 1em;
}
.m__heading_block.-wt p, .m__heading_block.-wt h2 {
  color: #fff;
}
.m__heading_block.-wt p {
  border-left-color: #fff;
}
.m__heading_center {
  font-size: min(6vw, 3rem);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}
.m__heading_center::after {
  content: "";
  width: min(10.67vw, 40px);
  height: 2px;
  background-color: var(--c-co);
  display: block;
  margin-inline: auto;
  -webkit-margin-before: 0.8em;
          margin-block-start: 0.8em;
}
.m__btn {
  font-size: min(4.8vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.15em;
  width: 12.9em;
  height: 3.7em;
  border-radius: 1.85em;
  display: grid;
  place-items: center;
  background-size: 0.75em;
  background-repeat: no-repeat;
  background-position: right 1.8em center;
  transition: all 0.2s;
}
@media (width < 740px) {
  .m__btn {
    width: min(68vw, 255px);
    background-size: 0.8333333333em;
  }
}
.m__btn_newgrad {
  color: var(--c-acnt);
  background-color: var(--c-co);
  -webkit-padding-end: 0.75em;
          padding-inline-end: 0.75em;
  background-image: url(../img/ico-blanc-acnt.png);
}
@media (width < 740px) {
  .m__btn_newgrad {
    -webkit-padding-end: 0.8333333333em;
            padding-inline-end: 0.8333333333em;
    background-position: right 3.3333333333em center;
  }
}
.m__btn_newgrad:focus-visible {
  color: var(--c-co);
  background-color: var(--c-acnt);
  background-image: url(../img/ico-blank-co.png);
}
@media (any-hover: hover) {
  .m__btn_newgrad:hover {
    color: var(--c-co);
    background-color: var(--c-acnt);
    background-image: url(../img/ico-blank-co.png);
  }
}
.m__btn_career {
  color: var(--c-co);
  background-color: var(--c-acnt);
  -webkit-padding-end: 0.45em;
          padding-inline-end: 0.45em;
  background-image: url(../img/ico-blank-co.png);
}
@media (width < 740px) {
  .m__btn_career {
    -webkit-padding-end: 1.1111111111em;
            padding-inline-end: 1.1111111111em;
    background-position: right 2.5555555556em center;
  }
}
.m__btn_career:focus-visible {
  color: var(--c-acnt);
  background-color: var(--c-co);
  background-image: url(../img/ico-blanc-acnt.png);
}
@media (any-hover: hover) {
  .m__btn_career:hover {
    color: var(--c-acnt);
    background-color: var(--c-co);
    background-image: url(../img/ico-blanc-acnt.png);
  }
}
.m__btn_bottom {
  display: none;
}
@media (width < 740px) {
  .m__btn_bottom {
    display: grid;
    grid-template-columns: 1fr min(13.33vw, 50px);
    width: 100vw;
    height: min(13.33vw, 50px);
    position: -webkit-sticky;
    position: sticky;
    bottom: 0;
    z-index: 99;
  }
}
.m__btn_bottom .-entry {
  display: grid;
  place-items: center;
  background-color: var(--c-acnt);
  color: var(--c-co);
  font-weight: 700;
  font-size: min(5.6vw, 21px);
  letter-spacing: 0.1em;
}
.m__btn_bottom .-top {
  display: grid;
  place-items: center;
  place-content: center;
  gap: 0.5em;
  font-size: min(3.73vw, 14px);
  color: #fff;
  background-color: var(--c-dark);
  font-weight: 700;
  letter-spacing: 0.1em;
}
.m__btn_bottom .-top::before {
  content: "";
  width: 1.1428571429em;
  height: 0.7857142857em;
  display: block;
  background-color: #fff;
  -webkit-clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
          clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
}
.m__block1 {
  font-size: 1.8rem;
  color: #fff;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  background-color: var(--c-co);
  height: 35.1111111111em;
}
@media (width < 740px) {
  .m__block1 {
    font-size: 1.5rem;
    height: min(168.8vw, 700px);
  }
}
.m__block1 picture {
  display: contents;
}
.m__block1 .-map {
  grid-area: 1/1/2/2;
  height: 35.1111111111em;
  width: auto;
  z-index: 1;
  -webkit-margin-start: calc((100vw - var(--w-full)) / 2 + 57px);
          margin-inline-start: calc((100vw - var(--w-full)) / 2 + 57px);
}
@media (width < 900px) {
  .m__block1 .-map {
    -webkit-margin-start: calc((100vw - var(--w-full)) / 2 + 80px);
            margin-inline-start: calc((100vw - var(--w-full)) / 2 + 80px);
  }
}
@media (width < 740px) {
  .m__block1 .-map {
    width: min(84.8vw, 318px);
    height: auto;
    -webkit-margin-start: unset;
            margin-inline-start: unset;
  }
}
.m__block1 .-bg-txt {
  grid-area: 1/1/2/2;
  font-size: 5.42vw;
  letter-spacing: 0.02em;
  color: rgba(0, 79, 155, 0.21);
  justify-self: center;
  align-self: end;
  z-index: 2;
  mix-blend-mode: multiply;
  font-weight: 700;
  white-space: nowrap;
  translate: -0.05em 0.15em;
}
@media (width < 900px) {
  .m__block1 .-bg-txt {
    font-size: 12vw;
    width: calc(100vw + 0.05em);
    overflow: hidden;
  }
}
@media (width < 740px) {
  .m__block1 .-bg-txt {
    translate: -0.05em 0.08em;
  }
}
.m__block1 .-inner {
  grid-area: 1/1/2/2;
  align-self: center;
  z-index: 3;
}
@media (width < 740px) {
  .m__block1 .-inner {
    align-self: end;
    -webkit-margin-after: min(13.33vw, 50px);
            margin-block-end: min(13.33vw, 50px);
  }
}
.m__block1 .-txts {
  width: 23.8888888889em;
  margin-inline: auto 0;
}
@media (width < 900px) {
  .m__block1 .-txts {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
@media (width < 740px) {
  .m__block1 .-txts {
    width: var(--w-wrap-sp);
  }
}
.m__block1 .-txt1 {
  font-size: 3.1111111111em;
  font-weight: 700;
  line-height: 1.5;
  -webkit-margin-after: 0.8928571429em;
          margin-block-end: 0.8928571429em;
}
@media (width < 740px) {
  .m__block1 .-txt1 {
    font-size: min(9.87vw, 5.6rem);
  }
}
.m__block1 .-txt2 {
  font-weight: 400;
  line-height: 2.1;
}
.m__block3 .-sec-2 {
  font-size: min(4.27vw, 1.6rem);
  padding-block: min(16vw, 60px);
  padding-inline: min(8vw, 66px);
  border-radius: min(8vw, 30px);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}
@media (width < 740px) {
  .m__block3 .-sec-2 {
    width: 89.33vw;
    translate: -2.67vw 0;
  }
}
.m__block3 .-sec-2 .-txt1 {
  font-size: 1.25em;
  line-height: 1.8;
  font-weight: 400;
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
  -webkit-margin-after: 2em;
          margin-block-end: 2em;
}
@media (width < 740px) {
  .m__block3 .-sec-2 .-txt1 {
    font-size: 1.1333333333em;
  }
}
.m__block3 .-sec-2 .-txt2 {
  font-size: min(4.27vw, 1.5rem);
  font-weight: 400;
  line-height: 1.8;
  -webkit-margin-before: 3.0666666667em;
          margin-block-start: 3.0666666667em;
  text-align: start;
}
@media (width < 740px) {
  .m__block3 .-sec-2 .-txt2 {
    -webkit-margin-before: min(5.33vw, 20px);
            margin-block-start: min(5.33vw, 20px);
  }
}
.m__block3 .-sec-2 h4 {
  font-size: 1.5625em;
  font-weight: 700;
  display: grid;
  grid-template-columns: -webkit-max-content 1fr;
  grid-template-columns: max-content 1fr;
  gap: 0.32em;
  align-items: end;
}
@media (width < 740px) {
  .m__block3 .-sec-2 h4 {
    -webkit-margin-before: min(6.67vw, 25px);
            margin-block-start: min(6.67vw, 25px);
  }
}
.m__block3 .-sec-2 h4 span {
  font-size: 0.68em;
  display: block;
  color: var(--c-co);
}
.m__block3 .-sec-2-list {
  -webkit-margin-before: min(13.33vw, 40px);
          margin-block-start: min(13.33vw, 40px);
}
.m__block3 .-sec-2-list li:not(:first-of-type) {
  -webkit-margin-before: min(5.33vw, 20px);
          margin-block-start: min(5.33vw, 20px);
}
.m__block3 .-sec-2-list li h4 {
  grid-area: h;
}
.m__block3 .-sec-2-list li p {
  grid-area: p;
}
.m__block3 .-sec-2-list li button {
  grid-area: img;
  align-self: start;
}
.m__block3 .-sec-2-list li .-grid {
  display: grid;
  grid-template-columns: 1fr 36%;
  gap: 0 5%;
  grid-template-areas: "h img" "p img";
}
@media (width < 740px) {
  .m__block3 .-sec-2-list li .-grid {
    grid-template-columns: 1fr;
    grid-template-areas: "img" "h" "p";
  }
}
.m__block3 .-sec-2-list li .-triangle {
  -webkit-margin-before: min(10.67vw, 40px);
          margin-block-start: min(10.67vw, 40px);
  margin-inline: auto;
  display: block;
  width: min(18.67vw, 106px);
  aspect-ratio: 53 / 27;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #D9D9D9;
}
.m__block3 .-sec-2-list li .-grid2 {
  display: grid;
  grid-template-rows: -webkit-max-content 1fr;
  grid-template-rows: max-content 1fr;
  gap: 0 5%;
}
.m__block3 .-sec-2-list li:nth-of-type(odd) .-grid2 {
  grid-template-columns: 47% 1fr;
  grid-template-areas: "img h" "img p";
}
@media (width < 740px) {
  .m__block3 .-sec-2-list li:nth-of-type(odd) .-grid2 {
    grid-template-columns: 1fr;
    grid-template-areas: "img" "h" "p";
  }
}
.m__block3 .-sec-2-list li:nth-of-type(even) .-grid2 {
  grid-template-columns: 1fr 47%;
  grid-template-areas: "h img" "p img";
  padding-block: 80px;
}
@media (width < 740px) {
  .m__block3 .-sec-2-list li:nth-of-type(even) .-grid2 {
    grid-template-columns: 1fr;
    grid-template-areas: "img" "h" "p";
    padding-block: 1em;
  }
}
.m__block4 {
  -webkit-margin-before: min(24vw, 145px);
          margin-block-start: min(24vw, 145px);
}
.m__block5 {
  font-size: 1.7rem;
  container-type: inline-size;
}
@media (width < 740px) {
  .m__block5 {
    font-size: 1.5rem;
  }
}
.m__block5.-bg-co {
  background-color: var(--c-co);
}
.m__block5.-bg-co .-txt1 {
  color: #fff;
}
.m__block5.-bg-map {
  background-color: var(--c-bg);
  background-image: url(../img/img-map-2.png);
  background-size: 40.1176470588em;
  background-repeat: no-repeat;
  background-position: top 0 left calc((100vw - var(--w-full)) / 2 + 748px);
}
@media (width < 1256px) {
  .m__block5.-bg-map {
    background-position: top 0 left calc(60vw - 171px);
  }
}
@media (width < 900px) {
  .m__block5.-bg-map {
    background-size: min(76.27vw, 400px);
    background-position: top 0 right -5%;
  }
}
@media (width < 740px) {
  .m__block5.-bg-map {
    background-position: top 0 right max(-53%, -64px);
  }
}
.m__block5.-bg-map .-txt1 {
  width: 582px;
  line-height: 2.2;
  font-weight: 400;
}
@media (width < 1256px) {
  .m__block5.-bg-map .-txt1 {
    width: calc(100% - 546px);
  }
}
@media (width < 900px) {
  .m__block5.-bg-map .-txt1 {
    width: 100%;
    -webkit-margin-before: min(50.67vw, 90px);
            margin-block-start: min(50.67vw, 90px);
  }
}
.m__block5_roof {
  width: min(1189px, 100% - (100% - var(--w-wrap)) / 2);
  -webkit-margin-start: max(40px, (100% - var(--w-wrap)) / 2);
          margin-inline-start: max(40px, (100% - var(--w-wrap)) / 2);
  display: grid;
  grid-template-columns: 1fr 550px;
  grid-template-rows: -webkit-max-content 1fr;
  grid-template-rows: max-content 1fr;
  grid-template-areas: "h img" "p img";
  gap: 0 30px;
  -webkit-margin-after: min(8vw, 80px);
          margin-block-end: min(8vw, 80px);
}
@media (width < 900px) {
  .m__block5_roof {
    width: calc(100% - 40px);
    grid-template-columns: 1fr 45%;
    grid-template-areas: "h img" "p p";
    gap: 30px 0;
  }
}
.m__block5_roof .m__heading_block {
  grid-area: h;
  -webkit-margin-before: min(24vw, 150px);
          margin-block-start: min(24vw, 150px);
}
.m__block5_roof .-txt1 {
  grid-area: p;
}
@media (width < 900px) {
  .m__block5_roof .-txt1 {
    width: calc(100% - 40px);
  }
}
.m__block5_roof .-img-wrap {
  grid-area: img;
  border-radius: 50px;
  width: 803px;
  aspect-ratio: 803 / 488;
  overflow: hidden;
}
@media (width < 900px) {
  .m__block5_roof .-img-wrap {
    width: min(43.73vw, 100%);
    aspect-ratio: 41 / 54;
    border-top-left-radius: min(4vw, 15px);
    border-bottom-left-radius: min(4vw, 15px);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    justify-self: end;
  }
}
.m__block5_roof .-img-wrap img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media (width < 900px) {
  .m__block5_roof .-img-wrap img {
    -o-object-position: left 27% top 0;
       object-position: left 27% top 0;
  }
}
.m__block5 .-txt1 {
  line-height: 2.2;
  font-weight: 400;
}
.m__block6 .-txt1 {
  font-size: min(4.53vw, 1.7rem);
  line-height: 1.8;
  font-weight: 400;
  -webkit-margin-before: 2.3529411765em;
          margin-block-start: 2.3529411765em;
}
@media (width < 740px) {
  .m__block6 .-txt1 {
    font-size: 1.5rem;
    -webkit-margin-before: 1.4705882353em;
            margin-block-start: 1.4705882353em;
  }
}
.m__block6 .l__container {
  container-type: inline-size;
}
.m__block7 {
  -webkit-padding-after: 40px;
          padding-block-end: 40px;
}
.m__about {
  font-size: 1.7rem;
}
@media (width < 740px) {
  .m__about {
    font-size: 1.5rem;
  }
}
.m__about .-box {
  display: grid;
  align-items: start;
  gap: 3.8823529412em;
}
@media (width < 900px) {
  .m__about .-box {
    gap: 4vw;
  }
}
@media (width < 740px) {
  .m__about .-box {
    gap: min(8vw, 30px);
  }
}
.m__about .-box p {
  font-weight: 400;
  line-height: 2;
}
.m__about .-box:nth-of-type(odd) {
  grid-template-columns: 1fr 42%;
}
@media (width < 900px) {
  .m__about .-box:nth-of-type(odd) {
    grid-template-columns: 1fr 45%;
  }
}
@media (width < 740px) {
  .m__about .-box:nth-of-type(odd) {
    grid-template-columns: 1fr;
  }
}
.m__about .-box:nth-of-type(even) {
  grid-template-columns: 42% 1fr;
}
@media (width < 900px) {
  .m__about .-box:nth-of-type(even) {
    grid-template-columns: 45% 1fr;
  }
}
@media (width < 740px) {
  .m__about .-box:nth-of-type(even) {
    grid-template-columns: 1fr;
  }
}
.m__about .-box:nth-of-type(even) p {
  order: 2;
}
@media (width < 740px) {
  .m__about .-box:nth-of-type(even) p {
    order: 1;
  }
}
.m__about .-box:nth-of-type(even) .-modal-open {
  order: 1;
}
@media (width < 740px) {
  .m__about .-box:nth-of-type(even) .-modal-open {
    order: 2;
  }
}
.m__about .-box + .-box {
  -webkit-margin-before: min(16vw, 70px);
          margin-block-start: min(16vw, 70px);
}
.m__works {
  font-size: 1.7rem;
}
@media (width < 740px) {
  .m__works {
    font-size: 1.6rem;
  }
}
.m__works .-box {
  display: grid;
  align-items: start;
  gap: 8%;
}
@media (width < 900px) {
  .m__works .-box {
    gap: 4vw;
  }
}
@media (width < 740px) {
  .m__works .-box {
    gap: min(10.67vw, 40px);
  }
}
.m__works .-box h3 {
  font-size: clamp(2.5rem, 3.02vw, 3.3rem);
  display: grid;
  grid-template-columns: -webkit-max-content 1fr;
  grid-template-columns: max-content 1fr;
  gap: 0.5em;
  -webkit-margin-after: 0.9090909091em;
          margin-block-end: 0.9090909091em;
}
@media (width < 740px) {
  .m__works .-box h3 {
    font-size: min(6.67vw, 2.5rem);
  }
}
.m__works .-box h3 .-num {
  display: block;
  font-size: 0.4848484848em;
  color: var(--c-co);
  font-weight: 900;
  -webkit-margin-before: 0.2em;
          margin-block-start: 0.2em;
}
@media (width < 740px) {
  .m__works .-box h3 .-num {
    font-size: 0.56em;
    -webkit-margin-before: 0.25em;
            margin-block-start: 0.25em;
  }
}
.m__works .-box h3 .-ttl {
  display: block;
  line-height: 1.2;
  font-weight: 700;
}
.m__works .-box p {
  font-weight: 400;
  line-height: 1.8;
  text-align: start;
}
.m__works .-box:nth-of-type(odd) {
  grid-template-columns: 1fr 54%;
}
@media (width < 900px) {
  .m__works .-box:nth-of-type(odd) {
    grid-template-columns: 1fr 50%;
  }
}
@media (width < 740px) {
  .m__works .-box:nth-of-type(odd) {
    grid-template-columns: 1fr;
  }
}
.m__works .-box:nth-of-type(even) {
  grid-template-columns: 54% 1fr;
}
@media (width < 900px) {
  .m__works .-box:nth-of-type(even) {
    grid-template-columns: 50% 1fr;
  }
}
@media (width < 740px) {
  .m__works .-box:nth-of-type(even) {
    grid-template-columns: 1fr;
  }
}
.m__works .-box:nth-of-type(even) .-txt {
  order: 2;
}
@media (width < 740px) {
  .m__works .-box:nth-of-type(even) .-txt {
    order: 1;
  }
}
.m__works .-box:nth-of-type(even) .-modal-open {
  order: 1;
}
@media (width < 740px) {
  .m__works .-box:nth-of-type(even) .-modal-open {
    order: 2;
  }
}
.m__works .-box + .-box {
  -webkit-margin-before: min(18.67vw, 100px);
          margin-block-start: min(18.67vw, 100px);
}
.m__member-1 {
  border: 1px solid var(--c-co);
  background-color: var(--c-co);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-areas: "card1 card2 card3" "card4 card5 card5" "card4 card6 card7";
  gap: 1px;
}
@media (width < 740px) {
  .m__member-1 {
    grid-template-columns: 1fr;
    grid-template-areas: "card1" "card2" "card3" "card4" "card5" "card6" "card7";
    width: min(100%, 400px);
    margin-inline: auto;
  }
}
.m__member-1 .-card {
  font-size: min(1.47vw, 1.6rem);
  -webkit-padding-before: 1.875em;
          padding-block-start: 1.875em;
  -webkit-padding-after: 0.9375em;
          padding-block-end: 0.9375em;
  padding-inline: 0.9375em;
  background-color: #fff;
  display: grid;
  grid-template-rows: -webkit-max-content 1fr -webkit-max-content;
  grid-template-rows: max-content 1fr max-content;
}
@media (width < 740px) {
  .m__member-1 .-card {
    font-size: min(4vw, 15px);
    grid-template-rows: auto;
    -webkit-padding-before: min(8vw, 30px);
            padding-block-start: min(8vw, 30px);
    -webkit-padding-after: min(4vw, 15px);
            padding-block-end: min(4vw, 15px);
    padding-inline: min(4vw, 15px);
  }
}
.m__member-1 .-card .-heading {
  font-size: 1.25em;
  text-align: center;
  font-weight: 700;
  line-height: 1.5;
  color: var(--c-co);
  -webkit-margin-after: 1.5em;
          margin-block-end: 1.5em;
}
.m__member-1 .-card > img {
  justify-self: center;
}
.m__member-1 .-card .-txt-s {
  font-size: 0.9375em;
  font-weight: 400;
  justify-self: end;
  color: #6c6c6c;
}
.m__member-1 .-card1 {
  grid-area: card1;
}
.m__member-1 .-card2 {
  grid-area: card2;
}
.m__member-1 .-card3 {
  grid-area: card3;
}
.m__member-1 .-card4 {
  grid-area: card4;
  grid-template-rows: -webkit-max-content auto auto;
  grid-template-rows: max-content auto auto;
}
.m__member-1 .-card4 .m__number-box-1 + .m__number-box-1 {
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
}
.m__member-1 .-card4 .-txt-s {
  align-self: end;
}
.m__member-1 .-card5 {
  grid-area: card5;
}
.m__member-1 .-card5 .-txt {
  width: min(100%, 22em);
  text-align: center;
  margin-inline: auto;
  -webkit-margin-before: 1.875em;
          margin-block-start: 1.875em;
  line-height: 1.5;
  font-weight: 500;
}
@media (width < 740px) {
  .m__member-1 .-card5 .-txt {
    -webkit-margin-after: 1em;
            margin-block-end: 1em;
  }
}
.m__member-1 .-card6 {
  grid-area: card6;
}
.m__member-1 .-card6 .-heading {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.m__member-1 .-card6 .-txt-s {
  -webkit-margin-before: 1.6666666667em;
          margin-block-start: 1.6666666667em;
}
@media (width < 740px) {
  .m__member-1 .-card6 .-txt-s {
    -webkit-margin-before: min(8vw, 30px);
            margin-block-start: min(8vw, 30px);
  }
}
.m__member-1 .-card7 {
  grid-area: card7;
}
.m__member-1 .-card7 .-heading {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.m__member-1 .-card7 .-txt-s {
  -webkit-margin-before: 1.6666666667em;
          margin-block-start: 1.6666666667em;
}
@media (width < 740px) {
  .m__member-1 .-card7 .-txt-s {
    -webkit-margin-before: min(8vw, 30px);
            margin-block-start: min(8vw, 30px);
  }
}
.m__member-2 .-txt1 {
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.8;
  -webkit-margin-before: 2.3529411765em;
          margin-block-start: 2.3529411765em;
  -webkit-margin-after: 3.5294117647em;
          margin-block-end: 3.5294117647em;
}
@media (width < 740px) {
  .m__member-2 .-txt1 {
    font-size: 1.5rem;
  }
}
.m__member-2 .-box {
  display: grid;
  grid-template-columns: 216px 1fr;
  gap: 30px 5%;
  font-size: 1.5rem;
}
@media (width < 900px) {
  .m__member-2 .-box {
    grid-template-columns: 1fr;
    gap: min(8vw, 30px);
  }
}
.m__member-2 .-box li {
  background-color: #fff;
  border-radius: min(2.67vw, 20px);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.11);
  overflow: hidden;
  display: grid;
  grid-column: span 2;
  grid-template-columns: subgrid;
  gap: 0;
}
@media (width < 900px) {
  .m__member-2 .-box li {
    grid-template-columns: 1fr;
    grid-column: span 1;
  }
}
@media (width < 900px) {
  .m__member-2 .-box li .-roof {
    display: grid;
    grid-template-columns: 216px 1fr;
  }
}
@media (width < 740px) {
  .m__member-2 .-box li .-roof {
    grid-template-columns: min(36vw, 135px) 1fr;
  }
  .m__member-2 .-box li .-roof img {
    aspect-ratio: 27 / 35;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: top center;
       object-position: top center;
  }
}
.m__member-2 .-box li .-person-data {
  padding-block: 0.8em 1em;
  padding-inline: 2em;
  border-right: 1px solid #f4f4f4;
}
@media (width < 740px) {
  .m__member-2 .-box li .-person-data {
    padding-block: 1em 0.5em;
    padding-inline: 1.2666666667em;
    border-right: none;
    border-bottom: 1px solid #f4f4f4;
  }
}
.m__member-2 .-box li .-person-data span {
  display: block;
}
.m__member-2 .-box li .-person-data .-name {
  font-size: 1.6em;
  font-weight: 700;
}
@media (width < 740px) {
  .m__member-2 .-box li .-person-data .-name {
    font-size: min(4.8vw, 1.8rem);
  }
}
.m__member-2 .-box li .-person-data .-dept {
  font-weight: 400;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  line-height: 1.41;
  text-align: start;
}
@media (width < 740px) {
  .m__member-2 .-box li .-person-data .-dept {
    -webkit-margin-before: 0.6em;
            margin-block-start: 0.6em;
  }
}
.m__member-2 .-box li .-person-data .-year {
  font-size: 0.9333333333em;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  color: #6c6c6c;
}
@media (width < 740px) {
  .m__member-2 .-box li .-person-data .-year {
    -webkit-margin-before: 0.8em;
            margin-block-start: 0.8em;
  }
}
.m__member-2 .-box li .-cont {
  -webkit-padding-before: 4em;
          padding-block-start: 4em;
  -webkit-padding-after: 2.6666666667em;
          padding-block-end: 2.6666666667em;
  padding-inline: 2.6666666667em;
}
@media (width < 900px) {
  .m__member-2 .-box li .-cont {
    -webkit-padding-before: min(5.33vw, 20px);
            padding-block-start: min(5.33vw, 20px);
    -webkit-padding-after: min(5.33vw, 20px);
            padding-block-end: min(5.33vw, 20px);
    padding-inline: min(5.33vw, 20px);
  }
}
.m__member-2 .-box li .-cont .-q {
  font-size: 1.3333333333em;
  font-weight: 700;
  line-height: 1.5;
  display: grid;
  grid-template-columns: 1.1em 1fr;
  gap: 0.4em;
}
@media (width < 740px) {
  .m__member-2 .-box li .-cont .-q {
    font-size: 1.2em;
  }
}
.m__member-2 .-box li .-cont .-q .-ini {
  font-size: 1.1em;
  color: var(--c-co);
  display: block;
}
.m__member-2 .-box li .-cont .-a {
  font-weight: 400;
  line-height: 1.8;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  text-align: start;
}
.m__bnr {
  display: block;
  width: min(100%, 669px);
  margin-inline: auto;
  -webkit-margin-before: min(16vw, 70px);
          margin-block-start: min(16vw, 70px);
}
.m__area {
  font-size: 1.5rem;
}
.m__area li {
  display: grid;
  border-radius: min(4vw, 20px);
  overflow: hidden;
}
.m__area li img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.m__area li:not(:first-of-type) {
  -webkit-margin-before: min(8vw, 40px);
          margin-block-start: min(8vw, 40px);
}
.m__area.-ltr li:nth-of-type(odd) {
  grid-template-columns: 1fr 41%;
}
@media (width < 740px) {
  .m__area.-ltr li:nth-of-type(odd) {
    grid-template-columns: 1fr;
  }
}
.m__area.-ltr li:nth-of-type(odd) img {
  order: 2;
}
@media (width < 740px) {
  .m__area.-ltr li:nth-of-type(odd) img {
    order: 1;
  }
}
.m__area.-ltr li:nth-of-type(odd) .u__bg_wt {
  order: 1;
}
@media (width < 740px) {
  .m__area.-ltr li:nth-of-type(odd) .u__bg_wt {
    order: 2;
  }
}
.m__area.-ltr li:nth-of-type(even) {
  grid-template-columns: 41% 1fr;
}
@media (width < 740px) {
  .m__area.-ltr li:nth-of-type(even) {
    grid-template-columns: 1fr;
  }
}
.m__area.-rtl li:nth-of-type(odd) {
  grid-template-columns: 41% 1fr;
}
@media (width < 740px) {
  .m__area.-rtl li:nth-of-type(odd) {
    grid-template-columns: 1fr;
  }
}
.m__area.-rtl li:nth-of-type(even) {
  grid-template-columns: 1fr 41%;
}
@media (width < 740px) {
  .m__area.-rtl li:nth-of-type(even) {
    grid-template-columns: 1fr;
  }
}
.m__area.-rtl li:nth-of-type(even) img {
  order: 2;
}
@media (width < 740px) {
  .m__area.-rtl li:nth-of-type(even) img {
    order: 1;
  }
}
.m__area.-rtl li:nth-of-type(even) .u__bg_wt {
  order: 1;
}
@media (width < 740px) {
  .m__area.-rtl li:nth-of-type(even) .u__bg_wt {
    order: 2;
  }
}
.m__area .-card4 img {
  -o-object-position: top right;
     object-position: top right;
}
.m__area .u__bg_wt {
  padding-block: 2.6666666667em;
  padding-inline: 2.6666666667em;
}
@media (width < 900px) {
  .m__area .u__bg_wt {
    padding-block: 2em;
    padding-inline: 2em;
  }
}
@media (width < 740px) {
  .m__area .u__bg_wt {
    padding-block: 1.3333333333em;
    padding-inline: 1.3333333333em;
  }
}
.m__area h3 {
  font-size: 1.6666666667em;
  font-weight: 700;
  -webkit-margin-after: 0.92em;
          margin-block-end: 0.92em;
  -webkit-padding-after: 0.92em;
          padding-block-end: 0.92em;
  border-bottom: 1px solid var(--c-bg);
  line-height: 1.5;
  display: grid;
  grid-template-columns: 0.68em 1fr;
  gap: 0.32em;
}
@media (width < 900px) {
  .m__area h3 {
    -webkit-margin-after: 0.6em;
            margin-block-end: 0.6em;
    -webkit-padding-after: 0.6em;
            padding-block-end: 0.6em;
  }
}
@media (width < 740px) {
  .m__area h3 {
    font-size: 1.3333333333em;
  }
}
.m__area h3 span {
  font-size: 0.68em;
  display: block;
  -webkit-margin-before: 0.5em;
          margin-block-start: 0.5em;
  color: var(--c-co);
}
.m__area .-txt2 {
  line-height: 1.8;
  font-weight: 400;
}
.m__area .-txt-s {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto 0;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  line-height: 1.8;
  font-weight: 400;
}
.m__area .-txt-s a {
  display: inline-block;
  color: #2889d9;
  text-decoration: underline;
}
.m__area .-txt-s a:focus-visible {
  text-decoration: none;
}
@media (any-hover: hover) {
  .m__area .-txt-s a:hover {
    text-decoration: none;
  }
}
.m__data {
  font-size: min(1.47vw, 1.6rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-areas: "data1 data2" "data3 data2" "data6 data6";
  gap: 20px;
  -webkit-margin-before: 4.375em;
          margin-block-start: 4.375em;
}
@container (max-width: 988px) {
  .m__data {
    gap: 1.83vw;
  }
}
@media (width < 740px) {
  .m__data {
    font-size: 1.5rem;
    grid-template-columns: 1fr;
    grid-template-areas: "data1" "data2" "data3" "data6";
    gap: 30px;
    width: min(100%, 400px);
    margin-inline: auto;
  }
}
.m__data .-heading {
  font-size: max(1.8rem, 1.4375em);
  font-weight: 700;
  line-height: 1.6;
}
@container (max-width: 988px) {
  .m__data .-heading {
    -webkit-margin-start: 1em;
            margin-inline-start: 1em;
  }
}
@media (width < 740px) {
  .m__data .-heading {
    font-size: 1.7rem;
  }
}
.m__data .-txt2 {
  line-height: 1.6;
  font-weight: 500;
  padding-inline: 0.625em;
  font-size: 1.6rem;
}
@media (width < 740px) {
  .m__data .-txt2 {
    font-size: 1.6rem;
    padding-inline: 0;
  }
}
.m__data .-txt-s {
  font-size: 0.9375em;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto 0;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  line-height: 1.6;
  font-weight: 400;
  text-align: start;
}
@media (width < 740px) {
  .m__data .-txt-s {
    font-size: 1.5rem;
  }
}
.m__data .-txt-s a {
  display: inline-block;
  color: #2889d9;
  text-decoration: underline;
}
.m__data .-txt-s a:focus-visible {
  text-decoration: none;
}
@media (any-hover: hover) {
  .m__data .-txt-s a:hover {
    text-decoration: none;
  }
}
.m__data .-item-name {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.15;
  color: var(--c-co);
  display: grid;
  place-items: center;
  background-color: var(--c-bg);
}
@media (width < 740px) {
  .m__data .-item-name {
    font-size: 1em;
  }
}
.m__data .-hojo {
  font-size: 1.25em;
  font-weight: 700;
  color: var(--c-co);
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  gap: 2.9em;
  width: min(100%, 17.8em);
  margin-inline: auto;
}
@media (width < 740px) {
  .m__data .-hojo {
    gap: 1em;
  }
}
.m__data .-hojo-txt span {
  display: block;
  -webkit-margin-after: 0.4em;
          margin-block-end: 0.4em;
}
.m__data .-hojo-txt img {
  width: min(100%, 7.45em);
}
.m__data .-card {
  background-color: #fff;
  border: 2px solid var(--c-co);
  border-radius: min(4vw, 20px);
  box-shadow: 7px 7px 0 0 var(--c-co);
  -webkit-padding-before: 1.875em;
          padding-block-start: 1.875em;
  -webkit-padding-after: 2.5em;
          padding-block-end: 2.5em;
  padding-inline: 2.5em;
}
@container (max-width: 988px) {
  .m__data .-card {
    padding-inline: 1em;
  }
}
@media (width < 740px) {
  .m__data .-card {
    padding-block: 1.6666666667em;
    padding-inline: 1.6666666667em;
  }
}
.m__data .-card1 {
  grid-area: data1;
}
.m__data .-card1 .-ico {
  width: 5.25em;
  margin-inline: auto;
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
  -webkit-margin-after: 1.3333333333em;
          margin-block-end: 1.3333333333em;
}
@media (width < 740px) {
  .m__data .-card1 .-ico {
    width: min(16.53vw, 62px);
    -webkit-margin-before: 1.6666666667em;
            margin-block-start: 1.6666666667em;
  }
}
.m__data .-card1 .-img {
  width: min(100%, 413px);
  margin-inline: auto;
}
@media (width < 740px) {
  .m__data .-card1 .-img {
    width: min(67.2vw, 252px);
  }
}
.m__data .-card1 .-txt2 {
  -webkit-margin-before: 1.5625em;
          margin-block-start: 1.5625em;
}
.m__data .-card2 {
  grid-area: data2;
}
.m__data .-card2 .-ico {
  width: 15.3125em;
  margin-inline: auto;
  -webkit-margin-before: 2.25em;
          margin-block-start: 2.25em;
}
@media (width < 740px) {
  .m__data .-card2 .-ico {
    width: min(31.2vw, 117px);
  }
}
.m__data .-card2 h4 {
  font-size: 1.5625em;
  color: var(--c-co);
  text-align: center;
  font-weight: 700;
  line-height: 1.2;
  margin-block: 1em;
}
.m__data .-card2 h4.-hojo-ttl {
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
}
@media (width < 740px) {
  .m__data .-card2 h4 {
    font-size: min(4.53vw, 1.7rem);
    -webkit-margin-before: 1.4705882353em;
            margin-block-start: 1.4705882353em;
  }
}
.m__data .-card2 table {
  display: block;
  padding-inline: 0.625em;
  -webkit-margin-after: 0.9375em;
          margin-block-end: 0.9375em;
}
.m__data .-card2 table tbody {
  display: block;
}
.m__data .-card2 table tr, .m__data .-card2 table th, .m__data .-card2 table td {
  display: block;
}
@media (width < 740px) {
  .m__data .-card2 table td img {
    margin-inline: auto;
  }
}
.m__data .-card2 table .-item-name {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 2.15em;
  padding-inline: 0.5em;
  -webkit-margin-after: 0.75em;
          margin-block-end: 0.75em;
}
@media (width < 740px) {
  .m__data .-card2 table .-item-name {
    height: 2.4666666667em;
    padding-inline: 0.8666666667em;
    margin-inline: auto;
  }
}
.m__data .-card2 .-price1 {
  height: 4.3125em;
  width: auto;
  -webkit-margin-after: 2.1875em;
          margin-block-end: 2.1875em;
}
@media (width < 740px) {
  .m__data .-card2 .-price1 {
    height: auto;
    width: min(56.53vw, 212px);
  }
}
.m__data .-card2 .-price2 {
  height: 4.125em;
  width: auto;
  -webkit-margin-after: 2.1875em;
          margin-block-end: 2.1875em;
}
@media (width < 740px) {
  .m__data .-card2 .-price2 {
    height: auto;
    width: min(33.6vw, 125px);
  }
}
.m__data .-card2 .-price3 {
  height: 4.1875em;
  width: auto;
}
@media (width < 740px) {
  .m__data .-card2 .-price3 {
    height: auto;
    width: min(33.6vw, 126px);
  }
}
.m__data .-card2 .-price4 {
  width: min(100%, 404px);
  margin-inline: auto;
}
@media (width < 740px) {
  .m__data .-card2 .-price4 {
    width: min(100%, 269px);
  }
}
@media (width < 740px) {
  .m__data .-card2 .-txt-s {
    text-align: end;
  }
}
.m__data .-card3 {
  grid-area: data3;
}
.m__data .-card3 table {
  display: block;
  -webkit-margin-before: 2.875em;
          margin-block-start: 2.875em;
  -webkit-margin-after: 3.375em;
          margin-block-end: 3.375em;
}
@media (width < 740px) {
  .m__data .-card3 table {
    -webkit-margin-before: 1.3333333333em;
            margin-block-start: 1.3333333333em;
    -webkit-margin-after: 2em;
            margin-block-end: 2em;
  }
}
.m__data .-card3 table tbody {
  display: grid;
  grid-template-columns: 11.875em 1fr;
  gap: 1.5625em 1em;
  align-items: end;
}
@media (width < 740px) {
  .m__data .-card3 table tbody {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.m__data .-card3 table tr {
  display: contents;
}
@media (width < 740px) {
  .m__data .-card3 table tr:not(:first-of-type) th {
    -webkit-margin-before: 1.6666666667em;
            margin-block-start: 1.6666666667em;
  }
}
.m__data .-card3 table th {
  display: block;
}
.m__data .-card3 table .-item-name {
  text-align: center;
  height: 3.25em;
}
@media (width < 740px) {
  .m__data .-card3 table .-item-name {
    height: 2.1764705882em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding-inline: 0.8666666667em;
    margin-inline: auto;
    -webkit-margin-after: 7px;
            margin-block-end: 7px;
  }
  .m__data .-card3 table .-item-name br {
    display: none;
  }
}
.m__data .-card3 table td img {
  height: 4.75em;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: left;
     object-position: left;
}
@media (width < 740px) {
  .m__data .-card3 table td img {
    height: min(14.13vw, 53px);
    margin-inline: auto;
    -webkit-margin-before: 0.6666666667em;
            margin-block-start: 0.6666666667em;
  }
}
.m__data .-card3 .-txt2 {
  -webkit-margin-before: 1.875em;
          margin-block-start: 1.875em;
}
.m__data .-card6 {
  grid-area: data6;
}
.m__data .-card6 .-ico {
  align-self: center;
}
.m__data .-card6 .-head18 {
  font-size: 1.125em;
  font-weight: 700;
  line-height: 1.6;
  color: var(--c-co);
  align-self: center;
}
@media (width < 740px) {
  .m__data .-card6 .-head18 {
    font-size: min(4.53vw, 17px);
  }
}
.m__data .-card6 .-under {
  font-size: 0.9375em;
  white-space: nowrap;
  line-height: 1.6;
  text-align: center;
}
@media (width < 740px) {
  .m__data .-card6 .-under {
    font-size: 1em;
  }
}
.m__data .-card6 .-txt2 {
  -webkit-margin-before: 1.8125em;
          margin-block-start: 1.8125em;
  width: min(100%, 762px);
}
.m__data .-card6 ul {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: flex-start;
  gap: 7.5em;
  -webkit-margin-before: 1.375em;
          margin-block-start: 1.375em;
}
@media (width < 740px) {
  .m__data .-card6 ul {
    display: block;
  }
}
.m__data .-card6 li {
  display: grid;
  grid-template-columns: -webkit-max-content -webkit-max-content;
  grid-template-columns: max-content max-content;
}
.m__data .-card6 li .-cont {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 3.625em 1fr -webkit-max-content;
  grid-template-rows: 3.625em 1fr max-content;
  height: 9.375em;
}
.m__data .-card6 li .-cont img {
  align-self: end;
}
@media (width < 740px) {
  .m__data .-card6 li {
    grid-template-columns: min(9.97vw, 37.4px) 1fr;
    width: min(68vw, 255px);
    margin-inline: auto;
  }
  .m__data .-card6 li .-ico {
    grid-area: 1/1/2/2;
    justify-self: center;
  }
  .m__data .-card6 li .-cont {
    display: contents;
  }
  .m__data .-card6 li .-cont .-head18 {
    grid-area: 1/2/2/3;
    text-align: center;
    -webkit-padding-end: min(9.97vw, 37.4px);
            padding-inline-end: min(9.97vw, 37.4px);
  }
  .m__data .-card6 li .-cont img {
    grid-area: 2/1/3/3;
    margin-inline: auto;
    -webkit-margin-before: min(5.33vw, 20px);
            margin-block-start: min(5.33vw, 20px);
  }
  .m__data .-card6 li .-cont .-under {
    grid-area: 3/1/4/3;
    text-align: center;
    -webkit-margin-before: 0.5em;
            margin-block-start: 0.5em;
  }
}
.m__data .-card6 li:first-of-type {
  gap: 0.9375em;
}
.m__data .-card6 li:first-of-type .-ico {
  width: 5.25em;
}
.m__data .-card6 li:first-of-type .-cont {
  width: 12.5625em;
}
@media (width < 740px) {
  .m__data .-card6 li:first-of-type {
    gap: 0;
  }
  .m__data .-card6 li:first-of-type .-ico {
    width: min(9.97vw, 37.4px);
  }
  .m__data .-card6 li:first-of-type .-cont img {
    width: min(46.13vw, 173px);
  }
}
.m__data .-card6 li:nth-of-type(2) {
  gap: 1.5em;
}
.m__data .-card6 li:nth-of-type(2) .-ico {
  width: 3.875em;
}
.m__data .-card6 li:nth-of-type(2) .-cont {
  width: 20.8125em;
}
@media (width < 740px) {
  .m__data .-card6 li:nth-of-type(2) {
    gap: 0;
    -webkit-margin-before: min(6.67vw, 25px);
            margin-block-start: min(6.67vw, 25px);
  }
  .m__data .-card6 li:nth-of-type(2) .-ico {
    width: min(8.21vw, 30.8px);
  }
  .m__data .-card6 li:nth-of-type(2) .-cont img {
    width: min(74.67vw, 280px);
  }
}
.m__cta {
  background-color: #fff;
  border-radius: min(4vw, 40px);
  width: min(94.14vw, 1286px);
  margin-inline: auto;
  padding-inline: min(8vw, 30px);
  padding-block: min(16vw, 70px);
}
@media (width < 740px) {
  .m__cta {
    width: 84vw;
  }
}
.m__cta .-heading {
  font-size: min(13.33vw, 8rem);
  font-weight: 700;
  color: var(--c-co);
  -webkit-margin-after: min(8.53vw, 40px);
          margin-block-end: min(8.53vw, 40px);
  text-align: center;
}
.m__cta p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  width: min(100%, 30em);
  text-align: center;
  display: block;
  margin-inline: auto;
}
@media (width < 740px) {
  .m__cta p {
    font-size: 1.5rem;
  }
}
.m__cta .-btns {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
  -webkit-margin-before: min(10.67vw, 40px);
          margin-block-start: min(10.67vw, 40px);
}
@media (width < 740px) {
  .m__cta .-btns {
    flex-direction: column;
    gap: min(6.67vw, 25px);
  }
}
.m__dialog {
  position: fixed;
  inset: 0;
  overscroll-behavior-block: contain;
  transition-duration: 300ms;
  transition-property: display, overlay, opacity;
  transition-timing-function: ease-out;
  transition-behavior: allow-discrete;
  border: none;
  background-color: transparent;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
}
.m__dialog_inner {
  width: 90vw;
  max-width: 1200px;
  display: flex;
  flex-flow: column;
  justify-content: center;
}
.m__dialog_inner > img, .m__dialog_inner > video {
  width: 100%;
  height: calc(100% - 100px);
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
  margin-inline: auto;
}
.m__dialog_inner > img {
  cursor: default;
}
.m__dialog:focus {
  outline: #6c6c6c;
}
.m__dialog::-webkit-backdrop {
  background-color: rgba(0, 0, 0, 0.8);
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
  transition-duration: inherit;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  transition-timing-function: inherit;
}
.m__dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.8);
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
  transition-duration: inherit;
  transition-property: opacity;
  transition-timing-function: inherit;
}
@starting-style {
  .m__dialog:modal::-webkit-backdrop {
    opacity: 0;
  }
  .m__dialog:modal, .m__dialog:modal::backdrop {
    opacity: 0;
  }
}
.m__dialog:not(:modal)::-webkit-backdrop {
  opacity: 0;
}
.m__dialog:not(:modal), .m__dialog:not(:modal)::backdrop {
  opacity: 0;
}
.m__dialog button {
  display: block;
  -webkit-margin-before: 20px;
          margin-block-start: 20px;
}
.m__dialog button img {
  width: min(10vw, 60px);
  margin-inline: auto;
}
.m__number-box-wrap2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2em 0;
}
@media (width < 740px) {
  .m__number-box-wrap2 {
    grid-template-columns: 1fr;
  }
}
.m__number-box-wrap2 .m__numbers {
  line-height: 1em;
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
}
.m__number-box-1 .-ttl {
  font-size: 1.4375em;
  font-weight: 700;
  color: var(--c-co);
  display: grid;
  grid-template-columns: 1.8695652174em 4em;
  place-content: center;
  align-items: center;
  gap: 0.7826086957em;
}
.m__number-box-1 .-ttl img {
  aspect-ratio: 43 / 44;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
.m__number-box-1 .-ttl2 {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.5;
  color: var(--c-co);
  text-align: center;
}
@media (width < 740px) {
  .m__number-box-1 .-ttl2 {
    line-height: 1;
  }
}
.m__numbers {
  text-align: center;
  -webkit-margin-before: 0.8em;
          margin-block-start: 0.8em;
}
.m__numbers .anim__scale {
  display: inline-block;
  -webkit-margin-end: 0.4em;
          margin-inline-end: 0.4em;
}
.m__numbers .-l {
  font-size: 3.9375em;
  font-weight: 700;
  color: var(--c-co);
}
.m__numbers .-m {
  font-size: 3.3125em;
  font-weight: 700;
  color: var(--c-co);
}
.m__numbers .-per {
  font-size: 1.8125em;
  font-weight: 700;
  color: var(--c-co);
}

button.-modal-open {
  cursor: zoom-in;
  position: relative;
  display: block;
}
button.-modal-open:has(img.-ico-wt) {
  border-radius: min(4vw, 15px);
  overflow: hidden;
}
button.-modal-open:has(img.-ico-wt)::after {
  content: "";
  width: min(3.2vw, 20px);
  aspect-ratio: 10 / 11;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom center;
  position: absolute;
  bottom: 10px;
  right: 10px;
  background-image: url(../img/ico-magnifire.png);
}
button.-modal-open:has(img.-ico-gry) {
  border-radius: min(4vw, 15px);
  overflow: hidden;
}
button.-modal-open:has(img.-ico-gry)::after {
  content: "";
  width: min(3.2vw, 20px);
  aspect-ratio: 10 / 11;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom center;
  position: absolute;
  bottom: 10px;
  right: 10px;
  background-image: url(../img/ico-magnifire-gry.png);
}
button.-modal-open:has(img.-video-btn)::after {
  content: "";
  width: 94px;
  aspect-ratio: 1/1;
  display: block;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.5);
  background-image: url(../img/ico-video-start.png);
  background-size: 30%;
  background-repeat: no-repeat;
  background-position: center right 30px;
  position: absolute;
  top: calc(50% - 47px);
  left: calc(50% - 47px);
  transition: background-color 0.3s;
}
@media (width < 740px) {
  button.-modal-open:has(img.-video-btn)::after {
    width: 70px;
    top: calc(50% - 35px);
    left: calc(50% - 35px);
    background-position: center right 22px;
  }
}
button.-modal-open:has(img.-video-btn):focus-visible::after {
  background-color: rgba(238, 0, 0, 0.5);
}
@media (any-hover: hover) {
  button.-modal-open:has(img.-video-btn):hover::after {
    background-color: rgba(238, 0, 0, 0.5);
  }
}

.u__for-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.u__upper {
  text-transform: uppercase;
}
.u__ib {
  display: inline-block;
}
.u__pb_l {
  padding-block: min(24vw, 150px);
}
.u__pbs_l {
  -webkit-padding-before: min(24vw, 150px);
          padding-block-start: min(24vw, 150px);
}
.u__pbe_l {
  -webkit-padding-after: min(24vw, 150px);
          padding-block-end: min(24vw, 150px);
}
.u__mbs_l {
  -webkit-margin-before: min(24vw, 150px);
          margin-block-start: min(24vw, 150px);
}
.u__mbs_m {
  -webkit-margin-before: min(16vw, 60px);
          margin-block-start: min(16vw, 60px);
}
.u__radial-top {
  border-top-left-radius: min(8vw, 50px);
  border-top-right-radius: min(8vw, 50px);
}
.u__bg_bl {
  background-color: var(--c-bg);
}
.u__bg_wt {
  background-color: #fff;
}
.u__txt_center {
  text-align: center;
}

.header {
  width: 100%;
  height: var(--h-header);
  background-color: var(--c-dark);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
}
@media (width < 740px) {
  .header {
    height: var(--h-header-sp);
  }
}
.header__inner {
  width: min(100vw - 80px, 1306px);
  height: 100%;
  margin-inline: auto;
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: center;
}
@media (width < 900px) {
  .header__inner {
    width: min(100vw - 40px, 1306px);
  }
}
@media (width < 740px) {
  .header__inner {
    width: 100vw;
    -webkit-padding-start: 3.47vw;
            padding-inline-start: 3.47vw;
  }
}
.header__logo {
  width: min(38.13vw, 143px);
  transition: opacity 0.2s;
}
.header__logo:focus-visible {
  opacity: 0.7;
}
@media (any-hover: hover) {
  .header__logo:hover {
    opacity: 0.7;
  }
}

footer {
  padding-block: 40px 102px;
  background: #2f2f2f;
}
@media (width < 740px) {
  footer {
    padding-block: 18px 32px;
  }
}
footer .footer {
  width: min(100%, 1366px);
  margin-inline: auto;
}
footer ul.foot_nav {
  color: #fff;
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  gap: 1em 0;
  font-size: min(3.73vw, 14px);
  font-weight: 500;
}
@media (width < 740px) {
  footer ul.foot_nav {
    margin-block: 10px;
    margin-inline: 10px;
    flex-flow: row wrap;
    justify-content: flex-start;
  }
}
footer ul.foot_nav li {
  padding-inline: 2em;
}
footer ul.foot_nav li a {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
footer ul.foot_nav li a:focus-visible {
  text-decoration: underline;
}
@media (any-hover: hover) {
  footer ul.foot_nav li a:hover {
    text-decoration: underline;
  }
}
footer ul.foot_nav li:not(:first-of-type) {
  border-left: 1px solid #fff;
}
@media (width < 740px) {
  footer ul.foot_nav li {
    padding-inline: 1em;
  }
  footer ul.foot_nav li:nth-of-type(2) {
    width: calc(100% - 12em);
  }
  footer ul.foot_nav li:nth-of-type(3) {
    border-left: none;
  }
}
footer .copy-right {
  padding: 0 10px;
  color: #fff;
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
  font-size: min(2.67vw, 13px);
  font-weight: 300;
}
footer .copy-right p {
  text-align: center;
}

.menu__btn {
  display: none;
}
@media (width < 740px) {
  .menu__btn {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    height: 100%;
    place-items: center;
    place-content: center;
    aspect-ratio: 1/1;
    background-color: var(--c-acnt);
  }
  .menu__btn span {
    display: block;
    width: 50%;
    height: 2px;
    background-color: var(--c-co);
    transition: rotate 0.2s;
  }
  .menu__btn.is-close {
    grid-template-rows: 1fr;
    gap: 0;
  }
  .menu__btn.is-close span {
    grid-area: 1/1/2/2;
  }
  .menu__btn.is-close span:first-of-type {
    rotate: 45deg;
  }
  .menu__btn.is-close span:nth-of-type(2) {
    opacity: 0;
  }
  .menu__btn.is-close span:nth-of-type(3) {
    rotate: -45deg;
  }
}
.menu__wrap {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(1.83vw, 1.7rem);
  letter-spacing: 0.1em;
  font-weight: 700;
  color: #fff;
}
@media (width < 740px) {
  .menu__wrap {
    display: none;
  }
}
.menu__wrap ul {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-end;
  align-items: center;
  gap: min(1.17vw, 1.8823529412em);
}
.menu__wrap li:not(.-entry) a {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  transition: opacity 0.2s;
}
.menu__wrap li:not(.-entry) a:focus-visible {
  opacity: 0.7;
}
@media (any-hover: hover) {
  .menu__wrap li:not(.-entry) a:hover {
    opacity: 0.7;
  }
}
.menu__wrap li.-entry a {
  background-color: var(--c-acnt);
  color: var(--c-co);
  font-size: 1.0588235294em;
  display: grid;
  place-items: center;
  width: 6.8888888889em;
  height: 2.2222222222em;
  border-radius: 1.1111111111em;
  transition: background-color 0.2s, color 0.2s;
}
.menu__wrap li.-entry a:focus-visible {
  background-color: var(--c-co);
  color: var(--c-acnt);
}
@media (any-hover: hover) {
  .menu__wrap li.-entry a:hover {
    background-color: var(--c-co);
    color: var(--c-acnt);
  }
}
.menu__sp {
  display: none;
}
@media (width < 740px) {
  .menu__sp {
    font-size: min(5.87vw, 2.2rem);
    position: fixed;
    top: var(--h-header-sp);
    left: 0;
    z-index: 1000;
    width: 100vw;
    height: calc(100vh - var(--h-header-sp));
    height: calc(100dvh - var(--h-header-sp));
    overflow-y: auto;
    background-color: var(--c-bg);
    display: block;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
  }
  .menu__sp.is-visible {
    opacity: 1;
    pointer-events: all;
  }
  .menu__sp ul {
    width: min(var(--w-wrap-sp), 315px);
    margin-inline: auto;
    padding-block: 2.7272727273em 2.0909090909em;
  }
  .menu__sp li:not(.-entry) a {
    display: block;
  }
  .menu__sp li:not(.-entry) a .u__upper {
    font-size: 0.6818181818em;
    font-weight: 900;
    line-height: 1;
    color: var(--c-co);
    letter-spacing: 0.05em;
    display: grid;
    grid-template-columns: 3px 1fr;
    gap: 0.6em;
    align-items: center;
  }
  .menu__sp li:not(.-entry) a .u__upper::before {
    content: "";
    display: block;
    height: 0.8em;
    background-color: var(--c-co);
  }
  .menu__sp li:not(.-entry) a .-ja {
    display: block;
    font-weight: 700;
    -webkit-margin-before: 0.5909090909em;
            margin-block-start: 0.5909090909em;
    line-height: 1.4;
  }
  .menu__sp li:not(:first-of-type) {
    -webkit-margin-before: min(10.67vw, 40px);
            margin-block-start: min(10.67vw, 40px);
  }
  .menu__sp li.-entry a {
    font-size: 0.9545454545em;
    display: grid;
    place-items: center;
    width: 100%;
    height: 2.9523809524em;
    border-radius: 1.4761904762em;
    font-weight: 700;
    letter-spacing: 0.1em;
    background-color: var(--c-acnt);
    color: var(--c-co);
  }
}

.anim__ltr {
  transform: translateX(-100%);
}
.anim__appear {
  opacity: 0;
  visibility: hidden;
  transform: scale(1.5);
}
.anim__rise {
  opacity: 0;
  transform: translateY(150px);
}
.anim__scale {
  transform: scale(0);
}
/*# sourceMappingURL=style.css.map */