@charset "UTF-8";

:root {
    --color-primary: #11783a;
    --color-primary-dark: #006535;
    --color-primary_light: #11783a;
    --color-secondary: #d93724;
    --color-main: #231815;
    --black: #000;
    --gray-5: #555;
    --gray-4: #666;
    --gray-3: #BCBCBC;
    --gray-2: #DEDEDE;
    --gray-1: #eef6f1;
    --white: #FFF;
    --yellow: #FFFF00;
    --red: #C50200;

    --hover: #EB0000;
    --link: #e8a63f;
    --color-green: #009944;
    --color-pink: #d65b8e;

    --font-primary: "Zen Kaku Gothic Antique", sans-serif;
    --font-secondary: "Noto Serif", serif;
    --font-base: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
    --font-en: "Crimson Text", serif;
    --font-nav: "Spectral", serif;
}

/*--------------------------------------------------------------
    # typography
--------------------------------------------------------------*/
html,
body {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    line-height: 1.4;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: var(--scroll-padding, 98px)
}

body {
    margin: 0;
    background-color: rgba(198, 156, 109, 51%);
    color: var(--color-main);
    font-family: var(--font-primary);
    font-weight: 400;
}


/*
@media only screen and (min-width: 768px) {
    #wrapper.bg-two-tone {
        background: #fff;
    }

    .home #wrapper.bg-two-tone {
        background: #fff;
    }
}
*/



#content {
    margin: 0 auto;
    padding-bottom: 5rem;
    max-width: 460px;
    background: #fff;
    min-height: 800px;
}

h1 {
    font-size: 1.8rem;
}

h2 {
    font-size: 1.3rem;
}

h3 {
    font-size: 1.15rem;
}

h3 code {
    font-family: inherit;
    font-size: 1rem;
    font-weight: normal;
}

h4 {
    font-size: 1.12rem;
}

h5 {
    font-size: 1.1rem;
}

h6 {
    font-size: 1rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: bold;
}

h1.is-style-title,
h2.is-style-title,
h3.is-style-title,
h4.is-style-title,
h5.is-style-title,
h6.is-style-title {
    margin-bottom: 2.25rem;
    color: var(--color-primary);
    font-size: 1.75rem;
    font-weight: 700;
}

h1.is-style-headline,
h2.is-style-headline,
h3.is-style-headline,
h4.is-style-headline,
h5.is-style-headline,
h6.is-style-headline {
    position: relative;
    padding-bottom: 0;
    -webkit-text-stroke-width: 1.5px;
    -webkit-text-stroke-color: #555;
    color: transparent !important;
    letter-spacing: 1px;
    font-size: 3.5rem;
    font-family: var(--font-en);
    font-weight: 600;
    line-height: 1.1;
}


.is-style-headline.has-white-color {
    color: transparent;
    -webkit-text-stroke-color: #fff;
}

.is-style-headline:after {
    display: block;
    content: "";
    position: absolute;
    left: 0;
    bottom: .24em;
    width: 100%;
    border-bottom: 1px solid #999;
}

.is-style-headline.has-white-color:after {
    border-bottom-color: #fff;
}

h1.is-style-left-line,
h2.is-style-left-line,
h3.is-style-left-line,
h4.is-style-left-line,
h5.is-style-left-line,
h6.is-style-left-line {
    padding-left: 10px;
    border-left: 3px solid var(--gray-4);
}

h1.is-style-title-xxl,
h2.is-style-title-xxl,
h3.is-style-title-xxl,
h4.is-style-title-xxl,
h5.is-style-title-xxl,
h6.is-style-title-xxl {
    margin-bottom: 0;
    color: var(--color-primary);
    font-weight: 700;
    font-size: 2.5rem;
    line-height: 1;
}

h1.is-style-title-xxl-clight,
h2.is-style-title-xxl-clight,
h3.is-style-title-xxl-clight,
h4.is-style-title-xxl-clight,
h5.is-style-title-xxl-clight,
h6.is-style-title-xxl-clight {
    color: var(--color-primary);
    opacity: .25;
    font-weight: 700;
    font-size: 2.5rem;
    line-height: 1;
}

h1.is-style-icon,
h2.is-style-icon,
h3.is-style-icon,
h4.is-style-icon,
h5.is-style-icon,
h6.is-style-icon {
    margin-bottom: 3.4rem;
    text-align: center;
    color: #555;
    font-size: 1.3rem;
    font-weight: bold;
}

h1.is-style-icon i,
h2.is-style-icon i,
h3.is-style-icon i,
h4.is-style-icon i,
h5.is-style-icon i,
h6.is-style-icon i {
    display: block;
    margin-bottom: 0.8rem;
    color: var(--color-primary);
    font-size: 2.7rem;
}

h1.is-style-thin-copy,
h2.is-style-thin-copy,
h3.is-style-thin-copy,
h4.is-style-thin-copy,
h5.is-style-thin-copy,
h6.is-style-thin-copy {
    margin-bottom: 3.8rem;
    color: var(--black);
    ;
    font-size: 2rem;
    font-weight: 100;
}

h1.is-style-thin,
h2.is-style-thin,
h3.is-style-thin,
h4.is-style-thin,
h5.is-style-thin,
h6.is-style-thin {
    margin-bottom: 1.3rem;
    color: var(--black);
    ;
    font-size: 2rem;
    font-weight: 100;
}

h1.is-style-light,
h2.is-style-light,
h3.is-style-light,
h4.is-style-light,
h5.is-style-light,
h6.is-style-light {
    margin-bottom: 1.2rem;
    font-weight: 300;
}

h1.is-style-heading-bg,
h2.is-style-heading-bg,
h3.is-style-heading-bg,
h4.is-style-heading-bg,
h5.is-style-heading-bg,
h6.is-style-heading-bg {
    display: inline-block;
    margin: 2rem 0 0 !important;
    padding: .4rem 2.125rem .5rem;
    background: var(--color-primary-dark);
    color: var(--white);
    font-size: 1rem;
    letter-spacing: .1em;
    font-weight: bold;
    line-height: 1.53;
}

.is-style-heading-bg {
    display: inline-block;
    margin-top: 2rem;
    padding: .4rem 2.75rem .5rem;
    background: var(--color-primary-dark);
    color: var(--white);
    font-size: 1rem;
    font-weight: bold;
    line-height: 1.53;
}

.is-style-heading2 {
    font-size: 2.6rem;
    font-weight: 500;
    line-height: 1.3;
}

@media (max-width:767px) {

    h1.is-style-headline,
    h2.is-style-headline,
    h3.is-style-headline,
    h4.is-style-headline,
    h5.is-style-headline,
    h6.is-style-headline {
        -webkit-text-stroke-width: 1px;
        font-size: 3.25rem;
    }

    h1.is-style-icon,
    h2.is-style-icon,
    h3.is-style-icon,
    h4.is-style-icon,
    h5.is-style-icon,
    h6.is-style-icon {
        margin-bottom: 3rem;
    }

    h1.is-style-title,
    h2.is-style-title,
    h3.is-style-title,
    h4.is-style-title,
    h5.is-style-title,
    h6.is-style-title {
        margin-bottom: 2.5rem;
    }

    h1.is-style-title-xxl,
    h2.is-style-title-xxl,
    h3.is-style-title-xxl,
    h4.is-style-title-xxl,
    h5.is-style-title-xxl,
    h6.is-style-title-xxl {
        font-size: 2.75rem;
    }

    h1.is-style-heading-bg,
    h2.is-style-heading-bg,
    h3.is-style-heading-bg,
    h4.is-style-heading-bg,
    h5.is-style-heading-bg,
    h6.is-style-heading-bg,
    .is-style-heading-bg {
        padding: .3rem 2rem .4rem;
        font-size: .8rem;
    }

    .is-style-heading2 {
        font-size: 1.8rem;
    }
}

.f-ntserif {
    font-family: "Noto Serif JP", serif;
}

.is-style-icon i {
    color: var(--color-primary);
}

.is-style-copy {
    font-size: 1rem;
    line-height: 2;
}

.is-style-lead {
    font-size: 1.25rem;
}

.is-style-lead-md {
    font-size: 1.5rem;
    font-weight: bold;
}

.is-style-lead_sm {
    font-size: 1.13rem;
}

.is-style-desc {
    line-height: 1.8;
}

.is-style-ds-text-sm {
    font-size: .88rem;
}

.is-style-ds-text-m {
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: .02em;
}

.is-style-ds-text-m20 {
    font-size: 1.02rem;
    font-weight: 600;
    letter-spacing: .05em;
}


.is-style-ds-text-ml {
    margin-bottom: 0;
    font-size: 1.0625rem;
    font-weight: 500;
    letter-spacing: .1em;
}

.is-style-ds-text-ml2 {
    margin-bottom: 0;
    font-size: 1.425rem;
    font-weight: 500;
}


.is-style-ds-text-l {
    margin-bottom: 0;
    font-size: 1.75rem;
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1.3;
}


.is-style-ds-text-mxl {
    margin-bottom: 0;
    font-size: 1.7rem;
    font-weight: 500;
    letter-spacing: .01em;
}

.is-style-ds-text-xl {
    margin-bottom: 0;
    font-size: 1.375rem;
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1.3;
}

.is-style-mb-1 {
    margin-bottom: 0.8rem;
}

@media (max-width:767px) {
    .is-style-desc_copy {
        margin-bottom: 2.4rem;
    }

    .is-style-ds-text-m {
        font-size: .75rem;
    }

    .is-style-ds-text-ml {
        font-size: 1rem;
    }

    .is-style-ds-text-ml2 {
        font-size: 1rem;
    }

    .is-style-ds-text-l {
        font-size: 1.25rem;

    }

    .is-style-ds-text-mxl {
        font-size: 1.375rem;
    }


    .is-style-ds-text-xl {
        font-size: 1.5rem;

    }

    .is-style-sp_left {
        text-align: left;
    }
}

ul li,
ol li {
    margin-bottom: 0.5rem;
    line-height: 1.65;
}

ul::after,
ol::after {
    content: "";
    display: block;
    clear: both;
}

a {
    text-decoration: underline;
    color: var(--link);
}

a img {
    transition: all 0.2s ease-in;
}


@media(hover: hover) {
    a:hover {
        color: var(--hover);
        ;
    }

    a.over:hover {
        opacity: 0.65;
    }
}

p {
    margin-bottom: 1.5rem;
    font-size: 1rem;
    line-height: 1.65;
}

strong {
    font-weight: 700;
}

code {
    font-family: var(--font-primary);
    font-weight: normal;
}

img {
    max-width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    vertical-align: bottom;
}

.obj-fit img {
    width: 100%;
}

.bold {
    font-weight: bold;
}


hr {
    margin: 3.6rem 0;
    background-color: var(--gray-4);
    ;
}

iframe {
    margin-bottom: 2rem;
    border: 0;
}

.inner {
    margin: 0 auto;
    padding: 0 2rem;
    max-width: 1024px;
    box-sizing: border-box;
}

.h-inner {
    margin: 0 auto;
    padding-top: 3rem;
    max-width: 329px;
}

.inner:after {
    content: "";
    display: block;
    clear: both;
}

.inner .wp-block-group {
    padding: 0;
}

@font-face {
    font-family: "Font Awesome 6 Brands";
    font-style: normal;
    font-weight: 400;
    font-display: block;
    src: url(./font/fa-brands-400.woff2) format("woff2"), url(./font/fa-brands-400.ttf) format("truetype");
}

@font-face {
    font-family: "Font Awesome 6 Free";
    font-style: normal;
    font-weight: 400;
    font-display: block;
    src: url(./font/fa-regular-400.woff2) format("woff2"), url(./font/fa-regular-400.ttf) format("truetype");
}

@font-face {
    font-family: "Font Awesome 6 Free";
    font-style: normal;
    font-weight: 900;
    font-display: block;
    src: url(./font/fa-solid-900.woff2) format("woff2"), url(./font/fa-solid-900.ttf) format("truetype");
}

.section {
    margin-bottom: 3rem;
}

/* テスト */
.section_big p {
    font-size: 1.4rem;
}

.section_big p span {
    font-size: 1.8rem;
}



@media only screen and (min-width: 768px) {
    .switch-sp {
        display: none;
    }

    br.sp {
        display: none;
    }
}


@media (max-width: 767px) {
    .switch-pc {
        display: none;
    }

    br.pc {
        display: none;
    }
}


.center {
    text-align: center;
}

.margin-bottom {
    margin-bottom: 2rem;
}

.wp-block-quote {
    padding-left: 1rem;
    border-left: 2px solid var(--color-primary);
}

.wp-block-quote cite {
    font-size: 0.8rem;
    font-style: initial;
}

.bd-bottom {
    margin: 0.7rem 0;
    border-bottom: 1px solid var(--gray-4);
}




@media only screen and (min-width: 768px) {
    .center_pc {
        text-align: center;
    }
}

.t-right {
    text-align: right
}

@media (max-width: 767px) {


    .inner {
        padding: 0 1rem;
        max-width: 100%;
    }

    .h-inner {
        max-width: 100%;
    }

    .inner-fluid {
        padding: 0 1rem;
    }

    img {
        width: 100%;
    }

    .lead {
        font-size: 1.1rem;
    }

    .lead_md {
        font-size: 1rem;
    }

    hr {
        margin: 2.6rem 0 2.7rem;
    }

}

/*--------------------------------------------------------------
    ## header
--------------------------------------------------------------*/
.logo_wrap {
    display: flex;
    position: fixed;
    left: 0;
    width: calc((100% - 460px) / 2);
    height: 100vh;
    line-height: 1;
    text-align: center;
    align-items: center;
    justify-content: center;
}

.logo img {
    max-width: 50%;
}


@media (max-width: 767px) {

    .logo_wrap {
        display: none;
    }
}

.btn-toggle-menu {
    display: none;
}

.h-inner {
    position: relative;
    /*
    display: flex;
    align-items: center;
    justify-content: space-between;
*/
}


@media (min-width: 768px) {
    #header {
        position: fixed;
        top: 0;
        right: 0;
        padding: 0;
        width: calc((100% - 460px) / 2);
        height: 100vh;
        z-index: 2;
    }
}

.logo_w img {
    max-width: 51.5%;
}

.gnav {
    padding: 0;
}

.gnav ul {
    position: relative;
    margin: 0;
    padding: 0;
    list-style-type: none;
    z-index: 1;
}

.gnav-in > ul {
    margin: 1.5rem 0 3.5rem 14%;
}

.gnav ul li {
    margin-bottom: 0;
    padding: .3rem 0;
    text-align: left;
    font-size: 1.1875rem;
    font-weight: 500;
}

/*
.gnav ul li.current-menu-item a {
    border-bottom: 1px solid #007c36;
}
*/

.gnav ul li a {
    display: block;
    color: #000;
    text-decoration: none;
}

.gnav ul li a:before {
    position: relative;
    top: 3px;
    display: inline-block;
    margin-right: 6px;
    content: "";
    width: 20px;
    height: 20px;
    background-color: #fff;
    border-radius: 50%;
    transition: all .3s ease-in;
}


@media(hover: hover) {
    .gnav ul li a:hover:before {
        background-color: var(--color-primary);
    }
}

@media only screen and (min-width: 880px) and (max-width:1199px) {
    .gnav ul li {
        font-size: 1.3vw;
    }

    .gnav ul li a:before {
        top: .25vw;
        width: 1.3vw;
        height: 1.3vw;
    }
}

@media only screen and (min-width: 880px) {
    .gnav {
        display: block !important;
        padding: 0 1rem;
    }
}

.wh-box {
    padding: .8rem 1.88rem 1rem;
    background-color: #fff;
    border: 1px solid #fff;
    border-radius: 18px;
}

.wh-box + .wh-box {
    margin-top: .75rem;
}

.wh-box .contact-ph-wrap {
    display: flex;
    column-gap: 1.2rem;
    align-items: center;
}

.wh-box .contact-ph-wrap .icon {
    margin-top: .25rem;
    width: 26px;
}

.wh-box .contact-ph .icon img {
    max-width: 100%;
}

.wh-box .contact-ph {
    width: calc(100% - 46px);
}

.wh-box .contact-ph p {
    margin-bottom: 0;
    font-weight: 500;
}


.wh-box .contact-ph .num1 {
    padding-top: .5rem;
    color: var(--color-main);
    text-decoration: none;
    font-size: 1.68rem;
    font-family: "Inter", sans-serif;
    line-height: 1.2;
}

.wh-box .contact-ph .num2 {
    margin-left: .4rem;
    color: var(--color-main);
    text-decoration: none;
    font-size: .8rem;
    font-family: "Inter", sans-serif;
}

.wh-box .contact-ph .reserv-time {
    margin-left: .4rem;
    font-size: .5rem;
}

.wh-box.wh-box--sns {
    padding: .5rem 1.88rem;
}

.wh-box.wh-box--sns .contact-ph-wrap {
    column-gap: 1.5rem;
}


.wh-box.wh-box--sns .contact-ph-wrap .icon {
    width: 31px;
}

.wh-box .contact-txt {
    font-size: .75rem;
    font-weight: 500;
}

.wh-box .line-qr {
    width: 59px;
    margin-left: -5px;
}

@media only screen and (min-width: 880px) and (max-width:1199px) {
    .wh-box {
        padding: .8rem 1rem 1rem;
    }

    .wh-box .contact-ph-wrap {
        column-gap: .5rem;
    }

    .wh-box .contact-ph-wrap .icon {
        width: 2vw;
    }

    .wh-box .contact-ph {
        width: calc(100% - (2vw + .5rem));
    }

    .wh-box .contact-ph .num1 {
        font-size: 1.85vw;
    }

    .wh-box .contact-ph .num2 {
        font-size: 1.2vw;
    }

    .wh-box .contact-ph .reserv-time {
        font-size: .9vw;
    }


    .wh-box.wh-box--sns {
        padding: .5rem 1rem;
    }

    .wh-box.wh-box--sns .contact-ph-wrap {
        column-gap: .5rem;
        justify-content: space-between;
    }

    .wh-box.wh-box--sns .contact-ph-wrap .icon {
        width: 3vw;
    }

    .wh-box .contact-txt {
        font-size: 1.2vw;
    }

}


@media (max-width: 879px) {

    .btn-toggle-menu::before {
        text-rendering: auto;
        font-size: 1rem;
        font-family: "Font Awesome 6 Free";
        font-weight: 900;
        -moz-osx-font-smoothing: grayscale;
        -webkit-font-smoothing: antialiased;
        font-style: normal;
        font-variant: normal;
    }

    .logo {
        width: 11.8rem;
        position: relative;
        padding: 0;
        z-index: 4;
    }

    .btn-toggle-menu {
        display: flex;
        position: fixed;
        top: .5rem;
        right: 15px;
        width: 48px;
        height: 48px;
        background: rgba(255,255,255,80%);
        border-radius: 50%;
        margin-bottom: 0;
        color: var(--color-main);
        line-height: 1;
        transition: all 0.3s ease-in;
        z-index: 4;
        cursor: pointer;
        justify-content: center;
        align-items: center;
    }

    .btn-toggle-menu::before {
        content: "\f0c9" !important;
        font-size: 2rem;
    }

    .btn-toggle-menu .icon-bar {
        display: block;
        width: 32px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--white);
        color: var(--white);
        transition: all 0.2s ease;
    }

    .btn-toggle-menu .icon-bar + .icon-bar {
        margin-top: 0.4rem;
    }

    .btn-toggle-menu .top-bar {
        transform: rotate(0deg);
    }

    .btn-toggle-menu .middle-bar {
        opacity: 1;
    }

    .btn-toggle-menu .bottom-bar {
        transform: rotate(0deg);
    }

    .btn-toggle-menu:focus {
        outline: none;
    }

    .btn-toggle-menu.collapsed::before {
        content: "\f00d" !important;
    }

    .btn-toggle-menu.collapsed .top-bar {
        margin-left: 0;
        width: 32px;
        transform: rotate(43deg);
        transform-origin: -4% 10%;
    }

    .btn-toggle-menu.collapsed .middle-bar {
        opacity: 0;
    }

    .btn-toggle-menu.collapsed .bottom-bar {
        margin-left: 0;
        width: 32px;
        transform: rotate(-43deg);
        transform-origin: 10% 90%;
    }

    
    #header {
        top: 0;
        padding: 0;
        width: 100%;
        box-shadow: none;
        z-index: 3;
    }

    .gnav {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        height: 100dvh; /* 新ブラウザ対応: アドレスバー含めた全画面 */
        background-color: #fff;
        clear: both;
        z-index: 3;
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
    }
    
    .gnav-in {
        padding: 3.5rem 1rem;
        background-color: rgba(198, 156, 109, 51%);
    }

    .gnav ul {
        display: block;
        margin: 1.5rem 0 3.5rem 7%;
    }

    .gnav ul.menu_sp li a {
        padding: 0;
    }

    .gnav ul li a {
        display: block;
    }

    .gnav ul li a svg {
        margin-bottom: 3px;
        font-size: 2.6rem;
    }

    .gnav .h_ft_logo {
        position: relative;
        bottom: 1.8rem;
        margin: 0 auto;
        width: 16rem;
    }

    .gnav .policy_h {
        margin-top: 5rem;
        display: block;
    }

    .gnav .policy_h a {
        color: var(--gray-5);
        text-decoration: none;
    }

    .gnav #sns {
        margin-bottom: 2rem;
        text-align: center;
    }

    .gnav #sns a {
        display: inline-block;
        margin-top: 0.2rem;
        padding-left: 1.1rem;
    }



    @media(hover: hover) {
        .gnav #sns a:hover {
            color: var(--white);
        }
    }

    .gnav #sns i {
        display: inline-block;
        font-size: 1.7rem;
        vertical-align: middle;
    }

    .gnav .search_btn {
        display: block;
    }
}


/*--------------------------------------------------------------
     ### 背景セクション
--------------------------------------------------------------*/
.mb_0 {
    margin-bottom: 0 !important;
}

.sec_bg {
    padding: 3rem 0;
    background-color: var(--gray-2);
    ;
}

.bg_primary {
    background-color: var(--color-primary);
    color: var(--white);
}

.bg_primary_dark {
    background-color: var(--color-primary);
}

.bg_primary_light {
    background-color: var(--color-primary-light);
    ;
}

.bg_yellow {
    background-color: var(--yellow);
    ;
}

.bg_red {
    background-color: var(--red);
    ;
    color: var(--white);
}

.bg_black {
    background-color: var(--black);
    ;
    color: var(--white);
}

.bg_gray_5 {
    background-color: var(--gray-5);
    ;
    color: var(--white);
}

.bg_gray_4 {
    background-color: var(--gray-4);
    ;
    color: var(--white);
}

.bg_gray_3 {
    background-color: var(--gray-3);
    ;
}

.bg_gray_2 {
    background-color: var(--gray-2);
    ;
}

.bg_gray_1 {
    background-color: var(--gray-1);
    ;
}

.bg_white {
    background-color: var(--white);
}

.bg_hover {
    background-color: var(--hover);
    ;
}

.bg_link {
    background-color: #1D72F1;
}

.bg_success {
    background-color: #88C459;
}

.bg_error {
    background-color: #F5414F;
}

.bg_warning {
    background-color: #FFD137;
}

.c-primary {
    color: var(--color-primary);
}

.c-primary_dark {
    color: var(--color-primary);
}

.f_secondary,
.is-style-f_secondary {
    font-family: var(--font-secondary);
}

.no_disc {
    padding: 0;
    list-style-type: none;
}

.caption {
    margin-bottom: 0;
    padding-left: 0.8rem;
    color: var(--gray-4);
    ;
    font-size: 0.8rem;
    text-indent: -0.8rem;
}

/*--------------------------------------------------------------
    ### スライダー
--------------------------------------------------------------*/
/*--------------------------------------------------------------
    ### title
--------------------------------------------------------------*/
.sub_title {
    font-size: 1.4rem;
    font-weight: 400;
}

.headline {
    position: relative;
    padding-bottom: 0;
    -webkit-text-stroke-width: 1.5px;
    -webkit-text-stroke-color: #555;
    color: transparent !important;
    letter-spacing: 1px;
    font-size: 3.5rem;
    font-family: var(--font-en);
    font-weight: 600;
    line-height: 1.1;
}

.cat_tit {
    margin-bottom: 2rem;
    font-size: 1.7rem;
    font-weight: 400;
    letter-spacing: 3px;
}

.title {
    margin-top: 2rem;
    margin-bottom: 3.5rem;
    text-align: center;
    font-size: 1.5rem;
}

.page_header {
    padding-top: 3.5rem;
}

.page_title {
    color: transparent;
    font-family: var(--font-en);
    font-size: 3.75rem;
    font-weight: 400;
    -webkit-text-stroke-width: 1.5px;
    -webkit-text-stroke-color: #555;
    line-height: 1.3;
}

.page_title i {
    display: block;
    margin-bottom: 0.8rem;
    color: var(--color-primary);
    font-size: 2.7rem;
}


.title_lg {
    margin: 1.3rem 0 3.7rem;
    color: var(--black);
    ;
    text-align: center;
    font-size: 2rem;
    font-weight: 100;
    line-height: 1.6;
}

.title_xl {
    margin-bottom: 1.5rem;
    text-align: left;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5;
}

.title_xxl {
    margin-top: 2rem;
    text-align: center;
    font-size: 2.5rem;
}

.entry_header {
    margin-bottom: 1.5rem;
}

.entry_title {
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.6;
}

@media (max-width:767px) {

    .sub_title {
        font-size: 1.5rem;
    }

    .cat_tit {
        font-size: 1.5rem;
        line-height: 1.35;
    }

    .page_title {
        font-size: 3.25rem;
    }

    .headline {
        margin-top: 2rem;
    }

    .title {
        margin-bottom: 2rem;
    }

    .title_lg {
        margin: 0.8rem 0 3.3rem;
    }

    .title_xl {
        font-size: 1.5rem;
    }

    .title_xxl {
        text-align: left;
        font-size: 1.7rem;
    }

    .entry_ov_tit {
        margin: 2rem 0 1.3rem;
    }

    .page_header .headline {
        margin-top: 0;
    }
}


.is-style-title-xxl + .is-style-desc {
    margin-top: 2rem;
}

.heading-bd {
    padding-top: 2.25rem;
    text-align: center;
}

.heading-bd span {
    padding: 0 1.6rem;
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    border: 1px solid #000;
    border-radius: 44px;
    font-size: 1.4375rem;
    font-weight: 500;
    text-align: center;
}

.heading-bd  img {
    max-width: 128px;
}

/*--------------------------------------------------------------
    ###button
--------------------------------------------------------------*/
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 1rem .1rem;
    min-width: 166px;
    min-height: 44px;
    background-color: var(--color-primary-dark);
    box-sizing: border-box;
    border: 1px solid var(--color-primary);
    text-align: center;
    text-decoration: none;
    color: var(--white);
    font-size: 1.4375rem;
    font-weight: bold;
    line-height: 1.2;
    cursor: pointer;
    transition: background-color .4s ease, color .4s ease, border .4s ease;
}

@media(hover: hover) {
    .button:not(.primary-light):hover {
        color: var(--color-primary);
        border-color: var(--color-primary);
        background-color: var(--white);
    }
}

.button.primary-light {
    background-color: rgba(57, 110, 178, .7);
    border-color: transparent;
}

.is-style-button--size-xs {
    min-width: 78px;
    min-height: 24px;
    font-size: .88rem;
}

.is-style-button--size-sm {
    min-width: 164px;
}

.is-style-button--size-s {
    min-width: 112px;
    min-height: 22px;
    font-size: .75rem;
}


.btn-more-wrap {
    margin-top: .75rem;
}

.button-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 1rem .1rem;
    min-width: 242px;
    min-height: 40px;
    background-color: var(--white);
    border: 1px solid var(--color-primary);
    text-align: center;
    text-decoration: none;
    color: var(--color-prima);
    font-size: 1rem;
    font-weight: bold;
    line-height: 1.2;
    cursor: pointer;
    transition: background-color .4s ease, color .4s ease, border .4s ease;
}


@media(hover: hover) {
    .button-outline:hover {
        color: var(--white);
        border-color: var(--color-primary);
        background-color: var(--color-primary);
    }
}



.btn-cat .is-style-button--size-xs {
    padding: 0 .4rem .1rem;
    min-width: 112px;
    min-height: 22px;
    font-size: 0.75rem;
}

.btn_wrap {
    margin-top: 3rem;
    text-align: center;
}




@media (max-width:767px) {

    /*--------------------------------------------------------------
      ### button
    --------------------------------------------------------------*/
    .btn_wrap {
        margin-top: 3.2rem;
    }
}

.card_group {
    padding: 5rem 0 4rem;
}



@media (max-width:767px) {
    .card_group {
        padding: 3.5rem 0 1.5rem;
    }
}

.is-style-box-shadow {
    padding: 2rem 2rem 1.6rem;
    border-radius: 8px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}

.is-style-box-shadow .is-style-icon {
    margin-bottom: 0.8rem;
}

.is-style-box-shadow p {
    color: var(--gray-4);
    ;
    font-size: 0.9rem;
}

.is-style-box-shadow .wp-block-button {
    margin-bottom: 0;
}

.is-style-box-shadow .wp-block-button.is-style-outline .wp-block-button__link {
    padding: 0.3rem 2rem;
}

.is-style-box-square {
    padding: 1.2rem 1rem 1.8rem;
}

.is-style-box-square h5 {
    text-align: center;
    line-height: 1.4;
}

.is-style-box-square figure {
    margin: 1.6rem auto;
    width: 80px;
}

.is-style-box-square p {
    margin-bottom: 0;
}

/*--------------------------------------------------------------
    ### ヒーローイメージ
--------------------------------------------------------------*/
#hero {
    position: relative;
    width: 100%;
}

#hero .pic {
    position: relative;
}

#hero .pic img {
    position: relative;
    width: 100%;
    height: auto;
    vertical-align: bottom;
    z-index: 1;
}

#hero .hero_copy {
    margin: 5rem 0;
}

#hero.visual_2 {
    margin-bottom: 0;
}

#hero.visual_2.mb_0 {
    margin-bottom: 0 !important;
}

#hero.visual_2 .pic {
    margin-bottom: 0;
}

#hero.visual_2 .hero_copy {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    display: flex;
    align-items: center;
    height: 100%;
    color: var(--white);
    z-index: 1;
}

#hero.visual_2 .page_header {
    padding-top: 0;
    text-align: left;
}

#hero.visual_2 .page_title {
    margin-top: 2rem;
    letter-spacing: 1px;
    font-size: 4.5rem;
    -webkit-text-stroke-color: #fff;
    line-height: 1;
}

#hero .copy_lead {
    margin-bottom: 1rem;
    padding-bottom: 1.3rem;
    text-shadow: 0 3px 6px rgba(0, 3, 6, 0.16);
    font-size: 3.5rem;
    font-weight: 300;
    line-height: 1.3;
}

@media (max-width:767px) {

    #hero {
        margin-top: 0;
    }

    #hero .hero_copy {
        margin-bottom: 3.3rem;
        box-sizing: border-box;
    }

    #hero.visual_2 .page_header {
        left: 0;
        right: 0;
    }

    #hero.visual_2 .page_title {
        margin-top: 9.5vw;
        font-size: 17vw;
    }

    #hero .copy_lead {
        margin-bottom: 0;
        font-size: 3rem;
    }

    .copy_lead {
        font-size: 1.2rem;
    }
}

.copy_lead {
    margin-bottom: 4.5rem;
    font-weight: 500;
    line-height: 1.8;
}

/*--------------------------------------------------------------
      ### scroll icon
--------------------------------------------------------------*/
.scroll_icn {
    position: absolute;
    top: 42%;
    right: 15px;
    overflow: hidden;
    transition: all .3s;
    z-index: 1;
}


.scroll_icn::before {
    animation: 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    animation-iteration-count: infinite;
    background: #fff;
    content: '';
    pointer-events: none;
    position: absolute;
    z-index: 1;
}

.scroll_icn::before {
    animation-name: scrll-down;
    inset: 0 0 0;
}

.scroll_icn.scrolled {
    display: none;
}



@keyframes scrll-down {
    100% {
        transform: translateY(100%);
    }
}

@keyframes scrll-up {
    100% {
        opacity: 0;
        transform: translateY(0);
    }
}

.scroll_icn img {
    max-width: 20px;
}

@media only screen and (min-width: 1480px) {
    .scroll_icn {
        right: 5%;
    }
}

@media only screen and (max-width: 1280px) {
    .scroll_icn {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .scroll_icn {
        display: none;
    }
}

/*--------------------------------------------------------------
      ### wp related
--------------------------------------------------------------*/
.wp-block-group {
    padding: 2.5rem 1.18rem;
}

.wp-block-group .inner {
    padding: 0;
}

.wp-block-group .wp-block-group {
    padding-left: 0;
    padding-right: 0;
}

.wp-block-group.has-cyan-bluish-gray-background-color {
    background-color: var(--gray-1);
    ;
}

.wp-block-group.is-style-banner {
    margin-top: 1rem;
}

.wp-block-group.is-style-banner .wp-block-group__inner-container {
    padding: 2.5rem 1rem 1.9rem;
}

.wp-block-group.is-style-banner .wp-block-group__inner-container p {
    font-size: 0.9rem;
}

.wp-block-group.is-style-pt-0 {
    padding-top: 0 !important;
}

.wp-block-group.is-style-p-0 {
    padding: 0 !important;
}

.wp-block-group.is-style-bd {
    border: 1.3px solid var(--color-primary-dark);
}

.wp-block-group .sec_striped {
    padding: 0;
}

.wp-block-group .sec_striped .headline {
    margin-top: 0;
}

.wp-block-group.is-style-pt-md {
    padding-top: 2rem;
}

.wp-block-group > * {
    max-width: 1280px;
    margin-left: auto !important;
    margin-right: auto !important;
}

@media (max-width:767px) {
    .wp-block-group > * {
        max-width: 100%;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .wp-block-group {
        padding: 3.25rem 1rem 4rem;
    }

    .wp-block-group.is-style-banner .wp-block-group__inner-container br {
        display: block;
    }

    .wp-block-group .wp-block-group__inner-container {
        max-width: 100%;
        padding: 0 1rem;
    }

    #page .wp-block-group.has-background {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

.wp-block-columns.is-layout-flex.is-style-flex-wrap {
    flex-wrap: wrap !important;
}

.wp-block-columns.is-layout-flex.is-style-gr-lg {
    flex-wrap: wrap !important;
    gap: 3rem;
}

.wp-block-columns.is-layout-flex.is-style-gr-sm {
    flex-wrap: wrap !important;
    gap: 0.95rem;
}

.wp-block-columns.is-layout-flex.is-style-columns-3 {
    flex-grow: 0;
    flex-wrap: wrap !important;
}

.wp-block-columns.is-layout-flex.is-style-columns-3 .wp-block-column {
    flex-basis: calc(33.3% - 2rem);
}



.wp-block-column .wp-block-image + p {
    margin-top: .5rem;
}

.wp-block-columns .wp-block-column:not(.is-style-box-shadow).has-background {
    padding-bottom: 1rem;
}

.wp-block-columns .wp-block-column:not(.is-style-box-shadow).has-background > *:not(.wp-block-image) {
    padding: 0 1rem;
}

@media only screen and (min-width: 768px) {

    .wp-block-columns.is-style-ds_column_2 .wp-block-column:not(:only-child) {
        flex-basis: calc(50% - 2.4rem) !important;
        flex-grow: 0;
    }

    .wp-block-columns.is-style-ds_column_2 .wp-block-column:nth-child(2n) {
        margin-left: 4.6rem;
    }
}

@media only screen and (min-width: 768px) and (max-width: 992px) {
    .wp-block-columns.is-style-ds_column_2 .wp-block-column:not(:only-child) {
        flex-basis: calc(50% - 2.3rem) !important;
        flex-grow: 0;
    }

    .wp-block-columns.is-style-ds_column_2 .wp-block-column:nth-child(2n) {
        margin-left: 2.6rem;
    }
}

@media (max-width:767px) {

    .wp-block-columns.is-style-sp_column_2 .wp-block-column {
        flex-basis: calc(50% - 1rem) !important;
        flex-grow: 0;
    }

    #page .wp-block-columns.is-style-ds_column_2 {
        margin-bottom: 0;
    }

    #page .wp-block-columns.is-style-ds_column_2 .wp-block-column {
        margin-bottom: 1.2rem;
    }
}

.wp-block-media-text {
    margin-bottom: 2.5rem;
}

.wp-block-media-text.is-style-224.has-media-on-the-right {
    margin-bottom: 0;
    grid-template-columns: auto 224px;
}

.wp-block-media-text.is-style-224 .wp-block-media-text__media {
    width: 224px;
}

.wp-block-media-text.is-style-224.has-media-on-the-right .wp-block-media-text__content {
    padding-left: 0;
    padding-right: 3.5%;
}

.wp-block-media-text.is-style-224 .wp-block-media-text__content p {
    color: #333;
    font-size: 0.9rem;
}

.wp-block-media-text.is-style-works-gmt {
    grid-template-columns: 256px auto;
}

.wp-block-media-text.is-style-works-gmt .wp-block-media-text__media {
    width: 256px;
}

.wp-block-media-text.is-style-works-gmt .wp-block-media-text__content {
    padding: 0 6.5%;
}

.wp-block-media-text.is-style-block.has-media-on-the-right {
    grid-template-columns: auto 39.6% !important;
}

.wp-block-media-text.is-style-block.has-media-on-the-right .wp-block-media-text__content {
    padding-left: 0;
    padding-right: 10%;
}

.wp-block-media-text.is-style-block.has-media-on-the-right .wp-block-media-text__content p {
    color: #555;
    font-size: 0.9rem;
}

@media only screen and (min-width: 768px) and (max-width: 992px) {
    .wp-block-media-text {
        margin-bottom: 1rem;
    }
}

@media (max-width: 600px) {
    .wp-block-media-text {
        margin-bottom: 3.1rem;
    }

    .wp-block-media-text.is-style-block.has-media-on-the-right .wp-block-media-text__content p {
        margin-bottom: 1.3rem;
    }

    .wp-block-media-text.has-media-on-the-right.is-stacked-on-mobile {
        grid-template-columns: 100% !important;
    }

    .wp-block-media-text.has-media-on-the-right.is-stacked-on-mobile .wp-block-media-text__content {
        padding-right: 0;
        grid-column: 1;
        grid-row: 1;
    }

    .wp-block-media-text.has-media-on-the-right.is-stacked-on-mobile .wp-block-media-text__media {
        grid-column: 1;
        grid-row: 2;
    }

    .wp-block-media-text.is-style-works-gmt .wp-block-media-text__media {
        width: 100%;
    }

    .wp-block-media-text.is-style-works-gmt .wp-block-media-text__content {
        padding: 2rem 0 0;
    }

    .wp-block-media-text.is-style-224.has-media-on-the-right {
        margin-bottom: 0;
    }

    .wp-block-media-text.is-style-224.has-media-on-the-right + .wp-block-media-text.is-style-224.has-media-on-the-right {
        margin-top: 2rem;
    }

    .wp-block-media-text.is-style-224.has-media-on-the-right.is-stacked-on-mobile .wp-block-media-text__media {
        grid-column: 1;
        grid-row: 1;
    }

    .wp-block-media-text.is-style-224.has-media-on-the-right.is-stacked-on-mobile .wp-block-media-text__content {
        margin-top: 1rem;
        grid-column: 1;
        grid-row: 2;
    }
}



.wp-block-table.is-style-company-tbl table {
    border: none;
}

.wp-block-table.is-style-company-tbl table:last-child {
    border: none;
    margin-bottom: 0;
}


.wp-block-table.is-style-company-tbl table tr td {
    padding: 0 0 1.25rem 1.13rem;
    border: 0;
    font-size: 1rem;
    text-align: left;
    line-height: 1.5;
}


.wp-block-table.is-style-company-tbl table tr:last-child td {
    padding-bottom: 0
}

.wp-block-table.is-style-company-tbl table tr td:nth-child(1) {
    width: 96px;
    font-weight: bold;
}

.wp-block-table.is-style-company-tbl table tr td:nth-child(2) {
    padding-left: 1.25rem;
    padding-right: 1rem;
    width: calc(100% - 114px);
}

.wp-block-table.is-style-company-tbl table tr td code {
    display: block;
    margin-top: 1rem;
    font-size: 13px;
    line-height: 1.5;
}



@media (max-width:767px) {

    .wp-block-table.is-style-company-tbl {
        border: none;
    }

    .wp-block-table.is-style-company-tbl table tr td {
        width: 100%;
        line-height: 1.5;
    }

    .wp-block-table.is-style-company-tbl table tr td:nth-child(1) {
        padding: 1.2rem 0 0;
        font-weight: bold;
    }

    .wp-block-table.is-style-company-tbl table tr td:nth-child(2) {
        padding: 0.25rem 0 1.2rem;
    }

}

.wp-block-buttons.is-style-gap-xs {
    gap: .4rem;
}

.wp-block-buttons .wp-block-button {
    line-height: 1.65;
}

.wp-block-buttons .wp-block-button.wp-block-button__width-25 {
    width: calc(25% - 2rem);
}

.wp-block-buttons .wp-block-button.wp-block-button__width-50 {
    width: calc(50% - 2rem);
}

.wp-block-buttons .wp-block-button.wp-block-button__width-75 {
    width: calc(75% - 2rem);
}

.wp-block-buttons .wp-block-button .wp-block-button__link {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.8rem .1rem;
    min-width: 164px;
    min-height: 41px;
    background-color: var(--color-primary-dark);
    border: 1px solid var(--color-primary);
    border-radius: 40px;
    text-align: center;
    text-decoration: none;
    color: var(--white);
    font-size: 1.1rem;
    letter-spacing: .2em;
    font-weight: bold;
    line-height: 1.2;
    cursor: pointer;
    transition: background-color .4s ease, color .4s ease, border .4s ease;
}

.wp-block-buttons .wp-block-button .wp-block-button__link i {
    position: absolute;
    right: .75rem;
}

@media(hover: hover) {
    .wp-block-buttons .wp-block-button .wp-block-button__link:hover {
        text-decoration: none;
        border-color: #f7b82d;
        background-color: #f7b82d;
        opacity: 1 !important;
    }
}


.wp-block-buttons .wp-block-button .wp-block-button__link.has-cyan-bluish-gray-background-color {
    background-color: #abb8c3;
    border-color: #abb8c3;
}

.wp-block-buttons .wp-block-button .wp-block-button__link.has-luminous-vivid-amber-background-color {
    background-color: #fcb900;
    border-color: #fcb900;
}

.wp-block-buttons .wp-block-button .wp-block-button__link.has-vivid-cyan-blue-background-color {
    background-color: #0693e3;
    border-color: #0693e3;
}

.wp-block-buttons .wp-block-button .wp-block-button__link.has-vivid-red-background-color {
    background-color: #cf2e2e;
    border-color: #cf2e2e;
}

.wp-block-buttons .wp-block-button .wp-block-button__link.has-black-color {
    color: var(--black);
    ;
}

.wp-block-buttons .wp-block-button.is-style-outline .wp-block-button__link {
    border: 1px solid var(--color-primary-dark);
    background: transparent;
    color: var(--color-primary-dark);
}

.wp-block-buttons .wp-block-button.is-style-outline-sm .wp-block-button__link {
    min-width: inherit;
    padding: 0 1.25rem .1rem;
    border: 1px solid var(--color-primary-dark);
    background: transparent;
    color: var(--color-primary-dark);
    font-size: 1.5rem;
    font-weight: 500;
}


@media(hover: hover) {
    .wp-block-buttons .wp-block-button.is-style-outline .wp-block-button__link:hover {
        background: var(--color-primary-dark);
        color: var(--white);
        border-color: var(--color-primary-dark);
        opacity: 1 !important;
    }

    .wp-block-buttons .wp-block-button.is-style-outline-sm .wp-block-button__link:hover {
        background: var(--color-primary-dark);
        color: var(--white);
        border-color: var(--color-primary-dark);
        opacity: 1 !important;
    }

}

@media (max-width:767px) {

    .wp-block-buttons.is-style-gap-xs {
        column-gap: 5px;
    }

    .wp-block-buttons .wp-block-button.is-style-outline-sm .wp-block-button__link {
        padding: 0 1rem .1rem;
        font-size: .95rem;
        min-height: 29px;
    }
}



.wp-block-buttons .wp-block-button.is-style-outline .wp-block-button__link.has-white-color {
    border-color: var(--white);
    color: var(--white);
}


.wp-block-buttons .wp-block-button.is-style-fill-square .wp-block-button__link {
    border-radius: 0;
}

.wp-block-buttons .wp-block-button.is-style-square-outline .wp-block-button__link {
    border: 1px solid var(--color-primary);
    border-radius: 0;
    background-color: transparent;
    color: var(--color-primary);
}

.wp-block-buttons .wp-block-button.is-style-square-outline .wp-block-button__link.has-white-color {
    border-color: #fff;
    color: var(--white);
}

@media(hover: hover) {
    .wp-block-buttons .wp-block-button.is-style-square-outline .wp-block-button__link.has-white-color:hover {
        background: var(--color-primary);
        color: var(--white);
        border-color: var(--color-primary);
        opacity: 1 !important;
    }

}

.wp-block-buttons .wp-block-button.is-style-popup .wp-block-button__link {
    padding: 0 1.2rem 0.1rem;
    min-height: 25px;
    font-size: 0.88rem;
}

.wp-block-buttons .wp-block-button.btn_arrow .wp-block-button__link {
    position: relative;
    text-decoration: none;
    text-align: center;
    color: #fff !important;
    font-size: 1.13rem;
}

.wp-block-buttons .wp-block-button.btn_arrow .wp-block-button__link:after {
    position: absolute;
    right: 1rem;
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    content: "\f105";
    font-size: 1.5em;
    line-height: 1;
}

.wp-block-buttons .wp-block-button.btn-md .wp-block-button__link {
    padding: 0.5rem 2.2rem;
}

.wp-block-buttons .wp-block-button.btn-lg .wp-block-button__link {
    padding: 0.4rem 8rem;
}

.wp-block-buttons .wp-block-button.btn-xl .wp-block-button__link {
    padding: 0.4rem 9rem;
}

@media only screen and (min-width: 768px) {
    .wp-block-buttons.is-style-mt-38.is-style-mt-md-15 {
        margin-top: 1.5rem;
    }
}

.is-style-button--pp {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
}

.wp-block-file {
    margin-bottom: 1.5rem;
    line-height: 1.65;
}

.wp-block-file a {
    display: inline-block;
}

.wp-block-file a.wp-block-file__button {
    margin-top: 0.5rem;
    padding: 0.5rem 2rem;
    border: 1px solid var(--color-primary);
    border-radius: 4px;
    background: var(--white);
    color: var(--color-primary);
    font-size: 0.9rem;
}

.wp-block-file a.wp-block-file__button:active,
.wp-block-file a.wp-block-file__button:focus,
.wp-block-file a.wp-block-file__button:visited {
    color: var(--color-primary);
    opacity: 1;
}

@media(hover: hover) {
    .wp-block-file a.wp-block-file__button:hover {
        text-decoration: none;
        border: 1px solid #EB0000;
        color: var(--hover);
    }
}


.wp-block-file:last-child {
    margin-bottom: 2rem;
}

.map iframe {
    width: 100%;
}

.map iframe iframe {
    margin-bottom: 2.3rem;
}


.pickup-box {
    padding: 2rem 1.2rem;
}


/*--------------------------------------------------------------
    詳細ページパターン
--------------------------------------------------------------*/
@media (max-width:767px) {
    .visual-image {
        margin: -1rem -1rem 0;
    }
}
.pickup-box {
    margin-top: 2.6rem;
    position: relative;
    /* margin-top: 5rem; */
    /* padding: 2.25rem 1rem 2rem 3rem; */
    border: 1px solid var(--color-secondary);
}

.pickup-title {
    margin-bottom: .5rem;
    position: absolute;
    top: -25px;
    left: 0;
    right: 0;
    text-align: center;
}

.pickup-title span {
    display: inline-block;
    color: var(--color-secondary);
    font-size: 1.62rem;
    font-weight: 700;
    padding: 0 1.25rem;
    background: #fff;
}

.pickup-list {
    margin: 0;
}

.pickup-list li {
    margin-bottom: 0;
    padding-left: 2.4rem;
    padding-bottom: 1rem;
    font-size: 1.2rem;
    font-weight: 700;
    background: url('../../img/check_icn.png') no-repeat 0 2px;
    background-size: 25px auto;
    line-height: 1.4;

}


@media (max-width:767px) {
    .pickup-box {
        margin-top: 5rem;
        /* padding: 2.25rem 1rem 2rem 3rem; */
    }

    .pickup-list li {
        padding-left: 1.9rem;
        font-size: 1rem;
        background-size: 21px auto;
    }

}

.madori-img-wrap {
    margin: 1.8rem 0 0;
    max-width: 455px;
    width: 100%;
}


.madori-img + .wp-block-buttons {
    margin-top: 2.5rem;
}

.popup-btn {
    margin-top: 1.8rem;
}

@media (max-width:767px) {
    .madori-img-wrap {
        margin: 2.9rem 0 1.5rem;
        max-width: inherit;
        width: 100%;
    }

    .madori-img + .wp-block-buttons {
        margin-top: 1.8rem;
    }
}

.entry-visual img {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 10/4;
}

@media (max-width:767px) {
    .entry-visual img {
        aspect-ratio: 9/4;
    }
}


.single_entry {
    margin-bottom: 5.2rem;
}

.single_entry .bf-content {
    margin: 1.125rem 0 0 0;
    max-width: 512px;
}


.bf-content .bf-content-box {
    padding: 2.5rem 2rem 1.5rem;
}



.bf-content .bf-content-box .wp-block-separator {
    margin: 1rem 0;
}

@media (min-width: 768px) {

    .bf-content .bf-content-box.traffic-box {
        padding: .9rem 2rem .75rem;
    }

    .bf-content .bf-content-box.taffic-box .wp-block-separator {
        margin: .5rem -1.2rem !important;
    }

}

.bf-content-box .wp-block-separator + .is-style-ds-text-xl {
    margin-top: 0;
}

.bf-content-box .is-style-ds-text-xl + .wp-block-buttons {
    margin-top: 1rem;
}

.wp-block-buttons .wp-block-button.is-style-outline-sm .wp-block-button__link.traffic-btn {
    padding: 0 .6rem .1rem;
    min-height: 31px;
    letter-spacing: .1em;
}

@media (min-width: 768px) {
    .wp-block-buttons .wp-block-button.is-style-outline-sm .wp-block-button__link.traffic-btn {
        font-size: 1.19rem;
    }
}

.bf-content-box .is-style-ds-text-ml + .is-style-ds-text-mxl {
    margin-top: .3rem;
}

.bf-content-box .is-style-ds-text-mxl + .is-style-ds-text-m {
    margin-top: 0;
}

.bf-content-box .is-style-ds-text-ml {
    margin-top: 3rem;
}




@media (max-width:767px) {

    .single_entry .bf-content {
        margin: 2.75rem 0 0;
        max-width: 100%;
    }

    .bf-content-box .is-style-bd .wp-block-separator {
        margin: .5rem 0;
    }

    .bf-content .wp-block-group {
        padding: 1.25rem 1.5rem;
    }

    .bf-content .bf-content-box .is-style-ds-text-l + .wp-block-buttons {
        margin-top: .8rem;
    }

    .bf-content-box .is-style-ds-text-ml {
        margin-top: 2rem;
    }

}

.bf-content .bd-box {
    padding: .75rem .8rem .75rem 1.2rem;
    border: 1px solid var(--color-primary);
    border-radius: 18px;
}

.bf-content .bd-box + .bd-box {
    margin-top: .7rem;
}

.bf-content-box .price-box {
    margin: 2.25rem 0 1.1rem;
    padding: 1.65rem 1rem 2rem;
    border: 1px solid var(--color-primary-dark);
    border-radius: 15px;
    text-align: center;
    color: #006033;
    font-weight: 500;
    border-radius: 20px;
}

.price-box .price-txt {
    position: relative;
    margin-bottom: .5rem;
    font-size: 1.25rem;
    letter-spacing: .03em;
}


.price-box .arrow {
    margin-top: 1rem;
    padding-bottom: 1rem;
}

.dwn-arrow {
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 9px solid transparent;
    border-left: 9px solid transparent;
    border-top: 12px solid #006033;
    border-bottom: 0;
}


.price-box .is-style-ds-text-l {
    letter-spacing: inherit;
    line-height: 1.3;
}

.price-box .total-price {
    display: inline-block;
    position: relative;
    margin-bottom: 0;
    padding: 0 22px;
    font-size: 2.3125rem;
    font-weight: 900;
    line-height: 1.3;
}

.price-box .total-price span {
    position: relative;
    z-index: 1;
}

.price-box .total-price:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 3px;
    width: 100%;
    border-bottom: 7px solid #f1ab3e;
}


@media (max-width:767px) {

    .price-box .price-txt {
        font-size: .88rem;
    }

    .dwn-arrow {
        border-right-width: 7px;
        border-left-width: 7px;
        border-top-width: 10px;
    }

    .price-box .total-price {
        font-size: 1.625rem;
        padding: 0 .65rem;
    }
}


.bf-content .overview-gallery li {
    position: relative;
    margin-bottom: 1.25rem;
}

.bf-content .overview-txt {
    margin-top: 2rem;
    font-weight: 700;
}

.bf-content .overview-txt p {
    font-size: .8rem;
    line-height: 1.9;
    margin-right: -.7rem;
}

.bf-content .caution-txt p {
    margin-bottom: 1rem;
    font-size: .67rem;
    font-weight: 500;
    margin-right: -.9rem;
}

.bf-content .overview-gallery .img-caption {
    position: absolute;
    right: .75rem;
    bottom: .1rem;
    margin-bottom: 0;
    font-size: .625rem;
    color: #fff;
}


.bf-content .is-style-ds-text-ml2 span {
    display: block;
    font-size: .88rem;
}

.bf-content .is-style-ds-text-ml2 .land-price {
    display: inline-block;
    padding: 0 .5rem 0 1rem;
    font-size: 3.125rem;
    font-weight: 700;
    line-height: 1;
}

.bf-content-box .wp-block-separator + .is-style-ds-text-ml2:not(.land-price-txt) {
    margin-top: .5rem;
}

@media (max-width:767px) {
    .bf-content .overview-txt p {
        font-size: .65rem;
    }

    .bf-content .caution-txt p {
        font-size: .5rem;
    }

    .bf-content-box .is-style-ds-text-ml2 {
        font-size: 1.13rem;
    }

    .bf-content .is-style-ds-text-ml2 span {
        font-size: .65rem;
    }

    .bf-content .land-price-txt {
        margin-bottom: .75rem;
    }

    .bf-content .is-style-ds-text-ml2 .land-price {
        font-size: 2.125rem;
        padding: 0 .3rem 0 .7rem
    }
}


.bf-content .number-box {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.bf-content .is-style-ds-text-ml + .is-style-ds-text-ml {
    margin-top: .8rem;
}


.is-style-heading2 + .is-style-ds-text-ml {
    margin-top: 0;
}

@media (max-width:767px) {
    .bf-content .number-box {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }
}

@media (min-width:768px) {
    .bf-content .is-style-ds-text-ml.has-md-font-size {
        font-size: 1rem !important;
    }
}


/*--------------------------------------------------------------
    ### form
--------------------------------------------------------------*/
/*
.sent .contact_form {
    display: none;
}
*/
.contact-box {
    margin: .5rem 0 2.3rem;
    padding: 2.3rem 1.5rem;
    background-color: var(--gray-1);
    border-radius: 17px;
}

.contact-box .contact_tbl_wrp {
    margin-top: 3rem;
}

#s_primary.list-content .contact-box {
    margin-left: 1rem;
    margin-right: 1rem;
}

.contact_tbl {
    margin-bottom: 1.5rem;
    width: 100%;
    color: var(--color-main);
}

.contact_tbl input.cf-error {
    border: 2px solid #e74c3c !important;
    background: #fdf2f2;
}

.contact_tbl .cf-error input[type=checkbox] {
    outline:auto;
    outline-color: #e74c3c;
}

.contact_tbl .cf-email-error {
    margin-top: -1rem;
}

.contact_tbl .cnt-row {
    padding: 0;
    line-height: 1.5;
    vertical-align: top;
}

.contact_tbl .cnt-row + .cnt-row {
    margin-top: 1.8rem;
}

.contact_tbl .cnt-row label {
    display: block;
    margin-bottom: 0.625rem;
    color: var(--color-main);
    font-size: .88rem;
    font-weight: 700;
}

.contact_tbl .cnt-row .input {
    width: 100%;
    border: 1px solid #040000;
    color: var(--color-main);
    box-sizing: border-box;
}

.contact_tbl .cnt-row textarea {
    line-height: 1.7;
}

.contact_tbl .cnt-row #zip1,
.contact_tbl .cnt-row #zip2,
.contact_tbl .cnt-row .input {
    padding: 0.45rem 0.3rem;
    font-size: 1rem;
}

.contact_tbl #select {
    padding: 0.4rem 0.3rem;
    width: 90%;
    color: #999;
}

.contact_tbl .line {
    padding-bottom: 4rem;
    border-bottom: 1px solid var(--gray-4);
}

.contact_tbl .n_mark {
    display: inline-flex;
    padding: 0;
    min-width: 34px;
    min-height: 18px;
    border-radius: 18px;
    background-color: #b6282c;
    color: var(--white);
    font-size: 0.53rem;
    line-height: 1;
    align-items: center;
    justify-content: center;
}

.sec_contact {
    margin-bottom: 4rem;
}

.mw_wp_form .submit_wrap {
    text-align: center;
}

.mw_wp_form .submit_wrap .agree_policy {
    margin: 0 auto 1.5rem;
    width: 335px;
    text-align: left;
    color: var(--color-main);
}

.mw_wp_form .submit_wrap .agree_policy a {
    color: var(--color-main);
}

.mw_wp_form .submit_wrap .agree_policy input[type=checkbox] {
    margin-right: 0.6rem;
    width: 15px;
    height: 15px;
    transform: scale(1.4);
}

.mw_wp_form .submit_wrap .error {
    clear: both;
}

.submit_wrap .wpcf7-spinner {
    display: none;
}

.submit_wrap .btn {
    padding-bottom: .2rem;
    width: 187px;
    height: 40px;
    border: 1px solid var(--color-primary);
    border-radius: 40px;
    background-color: var(--color-primary);
    color: var(--white);
    font-size: 1.25rem;
    font-family: var(--font-primary);
    cursor: pointer;
    outline: none;
}



@media(hover: hover) {
    .mw_wp_form .submit_wrap .btn:hover {
        opacity: 0.75;
    }
}

.mw_wp_form.mw_wp_form_confirm .agree_policy {
    display: none;
}

@media (max-width:767px) {

    .contact-box {
        padding: 1.5rem 1.7rem;
    }

    .contact-box .contact_tbl_wrp {
        margin-top: 2rem;
    }

    .contact_tbl {
        margin-bottom: .3rem;
    }

    .contact_tbl .cnt-row + .cnt-row {
        margin-top: 0;
    }

    .contact_tbl .line {
        padding: 3rem 0 2.5rem;
        border: 0;
    }

    .contact_tbl .cnt-row {
        /* padding: 0.6rem 0; */
        width: 100%;
    }

    .contact_tbl .cnt-row .input {
        width: 100%;
    }

    .contact_tbl .cnt-row #select {
        width: 100%;
    }

    .mw_wp_form .submit_wrap p {
        display: block;
    }

    .mw_wp_form .submit_wrap .agree_policy {
        width: 100%;
        text-align: center;
    }

    .mw_wp_form .submit_wrap .btn {
        width: 53%;
        height: 33px;
        font-size: 1rem;
    }
}




.bf-content .contact-ph-wrap {
    display: flex;
    column-gap: .4rem;
    align-items: center;
}

.bf-content .contact-txt-wrp {
    width: 120px;
    display: flex;
    align-items: flex-start;
}

.bf-content .contact-txt-wrp:before {
    position: relative;
    top: 3px;
    content: "";
    display: inline-block;
    margin-right: .5rem;
    width: 26px;
    height: 38px;
    background: url("../../img/ph_icon.png") no-repeat;
    background-size: 26px auto;
}

.bf-content .contact-txt {
    margin-bottom: 0;
    font-size: .88rem;
    font-weight: 500;
    line-height: 1.4;
}

.bf-content .contact-number-wrap {
    width: calc(100% - 140px);
    font-weight: 500;
}

.bf-content .contact-number-wrap .num1 {
    padding-top: .5rem;
    text-decoration: none;
    margin-bottom: 0;
    color: var(--color-main);
    font-size: 2.4375rem;
    font-family: "Inter", sans-serif;
    line-height: 1.2;
}

.bf-content .contact-number-wrap .num2 {
    margin-bottom: 0;
    text-decoration: none;
    color: var(--color-main);
    font-size: 1.4375rem;
    font-family: "Inter", sans-serif;
}

.bf-content .contact-number-wrap .reserv-time {
    margin-bottom: 0;
    font-size: .73rem;
}

.bf-content .contact-txt-wrp.contact-txt-wrp--sns:before {
    position: relative;
    top: 3px;
    content: "";
    display: inline-block;
    margin-right: .5rem;
    width: 27px;
    height: 28px;
    background: url("../../img/line_icon.png") no-repeat;
    background-size: 27px auto;
}

.bf-content .line-btn,.gnav .line-btn {
    margin-top: 1.25rem;
}

.bf-content .line-btn img,.gnav .line-btn img{
    max-width: 254px;
}

@media (max-width: 767px) {

    .bf-content .bd-box {
        border-radius: 15px;
        padding: .6rem 1rem;
    }

    .bf-content .contact-ph-wrap {
        column-gap: .8rem;
    }

    .bf-content .contact-txt-wrp {
        width: 86px;
    }

    .bf-content .contact-txt-wrp:before {
        width: 17px;
        height: 27px;
        background-size: 17px auto;
    }

    .bf-content .contact-txt-wrp.contact-txt-wrp--sns:before {
        width: 18px;
        height: 18px;
        background-size: 18px auto;
    }

    .bf-content .contact-txt {
        font-size: .625rem;
        font-weight: 700;
    }

    .bf-content .contact-number-wrap {
        width: calc(100% - 100px);
        font-weight: 700;
    }

    .bf-content .contact-number-wrap .num1 {
        font-size: 1.75rem;
    }

    .bf-content .contact-number-wrap .num2 {
        font-size: 1rem;
    }

    .bf-content .contact-number-wrap .reserv-time {
        font-size: .625rem;
    }

    .bf-content .contact-number-wrap .line-btn {
        max-width: 121px;
        margin-left: 2rem;
    }


}


.sec-fx {
    margin-top: 5.75rem;
}

.sec-fx .pic-block:first-of-type {
    margin-top: 3.125rem;
}

.sec-fx .pic-block {
    margin-top: 3.5rem;
}


.sec-fx .pic-block figure + figure {
    margin-top: 1.7rem;
}

.sec-fx .pic-block figcaption {
    margin-top: .5rem;
    font-size: 1.1rem;
    font-weight: 500;
}

.sec-fx .advice-block {
    margin-top: 6.25rem;
}

.sec-fx .advice-block img {
    max-width: 380px;
}

@media (max-width:767px) {
    .sec-fx {
        margin-top: 4.25rem;
    }

    .sec-fx .pic-block {
        margin-top: 2.5rem;
    }

    .sec-fx .pic-block figcaption {
        font-size: .75rem;
    }

    .sec-fx .advice-block {
        margin-top: 4.8rem;
        padding-right: 0;
    }

    .sec-fx .advice-block img {
        max-width: 89%;
    }
}

.sec-benefit {
    margin-top: 5rem;
    padding: 0 1.625rem 0 1.75rem;
}

.sec-benefit .tit_g img {
    max-width: 242px;
}

.sec-benefit .tit {
    margin-top: 2.5rem;
}

.sec-benefit .tit_1 img {
    max-width: 351px;
}

.sec-benefit .is-style-ds-text-m20 {
    margin-top: 1.4rem;
}

.sec-benefit .tit_2 img {
    max-width: 369px;
}

.sec-benefit .is-style-ds-text-m20 + .tit {
    margin-top: 3.75rem;
}

.mark {
    position: relative;
    background-position: left -100% center;
    padding-bottom: 1.1em;
    font-weight: bold;
    background-size: 200% 0.4em;
    background-repeat: repeat-x;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, rgb(251, 171, 62) 50%);
    transition: background-position 2s 0.1s;
}


.sec-benefit .tit_3 img {
    max-width: 373px;
}

.sec-benefit + .contact-box {
    margin-top: 5.5rem;
}

.list-more {
    margin-top: 1.75rem;
}

.list-more img {
    max-width: 208px;
}



@media (max-width:767px) {

    .sec-benefit {
        margin-top: 0;
        padding: 0 .75rem;
    }

    .sec-benefit .tit {
        margin-top: 1.5rem;
    }

    .sec-benefit .tit_g img {
        max-width: 167px;
    }


    .sec-benefit .tit_1 img {
        max-width: 282px;
    }

    .is-style-ds-text-m20 {
        font-size: .88rem;
    }

    .sec-benefit .is-style-ds-text-m20 {
        margin-top: 1.25rem;
    }

    .sec-benefit + .contact-box {
        margin-top: 4.125rem;
    }
}

.single_entry .entry_meta .date {
    display: inline-block;
    margin-right: 1rem;
}

.single_entry .entry_meta .btn-cat {
    width: auto;
}

.single_entry .entry_meta hr {
    margin: 1.8rem 0;
}

.single_entry .pic {
    margin-bottom: 2rem;
}

.entry_content h6,
.entry_content h5,
.entry_content h4,
.entry_content h3,
.entry_content h2,
.entry_content h1 {
    margin: 3rem 0 1rem;
}

.entry_content .title {
    margin-top: 0;
    margin-bottom: 4.2rem;
}

.entry_content ul,
.entry_content ol {
    margin-bottom: 2rem;
    padding-left: 1.5rem;
    list-style-type: disc;
}

.entry_content ul li,
.entry_content ol li {
    margin-bottom: 0;
}

.entry_content .wp-block-buttons {
    margin-bottom: 2rem;
}

.entry_content .wp-block-image {
    margin-bottom: 2rem;
}



.entry_content .wp-block-image.is-style-mb-1 {
    margin-bottom: 1rem;
}

.entry_content .wp-block-image figcaption {
    margin-bottom: 0;
    color: var(--gray-4);
    font-size: 0.9rem;
}

.entry_content .wp-block-embed {
    margin-bottom: 2rem;
}

.entry_content .wp-block-embed.aligncenter {
    margin-left: auto;
    margin-right: auto;
}

.entry_content .wp-block-embed.alignright {
    margin-left: auto;
    margin-right: 0;
    max-width: inherit;
}

.entry_content .wp-block-embed iframe {
    margin-bottom: 0;
}

.entry_content .wp-block-embed-youtube {
    width: 628px;
}


.entry_content .wp-block-column h6:first-child,
.entry_content .wp-block-column h5:first-child,
.entry_content .wp-block-column h4:first-child,
.entry_content .wp-block-column h3:first-child,
.entry_content .wp-block-column h2:first-child,
.entry_content .wp-block-column h1:first-child {
    margin-top: 0;
}

.entry_content .wp-block-column .wp-block-embed-youtube {
    width: auto;
}

.entry_content .wp-block-column .wp-block-image {
    margin-bottom: 1em;
}

.entry_content figcaption {
    font-size: 0.8rem;
    line-height: 1.4;
}

.entry_content .wp-block-gallery {
    padding-left: 0 !important;
}

.entry_content .wp-block-gallery .blocks-gallery-item {
    margin-bottom: 1.5rem;
}

.entry_content .blocks-gallery-caption {
    margin-bottom: 2rem;
}

.entry_content .is-style-circle-mask img,
.entry_content .is-style-rounded img {
    border-radius: 50%;
}

.entry_content .wp-block-table {
    margin-bottom: 2rem;
    overflow-y: hidden;
}

.entry_content .wp-block-table.is-style-regular table {
    border: 1px solid var(--gray-4);
}

.entry_content .wp-block-table.is-style-regular table th,
.entry_content .wp-block-table.is-style-regular table td {
    border: 1px solid var(--gray-4);
}

.entry_content .wp-block-table table {
    margin-bottom: 0.5rem;
}

.entry_content .wp-block-table table th,
.entry_content .wp-block-table table td {
    padding: 0.7rem;
}

.entry_content .wp-block-media-text {
    margin-bottom: 2rem;
}

.entry_content .wp-block-group.is-style-banner h1,
.entry_content .wp-block-group.is-style-banner h2,
.entry_content .wp-block-group.is-style-banner h3,
.entry_content .wp-block-group.is-style-banner h4,
.entry_content .wp-block-group.is-style-banner h5,
.entry_content .wp-block-group.is-style-banner h6 {
    margin-bottom: 0.5rem;
}

.entry_content .wp-block-group.is-style-banner h1:first-child,
.entry_content .wp-block-group.is-style-banner h2:first-child,
.entry_content .wp-block-group.is-style-banner h3:first-child,
.entry_content .wp-block-group.is-style-banner h4:first-child,
.entry_content .wp-block-group.is-style-banner h5:first-child,
.entry_content .wp-block-group.is-style-banner h6:first-child {
    margin-top: 0;
}

.entry_content .wp-block-group.is-style-banner .wp-block-buttons:last-child {
    margin-bottom: 0;
}

@media (max-width:767px) {

    /*--------------------------------------------------------------
    ### 詳細ページパターン
    --------------------------------------------------------------*/

    .single_entry {
        margin-bottom: 3.5rem;
    }

    .single_entry .entry_meta {
        margin-bottom: 1.5rem;
    }


    .order_sp01 {
        order: 1;
    }

    .order_sp02 {
        order: 2;
    }

    .order_sp03 {
        order: 3;
    }

    .order_sp04 {
        order: 4;
    }

    .order_sp05 {
        order: 5;
    }

    .order_sp066 {
        order: 6;
    }

    .entry_content .title {
        margin-bottom: 2rem;
    }

    .entry_content .wp-block-embed-youtube {
        width: 100%;
    }

    .entry_content .wp-block-embed iframe {
        max-width: 100% !important;
        width: 100%;
        min-width: 100% !important;
    }

    .entry_content iframe {
        width: 100%;
    }
}

/*--------------------------------------------------------------
    ### popup
--------------------------------------------------------------*/
.pp_none {
    display: none;
}

.pp_content {
    padding: 2.4rem 3.25rem 2.1rem;
    background-color: var(--white);
    border: 1px solid #ccc;
    border-radius: 10px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}

.pp_content .pp_tit {
    color: var(--color-primary);
    font-size: 3.25rem;
    line-height: 1.3;
}

.pp_content .pp_txt {
    font-size: 0.95rem;
}

@media (max-width:767px) {
    .pp_content {
        padding: 3.5rem 0 0;
        box-shadow: none;
        border: none;
        border-radius: 0;
    }
}

/*--------------------------------------------------------------
    ### card
--------------------------------------------------------------*/


@media(hover: hover) {
    a.card:hover {
        opacity: 0.75;
        color: var(--color-primary);
    }
}

.card {
    display: block;
    border: none;
    border-radius: 0;
    text-decoration: none;
    color: var(--color-main);
    line-height: 1.5;
}

.card.has-bg {
    padding: 1.25rem 1rem;
}

.card.has-bg.bg-white {
    background-color: #fff;
}

.card .card-img {
    margin-bottom: 0;
    border-radius: 0;
}

.card .card-img img {
    width: 100%;
    aspect-ratio: 1/1;
    object-fit: cover;
}

.card .card-body {
    padding: 0.8rem 1rem;
}

.card .card-title {
    margin-bottom: 0;
    min-height: 48px;
    font-size: 1.5rem;
    line-height: 1.3;

}

.card .card-title.sm {
    font-size: 0.9rem;
    font-weight: normal;
}

.card .card-title.md {
    font-size: 1.25rem;
    font-weight: 700;
}

.card .card-desc {
    margin-top: .5rem;
    min-height: 52px;
}

.card .card-desc > * {
    margin-bottom: 0
}

.card .card-date {
    font-size: 1.5rem;
    line-height: 1.2
}

.card .card-txt {
    font-size: 0.9rem;
}

.card .btn-more {
    background-color: rgba(57, 110, 178, .7);
    border-color: transparent;
}

.card .more {
    margin-bottom: 1rem;
}

.card.npd .card-body {
    padding: 0.8rem 0;
}

.card.card_cnt {
    background-color: var(--gray-1);
    ;
}

.card.card_cnt .card-title {
    text-align: center;
}

.card.card_cnt .more {
    text-align: center;
}

.card .img-rounded {
    display: block;
    text-align: center;
}

.card .img-rounded img {
    width: 216px;
    height: 216px;
    border-radius: 50%;
}


@media only screen and (min-width: 768px) {
    .archive_blog .dcol .card-img img {
        height: 251px;
    }
}

@media (max-width:767px) {
    .card.has-bg {
        padding: 1.7rem 1rem;
    }

    .card .card-title {
        min-height: auto;
        font-size: .88rem;
    }

    .card .card-date {
        font-size: .88rem;
    }

    .card .card-desc {
        min-height: auto;
    }
}



.lead {
    font-size: 1.2rem;
}

.lead_md {
    font-size: 1.1rem;
}

.lead_sm {
    font-size: 0.9rem;
}

/*---  アンダーライン強調  ---*/
.color_bd span {
    background: linear-gradient(transparent 55%, #ffee00 40%);
    font-weight: 700;
}

/*--------------------------------------------------------------
    ### category-style
--------------------------------------------------------------*/
@media screen and (min-width: 768px) {
    /*
    #s_primary .img-col {
        position: fixed;
        height: 100vh;
    }
*/

    .img-col .visual-image img {
        width: 100%;
        object-fit: cover;
    }

    /*
    #s_primary #main { 
        margin-left: 50%;
    }
*/
}

.main-in {
    padding: .75rem .75rem 0;
}

.main-list-in {
    padding: 0 1.13rem;
}


@media (max-width:767px) {
    #s_primary:not(.list-content) #main {
        margin-left: 0;
    }

    .main-in {
        padding: 1rem 1rem 0;
    }

    .main-list-in {
        padding: 0 1rem 1rem;
    }

}


@media screen and (min-width: 768px) {

    body:not(.wp-admin) .blockopts-hide.blockopts-desktop,
    body:not(.wp-admin) .editorskit-no-desktop Specificity: (0, 3, 1) {
        display: none;
    }
}

@media (max-width:767px) {

    body:not(.wp-admin) .blockopts-hide.blockopts-mobile,
    body:not(.wp-admin) .editorskit-no-mobile Specificity: (0, 3, 1) {
        display: none;
    }

}


.cat-title + .is-style-ds-text-ml2 {
    margin-top: 2.2rem;
}

.deli_icon {
    margin-bottom: 2rem;
}

.deli_icon img {
    max-width: 205px;
}


@media (max-width:767px) {
    .cat_title {
        padding: 0 .5rem;
    }

    .cat_title img {
        width: 100% !important;
    }


    .deli_icon img {
        max-width: 180px;
    }

}

.main-list-in .ds-row {
    gap: .75rem .6rem;
}

#pp_content {
    display: none;
}


.wp-block-group .news.news--b {
    margin: 3rem 0 3.5rem;
}

.news ul {
    padding-left: 0;
    list-style-type: none;
}

.news ul li a {
    text-decoration: none;
}


@media(hover: hover) {
    .news ul li a:not(.button):hover {
        color: var(--hover);
    }

    .news ul li a.button:hover {
        background-color: var(--color-primary);
        color: #fff;
    }
}


.news .news__copy {
    display: flex;
    width: 100%;
    align-items: flex-start;
}

.news .news__copy p {
    margin: 0;
    padding: 0 1rem;
    font-size: 1rem;
    line-height: 1.6;
}

.news .news__copy .date {
    display: inline-block;
    padding-left: 0;
    line-height: 1.5;
    white-space: nowrap;
    color: #333;
}

.news .news__copy .btn-cat {
    margin-top: 1px;
    font-size: 0.75rem;
}

.news .news__copy .t_right {
    padding: 0 0.9rem;
}

.news .news__copy .t_right p {
    padding: 0;
}

.news .news__copy .t_right .btn-cat {
    margin-right: 1rem;
    padding: 0;
}

.news .btn {
    margin-bottom: 0.7rem;
}

.news .news__r .thumb_ph img {
    height: 150px;
}

.news .news_bd {
    padding: 1.8rem 0 0.8rem;
    border-top: 1px solid #ccc;
}

.news .news_bd:last-child {
    border-bottom: 1px solid #ccc;
}

.news.news--ph .news__r {
    margin-bottom: 1.9rem;
}

.news.news--ph .news__r .news__copy p {
    padding: 0;
}

.news.news--ph .news__r .news__copy .tit {
    display: block;
    min-height: 56px;
}

.news.news--ph .news__r .news__copy .tit a {
    color: var(--gray-5);
    ;
    text-decoration: none;
}

.news.news--ph .news__r .news__copy .date {
    display: block;
    color: #777;
    font-size: 0.9rem;
}

.news.news--b .news__in .news__copy {
    display: flex;
    margin: 0 0 1.25rem;
}

.news.news--b .news__in .news__copy .tit {
    position: relative;
    padding-right: 0;
    width: 70%;
    vertical-align: middle;
}

.news.news--b .news__in .news__copy:last-child {
    margin-bottom: 0;
}

.news.news--d ul {
    padding: 0;
    list-style-type: none;
}

.news.news--d ul li {
    margin-bottom: 2rem;
}

.news.news--d ul li .date {
    display: block;
    margin-bottom: 0.5rem;
}

.news.news--d ul li a {
    color: var(--gray-5);
    ;
}

@media only screen and (min-width: 768px) {
    .news .news__copy .tit a {
        text-decoration: none;
    }
}

@media only screen and (min-width: 768px) and (max-width: 992px) {
    .news.news--b .news__in .news__copy .btn-cat {
        width: 170px;
    }
}

@media (max-width:767px) {

    /*--------------------------------------------------------------
    ### category-style
    --------------------------------------------------------------*/
    .news_wrp {
        margin-bottom: 2.8rem;
    }

    .wp-block-group .news.news--b {
        margin: 2.5rem 0 2.5rem;
    }

    .news .news__copy .date {
        margin-bottom: 0.7rem;
    }

    .news .news__copy .btn-cat {
        margin-bottom: 0.7rem;
    }

    .news .news__copy .t_right {
        display: block;
    }

    .news .news__r .thumb_ph {
        margin-bottom: 1rem;
    }

    .news .news_bd {
        padding-top: 1.5rem;
    }

    .news.news--ph .news__r .news__copy .tit {
        min-height: inherit;
    }

    .news.news--b .news__in .news__copy {
        margin-bottom: 1.8rem;
    }

    .news.news--b .news__in .news__copy .tit {
        width: 84%;
    }

    .news.news--b .news__in .news__copy .tit_sp {
        display: block;
        padding: 0;
        width: 100%;
        line-height: 1.8;
    }

    .news.news--b .news__in .news__copy .tit_sp a {
        text-decoration: underline;
    }

    .news.news--b .news__in .news__copy.sp-wrap .tit {
        width: 100%;
    }

    .sp-wrap {
        flex-wrap: wrap;
    }
}



/*--------------------------------------------------------------
    ### search
--------------------------------------------------------------*/
.not-found .search {
    margin-top: 2rem;
}

.search-form {
    font-size: 0;
}

.search-form label {
    vertical-align: top;
}

.search-form .screen-reader-text {
    display: none;
}

.search-form input[type=search] {
    padding-left: 0.5rem;
    width: 250px;
    height: 47px;
    border: 1px solid #ccc;
    border-radius: 0;
    font-family: var(--font-primary);
    font-size: 0.9rem;
    -moz-appearance: none;
    appearance: none;
    -webkit-appearance: none;
}

.search-form input[type=search]:focus {
    border-radius: 0;
    outline: none;
}

.search-form input[type=search]::-webkit-search-cancel-button {
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    background: url(../img/ico_cancel.png) no-repeat;
    background-size: 20px 100%;
}

.search-form .search-submit {
    position: relative;
    top: 1px;
    margin: 0;
    padding: 0.7rem 1rem;
    height: 47px;
    border: 0;
    background: var(--color-primary);
    color: var(--white);
    font-size: 1.1rem;
    outline: none;
    cursor: pointer;
    -moz-appearance: none;
    appearance: none;
    -webkit-appearance: none;
}

.search_result .entry_header a {
    font-size: 1.2rem;
}



@media(hover: hover) {
    .search_result .entry_header a:hover {
        color: var(--hover);
    }
}

.search_result .entry_content {
    color: #999;
}


@media (max-width:767px) {
    .search_select .select_box {
        width: 100%;
        margin-right: 0;
        margin-bottom: 2rem;
    }

    .search_select .select_box:last-child {
        margin-bottom: 0;
    }
}




/*--------------------------------------------------------------
### Pagination
--------------------------------------------------------------*/
.pagination {
    position: relative;
    margin-top: 4.5rem;
    text-align: center;
    clear: both;
}

.pagination a,
.pagination span {
    display: inline-block;
    margin: 0.1rem 0.3rem;
    padding: 0.5rem 0.9rem;
    border: 1px solid var(--color-primary);
    border-radius: 4px;
    background-color: transparent;
    text-decoration: none;
    color: var(--color-primary);
    transition: background-color 0.3s;
}

.pagination .current,
.pagination a:hover {
    border: 1px solid var(--color-primary);
    background-color: var(--color-primary);
    color: var(--white);
}

@media only screen and (min-width: 768px) {

    /*--------------------------------------------------------------
       pagination
     --------------------------------------------------------------*/
    .pagination a.btn-prev,
    .pagination a.btn-next {
        padding-left: 1.3rem;
        padding-right: 1.3rem;
    }

    .pagination.pg-lg a,
    .pagination.pg-lg span {
        padding: 0.8rem 1.2rem;
    }

    .pagination.pg-lg a.btn-prev,
    .pagination.pg-lg a.btn-next {
        padding-left: 1.3rem;
        padding-right: 1.3rem;
    }
}

@media (max-width:767px) {

    /*--------------------------------------------------------------
      ### pagination
    --------------------------------------------------------------*/
    .pagination.pg-lg span,
    .pagination.pg-lg a,
    .pagination span,
    .pagination a {
        margin: 0.2rem;
        padding: 0.3rem 0.7rem;
    }

    .pagination {
        margin: 4rem 0;
    }

    .wp-block-group .pagination {
        margin-bottom: 0;
    }
}


/*--------------------------------------------------------------
    ### sidebar
--------------------------------------------------------------*/
#side_bar {
    margin-bottom: 0;
}

#side_bar .section {
    margin-bottom: 4rem;
}

#side_bar .section:last-child {
    margin-bottom: 0;
}

#side_bar .side_title {
    margin-bottom: 1.2rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid #999;
    font-size: 1.13rem;
    line-height: 1.6;
}

#side_bar .popular_post {
    padding: 0;
    list-style-type: none;
}

#side_bar .popular_post li {
    margin-bottom: 1.2rem;
}

#side_bar .popular_post li a {
    text-decoration: none;
}

#side_bar .popular_post li .p_thumb {
    display: block;
    margin-bottom: 0.6rem;
}

#side_bar .popular_post li .p_title {
    display: block;
}

#side_bar .cat_lists {
    padding: 0;
    list-style-type: none;
}

#side_bar .cat_lists li {
    margin-bottom: 1rem;
}

#side_bar .cat_lists li a {
    text-decoration: none;
}


@media (max-width:767px) {

    /*--------------------------------------------------------------
     ### side_bar
    --------------------------------------------------------------*/
    #side_bar {
        margin-top: 1rem;
    }

    #side_bar .section:last-child {
        margin-bottom: 0;
    }

    #side_bar .popular_post li:after {
        content: "";
        display: block;
        clear: both;
    }

    #side_bar .popular_post li .p_thumb {
        float: left;
        margin-right: 0.8rem;
        width: 20%;
    }

    #side_bar .popular_post li .p_thumb img {
        width: 100%;
        height: auto;
    }

    #side_bar .popular_post li .p_title {
        width: 100%;
    }
}

/*--------------------------------------------------------------
    # footer
--------------------------------------------------------------*/
#footer {
    padding: 4rem 0 .75rem;
    position: relative;
    background: var(--color-primary) url(../img/ft.jpg) no-repeat;
    background-size: cover;
    color: #fff;
    text-align: center;
}

#footer .inner {
    position: relative;
}

#footer #scroll_top {
    position: absolute;
    right: 10px;
    top: -70px;
    height: 50px;
    transition: all 0.2s ease-in;
    opacity: 0;
}

#footer #scroll_top.fixed {
    position: fixed;
    top: auto;
    right: 10px;
    bottom: 20px;
    z-index: 2;
}

#footer #scroll_top.move {
    right: 10px;
    top: -70px;
}

#footer #scroll_top a {
    display: inline-flex;
    width: 50px;
    height: 50px;
    border-radius: 25px;
    background-color: rgba(51, 51, 51, 0.3);
    color: var(--white);
    text-decoration: none;
    align-items: center;
    flex-flow: column;
    justify-content: center;
}

#footer #scroll_top i {
    font-size: 2.4rem;
}

#footer .ft_logo {
    margin: 0 auto;
    text-align: center;
}

#footer .ft_logo img {
    width: 10rem;
    vertical-align: middle;
}

#footer .ft_logo a {
    display: block;
}

#footer #ft_nav {
    margin: 2.5rem 0 11.9rem;
}

#footer #ft_nav ul {
    display: flex;
    margin-bottom: 0;
    flex-wrap: wrap;
    justify-content: center;
    list-style-type: none;
}

#footer #ft_nav ul li {
    padding: 0 1rem;
    margin-bottom: 0;
    text-align: center;
    font-family: var(--font-nav);
    font-size: 1.3rem;
    font-weight: bold;
    line-height: 1.4;
}

#footer #ft_nav ul li .f_jp {
    display: block;
    letter-spacing: initial;
    font-size: 0.85rem;
    font-family: var(--font-primary);
    color: #9FA3AD;
}

#footer #ft_nav ul li a {
    color: var(--white);
    text-decoration: none;
}



@media(hover: hover) {
    #footer #ft_nav ul li a:hover {
        color: var(--white);
        text-decoration: none;
        opacity: 0.75;
    }
}

#footer .policy_link {
    margin-top: 2rem
}

#footer .policy_link a {
    text-decoration: none;
    color: #fff;
    font-size: 0.75rem;
}

#footer .copyright {
    margin-bottom: 0;
    color: #fff;
    font-size: 0.75rem;
}


@media (max-width: 767px) {
    #footer {
        padding-top: 5rem;
        background: url(../img/ft_sp.jpg)no-repeat;
        background-size: cover;
        text-align: center;
    }

    #footer #scroll_top.fixed {
        bottom: 60px;
    }

    #footer #scroll_top.move {
        opacity: 0 !important;
    }

    #footer .ft_logo {
        margin-bottom: 3rem;
    }


    #footer #ft_nav {
        margin: 6.5rem 0 1rem;
    }

    #footer #ft_nav ul {
        padding: 0;
    }

    #footer #ft_nav ul li {
        float: none;
        margin-top: 1.25rem;
        width: 38%;
    }


    #footer #ft_nav ul li a {
        display: block;
    }

    #footer .policy_link {
        margin-top: 1.5rem;
    }

    #footer .ft_btm {
        display: block;
        text-align: center;
    }

    #footer .ft_btm .copyright {
        margin-top: 1.25rem;
    }
}


@media (max-width: 767px) {
    #content {
        width: 100%;
        max-width: 100%;
        min-height: calc(100vh - 24px);
    }


    #content.left-side #side_bar {
        order: 2;
    }
}

@media (max-width: 340px) {
    .lnav ul li {
        padding: 0 0.75rem;
    }

}
