/* cases page 
cases archive page  */
section:last-child {
    padding-bottom: 0;
}


section ul{
    width: 95%;
    max-width: 1188px;
    align-self: center;
}
@media screen and (max-width: 880px) {
    section ul{
        width: 87.201%;
    }
}

.cases_top_section{
    padding-top: 80px;
    gap: 80px;
    margin-top: 96px;
}

.cases_top_title {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.cases_top_title h2{
}

.cases_top_container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 62px;
}

.cases_top_container .cases_top_text {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.cases_top_container .cases_top_text span {
    display: flex;
    color: var(--black-0, #252729);
    font-size: 20px;
    line-height: normal;
}
.cases_top_container .cases_top_text span br{
    display: none;
}
.cases_top_container .cases_top_btn {
    display: block;
    width: 100%;
    max-width: 592px;
    margin: 0 auto;
    height: 98px;
    background-color: #fff;
    border-radius: 10px;
    border-radius: 6px;
    background: var(--Color, #FFF);
    box-shadow: 2px 4px 8px 0px rgba(0, 0, 0, 0.20);
}
.cases_top_container .cases_top_btn_main {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    position: relative;
    margin-left: 20px;
    height: inherit;
    margin-right: 20px;
}
.cases_top_container .cases_top_btn_main .cases_top_btn_img {
    width: 100%;
    max-width: 192px;
    position: relative;
    bottom: 15px;
}
.cases_top_container .cases_top_btn_main .cases_top_btn_img img{
    display: block;
    width: 100%;
    height: auto;
}
.cases_top_container .cases_top_btn_main .cases_top_btn_text{
    display: flex;
    flex-direction: column;
}
.cases_top_container .cases_top_btn_main .cases_top_btn_text .cases_top_btn_text_top{
    display: flex;
    color: var(--blue, #0974E8);
    font-size: 16px;
    line-height: normal;
}
.cases_top_container .cases_top_btn_main .cases_top_btn_text .cases_top_btn_text_bottom{
    display: flex;
    color: var(--blue, #0974E8);
    font-size: 24px;
    line-height: normal;
}
.cases_top_container .cases_top_btn:hover{
    box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}

@media screen and (max-width: 880px) {
    .cases_top_section {
        width: 87.202%;
        padding-top: 64px;
        margin-top: 49px;
        gap: 64px;
    }
    .cases_top_container .cases_top_text span {
        font-size: 14px;
    }
    .cases_top_container .cases_top_btn_main .cases_top_btn_text .cases_top_btn_text_top{
        font-size: 12px;
    }
    .cases_top_container .cases_top_btn_main .cases_top_btn_text .cases_top_btn_text_bottom{
        font-size: 18px;
    }
}

@media screen and (max-width: 650px) {
    .cases_top_container .cases_top_text span br{
        display: block;
    }
    .cases_top_container .cases_top_text {
        align-items: baseline;
    }
    .cases_top_container .cases_top_btn_main {
        flex-direction: column;
        gap: 0;
        margin-bottom: 16px;
    }
    .cases_top_container .cases_top_btn {
        height: auto;
    }
    .cases_top_container .cases_top_btn_main .cases_top_btn_text {
        margin-bottom: 12px;
        align-items: center;
    }
    .cases_top_container .cases_top_btn_main .cases_top_btn_img {
        bottom: 32px;
        height: 96px;
    }
}


/* filter  */
.archive_filter_section{
    display: flex;
    flex-direction: row;
    gap: 40px;
    align-self: center;
    justify-content: center;
}
.archive_filter_section .section_main{
    gap: 24px;
    width: 95%;
    max-width: 1188px;
    padding-top: 0;
}
.archive_filter_section .section_main .cases_category_filter{
    display: flex;
    align-items: center;
    width: 100%;
}
.archive_filter_section .section_main .cases_category_filter > span{
    color: var(--black, #252729);
    text-align: right;
    
    font-size: 14px;
    line-height: normal;
}
.cases_filter_title{
    display: flex;
    flex-direction: row;
    gap: 24px;
    align-items: center;
    margin-right: 24px;
    padding-right: 24px;
    border-right: 1px solid var(--gray-30, #DCDEE0);
}

.cases_filter_title .cases_all_select > input[type="radio"]{
    display: none;
}
.archive_filter_section .section_main .cases_category_filter .cases_label_box > label > input[type="radio"]{
    display: none;
}
.archive_filter_section .section_main .cases_category_filter .cases_label_box > label > span,
.cases_filter_title .cases_all_select > span{
    display: inline-block;
    padding: 5px 10px;
    background-color: var(--white, #FFFFFF);
    border: 1px solid var(--blue, #0974E8);
    border-radius: 5px;
    transition: all 0.3s ease;
    color: var(--blue, #0974E8);

    font-size: 12px;
    font-weight: 400;
    line-height: normal;
}
.archive_filter_section .section_main .cases_category_filter .cases_label_box > label > input[type="radio"]:checked + span,
.cases_filter_title .cases_all_select > input[type="radio"]:checked + span{
    background-color: var(--blue, #0974E8);
    color: #fff !important;  /* 選択すると文字色のスタイルが適用されないため、この場合のみimportantを追加 (09.30) */
    border-color: var(--blue, #0974E8);
}
.cases_label_box{
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.cases_filter_title label,
.cases_label_box label{
    cursor: pointer;
}
.cases_filter_title > label{
    display: flex;
    width: max-content;
}
.cases_filter_title_span{
    display: flex;
    width: max-content;
    text-align: right;
    min-width: 140px;
    justify-content: right;
}
.cases_filter_title_span > span{
    font-size: 14px;
    display: flex;
}

@media screen and (max-width: 768px) {
    .archive_filter_section .section_main {
        width: 87.201%;
    }
}
@media screen and (max-width: 680px) {
    .archive_filter_section .section_main .cases_category_filter{
        display: flex;
        flex-direction: column;
        gap: 8px;
        align-items: baseline;
    }
    .cases_filter_title {
        border-bottom: 1px solid var(--gray-30, #DCDEE0);
        border-right: none;
        width: 100%;
        padding: 0;
        margin: 0;
        padding-bottom: 8px;
        flex-direction: column;
        align-items: baseline;
        gap: 8px;
    }
    .cases_filter_title_span{
        justify-content: unset;
    }
}

.sol_form_main{
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 95%;
    max-width: 640px;
}
.sol_form_main .sol_form_top_deco{
    display: flex;
    gap: 24px;
    align-items: center;
}
.sol_form_main .sol_form_top_deco .miniformtitlebox{
    display: none;

}
.sol_form_main .sol_form_top_deco .miniformtitlebox span{
    color: var(--blue, #0974E8);
    text-align: center;
    font-size: 24px;
    line-height: normal;
}

.sol_form_main .sol_form_top_deco .imgbox{
    display: flex;
}
.sol_form_main .sol_form_top_deco .imgbox img{
    display: block;
    width: 100%;
    height: auto;
    max-width: 140px;
}
.sol_form_main .sol_form_top_deco .txtbox{
    
}
.sol_form_main .sol_form_top_deco .txtbox > span{
    color: var(--black, #252729);
    text-align: center;
    font-size: 24px;
    line-height: normal;
}
.sol_form_main .sol_form_top_deco .txtbox > ul{
    display: flex;
    flex-direction: column;
    list-style: disc;
    padding: revert;
    padding-left: 27px;
}
.sol_form_main .sol_form_top_deco .txtbox > ul > li{
    color: var(--black, #252729);

    font-size: 16px;
    font-weight: 400;
    line-height: 200%; /* 32px */
}

.sol_form_main .sol_form_top_deco .txtbox p{
    display: flex;
    flex-direction: column;
}
.sol_form_main .sol_form_top_deco .txtbox p span{
    color: var(--black, #252729);
    font-size: 24px;
    line-height: normal;
}
.sol_form_main .sol_form_top_deco .txtbox .sol_public_txt{
    color: var(--black-0, #252729);
    font-size: 16px;
    font-weight: 400;
    line-height: 200%; /* 32px */
    margin-top: 16px;
    display: flex;
}


.sol_form_main .sol_form_area{
    display: flex;
    padding-top: 32px;
    padding-bottom: 32px;
    flex-direction: column;
    border-radius: 6px;
    background: var(--white, #FFF);
}
.sol_form_main .sol_form_area .title{
    display: flex;
    flex-direction: column;
    text-align: center;
    letter-spacing: inherit;
    font-feature-settings: normal;
}
.sol_form_main .sol_form_area .title span{
    color: var(--blue, #0974E8);
    text-align: center;

    font-size: 20px;
    line-height: normal;
}
.sol_form_main .sol_form_area .title .blue_txt_lgr{
    font-size: 32px;
}

/* bottom form custom */
.sol_form_main .sol_form_area .bot_form_main{
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: center;
}
.sol_form_main .sol_form_area .bot_form_main .hbspt-form{
    display: flex;
    justify-content: center;
    width: 100%;
    margin-top: 16px;
    margin-bottom: 16px;
}
.sol_form_main .sol_form_area .bot_form_main .hbspt-form form{
    
}
.sol_form_main .sol_form_area .bot_form_main .btndiv{
    display: flex;
    width: 100%;
    justify-content: center;
}
.sol_form_main .sol_form_area .bot_form_main .btndiv button span{
    color: var(--white,  #FFF);
    text-align: center;

    font-size: 14px;
    line-height: normal;
}

@media screen and (max-width: 650px) {
    .sol_form_main {
        gap: 0px;
    }
    .sol_form_main .sol_form_area .bot_form_main .hbspt-form form {
        width: 91.79%;
    }
    .sol_form_main .sol_form_top_deco {
        flex-direction: column;
    }
    .sol_form_main .sol_form_top_deco .txtbox > span {
        display: flex;
        justify-content: center;
        font-size: 20px;
    }
    .sol_form_main .sol_form_area {
        background: transparent;
        padding-bottom: 0;
    }
    .sol_form_main .sol_form_top_deco .miniformtitlebox{
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        letter-spacing: inherit;
        font-feature-settings: normal;
    }
    .sol_form_main .sol_form_area .title {
        display: none;
    }
    .sol_form_main .sol_form_top_deco .imgbox img {
        max-width: 240px;
    }

    .sol_form_main .sol_form_top_deco .txtbox p span{
        font-size: 20px;
    }
    
    .sol_form_main .sol_form_top_deco .txtbox .sol_public_txt{
        margin-top: 0;
        text-align: left;
    }
    .sol_form_main .sol_form_top_deco .txtbox p span{
        text-align: center;
    }
}
@media screen and (max-width: 450px) {
    .sol_form_main .sol_form_top_deco .txtbox {
        width: 91.79%;
        display: flex;
        flex-direction: column;
        gap: 8px;
    }
}

.cases_archive_list_section{
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding-bottom: 80px;
    align-items: center;
    position: relative;
}
.cases_archive_list_section .card-list-container{
    flex-direction: row;
    flex-wrap: wrap;    
}
@media screen and (max-width: 768px) {
    .cases_archive_list_section {
        padding-bottom: 64px;
    }
}

/* card custom -archive page  */
.card-description .card_title_catchprize{

}
.card-description .card_title_catchprize h1,
.card-description .card_title_catchprize h2,
.card-description .card_title_catchprize h3,
.card-description .card_title_catchprize h4,
.card-description .card_title_catchprize h5,
.card-description .card_title_catchprize h6,
.card-description .card_title_catchprize p,
.card-description .card_title_catchprize span,
.card-description .card_title_catchprize p span,
.card-description .card_title_catchprize p > span{
    color: var(--blue-0, #0974E8) !important;  /* キャッチプライズ編集 wp-adminページで色を指定する場合、適用されないので、importantで色を指定します。 */
    font-family: "Noto Sans JP";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.cases_filter_loading{
    position: absolute;
    top: 0;
    margin-top: 0;
    width: 100%;
}

.added_more_btn {
    position: relative;
    bottom: unset;
    display: flex;
    width: 100%;
    /* display: grid; */
    grid-column: 1 / -1;
}
.button-container.center {
    padding-top: 0;
    width: 100%;
    justify-items: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
.blu_txt_top_alnk{
    color: var(--blue-0, #0974E8);
    text-align: center;
    
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}
.blu_txt_top_alnk:hover{
    color: var(--blue-10, #075BB7);
    transition: all .3s;
}


@media screen and (max-width: 768px) {
    .cases_archive_list_section .card-list-container {
        gap: 24px;
    }
    .button-container > a {
        margin: 0px auto;
        margin-bottom: 0px;
    }
}

.cases_related_section{
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* single cases image */
.content-inner article img{
    border-radius: 0 !important;
}


/* single cases cta  */
.cases_single_cta_main{
    display: flex;
    flex-direction: column;
    gap: 24px;
    align-items: center;
    padding-bottom: 80px;
    width: 95%;
    max-width: 1200px;
    background: var(--blue-50, #F1F8FE);
    padding-top: 80px;
    margin-bottom: 80px;
    padding-left: 40px;
    padding-right: 40px;
    margin-top: 80px;
}
.cases_single_cta_main .cases_single_cta_main_inner{
    display: flex;
    flex-direction: row;
    gap: 20px;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left{
    display: flex;
    width: 100%;
    max-width: 446px;
    flex-direction: column;
    align-self: center;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_title{
    color: var(--blue, #0974E8);
    font-size: 40px;
    font-weight: 700;
    line-height: normal;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_content{
    display: flex;
    flex-direction: column;
    margin-top: 24px;
    margin-bottom: 32px;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_content span{
    color: var(--black-0, #252729);
    font-size: 16px;
    font-weight: 400;
    line-height: 200%; /* 32px */
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right{
    display: flex;
    width: 100%;
    max-width: 480px;
    align-items: center;
    flex-direction: column;
    align-self: center;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right img{
    display: block;
    width: 100%;
    height: auto;
}
.cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right .mini_cta_title_box{
    display: none;
}
.cases_related_section .button-container{
    display: flex;
    width: 100%;
    justify-content: center;
}
@media screen and (max-width: 970px) {
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_title {
        font-size: 30px;
    }
}

@media screen and (max-width: 768px) {
    .cases_single_cta_main {
        padding-bottom: 64px;
        padding-left: 0px;
        padding-right: 0px;
        width: 100%;
        padding-top: 64px;
        margin-bottom: 64px;
        margin-top: 64px;
    }
    .cases_single_cta_main .cases_single_cta_main_inner {
        display: flex;
        flex-direction: column-reverse;
        gap: 16px;
        align-items: center;
        width: 87.202%;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right .mini_cta_title_box{
        display: flex;
        flex-direction: column;
        gap: 8px;
        font-size: 20px;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right .mini_cta_title_box > h2{
        font-size: 20px;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_content span {
        font-size: 14px;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_title {
        display: none;
        
    }
    .cases_single_cta_main_inner_left_btn{
        display: flex;
        justify-content: center;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .cases_single_cta_main_inner_left_content {
        margin-top: 0px;
    }
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_right {
        gap: 16px;
    }
    
    .cases_single_cta_main .cases_single_cta_main_inner .cases_single_cta_main_inner_left .blu_button_line {
        max-width: 327px;
    }
    .cases_related_section .button-container > a {
        max-width: 327px;
    }
}

#cases_theme {
	font-style: normal;
}
.article-title-container > span {
    font-weight: 400;
}

.client-detail-box {
    display: flex;
    flex-direction: row;
}
.article-title {
    color: var(--black-0, #252729);
    font-size: 32px;
}
.client-detail-box > .content {
    display: flex;
    flex-direction: column;
    width: 100%;
}
article > header {
    margin-bottom: 0;
}
#case-header-custom{
    margin-bottom: 0;
}
.article-title-container-custom {
    padding: 24px;
    width: 86.044%;
    /* position: absolute; */
    display: block;
    max-width: 878px;
    position: relative;
    top: -120px;
    background: var(--Color, #FFF);
}
.article-title-container-custom span{
    color: var(--black-0, #252729);
    font-size: 16px;
    font-weight: 400;
}
.article-title-container-custom a{
    color: #0974E8;
}

.content-inner article .article-content-custom{
    margin-bottom: 0;
}

.article-content-custom{
    display: flex;
    flex-direction: column;
    top: -120px;
    position: relative;
    margin-top: 40px;
    align-items: center;
}

.article-content-container {
    margin: 0 auto;
}
.client-detail-box {
    background: var(--gray-40, #F7F7F8);
    border: none;
    border-radius: 0;
}
.client-detail-box > .img_div{
    background-color: var(--white, #fff);
    display: flex;
    max-width: 160px;
    align-items: center;
    height: 80px;
}
.client-detail-box > .img_div img{
    display: block;
    width: 100%;
    height: auto;
}
@media screen and (max-width: 767px) {
    .article-title-container-custom {
        top: 0;
        padding: 0px;
        padding-top: 24px;
        width: 100%;
    }
    .article-content-custom{
        top: 0;
        margin-top: 32px;
    }
    .client-detail-box {
        flex-direction: column;
    }
    .article-title {
        font-size: 24px;
    }
    .article-title-container-custom span{
        font-size: 12px;
    }
    .client-detail-box {
        flex-direction: column;
        padding: 16px;
        width: 100%;
    }
}

/* case page form custom */
.hbspt-form form{
    display: unset;
    flex-direction: unset;
}
.hbspt-form form .form-columns-0 .body2{
    display: none;
}
.hbspt-form form .form-columns-0 .body2{
    display: none;
}
.hbspt-form form fieldset.form-columns-1 .input {
    margin-right: 0;
}
.hbspt-form form fieldset.form-columns-1 .hs-input {
    width: 100%;
    margin-right: 0;
}
.hbspt-form form fieldset > div{
    margin-bottom: 1.2rem;
}
.hbspt-form form .form-columns-2 {
    display: flex;
    align-items: end;
}
.hbspt-form form .hs_firstname .hs-error-msg,
.hbspt-form form .hs_lastname .hs-error-msg {
    font-size: 1.2rem;
    position: absolute;
    line-height: 1.3;
}
fieldset > div:not(.hs_utm_term):not(.hs_utm_source):not(.hs_utm_medium):not(.hs-richtext) {
    margin-bottom: 1.6rem;
}
.hs_firstname > label{ 
    display: none !important;
}
.hbspt-form form .hs_firstname ul,
.hbspt-form form .hs_lastname ul {
    margin-top: 0;
}