/*common
------------------------------------------------------*/
body {
    position: relative;
}
.btn {
    font-family: 'Shippori Mincho B1', serif;
    color: #fff;
    font-size: 24px;
    background: linear-gradient(to right,  #ccc47a -1%,#ccc47a 0%,#a39838 100%,#a39838 100%);
    padding: 7px 28px;
    display: block;
    border-radius: 3px;
    box-shadow: 4px 4px 10px -7px #000;
    text-align: center;
}
.btn:hover {
    opacity: 0.5;
    transition: opacity 0.3s;
}

a[href^="tel:"] {
    pointer-events: none;
}

.each__title {
    font-family: 'Habibi', serif;
    color: #A39838;
    font-size: 42px;
    font-weight: 400;
    line-height: 50.4px;
    text-align: center;
    letter-spacing: 5px;
    margin-bottom: 36px;
}
.each__txt {
    text-align: center;
    font-size: 20px;
    line-height: 30px;
}

p {
    font-family: 'Noto Serif JP', serif;
    color: #4D2A0A;
    text-align: center;
}

/*header
------------------------------------------------------*/
header {
    height: 100px;
    background-color: #FFFFFB;
    display: flex;
    justify-content: center;
    align-items: center;
}
.header__btn .btn {
    max-width: 152px;
}
.header__flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0px 30px 10px 0;
}


/*visual
------------------------------------------------------*/
.visual {
    position: relative;
    background: url(../img/img16.jpg) no-repeat center;
    height: 760px;
    background-size: cover;
    display: flex;
    align-items: center;
    justify-content: center;
}
.visual-2 {
    background: url(../img/img02.jpg) no-repeat center;
    background-color: #000;
    background-size: 100%;
}
.visual__title {
    position: relative;
    top: -10px;
    font-family: 'Shippori Mincho B1', serif;
    color: #fff;
    font-size: 44px;
    line-height: 63.71px;
    text-align: center;
    letter-spacing: 13px;
    background-color: rgb(20, 20, 20, .6);
    padding: 10px 0;
}
.visual__title-2 {
    background-color: rgb(20, 20, 20, .4);
    padding: 10px 0;
}
.visual__title p {
    color: #fff;
}

.visual__title_logo img {
    position: absolute;
    top: 25%;
    left: 50%;
    transform: translateX(-50%);
    width: 500px;
}
@media screen and (max-width:768px) {
    .visual__title_logo img {
        width: 80%;
    }
}

/*about
------------------------------------------------------*/
.about {
    background-color: #F3F2EA;
    padding: 96px 0 120px;
}
.about .each__title {
    margin-bottom: 32px;
}


/*access
------------------------------------------------------*/
.access {
    background-color: #F3F2EA;
    padding: 96px 0 0 0;
}
.access__telwrap {
    margin-bottom: 8px;
}
.access__telTxt {
    position: relative;
    z-index: 5;
    font-size: 20px;
    line-height: 30px;
}
.access__telTxt::before {
    position: absolute;
    z-index: 5;
    content: "";
    background: url(../img/img07.png) no-repeat;
    width: 21px;
    height: 22px;
    left: -33.5px;
    bottom: 4px;
}
.access__address {
    font-size: 20px;
    line-height: 24px;
    margin-bottom: 36px;
}
.access__address span {
    position: relative;
    z-index: 5;
}
.access__address span::before {
    position: absolute;
    z-index: 5;
    content: "";
    background: url(../img/img08.png) no-repeat;
    width: 45px;
    height: 45px;
    left: -45px;
    bottom: -9px;
}
.access__map {
    text-align: center;
}

@media screen and (max-width:1130px) {
    .access__map iframe {
        width: 100%;
    }
}



/*recruit
------------------------------------------------------*/
.recruit {
    background-color: #F3F2EA;
    padding: 96px 0 0 0;
}
.recruit .each__txt {
    margin-bottom: 56px;
}
.recruit__btn {
    width: 248px;
    margin: 0 auto 8px auto;
}

/*picBox
------------------------------------------------------*/
.picBox {
    background-color: #F3F2EA;
    padding: 96px 0;
}
.picBox__wrap {
    display: flex;
    justify-content: center;
}
.picBox__item {
    width: 22.569%;
    max-width: 325px;
    height: auto;
    margin: 0 20px;
}
.picBox__item img {
    width: 325px;
    height: 325px;
    object-fit: cover;
}

/*contact
------------------------------------------------------*/
.contact {
    background-color: #F3F2EA;
    padding: 96px 0 96px 0;
}
.contact .each__title {
    margin-bottom: 64px;
}
.contact__tel {
    border: 1px solid #A39838;
    padding: 32px 0 32px 0;
    width: 465px;
    margin: 0 auto 64px auto;
    text-align: center;
}
.contact__telTxt {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 4px;
}
.contact__telNumTxt {
    position: relative;
    z-index: 5;
    font-size: 20px;
    line-height: 30px;
}
.contact__telNumTxt::before {
    position: absolute;
    z-index: 5;
    content: "";
    background: url(../img/img11.png) no-repeat;
    width: 33px;
    height: 33px;
    left: -33px;
    bottom: -4px;
}

.contact__form {
    width: 512px;
    margin: 0 auto;
}

.contact__insta {
    border: 1px solid #A39838;
    padding: 32px 0 32px 0;
    width: 465px;
    margin: 0 auto 64px auto;
    text-align: center;
}
@media screen and (max-width:1130px) {
    .contact__insta {
        width: 100%;
    }
}

.contact__insta a img {
    margin: 20px 0 0;
    width: 70px;
    height: auto;
}
.contact__insta a img:hover {
    opacity: .7;
}
.form__title {
    font-family: 'Noto Serif JP', serif;
    color: #4D2A0A;
    font-size: 16px;
    line-height: 16px;
    font-weight: 500;
    margin-bottom: 8px;
}
.form__redtxt {
    color: #D32929;
}
.form__put {
    border: 1px solid #B3B3B3;
    background-color: #fff;
    width: 100%;
    height: 38px;
    border-radius: 8px;
    margin-bottom: 32px;
}
.form__put.freeTxt-Box {
    height: auto;
}
.form__put input {
    width: 100%;
    height: 100%;
    padding: 0px 10px;
}
.checkbox {
    margin-bottom: 32px;
}
.checkbox__ul {
    display: flex;
}
.checkbox__list {
    font-family: 'Noto Serif JP', serif;
    color: #4D2A0A;
    font-size: 16px;
    line-height: 24px;
    margin-right: 40px;
}

/*radio*/
#checkbox input[type=radio] {
    padding-left: 22px;
    vertical-align: middle;
    position: relative;
}
#checkbox input[type=radio]::before,
#checkbox input[type=radio]::after {
    content: "";
    display: block;
    position: absolute;
}
#checkbox input[type=radio]::before {
    background-color: #fff;
    border: 1px solid #E0E0E0;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    left: 0px;
    bottom: -6px;
}
#checkbox input[type=radio]::after {
    opacity: 0;
    height: 16px;
    width: 17px;
    background: url(../img/img12.png) no-repeat;
    left: 0px;
    bottom: -6px;
    box-sizing: border-box;
}
#checkbox input[type=radio]:checked::after {
    opacity: 1;
}
.form__textarea {
    width: 100%;
    height: 100%;
    padding: 9px 10px;
}
.form__btn {
    margin: 0 auto 8px auto;
    font-size: 20px;
    line-height: 28.96px;
}
input:focus,
textarea:focus {
    outline: #D32929 1px solid;
    border-radius: 8px;
}
input[type=radio]:focus,
input[type=submit]:focus {
    outline: transparent;
}
input {
    font-family: 'Noto Serif JP', serif;
}
#textarea-id {
    width: 100%;
    height: 38px;
    margin: 0 auto;
    resize: vertical;
    font-family: 'Noto Serif JP', serif;
}
/*validation*/
#form_id .formError .formErrorContent {
    background: transparent;
    color: #D32929;
    font-size: 16px;
    border: none;
    box-shadow: none;
    padding: 0;
    font-family: 'Noto Serif JP', serif;
}
#form_id .formError .formErrorArrow div {
    background: transparent;
    border: none;
    box-shadow: none;
}



/*footer
------------------------------------------------------*/
footer {
    background-color: #FFFFFB;
    padding: 46px 0px 11px 0px;
}
.footer__flex {
    display: flex;
    justify-content: space-between;
}
.footer__logo {
    display: block;
    text-align: left;
    margin-bottom: 25px;
}
.footer__address {
    position: relative;
    z-index: 5;
    color: #A39838;
    text-align: left;
    font-size: 20px;
    line-height: 24px;
    font-weight: 500;
    margin-bottom: 13px;
    margin-left: 30px;
}
.footer__address::before {
    position: absolute;
    z-index: 5;
    content: "";
    background: url(../img/img10.png) no-repeat;
    width: 45px;
    height: 45px;
    left: -43px;
    bottom: -10px;
}
.footer__telwrap {
    text-align: left;
    margin-bottom: 12px;
}
.footer__tel {
    position: relative;
    z-index: 5;
    color: #A39838;
    font-size: 20px;
    line-height: 30px;
    font-weight: 500;
    margin-left: 33px;

}
.footer__tel::before {
    position: absolute;
    z-index: 5;
    content: "";
    background: url(../img/img09.png) no-repeat;
    width: 22px;
    height: 22px;
    left: -32px;
    bottom: 2px;
}
.footer__copyright {
    color: #A39838;
    font-size: 20px;
    line-height: 24px;
    font-weight: 500;
}


/*top SP
------------------------------------------------------*/
@media screen and (max-width:767px) {
    /*common
    =========================================*/
    .sitewrap {
        padding: 0px 20px;
    }
    .btn {
        font-size: 16px;
        width: auto;
        padding: 3.5px 16.5px;
    }

    .each__title {
        margin-bottom: 18px;
        font-size: 32px;
    }
    .each__txt {
        font-size: 16px;
    }

    a[href^="tel:"] {
        pointer-events: auto;
    }


    /*header
    =========================================*/
    header {
        height: auto;
    }
    .header__flex {
        height: 60px;
        padding: 0 0px 0px 10px;
    }

    .header__btn .btn {
        width: 97px;
        height: 30px;
        font-size: 16px;
        padding: 0;
        line-height: 30px;
    }
    .header__logo {
        max-width: 91px;
        height: 23px;
    }
    .header__logo img {
        width: 100%;
        height: 100%;
    }

    /*visual
    =========================================*/
    .visual {
        background: url(../img/sp_img16.jpg) no-repeat center;
        background-size: cover;
        height: 600px;
    }
    .visual-2 {
        background: url(../img/img02.jpg) no-repeat center;
    }
    .visual__title {
        writing-mode: vertical-rl;
        font-size: 20px;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        line-height: 35px;
    }
    .top-page .visual__title {
        top: -30px;
    }
    .visual__title p {
        text-align: end;
        margin-top: 10.5em;
    }

    /*about
    =========================================*/
    .about {
        padding-top: 48px;
    }
    .about .each__txt:nth-of-type(1) {
        margin-bottom: 20px;
    }
    .about .each__title {
        margin-bottom: 18px;
    }

    /*access
    =========================================*/
    .access__map iframe {
        width: 100%;
        height: auto;
    }
    .access__address {
        font-size: 16px;
        margin-bottom: 18px;
    }
    .access__address span::before {
        background-size: contain;
        width: 32px;
        height: 32px;
        left: -30px;
        bottom: -4px;
    }
    .access__map {
        position: relative;
        width: 100%;
        height: 0;
        padding-top: 75%;
    }
    .access__map iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    /*recruit
    =========================================*/
    .recruit {
        padding: 96px 0;
    }
    .recruit .each__txt {
        margin-bottom: 18px;
    }
    .recruit__btn {
        max-width: 184px;
        padding:  7px 0;
    }

    /*picBox
    =========================================*/
    .picBox {
        padding: 0px 20px;
    }
    .picBox__wrap {
        flex-wrap: wrap;
    }
    .picBox__item {
        width: 100%;
    }
    .picBox__item:nth-of-type(1),
    .picBox__item:nth-of-type(2) {
        margin-bottom: 20px;
    }
    .picBox__pic {
        width: 100%;
        height: 100%;
    }

    /*contact
    =========================================*/
    .contact {
        padding: 96px 0 48px 0;
    }
    .contact .each__title {
        margin-bottom: 18px;
    }
    .contact__tel {
        width: 100%;
        margin-bottom: 36px;
        padding-bottom: 29px;
    }
    .contact__form {
        width: 100%;
        padding: 0px 12px;
    }
    .form__put {
        margin-bottom: 18px;
    }
    .checkbox {
        margin-bottom: 18px;
    }
    .form__put.freeTxt-Box {
        margin-bottom: 28px;
    }
    .form__btnWrap .btn {
        width: 120px;
    }
    #form_id .formError .formErrorContent {
        font-size: 12px;
    }
    #checkbox input[type=radio]::before {
        bottom: 2px;
    }
    #checkbox input[type=radio]::after {
        bottom: 2px;
    }

    /*footer
    =========================================*/
    footer {
        padding: 53px 0 47px 0;
    }
    .footer__flex {
        display: block;
    }
    .footer__logo {
        margin-bottom: 32px;
        width: 108px;
        height: auto;
    }
    .footer__logo img {
        width: 100%;
        height: 100%;
    }
    .footer__address {
        font-size: 16px;
    }
    .footer__tel {
        font-size: 16px;
    }
    .footer__telwrap {
        margin-bottom: 34px;
    }
    .footer__btnwrap {
        margin-bottom: 33px;
    }
    .footer__btnwrap .btn {
        width: 120px;
    }
    .footer__copyright {
        font-size: 12px;
    }
    .footer__btn {
        padding: 7px 28px;
    }
}



/*------------------------------------------------------
recruit page
------------------------------------------------------*/

/*details
------------------------------------------------------*/
.details {
    background-color: #F3F2EA;
    padding: 96px 0;
}
.details__wrap {
    max-width: 781px;
    margin: 0 auto;
}
.details__item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.details__title {
    font-family: 'Noto Serif JP', serif;
    background-color: #DDD8A9;
    font-size: 20px;
    max-width: 209px;
    width: 26.7%;
    height: 80px;
    line-height: 80px;
    color: #4D2A0A;
    text-align: center;
    font-weight: 500;
}
.details__txt {
    font-family: 'Noto Serif JP', serif;
    background-color: #FFFFFB;
    font-size: 20px;
    max-width: 552px;
    width: 70.6%;
    height: 80px;
    color: #4D2A0A;
    display: flex;
    align-items: center;
    padding-left: 30px;
}


/*step
------------------------------------------------------*/
.step {
    background-color: #FFFFFB;
    padding: 100px 0 100px 0;
}
.step .each__title {
    margin-bottom: 73px;
}
.step__listWrap {
    max-width: 785px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}
.step__list {
    width: 200px;
}
.step__num {
    width: 56px;
    height: 56px;
    background-color: #DDD8A9;
    border-radius: 50%;
    margin: 0 auto 30px auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
.step__title {
    font-size: 28px;
    font-family: 'Noto Serif JP', serif;
    text-align: center;
    color: #4D2A0A;
    margin-bottom: 30px;
}
.step__txt {
    font-size: 20px;
    text-align: left;
}

/*questions
------------------------------------------------------*/
.questions {
    background-color: #F3F2EA;
    padding: 96px 0 0 0;
}
.questions .each__title {
    margin-bottom: 96px;
}
.quesion__wrap {
    max-width: 781px;
    margin: 0 auto;
}
.question__each {
    background-color: #FFFFFB;
    font-family: 'Noto Serif JP', serif;
    color: #4D2A0A;
    font-size: 20px;
    padding: 28px 40px;
    margin-bottom: 18px;
}
.question__each:last-child {
    margin-bottom: 0;
}
.question__Flex {
    display: flex;
}
.question__Flex.tit {
    padding-bottom: 25px;
    margin-bottom: 25px;
    border-bottom: 1px solid #A39838;
}
.question__maru {
    font-weight: 500;
    margin-right: 19px;
}
.question__titleTxt {
    font-weight: 500;
    text-align: left;
}

/*recruit SP
------------------------------------------------------*/
@media screen and (max-width:767px) {
    /*details
    =========================================*/
    .details {
        padding: 48px 0;
    }
    .details__wrap {
        padding: 0;
    }
    .details__item {
        display: block;
    }
    .details__title {
        height: auto;
        line-height: 100%;
        padding: 11.5px 30px;
        font-size: 16px;
        margin-bottom: 8px;
        width: auto;
        display: inline-block;
    }
    .details__txt {
        height: auto;
        padding: 11.5px 0 11.5px 30px;
        font-size: 16px;
        max-width: 100%;
        width: 100%;
    }

    /*step
    =========================================*/
    .step {
        padding: 48px 0;
    }
    .step .each__title {
        margin-bottom: 36px;
    }
    .step__listWrap {
        display: block;
    }
    .step__list {
        width: 209px;
        margin: 0 auto 28px auto;
    }
    .step__list:last-child {
        margin-bottom: 0px;
    }
    .step__num {
        margin-bottom: 18px;
    }
    .step__title {
        margin-bottom: 18px;
    }
    .step__txt {
        font-size: 16px;
    }


    /*question
    =========================================*/
    .questions {
        padding-top: 48px;
    }
    .quesion__wrap {
        width: 100%;
        padding: 0;
    }
    .questions .each__title {
        margin-bottom: 18px;
    }
    .question__each {
        font-size: 16px;
        padding: 28px;
    }
    .question__Flex .tit {
        margin-bottom: 20px;
        padding-bottom: 20px;
        padding-left: 24px;
    }
}

/*send-page
------------------------------------------------------*/
.form__sent {
    height: 100vh;
    background-color: #F3F2EA;
    display: flex;
    align-items: center;
}
.form__sent-text {
    margin-bottom: 50px;
    font-size: 16px;
    line-height: 1.6;

}
.form__sent-TOP--btn  {
    margin: 0 auto;
    max-width: 180px;
}

@media screen and (max-width:767px)  {
    .form__sent-text {
        margin-bottom: 30px;
        font-size: 14px;
    }
}

@media screen and (max-width:374px) {
    .checkbox__list {
        font-size: 13px;
    }
    #form_id .formError .formErrorContent {
        font-size: 10px;
    }
}

.background {
    display: flex;
    justify-content: center;
    width: 100%;
    background-color: #000;
}

.background img {
    width: auto;
    height: 500px;
}

.load-fade {
    opacity: 0;
    visibility: hidden;
    transition: all 1s;
}
.load-fade.is-show {
    opacity: 1;
    visibility: visible;
}

.fixed-btn {
    display: none;
}
@media screen and (max-width:768px) {
    .fixed-btn {
        opacity: 0;
        transition: .5s;
        position: fixed;
        left: 0;
        bottom: 0;
        z-index: 999;
        display: flex;
        padding: 10px;
        width: 100%;
        background-color: rgba(255, 255, 255, 0.773);
    }

    .fixed-btn a {
        height: 60px;
        margin: 0 5px;
    }
    .fixed-btn img {
        height: 60px;
    }
}

.fixed-btn-recruit {
    font-family: 'Shippori Mincho B1', serif;
    color: #fff;
    font-size: 20px;
    padding: 18px 20px 22px;
    background: linear-gradient(to right, #ccc47a -1%,#ccc47a 0%,#a39838 100%,#a39838 100%);
    display: block;
    border-radius: 3px;
    width: 100%;
    box-shadow: 4px 4px 10px -7px #000;
    text-align: center;
}


.pc {
    display: block;
}
@media screen and (max-width:768px) {
    .pc {
        display: none;
    }
}
.sp {
    display: none;
}
@media screen and (max-width:768px) {
    .sp {
        display: block;
    }
}