/*===========================================================================
unique
単一ページで使用するCSS
接頭辞【.u-】

【予測変換用 _base.css記述】
:root {
	--font-color-base: #000;
	--font-family-base: "Noto Sans JP", sans-serif;
	--back-color-base: #fff;
	--design-size-pc: 1400;
	--design-size-sp: 750;
}
===========================================================================*/
.m-pageKv {
  margin-bottom: 8.1rem;
}
.c-ctsWrap {
  margin-top: 8.2rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .m-pageKv {
    margin-bottom: 1.7rem;
  }
}


/* 共通パーツ
====================================*/
.u-sec + .u-sec {
  margin-top: 12rem;
}
.u-sec__lead {
  color: var(--font-color-main);
  line-height: 1.8;
}
.u-sec__lead + * {
  margin-top: 1.6rem;
}
.u-sec__ttl {
  font-family: var(--font-family-serif);
  font-size: 3.2rem;
  font-weight: 300;
  line-height: 1.8;
}
.u-sec__ttl:has(.text-big) {
  line-height: 1.5;
}
.u-sec__ttl .text-big {
  font-size: 4rem;
}
.u-sec__subTtl {
  color: var(--font-color-main);
  font-size: 2.8rem;
  font-weight: normal;
  line-height: 1.8;
}
* + .u-sec__subTtl {
  margin-top: 3.2rem;
}
.u-sec__txt {
  margin-top: 2.4rem;
}
.u-sec__txt + .u-sec__txt {
  margin-top: 4.8rem;
}
.u-sec__box {
  overflow: hidden;
  margin-top: 2.4rem;
  border-radius: 0.8rem;
  box-shadow: 0.3rem 0.4rem 4.8rem 0 rgba(0, 0, 0, 0.08);
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .u-sec__ttl .text-big-pc {
    font-size: 4rem;
  }
  .u-sec__subTtl + .u-sec__txt {
    margin-top: 0.8rem;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-sec + .u-sec {
    margin-top: 10rem;
  }
  .u-sec__ttl {
    font-size: 3rem;
  }
  .u-sec__ttl:has(.text-big) {
    font-size: 2.4rem;
  }
  .u-sec__ttl .text-big {
    font-size: 3.2rem;
  }
  .u-sec__subTtl {
    font-size: 2.4rem;
  }
  * + .u-sec__subTtl {
    margin-top: 3.2rem;
  }
  .u-sec__txt {
    margin-top: 2.4rem;
  }
  .u-sec__txt + .u-sec__txt {
    margin-top: 4.8rem;
  }
  .u-sec__box:has( > .c-imgScroll) {
    overflow: initial;
    margin-top: 2rem;
  }
  .u-sec__box > .c-imgScroll {
    margin-top: 0;
  }
  .u-sec__box > .c-imgScroll > *:first-child {
    width: 92rem;
  }
}


/* 事業
====================================*/
.u-next__row {
  display: flex;
  flex-direction: row-reverse;
  gap: 0 8rem;
}
.u-next__col {
  flex: 1;
  margin-top: 4.8rem;
}
.u-next__col .u-sec__txt {
  margin-top: 4rem;
}
.u-next__imgWrap {
  position: relative;
  flex-basis: 56rem;
}
.u-next__img01 {
  width: 48rem;
}
.u-next__img02 {
  width: 24rem;
  margin-top: 4rem;
  margin-left: auto;
}
.u-next__img03 {
  width: 18rem;
  margin-top: -7.2rem;
  margin-left: 5.6rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-next__inr {
    padding-top: 6.8rem;
  }
  .u-next__row {
    flex-direction: column-reverse;
    gap: 5.6rem;
  }
  .u-next__col {
    flex: initial;
    margin-top: 0;
  }
  .u-next__col .u-sec__txt {
    margin-top: 1.6rem;
  }
  .u-next__imgWrap {
    flex-basis: initial;
  }
  .u-next__img01 {
    width: 30rem;
  }
  .u-next__img02 {
    width: 14rem;
  }
  .u-next__img03 {
    width: 10.5rem;
    margin-top: -4.5rem;
    margin-left: 4rem;
  }
}



.u-plan__block {
  margin-top: 12rem;
}
.u-plan__block + .u-plan__block {
  margin-top: 3.2rem;
}
.u-plan__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2.4rem;
}
.u-plan__row .u-planBgBox {
  min-height: 14rem;
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .u-sec + .u-plan {
    margin-top: 10rem;
  }
  .u-plan__intro {
    position: relative;
  }
  .u-plan__col {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: max-content;
  }
  .u-plan__img {
    width: 110rem;
    margin-left: auto;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-plan__img {
    margin-top: 2.4rem;
  }
  .u-plan__block {
    margin-top: 8rem;
  }
  .u-plan__row {
    display: block;
  }
  .u-plan__row .u-planBgBox {
    min-height: initial;
    padding: 2.4rem 1rem;
    line-height: 1.8;
  }
  .u-plan__row .u-planBgBox__num {
    line-height: 1.48;
  }
}


.u-planBox {
  display: flex;
  flex-direction: column;
  margin-top: 2.4rem;
  padding: 3.2rem;
  border-radius: 0.8rem;
  background-color: var(--back-color-base);
  box-shadow: 0.3rem 0.4rem 4.8rem 0 rgba(0, 0, 0, 0.08);
}
.u-planBox > *:first-child {
  margin-top: 0 !important;
}
.u-planBox__ttl {
  color: var(--font-color-main);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  text-align: center;
}
.u-planBox__img {
  margin-top: 1.6rem;
}
.u-planBox__note {
  margin-top: 1.6rem;
  font-size: 1.2rem;
  font-weight: normal;
  line-height: 2;
  letter-spacing: normal;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-planBox {
    display: block;
  }
  .u-planBox + .u-planBox {
    margin-top: 1.6rem;
  }
  .u-planBox:has(.u-strategy) {
    padding: 2rem;
  }
}

.u-planBgBox {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 0.8rem;
  padding: 2.4rem 1rem;
  background-color: #f4f7fb;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
}
.u-planBgBox:first-of-type {
  margin-top: 1.6rem;
}
.u-planBgBox > * + * {
  margin-top: 1.6rem;
}
.u-planBgBox__num {
  color: var(--font-color-main);
  font-size: 4.8rem;
  font-weight: bold;
}
* + .u-planBgBox__num {
  margin-left: 0.8rem;
}
.u-planBgBox__unit {
  margin: 0 0.8rem 0 0.4rem;
  color: var(--font-color-main);
}
.u-planBgBox__txt {
  margin-top: 0.8rem;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 2;
  letter-spacing: normal;
}
.u-planBgBox .u-planBox__note {
  margin-top: 0.4rem;
}
.u-planBgBox__row {
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.u-planBgBox__col {
  position: relative;
  padding: 0 4.5rem;
}
.u-planBgBox__col .u-planBgBox__num {
  margin-left: 0;
}
.u-planBgBox__col .u-planBgBox__note {
  text-align: center;
}

.u-planBgBox:has(.u-planBgBox__row.--type-line) {
  align-items: stretch;
  padding: 2rem;
}
.u-planBgBox__row.--type-line {
  display: flex;
}
.u-planBgBox__row.--type-line .u-planBgBox__col {
  display: flex;
  align-items: end;
  gap: 0.4rem;
  padding: 0 3.5rem;
}
.u-planBgBox__row.--type-line .u-planBgBox__num {
  font-size: 4rem;
  line-height: 1;
}
.u-planBgBox__row.--type-line .u-planBgBox__unit {
  margin: 0 0.4rem;
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .u-planBgBox__col:nth-child(even)::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 1px;
    height: 7.2rem;
    background-color: #c4cedc;
    transform: translateY(-50%);
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col:first-child {
    padding-left: 0;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col:last-child {
    padding-right: 0;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col:not(:first-child)::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 1px;
    height: 4rem;
    background-color: #c4cedc;
    transform: translateY(-50%);
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-planBgBox {
    display: block;
    text-align: center;
  }
  .u-planBgBox > * + p:has(.u-planBgBox__num) {
    margin-top: -0.1rem;
  }
  .u-planBgBox__unit {
    margin: 0 0.4rem;
  }
  .u-planBgBox__txt {
    margin-top: 0;
    font-size: 1.6rem;
  }
  .u-planBgBox__row {
    display: block;
  }
  .u-planBgBox__col {
    padding: 0;
  }
  .u-planBgBox__col:not(:first-child) {
    padding-top: 1.6rem;
  }
  .u-planBgBox__col:not(:last-child) {
    padding-bottom: 1.6rem;
  }

  .u-planBgBox:has(.u-planBgBox__row.--type-line) {
    align-items: stretch;
    padding: 2.2rem 1rem;
    font-size: 1.5rem;
    line-height: 1.4;
  }
  .u-planBgBox__row.--type-line {
    flex-wrap: wrap;
    gap: 2.3rem 1.1rem;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col {
    display: block;
    width: calc((100% - 1.2rem) / 2);
    padding: 0;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col:nth-child(even)::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -0.6rem;
    width: 1px;
    height: 4.4rem;
    background-color: #c4cedc;
    transform: translateY(-50%);
  }
  .u-planBgBox__row.--type-line .u-planBgBox__col > * + * {
    margin-top: 0.4rem;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__num {
    font-size: 2.8rem;
  }
  .u-planBgBox__row.--type-line .u-planBgBox__unit {
    margin: 0 0.2rem;
    font-size: 1.4rem;
  }
}


.u-strategy {
  position: relative;
  margin-top: 4rem;
  padding: 3.2rem 2rem;
  background-color: #e3e9f4;
}
.u-strategy::before {
  content: "";
  position: absolute;
  top: -3.2rem;
  left: 50%;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  width: 6.4rem;
  height: 4rem;
  background: #e3e9f4;
  transform: translateX(-50%);
}
.u-strategy__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}
.u-strategy__item {
  display: flex;
  flex-direction: column;
  padding: 2rem;
  background-color: #f4f7fb;
}
.u-strategy__ttl {
  color: var(--font-color-main);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.u-strategy__cts {
  flex: 1;
  margin-top: 1.6rem;
}
.u-strategy__box {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.8rem;
  height: 100%;
}
.u-strategy__boxItem {
  gap: 0 2rem;
  padding: 1.6rem 2.4rem 1.6rem 2rem;
  border-radius: 0.4rem;
  background-color: #fff;
}
.u-strategy__boxTtlWrap {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.u-strategy__boxTtl {
  font-weight: 500;
  line-height: 1.5;
}
.u-strategy__label {
  min-width: 9rem;
  padding: 0.3rem 1rem;
  border-radius: 10rem;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.u-strategy__label.--bgc-bl {
  background-color: #5197ef;
}
.u-strategy__label.--bgc-rd {
  background-color: #e88a85;
}
.u-strategy__label.--bgc-gr {
  background-color: #17c663;
}
.u-strategy__label.--bgc-yl {
  background-color: #f8a758;
}
.u-strategy__boxTtlWrap + * {
  margin-top: 0.6rem;
}
.u-strategy__boxCts {
  font-size: 1.4rem;
  line-height: 1.5;
}
.u-strategy__boxCts ul:not([class]) > li {
  position: relative;
  padding-left: 2.4rem;
}
.u-strategy__boxCts ul:not([class]) > li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0.4rem;
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .u-strategy__item.--col-1-pc {
    grid-column: 1 / -1;
  }
  .u-strategy__box.--col-2-pc {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .u-strategy__box.--col-2-pc .u-strategy__boxItem {
    min-height: 12.7rem;
  }
  .u-strategy__boxItem.l-grid-pc .u-strategy__boxTtlWrap + * {
    margin-top: 0;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-strategy {
    margin-top: 2.8rem;
    padding: 2rem 1.2rem;
  }
  .u-strategy::before {
    top: -2rem;
  }
  .u-strategy__grid {
    grid-template-columns: minmax(0, 1fr);
  }
  .u-strategy__item {
    padding: 2rem 1.2rem;
  }
  .u-strategy__cts {
    margin-top: 1.2rem;
  }
  .u-strategy__boxItem {
    padding: 2rem 1.2rem;
  }
  .u-strategy__label.--bgc-gr {
    min-width: 6.7rem;
  }
  .u-strategy__boxCts ul:not([class]) > li {
    padding-left: 2.1rem;
  }
  .u-strategy__boxCts ul:not([class]) > li::before {
    top: 0.2rem;
  }
}


.u-box {
  padding: 2.9rem 3.2rem 3.2rem;
}
.u-box__ttl {
  color: var(--font-color-main);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}
.u-box__row {
  display: grid;
  grid-template-columns: 63.5rem minmax(0, 1fr);
  gap: 4rem;
  margin-top: 2.4rem;
}
.u-box__img .m-img {
  margin-top: 0;
}

.u-dlList {
  line-height: 1.5;
}
.u-dlList__item:not(:first-child) {
  margin-top: 1.6rem;
  padding-top: 1.6rem;
  background-image: repeating-linear-gradient(90deg, #c4cedc, #c4cedc 0.4rem, transparent 0.4rem, transparent 8px);
  background-repeat: repeat-x;
  background-position: left top;
  background-size: 100% 1px;
}
.u-dlList__item.--type-01 {
  --type-color: #d6e5fd;
}
.u-dlList__item.--type-02 {
  --type-color: #5197ef;
}
.u-dlList__item.--type-03 {
  --type-color: #e88a85;
}
.u-dlList__item.--type-04 {
  --type-color: #17c663;
}
.u-dlList__item.--type-05 {
  --type-color: #f8a758;
}
.u-dlList__ttl {
  position: relative;
  padding-left: 2.4rem;
}
.u-dlList__ttl::before {
  content: "";
  position: absolute;
  top: 0.4rem;
  left: 0;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 1px;
  background-color: var(--type-color);
}
.u-dlList__ttl .text-small {
  display: inline-block;
  padding: 0.2rem 1rem;
  border: 1px solid var(--font-color-main);
  border-radius: 1.6rem;
  color: var(--font-color-main);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.5;
}
.u-dlList__cts {
  margin-top: 0.4rem;
  padding-left: 2.4rem;
  font-size: 1.4rem;
}
.u-dlList__cts ul:not([class]) > li {
  position: relative;
  padding-left: 2.4rem;
}
.u-dlList__cts ul:not([class]) > li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0.4rem;
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .u-dlList__ttl:has( .text-small) > p:first-child {
    display: inline;
  }
  .u-dlList__ttl:has( .text-small) > * + * {
    margin-left: 1rem;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .u-box {
    padding: 3.2rem 2rem;
  }
  .u-box__row {
    display: block;
  }
  .u-box__img .m-img {
    width: 63.5rem;
    margin-top: 0.4rem;
  }
  .u-box__col {
    margin-top: 2.4rem;
  }

  .u-dlList__ttl .text-small {
    margin-top: 0.4rem;
  }
  .u-dlList__cts ul:not([class]) > li {
    padding-left: 2.1rem;
  }
  .u-dlList__cts ul:not([class]) > li::before {
    top: 0.2rem;
  }
}
