@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700&display=swap");
html, body {
  height: 100%;
}

html {
  font-size: 62.5%;
  overflow-y: scroll;
}

@media screen and (max-width: 767px) {
  html {
    font-size: calc(100vw * 10 / 375);
  }
}
body, h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, th, td, img, form, figure {
  margin: 0;
  padding: 0;
  border: none;
  list-style-type: none;
  font-style: normal;
  font-weight: normal;
  font-family: "Noto Sans JP", sans-serif;
  text-align: left;
  color: #333;
  font-size: 2.4rem;
  line-height: calc(38/24);
  font-weight: 500;
}

div, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li, form, input, textarea, button, table, tr, th, td, article, aside, footer, header, hgroup, nav, section, a, span {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

img {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

main {
  position: relative;
}

@media screen and (max-width: 767px) {
  html {
    min-height: 100vh;
  }

  body, h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, th, td, img, form, figure {
    line-height: 1.5;
    min-width: 1%;
    position: relative;
    font-size: 4vw;
    max-width: 100%;
  }
}
/* img
--------------------------------------------------*/
figure {
  text-align: center;
  line-height: 0;
  margin: 0;
  padding: 0;
}

@media screen and (max-width: 767px) {
  figure {
    width: 100%;
    text-align: center;
  }

  img {
    display: block;
  }
}
/* link
--------------------------------------------------*/
a {
  color: inherit;
}
a:link, a:active, a:visited {
  text-decoration: none;
}
a.c-link {
  text-decoration: underline;
}

@media print, screen and (min-width: 768px) {
  a {
    transition: 0.3s;
  }
  a[href^="tel:"] {
    display: inline-block;
    pointer-events: none;
  }
  a:hover {
    opacity: 0.7;
  }

  a {
    outline: 1px solid transparent;
    outline: none;
  }
  a * {
    outline: 1px solid transparent;
    outline: none;
  }
  a img {
    transition: opacity 0.3s ease-out;
  }
}
/* txt/deco
--------------------------------------------------*/
.ta_c {
  text-align: center;
}

.fwb {
  font-weight: 700;
  letter-spacing: -0.01em;
}

.highlight {
  background: linear-gradient(transparent 55%, #f2e825 55%, #f2e825 96%, transparent 96%);
}

.udl {
  border-bottom: 1px solid #333;
  padding-bottom: 0;
}

.color_red {
  color: #e06262;
}

.color_red2 {
  color: #de4d5f;
}

.color_pink {
  color: #e25d6e;
}

.color_blue {
  color: #0872b1;
}

.color_blk {
  color: #121212;
}

.grad {
  background: linear-gradient(90deg, #0771b0 0%, #2295cb 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.serif {
  font-family: "Noto Serif JP", serif;
}

.gap {
  display: inline-block;
  margin-right: -0.3em;
}

/* pc/sp
--------------------------------------------------*/
.pc {
  display: none;
}

.sp {
  display: block;
}

@media print, screen and (min-width: 768px) {
  .pc {
    display: block;
  }

  .sp {
    display: none;
  }
}
/* flex
--------------------------------------------------*/
.flex {
  display: flex;
  display: -webkit-flex;
  display: -ms-flex;
}
.flex.-reverse {
  flex-direction: row-reverse;
}

/* clearfix
--------------------------------------------------*/
.cf {
  display: inline-block;
}
.cf:after {
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}

* html .cf {
  height: 1%;
}

.cf {
  display: block;
}

.clear {
  clear: both;
}

/* form
--------------------------------------------------*/
input, textarea, select, .select {
  font-size: 16px !important;
}

/* header */
.l-header {
  position: relative;
  background: #f6f6f6;
}
@media screen and (min-width: 768px) {
  .l-header::before {
    position: absolute;
    background: url("../img/bg_fv_pc.png") no-repeat center top/contain;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-blend-mode: multiply;
    opacity: 0.1;
    z-index: 1;
  }
}
.l-header__fv {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  max-width: 1152px;
  max-height: 626px;
  margin: 0 auto;
  line-height: 0;
}
.l-header__fv + .p-ctabtn {
  z-index: 1;
}
@media screen and (max-width: 1152px) {
  .l-header__fv + .p-ctabtn {
    margin-top: -18px;
  }
}
@media screen and (max-width: 767px) {
  .l-header__fv {
    max-width: inherit;
    max-height: inherit;
  }
  .l-header__fv + .p-ctabtn {
    margin-top: 0;
  }
}

/* ttl */
.c-ttl, .c-subttl {
  text-align: center;
  font-weight: 700;
  display: block;
}

.c-ttl-en {
  display: block;
  line-height: 1;
  text-align: center;
  margin: 0 auto 10px;
}
.c-ttl-en img {
  margin: auto;
}

@media screen and (max-width: 767px) {
  .c-ttl-en {
    margin-bottom: 0;
    width: 70%;
  }
}
.c-ttl-grad {
  background: linear-gradient(90deg, #0771b0 0%, #2295cb 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  letter-spacing: -.06em;
  line-height: 1.5;
  text-align: center;
  display: block;
}

.c-ttlwrap {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

/* obi */
.c-obi {
  position: relative;
  z-index: 10;
  line-height: 0;
  height: 13rem;
  background-image: url("../img/img_obi_pc.jpg");
  background-repeat: repeat-x;
  background-position: left center;
  background-size: auto 100%;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .c-obi {
    height: 24.8vw;
    background-position: left center;
  }
}
.c-catch {
  position: relative;
  background: #f7f7f7;
}
@media screen and (max-width: 767px) {
  .c-catch {
    background: #fafafa;
  }
  .c-catch::before {
    background: url("../img/bg_catch_sp.png") no-repeat center top/cover !important;
  }
}
.c-catch.catch01 {
  padding: 55px 0 0;
  max-height: 698px;
}
.c-catch.catch01::before {
  background: url("../img/bg_catch01.png") no-repeat center top/contain;
}
@media screen and (max-width: 942px) {
  .c-catch.catch01 {
    padding-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .c-catch.catch01 {
    padding: 5% 0 0;
    max-height: inherit;
  }
}
.c-catch.catch02 {
  padding: 50px 0 0;
  max-height: 477px;
}
.c-catch.catch02::before {
  background: url("../img/bg_catch02.png") no-repeat center top/contain;
}
@media screen and (max-width: 942px) {
  .c-catch.catch02 {
    padding-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .c-catch.catch02 {
    padding: 5% 0 0;
    max-height: inherit;
  }
}
.c-catch::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background-blend-mode: multiply;
  z-index: 1;
}
.c-catch__txt {
  position: relative;
  z-index: 2;
  font-size: 4rem;
  letter-spacing: .075em;
  line-height: calc(56.49/40.49);
  color: #222021;
  width: 100%;
  max-width: 942px;
  margin: 0 auto 50px;
  padding-left: 185px;
}
.c-catch__txt span {
  position: relative;
  display: inline-block;
  left: -0.5em;
}
@media screen and (max-width: 942px) {
  .c-catch__txt {
    padding-left: clamp(14rem, calc( 0.76rem + 17.2vw ), 18.5rem);
    font-size: clamp(2.6rem, calc( -3.58rem + 8vw ), 4rem);
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .c-catch__txt {
    max-width: inherit;
    font-size: 4.8vw;
    text-align: center;
    padding: 0;
    margin-bottom: 5%;
  }
  .c-catch__txt span {
    left: auto;
  }
}
.c-catch__img {
  position: relative;
  line-height: 1;
  z-index: 3;
}

.c-btn {
  line-height: 1;
  text-align: center;
}
.c-btn a {
  position: relative;
  display: block;
  margin: 0 auto;
}

/* cta */
.p-ctabtn {
  position: relative;
  background: linear-gradient(to right, #1c7dab 0%, #208abb 76%, #2597cc 100%);
  height: 13rem;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-ctabtn {
    height: auto;
    padding: 2.5% 0;
  }
  .p-ctabtn .c-btn {
    width: 96%;
  }
}

.p-cta {
  text-align: center;
}
.p-cta__img {
  margin: 0 auto 30px;
}
@media screen and (max-width: 767px) {
  .p-cta__img {
    width: 90%;
    margin-bottom: 3%;
  }
}

/* layout */
.l-wrapper {
  overflow: hidden;
}

.l-section {
  position: relative;
}

.l-inner {
  position: relative;
  width: 100%;
  max-width: 75rem;
  margin: auto;
}

@media screen and (max-width: 767px) {
  .l-inner {
    padding: 0 3%;
  }
}
.l-contents {
  position: relative;
  width: 100%;
  margin: 0 auto;
  box-shadow: 0 0 4px 2px rgba(51, 51, 51, 0.2);
  background-color: #fff;
}
.l-contents.light {
  box-shadow: 0 0 6px 4px rgba(213, 213, 213, 0.3);
}

@media print, screen and (min-width: 768px) {
  .l-contents {
    max-width: 72.7rem;
  }
  .l-contents.light {
    box-shadow: 0 0 4px 2px rgba(213, 213, 213, 0.3);
  }
}
/* sec01 */
.p-sec01 {
  background: #f6f6f6;
  padding: 60px 0 56px;
}
.p-sec01__movie {
  text-align: center;
  margin: 0 auto 50px;
}
.p-sec01__movie iframe {
  border: 0;
  width: 100%;
  height: 100%;
  max-width: 560px;
  aspect-ratio: 560/315;
  margin: 0 auto;
}
.p-sec01__ttl {
  position: relative;
  color: #333132;
  font-size: 5.9rem;
  letter-spacing: -.075em;
  width: calc(100% + 80px);
  margin: 0 -40px 56px;
  left: -.25em;
}
.p-sec01 .l-inner {
  padding: 0 10px;
}
.p-sec01 .l-inner > p {
  font-size: 2.2rem;
  line-height: calc(36/22);
  letter-spacing: normal;
}
.p-sec01 .l-inner > p + p {
  margin-top: 35px;
}
.p-sec01 .img_box {
  margin: 46px auto 60px;
  text-align: center;
}
.p-sec01 .img {
  position: relative;
  display: inline-block;
}
.p-sec01 .img img {
  position: relative;
  display: block;
  z-index: 2;
}
.p-sec01 .img::before {
  position: absolute;
  content: "";
  background: #212327;
  width: 100%;
  height: 100%;
  left: 15px;
  top: 15px;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .p-sec01 {
    padding: 8% 0;
  }
  .p-sec01__movie {
    margin: 0 auto 6.5%;
  }
  .p-sec01__ttl {
    font-size: 6.8vw;
    width: 100%;
    margin: 0 auto 8%;
    left: inherit;
  }
  .p-sec01 .l-inner {
    padding: 0 3%;
  }
  .p-sec01 .l-inner > p {
    font-size: 4vw;
    line-height: 1.5;
  }
  .p-sec01 .l-inner > p + p {
    margin-top: 5%;
  }
  .p-sec01 .img_box {
    margin: 8% auto;
  }
  .p-sec01 .img {
    width: 80%;
  }
  .p-sec01 .img::before {
    left: 2.667vw;
    top: 2.667vw;
  }
}
/* sec02 */
.p-sec02 {
  background: url("../img/bg_sec02.jpg") no-repeat center top 272px/cover;
  padding: 32px 0 50px;
  border-top: 12px solid;
  border-bottom: 12px solid;
  border-image-source: linear-gradient(to right, #67d4cf 0%, #6fd4d5 13%, #88d6e4 36%, #c4dae5 66%, #d3dcc9 74%, #f2e271 92%, #f8e35f 96%, #fbe456 100%);
  border-image-slice: 1;
}
.p-sec02::before {
  position: absolute;
  content: "";
  background: linear-gradient(to right, #1c7dab 0%, #208abb 76%, #2597cc 100%);
  width: 100%;
  height: 272px;
  top: 0;
  left: 0;
}
.p-sec02 .l-contents {
  padding: 52px 20px 0;
}
.p-sec02 .l-contents p + p {
  margin-top: 35px;
}
.p-sec02 .l-contents p.nrw {
  letter-spacing: -.02em;
}
.p-sec02__ttlwrap {
  position: relative;
  border-bottom: 1px solid #0771b0;
  margin-bottom: 40px;
}
.p-sec02__ttl {
  position: relative;
}
.p-sec02__ttl:not(.ttl01)::before {
  position: absolute;
  content: "";
  background: #0771b0;
  width: calc(100% - 16px);
  height: 1px;
  left: 50%;
  transform: translateX(-50%);
  bottom: -25px;
}
.p-sec02__ttl .ttltxt {
  display: block;
  letter-spacing: -.025em;
}
.p-sec02__ttl.ttl01 {
  font-size: 6.55rem;
  white-space: nowrap;
  margin: 0 auto;
}
.p-sec02__ttl.ttl02 {
  font-size: 4.8rem;
  line-height: calc(60/48);
  margin: 80px auto 75px;
}
.p-sec02__ttl.ttl03 {
  font-size: 6rem;
  line-height: calc(72/60);
  margin: 110px auto 75px;
}
.p-sec02__ttl.ttl04 {
  font-size: 4.8rem;
  line-height: calc(60/48);
  margin: 110px auto 75px;
}
.p-sec02__ttl.ttl05 {
  font-size: 6.2rem;
  line-height: calc(78/62.6);
  margin: 50px auto 75px;
}
.p-sec02__maintxt {
  font-size: 3.1rem;
  color: #e06262;
  font-weight: 700;
  margin-bottom: 40px;
}
.p-sec02__img.img01 {
  margin: 0 35px 0 0;
}
.p-sec02__img.img02 {
  margin: 24px auto 30px;
}
.p-sec02__img.img03 {
  margin: 0 5px 0 18px;
}
.p-sec02__img.img04 {
  margin: 38px auto 60px;
  position: relative;
  display: inline-block;
}
.p-sec02__img.img04 img {
  position: relative;
  display: block;
  z-index: 2;
}
.p-sec02__img.img04::before {
  position: absolute;
  content: "";
  background: #c5dae4;
  width: 100%;
  height: 100%;
  left: 14px;
  top: 14px;
  z-index: 1;
}
.p-sec02__img.img05 {
  margin: 88px auto 80px;
}
.p-sec02__img.img06 {
  margin: 76px auto 56px;
}
.p-sec02__img.img07 {
  margin: 60px auto 88px;
}
.p-sec02__img.img08 {
  margin: 20px auto 0;
}
.p-sec02__txtbox.box01 {
  margin-bottom: 40px;
}
.p-sec02__txt {
  flex: 1;
}

@media screen and (max-width: 767px) {
  .p-sec02 {
    background-position: center top;
    padding: 8% 0;
    border-top-width: 6px;
    border-bottom-width: 6px;
  }
  .p-sec02::before {
    height: 160px;
  }
  .p-sec02 .l-contents {
    padding: 6.5% 3% 0%;
  }
  .p-sec02 .l-contents p + p {
    margin-top: 5%;
  }
  .p-sec02__ttlwrap {
    margin-bottom: 8%;
    padding-bottom: 2.4%;
  }
  .p-sec02__ttl:not(.ttl01)::before {
    width: 100%;
    bottom: -10px;
  }
  .p-sec02__ttl.ttl01 {
    font-size: 8vw;
    white-space: normal;
    left: .2em;
  }
  .p-sec02__ttl.ttl02 {
    font-size: 6vw;
    line-height: 1.25;
    margin: 10% auto 8%;
  }
  .p-sec02__ttl.ttl03, .p-sec02__ttl.ttl04, .p-sec02__ttl.ttl05 {
    font-size: 6.8vw;
    line-height: 1.25;
    margin: 10% auto 8%;
  }
  .p-sec02__maintxt {
    font-size: 4.8vw;
    margin-bottom: 5%;
  }
  .p-sec02__img.img01 {
    width: 60%;
    margin: 0 auto 5%;
  }
  .p-sec02__img.img02 {
    width: 90%;
    margin: 5% auto;
  }
  .p-sec02__img.img03 {
    width: 60%;
    margin: 5% auto 0;
  }
  .p-sec02__img.img04 {
    width: 80%;
    margin: 6.5% auto;
  }
  .p-sec02__img.img04::before {
    left: 1.867vw;
    top: 1.867vw;
  }
  .p-sec02__img.img05, .p-sec02__img.img06, .p-sec02__img.img07 {
    margin: 8% auto;
  }
  .p-sec02__img.img08 {
    width: 90%;
    margin: 8% auto 0;
  }
  .p-sec02__txtbox {
    flex-direction: column;
    align-items: center;
  }
  .p-sec02__txtbox.box01 {
    margin-bottom: 5%;
  }
}
/* sec03 */
.p-sec03 {
  background: url("../img/bg_check.png") repeat;
  padding: 38px 0 124px;
}
.p-sec03__voice {
  width: 100%;
  max-width: 718px;
  margin: 0 auto;
  border: 5px solid #8bd6e4;
  background: #fff;
  padding: 32px 13px 42px;
}
.p-sec03__voice-head {
  margin-bottom: 32px;
}
.p-sec03__voice-ttl {
  color: #e25d6e;
  font-family: "Noto Serif JP", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: calc(60/48);
  text-align: center;
  border-bottom: 1px solid #111;
  padding-bottom: 22px;
  margin-bottom: 26px;
}
.p-sec03__voice-name {
  color: #111;
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
}
.p-sec03__voice-body {
  padding: 0 12px;
}
.p-sec03__voice-body p:not([class]) + p:not([class]) {
  margin-top: 35px;
}
.p-sec03__voice-txt {
  flex: 1;
}
.p-sec03__voice-thumb {
  padding-top: 8px;
  padding-left: 45px;
}
.p-sec03__voice + .p-sec03__voice {
  margin-top: 52px;
}
.p-sec03__voice.voice01 .p-sec03__voice-txtbox {
  margin-bottom: 32px;
}
.p-sec03__voice.voice02 .p-sec03__voice-txtbox {
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .p-sec03 {
    padding: 8% 0;
    border-bottom-width: 8px;
  }
  .p-sec03__ttl {
    margin: 0 auto 8%;
    width: 90%;
  }
  .p-sec03__voice {
    max-width: inherit;
    border-width: 3px;
    padding: 6.5% 3%;
  }
  .p-sec03__voice-head {
    margin-bottom: 5%;
  }
  .p-sec03__voice-ttl {
    font-size: 6.4vw;
    padding-bottom: 3.5%;
    margin-bottom: 3%;
  }
  .p-sec03__voice-name {
    font-size: 4.5vw;
  }
  .p-sec03__voice-body {
    padding: 0;
  }
  .p-sec03__voice-body p:not([class]) + p:not([class]) {
    margin-top: 5%;
  }
  .p-sec03__voice-thumb {
    padding: 0 0 5%;
    width: 50%;
  }
  .p-sec03__voice + .p-sec03__voice {
    margin-top: 5%;
  }
  .p-sec03__voice-txtbox {
    flex-direction: column !important;
    align-items: center;
    margin-bottom: 5% !important;
  }
}
/* sec04 */
.p-sec04 {
  background: linear-gradient(to right, #1d8bbe 0%, #1e8ec2 27%, #2299cf 74%, #25a4de 90%, #27a8e3 100%);
  padding: 22px 0 100px;
  border-bottom: 12px solid;
  border-image-source: linear-gradient(to right, #67d4cf 0%, #6fd4d5 13%, #88d6e4 36%, #c4dae5 66%, #d3dcc9 74%, #f2e271 92%, #f8e35f 96%, #fbe456 100%);
  border-image-slice: 1;
  z-index: 2;
}
@media screen and (max-width: 942px) {
  .p-sec04 {
    margin-top: -14px;
  }
}
.p-sec04::before, .p-sec04::after {
  position: absolute;
  content: "";
  background-color: rgba(255, 255, 255, 0.1);
  background-blend-mode: multiply;
  height: 30px;
  width: 120%;
  left: 50%;
  transform: translateX(-50%);
  filter: blur(4px);
}
.p-sec04::before {
  top: 0;
}
.p-sec04::after {
  bottom: 0;
}
.p-sec04 .l-contents {
  padding: 30px 18px 78px;
}
.p-sec04 .l-contents p + p {
  margin-top: 38px;
}
.p-sec04__detail-head {
  margin-bottom: 40px;
}
.p-sec04__detail-num {
  margin: 0 auto 20px;
  text-align: center;
}
.p-sec04__detail-ttl {
  font-size: 5.23rem;
  line-height: calc(63.15/52);
  margin: 0 auto 25px;
}
.p-sec04__detail-ttl .ttltxt {
  display: block;
}
.p-sec04__detail + .p-sec04__detail {
  margin-top: 80px;
}
.p-sec04__detail.detail01, .p-sec04__detail.detail03, .p-sec04__detail.detail06 {
  margin-top: 50px;
}
.p-sec04__box {
  margin: 0 auto;
  background: url("../img/bg_sec04_cont.png") no-repeat center top/100% auto;
  padding: 44px 24px;
  min-height: 369px;
  margin-bottom: 30px;
}
.p-sec04__box.-high {
  background-image: url("../img/bg_sec04_cont_l.png");
  min-height: 407px;
}
.p-sec04__box-ttl {
  position: relative;
  font-size: 3.2rem;
  font-family: "Noto Serif JP", serif;
  color: #0f0f0f;
  font-weight: 700;
  letter-spacing: -.025em;
  line-height: 1.5;
  text-align: center;
  padding-bottom: 16px;
  margin-bottom: 40px;
}
.p-sec04__box-ttl::before {
  position: absolute;
  content: "";
  background: #0f0f0f;
  width: calc(100% - 40px);
  height: 1px;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
.p-sec04__box-ttl.-low {
  margin-bottom: 16px;
}
.p-sec04__box-ttl.-sm {
  font-size: 3.1rem;
  letter-spacing: -.05em;
}
.p-sec04__box-list {
  width: 100%;
}
.p-sec04__box-list li {
  position: relative;
  font-size: 3rem;
  line-height: 1.35;
  font-weight: 500;
  color: #0f0f0f;
  padding-left: 1.9em;
}
.p-sec04__box-list li + li {
  margin-top: .6em;
}
.p-sec04__box-list li.-wide50 {
  letter-spacing: .05em;
}
.p-sec04__box-list li.-nrw25 {
  letter-spacing: -.025em;
}
.p-sec04__box-list li.-nrw30 {
  letter-spacing: -.03em;
}
.p-sec04__box-list li.-nrw50 {
  letter-spacing: -.05em;
}
.p-sec04__box-list li.-nrw80 {
  letter-spacing: -.08em;
}
.p-sec04__box-list li::before {
  position: absolute;
  content: "";
  background: url("../img/icn_check_square.png") no-repeat center center/contain;
  width: 29px;
  height: 29px;
  left: .5em;
  top: .25em;
}
.p-sec04__benefit {
  margin: 70px auto 120px;
}
.p-sec04__benefit-ttl {
  margin: 0 auto 80px;
  line-height: 1;
  background: url("../img/bg_ribonn.png") no-repeat center top/contain;
  width: 668px;
  height: 119px;
  color: #fff;
  font-size: 4.3rem;
  font-weight: 700;
  letter-spacing: .075em;
  text-align: center;
  line-height: 1.5;
  padding-top: 10px;
}
.p-sec04__benefit-txtbox {
  padding: 0 20px 50px 30px;
}
.p-sec04__benefit-txt {
  flex: 1;
  margin-top: -6px;
}
.p-sec04__benefit-txt p {
  line-height: calc(36/24);
}
.p-sec04__benefit-img {
  margin-right: 45px;
}
.p-sec04__benefit-checklist {
  margin-bottom: 45px;
  padding: 0 0 0 25px;
}
.p-sec04__benefit-checklist li {
  position: relative;
  font-size: 2.4rem;
  color: #222021;
  letter-spacing: .1em;
  padding-left: 1.5em;
}
.p-sec04__benefit-checklist li + li {
  margin-top: .5em;
}
.p-sec04__benefit-checklist li::before {
  position: absolute;
  content: "";
  background: url("../img/icn_check_blue.svg") no-repeat center center/contain;
  width: 22px;
  height: 18px;
  left: 0;
  top: .45em;
}
.p-sec04__benefit-checklist + p {
  padding-left: 15px;
}

@media screen and (max-width: 767px) {
  .p-sec04 {
    padding: 6.5% 0;
    border-bottom-width: 6px;
    margin-top: 0;
  }
  .p-sec04 .l-contents {
    padding: 6.5% 3%;
  }
  .p-sec04 .l-contents p + p {
    margin-top: 5%;
  }
  .p-sec04__detail-head {
    margin-bottom: 5%;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .p-sec04__detail-num {
    margin: 0 auto 3%;
  }
  .p-sec04__detail-num img {
    width: 12.8vw;
  }
  .p-sec04__detail-ttl {
    font-size: 6.8vw;
    line-height: 1.25;
    margin: 0 auto;
  }
  .p-sec04__detail + .p-sec04__detail {
    margin-top: 10% !important;
  }
  .p-sec04__detail.detail01 {
    margin-top: 10%;
  }
  .p-sec04__box {
    background-image: url("../img/bg_sec04_cont_l.png");
    background-size: 100% 100%;
    padding: 8% 3%;
    min-height: inherit;
    margin-bottom: 5%;
  }
  .p-sec04__box.-high {
    min-height: inherit;
  }
  .p-sec04__box-ttl {
    font-size: 4.8vw !important;
    padding-bottom: 3%;
    margin-bottom: 5% !important;
  }
  .p-sec04__box-ttl::before {
    width: calc(100% - 3vw);
  }
  .p-sec04__box-list {
    padding: 0 3%;
  }
  .p-sec04__box-list li {
    font-size: 4.2vw;
    padding-left: 1.9em;
    letter-spacing: normal !important;
  }
  .p-sec04__box-list li + li {
    margin-top: .6em;
  }
  .p-sec04__box-list li::before {
    width: 4.8vw;
    height: 4.8vw;
    left: 0;
    top: .15em;
  }
  .p-sec04__benefit {
    margin: 12% auto;
  }
  .p-sec04__benefit-ttl {
    margin: 0 auto 5%;
    width: 100%;
    height: auto;
    aspect-ratio: 668/119;
    font-size: 6vw;
    letter-spacing: .05em;
    padding-top: .25em;
  }
  .p-sec04__benefit-txtbox {
    flex-direction: column;
    align-items: center;
    padding: 0;
  }
  .p-sec04__benefit-txt {
    margin-top: 0;
  }
  .p-sec04__benefit-txt p {
    line-height: 1.5;
  }
  .p-sec04__benefit-img {
    margin: 0 auto 5%;
    width: 50%;
  }
  .p-sec04__benefit-checklist {
    margin: 8% auto;
    padding: 0;
  }
  .p-sec04__benefit-checklist li {
    font-size: 4.5vw;
    padding-left: 1.5em;
  }
  .p-sec04__benefit-checklist li::before {
    width: 4vw;
    height: 3.2vw;
    top: .4em;
  }
  .p-sec04__benefit-checklist + p {
    padding-left: 0;
  }
}
/* sec05 */
.p-sec05 {
  background: url("../img/bg_check.png") repeat;
  padding: 100px 0 100px;
  border-bottom: 12px solid;
  border-image-source: linear-gradient(to right, #67d4cf 0%, #6fd4d5 13%, #88d6e4 36%, #c4dae5 66%, #d3dcc9 74%, #f2e271 92%, #f8e35f 96%, #fbe456 100%);
  border-image-slice: 1;
}
.p-sec05 .l-inner {
  padding: 0 18px;
}
.p-sec05 .l-inner p:not([class]) + p:not([class]) {
  margin-top: 38px;
}
.p-sec05__ttl.ttl01 {
  font-size: 9rem;
  margin: 0 auto;
}
.p-sec05__ttl.ttl02 {
  font-size: 9rem;
  margin: 0 auto;
}
.p-sec05__img.img01 {
  margin: 60px auto 30px;
}
.p-sec05__img.img02 {
  margin: 60px auto 60px;
}
.p-sec05__pos {
  font-size: 3rem;
  line-height: 1.35;
  font-weight: 500;
  color: #222021;
  text-align: center;
}
.p-sec05__name {
  font-weight: 500;
  color: #222021;
  line-height: 1.35;
  justify-content: center;
  align-items: center;
  gap: 0 22px;
}
.p-sec05__name .txt01 {
  font-size: 3rem;
}
.p-sec05__name .txt02 {
  font-size: 5.4rem;
}
.p-sec05__txtbox {
  margin: 36px auto 120px;
}
.p-sec05__txtbox p {
  font-size: 2.2rem;
  line-height: calc(36/22);
}
.p-sec05__voice-inner {
  width: 100%;
  max-width: 718px;
  margin: 0 auto;
  border: 5px solid #8bd6e4;
  background: #fff;
  padding: 28px 13px 60px;
}
.p-sec05__voice-head {
  margin-bottom: 40px;
}
.p-sec05__voice-ttl {
  color: #e25d6e;
  font-family: "Noto Serif JP", serif;
  font-size: 4.6rem;
  font-weight: 700;
  line-height: calc(60/48);
  text-align: center;
  border-bottom: 1px solid #111;
  padding-bottom: 26px;
  margin-bottom: 14px;
}
.p-sec05__voice-name {
  color: #111;
  font-size: 2.8rem;
  font-weight: 500;
  line-height: calc(48/28);
  text-align: center;
}
.p-sec05__voice-body {
  padding: 0 8px;
}
.p-sec05__voice-body p:not([class]) + p:not([class]) {
  margin-top: 38px;
}
.p-sec05__voice-body .dot {
  color: #1e94cb;
  margin-right: 0.5em;
}
.p-sec05__voice-txt {
  flex: 1;
}
.p-sec05__voice-thumb {
  padding-right: 20px;
}
.p-sec05__voice-txtbox {
  margin-bottom: 16px;
}

@media screen and (max-width: 767px) {
  .p-sec05 {
    padding: 8% 0;
    border-bottom-width: 6px;
  }
  .p-sec05 .l-inner {
    padding: 0 3%;
  }
  .p-sec05 .l-inner p:not([class]) + p:not([class]) {
    margin-top: 5%;
  }
  .p-sec05__ttl.ttl01 {
    font-size: 10vw;
  }
  .p-sec05__ttl.ttl02 {
    font-size: 10vw;
  }
  .p-sec05__img.img01 {
    width: 80%;
    margin: 5% auto;
  }
  .p-sec05__img.img02 {
    width: 80%;
    margin: 5% auto;
  }
  .p-sec05__pos {
    font-size: 4.8vw;
  }
  .p-sec05__name {
    gap: 0 3vw;
  }
  .p-sec05__name .txt01 {
    font-size: 4.8vw;
  }
  .p-sec05__name .txt02 {
    font-size: 6.8vw;
    padding-bottom: .1em;
  }
  .p-sec05__txtbox {
    margin: 5% auto 10%;
  }
  .p-sec05__txtbox p {
    font-size: 4vw;
    line-height: 1.5;
  }
  .p-sec05__voice {
    margin-top: 3.5%;
  }
  .p-sec05__voice-inner {
    border-width: 3px;
    padding: 6.5% 3%;
  }
  .p-sec05__voice-head {
    margin-bottom: 5%;
  }
  .p-sec05__voice-ttl {
    font-size: 6.4vw;
    padding-bottom: 3.5%;
    margin-bottom: 3%;
  }
  .p-sec05__voice-name {
    font-size: 4.5vw;
    line-height: 1.5;
  }
  .p-sec05__voice-body {
    padding: 0;
  }
  .p-sec05__voice-body p:not([class]) + p:not([class]) {
    margin-top: 5%;
  }
  .p-sec05__voice-thumb {
    padding-right: 0;
    margin-bottom: 3.5%;
    width: 60%;
  }
  .p-sec05__voice-txtbox {
    margin-bottom: 5%;
    flex-direction: column;
    align-items: center;
  }
}
/* sec06 */
.p-sec06 {
  background: linear-gradient(to right, #1d8bbe 0%, #1e8ec2 27%, #2299cf 74%, #25a4de 90%, #27a8e3 100%);
  padding: 22px 0 90px;
  z-index: 2;
}
@media screen and (max-width: 942px) {
  .p-sec06 {
    margin-top: -14px;
  }
}
.p-sec06::before, .p-sec06::after {
  position: absolute;
  content: "";
  background-color: rgba(255, 255, 255, 0.1);
  background-blend-mode: multiply;
  height: 30px;
  width: 120%;
  left: 50%;
  transform: translateX(-50%);
  filter: blur(4px);
}
.p-sec06::before {
  top: 0;
}
.p-sec06::after {
  bottom: 0;
}
.p-sec06 .l-contents {
  padding: 42px 15px 135px;
  overflow: hidden;
}
.p-sec06 .l-contents p:not([class]) + p:not([class]) {
  margin-top: 38px;
}
.p-sec06__ttlwrap {
  position: relative;
}
.p-sec06__ttlwrap.ttlwrap01 {
  padding-bottom: 14px;
  margin-bottom: 35px;
}
.p-sec06__ttlwrap.ttlwrap01::before {
  position: absolute;
  content: "";
  background: #0771b0;
  width: calc(100% - 20px);
  height: 1px;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
.p-sec06__ttlwrap.ttlwrap03 {
  margin-top: 160px;
  margin-bottom: 60px;
}
.p-sec06__ttl {
  position: relative;
}
.p-sec06__ttl.ttl01 {
  font-size: 5.7rem;
  width: 100%;
  letter-spacing: -.075em;
}
.p-sec06__ttl.ttl02 {
  font-size: 7.3rem;
  color: #fff;
  letter-spacing: -.06em;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  background: #1d8cbf;
  width: calc(100% + 30px);
  margin-left: -15px;
  margin-right: -15px;
  height: 153px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-top: 6px solid #f2e825;
  margin-top: 77px;
  margin-bottom: 43px;
}
.p-sec06__ttl.ttl03 {
  font-size: 9rem;
  margin-top: -20px;
}
.p-sec06__txtbox {
  padding: 0 10px;
}
.p-sec06__tbl {
  border: 1px solid #b8b8b8;
}
.p-sec06__tbl dt {
  background: #5ab8e3;
  color: #fff;
  font-size: 3rem;
  line-height: 1.35;
  font-weight: 500;
  text-align: center;
  padding: 0.1em 0.7em;
}
.p-sec06__tbl dd {
  background: #fff;
  padding: 0.7em 0.7em;
  line-height: calc(42/24);
}
.p-sec06__form {
  position: relative;
  width: 100%;
  max-width: 842px;
  margin: 46px auto 50px;
  text-align: center;
}
.p-sec06__form iframe {
  border: none;
  border-style: inherit;
  width: 100%;
  max-width: 655px;
  height: 523px;
  background: #dfe4f0;
}
.p-sec06__qabox {
  margin-bottom: 110px;
}
.p-sec06__qabox dl {
  margin-bottom: 38px;
}
.p-sec06__qabox dt {
  font-weight: 700;
}
.p-sec06__qabox dt .icn_q {
  color: #2791c4;
}
.p-sec06__qabox dd {
  margin-top: 30px;
}
.p-sec06__qabox dd + dt {
  margin-top: 80px;
}

@media screen and (max-width: 767px) {
  .p-sec06 {
    padding: 8% 0;
    margin-top: 0;
  }
  .p-sec06 .l-contents {
    padding: 6.5% 3%;
  }
  .p-sec06 .l-contents p:not([class]) + p:not([class]) {
    margin-top: 5%;
  }
  .p-sec06__ttlwrap.ttlwrap01 {
    padding-bottom: 3.5%;
    margin-bottom: 5%;
  }
  .p-sec06__ttlwrap.ttlwrap01::before {
    width: 100%;
  }
  .p-sec06__ttlwrap.ttlwrap03 {
    margin-top: 15%;
    margin-bottom: 8%;
  }
  .p-sec06__ttl {
    line-height: 1.25;
  }
  .p-sec06__ttl.ttl01 {
    font-size: 8vw;
    margin-top: 1.5%;
  }
  .p-sec06__ttl.ttl02 {
    font-size: 8vw;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    height: auto;
    padding: 3% 0;
    border-top-width: 3px;
    margin-top: 8%;
    margin-bottom: 5%;
  }
  .p-sec06__ttl.ttl03 {
    font-size: 8vw;
    margin-top: .1em;
  }
  .p-sec06__qabox {
    margin-bottom: 10%;
  }
  .p-sec06__qabox dl {
    margin-bottom: 8%;
  }
  .p-sec06__qabox dd {
    margin-top: 3.5%;
  }
  .p-sec06__qabox dd + dt {
    margin-top: 8%;
  }
  .p-sec06__txtbox {
    padding: 0;
  }
  .p-sec06__tbl dt {
    font-size: 4.8vw;
    padding: 0.5em 0.7em;
  }
  .p-sec06__tbl dd {
    font-size: 4vw;
  }
  .p-sec06__form {
    margin: 10% auto;
  }
  .p-sec06__form iframe {
    height: 350vw;
    max-width: inherit;
  }
}
/* footer */
.l-footer {
  text-align: center;
  padding-top: 90px;
}
.l-footer * {
  letter-spacing: .08em;
  color: #fff;
}
.l-footer__link {
  display: flex;
  justify-content: center;
  align-items: center;
}
.l-footer__link li {
  position: relative;
  padding: 0 12px;
}
.l-footer__link li:nth-child(n + 2)::before {
  position: absolute;
  content: "";
  width: 2px;
  height: calc(100% - 12px);
  background: #fff;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
.l-footer__copy {
  margin: 22px auto 0;
}

@media screen and (max-width: 767px) {
  .l-footer {
    padding-top: 8%;
  }
  .l-footer * {
    letter-spacing: .08em;
  }
  .l-footer__link li {
    font-size: 3.6vw;
    padding: 0 1em;
  }
  .l-footer__link li:nth-child(n + 2)::before {
    height: calc(100% - 0.5em);
  }
  .l-footer__copy {
    margin: 5% auto 0;
    font-size: 3.2vw;
  }
}
/* 外部css調整 */
.content_title h2 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem !important;
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
}

.content_form .input_unit {
  border-bottom: 1px solid #bfbfbf;
  margin-top: 0 !important;
  width: 100% !important;
}
.content_form .input_unit:first-of-type {
  border-top: 1px solid #bfbfbf;
}

.content_form .input_unit .my_left.my_column {
  background: #eef5fb !important;
}

.content_title label,
.content_box label,
.content_confirm label,
.content_form label {
  font-size: 1.6rem;
}

form.myForm input[type="text"],
form.myForm input[type="password"] {
  font-size: 1.6rem;
}

form.myForm div.submit {
  margin-top: 5rem !important;
  transition: .3s ease;
}
form.myForm div.submit input[type="submit"] {
  background: #231815;
  border-radius: 5px;
  padding: 0.8rem 4rem;
  color: #fff;
  font-size: 2.8rem;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif !important;
  height: 6rem;
  cursor: pointer;
}
@media print and (any-hover: hover), screen and (any-hover: hover) and (min-width: 768px) {
  form.myForm div.submit:hover {
    opacity: 0.7;
  }
}

form.myForm input[type="text"] {
  height: 4rem;
  background: #ffdddd;
  width: calc(100% -  2.8px) !important;
}

form.myForm .required .my_column.my_left label:first-child:after {
  padding-top: 0 !important;
  padding-bottom: 0.4rem !important;
  width: 4rem !important;
  height: 1.8rem !important;
  font-size: 1.4rem !important;
}

::-webkit-full-page-media, :future, :root form.myForm .required .my_column.my_left label:first-child:after {
  padding-bottom: 0.5rem !important;
}

form.myForm textarea {
  width: 100% !important;
}

@media screen and (max-width: 800px) {
  .content_title h2 {
    font-size: 4.8vw !important;
  }

  .content_form {
    max-width: inherit;
    width: 100%;
    padding-bottom: 3%;
  }

  .content_form .input_unit .my_left.my_column {
    width: 100% !important;
    padding: 3% !important;
  }

  .content_title .input_unit,
  .content_box .input_unit
  .my_right.my_column,
  .content_form .input_unit
  .my_right.my_column,
  .content_confirm .input_unit .my_right.my_column {
    width: 100% !important;
  }

  .content_title label,
  .content_box label,
  .content_confirm label,
  .content_form label {
    font-size: 16px;
  }

  form.myForm input[type="text"],
  form.myForm input[type="password"] {
    font-size: 16px;
  }

  form.myForm div.submit {
    margin-top: 8% !important;
  }
  form.myForm div.submit input[type="submit"] {
    font-size: 1.6rem;
    height: auto;
    padding: 3% 8%;
  }
}
