@charset "UTF-8";

/*-all-*/
body {
    font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    font-style: normal;
    color: #DCDCDC;
    background-color: #2F4737;
}
.contents_inner {
    width: 1400px;
    max-width: 1400px;
}
.line {
    border: 1px solid #596C5F;
}
p {
    font-size:16px;
    font-weight:400;
    line-height: 3rem;
}
a img {
	transition : 0.2s;
	-webkit-transition :  0.2s;
	-moz-transition :  0.2s;
	-o-transition : 0.2s;
	-ms-transition :  0.2s;
}
a:hover img {
	opacity: 0.5;
}
header a img:hover {
    opacity: 1 !important;
}
a:hover {
	opacity: 0.5;
	text-decoration: none;
}
header a img:hover {
    opacity: 1 !important;
}
header a:hover {
    opacity: 1 !important;
}
@media screen and (max-width: 1400px) {
    .contents_inner {
        width: 90%;
    }
}
@media screen and (max-width: 640px) {
    p {
        font-size:13px;
        font-weight:400;
        line-height: 3rem;
    }
    .contents_inner {
        width: 90%;
    }
}
/*-TOP img-*/
#topimg_block {
    width: 100%;
    position: relative;
}
#topimg_block img {
    width:100%;
    object-fit:cover;
    object-position: top;
    height: 400px;
}
.page_title_box {
    position:relative;
}
.page_title_box .topomg_background_img h2 {
    font-size: 50px;
    font-weight: 400;
    letter-spacing: -0.15em;
    position: absolute;
    top: 2%;
    left: 2%;
    z-index: 10;
    display: flex;
    align-items: center;
    column-gap: 10px;
}
.topomg_background_img {
    background:url(../img/brand/som/bg_deco01.png);
    background-repeat: no-repeat;
    position: absolute;
    width: 100%;
    height: 600px;
    top: -75px;
}
@media screen and (max-width: 840px) {
    .page_title_box .topomg_background_img h2 {
        font-size: 36px;
        letter-spacing: -0.2em;
    }
.topomg_background_img {
    background-position: -280px top;
}
}
@media screen and (max-width: 640px) {
    #topimg_block img {
        height: 200px;
    }
    .page_title_box  .topomg_background_img h2 {
        font-size: 5.5vw;
        top: 0;
        height: 12vw;
    }
    .topomg_background_img {
        background:url(../img/brand/bg_deco01_sp.png);
        background-repeat: no-repeat;
        background-size: contain;
        top: -12vw;
    }
}
/*-breadcrumbs-*/
#breadcrumbs {
    position: relative;
    margin: 35px 0 60px;
}
#breadcrumbs ul {
    display: flex;
    color: #97a39b;
    font-size: 13px;
}
#breadcrumbs ul li:not(:last-child)::after {
    content: ">";
    margin: 0 10px;
}
#breadcrumbs ul li a {
    color: #c1c8c3;
    text-decoration: underline;
}
@media screen and (max-width: 640px) {
    #breadcrumbs {
        margin: 20px 0 30px;
    }
    #breadcrumbs ul {
        font-size: 11px;
        width: 90%;
        margin: 0 auto;
    }
    #breadcrumbs ul li:not(:last-child)::after {
        margin: 0 5px;
    }
}
/*-intro_block-*/
#intro_block {
    position: relative;
    width: min(1400px, 90%);
    margin: 0 auto;
}
@media screen and (max-width: 640px) {
#intro_block img {
    width: 100%;
    height: 80vw;
    object-fit: cover;
}
}
/*-menu-*/
#menu {
    position: relative;
    width: min(1400px, 90%);
    padding: 40px 0;
    background: #dbe3dd;
    margin: 0 auto;
    border-bottom: 1px solid #2f4737;
}
#menu .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
#menu ul {
    justify-content: center;
    align-items: center;
    gap: 20px 60px;
}
#menu ul li a {
    display: block;
    color: #2f4737;
    font-size: 18px;
    line-height: 40px;
    padding-right: 50px;
    background: url(../img/brand/som/menu_arrow.svg) no-repeat right center/40px;
}
@media screen and (max-width: 840px) {
    #menu ul li a {
        font-size: 18px;
        line-height: 40px;
        padding-right: 50px;
        background: url(../img/brand/som/menu_arrow.svg) no-repeat right center/40px;
    }
}
@media screen and (max-width: 640px) {
    #menu {
        padding: 30px 0;
    }
    #menu ul {
        gap: 20px;
    }
    #menu ul li a {
        font-size: 15px;
        line-height: 30px;
        padding-right: 35px;
        background: url(../img/brand/som/menu_arrow.svg) no-repeat right center/30px;
    }
}
/*-bg_color_box01-*/
.bg_color_box01 {
    position: relative;
    width: min(1400px, 90%);
    margin: 0 auto;
    padding: 100px 0 0;
    border-bottom: 1px solid #2f4737;
    background: #dbe3dd url(../img/brand/bg_deco04.png) no-repeat center top/100%;
    color: #2f4737;
}
.bg_color_box01 .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
.bg_color_box01 h3 {
    font-size: 38px;
    font-weight: 500;
    line-height: 1.31;
    text-align: center;
    padding: 0 0 30px;
    margin-bottom: 55px;
    position: relative;
}
.bg_color_box01 h3::after {
    content: "";
    position: absolute;
    width: 164px;
    height: 4px;
    background-color: #2f4737;
    bottom: 0;
    left: calc(50% - 82px);
}
@media screen and (max-width: 840px) {
    .bg_color_box01 h3 {
        font-size: 32px;
    }
}
@media screen and (max-width: 640px) {
    .bg_color_box01 {
        padding: 50px 0 0;
        background: #dbe3dd url(../img/brand/bg_deco04.png) no-repeat center top/100%;
    }
    .bg_color_box01 h3 {
        font-size: 26px;
        padding: 0 0 15px;
        margin-bottom: 30px;
    }
    .bg_color_box01 h3::after {
        width: 100px;
        height: 3px;
        left: calc(50% - 50px);
    }
}
/*-bg_color_box02-*/
.bg_color_box02 {
    position: relative;
    width: min(1400px, 90%);
    margin: 0 auto;
    padding: 100px 0;
    border-bottom: 1px solid #2f4737;
    background: #dbe3dd;
    color: #2f4737;
}
.bg_color_box02 .contents_inner {
    width: min(1100px, 90%);
    margin: 0 auto;
}
.bg_color_box02 h3 {
    text-align: center;
    font-size: 30px;
    font-weight: 500;
    line-height: 1.13;
    margin-bottom: 30px;
}
.bg_color_box02 h3 span {
    display: block;
    width: 130px;
    height: 130px;
    line-height: 130px;
    color: #FFF;
    border-radius: 50%;
    margin: 0 auto;
    text-align: center;
    font-size: 20px;
    font-weight: 500;
    margin-bottom: 20px;
}
.bg_color_box02 .contents_inner > p {
    line-height: 1.875;
    letter-spacing: -0.05em;
    text-align: center;
    width: min(855px,100%);
    margin: 0 auto 60px;
}
@media screen and (max-width: 640px) {
    .bg_color_box02 {
        padding: 50px 0;
    }
    .bg_color_box02 h3 {
        font-size: 20px;
        letter-spacing: 0;
        margin-bottom: 20px;
    }
    .bg_color_box02 h3 span {
        width: 80px;
        height: 80px;
        line-height: 80px;
        font-size: 16px;
        margin-bottom: 10px;
    }
    .bg_color_box02 .contents_inner > p {
        text-align: left;
        margin: 0 auto 40px;
    }
}
/*-sec01_block-*/
#sec01_block .contents_inner > p {
    text-align: center;
    margin-bottom: 70px;
}
#sec01_block .sec01_box {
    width: 1400px;
    margin: 0 -150px;
    padding: 100px 150px;
    background: #e9eeea;
}
#sec01_block .sec01_box h4 {
    font-size: 30px;
    font-weight: 500;
    text-align: center;
    margin-bottom: 30px;
}
#sec01_block .row_box a {
    width: 31%;
    background: #FFF url(../img/brand/som/menu_arrow.svg) no-repeat center calc(100% - 20px)/40px;
    color: #2f4737;
    padding-bottom: 60px;
}
#sec01_block .row_box a .step {
    font-size: 24px;
    font-weight: 500;
    letter-spacing: -0.15em;
    background: #e9eeea;
    padding-bottom: 15px;
}
#sec01_block .row_box a .step span {
    display: inline-block;
    color: #FFF;
    font-size: 17px;
    letter-spacing: -0.03em;
    padding: 10px 15px;
    border-radius: 0 30px 30px 0;
    margin-right: 10px;
}
#sec01_block .row_box a.item01 .step span {
    background: #00a688;
}
#sec01_block .row_box a.item02 .step span {
    background: #007e9c;
}
#sec01_block .row_box a.item03 .step span {
    background: #695080;
}
#sec01_block .row_box a p {
    text-align: center;
    padding: 20px;
    font-size: 15px;
    letter-spacing: -0.05em;
    line-height: 1.875;
}
@media screen and (max-width: 1560px) {
    #sec01_block .sec01_box {
        width: 89.74vw;
        margin: 0 calc(50% - 44.87vw);
        padding: 100px calc(44.87vw - 50%);
    }
}
@media screen and (max-width: 1360px) {
    #sec01_block .row_box a {
        width: 31.5%;
        background: #FFF url(../img/brand/som/menu_arrow.svg) no-repeat center calc(100% - 1.47vw)/2.94vw;
        padding-bottom: 4.41vw;
    }
    #sec01_block .row_box a .step {
        font-size: 1.76vw;
    }
    #sec01_block .row_box a .step span {
        font-size: 1.25vw;
        padding: 10px 1.1vw;
        margin-right: 0.73vw;
    }
    #sec01_block .row_box a p {
        padding: 1.47vw;
        font-size: 1.1vw;
    }
}
@media screen and (max-width: 840px) {
    #sec01_block .sec01_box h4 {
        font-size: 24px;
    }
}
@media screen and (max-width: 640px) {
    #sec01_block .contents_inner > p {
        text-align: left;
        margin-bottom: 35px;
    }
    #sec01_block .sec01_box {
        padding: 50px calc(44.87vw - 50%);
    }
    #sec01_block .sec01_box h4 {
        font-size: 18px;
        line-height: 1.4;
    }
    #sec01_block .row_box {
        row-gap: 20px;
    }
    #sec01_block .row_box a {
        width: 100%;
        background: #FFF url(../img/brand/som/menu_arrow.svg) no-repeat center calc(100% - 15px)/30px;
        padding-bottom: 45px;
    }
    #sec01_block .row_box a .step {
        font-size: 18px;
        letter-spacing: -0.05em;
        padding-bottom: 10px;
    }
    #sec01_block .row_box a .step span {
        font-size: 15px;
        padding: 5px 10px;
        border-radius: 0 20px 20px 0;
        margin-right: 5px;
    }
    #sec01_block .row_box a p {
        padding: 15px;
        font-size: 13px;
    }
}
/*-sec02_block -*/
#sec02_block h3 span {
    background: #00a688;
}
#sec02_block h4 {
    background: #00a688;
    color: #FFF;
    text-align: center;
    font-size: 22px;
    font-weight: 500;
    padding: 15px 0;
    margin-bottom: 20px;
}
#sec02_block .white_box {
    background: #FFF;
    padding: 40px 50px;
}
#sec02_block .white_box .white_box_inner {
    margin-bottom: 80px;
}
#sec02_block .white_box .ttl {
    border: 1px dashed #2f4737;
    font-weight: 500;
    display: flex;
    margin-bottom: 20px;
}
#sec02_block .white_box .ttl .case {
    font-size: 21px;
    background: #dfe6e1;
    border-right: 1px dashed #2f4737;
    padding: 15px 20px;
    width: 130px;
    display: grid;
    place-content: center;
}
#sec02_block .white_box .ttl .text {
    padding: 15px 20px;
    font-size: 24px;
    width: calc(100% - 130px);
    letter-spacing: -0.1em;
    line-height: 1.3;
}
#sec02_block .white_box p.copy {
    text-align: center;
    margin-bottom: 30px;
    line-height: 1.875;
}
#sec02_block .white_box .row_box {
    justify-content: center;
    column-gap: min(90px,10%);
    position: relative;
}
#sec02_block .white_box .row_box::before {
    content: "";
    width: 42px;
    height: 88px;
    background: url(../img/brand/som/som_sec02_arrow.svg) no-repeat center/contain;
    position: absolute;
    top: calc(50% - 44px);
    left: calc(50% - 21px);
}
#sec02_block .white_box .row_box .box_inner {
    width: min(410px, 45%);
}
#sec02_block .white_box .row_box .box_inner .inner_ttl {
    color: #FFF;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.29;
    text-align: center;
    margin-bottom: 20px;
    background: #5a7f64;
    padding: 10px 0;
}
#sec02_block .white_box .row_box .box_inner.item02 .inner_ttl {
    background: #bc5a76;
}
#sec02_block .white_box .row_box .box_inner.item04 .inner_ttl {
    background: #488dc5;
}
#sec02_block .white_box .row_box .box_inner img {
    display: block;
    margin: 0 auto;
}
#sec02_block .white_box p.note {
    font-size: 13px;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.875;
    letter-spacing: -0.05em;
}
@media screen and (max-width: 840px) {
    #sec02_block .white_box .ttl .case {
        font-size: 17px;
        width: 110px;
        padding: 15px;
    }
    #sec02_block .white_box .ttl .text {
        font-size: 20px;
        width: calc(100% - 110px);
        padding: 15px;
    }
    #sec02_block .white_box .row_box {
        row-gap: 70px;
    }
    #sec02_block .white_box .row_box::before {
        width: 30px;
        height: 62px;
        top: calc(50% - 31px);
        left: calc(50% - 15px);
        rotate: 90deg;
    }
    #sec02_block .white_box .row_box .box_inner {
        width: min(410px, 100%);
    }
}
@media screen and (max-width: 640px) {
    #sec02_block h4 {
        font-size: 17px;
        padding: 10px 0;
        margin-bottom: 10px;
    }
    #sec02_block .white_box {
        padding: 20px 25px;
    }
    #sec02_block .white_box .white_box_inner {
        margin-bottom: 40px;
    }
    #sec02_block .white_box .ttl {
        flex-direction: column;
        margin-bottom: 10px;
    }
    #sec02_block .white_box .ttl .case {
        font-size: 15px;
        border-right: none;
        border-bottom: 1px dashed #2f4737;
        padding: 10px;
        width: 100%;
        display:block;
    }
    #sec02_block .white_box .ttl .text {
        padding: 10px;
        font-size: 16px;
        width: 100%;
    }
    #sec02_block .white_box p.copy {
        margin-bottom: 15px;
    }
    #sec02_block .white_box .row_box .box_inner .inner_ttl {
        font-size: 14px;
        margin-bottom: 10px;
        padding: 5px 0;
    }
    #sec02_block .white_box p.note {
        font-size: 10px;
    }
}
/*-sec03_block -*/
#sec03_block h3 span {
    background: #007e9c;
}
#sec03_block .sec03_inner:not(:last-child) {
    margin-bottom: 70px;
}
#sec03_block .sec03_inner h4 {
    font-size: 25px;
    font-weight: 500;
    text-align: center;
    padding-bottom: 15px;
    margin-bottom: 30px;
    border-bottom: 2px solid #FFF;
    position: relative;
}
#sec03_block .sec03_inner h4::after {
    content: "";
    width: 100px;
    height: 2px;
    background: #366342;
    position: absolute;
    bottom: -2px;
    left: calc(50% - 50px);
}
#sec03_block .sec03_inner h4 span {
    display: block;
    font-size: 15px;
    margin-bottom: 5px;
}
#sec03_block .row_box {
    row-gap: 70px;
}
#sec03_block .row_box .box_inner {
    width: 47.273%;
    display: flex;
    flex-direction: column;
    row-gap: 30px;
}
#sec03_block .row_box .box_inner .inner_ttl {
    font-size: 20px;
    font-weight: 500;
    text-align: center;
    padding: 10px 0;
    background: #007e40;
    color: #FFF;
}
@media screen and (max-width: 840px) {
    #sec03_block .row_box .box_inner {
        width: 100%;
    }
}
@media screen and (max-width: 640px) {
    #sec03_block .sec03_inner:not(:last-child) {
        margin-bottom: 35px;
    }
    #sec03_block .sec03_inner h4 {
        font-size: 19px;
        padding-bottom: 10px;
        margin-bottom: 20px;
    }
    #sec03_block .sec03_inner h4::after {
        width: 80px;
        left: calc(50% - 40px);
    }
    #sec03_block .sec03_inner h4 span {
        font-size: 12px;
    }
    #sec03_block .row_box {
        row-gap: 35px;
    }
    #sec03_block .row_box .box_inner {
        row-gap: 15px;
    }
    #sec03_block .row_box .box_inner .inner_ttl {
        font-size: 16px;
        padding: 5px 0;
    }
}
/*-sec04_block -*/
#sec04_block h3 span {
    background: #695080;
}
#sec04_block h4 {
    background: #695080;
    color: #FFF;
    text-align: center;
    font-size: 22px;
    font-weight: 500;
    padding: 15px 0;
    margin-bottom: 20px;
}
#sec04_block .row_box {
    gap: 60px 3.5%;
}
#sec04_block .row_box .box_inner {
    width: 31%;
    display: flex;
    flex-direction: column;
    row-gap: 15px;
    letter-spacing: 0;
}
#sec04_block .row_box .box_inner .ttl {
    font-size: 20px;
    font-weight: 500;
    text-align: center;
}
#sec04_block .row_box .box_inner p {
    font-size: 15px;
    line-height: 1.8;
    width: 90%;
    margin: 0 auto;
}
@media screen and (max-width: 840px) {
    #sec04_block .row_box {
        gap: 60px 4%;
    }
    #sec04_block .row_box .box_inner {
        width: 48%;
    }
}
@media screen and (max-width: 640px) {
    #sec04_block h4 {
        font-size: 17px;
        padding: 10px 0;
    }
    #sec04_block .row_box {
        gap: 30px 0;
    }
    #sec04_block .row_box .box_inner {
        width: 100%;
        row-gap: 10px;
    }
    #sec04_block .row_box .box_inner .ttl {
        font-size: 16px;
    }
    #sec04_block .row_box .box_inner p {
        font-size: 12px;
    }
}
/*-sec05_block-*/
#sec05_block .contents_inner {
    width: min(1000px,90%);
}
/*-sec06_block-*/
#sec06_block dl {
    font-size: 16px;
    line-height: 1.875;
    letter-spacing: -0.05em;
}
#sec06_block dl dt,
#sec06_block dl dd {
    display: flex;
    column-gap: 20px;
}
#sec06_block dl dt {
    border-top: 1px dashed #a5b9aa;
    padding: 20px 0 10px;
}
#sec06_block dl dd {
    padding: 10px 0 20px;
}
#sec06_block dl dt::before,
#sec06_block dl dd::before {
    font-size: 20px;
    font-weight: 500;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    text-align: center;
    line-height: 50px;
}
#sec06_block dl dt::before {
    content: "Q";
    background: #366342;
    color: #FFF;
}
#sec06_block dl dd::before {
    content: "A";
    background: #FFF;
    color: #366342;
}
#sec06_block dl dt span,
#sec06_block dl dd span {
    display: block;
    width: calc(100% - 70px);
    padding-top: 10px;
}
@media screen and (max-width: 840px) {
}
@media screen and (max-width: 640px) {
    #sec06_block dl {
        font-size: 13px;
    }
    #sec06_block dl dt,
    #sec06_block dl dd {
        column-gap: 10px;
    }
    #sec06_block dl dt {
        padding: 14px 0 7px;
    }
    #sec06_block dl dd {
        padding: 7px 0 14px;
    }
    #sec06_block dl dt::before,
    #sec06_block dl dd::before {
        font-size: 16px;
        width: 34px;
        height: 34px;
        line-height: 34px;
    }
    #sec06_block dl dt span,
    #sec06_block dl dd span {
        width: calc(100% - 50px);
        padding-top: 7px;
    }
}