@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
    v2.0 | 20110126
    License: none (public domain)
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    box-sizing: border-box;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
body {line-height: 1;}
ol, ul {list-style: none;}
blockquote, q {quotes: none;}
blockquote:before, blockquote:after, q:before, q:after {content: ''; content: none;}
table {border-collapse: collapse; border-spacing: 0;}

/* CSS Document */

/*色関連----------------------------------------------------------- */
:root {
    --color_bk: #141414;
    --color_wt: #fff;
    --color0: #f6f6f6;
    --color1: #5c90b5;
    --color2: #f1eee7;
    --color3: #e9e9e9;
}
.cl_main {color: var(--color1)!important;}
.bg_main {background: var(--color1)!important;}
.cl_base {color: var(--color2)!important;}
.bg_base {background: var(--color2)!important;}
.cl_accent {color: var(--color3)!important;}
.bg_accent {background: var(--color3)!important;}
.cl_black {color: var(--color_bk)!important;}
.bg_black {background: var(--color_bk)!important;}
.cl_white {color: var(--color_wt)!important;}
.bg_white {background: var(--color_wt)!important;}

/*オリジナルリセットcss----------------------------------------------------------- */
p {margin-bottom: 0;}
img {display: block;}

/*デバイス共通----------------------------------------------------------- */
html {
    font-size: 62.5%;
}
body {
    font-family: "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "YuGothic M", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", sans-serif;
    font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.1em;
    color: var(--color_bk);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    word-break: break-all;
}
main {
    background: var(--color0)!important;
}
@media (min-width: 768px) and (max-width: 1229px) {
    body {
        font-size: 1.6rem;
        line-height: 1.4;
    }
}
@media screen and (max-width: 767px) {
    body {
        font-size: 1.5rem;
        line-height: 1.4;
    }
}
a {
    text-decoration: none;
}
a, a img {
    transition: all .3s;
}
li {
    list-style: none;
}
.dib {display: inline-block;}
.m0a {margin: 0 auto;}
.mla {margin-left: auto;}
.posr {position: relative;}
.posa {position: absolute;}
.imgr {display: block; max-width: 100%; height: auto;}
.bdrd {border-radius: 15px;overflow: hidden;}

@media screen and (max-width: 767px) {
    .sp_scroll {width: 100%; overflow-x: scroll;}
    .sp_scroll>* {min-width: 768px;}
}

/*テキスト関連----------------------------------------------------------- */
.fwb {font-weight: bold !important;}
.underline {text-decoration: underline;}
.font_xs {font-size: 12px;}
.font_s {font-size: 14px;}
.font_m {font-size: 16px;}
.font_l {font-size: 24px;}
.font_xl {font-size: 32px;}
.font_xxl {font-size: 40px;}
@media screen and (max-width: 767px) {
.font_xs {font-size: 10px;}
.font_s {font-size: 12px;}
.font_m {font-size: 14px;}
.font_l {font-size: 18px;}
.font_xl {font-size: 20px;}
.font_xxl {font-size: 21px;}
}
.lh1 {line-height: 1;}
.tac {text-align: center !important;}
.tal {text-align: left !important;}
.tar {text-align: right !important;}
.shadow {text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;}
.font_min {font-family:"游明朝体", "Yu Mincho", YuMincho, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;}
.font_go {font-family: "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", "游ゴシック体", YuGothic, "YuGothic M", sans-serif;}
@import url('https://fonts.googleapis.com/css2?family=Lato&display=swap');
.font_lato {font-family: 'Lato', sans-serif;}
@import url('https://fonts.googleapis.com/css2?family=Jost&family=Noto+Sans+JP:wght@100;400;700&display=swap');
.font_noto {font-family: 'Noto Sans JP', sans-serif,}
/* @import url('https://fonts.cdnfonts.com/css/din-2'); */
.font_din {font-family: din-2014, sans-serif;font-weight: 600;}
.font_hel {font-family: Helvetica, sans-serif;}

.indent {
    text-indent: -1em;
    padding-left: 1em;
}
.note {
    position: relative;
    font-size: 0.777em;
    padding-left: 1em;
}
.note:before {
    position: absolute;
    content: "※";
    top: 0;
    left: 0;
    font-size: 1em;
    line-height: 1.554em;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .tab_shadow {
        text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
    }
}
@media screen and (max-width: 767px) {
    .sp_tal {
        text-align: left !important;
    }

    .sp_shadow {
        text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
    }
}

/*余白&幅調整----------------------------------------------------------- */
.mt0 {margin-top: 0;}.mt5 {margin-top: 5px;}.mt10 {margin-top: 10px;}.mt15 {margin-top: 15px;}.mt20 {margin-top: 20px;}.mt30 {margin-top: 30px;}.mt45 {margin-top: 45px;}.mt60 {margin-top: 60px;}.mt75 {margin-top: 75px;}.mt90 {margin-top: 90px;}.mt120 {margin-top: 120px;}.mb0 {margin-bottom: 0;}.mb5 {margin-bottom: 5px;}.mb10 {margin-bottom: 10px;}.mb15 {margin-bottom: 15px;}.mb20 {margin-bottom: 20px;}.mb30 {margin-bottom: 30px;}.mb45 {margin-bottom: 45px;}.mb60 {margin-bottom: 60px;}.mb75 {margin-bottom: 75px;}.mb90 {margin-bottom: 90px;}.mb120 {margin-bottom: 120px;}.pt0 {padding-top: 0;}.pt5 {padding-top: 5px;}.pt10 {padding-top: 10px;}.pt15 {padding-top: 15px;}.pt20 {padding-top: 20px;}.pt30 {padding-top: 30px;}.pt45 {padding-top: 45px;}.pt60 {padding-top: 60px;}.pt75 {padding-top: 75px;}.pt90 {padding-top: 90px;}.pt120 {padding-top: 120px;}.pb0 {padding-bottom: 0;}.pb5 {padding-bottom: 5px;}.pb10 {padding-bottom: 10px;}.pb15 {padding-bottom: 15px;}.pb20 {padding-bottom: 20px;}.pb30 {padding-bottom: 30px;}.pb45 {padding-bottom: 45px;}.pb60 {padding-bottom: 60px;}.pb75 {padding-bottom: 75px;}.pb90 {padding-bottom: 90px;}.pb120 {padding-bottom: 120px;}.pl0 {padding-left: 0;}.pr0 {padding-right: 0;}.ph0 {padding-left: 0; padding-right: 0;}.ph15 {padding-left: 15px; padding-right: 15px;}
@media screen and (max-width: 767px) {
    .spmt0 {margin-top: 0;}.spmt5 {margin-top: 5px;}.spmt10 {margin-top: 10px;}.spmt15 {margin-top: 15px;}.spmt20 {margin-top: 20px;}.spmt30 {margin-top: 30px;}.spmt45 {margin-top: 45px;}.spmt60 {margin-top: 60px;}.spmb0 {margin-bottom: 0;}.spmb5 {margin-bottom: 5px;}.spmb10 {margin-bottom: 10px;}.spmb15 {margin-bottom: 15px;}.spmb20 {margin-bottom: 20px;}.spmb30 {margin-bottom: 30px;}.spmb45 {margin-bottom: 45px;}.spmb60 {margin-bottom: 60px;}.sppt0 {padding-top: 0;}.sppt5 {padding-top: 5px;}.sppt10 {padding-top: 10px;}.sppt15 {padding-top: 15px;}.sppt20 {padding-top: 20px;}.sppt30 {padding-top: 30px;}.sppt45 {padding-top: 45px;}.sppt60 {padding-top: 60px;}.sppb0 {padding-bottom: 0;}.sppb5 {padding-bottom: 5px;}.sppb10 {padding-bottom: 10px;}.sppb15 {padding-bottom: 15px;}.sppb20 {padding-bottom: 20px;}.sppb30 {padding-bottom: 30px;}.sppb45 {padding-bottom: 45px;}.sppb60 {padding-bottom: 60px;}.sppl0 {padding-left: 0;}.sppr0 {padding-right: 0;}.spph0 {padding-left: 0; padding-right: 0;}
}
@media screen and (max-width: 767px) {
    .spwd50 {width: 50% !important;}
    .spwd60 {width: 60% !important;}
    .spwd70 {width: 70% !important;}
    .spwd80 {width: 80% !important;}
    .spwd90 {width: 90% !important;}
}

/*見出し----------------------------------------------------------- */
h1, h2, h3 {
    letter-spacing: 0.05em;
    line-height: 1.4;
}
h2 {
    margin: 0;
    padding: 0 0 30px;
    text-align: center;
    font-size: 50px;
}
h3 {
    margin: 0;
    padding: 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    h2 {
        padding: 0 0 45px;
        font-size: 32px;
    }
    h2 .font_lato,
    h2.font_lato {
        letter-spacing: 0.05em;
    }
}
@media screen and (max-width: 767px) {
    h2 {
        padding: 0 0 30px;
        font-size: 32px;
    }
}

/*はみ出し画像中央----------------------------------------------------------- */
.wic_wrap {
    overflow-x: hidden;
}
.wic img {
    width: auto;
    max-width: unset;
}
.wic1 {
    margin-left: calc(50% - 1000px);
}
.wic1 img {
    width: 2000px;
    max-width: 2000px;
}
.wic2 {
    margin-left: calc(50% - 670px);
}
.wic2 img {
    /* width: 1340px;
max-width: 1340px; */
}
@media screen and (max-width: 767px) {
    .wic1 img {
        width: 100%;
    }
    .wic1 {
        margin-left: 0;
        margin-right: 0;
    }
}

/*white-box----------------------------------------------------------- */
.white_box {
    padding: 45px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_xl {
    padding: 90px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_l {
    padding: 60px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_s {
    padding: 30px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_xs {
    padding: 15px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box:last-of-type,
.white_box_xl:last-of-type,
.white_box_l:last-of-type,
.white_box_s:last-of-type,
.white_box_xs:last-of-type {
    margin-bottom: 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .white_box {
        padding: 30px;
        margin-bottom: 15px;
    }
    .white_box_xl {
        padding: 45q;
        margin-bottom: 30px;
    }
    .white_box_l {
        padding: 45q;
        margin-bottom: 30px;
    }
    .white_box_s,
    .white_box_xs {
        padding: 15px;
        margin-bottom: 15px;
    }
}
@media screen and (max-width: 767px) {
    .white_box,
    .white_box_s,
    .white_box_xs {
        padding: 15px;
        margin-bottom: 15px;
    }
    .white_box_xl,
    .white_box_l {
        padding: 30px;
        margin-bottom: 15px;
    }
}

/* pagination */
.wp-pagenavi {
    padding-top: 60px;
    text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
    margin: 0;
    padding: 0;
    border: none;
    width: 30px;
    height: 30px;
    display: inline-block;
    text-align: center;
    line-height: 30px;
    margin-right: 10px;
}
.wp-pagenavi a:last-child,
.wp-pagenavi span:last-child {
    margin-right: 0;
}
.wp-pagenavi .current {
    background-color: var(--color1);
    color: var(--color_wt);
}
.wp-pagenavi .larger,
.wp-pagenavi .smaller {
    background-color: #ededed;
    color: var(--color_bk);
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
    background-color: #ededed;
    color: var(--color_bk);
}
/*背景左右はみだし----------------------------------------------------------- */
.white_box.bg_over_l,
.white_box.bg_over_r {
    margin-bottom: 60px;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .white_box.bg_over_l,
    .white_box.bg_over_r {
        margin-bottom: 30px;
    }
}
@media screen and (max-width: 767px) {
    .white_box.bg_over_l,
    .white_box.bg_over_r {
        margin-bottom: 15px;
    }
}
.white_box.bg_over_l,
.white_box.bg_over_l>*,
.white_box.bg_over_r,
.white_box.bg_over_r>* {
    position: relative;
    z-index: 1;
}
.white_box.bg_over_l:before {
    position: absolute;
    display: block;
    content: "";
    height: 100%;
    width: 50vw;
    top: 0;
    left: 50%;
    transform: translateX(-50vw);
    background-color: #efefef;
    z-index: 0;
}
.white_box.bg_over_r:before {
    position: absolute;
    display: block;
    content: "";
    height: 100%;
    width: 50vw;
    top: 0;
    right: 0;
    transform: translateX(50vw);
    background-color: #efefef;
    z-index: 0;
}


/*check_list----------------------------------------------------------- */
.check_list li {
    position: relative;
    padding-left: 1.5em;
    margin-bottom: 3px;
}
.check_list li:last-child {
    margin-bottom: 0;
}
.check_list li:before {
    position: absolute;
    content: "\f058";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    top: 0;
    left: 0;
    color: orange;
}
.list_border {
    border-bottom: 2px dashed #000;
}
.list_border_stop {
    border-bottom: 2px dashed #000;
    display: inline-block;
}


/*FOXcss追加スタイル----------------------------------------------------------- */
.fx-row-gutter-s {
    margin-left: -8px;
    margin-right: -8px;
}
.fx-row-gutter-s > li,
.fx-row-gutter-s > div {
    padding-left: 8px;
    padding-right: 8px;
}
.fx-row-gutter-xs {
    margin-left: -5px;
    margin-right: -5px;
}
.fx-row-gutter-xs > li,
.fx-row-gutter-xs > div {
    padding-left: 5px;
    padding-right: 5px;
}

/*Container / Break----------------------------------------------------------- */
@media (min-width: 1230px) {
    .container {
        width: 1230px;
        margin: 0 auto;
        position: relative;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: none;}
    .pt_none {display: none;}
    .ps_none {display: none;}
    .t_none {display: block;}
    .ts_none {display: block;}
    .s_none {display: block;}
}

@media (min-width: 768px) and (max-width: 1229px) {
    body {
        overflow-x: hidden;
    }
    .container {
        width: 768px;
        margin: 0 auto;
        position: relative;
        margin-right: auto;
        margin-left: auto;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: block;}
    .pt_none {display: none;}
    .ps_none {display: block;}
    .t_none {display: none;}
    .ts_none {display: none;}
    .s_none {display: block;}
}
@media screen and (max-width: 767px) {
    body {
        overflow-x: hidden;
        display: block;
        max-width: 767px;
    }
    .container {
        margin-right: auto;
        margin-left: auto;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: block;}
    .pt_none {display: block;}
    .ps_none {display: none;}
    .t_none {display: block;}
    .ts_none {display: none;}
    .s_none {display: none;}
}

/*************************************************************/
/**********************     共通部分     **********************/
/*************************************************************/

/*セクション間余白----------------------------------------------------------- */
section {
    padding: 150px 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    section {
        padding: 90px 0;
    }
}
@media screen and (max-width: 767px) {
    section {
        padding: 75px 0;
    }

}

/*テキスト関連----------------------------------------------------------- */
.highlight {
    background: -webkit-linear-gradient(transparent 60%, #ffd200 50%);
    background: -o-linear-gradient(transparent 60%, #ffd200 50%);
    background: linear-gradient(transparent 60%, #ffd200 50%);
    font-weight: bold;
}

/*リンク色----------------------------------------------------------- */
a:link,
a:visited,
a:hover { text-decoration: none;}
a { color: #272727; }

/*共通部分----------------------------------------------------------- */
.btn {
    /* max-width: 400px; */
    width: 100%;
}
.btn a,
.btn button {
    position: relative;
    background-color: var(--color1);
    padding: 27px 0;
    transition: all .4s;
    width: 100%;
    font-weight: bold;
    color: var(--color_wt);
    display: block;
    cursor: pointer;
}
.btn a:hover,
.btn button:hover {
    transform: translateY(-5px);
    box-shadow: none;
}
.btn .fa,
.btn .fas {
    position: absolute;
    right: 32px;
    top: 50%;
    transform: translateY(-50%);
}
.btn.btn1 {
    width: 480px;
    margin: 0 auto;
}
.btn.btn2 {
    width: 600px;
    margin: 0 auto;
}
@media screen and (max-width: 1229px) {
    .btn a, .btn button {
        max-width: 100%;
    }
}

@media screen and (max-width: 767px) {
    .btn {
        width: 100%;
    }
    .btn a, .btn button {
        padding: 10px 0;
        position: relative;
        transition: all .4s;
    }
    .btn .fa,
    .btn .fas {
        right: 15px;
    }
    .btn.btn1, .btn.btn2 {
        width: 100%;
    }
}
/*Header----------------------------------------------------------- */
header {
    position: -webkit-sticky;
    position: sticky;
    z-index: 999999;
    top: 0;
    width: 100%;
    background: var(--color0)!important;
    font-size: 16px;
    /* background: #fff; */
    /* box-shadow: 0 5px 10px rgba(0,0,0,0.3); */
}
header>div {
    display: flex;
    align-items: center;
    height: 80px;
}
header .logo {
    margin-right: auto;
    padding-left: 15px;
}
.openbtn6 {
    display: none;
}
header .header_nav>ul {
    display: flex;
    align-items: center;
    gap: 5px;
    padding-right: 15px;
}
header .sp_nav {
    display: none;
}
.header_list  {
    padding: 15px 15px;
    line-height: 1;
    color: var(--color_bk);
    letter-spacing: 0.2em;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: all .3s;
}
.header_list:hover {
    color: #000;
    text-decoration: none;
    transform: translateY(-5px);
}
header .tel_wrap p {
    text-align: right;
}
header .head_cta {
    display: flex;
    align-items: center;
    gap: 30px;
    margin-left: 15px;
    height: 100%;
}
header .contact {
    display: flex;
    align-items: center;
    text-align: right;
}
header .head_contact {
    height: 100%;
}
header .head_contact a {
    background-color: var(--color1);
    padding-inline: 30px;
    color: #fff;
    text-decoration: none;
    position: relative;
    transition: all .3s;
    height: inherit;
    display: flex;
    align-items: center;
}
header .head_contact a:hover {
    opacity: 0.7;
}
header .head_contact a span {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
nav {
    display: flex;
    height: inherit;
    align-items: center;
}
nav ul li {
    position: relative;
}
nav li.has-child:hover>ul,
nav li.has-child ul li:hover>ul,
nav li.has-child:active>ul,
nav li.has-child ul li:active>ul {
    visibility: visible;
    opacity: 1;
}
nav li.has-child ul li a {
    color: #000;
    border-bottom: solid 1px rgba(255, 255, 255, 0.6);
}
nav li.has-child ul li:last-child a {
    border-bottom: none;
}
nav li.has-child ul li a:hover,
nav li.has-child ul li a:active {
    background: var(--color1);
    color: #fff;
}
@media screen and (max-width:1469px) {
    header {
        border-radius: 0 0 15px 15px;
    }
    header .dn {
        display: none;
    }
    header.bgB {
        background: var(--color1);
    }
    header .logo {
        height: inherit;
        align-items: center;
        justify-content: end;
        padding-left: 0;
    }
    header .logo img {
        max-width: 140px;
    }
    header .header_nav>ul {
        padding-right: 0;
        gap: 0;
    }
    header nav ul a:link,
    header nav ul a:visited {
        color: #fff;
        text-align: center;
        padding: 20px 15px;
    }
    header>div {
        flex-direction: column;
        width: 100%;
        height: 60px;
        padding-inline: 15px;
    }
    nav {
        display: none;
        flex-direction: column;
        padding: 0;
        width: 100%;
        /* height: calc(100vh - 70px); */
        height: 101vh;
        overflow: none;
        background-color: var(--color1);
        padding-bottom: 30px;
        width: 100vw;
    }
    nav ul {
        flex-direction: column;
    }
    nav ul li {
        width: 100%;
    }
    nav li.has-child ul,
    nav li.has-child ul ul {
        position: relative;
        left: 0;
        top: 0;
        width: 100%;
        visibility: visible;
        opacity: 1;
        display: none;
        transition: none;
    }
    nav ul li a {
        width: 100%;
    }
    nav>ul>li {
        border-bottom: 1px solid #ccc;
    }
    nav>ul>li>a {
        text-align: center;
        position: relative;
    }
    nav>ul>li.has-child>a:before {
        position: absolute;
        content: "\f078";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        top: calc(50% - 6px);
        right: 10px;
        line-height: 1;
        transition: all .3s;
    }
    nav>ul>li.active>a:before {
        transform: rotate(180deg);
    }
    nav>ul>li>a:hover {
        transform: translateY(0);
    }
    nav li.has-child ul li a {
        border-bottom: 0;
        border-top: 1px dotted #ccc;
    }
    header .tel_wrap {
        text-align: center;
        padding-top: 30px;
    }
    header .tel_num {
        color: var(--color3);
    }
    header .head_cta {
        display: none;
    }
    header .sp_head_cta a,
    header .sp_head_cta span {
        display: block;
        width: 100%;
        text-align: center;
        border-radius: 45px;
    }
    header .head_cta .head_tel {
        width: 45%;
    }
    header .contact_form,
    header .contact_tel {
        padding-inline: 15px;
    }
    header .contact_form {
        margin: 0 auto;
    }
    header .contact_form a {
        margin-top: 30px;
        background: #fff;
        color: var(--color1);
        padding: 15px;
    }
    header .contact_form .fa-envelope {
        color: var(--color1);
    }
    header .contact_tel span {
        margin-top: 30px;
        background: var(--color2);
        color: #fff;
        padding: 15px;
    }
    header .head_contact a {
        padding: 10px 45px;
        background: var(--color1);
        color: #fff;
        text-decoration: none;
        position: relative;
        transition: all .3s;
        display: inline-block;
        box-shadow: 2px 2px 0 #969696;
    }
    header .head_contact a:hover {
        transform: translate(2px, 2px);
        box-shadow: 0 0 0 #969696;
    }
    .header_list span {
        color: var(--color_wt);
    }
    header .tel_wrap p {
        text-align: center;
    }
    /*ハンバーガー*/
    header .logo {
        display: flex;
        justify-content: space-between;
        margin-right: 0;
        width: 100%;
        padding: 5px 0;
    }
    nav .btns {
        display: flex;
    }
    nav .btns p {
        width: 50%;
    }
    .openbtn6 {
        display: block;
        position: relative;
        background: var(--color1);
        cursor: pointer;
        width: 50px;
        height: 50px;
        border-radius: 15px;
        margin-left: auto;
    }
    .openbtn6 span {
        display: inline-block;
        transition: all .4s;
        position: absolute;
        left: 14px;
        height: 3px;
        /* border-radius: 2px; */
        background: #fff;
    }
    .openbtn6 span:nth-of-type(1) {
        top: 15px;
        width: 45%;
    }
    .openbtn6 span:nth-of-type(2) {
        top: 23px;
        width: 35%;
    }
    .openbtn6 span:nth-of-type(3) {
        top: 31px;
        width: 20%;
    }
    .openbtn6.active span:nth-of-type(1) {
        top: 18px;
        left: 18px;
        transform: translateY(6px) rotate(-135deg);
        width: 30%;
    }
    .openbtn6.active span:nth-of-type(2) {
        opacity: 0;
    }
    .openbtn6.active span:nth-of-type(3) {
        top: 30px;
        left: 18px;
        transform: translateY(-6px) rotate(135deg);
        width: 30%;
    }
}
@media screen and (max-width: 767px) {
    nav .btns {
        display: flex;
        flex-direction: column;
    }
    nav .btns p {
        width: 90%;
        margin-inline: auto;
    }
    header .tel_num {
        font-size: 30px;
    }
    header .tel_wrap p {
        font-size: 12px;
        padding-top: 5px;
    }
}

/*footer----------------------------------------------------------- */
.foot_link {
    display: flex;
    justify-content: center;
    gap: 30px;
}
.foot_link a:hover {
    opacity: 0.7;
}
@media screen and (max-width: 767px) {
    .foot_link {
        flex-direction: column;
        gap: 15px;
    }
}


/*breadclumb----------------------------------------------------------- */
.breadcrumb-area {
    padding: 5px 15px;
}
.bread_crumb .taxonomy,
.brea.entries__tagegory {
    color: var(--color1);
}
.bread_icon {
    padding-inline: 15px;
}

@media (min-width: 768px) and (max-width: 1229px) {}

@media screen and (max-width: 767px) {}

/*Footer----------------------------------------------------------- */
.footer_wrap {
    display: flex;
    flex-direction: column;
    padding: 45px 0;
}
@media screen and (max-width: 1229px) {
}
@media screen and (max-width: 767px) {
}

/* contact form 共通
----------------------------------------- */
form > ul > li {
    padding: 15px 0;
}
form > ul > li.bb_none {
    border-bottom: none;
}
.form_head {
    text-align: right;
}
.form_head span {
    display: inline-block;
    font-weight: bold;
}
.haveto {
    background-color: #fb9613;
    color: #fff;
    padding: 1px 8px;
    font-weight: bold;
    font-size: 0.7em;
    margin-left: 10px;
}
.any {
    background-color: #81807f;
    color: #fff;
    padding: 1px 8px;
    font-weight: bold;
    font-size: 0.7em;
    margin-left: 10px;
}
.input_adjust {
    padding: 15px;
    border-radius: 10px;
    border: 2px solid #ccc;
    font-size: 1em;
}
.input_2col {
    display: flex;
    justify-content: space-between;
    padding-right: 30px;
    width: 100%;
}
.input_2col input {
    width: calc(50% - 15px);
}
.input_1col {
    padding-right: 30px;
}
.input_1col input {
    width: 100%;
    box-sizing: border-box;
}
.input_zip_2col input {
    width: 30%;
}
.input_pref {
    width: 50%;
}
.input_select select {
    width: 80%;
    padding-right: 1em;
    cursor: pointer;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    padding: 12px 16px;
}
.input_select select::-ms-expand {
    display: none;
}
.input_select {
    position: relative;
    border: 2px solid #ccc;
    border-radius: 10px;
    background: #ffffff;
}
.input_select::before {
    position: absolute;
    top: calc(50% - 3px);
    right: 1em;
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #000;
    pointer-events: none;
}
.input_tel_3col input {
    width: 30%;
}
.input_tel_3col input:first-child {
    width: 20%;
}
.radio_2col {
    display: flex;
}
.radio_2col label {
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.radio_2col label:first-child {
    padding-right: 30px;
}
.radio_2col span {
    padding-left: 10px;
}
.radio_1col > label {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.radio_1col span {
    padding-left: 10px;
}
.date_2col {
    display: flex;
    justify-content: space-between;
    padding-right: 30px;
}
.date_2col > * {
    display: block;
    width: calc(50% - 15px);
}
.input_date {
    position: relative;
}
.input_date:before {
    position: absolute;
    content: "\f073";
    font-family: "Font Awesome 5 Free";
    right: 15px;
}
input[type="date"] {
    position: relative;
}
input[type="date"]::-webkit-calendar-picker-indicator {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
}
input[type="date"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
}
input[type="date"]::-webkit-clear-button {
    -webkit-appearance: none;
}
.check_1col > label {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.check_1col span {
    padding-left: 10px;
}
.select_1col {
    padding-right: 30px;
}
.textarea {
    padding-right: 30px;
}
.textarea textarea {
    width: 100%;
    max-height: 160px;
    box-sizing: border-box;
}
.check_agree input {
    height: 20px;
    width: 20px;
}
.check_agree span {
    padding-top: 5px;
}
.sbm_wrap {
    padding: 30px 15px;
}
.btn button {
    width: 100%;
}
.sbm_btn {
    border: none;
}
/* .btn2 button {
    color: var(--color_wt);
    font-weight: bold;
    border: 0;
    background-color: var(--color2);
} */
@media (min-width: 768px) and (max-width: 1229px) {
}
@media screen and (min-width: 768px) {
    .common_form .fx-col-16-s {
        -ms-flex-preferred-size: 16%;
        flex-basis: 16%;
        max-width: 16%;
        padding-top: 12px;
    }
    .common_form.fx-col-54-s {
        -ms-flex-preferred-size: 54%;
        flex-basis: 54%;
        max-width: 54%;
    }
    .input_select {
        margin-right: 30px;
    }
}
@media screen and (max-width: 767px) {
    .form_wrap {
        padding: 0;
    }
    form > ul > li .fx-row > *:first-child {
        padding-top: 0;
    }
    form > ul > li {
        padding: 15px;
    }
    .form_head {
        text-align: left;
    }
    .input_adjust {
        padding: 8px 12px;
    }
    .input_2col {
        padding-right: 0px;
    }
    .input_1col {
        padding-right: 0px;
    }
    .input_pref {
        width: 80%;
    }
    .input_select select {
        padding: 8px 12px;
    }
    .radio_2col label:first-child {
        padding-right: 0px;
    }
    .date_2col {
        padding-right: 0px;
    }
    .date_2col > * {
        width: calc(50% - 8px);
    }
    .select_1col {
        padding-right: 0px;
    }
    .textarea {
        padding-right: 0px;
    }
    .sbm_wrap {
        padding: 0;
    }
    .btn button {
        width: 100%;
        padding: 15px 0;
    }
    .sbm {
        width: 100%;
    }
}
/*下層ページ共通----------------------------------------------------------- */
.sec_mv_wrap {
    /* background-color: var(--color2); */
    padding: 90px 0;
}
.sec_head_wrap .sec_head{
    font-size: 48px;
}
.sec_head {
    text-align: left;
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    color: var(--color1)!important;
    position: relative;
    padding-bottom: 15px;
}
.sec_head:before {
    position: absolute;
    content: "";
    width: 100px;
    height: 1px;
    background: var(--color1);
    bottom: 0;
}
@media screen and (max-width: 1229px) {
    .sec_mv_wrap {
        padding: 80px 0;
    }
}
@media screen and (max-width: 767px) {
    .sec_mv_wrap {
        padding: 60px 0;
    }
    .sec_head_wrap .sec_head {
        font-size: 26px;
    }
}
/* SINGLE 共通
----------------------------------------- */
.entries__inner {
    flex-direction: row-reverse;
}
.entries__ttl {
    font-size: 45px;
}
.entries__date {
    display: flex;
    align-items: center;
}
.entries__date p {
    padding-right: 30px;
    width: fit-content;
    color: #b6b6b6;
}
.entries__tags {
    width: fit-content;
    display: flex;
}
.entries__tag {
    padding-right: 5px;
}
.entries__tag:last-child {
    padding-right: 0;
}
.entries__tag a {
    padding: 5px 10px;
    border: 1px solid #999;
    border-radius: 20px;
    color: #999;
    font-size: 14px;
}
.entries__tag a:hover {
    background-color: #999;
    color: #fff;
}
.entries__img img {
    width: 100%;
}
.entries__wrap h3 {
    padding: 15px 30px;
    position: relative;
    font-size: 30px;
}
.entries__wrap h3::before,
.entries__wrap h3::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
}
.entries__wrap h3::before {
    border-top: 3px solid var(--color1);
    border-left: 3px solid var(--color1);
    top: 0;
    left: 0;
}
.entries__wrap h3::after {
    border-bottom: 3px solid var(--color1);
    border-right: 3px solid var(--color1);
    bottom: 0;
    right: 0;
}
.entries__wrap h4 {
    font-size: 26px;
    padding-bottom: 15px;
    position: relative;
}
.entries__wrap h4::before,
.entries__wrap h4::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
}
.entries__wrap h4::before {
    width: 100%;
    height: 4px;
    background-color: #e5e5e5;
}
.entries__wrap h4::after {
    width: 30%;
    height: 4px;
    background-color: var(--color1);
}
.entries__wrap h5 {
    font-size: 24px;
    position: relative;
    padding-left: 15px;
}
.entries__wrap h5::before {
    content: '';
    position: absolute;
    height: 100%;
    width: 4px;
    background-color: var(--color1);
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
.wp-block-image img {
    margin: 0 auto;
    padding-bottom: 45px;
}
.wp-block-columns {
    padding-bottom: 60px;
}
.wp-block-column > p:not(:last-child) {
    padding-bottom: 45px;
}
.wp-block-column > .wp-block-heading {
    margin-top: 0;
}
.wp-block-heading {
    margin: 45px 0 15px;
}
.entries .btn {
    max-width: 400px;
    width: 100%;
}
.side-bar_head {
    position: relative;
    font-size: 24px;
    padding-left: 30px;
    text-align: unset;
}
.side-bar_head::before {
    content: '';
    position: absolute;
    width: 3px;
    height: 30px;
    background-color: var(--color1);
    top: 0;
    left: 0;
}
.monthly-list li {
    padding-left: 30px;
    letter-spacing: 0.2em;
}
@media screen and (max-width: 1229px) {
    .entries__ttl {
        font-size: 40px;
    }
    .entries__wrap h3 {
        padding-inline: 15px;
    }
    .side-bar_head {
        padding-bottom: 30px;
    }
}
@media screen and (max-width: 767px) {
    .entries__ttl {
        font-size: 26px;
        padding-bottom: 15px;
    }
    .entries__tag a {
        font-size: 12px;
    }
    .entries__wrap h2 {
        padding-bottom: 15px;
        font-size: 26px;
    }
    .entries__wrap h3 {
        padding: 15px;
        font-size: 24px;
    }
    .entries__wrap h4 {
        font-size: 20px;
    }
    .entries__wrap h5 {
        font-size: 18px;
    }
    .entries__btn {
        width: 70%;
    }
    .side-bar_head {
        padding-bottom: 15px;
    }
}

/* -----------------------------------------
                PAGENATION
--------------------------------------------*/
.wp-pagenavi {
    display: flex;
    align-items: center;
    justify-content: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
    text-decoration: none;
    border: 1px solid var(--color1);
    margin: 2px;
    line-height: 1;
}
.wp-pagenavi a:hover {
    background-color: var(--color1);
    color: var(--color_wt);
    border: 1px solid var(--color1);
    padding: 5px;
}
.wp-pagenavi .previouspostslink:hover,
.wp-pagenavi .nextpostslink:hover {
    padding: 3px 5px;
}
.wp-pagenavi span.current {
    background-color: var(--color1);
    color: var(--color_wt);
    border: 1px solid var(--color1);
    padding: 5px;
}
.wp-pagenavi .larger,
.wp-pagenavi .smaller {
    background-color: var(--color_wt);
    color: var(--color1);
    border: 1px solid var(--color1);
    line-height: 1;
    padding: 5px;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
    background-color: var(--color_wt);
    color: var(--color1);
    border: 1px solid var(--color1);
    line-height: 1;
    padding: 3px 5px;
}
@media screen and (max-width: 1229px) {
    .wp-pagenavi span.current,
    .wp-pagenavi .larger,
    .wp-pagenavi .smaller {
        padding: 7px;
    }
    .wp-pagenavi .previouspostslink,
    .wp-pagenavi .nextpostslink {
        padding-block: 6px;
    }
}