@charset "UTF-8";

/* 
------------------------------------*/
#mainImg {
    position: relative;
    background-color: #fff;
}
.w_box {
    background-color: #fff;
    border-radius: 20px;
    padding: 40px 20px;
}


            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .w_box {
                    padding: 60px 40px;
                    border-radius: 30px;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
            }





/* c01
------------------------------------*/
.entryLayout #c01 {
    margin-top: 60px;
    padding-bottom: 0;
}
.entryLayout #c01 .t_box {
    max-width: 800px;
    margin: 0 auto 40px;
}





            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .entryLayout #c01 {
                    margin-top: 100px;
                }
                .entryLayout #c01 .t_box {
                    margin-bottom: 60px;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
            }




/* c02
------------------------------------*/
.entryLayout #c02 .merit_box, .entryLayout #c02 .hash_box, .entryLayout #c03 .huku_box {
    margin-top: 60px;
}
.entryLayout #c02 .merit_box h3 {
    font-family: "Zen Maru Gothic", serif;
    font-weight: 500;
    font-size: 2.4rem;
    text-align: left;
    margin-bottom: 10px;
}
.entryLayout #c02 .merit_box h3 span {
    font-size: 50%;
    display: inline-block;
    margin-right: 5px;
}
.entryLayout #c02 .hash_box h4 {
    color: #EE5324;
    text-align: center;
    padding-left: 0;
    font-size: 2rem;
    letter-spacing: 2px;
}
.entryLayout #c02 .hash_box h4::before {
    content: none;
}
.entryLayout #c02 .hash_box h4 .g {
    color: #2AAA79;
}
.entryLayout #c02 .hash_box h4 .y {
    color: #D8C535;
}
.entryLayout #c02 .hash_box h4 .p {
    color: #B161A4;
}
.entryLayout #c02 .hash_box .icon {
    padding: 10px 20px;
    display: inline-block;
    border-radius: 50px;
    color: #fff;
    background-color: #EE5324;
    font-size: 0.7rem;
}
.entryLayout #c02 .hash_box .icon.g {
    background-color: #2AAA79;
}
.entryLayout #c02 .hash_box .icon.y {
    background-color: #D8C535;
}
.entryLayout #c02 .hash_box .icon.p {
    background-color: #B161A4;
}
.entryLayout #c02 .hash_box ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 15px;
}




            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .entryLayout #c02 .merit_box, .entryLayout #c02 .hash_box, .entryLayout #c03 .huku_box {
                    margin-top: 100px;
                }
                .entryLayout #c02 .merit_box .flex_box01:first-child {
                    width: 60%;
                }
                .entryLayout #c02 .merit_box .flex_box01:last-child {
                    width: 36%;
                }
                .entryLayout #c02 .merit_box h3 {
                    font-size: 4rem;
                }
                .entryLayout #c02 .hash_box h4 {
                    font-size: 2.6rem;
                }
                .entryLayout #c02 .hash_box .icon {
                    font-size: 1rem;
                }
                .entryLayout #c02 .merit02 h3 {
                    max-width: 60%;
                    margin-left: auto;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
                .entryLayout #c02 .hash_box h4 {
                    font-size: 3rem;
                }
            }





/* c03
------------------------------------*/
.entryLayout #c03 .huku_li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px 2%;
}
.entryLayout #c03 .huku_li > li {
    width: 48%;
}
.entryLayout #c03 .huku_li .ttl {
    margin-top: 10px;
    font-size: 0.9rem;
    text-align: center;
    font-weight: bold;
}
.entryLayout #c03 .huku_li > li .img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 110px;
}



            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .entryLayout #c03 .huku_li > li {
                    width: 32%;
                }
                .entryLayout #c03 .huku_li > li .img {
                    height: 100px;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
                .entryLayout #c03 .huku_li > li {
                    width: 15%;
                }
            }



/* 
------------------------------------*/
.entryLayout #c05 {
    background-color: #E4F2EE;
}
.entryLayout #c05 .w_box:not(:last-child) {
    margin-bottom: 60px;
}
.entryLayout #c05 .w_box .btn_box {
    position: relative;
    z-index: 1;
}
.entryLayout #c05 .w_box table {
    border: none;
}
.entryLayout #c05 .w_box th {
    padding-bottom: 0;
    vertical-align: baseline;
    background-color: transparent;
    border-bottom: none;
}
.entryLayout #c05 .w_box td {
    padding-top: 10px;
    text-align: left;
}
.entryLayout #c05 .w_box tr {
    border-bottom: 1px solid #000;
}
.entryLayout #c05 .w_box tr:first-child {
    border-top: 1px solid #000;
}
.entryLayout #c05 h2::before {
    background-color: #c8e6dd;
}



            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .entryLayout #c05 .w_box:not(:last-child) {
                    margin-bottom: 100px;
                }
                .entryLayout #c05 .w_box th {
                    padding-bottom: 30px;
                    padding-top: 30px;
                    width: 20%;
                }
                .entryLayout #c05 .w_box td {
                    padding-top: 30px;
                    padding-bottom: 30px;
                    width: 80%;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
            }





/* c06
------------------------------------*/
.entryLayout #c06 .flow_li {
    border: 5px solid #39A886;
    color: #39A886;
    text-align: center;
    overflow: hidden;
    max-width: 250px;
    margin: 0 auto 60px;
}
.entryLayout #c06 .flow_li > li {
    padding: 30px 0;
    font-weight: bold;
    font-size: 1.1rem;
}
.entryLayout #c06 .flow_li > li .s {
    font-size: 0.8rem;
}
.entryLayout #c06 .flow_li > li:not(:last-child) {
    position: relative;
    padding: 30px 0 60px;
}
.entryLayout #c06 .flow_li > li:not(:last-child)::before, .entryLayout #c06 .flow_li > li:not(:last-child)::after {
    position: absolute;
    content: "";
    border-style: solid;
    border-right: 150px solid transparent;
    border-left: 150px solid transparent;
    border-bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
.entryLayout #c06 .flow_li > li:not(:last-child)::before {
    border-top: 50px solid #39A886;
    bottom: 0;
}
.entryLayout #c06 .flow_li > li:not(:last-child)::after {
    border-top: 50px solid #fff;
    bottom: 5px;
}
.entryLayout #c06 h5 {
    font-size: 1.8rem;
}



            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .entryLayout #c06 .flow_li > li:not(:last-child)::before, .entryLayout #c06 .flow_li > li:not(:last-child)::after {
                    border-right-width: 150px;
                    border-left-width: 150px;
                }
                .entryLayout #c06 h5 {
                    font-size: 2rem;
                }
            }
            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
                .entryLayout #c06 .flow_li {
                    max-width: 100%;
                    display: flex;
                    justify-content: space-between;
                }
                .entryLayout #c06 .flow_li > li {
                    padding: 30px 0;
                    width: 25%;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                    flex-direction: column;
                }
                .entryLayout #c06 .flow_li > li:not(:last-child) {
                    padding: 30px 60px 30px 0;
                }
                .entryLayout #c06 .flow_li > li:not(:last-child)::before, .entryLayout #c06 .flow_li > li:not(:last-child)::after {
                    left: auto;
                    top: 50%;
                    transform: translateY(-50%);
                    border-top: 100px solid transparent;
                    border-bottom: 100px solid transparent;
                    border-right-width: 0;
                }
                .entryLayout #c06 .flow_li > li:not(:last-child)::before {
                    right: 0;
                    border-left: 40px solid #39A886;
                }
                .entryLayout #c06 .flow_li > li:not(:last-child)::after {
                    right: 5px;
                    border-left: 40px solid #fff;
                }
                .entryLayout #c06 h5 {
                    font-size: 2.4rem;
                }
            }





/* form_ca
------------------------------------*/
.form_ca {
    background-color: #FAF5E8;
}
.entryLayout .form_ca table {
    margin-top: 60px;
}
.form_ca table {
    border: none;
}
.form_ca tr, .form_ca th {
    border-bottom: none;
}
.form_ca th, .form_ca td {
    text-align: left;
}
.form_ca th {
    padding-bottom: 0;
    vertical-align: baseline;
    background-color: transparent;
}
.form_ca td {
    padding-top: 10px;
}
.form_ca td input[type=text], .form_ca td input[type=email],
.form_ca td textarea {
    font-size: 100%;
    padding: 10px 20px;
    width: calc(100% - 40px);
}
.form_ca td #cord[type=text] {
    max-width: 300px;
    width: calc(40% - 40px);
    margin-bottom: 10px;
}
.form_ca td textarea {
    max-height: 150px;
}
.form_ca th .icon {
    display: inline-block;
    padding: 2px 10px;
    color: #fff;
    background-color: #989898;
    border-radius: 5px;
    margin-right: 10px;
    font-size: 0.8rem;
}
.form_ca th .icon.hissu {
    background-color: #39A886;
}
.form_ca .sex_td > div:not(:last-child) {
    margin-bottom: 10px;
}
.form_ca .alert-danger {
  color: #EE5324;
  font-weight: bold;
}


            /* 【スマートフォン用のスタイル記述】 */
            @media screen and (min-width: 760px) {
                .form_ca th {
                    width: 30%;
                    padding-bottom: 20px;
                }
                .form_ca td {
                    width: 70%;
                    padding-top: 20px;
                }
            }

            /* 【タブレット用のスタイル記述】 */
            @media screen and (min-width: 960px) {
                .form_ca th {
                    width: 25%;
                }
                .form_ca td {
                    width: 75%;
                }
            }