@charset "utf-8";

/*================================
	Layout, Elements
================================*/
:root {
    --GN: #435A41;
    --wt: #FFFFFF;
    --bk: #333333;
    --br: #958663;
    --line-height: 2;
    --letter-spacing: 0.1em;
}


.clearfix:after,
input[type=text],
input[type=password],
input[type=tel],
input[type=url],
input[type=email],
input[type=file],
input[type=image],
input[type=number],
input[type=range],
input[type=color],
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=month],
input[type=week],
input[type=time],
input[type=search],
select,
textarea {
    display: block
}

blockquote,
body,
button,
code,
dd,
div,
dl,
dt,
fieldset,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
legend,
li,
ol,
p,
pre,
select,
td,
textarea,
th,
ul {
    margin: 0;
    padding: 0
}

a,
a:active,
a:hover,
a:link,
a:visited {
    text-decoration: none;
    outline: 0
}

li,
ul {
    list-style: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

caption,
th {
    text-align: left
}

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

.clearfix:after {
    content: " ";
    clear: both
}


html {
    font-size: 10px;
    background: #F4F4F3;
    height: 100%
}

body {
    position: relative;
    min-width: 1220px;
    min-height: 100vh;
    display: flex;
    display: -webkit-flex;
    flex-direction: column;
    -webkit-flex-direction: column;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 10px;
    line-height: var(--line-height);
    letter-spacing: var(--letter-spacing);
    color: var(--bk);
}

button,
input[type=submit],
input[type=reset],
input[type=search],
input[type=button],
select,
textarea {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none
}

button,
input,
select,
textarea {
    font-family: inherit;
    font-weight: inherit;
    outline: 0;
    border: 1px solid #333;
    background-color: #FFF
}

button,
input[type=submit],
input[type=reset],
input[type=file],
input[type=color],
input[type=button] {
    cursor: pointer
}

input[type=file],
input[type=image],
input[type=color] {
    border: none;
    background-color: transparent
}

select {
    text-indent: .01px;
    text-overflow: '';
    background-position: 100% center;
    background-repeat: no-repeat;
    padding: 0 20px 0 10px
}

select::-ms-expand {
    display: none
}

textarea {
    overflow: auto;
    resize: vertical
}

canvas,
iframe,
svg,
video {
    border: 0;
    max-width: 100%;
    display: block
}

img {
    display: inline-block;
}


html {
    font-size: 10px;
    scroll-behavior: smooth;
    scroll-padding-top: 90px;
}

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

.lato {
    font-family: "Lato", sans-serif;
    font-weight: 700;
}

.baskervville {
    font-family: "Baskervville", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}




main {
    overflow: clip;
    position: relative;
    z-index: 1;
}

html.noscroll,
body.noscroll {
    overflow: hidden;
}

img {
    height: auto;
}

.animated {
    opacity: 0;
}

.fadeInUp {
    opacity: 1;
}

hr {
    background-color: #CCBCA4;
    margin: 80px 0;
    height: 1px;
    border: none;
}

.bar_effect1 .active span:nth-of-type(1) {
    -webkit-transform: translateY(12px) rotate(-45deg);
    transform: translateY(12px) rotate(-45deg);
    background: #fff !important;
}

.bar_effect1 .active span:nth-of-type(2) {
    opacity: 0;
}

.bar_effect1 .active span:nth-of-type(3) {
    -webkit-transform: translateY(-8px) rotate(45deg);
    transform: translateY(-8px) rotate(45deg);
    background: #fff !important;
}

.bar_effect2 .active span:nth-of-type(1) {
    -webkit-transform: translateY(17px) rotate(-315deg);
    transform: translateY(17px) rotate(-315deg);
    background: #fff !important;
}

.bar_effect2 .active span:nth-of-type(2) {
    opacity: 0;
}

.bar_effect2 .active span:nth-of-type(3) {
    -webkit-transform: translateY(-4px) rotate(315deg);
    transform: translateY(-4px) rotate(315deg);
    background: #fff !important;
}

.bar_effect3 .active {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
}

.bar_effect3 .active span:nth-of-type(1) {
    -webkit-transform: translateY(11px) rotate(-45deg);
    transform: translateY(11px) rotate(-45deg);
}

.bar_effect3 .active span:nth-of-type(2) {
    -webkit-transform: translateY(0) rotate(45deg);
    transform: translateY(0) rotate(45deg);
}

.bar_effect3 .active span:nth-of-type(3) {
    opacity: 0;
}

.bar_effect4 span:nth-of-type(3),
.bar_effect4 .active span:nth-of-type(3) {
    transition: none;
}

.bar_effect4 .active {
    -webkit-transform: rotateX(720deg);
    transform: rotateX(720deg);
}

.bar_effect4 .active span:nth-of-type(1) {
    -webkit-transform: translateY(11px) rotate(-45deg);
    transform: translateY(11px) rotate(-45deg);
}

.bar_effect4 .active span:nth-of-type(2) {
    -webkit-transform: translateY(0) rotate(45deg);
    transform: translateY(0) rotate(45deg);
}

.bar_effect4 .active span:nth-of-type(3) {
    opacity: 0;
}

.bar_effect5 span:nth-of-type(1) {
    -webkit-animation: menu-bar01 .75s forwards;
    animation: menu-bar01 .75s forwards;
}

@-webkit-keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(12px) rotate(45deg);
    }

    50% {
        -webkit-transform: translateY(12px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar01 {
    0% {
        transform: translateY(12px) rotate(45deg);
    }

    50% {
        transform: translateY(12px) rotate(0);
    }

    100% {
        transform: translateY(0) rotate(0);
    }
}

.bar_effect5 span:nth-of-type(2) {
    transition: all .25s .25s;
    opacity: 1;
}

.bar_effect5 span:nth-of-type(3) {
    -webkit-animation: menu-bar02 .75s forwards;
    animation: menu-bar02 .75s forwards;
}

@-webkit-keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-12px) rotate(-45deg);
    }

    50% {
        -webkit-transform: translateY(-12px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar02 {
    0% {
        transform: translateY(-12px) rotate(-45deg);
    }

    50% {
        transform: translateY(-12px) rotate(0);
    }

    100% {
        transform: translateY(0) rotate(0);
    }
}

.bar_effect5 .active span:nth-of-type(1) {
    -webkit-animation: active-menu-bar01 .75s forwards;
    animation: active-menu-bar01 .75s forwards;
}

@-webkit-keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(12px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(12px) rotate(45deg);
    }
}

@keyframes active-menu-bar01 {
    0% {
        transform: translateY(0) rotate(0);
    }

    50% {
        transform: translateY(12px) rotate(0);
    }

    100% {
        transform: translateY(12px) rotate(45deg);
    }
}

.bar_effect5 .active span:nth-of-type(2) {
    opacity: 0;
}

.bar_effect5 .active span:nth-of-type(3) {
    -webkit-animation: active-menu-bar03 .75s forwards;
    animation: active-menu-bar03 .75s forwards;
}

@-webkit-keyframes active-menu-bar03 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(-10px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(-10px) rotate(-45deg);
    }
}

@keyframes active-menu-bar03 {
    0% {
        transform: translateY(0) rotate(0);
    }

    50% {
        transform: translateY(-10px) rotate(0);
    }

    100% {
        transform: translateY(-10px) rotate(-45deg);
    }
}

.bar_effect6 .active span:nth-of-type(1) {
    -webkit-transform: translateY(8px) rotate(-45deg);
    transform: translateY(8px) rotate(-45deg);
}

.bar_effect6 .active span:nth-of-type(2) {
    left: 200%;
    opacity: 0;
    -webkit-transform: translateY(10px);
    transform: translateY(10px);
    -webkit-animation: active-menu-bar02 .8s forwards;
    animation: active-menu-bar02 .8s forwards;
}

@-webkit-keyframes active-menu-bar02 {
    100% {
        height: 0;
    }
}

@keyframes active-menu-bar02 {
    100% {
        height: 0;
    }
}

.bar_effect6 .active span:nth-of-type(3) {
    -webkit-transform: translateY(-13px) rotate(45deg);
    transform: translateY(-13px) rotate(45deg);
}

.slick-arrow {
    font-size: 0;
    border: none;
    background-color: transparent;
    position: absolute;
    z-index: 2;
}

.slick-arrow:before {
    content: '';
    background-image: url(../img/arrow.png);
    background-repeat: no-repeat;
    background-size: cover;
    width: 30px;
    height: 30px;
    display: block;
}

.slick-prev.slick-arrow:before {
    transform: rotate(-180deg);
}

.scroll_signal {
    width: 1px;
    height: 65px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    opacity: .65;
}

.scroll_signal span {
    position: absolute;
    left: -3px;
    right: 0;
    top: 0;
    margin: auto;
    width: 7px;
    height: 7px;
    background-color: #FFFFFF;
    border-radius: 10px;
    animation: scroll-signal 1.8s forwards infinite;
}

@-webkit-keyframes scroll-signal {
    0% {
        top: 0;
        opacity: 1;
    }

    100% {
        top: 105%;
        opacity: .6;
    }
}

@keyframes scroll-signal {
    0% {
        top: 0;
        opacity: 1;
    }

    100% {
        top: 105%;
        opacity: .6;
    }
}

body::before {}

select {
    background-color: transparent;
    border: 1px solid #BCB9AE;
    padding-right: 50px;
    font-size: 12px;
    padding: 7px 10px;
    padding-right: 50px;
    /* background-image: url(../img/arrow_bottom.png); */
    background-size: 10px;
    background-position: 95% center;
    color: inherit;
}

::placeholder {
    color: #9D9D9D;
    font-weight: 500;
    font-family: inherit;
}

#wrapper {
    /* min-width: 1220px; */
}

.sp {
    display: none !important;
}

.pc {
    display: block;
}

a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    transition: all .3s;
}

a:hover {
    opacity: .7;
}
p,a,i,span,li,ul,ol,h1,h2,h3,h4,h5,h6
 {
    font-size: inherit;
    font-family: inherit;
    font-weight: inherit;
    line-height: 2;
    letter-spacing: .1em;
    color: inherit;
    text-decoration: none;
    text-align: inherit;
    text-transform: inherit;
    text-indent: inherit;
}

p,li {
    font-size: 1.3rem;
    line-height: 2.2;
}

@keyframes video-lazy-spin {
    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

video {
    background-color: var(--GN);
}

/* ロード完了後にフェードイン */
.video-lazy-load {
    opacity: 0;
    transition: opacity 0.6s ease;
    will-change: opacity;
}
.video-lazy-load.is-loaded {
    opacity: 1;
}

/* .video-lazy-load は疑似要素不可のため、親に重ねる */
.works .people .people_inner > .img:has(.video-lazy-load:not(.is-loaded))::after,
.special .video_box:has(.video-lazy-load:not(.is-loaded))::after,
.special .special_video:has(.video-lazy-load:not(.is-loaded))::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: 2.8rem;
    height: 2.8rem;
    box-sizing: border-box;
    border: 2px solid rgba(255, 255, 255, 0.22);
    border-top-color: var(--wt);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    animation: video-lazy-spin 0.75s linear infinite;
    pointer-events: none;
    z-index: 2;
}

.special .special_video:has(.video-lazy-load:not(.is-loaded)) {
    position: relative;
}

.main_header {
    transition: all .8s;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 50px;
    width: 100%;
    z-index: 100;
    position: fixed;
    z-index: 100;
    background: #F4F4F3;
    min-width: 1250px;
}

.home .main_header {
    display: none;
}


.main_header .triger_wrap {
    display: flex;
    width: 75px;
    height: 75px;
    position: static;
    right: 40px;
    top: 43px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    cursor: pointer;
    transition: all .3s;
    z-index: 1000;
    order: 4;
}

.triger_wrap .menu-trigger {
    transition: all .3s;
}

.triger_wrap .menu-trigger {
    display: block;
    position: relative;
    /* width: 75px; */
    /* height: 70px; */
}

.mobilenav {
    display: none;
    position: fixed;
    top: 0;
    left: auto;
    right: 0;
    width: 100%;
    z-index: 80;
    height: 100vh;
    background-color: #f9f8f4;
    width: 100%;
    padding: 0px 0px 0px 0px;
    z-index: 10;
}

.mobilenav.is-show {
    display: block;
    overflow: auto;
    /* IE,Edge */
    -ms-overflow-style: none;
    /* Firefox */
    scrollbar-width: none;
}

/* Chrome,Safari */

.mobilenav.is-show:-webkit-scrollbar {
    display: none
}

.mobilenav .wrap {
    position: absolute;
    left: auto;
    right: calc((100% - 1200px) / 2 + 50px);
    display: flex;
    top: 0;
    bottom: 0;
    margin: auto;
    align-items: center;
}

.mobilenav .wrap h3 {
    position: relative;
}

.mobilenav .wrap h3 span {
    color: #B2A390;
    display: block;
}

.mobilenav .wrap h3 .en {
    font-size: 2rem;
    position: relative;
    padding-bottom: 5px;
}

.mobilenav .wrap h3:before {
    content: '';
    width: calc(100% - 13px);
    height: 1px;
    background-color: #B2A390;
    position: absolute;
    top: calc(50% + 1px);
}

.mobilenav .wrap h3:after {
    content: '';
    width: 5px;
    height: 5px;
    border-radius: 100%;
    background-color: #B2A390;
    position: absolute;
    top: calc(50% - 1px);
    right: 0;
}

.mobilenav .wrap h3 .ja {
    font-size: 1.3rem;
}

.mobilenav .wrap .g_collection_box {
    margin-right: 75px;
    margin-top: 0px;
}

.mobilenav .wrap ul li {
    margin-bottom: 20px;
    width: 180px;
    height: 60px;
    page-break-inside: avoid;
    break-inside: avoid;
}

.mobilenav .wrap ul li a {
    position: relative;
    display: block;
}

.mobilenav .wrap ul li a:before {
    content: '';
    width: calc(100% - 13px);
    height: 1px;
    background-color: #AFAEAE;
    position: absolute;
    top: calc(50% + 1px);
}

.mobilenav .wrap ul li a:after {
    content: '';
    width: 5px;
    height: 5px;
    border-radius: 100%;
    background-color: #AFAEAE;
    position: absolute;
    top: calc(50% - 1px);
    right: 0;
}

.mobilenav .wrap ul li .en {
    font-size: 1.8rem;
    padding-bottom: 7px;
}

.mobilenav .wrap ul li .ja {
    color: var(--GN, #435A41);
    font-size: 1.3rem;}


.main_header .triger_wrap span {
    background-color: #F7F4E9;
    height: 2px;
    width: 30px;
    position: absolute;
    top: 20px;
    left: 0;
    right: 0;
    margin: auto;
    transition: all .4s;
}

.main_header .triger_wrap span:nth-of-type(1) {
    top: 26px;
}

.main_header .triger_wrap span:nth-of-type(2) {
    top: 40px;
}

.main_header .triger_wrap.active span:nth-of-type(1),
.main_header .triger_wrap.active span:nth-of-type(2) {
    width: 21px;
}

.main_header .triger_wrap.active span:nth-of-type(1) {
    transform: rotate(-45deg);
    right: 0px;
    top: 29px;
}

.main_header .triger_wrap.active span:nth-of-type(2) {
    transform: rotate(45deg);
    right: 0px;
    top: 29px;
}

.main_header .triger_wrap.active span:nth-of-type(3) {
    opacity: 0;
    top: 29px;
    width: 0;
    /* display: none; */
}

.main_header .triger_wrap.active span {
    /* background-color: #555555; */
}


.header_sns i {
    color: #F7F4E9;
    font-size: 1.9rem;
    transition: all .3s;
}

.mobilenav .reservation_btns li {
    margin-right: 0;
    /* margin-right: 5px; */
    margin-bottom: 5px;
}

.mobilenav .reservation_btns {
    margin-top: 30px;
}

.mobilenav .reservation_btns a {
    color: #F7F4E9;
    background-color: #907416;
    width: 100%;
}

.mobilenav .reservation_btns a i {
    color: #F7F4E9;
}

.mobilenav .general_info {
    margin-top: 20px;
}

.mobilenav .general_info .tel a {
    color: #907416;
}

.mobilenav .general_info .opentime {
    color: #907416;
}

.main_header .top_nav {
    position: static;
    z-index: 102;
    top: 64px;
    left: 0;
    right: 0;
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
}

.main_header .top_nav .logo {
    margin-right: 20px;
    display: flex;
    align-items: center;
}

.main_header .top_nav .logo a {
    display: flex;
    align-items: center;
}



.main_header .top_nav ul {
    display: flex;
    justify-content: flex-end;
    color: var(--GN);
    margin-left: auto;
    align-items: center;
}

.main_header .sitemap_list > li {
    margin: 0 1vw;
    color: var(--GN);
}


.main_header .sitemap_list a {
    white-space: nowrap;
    transition: all .3s;
    font-size: 1.3rem;
}
.main_header .sitemap_list a i {
    font-size: 1.7rem;
    margin-top: 2px;
}
.main_header .sitemap_list > li.entry_btn {
    margin-right: 0;
}
.entry_btn a {
    display: flex;
    align-items: center;
    gap: 10px;
}
.main_header .top_nav .entry_btn a {
    background-color: var(--GN);
    color: var(--wt);
    font-size: 1.1rem;
    transition: all .3s;
    display: flex;
    /* justify-content: center; */
    align-items: center;
    gap: 6px;
    width: 201px;
    height: 49px;
    border-radius: 100px;
    border: 1px solid var(--GN);
    padding: 0 10px;
    font-size: 1.2rem;
}
.entry_btn a .icon {
    background-color: #F4F4F3;
    width: 29px;
    height: 29px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100px;
    margin-right: 3px;
    position: relative;
}
.entry_btn a .icon span {
    width: 11px;
    height: 1px;
    background-color: #435A41;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    transition: transform .3s ease, opacity .3s ease;
}
.entry_btn a .icon span:nth-child(1) {
    top: 10px;
}
.entry_btn a .icon span:nth-child(2) {
    top: 14px;
}
.entry_btn a .icon span:nth-child(3) {
    top: 18px;
}
.main_header .top_nav .entry_btn a.active {
    background-color: var(--wt);
    color: var(--GN);
}
.main_header .top_nav .entry_btn a.active .icon span:nth-child(1) {
    transform: translateX(-50%) translateY(4px) rotate(45deg);
}
.main_header .top_nav .entry_btn a.active .icon span:nth-child(2) {
    opacity: 0;
}
.main_header .top_nav .entry_btn a.active .icon span:nth-child(3) {
    transform: translateX(-50%) translateY(-4px) rotate(-45deg);
}

/* ----- large header（採用トップ MV） ----- */
#large_header {
    position: absolute;
    z-index: 10;
    /* background-color: #000; */
    padding: 50px 3.2rem 0 2.4rem;
    width: 100%;
}

#large_header .large_header_inner {
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 2.4rem 3.8rem;
    max-width: 100%;
}

#large_header .large_header_nav {
    display: flex;
    align-items: stretch;
    gap: 3.3rem;
}

#large_header .large_header_col {
    display: flex;
    flex-direction: column;
    gap: 1.3rem;
    margin: 0;
    padding: 0;
}

#large_header .large_header_col a {
    display: flex;
    align-items: baseline;
    flex-wrap: nowrap;
    gap: 1rem 1.2rem;
    color: inherit;
    transition: opacity 0.3s;
    justify-content: space-between;
    gap: 15px;
}

#large_header .large_header_col a:hover {
    opacity: 0.78;
}

#large_header .large_header_en {
    font-size: 1.1rem;
    font-weight: 600;
    color: #fff;
    text-transform: uppercase;
    white-space: nowrap;
}

#large_header .large_header_ja {
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--wt);
    white-space: nowrap;
}
#large_header .large_header_col_1 .large_header_ja {
    width:72px
} 
#large_header .large_header_col_2 .large_header_ja {
    width: 96px;
}
#large_header .large_header_col_3 .large_header_ja {
    width: 84px;
}

#large_header .large_header_sep {
    width: 1px;
    align-self: stretch;
    min-height: 1.6em;
    background-color: #ffffff78;
    flex-shrink: 0;
}

#large_header .large_header_entry_wrap {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

#large_header .large_header_entry_btn {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    background-color: #f4f4f3;
    color: var(--bk);
    font-size: 1.2rem;
    width: auto;
    min-width: 19rem;
    height: 4.9rem;
    padding: 0 1.6rem 0 1rem;
    border-radius: 999px;
    border: 1px solid transparent;
    box-sizing: border-box;
    transition: background-color 0.3s, color 0.3s, border-color 0.3s;
    width: 20rem;
}

#large_header .large_header_entry_icon {
    position: relative;
    width: 2.9rem;
    height: 2.9rem;
    border-radius: 50%;
    background-color: var(--GN);
    flex-shrink: 0;
}

#large_header .large_header_entry_icon span {
    width: 1.1rem;
    height: 1px;
    background-color: #fff;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    transition: transform 0.3s ease, opacity 0.3s ease;
}

#large_header .large_header_entry_icon span:nth-child(1) {
    top: 1rem;
}

#large_header .large_header_entry_icon span:nth-child(2) {
    top: 1.4rem;
}

#large_header .large_header_entry_icon span:nth-child(3) {
    top: 1.8rem;
}

#large_header .large_header_entry_text {
    display: flex;
    align-items: baseline;
    gap: 0.6rem;
}

#large_header .large_header_entry_en {
    font-size: 1.2rem;
    text-transform: uppercase;
    color: var(--GN);
}

#large_header .large_header_entry_ja {
    font-size: 1.2rem;
    color: var(--GN);
}

#large_header .large_header_entry_btn.active {
    background-color: var(--GN);
    color: var(--wt);
}

#large_header .large_header_entry_btn.active .large_header_entry_icon {
    background-color: #f4f4f3;
}

#large_header .large_header_entry_btn.active .large_header_entry_icon span {
    background-color: var(--GN);
}

#large_header .large_header_entry_btn.active .large_header_entry_icon span:nth-child(1) {
    transform: translateX(-50%) translateY(4px) rotate(45deg);
}

#large_header .large_header_entry_btn.active .large_header_entry_icon span:nth-child(2) {
    opacity: 0;
}

#large_header .large_header_entry_btn.active .large_header_entry_icon span:nth-child(3) {
    transform: translateX(-50%) translateY(-4px) rotate(-45deg);
}

@media (max-width: 1100px) {

    #large_header .large_header_inner {
        gap: 1.6rem 2rem;
    }

    #large_header .large_header_nav {
        gap: 1.6rem;
        overflow-x: auto;
        max-width: 100%;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 2px;
    }

    #large_header .large_header_col {
        flex-shrink: 0;
    }
}

@media (max-width: 768px) {
    #large_header .large_header_en {
    font-size: 1rem;
}

    #large_header .large_header_ja {
    font-size: 1rem;
}

    #large_header .large_header_entry_btn {
        min-width: 0;
        height: 4.4rem;
        padding: 0 1.2rem 0 0.8rem;
    }

    #large_header .large_header_entry_en,
    #large_header .large_header_entry_ja {
        font-size: 1.1rem;
    }
}

.mobilenav .wrap h3 .en {
    font-size: 1.8rem;
}

.mobilenav .wrap h3 .ja {
    font-size: 1.3rem;
}

.main_header .triger_wrap {
    display: flex;
    width: 70px;
    height: 70px;
    align-self: stretch;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    cursor: pointer;
    transition: all .3s;
    z-index: 1000;
    background-color: #c9b8a3;
    flex-shrink: 0;
    position: absolute;
    top: 0;
    right: 70px;
}

.main_header .triger_wrap span {
    background-color: #ffffff;
    top: 26px; /* 1本目: (70 - 18) / 2 */
}

.main_header .triger_wrap span:nth-of-type(1) {
    top: 36px; /* 2本目: 26 + 2 + 6 */
}

.main_header .triger_wrap span:nth-of-type(2) {
    top: 42px; /* 3本目: 34 + 2 + 6 */
}

.main_header .triger_wrap.active span:nth-of-type(1) {
    top: 34px;
}

.main_header .triger_wrap.active span:nth-of-type(2) {
    top: 34px;
}

.main_header .triger_wrap.active span:nth-of-type(3) {
    top: 34px;
}

.triger_wrap .menu-trigger {
    transition: all .3s;
    display: block;
    position: relative;
    width: 70px;
    height: 70px;
}

.main_header .top_nav {
    width: auto;
    display: flex;
    flex: 1;
    min-width: 0;
    align-items: center;
    justify-content: center;
}
.main_header .top_nav ul.sitemap_list {
    gap: 0.6rem;
    align-items: center;
}

.main_header.is-transparent {
    background-color: transparent;
    position: absolute;
}

.main_header.is-transparent .top_nav {
    background-color: transparent;
}

.main_header.is-transparent .top_nav ul {
    background-color: transparent;
}
.main_header.is-transparent .logo {
    display: none;
}


.main_header.is-transparent .top_nav ul.sitemap_list {
    background-color: transparent;
}
.main_header.is-transparent .triger_wrap {
    background-color: transparent;
}
.main_header.is-transparent .header_nav_sns a {
    color: #fff;
}




.mobilenav {
    display: none;
    width: 100%;
    overflow: auto;
    padding: 0;
    -webkit-overflow-scrolling: touch;
}

.mobilenav.is-show {
    display: block;
}

.mobilenav .wrap {
    flex-direction: column;
    width: 100%;
    max-width: 100%;
    position: static;
    padding: 95px 0 40px 50px;
    box-sizing: border-box;
}

.mobilenav .wrap ul.sitemap_list {
    width: 100%;
}

.mobilenav .wrap ul li {
    width: 100%;
    height: auto;
    margin-bottom: 0;
    page-break-inside: auto;
    break-inside: auto;
}

.main_header .mobilenav .sitemap_list > li {
    margin-left: 0;
    margin-right: 0;
    border-bottom: 1px solid #CCBCA4;
    margin-bottom: 13px;
}

.main_header .mobilenav .sitemap_list a {
    display: flex;
    align-items: unset;
    gap: 1rem;
    padding: 10px 0 10px;
    /* min-height: 3.25rem; */
    box-sizing: border-box;
    line-height: 1em;
}
 .mobilenav .header_nav_sns {
    position: absolute;
    right: 165px;
    top: 8px;
    border: none!important;
}

.mobilenav .sitemap_list > li:not(.mobilenav_instagram) > a::before {
    display: none !important;
    content: none !important;
}

.mobilenav .sitemap_list > li:not(.mobilenav_instagram) > a .ja {
    color: #42543f;
}

.mobilenav .sitemap_list > li:not(.mobilenav_instagram) > a::after {
    content: '';
    width: 18px;
    height: 18px;
    background-image: url(../../common/img/arrow-r.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    position: absolute;
    /* right: auto !important; */
    right: 50px;
    top: 0;
    bottom: 0;
    margin: auto;
}

.mobilenav .mobilenav_instagram {
    margin: 1.75rem 5% 0;
    padding-top: 0.5rem;
    border-bottom: none;
}

.mobilenav .mobilenav_instagram > a {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.75rem 0;
    color: #42543f;
}

.mobilenav .mobilenav_instagram > a::before,
.mobilenav .mobilenav_instagram > a::after {
    display: none !important;
    content: none !important;
}

.mobilenav .mobilenav_instagram i {
    font-size: 1.45rem;
    color: #42543f;
}

.main_header .sitemap_list > li.mobilenav_instagram {
    border-bottom: none;
}
.mobilenav .mobilenav_instagram_label {
    font-size: 1.1rem;
/**/
/* font-weight: 500; */;
}

.main_header:has(.mobilenav.is-show) .triger_wrap {
    background-color: #c9b8a3;
}

.main_header:has(.mobilenav.is-show) .triger_wrap.active span {
    /* background-color: #484848; */
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a {
    background-color: #42543f;
    border-color: #42543f;
    border-radius: 0;
    width: auto;
    min-width: 5.5rem;
    height: 2.75rem;
    padding: 0 0.85rem;
    gap: 0;
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a .icon {
    display: none;
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a .ja {
    display: none;
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a .en {
    position: relative;
    padding-bottom: 2px;
    border-bottom: 1px solid #ffffff;
    font-size: 0.85rem;
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a.active {
    background-color: #ffffff;
    color: #42543f;
    border-color: #42543f;
}

.main_header:has(.mobilenav.is-show) .top_nav .entry_btn a.active .en {
    border-bottom-color: #42543f;
}

.g_page_list {
    columns: unset;
    width: 100%;
}

.mobilenav .wrap .g_collection_box {
    width: 100%;
    margin-top: 0;
    margin-right: 0;
}

.mobilenav .wrap h3 {
    margin-bottom: 13px;
    color: #555555;
}

.mobilenav .wrap h3 span {
    color: #555555;
}

.mobilenav .wrap h3:before,
.mobilenav .wrap h3:after {
    background-color: #AFAEAE;
}

.g_collection_list {
    padding-left: 25px;
}

.main_header .triger_wrap span {
    background-color: #fff;
    height: 1px;
    width: 30px;
    position: absolute;
    top: 16px;
    left: 0;
    right: 0;
    margin: auto;
    transition: all .4s;
}

.main_header .triger_wrap span:nth-of-type(1) {
}

.main_header .triger_wrap span:nth-of-type(2) {
    top: 45px;
}

.main_header .triger_wrap.active span:nth-of-type(1),
.main_header .triger_wrap.active span:nth-of-type(2) {
    width: 21px;
}

.main_header .triger_wrap.active span:nth-of-type(1) {
    transform: rotate(-45deg);
    right: 0px;
    top: 34px;
}

.main_header .triger_wrap.active span:nth-of-type(2) {
    transform: rotate(45deg);
    right: 0px;
    top: 34px;
    /* width: 21px; */
}

.main_header .triger_wrap span:nth-of-type(3) {
    /* display: none; */
    top: 27px;
}

.main_header .triger_wrap.active span:nth-of-type(3) {
    opacity: 0;
    top: 34px;
    width: 0;
    /* display: none; */
}

.header_reservation_btn {
    position: fixed;
    z-index: 101;
    top: 75px;
    right: 25px;
}

.header_reservation_btn button {
    border: none;
    background-color: transparent;
    font-size: 12px;
    color: #fff;
    transition: all .3s;
    display: block;
}

.header_reservation_btn button.color {
    color: #000;
}

.main_header .top_nav {
    top: 0;
    padding: 0 0px;
    height: 100%;
    z-index: 12;
    position: relative;
}

.main_header .top_nav .logo {
    top: 20px;
    left: 20px;
    width: 128px;
    position: static;
    margin-top: 0;
    min-width: 128px;
}

.main_header .top_nav .logo svg path {
    transition: all .3s;
}

.header_sns {
    right: 23px;
    top: 130px;
    text-align: right;
    z-index: 999;
}

.entry_area {
    background-color: var(--GN);
    padding-bottom: 115px;
    position: relative;
    z-index: 1;
}

.entry_area .entry_title {
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.entry_area .entry_title h2 {
    text-align: center;
    font-size: 1.4rem;
    color: var(--wt);
    margin-top: 60px;
}
.entry_area .entry_title picture {
    display: block;
    text-align: center;
    position: relative;
    margin-top: -1px;
}
.entry_area .entry_title picture:before {
    content: '';
    width: 100%;
    height: 1px;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #ECE1CE;
    z-index: 1;
    position: absolute;
    top: 54.5px;
    left: 0;
}

.entry_area h3 {
    font-size: 1.4rem;
    margin-bottom: 20px;
}

.entry_area .entry_btns {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-top: 60px;
    flex-wrap: wrap;
}
.entry_area .entry_btns .btn a {
    height: 6.4rem;
    width: 30.5rem;
    padding-left: 40px;
}
.entry_area .entry_btns .btn a:before {
    width: 2.5rem;
    height: 2.5rem;
}

.entry_modal {
    position: fixed;
    top: 0;
    right: 0;
    width: 423px;
    background-color: var(--GN);
    padding: 150px 50px 0 60px;
    color: var(--wt);
    height: 100%;
    z-index: 100;
    transform: translateX(100%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: transform .35s cubic-bezier(0.22, 1, 0.36, 1), opacity .2s ease, visibility .2s ease;
}
.entry_modal.is-show {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    padding-bottom: 40px;
    overflow: auto;
}
.entry_modal .en {
    text-align: right;
}
.entry_modal h3 {
    color: var(--wt);
    font-size: 1.4rem;
    margin-bottom: 50px;
    text-align: center;
    font-weight: 400;
    margin-top: 20px;
    text-align: right;
}
.entry_modal .btns {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.entry_modal .btns a {
    height: 6.4rem;
    width: 100%;
    padding-left: 40px;
}
.entry_modal .btns a:before {
    width: 2.5rem;
    height: 2.5rem;
}
.close-modal-btn {
    border: none;
    color: var(--wt);
    background: none;
    font-size: 1.3rem;
    font-weight: 400;
    text-align: right;
    cursor: pointer;
    transition: all .3s;
    position: absolute;
    right: 15px;
    top: 15px;
}
.close-modal-btn i {
    /* margin-right: 5px; */
    font-size: 2.3rem;
}

.breadcrunp {
    background: #F4F4F3;
    position: relative;
    z-index: 1;
}
.breadcrunp .breadcrumb__list {
    max-width: 1200px;
    margin: 0 auto;
    padding: 15px 30px;
    display: flex;
    align-items: center;
    color: #958663;
}

.breadcrunp .breadcrumb__list li {
    font-size: 12px;
    padding-right: 10px;
    line-height: 1em;
}

.breadcrunp .breadcrumb__list li:after {
    content: '>';
    color: #A39175;
    font-size: 12px;
    margin-left: 4px;
}

.breadcrunp .breadcrumb__list li:last-child:after {
    content: none;
}

.breadcrunp .breadcrumb__list span {
    color: #958663;
    font-size: 12px;
}

.btn a,
.btn button {
    color: var(--GN, #435A41);
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 400;
    border-radius: 10rem;
    background: #F4F4F3;
    width: 27.2rem;
    height: 5.7rem;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-left: 30px;
    position: relative;
    transition: all 0.3s;
    border: 1px solid;
}

.btn a::before {
    content: '';
    width: 1.8rem;
    height: 1.8rem;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 20px;
    background-image: url(../../common/img/arrow-r.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transition: all 0.3s;
}
.btn a:hover {
    opacity: 0.8;
}
.btn a:hover::before {
    transform: translateX(5px);
}


.btn.green a {
    background-color: var(--GN);
    color: var(--wt);
    border-color: var(--GN);
}
.btn.green a::before {
    background-image: url(../../common/img/arrow-r-w.svg);
}

.btn.brown a {
    color: var(--br);
    border-color: var(--br);
}
.btn.brown a::before {
    background-image: url(../../common/img/arrow-r-br.svg);
}
.btn.none_border a {
    border: none;
}

.btn.bg_brown a {
    background-color: var(--br);
    border-color: var(--br);
    color: var(--wt);
}
.btn.bg_brown a::before {
    background-image: url(../img/arrow-r-br-w.svg);
}



@keyframes btn-anim-line {
    0% {
        width: 0;
    }

    100% {
        width: 27px;
    }
}

@-webkit-keyframes btn-anim-line {
    0% {
        width: 0;
    }

    100% {
        width: 27px;
    }
}

@keyframes btn-anim-circle {
    0% {
        transform: scale(1.5);
    }

    100% {
        transform: scale(1);
    }
}

@-webkit-keyframes btn-anim-circle {
    0% {
        transform: scale(1.5);
    }

    100% {
        transform: scale(1);
    }
}

main .text {
    font-size: 1.3rem;
    margin-bottom: 20px;
    text-align: left;
}

.page_header {
    margin-top: 180px;
    margin-bottom: 80px;
    max-width: 1160px;
    margin: 0 auto;
    padding: 225px 30px 80px;
}
.page_header .en {
    position: relative;
    font-size: 9.5rem;
    color: var(--br);
}
.page_header .en:before {
    content: '';
    width: 200vw;
    position: absolute;
    left: 0;
    top: 0;
    background-color: #CCBCA4;
    height: 1px;
    left: -50vw;
}

.page_header h1 {
    color: var(--br);
    font-size: 1.6rem;
    margin-top: 30px;
}

main .page_cover img {
    width: 100%;
}

.wp-pagenavi {
    text-align: center;
    margin-bottom: 100px;
    margin-top: 50px;
}

.wp-pagenavi * {
    font-size: 13px;
}

.wp-pagenavi>* {
    margin: 0 6px;
    padding: 0 3px 3px;
}

.wp-pagenavi .current {
    position: relative;
}

.wp-pagenavi .current::after {
    content: '';
    width: 100%;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-color: #000000;
}

.previouspostslink,
.nextpostslink {
    font-size: 0;
    width: 13px;
    height: 13px;
    display: inline-block;
}

.previouspostslink:before,
.nextpostslink:before {
    content: '';
    width: 6px;
    height: 6px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    display: block;
}

.previouspostslink:before {
    transform: rotate(-135deg);
}

.nextpostslink:before {
    transform: rotate(45deg);
    margin-bottom: 2px;
}

#nav_overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 7;
    background-color: #000;
    opacity: .6;
}

.faq_list li {
    margin-bottom: 30px;
}

.faq_list li .q {
    position: relative;
    /* cursor: pointer; */
    transition: all .3s;
}



.faq_list li .q.is-open:after {
    opacity: 0;
}

.faq_list li .q h3 {
    font-size: 1.5rem;
    color: var(--br);
    padding-left: 45px;
    position: relative;
    border-bottom: 1px solid #CCBCA4;
    padding-bottom: 20px;
    padding-right: 40px;
    padding-top: 17px;
}

.faq_list li .q h3:before {
    content: '';
    font-size: 3rem;
    color: var(--br);
    position: absolute;
    left: 7px;
    top: 19px;
    margin: auto;
    height: 37px;
    font-family: "Baskervville", serif;
    background-image: url(../img/Q.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 19px;
    height: 22px;
    line-height: 1em;
}

.faq_list li .answer {
    position: relative;
    padding-left: 45px;
    padding-top: 25px;
    max-width: 640px;
}

.faq_list li .answer:before {
    content: '';
    font-size: 3rem;
    color: #CCBCA4;
    position: absolute;
    left: 9px;
    top: 31px;
    font-family: "Baskervville", serif;
    background-image: url(../img/A.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 16px;
    height: 17px;
    line-height: 1em;
}

.faq_list li .answer p {
    font-size: 1.3rem;
    font-weight: 400;
}

.faq_list li .answer p a {
    text-decoration: underline;
    font-size: inherit;
    color: inherit;
}


#footer {
    background-color: #F4F4F3;
    padding-top: 100px;
    position: relative;
    z-index: 1;
}

#footer small {
    text-align: center;
    display: block;
    background-color: var(--GN);
    color: var(--wt);
    font-size: 1.1rem;
    font-weight: 700;
    padding: 20px;
}
#footer .logo {
    text-align: center;
}
#footer .sitemap {
    margin-top: 60px;
    padding-bottom: 70px;
    border-bottom: 1px solid #DCDCDC;
    margin-bottom: 60px;
}

#footer .sitemap_list {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}
#footer .sitemap_list a {
    display: flex;
    align-self: center;
    justify-content: center;
    flex-direction: column;
    gap: 0;
    text-align: center;
    font-size: 1.1rem;
    text-transform: uppercase;
}
#footer .sitemap .sns {
    text-align: center;
    color: var(--GN);
}
#footer .sitemap .sns a {
    font-size: 1.1rem;
    display: inline-block;
}
#footer .sitemap .sns a i {
    margin-right: 5px;
    font-size: 1.5rem;
    vertical-align: text-bottom;
}

#footer .company_info {
    margin-top: 60px;
    padding-bottom: 60px;
}
#footer .company_info h3 {
    text-align: center;
    font-size: 1.3rem;
    margin-bottom: 20px;
}
#footer .company_info p.address {
    text-align: center;
    font-size: 1.3rem;
    margin-bottom: 20px;
}
#footer .company_info .btns {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-top: 30px;
    flex-wrap: wrap;
}

#footer .company_info .links {
    text-align: center;
    font-size: 1.3rem;
    margin-top: 50px;
}
#footer .company_info .links a {
    padding: 0 14px;
    border-right: 1px solid;
    display: inline-block;
    line-height: 1em;
}
#footer .company_info .links a:last-of-type {
    border: none;
}

.swiper-pagination {
    text-align: left;
}
.swiper-pagination-bullet {
    background-color: #CCBCA4;
    opacity: 1;
}
.swiper-pagination-bullet-active {
    background-color: #958663;
}
.swiper-button-next, .swiper-button-prev {
    width: 33px;
    height: 33px;
    background-color: var(--wt);
    border-radius: 100px;
}
.swiper-button-next svg,
.swiper-button-prev svg
 {
    width: 6px;
}
.swiper-button-next svg path,
.swiper-button-prev svg path {
    fill : #958663;
}
.sp_entry_btn {
    position: absolute;
    right: 0;
    top: 0;
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: var(--GN);
    color: #ffffff;
    padding: 0 1.2rem;
    font-size: 0.9rem;
    white-space: nowrap;
    flex-shrink: 0;
    font-weight: 700;
    cursor: pointer;
    justify-content: center;
    padding-bottom: 6px;
    z-index: 999;
    display: none;
}
.sp_entry_btn span {
    border-bottom: 1px solid;
}
.sp_entry_btn:hover {
    opacity: 1;
}
.sp_instagram_btn {
    position: absolute;
    right: 159px;
    font-size: 1.6rem;
    color: var(--GN);
    z-index: 999;
    top: 22px;
    /* bottom: 0; */
    /* margin: auto; */
}


.other_page_links {
    margin-bottom: 140px;
}
.other_page_links_inner {
    display: flex;
}
.other_page_links_inner > div {
    width: 50%;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    padding: 5% 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    aspect-ratio: 68 / 48;
}
.other_page_links_inner > div h2 {
    color: var(--wt);
    text-align: center;
    font-size: 1.4rem;
    margin-bottom: 30px;
    margin-top: 15px;
}
.other_page_links .people_link {
    background-image: url(../img/bg_people.jpg);
}
.other_page_links .special_link {
    background-image: url(../img/bg_special.jpg);
}
.other_page_links .works_link {
    background-image: url(../img/bg_works.jpg);
}
.other_page_links > .btn {
    display: flex;
    justify-content: center;
    margin-top: 60px;
}


.contents_detail p {
    font-size: 1.3rem;
    margin-bottom: 40px;
    margin-top: 20px;
}
  .contents_detail h2 {
    color: var(--br);
    font-size: 1.8rem;
    margin-bottom: 20px;
    margin-top: 40px;
    position: relative;
    padding-bottom: 5px;
}
  .contents_detail h2:before {
    content: '';
    width: 100vw;
    height: 1px;
    background-color: #CCBCA4;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .contents_detail .img_box {
    margin-bottom: 40px;
  }
  .contents_detail .imgs {
    display: flex;
    gap: 10px;
    /* flex-wrap: wrap; */
  }
  .contents_detail .imgs picture {
    width: 100%;
  }
  .contents_detail .imgs picture img {
    width: 100%;
    object-fit: cover;
    border-radius: 10px;
  }
  .contents_detail .img_box .caption {
    margin-top: 10px;
  }
  .contents_detail .video_btn a {
    width: 100%;
    height: 100%;
    color: var(--br);
    font-size: 1.4rem;
    border-bottom: 1px solid;
    display: flex;
    align-items: center;
    position: relative;
    padding: 5px 0;
    width: 152px;
}
  .contents_detail .video_btn a i {
    margin-left: auto;
    font-size: 2.5rem;
}
.common_form {
    padding: 0px 0 120px;
    /* border-top: 1px solid #CCBCA4; */
}
.common_form .memo {
    font-size: 1.4rem;
    font-weight: 400;
    margin-bottom: 60px;
}
.wpcf7-not-valid-tip {
    font-weight: 700!important;
    display: block!important;
    width: 100%;
    font-size: 1.2rem!important;
}
.common_form .birth_day .wpcf7-not-valid-tip {
    position: absolute;
    bottom: -20px;
    white-space: nowrap;
}
.common_form .inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 60px;
}

.common_form .heading {
    margin-bottom: 50px;
}

.common_form .heading h2 {
    color: var(--br);
    font-size: 1.4rem;
    font-weight: 400;
    margin-top: 20px;
}

.common_form .form_wrap > p {
    font-size: 1.4rem;
    margin-bottom: 50px;
    color: var(--bk);
}

/* ---- Table layout ---- */
.form_table {
    width: 100%;
}

.form_row {
    display: flex;
    align-items: stretch;
    margin-bottom: 1em;
}

.form_th {
    width: 200px;
    min-width: 200px;
    padding: 10px 20px 0 0;
    display: flex;
    align-items: flex-start;
    gap: 6px;
    color: #958663;
    font-size: 1.4rem;
    font-weight: 600;
    position: relative;
    /* padding-left: 22px; */
}

.form_th .req {
    color: var(--br);
    font-size: 1.3rem;
    flex-shrink: 0;
    font-family: "Noto Serif JP", serif;
    margin-right: 5px;
    line-height: 1em;
    margin-top: 8px;
}

.form_td {
    flex: 1;
    padding: 0 0 0 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
}

/* ---- Inputs ---- */
.form_td input[type="text"],
.form_td input[type="email"],
.form_td input[type="tel"] {
    width: 100%;
    height: 50px;
    padding: 0 14px;
    border: none;
    background: #F7F5F1;
    font-size: 1.4rem;
    border-radius: 5px;
    box-sizing: border-box;
    background-color: #fff;
}


.form_td select {
    height: 50px;
    padding: 0 35px 0 14px;
    border: none;
    background-color: #F7F5F1;
    background-image: url(../img/arrow-down.svg);
    background-size: 12px;
    background-position: right 14px center;
    background-repeat: no-repeat;
    font-size: 1.4rem;
    border-radius: 3px;
    cursor: pointer;
    background-color: #fff;
    min-width: 178px;
}

.form_td select[name="education"] {
    max-width: 320px;
    width: 100%;
}

.form_td textarea {
    width: 100%;
    height: 220px;
    padding: 14px;
    border: none;
    background: #fff;
    font-size: 1.4rem;
    border-radius: 3px;
    resize: vertical;
    box-sizing: border-box;
}



/* ---- Radio ---- */
.form_td .wpcf7-radio {
    display: flex;
    gap: 30px;
    align-items: center;
}

.form_td .wpcf7-radio .wpcf7-list-item {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1.4rem;
    cursor: pointer;
}

.form_td .wpcf7-radio .wpcf7-list-item-label {
    cursor: pointer;
}

.form_td .wpcf7-radio input[type="radio"] {
    width: 18px;
    height: 18px;
    min-width: 18px;
    border: 1px solid #958663;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    appearance: auto;
    -webkit-appearance: auto;
    display: inline-block;
    vertical-align: sub;
    margin-right: 6px;
}

/* ---- Inline row (birth date / tel) ---- */
.inline_row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    width: 100%;
}

.inline_row .wpcf7-form-control-wrap {
    display: flex;
    flex-wrap: wrap;
}

.inline_row select {
    width: auto;
    height: 50px;
}

.inline_row input[type="text"] {
    width: 90px;
    height: 46px;
}

.inline_row .unit {
    font-size: 1.4rem;
    color: var(--bk);
}

.inline_row .hyphen {
    font-size: 1.4rem;
    color: var(--bk);
}

/* birth year wider */
[data-name="birth_year"] select {width: 110px;display: inline-block;}
[data-name="birth_month"] select,
[data-name="birth_day"] select { width: 80px; }

/* ---- Address ---- */
.form_address_row {
    display: flex;
    align-items: center;
    gap: 16px;
}
.form_address_row .wpcf7-form-control-wrap {
    width: 100%;
}
.form_address_row select {
    width: 270px;
}

.form_address_row .address_label {
    min-width: 120px;
    font-size: 1.3rem;
    color: #958663;
    flex-shrink: 0;
}

.form_address_row input[type="text"] {
    flex: 1;
    /* height: 46px; */
    padding: 0 14px;
    border: none;
    background: #F7F5F1;
    font-size: 1.4rem;
    border-radius: 5px;
    box-sizing: border-box;
    width: auto;
    background-color: #fff;
    width: 100%;
    display: inline-block;
}

.form_address_row select {
    flex: 1;
}

.form_address_row .inline_row {
    flex: 1;
}

.form_address_row .inline_row input[type="text"] {
    flex: unset;
    width: 270px;
}

.privacy_section {
    /* margin-top: 50px; */
    padding: 0px 40px 20px;
    background: #F4F4F3;
    font-size: 1.4rem;
    color: var(--bk);
    margin-left: 200px;
    margin-top: 30px;
}

.privacy_section .privacy_title {
    font-size: 1.4rem;
    margin-bottom: 10px;
}

.privacy_section .privacy_check {
    margin-top: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
}
.privacy_section .privacy_check .wpcf7-list-item {
    margin-left: 0;
}
.privacy_section .privacy_check .wpcf7-not-valid-tip {
    position: absolute;
    white-space: nowrap;
}

.privacy_section .wpcf7-acceptance input[type="checkbox"] {
    width: 18px;
    height: 18px;
    min-width: 18px;
    border: 1px solid #958663;
    background: #fff;
    cursor: pointer;
    appearance: auto;
    -webkit-appearance: auto;
    display: inline-block;
}

.privacy_section .privacy_check a {
    /* color: var(--br); */
    text-decoration: underline;
}

/* ---- Submit ---- */
.common_form .wpcf7-submit {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-left: 30px;
    margin-top: 30px;
    background-color: var(--GN);
    color: var(--wt);
    border-radius: 10rem;
    width: 30.5rem;
    height: 5.7rem;
    font-size: 1.4rem;
    cursor: pointer;
    transition: opacity 0.3s;
    position: relative;
    margin-left: 230px;
    background-image: url(../../common/img/arrow-r-w.svg);
    background-size: 1.8rem;
    background-position: right 30px center;
    background-repeat: no-repeat;
}

.common_form .wpcf7-submit::after {
    content: '';
    width: 2.5rem;
    height: 2.5rem;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 30px;
    background-image: url(../../common/img/arrow-r-br-w.svg);
    background-size: contain;
    background-position: right center;
    background-repeat: no-repeat;
}

.common_form .wpcf7-submit:hover {
    opacity: 0.8;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
    background-color: #fff;
    padding: 10px 15px;
    font-size: 1.4rem;
    font-weight: 700;
    color: red;
    border: 2px solid red!important;
    border-radius: 5px;
    text-align: center;
}
.wpcf7 form.sent .wpcf7-response-output {
    background-color: #fff;
    padding: 30px 20px;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--GN);
    border: 3px solid var(--GN)!important;
    border-radius: 5px;
    text-align: center;
}
/*---------------------------------------------------------------*\
	$1130px
\*---------------------------------------------------------------*/
@media screen and (max-width: 1130px) {
    .main_header .sitemap_list a {
        font-size: 1.2rem
    }
    .main_header .sitemap_list > li {
        margin: 0 .5vw;
    }
}

/*---------------------------------------------------------------*\
	$736px
\*---------------------------------------------------------------*/

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

    .main_header {
        padding: 0px 0 0px 20px;
        min-width: unset;
        height: 70px;
        align-items: stretch;
    }

    body {
        min-width: unset;
    }

    #wrapper {
        min-width: unset;
    }

    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    a,
    button {
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        cursor: pointer;
    }

    p,li {
        line-height: 2;
    }

    .main_header .top_nav .sitemap_list > li.entry_btn {
    display: none !important;
    }
    .main_header .top_nav .sitemap_list > li:not(.entry_btn):not(.header_nav_sns) {
        display: none;
    }
    .sp_entry_btn {
        display: flex;
    }
    .main_header .header_nav_sns {
        position: absolute;
        right: 160px;
        /* transition: all .1s; */
    }
    .main_header.is-transparent .header_nav_sns {
        right: 140px;
    }
    .main_header .header_nav_sns a {
        color: #42543f;
        font-size: 1.5rem;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .menu_overlay {
        opacity: .44;
        background: #000;
    }


    .breadcrunp {
        width: 100%;
        overflow: auto;
        padding: 5px 0;
    }

    .breadcrunp .breadcrumb__list {
        margin: 0 auto;
        padding: 12px 30px;
        display: flex;
        align-items: center;
        width: auto;
    }

    .breadcrunp .breadcrumb__list li {
    font-size: 12px;
    padding-right: 10px;
    white-space: nowrap;
    line-height: 1em;
}

    .breadcrunp .breadcrumb__list li:after {
        content: '>';
        color: #A39175;
        font-size: 12px;
        margin-left: 4px;
    }

    .breadcrunp .breadcrumb__list li:last-child:after {
        content: none;
    }

    .breadcrunp .breadcrumb__list a {
        display: inline-block;
    }

    .breadcrunp .breadcrumb__list span {
        color: #A39175;
        font-size: 12px;
        display: inline-block;
    }

    @keyframes line-anim {
        0% {
            width: 0%;
        }

        60% {
            width: 100%;
        }

        100% {
            width: 100%;
        }
    }

    @-webkit-keyframes line-anim {
        0% {
            width: 0%;
        }

        60% {
            width: 100%;
        }

        100% {
            width: 100%;
        }
    }

    main .page_header {
        padding-bottom: 30px;
        padding-top: 130px;
    }

    main .page_header * {
        height: auto;
    }

    .page_header .en {
    font-size: 6rem;
}

    main .page_header h1 {
        margin-top: 13px;
        font-size: 1.4rem;
    }

    main .page_cover img {
        width: 100%;
    }

    .wp-pagenavi {
        text-align: center;
        margin-bottom: 100px;
        margin-top: 50px;
    }

    .wp-pagenavi * {
        font-size: 13px;
    }

    .wp-pagenavi>* {
        margin: 0 6px;
        padding: 0 3px 3px;
    }

    .wp-pagenavi .current {
        position: relative;
    }

    .wp-pagenavi .current::after {
        content: '';
        width: 100%;
        height: 1px;
        position: absolute;
        bottom: 0;
        left: 0;
        background-color: #000000;
    }

    .previouspostslink,
    .nextpostslink {
        font-size: 0;
        width: 13px;
        height: 13px;
        display: inline-block;
    }

    .previouspostslink:before,
    .nextpostslink:before {
        content: '';
        width: 6px;
        height: 6px;
        border-top: 1px solid #000;
        border-right: 1px solid #000;
        display: block;
    }

    .previouspostslink:before {
        transform: rotate(-135deg);
    }

    .nextpostslink:before {
        transform: rotate(45deg);
        margin-bottom: 2px;
    }


    .entry_area h3 {
        border-bottom: 1px solid #CEBFAE;
        padding-bottom: 10px;
        font-size: 1.4rem;
    }

    .entry_area .box_wrap {
        columns: unset;
    }

    .entry_area .box_wrap .box {
        margin-bottom: 30px;
    }

    .entry_area .box h4 {
        font-size: 1.3rem;
        margin-bottom: 5px;
    }


    .faq_list li {
        margin-bottom: 15px;
    }

    .faq_list li .q h3 {
    padding-left: 35px;
    font-size: 1.4rem;
    padding-right: 0;
    padding-bottom: 10px;
    padding-right: 30px;
}

    .faq_list li .q h3:before {
    left: 0;
    font-size: 2.4rem;
    top: 24px;
    line-height: 1em;
}

    .faq_list li .answer {
        padding-left: 35px;
        font-size: 1.3rem;
        padding-top: 15px;
        padding-right: 30px;
    }

    .faq_list li .answer:before {
    left: 0px;
    font-size: 2.4rem;
    top: 22px;
    line-height: 1em;
}

    .faq_list li .q:before {
        right: 20px;
    }

    .faq_list li .q:after {
        right: 27px;
    }

    .btn a, .btn button {
        width: 100%;
        height: 60px;
    }
    .btn a::before {
        right: 22px;
    }


    .entry_area {
        padding-top: 85px;
        padding-bottom: 70px;
    }
    .entry_area .entry_title picture:before {
        top: 20%;
    }
    .entry_area .entry_title h2 {
        margin-top: 20px;
    }
    .entry_area .entry_btns {
        padding: 0 30px;
        margin-top: 30px;
        gap: 10px;
    }
    .entry_area .entry_btns .btn {
        width: 100%;
    }
    .entry_area .entry_btns .btn a {
        width: 100%;
        padding-left: 30px;
    }
    .entry_area .entry_btns .btn a:before {
        right: 20px;
    }
    #footer {
        padding-top: 50px;
    }
    #footer .logo {
        width: 280px;
        margin: 0 auto;
    }
    #footer .sitemap {
        /* padding-top: 60px; */
        padding-bottom: 40px;
        margin-bottom: 40px;
    }
    #footer .sitemap_list {
        gap: 20px 5px;
        padding: 0 30px;
        justify-content: flex-start;
    }
    #footer .sitemap_list > li {
        width: calc(50% - 2.5px);
        border-bottom: 1px solid #dcdcdc;
        padding-bottom: 10px;
    }
    #footer .company_info {
        margin-top: 40px;
    }
    #footer .company_info .btns {
        flex-direction: column;
    }
    #footer .company_info .btns {
        padding: 0 30px;
        gap: 10px;
    }
    #footer .company_info .btns .btn {
        width: 100%;
    }
    .entry_modal {
        width: 100%;
        padding: 150px 50px 50px;
        z-index: 15;
    }
    .entry_modal .en {
        text-align: center;
    }
    .entry_modal .en img {
        width: 272px;
    }
    .entry_modal h3 {
    text-align: center;
    margin-top: 30px;
    margin-bottom: 60px;
}
    .entry_modal .btns {
        gap: 15px;
    }
    .entry_modal .btns a {
        padding-left: 30px;
    }
    .entry_modal .btns a:before {
        right: 17px;
    }
    .common_form {
        padding-bottom: 70px;
    }
    .common_form .inner {
        padding: 0 30px;
    }
    .form_row {
        flex-direction: column;
        margin-bottom: 10px;
    }
    .form_td {
        padding-left: 0;
        margin-top: 10px;
    }
    .privacy_section {
        padding: 0;
        margin: 0 auto;
    }
    .common_form .wpcf7-submit {
        margin: 30px auto 0;
        width: 290px;
        padding-left: 30px;
        height: 5.7rem;
        background-position: right 20px center;
    }
    .birth_day select {
        min-width: unset;
        width: auto;
        padding-right: 40px;
    }
    .job_type select {
        width: 100%;
        text-overflow: ellipsis;
    }
    .form_address_row {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    .form_address_row .wpcf7-form-control-wrap {
        width: 100%;
    }
    .common_form .tel .inline_row .wpcf7-form-control-wrap {
        width: 100%;
    }
    .common_form .subject select {
        width: 100%;
    }
    .common_form .memo {
        margin-bottom: 20px;
    }

    .other_page_links {
        margin-bottom: 100px;
    }
    .other_page_links_inner {
        flex-direction: column;
    }
    .other_page_links_inner > div {
        width: 100%;
        aspect-ratio: 390 / 300;
    }
    .other_page_links_inner > div h2 {
        margin-bottom: 20px;
    }
    .other_page_links_inner > div .btn {
        width: 100%;
        padding: 0 60px;
        margin-top: 0px;
    }
    .other_page_links_inner > div .btn a {
        height: 5.7rem;
    }
    .other_page_links > .btn {
        margin-top: 60px;
        padding: 0 30px;
    }
    .swiper-pagination-bullet {
        width: 6px;
        height: 6px;
    }

    .contents_detail h2 {
        font-size: 1.6rem;
    }

}
