/* common
  ========================================================================== */
/* font */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
.u-font__noto {
  font-family: "Noto Sans JP", sans-serif;
}

/* display */
.u-dp__ib {
  display: inline-block;
}

/* color */
.u-color__red {
  color: #e24d4d;
}

/* main
  ========================================================================== */
/* .p-dobroku_caution */
.p-dobroku_caution {
  background: #fff;
  padding: 3.25em 0 3.75em;
}

.p-dobroku_caution__wrapper {
  width: 458px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 13.7% 1.6% 1fr;
  grid-template-columns: 13.7% 1fr;
  grid-column-gap: 1.6%;
  padding: 1.6em 2%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border: 1px solid #e24d4d;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.p-dobroku_caution__img {
  -ms-grid-column-align: center;
      justify-self: center;
  height: 38px;
}

.p-dobroku_caution__text {
  font-size: 13.7px;
  line-height: 1.65;
}

/* .p-dobroku_kv */
.p-dobroku_kv__pic .__img {
  max-width: 100%;
}

/* .p-dobroku_catch */
.p-dobroku_catch {
  position: relative;
  background: #fff;
  padding: 4.4em 0 7.55em;
}
.p-dobroku_catch:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  height: 83%;
  width: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#b6dae5));
  background: linear-gradient(to bottom, #fff 0%, #b6dae5 100%);
}

.p-dobroku_catch__wrapper {
  position: relative;
  z-index: 1;
  padding: 0 2.25%;
}

.p-dobroku_catch__text {
  font-weight: 700;
  font-size: 84px;
  line-height: 0.975;
  letter-spacing: 0.03em;
  color: #4ca1b9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0 0.25em;
}
.p-dobroku_catch__gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 3.06%;
  margin-top: 1.75em;
}

.p-dobroku_catch__gallery__item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.p-dobroku_catch__gallery__item .__img {
  width: 100%;
  height: 100%;
  aspect-ratio: 166/109;
  -o-object-fit: cover;
     object-fit: cover;
}

/* .p-dobroku_about */
.p-dobroku_about {
  padding: 2.7em 0 7em;
  background: #fff;
}

.p-dobroku_about__info {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 4.9% auto 4.9% auto;
  grid-template-columns: 1fr repeat(2, auto);
  -ms-grid-rows: 0.9fr 1.2em auto 1.2em auto 1.2em 1fr;
  grid-template-rows: 0.9fr repeat(2, auto) 1fr;
      grid-template-areas: ". . img" ". sub img" ". text img" ". . img";
  grid-column-gap: 4.9%;
  grid-row-gap: 1.2em;
}
.p-dobroku_about__info:after {
  -ms-grid-row: 1;
  -ms-grid-row-span: 7;
  -ms-grid-column: 5;
  grid-area: img;
  content: "";
  display: block;
  width: 209px;
  height: auto;
  aspect-ratio: 96/155;
  background: url(../images/doburoku/dec-dobroku_about.jpg) no-repeat left center/cover;
}

.p-dobroku_about__info__sub {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  grid-area: sub;
  font-weight: 700;
  font-size: 27.4px;
  letter-spacing: 0.05em;
}
.p-dobroku_about__info__sub:after {
  content: "";
  display: block;
  height: 3px;
  width: 51px;
  background: #f1c21b;
  margin-top: 0.575em;
}

.p-dobroku_about__info__text {
  -ms-grid-row: 5;
  -ms-grid-column: 3;
  grid-area: text;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.85;
}

.p-dobroku_about__point {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 2.1%;
  margin-top: 1.15em;
}

.p-dobroku_about__point__item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr auto;
  grid-template-columns: 1fr auto;
  -ms-grid-rows: auto 1em auto;
  grid-template-rows: repeat(2, auto);
      grid-template-areas: ". head" ". body";
  grid-row-gap: 1em;
}
.p-dobroku_about__point__item:nth-of-type(2) {
  -ms-grid-columns: 1fr 84%;
  grid-template-columns: 1fr 84%;
}
.p-dobroku_about__point__item:nth-of-type(3) {
  -ms-grid-columns: 1fr 91%;
  grid-template-columns: 1fr 91%;
}
.p-dobroku_about__point__item .__head {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: head;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 0 0.5em;
  line-height: 1;
  position: relative;
}
.p-dobroku_about__point__item .__head:before {
  content: "";
  display: block;
  width: 48px;
  height: 48px;
  background: url(../images/doburoku/dec-dobroku_about__point.svg) no-repeat center/contain;
  position: absolute;
  left: -24px;
  bottom: -4px;
  z-index: 1;
}
.p-dobroku_about__point__item .__head .__text,
.p-dobroku_about__point__item .__head .__num {
  position: relative;
  z-index: 2;
}
.p-dobroku_about__point__item .__head .__text {
  font-size: 18.75px;
}
.p-dobroku_about__point__item .__head .__num {
  font-size: 23.75px;
}
.p-dobroku_about__point__item .__body {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
  grid-area: body;
  font-size: 16px;
  line-height: 1.725;
  letter-spacing: 0.05em;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted #f1c21b;
          text-decoration: underline dotted #f1c21b;
  text-underline-offset: 0.25em;
}

.p-dobroku_about__detail {
  border: 1px solid #333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 95.8%;
  margin: 3.5em auto 0;
  border-radius: 12px;
  padding: 2.35em 6.15%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.p-dobroku_about__detail__text {
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.05em;
  width: 51.59%;
}

.p-dobroku_about__detail__img {
  width: 41.9%;
  height: auto;
  aspect-ratio: 251/138;
  -o-object-fit: cover;
     object-fit: cover;
}

/* .p-dobroku_howto */
.p-dobroku_howto {
  padding-bottom: 7.25em;
  background: #fff;
}

.p-dobroku_howto__head {
  width: 100%;
  height: auto;
  aspect-ratio: 716/433;
  background: url(../images/doburoku/bg-dobroku_howto__head.jpg) no-repeat center/cover;
  color: #fff;
  padding: 0 6% 2em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  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: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 1.1em 0;
}

.p-dobroku_howto__head__sub {
  font-weight: 600;
  font-size: 27px;
  letter-spacing: 0.065em;
  line-height: 1.6;
}
.p-dobroku_howto__head__sub:after {
  content: "";
  display: block;
  height: 2px;
  width: 51px;
  background: #f1c21b;
  margin-top: 0.52em;
}

.p-dobroku_howto__head__text {
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.85;
}

.p-dobroku_howto__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 0 2.1%;
  gap: 0 2.915%;
  margin-top: 2.05em;
}

.p-dobroku_howto__list__box {
  width: 31.39%;
}
.p-dobroku_howto__list__box .__figure {
  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.95em 0;
}
.p-dobroku_howto__list__box .__figure .__figure__img {
  width: 100%;
  height: auto;
  aspect-ratio: 43/32;
  border-radius: 12px;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-dobroku_howto__list__box .__figure .__figure__caption {
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.59;
}

/* .p-dobroku_idea */
.p-dobroku_idea {
  background: url(../images/doburoku/bg-dobroku_idea.jpg) no-repeat center/cover;
  position: relative;
  padding: 7em 0 7.05em;
}
.p-dobroku_idea:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.12;
  background: #41445c;
  z-index: 1;
}

.p-dobroku_idea__wrapper {
  width: 548px;
  border-radius: 12px;
  margin: 0 auto;
  position: relative;
  background: rgba(255, 255, 255, 0.96);
  border: 2px solid rgba(51, 51, 51, 0.96);
  padding: 2.1em 6% 2.7em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  z-index: 2;
}
.p-dobroku_idea__wrapper:after {
  content: "";
  display: block;
  width: 86px;
  height: auto;
  aspect-ratio: 47/50;
  background: url(../images/doburoku/dec-dobroku_idea.svg) no-repeat center/contain;
  position: absolute;
  bottom: 1.55em;
  right: 7.3%;
}

.p-dobroku_idea__sub {
  font-weight: 500;
  font-size: 18.3px;
  letter-spacing: 0.05em;
  position: relative;
}
.p-dobroku_idea__sub:before {
  content: "";
  display: block;
  width: 17px;
  height: 17px;
  background: url(../images/doburoku/dec-dobroku_idea__sub.svg) no-repeat center/contain;
  position: absolute;
  top: -10px;
  left: -19px;
}

.p-dobroku_idea__list {
  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.77em 0;
  margin-top: 1.2em;
}

.p-dobroku_idea__list__item {
  font-size: 16px;
  letter-spacing: 0.05em;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 0.5em 1fr;
  grid-template-columns: auto 1fr;
  grid-column-gap: 0.5em;
}
.p-dobroku_idea__list__item:before {
  content: "";
  display: block;
  width: 0.7em;
  height: 0.7em;
  border-radius: 100%;
  background: #f1c21b;
  margin-top: calc((1lh - 0.7em) / 2);
}

/* .p-dobroku_why */
.p-dobroku_why {
  padding: 6.4em 0 7.4em;
  background: #fff;
}

.p-dobroku_why__wrapper {
  padding: 0 6%;
}

.p-dobroku_why__sub {
  font-weight: 700;
  font-size: 27.5px;
  line-height: 1.575;
  letter-spacing: 0.05em;
}
.p-dobroku_why__sub:after {
  content: "";
  display: block;
  height: 2px;
  width: 51px;
  background: #f1c21b;
  margin-top: 0.53em;
}

.p-dobroku_why__about {
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.85;
  margin-top: 0.9em;
}

.p-dobroku_why__details {
  border: 1px solid rgba(51, 51, 51, 0);
  border-top: 0;
  border-radius: 12px;
  background: #f8f8f8;
  width: 94.6%;
  margin: 7.2em auto 0;
  position: relative;
  -webkit-transition: border 0.25s;
  transition: border 0.25s;
}
.p-dobroku_why__details[open] {
  border-color: rgb(51, 51, 51);
}
.p-dobroku_why__details .__summary {
  list-style: none;
  cursor: pointer;
  -webkit-transition: opacity 0.25s;
  transition: opacity 0.25s;
  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;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.p-dobroku_why__details .__summary:before, .p-dobroku_why__details .__summary:after {
  content: "";
  display: block;
  width: calc(50% - 7.8em);
  height: 24px;
  position: absolute;
  top: 100%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border-top: 1px solid #333;
  -webkit-transition: border-radius 0.25s;
  transition: border-radius 0.25s;
}
.p-dobroku_why__details .__summary:before {
  left: 0;
  border-radius: 0;
}
.p-dobroku_why__details .__summary:after {
  right: 0;
  border-radius: 0;
}
.p-dobroku_why__details .__summary .__summary__inner {
  font-size: 17.1px;
  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: 0 0.5em;
}
.p-dobroku_why__details .__summary .__summary__inner:after {
  content: "";
  display: block;
  width: 14px;
  height: auto;
  aspect-ratio: 13/10;
  background: url(../images/doburoku/icon-dobroku_why__details.svg) no-repeat center/contain;
  -webkit-transition: rotate 0.25s;
  transition: rotate 0.25s;
}
.p-dobroku_why__details[open] .__summary:before {
  border-radius: 12px 0 0 0;
}
.p-dobroku_why__details[open] .__summary:after {
  border-radius: 0 12px 0 0;
}
.p-dobroku_why__details[open] .__summary .__summary__inner:after {
  rotate: 180deg;
}
.p-dobroku_why__details .__content {
  overflow: hidden;
}
.p-dobroku_why__details .__content .__content__inner {
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.85;
  padding: 3.55em 8% 2.45em;
}
.p-dobroku_why__details .__content .__content__inner > p + p {
  margin-top: 1.89em;
}

/* .p-dobroku_voice */
.p-dobroku_voice {
  padding: 6.1em 0 6em;
  background: #fef3ee;
  margin-bottom: 7.3em;
}

.p-dobroku_voice__sub {
  font-weight: 700;
  font-size: 27.5px;
  line-height: 1.55;
  letter-spacing: 0.05em;
  padding: 0 8.2%;
}

.p-dobroku_voice__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1em 0;
  padding: 0 6.2%;
  margin-top: 3.4em;
}

.p-dobroku_voice__list__box {
  display: -ms-grid;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-dobroku_voice__list__box:nth-of-type(odd) {
  -ms-grid-columns: 100px auto 1fr;
  grid-template-columns: 100px auto 1fr;
      grid-template-areas: "icon balloon .";
}
.p-dobroku_voice__list__box:nth-of-type(odd) .__balloon {
  padding: 1em 2em 1.1em 3.2em;
  margin-left: 1.3em;
}
.p-dobroku_voice__list__box:nth-of-type(odd) .__balloon:after {
  top: 25%;
  left: -14px;
  rotate: -112deg;
}
.p-dobroku_voice__list__box:nth-of-type(even) {
  -ms-grid-columns: 1fr auto 100px;
  grid-template-columns: 1fr auto 100px;
      grid-template-areas: ". balloon icon";
}
.p-dobroku_voice__list__box:nth-of-type(even) .__balloon {
  padding: 1em 4em 1em 2.65em;
  margin-right: 4.7em;
}
.p-dobroku_voice__list__box:nth-of-type(even) .__balloon:after {
  top: 29%;
  right: -16px;
  rotate: 105deg;
}
.p-dobroku_voice__list__box .__balloon {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: balloon;
  background: #fff;
  border-radius: 10px;
  position: relative;
  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: 0.3em 0;
  width: 100%;
  max-width: 580px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.p-dobroku_voice__list__box .__balloon:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 9px 26px 9px;
  border-color: transparent transparent #fff transparent;
  position: absolute;
}
.p-dobroku_voice__list__box .__balloon .__balloon__sub {
  font-weight: 500;
  font-size: 18.3px;
}
.p-dobroku_voice__list__box .__balloon .__balloon__text {
  font-size: 14.9px;
  line-height: 1.6;
  padding-left: 0.3em;
}
.p-dobroku_voice__list__box .__icon {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: icon;
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: relative;
}
.p-dobroku_voice__list__box:nth-of-type(1) .__icon {
  bottom: -35px;
}
.p-dobroku_voice__list__box:nth-of-type(2) {
  margin-top: 3.1em;
}
.p-dobroku_voice__list__box:nth-of-type(2) .__balloon {
  max-width: 524px;
}
.p-dobroku_voice__list__box:nth-of-type(3) {
  margin-top: 2.6em;
}
.p-dobroku_voice__list__box:nth-of-type(3) .__balloon {
  max-width: 520px;
}

/* .p-dobroku_notice */
.p-dobroku_notice {
  padding: 5em 0 6.5em;
  background: rgba(255, 255, 255, 0.69);
}

.p-dobroku_notice__wrapper {
  padding: 0 8%;
}

.p-dobroku_notice__head {
  font-weight: 500;
  font-size: 27.5px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding-bottom: 0.2em;
  border-bottom: 1px solid #e24d4d;
  margin-bottom: 1.54em;
}

.p-dobroku_notice__sub {
  font-weight: 500;
  font-size: 18.3px;
}
.p-dobroku_notice__sub:not(:first-of-type) {
  margin-top: 4.15em;
}

.p-dobroku_notice__text {
  font-size: 16px;
  line-height: 1.44;
  margin-top: 1.15em;
}

.p-dobroku_notice__list {
  font-size: 16px;
  line-height: 1.7;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 42.8% 1fr;
  grid-template-columns: 42.8% 1fr;
  border-bottom: 1px solid #d8d8d8;
  margin-top: 0.15em;
}

.p-dobroku_notice__list__dt,
.p-dobroku_notice__list__dd {
  padding: 0.9em 0 1.05em;
}
.p-dobroku_notice__list__dt:not(:first-of-type),
.p-dobroku_notice__list__dd:not(:first-of-type) {
  border-top: 1px solid #d8d8d8;
}

.p-dobroku_notice__list__dt {
  font-weight: 500;
}

.p-dobroku_notice__list__dd {
  font-weight: 400;
}

.p-dobroku_notice__copy {
  font-size: 16px;
  display: block;
  text-align: right;
  margin-top: 1.3em;
}

/* .p-dobroku_recommend */
.p-dobroku_recommend {
  padding: 6.35em 0 3.4em;
  background: #e1f1f7;
}

.p-dobroku_recommend__wrapper {
  padding: 0 8.2%;
}

.p-dobroku_recommend__sub {
  font-weight: 500;
  font-size: 27.45px;
  line-height: 1.57;
  letter-spacing: 0.05em;
}
.p-dobroku_recommend__sub:after {
  content: "";
  display: block;
  height: 2px;
  width: 57px;
  background: #f1c21b;
  margin-top: 0.9em;
}

.p-dobroku_recommend__text {
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.99;
  margin-top: 1.5em;
}