.usui_hakkei_main{
    background-image: url(../img/kumo3.png), url(../img/kumo2.png);
    background-repeat: no-repeat, no-repeat;
    background-position: bottom -20px left, bottom -20px right;
    background-color: #f9f6f4;
}
.usui_hakkei_main .title{
    background-image: url(../img/kv_gara.png), url(../img/kv_back.jpg);
    background-repeat: no-repeat, no-repeat;
    background-size: auto, cover;
    padding: 60px 0;
}
.usui_hakkei_main .title .page-title{
    text-align: center;
    font-size:28px;
    color: #442708;
}
.usui_hakkei_main .common_frame{
    max-width: 1160px;
    width: calc(100% - 30px);
    margin:0 auto;
}
.usui_hakkei_main .index_section{
    padding: 60px 0;
}
.usui_hakkei_main .index_section .box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.usui_hakkei_main .index_section .exp,
.usui_hakkei_main .index_section .index{
    width: calc(50% - 20px);
}
.usui_hakkei_main .index_section .exp p{
    font-size: 16px;
    line-height: 1.7;
    margin-bottom: 20px;
}
.usui_hakkei_main .index_section .index ul.btns{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.usui_hakkei_main .index_section .index ul.btns li{
    width: calc(50% - 5px);
    margin-bottom: 15px;
}
.usui_hakkei_main .index_section .index ul.btns li a{
    display: block;
    width: 100%;
    padding:20px;
    color: white;
    background-color: #5c7c3f;
    text-align: center;
    border-radius: 30px;
    text-decoration: none;
    font-weight: bold;
    transition: 0.3s ease all;
    position: relative;
}
.usui_hakkei_main .index_section .index ul.btns li a:hover{
    opacity: 0.8;
}
.usui_hakkei_main .index_section .index ul.btns li a:after{
    content: '';
    width: 8px;
    height: 8px;
    margin-top: -4px;
    border-bottom: solid 2px white;
    border-right: solid 2px white;
    transform: rotate(45deg);
    position: absolute;
    top: 47%;
    right: 15px;
}
@media (max-width: 767px) { 
    .usui_hakkei_main .index_section{
        padding: 20px 0 40px 0;
    }
    .usui_hakkei_main .index_section .box{
        display: block;
    }
    .usui_hakkei_main .index_section .exp,
    .usui_hakkei_main .index_section .index{
        width: 100%;
    }
}

.usui_hakkei_main .hakkei_section .spot_title{
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 20px;
    line-height: 1.4;
}
.usui_hakkei_main .hakkei_section .spot_title .cap{
    font-size: 18px;
    font-weight: normal;
    margin-top: 8px;
}
@media (max-width: 767px) { 
    .usui_hakkei_main .hakkei_section .spot_title{
        font-size:22px;
    }
    .usui_hakkei_main .hakkei_section .spot_title .cap{
        display: block;
    }
}
.usui_hakkei_main .hakkei_section .box{
    padding-bottom: 60px;
}
.usui_hakkei_main .hakkei_section .banmen{
    display: flex;
    align-items: stretch;
}
.usui_hakkei_main .hakkei_section .banmen.no-photo{
    justify-content: center;
}
.usui_hakkei_main .hakkei_section .banmen .child{
    width: 50%;
    max-height: 340px;
    height: clamp(200px, 30vw, 340px);
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
}
.usui_hakkei_main .hakkei_section .banmen.no-photo .child{
    width: 100%;
    max-width: 600px;
    height: auto;
}
.usui_hakkei_main .hakkei_section .banmen .child .img{
    object-fit: cover;
    width:100%;
    height:100%;
}
.usui_hakkei_main .hakkei_section .banmen .child a{
    transition: 0.3s ease all;
    position: relative;
    height:100%;
    display: block;
}
.usui_hakkei_main .hakkei_section .banmen .child a:hover{
    opacity: 0.8;
}
.usui_hakkei_main .hakkei_section .banmen .child a.link-banmen:before{
    content: "クリック・タップでPDFを表示";
    position: absolute;
    color: white;
    font-size: 13px;
    right:15px;
    bottom: 15px;
    padding: 7px 12px;
    border-radius: 20px;
    background: rgba(92,124,63,0.8);
}

@media (max-width: 767px) { 
    .usui_hakkei_main .hakkei_section .banmen{
        display: block;
    }
    .usui_hakkei_main .hakkei_section .banmen .child{
        width: 100%;
        max-width: 600px;
        margin:auto;
        max-height: 380px;
        height: clamp(200px, 56vw, 380px);
    }
}