@charset "UTF-8";
/* ========================================
  @media screen and (min-width: 768px), print
======================================== */
@media screen and (min-width: 768px),print {
#empathy .main-ttl-wrap {
    margin-bottom: 0;
}
#empathy .seo_bread_list {padding: 16px 0;}
.section-wrap {
    background: #EEF0E7;
    padding-bottom: 145px;
}

/* mv
-------------------------------------*/
.mv {
    position: relative;
    margin: 59px 0 83px;
}
.mv::before {
    position: absolute;
    content: "";
    width: 91.6666%;
    height: 96.1%;
    border-radius: 0px 100px 100px 0px;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, #fff 100%);
    top: 0;
    left: 0;
    pointer-events: none;
}
.mv .inner {
    width: min(95%, 1200px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: 46.5% 44.0833%;
    padding: 72px 0 0;
    gap: 114px;
}
.mv .txt-box {
    position: relative;
}
.mv .txt-box::before {
    position: absolute;
    content: "";
    background: url(../images/page-common/mv-deco.png)no-repeat;
    background-size: contain;
    width: 162px;
    height: 144px;
    top: -114px;
    right: -42px;
}
.mv .enttl {
    font-size: 22px;
    letter-spacing: 0;
    color: #3b8461;
    margin-bottom: 27px;
}
.mv h2 {
    font-weight: 500;
    font-size: 36px;
    letter-spacing: 0.05em;
    line-height: 1.027777;
    margin-bottom: 29px;
}
.mv .txt {
    font-weight: 500;
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 2.285714;
}
.mv .photo {
    position: relative;
    top: -117px;
}

/* point共通
-------------------------------------*/
.point {
    width: min(95%, 1200px);
    margin-inline: auto;
    background: #fff;
    position: relative;
    margin-bottom: 100px;
}
.point::before {
    position: absolute;
    content: "";
    background: url(../images/empathy/point-line.png)no-repeat;
    background-size: contain;
    width: 100%;
    height: 4px;
    top: 0;
    left: 0;
}
.point .inner {
    padding: 92px 80px 114px;
}
.point .inBox {
    display: grid;
    grid-template-columns: 61.53846% 61.53846%;
    align-items: start;
}
.point .num {
    font-size: 16px;
    letter-spacing: 0;
    display: flex;
    gap: 4px;
    align-items: baseline;
    margin-bottom: -4px;
}
.point .num span{
    font-size: 28px;
    line-height: 1.6;
    letter-spacing: 0;
    position: relative;
    top: 3px;
}
.point h2 {
    font-weight: 500;
    font-size: 28px;
    letter-spacing: 0.05em;
    line-height: 1.785714;
    margin-bottom: 28px;
}
.point .txt-box {
    background: #fff;
    padding: 37px 51px 0 29px;
    position: relative;
    z-index: 2;
    left: -29px;
}
.point .txt {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.05em;
    line-height: 2.25;
    margin-bottom: 18px;
}
.point .txt:nth-last-of-type(1) {
    margin-bottom: 0;
}
.point .photo-box {
    position: relative;
    top: -53px;
    left: -120px;
}

/* point01
-------------------------------------*/
.point01 .txt:nth-of-type(3),
.point01 .txt:nth-of-type(4){width: min(95%, 490px);}
.point01 .photo02 {position: absolute;left: 37.5%;bottom: -140px;}

/* point02
-------------------------------------*/
.point02 .inner {
    padding: 92px 80px 80px;
}
.point02 .num {
    justify-content: center;
    margin-left: 182px;
}
.point02 .txt-box {
    left: auto;
    right: 180px;
    padding: 37px 30px 34px 50px;
}
.point02 .inBox02 {
    display: grid;
    grid-template-columns: 31.4606% 1fr;
    width: min(95%, 890px);
    margin-inline: auto;
    gap: 50px;
    margin-top: -2px;
    align-items: center;
}
.point02 .inBox02 .txt-box {
    left: auto;
    right: auto;
    padding: 0;
}

/* point03
-------------------------------------*/
.point03 .inner {
    padding: 92px 80px 74px;
}

/* bnr-box
-------------------------------------*/
.bnr-box {
    position: relative;
    margin-top: -185px;
}
.bnr-box::before {
    position: absolute;
    content: "";
    background: url(../images/empathy/bnr-box-bg.png)no-repeat;
    background-size: contain;
    width: 100%;
    height: 240px;
    top: 0;
    left: 0;
}
.bnr-box .inner {
    width: min(95%, 1100px);
    margin-inline: auto;
    position: relative;
    padding: 318px 0 157px;
}
.bnr-box .inner::before,
.bnr-box .inner::after {
    position: absolute;
    content: "";
}
.bnr-box .inner::before {
    background: url(../images/empathy/bnr-box-deco01.png)no-repeat;
    background-size: contain;
    width: 517px;
    height: 500px;
    top: 92px;
    left: -80px;
}
.bnr-box .inner::after {
    background: url(../images/empathy/bnr-box-deco02.png)no-repeat;
    background-size: contain;
    width: 459px;
    height: 446px;
    top: 226px;
    right: -19px;
}
.bnr-box .subt {
    font-weight: 500;
    font-size: 28px;
    letter-spacing: 0.05em;
    margin-bottom: 26px;
    text-align: center;
}
.bnr-box h2 {
    font-weight: 500;
    font-size: 48px;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 99px;
    position: relative;
}
.bnr-box .list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 40px;
} 
.bnr-box .list li img {
    margin-bottom: 11px;
}
.bnr-box .list li .txt {
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 1.7142857;
    text-align: center;
}

}

/* ========================================
@media screen and (min-width:768px) and (max-width:1600px) 
======================================== */
@media screen and (min-width:768px) and (max-width:1600px) {
/* mv
-------------------------------------*/
.mv {
    margin: 3.688vw 0 5.188vw;
}
.mv::before {
    border-radius: 0px 6.25vw 6.25vw 0px;
}
.mv .inner {
    width: 75vw;
    padding: 4.5vw 0 0;
    gap: 7.125vw;
}
.mv .txt-box::before {
    width: 10.125vw;
    height: 9vw;
    top: -7.125vw;
    right: -0.625vw;
}
.mv .enttl {
    font-size: 1.375vw;
    margin-bottom: 1.688vw;
}
.mv h2 {
    font-size: 2.25vw;
    margin-bottom: 1.812vw;
}
.mv .txt {
    font-size: clamp(0.75rem, 0.635rem + 0.24vw, 0.875rem);
}
.mv .photo {
    top: -7.312vw;
}
.mv .photo img {
    width: 100%;
    height: auto;
}

}


/* ========================================
@media screen and (min-width:768px) and (max-width:1440px)
======================================== */
@media screen and (min-width:768px) and (max-width:1440px) {
.mv .inner {
    width: 89vw;
    gap: 3vw;
}
}

/* ========================================
@media screen and (min-width:768px) and (max-width:1100px)
======================================== */
@media screen and (min-width:768px) and (max-width:1100px) {
.mv .txt {
    font-size: clamp(0.688rem, 0.543rem + 0.3vw, 0.75rem);
}
}

/* ========================================
@media screen and (min-width:768px) and (max-width:1440px)
======================================== */
@media screen and (min-width:768px) and (max-width:1440px) {
/* point共通
-------------------------------------*/
.point {
    width: 83.333vw;
    margin-bottom: 6.944vw;
}
.point::before {
    height: 0.278vw;
}
.point .inner {
    padding: 6.389vw 5.556vw 7.917vw;
}
.point .inBox {
    grid-template-columns: 61.53846% 61.53846%;
}
.point .inBox img {
    width: 100%;
    height: auto;
}
.point .num {
    font-size: 1.111vw;
    gap: 0.278vw;
    margin-bottom: -0.278vw;
}
.point .num span{
    font-size: 1.944vw;
    top: 0.208vw;
}
.point h2 {
    font-size: 1.944vw;
    margin-bottom: 1.944vw;
}
.point .txt-box {
    padding: 2.569vw 3.542vw 0 2.014vw;
    left: -2.014vw;
}
.point .txt {
    font-size: clamp(0.688rem, 0.33rem + 0.74vw, 1rem);
    margin-bottom: 1.25vw;
}
.point .photo-box {
    top: -3.681vw;
    left: -8.333vw;
}

/* point01
-------------------------------------*/
.point01 .txt:nth-of-type(3),
.point01 .txt:nth-of-type(4){width: 34.028vw;}
.point01 .photo02 {position: absolute;left: 37.5%;bottom: -9.722vw;}

/* point02
-------------------------------------*/
.point02 .inner {
    padding: 6.389vw 5.556vw 5.556vw;
}
.point02 .num {
    margin-left: 12.639vw;
}
.point02 .txt-box {
    right: 12.5vw;
    padding: 2.569vw 2.083vw 2.361vw 3.472vw;
    left: auto;
}
.point02 .inBox02 {
    grid-template-columns: 31.4606% 1fr;
    width: 61.806vw;
    gap: 3.472vw;
    margin-top: -0.139vw;
}
.point02 .inBox02 img {
    width: 100%;
    height: auto;
}

/* point03
-------------------------------------*/
.point03 .inner {
    padding: 6.389vw 5.556vw 5.139vw;
}
}

/* ========================================
@media screen and (min-width:768px) and (max-width:1500px) 
======================================== */
@media screen and (min-width:768px) and (max-width:1500px) {
/* bnr-box
-------------------------------------*/
.bnr-box {
    margin-top: -12.333vw;
}  
}

/* ========================================
@media screen and (min-width:768px) and (max-width:1140px) 
======================================== */
@media screen and (min-width:768px) and (max-width:1140px) {
/* bnr-box
-------------------------------------*/
.bnr-box .inner {
    width: 96.491vw;
    padding: 27.895vw 0 13.772vw;
}
.bnr-box .inner::before {
    width: 45.351vw;
    height: 43.86vw;
    top: 8.07vw;
    left: -7.018vw;
}
.bnr-box .inner::after {
    width: 40.263vw;
    height: 39.123vw;
    top: 19.825vw;
    right: -1.667vw;
}
.bnr-box .subt {
    font-size: 2.456vw;
    margin-bottom: 2.281vw;
}
.bnr-box h2 {
    font-size: 4.211vw;
    margin-bottom: 8.684vw;
}
.bnr-box .list {
    gap: 3.509vw;
} 
.bnr-box .list li img {
    margin-bottom: 0.965vw;
    width: 100%;
    height: auto;
}
.bnr-box .list li .txt {
    font-size: clamp(0.688rem, 0.3rem + 0.81vw, 0.875rem);
}

}


/* ========================================
@media screen and (max-width: 767px) 
======================================== */
@media screen and (max-width: 767px) {
#empathy .main-ttl-wrap {
    margin-bottom: 0;
}
.section-wrap {
    background: #EEF0E7;
    padding-bottom: 7vw;
    padding-top: 10vw;
}

/* mv
-------------------------------------*/
.mv {
    position: relative;
}
.mv::before {
    position: absolute;
    content: "";
    width: 97.10vw;
    height: 168.60vw;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, #fff 100%);
    border-radius: 0 9.66vw 9.66vw 0;
    top: 0;
    left: 0;
    pointer-events: none;
}
.mv .inner {
    display: grid;
    position: relative;
    padding: 13vw 8.94vw 34vw;
    gap: 8.5vw;
}
.mv .inner::before {
    position: absolute;
    content: "";
    background: url(../images/page-common/mv-deco_sp.png)no-repeat;
    background-size: contain;
    width: 28.02vw;
    height: 24.88vw;
    top: -5.5vw;
    left: 5.5vw;
}
.mv .enttl {
    font-size:5.797vw;
    letter-spacing: 0;
    color: #3b8461;
    text-align: center;
    margin-bottom: 8.5vw;
}
.mv h2 {
    font-weight: 500;
    font-size:5.797vw;
    letter-spacing: 0.05em;
    line-height: 1.027777;
    text-align: center;
    margin-bottom: 8.4vw;
}
.mv .txt {
    font-weight: 500;
    font-size:3.382vw;
    letter-spacing: 0.05em;
    line-height: 2;
    margin-bottom: 4vw;
}
.mv .txt:nth-last-of-type(1) {
    margin-bottom: 0;
}

/* point共通
-------------------------------------*/
.point {
    background: #fff;
    position: relative;
    margin-bottom: 20vw;
}
.point::before {
    position: absolute;
    content: "";
    background: url(../images/empathy/point-line_sp.png)no-repeat;
    background-size: contain;
    width: 100%;
    height: 0.97vw;
    top: 0;
    left: 0;
}
.point .inner {
    padding: 13vw 5.3vw 13vw;
}
.point .inBox {
    display: grid;
}
.point .num {
    font-size:2.898vw;
    letter-spacing: 0;
    display: flex;
    gap: 1.2vw;
    align-items: baseline;
    margin-bottom: 2.5vw;
}
.point .num span{
    font-size:6.28vw;
    line-height: 0.76923;
    letter-spacing: 0;
}
.point h2 {
    font-weight: 500;
    font-size:4.348vw;
    letter-spacing: 0.05em;
    line-height: 1.77777;
    margin-bottom: 5.8vw;
    order: 1;
}
.point .txt-box {
    display: contents;
}
.point .txt {
    font-weight: 500;
    font-size:3.382vw;
    letter-spacing: 0.05em;
    line-height: 2;
    margin-bottom: 7vw;
    order: 3;
}
.point .txt:nth-last-of-type(1) {
    margin-bottom: 0;
}
.point .photo-box {
    display: contents;
}
.point .photo01 {
    order: 2;
    margin-bottom: 6.5vw;
}
.point .photo02 {
    order: 4;
    margin-bottom: 6.2vw;
}

/* point01
-------------------------------------*/
.point01 .txt:nth-of-type(2) {
    margin-bottom: 11vw;
}
.point01 .txt:nth-of-type(3),
.point01 .txt:nth-of-type(4){order: 5;}

/* point02
-------------------------------------*/
.point02 .inBox02 {
    padding: 11vw 0 0;
}

/* point03
-------------------------------------*/
.point03 .txt:nth-of-type(3),
.point03 .txt:nth-of-type(4){order: 5;}
.point03 .txt:nth-of-type(2) {
    margin-bottom: 11vw;
}

/* bnr-box
-------------------------------------*/
.bnr-box {
    position: relative;
    margin-top: -17vw;
}
.bnr-box::before {
    position: absolute;
    content: "";
    background: url(../images/empathy/bnr-box-bg_sp.png)no-repeat;
    background-size: contain;
    width: 100%;
    height: 19.32vw;
    top: 0;
    left: 0;
}
.bnr-box .inner {
    width: 82.13vw;
    margin-inline: auto;
    position: relative;
    padding: 38.5vw 0 24vw;
}
.bnr-box .inner::before,
.bnr-box .inner::after {
    position: absolute;
    content: "";
}
.bnr-box .inner::before {
    background: url(../images/empathy/bnr-box-deco01_sp.png)no-repeat;
    background-size: contain;
    width: 65.46vw;
    height: 63.77vw;
    top: 7vw;
    left: -23vw;
}
.bnr-box .inner::after {
    background: url(../images/empathy/bnr-box-deco02_sp.png)no-repeat;
    background-size: contain;
    width: 56.28vw;
    height: 54.83vw;
    top: 40vw;
    right: -7vw;
}
.bnr-box .subt {
    font-weight: 500;
    font-size:4.348vw;
    letter-spacing: 0.05em;
    margin-bottom: 4vw;
    text-align: center;
    position: relative;
}
.bnr-box h2 {
    font-weight: 500;
    font-size:5.797vw;
    letter-spacing: 0.05em;
    line-height: 1.7;
    text-align: center;
    margin-bottom: 23vw;
    position: relative;
}
.bnr-box .list {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    text-align: center;
    gap: 6.25vw;
} 
.bnr-box .list li img {
    margin-bottom: 3.38vw;
}
.bnr-box .list li .txt {
    font-size:3.382vw;
    letter-spacing: 0.05em;
    line-height: 1.7142857;
    text-align: center;
}

}