/* ----------------------------------------------------------------------------
* portal
* ------------------------------------------------------------------------- */
.l-headerMain__right {
  display: flex;
  width: -moz-fit-content;
  width: fit-content;
  gap: 20px;
  align-items: center;
}
.l-headerMain__right .m-headerLink {
  position: relative;
  top: 0;
  right: auto;
}
.l-headerMain__right .m-headerUtil__fontsize {
  align-items: center;
}

h1 {
  font-size: 2.3rem;
  font-size: clamp(1.625rem, 4vw, 2.3rem);
  font-weight: bold;
  text-align: center;
  color: #d93d00;
}

.flex {
  display: flex;
  gap: 10px;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .flex {
    gap: 20px;
  }
}

.m-grid {
  margin-left: 0;
  gap: 20px;
  flex-direction: column;
}
@media screen and (min-width: 980px) {
  .m-grid {
    flex-direction: row;
  }
}

.m-grid__col2 {
  margin-left: 0;
  flex-grow: 1;
}
@media screen and (max-width: 979px) {
  .m-grid__col2 {
    width: 100%;
  }
}

.m-grid__col2 + .m-grid__col2 {
  width: 46.34%;
  flex-grow: 0;
}
@media screen and (max-width: 979px) {
  .m-grid__col2 + .m-grid__col2 {
    width: 100%;
  }
}

.m-grid__col4 {
  flex-shrink: 0;
  margin-left: 0;
}
@media screen and (max-width: 767px) {
  .m-grid__col4 {
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}

.m-grid__col {
  flex-basis: auto;
  flex-grow: 1;
  width: calc(75% - 30px);
}
@media screen and (max-width: 767px) {
  .m-grid__col {
    width: 100%;
  }
}

.lp-bnr,
section {
  padding: 45px 15px;
}
@media screen and (min-width: 1010px) {
  .lp-bnr,
  section {
    padding: 45px calc((100% - 980px) / 2);
  }
}
.lp-bnr h2,
section h2 {
  font-size: 2rem;
  font-size: clamp(1.625rem, 4vw, 2rem);
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}
.lp-bnr h3,
section h3 {
  font-size: 1.75rem;
  font-size: clamp(1.375rem, 4vw, 1.75rem);
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}
.lp-bnr p,
section p {
  font-size: 1.125rem;
  line-height: 1.6;
}
.ict-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0 20px;
  margin: 20px auto 30px;
}
@media screen and (min-width: 768px) {
.ict-grid {
  grid-template-columns: minmax(505px,auto) 1fr;
}
}
@media screen and (min-width: 768px) {
  .ict-grid + .m-grid {
    flex-direction: row-reverse;
  }
}
.ict-grid + .m-grid p {
  margin-top: 0;
}
.lp-ict_header {
  position: relative;
  overflow: hidden;
  padding-top: 0;
  padding-bottom: 100px;
}
.lp-ict_header::before {
  content: "";
  z-index: -1;
  background-color: #fff2e6;
  border-radius: 100%;
  position: absolute;
  left: calc(50% - 200dvw);
  top: 30%;
  width: 400dvw;
  height: 400dvw;
}
.lp-ict_header::after {
  content: "";
  z-index: 1;
  position: absolute;
  left: 0;
  bottom: 0;
  height: 70px;
  width: 100%;
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgb(255, 255, 255));
}
.lp-ict_header .flex a {
  background-image: url("../../images/ict_users_bg.png");
  background-repeat: repeat;
  font-size: 1.1rem;
  font-size: clamp(0.8rem, 3vw, 1.1rem);
  color: #000;
  text-decoration: none;
  font-weight: bold;
  border: 1px solid #0650cb;
  border-radius: 100%;
  width: calc(50% - 10px);
  aspect-ratio: 1 / 1;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  box-shadow: inset 0 0 0 1px #0650cb, inset 0 0 0 6px #fff, inset 0 0 0 7px #0650cb;
}
@media screen and (min-width: 768px) {
  .lp-ict_header .flex a {
    box-shadow: inset 0 0 0 1px #0650cb, inset 0 0 0 10px #fff, inset 0 0 0 11px #0650cb;
  }
}
.lp-ict_header .flex a:hover {
  box-shadow: inset 0 0 0 6px #0650cb;
}
@media screen and (min-width: 768px) {
  .lp-ict_header .flex a:hover {
    box-shadow: inset 0 0 0 10px #0650cb;
  }
  .lp-ict_header .flex a:hover::after {
    bottom: 12px;
  }
}
.lp-ict_header .flex a dl {
  text-align: center;
}
.lp-ict_header .flex a dt {
  background-color: #0650cb;
  color: #fff;
  white-space: nowrap;
  width: -moz-fit-content;
  width: 100%;
  border-radius: 50px;
  margin: 0 auto 5px;
  padding: 8px 16px;
}
@media screen and (min-width: 601px) {
  .lp-ict_header .flex a dt {
    margin: 0 auto 10px;
    padding: 10px 20px;
  }
}
.lp-ict_header .flex a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 11px solid transparent;
  border-left: 11px solid transparent;
  border-top: 14px solid #0650cb;
  border-bottom: 0;
  position: absolute;
  bottom: 8.5%;
  transition: 0.3s all ease;
}
.lp-ict_header .flex a + a {
  background-image: url("../../images/ict_supporters_bg.png");
  border: 1px solid #613cdc;
  box-shadow: inset 0 0 0 1px #613cdc, inset 0 0 0 6px #fff, inset 0 0 0 7px #613cdc;
}
@media screen and (min-width: 768px) {
  .lp-ict_header .flex a + a {
    box-shadow: inset 0 0 0 1px #613cdc, inset 0 0 0 10px #fff, inset 0 0 0 11px #613cdc;
  }
}
.lp-ict_header .flex a + a dt {
  background-color: #613cdc;
}
.lp-ict_header .flex a + a::after {
  border-top: 14px solid #613cdc;
}
.lp-ict_header .flex a + a:hover {
  box-shadow: inset 0 0 0 6px #613cdc;
}
@media screen and (min-width: 768px) {
  .lp-ict_header .flex a + a:hover {
    box-shadow: inset 0 0 0 10px #613cdc;
  }
}

.lp-ict_place h2 {
  color: #d93d00;
  padding-bottom: 5px;
  border-bottom: 1px solid #d93d00;
}

.lp-ict_users,
.lp-ict_supporters {
  background-color: #eff5ff;
  text-align: center;
}
.lp-ict_users > div,
.lp-ict_supporters > div {
  background-image: url("../../images/ict_users_bg.png");
  background-repeat: repeat;
  border: 1px solid #0650cb;
  border-top-width: 4px;
  padding: 30px;
}
.lp-ict_users > div + div,
.lp-ict_supporters > div + div {
  margin-top: 30px;
}
.lp-ict_users > div + div h3,
.lp-ict_supporters > div + div h3 {
  background-image: url("../../images/ict_users_ico_2.svg");
}
.lp-ict_users h2,
.lp-ict_supporters h2 {
  color: #0650cb;
}
.lp-ict_users h3,
.lp-ict_supporters h3 {
  background-image: url("../../images/ict_users_ico_1.svg");
  background-repeat: no-repeat;
  background-size: auto 50px;
  background-position: top center;
  color: #0650cb;
  padding-top: 60px;
}
.lp-ict_users p,
.lp-ict_supporters p {
  text-align: left;
  margin: 0 0 20px;
}
.lp-ict_users a,
.lp-ict_supporters a {
  background-color: #fff;
  font-size: 1.438rem;
  color: #0650cb;
  text-align: center;
  line-height: 1.1;
  font-weight: bold;
  text-decoration: none;
  border: 2px solid #0650cb;
  border-radius: 100px;
  padding: 15px 50px;
  position: relative;
  display: block;
}
.lp-ict_users a::before,
.lp-ict_supporters a::before {
  content: "";
  background-image: url("../../images/icn_sprite.svg");
  background-position: -393px -393px;
  background-size: 1405px 1385px;
  background-repeat: no-repeat;
  width: 22px;
  height: 22px;
  position: absolute;
  left: 20px;
  top: calc(50% - 11px);
  transition: 0.3s all ease;
}
.lp-ict_users a:hover,
.lp-ict_supporters a:hover {
  background-color: #eff5ff;
}
.lp-ict_users a:hover::before,
.lp-ict_supporters a:hover::before {
  left: 26px;
}

.lp-ict_supporters {
  background-color: #f3efff;
}
.lp-ict_supporters > div {
  background-image: url("../../images/ict_supporters_bg.png");
  border: 1px solid #613cdc;
  border-top-width: 4px;
}
.lp-ict_supporters > div h3 {
  background-image: url("../../images/ict_supporters_ico_1.svg");
}
.lp-ict_supporters > div + div h3 {
  background-image: url("../../images/ict_supporters_ico_2.svg");
}
.lp-ict_supporters h2 {
  color: #613cdc;
}
.lp-ict_supporters h3 {
  color: #613cdc;
}
.lp-ict_supporters a {
  color: #613cdc;
  border: 2px solid #613cdc;
}
.lp-ict_supporters a::before {
  background-image: url("../../images/ict_supporters_btn.svg");
  background-size: 100%;
  background-position: 0;
}
.lp-ict_supporters a:hover {
  background-color: #f3efff;
}

.lp-ict_others .m-hdgLv2 {
  margin-top: 0;
}

.lp-bnr {
  background-color: #f4f5f8;
}
.lp-bnr ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
}