@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/*======================================================*/
/* for cocoon */
/*======================================================*/
html,
body {
    overflow-x: clip;
}

a {
    text-decoration: none;
    transition: all 0.3s;
}

.wrap {
    width: 100%;
}

.main,
main.main {
    background-color: transparent;
    border: none;
    padding: 0;
}

.content {
    margin-top: 0;
}

.content ul {
    padding-left: 1em;
}

.content ul li {
    font-size: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
    line-height: 2;
}

.content ul li:not(:first-child) {
    padding-top: 1em;
}
/*rechaptchaアイコン非表示*/
.grecaptcha-badge {
    visibility: hidden;
}
/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {}

/*834px以下*/
@media screen and (max-width: 834px) {
    li {
        font-size: clamp(14px, calc(14px + (2 / 353) * (100vw - 481px)), 16px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    /*必要ならばここにコードを書く*/
}

/*======================================================*/
/* for cocoon ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*共通コンテナ*/
/*======================================================*/
.stdtemp_box {
    padding: 0 clamp(30px, calc(30px + (120 / 896) * (100vw - 1024px)), 150px);
}

.stdtemp_inner p {
    font-size: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
    line-height: 2;
    margin-bottom: 1em;
}

.stdtemp_content {
    max-width: 1100px;
    margin: 0 auto;
    padding-top: calc(clamp(100px, calc(100px + (50 / 896) * (100vw - 1024px)), 150px) + 60px);
}

.stdtemp_content h1 {
    text-align: center;
    border-bottom: solid 2px #fff;
    padding-bottom: clamp(40px, calc(40px + (10 / 896) * (100vw - 1024px)), 50px);
    line-height: 1.5;
}

.stdtemp_content time {
    display: block;
    text-align: right;
    font-size: 14px;
    padding-top: 1em;
}

.stdtemp_inner {
    margin-top: clamp(40px, calc(40px + (10 / 896) * (100vw - 1024px)), 50px);
    border-bottom: solid 1px #fff;
    padding-bottom: clamp(100px, calc(100px + (50 / 896) * (100vw - 1024px)), 150px);
}

.stdtemp_inner h2 {
    font-size: clamp(24px, calc(24px + (4 / 896) * (100vw - 1024px)), 28px);
    border-top: solid 2px #34C8D9;
    border-bottom: solid 2px #3DBEA3;
    background-color: #34C8D91A;
    padding: 0.5em 0.71em;
    line-height: 1.5;
    margin-top: calc(2em + calc(16px + (4 / 896) * (100vw - 1024px)));
    margin-bottom: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
}

.stdtemp_inner h3 {
    position: relative;
    font-size: clamp(20px, calc(20px + (4 / 896) * (100vw - 1024px)), 24px);
    background-color: #34C8D91A;
    padding: 0.5em calc(0.71em + 6px);
    line-height: 1.5;
    margin-top: calc(1em + calc(16px + (4 / 896) * (100vw - 1024px)));
    margin-bottom: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
}

.stdtemp_inner h3::before,
.stdtemp_inner h3::after {
    content: '';
    display: block;
    width: 3px;
    height: 100%;
    background-color: #34C8D9;
    position: absolute;
    top: 0;
}

.stdtemp_inner h3::before {
    background-color: #34C8D9;
    left: 0;
}

.stdtemp_inner h3::after {
    background-color: #3DBEA3;
    left: 3px;
}

.stdtemp_inner h4 {
    font-size: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
    padding: 0 0.5em 0.5em 0.5em;
    margin-top: calc(1em + calc(16px + (4 / 896) * (100vw - 1024px)));
    margin-bottom: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
    border-bottom: dotted 2px #fff;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .stdtemp_box {
        padding: 0 clamp(30px, calc(30px + (64 / 188) * (100vw - 835px)), 94px);
    }

    .stdtemp_inner p {
        font-size: clamp(14px, calc(14px + (2 / 188) * (100vw - 835px)), 16px);
    }

    .stdtemp_content {
        padding-top: calc(clamp(50px, calc(50px + (50 / 188) * (100vw - 835px)), 100px) + 50px);
    }

    .stdtemp_inner h2 {
        font-size: clamp(20px, calc(20px + (4 / 188) * (100vw - 835px)), 24px);
        margin-top: calc(2em + calc(14px + (2 / 188) * (100vw - 835px)));
        margin-bottom: clamp(14px, calc(14px + (2 / 188) * (100vw - 835px)), 16px);
    }

    .stdtemp_inner h3 {
        font-size: clamp(18px, calc(18px + (2 / 188) * (100vw - 835px)), 20px);
        margin-top: calc(1em + calc(14px + (2 / 188) * (100vw - 835px)));
        margin-bottom: clamp(14px, calc(14px + (2 / 188) * (100vw - 835px)), 16px);
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {
    .stdtemp_box {
        padding: 0 clamp(20px, calc(20px + (157 / 353) * (100vw - 481px)), 177px);
    }

    .stdtemp_content h1 {
        padding-bottom: clamp(30px, calc(30px + (10 / 353) * (100vw - 481px)), 40px);
    }

    .stdtemp_inner {
        margin-top: clamp(30px, calc(30px + (10 / 353) * (100vw - 481px)), 40px);
        padding-bottom: clamp(80px, calc(80px + (20 / 353) * (100vw - 481px)), 100px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    .stdtemp_inner h2 {
        font-size: clamp(18px, calc(18px + (2 / 160) * (100vw - 320px)), 20px);
    }

    .stdtemp_inner h3 {
        font-size: clamp(16px, calc(16px + (2 / 160) * (100vw - 320px)), 18px);
    }
}

/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*フォント*/
/*======================================================*/
/*サイズ*/
.f-s_P34 {
    font-size: clamp(24px, calc(24px + (10 / 896) * (100vw - 1024px)), 34px) !important;
}

.f-s_P24 {
    font-size: clamp(20px, calc(20px + (4 / 896) * (100vw - 1024px)), 24px) !important;
}

.f-s_P20 {
    font-size: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px) !important;
}

.f-s_P20-2 {
    font-size: clamp(18px, calc(18px + (2 / 896) * (100vw - 1024px)), 20px) !important;
}

.f-s_P16 {
    font-size: clamp(14px, calc(14px + (2 / 896) * (100vw - 1024px)), 16px) !important;
}

.f-s_P14 {
    font-size: 14px !important;
}


/*-----------------------------------------*/
/*フォントファミリー*/
.f-f_HGW6 {
    font-family: "FP-ヒラギノ角ゴ ProN W6" !important;
}

.f-f_HGW4 {
    font-family: "FP-ヒラギノ角ゴ StdN W4" !important;
}

.f-af_futuraB {
    font-family: futura-pt, sans-serif !important;
    font-weight: 400;
    font-style: normal;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {

    /*サイズ*/
    .f-s_P34 {
        font-size: clamp(20px, calc(20px + (4 / 188) * (100vw - 835px)), 24px) !important;
    }

    .f-s_P24 {
        font-size: clamp(18px, calc(18px + (2 / 188) * (100vw - 835px)), 20px) !important;
    }

    .f-s_P16 {
        font-size: clamp(12px, calc(12px + (2 / 188) * (100vw - 835px)), 14px) !important;
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {

    /*サイズ*/
    .f-s_P20 {
        font-size: clamp(14px, calc(14px + (2 / 353) * (100vw - 481px)), 16px) !important;
    }

    .f-s_P14 {
        font-size: 12px !important;
    }

}

/*480px以下*/
@media screen and (max-width: 480px) {
    .f-s_P34 {
        font-size: clamp(18px, calc(18px + (2 / 160) * (100vw - 320px)), 20px) !important;
    }

    .f-s_P24 {
        font-size: clamp(16px, calc(16px + (2 / 160) * (100vw - 320px)), 18px) !important;
    }
}

/*======================================================*/
/* フォント ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*グローバルメニュ*/
/*======================================================*/
#navi .navi-in>ul>li>a {
    padding: 0 15px;
}

.site-name-text-link {
    padding: 0 0 0 1em;
}

.header-container {
    background-color: #1C2838E6;
    backdrop-filter: blur(30px) brightness(110%);
    -webkit-backdrop-filter: blur(30px) brightness(110%);
    position: fixed;
    top: 0;
    z-index: 1;
    width: 100%;
}

li.gm_btn {
    width: 180px !important;
    transition: all 0.3s;
}

li.gm_btn-bl {
    background-color: #34C8D9;
    margin-left: 15px;
}

li.gm_btn-gr {
    background-color: #3DBEA3;
}

li.gm_btn:hover {
    opacity: 0.8;
}

li.gm_btn a:hover {
    color: #fff !important;
}

#navi .navi-in a:hover {
    background-color: transparent !important;
}

#navi .navi-in li:nth-child(odd) a:hover {
    color: #3DBEA3;
}

#navi .navi-in li:nth-child(even) a:hover {
    color: #34C8D9;
}

.menu-drawer a {
    color: #000;
}

.menu-content .menu-drawer {
    padding: 30px 2em;
    display: flex;
    flex-direction: column;
    row-gap: 15px;
}

.menu-drawer a:hover {
    background-color: unset;
    color: #34C8D9;
}

.menu-close-button {
    position: absolute;
    right: 10px;
    bottom: 10px;
}

.fa-remove:before,
.fa-close:before,
.fa-times:before {
    content: "\f057";
    color: #ddd;
}

/*固定ボタン*/
.fixbutton_container {
    display: none;
}

/*1460px以下*/
@media screen and (min-width: 1024px) and (max-width: 1399px) {

    li.gm_btn {
        display: none !important;
    }

    /*固定ボタン*/
    .fixbutton_container {
        height: fit-content;
        display: block;
        position: fixed;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto 0;
        z-index: 2;
    }

    .fixbutton_linkbtn {
        width: 50px;
        height: 50px;
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: #323E4C;
        border-radius: 10px 0 0 10px;
        position: relative;
        padding: 13px;
        transition: all 0.3s;
    }

    .fixbutton_linkbtn:hover {
        transform: translateX(-10px);
    }

    .fixbutton_linkbtn:hover::after {
        transform: translateX(10px);
        width: 10px;
    }

    .fixbutton_linkbtn:not(:last-child) {
        margin-bottom: 10px;
    }

    .fixbutton_linkbtn::after {
        content: '';
        display: block;
        width: 3px;
        height: 100%;
        position: absolute;
        top: 0;
        right: 0;
        transition: all 0.3s;
    }

    .fixbutton_linkbtn:nth-child(odd)::after {
        background-color: #34C8D9;
    }

    .fixbutton_linkbtn:nth-child(even)::after {
        background-color: #3DBEA3;
    }
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .site-name-text-link {
        padding: 0 0.5em;
    }

    li.gm_btn {
        width: 100% !important;
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 0.5em 1em;
    }

    li.gm_btn a {
        color: #fff;
    }

    li.gm_btn-bl {
        margin-left: 0;
        margin-top: 20px;
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {}

/*480px以下*/
@media screen and (max-width: 480px) {
    .header-container {
        position: absolute;
    }
}

/*======================================================*/
/*グローバルメニュ　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*リンクボタン*/
/*======================================================*/
/*基本ボタン*/
.linkbtn_bl,
input.linkbtn_bl,
.linkbtn_gr,
.linkbtn_wh {
    display: flex;
    background-color: transparent;
    justify-content: center;
    align-items: center;
    font-family: "FP-ヒラギノ角ゴ ProN W6";
    font-size: clamp(18px, calc(18px + (2 / 896) * (100vw - 1024px)), 20px);
    padding: clamp(14px, calc(14px + (4 / 896) * (100vw - 1024px)), 18px) 1em;
    width: clamp(200px, calc(200px + (50 / 896) * (100vw - 1024px)), 250px);
    text-decoration: none;
    line-height: 1;
    transition: all 0.3s;
}

.linkbtn_bl,
input.linkbtn_bl {
    background-color: #34C8D900;
    border: solid 2px #34C8D9;
    color: #34C8D9;
}

.linkbtn_bl:hover,
input.linkbtn_bl:hover {
    background-color: #34C8D926;
    color: #34C8D9;
}

.linkbtn_gr {
    background-color: #3DBEA300;
    border: solid 2px #3DBEA3;
    color: #3DBEA3;
}

.linkbtn_gr:hover {
    background-color: #3DBEA326;
    color: #3DBEA3;
}

.linkbtn_wh {
    background-color: #ffffff00;
    border: solid 2px #fff;
    color: #fff;
}

.linkbtn_wh:hover {
    background-color: #ffffff26;
    color: #fff;
}

/*サブボタン*/
.linkbtnsub_k,
.linkbtnsub_wh {
    font-size: clamp(14px, calc(14px + (6 / 896) * (100vw - 1024px)), 20px);
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 30px;
    text-decoration: none;
    padding: 0.5em 1.5em;
    line-height: 1;
    transition: all 0.3s;
}

.linkbtnsub_k {
    color: #000;
    border: solid 1px #000;
    background-color: #00000000;
}

.linkbtnsub_wh {
    color: #fff;
    border: solid 1px #fff;
    background-color: #ffffff00;
}

.linkbtnsub_k:hover {
    color: #000;
    background-color: #0000001A;
}

.linkbtnsub_wh:hover {
    color: #fff;
    background-color: #ffffff1A;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {

    .linkbtn_bl,
    .linkbtn_gr,
    .linkbtn_wh {
        font-size: clamp(16px, calc(16px + (2 / 188) * (100vw - 835px)), 18px);
        width: clamp(180px, calc(180px + (20 / 188) * (100vw - 835px)), 200px);
        padding: clamp(12px, calc(12px + (2 / 188) * (100vw - 835px)), 14px) 1em;
    }

    .linkbtnsub_k,
    .linkbtnsub_wh {
        font-size: 14px;
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {

    .linkbtn_bl,
    .linkbtn_gr,
    .linkbtn_wh {
        font-size: 16px;
        width: 180px;
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {

    .linkbtn_bl,
    .linkbtn_gr,
    .linkbtn_wh {
        font-size: clamp(14px, calc(14px + (2 / 160) * (100vw - 320px)), 16px);
        width: clamp(150px, calc(150px + (30 / 160) * (100vw - 320px)), 180px);
    }
}

/*======================================================*/
/*リンクボタン　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*シェイプ可変設定*/
/*======================================================*/
.shape_size img {
    width: clamp(400px, calc(400px + (362 / 896) * (100vw - 1024px)), 762px);
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .shape_size img {
        width: clamp(290px, calc(290px + (110 / 188) * (100vw - 835px)), 400px);
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {
    .shape_size img {
        width: clamp(220px, calc(220px + (70 / 353) * (100vw - 481px)), 290px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    .shape_size img {
        width: clamp(180px, calc(180px + (40 / 160) * (100vw - 320px)), 220px);
    }
}

/*======================================================*/
/*シェイプ可変設定　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*関連記事カルーセル基本設定*/
/*======================================================*/
/*タイトル*/
.relatedatc_area-title {
    line-height: 1;
    margin-bottom: clamp(50px, calc(50px + (20 / 896) * (100vw - 1024px)), 70px);
    display: flex;
    align-items: center;
    gap: 1em;
}

.relatedatc_area-title::before {
    content: '';
    display: block;
    width: clamp(30px, calc(30px + (90 / 896) * (100vw - 1024px)), 120px);
    height: 1px;
    background-color: #fff;
}

.relatedatc_area-title::after {
    content: '';
    display: block;
    width: calc(100% - clamp(30px, calc(30px + (90 / 896) * (100vw - 1024px)), 120px) - 6em);
    height: 1px;
    background-color: #fff;
}

/*swiper*/
.post-carousel-swiper {
    padding: 0 clamp(15px, 1.5vw, 30px) !important;
    margin-bottom: 50px;
}

.swiper-wrapper {
    align-items: stretch;
    width: fit-content;
    margin: auto;
}

.post-carousel-slide {
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.post-carousel-slide:hover .post-thumbnail>a>img,
.related-article_card:hover .post-thumbnail>a>img {
    transform: scale(1.1);
}

.post-carousel-slide:hover .post-meta>.post-title a,
.related-article_card:hover .post-meta>.post-title a {
    color: #34C8D9;
}

.post-thumbnail {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    background-color: #fff;
}

.post-thumbnail img {
    width: 100%;
    height: clamp(200px, calc(200px + (100 / 896) * (100vw - 1024px)), 300px);
    object-fit: cover;
    transition: all 0.3s;
}

.no-thumbnail {
    width: 100%;
    height: clamp(200px, calc(200px + (100 / 896) * (100vw - 1024px)), 300px);
    background-color: #ccc;
}

.post-meta {
    padding: 15px 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    font-size: clamp(16px, 5vw, 18px);
}

.post-category {
    position: absolute;
    bottom: 0;
    right: 0;
    display: inline-block;
    background-color: #000;
    text-decoration: none;
    color: white;
    padding: 2px 8px;
    font-size: 12px;
    margin: 10px;
    transition: all 0.3s;
}

.post-category:hover {
    color: white;
    background-color: #34C8D9;
}

.post-date {
    font-size: 12px;
    color: #fff;
    margin-bottom: 6px;
}

.post-title a {
    text-decoration: none;
    color: #fff;
    transition: all 0.3s;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}


/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {}

/*834px以下*/
@media screen and (max-width: 834px) {

    /*タイトル*/
    .relatedatc_area-title {
        margin-bottom: clamp(40px, calc(40px + (10 / 353) * (100vw - 481px)), 50px);
    }

    .relatedatc_area-title::before {
        width: clamp(20px, calc(20px + (10 / 353) * (100vw - 481px)), 30px);
    }

    .relatedatc_area-title::after {
        content: '';
        display: block;
        width: calc(100% - clamp(20px, calc(20px + (10 / 353) * (100vw - 481px)), 30px) - 6em);
        height: 1px;
        background-color: #fff;
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {}

/*======================================================*/
/*関連記事カルーセル基本設定　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*コンテンツ下部*/
/*======================================================*/
.footertop_content {
    position: relative;
    padding: clamp(132px, calc(132px + (115 / 896) * (100vw - 1024px)), 247px) 0 clamp(29px, calc(29px + (23 / 896) * (100vw - 1024px)), 52px) 0;
    z-index: 0;
}

.footertop_content::before,
.footertop_content::after {
    content: '';
    display: block;
    width: clamp(400px, calc(400px + (364 / 896) * (100vw - 1024px)), 764px);
    height: clamp(182px, calc(182px + (165 / 896) * (100vw - 1024px)), 347px);
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
}

.footertop_content::before {
    background-image: url(/craws/wp-content/uploads/2025/09/shape_b.png);
    top: 0;
    right: clamp(30px, calc(30px + (97 / 896) * (100vw - 1024px)), 127px);
    z-index: 1;
}

.footertop_content::after {
    background-image: url(/craws/wp-content/uploads/2025/06/shape_bgb.png);
    bottom: 0;
    left: clamp(30px, calc(30px + (97 / 896) * (100vw - 1024px)), 127px);
}

.footertop_contactarea {
    display: flex;
    justify-content: center;
    border-top: solid 1px #fff;
    border-bottom: solid 1px #fff;
    overflow-y: clip;
}

.footertop_contactarea-innerline {
    height: auto;
    width: 1px;
    transform: rotate(38deg);
    background-color: #fff;
    display: flex;
    position: relative;
}

.footertop_contactarea-innerline::before,
.footertop_contactarea-innerline::after {
    content: '';
    display: block;
    width: 1px;
    height: 200px;
    background-color: #fff;
    position: absolute;
}

.footertop_contactarea-innerline::before {
    top: -200px;
}

.footertop_contactarea-innerline::after {
    bottom: -200px;
}

.footertop_contactarea-inner {
    width: clamp(352px, calc(352px + (308 / 896) * (100vw - 1024px)), 660px);
    box-sizing: content-box;
}

.footertop_contactarea-inner:first-of-type {
    padding: clamp(50px, calc(50px + (10 / 896) * (100vw - 1024px)), 60px) clamp(100px, calc(100px + (50 / 896) * (100vw - 1024px)), 150px) 0 0;
}

.footertop_contactarea-inner:last-of-type {
    padding: clamp(110px, calc(110px + (40 / 896) * (100vw - 1024px)), 150px) 0 clamp(50px, calc(50px + (10 / 896) * (100vw - 1024px)), 60px) clamp(100px, calc(100px + (50 / 896) * (100vw - 1024px)), 150px);
}

.footertop_contactarea-inner h2 {
    line-height: 1;
}

.footertop_contactarea-inner p {
    padding: 30px 0;
}

.footertop_logoarea {
    width: clamp(746px, calc(746px + (506 / 896) * (100vw - 1024px)), 1252px);
    margin: 0 0 0 auto;
    border-bottom: solid 1px #fff;
}

.footertop_logoarea a {
    display: flex;
    align-items: center;
    justify-content: end;
    padding: clamp(13px, calc(13px + (12 / 896) * (100vw - 1024px)), 25px) clamp(80px, calc(80px + (170 / 896) * (100vw - 1024px)), 250px) clamp(13px, calc(13px + (12 / 896) * (100vw - 1024px)), 25px) 0;
    gap: clamp(20px, calc(20px + (30 / 896) * (100vw - 1024px)), 50px);
    text-decoration: none;
}

.footertop_logoarea a>img {
    height: clamp(76px, calc(76px + (67 / 896) * (100vw - 1024px)), 143px);
}

.footertop_logoarea a>p {
    font-size: 14px;
    padding: 0.8em 2em;
    border: solid 1px #fff;
    border-radius: 5px;
    background-color: #ffffff1A;
    line-height: 1;
    color: #fff;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .footertop_content {
        padding: clamp(101px, calc(101px + (31 / 188) * (100vw - 835px)), 132px) 0 clamp(12px, calc(12px + (17 / 188) * (100vw - 835px)), 29px) 0;
    }

    .footertop_content::before,
    .footertop_content::after {
        width: clamp(290px, calc(290px + (110 / 188) * (100vw - 835px)), 400px);
        height: clamp(132px, calc(132px + (50 / 188) * (100vw - 835px)), 182px);
    }

    .footertop_contactarea-inner {
        width: clamp(300px, calc(300px + (52 / 188) * (100vw - 835px)), 352px);
    }

    .footertop_contactarea-inner:first-of-type {
        padding: 50px clamp(85px, calc(85px + (15 / 188) * (100vw - 835px)), 100px) 0 0;
    }

    .footertop_contactarea-inner:last-of-type {
        padding: clamp(105px, calc(105px + (5 / 188) * (100vw - 835px)), 110px) 0 50px clamp(85px, calc(85px + (15 / 188) * (100vw - 835px)), 100px);
    }

    .footertop_contactarea-inner:last-of-type h2 {
        display: flex;
        justify-content: end;
    }

    .footertop_contactarea-inner p {
        padding: clamp(20px, calc(20px + (10 / 188) * (100vw - 835px)), 30px) 0;
    }

    .footertop_logoarea {
        width: clamp(608px, calc(608px + (138 / 188) * (100vw - 835px)), 746px);
    }

    .footertop_logoarea a>img {
        height: clamp(63px, calc(63px + (13 / 188) * (100vw - 835px)), 76px);
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {
    .footertop_content {
        padding: 101px 0;
    }

    .footertop_content::before {
        right: 0;
    }

    .footertop_content::after {
        left: 0;
    }

    .footertop_contactarea {
        flex-direction: column;
        align-items: center;
        gap: 50px;
        padding: 80px clamp(20px, calc(20px + (10 / 353) * (100vw - 481px)), 30px);
    }

    .footertop_contactarea-inner {
        max-width: 390px;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .footertop_contactarea-innerline {
        height: 1px;
        width: 100%;
        max-width: 480px;
        transform: rotate(0deg);
    }

    .footertop_contactarea-innerline::before,
    .footertop_contactarea-innerline::after {
        content: none;
    }

    .footertop_contactarea-inner:first-of-type,
    .footertop_contactarea-inner:last-of-type {
        padding: 0;
    }

    .footertop_contactarea-inner:last-of-type h2 {
        justify-content: start;
    }

    .footertop_logoarea {
        display: none;
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    .footertop_content {
        padding: clamp(61px, calc(61px + (40 / 160) * (100vw - 320px)), 101px) 0;
    }

    .footertop_content::before,
    .footertop_content::after {
        width: clamp(180px, calc(180px + (110 / 160) * (100vw - 320px)), 290px);
        height: clamp(82px, calc(82px + (50 / 160) * (100vw - 320px)), 132px);
    }
}

/*======================================================*/
/*コンテンツ下部　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*フッター*/
/*======================================================*/
.footer,
.footer-widgets-mobile,
.footer-mobile {
    margin-top: 0;
    padding: 0;
}

.footer-center,
.footer-right {
    display: none;
}

.footer-left {
    width: 100%;
    padding: 0 clamp(30px, calc(30px + (120 / 896) * (100vw - 1024px)), 150px);
}

.footerbottom_content {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.footerbottom_copy {
    width: clamp(272px, calc(272px + (252 / 896) * (100vw - 1024px)), 524px);
    display: flex;
    justify-content: space-between;
    padding-left: clamp(0px, calc(14px - (14 / 896) * (100vw - 1024px)), 14px);
    box-sizing: content-box;
}

.footerbottom_copy p {
    writing-mode: vertical-rl;
    font-family: "FP-ヒラギノ角ゴ StdN W0";
    font-size: clamp(32px, calc(32px + (28 / 896) * (100vw - 1024px)), 60px);
    line-height: 1;
    letter-spacing: 0.3em;
}

ul#menu-footermenu,
ul#menu-footermenu-1 {
    width: clamp(480px, calc(480px + (356 / 896) * (100vw - 1024px)), 836px);
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    column-gap: clamp(30px, calc(30px + (20 / 896) * (100vw - 1024px)), 50px);
    row-gap: clamp(30px, calc(30px + (50 / 896) * (100vw - 1024px)), 80px);
    font-size: clamp(14px, calc(14px + (6 / 896) * (100vw - 1024px)), 20px);
    padding: 0;
}

ul#menu-footermenu li,
ul#menu-footermenu-1 li {
    line-height: 1;
}

ul#menu-footermenu li>a,
ul#menu-footermenu-1 li>a {
    text-decoration: none;
    color: #fff;
    transition: all 0.3s;
}

ul#menu-footermenu li:nth-child(odd)>a:hover,
ul#menu-footermenu-1 li:nth-child(odd)>a:hover {
    color: #34C8D9;
}

ul#menu-footermenu li:nth-child(even)>a:hover,
ul#menu-footermenu-1 li:nth-child(even)>a:hover {
    color: #3DBEA3;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .footerbottom_copy {
        width: clamp(206px, calc(206px + (66 / 188) * (100vw - 835px)), 272px);
        padding-left: clamp(5px, calc(5px + (9 / 188) * (100vw - 835px)), 14px);
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {
    .footerbottom_content {
        width: 100%;
        max-width: 540px;
        flex-direction: column;
        margin: auto;
        padding: clamp(0px, calc(50px - (50 / 353) * (100vw - 481px)), 50px) clamp(20px, calc(20px + (10 / 353) * (100vw - 481px)), 30px) 0;
    }

    .footerbottom_copy {
        width: clamp(178px, calc(178px + (26 / 353) * (100vw - 481px)), 204px);
        padding-left: 0;
    }

    .footertop_logoarea-mobile {
        width: 100%;
        margin: 0 0 0 auto;
    }

    .footertop_logoarea-mobile a {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 20px;
        text-decoration: none;
        padding: clamp(50px, calc(50px + (30 / 353) * (100vw - 481px)), 80px) 0 50px;
    }

    .footertop_logoarea-mobile a>img {
        height: 63px;
    }

    .footertop_logoarea-mobile a>p {
        font-size: 14px;
        padding: 0.5em 1em;
        border: solid 1px #fff;
        border-radius: 5px;
        background-color: #ffffff1A;
        line-height: 1;
        color: #fff;
    }

    ul#menu-footermenu,
    ul#menu-footermenu-1 {
        width: clamp(358px, calc(358px + (182 / 353) * (100vw - 481px)), 540px);
        row-gap: clamp(20px, calc(20px + (10 / 353) * (100vw - 1024px)), 30px);
        column-gap: clamp(20px, calc(20px + (10 / 353) * (100vw - 1024px)), 30px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    .footerbottom_copy {
        width: clamp(156px, calc(156px + (22 / 160) * (100vw - 320px)), 178px);
    }

    ul#menu-footermenu,
    ul#menu-footermenu-1 {
        width: clamp(270px, calc(270px + (88 / 160) * (100vw - 320px)), 358px);
    }
}

/*======================================================*/
/*フッター　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*キャンペーンバナー　↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓*/
/*======================================================*/
.swiper.campaign-slider {
    width: 100%;
    aspect-ratio: 16 / 9;
    border: solid 2px #fff;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3);
}

.swiper.campaign-slider a img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.swiper-wrapper {
    margin: 0;
}

/*-----------------------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {}

/*834px以下*/
@media screen and (max-width: 834px) {}

/*480px以下*/
@media screen and (max-width: 480px) {}

/*======================================================*/
/*キャンペーンバナー ここまで↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*お知らせアーカイブ+詳細ページ*/
/*======================================================*/
.newslist {
    margin-top: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px);
}

.newslist a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    text-decoration: none;
    color: #fff;
    position: relative;
    padding: 15px 0;
    font-family: "FP-ヒラギノ角ゴ StdN W4";
}

.newslist a:not(:first-child) {
    margin-top: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px);
}

.newslist a::before {
    content: '';
    display: block;
    width: 1px;
    height: 1px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
    transition: all 0.3s;
    opacity: 0;
}

.newslist a::after {
    content: '';
    display: block;
    width: 80px;
    height: 40px;
    background-image: url(/craws/wp-content/uploads/2025/06/shape_bgb.png);
    background-size: contain;
    background-repeat: no-repeat;
    transition: all 0.3s;
    transform: translateX(-20px);
    opacity: 0;
    flex-shrink: 0;
}

.newslist_child {
    display: flex;
    align-items: center;
    gap: 20px;
    transform: translateX(40px);
    transition: all 0.3s;
}

.newslist_child h2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    transition: all 0.3s;
}

.newslist_child time {
    font-size: 14px;
    padding: 0;
}

/*ホバー*/
.newslist a:nth-child(odd):hover .newslist_child h2 {
    color: #34C8D9;
}

.newslist a:nth-child(even):hover .newslist_child h2 {
    color: #3DBEA3;
}

.newslist a:hover::before {
    width: 100%;
    opacity: 1;
}

.newslist a:hover::after {
    transform: translateX(0px);
    opacity: 1;
}

.newslist a:hover .newslist_child {
    transform: translateX(0px);
}

/*ページネーション（共通）*/
.pagination {
    margin: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px) 0 50px;
}

.page-numbers {
    border: none;
    border-radius: 0;
}

.current.page-numbers {
    background-color: transparent;
    position: relative;
    color: #34C8D9;
}

.current.page-numbers::after {
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    background-color: #34C8D9;
    position: absolute;
    bottom: 0;
}

.page-numbers.dots {
    background-color: transparent;
}

.next.page-numbers,
.prev.page-numbers {
    border: solid 1px #fff;
    min-width: 80px;
}

.pagination a:hover {
    background-color: #3DBEA3;
}

/*詳細ページ*/
.singlenews a.linkbtn_wh {
    margin: clamp(100px, calc(100px + (50 / 896) * (100vw - 1024px)), 150px) auto;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {}

/*834px以下*/
@media screen and (max-width: 834px) {
    .newslist {
        margin-top: clamp(30px, calc(30px + (20 / 353) * (100vw - 481px)), 50px);
    }

    .newslist a:not(:first-child) {
        margin-top: clamp(30px, calc(30px + (20 / 353) * (100vw - 481px)), 50px);
    }

    .newslist a::after {
        display: none;
    }

    .newslist_child {
        flex-direction: column;
        align-items: start;
        gap: 5px;
        transform: translateX(0);
    }

    /*詳細ページ*/
    .singlenews a.linkbtn_wh {
        margin: clamp(80px, calc(80px + (20 / 353) * (100vw - 481px)), 100px) auto;
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    .page-numbers.dots {
        display: block;
    }
}

/*======================================================*/
/*お知らせアーカイブ+詳細ページ　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*関連記事アーカイブ　詳細はお知らせ同様*/
/*======================================================*/
.related-article h1 {
    border-bottom: none;
    padding-bottom: 20px;
}

.category-buttons {
    display: flex;
    justify-content: end;
    gap: 20px;
    padding-bottom: 20px;
    border-bottom: solid 2px #fff;
}

.category-buttons a {
    font-size: clamp(14px, calc(14px + (2 / 896) * (100vw - 1024px)), 16px);
    border-radius: 50px;
    border: solid 1px #fff;
    padding: 0.7em;
    min-width: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1;
    text-decoration: none;
    color: #fff;
    transition: all 0.3s;
}

.category-buttons a.active {
    border: solid 1px #34C8D9;
    color: #34C8D9;
    pointer-events: none;
}

.category-buttons a:hover {
    background-color: #34C8D926;
}

.articlelist {
    margin-top: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px);
    display: flex;
    flex-wrap: wrap;
    row-gap: 80px;
    column-gap: 5%;
}

.articlelist a {
    display: block;
    width: 30%;
    text-decoration: none;
    color: #fff;
}

.articlelist_child h2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    transition: all 0.3s;
}

a.articlelist-slide:hover .post-thumbnail>p>img {
    transform: scale(1.1);
}

a.articlelist-slide:hover .articlelist_child h2 {
    color: #34C8D9;
}


/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .articlelist {
        row-gap: 50px;
    }
}

/*834px以下*/
@media screen and (max-width: 834px) {
    .related-article h1 {
        padding-bottom: 30px;
    }

    .category-buttons a {
        min-width: 80px;
    }

    .category-buttons {
        justify-content: start;
        gap: 15px;
    }

    .articlelist {
        column-gap: 10%;
    }

    .articlelist a {
        width: 45%;
    }

    .articlelist>a>.post-thumbnail img {
        height: clamp(126px, calc(126px + (74 / 514) * (100vw - 320px)), 200px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {}

/*======================================================*/
/*関連記事アーカイブ 詳細はお知らせ同様　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/*お問い合わせフォーム*/
/*======================================================*/
.cf-input {
    margin-top: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px);
}

.cf-input>p {
    margin-bottom: clamp(50px, calc(50px + (30 / 896) * (100vw - 1024px)), 80px);
}

.cf-input label {
    display: flex;
    align-items: start;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 80px;
}

.cf-input.cf-confirm label {
    flex-direction: column;
    row-gap: 20px;
    margin-bottom: 50px;
}

.cf-input.cf-confirm label.pp-agr-area {
    margin-bottom: 80px;
}

.cf-input.cf-confirm label:not(:first-of-type) {
    border-top: dotted 1px #ffffff4D;
    padding-top: 50px;
}

label span.form-fieldname {
    display: flex;
    align-items: center;
    gap: 1em;
    line-height: 1;
    word-break: keep-all;
    white-space: nowrap;
    height: 50px;
    width: calc(80px + 12em);
}

.cf-input.cf-confirm label span.form-fieldname:not(:has(span.required-icon)) {
    padding-left: 0 !important;
}

label span.form-fieldname:not(:has(span.required-icon)) {
    padding-left: calc(80px + 1em);
}

.required-icon {
    background-color: #34C8D9;
    word-break: keep-all;
    white-space: nowrap;
    height: 70%;
    width: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 80%;
}

.wpcf7-form-control-wrap {
    width: 65%;
}

input[type=text],
input[type=password],
input[type=date],
input[type=datetime],
input[type=email],
input[type=number],
input[type=search],
input[type=tel],
input[type=time],
input[type=url],
textarea,
select,
.search-edit {
    min-height: 50px;
    border-radius: unset;
    background-color: transparent;
    color: #fff;
    border: solid 1px #fff;
}

input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(100%);
}

::placeholder {
    color: #ffffff4D;
}

label.pp-agr-area {
    background-color: #34C8D933;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: clamp(30px, calc(30px + (20 / 896) * (100vw - 1024px)), 50px);
    border-top: none !important;
}

label.pp-agr-area span {
    max-width: 718px;
    padding-left: 0 !important;
    width: auto;
}

.wpcf7-list-item {
    margin: 0;
}

input[type="checkbox"] {
    width: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
    height: clamp(16px, calc(16px + (4 / 896) * (100vw - 1024px)), 20px);
}

.pp-agr>span {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
}

.toconfirm {
    position: relative;
}

.toconfirm input[type=submit] {
    margin: 0 auto;
}

.wpcf7-spinner {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}

button.entry-backbtn,
input.wpcf7-previous {
    display: block;
    margin: 20px auto 50px;
    border: none;
    background-color: transparent;
    color: #fff;
    cursor: pointer;
    transition: all 0.3s;
}

button.entry-backbtn:hover,
input.wpcf7-previous:hover {
    color: #ffffff66;
}

/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {
    .wpcf7-form-control-wrap {
        width: 100%;
    }

    .cf-input label {
        row-gap: 20px;
    }

    label span.form-fieldname:not(:has(span.required-icon)) {
        padding-left: 0;
    }

}

/*834px以下*/
@media screen and (max-width: 834px) {
    .cf-input label {
        margin-bottom: 60px;
        row-gap: clamp(10px, calc(10px + (10 / 353) * (100vw - 481px)), 20px);
    }
}

/*480px以下*/
@media screen and (max-width: 480px) {
    label.pp-agr-area {
        padding: clamp(20px, calc(20px + (10 / 160) * (100vw - 320px)), 30px);
    }
}

/*======================================================*/
/*　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/**/
/*======================================================*/
/*-----------------------------------------*/
/*1023px以下*/
@media screen and (max-width: 1023px) {}

/*834px以下*/
@media screen and (max-width: 834px) {}

/*480px以下*/
@media screen and (max-width: 480px) {}

/*======================================================*/
/*　ここまで*/
/*======================================================*/
/*/////////////////////////////////////////////////////////////////////////////////*/
/*======================================================*/
/**/
/*======================================================*/