@charset "UTF-8";

/*
Theme Name: eight
Theme URI:
Author: eight
Author URI:
Description: 
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: eight

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

article,
blockquote,
body,
dd,
section,
div,
dl,
dt,
fieldset,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
li,
ol,
p,
pre,
td,
textarea,
th,
ul {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
    font-style: normal;
}

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

caption,
p,
th {
    text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 100%;
    text-align: left;
    color: #fff;
}

abbr,
acronym,
fieldset,
img {
    border: 0;
}

li {
    list-style-type: none;
}

img {
    vertical-align: middle;
    margin: 0;
    padding: 0;
    border: 0;
    max-width: 100%;
    height: auto;
    /***/
    width: auto;
}

a {
    color: inherit;
    text-decoration: none;
    transition: 0.4s;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    cursor: pointer;
    outline: 0;
}

a:active,
a:focus,
a:hover {
    text-decoration: none;
    outline: none;
}

@media only screen and (min-width: 780px) {
    a:hover {
        opacity: 0.8;
    }
}

a:hover img {
    opacity: 0.8;
}

body p {
    display: block;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0;
    -webkit-margin-end: 0;
    color: #fff;
}

.fadeU,
.fadeD,
.fadeL,
.fadeR {
    opacity: 0;
}


/* General setting */

html {
    overflow-y: scroll;
    font-size: 62.5%;
}

body,
html {
    width: 100%;
}

body {
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 500;
    /* color: #000; */
    background-color: #000;
}

.headline {
    width: 100%;
    height: 120px;
    margin: auto;
    padding: 30px 30px 0;
}

@media only screen and (max-width: 800px) {
    .headline {
        height: 60px;
        background-color: rgba(255, 255, 255, .8);
        position: fixed;
        z-index: 9999;
        padding: 0;
    }
}

.headline-line {
    width: 140px;
    height: 60px;
    border: 1px solid #9e865b;
    background-color: #fff;
    text-align: center;
    font-family: "shippori-sb", serif;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    line-height: 58px;
    color: #9e865b;
}

@media only screen and (max-width: 800px) {
    .headline-line {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

@media only screen and (min-width: 800px) {
    .headline-line:hover {
        background-color: #b79e85;
        color: #fff;
        opacity: 1;
    }
}

.headline-right {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-left: auto;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

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

.headline .com-info {
    margin-left: 20px;
}

.logo {
    display: inline-block;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    position: absolute;
    left: 30px;
    max-width: 150px;
    z-index: 9999;
}

.logo:hover {
    opacity: 0.7;
}

.logo a,
.logo img {
    display: block;
}

@media only screen and (max-width: 800px) {
    .logo img {
        height: 60px;
        object-fit: contain;
        max-width: 120px;
    }

    .logo {
        left: 10px;
        position: relative;
        max-width: 120px;
    }
}

.com-info {
    width: 308px;
}

.com-info-link {
    width: 150px;
    padding-left: 20px;
    padding-bottom: 7px;
    border-bottom: 1px solid #222222;
    color: #222222;
    line-height: 1.2;
}

.com-info-link-wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.com-info-link-mail {
    background: url(../img/top/info-mail.png) no-repeat left 5px;
    font-family: "shippori", serif;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.06em;
    -webkit-column-rule: #222222;
    -moz-column-rule: #222222;
    column-rule: #222222;
}

@media only screen and (max-width: 767px) {
    .com-info-link-mail {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

.com-info-link-tel {
    background: url(../img/top/info-tel.png) no-repeat left 4px;
    font-family: "Noto serif Medium", serif;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    -webkit-column-rule: #222222;
    -moz-column-rule: #222222;
    column-rule: #222222;
}

@media only screen and (max-width: 767px) {
    .com-info-link-tel {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

.com-info-txt {
    font-family: "Noto serif Medium", serif;
    font-size: 14px;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    color: #222222;
}

@media only screen and (max-width: 767px) {
    .com-info-txt {
        font-size: 13px;
        font-size: 1.3rem;
    }
}

.com-info-txt-wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-top: 4px;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.com-info-txt-wrap p:nth-of-type(n+2) {
    margin-left: 14px;
}

.slider-container {
    /* position: relative; */
    width: 100%;
    height: auto;
    overflow: hidden;
}

.other-container {
    position: relative;
    width: 100%;
    height: 400px;
    overflow: hidden;
    background-color: #caafa5;
}

.slider-container_sp,
.other-container_sp {
    display: none;
}

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

    .slider-container,
    .other-container {
        display: none;
    }
}

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

    .slider-container_sp {
        display: block;
        position: relative;
        width: 100%;

        overflow: hidden;
        top: 0;
        z-index: -1;
    }

    .other-container_sp {
        display: block;
        position: relative;
        width: 100%;
        height: 50vh;
        overflow: hidden;
        top: -60px;
        z-index: -1;
    }
}

@media only screen and (max-width: 530px) {
    .slider-container_sp {
        height: 100vh;

    }
}

.slideimg {
    /* position: absolute; */
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    opacity: 0;
    background-size: cover;
    /* 画像をスライド全体にカバー */
    animation: slideAnime 15s infinite;
    /* 15秒で1サイクル */
    border-bottom-left-radius: 100px;
}

@keyframes slideAnime {

    0%,
    63%,
    100% {
        opacity: 0;
    }

    /* スライドの非表示タイミング */
    10%,
    43% {
        opacity: 1;
    }

    /* スライドの表示タイミング */
}

.other_img {
    position: absolute;
    width: 55%;
    height: 100%;
    top: 0;
    right: 0;
    background-size: contain;
    border-bottom-left-radius: 100px;
}

@media only screen and (max-width: 1200px) {
    .other_img {
        width: 80%;
    }
}

.slideimg_sp {
    display: none;
}


/* 各スライドのアニメーションタイミングを均等にずらす */

/* .slideimg:nth-of-type(1) {
    background-image: url('img/top01.png');
    animation-delay: 0s;
}

.slideimg:nth-of-type(2) {
    background-image: url('img/top02.png');
    animation-delay: 5s;
}

.slideimg:nth-of-type(3) {
    background-image: url('img/top03.png');
    animation-delay: 10s;
}

.slideimg_sp:nth-of-type(1) {
    background-image: url('img/top_sp01.png');
    animation-delay: 0s;
}

.slideimg_sp:nth-of-type(2) {
    background-image: url('img/top_sp02.png');
    animation-delay: 5s;
}

.slideimg_sp:nth-of-type(3) {
    background-image: url("img/top_sp03.png");
    animation-delay: 10s;
} */


/*	mv  PC
  ------------------------------------ */

.top .mv {
    height: 580px;
    position: relative;
}

.other .mv {
    display: none;
}

.top .mv_menu {
    height: 580px;
    position: relative;
}

.other .mv_menu {
    height: 400px;
    position: relative;
}

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

    .top .mv,
    .mv_menu {
        height: auto;
    }
}

.top .mv::before {
    content: "";
    display: block;
    width: 100%;
    height: 180px;
    margin: auto;
    background-color: #eff0f1;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: -1;
}

.menu_img,
.korugi_img,
.qa_img,
.contact_img {
    background-repeat: no-repeat;
    background-size: cover;
}

.menu_img {
    background-image: url('img/menu_top.png');
}

.korugi_img {
    background-image: url('img/korugi_top.png');
}

.qa_img {
    background-image: url('img/qa_top.png');
}

.contact_img {
    background-image: url('img/contact_top.png');
}

.menu_img_sp,
.korugi_img_sp,
.qa_img_sp,
.contact_img_sp {
    display: none;
}

@media only screen and (max-width: 800px) {
    .other-container_sp {
        top: 0;
    }

    .menu_img_sp,
    .korugi_img_sp,
    .qa_img_sp,
    .contact_img_sp {
        display: block;
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        right: 0;
        background-size: cover;
        border-bottom-left-radius: 100px;
        background-repeat: no-repeat;
    }

    .menu_img_sp {
        background-image: url('img/menu_sp.png');
    }

    .korugi_img_sp {
        background-image: url('img/korugi_sp.png');
    }

    .qa_img_sp {
        background-image: url('img/qa_sp.png');
    }

    .contact_img_sp {
        background-image: url('img/contact_sp.png');
    }

    .menu_img,
    .korugi_img,
    .qa_img,
    .contact_img {
        display: none;
    }
}

@media only screen and (max-width: 530px) {
    .menu_img_sp {
        background-image: url('img/menu_sp2.png');
    }

    .korugi_img_sp {
        background-image: url('img/korugi_sp2.png');
    }

    .qa_img_sp {
        background-image: url('img/qa_sp2.png');
    }

    .contact_img_sp {
        background-image: url('img/contact_sp2.png');
    }
}

.mv-img {
    width: 56.25%;
    margin-left: auto;
    position: absolute;
    top: 0;
    right: 0;
}

@media only screen and (max-width: 800px) {
    .mv-img {
        width: 100%;
        position: static;
    }
}

.mv-inner {
    width: 100%;
    max-width: 1080px;
    margin: auto;
    position: absolute;
    top: 0;
    left: 10px;
    right: 0;
}

@media only screen and (max-width: 800px) {
    .mv-inner {
        padding: 0 15px 50px;
        position: absolute;
        top: 50%;
    }
}

.mv-catch {
    text-align: left;
    position: absolute;
    top: 200px;
    left: 0;
    z-index: 1;
}

@media only screen and (max-width: 800px) {
    .mv-catch {
        position: relative;
        top: auto;
        left: auto;
        background-color: #ffffffb3;
        padding: 5px 0 5px 5px;
    }
}

.mv-catch-en {
    display: block;
    font-family: "cormorant", serif;
    font-size: 5rem;
    letter-spacing: 0;
    color: #f2eeee;
    line-height: 1;
    position: absolute;
    top: -68px;
    left: 0;
    z-index: -1;
    white-space: nowrap;
    text-shadow: 1px 1px 1px #caafa5;
}

@media only screen and (max-width: 800px) {
    .mv-catch-en {
        font-size: 25px;
        font-size: 2.5rem;
        left: 0;
    }
}

.mv-catch-en02 {
    margin-top: 20px;
    font-family: "shippori", serif;
    font-size: 22px;
    font-size: 2.2rem;
    letter-spacing: 0.2em;
    color: #9e865b;
    line-height: 2.5;
}

@media only screen and (max-width: 800px) {
    .mv-catch-en02 {
        font-size: 18px;
        font-size: 1.8rem;
    }
}

.mv-catch-ja,
.mv-catch-ja02 {
    display: block;
    font-family: "shippori", serif;
    font-size: 3.4rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1.6;
    text-shadow: 1px 1px 1px #eee
}

.mv-catch-ja02 {
    font-size: 1.8rem;
    padding: 10px 0 0;
}

@media only screen and (max-width: 800px) {
    .mv-catch-ja {
        font-size: 2.2rem;
    }

    .mv-catch-ja02 {
        display: none;
    }
}

.mv-catch-ja02 span {
    font-size: 2.5rem;
}

.bx-wrapper {
    border: none !important;
    margin: 0 !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

@media only screen and (min-width: 800px) {
    .bx-wrapper li {
        height: 0 !important;
        padding-top: 580px !important;
    }

    .bx-wrapper img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        vertical-align: bottom;
    }
}

@media only screen and (min-width: 800px) {
    .bx-viewport {
        height: 580px !important;
    }
}

.gnav-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 700px;
    padding: 0;
    background-color: #b79e85;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    justify-content: space-evenly;
}

.gnav-item {
    line-height: 1;
}

.gnav-item a {
    display: block;
    padding: 12px 0;
    font-family: "shippori", serif;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    color: #fff;
    text-align: center;
    line-height: 15px;
    margin: 0 20px;
}

@media only screen and (max-width: 767px) {
    .gnav-link {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

.gnav-link:hover {
    opacity: 1;
    color: #e7e2e0;
}

.gnav-link-current {
    color: #e7e2e0;
}

.top #header {
    z-index: 99;
}


/* .leave_head .headline {
        background-color: white;
        box-shadow: #eee 2px 2px 2px;
    } */

#header .header_wrap {
    padding: 0 10px;
    width: 100%;
    max-width: 1200px;
    height: 100%;
    position: relative;
    display: flex;
    transition: .4s;
    justify-content: space-between;
    margin: 0 auto;
}

@media only screen and (min-width: 1260px) {
    #header .header_wrap {
        padding: 0 70px;
    }
}

@media only screen and (max-width: 1200px) {
    .footer__social {
        text-align: center;
        padding: 20px 0;
    }
}

#footer {
    width: 100%;
    height: auto;
}

@media only screen and (max-width: 800px) {
    #footer {
        background: #7f786c;
    }
}

#footer a,
#footer p {
    font-size: 1.6rem;

}

@media only screen and (max-width: 800px) {
    #footer img {
        text-align: center;
    }
}

#footer p {
    text-align: center;
    /* color: #6d6159; */
    margin: 0 auto;
}

#footer .footer_wrap .logo_wrap .logo_img_wrap {
    width: 260px;
    margin: 10px auto;
}

#footer .footer_wrap .privacy_link {
    position: relative;
    width: 100%;
}

#footer .footer_wrap .privacy_link a {
    display: block;
    text-align: center;
    font-size: 1.2rem;
    line-height: 1.5;
}

.footer {
    padding: 3rem 2rem 1.5rem;
    background-color: #ffffff;
}

.footer__container {
    display: grid;
    justify-items: center;
    grid-template-columns: repeat(2, 1fr);
    max-width: 1200px;
    margin: 100px auto 50px;
    align-content: center;
    justify-content: space-evenly;
    align-items: end;
}

.footer__logo {
    width: 104px;
    height: 26px;
    margin-bottom: .2em;
}

.footer__title,
.footer__link {
    margin: 0 0 1em;
    color: #333;
    font-size: .9em;
}

.footer__title {
    font-weight: 600;
}

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

.footer__link {
    display: block;
}

.footer__link:not(:hover) {
    text-decoration: none;
}

@media only screen and (max-width: 800px) {
    .footer__container {
        justify-items: center;
        gap: 3em;
        display: flex;
        flex-direction: column;
        align-content: center;
        align-items: center;
    }
}

@media only screen and (max-width: 530px) {
    .footer__container {
        flex-direction: row;
        margin: 20px 0;
    }
}

.footer__social {
    margin: 20px auto;
}

.footer__head img {
    max-width: 200px;
    object-fit: contain;
}

@media only screen and (max-width: 530px) {
    .footer__head img {
        max-width: 150px;
    }
}

#price, #floor {
    /* display: block; */
    margin-top: -20px;
    /* padding-top: 20px;
    background: #222; */

}

/* セクション */

.wrapper>.content {
    width: 100%;
    max-width: 1080px;
    margin: 20px auto;
    margin-top: 100px;
    background: #fff;
    padding: 20px;
}

@media only screen and (max-width: 414px) {
    .wrapper>.content {
        margin-top: 80px;
    }
}

.wrapper>section:last-child {
    margin-bottom: 0;
}

.container {
    position: relative;
    background: #fff;
    height: 0;
    margin: 0 auto;
    width: 1200px;
}

.wave_btm {
    position: absolute;
    height: 70px;
    width: 100%;
    background: #fff;
    bottom: 0;
}

.wave_btm::before,
.wave_btm::after {
    content: "";
    display: block;
    position: absolute;
    border-radius: 100% 50%;
}

.wave_btm::before {
    width: 55%;
    height: 109%;
    background-color: #caafa5;
    right: -1.5%;
    top: 60%;
}

.wave_btm::after {
    width: 55%;
    height: 100%;
    background-color: #fff;
    left: 0;
    top: 35%;
}

.korugi_wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    background-color: #fff;
    padding: 60px;
    margin: 60px auto;
    max-width: 1200px;
}

@media only screen and (max-width: 800px) {
    .korugi_wrap {
        flex-direction: column;
        padding: 20px;
    }
}

.korugi_wrap img {
    display: block;
    width: 48%;
    height: auto;
}

.korugi_box {
    width: 48%;
}

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

    .korugi_box,
    .korugi_wrap img {
        width: 100%;
    }
}

.korugi_box h2 {
    font-size: 3rem;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 2;
}

@media only screen and (max-width: 530px) {
    .korugi_box h2 {
        font-size: 2.4rem;
        margin-top: 10px;
    }
}

.korugi_box p {
    font-size: 1.6rem;
    letter-spacing: 1px;
    line-height: 2;
    margin-top: 20px;
}

@media only screen and (max-width: 530px) {
    .korugi_box p {
        margin-top: 10px;
    }
}

.k_box {
    padding: 2em;
    position: relative;
    border: 8px solid #eee;
    z-index: 0;
    margin: 30px auto 0;
    font-size: 1.6rem;
    line-height: 1.5;
    letter-spacing: 1px;
}

@media only screen and (max-width: 530px) {
    .k_box {
        padding: 1em;
    }
}

.k_box:before {
    background-color: #cca497;
    content: '';
    display: block;
    position: absolute;
    top: -8px;
    left: -8px;
    width: 8px;
    height: 8px;
    z-index: 1;
}

.k_box .box-title {
    color: #AA8276;
    font-size: 18px;
    font-weight: bold;
}

.k_box .box-title:before {
    font-family: "Font Awesome 5 Free";
    content: "\f06a";
    font-size: 18px;
    margin: 0 3px 0 0;
    font-weight: bold;
}

table.company {
    width: 50%;
    margin: 3rem auto;
    border-collapse: separate;
    border-spacing: 0px 10px;
    font-size: 16px;
}

table.company th,
table.company td {
    padding: 10px;
    letter-spacing: 3px;
    border-bottom: #efeff0 1px solid;
    color: #222;
}

table.company th {
    vertical-align: middle;
    text-align: center;
    width: 30%;
    overflow: visible;
    position: relative;
    font-size: 16px;
    padding: 15px 0;
}

table.company td {
    width: 70%;
}

table.company tr {
    padding-bottom: 10px;
}

@media only screen and (max-width: 780px) {
    table.company {
        width: 90%;
    }
}

@media only screen and (max-width: 530px) {
    table.company {
        width: 95%;
    }

    table.company td,
    table.company th {
        display: block;
        width: 100%;
        text-align: center;
    }

    table.company th {
        background-color: rgb(239 239 240 / 20%);
    }

    table.company td {
        border-bottom: none;
    }

    table.company tr {
        padding: 0;
    }
}

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

    table.company th,
    table.company td {
        padding: 5px;
    }
}


/*Google　map*/

.ggmap {
    position: relative;
    height: 0;
    overflow: hidden;
    padding-top: 40%;
    width: 700px;
    margin: 6rem auto;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/* お問い合わせ詳細 */

.tel_box {
    display: flex;
    justify-content: center;
}

.contact_att {
    margin: auto;
    text-align: center;
}

.contact_att p {
    font-size: 13px;
    text-align: center;
    margin-left: 2em;
}

.tel_img {
    vertical-align: middle;
}

.contact_info {
    font-size: 16px;
    text-align: center;
}

.contact_info p {
    font-size: 1.8rem;
    text-align: center;
    margin: 1em 1rem;
    line-height: 2;
    margin-top: 70px;
    letter-spacing: 0.05em;
}

.contact_info .tel_number {
    font-size: 36px;
    margin: 15px 0 0 10px;
    text-align: center;
    color: #fff;
}

@media only screen and (max-width: 530px) {
    .contact_info p {
        font-size: 1.6rem;
    }

    .contact_info .tel_number {
        font-size: 28px;
    }

    .tel_img img {
        width: 36px;
    }
}

.telephone {
    font-weight: bold;
    position: relative;
    display: inline-block;
    padding: 0 55px;
    font-size: 22px;
    margin-top: 2em;
    margin-bottom: 1em;
}

.telephone:before,
.telephone:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 45px;
    height: 1px;
    background-color: black;
}

.telephone:before {
    left: 0;
}

.telephone:after {
    right: 0;
}


/* 営業時間 */

.time_about {
    border: 2px solid #d9c7b3;
    margin: 70px auto 20px;
    padding: 1em;
    width: 50%;
}

@media only screen and (max-width: 800px) {
    .time_about {
        margin: 30px auto 0;
        width: 70%;
    }
}

@media only screen and (max-width: 600px) {
    .time_about {
        width: 80%;
    }
}

.time_about p {
    text-align: center;
    margin: 0 auto;
    letter-spacing: 2px;
}

.time_about span {
    color: #f2eeee;
    font-size: 1.3rem;
}


/* コンタクトフォーム７ */

#contact_form {
    font-size: 1.5rem;
    margin: 40px auto;
    padding: 0 20%;
}

@media only screen and (max-width: 414px) {
    #contact_form {
        margin: 10px auto;
        padding: 0;
        font-size: 1.4rem;
    }
}

.cf7 {
    max-width: 100%;
    box-sizing: border-box;
}

.cf7 dt i {
    margin-right: .5em;
}

.cf7 dd {
    margin: 0 0 2vh 0;
}

.cf7 .rqd {
    color: #ff6666;
    font-size: .8em;
    margin-left: .5em;
}

.btn_cf7 {
    text-align: center;
}

.btn-cf7:active {
    border-bottom: solid 2px #dbe1e8;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.30);
}

.btn_cf7 input {
    width: 100%;
    position: relative;
    padding: 0.25em 0.5em;
    margin-top: 1em;
    text-decoration: none;
    color: #FFF;
    background: #7f7866;
    border-bottom: solid 2px #565149;
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.2), 0 2px 2px rgba(0, 0, 0, 0.19);
    font-weight: bold;
    font-size: 1.8rem;
}

@media only screen and (max-width: 414px) {
    .btn_cf7 input {
        margin: 0;
        font-weight: 500;
    }
}

@media only screen and (min-width: 768px) {
    .cf7 dt {
        float: left;
        clear: left;
        width: 35%;
        padding: .5em 1em .5em 0;
    }

    .cf7 dd {
        margin-left: 35%;
    }

    .cf7 .rqd {
        float: right;
        margin-left: 0;
        margin-top: .2em;
    }

    .btn_cf7 input {
        width: 70%;
    }
}

.formBtn {
    width: 300px;
    margin: 0 auto;
    background-color: #7f7866;
    border: 1px solid #7f7866;
    border-radius: 10px;
    transition: .4s;
}

.formBtn:hover {
    background-color: #fff;
}

.formBtn a {
    line-height: 40px;
    color: #FFF;
    display: block;
    text-align: center;
    font-size: 1.6rem;
}

.formBtn a:hover {
    color: #7f7866;
    transform: scale(1);
}


/* フォームCSS */

div.wpcf7 {
    padding-top: 23px;
}

#contact_form strong {
    font-size: 16px;
    font-weight: bold;
    display: inline-block;
    float: right;
    margin: 3.5px 18px 3.5px 0;
    padding: 0 9px 0 10px;
    vertical-align: middle;
    letter-spacing: .2em;
    color: #ff3e30;
}

#contact_form .any {
    font-size: 16px;
    font-weight: bold;
    display: inline-block;
    float: right;
    margin: 3.5px 18px 3.5px 0;
    padding: 0 9px 0 10px;
    vertical-align: middle;
    letter-spacing: .2em;
    color: #3072ff;
}

#contact_form .vanish {
    display: none;
}

.wpcf7-form-control-wrap input {
    width: 100%;
    height: 43px;
    padding: 0 0 0 17px;
}

.wpcf7-form-control-wrap textarea {
    height: 200px;
    padding: 17px;
}

.wpcf7-radio span label input {
    width: 16px;
    height: 18px;
    padding: 0;
    cursor: pointer;
    background-color: #ff3e30;
}

span.wpcf7-list-item {
    display: inline-block;
    margin: 0 0 0 10px;
}

.table_contact .radio_button_wrap {
    font-size: 1.6rem;
    font-size: 16px;
    position: relative;
    top: 11px;
    padding-bottom: 34px;
    text-align: left;
}

span.wpcf7-form-control.wpcf7-radio .wpcf7c-conf {
    display: none;
}

input.wpcf7c-conf-hidden+span.wpcf7-list-item-label {
    font-size: 13px;
    display: table;
}

input.wpcf7c-conf+span.wpcf7-list-item-label {
    display: none;
}

.wpcf7-list-item-label {
    position: relative;
}


/* rectuit */

.tab_select {
    width: auto;
    margin: 20px auto 40px;
    display: flex;
    justify-content: space-between;
}

a.tabButton {
    font-size: 16px;
    width: 24%;
    display: block;
    text-align: center;
    position: relative;
    font-weight: bold;
    padding: 0.25em 0;
    text-decoration: none;
    color: #7f7866;
    background: #ECECEC;
    transition: .4s;
}

a.tabButton:hover {
    background: #7f7866;
    color: white;
}

a.tabButton br.px_780 {
    display: none;
}

@media only screen and (max-width: 780px) {
    a.tabButton br.px_780 {
        display: inline;
    }
}


/* サンクスpage */

.thanks_message {
    font-weight: bold;
    color: #7f7866;
    font-size: 2.6em;
}

.thk_msg {
    text-align: center;
    margin-top: 120px;
}

.thk_msg p {
    font-size: 16px;
    text-align: center;
    margin-top: 20px;
    margin-bottom: 20px;
    line-height: 1.5;
}


/* プライバシーポリシー */

.privacy {
    width: 70%;
    margin: 0 auto;
}

.privacy h2 {
    font-size: 20px;
    padding: 0.25em 0.5em;
    color: #000;
    background: #e3e3e3;
    border-left: solid 5px #7f7866;
    margin-bottom: 1em;
    margin-top: 12rem;
}

.privacy p {
    font-size: 16px;
    margin-left: 2em;
}

.policy {
    font-size: 18px;
    margin: 15px 0 5px 0;
    padding-left: 15px;
}

.info_address {
    margin: 2em 0;
}


/* 404 */
.error_top {
    padding: 40px;
    font-size: 75px;
    font-family: 'Monoton', cursive;
    text-align: center;
    text-transform: uppercase;
    text-shadow: 0 0 80px red, 0 0 30px FireBrick, 0 0 6px DarkRed;
    color: red;
}

#error:hover {
    text-shadow: 0 0 200px #ffffff, 0 0 80px #008000, 0 0 6px #0000ff;
}

#code:hover {
    text-shadow: 0 0 100px red, 0 0 40px FireBrick, 0 0 8px DarkRed;
}

#error {
    color: #fff;
    font-size: 75px;
    text-align: center;

    text-shadow: 0 0 80px #ffffff, 0 0 30px #008000, 0 0 6px #0000ff;
}

#error span {
    animation: upper 11s linear infinite;
}

#code {
    font-size: 75px;
    text-align: center;
}

#code span:nth-of-type(2) {
    animation: lower 10s linear infinite;
}

#code span:nth-of-type(1) {
    text-shadow: none;
    opacity: .4;
}

@keyframes upper {
    0%, 19.999%, 22%, 62.999%, 64%, 64.999%, 70%, 100% {
        opacity: .99;
        text-shadow: 0 0 80px #ffffff, 0 0 30px #008000, 0 0 6px #0000ff;
    }

    20%, 21.999%, 63%, 63.999%, 65%, 69.999% {
        opacity: 0.4;
        text-shadow: none;
    }
}

@keyframes lower {
    0%, 12%, 18.999%, 23%, 31.999%, 37%, 44.999%, 46%, 49.999%, 51%, 58.999%, 61%, 68.999%, 71%, 85.999%, 96%, 100% {
        opacity: 0.99;
        text-shadow: 0 0 80px red, 0 0 30px FireBrick, 0 0 6px DarkRed;
    }

    19%, 22.99%, 32%, 36.999%, 45%, 45.999%, 50%, 50.99%, 59%, 60.999%, 69%, 70.999%, 86%, 95.999% {
        opacity: 0.4;
        text-shadow: none;
    }
}

.error_message {
    max-width: 1200px;
    text-align: center;
    padding: 5em 0;
    margin-top: 70px;
    margin-right: auto;
    margin-left: auto;
}

.about404 {
    font-size: 1.6rem;
    text-align: center;
    margin: 20px;
    line-height: 1.5;
}

.error1 {
    font-size: 30px;
    font-weight: bold;
    color: #414040;
}

.error2 {
    font-size: 140px;
    font-weight: bold;
    color: #858585;
    text-align: center;
    padding: 20px 0 0;
    line-height: 100px;
}

@media only screen and (max-width: 780px) {
    .errorBtn {
        width: 260px;
    }

    .errorBtn a {
        font-size: 1.4rem;
    }

    .error_message .error1 {
        font-size: 20px;
    }

    .error_message .error2 {
        font-size: 70px;
        line-height: 55px;
    }

    .error_message {
        width: 95%;
    }
}

@media only screen and (max-width: 530px) {
    .about404 {
        margin: 20px 0;
    }

    .error_message .error2 {
        font-size: 50px;
        line-height: 45px;
    }
}


/* TOPに戻る */

.topBtn {
    width: 300px;
    margin: 0 auto;
    background-color: #ae9373;
    border: 1px solid #414040;
    border-radius: 10px;
    transition: .4s;
    padding: 20px 0;
    font-size: 16px;
}

.topBtn:hover {
    background-color: transparent;
}


/* .topBtn a {
    line-height: 40px;
    color: #FFF;
    display: block;
    text-align: center;
    font-size: 1.6rem;
} */

.topBtn a:hover {
    color: #414040;
    transform: scale(1);
}

@media only screen and (max-width: 414px) {
    .topBtn {
        width: 70%;
    }
}

.table_contact {
    width: 100%;
    table-layout: fixed;
}

.table_contact th {
    line-height: 35px;
    width: 293px;
}

.table_contact th span {
    font-size: 1.6rem;
    font-size: 16px;
    font-weight: 600;
}

.table_contact td {
    padding-bottom: 34px;
}

.table_contact input {
    cursor: text;
    border-style: none;
}

.confirm_btn {
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    text-align: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.confirm_btn input {
    font-size: 17px;
    font-size: 1.7rem;
    display: block;
    width: 314px;
    height: 50px;
    margin: 10px 0 0 0;
    cursor: pointer;
    transition: all .4s;
    color: #fff;
    border: 1px solid #7f7866;
    border-radius: 10px;
    background-color: #7f7866;
    -webkit-appearance: none;
}

.confirm_btn input:focus {
    outline: none;
}

.confirm_btn .wpcf7c-btn-back {
    margin: 0 10px 0 0;
    border: 1px solid #ff3e309d;
    background-color: #ff3e309d;
    -webkit-appearance: none;
}

.confirm_btn .wpcf7c-btn-back:hover {
    color: #e8046d;
}

.confirm_btn .wpcf7-submit {
    margin: 0;
}

.confirm_btn input:hover {
    transition: all .4s;
    color: #7f7866;
    background-color: #fff;
}

div.wpcf7-mail-sent-ok {
    display: none !important;
}

textarea {
    width: 100%;
    resize: vertical;
    border: #b3b3b3 1px solid;
}

#contact_form tr {
    width: 100%;
    vertical-align: top;
}

.wpcf7 .required {
    color: #f00;
}

.wpcf7 .wpcf7-not-valid {
    background: #ffb6c1;
}

.wpcf7-text:-webkit-autofill {
    box-shadow: 0 0 0 1000px #e3e3e3 inset;
}

.wpcf7c-conf:-webkit-autofill {
    box-shadow: 0 0 0 1000px #fff inset;
}

input.wpcf7c-conf,
textarea.wpcf7c-conf {
    padding: 0 0 0 17px;
    border: 0;
    background-color: #fff;
}

#submit_button .wpcf7c-force-hide+span::before {
    display: none;
    visibility: hidden;
}

#submit_button input+span::before {
    font-size: 16px;
    line-height: 30px;
    display: block;
    visibility: visible;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    content: 'å†…å®¹ã‚’ç¢ºèªã—ã¦é€ä¿¡ã‚’ã—ã¦ãã ã•ã„';
    color: black;
    border-radius: 10px;
    background-color: red;
}

div.wpcf7 .ajax-loader {
    display: none;
}

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
    display: none !important;
}

span.wpcf7-not-valid-tip {
    line-height: 1.5;
}

.form_spam {
    font-size: 16px;
    margin-bottom: 50px;
}


/* レスポンシブ対応 */

@media only screen and (max-width: 1040px) {
    .wrapper>.content {
        max-width: none;
        padding: 0 20px;
    }

    .product_wrap {
        width: 32%;
    }

    .mod_corporation span {
        display: inline-block;
        position: absolute;
        top: -0.6em;
        margin: 0 auto;
        padding: 0px 13px;
        background: #fff;
        font-weight: bold;
    }

    .philosophy {
        display: inline-block;
        color: #7f7866;
        font-size: 20pt;
        margin: 1em auto;
    }
}

@media only screen and (max-width: 1024px) {
    .contact_wrap {
        padding: 60px 10px;
    }

    .table-res-form th,
    .table-res-form td {
        display: block;
        float: left;
        clear: both;
        width: 100%;
    }

    .table-res-form table,
    .table-res-form tbody,
    .table-res-form tr {
        display: block;
        width: 100%;
    }

    .telephone {
        font-size: 21px;
    }

    div.wpcf7 {
        padding-top: 30px;
    }

    .table_contact td {
        padding-bottom: 30px;
    }

    .table-res-form th {
        padding-bottom: 0;
        text-align: left;
    }

    .table-res-form .empty {
        display: none;
    }

    #contact_form strong {
        float: none;
        margin: 2.5px 13px 2.5px 13px;
    }

    #contact_form strong {
        font-size: 14px;
        padding: 0 5px 0 5px;
    }

    .confirm_title {
        font-size: 2.8rem;
        font-size: 28px;
    }
}

@media only screen and (max-width: 1220px) {
    .contact_wrap {
        max-width: none;
        padding: 90px 10px;
    }

    .wpcf7-form {
        margin: 0;
    }

    .confirm_btn input {
        width: 260px;
    }

    .confirm_title {
        font-size: 3rem;
        font-size: 30px;
    }
}

@media only screen and (max-width: 780px) {
    .wrapper>.content {
        padding: 0 10px;
    }

    .ggmap {
        width: 100%;
        padding-top: 60%;
    }

    .formBtn {
        width: 260px;
    }

    .formBtn a {
        font-size: 1.4rem;
    }

    .errorBtn {
        width: 260px;
    }

    .errorBtn a {
        font-size: 1.4rem;
    }

    .px_780 {
        display: inline;
    }

    .information .content_wrap h2 {
        text-align: center;
        font-size: 2rem;
        margin-bottom: 10px;
    }

    .information .content_wrap p {
        font-size: 1.6rem;
    }

    .information .content_wrap p {
        font-size: 1.4rem;
    }
}

@media only screen and (max-width: 640px) {
    .contact_wrap {
        padding: 30px 10px;
    }

    .telephone {
        font-size: 18px;
    }

    div.wpcf7 {
        padding-top: 15px;
    }

    .table_contact th span {
        font-size: 1.4rem;
        font-size: 14px;
    }

    .confirm_btn input {
        font-size: 14px;
        width: 240px;
    }

    .table_contact td {
        padding-bottom: 20px;
    }

    .confirm_btn {
        flex-direction: column;
        -ms-flex-direction: column;
        -ms-flex-align: center;
        align-items: center;
    }

    .confirm_btn .wpcf7c-btn-back {
        margin: 10px 0;
    }

    .confirm_btn .wpcf7-submit {
        margin: 0;
    }

    .confirm_title {
        font-size: 1rem;
        font-size: 10px;
    }

    .px_780 {
        display: none;
    }

    .nakayo1 {
        max-width: 100px;
        height: auto;
    }

    .privacy {
        width: 90%;
    }
}

@media only screen and (max-width: 480px) {
    .philosophy {
        font-size: 18pt;
    }

    .privacy p {
        font-size: 12px;
    }
}

@media only screen and (max-width: 414px) {
    .wrapper>.content {
        padding: 0 5px;
    }

    a.tabButton {
        font-size: 14px;
    }

    .ggmap {
        width: 100%;
        padding-top: 77%;
        margin: 0;
    }
}

.greeting {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 20px;
}

.greeting_wrap {
    margin: 0 auto;
    flex-basis: 70%;
}

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

    .greeting_wrap,
    .greeting {
        display: block;
    }
}

.greeting_img_wrap {
    flex-basis: 30%;
    margin: 10px;
}

@media only screen and (max-width: 780px) {
    .greeting_wrap {
        flex-basis: 48.5%;
        width: 80%;
        margin: 0 auto;
    }

    .greeting_img_wrap {
        flex-basis: 48.5%;
        width: 40%;
        margin: 0 auto;
    }
}

@media only screen and (max-width: 414px) {
    .greeting_wrap {
        width: 100%;
        display: block;
    }

    .greeting_img_wrap {
        width: 70%;
    }
}

.greeting_wrap p {
    font-size: 1.6rem;
}

@media only screen and (max-width: 414px) {
    .greeting_wrap p {
        font-size: 1.4rem;
    }
}

.greeting_wrap .t_r {
    text-align: right;
    margin: 10px 0;
}

.greeting_wrap ul {
    margin: 25px 0;
}

.greeting_wrap ul li {
    font-size: 16px;
    list-style-type: circle;
    margin-left: 1.5em;
}

@media only screen and (max-width: 414px) {
    .greeting_wrap ul li {
        font-size: 14px;
    }
}

.clock_wrap {
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    /* IE10 */
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    /* IE10 */
}

.clock_wrap p {
    font-size: 14px;
    text-align: center;
    margin-bottom: 10px;
}

.clock_wrap>.c_img {
    width: 33.33333%;
    padding: 10px;
}

@media only screen and (max-width: 960px) {
    .clock_wrap>.c_img {
        width: 50%;
        height: auto;
    }

    .clock_wrap p {
        margin: 0;
    }
}

@media only screen and (max-width: 414px) {
    .clock_wrap>.c_img {
        width: 100%;
    }
}

.shop_about {
    margin: 20px 0;
}

.shop_about p {
    font-size: 16px;
    text-align: center;
    color: #fff;
}

@media only screen and (max-width: 414px) {
    .shop_about p {
        font-size: 14px;
    }
}

.price_table *,
.price_table *:before,
.price_table *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.price_table {
    width: 100%;
    margin: 0 auto;
    border-spacing: 1px 0;
    border-collapse: separate;
    font-size: 16px;
    margin-bottom: 10px;
}

@media only screen and (max-width: 414px) {
    .price_table {
        font-size: 13px;
    }
}

.price_table th,
.price_table td {
    padding: 10px;
}

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

    .price_table th,
    .price_table td {
        padding: 5px 0;
    }
}

.price_table th {
    position: relative;
    z-index: 1;
    text-align: center;
    vertical-align: middle;
    color: #ffffff;
    border-radius: 5px 5px 0 0;
}

.price_table th.group1 {
    background: #a49e94;
    width: 30%;
}

.price_table th.group1:after {
    color: #a49e94;
}

.price_table th.group2 {
    background: #7f786c;
    width: 40%;
}

.price_table th.group2:after {
    color: #7f786c;
}

.price_table th.group3 {
    background: #a49e94;
    width: 30%;
}

.price_table th.group3:after {
    color: #a49e94;
}


/*メインブロック*/

.price_table tr td {
    text-align: center;
    border: none;
}

.price_table tr:last-child td {
    border-radius: 0 0 5px 5px;
}

.price_table tr:nth-child(2n+1) td.group1 {
    background: rgb(164, 158, 148, 0.6);
}

.price_table tr:nth-child(2n+0) td.group1 {
    background: rgb(164, 158, 148, 0.3);
}

.price_table tr:nth-child(2n+1) td.group2 {
    background: rgb(127, 120, 108, 0.6);
}

.price_table tr:nth-child(2n+0) td.group2 {
    background: rgb(127, 120, 108, 0.3);
}

.price_table tr:nth-child(2n+1) td.group3 {
    background: rgb(164, 158, 148, 0.6);
}

.price_table tr:nth-child(2n+0) td.group3 {
    background: rgb(164, 158, 148, 0.3);
}


/* お客様の声 */

.report .voice {
    display: table;
    background: #FFF;
    margin-bottom: 4px;
    padding: 10px 20px;
    width: 100%;
    box-sizing: border-box;
}

.report .voice dt {
    width: 150px;
    font-size: 12px;
    text-align: center;
}

.report .voice dt,
.report .voice dd {
    display: table-cell;
    vertical-align: middle;
}

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

    .report .voice dt,
    .report .voice dd {
        display: inline-block;
        width: 100%;
    }

    .report .voice {
        padding: 0;
    }
}

.report .voice dt img {
    border-radius: 48px;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
}

.report .review_box {
    position: relative;
    background: #ffffff;
    border: 1px solid #d8d8d8;
    margin: 10px;
    padding: 10px;
    border-radius: 4px;
}

@media only screen and (max-width: 414px) {
    .report .review_box {
        margin: 0;
        padding: 5px;
    }
}

.report .review_box:after,
.report .review_box:before {
    right: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}

.report .review_box:before {
    border-color: rgba(216, 216, 216, 0);
    border-right-color: #d8d8d8;
    border-width: 7px;
    margin-top: -7px;
}

.report .review_box:after {
    border-color: rgba(255, 255, 255, 0);
    border-right-color: #ffffff;
    border-width: 6px;
    margin-top: -6px;
}

.report .voice dd p {
    margin-left: 1em;
    font-size: 14px;
}

.voice>dt>div>p {
    text-align: center;
}

.attention {
    font-size: 12px;
    text-align: center;
    margin-bottom: 20px;
}

.title_box {
    padding: 10px 0 0;
    border-bottom: 2px solid #7f786c;
    margin-bottom: 10px;
    font-size: 28px;
    position: relative;
    text-align: center;
    width: 100%;
}

@media only screen and (max-width: 780px) {
    .title_box {
        font-size: 24px;
    }
}

@media only screen and (max-width: 414px) {
    .title_box {
        font-size: 20px;
        margin-top: 10px;
        font-weight: 500;
    }
}

.title_box span {
    position: absolute;
    top: -5px;
    font-size: 14px;
    color: #f7f7f7;
    opacity: 0.3;
    left: 050%;
    transform: translateX(-50%);
}

@media only screen and (max-width: 780px) {
    .title_box span {
        color: #7f786c;
        top: 0;
    }
}

nav.cp_navi *,
nav.cp_navi *:after,
nav.cp_navi *:before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

nav.cp_navi a {
    text-decoration: none;
}

nav.cp_navi {
    margin: 2em 0;
    text-align: center;
}

.cp_navi .cp_pagination {
    display: inline-block;
    margin-top: 2em;
    padding: 0 0.5em;
}

.cp_navi .cp_pagenum {
    font-size: 1.4em;
    line-height: 50px;
    display: block;
    float: left;
    transition: 400ms ease;
    letter-spacing: 0.1em;
    color: #37474F;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    margin: auto .5em;
}

.cp_navi .cp_pagenum:hover,
.cp_navi .cp_pagenum.current {
    font-weight: bold;
    color: #ffffff;
    background-color: #565149;
    border-radius: 50%;
}

.cp_navi .cp_pagenum.prev:hover,
.cp_navi .cp_pagenum.next:hover {
    color: #565149;
    background-color: transparent;
    border-radius: 50%;
}

@media only screen and (max-width: 960px) {
    .cp_navi .cp_pagination {
        margin-top: 50px;
        padding: 0 10px;
    }

    .cp_navi .cp_pagenum {
        font-size: 0.8em;
        line-height: 25px;
        width: 45px;
        height: 25px;
        margin: auto .1em;
        border-radius: 0.3em;
    }

    .cp_navi .cp_pagenum.prev,
    .cp_navi .cp_pagenum.next {
        padding: 0 25px 0 0;
    }

    .cp_navi .cp_pagenum:hover,
    .cp_navi .cp_pagenum.current {
        border-radius: 0.3em;
    }

    .cp_navi .cp_pagenum.prev:hover,
    .cp_navi .cp_pagenum.next:hover {
        border-radius: 0.3em;
    }
}

@media only screen and (min-width: 120px) and (max-width: 767px) {
    .cp_navi .cp_pagenum {
        display: none;
        border-radius: 0.3em;
    }

    .cp_navi .cp_pagenum:nth-of-type(2) {
        position: relative;
        padding-right: 20px;
    }

    .cp_navi .cp_pagenum:nth-of-type(2)::after {
        font-size: 1.2em;
        position: absolute;
        top: 0;
        left: 25px;
        content: '...';
    }

    .cp_navi .cp_pagenum:nth-child(-n+3),
    .cp_navi .cp_pagenum:nth-last-child(-n+3) {
        display: block;
    }

    .cp_navi .cp_pagenum:nth-last-child(-n+4) {
        padding: 0 5px;
    }

    .cp_navi .cp_pagenum:nth-last-child(-n+4)::after {
        content: none;
    }

    .cp_navi .cp_pagenum:hover,
    .cp_navi .cp_pagenum.current {
        border-radius: 0.3em;
    }

    .cp_navi .cp_pagenum.prev:hover,
    .cp_navi .cp_pagenum.next:hover {
        border-radius: 0.3em;
    }
}

@keyframes plusMove {
    0% {
        bottom: 56px;
    }

    60% {
        bottom: 4px;
    }

    80% {
        bottom: 4px;
    }

    100% {
        bottom: 4px;
    }
}


/* header
----------------------------------------- */

.main-visual {
    position: relative;
}

.main-visual-img {
    border-bottom: 10px solid #AF9263;
}

.main-visual-slide-sp {
    display: none;
}

@media only screen and (max-width: 1200px) {
    .main-visual-slide-sp {
        display: block;
        height: 100vh;
    }

    .main-visual-slide-sp img {
        height: 100vh !important;
    }

    .main-visual-slide {
        display: none;
    }
}

.cms {
    float: left;
    margin: 40px;
    padding: 20px;
    position: absolute;
    top: 200px;
    max-width: 600px;
    z-index: 100;
    -webkit-font-smoothing: antialiased;
    background-color: rgba(255, 255, 255, 0.5)
}

@media only screen and (max-width: 1500px) {
    .cms {
        top: 135px;
    }
}

@media only screen and (max-width: 1200px) {
    .cms {
        top: 200px;
    }
}

.cms h1 {
    font-size: 63px;
    line-height: 70px;
    color: #6d6159;
}

.cms h5 {
    font-size: 28px;
    line-height: 70px;
    padding: 0;
    margin: 0;
    color: #ffffff;
}

@media only screen and (max-width: 480px) {
    .cms {
        clear: both;
        width: 100%;
        padding: 0;
    }

    .cms h1 {
        font-size: 50px;
    }

    .cms h5 {
        font-size: 20px;
    }
}

.main-visual-img img {
    height: auto;
}

.main-copy {
    position: absolute;
    top: 30%;
    bottom: 0;
    left: 0;
    height: auto;
    overflow: hidden;
    z-index: 100;
    margin: auto;
    width: 100%;
}

.main-copy p {
    font-size: 5rem;
    color: #6d6159;
}


/* .main-copy::before {
    position: absolute;
    top: 0;
    left: -75%;
    z-index: 2;
    display: block;
    content: '';
    width: 50%;
    height: 100%;
    background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .3) 100%);
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .3) 100%);
    -webkit-transform: skewX(-25deg);
    transform: skewX(-25deg);
    animation-name: shine;
    animation-duration: 6.0s;
    animation-timing-function: ease;
    animation-iteration-count: infinite;
} */

@keyframes shine {
    0% {
        left: -75%;
    }

    34% {
        left: -75%;
    }

    40% {
        left: 125%;
    }

    100% {
        left: 125%;
    }
}


/* contents
----------------------------------------- */


/* n-parts */


/* .sec-ttl {
        position: relative;
        margin-bottom: 20px;
        padding-bottom: 25px;
    }
     */

.sec-ttl .eng {
    font-weight: 400;
    font-size: 10px;
}

.sec-ttl .jpn {
    font-weight: 500;
    display: block;
    font-size: 20px;
    letter-spacing: 0.2em;
}


/* .sec-ttl::before {
        content: "";
        display: inline-block;
        position: absolute;
        bottom: 4px;
        left: 3px;
        width: 9px;
        height: 1px;
        background-color: #000;
    }
    
    .sec-ttl::after {
        content: "";
        display: inline-block;
        position: absolute;
        bottom: 0;
        left: 7px;
        width: 1px;
        height: 9px;
        background-color: #000;
    } */

.link-box {
    font-weight: 400;
    box-sizing: border-box;
    position: relative;
    display: inline-block;
    width: 70px;
    height: 70px;
    padding: 20px 0 0 8px;
    border: 1px solid #000;
    font-size: 10px;
    line-height: 1.2;
    text-align: left;
}

.link-box::after {
    content: "";
    display: inline-block;
    position: absolute;
    bottom: 12px;
    left: 8px;
    width: 22px;
    height: 4px;
    background: url(../images/arrow01_sp.svg) 0 0 no-repeat;
    background-size: 22px 4px;
}


/* news-sec */

.news-sec {
    margin-bottom: 40px;
}

.news-sec-inner {
    background-color: #f7f5f2;
}


/* .news-list li {
    margin-bottom: 10px;
    padding-bottom: 12px;
    border-bottom: 1px solid #fff;
} */


/* .news-list li:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
} */

.news-list span {
    font-weight: 400;
    display: block;
    font-size: 14px;
}

.news-list a {
    display: block;
    font-size: 14px;
    line-height: 1.6;
}

.news-sec-btn {
    margin-top: -26px;
    padding-right: 5%;
    text-align: right;
}

.news_list img {
    max-width: 120px;
    float: left;
    margin-right: 30px;
}

.news_list {
    margin: 0 0 10px;
    padding-bottom: 10px;
}


/* menu-sec */

.menu-sec {
    margin-bottom: 40px;
}

.menu-sec-btn {
    display: block;
    position: relative;
    width: 80%;
    margin: 0 0 8% 5%;
    color: #fff;
}

@media only screen and (max-width: 780px) {
    .menu-sec-btn {
        margin: 10px auto;
        width: 70%;
    }
}

@media only screen and (max-width: 414px) {
    .menu-sec-btn {
        width: 90%;
    }
}

.menu-sec-btn:last-child {
    margin: 0 0 0 5%;
}

@media only screen and (max-width: 600px) {
    .menu-sec-btn:last-child {
        margin: 0 auto;
    }
}


/* .menu-btn01,
    .menu-btn02,
    .menu-btn03 {
        opacity: 0;
        transition: all 1.0s;
    }
    
    .menu-btn01.fade-in,
    .menu-btn02.fade-in,
    .menu-btn03.fade-in {
        opacity: 1;
    }
     */

.menu-sec-btn::after {
    content: "";
    display: inline-block;
    position: absolute;
    bottom: 25px;
    right: 25px;
    width: 35px;
    height: 6.5px;
    background-size: 35px 6.4px;
    z-index: 1000;
}

.menu-sec-btn:hover {
    color: #fff;
}

.menu-sec-btn.second {
    margin-left: 15%;
}

@media only screen and (max-width: 414px) {
    .menu-sec-btn.second {
        margin: 0 auto;
    }
}

.menu-sec-btn-inner {
    box-sizing: border-box;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background-color: rgba(93, 60, 22, 0.56);
    text-align: center;
    z-index: 100;
}

.menu-sec-btn-inner-text {
    margin-top: 15%;
}

.menu-sec-btn-ttl {
    margin-bottom: 30px;
    line-height: 1.7;
    letter-spacing: 0.16em;
}

.menu-sec-btn-ttl .eng {
    font-weight: 400;
    display: inline-block;
    margin-bottom: 5px;
    font-size: 12px;
}

.menu-sec-btn-ttl .jpn {
    font-weight: 500;
    font-size: 7vw;
    text-align: center;
}

.menu-sec-btn-ttl .jpn span {
    display: block;
    font-size: 3.8vw;
}

.menu-icon01 {
    width: 17.6%;
    margin: 0 auto;
}

.menu-icon02 {
    width: 16.5%;
    margin: 0 auto;
}

.menu-icon03 {
    width: 18.6%;
    margin: 0 auto;
}

#menu-text {
    font-size: 1rem;
    text-align: center;
    color: #fff;
}


/* director-sec */

.director-sec {
    margin-bottom: 80px;
    padding: 0 5%;
}

.director-text {
    margin-bottom: 20px;
    font-size: 14px;
}

.director-sec-right {
    position: relative;
}

.director-sec-img {
    padding-top: 20px;
    opacity: 0;
    transition: 1.0s;
}

.director-sec-img.fade-in {
    padding-top: 0;
    opacity: 1;
}

.director-sec .link-box {
    position: absolute;
    bottom: -43px;
    left: 5%;
}


/* blog-sec */

.blog-sec {
    margin-bottom: 40px;
    padding: 7% 5%;
    background-color: #f7f5f2;
}

.blog-sec-inner {
    position: relative;
    padding: 7% 6%;
    background-color: #fff;
}

.blog-list {}

.blog-list li {
    margin-bottom: 10px;
    padding-bottom: 12px;
    border-bottom: 1px dashed #dcdcdc;
}

.blog-list li:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.blog-list span {
    font-weight: 400;
    display: block;
    font-size: 14px;
}

.blog-list a {
    display: block;
    font-size: 14px;
    line-height: 1.6;
}

.blog-sec .link-box {
    position: absolute;
    top: 30px;
    right: 20px;
}


/* tablet 600px - 799px */

@media only screen and (min-width: 600px) {
    .menu-sec {
        display: flex;
        margin-bottom: 80px;
        padding: 0;
    }

    .menu-sec-btn {
        display: block;
        position: relative;
        width: 33.3%;
        margin: 0 0 0 0;
        color: #fff;
    }

    .menu-sec-btn:last-child {
        margin: 0;
    }

    .menu-sec-btn::after {
        content: "";
        display: inline-block;
        position: absolute;
        bottom: 15px;
        right: 15px;
        width: 35px;
        height: 6.5px;
        background: url(../images/arrow02_sp.svg) 0 0 no-repeat;
        background-size: 35px 6.4px;
        z-index: 1000;
    }

    .menu-sec-btn:hover {
        color: #fff;
    }

    .menu-sec-btn.second {
        width: 33.4%;
        margin-left: 0;
    }

    .menu-sec-btn-inner {
        box-sizing: border-box;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        background-color: rgba(93, 60, 22, 0.56);
        text-align: center;
        z-index: 100;
        transition: all .2s;
    }

    .menu-sec-btn-inner-text {
        margin-top: 14%;
    }

    .menu-sec-btn-ttl {
        margin-bottom: 25px;
        line-height: 1.7;
        letter-spacing: 0.16em;
    }

    .menu-sec-btn-ttl .eng {
        font-weight: 400;
        display: inline-block;
        margin-bottom: 5px;
        font-size: 1.2vw;
    }

    .menu-sec-btn-ttl .jpn {
        font-weight: 500;
        font-size: 3.6vw;
    }

    .menu-sec-btn-ttl .jpn span {
        display: block;
        font-size: 1.6vw;
    }

    .menu-icon01 {
        width: 17.6%;
        margin: 0 auto;
    }

    .menu-icon02 {
        width: 16.5%;
        margin: 0 auto;
    }

    .menu-icon03 {
        width: 18.6%;
        margin: 0 auto;
    }

    /* director-sec */
    .director-sec {
        display: flex;
        margin-bottom: 80px;
        padding: 0 0 0 5%;
    }

    .director-text {
        margin-bottom: 0;
        font-size: 14px;
    }

    .director-sec-left {
        box-sizing: border-box;
        width: 45%;
        margin-right: 10%;
        padding: 30px 0 0 20px;
    }

    .director-sec-right {
        width: 45%;
        position: relative;
    }

    .director-sec .link-box {
        position: absolute;
        bottom: -25px;
        left: 10%;
    }
}


/* tablet end */


/* PC 800px - */

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

    /* header
----------------------------------------- */
    .header-inner {
        position: relative;
    }

    .header-address {
        box-sizing: border-box;
        width: 80px;
        padding: 50px 27px 0 0;
        font-size: 20px;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
    }

    .header-address span {
        display: inline-block;
    }

    .main-visual {
        position: relative;
        padding: 80px 80px 0 0;
    }

    .main-visual-img {
        border-bottom: 10px solid #AF9263;
    }

    /* contents
----------------------------------------- */
    /* n-parts */
    .sec-ttl {
        position: relative;
        margin-bottom: 20px;
        padding-bottom: 38px;
    }

    .sec-ttl .eng {
        display: inline-block;
        font-weight: 400;
        margin-bottom: 12px;
        font-size: 12px;
    }

    .sec-ttl .jpn {
        font-weight: 500;
        display: block;
        font-size: 26px;
        letter-spacing: 0.2em;
    }

    /* news-sec */
    .news-sec {
        padding: 0 6%
    }

    .news-sec-inner {
        display: flex;
        padding: 70px;
        background-color: #f7f5f2;
    }

    .news-sec-ttl {
        width: 30%;
    }

    .news-list {
        width: 100%;
        padding-top: 20px;
    }

    .news-list li {
        display: flex;
        margin-bottom: 20px;
        padding-bottom: 18px;
        border-bottom: 1px solid #fff;
    }

    .news-list li:last-child {
        margin-bottom: 0;
        padding-bottom: 0;
        border-bottom: none;
    }

    .news-list span {
        font-weight: 400;
        display: block;
        width: 100%;
        font-size: 16px;
        margin: 10px 0;
    }

    .news-list a {
        display: block;
        width: 78%;
        font-size: 14px;
        line-height: 1.6;
        transition: all .2s;
    }

    .news-list a:hover {
        color: #999;
    }

    .news-sec-btn {
        margin-top: -90px;
        padding-right: 12%;
        text-align: right;
    }

    /* menu-sec */
    .menu-sec {
        display: flex;
        margin-bottom: 160px;
        padding: 0 6%;
    }

    .menu-sec-btn {
        display: block;
        position: relative;
        width: 32.2%;
        margin: 0 1.7% 0 0;
        color: #fff;
        transition: all .2s;
    }

    .menu-sec-btn:last-child {
        margin: 0;
    }

    .menu-sec-btn::after {
        content: "";
        display: inline-block;
        position: absolute;
        bottom: 45px;
        right: 50px;
        width: 48px;
        height: 9px;
        background: url(../images/arrow02_pc.svg) 0 0 no-repeat;
        background-size: 48px 9px;
        z-index: 1000;
        transition: all .3s;
    }

    .menu-sec-btn:hover::after {
        position: absolute;
        bottom: 45px;
        right: 30px;
    }

    .menu-sec-btn:hover {
        color: #fff;
    }

    .menu-sec-btn.second {
        width: 32.2%;
        margin-left: 0;
    }

    .menu-sec-btn-inner {
        box-sizing: border-box;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        background-color: rgba(93, 60, 22, 0.3);
        text-align: center;
        z-index: 100;
        transition: all .3s;
    }

    .menu-sec-btn:hover .menu-sec-btn-inner {
        background-color: rgba(93, 60, 22, 0.8);
    }

    .menu-sec-btn-inner-text {
        margin-top: 30%;
    }

    .menu-sec-btn-ttl {
        margin-bottom: 30px;
        line-height: 1.7;
        letter-spacing: 0.16em;
    }

    .menu-sec-btn-ttl .eng {
        font-weight: 400;
        display: inline-block;
        margin-bottom: 10px;
        font-size: 0.9vw;
    }

    .menu-sec-btn-ttl .jpn {
        font-weight: 500;
        font-size: 2.6vw;
        letter-spacing: 0.18em;
        text-align: center;
    }

    .menu-sec-btn-ttl .jpn span {
        display: block;
        font-size: 1.5vw;
        letter-spacing: 0.15em;
    }

    .menu-icon01 {
        width: 68px;
        height: 77px;
        margin: 0 auto;
    }

    .menu-icon02 {
        width: 64px;
        height: 64px;
        margin: 0 auto;
    }

    .menu-icon03 {
        width: 73px;
        height: 78px;
        margin: 0 auto;
    }

    /* director-sec */
    .director-sec {
        display: flex;
        max-width: 1000px;
        margin: 0 auto 220px;
        padding: 0 3%;
    }

    .director-sec .sec-ttl {
        margin-bottom: 60px;
    }

    .director-text {
        margin-bottom: 0;
        font-size: 14px;
        line-height: 2.0;
    }

    .director-sec-left {
        box-sizing: border-box;
        width: 26%;
        margin-right: 10%;
        padding: 75px 0 0 0;
    }

    .director-sec-right {
        width: 64%;
        position: relative;
    }

    .director-sec-img {
        border-right: 10px solid #ae9373;
    }

    .director-sec .link-box {
        position: absolute;
        bottom: 60px;
        left: -90px;
    }

    /* blog-sec */
    .blog-sec {
        margin-bottom: 160px;
        padding: 0 6% 8%;
        background-color: transparent;
        background: url(../../images/blog-bg.jpg) 0 0 no-repeat;
        background-size: cover;
    }

    .blog-sec-inner {
        display: flex;
        padding: 0 26% 8% 9%;
        background-color: #fff;
    }

    .blog-sec-ttl {
        width: 32%;
        height: auto;
    }

    .blog-list {
        width: 68%;
        padding-top: 20px;
    }

    .blog-list li {
        margin-bottom: 18px;
        padding-bottom: 20px;
        border-bottom: 1px dashed #dcdcdc;
    }

    .blog-list li:last-child {
        margin-bottom: 0;
        padding-bottom: 0;
        border-bottom: none;
    }

    .blog-list span {
        font-weight: 400;
        display: block;
        margin-bottom: 5px;
        font-size: 15px;
    }

    .blog-list a {
        display: block;
        font-size: 14px;
        line-height: 1.6;
        transition: all .2s;
    }

    .blog-list a:hover {
        color: #999;
    }

    .blog-sec .link-box {
        position: absolute;
        top: 0;
        right: 9%;
    }
}

@media only screen and (max-width: 800px) {
    .main-visual {
        position: relative;
        padding: 60px 0 0 0;
        background-color: #fff;
    }

    .header-logo {
        width: 100%;
        text-align: center;
    }

    .header-logo img {
        height: 60px;
        object-fit: contain;
    }
}

a:focus {
    outline: none;
}

.pc {
    display: none !important;
}

.sp {
    display: block !important;
}

input:focus,
select:focus,
textarea:focus {
    outline: none;
}

img {
    width: 100%;
    height: auto;
    -webkit-backface-visibility: hidden;
}


/* common parts
----------------------------------------- */


/* loading */

#contents-wrap {
    opacity: 0;
    transition: all 1.4s;
}

#contents-wrap.fade-in {
    opacity: 1;
}

#contents {
    max-width: 1200px;
    margin: 70px auto;
}

.top_end {
    position: relative;
}

.loading-img {
    position: fixed;
    top: 50%;
    left: 50%;
    width: 60px;
    height: 60px;
    margin-top: -35px;
    margin-left: -30px;
    text-align: center;
    color: #fff;
    z-index: 2;
    text-align: center;
}

.loading-img img {
    width: 100%;
    height: auto;
}


/* slide-menu-btn */

.slide-menu-btn {
    position: absolute;
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
    background-color: #ae9373;
    z-index: 10000;
}

.nav_menu_sp {
    box-sizing: border-box;
    display: none;
    width: 100%;
    position: absolute;
    top: 60px;
    left: 0;
    padding-top: 35px;

    background-color: rgba(0, 0, 0, 0.85);
    z-index: 9000;
    text-align: center;
}

.nav_menu_sp .gnav {
    margin-bottom: 35px;
    padding-top: 50%;
}

.nav_menu_sp .gnav a {
    font-weight: 500;
    display: inline-block;
    margin-bottom: 33px;
    font-size: 16px;
    color: #FFF;
    line-height: 1.4;
    letter-spacing: 0.3em;
}

.nav_menu_sp .gnav li:last-child a {
    margin-bottom: 0;
}

.slide-menu-tel {
    font-weight: 400;
    font-size: 25px;
}

.slide-menu-tel span {
    font-size: 20px;
}


/* position-active */

.nav_menu_sp .gnav01 a,
.nav_menu_sp .gnav02 a,
.nav_menu_sp .gnav03 a,
.nav_menu_sp .gnav04 a,
.nav_menu_sp .gnav05 a,
.nav_menu_sp .gnav06 a {
    color: #ae9373;
}

.sp_menu .menuButton {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 60px;
    height: 60px;
    box-shadow: 0 0 10px #fff, 0 0 10px #fff, 0 0 20px #fff, 0 0 40px #ff22f7, 0 0 20px #ff22f7, 0 0 40px #ff22f7, 0 0 60px #ff22f7;
    z-index: 99;
    background-color: #000;
    color: #fff;
    border-radius: 15px;
}


.sp_menu .menuButton:hover>span {
    /* background-color: #fc6060; */
    color: #000;
    background: #fff;
}

.sp_menu .menuButton.active span {
    background-color: #fc6060;
    transition: .4s;
}

.nav_menu_sp {
    display: none;
}

@media only screen and (max-width: 800px) {
    .nav_menu_sp {
        position: absolute;
        top: -150px;
        left: 0;
        align-items: center;
        width: 100vw;
        z-index: -1;
        display: block;
        transition: .4s;
        opacity: 0;
        height: 100vh;
    }
}

.nav_menu_sp li a {
    display: block;
    text-align: center;
    font-size: 1.5em;
    transition: .4s;
}

.nav_menu_sp li a:hover {
    opacity: .7;
}

.nav_menu_sp.open {
    opacity: 1;
    top: 60px;
    z-index: 98;
}

@media only screen and (max-width: 800px) {
    .nav_menu_sp.open {
        top: 0;
    }
}

#pc_menu {
    display: block;
    width: 60%;
}

@media only screen and (max-width: 800px) {
    #pc_menu {
        display: none;
    }
}

.sp_menu {
    display: none;
}

@media only screen and (max-width: 800px) {
    .sp_menu {
        display: block;
    }
}

.menu-trigger,
.menu-trigger span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
    cursor: pointer;
}

.menu-trigger {
    position: relative;
    width: 60px;
    height: 60px;
    color: #000;
    border-radius: 4px;
    z-index: 7;
}

.menu-trigger span {
    position: absolute;
    background: #fff;
    width: 30px;
    height: 2px;
    left: 0;
    right: 0;
    margin: auto;
}

.menu-trigger span:nth-of-type(1) {
    top: 25px;
}

.menu-trigger span:nth-of-type(2) {
    top: 9px;
    bottom: 0;
}

.menu-trigger span:nth-of-type(3) {
    bottom: 15px;
}

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

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

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

.access-sec {
    margin-bottom: 20px;
    padding: 0 5%;
}

.access-sec-inner {
    padding-bottom: 5%;
    background-color: #f7f5f2;
}

.access-sec-left {
    margin-bottom: 20px;
}

.access-sec-right {}

.sec-sub-ttl {
    position: relative;
    margin-bottom: 20px;
    padding-left: 70px;
    line-height: 1.0;
}

.sec-sub-ttl img {
    max-width: 200px;
    object-fit: contain;
}

@media only screen and (max-width: 530px) {
    .sec-sub-ttl img {
        max-width: 100px;
    }
}


/* .access-sec .sec-sub-ttl::before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 60px;
        height: 60px;
        background: url(../images/icon-access.svg) 15px 14px no-repeat;
        background-size: 30px 35px;
        background-color: #333333;
    } */

.sec-sub-ttl .eng {
    font-weight: 400;
    display: block;
    margin-bottom: 8px;
    padding: 18px 0 0 10px;
    font-size: 10px;
}

.access-sec-text {
    padding: 0 5%;
}

.access-sec-text p {
    margin-bottom: 10px;
}

.access-sec-text p:last-child {
    margin-bottom: 0;
}

.gmap {
    padding: 0 5%;
}


/* information-sec */

.information-sec {
    padding: 0 5%;
}

.information-sec-inner {
    padding-bottom: 5%;
    background-color: #f7f5f2;
}

.information-sec .sec-sub-ttl::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    height: 60px;
    background-size: 37px 33px;
    background-color: #333333;
}

.information-sec-tel {
    font-weight: 400;
    margin-bottom: 20px;
    padding: 0 5%;
}

.information-sec-tel .tel-num {
    font-size: 25px;
}

.information-sec-tel .tel-num span {
    font-size: 15px;
}

.information-sec-tel .fax-num {
    font-size: 14px;
}

.page-top {
    font-weight: 400;
    position: relative;
    display: block;
    width: 90%;
    margin: 0 auto;
    padding: 7px 0 12px;
    background-color: #222;
    font-size: 10px;
    text-align: center;
    color: #fff;
    z-index: 100;
}

.page-top:hover {
    color: #fff;
}

.page-top img {
    width: 20px;
    height: 9px;
}

.page-top-text {
    margin-top: 5px;
}

.grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.footer {
    padding: 2rem;
    font-size: 15px;
    padding: 2rem;
    font-size: 15px;
    color: #fff;
    background: #000;
}

.footer__navi-heading {
    font-weight: 600;
}

.footer__logo {
    display: inline-block;
    margin-bottom: 2rem;
}

.footer__logo img {
    max-width: 280px;
}

.footer__navi li {
    margin-bottom: 0.75rem;
}

.footer__social a {
    display: inline-block;
    width: 35px;
    opacity: 0.7;
}

.footer__social a:not(:last-child) {
    margin-right: 25px;
}

@media (min-width: 768px) {
    .md-flex {
        display: flex;
    }

    .md-justify-between {
        justify-content: space-between;
    }

    .grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media only screen and (min-width: 1021px) {
    .footer-left {
        float: left;
        width: 30%;
    }
}

@media only screen and (min-width: 760px) {
    .footer-left {
        float: left;
        width: 30%;
    }
}

@media only screen and (min-width: 760px) {
    .footer-logo {
        position: relative;
        display: inline-block;
        width: 115px;
        height: auto;
        margin-bottom: 25px;
    }
}

.footer__list {
    padding: 10px 0;
}

.footer-logo {
    display: inline-block;
    width: 80px;
    height: auto;
    margin-bottom: 20px;
}

.footer-left img {
    margin-left: 30px;
}

@media only screen and (min-width: 760px) {
    #footer {
        position: relative;
        margin-top: 230px;
    }
}

@media only screen and (max-width: 780px) {
    .footer-left img {
        margin-left: 0;
    }
}

#footer {
    position: relative;
    margin-top: 100px;
}

@media only screen and (max-width: 600px) {
    #footer {
        margin-top: 10px;
    }
}

@media only screen and (min-width: 1021px) {
    .footer-right {
        float: right;
        width: 70%;
    }
}

@media only screen and (min-width: 760px) {
    .footer-right {
        float: right;
        width: 70%;
    }
}

@media only screen and (min-width: 1021px) {
    .footer-nav {
        margin: 60px 0 52px 0;
        text-align: right;
    }
}

@media only screen and (min-width: 760px) {
    .footer-nav {
        margin: 60px 0 52px 0;
        text-align: right;
    }
}

.footer-nav {
    margin-bottom: 42px;
}

@media only screen and (min-width: 1021px) {
    .footer-nav li {
        display: inline-block;
        margin: 0 7.5% 0 0;
    }
}

@media only screen and (min-width: 760px) {
    .footer-nav li {
        display: inline-block;
        margin: 0 5% 0 0;
    }
}

@media only screen and (min-width: 760px) {
    .footer-sub-nav {
        margin-bottom: 0;
        text-align: right;
    }
}

.footer-sub-nav {
    margin-bottom: 50px;
}

.footer-nav li {
    margin-bottom: 15px;
}

@media only screen and (min-width: 1021px) {
    .footer-address {
        margin-bottom: 50px;
        font-size: 13px;
    }
}

@media only screen and (min-width: 760px) {
    .footer-address {
        margin-bottom: 50px;
        font-size: 12px;
    }
}

.footer-address {
    margin-bottom: 25px;
    font-size: 10px;
}

@media only screen and (min-width: 760px) {
    .copyright {
        font-size: 11px;
    }
}

.copyright {
    font-size: 10px;
}

.footer-nav {
    padding-top: 20px;
}

.footer-nav li {
    margin-bottom: 13px;
}

.footer-nav a {
    color: #fff;
    font-size: 11px;
}

.copyright {
    font-weight: 400;
    font-size: 9px;
    letter-spacing: 0;
}


/* tablet 600px - 799px */

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

    /* common parts
----------------------------------------- */
    .loading-img {
        position: fixed;
        top: 50%;
        left: 50%;
        width: 70px;
        height: 70px;
        margin-top: -70px;
        margin-left: -35px;
        text-align: center;
        color: #fff;
        z-index: 2;
        text-align: center;
    }

    .loading-img img {
        width: 100%;
        height: auto;
    }

    .page-ttl-under {
        font-weight: 500;
        position: absolute;
        top: 100px;
        left: 6%;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        font-size: 2.6vw;
        letter-spacing: 0.18em;
    }

    .page-lead-box {
        font-weight: 500;
        padding: 14% 8% 10% 17%;
        background-color: #f7f5f2;
        font-size: 1.8vw;
        line-height: 1.8;
        color: #ae9373;
    }

    .page-ttl-box {
        font-weight: 400;
        padding: 13% 8% 8% 17%;
        background-color: #f7f5f2;
        font-size: 2.2vw;
        line-height: 1.8;
        color: #ae9373;
    }

    .page-sub-ttl {
        margin-bottom: 40px;
        text-align: center;
    }

    .first .page-sub-ttl {
        margin-top: -1.5%;
    }

    .page-sub-ttl .jpn {
        font-weight: 500;
        display: block;
        margin-bottom: 7px;
        font-size: 2.6vw;
        letter-spacing: 0.2em;
        line-height: 1.0;
    }

    .page-sub-ttl .eng {
        font-weight: 400;
        font-size: 1.2vw;
        line-height: 1.0;
    }

    /* access-sec */
    .gmap {
        padding: 0 5%;
    }

    .gmap iframe {
        width: 100%;
        height: 340px;
    }

    /* information-sec */
    .opening-time-tbl th {
        padding: 8px 2px;
        border: 1px solid #dcdcdc;
        background-color: #ae9373;
        color: #fff;
        font-size: 12px;
        text-align: center;
    }

    .opening-time-tbl td {
        padding: 8px 2px;
        border: 1px solid #dcdcdc;
        vertical-align: middle;
        background-color: #fff;
        color: #000;
        font-size: 12px;
        text-align: center;
    }

    .opening-tbl-circle {
        width: 10px;
        height: 10px;
        vertical-align: middle;
    }

    .opening-tbl-slash {
        width: 11px;
        width: 11px;
        vertical-align: middle;
    }

    .opening-tbl-triangle {
        width: 10px;
        height: 10px;
        vertical-align: middle;
    }

    .opening-time-text {
        padding: 0 5%;
        font-size: 12px;
    }

    .opening-time-text img {
        width: 10px;
        height: 10px;
        vertical-align: middle;
    }

    .opening-time-text span {
        display: inline-block;
        padding-left: 5px;
    }

    /* footer
----------------------------------------- */
    #footer {}
}

.neon {
    padding: 10px 0;
}

.neon a {
    color: white;
    font-size: 5vw;
    letter-spacing: 2px;
    transition: 1s;

}

.neon a:hover {
    text-shadow:
        0 0 7px #fff,
        0 0 10px #fff,
        0 0 20px #fff,
        0 0 40px #b2ebf5,
        0 0 80px #b2ebf5,
        0 0 90px #b2ebf5
}

.footer__head {
    text-align: center;
}

/* tablet end */


/* PC 800px - */

@media only screen and (min-width: 800px) {
    .pc {
        display: block !important;
    }

    .sp {
        display: none !important;
    }
}

.header-inner {
    position: relative;
}

.header-inner::after {
    content: "";
    display: block;
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    height: 80px;
    background-color: #f7f5f2;
    z-index: -10;
}

.header-logo {
    box-sizing: border-box;
    position: absolute;
    top: 5px;
    left: 50%;
    width: 300px;
    /* height: 36px; */
    min-height: auto;
    padding: 0;
    z-index: 100;
    margin-left: -140px;
}

@media only screen and (max-width: 530px) {
    .header-logo {
        padding-right: 60px;
    }
}

.header-logo a {
    display: inline-block;
    transition: all .2s;
}

.header-logo a:hover {
    opacity: 0.6;
}

.header-tel_pc {
    font-weight: 400;
    position: absolute;
    top: 0;
    right: 80px;
    width: auto;
    height: 80px;
    padding: 0 30px 0 0;
    z-index: 100;
    font-size: 22px;
}

.header-tel_pc p {
    display: flex;
    align-items: center;
    height: 80px;
    line-height: 1.0;
    font-size: 3rem;
    color: #fff;
}

@media only screen and (max-width: 1000px) {
    .header-tel_pc p {
        display: none;
    }
}

.header-tel_pc span {
    position: relative;
    font-size: 2.5rem;
    line-height: 1.0;
    padding: 0 10px;
}

.header-nav-pc {
    margin-left: 80px;
    padding: 120px 0 50px;
    color: #fff;
    font-size: 1.8rem;
}

.cp_snslink03 {
    position: fixed;
    top: 180px;
    right: 0;
    transform: translateY(-50%);
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0 0 0 5px;
    z-index: 999;
}

@media only screen and (max-width: 800px) {
    .cp_snslink03 {
        top: 120px
    }
}


/*それぞれのSNS iconの設定*/

@media only screen and (min-width: 800px) {
    .cp_snslink03 .cp_link {
        position: relative;
        right: -70px;
        padding: 10px;
        background: #fff;
        height: 60px;
        border-right: none;
        cursor: pointer;
        transition: right 0.6s ease-in-out;
    }
}

@media only screen and (max-width: 800px) {
    .cp_snslink03 .cp_link {
        position: relative;
        right: 0;
        padding: 0;
        background: #fff;
        height: 60px;
        width: 60px;
    }
}

.cp_snslink03 .cp_link .nav-label {
    padding: 10px 0 0 60px;
}

@media only screen and (max-width: 800px) {
    .cp_snslink03 .cp_link .nav-label {
        display: none;
    }
}

.cp_snslink03 .cp_link.line::before,
.cp_snslink03 .cp_link.instagram::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 5px;
    transform: translateY(-50%);
    background-size: contain;
    background-repeat: no-repeat;
    width: 50px;
    height: 50px;
}


/*line*/

.cp_snslink03 .cp_link.line::before {
    background-image: url(img/line.png);
}


/*instagram*/

.cp_snslink03 .cp_link.instagram::before {
    background-image: url(img/ig.png);
    height: 50px;
}

@media only screen and (min-width: 800px) {
    .cp_snslink03 .cp_link:hover {
        right: 0;
        background: #efeff0;
        box-shadow: 0px 0px 0px 3px #efeff0;
    }
}

.cp_snslink03 .cp_link a {
    text-decoration: none;
    color: #222;
}

@media only screen and (max-width: 800px) {
    .cp_snslink03 .cp_link a {
        text-decoration: none;
        color: #222;
        height: 60px;
        display: block;
    }
}

.cp_snslink03 .cp_link:hover a {
    color: #222;
}

#top .header-nav-pc li.gnav01,
#top .header-nav-pc li.gnav02,
#top .header-nav-pc li.gnav03,
#top .header-nav-pc li.gnav04,
#top .header-nav-pc li.gnav05,
#top .header-nav-pc li.gnav06 {
    margin-top: 20px;
    opacity: 0;
    transition: all 1.0s;
}

#top .header-nav-pc li.gnav01.fade-in,
#top .header-nav-pc li.gnav02.fade-in,
#top .header-nav-pc li.gnav03.fade-in,
#top .header-nav-pc li.gnav04.fade-in,
#top .header-nav-pc li.gnav05.fade-in,
#top .header-nav-pc li.gnav06.fade-in {
    margin-top: 0;
    opacity: 1;
}

.header-nav-pc a {
    font-weight: 500;
    transition: all .2s;
}

.header-nav-pc a:hover {
    color: #ae9373;
}


/* position-active */

#about .header-nav-pc .gnav01 a,
#treatment .header-nav-pc .gnav02 a,
#expense .header-nav-pc .gnav03 a,
#blog .header-nav-pc .gnav04 a,
#access .header-nav-pc .gnav05 a,
#recruit .header-nav-pc .gnav06 a {
    color: #ae9373;
}


/* contents
----------------------------------------- */

.page-ttl-under {
    font-weight: 500;
    position: absolute;
    top: 110px;
    left: 50%;
    height: 10em;
    margin-left: -0.5em;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 24px;
    letter-spacing: 0.18em;
    line-height: 1.0;
}

.page-lead-box {
    font-weight: 500;
    padding: 70px 0 110px 0;
    background-color: #f7f5f2;
    font-size: 20px;
    letter-spacing: 0.2em;
    line-height: 2.0;
    text-align: center;
    color: #ae9373;
}

.page-ttl-box {
    font-weight: 400;
    height: 100px;
    padding: 0;
    background-color: #f7f5f2;
    font-size: 20px;
    line-height: 100px;
    letter-spacing: 0.2em;
    color: #ae9373;
    text-align: center;
}

.page-sub-ttl {
    margin-bottom: 95px;
    text-align: center;
}

.first .page-sub-ttl {
    margin-top: -14px;
}

.page-sub-ttl .jpn {
    font-weight: 500;
    display: block;
    margin-bottom: 20px;
    font-size: 24px;
    letter-spacing: 0.2em;
    line-height: 1.0;
}

.page-sub-ttl .eng {
    font-weight: 400;
    font-size: 12px;
    line-height: 1.0;
}


/* access-sec */

.access-sec {
    margin-bottom: 40px;
    padding: 6%;
}

@media only screen and (max-width: 530px) {
    .access-sec {
        margin-bottom: 20px;
        padding: 3%;
    }
}

.access-sec-inner {
    background-color: #f7f5f2;
    padding: 0;
}

.access-sec-inner-in {
    display: flex;
    margin: 0 auto;
    padding: 70px;
}

@media only screen and (max-width: 800px) {
    .access-sec-inner-in {
        display: block;
        padding: 0 20px 10px;
    }
}

.access-sec-left {
    width: 30%;
    margin: 0 10% 0 0;
}

.access-sec-right {
    width: 60%;
    padding: 0;
}

.sec-sub-ttl {
    position: relative;
    margin-bottom: 45px;
    padding: 0;
    line-height: 1.0;
}

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

    .access-sec-left,
    .access-sec-right {
        width: 100%;
        margin: 30px auto;
    }
}

@media only screen and (max-width: 600px) {
    .sec-sub-ttl {
        margin-bottom: 30px;
    }
}

@media only screen and (max-width: 530px) {
    .sec-sub-ttl {
        margin-bottom: 15px;
    }
}


/* .access-sec .sec-sub-ttl::before {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            left: 0;
            width: 80px;
            height: 80px;
            background: url(../images/icon-access.svg) 21px 18px no-repeat;
            background-size: 40px 46px;
            background-color: #333333;
        } */

.sec-sub-ttl .eng {
    font-weight: 400;
    display: block;
    margin-bottom: 25px;
    padding: 18px 0 0 5px;
    font-size: 20px;
}

.sec-sub-ttl .jpn {
    font-weight: 500;
    display: block;
    padding-left: 0;
    font-size: 26px;
    letter-spacing: 0.2em;
}

@media only screen and (max-width: 414px) {
    .sec-sub-ttl .jpn {
        padding-left: 8px;
        font-size: 20px;
    }
}

.access-sec-text {
    padding: 0;
}

.access-sec-text p {
    margin-bottom: 20px;
    font-size: 1.6rem;
}

.access-sec-text p:last-child {
    margin-bottom: 0;
}

.gmap {
    padding: 0;
}

.gmap iframe {
    width: 100%;
    max-height: 300px;
}


/* information-sec */

.information-sec {
    padding: 0 6%;
}

.information-sec-inner {
    background-color: #f7f5f2;
    padding: 0;
}

.information-sec-inner-in {
    display: flex;
    max-width: 870px;
    margin: 0 auto;
    padding: 0 2% 60px;
}

.information-sec-left {
    width: 30%;
    margin: 0 10% 0 0;
}

.information-sec-right {
    width: 60%;
    padding: 100px 0 0;
}

.information-sec .sec-sub-ttl::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 80px;
    height: 80px;
    background-size: 50px 44px;
    background-color: #333333;
}

.information-sec-tel {
    font-weight: 400;
    margin-bottom: 20px;
    padding: 0;
}

.information-sec-tel .tel-num {
    margin-bottom: 12px;
    font-size: 30px;
    line-height: 1.3;
}

.information-sec-tel .tel-num span {
    display: block;
    font-size: 20px;
}

.information-sec-tel .fax-num {
    font-size: 14px;
}

.opening-time-tbl-wrapper {
    margin-bottom: 15px;
    padding: 0;
}

.opening-time-tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    line-height: 1.6;
}

.opening-time-tbl th {
    padding: 8px 2px;
    border: 1px solid #dcdcdc;
    background-color: #ae9373;
    color: #fff;
    font-size: 14px;
    text-align: center;
}

.opening-time-tbl td {
    padding: 8px 2px;
    border: 1px solid #dcdcdc;
    vertical-align: middle;
    background-color: #fff;
    color: #000;
    font-size: 12px;
    text-align: center;
}

.opening-time-tbl .th-hour-ttl {
    width: 28%;
}

.opening-time-tbl .th-week01 {
    width: 9%;
}

.opening-time-tbl .th-week02 {
    width: 9%;
}

.opening-time-tbl .th-week03 {
    width: 9%;
}

.opening-time-tbl .th-week04 {
    width: 9%;
}

.opening-time-tbl .th-week05 {
    width: 9%;
}

.opening-time-tbl .th-week06 {
    width: 9%;
}

.opening-time-tbl .th-week07 {
    width: 13%;
}

.opening-tbl-circle {
    width: 14px;
    height: 14px;
    vertical-align: middle;
}

.opening-tbl-slash {
    width: 15px;
    width: 15px;
    vertical-align: middle;
}

.opening-tbl-triangle {
    width: 14px;
    height: 14px;
    vertical-align: middle;
}

.opening-time-text {
    padding: 0;
    font-size: 14px;
}

.opening-time-text img {
    width: 10px;
    height: 10px;
    padding-bottom: 3px;
    vertical-align: middle;
}

.opening-time-text span {
    display: inline-block;
    padding-left: 5px;
}

.page-top {
    font-weight: 400;
    position: relative;
    display: block;
    width: 90%;
    margin: 0 auto;
    padding: 20px 0 22px;
    background-color: #222;
    font-size: 14px;
    text-align: center;
    color: #fff;
    z-index: 100;
    transition: all .3s;
}

.page-top:hover {
    color: #fff;
    background-color: #000;
}

.page-top img {
    width: 34px;
    height: 16px;
}

.page-top-text {
    margin-top: 8px;
}

.footer-info01 {
    width: 38%;
}

.footer-info01-in {
    border-right: 1px solid #fff;
}

.footer-info02 {
    box-sizing: border-box;
    display: flex !important;
    width: 45%;
    padding: 20px 0 0 70px;
}

.footer-open-day {
    width: 40%;
}

.footer-open-hour {
    width: 60%;
}

.footer-info03 {
    width: 17%;
    text-align: right;
}

.footer-clinic-name {
    margin-bottom: 10px;
    font-size: 16px;
}

.footer-address {
    font-size: 14px;
}

.footer-recruit-btn {
    font-weight: 500;
    display: inline-block;
    width: 140px;
    height: 140px;
    border: 1px solid #fff;
    font-size: 14px;
    color: #fff;
    line-height: 140px;
    text-align: center;
    transition: all .2s;
}

.footer-recruit-btn:hover {
    border: 1px solid #fff;
    background-color: #fff;
    color: #000;
}

.footer-inner02 {
    padding: 40px 0 20px;
    background-color: #393939;
    text-align: center;
}

.footer-nav {
    margin-bottom: 65px;
    padding: 0 10% 0 0;
}

@media only screen and (max-width: 780px) {
    .footer-nav {
        padding: 0;
        margin: 20px auto;
        text-align: center;
    }
}

.footer-nav li {
    display: inline-block;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    vertical-align: top;
    margin-right: 5rem;
    text-align: left;
}

@media only screen and (max-width: 414px) {
    .footer-nav li {
        margin-right: 2rem;
    }
}

.footer-nav li:last-child {
    margin: 0;
}

.footer-nav li:last-child:after {
    content: none;
    padding-left: 0;
}

.footer-nav a {
    color: #fff;
    font-size: 13px;
    transition: all .2s;
}

.footer-nav a:hover {
    color: #999;
}

.copyright {
    font-weight: 400;
    display: block;
    padding-right: 30px;
    font-size: 16px;
    letter-spacing: 0;
    text-align: right;
}


/* PC 1000px - */

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

    /* header
----------------------------------------- */
    .header-nav-pc li {
        display: inline-block;
        padding-right: 40px;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        vertical-align: top;
        font-size: 18px;
    }

    .header-nav-pc li span {
        font-size: 12px;
        letter-spacing: 3.5px;
        padding: 3px;
    }
}


/* 新着情報 */

.information {
    background-color: #503630;
}

.info_title {
    border-bottom: solid 2px #000;
    position: relative;
    font-weight: normal;
    margin-bottom: 1.6rem;
    padding-top: 100px;
}

.info_title p {
    padding: 20px 70px;
    font-size: 30px;
    line-height: 1.5;
    margin-left: 10px;
    color: #f7f5f2;
}

@media only screen and (max-width: 780px) {
    .info_title p {
        padding: 20px 20px;
        font-size: 18px;
    }
}

@media only screen and (max-width: 414px) {
    .info_title p {
        padding: 0px 10px;
        font-size: 16px;
    }
}

.content_wrap {
    background-color: #f7f5f2;
    margin: 80px;
    padding-bottom: 30px;
}

.content_wrap h2 {
    font-size: 16px;
    padding-top: 20px;
    margin: 0 20px;
}

.single_txt {
    font-size: 18px;
    margin: 50px auto;
}

.single_txt p {
    margin: 1em auto;
    width: 70%;
    font-size: 16px;
}

@media only screen and (max-width: 780px) {
    .content_wrap {
        margin: 30px;
    }

    .single_txt p {
        width: 80%;
    }
}

@media only screen and (max-width: 414px) {
    .single_txt {
        font-size: 16px;
        margin: 20px auto;
    }

    .content_wrap {
        margin: 30px;
    }

    .single_txt p {
        width: 95%;
    }
}

.wp-pagenavi {
    font-size: 1.8rem;
    width: 100%;
    max-width: 1080px;
    margin: 20px auto 0;
    display: flex;
    justify-content: flex-end;
}

.wp-pagenavi>.current {
    background-color: #503630;
    color: #fff;
    border-radius: 5px;
}

.wp-pagenavi>a,
.wp-pagenavi>span {
    width: 1em;
    padding: 0 0.2em;
    margin: 0 5px;
    display: block;
    border-radius: 5px;
    text-align: center;
    transition: .4s;
}

.wp-pagenavi>a:not(.current):hover {
    background-color: #e3e3e3;
}

#content {
    max-width: 1080px;
    margin: auto;
}

.contact_sns a {
    display: inline-block;
    width: 60px;
    opacity: 0.7;
    margin: 30px;
    color: #fff;
    text-align: center;
}

.sns-area {
    padding: 0 30px;
    text-align: center;
}

@media only screen and (min-width: 1021px) {
    .sns-area {
        width: 900px;
        margin: 20px auto;
        padding: 0;
    }
}

@media only screen and (min-width: 760px) {
    .sns-area {
        width: 90%;
        margin: 20px auto;
        padding: 0;
    }
}

@media only screen and (min-width: 1021px) {
    .sns-area-inner {
        border-top: 1px solid #000;
        border-bottom: 1px solid #000;
    }
}

@media only screen and (min-width: 760px) {
    .sns-area-inner {
        border-top: 1px solid #000;
        border-bottom: 1px solid #000;
    }
}

.sns-area-inner {
    display: inline-block;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
}

@media only screen and (max-width: 780px) {
    .sns-area-inner {
        border-top: none;
    }
}

.cf {
    zoom: 1;
}

.cf:before,
.cf:after {
    content: "";
    display: table;
}

@media only screen and (min-width: 760px) {
    .sns-left {
        float: left;
        width: 50%;
        text-align: center;
    }
}

.sns-left {
    float: left;
    width: 50%;
    text-align: center;
}

@media only screen and (min-width: 760px) {
    .sns-area-inner a {
        display: inline-block;
        font-size: 12px;
        font-weight: 600;
        line-height: 26px;
        letter-spacing: 0.2em;
        transition: all .3s;
    }
}

.sns-area-inner a {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    line-height: 20px;
    letter-spacing: 0.2em;
}

@media only screen and (min-width: 1021px) {
    .sns-right {
        float: right;
        width: 50%;
        text-align: center;
    }
}

@media only screen and (min-width: 760px) {
    .sns-right {
        float: right;
        width: 50%;
        text-align: center;
    }
}

.sns-right {
    float: right;
    width: 50%;
    text-align: center;
}

@media only screen and (min-width: 760px) {
    .sns-area .facebook-link {
        padding: 2px 0 0 35px;
        background: url("img/fb.png") 0 0 no-repeat;
    }
}

.sns-area .facebook-link {
    padding: 6px 0 6px 40px;
    background: url("img/fb.png") 0 0 no-repeat;
    background-size: 30px 30px;
    margin: 20px 0;
}

@media only screen and (min-width: 760px) {
    .sns-area .instagram-link {
        padding: 0 0 2px 44px;
        background: url("img/ig.png") 0 0 no-repeat;
    }
}

.sns-area .instagram-link {
    padding: 5px 0 6px 40px;
    background: url("img/ig.png") 0 0 no-repeat;
    background-size: 30px 30px;
    margin: 20px 0;
}

@media only screen and (min-width: 760px) {
    .sns-area .hotpepper-link {
        padding: 0 0 2px 44px;
        background: url("img/hpb_p.png") 0 0 no-repeat;
        margin: 20px 0;
    }
}

.sns-area .hotpepper-link {
    padding: 5px 0 6px 40px;
    background: url("img/hpb_p.png") 0 0 no-repeat;
    background-size: 30px 30px;
    margin: 20px 0;
    background-position: left;
}

@media only screen and (min-width: 760px) {
    .sns-area .line-link {
        padding: 0 0 2px 44px;
        background: url("img/line.png") 0 0 no-repeat;
    }
}

.sns-area .line-link {
    padding: 5px 0 6px 40px;
    background: url("img/line.png") 0 0 no-repeat;
    background-size: 30px 30px;
    margin: 20px 0;
}

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

    .sns-right,
    .sns-left {
        float: none;
        width: 100%;
    }

    .sns-area .facebook-link,
    .sns-area .hotpepper-link,
    .sns-area .line-link,
    .sns-area .instagram-link {
        margin: 10px 0;
    }
}

@media only screen and (max-width: 414px) {
    .sns-area {
        margin: 10px 0;
    }
}

.cp_wrap p {
    text-align: center;
}

.step-flow {
    text-align: center;
}

.step-wrap2 {
    counter-reset: count;
    margin: 2em;
    position: relative;
    font-size: 16px;
    display: inline-block;
}

.step-content2 {
    padding: 0 0 1.3em 2.3em;
    margin: 0;
    position: relative;
}

.step-content2::before {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    background: #d9c7b3;
    border-radius: 50%;
    position: absolute;
    top: 7px;
    left: 0;
}

.step-content2::after {
    content: "";
    display: block;
    height: calc(100% - 17px);
    border-left: solid 5px #bbb;
    position: absolute;
    top: 20px;
    left: 3px;
}

.step-label2 {
    color: #d9c7b3;
    font-weight: bold;
    margin: 10px 0;
    text-align: left;
}

.step-label2::before {
    content: "";
    display: block;
    width: 12px;
    border-top: solid 3px #d9c7b3;
    position: absolute;
    top: 10px;
    left: 12px;
}

.step-label2::after {
    counter-increment: count;
    content: counter(count);
    position: relative;
    left: .3em;
}

.step-title2 {
    font-weight: bold;
    font-size: 120%;
    margin: 10px;
    text-align: left;
    color: #F3F3F3;
}

.step-body2 {
    margin-top: .5em;
    padding: 0 0 1em;
    text-align: left;
    letter-spacing: 1.5px;
    color: #F3F3F3;
}

.step-body2::before {
    content: "";
    height: calc(100% - 35px);
    display: block;
    border-left: solid 3px #d9c7b3;
    position: absolute;
    top: 10px;
    left: 21px;
}

.step-body2::after {
    content: "";
    width: 100%;
    display: block;
    border-bottom: solid 3px #d9c7b3;
    position: absolute;
    bottom: 22px;
    left: 21px;
}

.step-wrap2> :last-of-type::after {
    display: none;
}

.recruit_wrap {
    max-width: 1000px;
    margin: 0 auto;
}

.recruit_info {
    font-size: 1.6rem;
    margin-top: 40px;
    padding-bottom: 40px;
}

.recruit_info dl {
    display: flex;
    flex-wrap: wrap;
}

.recruit_info dt {
    width: 35%;
    padding: 20px;
    background-color: #d9c7b3;
    margin: 0 0 10px 0;
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.recruit_info dd {
    width: 65%;
    padding: 20px;
    background-color: #F3F3F3;
    margin: 0 0 10px 0;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
}

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

    .recruit_info dt,
    .recruit_info dd {
        width: 100%;
        margin: 0;
    }

    .recruit_info dd {
        text-align: center;
    }
}

@media only screen and (max-width: 414px) {
    .recruit_info dt {
        padding: 10px;
    }
}

@media only screen and (max-width: 780px) {
    .recruit_info {
        font-size: 1.4rem;
    }
}

.recruit_info dt.t_top {
    border-top: #d9c7b3 5px solid;
}

.recruit_info dd.t_top {
    border-top: #DADADA 5px solid;
}

.top-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    max-width: 1280px;
    margin: 0 auto;
}

.top-content img {
    display: block;
    max-width: 600px;
    margin: 0 auto;
}

.top-content .top-content-box {
    width: 48%;
    text-align: center;
}

.top-content .top-content-box p {
    font-size: 15px;
    font-weight: 400;
    line-height: 2.0;
    text-align: center;
    color: #F3F3F3;
}

@media only screen and (max-width: 1450px) {
    .top-content p {
        padding-right: 80px;
    }
}

@media only screen and (max-width: 1150px) {
    .top-content {
        display: block;
        justify-content: center;
    }

    .top-content .top-content-box {
        width: 100%;
    }

    .top-content .top-content-box p {
        margin: 2em 0;
        padding-right: 80px;
    }
}

@media only screen and (max-width: 800px) {
    .top-content .top-content-box p {
        padding: 0;
    }
}

@media only screen and (max-width: 780px) {
    .top-content {
        display: block;
        justify-content: center;
    }

    .top-content img {
        width: 100%;
    }

    .top-content .top-content-box {
        width: 100%;
    }

    .top-content .top-content-box p {
        margin: 20px 0;
        line-height: 1.5;
    }
}

@media only screen and (max-width: 414px) {
    .top-content .top-content-box p {
        font-size: 14px;
    }
}

.sp-br {
    display: none;
}

.pc-br {
    display: inline;
}

@media only screen and (max-width: 800px) {
    .sp-br {
        display: inline;
    }

    .pc-br {
        display: none;
    }
}

.subtitle-wrap {
    margin: 40px 0 20px 0;
}

.sub_title {
    font-size: 26px;
    text-align: center;
    color: #fff;
}

.sub_title span {
    display: table;
    align-items: center;
    color: #d9c7b3;
    font-size: 18px;
    margin: 20px auto;
}

.sub_title span::before {
    content: '';
    display: inline-block;
    margin-right: 20px;
    width: 40px;
    height: 1px;
    background-color: #d9c7b3;
}


/*タイトル見出し共通*/

.title-wrap {
    width: 100%;
    margin-bottom: 40px;
    padding-left: 10px;
}

.page_title {
    font-size: 26px;
}

.page_title::before {
    content: attr(data-en);
    display: block;
    color: #503630;
    font-size: 18px;
    margin: 12px 0;
}

.page_title::after {
    content: '';
    display: block;
    width: 50px;
    height: 1px;
    background-color: #503630;
    margin-top: 10px;
}

@media only screen and (max-width: 780px) {
    .page_title {
        font-size: 20px;
    }

    .page_title::before {
        font-size: 12px;
    }

    .sub_title {
        font-size: 20px;
    }
}

@media only screen and (max-width: 414px) {
    .page_title {
        font-size: 18px;
    }

    .page_title::before {
        font-size: 11px;
    }

    .sub_title {
        font-size: 18px;
    }
}

.salon-title {
    color: #fff;
    font-size: 22px;
    margin: 0 auto;
    text-align: center;
    border-bottom: 1px solid;
    padding: 15px;
}

.hpb_link {
    display: flex;
    justify-content: center;
}

.hpb_link p {
    color: #fff;
    text-align: center;
    padding-top: 10px;
}

.hpb {
    padding: 30px;
}

.hpb img {
    width: 150px;
}


/* menu design */

dl.menu {
    width: 100%;
    font-size: 1.8rem;
    max-width: 1000px;
    text-align: center;
    margin: 0 auto;
}

dl.menu div {
    position: relative;
    display: flex;
    justify-content: space-between;
    margin: 10px 0;
    padding: 5px 0;
    color: #fff;
}

dl.menu div::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    z-index: 1;
    width: 100%;
    border-bottom: dotted 1px #000;
}

dl.menu dt {
    margin: 0;
    padding: 0 5px 0 0;
    z-index: 2;
    text-align: left;
    background-color: #caafa5;
    font-size: 2rem;
}

dl.menu dd {
    margin: 0;
    padding: 0 0 0 5px;
    z-index: 2;
    text-align: right;
    background-color: #caafa5;
    font-size: 2rem;
}

dl.menu p {
    color: #222;
    padding-left: 45px;
    font-size: 16px;
}

dl.menu span {
    text-align: right;
    display: block;
    font-size: 12px;
    color: #fff;
}

@media only screen and (max-width: 1200px) {
    dl.menu {
        padding-right: 80px;
    }
}

@media only screen and (max-width: 800px) {
    dl.menu {
        padding-right: 0;
        width: 95%;
        font-size: 1.6rem;
    }

    dl.menu dt {
        font-size: 1.8rem;
    }
}

@media only screen and (max-width: 414px) {
    dl.menu p {
        padding-left: 0;
        font-size: 14px;
    }
}

.menu p.att {
    margin: 30px 0;
    text-align: right
}

.menu p.Att {
    margin: 50px 0;
    text-align: center;
    font-size: 15px;
}

.menu p.att_l {
    margin: 30px 0;
    text-align: center;
    color: #fff;
}

.lineBtn {
    margin: 20px auto;
    text-align: center
}

.btn,
a.btn,
button.btn {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.5rem;
}

a.btn-c {
    font-size: 2.2rem;
    position: relative;
    padding: 1.5rem 2rem 1.5rem 5rem;
    color: #caafa5;
    background: #fff;
    -webkit-box-shadow: 0 5px 0 #bda399;
    box-shadow: 0 5px 0 #bda399;
}

a.btn-c span {
    font-size: 1.4rem;
    display: inline-block;
    width: 100%;
    margin-bottom: 0.5em;
    padding: 0.2rem 0.5rem;
    color: #fff;
    border-radius: 4px;
    background: #caafa5;
}

a.btn-c:before {
    font-family: "Font Awesome 5 Free";
    font-size: 1.8rem;
    line-height: 1;
    position: absolute;
    top: calc(50% - 0.7rem);
    left: 1.5rem;
    margin: 0;
    padding: 0;
    content: "\f30b";
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

a.btn-c:hover {
    -webkit-transform: translate(0, 3px);
    transform: translate(0, 3px);
    color: #caafa5;
    background: #fff;
    -webkit-box-shadow: 0 2px 0 #bda399;
    box-shadow: 0 2px 0 #bda399;
}

a.btn-c:hover:before {
    left: 2rem;
}


/* background */

section.test_area {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.com-bg {
    background-color: #efeff0;
}

.com-en {
    font-family: "cormorant", serif;
    font-size: 240px;
    font-size: 24rem;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1;
}

@media only screen and (max-width: 767px) {
    .com-en {
        font-size: 70px;
        font-size: 7rem;
    }
}

.rec-en {
    font-family: "cormorant", serif;
    font-size: 12rem;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1;
}

@media only screen and (max-width: 800px) {
    .rec-en {
        font-size: 5rem;
    }
}

.rec_ttl,
.menu_ttl,
.korugi_ttl,
.att_ttl,
.contact_ttl,
.qa_ttl {
    font-size: 30px;
    font-weight: bold;
    position: relative;
    padding-left: 140px;
    margin-top: 130px;
}

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

    .rec_ttl,
    .menu_ttl,
    .korugi_ttl,
    .att_ttl,
    .contact_ttl,
    .qa_ttl {
        font-size: 22px;
        padding-left: 80px;
        margin-top: 90px;
        line-height: 1.2;
    }
}

.rec_ttl::before,
.menu_ttl::before,
.korugi_ttl::before,
.att_ttl::before,
.contact_ttl::before,
.qa_ttl::before {
    display: inline-block;
    font-family: "mrblaketon-pro", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 300%;
    color: rgba(255, 255, 255, 0.6);
    transform: rotate(-10deg);
    position: absolute;
    left: 0;
    top: -25px;
    z-index: -1;
    white-space: nowrap;
}

.att_ttl {
    margin-top: 200px;
}

@media only screen and (max-width: 530px) {
    .att_ttl {
        margin-top: 120px;
    }
}

.rec_ttl::before {
    content: "Recommend";
}

.menu_ttl::before {
    content: "Menu";
}

.korugi_ttl::before {
    content: "Korugi";
}

.att_ttl::before {
    content: "Attention";
}

.contact_ttl::before {
    content: "Contact";
}

.qa_ttl::before {
    content: "Question";
}

.com-box {
    padding: 67px 0 61px 79px;
    border: 1px solid #b89c6a;
}

.com-box-con {
    width: 100%;
    max-width: 530px;
}

.com-box-ttl {
    position: relative;
    z-index: 1;
}

.com-box-ttl-en {
    font-family: "mrs", serif;
    font-size: 100px;
    font-size: 10rem;
    letter-spacing: 0;
    color: rgba(184, 156, 106, 0.1);
    line-height: 1;
    position: absolute;
    left: -35px;
    top: -37px;
    z-index: -1;
}

@media only screen and (max-width: 767px) {
    .com-box-ttl-en {
        font-size: 50px;
        font-size: 5rem;
    }
}

.com-box-ttl-ja {
    padding-bottom: 7px;
    border-bottom: 1px solid #222222;
    font-family: "shippori", serif;
    font-size: 22px;
    font-size: 2.2rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1.6;
}

@media only screen and (max-width: 767px) {
    .com-box-ttl-ja {
        font-size: 18px;
        font-size: 1.8rem;
    }
}

.com-box-txt {
    max-width: 470px;
    margin-top: 35px;
}

.com-box-btn-wrap {
    margin-top: 23px;
}

.com-box-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    max-height: 120px;
    margin-top: 34px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.com-box-list-item {
    max-width: 268px;
}

.com-box-list-txt {
    font-family: "Noto serif Medium", serif;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    color: #222222;
    line-height: 1.65;
}

@media only screen and (max-width: 767px) {
    .com-box-list-txt {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

.sec-inner,
.bread-inner {
    width: 1080px;
    max-width: 100%;
    margin: auto;
}

#top-sec01 .sec01-inner {
    position: relative;
    z-index: 1;
    padding: 140px 0;
}

#top-sec01 .sec01-en {
    position: absolute;
    top: -45px;
    left: -100px;
    z-index: -1;
}

@media only screen and (max-width: 800px) {
    #top-sec01 .sec01-en {
        left: 0;
        background-color: #efeff0;
    }

    #top-sec01 .sec01-inner {
        padding: 0;
    }
}

#top-sec01 .sec01_wrap-right {
    width: 100%;
    max-width: 505px;
}

#top-sec01 .sec01-txt-box {
    margin: 30px;
}

@media only screen and (max-width: 800px) {
    #top-sec01 .sec01-txt-box {
        margin: 30px 10px;
    }
}

.sec02-check {
    position: relative;
    padding: 0.5em 1em 0.5em 2.3em;
}


/* .sec02-en {
    position: absolute;
    z-index: -1;
} */

@media only screen and (max-width: 800px) {
    #top-sec01 .sec02-en {
        left: 0;
    }

    /* .sec02-en {
        position: inherit;
    } */
}

.sec02-figure {
    width: 55%;
    margin: auto;
}

@media only screen and (max-width: 800px) {
    .sec02-figure {
        width: 30%;
        padding-top: 30px;
    }
}

@media only screen and (max-width: 530px) {
    .sec02-figure {
        width: 50%;
        padding-top: 30px;
    }
}

#top-sec01 .com-btn-wrap {
    margin: 25px auto;
    text-align: center;
    padding-top: 30px;
}

.com-head01 {
    text-align: center;
    font-family: "shippori", serif;
    font-size: 26px;
    font-size: 2.6rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1.6;
}

@media only screen and (max-width: 767px) {
    .com-head01 {
        font-size: 21px;
        font-size: 2.1rem;
    }
}


/* .com-head02-en {
    display: block;
    font-family: "cormorant", serif;
    font-size: 60px;
    font-size: 6rem;
    letter-spacing: 0.05em;
    color: #eff0f2;
    line-height: 0.6;
}

@media only screen and (max-width: 767px) {
    .com-head02-en {
        font-size: 30px;
        font-size: 3rem;
    }
} */


/* .com-head02-ja {
    display: block;
    padding: 23.5px 0;
    font-family: "shippori", serif;
    font-size: 20px;
    font-size: 2rem;
    letter-spacing: 0.2em;
    color: #222222;
    position: relative;
}

@media only screen and (max-width: 800px) {
    .com-head02-ja {
        font-size: 19px;
        font-size: 1.9rem;
    }
}

.com-head03 {
    margin: -5px auto 0;
    font-family: "shippori", serif;
    font-size: 26px;
    font-size: 2.6rem;
    letter-spacing: 0.2em;
    color: #222222;
}

@media only screen and (max-width: 767px) {
    .com-head03 {
        font-size: 21px;
        font-size: 2.1rem;
    }
}

.com-head04 {
    padding: 15px 20px;
    background-color: #bca7a7;
    font-family: "Noto serif Medium", serif;
    font-size: 23px;
    font-size: 2.3rem;
    letter-spacing: 0.08em;
    color: #fff;
}

@media only screen and (max-width: 767px) {
    .com-head04 {
        font-size: 18px;
        font-size: 1.8rem;
    }
} */

.com-txt,
#privacy .txt-box {
    color: #222222;
    font-size: 17px;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    line-height: 2;
}

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

    .com-txt,
    #privacy .txt-box {
        font-size: 16px;
        font-size: 1.6rem;
    }
}

.com-btn,
.com-btn:link,
.com-btn:visited {
    padding: 15px;
    border: 1px solid #222;
    color: #222;
    background-color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.6rem;
    letter-spacing: 3px;
    transition: all .2s ease-in-out;

    &:hover {
        background: #222;
        border: 1px solid #222;
        color: #fff;
        /* border-radius: 30px; */
    }
}

@media only screen and (min-width: 800px) {
    .com-btn a {
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
    }
}

.fle {
    display: -webkit-box;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

@media only screen and (max-width: 800px) {
    .fle {
        flex-direction: column-reverse;
    }
}

.sec01-figure img {
    max-width: 500px;
    border-top-right-radius: 100px;
}


/*	top-sec02  PC
  ------------------------------------ */

#top-sec02 .sec02-flex {
    margin: 43px auto 0;
    flex-direction: row-reverse;
}

@media only screen and (max-width: 800px) {
    #top-sec02 .sec02-flex {
        flex-direction: column;
        margin: 0;
    }
}

#top-sec02 .flex-right {
    width: 100%;
    max-width: 500px;
}

@media only screen and (min-width: 768px) {
    #top-sec02 .flex-right {
        margin-top: -7px;
    }
}

#top-sec02 .check-item {
    padding-left: 34px;
}

@media only screen and (max-width: 530px) {
    #top-sec02 .check-item {
        padding: 0.25em 0 0 34px;
    }
}

#top-sec02 .check-item:nth-of-type(n+2) {
    margin-top: 5px;
}

#top-sec02 .check-txt {
    font-size: 22px;
    font-size: 2.2rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1.6;
}

@media only screen and (max-width: 800px) {
    #top-sec02 .check-txt {
        font-size: 16px;
        font-size: 1.6rem;
        margin: 5px auto 0;
    }
}

.flex-check {
    border-radius: 5px;
    padding: 0.5em 1em 0.5em 2.3em;
    position: relative;
}

.check-item {
    line-height: 1.5;
    padding: 0.5em 0;
    list-style-type: none !important;
}

.check-item:before {
    font-family: "Font Awesome 5 Free";
    font-family: "FontAwesome";
    content: "\f138";
    /*アイコンの種類*/
    position: absolute;
    left: 1em;
    /*左端からのアイコンまでの距離*/
    color: #9e865b;
    /*アイコン色*/
}

#top-sec02 .sec02-txt {
    margin-top: 40px;
    text-align: center;
}

#top-sec02 .sec02-box {
    margin: 140px auto 0;
    position: relative;
}

#top-sec02 .sec02-box-cir-lg {
    font-size: 28px;
    font-size: 2.8rem;
    letter-spacing: 0.2em;
    line-height: 1;
}

@media only screen and (max-width: 767px) {
    #top-sec02 .sec02-box-cir-lg {
        font-size: 21px;
        font-size: 2.1rem;
    }
}

#top-sec02 .sec02-box-figure {
    position: absolute;
    top: 0;
    right: 12px;
}

#top-sec02 .com-btn {
    max-width: 350px;
    margin: 0;
}

#top-sec02 .com-btn-wrap {
    margin-top: 30px;
    padding-top: 30px;
    text-align: center;
}


/* 
#top-sec03 .sec03-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin: 50px auto 0;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

#top-sec03 .sec03-list-item {
    width: 100%;
    max-width: 538px;
    background: url(../img/top/bnr-wood.png) no-repeat center/cover;
}

#top-sec03 .sec03-list-box {
    width: 100%;
    max-width: 400px;
    margin: auto;
    padding-top: 80px;
    background: url(../img/top/bnr-bg-deco.png) no-repeat center right/cover;
    text-align: center;
}

#top-sec03 .sec03-list-ttl {
    display: inline-block;
    padding-bottom: 11px;
    border-bottom: 1px solid #222222;
    font-family: "shippori", serif;
    font-size: 22px;
    font-size: 2.2rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1;
}

@media only screen and (max-width: 767px) {
    #top-sec03 .sec03-list-ttl {
        font-size: 18px;
        font-size: 1.8rem;
    }
}

#top-sec03 .sec03-list-txt {
    margin: 35px auto 0;
}

#top-sec03 .sec03-list-btn {
    background-image: url(../img/top/bnr-target-ico.png);
    background-position: calc(100% - 17px) center;
}

#top-sec03 .sec03-list-btn-wrap {
    margin: 25px auto 0;
}

#top-sec03 .sec03-list-btn-wrap-line {
    margin-top: 55px;
} */

ol.att_list {
    counter-reset: list;
    list-style-type: none;
    font-size: 1.6rem;
    padding: 0;
}

ol.att_list li {
    position: relative;
    padding: 0 0 0 20px;
    margin: 7px 0 7px 0px;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 30px;
}

ol.att_list li:before {
    counter-increment: list;
    content: "";
    display: block;
    position: absolute;
    left: 0px;
    height: 10px;
    width: 10px;
    border-radius: 50%;
    background: #fff;
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.att_box {
    margin: 30px 10px;
}

.att_box p {
    font-size: 1.6rem;
    line-height: 2.5;
    letter-spacing: 1.2px;
}

@media only screen and (max-width: 530px) {
    .att_box p {
        font-size: 1.5rem;
        line-height: 1.6;
    }
}

.att_box h2 {
    font-size: 2.2rem;
    margin: 60px auto 20px;
    border-bottom: 10px #e9deda solid;
}

.cp_snslink05 {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    display: inline-block;
    margin: 0;
    padding: 0;
    list-style-type: none;
}


/*それぞれのSNS iconの設定*/

.cp_snslink05 .cp_link {
    position: relative;
    width: 35px;
    height: 40px;
    color: #ffffff;
    background: #1a405f;
    cursor: pointer;
}

.cp_snslink05 .cp_link:first-of-type {
    border-radius: 0 5px 0 0;
}

.cp_snslink05 .cp_link:last-of-type {
    border-radius: 0 0 5px 0;
}

.cp_snslink05 .cp_link::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 1em;
    height: 1em;
    background-size: contain;
    background-repeat: no-repeat;
    color: #ffffff;
}

.cp_snslink05 .cp_link:last-of-type {
    border-bottom: none;
}


/*facebook*/

.cp_snslink05 .cp_link.facebook::before {
    background-image: url(facebook_logo_secondary.svg);
}


/*line*/

.cp_snslink05 .cp_link.line::before {
    background-image: url(x-logo.svg);
}


/*instagram*/

.cp_snslink05 .cp_link.instagram::before {
    background-image: url(instagram_glyph_white.svg);
}


/*hoverで表示されるブロックの設定*/

.cp_snslink05 .cp_link span {
    position: absolute;
    top: 5px;
    left: 45px;
    display: flex;
    align-items: center;
    width: fit-content;
    height: 30px;
    padding: 0 10px;
    opacity: 0;
    color: #ffffff;
    background: #1a405f;
    border-radius: 2px;
    transition: all 0.5s ease 0.3ms;
    /*hover時の動きを設定*/
}

.cp_snslink05 .cp_link:hover span {
    left: 45px;
    opacity: 1;
}

.cp_snslink05 .cp_link span::after {
    /*吹き出しの三角の設定*/
    position: absolute;
    content: '';
    top: 50%;
    left: -15px;
    transform: translateY(-50%);
    width: 15px;
    height: 10px;
    background: #1a405f;
    clip-path: polygon(100% 0, 50% 50%, 100% 100%);
}


/* facebook */

.cp_snslink05 .cp_link.facebook:hover {
    background: #0866ff;
}


/* line */

.cp_snslink05 .cp_link.line:hover {
    background: #000000;
}


/* instagram */

.cp_snslink05 .cp_link.instagram:hover {
    background: linear-gradient(45deg, #FF7A00 0%, #FF0169 50.06%, #D300C5 99.36%);
}

.cp_qa *,
.cp_qa *:after,
.cp_qa *:before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.cp_qa {
    margin-top: 60px;
    font-size: 1.6rem;
}

.cp_qa .cp_actab {
    position: relative;
    overflow: hidden;
    width: 100%;
    margin: 0 0 1em 0;
    /* color: #b89c6a; */
    color: #222;
}

.cp_qa .cp_actab input {
    position: absolute;
    opacity: 0;
}


/* 質問 */

.cp_qa .cp_actab label {
    font-weight: bold;
    line-height: 1.6em;
    position: relative;
    display: block;
    margin: 0 10px;
    padding: 1em 2em 1em 2.5em;
    cursor: pointer;
    text-indent: 1em;
    border-radius: 0.5em;
    background: rgba(27, 37, 56, 0.1);
}

.cp_qa .cp_actab label::before {
    font-family: serif;
    font-size: 1.5em;
    margin-left: -2em;
    padding-right: 0.5em;
    content: 'Q';
}

.cp_qa .cp_actab label:hover {
    transition: all 0.3s;
    color: #fff;
}


/* --質問の＋アイコン */

.cp_qa .cp_actab label::after {
    font-size: 1.7em;
    font-weight: bold;
    line-height: 2.5em;
    position: absolute;
    top: 0;
    right: 0;
    content: '＋';
    display: inline-block;
    width: 2em;
    height: 2em;
    -webkit-transition: transform 0.4s;
    transition: transform 0.4s;
}


/* 答え */

.cp_qa .cp_actab .cp_actab-content {
    position: relative;
    overflow: hidden;
    max-height: 0;
    padding: 0 0 0 2.5em;
    -webkit-transition: max-height 0.2s;
    transition: max-height 0.2s;
    border-radius: 0 0 0.5em 0.5em;
}

.cp_qa .cp_actab .cp_actab-content::before {
    font-family: serif;
    font-size: 1.5em;
    position: absolute;
    margin: 0.7em 0 0 -1em;
    padding: 0;
    content: 'A';
}

.cp_qa .cp_actab .cp_actab-content p {
    margin: 1em 1em 1em 0;
    font-size: 1.6rem;
}


/* 質問を開いた時の仕様 */


/* --答えの高さ */

.cp_qa .cp_actab input:checked~.cp_actab-content {
    max-height: 40em;
    border: 10px solid rgba(27, 37, 56, 0.1);
}


/* 質問をクリックした時のアイコンの動き */

.cp_qa .cp_actab input:checked~label {
    color: #efdec9;
    border-radius: 0.5em 0.5em 0 0;
}


/* 質問をクリックした時の+の動き */

.cp_qa .cp_actab input[type=checkbox]:checked+label::after {
    -webkit-transform: rotateZ(45deg);
    transform: rotateZ(45deg);
    -webkit-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
}

.org_b {
    height: 350px;
    position: relative;
}

.fade::before {
    width: 60%;
}

.org_b::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
    background: #e1a036;
    transition: 0.5s;
    z-index: -1;
}

.about_wrap {
    width: 80%;
    margin: auto;
    padding-top: 25px;
}

.salon_img01 {
    position: relative;
    text-align: end;
}

.salon_img02 {
    position: relative;
    text-align: left;
    padding-top: 100px;
}

.salon_img01 img,
.salon_img02 img {
    max-width: 1200px;
}

@media only screen and (max-width: 530px) {
    .salon_img01 {
        /* top: 40px; */
        z-index: 99;
    }

    .salon_img02 {
        padding-top: 70px;
    }
}

.salon_b,
.salon_bl {
    position: relative;
}

.salon_img02 {}

.salon_b::before {
    content: '';
    display: block;
    position: absolute;
    top: -260px;
    right: 80px;
    height: 400px;
    background-color: rgba(255, 255, 255, 0.3);
    transition: 0.5s;
    z-index: -1;
    width: 1200px;
}

.salon_bl::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 40px;
    left: 80px;
    height: 400px;
    background-color: rgba(255, 255, 255, 0.3);
    transition: 0.5s;
    z-index: -1;
    width: 1200px;
}

@media only screen and (max-width: 650px) {
    .salon_b::before {
        display: none;
    }

    .salon_bl::before {
        height: 200px;
    }
}

.sec-link-wrap {
    text-align: right;
    padding-right: 15px;
}

.sec-link-white {
    font-weight: 400;
    position: relative;
    padding-right: 70px;
    color: #000;
    font-size: 2.2rem;
}

.sec-link-white::before {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: 55px;
    height: 1px;
    background-color: #000;
    transition: all .3s;
}

.sec-link-white::after {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    right: 1px;
    width: 5px;
    height: 5px;
    margin-top: -2px;
    border-top: 1px solid #000;
    transform: rotate(45deg);
    transition: all .2s;
}

.sec-link-white:hover {
    color: #393939;
}

.sec-link-white:hover::before {
    position: absolute;
    top: 50%;
    right: -8px;
    width: 63px;
}

.sec-link-white:hover::after {
    position: absolute;
    top: 50%;
    right: -7px;
}

.motto {
    position: relative;
    background: url(img/eight_top02.png);
    height: 600px;
    display: flex;
    flex-direction: column;
}

.motto_img img {
    display: block;
    width: auto;
    margin: 30px auto;
    /* position: relative;
    top: -50px; */
}

@media only screen and (max-width: 780px) {
    .motto_img img {
        width: 60%;
    }
}

@media only screen and (max-width: 530px) {
    .motto {
        background-size: cover;
    }
}

.motto_img02 img {
    display: block;
    width: auto;
    margin: 30px auto;
    position: relative;
    bottom: -50px;
    z-index: 1;
}

.logo_img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 300px;
}

@media only screen and (max-width: 530px) {
    .logo_img {
        width: 50%;
    }
}

.top_moji {
    position: absolute;
    top: 375px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 1000px;
    z-index: 1;
}

@media only screen and (max-width: 1000px) {
    .top_moji {
        width: 100%;
    }
}

@media only screen and (max-width:530px) {
    .top_moji {
        top: 42%
    }
}

.top_menu {
    position: absolute;
    top: -20px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 425px;
    z-index: 1;
}

@media only screen and (max-width: 800px) {
    .top_menu {
        top: -80px;
    }
}

@media only screen and (max-width: 530px) {
    .top_menu {
        top: -100px;
        max-width: 350px;
    }
}

.top_menu_c {
    position: absolute;
    top: -150px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 425px;
    z-index: 1;
}

@media only screen and (max-width: 530px) {
    .top_menu_c {
        position: unset;
        max-width: 350px;
    }
}

.top_floor {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 425px;
    z-index: 1;
}

@media only screen and (max-width: 530px) {
    .top_floor {
        max-width: 350px;
    }
}

.floor_wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    max-width: 1000px;
    margin: 0 auto 150px;
    padding-top: 150px;
}

@media only screen and (max-width: 530px) {
    .floor_wrap {
        flex-direction: column;
    }
}

.floor_wrap img {
    display: block;
    width: 48%;
    height: auto;
}

.floor_wrap .box {
    width: 48%;
}



.floor_wrap .box h2 {
    font-size: 2rem;
    line-height: 2;
}

.floor_wrap .box p {
    font-size: 1.6rem;
    line-height: 1.5;
    padding-top: 30px;
}

@media only screen and (max-width: 530px) {
    .floor_wrap .box {
        width: 90%;
    }

    .floor_wrap .box p, .floor_wrap .box h2 {
        text-align: center;
    }
}

/* 
.content {
    width: 450px;
    height: 300px;
    background-repeat: no-repeat;
    background-size: contain;

}

.content:nth-child(1) {
    background: url(img/top1.jpg);
    background-size: contain;
}

.content:nth-child(2) {
    background: url(img/top2.jpg);
    background-size: contain;
}

.content:nth-child(3) {
    background: url(img/top3.jpg);
    background-size: contain;
}

.content:nth-child(4) {
    background: url(img/top4.jpg);
    background-size: contain;
}

.content:nth-child(5) {
    background: url(img/top5.jpg);
    background-size: contain;
}

.content:nth-child(66) {
    background: url(img/top66.jpg);
    background-size: contain;
}

.content:nth-child(7) {
    background: url(img/top7.jpg);
    background-size: contain;
}

.content:nth-child(8) {
    background: url(img/top8.jpg);
    background-size: contain;
}

.content:nth-child(9) {
    background: url(img/top9.jpg);
    background-size: contain;
}

.content:nth-child(10) {
    background: url(img/top10.jpg);
    background-size: contain;
}

.content:nth-child(11) {
    background: url(img/top11.jpg);
    background-size: contain;
} */
/* 

.wrap {
    overflow: hidden;
    display: flex;
    align-items: center;
    height: 340px;
    margin-bottom: 100px;
}

.slideshow {
    display: flex;
    -webkit-animation: loop-slide 20s infinite linear 1s both;
    animation: loop-slide 20s infinite linear 1s both;
    position: absolute;
    top: 0;
    width: 100vw;
    overflow: hidden;
    flex-direction: row;
    background: center no-repeat;
}

@-webkit-keyframes loop-slide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes loop-slide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-100%);
    }
} */

/* ホバー時に動きを止める（パターン2・3）*/
.slide-paused:hover .slideshow {
    -webkit-animation-play-state: paused;
    animation-play-state: paused;
}

/* ホバー時の装飾（パターン3） */
.content-hover {
    transition: all 0.2s;
    margin-right: 20px;
}

.content-hover:hover {
    transform: translateY(-20px);
    border-radius: 0 10%;
    box-shadow: 0 3px 10px 0 #333;
    opacity: 0.8;
    cursor: pointer;
    animation-play-state: paused;
}

/* =======================================
	ClearFixElements
======================================= */
/* .slider-container ul:after {
    content: ".";
    height: 0;
    clear: both;
    display: block;
    visibility: hidden;
} */

/* 
.loopSlide {
    position: relative;
    display: flex;
    width: 100vw;
    overflow: hidden;

    ul {
        padding: 0;
        width: 100vw;
        display: flex;
        flex-shrink: 0;

        &:first-child {
            animation: slide1 60s -30s linear infinite;
        }

        &:last-child {
            animation: slide2 60s linear infinite;
        }

        li {
            display: inline-block;
            width: 100%;
            min-width: 150px;
            margin-right: 20px;
            list-style: none;
            text-align: center;

            img {
                display: block;
                width: 100%;
                height: auto;
            }
        }
    }

    &:hover {
        ul {
            animation-play-state: paused;
        }
    }
}

@keyframes slide1 {
    0% {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes slide2 {
    0% {
        transform: translateX(0);
    }

    to {
        transform: translateX(-200%);
    }
} */
.slider1 {
    display: flex;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
    height: 400px;
    overflow: hidden;
}

@media screen and (max-width: 768px) {
    .slider1 {
        height: 200px;
    }
}

.slider1 ul {
    display: flex;
    padding: 0;
    margin: 0;
}

.slider1 li {
    width: 600px;
    list-style: none;
}

@media screen and (max-width: 768px) {
    .slider1 li {
        width: 300px;
    }
}

.slider1 ul:first-child {
    animation: slide1 200s -100s linear infinite;
}

.slider1 ul:last-child {
    animation: slide2 200s linear infinite;
}

@keyframes slide1 {
    0% {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes slide2 {
    0% {
        transform: translateX(0);
    }

    to {
        transform: translateX(-200%);
    }
}

.slider1 ul:hover {

    animation-play-state: paused;

}

.about {
    margin: auto;
}

.about p {
    text-align: center;
    margin: 50px auto;
    font-size: 1.8rem;
}

@media only screen and (max-width: 530px) {
    .about p {
        font-size: 1.6rem;
    }
}

.loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 10;
    background-color: #222;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeOut 1.5s 2.5s forwards;
}

@keyframes fadeOut {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
        visibility: hidden;
    }
}

.loading__logo {
    opacity: 0;
    animation: logo_fade 2s 0.5s forwards;
    width: 500px;
}

@keyframes logo_fade {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }

    60% {
        opacity: 1;
        transform: translateY(0);
    }

    100% {
        opacity: 0;
    }
}

.container {
    width: 90%;
    /* margin: 50px auto; */
}

/* --------------------------------------------------------
	menu
-------------------------------------------------------- */

.container h1 {
    font-family: 'Bentham', serif;
    font-size: 300%;
    color: #fff;
    text-align: center;
    margin: 0 0 80px 0;
}

.mp_wrap {
    padding: 10% 0;
}

.menuPrice {
    width: 50%;
    margin: 50px auto;
    color: #fff;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
}



.menuLeft, .menuRight {
    flex: 0 1 auto;
    font-size: 2rem;
}

@media only screen and (max-width: 800px) {
    .menuPrice {
        width: 95%;
    }

    .menuLeft, .menuRight {
        font-size: 1.6rem;
    }
}

@media only screen and (max-width: 530px) {
    .menuLeft, .menuRight {
        font-size: 1.5rem;
    }

    .menuPrice {
        margin: 35px auto;
        flex-direction: column;
        align-items: center;
        align-content: center;
    }
}

.centerLine {
    padding: 5px 15px;
    flex-grow: 2;
}

@media only screen and (max-width: 530px) {
    .centerLine {
        display: none;
    }
}

.centerLine hr {
    border-width: 1px 0px 0px 0px;
    border-style: dotted;
    border-color: #fff;
}

.price_tax {
    font-size: 80%;
}

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

    /* 
    .menuPrice {
        width: 100%;
        margin-bottom: 20px;
        padding-bottom: 20px;
        border-bottom: 1px dotted #fff;
        flex-direction: column;
    } */

    .centerLine hr {
        display: none;
    }
}

.btn_box {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: 0;
}

.telbtn {
    color: #FFF;
    font-size: 28px;
    width: 176px;
    height: 65px;
    line-height: 65px;
    font-family: "Comfortaa", sans-serif;
    font-weight: 400;
    text-align: center;
    border: 4px solid #fff;
    text-decoration: none;
    letter-spacing: 0.15rem;
    display: block;
    border-radius: 5px;
    box-shadow: 0 0 10px #fff, inset 0 0 10px #fff, 0 0 0px #fff, 0 0 0px #2196F3, 0 0 0px #2196F3, 0 0 10px #2196F3, 0 0 10px #2196F3, inset 0 0 20px #2196F3;
    text-shadow: 0 0 10px #fff, 0 0 10px #fff, 0 0 0px #fff, 0 0 0px #FF5722, 0 0 0px #FF5722, 0 0 10px #FF5722, 0 0 10px #FF5722, 0 0 20px #FF5722;
}

.telbtn:hover {}

/*アニメーション*/
.animation:hover {
    animation: neon 1.5s infinite alternate;
}

@keyframes neon {
    0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% {
        box-shadow: 0 0 10px #fff, inset 0 0 10px #fff, 0 0 0px #fff, 0 0 0px #2196F3, 0 0 0px #2196F3, 0 0 10px #2196F3, 0 0 10px #2196F3, inset 0 0 20px #2196F3;
        text-shadow: 0 0 10px #fff, 0 0 10px #fff, 0 0 0px #fff, 0 0 0px #FF5722, 0 0 0px #FF5722, 0 0 10px #FF5722, 0 0 10px #FF5722, 0 0 20px #FF5722;
    }

    20%, 24%, 55% {
        text-shadow: none;
        box-shadow: none;
    }
}

.bounceU,
.bounceD,
.bounceL,
.flipInX,
.swing,
.bounceIn,
.fadeInR,
.fadeInL,
.fadeInU,
.fadeInD {
    opacity: 0;
    animation-fill-mode: forwards;
}

.is-show {
    transform: translate(0, 0);
    opacity: 1;
}

#animate {
    animation-duration: .5s;
    /* アニメーションの時間 */
    animation-delay: 4s;
    /* アニメーション開始時間 */
}

.contact-sec {
    font-size: 16px;
    margin: 120px 0 0;
}

.contact-sec-inner {
    padding-top: 250px;
}

@media only screen and (max-width: 530px) {
    .contact-sec-inner {
        padding-top: 0;
        background-image: url(img/l_back.jpg);
        height: 500px;
        background-repeat: no-repeat;
        background-size: cover;
        /* background-attachment: fixed; */
        background-position: center;
        position: relative;
        top: 0;

    }
}

.contact_page .contact-sec {
    margin: 0;

}

.contact_box {
    margin: 100px auto
}

.contact_box p {
    text-align: center;
    line-height: 2.2;
    font-size: 1.6rem;
}

@media screen and (max-width: 780px) {
    .contact_box p {
        width: 60%;
        margin: 0 auto;
        font-size: 14px;
    }
}

@media screen and (max-width: 530px) {
    .contact_box p {
        line-height: 1.8;

    }
}

.contact-sec p.att {
    font-size: 15px;
    color: #b8292d;
}

.contact-sec p.big {
    margin: 40px 0 50px;
    font-size: 20px;
    font-weight: 500;
}

@media only screen and (max-width: 414px) {
    .contact-sec p.big {
        font-size: 16px;
        margin: 10px 0 0px;
    }

    .contact-sec p {
        padding-left: 0;
    }
}


.contact-sec-ttl {
    position: absolute;
    top: -75px;
    left: 10.6%;
    width: 65px;
}

.contact-sec-ttl .jpn {
    font-weight: 700;
    font-size: 2.8rem;
    letter-spacing: 0.08em;
    line-height: 1.3;
    color: #5B6465;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    vertical-align: top;
}

.contact-sec-ttl .eng {
    font-weight: 500;
    font-size: 6.8rem;
    letter-spacing: 0.08em;
    line-height: 1;
    color: #c7b299ad;
    vertical-align: top;
    position: absolute;
    left: -35px;
    z-index: -1;
}

.contact-sec-lead {
    font-weight: 600;
    text-align: center;
    font-size: 1.6rem;
    padding: 60px 5px;
}

@media only screen and (max-width: 780px) {
    .contact-sec-ttl .jpn {
        font-size: 2rem;
    }
}

@media only screen and (max-width: 560px) {
    .contact-sec-lead .br-pc {
        display: none;
    }
}

@media only screen and (max-width: 414px) {
    .contact-sec-lead {
        font-size: 14px;
    }
}

.contact-sec-lead .br-pc {
    display: inline-block;
}

br.sp {
    display: none;
}

br.pc {
    display: inline-block;
}

@media only screen and (max-width: 530px) {
    br.sp {
        display: inline-block;
    }

    br.pc {
        display: none;
    }
}

.contact-sec-body {
    display: flex;
    justify-content: space-evenly;
    width: 50%;
    margin: auto;
    align-items: center;
}

@media only screen and (max-width: 1110px) {
    .contact-sec-body {
        width: 80%
    }
}

.contact-sec-form-area {
    width: 50%;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
}

.contact-sec-area-ttl {
    position: relative;
    margin-bottom: 22px;
    padding-left: 13px;
    font-size: 1.7rem;
    letter-spacing: 0.03em;
}

.contact-sec-area-ttl::before {
    content: "";
    position: absolute;
    left: -10px;
    top: 50%;
    width: 4px;
    height: 4px;
    margin-top: -1px;
    border-radius: 50%;
    background-color: #caafa5
}



.contact-sec-form-btn a {
    display: inline-block;
    padding: 0 48px;
    background: linear-gradient(165deg, #e77784, #d7c99d);
    line-height: 66px;
    border-radius: 5px;
    color: #fff;
    letter-spacing: 0.03em;
    font-size: 1.6rem;
    transition: background-color .3s;
}

.contact-sec-tel-area {
    width: 50%;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
}

@media only screen and (max-width: 620px) {
    .contact-sec-body {
        margin: 0 auto;
        display: flex;
        width: 100%;
        max-width: fit-content;
        flex-direction: column;
        align-items: center;
    }



    .contact-sec-tel-area {
        margin: 20px auto 0;
        width: 100%;
        max-width: fit-content;
    }

    .contact-sec-form-area {
        margin: 0 auto;
        width: 100%;
        max-width: fit-content;
    }
}

@media only screen and (max-width: 414px) {
    .contact-sec-body {
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 90%;
    }
}

.contact-sec-tel-area .contact-sec-area-ttl {
    margin-bottom: 15px;
}

.contact-sec-tel-num {
    font-weight: 500;
    color: #99A9AC;
    letter-spacing: 0;
}

.contact-sec-tel-num span {
    display: inline-block;
    margin-right: 5px;
    font-size: 2.0rem;
    vertical-align: top;
}

.contact-sec-tel-num .tel-number {
    display: inline-block;
    margin-bottom: 5px;
    font-size: 3.5rem;
    color: #99A9AC !important;
    line-height: 1.4;
    vertical-align: top;
}

.contact-sec-tel-hour {
    padding-left: 40px;
    font-size: 1.3rem;
    line-height: 1.8;
}

@media only screen and (max-width: 780px) {
    .contact-sec-form-btn a {
        padding: 0px 10px;
        line-height: 65px;
        font-size: 1.5rem;
    }

    .contact-sec-area-ttl {
        font-size: 1.6rem;
    }
}

@media only screen and (max-width: 530px) {
    .contact-sec-tel-num .tel-number {
        font-size: 3.5rem !important;
    }
}

@media only screen and (max-width: 414px) {
    .contact-sec-tel-num .tel-number {
        font-size: 2rem;
    }

    .contact-sec-form-btn {
        text-align: center;
        margin: 0 auto;
    }
}

.back_img {
    background-image: url(img/w_back.jpg);
    height: 85vh;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
}

@media only screen and (max-width: 1760px) {
    .back_img {

        background-size: contain;
    }
}

.back_img_sp {
    background-image: url(img/w_backsp.png);

    background-repeat: no-repeat;
    background-attachment: fixed;
    display: none;
}

@media only screen and (max-width: 1800px) {
    .back_img {
        display: none;
    }

    .back_img_sp {
        display: block;
    }
}

/* 
@media only screen and (max-width: 530px) {
    .back_img {
        height: auto;
        background-size: contain;
    }
} */

.back_img2 {
    background-image: url(img/l_back.jpg);
    height: 910px;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    background-position: center;
}

/* .back_img2_sp {
    background-image: url(img/l_backsp.png);

    background-repeat: no-repeat;
    background-attachment: fixed;
    display: none;
} */

@media only screen and (max-width: 800px) {
    /* .back_img2 {
        display: none;
    } */

    .back_img2_sp {
        display: block;
    }
}

@media only screen and (max-width: 530px) {
    .back_img2 {
        display: none;
    }
}