@charset "utf-8";

/*
Theme Name: SWELL-child
Template: swell
Version: 24-12
*/

/* @import url(css/reset.css); */     /* ブラウザリセット(今回は子テーマなので使用しない) */
@import url(css/base.css);       /* ブラウザリセット以外のリセット／全体レイアウト */
@import url(css/utility.css);    /* 1セレクター1プロパティ指定 */
@import url(css/parts.css);      /* 最小モジュール（タイトル・ボタン等） */
@import url(css/compornent.css); /* 複合モジュール（ブロック単位  カード・メディア等） */

@import url(css/header.css);
@import url(css/footer.css);

/* 各ページ単位のcssはfunctions.phpに指定 */






/* ==========================================================

    全体

========================================================== */



/* header変更
===========================================*/
.l-header { font-family: 'Zen Maru Gothic';}

.l-header__bar { display: none;}

/* PC（1420以上） */
@media screen and (min-width: 1420px) {
    .topTitleArea_original .l-container {
        padding-left: 0; padding-right: 0;
        max-width: var(--container_size);
    }

    .l-header {
        position: fixed;
        left: 0; top: 0;
        width: 260px; height: 100%;
    }

    .l-header .l-container { padding-right: 24px; padding-left: 24px;}

    .l-fixHeader,
    .l-fixHeader__inner { display: none;} /* SWELLデフォルト打消し */

    .-series .l-header__inner {
        height: 100%;
        padding-top: 60px; padding-bottom: 20px;
        flex-direction: column;
    }

    .-series .l-header__logo,
    .-series .c-headLogo { margin-right: 0;}

    .c-headLogo { height: 120px;}

    .-series-right .c-gnavWrap {
        width: 100%;
    }

    .c-gnav {
        flex-direction: column;
        position: relative;
    }

    .c-gnav>.menu-item:nth-child(1) { border-top: 1px solid #3F4422;}

    .c-gnav>.menu-item {
        padding-top: 3px; padding-bottom: 3px;
        margin-right: 8px; margin-left: 8px;
        position: relative;
        border-top: 1px solid #3F4422;
    }

    .c-gnav>.menu-item::after,
    .c-gnav>.menu-item::before {
        content: '';
        width: 10px; height: 10px;
        background: url(img/decor/decoration_nav.svg) no-repeat;
        background-size: cover;
        position: absolute;
    }

    .c-gnav>.menu-item::after,
    .c-gnav>.menu-item::before { top: -5px;}

    .c-gnav>.menu-item::after  { right: -10px;}
    .c-gnav>.menu-item::before { left: -8px;}
    
    .c-gnav>.menu-item>a {
        display: block;
        padding-top: 14px; padding-bottom: 14px;
        text-align: center;
        transition: all  0.3s ease;
        position: relative;
    }

    .c-gnav>.menu-item>a::after {
        background: none;
        transition: none;
    } /* SWELLデフォルトhover時打消し */

    .c-gnav>.menu-item>a:hover {
        background: #91978B;
        color: #fff;
    }

    .c-gnav>.menu-item>a:hover::after,
    .c-gnav>.menu-item>a:hover::before {
        content: '';
        display: block;
        width: calc(100% - 4px);
        position: absolute; left: 2px;
        border-top: 1px solid #fff;
    }

    .c-gnav>.menu-item>a:hover::after  { bottom: 1px;}
    .c-gnav>.menu-item>a:hover::before { top: 2px;}

    /* Privacy Policy別表記 */
    .c-gnav>.menu-item.menu-item_privacy>a {
        text-align: right;
        padding: 8px 0;
        font-family: "Zen Kurenaido", sans-serif;
    }

    .c-gnav>.menu-item.menu-item_privacy>a:hover {
        background: none;
        color: #91978B;
    }

}

/* PC（1420～1800） */
@media screen and (min-width: 1420px) and (max-width: 1749.98px) {
    /* .l-content,
    .l-topTitleArea .l-container { transform: translateX(14%);} */
}

/* PC（1800以上） */
@media screen and (min-width: 1800px) {
    /* .l-content,
    .l-topTitleArea .l-container { transform: translateX(9%);} */
}


/* header変更（1420以下）
===========================================*/
@media screen and (min-width: 960px) and (max-width: 1419.98px) {
    .-series .l-header__logo { padding-top: 6px; padding-bottom: 0;}

}


/* header変更（960以下）
===========================================*/
@media screen and (max-width: 959.98px) {
    .-img .c-headLogo__link { padding-top: 0; padding-bottom: 0;}
}


/* 追従header変更（960～1420）
===========================================*/
@media screen and (min-width: 960px) and (max-width: 1419.98px) {
    .l-fixHeader .l-fixHeader__logo {padding-top: 0; padding-bottom: 0;}
}




/* パンくず非表示
===========================================================*/
.p-breadcrumb { display: none;}









/* ==========================================================

    .p-postList.-type-card

========================================================== */
.p-postList.-type-card { align-items: flex-end;}

.-type-card .p-postList__link {
    background: #fff;
    border-radius: 7px;
    box-shadow: 1px 2px 5px 4px rgba(109 141 92 / 12%),
                0 30px 13px -6px rgba(24 26 24 / 25%);
    transition: all 0.25s;
}

.-type-card .p-postList__link:hover {
    transform-origin: center bottom;
    transform: scale(1.06);
}

.p-postList .p-postList__title {
    font-weight: normal;
    font-size: 14px;
}

.p-postList__meta {
    display: flex;
    justify-content: center; align-items: center;
    border-top: 1px dashed #ced7c6;
    padding-top: 0.7cqw;
}







/* ==========================================================

    archive（homeと共通）

========================================================== */
/* 全体レイアウト
===========================================================*/
.-type-card .p-postList__item {
    margin-bottom: 6cqw;
    position: relative;
}

.-type-card .p-postList__link {
    padding-bottom: 0.5cqw;
    overflow: hidden;
}


/* 親ページのみ表示
================================*/
.p-postChildList {
    border: 3px solid #eaf0dd;
    position: relative;
}

.p-postChildList ul { border: 1px solid #bcbfaa;}

.p-postChildList .p-postList.-type-card {
    margin-right: 0; margin-left: 0;
    padding: 1.2em 1em .1em;
}

.p-postChildList .-type-card .p-postList__item { margin-bottom: 1em;}

.p-postChildList .-type-card .p-postList__link {
    box-shadow: 2px 2px 4px rgba(109 141 92 / 52%);
    padding-bottom: 0;
}


@media screen and (min-width: 1020px) {
    .-sidebar-off .-type-card.-pc-col3 .p-postList__item,
    .-sidebar-off .-type-thumb.-pc-col3 .p-postList__item {
        width: 31%;
    }

    .-sidebar-off .-type-card.-pc-col3 .p-postList__item:not(:nth-child(3n)),
    .-sidebar-off .-type-thumb.-pc-col3 .p-postList__item:not(:nth-child(3n)) {
        margin-right: 3.5%;
    }

    .-sidebar-off .-type-card.-pc-col4 .p-postList__item,
    .-sidebar-off .-type-thumb.-pc-col4 .p-postList__item {
        width: 23.5%;
        padding: 0;
    }

    .-sidebar-off .-type-card.-pc-col4 .p-postList__item:not(:nth-child(4n)),
    .-sidebar-off .-type-thumb.-pc-col4 .p-postList__item:not(:nth-child(4n)) {
        margin-right: 2%;
    }

    .-sidebar-off .-type-card.-pc-col5 .p-postList__item,
    .-sidebar-off .-type-thumb.-pc-col5 .p-postList__item {
        width: 19.2%;
        padding: 0;
    }

    .-sidebar-off .-type-card.-pc-col5 .p-postList__item:not(:nth-child(5n)),
    .-sidebar-off .-type-thumb.-pc-col5 .p-postList__item:not(:nth-child(5n)) {
        margin-right: 1%;
    }
}

@media screen and (min-width: 600px) and (max-width: 1020px) {
    .-sidebar-off .-type-card.-pc-col5 .p-postList__item,
    .-sidebar-off .-type-thumb.-pc-col5 .p-postList__item {
        width: 23.5%;
        padding: 0;
    }

    .-sidebar-off .-type-card.-pc-col5 .p-postList__item:not(:nth-child(4n)),
    .-sidebar-off .-type-thumb.-pc-col5 .p-postList__item:not(:nth-child(4n)) {
        margin-right: 2%;
    }
}

/* SP（600以上） */
@media screen and (max-width: 600px) {
    .p-postChildList .p-postList.-type-card {
        padding: 0.8em 0.2em .01em;
    }

    .-type-card .p-postList__item { margin-bottom: 12vw;}
}




/* サムネ
===========================================================*/
.c-postThumb { overflow: visible;}

.c-postThumb__figure {
    aspect-ratio: 16 / 9;
}



/* テキスト
===========================================================*/
.-type-card .p-postList__body { padding-top: 0.5cqw;}

.p-postList .p-postList__title {
    margin-bottom: 0.5cqw;
    padding: 1cqw 0.5cqw 0.7cqw;
}

.-type-card .p-postList__type,
.-type-card .p-postList__term {
    display: flex;
    flex-wrap: wrap; justify-content: flex-start; align-items: stretch;
}

.-type-card .p-postList__type span {
    color: #82a774;
    font-size: 10px;
    margin-left: 0.3em;
}

.-type-card .p-postList__term span {
    background: #c3d5b3;
    color: #fff;
    font-size: 10px;
    padding-right: 0.5em; padding-left: 0.5em;
    border-radius: 2px;
    margin-top: 0.3em; margin-right: 2px; margin-left: 2px;
}





/* ページネーション
===========================================================*/
[class*=page-numbers],
[class*=page-numbers]:hover {
    border-radius: 5px;
    box-shadow: 0 18px 7px -8px rgb(0 0 0 / 17%);
}











/* ==========================================================

    .p-relatedPosts3

========================================================== */
/* PC・TB */
@media screen and (min-width: 960px) {
    .p-relatedPosts3 .p-postList__item { width: 33.33%;}
}











/* ==========================================================

    cqw使用のため.post_contentにcontainer-type指定

========================================================== */
.post_content { container-type: inline-size;}






/* ==========================================================

    吹き出し デフォルト設定変更

========================================================== */
.c-balloon { align-items: center;}

.c-balloon__icon { width: 14cqw;}

.c-balloon .c-balloon__iconImg { width: 14cqw; height: 14cqw;}


/* PC・TB */
@media screen and (min-width: 600px) {
    .c-balloon__text { max-width: 75cqw;}
}


/* SP */
@media screen and (max-width: 599.98px) {
    .c-balloon__body { padding-right: 4vw; padding-left: 4vw;}

    .c-balloon__shapes { top: auto; bottom: 0;}

    .-bln-right .c-balloon__shapes {
        transform: rotate(-90deg);
        right: calc(50% + 10px);
    }

    .c-balloon.-bln-right { flex-direction: column-reverse;}

    .c-balloon__icon {
        width: 28cqw;
        padding-top: 2vw;
    }

    .c-balloon .c-balloon__iconImg { width: 28cqw; height: 28cqw;}
}






/* ==========================================================

    キーボード風

========================================================== */
kbd {
    padding-right: 0.3em; padding-bottom: 1px; padding-left: 0.3em;
    margin-right: 0.3em; margin-left: 0.3em;
    border: 1px solid #ccc;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    background: #fff;
    font-size: 0.95em;
}






/* ==========================================================

    カスタム書式セット

========================================================== */
.swl-format-1,
.swl-format-2,
.swl-format-3,
.swl-format-4,
.swl-format-5,
.swl-format-6,
.swl-format-7,
.swl-format-8,
.swl-format-9 { display: inline-block;}



.swl-format-1 {
    padding-right: 0.5em; padding-bottom: 1px; padding-left: 0.5em;
    margin-right: 0.3em; margin-left: 0.3em;
    border: 1px solid #999;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    background: #999;
    color: #fff;
    font-size: 0.84em;
}


.swl-format-2 {
    padding-right: 0.5em; padding-bottom: 1px; padding-left: 0.5em;
    margin-right: 0.3em; margin-left: 0.3em;
    border: 1px solid #588ed3;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    background: #588ed3;
    color: #fff;
    font-size: 0.84em;
}


.swl-format-3 {
    padding-right: 0.5em; padding-bottom: 1px; padding-left: calc(0.3em + 16px + 0.5em);
    margin-right: 0.3em; margin-left: 0.3em;
    border: 1px solid #999;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    background: #999;
    color: #fff;
    font-size: 0.84em;
    position: relative;
}

.swl-format-3::after,
.swl-format-3::before {
    content: '';
    display: block;
    position: absolute;
}

.swl-format-3::before {
    width: 16px;
    height: 16px;
    left: 0.25em; top: 0.3em;
    background: #588ed3;
    border-radius: 3px;
}

.swl-format-3::after {
    width: 11px;
    height: 7px;
    transform: rotate(-45deg);
    left: calc(0.25em + 3px); top: calc(0.3em + 3px);
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
}


.swl-format-4 {
    padding-right: 0.5em; padding-bottom: 1px; padding-left: calc(0.3em + 16px + 0.5em);
    margin-right: 0.3em; margin-left: 0.3em;
    border: 1px solid #999;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    background: #999;
    color: #fff;
    font-size: 0.84em;
    position: relative;
}

.swl-format-4::before {
    content: '';
    display: block;
    width: 16px; height: 16px;
    position: absolute; left: 0.25em; top: 0.2em;
    background: #ccc;
    border-radius: 3px;
}

.swl-format-5,
.swl-format-6,
.swl-format-7,
.swl-format-8,
.swl-format-9 {
    padding-right: 0.5em; padding-bottom: 1px; padding-left: 0.5em;
    margin-right: 0.3em; margin-left: 0.3em;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    color: #fff;
    font-size: 0.84em;
}

.swl-format-5 {
    border: 1px solid #1d725e;
    background: #1d725e;
}

.swl-format-6 {
    border: 1px solid #246283;
    background: #246283;
}

.swl-format-7 {
    border: 1px solid #83314a;
    background: #83314a;
}

.swl-format-8 {
    border: 1px solid #79461d;
    background: #79461d;
}

.swl-format-9 {
    border: 1px solid #353535;
    background: #353535;
}






/* ==========================================================

    ブロック → カラム  カスタムスタイル追加

========================================================== */
.is-style-nextTo .wp-block-column:not(:last-child) { padding-right: 1%;}
.is-style-nextTo .wp-block-column:last-child       { padding-left: 1%;}

.is-style-nextTo .wp-block-column { position: relative;}

.is-style-nextTo .wp-block-column:not(:last-child)::after {
    content: '';
    border-top: 14px solid transparent;
    border-bottom: 14px solid transparent;
    border-left: 20px solid #b4d381;
    position: absolute; right: -22px; top: 50%;
    transform: translateY(-50%);
}

/* 左端無し */
.is-style-nextTo.__noLeft .wp-block-column:first-child::after { content: none;}

/* 右端無し */
.is-style-nextTo.__noRight .wp-block-column:nth-last-child(2)::after { content: none;}



@media screen and (max-width: 781px) {
    .is-style-nextTo .wp-block-column:not(:last-child) { padding-right: 0;}
    .is-style-nextTo .wp-block-column:last-child       { padding-left: 0;}

    .is-style-nextTo .wp-block-column:not(:last-child)::after {
        border-top: 16px solid #b4d381;
        border-right: 12px solid transparent;
        border-bottom: none;
        border-left: 12px solid transparent;
        right: auto; left: 50%; top: auto; bottom: -28px;
        translate: -50% 0;
    }
}


/* 上下
===========================================================*/
.is-style-nextTo_upDown figure:not(:last-child) {
    margin-bottom: 36px;
    position: relative;
}

.is-style-nextTo_upDown figure:not(:last-child)::before {
    content: '';
    border-right: 14px solid transparent;
    border-left: 14px solid transparent;
    border-top: 20px solid #b4d381;
    position: absolute; left: 50%; bottom: -28px;
    transform: translateX(-50%);
}





/* ==========================================================

    fixed SNSボタン 位置変更

========================================================== */
.-fix.c-shareBtns { left: auto; right: 8px;}





/* ==========================================================

    投稿 アイコン（テキスト内使用）

========================================================== */
/* Blender
===========================================================*/
/* プロパティ系
=======================================*/
.blender_p_view,
.blender_p_scene,
.blender_p_world,
.blender_p_render,
.blender_p_output,
.blender_p_physics,
.blender_p_setting,
.blender_p_texture,
.blender_p_material,
.blender_p_modifier,
.blender_p_particle,
.blender_p_obj-data_curve,
.blender_p_obj, .blender_p_obj-data, .blender_p_obj-constraint,
.blender_p_armature, .blender-p_bone, .blender_p_bconstraint {
    width: 22px; height: 22px;
    margin-right: 2px; margin-left: 2px;
    display: inline-block;
    vertical-align: text-bottom;
    border-radius: 3px;
}

.blender_p_material { background: url(img/icon/ico_blender-p-material.png) no-repeat center center;}
.blender_p_modifier { background: url(img/icon/ico_blender-p-modifier.png) no-repeat center center;}
.blender_p_obj      { background: url(img/icon/ico_blender-p-obj.png) no-repeat center center;}
.blender_p_obj-constraint { background: url(img/icon/ico_blender-p-obj-constraint.png) no-repeat center center;}
.blender_p_obj-data { background: url(img/icon/ico_blender-p-obj-data.png) no-repeat center center;}
.blender_p_obj-data_curve { background: url(img/icon/ico_blender-p-obj-data_curve.png) no-repeat center center;}
.blender_p_output   { background: url(img/icon/ico_blender-p-output.png) no-repeat center center;}
.blender_p_particle { background: url(img/icon/ico_blender-p-particle.png) no-repeat center center;}
.blender_p_physics  { background: url(img/icon/ico_blender-p-physics.png) no-repeat center center;}
.blender_p_render   { background: url(img/icon/ico_blender-p-render.png) no-repeat center center;}
.blender_p_scene    { background: url(img/icon/ico_blender-p-scene.png) no-repeat center center;}
.blender_p_setting  { background: url(img/icon/ico_blender-p-setting.png) no-repeat center center;}
.blender_p_texture  { background: url(img/icon/ico_blender-p-texture.png) no-repeat center center;}
.blender_p_view     { background: url(img/icon/ico_blender-p-view.png) no-repeat center center;}
.blender_p_world    { background: url(img/icon/ico_blender-p-world.png) no-repeat center center;}
.blender_p_armature    { background: url(img/icon/ico_blender-p-armature.png) no-repeat center center;}
.blender-p_bone        { background: url(img/icon/ico_blender-p-bone.png) no-repeat center center;}
.blender_p_bconstraint { background: url(img/icon/ico_blender-p-bconstraint.png) no-repeat center center;}



/* 矢印
=======================================*/
.blender_arr-b_up_down,
.blender_arr-g_up_down,
.blender_arr-b_border_down,
.blender_arr-g_border_down {
    display: inline-block;
    vertical-align: middle;
    font-size: 0.84em;
    width: 2em; height: 2em;
    position: relative; top: -2px;
    box-shadow: 0 0 3px rgba(0,0,0, 0.1);
    border-radius: 3px;
    padding-right: 0.5em; padding-left: 0.5em;
    margin-right: 0.3em; margin-left: 0.3em;
}

.blender_arr-b_border_down {
    background: #588ed3;
    border: 1px solid #588ed3;
}

.blender_arr-g_border_down {
    background: #999;
    border: 1px solid #999;
}

.blender_arr-b_up_down::after,
.blender_arr-g_up_down::after,
.blender_arr-b_border_down::after,
.blender_arr-g_border_down::after {
    content: '';
    display: block;
    width: 0.7em; height: 0.7em;
    position: absolute; top: 50%; left: 50%;
}

.blender_arr-b_up_down::after,
.blender_arr-g_up_down::after {
    border-left: 2px solid #fff;
    border-top: 2px solid #fff;
    transform: translate(-50%, calc(-50% - 1px)) rotate(45deg);
}

.blender_arr-b_border_down::after,
.blender_arr-g_border_down::after {
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: translate(-50%, calc(-50% - 1px)) rotate(45deg);
}





/* ==========================================================

    page共通

========================================================== */
.page .l-content { padding-top: 8em;}

.page .post_content {
    max-width: 960px;
    margin-inline: auto;
}