@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* SP */
/* @media only screen and (max-width: 959px) {
} */
/* PC */
/* @media only screen and (min-width: 960px) {
} */

:root {
    /* テーマ側で定義済 */
    /* 少し薄い黒(主に文字) */
    /* --color_text: #1e3241; */
    /* 紺(文字、ボーダー、フッター背景など多数) */
    /* --color_main: #162f3f; */

    /* 赤(ロゴなど) */
    --main-red: #c63b2d;
    /* 赤(ラベル) */
    --label-red: #ae3a2b;
    /* 青(ラベル) */
    --label-blue: #08418b;
    /* 灰色(文字) */
    --text-gray: #808080;
    /* 主に投稿で使用する黒文字 */
    --text-black-2: #231815;
    /* 濃い青(ボタン) */
    --button-blue: #00337f;

    /* 背景 */
    --bg-white: white;
    --bg-red: #f1cdc9;
    --bg-yellow: #fef5e7;
    --bg-blue: #d9e0ec;
    --bg-beige: #fefaf3;
    --bg-gray: #f5f5f5;

    /* 左右余白 */
    --x-pad-container-sp: 28px;
    --x-pad-container-pc: 80px;
}

@font-face {
    font-family: "Gothic821 Cn BT";
    src: url("font/GOTH821C.ttf") format("truetype");
}

a {
    /* aタグの色変化をなしに */
    color: inherit;
}

.sp-only {
    display: block;
}
.pc-only {
    display: none;
}
@media only screen and (min-width: 960px) {
    .sp-only {
        display: none;
    }
    .pc-only {
        display: block;
    }
}
.sp-only-inline {
    display: inline;
}
.pc-only-inline {
    display: none;
}
@media only screen and (min-width: 960px) {
    .sp-only-inline {
        display: none;
    }
    .pc-only-inline {
        display: inline;
    }
}
.sp-only-inline-block {
    display: inline-block;
}
.pc-only-inline-block {
    display: none;
}
@media only screen and (min-width: 960px) {
    .sp-only-inline-block {
        display: none;
    }
    .pc-only-inline-block {
        display: inline-block;
    }
}

/* 背景色設定のため領域を全幅に */
#content.l-container {
    padding-left: 0;
    padding-right: 0;
}
#content .l-article {
    max-width: initial;
}
#content .l-mainContent__inner > .post_content {
    padding-left: 0;
    padding-right: 0;
}
/* 背景色設定のため上下の余白も除去 */
#content {
    padding-top: 0 !important;
}
#content.l-content {
    margin-bottom: 0;
}
/* デフォルトで存在するページへの調整 */
/* 検索結果、Not Found */
#body_wrap.search #content.l-container,
#body_wrap.error404 #content.l-container {
    padding-top: 40px !important;
    padding-bottom: 60px;
    padding-left: var(--x-pad-container-sp);
    padding-right: var(--x-pad-container-sp);
}
@media only screen and (min-width: 960px) {
    #body_wrap.search #content.l-container,
    #body_wrap.error404 #content.l-container {
        padding-left: var(--x-pad-container-pc);
        padding-right: var(--x-pad-container-pc);
    }
}

/* サイドバー表示は通常投稿のみで、人・場所では非表示 */
#body_wrap.single-person #sidebar,
#body_wrap.single-spot #sidebar {
    display: none;
}
#sidebar {
    display: none;
}
/* サイドバーコンテンツはPCのみ表示 */
@media only screen and (min-width: 960px) {
    #sidebar {
        display: block;
    }
}
/* サイドバー表示幅を目一杯に */
.-sidebar-on #sidebar {
    width: calc(var(--swl-sidebar_width) + var(--swl-sidebar_margin));
}

/* SPハンバーガーメニュー */
.l-header__menuBtn {
    border: 1px solid #162F3F;
}
.p-spMenu__inner::before {
    background-color: var(--bg-yellow);
}
.c-widget__title.-spmenu {
    display: none;
}
.c-listMenu a {
    padding-left: 1em;
}
.c-listMenu .sub-menu a {
    padding-left: 2em;
}
/* 矢印非表示 */
.c-listMenu a:before {
    display: none;
}
.c-spnav a {
    border-bottom: 0;
}
.c-listMenu > li > a {
    font-family: "Gothic821 Cn BT", sans-serif;
    font-weight: normal;
    font-size: 20px;
    letter-spacing: 0.12em;
    line-height: 20px;
    color: var(--color_main);
    /* SPメニュー一段目は飾りなのでリンクを無効化 */
    pointer-events: none;
    padding-bottom: 10px;
}
.c-listMenu > li:first-of-type > a {
    padding-bottom: 20px;
}
.c-listMenu > li {
    padding-top: 10px;
}
.c-listMenu .sub-menu a {
    font-family: var(--swl-font_family);
    font-weight: normal;
    font-size: 18px;
    letter-spacing: 0.1em;
    line-height: 20px;
    color: var(--color_main);
}
.c-listMenu .c-searchForm {
    padding-left: 20px;
    margin-right: 20px;
    max-width: 320px;
}
.c-spnav.c-listMenu {
    position: relative;
}
.sp-menu-sns-icon-wrapper {
    position: absolute;
    bottom: -10px;
    left: 15px;
}
.sp-menu-sns-icon-link {
    display: inline-block !important;
    padding: 0 !important;
    margin: 0 8px;
}
.sp-menu-sns-icon {
    width: 24px;
    height: auto;
}
.sp-menu-logo-wrapper {
    position: absolute;
    bottom: -10px;
    right: 15px;
}
.sp-menu-logo {
    width: 114px;
    height: auto;
}
.sp-menu-spacer {
    height: 100px;
}

/* PCメインメニュー */
@media only screen and (min-width: 960px) {
    #header {
        padding-top: 16px;
        padding-bottom: 16px;
    }
    .l-header__inner.l-container {
        padding-left: var(--x-pad-container-pc);
        padding-right: var(--x-pad-container-pc);
    }
    .l-fixHeader__inner.l-container {
        padding-left: var(--x-pad-container-pc);
        padding-right: var(--x-pad-container-pc);
    }
    .l-header__logo {
        margin-left: 0;
        margin-right: 0 !important;
    }
    .l-fixHeader__logo {
        margin-left: 0;
        margin-right: 0;
    }
    .c-gnav {
        align-items: center;
    }
    .c-gnav > .menu-item {
        height: 60%;
        border-bottom: 1px solid var(--color_main);
        border-top: 1px solid var(--color_main);
    }
    .c-gnav > .menu-item:first-of-type {
        padding-left: 15px;
    }
    .c-gnav > .menu-item:last-of-type {
        padding-right: 15px;
    }
    .c-gnav > .menu-item > a {
        font-weight: bold;
        padding: 0 10px;
    }
    /* 動的下線の非表示 */
    .c-gnav > .menu-item > a:after {
        display: none;
    }
    .c-gnav > .menu-item > a .ttl {
        font-size: 11px;
    }
}
@media only screen and (min-width: 1100px) {
    .c-gnav > .menu-item:first-of-type {
        padding-left: 15px;
    }
    .c-gnav > .menu-item:last-of-type {
        padding-right: 15px;
    }
    .c-gnav > .menu-item > a {
        padding: 0 15px;
    }
}

/* ヘッダーSPロゴ */
@media only screen and (max-width: 959px) {
    #header .c-headLogo__img {
        visibility: hidden;
    }
}
.header-logo-sp-left {
    width: 73px;
    position: absolute;
    top: 8px;
    left: 8px;
}
.header-logo-sp-right {
    width: 51px;
    position: absolute;
    top: 16px;
    left: 89px;
}
.header-text {
    font-weight: bold;
    font-size: 8px;
    letter-spacing: 0.1em;
    line-height: 12px;
    text-align: left;
    color: var(--color_text);
    position: absolute;
    top: 16px;
    left: 158px;
}
/* フッター */
.l-footer__nav {
    flex-direction: column;
    padding-top: 25px;
}
.l-footer__nav a {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 30px;
    padding-left: var(--x-pad-container-sp);
    border-right: 0;
}
@media only screen and (min-width: 960px) {
    .l-footer__nav a {
        padding-left: var(--x-pad-container-pc);
    }
}
.l-footer__nav li:first-child a {
    border-left: 0;
}
.l-footer .copyright {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 23px;
    text-align: right;
    padding-right: var(--x-pad-container-sp);
    padding-bottom: 36px;
}
@media only screen and (min-width: 960px) {
    .l-footer .copyright {
        padding-right: var(--x-pad-container-pc);
    }
}
#footer .l-container {
    position: relative;
    padding-left: 0;
    padding-right: 0;
}
.footer-logo-sp {
    width: 120px;
    position: absolute;
    top: 40px;
    right: var(--x-pad-container-sp);
}
@media only screen and (min-width: 960px) {
    .footer-logo-pc {
        width: 120px;
        position: absolute;
        top: 40px;
        right: var(--x-pad-container-pc);
    }
}

/* 検索フォーム */
.c-searchForm__s {
    background-color: var(--bg-yellow);
    border-color: var(--color_main);
}
.c-searchForm__s:focus {
    outline: none;
}
.c-searchForm__submit {
    background-color: var(--bg-yellow) !important;
    border-color: var(--color_main);
    border-left: 0;
}
.c-searchForm__submit:before {
    color: var(--color_main);
}

/* パンくずリスト */
.p-breadcrumb {
    padding-top: 40px !important;
    padding-bottom: 24px;
}
@media only screen and (min-width: 960px) {
    .p-breadcrumb {
        padding-top: 104px !important;
    }
}
.p-breadcrumb__list {
    padding-left: var(--x-pad-container-sp);
    padding-right: var(--x-pad-container-sp);
}
@media only screen and (min-width: 960px) {
    .p-breadcrumb__list {
        padding-left: var(--x-pad-container-pc);
        padding-right: var(--x-pad-container-pc);
    }
}
.p-breadcrumb__text {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: normal;
    font-size: 9px;
    letter-spacing: 0.05em;
    line-height: 9px;
    color: var(--text-gray);
}
@media only screen and (min-width: 960px) {
    .p-breadcrumb__text {
        font-size: 12px;
        line-height: 12px;
    }
}
.p-breadcrumb__text .__home:before {
    /* HOMEアイコン非表示 */
    display: none;
}
/* 項目間の矢印 */
.p-breadcrumb__item:after {
    background-color: inherit;
    clip-path: none;
    content: ">";
    height: 15px;
    width: 18px;
    opacity: 1;
    color: var(--text-gray);
    font-size: 9px;
    text-align: center;
}
@media only screen and (min-width: 960px) {
    .p-breadcrumb__item:after {
        width: 20px;
    }
}

/* 固定ページ共通 タイトル部分 */
#top_title_area {
    background-color: var(--bg-white);
    border-bottom: 1.5px solid var(--color_main);
    height: 200px;
    /* コンテンツの最大幅で止める */
    max-width: 1296px;
    margin: 0 auto;
}
.l-topTitleArea__img {
    display: none;
}
.l-topTitleArea {
    min-height: 200px;
}
.l-topTitleArea.c-filterLayer::before {
    display: none;
}
.l-topTitleArea.c-filterLayer:after {
    display: none;
}
.c-pageTitle {
    text-align: center;
    color: var(--text-gray);
    font-size: 14px;
    font-weight: normal;
    letter-spacing: 0.1em;
}
@media only screen and (min-width: 960px) {
    .c-pageTitle {
        font-size: 20px;
    }
}
.c-pageTitle::before {
    /* 文字はページ毎に設定 */
    /* content: "xxx"; */
    display: block;
    color: var(--color_main);
    font-family: "Gothic821 Cn BT", sans-serif;
    font-weight: normal;
    font-size: 30px;
    letter-spacing: 0.12em;
    line-height: 40px;
    padding-bottom: 3px;
}
@media only screen and (min-width: 960px) {
    .c-pageTitle::before {
        display: inline;
        font-size: 45px;
        vertical-align: sub;
        padding-right: 16px;
    }
}
