@charset "UTF-8";

/*
Theme Name: wp
Theme URI:
Author: wp
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: wp

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;
}

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;
}

.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: .75s;
    /* アニメーション開始時間 */
}

/* General setting */

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

body {
    font-size: 62.5%;
    overflow-x: clip;
}

body,
html {
    width: 100%;
}

body {
    font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
    font-weight: 500;
    background: #e9e8e2;
    color: #000;
    /* overflow-x: hidden; */
}

.headline {
    width: 100%;
    height: 120px;
    margin: auto;
    padding: 30px 30px 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-around;

}

@media only screen and (max-width: 1200px) {
    .headline {
        justify-content: flex-start;
    }
}

@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 #df8887;
    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: #df8887;
}

@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: #dcae95;
        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: flex;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    align-items: center;
    z-index: 9999;
}

.logo:hover {
    opacity: 0.7;
}

.logo a,
.logo img {
    display: block;
    max-width: 80px;
}

@media only screen and (max-width: 1200px) {
    .logo {
        max-width: 300px;
        flex-direction: row;
    }

    .logo img {
        max-width: 60px;
    }
}

@media only screen and (max-width: 800px) {
    .logo {
        left: 10px;
        position: relative;
    }
}

.logo h1 {
    font-size: 2.5rem;
    margin-left: 20px;
    letter-spacing: 1.5px;
}

@media only screen and (max-width: 1200px) {
    .logo h1 {
        font-size: 15px;
    }
}

.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;
}

.top .top-container {
    position: relative;
    width: 100%;
    height: 530px;
    overflow: hidden;
}

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

.top .other-container {
    display: none;
}

.other .other-container {
    display: block;
}

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

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

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

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

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

.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;
    filter: contrast(0.5);
}

@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;
}

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

    .slideimg_sp {
        display: block;
        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;
        filter: contrast(0.5);
    }
}

@keyframes slideAnime {

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

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

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


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

.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;
    background-position: bottom center;
}

.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;
    background-position: center;
}

.slideimg_sp {}

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

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

.other .mv {
    display: none;
}

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

.top .mv_menu_other {
    display: none;
}

.other .mv_menu_other {
    /* height: 300px; */
    position: relative;
}

@media only screen and (max-width: 530px) {
    .other .mv_menu_other {
        height: 70px;
    }
}

@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: #e9e8e2;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: -1;
}

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

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

.work_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,
.work_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,
    .work_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');
    }

    .work_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,
    .work_img,
    .qa_img,
    .contact_img {
        display: none;
    }
}

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

    .work_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: 400px;
    left: 0;
    z-index: 1;
}

@media only screen and (max-width: 800px) {
    .mv-catch {
        position: relative;
        top: auto;
        left: auto;
        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 {
    display: block;
    font-family: "shippori", serif;
    font-size: 3.4rem;
    letter-spacing: 0.2em;
    color: #fff;
    line-height: 1.6;
    text-shadow: 1px 1px 1px #eee
}

.mv-catch-ja02 {
    font-size: 1.8rem;
    color: #eee;
    padding: 10px 0 0;
    letter-spacing: 2px;
    line-height: 1.3
}

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

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

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

.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;

    padding: 0;
    background: linear-gradient(to left, #e77784 50%, #d7c99d 100%);
    -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 {
        padding: 20px 0;
    }
}

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

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

#footer video {
    position: absolute;
    z-index: -99999999;
    width: 100%;
    height: 100%;
    object-fit: cover;
    overflow: hidden;
    top: 0;
    left: 0;
}



#footer a,
#footer p {
    font-size: 1.6rem;
    color: #6d6159;
}

@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;
}

.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: 100px;
    object-fit: contain;
}

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


/* セクション */

.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%;
}

.work_wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    background: rgb(255, 255, 255, 0.3);
    padding: 60px;
    margin: 60px auto;
    max-width: 1200px;
}

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

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

.work_box {
    width: 48%;
}

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

    .work_box,
    .work_wrap img {
        width: 100%;
    }
}

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

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

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

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

.k_box {
    padding: 2em;
    position: relative;
    border: 8px solid #e777844a;
    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: #e77784;
    content: '';
    display: block;
    position: absolute;
    top: -8px;
    left: -8px;
    width: 8px;
    height: 8px;
    z-index: 1;
}

.k_box .box-title {
    color: #e77784;
    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: 0 auto;
}

@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 {

    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_message {
    background: #fff;
    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 screen and (max-width: 530px) {
    div.wpcf7 {
        padding-top: 0;
    }
}

@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;
}

.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(255, 255, 255, 0.9);
    z-index: 9000;
    text-align: center;
}

.nav_menu_sp .gnav {
    margin-bottom: 35px;
}

.nav_menu_sp .gnav a {
    font-weight: 500;
    display: inline-block;
    margin-bottom: 33px;
    font-size: 16px;
    color: #000;
    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: #2271b1;
}

.sp_menu .menuButton {
    position: fixed;
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
    background: linear-gradient(165deg, #e77784, #d7c99d);
    z-index: 10000;
}

.sp_menu .menuButton:hover>span {
    background-color: #fc6060;
}

.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: 9999;
}

@media only screen and (max-width: 800px) {
    .nav_menu_sp.open {
        top: 60px;
        position: fixed;

    }
}

#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: #fff;
    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;
    color: #4b5564;
    background: #ffffffd1;
    position: absolute;
    width: 100%;
}

@media only screen and (max-width: 530px) {
    .footer {}
}

.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 {}
}


/* 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.hpb::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;
        z-index: 9999999;
        position: relative;
    }
}

.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;
    font-size: 12px;
}

.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: #e9e8e2;
}

.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,
.work_ttl,
.att_ttl,
.contact_ttl,
.qa_ttl {
    font-size: 30px;
    font-weight: bold;
    position: relative;
    padding-left: 140px;
    margin-top: 170px;
}

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

    .rec_ttl,
    .menu_ttl,
    .work_ttl,
    .att_ttl,
    .contact_ttl,
    .qa_ttl {
        font-size: 12px;
        padding-left: 0;
        margin-top: 70px;
        line-height: 1.2;
        top: 20px;
        left: 62px;

    }
}

.rec_ttl::before,
.menu_ttl::before,
.work_ttl::before,
.att_ttl::before,
.contact_ttl::before,
.qa_ttl::before {
    display: inline-block;
    font-family: "mrblaketon-pro", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 300%;
    transform: rotate(-5deg);
    position: absolute;
    left: -80px;
    top: -66px;
    z-index: -1;
    white-space: nowrap;
    color: #fff;
}

.att_ttl {
    margin-top: 200px;
}

@media only screen and (max-width: 530px) {
    .att_ttl {
        margin-top: 120px;
    }
}

.rec_ttl::before {
    content: "What job type are you interested in?";
}

.menu_ttl::before {
    content: "Menu";
}

.work_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: 160px 0;
}

#top-sec01 .sec01-en {
    position: absolute;
    top: -45px;
    left: -100px;
    z-index: -1;
}

#top-sec01 .sec01-en span {
    color: #e7778482;
}

@media only screen and (max-width: 800px) {
    #top-sec01 .sec01-en {
        left: 0;
    }

    #top-sec01 .sec01-inner {
        padding: 0;
    }
}

#top-sec01 .sec01_wrap-top {
    width: 100%;
    background: rgb(255, 255, 255, 0.3);
    margin: 0 20px;
    padding: 20px 0;
}

@media only screen and (max-width: 530px) {
    #top-sec01 .sec01_wrap-top {
        margin: 20px;
    }
}

#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;
}


@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: 70%;
        padding: 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;
    }
}

.jobttl {
    font-size: 3rem;
    position: relative;
    text-align: center;
    padding: 1em;
    width: fit-content;
    margin: 100px auto;
}

@media only screen and (max-width: 530px) {
    .jobttl {
        font-size: 2rem;
        line-height: 1.5;
        margin: 0 auto;

    }
}

.jobttl::before,
.jobttl::after {
    position: absolute;
    content: '';
    width: 100px;
    height: 2px;
    background: #686564;
}

.jobttl::before {
    left: 0;
    top: 0;
}

.jobttl::after {
    right: 0;
    bottom: 0;
}

.com_wrap {
    width: 100%;
    max-width: 1080px;
    background: rgb(255, 255, 255, 0.3);
    margin: 20px auto 50px;
    padding: 20px 0;
}

@media only screen and (max-width: 530px) {
    /* .com_wrap {
        padding-right: 50px;
    } */
}

.com_about {
    padding: 0 20px;
}

.com_tbl {
    margin: 0 auto;
    display: flex;
    justify-content: space-around;
}

.com_tbl .first {
    padding-top: 20px;
}

.com_tbl th,
.com_tbl td {
    font-size: 1.6rem;
    letter-spacing: 1.8px;
    line-height: 1.5;
    padding: 20px 5px;
}

.com_tbl th {
    border-right: 1px solid #f0f0f1;
    /* width: 30%; */
}

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

    .com_tbl th,
    .com_tbl td {
        font-size: 1.5rem;
    }

    .com_tbl th {
        width: 30%;
    }

}

.com_tbl td {}

.com-txt,
#privacy .txt-box {
    color: #222222;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    line-height: 2;
}

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

    .com-txt,
    #privacy .txt-box {
        font-size: 1.6rem;
    }
}

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

    .com-txt,
    #privacy .txt-box {
        font-size: 1.5rem;
    }
}

.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;
    }
}

ol.public {
    counter-reset: list;
    list-style-type: none;
    padding: 0;
}

ol.public li {
    position: relative;
    padding: 0 0 0 20px;
    margin: 7px 0;
    font-size: 14px;
    line-height: 30px;
}

ol.public li:before {
    counter-increment: list;
    content: "";
    display: block;
    position: absolute;
    left: 0px;
    height: 10px;
    width: 10px;
    border-radius: 50%;
    background: #787c82;
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.com_wrap p {
    margin: .5em 0 1em 2em;
    letter-spacing: 1.2px;
    line-height: 2;
    font-size: 1.4rem;
}

.com_wrap span {
    padding: 0.25em 0.5em;
    margin-left: 1em;
    color: #494949;
    background: #2271b12e;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 1.2px;
}

.com_wrap h3 {
    padding: 10px;
    font-size: 2rem;
    font-weight: bold;
    border-left: solid 5px #7db4e6;
    margin: 1em 0.5em 3rem 1rem;
    letter-spacing: 1.2px;
    line-height: 1.5;
}

@media only screen and (max-width: 530px) {
    .com_wrap h3 {

        font-size: 1.8rem;
        padding: 5px 30px 0 5px;
    }
}

.com_kv {
    width: 100%;
    text-align: center;
    margin: 30px auto 70px;
}

.com_kv img,

img {
    width: auto;
}

.com_kv_box {
    position: relative;
}

.com_kv02 {
    position: absolute;
    right: 19%;
    top: 15px;
}

@media only screen and (max-width: 530px) {
    .com_about {
        right: 0;
    }

    .com_kv02 {
        width: 55px;
        right: 0%;
    }
}

.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: 70px auto 0;
    flex-direction: row-reverse;
}

#top-sec02 .sec02-flex02 {
    margin: 70px auto 0;
}

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

    #top-sec02 .sec02-flex,
    #top-sec02 .sec02-flex02 {
        flex-direction: column;
        margin: 0;
    }
}

#top-sec02 .sec02-flex02 .flex-right {
    margin-left: 30px;
}

#top-sec02 .flex-right {
    width: 100%;
    max-width: 500px;
}

@media only screen and (max-width: 530px) {
    #top-sec02 .flex-right {
        margin-left: 30px;
    }
}

@media only screen and (min-width: 768px) {
    #top-sec02 .flex-right {
        margin-top: -7px;
    }
}

#top-sec02 .check-item {
    padding-left: 15px;
}

@media only screen and (max-width: 530px) {
    #top-sec02 .check-item {
        padding: 0.25em 0 0 10px;
    }
}

#top-sec02 .check-item:nth-of-type(n+2) {
    margin-top: 5px;
}

#top-sec02 .check-txt {

    font-size: 1.8rem;
    letter-spacing: 0.2em;
    color: #222222;
    line-height: 1.8;
}

@media only screen and (max-width: 800px) {
    #top-sec02 .check-txt {
        font-size: 16px;
        font-size: 1.6rem;
        margin: 5px auto 0;
    }
}

@media only screen and (max-width: 530px) {
    #top-sec02 .check-txt {
        font-size: 1.5rem;
    }
}

.job_title {
    position: relative;
    display: flex;
    font-size: 3rem;
    align-items: flex-end;
    width: 300px;
    margin-bottom: 30px;
}

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

.job_title:before {
    position: absolute;
    content: '';
    height: 15px;
    /*ラインの太さ*/
    width: 100%;
    /*ラインの長さ*/
    background-color: #e7778469;
    /*ラインの色*/
    transform: skew(20deg, 0deg);
    /*ラインの傾斜角度*/
    z-index: -1;
    bottom: -12px;
}

@media only screen and (max-width: 530px) {
    .job_title:before {
        height: 8px;
        bottom: -4px;
    }
}

.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: 0;
    color: #d7c99d;
    font-size: 1.5rem;
    line-height: 3rem;

}

#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;
    text-align: center;
}

@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;
}

.contact-sec {
    font-size: 16px;
    margin: 120px 0 0;

}

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

    .contact-sec {
        margin: 60px 0
    }
}

.contact_page .contact-sec {
    margin: 0;

}

.contact_box {
    margin: 100px auto 0
}

.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: 530px) {
    .contact-sec p.big {
        font-size: 16px;
        margin: 10px 0 0px;
    }

}

.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;
    color: #000;
    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: 530px) {
    .contact-sec-lead {
        font-size: 15px;
        padding: 30px;
    }
}

.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;
}

@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;
    color: #000;
}

.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: 530px) {
    /* .contact-sec-body {
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 90%;
    } */

    .contact-sec-tel-area {
        margin: 20px auto 0;
    }
}

.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;
    color: #000;
}

@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;
    }
}

.topttl {
    position: relative;
    padding-top: .75em;
    font-size: 3rem;
    color: #333333;
    text-align: center;
}

.topttl::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: -1;
    color: #caafa5;
    font-size: 1.5em;
    line-height: 1;
    content: attr(data-word);
    pointer-events: none;
}

.flow_wrap {
    padding: 60px;
    max-width: 1200px;
}

@media only screen and (max-width: 530px) {
    .flow_wrap {
        padding: 0;
    }
}

.jobflow {
    margin: 0 auto;
    padding: 0 60px;
    font-size: 1.6rem;
    max-width: 900px;
}

@media only screen and (max-width: 530px) {
    .jobflow {
        padding: 0;
        font-size: 15px;
    }
}

.jobflow>li {
    list-style-type: none;
    position: relative;
    padding-bottom: 50px;
    display: flex;
    justify-content: space-around;
    align-items: center;

}

@media only screen and (max-width: 530px) {
    .jobflow>li {
        justify-content: center;
        align-items: flex-start;
        padding-bottom: 20px;
    }
}

.jobflow>li:nth-of-type(even)::after {
    content: "";
    position: absolute;
    left: 50px;
    top: 0;
    width: 0;
    height: 100%;
    border-left: 4px dotted #d4d4d4;
}

.jobflow>li:nth-of-type(odd)::before {
    content: "";
    position: absolute;
    left: 50px;
    top: -40px;
    width: 20%;
    height: 40px;
}

.jobflow>li:nth-of-type(odd)::after {
    content: "";
    position: absolute;
    left: 50px;
    top: 50px;
    width: 20%;
    height: calc(100% - 50px);
    border-left: 4px dotted #d4d4d4;
}

.jobflow>li:first-of-type::before, .jobflow>li:last-of-type::after {
    content: unset;
}

.jobflow>li dl {
    display: inline-block;
    vertical-align: top;
    width: calc(100% - 130px);
}

.jobflow>li .flow_p {
    display: inline-block;
    margin: 0;
    width: 100px;
    height: auto;
    margin-right: 20px;
    text-align: center;
    font-weight: bold;
    vertical-align: middle;
    font-size: 2rem;
    line-height: 100px;
    background: #787c82;
    color: #fff;
    border-radius: 100vh;
    position: relative;
    z-index: 1;
}

@media only screen and (max-width: 530px) {
    .jobflow>li .flow_p {
        line-height: 50px;
        width: 50px;
    }
}

.jobflow>li dt {
    display: inline-block;
    margin: 1rem 0 0.5rem;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: .1em;
}

@media only screen and (max-width: 530px) {
    .jobflow>li dt {
        font-size: 1.5rem;
    }
}

.jobflow>li dd {
    margin: 0;
    font-weight: normal;
    line-height: 2;
    letter-spacing: .1em;
}

@media screen and (min-width: 960px) {
    .jobflow>li:nth-of-type(even) {
        margin-left: 20%;
        padding-top: 20px;
    }

    .jobflow>li:nth-of-type(odd)::after {
        border-bottom: 4px dotted #d4d4d4;
    }

    .jobflow>li:nth-of-type(odd)::before {
        border-top: 4px dotted #d4d4d4;
        border-left: 4px dotted #d4d4d4;
    }

    .jobflow>li:nth-of-type(even)::after {
        height: calc(100% - 40px);
    }
}

.for-individual_page {
    max-width: 1200px;
    margin: 0 auto;
}

.support {
    margin: 50px auto 0;
}

.support_wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 60px auto;
}

.item {
    padding: 30px;
    width: 49%;
    background-color: #fff;
}

@media not all and (min-width: 768px) {
    .item {
        width: 100%;
    }

    .item:not(:last-child) {
        margin-bottom: 30px;
    }
}

.item h2 {
    font-size: 2rem;
    margin: 20px auto;
    text-align: center;
}

.item p {
    font-size: 1.6rem;
    line-height: 1.7;
    font-weight: 400;
}

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

.reasons9 {
    position: relative;
    margin: 0 0 45px;
    z-index: 9;
    max-width: 1200px;
    margin: 70px auto;
    padding: 100px 0;
}

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

@media only screen and (max-width: 780px) {
    .reasons9 {
        width: 100%;
        margin: 30px auto;
    }
}

@media only screen and (max-width: 530px) {
    .reasons9 {
        padding: 30px 0;
    }
}

.reasons9:before {
    position: absolute;
    content: "";
    top: 0;
    right: -9999px;
    bottom: 0;
    left: -9999px;
    background: #fff;
    z-index: -1;
}

.reasons9 .info_title_wrap2 .red1 {
    color: #ec6d74;
    font-size: 2.5rem;
}

.reasons9 ul {
    margin: 0;
    letter-spacing: -4px;
    line-height: 18px;
    font-weight: bold;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.list_reasons9,
.list-inline {
    padding-left: 0;
    list-style: none;
}

.reasons9 ul li {
    display: block;
    float: left;
    width: 33.33%;
    min-height: 180px;
    padding: 10px 15px;
    letter-spacing: normal;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center;
    background: #fff;
}

@media only screen and (max-width: 780px) {
    .reasons9 ul li {
        width: 49%;
        margin: 2px auto;
        padding: 10px 10px;
    }
}

@media only screen and (max-width: 530px) {
    .reasons9 ul li {
        display: flex;
        flex-direction: column;
        justify-content: space-between
    }
}

.reasons9 h3,
.reasons9 .about-text article h4,
.about-text article .reasons9 h4 {
    font-size: 2.3rem;
    line-height: 1.2;
    text-align: center;
    margin: 0 0 10px;
    background: #d7c99d;
    color: #fff;
    padding: 5px;
    letter-spacing: 1.2px;
}

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

    .reasons9 h3,
    .reasons9 .about-text article h4,
    .about-text article .reasons9 h4 {
        font-size: 2rem;
    }
}

@media only screen and (max-width: 530px) {
    .reasons9 h3, .reasons9 .about-text article h4, .about-text article .reasons9 h4 {
        font-size: 1.3rem;
    }
}

.reasons9 p {
    margin: 0;
    font-size: 13px;
    font-weight: 500;
    padding: 20px 0;
    font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.reasons9 h3 span,
.reasons9 .about-text article h4 span,
.about-text article .reasons9 h4 span {
    display: block;
    font-size: 17px;
    font-size: 1.21429rem;
    line-height: 28px;
    color: #d20010;
    font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.heading04 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 26px;
    text-align: center;
    padding: 30px 0;
}

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

    .heading04 {
        font-size: 18px;
        padding: 10px 0;
    }
}

.heading04::before,
.heading04::after {
    content: '';
    width: 3px;
    height: 40px;
    background-color: #37474F;
}

.heading04::before {
    margin-right: 30px;
    transform: rotate(-35deg)
}

.heading04::after {
    margin-left: 30px;
    transform: rotate(35deg)
}

.Form {
    margin: 0 auto;
    max-width: 1200px;
    width: 100%;
    text-align: center;
}

/* 
@media screen and (max-width: 480px) {
    .Form {
        margin-top: 40px;
    }
} */

.Form-Item {
    padding-top: 24px;
    padding-bottom: 24px;
    width: 100%;
    display: flex;
    max-width: 1000px;
    align-items: center;
    margin: 0 auto;
}

@media screen and (max-width: 480px) {
    .Form-Item {
        padding-left: 14px;
        padding-right: 14px;
        padding-top: 16px;
        padding-bottom: 16px;
        flex-wrap: wrap;
    }
}

.Form-Item:nth-child(5) {}

.wpcf7 form.sent .wpcf7-response-output {
    text-align: center;
    padding: 1em;
    border: none;
}

.Form-Item-Label {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;

    width: 100%;
    /* max-width: 248px; */
    letter-spacing: 0.05em;
    font-weight: bold;
    font-size: 16px;
}

@media screen and (max-width: 480px) {
    .Form-Item-Label {
        max-width: inherit;
        display: flex;
        align-items: center;
        font-size: 15px;
    }
}

.Form-Item-Label.isMsg {
    margin-top: 8px;
    margin-bottom: auto;
}

@media screen and (max-width: 480px) {
    .Form-Item-Label.isMsg {
        margin-top: 0;
    }
}

.Form-Item-Label-optional {
    border-radius: 6px;
    margin-right: 8px;
    padding-top: 8px;
    padding-bottom: 8px;
    width: 48px;
    display: inline-block;
    text-align: center;
    background: #dcdcdc;
    color: #000;
    font-size: 14px;
}

.Form-Item-Label-Required {
    border-radius: 6px;
    margin-right: 8px;
    padding-top: 8px;
    padding-bottom: 8px;
    width: 48px;
    display: inline-block;
    text-align: center;
    background: #545454;
    color: #fff;
    font-size: 14px;
}

@media screen and (max-width: 480px) {
    .Form-Item-Label-optional, .Form-Item-Label-Required {
        border-radius: 4px;
        padding-top: 4px;
        padding-bottom: 4px;
        width: 32px;
        font-size: 10px;
    }
}

.Form-Item-Input {
    border: 1px solid #ddd;
    border-radius: 6px;
    margin-left: 40px;
    padding-left: 1em;
    padding-right: 1em;
    height: 48px;
    flex: 1;
    width: 100%;
    font-size: 16px;
    width: 500px;
    max-width: 500px;
    background: #eaedf2;
    font-size: 16px;
}

@media screen and (max-width: 530px) {
    .Form-Item-Input {
        margin-left: 0;
        margin-top: 18px;
        height: 40px;
        flex: inherit;
        font-size: 15px;
        width: 95vw;
    }
}

.Form-Item-Textarea {
    border: 1px solid #ddd;
    border-radius: 6px;
    margin-left: 40px;
    padding: 1em;
    height: 216px;
    flex: 1;
    width: 100%;
    max-width: 410px;
    background: #eaedf2;
    font-size: 16px;
    width: 500px;
    max-width: 500px;
}

@media screen and (max-width: 530px) {
    .Form-Item-Textarea {
        margin-top: 18px;
        margin-left: 0;
        height: 200px;
        flex: inherit;
        font-size: 15px;
        width: 95vw;
    }
}

.Form-Btn {
    border-radius: 6px;
    margin-top: 32px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 20px;
    padding-bottom: 20px;
    width: 280px;
    display: block;
    letter-spacing: 0.05em;
    background: #545454;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    font-family: unset;

}

@media screen and (max-width: 480px) {
    .Form-Btn {
        margin-top: 24px;
        padding-top: 8px;
        padding-bottom: 8px;
        width: 160px;
        font-size: 16px;
    }
}

.contact_page .contact-sec-tel-area {
    width: 100%;

}

.contact_page .contact-sec-body {
    display: flex;
    width: 100%;
    margin: auto;
    flex-direction: column;
}

.contactttl {
    font-size: 26px;
    padding: 30px 0;

}

.contactttl::before {
    content: attr(data-en);
    display: block;
    color: #498ee0;
    font-size: 18px;
    margin-bottom: 10px;
}

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

    .contactttl::before {
        margin-bottom: 20px;
    }
}

.contactttl::after {
    content: '';
    display: block;
    width: 40px;
    height: 1px;
    margin-top: 10px;
    background-color: #498ee0;
}

.video_box {
    position: relative;
    margin: 0 0 50px;
    filter: saturate(0.5);
}

.video_box video {
    width: 100%;
    height: 600px;
    object-fit: cover;
    overflow: hidden;
    object-position: top;
}

@media only screen and (max-width: 530px) {
    .video_box video {
        height: 200px;
    }
}

.top .topCreative {
    padding: 15rem 0;
    position: relative;
}

@media only screen and (max-width: 530px) {
    .top .topCreative {
        padding: 0;
    }
}

.top .topCreative .top_ttl {
    text-align: center;
    width: 100%;
    margin: 50px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.top .topCreative h2 {
    font-weight: 900;
    font-size: 5.25rem;
    margin-bottom: 1.875rem;
}

@media only screen and (max-width: 530px) {
    .top .topCreative h2 {
        font-size: 3rem;
        text-align: center;
        line-height: 1.5;
    }
}

.top .topCreative .description {
    font-weight: 900;
    font-size: 1.8rem;
}

.container-min {
    margin: 0 auto;
    padding: 0 1.5rem;
}

.container-min p {
    font-size: 1.6rem;
    text-align: center;
    line-height: 2;
    letter-spacing: 1px;
}

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

.sample_btn {
    display: block;
    width: 250px;
    text-align: center;
    text-decoration: none;
    line-height: 60px;
    outline: none;
    color: #FFFFFF;
    background: linear-gradient(165deg, #e77784, #d7c99d);
    background-position: 0% 50%;
    background-size: 200% auto;
    transition: all 0.3s ease-out;
    margin: 70px auto 0;
    font-size: 1.6rem;
    border-radius: 15px 0;
}

@media only screen and (max-width: 530px) {
    .sample_btn {
        margin: 30px auto
    }
}

.back_wrap {
    position: relative;
}

.back_logo {
    margin: auto;
    max-width: 600px;
    width: 100%;
    height: 600px;
    background-image: url(img/wplogo_b.png);
    background-size: contain;
    transform: rotate(30deg);
    position: absolute;
    top: 50px;
    background-repeat: no-repeat;
    right: 5px;
    opacity: 0.4;
}

.back_bp {
    margin: auto;
    max-width: 600px;
    width: 100%;
    height: 600px;
    background-image: url(img/bp.png);
    background-size: contain;
    transform: rotate(-30deg);
    position: absolute;
    top: 50px;
    background-repeat: no-repeat;
    left: 5px;
    opacity: 0.4;
}

.rec_btn {
    margin: auto;
}

.recbox-btn {
    text-align: center;
    margin: auto;

}

a.btn-radius-solid {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 350px;
    margin: 20px auto;
    padding: .9em 2em;
    border: none;
    border-radius: 5px;
    background: linear-gradient(165deg, #e77784, #d7c99d);
    color: #fff;
    font-weight: 600;
    font-size: 2.2rem;
}

a.btn-radius-solid:hover {
    animation: anima-button-41 2s linear infinite;
}

@keyframes anima-button-41 {
    7% {
        transform: translateY(-15px);
    }

    15% {
        transform: translateY(0);
    }

    20% {
        transform: translateY(-7px);
    }

    25% {
        transform: translateY(0);
    }
}

a.btn-radius-solid::after {
    transform: rotate(45deg);
    width: 5px;
    height: 5px;
    margin-left: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    content: '';
}

.circle_btn03 {
    position: fixed;
    padding: 1em 2em;
    transition: all 0.2s ease;
    border: none;
    background: none;
    text-decoration: none;
    display: inline-block;
    writing-mode: vertical-lr;
    right: 80px;
    font-size: 1.8rem;
    z-index: 1000;
}

@media only screen and (max-width: 1200px) {
    .circle_btn03 {
        display: none;
    }
}

.circle_btn03:before {
    content: "";
    position: absolute;

    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    display: block;
    border-radius: 100vh;
    background: linear-gradient(165deg, #e77784, #d7c99d);
    /* 背景色 */
    width: 4em;
    /* 丸の横幅 */
    height: 4em;
    /* 丸の高さ */
    transition: all 0.3s ease;

    top: 0;
    left: 50%;

}

.circle_btn03 span {
    position: relative;
    font-weight: 700;
    /* 文字の太さ */
    letter-spacing: 0.05em;
    /* 文字間隔 */
    color: #000;
    /* 文字色 */
}

/* マウスオーバーした際のデザイン */
.circle_btn03:hover:before {
    height: calc(100% + 0.5em);
}

.circle_btn03:active {
    transform: scale(0.95);
}