@charset "UTF-8";
@media screen and (min-width: 768px),print {
#reason {
    max-width: 1830px;
    width: 100%;
    margin-inline: auto;
    background: url(../images/reason/com-bg.png)repeat-y;
    background-size: contain;
}
.btn {
    width: min(95%, 440px);
    margin-inline: auto;
    background: url(../images/reason/btn-bg.png)no-repeat center;
    background-size: contain;
    transition: 0.25s ease-in-out;
}
.btn02 {
    background: url(../images/reason/btn02-bg.png)no-repeat center;
}
.btn a {
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 0.05em;
    line-height: 1.444444;
    text-align: center;
    color: #fff;
    display: block;
    padding: 19px 0 25px;
    text-decoration: none;
    overflow: hidden;
}
.btn02 a {padding: 23px 0 32px;}
.btn:hover {
    transform: translate(0px, 5px);
    background: url(../images/reason/btn-bg-hover.png) no-repeat center; 
    background-size: contain;
}
.btn02:hover {
    background: url(../images/reason/btn02-bg-hover.png) no-repeat center; 
}
.btn a:hover img {
    opacity: 1;
}
/* mv
-------------------------------------*/
.mv {
    position: relative;
}
.mv::after {
    content: "";
    position: absolute;
    background: #0249AD;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 55.164%;
}
.mv .inner {
    width: min(95%, 1280px);
    margin-inline: auto;
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 65px 0 33px;
}
.mv .main-ttl {
    font-weight: 900;
    font-size: 70px;
    line-height: 1.44285714;
    text-align: center;
    margin-bottom: 12px;
    letter-spacing: 0;
}
.mv .subt {
    font-weight: 900;
    font-size: 36px;
    letter-spacing: 0.05em;
    line-height: 1.66666;
    text-align: center;
    margin-bottom: 6px;
}
.mv .subt02 {
    font-weight: 900;
    font-size: 36px;
    letter-spacing: 0.05em;
    text-align: left;
    color: #fff;
    background: #0249AD;
    display: inline-block;
    padding: 0 10px 5px;
    line-height: 1.2;
    margin-bottom: 48px;
}
.mv .photo img {
    width: 100%;
    max-width: 1280px;
    height: auto;
}

/* point
-------------------------------------*/
.point {
    width: min(95%, 1100px);
    margin-inline: auto;
    padding: 83px 0 0;
}
.point .num {
    font-family: "Outfit", sans-serif;
    font-weight: bold;
    font-size: 30px;
    letter-spacing: 0.05em;
    display: flex;
    gap: 6px;
    justify-content: center;
    align-items: baseline;
    margin-bottom: 5px;
}
.point .num span {
    font-weight: bold;
    font-size: 70px;
    color: #0249ad;
    letter-spacing: 0;
    line-height: 1;
    position: relative;
    top: 5px;
}
.point .main-ttl {
    font-weight: 900;
    font-size: 46px;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 40px;
}
.point .main-ttl span {
    color: #FFFFFF;
    background: #0249AD;
    font-feature-settings: "palt";
    letter-spacing: 0.05em;
    display: inline-block;
    line-height: 1;
    padding: 4px 0 14px;
    margin: 15px 0 0;
    letter-spacing: 0.12em;
}
.point .inBox {
    display: inline-grid;
    grid-template-columns: 46.8181% 49.0909%;
    gap: 35px;
    margin-bottom: 27px;
}
.point .txt-box {
    border-radius: 8px;
    background: #fff;
    border: 1px solid #252525;
    padding: 27px 33px 27px 35px;
    position: relative;
    z-index: 2;
    box-shadow: 10px 10px 0 #eae3d3;
    height: 98.5%;
}
.point .txt-box .ttl {
    font-weight: bold;
    font-size: 30px;
    letter-spacing: 0.05em;
    line-height: 1.6;
    position: relative;
    margin-bottom: 37px;
}
.point03 .txt-box .ttl,
.point04 .txt-box .ttl,
.point05 .txt-box .ttl {
    font-size: 32px;
    line-height: 1.5;
}

.point .txt-box .ttl::after {
    position: absolute;
    content: "";
    background: #252525;
    width: 100%;
    height: 1px;
    bottom: -17px;
    left: 0;
}
.point .txt-box .ttl span {
    background: linear-gradient(transparent 75%, #FFDE1E 25%);
}
.point .txt-box .txt {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.05em;
    line-height: 2;
    margin-bottom: 32px;
}
.point .txt-box .txt .large{
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.6;
}
.point .txt-box .txt:last-of-type {
    margin-bottom: 0;
}
.point:nth-child(odd) .inBox {
    grid-template-columns: 49.1% 47.2727%;
    gap: 40px;
}
.point:nth-child(odd) .photo {
    order: 2;
}
.point:nth-child(odd) .txt-box {
    order: 1;
}
.point .btn-wrap {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-inline: auto;
    justify-content: center;
    margin: 0 80px;
}
/* point01 */
.point01 {
    padding: 90px 0 0;
}
.point01 .main-ttl span {
    padding: 4px 9px 14px;
}
/* point02 */ 
.point02 .main-ttl {
    display: flex;
    gap: 17px;
    justify-content: center;
    position: relative;
    left: 33px;
}
.point02 .main-ttl span {
    margin: 7px 0 0;
}
/* point04 */ 
.point04 .main-ttl span {padding: 4px 15px 14px;}
/* point05 */ 
.point05 .main-ttl span {padding: 4px 6px 14px;margin: 15px 20px 0 0;position: relative;left: 7px;}

/* bottom-sec
-------------------------------------*/
.bottom-sec {
    width: min(95%, 1220px);
    margin-inline: auto;
    margin-bottom: -184px;
}
.bottom-sec .inner {
    display: inline-grid;
    grid-template-columns: 55.16% 50.81%;
    padding: 120px 0 187px;
    align-items: center;
}
.bottom-sec .txt-box {
    border-radius: 50px;
    background: #fff;
    border: 1.2px solid #252525;
    box-shadow: 17px 17px 23px rgba(0, 0, 0, 0.1);
    padding: 60px 0 55px 38px;
    position: relative;
    left: 3px;
    z-index: 2;
    top: -10px;
}
.bottom-sec .txt-box .ttl {
    font-weight: 900;
    font-size: 46px;
    line-height: 1.4347826;
    letter-spacing: 0;
    margin-bottom: 17px;
    position: relative;
}
.bottom-sec .txt-box .ttl::before {
    position: absolute;
    content: "";
    background: url(../images/common/bottom-sec-deco.png)no-repeat;
    background-size: contain;
    width: 56px;
    height: 65px;
    top: -78px;
    left: 20px;
}
.bottom-sec .txt-box .txt {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.05em;
    line-height: 1.777777;
}
.bottom-sec .photo {
    position: relative;
    left: -68px;
}
.bottom-sec .photo img {
    width: 100%;
    height: auto;
}

}





@media screen and (max-width: 767px) {
#reason {
    background: url(../images/reason/com-bg_sp.png)repeat;
    background-size: contain;
    margin: 7vw 0 0;
}
.btn {
    width: 87vw;
    margin-inline: auto;
    background: url(../images/reason/btn-bg_sp.png)no-repeat center;
    background-size: contain;
    transition: 0.25s ease-in-out;
}
.btn a {
    font-weight: 500;
    font-size:4.348vw;
    letter-spacing: 0.05em;
    line-height: 1.444444;
    text-align: center;
    color: #fff;
    display: block;
    padding: 5vw 4vw 6vw 0;
    text-decoration: none;
    overflow: hidden;
}
.btn:hover {
    transform: translate(0px, 5px);
    background: url(../images/reason/btn-bg-hover_sp.png) no-repeat center;
    background-size: contain;
}
.btn a:hover img {
    opacity: 1;
}

/* mv
-------------------------------------*/
.mv {
    position: relative;
}
.mv::after {
    content: "";
    position: absolute;
    background: #0249AD;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 66.67vw;
}
.mv .inner {
    width: 94.205vw;
    margin-inline: auto;
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 5.5vw 0 2.5vw;
}
.mv .main-ttl {
    font-weight: 900;
    font-size:8.696vw;
    letter-spacing: 0;
    line-height: 1.277777;
    text-align: center;
    margin-bottom: 3.7vw;
}
.mv .subt {
    font-weight: 900;
    font-size:5.797vw;
    letter-spacing: 0.05em;
    line-height: 1.1666666;
    text-align: center;
    margin-bottom: 2vw;
}
.mv .subt02 {
    font-weight: 900;
    font-size:5.072vw;
    line-height: 1.3;
    letter-spacing: 0.05em;
    text-align: left;
    color: #fff;
    background: #0249AD;
    display: inline-block;
    margin-bottom: 6vw;
    padding: 0.5vw 1vw;
}

/* point
-------------------------------------*/
.point {
    width: 95.17vw;
    margin-inline: auto;
    padding: 11vw 0 0;
}
.point .num {
    font-family: "Outfit", sans-serif;
    font-weight: bold;
    font-size:4.589vw;
    letter-spacing: 0.05em;
    display: flex;
    gap: 1vw;
    justify-content: center;
    align-items: baseline;
    margin-bottom: 0.5vw;
}
.point .num span {
    font-weight: bold;
    font-size:10.87vw;
    color: #0249ad;
    letter-spacing: 0;
    line-height: 1.33333;
    position: relative;
    top: 1vw;
}
.point .main-ttl {
    font-weight: 900;
    font-size:7.246vw;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 5.1vw;
}
.point .main-ttl span {
    color: #FFFFFF;
    background: #0249AD;
    letter-spacing: 0.05em;
    display: inline-block;
    line-height: 1.46;
}
.point .inBox {
    border-radius: 1.3vw;
    background: #fff;
    border: 1px solid #252525;
    box-shadow: 10px 10px 0 #eae3d3;
    display: grid;
    padding: 5.3vw 4.59vw 7vw;
    margin-bottom: 7vw;
}
.point .txt-box {display: contents;}
.point .txt-box .ttl {
    font-weight: bold;
    font-size:5.797vw;
    letter-spacing: 0.05em;
    line-height: 1.66666;
    position: relative;
    margin-bottom: 6vw;
    order: 1;
    padding-bottom: 3.5vw;
}
.point .txt-box .ttl::after {
    position: absolute;
    content: "";
    background: #252525;
    width: 100%;
    height: 0.2vw;
    bottom: 0;
    left: 0;
}
.point .txt-box .ttl span {
    background: linear-gradient(transparent 75%, #FFDE1E 25%);
}
.point .txt-box .txt {
    font-weight: 500;
    font-size:3.865vw;
    letter-spacing: 0.05em;
    line-height: 2;
    margin-bottom: 7.5vw;
    order: 3;
}
.point .txt-box .txt .large{
    font-weight: bold;
    font-size:4.831vw;
    letter-spacing: 0.05em;
    line-height: 1.6;
}
.point .txt-box .txt:last-of-type {
    margin-bottom: 0;
}
.point .photo {
    order: 2;
    margin-bottom: 2.15vw;
}
.point .btn-wrap {
    display: grid;
    gap: 4.5vw;
}

/* point01 */
.point01 {
    padding: 6vw 0 0;
}
/* point02 */
.point02 .btn {
    background: url(../images/reason/btn02-bg_sp.png)no-repeat center;
    background-size: contain;
}
.point02 .btn:nth-of-type(2) {
    background: url(../images/reason/btn03-bg_sp.png)no-repeat center;
    background-size: contain;
}
.point02 .btn a {
    padding: 2vw 0 5vw;
}
.point02 .btn:nth-of-type(2) a {padding: 4.4vw 0 6vw;}
.point02 .btn:hover {
    background: url(../images/reason/btn02-bg-hover_sp.png) no-repeat center;
    background-size: contain;
}
.point02 .btn:nth-of-type(2):hover {
    background: url(../images/reason/btn03-bg-hover_sp.png) no-repeat center;   
    background-size: contain;
}

/* point03, point04, point05 */
.point03 .btn,
.point04 .btn,
.point05 .btn {
    background: url(../images/reason/btn04-bg_sp.png)no-repeat center;
    background-size: contain;
}
.point03 .btn a,
.point04 .btn a,
.point05 .btn a {
    padding: 6vw 0 7.5vw;
}
.point03 .btn:hover,
.point04 .btn:hover,
.point05 .btn:hover {
    background: url(../images/reason/btn04-bg-hover_sp.png) no-repeat center;
    background-size: contain;
}

/* point04 */
.point04 .main-ttl span {padding: 0 2.5vw;}

/* bottom-sec
-------------------------------------*/
.bottom-sec .inner {
    display: grid;
    padding: 17vw 0;
}   
.bottom-sec .txt-box {
    order: 2;
    border-radius: 7.3vw;
    background: #fff;
    border: 0.2vw solid #252525;
    box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.1);
    padding: 12vw 7vw 8.5vw;
    position: relative;
    z-index: 2;
    top: -10vw;
    width: 87vw;
    left: 49%;
    transform: translateX(-50%);
}
.bottom-sec .txt-box .ttl {
    font-weight: 900;
    font-size:6.763vw;
    line-height: 1.53571428;
    letter-spacing: 0;
    margin-bottom: 4vw;
    position: relative;
    text-align: center;
}
.bottom-sec .txt-box .ttl::before {
    position: absolute;
    content: "";
    background: url(../images/common/bottom-sec-deco.png)no-repeat;
    background-size: contain;
    width: 11.114vw;
    height: 12.08vw;
    top: -15vw;
    left: 48%;
    transform: translateX(-50%);
}
.bottom-sec .txt-box .txt {
    font-weight: bold;
    font-size:3.865vw;
    letter-spacing: 0.05em;
    line-height: 2;
}
.bottom-sec .photo {
    order: 1;
}

}