@charset "utf-8";

body{
    counter-reset: number 0; 
    font-family: "Noto Serif JP", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}

.header_nav02_item.completion::before {
    content: "";
    width: 80%;
    height: 4px;
    background: #466172;
}

.subhead_ttl{
    font-family: "Cormorant Infant", serif!important;
}

.subhead_ttlsub{
    font-family: "Cormorant Infant", serif!important;
    position: absolute;
    left: 50%;
    top: 54%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 1.2vw;
    letter-spacing: 0.1em;
    white-space: nowrap;
    text-align: center;   /* ← 追加 */
}




@media screen and (max-width: 1000px) {
    .header_nav02_item.completion {
        background: #555555;
        color: #fff;
    }
    .subhead_ttlsub{
        font-size: 2vw;
        top: 57%;
    }
}
@media screen and (max-width: 650px) {
    .subhead_ttlsub {
        font-size: 3.2vw;
        top: 54%;
    }
}



/* completion */
#wrapper {
    overflow-x: initial;
    overflow: clip
}
.subhead_box.mb0 {
    margin-bottom: 0;
}
.cap_pd20 {
    padding: 20px 0;
}
.cap_pt20 {
    padding-top: 20px;
}
.txt_wht {
    color: #fff;
}
.merit_sec01 {
    background: #f9f4ed;
    padding-top: 1px;
    margin-top: -1px;
    /* padding-bottom: 60px; */
}
.merit_sec02 {
    background: #0a1c2d;
    padding-top: 1px;
    margin-top: -1px;
    padding: 60px 0;
}
.merit_sec02 .sec_ttl_box{
    margin-bottom: 0;
}

.merit_sec02 .merit_sec02_cap{
    font-size: 12px;
    color: #999;
    margin-top: 40px;
    text-align: center;
}


.bg_area{
    background: #f9f4ed;
    padding-top: 60px;
}

.cont_wrap{
    padding-bottom: 80px;
}

.img_sp{
    display: none;
}

@media screen and (max-width: 650px) {

.cont_wrap{
    padding-bottom: 60px;
}

.bg_area{
    padding-top: 40px;
}

.img_pc{
    display: none;
}
.img_sp{
    display: block;
}

.merit_sec02 {
    padding: 40px 0;
}

}


/* ナビボタン */
.lnav {
    width: 100%;
    position: sticky;
    top: 130px;
    left: 0;
    z-index: 99;
}

.lnav ul {
    display: flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    justify-content: space-between;
    -webkit-box-align: stretch;
    align-items: stretch;
    width: 100%;
    max-width: 1000px;
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
    z-index: 3;
    padding: 10px 20px;
    background: #f9f4ed;
}
.lnav ul li { 
    width: calc((100% - 32px)/5);
}
.lnav ul li img {
    width: 100%;
    height: auto;
    line-height: 1; 
}
.lnav ul li a {
    position: relative;
    background-color: #a6a6a6;
    display: block;
    width: 100%;
    padding: 5px;
    color: #f9f4ed;
    transition: all 0.4s ease;
    text-align: center;
    height: 100px;
}
.lnav ul li a .icon {
    width: 80%;
    max-width: 90px;
    margin: auto;
    transition: all 0.4s ease;
}
.lnav ul li a .note {
    margin-top: 8px;
}
.lnav ul li a::after {
    content: "";
    display: block;
    aspect-ratio: 1/0.48;
    width: 14px;
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    background-color: #f9f4ed;
    margin: 10px auto 0;
    transition: all 0.4s ease;
}
.lnav ul li a.current, .lnav ul li a:hover {
    color: #fff;
    background-color: #0a1c2d;
    color: #f9f4ed;
}
.lnav ul li a.current::after, .lnav ul li a:hover::after { 
    background-color: #fff; 
}
.note {
    font-size: 0.8rem;
    line-height: 1.6;
}


.merit_link{
    padding-top: 250px;
    margin-top: -250px;
}
@media screen and (max-width: 1000px) {
.lnav { 
    top: 60px; 
}
.lnav ul li a {
    height: 50px;
}
.lnav ul li a .note { 
    display: none; 
} 
.lnav ul li a .icon {
    max-width: 80px;
}

.merit_link{
    padding-top: 130px;
    margin-top: -130px;
}
}
/* ナビボタン end */

/* 見出し */
.midashi {
    padding-top: 80px;
    text-align: center;
}

.txt-s {
    font-size: 0.7em;
}

.mark{
    position: relative;
}

.mark::after{
    content: "※";
    position: absolute;
    top: 0.2em;
    right: 0.5em;
    font-size: 45%;
    line-height: 1;
    color: inherit;          /* ← 色を絶対に継承 */
    font-weight: normal;     /* ← 太字崩れ防止 */
    pointer-events: none;
}



.ttl_icon_box{
    max-width: 200px;
    width: 100%;
    border-top: #0a1c2d 1.4px solid;
    border-bottom: #0a1c2d 1.4px solid;
    margin: 0 auto;
}
.ttl_icon{
    max-width: 110px;
    width: 100%;
    padding: 20px 0;
    margin: 0 auto;
}

.midashi .ja {
    margin-top: 40px;
    font-size: 34px;
    line-height: 1.8;
}

.txt-c {
    text-align: center;
}

.aw {
    font-weight: bold;
}
@media screen and (max-width: 1000px) {
.midashi .ja {
    font-size: 28px;
}
}
@media screen and (max-width: 650px) {
.midashi {
    padding-top: 60px;
}

.midashi .ja {
    font-size: 22px;
}

.ttl_icon_box {
    max-width: 150px;
}
.ttl_icon{
    max-width: 90px;
}
    
}
@media screen and (max-width: 500px) {
    .midashi .ja {
        font-size: 20px;
    }
}

/* merit1 */
.flex_img_box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1000px;
    width: 100%;
    margin: 70px auto 0;
}

.flex_img_item{
    max-width: 490px;
    width: 49%;
}

@media screen and (max-width: 650px) {
.flex_img_box{
    margin: 40px auto 0;
}

.flex_img_item{
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
}
.flex_img_item:last-of-type{
    margin-top: 20px;
}

}

/* uc */
.uc {
    width: 100%;
    border: 1.4px solid #422d29;
    margin-top: 50px;
}

.uc .uc-head {
    background-color: #422d29;
    padding: 0.8rem;
    text-align: center;
    color: #fff;
    letter-spacing: 0.1em;
}

.uc .uc-txt {
    padding: 20px 0;
}

.uc-txt .sec_lead{
    margin-top: 0;
}

@media screen and (max-width: 650px) {
.uc {
    margin-top: 40px;
}

.uc-head p{
    font-size: 14px;
}
}


/* merit2 */
.bg_blue{
    background: #0a1c2d
}
.bg_blue .uc-txt{
    background: #f9f4ed;
}

.bg_blue .cap p{
    color: #a3a3a3;
}

.merit_flex_box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1000px;
    width: 100%;
    color: #f9f4ed;
    padding-top: 100px;
    align-items: center;
}

.merit_flex_item{
    max-width: 500px;
    width: 50%;
}

.merit_flex_box .midashi{
    padding: 0;
    text-align: left;
}

#Merit2_area .ttl_icon_box{
    border-top: #f9f4ed 1.4px solid;
    border-bottom: #f9f4ed 1.4px solid;
    margin: initial;
}

.merit_flex_box .ttl_icon_box{
    margin-right: auto;
}

.merit_flex_box .txt-c {
    margin-top: 40px;
    text-align: left;
}

@media screen and (max-width: 800px) {
.merit_flex_box{
    justify-content: center;
    padding-top: 60px;
}

.merit_flex_item{
    max-width: 650px;
    width: 100%;
}

#Merit2_area .ttl_icon_box{
    margin: 0 auto;
}

.merit_flex_box .midashi{
    text-align: center;
}

.merit_flex_box .txt-c {
    text-align: center;
}

.merit_flex_item:nth-of-type(2){
    margin-top: 40px;
}
}

@media screen and (max-width: 800px) {
.merit_flex_item{
    max-width: 500px;
}
}


/* merit3 */
#Merit3_area .merit_flex_box{
    color: #0a1c2d;
}

#Merit3_area .ttl_icon_box{
    margin: initial;
}

.merit_flex_item03{
    display: flex;
    max-width: 500px;
    width: 100%;
}

.merit_flex_item03 div{
    width: 50%;
}

.merit_flex_item05{
    max-width: 500px;
    width: 50%;
}

.merit_flex_item04{
    max-width: 450px;
    width: 45%;
}

@media screen and (max-width: 800px) {
#Merit3_area .ttl_icon_box{
    margin: 0 auto;
}

.merit_flex_item04{
    max-width: 650px;
    width: 100%;
}

.merit_flex_item05{
    max-width: 500px;
    width: 100%;
    order: 1;
    margin-top: 40px;
}

#Merit3_area .cap_pd20{
    padding-bottom: 0;
}
}

/* merit4 */
#Merit4_area .ttl_icon_box{
    border-top: #f9f4ed 1.4px solid;
    border-bottom: #f9f4ed 1.4px solid;
}

#Merit4_area .text{
    color: #f9f4ed;
}

.merit4_img{
    margin-top: 60px;
}

@media screen and (max-width: 1000px) {
.merit4_img{
    margin: 40px auto 0;
    max-width: 500px;
}
}