@charset "UTF-8";

.u-desktop {
  display: block;
}

.u-mobile {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default padding */

ul,
ol {
  padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Set core root defaults */

html {
  scroll-behavior: smooth;
}

/* Set core body defaults */

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
  list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
  max-width: 100%;
  display: block;
  width: 100%;
}

/* Natural flow and rhythm in articles by default */

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
  font: inherit;
}

/* Blur images when they have no alt attribute */

img:not([alt]) {
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

/* フォームリセット */

input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

/* ホバー */

a {
  text-decoration: none;
  color: inherit;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

html {
  font-size: 16px;
}

body {
  color: #000000;
  font-family: "Noto Sans JP", sans-serif;
}

.l-footer {
  width: 100%;
}

.l-header {
  width: 100%;
}

.circle {
  overflow: hidden;
  position: relative;
}

.circle__connection {
  position: absolute;
  content: "";
  bottom: 111.5625rem;
  right: -6rem;
  border-radius: 50%;
  background: #e4f2fd;
  width: 21.9375rem;
  height: 21.9375rem;
  z-index: 1;
}

.circle__vision1 {
  position: absolute;
  content: "";
  top: 8.1875rem;
  right: -8.6875rem;
  border-radius: 50%;
  background: #e4f2fd;
  opacity: 0.5;
  width: 28.375rem;
  height: 28.375rem;
}

.circle__vision2 {
  position: absolute;
  content: "";
  bottom: -22.25rem;
  left: -6.875rem;
  border-radius: 50%;
  background: #e4f2fd;
  width: 47.375rem;
  height: 47.375rem;
}

.circle__vision--big {
  position: absolute;
  top: 24.0625rem;
}

.circle__vision--big img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.circle__point1 {
  position: absolute;
  content: "";
  top: 19.8125rem;
  right: -6.875rem;
  border-radius: 50%;
  background: #e4f2fd;
  width: 21.9375rem;
  height: 21.9375rem;
  z-index: -1;
}

.circle__point2 {
  position: absolute;
  content: "";
  bottom: 11.6875rem;
  left: -6rem;
  border-radius: 50%;
  background: #e4f2fd;
  width: 39.75rem;
  height: 39.75rem;
  z-index: -1;
}

.circle__point--big {
  position: absolute;
  content: "";
  bottom: 57.8125rem;
  border-radius: 50%;
}

.column {
  padding-block: 6rem 6rem;
}

.column__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.column__title-block {
  text-align: center;
}

.column__heading {
  font-family: "Roboto", sans-serif;
  font-size: clamp(2rem, 0.0317679558rem + 8.3977900552vw, 6.75rem);
  text-transform: uppercase;
  font-weight: 500;
  line-height: 1;
  background: -webkit-gradient(linear, left top, right top, from(#81c0e8), color-stop(50%, #a2d4f4), to(#81c0e8));
  background: linear-gradient(90deg, #81c0e8 0%, #a2d4f4 50%, #81c0e8 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.column__sub-title {
  margin-top: 1rem;
  color: #211815;
  font-size: clamp(1rem, 0.7928176796rem + 0.8839779006vw, 1.5rem);
  font-weight: 700;
  line-height: 2;
}

.column__items {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.4782608696%;
}

.column__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100% !important;
  position: static !important;
  -webkit-transform: none !important;
          transform: none !important;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.column__item:hover {
  opacity: 0.5;
}

.column__image {
  width: 100%;
  max-width: 100%;
}

.column__image img {
  width: 16.4375rem;
  height: 10.1875rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.column__text-block {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.4375rem;
  text-align: left;
}

.column__label-block {
  width: 5.375rem;
  padding-block: 0.5rem;
  border-radius: 62.5rem;
  background: #d3eeff;
  text-align: center;
}

.column__label {
  color: #000000;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1;
}

.column__title-wrap {
  text-align: left;
}

.column__title {
  color: #211815;
  font-size: clamp(1rem, 0.8964088398rem + 0.4419889503vw, 1.25rem);
  font-weight: 700;
  line-height: 1.8;
}

.column__text {
  color: #211815;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2.07;
}

.connection {
  position: relative;
  overflow: hidden;
}

.contact {
  padding-block: 3rem;
  background-color: #0099ff;
}

.contact__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: center;
}

.contact__text {
  color: #ffffff;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
}

.contact__button {
  margin-top: 1.875rem;
  border-radius: 62.5rem;
  background: #ff1673;
  padding: 0.75rem;
  border: 1px solid #ff1673;
  color: #ffffff;
  width: 100%;
  max-width: 15.25rem;
  margin-inline: auto;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.contact__button:hover {
  background-color: #ffffff;
  color: #ff1673;
  border: 1px solid #ff1673;
  cursor: pointer;
}

.contact__button-link {
  font-size: clamp(1rem, 0.8964088398rem + 0.4419889503vw, 1.25rem);
  font-weight: 700;
  line-height: 1.6;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.detail {
  background-image: url(../../assets/img/common/building.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  position: relative;
}

.detail__gradient {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20;
  width: 100%;
  max-width: 100%;
  height: 5.9375rem;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(180deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
}

.detail__inner {
  position: relative;
  z-index: 20;
  width: 100%;
  max-width: 75%;
  margin-right: auto;
  background: rgba(255, 255, 255, 0.65);
  -webkit-backdrop-filter: blur(25px);
          backdrop-filter: blur(25px);
  padding-block: 4rem 4.375rem;
}

.detail__container {
  width: 100%;
  max-width: 100%;
  padding-left: 15.4639175258%;
  padding-right: 3.4020618557%;
}

.detail__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.detail__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.0625rem;
  padding-bottom: 2.8125rem;
  border-bottom: 0.125rem solid #ffffff;
}

.detail__item:not(:first-child) {
  margin-top: 3.125rem;
}

.detail__image {
  width: 100%;
  max-width: 23.1362467866%;
}

.detail__wrap {
  position: relative;
  content: "";
  display: block;
  width: 11.25rem;
  height: 11.25rem;
  border-radius: 50%;
  background: #ffffff;
  -webkit-box-shadow: 0px 0px 12px 0px rgba(0, 94, 157, 0.2);
          box-shadow: 0px 0px 12px 0px rgba(0, 94, 157, 0.2);
}

.detail__image img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 7.5rem;
  height: 7.5rem;
  -o-object-fit: contain;
     object-fit: contain;
}

.detail__text-block {
  width: 100%;
  max-width: 72.7506426735%;
}

.detail__title {
  color: #000000;
  font-size: clamp(0.875rem, 0.6160220994rem + 1.1049723757vw, 1.5rem);
  font-weight: 400;
  line-height: 2.1;
}

.detail__title .detail__title--big {
  display: block;
  font-size: clamp(1.125rem, 0.8660220994rem + 1.1049723757vw, 1.75rem);
  font-weight: 700;
}

.detail__block {
  margin-top: 2.8125rem;
}

.detail__sub-title {
  position: relative;
  color: #000000;
  font-size: clamp(1rem, 0.8964088398rem + 0.4419889503vw, 1.25rem);
  font-weight: 700;
  line-height: 1.8;
  padding-left: 1.125rem;
}

.detail__sub-title::before {
  position: absolute;
  bottom: 0.3125rem;
  left: 0.0625rem;
  content: "";
  display: inline-block;
  width: 0.375rem;
  height: 1.5rem;
  background-color: #09f;
}

.detail__sub-text {
  margin-top: 0.75rem;
  color: #000000;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
}

.detail__sub-text--big {
  font-weight: 700;
}

.drawer {
  display: none;
}

.drawer__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.drawer__container {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.drawer__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3.25rem;
}

.drawer__item {
  text-align: center;
}

.drawer__link {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.57;
  color: #0c2952;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.drawer__link:hover {
  color: #0099ff;
}

.drawer__button {
  margin-top: 3.875rem;
}

.drawer__button-link {
  display: inline-block;
  padding: 0.75rem 2rem;
  background-color: #ff1673;
  border-radius: 1.625rem;
  color: #ffffff;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.57;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}

.drawer__button-link:hover {
  background-color: #ffffff;
  color: #ff1673;
  border: 1px solid #ff1673;
}

.footer {
  padding-block: 2.9375rem 4.1875rem;
  background: #002a66;
}

.footer__inner {
  width: 100%;
  max-width: 64.375rem;
  margin-inline: auto;
  padding-inline: 25px;
}

.footer__logo {
  width: 100%;
  max-width: 100%;
}

.footer__logo img {
  width: 7.9375rem;
  height: 1.4375rem;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer__container {
  margin-top: 1.75rem;
}

.footer__items.footer__items--middle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 0.75rem;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.footer__items.footer__items--middle:hover {
  opacity: 0.8;
  cursor: pointer;
}

.footer__item-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.75rem;
  max-width: 100%;
}

.footer__items.footer__items--wide {
  margin-top: 0.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.75rem;
}

.footer__item {
  width: 100%;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  color: #ffffff;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.footer__item:hover {
  opacity: 0.5;
  cursor: pointer;
}

.footer__item a {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.14;
  font-weight: 700;
}

.footer__copy-right {
  margin-top: 1.8125rem;
}

.footer__copy-right-text {
  color: #ffffff;
  font-size: clamp(0.75rem, 0.6982044199rem + 0.2209944751vw, 0.875rem);
  font-weight: 400;
  line-height: 1.41;
}

.fv {
  width: 100%;
  max-width: 100%;
  height: 31.25rem;
  background-image: url("../../assets/img/common/fv_bk.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin-inline: auto;
  position: relative;
  margin-top: 5rem;
}

.fv__inner {
  width: inherit;
  height: inherit;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.fv__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: inherit;
  position: relative;
}

.fv__title-block {
  position: absolute;
  top: 11.5625rem;
  left: 3.75rem;
  width: 100%;
  max-width: 38.2608695652%;
}

.fv__title-block img {
  width: 27.5rem;
  height: 10.9375rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.fv__image-block {
  position: absolute;
  top: 4.9375rem;
  right: 0;
  width: 100%;
  max-width: 52.1739130435%;
}

.fv__image img {
  width: 37.5rem;
  height: 37.5rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.fv__text-block {
  position: absolute;
  top: 6.1875rem;
  right: 50%;
  -webkit-transform: translate(50%);
          transform: translate(50%);
  z-index: 20;
  width: 25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem;
}

.fv__sub-title {
  color: #0b4588;
  font-size: clamp(1rem, 0.7928176796rem + 0.8839779006vw, 1.5rem);
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}

.fv__text {
  width: 100%;
}

.fv__text img {
  width: 25rem;
  height: 4.5rem;
}

.fv__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.625rem;
  border-radius: 62.5rem;
  background: #ff1673;
  padding: 0.8125rem;
  width: 100%;
  max-width: 21.5625rem;
  color: #ffffff;
  border: 1px solid #ff1673;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.fv__button:hover {
  background-color: #ffffff;
  color: #ff1673;
  border: 1px solid #ff1673;
  cursor: pointer;
}

.fv__button-text {
  white-space: nowrap;
  text-align: center;
  font-size: clamp(1rem, 0.8964088398rem + 0.4419889503vw, 1.25rem);
  font-weight: 700;
  line-height: 1.45;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.fv__label-block {
  background-image: url("../../assets/img/common/circle-img.webp");
  position: absolute;
  width: 9rem;
  height: 9rem;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  top: -4.125rem;
  right: 0.9375rem;
  z-index: 30;
}

.fv__label-wrap {
  margin-top: 0.375rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.fv__label-title {
  color: #09f;
  text-align: center;
  font-size: clamp(1rem, 0.6892265193rem + 1.3259668508vw, 1.75rem);
  font-weight: 700;
  line-height: 1.3;
  white-space: nowrap;
}

.fv__lalel-title--small {
  margin-top: -0.25rem;
  color: #09f;
  text-align: center;
  font-size: clamp(0.875rem, 0.8232044199rem + 0.2209944751vw, 1rem);
  font-weight: 700;
  white-space: nowrap;
}

.hamburger {
  display: none;
  cursor: pointer;
}

.header {
  width: 100%;
  max-width: 100%;
  height: 5rem;
  padding-inline: 3rem;
  margin-inline: auto;
  background-color: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}

.header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: inherit;
}

.header__logo {
  width: 100%;
  max-width: 100%;
}

.header__logo img {
  width: 7.9375rem;
  height: 1.4375rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.header__list {
  height: inherit;
}

.header__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: inherit;
}

.header__item {
  height: inherit;
}

.header__link {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-inline: 0.75rem;
  white-space: nowrap;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  cursor: pointer;
  text-align: center;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.7142857143;
}

.header__link:hover {
  color: #0099ff;
}

.header__button {
  width: 100%;
  max-width: 8.25rem;
  margin-left: 1.375rem;
  background-color: #ff1673;
  padding-block: 0.75rem;
  text-align: center;
  border-radius: 62.5rem;
  color: #ffffff;
  border: 1px solid #ff1673;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.header__button:hover {
  background-color: #ffffff;
  color: #ff1673;
  border: 1px solid #ff1673;
  cursor: pointer;
}

.header__button-link {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.7142857143;
  white-space: nowrap;
}

.message {
  position: relative;
  padding-block: 6rem 5.9375rem;
}

.message__bg1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
}

.message__bg1 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.message__bg2 {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  z-index: -1;
}

.message__bg2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.message__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.message__title-block {
  text-align: left;
}

.message__heading {
  color: #adf;
  font-family: "Roboto", sans-serif;
  font-size: clamp(3rem, 1.4461325967rem + 6.6298342541vw, 6.75rem);
  text-transform: uppercase;
  font-weight: 500;
  line-height: 1;
  mix-blend-mode: hard-light;
}

.message__sub-title {
  color: #ffffff;
  font-size: clamp(1.125rem, 0.9696132597rem + 0.6629834254vw, 1.5rem);
  font-weight: 700;
  line-height: 2;
  margin-top: 0.9375rem;
}

.message__items {
  width: 100%;
  max-width: 71.25rem;
  margin-top: 2.9375rem;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 3rem;
  margin-inline: auto;
}

.message__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4.7826086957%;
}

.message__image {
  width: 100%;
  max-width: 43.4782608696%;
}

.message__image img {
  width: 30rem;
  height: 20rem;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0.8125rem;
}

.message__text-block {
  width: 100%;
  max-width: 55.652173913%;
}

.message__title-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75rem;
}

.message__number {
  color: #002a66;
  font-size: clamp(3rem, 2.7928176796rem + 0.8839779006vw, 3.5rem);
  font-family: "Roboto", sans-serif;
  font-style: italic;
  font-weight: 400;
  line-height: 1.28;
  margin-top: -0.3125rem;
}

.message__title {
  color: #002a66;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(1.125rem, 0.9696132597rem + 0.6629834254vw, 1.5rem);
  font-weight: 700;
  line-height: 1.5;
}

.message__text {
  margin-top: 1.25rem;
  color: #211815;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
}

.point {
  position: relative;
  overflow: hidden;
  padding-block: 6rem 5rem;
}

.point__circle1 {
  position: absolute;
  top: 19.8125rem;
  right: -6.6875rem;
  width: 21.9375rem;
  height: 21.9375rem;
  background-color: #e4f2fd;
  border-radius: 50%;
  z-index: 1;
}

.point__circle2 {
  position: absolute;
  bottom: 10.9375rem;
  left: -6.0625rem;
  width: 39.75rem;
  height: 39.75rem;
  background-color: #e4f2fd;
  border-radius: 50%;
}

.point__circle-big {
  position: absolute;
  bottom: 57.8125rem;
  left: 0;
  width: 100%;
  z-index: 2;
}

.point__circle-big img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.point__inner {
  position: relative;
  z-index: 500;
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.point__title-block {
  width: 100%;
  max-width: 49.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 3.375rem;
  margin-inline: auto;
}

.point__text-block {
  width: 100%;
  max-width: 35.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.25rem;
}

.point__title-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 100%;
  gap: 0.75rem;
}

.point__title-box img {
  width: 15rem;
  height: 2.6875rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.point__title {
  color: #002a66;
  font-size: clamp(1.25rem, 0.9392265193rem + 1.3259668508vw, 2rem);
  font-weight: 700;
  line-height: 1.75;
}

.point__text {
  color: #000000;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
  margin-top: -0.3125rem;
}

.point__text-wrap {
  text-align: center;
}

.point__content-title {
  color: #002a66;
  font-size: clamp(1.125rem, 0.8660220994rem + 1.1049723757vw, 1.75rem);
  font-weight: 700;
  line-height: 1.75;
}

.point__content-text {
  color: #000000;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
  margin-top: 0.3125rem;
}

.point__image {
  width: 100%;
  max-width: 22.125%;
}

.point__image img {
  width: 11.0625rem;
  height: 13.3125rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.point__items {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 3.125rem;
  background-color: #ffffff;
  background: rgba(255, 255, 255, 0.9);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

.point__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.point__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.4375rem;
}

.point__image-wrap {
  width: 100%;
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.point__image-wrap img {
  width: 11.25rem;
  height: 5rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.point__images {
  margin-top: 2rem;
  width: 100%;
  max-width: 100%;
}

.point__images img {
  width: 60rem;
  height: 11.25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.problem {
  position: relative;
  z-index: 50;
  overflow: hidden;
  background: -webkit-gradient(linear, left top, left bottom, from(#d3eeff), color-stop(15.87%, #a2d4f4), color-stop(43.75%, #a2d4f4), color-stop(68.27%, #fff));
  background: linear-gradient(180deg, #d3eeff 0%, #a2d4f4 15.87%, #a2d4f4 43.75%, #fff 68.27%);
  padding-bottom: 4rem;
}

.problem__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.problem__title-block {
  padding-top: 4rem;
}

.problem__title {
  color: #ffffff;
  text-align: center;
  text-shadow: 0px 0px 5px rgba(0, 42, 102, 0.4);
  font-size: clamp(1.25rem, 0.9392265193rem + 1.3259668508vw, 2rem);
  font-weight: 700;
  line-height: 1.6875;
}

.problem__title:after {
  content: "";
  display: block;
  width: 100%;
  max-width: 1150px;
  height: 0.125rem;
  background-color: #ffffff;
  margin-inline: auto;
  margin-top: 0.75rem;
}

.problem__container {
  margin-top: 3.5625rem;
  padding-bottom: 9.4375rem;
}

.problem__items {
  width: 100%;
  max-width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 26.25rem);
  -webkit-column-gap: 7.1875rem;
     -moz-column-gap: 7.1875rem;
          column-gap: 7.1875rem;
  row-gap: 4.6875rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.problem__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
}

.problem__item-wrap {
  position: relative;
  width: 100%;
  top: 0.4375rem;
  max-width: 78.0952380952%;
  height: 7rem;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.5);
}

.problem__item-title {
  color: #0c2952;
  text-align: center;
  font-size: clamp(1rem, 0.7928176796rem + 0.8839779006vw, 1.5rem);
  font-weight: 700;
  line-height: 1.66667;
}

.problem__top-line {
  position: absolute;
  content: "";
  display: inline-block;
  top: -0.4375rem;
  left: 0.375rem;
  width: 2.8125rem;
  height: 2.125rem;
  border-top: 0.125rem solid #0c2952;
  border-left: 0.125rem solid #0c2952;
}

.problem__bottom-line {
  position: absolute;
  content: "";
  display: inline-block;
  bottom: -0.4375rem;
  right: 0.375rem;
  width: 2.8125rem;
  height: 2.125rem;
  border-bottom: 0.125rem solid #0c2952;
  border-right: 0.125rem solid #0c2952;
}

.problem__image {
  width: 100%;
  max-width: 21.9047619048%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.problem__image img {
  width: 5.75rem;
  height: 7.875rem;
}

.resolution {
  overflow: hidden;
  padding-block: 4.3125rem 3.9375rem;
  background-color: #ffffff;
}

.resolution__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.resolution__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3.0434782609%;
}

.resolution__text-block {
  padding-block: 3.125rem;
  width: 100%;
  max-width: 53.9130434783%;
  text-align: center;
}

.resolution__title {
  color: #002a66;
  font-size: clamp(1.125rem, 1.0732044199rem + 0.2209944751vw, 1.25rem);
  font-weight: 700;
  line-height: 2.4;
}

.resolution__logo {
  margin-top: 2rem;
  width: 100%;
}

.resolution__logo img {
  width: 22.5rem;
  height: 4.0625rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.resolution__image {
  position: relative;
  width: 100%;
  max-width: 52.1739130435%;
  margin-right: calc(50% - 50vw);
}

.resolution__image img {
  position: absolute;
  right: -1.375rem;
  width: 37.5rem;
  height: 25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.resolution__text {
  margin-top: 2.9375rem;
  color: #000000;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  letter-spacing: -0.001em;
  line-height: 2;
}

.service {
  position: relative;
  padding-block: 5rem 2.9375rem;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), color-stop(25%, #e4f2fd), color-stop(75%, #e4f2fd), to(#fff));
  background: linear-gradient(180deg, #fff 0%, #e4f2fd 25%, #e4f2fd 75%, #fff 100%);
}

.service__circle {
  position: absolute;
  content: "";
  background-color: #e4f2fd;
  top: -11.8125rem;
  right: -5.875rem;
  width: 21.9375rem;
  height: 21.9375rem;
  border-radius: 50%;
}

.service__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
  text-align: center;
}

.service__title-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.service__heading {
  font-family: "Roboto", sans-serif;
  font-size: clamp(3rem, 1.4461325967rem + 6.6298342541vw, 6.75rem);
  text-transform: uppercase;
  font-weight: 500;
  line-height: 1;
  background: -webkit-gradient(linear, left top, right top, from(#81c0e8), color-stop(50%, #a2d4f4), to(#81c0e8));
  background: linear-gradient(90deg, #81c0e8 0%, #a2d4f4 50%, #81c0e8 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.service__sub-title {
  margin-top: 0.8125rem;
  color: #002a66;
  font-size: clamp(1.125rem, 0.9696132597rem + 0.6629834254vw, 1.5rem);
  font-weight: 700;
  line-height: 2;
}

.service__items {
  margin-top: 2.1875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.3125rem;
}

.service__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.0869565217%;
  min-height: 9.75rem;
}

.service__image {
  position: relative;
  width: 100%;
  max-width: 13.0434782609%;
  z-index: 100;
}

.service__image img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
  width: 5.25rem;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}

.service__image-circle {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 8.5rem;
  height: 8.5rem;
  border-radius: 50%;
  z-index: 1;
  border: 0.25rem solid #c3d6f1;
  background: #ffffff;
}

.service__text-block {
  width: 100%;
  max-width: 84.347826087%;
  text-align: left;
}

.service__title {
  margin-top: 0.8125rem;
  color: #002a66;
  font-size: clamp(1rem, 0.7928176796rem + 0.8839779006vw, 1.5rem);
  font-weight: 700;
  line-height: 1.5;
}

.service__text {
  margin-top: 0.625rem;
  color: #211815;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
}

.service__after-text {
  color: #002a66;
  font-size: clamp(1.125rem, 1.0732044199rem + 0.2209944751vw, 1.25rem);
  font-weight: 700;
  line-height: 1.6;
  padding-block: 0.3125rem;
  border-block: 0.0625rem solid #002a66;
  margin-top: 0.4375rem;
}

.solution {
  position: relative;
  padding-block: 2.9375rem;
  background-color: #e4f2fd;
}

.solution__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.solution__title {
  color: #002a66;
  text-align: center;
  font-size: clamp(1.25rem, 1.1464088398rem + 0.4419889503vw, 1.5rem);
  font-weight: 700;
  line-height: 1.5;
}

.solution__triangle {
  position: absolute;
  bottom: -1.25rem;
  left: 50%;
  -webkit-transform: translateX(-50%) rotate(-180deg);
          transform: translateX(-50%) rotate(-180deg);
  width: 100%;
  max-width: 6.9565217391%;
  height: 3.4375rem;
  -webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
          clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  background-color: #e4f2fd;
}

.video {
  margin-top: 5rem;
  padding: 2.5rem 0;
}

.video__inner {
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.video__title {
  text-align: center;
  margin-bottom: 1.875rem;
  color: #002a66;
  font-size: clamp(1rem, 0.3784530387rem + 2.6519337017vw, 2.5rem);
  font-weight: 700;
  line-height: 1.3;
}

.video__movie {
  background-color: #f0f0f0;
  width: 100%;
  height: auto;
}

.vision {
  position: relative;
  padding-block: 4.5625rem 6rem;
  overflow: hidden;
}

.vision__circle1 {
  position: absolute;
  top: 8.1875rem;
  right: -8.6875rem;
  width: 28.375rem;
  height: 28.375rem;
  background-color: #e4f2fd;
  border-radius: 50%;
}

.vision__circle2 {
  position: absolute;
  bottom: -9.0625rem;
  left: -6.875rem;
  width: 47.375rem;
  height: 47.375rem;
  background-color: #e4f2fd;
  border-radius: 50%;
  z-index: -1;
}

.vision__circle-big {
  position: absolute;
  top: 23.5625rem;
  left: 0;
  width: 100%;
  z-index: 1;
}

.vision__circle-big img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.vision__inner {
  width: 100%;
  max-width: 1150px;
  margin-inline: auto;
  padding-inline: 25px;
}

.vision__title-block {
  text-align: center;
}

.vision__heading {
  font-family: "Roboto", sans-serif;
  font-size: clamp(3rem, 1.4461325967rem + 6.6298342541vw, 6.75rem);
  text-transform: uppercase;
  font-weight: 500;
  line-height: 1;
  background: -webkit-gradient(linear, left top, right top, from(#81c0e8), color-stop(50%, #a2d4f4), to(#81c0e8));
  background: linear-gradient(90deg, #81c0e8 0%, #a2d4f4 50%, #81c0e8 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.vision__sub-title {
  margin-top: 2.25rem;
  color: #002a66;
  font-size: clamp(0.875rem, 0.6678176796rem + 0.8839779006vw, 1.375rem);
  font-weight: 700;
  line-height: 1.3;
}

.vision__sub-title--big {
  margin-top: 0.9375rem;
  display: block;
  font-size: clamp(1.25rem, 0.9392265193rem + 1.3259668508vw, 2rem);
  font-weight: 700;
  line-height: 1.5;
}

.vision__container {
  margin-top: 2.375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 1.25rem;
}

.vision__box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4.1666666667%;
  padding: 3rem 4.375rem;
  background: rgba(255, 255, 255, 0.9);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  z-index: 100;
}

.vision__text-block {
  width: 100%;
  max-width: 45.8333333333%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.vision__text-title {
  color: #002a66;
  font-size: clamp(1.125rem, 0.9696132597rem + 0.6629834254vw, 1.5rem);
  font-weight: 700;
  line-height: 1.8;
}

.vision__text-title::after {
  margin-top: 1.375rem;
  content: "";
  display: block;
  width: 1.5rem;
  height: 0.1875rem;
  background-color: #002a66;
}

.vision__text {
  margin-top: 1.5rem;
  color: #000000;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  font-weight: 400;
  line-height: 2;
}

.vision__image {
  width: 100%;
  max-width: 50%;
}

.vision__image img {
  width: 30rem;
  height: 20rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.youknow {
  position: relative;
}

.youknow__out-image {
  position: absolute;
  top: -5.625rem;
  left: 0;
  width: 100%;
  max-width: 100%;
}

.youknow__out-image img {
  width: 22.8125rem;
  height: 9.375rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.youknow__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3.4782608696%;
}

.youknow__text-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  max-width: 57.3913043478%;
}

.youknow__text-block {
  margin-top: 3.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.youknow__title-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.youknow__title {
  text-align: center;
  color: #002a66;
  font-size: clamp(1rem, 0.7928176796rem + 0.8839779006vw, 1.5rem);
  font-weight: 700;
  line-height: 1.25;
}

.youknow__title.youknow__title--medium {
  text-decoration: underline;
  text-underline-offset: -0.3125rem;
  text-decoration-color: #f1ff86;
  text-decoration-thickness: 1rem;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}

.youknow__title--big {
  font-size: clamp(1.75rem, 1.2320441989rem + 2.2099447514vw, 3rem);
  font-weight: 700;
}

.youknow__title--medium {
  text-align: center;
  font-size: clamp(1.125rem, 0.7624309392rem + 1.546961326vw, 2rem);
}

.youknow__text {
  width: 100%;
  margin-top: 3rem;
  color: #000000;
  font-weight: 400;
  font-size: clamp(0.875rem, 0.7714088398rem + 0.4419889503vw, 1.125rem);
  line-height: 2;
}

.youknow__image {
  width: 100%;
  max-width: 39.1304347826%;
  height: auto;
}

.youknow__image img {
  width: 28.125rem;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.youknow__title-underline {
  position: relative;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  z-index: 0;
}

.youknow__title-underline::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.25rem;
  height: 1rem;
  background: #f1ff86;
  z-index: -1;
  border-radius: 0.5rem;
}

.hidden-md {
  display: block;
}

.hidden-pc {
  display: none;
}

.hidden-lg {
  display: none;
}

.hidden-lg-pc {
  display: block;
}

.hidden-xl {
  display: none;
}

.hidden-sm {
  display: block;
}

@media screen and (min-width: 1400px) {
  .hidden-xl {
    display: block;
  }
}

@media screen and (max-width: 1330px) {
  .hidden-lg {
    display: block;
  }

  .hidden-lg-pc {
    display: none;
  }
}

@media screen and (max-width: 1280px) {
  html {
    font-size: 1.25vw;
  }
}

@media screen and (max-width: 768px) {
  .u-desktop {
    display: none;
  }

  .u-mobile {
    display: block;
  }

  html {
    font-size: 4.2666666667vw;
  }

  .circle__connection {
    display: none;
  }

  .circle__vision1 {
    display: none;
  }

  .circle__vision2 {
    display: none;
  }

  .circle__vision--big {
    display: none;
  }

  .circle__vision--big img {
    display: none;
  }

  .circle__point1 {
    display: none;
  }

  .circle__point2 {
    display: none;
  }

  .circle__point--big {
    display: none;
  }

  .column {
    padding-block: 5.4375rem 2.5rem;
  }

  .column__inner {
    padding-inline: 20px;
  }

  .column__sub-title {
    margin-top: 0.875rem;
    line-height: 2.25;
  }

  .column__items {
    display: block;
    margin-top: 0.9375rem;
  }

  .column__item {
    min-width: 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 100% !important;
    position: relative !important;
  }

  .column__image img {
    width: 22.1875rem;
    height: 13.125rem;
  }

  .column__text-block {
    margin-top: 2.125rem;
  }

  .column__text {
    margin-top: 0.625rem;
    line-height: 1.78;
    padding-bottom: 3rem;
  }

  .column__items.splide .splide__track {
    overflow: hidden;
  }

  .column__items.splide .splide__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .column__items.splide .splide__slide {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 100%;
    margin: 0;
    padding: 0;
  }

  .column__items.splide .splide__arrows {
    display: none;
  }

  .column__pagination {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 1.5rem;
    gap: 0.5rem;
  }

  .column__pagination .splide__pagination__page {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: rgba(0, 153, 255, 0.3);
    border: none;
    -webkit-transition: background-color 0.3s ease;
    transition: background-color 0.3s ease;
    opacity: 1;
  }

  .column__pagination .splide__pagination__page.is-active {
    background: #09f;
  }

  .contact {
    padding-block: 2.25rem;
  }

  .contact__inner {
    padding-inline: 20px;
  }

  .contact__text {
    line-height: 1.71;
  }

  .contact__button {
    max-width: 13rem;
    padding: 0.9375rem;
  }

  .contact__button-link {
    line-height: 1.6;
  }

  .detail {
    background-image: url(../../assets/img/common/building_sp.webp);
  }

  .detail__gradient {
    height: 3.75rem;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(90%, #fff), color-stop(10%, rgba(255, 255, 255, 0)));
    background: linear-gradient(180deg, #fff 90%, rgba(255, 255, 255, 0) 10%);
  }

  .detail__inner {
    max-width: 100%;
    padding-block: 2.875rem 3rem;
    background: rgba(255, 255, 255, 0.45);
    padding-inline: 20px;
  }

  .detail__container {
    padding-left: 0rem;
    padding-right: 0rem;
  }

  .detail__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-bottom: 1.5rem;
    gap: 0.875rem;
  }

  .detail__item:not(:first-child) {
    margin-top: 1.5rem;
  }

  .detail__image {
    max-width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }

  .detail__wrap {
    width: 10rem;
    height: 10rem;
  }

  .detail__image img {
    width: 6.25rem;
    height: 6.25rem;
  }

  .detail__text-block {
    max-width: 100%;
    text-align: center;
  }

  .detail__title {
    line-height: 1.85;
  }

  .detail__block {
    margin-top: 3.5rem;
  }

  .detail__sub-title {
    line-height: 1;
    padding-left: 1rem;
  }

  .detail__sub-title::before {
    bottom: -0.375rem;
  }

  .detail__sub-text {
    margin-top: 0.9375rem;
    line-height: 1.71;
  }

  .drawer {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: #ffffff;
    z-index: 8888;
    padding-top: 3.375rem;
  }

  .footer {
    padding-block: 3rem;
  }

  .footer__inner {
    padding-inline: 0.9375rem;
    max-width: 23.4375rem;
  }

  .footer__items.footer__items--middle {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: initial;
  }

  .footer__item-container {
    gap: 0.4375rem;
  }

  .footer__item-container--second {
    margin-top: 0.75rem;
  }

  .footer__item {
    max-width: -webkit-max-content;
    max-width: -moz-max-content;
    max-width: max-content;
  }

  .fv {
    background-image: url("../../assets/img/common/fv_bk3.webp");
    margin-top: 5.8125rem;
  }

  .fv__inner {
    padding-inline: 20px;
  }

  .fv__title-block {
    max-width: 100%;
    top: 2.25rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }

  .fv__title-block img {
    width: 90%;
    height: auto;
    display: block;
    margin-inline: auto;
  }

  .fv__image-block {
    max-width: 100%;
    top: 13.125rem;
    right: 50%;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
  }

  .fv__image img {
    width: 21.25rem;
    height: 21.25rem;
  }

  .fv__text-block {
    top: 4rem;
    right: 50%;
    -webkit-transform: translate(50%);
            transform: translate(50%);
    width: 17rem;
    gap: 1.25rem;
  }

  .fv__text {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }

  .fv__text img {
    width: 14.0625rem;
    height: 2.5rem;
  }

  .fv__button {
    max-width: 16.875rem;
    padding: 0.75rem;
  }

  .fv__label-block {
    width: 6.25rem;
    height: 6.25rem;
    top: -2.5rem;
    right: 0rem;
  }

  .fv__label-wrap {
    margin-top: 0;
  }

  .hamburger {
    display: block;
    position: relative;
    z-index: 9999;
  }

  .hamburger__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 1.125rem;
    height: 1rem;
    cursor: pointer;
    gap: 0.3125rem;
  }

  .hamburger__line {
    display: inline-block;
    width: 100%;
    height: 0.125rem;
    background-color: #0c2952;
    border-radius: 62.5rem;
  }

  .header {
    height: 3.375rem;
    padding-inline: 20px;
  }

  .header__logo {
    z-index: 9999;
  }

  .header__logo img {
    width: 4.9375rem;
    height: 0.875rem;
  }

  .header__list {
    display: none;
  }

  .header__button {
    display: none;
  }

  .message {
    padding-block: 5.3125rem 3.1875rem;
    background-position: top;
    background-image: url("../../assets/img/common/bg-message-sp.webp");
    background-size: cover;
    background-repeat: no-repeat;
  }

  .message__bg1 {
    display: none;
  }

  .message__bg1 img {
    display: none;
  }

  .message__bg2 {
    display: none;
  }

  .message__bg2 img {
    display: none;
  }

  .message__inner {
    padding-inline: 20px;
  }

  .message__title-block {
    text-align: center;
  }

  .message__items {
    margin-top: 3.25rem;
    gap: 3.75rem;
  }

  .message__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .message__image {
    max-width: 100%;
    margin-top: 1.125rem;
  }

  .message__image img {
    width: 20.9375rem;
    height: 13.9375rem;
    margin-inline: auto;
  }

  .message__text-block {
    max-width: 100%;
  }

  .message__title-wrap {
    gap: 0.1875rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .message__number {
    margin-top: -0.875rem;
  }

  .message__title {
    line-height: 1.71;
    letter-spacing: -0.023em;
  }

  .message__text {
    margin-top: 1.625rem;
    line-height: 1.71;
    letter-spacing: -0.001em;
  }

  .point {
    padding-block: 3.75rem 3rem;
    background-image: url("../../assets/img/common/bg-why-sp.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 100%;
  }

  .point__circle1 {
    display: none;
  }

  .point__circle2 {
    display: none;
  }

  .point__circle-big {
    display: none;
  }

  .point__circle-big img {
    display: none;
  }

  .point__inner {
    padding-inline: initial;
    margin-inline: auto;
    max-width: 89.3333333333vw;
    background: initial;
    -webkit-backdrop-filter: initial;
            backdrop-filter: initial;
  }

  .point__title-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 3rem;
    max-width: 100%;
  }

  .point__text-block {
    text-align: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    max-width: 100%;
  }

  .point__title-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }

  .point__title-box img {
    width: 11.25rem;
    height: 2.0625rem;
  }

  .point__title {
    line-height: 1.4;
  }

  .point__text {
    line-height: 1.71;
    letter-spacing: -0.7px;
  }

  .point__content-title {
    line-height: 1.33;
    text-align: center;
  }

  .point__content-text {
    margin-top: 0.75rem;
    line-height: 1.78;
    letter-spacing: -0.7px;
  }

  .point__image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    max-width: 100%;
  }

  .point__image img {
    width: 9.25rem;
    height: 11.125rem;
  }

  .point__items {
    margin-top: 1.5rem;
    gap: 3rem;
    padding-block: 3rem;
  }

  .point__item {
    width: 100%;
    max-width: 100%;
  }

  .point__container {
    gap: 0.625rem;
    padding-inline: 0.8125rem;
    gap: 1.125rem;
  }

  .point__image-wrap img {
    width: 7.5rem;
    height: 3.3125rem;
  }

  .point__images {
    margin-top: 1.125rem;
  }

  .point__images img {
    width: 19.5rem;
    height: 3.75rem;
  }

  .problem {
    margin-top: -1.0625rem;
    background: -webkit-gradient(linear, left top, left bottom, from(#d3eeff), color-stop(15.87%, #a2d4f4), color-stop(25%, #a2d4f4), color-stop(47%, #fff));
    background: linear-gradient(180deg, #d3eeff 0%, #a2d4f4 15.87%, #a2d4f4 25%, #fff 47%);
    padding-bottom: 3rem;
  }

  .problem__inner {
    padding-inline: 20px;
  }

  .problem__title-block {
    padding-top: 2.25rem;
  }

  .problem__title {
    line-height: 1.8;
  }

  .problem__container {
    margin-top: 1.5rem;
    padding-bottom: 7.5rem;
  }

  .problem__items {
    grid-template-columns: repeat(1, 20.9375rem);
    row-gap: 2.25rem;
  }

  .problem__item-wrap {
    max-width: 100%;
    padding: 2rem 1.875rem;
    max-width: 72.5373134328%;
  }

  .problem__top-line {
    width: 2.0625rem;
  }

  .problem__bottom-line {
    width: 2.0625rem;
  }

  .problem__image {
    max-width: 26.6666666667%;
  }

  .resolution {
    padding-block: 3.75rem 3.125rem;
  }

  .resolution__inner {
    padding-inline: 20px;
  }

  .resolution__container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
    padding-bottom: 11.75rem;
  }

  .resolution__text-block {
    text-align: center;
    max-width: 100%;
    padding-block: 0rem;
    letter-spacing: 0.13em;
  }

  .resolution__title {
    line-height: 1;
    letter-spacing: -0.02em;
  }

  .resolution__logo {
    margin-top: 1.5625rem;
  }

  .resolution__logo img {
    width: 19.375rem;
    height: 3.4375rem;
    display: block;
    margin-inline: auto;
  }

  .resolution__image {
    margin-top: 1.3125rem;
    max-width: 100%;
    margin-right: initial;
  }

  .resolution__image img {
    right: 0rem;
    width: 100%;
    height: auto;
  }

  .resolution__text {
    margin-top: 1.625rem;
    line-height: 1.74;
    letter-spacing: -0.001em;
    text-align: left;
  }

  .service {
    padding-block: 3.125rem 2.0625rem;
  }

  .service__circle {
    display: none;
  }

  .service__inner {
    padding-inline: 20px;
  }

  .service__sub-title {
    margin-top: 0.625rem;
    line-height: 1.71;
    letter-spacing: 0.12em;
  }

  .service__items {
    margin-top: 6.375rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 4.6875rem;
  }

  .service__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .service__image {
    max-width: 100%;
  }

  .service__image img {
    width: 4rem;
  }

  .service__image-circle {
    width: 7rem;
    height: 7rem;
  }

  .service__text-block {
    max-width: 100%;
    text-align: center;
    margin-top: 4rem;
  }

  .service__title {
    line-height: 1.71;
  }

  .service__text {
    line-height: 1.78;
  }

  .service__after-title {
    width: 100%;
    max-width: 100%;
    margin-top: -2.9375rem;
  }

  .service__after-text {
    line-height: 1.71;
  }

  .solution {
    padding-block: 2.25rem;
  }

  .solution__inner {
    padding-inline: 20px;
  }

  .solution__title {
    line-height: 1.82;
  }

  .solution__triangle {
    max-width: 17.3913043478%;
    height: 2.25rem;
  }

  .video {
    margin-top: initial;
  }

  .video__inner {
    padding-inline: 20px;
  }

  .vision {
    padding-block: 3rem 5.25rem;
    background-image: url("../../assets/img/common/bg-vision-sp.webp");
    background-size: cover;
    background-repeat: no-repeat;
  }

  .vision__circle1 {
    display: none;
  }

  .vision__circle2 {
    display: none;
  }

  .vision__circle-big {
    display: none;
  }

  .vision__circle-big img {
    display: none;
  }

  .vision__inner {
    padding-inline: 20px;
  }

  .vision__sub-title {
    margin-top: 1.125rem;
  }

  .vision__sub-title--big {
    margin-top: 0.625rem;
  }

  .vision__container {
    row-gap: 5.25rem;
    margin-top: 3.4375rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }

  .vision__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: initial;
  }

  .vision__text-block {
    max-width: 100%;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
  }

  .vision__text-title {
    text-align: center;
    position: relative;
  }

  .vision__text-title::after {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    margin-top: 0.625rem;
  }

  .vision__text {
    margin-top: 1.875rem;
    line-height: 1.71;
    padding-inline: 0.625rem;
  }

  .vision__image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 1.25rem;
    max-width: 100%;
  }

  .vision__image img {
    width: 19.5rem;
    height: 13rem;
  }

  .youknow__out-image {
    top: -6.25rem;
    left: 1.25rem;
  }

  .youknow__out-image img {
    width: 13.125rem;
    height: 5.75rem;
  }

  .youknow__container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .youknow__text-container {
    max-width: 100%;
    text-align: center;
  }

  .youknow__text-block {
    margin-top: 0.3125rem;
    text-align: center;
  }

  .youknow__title.youknow__title--medium {
    text-decoration-thickness: 0.625rem;
  }

  .youknow__title--big {
    margin-top: 0.625rem;
  }

  .youknow__title--medium {
    margin-top: 0.625rem;
  }

  .youknow__text {
    margin-top: 1.5625rem;
    padding-left: 0rem;
    line-height: 1.71;
  }

  .youknow__image {
    margin-top: 2rem;
    max-width: 100%;
  }

  .youknow__image img {
    width: 20.9375rem;
    height: 15.625rem;
    margin-inline: auto;
  }

  .hidden-md {
    display: none;
  }

  .hidden-pc {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .hidden-sm {
    display: none;
  }
}
/*# sourceMappingURL=style.css.map */