@charset "UTF-8";

/*---------------------------------------------

	共通パーツ

---------------------------------------------*/
/* ↓ 色とテキストの定義 ------------------------*/
html {
    scroll-behavior: smooth;
    font-size: 14px;
}

@media screen and (min-width: 1316px) {
    html {
        font-size: 15px;
    }
}

@media screen and (min-width: 1450px) {
    html {
        font-size: 16px;
    }
}

@media screen and (max-width: 540px) {
    html {
        font-size: 3.5vw;
        touch-action: manipulation;
    }
}

body {
    color: #333333;
    letter-spacing: 0.08rem;
    line-height: 1.5;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    font-family: "Noto Sans SC", 'Roboto', 'Noto Sans JP', "Hiragino Sans GB", Tahoma, Helvetica, Arial, "Microsoft Yahei", "微软雅黑体", STXihei, "华文细黑", HiraKakuProN-W3, sans-serif;
    font-weight: 400;
    /*bold700 Medium 500 regular400 light 300*/
    position: relative;
    background: white;
}

.roboto {
    font-family: 'Roboto';
}

a:hover {
    opacity: 0.7;
}

.whiteframe {
    text-shadow: 4px 4px 0 #FFF, -4px -4px 0 #FFF,
        -4px 4px 0 #FFF, 4px -4px 0 #FFF,
        0px 4px 0 #FFF, 0 -4px 0 #FFF,
        -4px 0 0 #FFF, 4px 0 0 #FFF;
}

.caveat {
    font-family: 'Caveat', cursive;
}

.pcWidth-max2 {
    max-width: 1140px;
    margin: auto;
}

/*---------------------------------------------

	ファーストビュー

---------------------------------------------*/
/* ↓ ナビゲーションバー ------------------------*/
.header-logo {
    position: absolute;
    top: 1.5rem;
    left: 1.8rem;
}

@media screen and (max-width: 1024px) {
    .header-logo {
        position: absolute;
        top: 1.1rem;
        left: 0.9rem;
    }
}

@media screen and (max-width: 540px) {
    .header-logo {
        position: absolute;
        top: 0.8rem;
        left: 0.8rem;
    }
}

.header-logo img {
    width: 83%;
    height: auto;
}

@media screen and (max-width: 1024px) {
    .header-logo img {
        width: 83%;
        height: auto;
    }
    .fv-btn {
        width: 87vw;
    }
}

@media screen and (max-width: 1450px) and (max-height: 420px) {
    .header-logo img {
        width: 83%;
        height: auto;
    }
}

@media screen and (max-width: 540px) {
    .header-logo img {
        width: 51%;
        height: auto;
    }
}

/*ヘッダーメニュー*/
.header-menu {
    position: absolute;
    top: 0rem;
    right: 2rem;
    letter-spacing: normal;
    display: flex;
}


@media screen and (max-width: 1024px) {
    .header-menu {
        position: absolute;
        top: 0rem;
        right: 1rem;
    }
}

@media screen and (max-width: 540px) {
    .header-menu {
        position: absolute;
        top: 1rem;
        right: 1rem;
    }
}

.header-menu a {
    text-decoration: none;
    display: flex;
    background-color: #FF6B3B;
    color: white;
    padding: 0.2rem 0.6rem;
    border-radius: 0 0 0.5rem 0.5rem;
    margin-left: 0.8rem;
}

@media screen and (max-width: 540px) {
    .header-menu a {
        display: flex;
        color: #333;
        font-size: 0.8rem;
        background: none;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        margin-left: 0rem;
    }
}

.header-menu a img {
    width: 1.2rem;
    margin-right: 0.5rem;
}

@media screen and (max-width: 540px) {
    .header-menu a img {
        width: 1.8rem;
        margin-right: 0rem;
    }

}

/* ↓ ファーストビュー ------------------------*/
.fv {
    height: 86vh;
    width: 100%;
    background-image: url(/jp/office/international/img/top-bg.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 1200px 600px;
    display: flex;
    align-items: center;
    justify-content: center;
    touch-action: manipulation;
}
.fv-btn {
    position: relative;
    width: 1000px;
    margin: auto;
}
.fv-btn-left {
    position: absolute;
    left: 4%;
    top: calc(0px - 50px - (43vh - 360px));
}
.fv-btn-left a {
    text-decoration: none;
    opacity: 1;
}
.fv-btn-left-img {
    width: 300px;
}
.fv-btn-right {
    position: absolute;
    right: 4%;
    top: calc(0px - 50px - (43vh - 360px));
}
.fv-btn-right a {
    text-decoration: none;
    opacity: 1;
}
.fv-btn-right-img {
    width: 300px;
}
.contact-btn {
    display: none;
    width: 100%;
    position: fixed;
    z-index: 99;
    right: 0px;
    bottom: 0px;
}
.contact-btn-img {
    width: 100%;
}
.contact-btn a:hover {
    opacity: 1;
}
.top-btn {
    z-index: 99;
    position: fixed;
    right: 50px;
    bottom: 200px;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.top-btn a:hover {
    opacity: 1;
}
.top-btn-img {
    width: 50px;
}
.tokyo-btn-pc {
    z-index: 99;
    position: fixed;
    right: 35px;
    bottom: 145px;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.tokyo-btn-pc a:hover {
    opacity: 1;
}
.tokyo-btn-img-pc {
    width: 75px;
}
.osaka-btn-pc {
    z-index: 99;
    position: fixed;
    right: 35px;
    bottom: 90px;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.osaka-btn-pc a:hover {
    opacity: 1;
}
.osaka-btn-img-pc {
    width: 75px;
}
.contact-btn-pc {
    z-index: 99;
    position: fixed;
    right: 35px;
    bottom: 25px;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.contact-btn-pc a:hover {
    opacity: 1;
}
.contact-btn-img-pc {
    width: 75px;
}
.contact-btn {
    width: 100%;
    position: fixed;
    z-index: 99;
    right: 0px;
    bottom: 0px;
    display: none;
}
.contact-btn-img {
    width: 100%;
}
.contact-btn a:hover {
    opacity: 1;
}
.tokyo-btn {
    z-index: 99;
    position: fixed;
    right: 20px;
    bottom: 32vw;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.tokyo-btn a:hover {
    opacity: 1;
}
.tokyo-btn-img {
    width: 25vw;
}
.osaka-btn {
    z-index: 99;
    position: fixed;
    right: 20px;
    bottom: 18vw;
    cursor: pointer;
    text-align: right;
    visibility: hidden;
}
.osaka-btn a:hover {
    opacity: 1;
}
.osaka-btn-img {
    width: 25vw;
}
#toppc.show {
    visibility: visible;
}
#top1.show {
    visibility: visible;
}
#top2.show {
    visibility: visible;
}
#top3.show {
    visibility: visible;
}
.secRabbit {
    position: absolute;
    width: 7.5rem;
    top: -1rem;
    right: 9rem;
}
.eheyano1-rabbit {
    display: none;
}
@media screen and (max-width: 1450px) {
    .fv-btn-left-img {
        width: 285px;
    }
    .fv-btn-right-img {
        width: 285px;
    }
    .fv-btn {
        position: relative;
        width: 965px;
        height: 50px;
        margin: auto;
    }
    .fv-btn-left {
        position: absolute;
        left: 4%;
        top: calc(0px - 50px - (43vh - 329px));
    }
    .fv-btn-right {
        position: absolute;
        right: 4%;
        top: calc(0px - 50px - (43vh - 329px));
    }
}
@media screen and (max-width: 1316px) {
    .fv-btn-left-img {
        width: 270px;
    }
    .fv-btn-right-img {
        width: 270px;
    }
    .fv-btn {
        position: relative;
        width: 920px;
        height: 50px;
        margin: auto;
    }
    .fv-btn-left {
        position: absolute;
        left: 4%;
        top: calc(0px - 50px - (43vh - 300px));
    }
    .fv-btn-right {
        position: absolute;
        right: 4%;
        top: calc(0px - 50px - (43vh - 300px));
    }
}
@media screen and (max-width: 950px) {
    .header-menu {
        display: none;
    }
    .display-fade-out{
        animation-name: popUpBarFadeOut;
        animation-duration: 1s;
        animation-fill-mode: both;
    }
    .secRabbit {
        display: none !important;
    }
    .eheyano1-rabbit {
        position: absolute;
        top: -5rem;
        width: 144px;
        right: -1.5rem;
        display: block;
    }
    @keyframes popUpBarFadeOut{
    0%{
        opacity:1
    }
    to{
        opacity:0;
        transform:translateY(100%)
    }
    }
    #top1.show {
        visibility: hidden;
    }
    #top2.show {
        visibility: hidden;
    }
    #top3.show {
        visibility: hidden;
    }
    .fv-btn {
        display: none;
    }
    .tokyo-btn-pc {
        visibility: hidden;
    }
    .osaka-btn-pc {
        visibility: hidden;
    }
    .contact-btn-pc {
        visibility: hidden;
    }
    .contact-btn {
        width: 100%;
        position: fixed;
        z-index: 99;
        right: 0px;
        bottom: 0px;
        display: block;
    }
    .contact-btn-img {
        width: 100%;
    }
    .contact-btn a:hover {
        opacity: 1;
    }
    .top-btn {
        z-index: 99;
        position: fixed;
        right: 10vw;
        bottom: 47vw;
        cursor: pointer;
        text-align: right;
        visibility: hidden;
    }
    .top-btn a:hover {
        opacity: 1;
    }
    .top-btn-img {
        width: 10vw;
    }
    .tokyo-btn {
        z-index: 99;
        position: fixed;
        right: 20px;
        bottom: 32vw;
        cursor: pointer;
        text-align: right;
        visibility: visible;
    }
    .tokyo-btn a:hover {
        opacity: 1;
    }
    .tokyo-btn-img {
        width: 25vw;
    }
    .osaka-btn {
        z-index: 99;
        position: fixed;
        right: 20px;
        bottom: 18vw;
        cursor: pointer;
        text-align: right;
        visibility: visible;
    }
    .osaka-btn a:hover {
        opacity: 1;
    }
    .osaka-btn-img {
        width: 25vw;
    }
}
@media screen and (max-width: 915px) {
    .fv {
        background-image: url(/jp/office/international/img/top-bg.svg);
        background-size: 100% auto;
    }
}

@media screen and (min-width: 1316px) {
    .fv {
        background-size: 1316px 658px;
    }
}

@media screen and (min-width: 1450px) {
    .fv {
        background-size: 1450px 720px;
    }
}

/*iPad縦*/
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
    .fv {
        background-image: url(/jp/office/international/img/top-bg.svg);
        background-size: 100% auto;
        height: 65vh;
    }
}

@media screen and (max-height: 620px) {
    .fv {
        background-image: url(/jp/office/international/img/fv-landscape.svg);
        background-size: 100% auto;
    }
}

/*スマホ*/
@media screen and (max-width: 540px) {
    .fv {
        height: 78vh;
        background-image: url(/jp/office/international/img/sp-top.svg);
        background-size: 100% auto;
    }
    .top-btn {
        right: 12vw;
    }
}

/*スマホ（iPhoneX以上の縦幅）*/
@media screen and (max-width: 540px) and (min-height: 600px) {
    .fv {
        height: 77vh;
        background-image: url(/jp/office/international/img/sp-top.svg);
        background-size: 100% auto;
    }
}

.fv-box {
    width: 350px;
    height: 300px;
    /*    border: 1px solid;*/
    margin-bottom: 20px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

@media screen and (max-width: 915px) {
    .fv-box {
        width: 38.2vw;
        height: 32.8vw;
        margin-bottom: 2vw;
    }
}

@media screen and (min-width: 1316px) {
    .fv-box {
        width: 384px;
        height: 330px;
    }
}

@media screen and (min-width: 1450px) {
    .fv-box {
        width: 423px;
        height: 362px;
    }
}

@media screen and (max-height: 620px) {
    .fv-box {
        margin-bottom: 0px;
        margin-top: 2vh;
    }
}

@media screen and (max-width: 540px) {
    .fv-box {
        width: 68vw;
        height: 56vw;
    }
}

/*メインタイトル*/
.fvBox-maintitle {
    margin-bottom: 1.4rem;
    font-size: 1.4rem;
    letter-spacing: 0.05rem;
}

@media screen and (max-width: 915px) {
    .fvBox-maintitle {
        font-size: 1rem;
    }
}

@media screen and (max-width: 800px) and (max-height: 420px) {
    .fvBox-maintitle {
        font-size: 0.8rem;
        margin-bottom: 1rem;
    }
}

@media screen and (max-width: 540px) {
    .fvBox-maintitle {
        font-size: 1.1rem;
        margin-bottom: 1rem;
    }
}

/*メインタイトル（小）*/
.fvBox-maintitle-s {
    margin-bottom: 1.4rem;
    font-size: 1.1rem;
    letter-spacing: 0.05rem;
}

@media screen and (max-width: 915px) {
    .fvBox-maintitle-s {
        font-size: 0.9rem;
    }
}

@media screen and (max-width: 800px) and (max-height: 420px) {
    .fvBox-maintitle-s {
        font-size: 0.7rem;
        margin-bottom: 1rem;
    }
}

@media screen and (max-width: 540px) {
    .fvBox-maintitle-s {
        font-size: 0.9rem;
    }
}

/*サブタイトル*/
.fvBox-subtitle {
    font-size: 1.75rem;
    line-height: 1.2;
    letter-spacing: normal;
    color: #ff6b3b;
    margin-bottom: 1.2rem;
    background-color: white;
    padding: 0.25rem 0;
}

.fvBox-subtitle span {
    font-size: 2.6rem;
}

@media screen and (max-width: 915px) {
    .fvBox-subtitle {
        font-size: 1.3rem;
    }

    .fvBox-subtitle span {
        font-size: 2rem;
    }
}

@media screen and (max-width: 800px) and (max-height: 420px) {
    .fvBox-subtitle {
        font-size: 1rem;
        margin-bottom: 0.6rem;
    }

    .fvBox-subtitle span {
        font-size: 1.7rem;
    }
}

@media screen and (max-width: 540px) {
    .fvBox-subtitle {
        font-size: 1.3rem;
        margin-bottom: 1rem;
    }

    .fvBox-subtitle span {
        font-size: 2.2rem;
    }
}

/*キャッチ*/
.fvBox-maincatch {
    font-size: 1.5rem;
    margin-bottom: 0.2rem;
}

.fvBox-subcatch {
    letter-spacing: normal;
    font-size: 1.1rem;
    line-height: 1.4;
}

@media screen and (max-width: 800px) and (max-height: 420px) {
    .fvBox-maincatch {
        font-size: 1rem;
        margin-bottom: 0.1rem;
    }

    .fvBox-subcatch {
        font-size: 0.9rem;
        line-height: 1.2;
    }
}

/*キャッチ（小）*/
.fvBox-maincatch-s {
    font-size: 1.3rem;
    margin-bottom: 0.2rem;
}

.fvBox-subcatch-s {
    letter-spacing: normal;
    font-size: 0.9rem;
    line-height: 1.4;
}

@media screen and (max-width: 800px) and (max-height: 420px) {
    .fvBox-maincatch-s {
        font-size: 0.9rem;
        margin-bottom: 0.1rem;
    }

    .fvBox-subcatch-s {
        font-size: 0.8rem;
        line-height: 1.2;
    }
}

/* ↓ カミングスーン  ------------------------*/
.sec-comingsoon {
    background-color: #ff6d3b;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 14vh;
}

/*iPad縦*/
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
    .sec-comingsoon {
        height: 35vh;
    }
}

/*スマホ*/
@media screen and (max-width: 540px) {
    .sec-comingsoon {
        height: 22vh;
        padding-bottom: 5.5rem;
    }
}

/*スマホ（iPhoneX以上の縦幅）*/
@media screen and (max-width: 540px) and (min-height: 600px) {
    .sec-comingsoon {
        height: 22vh;
        padding-bottom: 3rem;
    }
}

.secComingsoon-title {
    height: 50%;
    max-height: 4rem;
}

@media screen and (max-width: 540px) {
    .secComingsoon-title {
        height: 30%;
        max-height: 2.2rem;
    }
}

/*---------------------------------------------

	セクション ｜ 選ばれる理由

---------------------------------------------*/
/* ↓ 共通コンテンツ横幅とマージン ------------------------*/
/*pcの横幅*/
.pcWidth-xl {
    width: 1024px;
    max-width: 94%;
    margin: 0 auto;
}

.pcWidth-l {
    width: 960px;
    max-width: 94%;
    margin: 0 auto;
}

.pcWidth-m {
    width: 900px;
    max-width: 94%;
    margin: 0 auto;
}

.pcWidth-s {
    width: 760px;
    max-width: 98%;
    margin: 0 auto;
}

@media screen and (min-width: 1450px) {
    .pcWidth-xl {
        width: 1216px;
    }

    .pcWidth-l {
        width: 1152px;
    }

    .pcWidth-m {
        width: 1080px;
    }

    .pcWidth-s {
        width: 912px;
    }
}

/*spの横幅*/
@media screen and (max-width: 540px) {
    .spWidth-max {
        max-width: 100%;
    }

    .spWidth-l {
        max-width: 94%;
    }

    .spWidth-m {
        max-width: 88%;
    }

    .spWidth-s {
        max-width: 78%;
    }
}

@keyframes fuwafuwa {
    0% {
        transform: translate3d(0, 0.3rem, 0);
    }

    50% {
        transform: translate3d(0, -0.3rem, 0);
    }

    100% {
        transform: translate3d(0, 0.3rem, 0);
    }
}

.sec-choose {
    padding-bottom: 6rem;
}
@media screen and (min-width: 1450px) {
    .sec-choose {
        padding: 3rem 0 4rem 0;
    }
}
@media screen and (max-width: 540px) {
    .sec-choose {
        padding: 3rem 0 4rem 0;
    }
}

.sec-titles {
    text-align: center;
    margin-bottom: 3rem;
}

@media screen and (max-width: 540px) {
    .sec-titles {
        text-align: center;
        margin-bottom: 1.8rem;
    }
}

.sec-title {
    font-size: 2.9rem;
    line-height: 1.2;
    margin-bottom: 0.4rem;
    font-weight: 700;
    font-family: 'PT Sans', sans-serif;
}
.shop-title {
    padding: 0 0 4rem 0;
    text-align: center;
}
@media screen and (max-width: 540px) {
    .sec-title {
        font-size: 1.8rem;
    }
}

.sec-titlebar {
    height: 4px;
}
.shop-title-image {
    width: 500px;
}
@media screen and (max-width: 540px) {
    .sec-titlebar {
        height: 2px;
    }
    .shop-title-image {
        width: 250px;
    }
}

.sec-content {
    position: relative;
}

.secChooseDeco-l {
    position: absolute;
    width: 10rem;
    top: 0;
    left: 0;
}

.secChooseDeco-r {
    position: absolute;
    width: 10rem;
    top: 0;
    right: 0;
}

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

    .secChooseDeco-r {
        display: none !important;
    }
}


.sec-explain {
    text-align: center;
    font-weight: 300;
    font-size: 1.8rem;
}

@media screen and (max-width: 540px) {
    .sec-explain {
        font-size: 1.3rem;
        font-weight: 400;
    }
}

.secChoose-fukidashis {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    margin-top: 2rem;
    height: 10rem;
}

@media screen and (max-width: 540px) {
    .secChoose-fukidashis {
        height: 20rem;
        width: 90%;
        margin: 0 auto;
        margin-top: 1rem;
    }
}

.secChoose-fukidashi {
    width: 14.2%;
    height: 10rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media screen and (max-width: 540px) {
    .secChoose-fukidashi {
        width: 33%;
        height: auto;
    }
}

.secChoose-fukidashi:nth-child(even) {
    padding-top: 3rem;
}

@media screen and (max-width: 540px) {
    .secChoose-fukidashi:nth-child(even) {
        padding-top: 1.5rem;
    }
}

a.secChoose-fukidashi {
    cursor: pointer;
}

.secChoose-fukidashi img {
    width: 110%;
    transition: all 0.4s ease 0s;
}

.secChoose-fukidashi img:hover {
    width: 140%;
    z-index: 5;
    transition: all 0.4s ease 0s, width all 0.4s ease 0s;
}

@media screen and (max-width: 540px) {
    .secChoose-fukidashi img:hover {
        width: 120%;
        z-index: 5;
        transition: all 0.4s ease 0s, width all 0.4s ease 0s;
    }
}

@supports (-ms-ime-align: auto) {
    .secChoose-fukidashi img {
        width: 110%;
        transition: none;
    }

    .secChoose-fukidashi img:hover {
        width: 140%;
        z-index: 5;
        transition: none;
    }

    @media screen and (max-width: 540px) {
        .secChoose-fukidashi img:hover {
            width: 120%;
            z-index: 5;
            transition: none;
        }
    }

}

/* for IE 11 */
@media all and (-ms-high-contrast:none) {

    *::-ms-backdrop,
    .secChoose-fukidashi img {
        width: 110%;
        transition: none;
    }

    .secChoose-fukidashi img:hover {
        width: 140%;
        z-index: 5;
        transition: none;
    }

    @media screen and (max-width: 540px) {
        .secChoose-fukidashi img:hover {
            width: 120%;
            z-index: 5;
            transition: none;
        }
    }
}

.secChoose-fukidashi.current img:hover {
    width: 110%;
}

.secChoose-fukidashi:hover {
    opacity: 1;
}

/* ↓ e-heya.net  ------------------------*/
.eheyano1 {
    border: 4px solid #C70A2F;
    border-radius: 1rem;
    position: relative;
    margin-top: 5rem;
    text-align: center;
    padding: 2.6rem 4rem;
}

@media screen and (max-width: 540px) {
    .eheyano1 {
        padding: 2.6rem 2rem;
    }
}

.eheyano1-badge {
    width: 10rem;
    position: absolute;
    top: -4rem;
    left: -4rem;
}

@media screen and (max-width: 1030px) {
    .eheyano1-badge {
        left: -1rem;
        width: 8rem;
    }
}

.eheyano1-title {
    width: 16rem;
    margin-bottom: 0.5rem;
}


@media screen and (max-width: 820px) {
    .eheyano1-title {
        width: 16rem;
        margin-bottom: 0.5rem;
    }
}


@media screen and (max-width: 540px) {
    .eheyano1-title {
        width: 10.1rem;
    }
}

.eheyano1-sentence {
    font-weight: 700;
    font-size: 1.9rem;
    letter-spacing: 0.04rem;
    margin-bottom: 1rem;
}

@media screen and (max-width: 540px) {
    .eheyano1-sentence {
        font-size: 1.8rem;
    }
}

.eheyano1-subsentence {
    letter-spacing: 0.04rem;
    font-size: 12pt;
}

.eheyano1-sentence span {
    background: linear-gradient(transparent 60%, #FFBD02 60%);
}

/*---------------------------------------------

	セクション ｜ 何ができるのか？

---------------------------------------------*/
.sec-cando {
    background-color: #FFBD02;
    padding: 6rem 0 7rem 0;
}

@media screen and (max-width: 540px) {
    .sec-cando {
        padding: 4rem 0 6rem 0;
    }
}

.secCando-circles {
    display: flex;
    justify-content: center;
    text-align: center;
}

.secCandoCircle-box {
    width: 20rem;
    display: block;
    margin-right: 2rem;
}

@media screen and (max-width: 980px) {
    .secCandoCircle-box {
        width: 15rem;
        display: block;
        margin-right: 1rem;
    }
}

@media screen and (max-width: 720px) {
    .secCandoCircle-box {
        width: 12rem;
        display: block;
        margin-right: 2rem;
    }
}


@media screen and (max-width: 540px) {
    .secCandoCircle-box {
        width: 20vw;
        display: block;
        margin-right: 2rem;
    }
}

.secCandoCircle-box:last-child {
    margin-right: 0rem;
}

.secCando-circle {
    display: inline-block;
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    background-color: white;
    position: relative;
    box-shadow: 0px 0px 6px 1px rgba(194, 192, 190, 0.6);
}

@media screen and (max-width: 980px) {
    .secCando-circle {
        width: 15rem;
        height: 15rem;
    }
}

@media screen and (max-width: 720px) {
    .secCando-circle {
        width: 12rem;
        height: 12rem;
    }
}


@media screen and (max-width: 540px) {
    .secCando-circle {
        display: inline-block;
        width: 20vw;
        height: 20vw;
    }
}

.secCando-circleinner {
    display: inline-block;
    left: 0;
    top: 2rem;
    width: 20rem;
    position: absolute;
}

@media screen and (max-width: 980px) {
    .secCando-circleinner {
        width: 15rem;
        top: 1rem;
    }
}

@media screen and (max-width: 720px) {
    .secCando-circleinner {
        width: 12rem;
        top: 1rem;
    }
}

@media screen and (max-width: 540px) {
    .secCando-circleinner {
        position: absolute;
        left: 0;
        top: 50%;
        width: 20vw;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}

.secCandoCircle-num {
    font-size: 5rem;
    text-align: center;
    padding-right: 2rem;
    line-height: 1;
    margin-bottom: 0.5rem;
}

@media screen and (max-width: 720px) {
    .secCandoCircle-num {
        font-size: 3.5rem;
        padding-right: 0.5rem;
    }
}

@media screen and (max-width: 540px) {
    .secCandoCircle-num {
        font-size: 3rem;
        padding-right: 0.5rem;
    }
}

.secCandoCircle-text {
    width: 80%;
    margin: 0 auto;
    line-height: 1.4;
    font-weight: 700;
    font-size: 1.4rem;
    color: #333333;
}

@media screen and (max-width: 980px) {
    .secCandoCircle-text {
        width: 80%;
        margin: 0 auto;
        line-height: 1.4;
        font-size: 1.2rem;
    }
}

@media screen and (max-width: 720px) {
    .secCandoCircle-text {
        width: 80%;
        margin: 0 auto;
        line-height: 1.4;
        font-size: 0.9rem;
    }
}

.secCandoCircle-text-s {
    width: 80%;
    margin: 0 auto;
    line-height: 1.2;
    font-weight: 700;
    font-size: 1.2rem;
    color: #333333;
}

@media screen and (max-width: 980px) {
    .secCandoCircle-text-s {
        width: 80%;
        margin: 0 auto;
        line-height: 1.2;
        font-size: 1rem;
    }
}

@media screen and (max-width: 720px) {
    .secCandoCircle-text-s {
        width: 80%;
        margin: 0 auto;
        line-height: 1.1;
        font-size: 0.8rem;
    }
}

.blue {
    color: #009DDA;
}

.orange {
    color: #FF6B3B;
}

.green {
    color: #78B12D;
}

.secCandoCircle-arrow {
    display: block;
    margin-top: 1rem;
    width: 100%;
    height: 4rem;
    text-align: center;
    transition: all 0.5s ease 0s;
}

.secCandoCircle-arrow img {
    width: 2rem;
}

.secCandoCircle-box:hover .secCandoCircle-arrow {
    padding-top: 1rem;
    transition: all 0.5s ease 0s;
}

.secCando-box {
    display: flex;
    padding: 2rem 4rem;
    background-color: white;
    border-radius: 1.6rem;
    position: relative;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

@media screen and (max-width: 540px) {
    .secCando-box {
        padding: 3rem 2rem 2rem 2rem;
    }
}

.secCando-box:last-child {
    margin-bottom: -2rem;
}

.secCandoBox-num {
    position: absolute;
    top: 1.4rem;
    left: 1.4rem;
    font-size: 3rem;
}

@media screen and (max-width: 540px) {
    .secCandoBox-num {
        position: absolute;
        top: 0rem;
        left: 1rem;
        font-size: 2rem;
    }
}

.secCandoBox-sentence {
    width: 55%;
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 2rem 0;
}

@media screen and (max-width: 540px) {
    .secCandoBox-sentence {
        width: 100%;
        padding: 0 0;
    }
}

.secCandoBox-ill {
    width: 45%;
    display: flex;
    align-items: center;
}

@media screen and (max-width: 540px) {
    .secCandoBox-ill {
        width: 100%;
    }
}

.secCandoBox-ill img {
    width: 100%;
}

.secCandoBox-title {
    font-size: 2rem;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 0.6rem;
}

@media screen and (max-width: 540px) {
    .secCandoBox-title {
        font-size: 1.6rem;
        text-align: center;
    }
}

.secCandoBox-explain {
    font-size: 1.2rem;
    font-weight: 300;
    margin-bottom: 2rem;
}

.secCandoBox-list {
    padding-left: 0px;
    margin-left: 0px;
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: normal;
}

.secCandoBox-list li img {
    width: 1.8rem;
    margin-left: 0.5rem;
}

@media screen and (max-width: 540px) {
    .secCandoBox-list {
        font-size: 1.2rem;
        padding-left: 0.5em;
        text-indent: -0.5em;
    }
}

/*---------------------------------------------

	セクション ｜ スタッフ

---------------------------------------------*/
.sec-staff {
    background-color: white;
    padding: 6rem 0 7rem 0;
}

@media screen and (max-width: 540px) {
    .sec-staff {
        padding: 4rem 0 6rem 0;
    }
}

.slider {
    pointer-events: none;
}

.staffcard-outer {
    display: block;
    width: 20rem;
    margin: 0 1rem;
    padding-top: 2rem;
    text-decoration: none;
    color: #333;
}

.staffcard-inner {
    border: 3px solid #D7D7D7;
    color: #333;
    text-align: center;
    border-radius: 1rem;
    position: relative;
}

.staffcard-fukidashi {
    position: absolute;
    top: -2rem;
    right: 0.5rem;
    width: 5rem;
}

.staffcard-sentence {
    padding: 2rem;
}

.staffcard-name {
    font-size: 1.4rem;
    margin-bottom: 0.8rem;
    font-weight: 700;
    line-height: 1.4;
}

.staffcard-message {
    letter-spacing: normal;
    text-align: left;
    font-size: 0.95rem;
    font-weight: 300;
    min-height: 13rem;
}
.staffcard-message2 {
    letter-spacing: normal;
    text-align: left;
    font-size: 0.95rem;
    font-weight: 300;
    min-height: 17rem;
}

@media screen and (max-width: 540px) {
    .staffcard-message {
        font-size: 1.2rem;
        min-height: 15rem;
    }
    .staffcard-message2 {
        font-size: 1.2rem;
        min-height: 20rem;
    }
}


.staffcard-ph img {
    width: 100%;
    border-radius: 0.5rem 0.5rem 0 0;
}

/*---------------------------------------------

	セクション ｜ コンタクト

---------------------------------------------*/
.sec-contact {
    background-color: #FFBD02;
    padding: 6rem 0 7rem 0;
    margin-top: 6rem;
}

@media screen and (max-width: 540px) {
    .sec-contact {
        padding: 4rem 0 6rem 0;
        margin-top: 6rem;
    }
}

input,
button,
textarea,
select {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.secContact-forms {
    margin-top: 2rem;
}

.secContact-text {
    font-size: 1.2rem;
}

/*エラーメッセージ*/
.error {
    font-size: 1rem;
    color: #FF2D3B;
    font-weight: bold;
}

/*一行*/
.formrow {
    display: flex;
    align-items: center;
    font-size: 1.2rem;
    letter-spacing: normal;
    margin-top: 1.5rem;
}

@media screen and (max-width: 540px) {
    .formrow {
        display: block;
        margin-top: 1rem;
    }
}

/*ラベル*/
.form-rabel {
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    width: 12rem;
    min-width: 12rem;
    font-weight: 700;
}

/*フォーム*/
.form-input {
    flex: 1;
}

/*width100%のフォーム*/
.input100 {
    width: 100%;
    background-color: white;
    border-radius: 1rem;
    padding: 2rem;
}

.formInput-flex {
    display: flex;
    align-items: center;
}

/*短いフォーム*/
.form-short {
    display: block;
    position: relative;
    width: 14rem;
    background-color: white;
    border-radius: 1rem;
}

.form-short2 {
    min-width: 14rem;
}

.form-short select {
    padding: 2rem;
    width: 14rem;
}

/*長いフォーム*/
.form-long {
    display: block;
    position: relative;
    width: 100%;
    background-color: white;
    border-radius: 1rem;
}

.form-long select {
    padding: 2rem;
    width: 100%;
}

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

    .form-short,
    .form-short select {
        width: 12rem;

    }

    .form-short2,
    .form-short2 select {
        min-width: 12rem;

    }
}

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

    .form-short,
    .form-short select {
        width: 11.5rem;

    }

    .form-short2,
    .form-short2 select {
        min-width: 11.5rem;

    }
}



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

    .form-short,
    .form-short select {
        width: 40vw;

    }
}

.form-short img, .form-long img {
    position: absolute;
    right: 1rem;
    width: 0.8rem;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.formslash {
    padding: 0 1rem;
}


/*ラジオボタン*/
input[type="radio"] {
    align-items: center;
    margin-top: 4px;
    margin-right: 8px;
    border: 2px solid #ffffff;
    width: 1.4rem;
    height: 1.4rem;
    border-radius: 1rem;
    position: relative;
    top: 4px;
    background-color: white;
}

.vertical-item {
    display: block;
    padding-left: 2.2em;
    text-indent: -2.2em;
}

input[type="radio"]:checked {
    border: 1px solid #ffffff;
    background: url(../img/icon-circle.png) no-repeat;
    background-size: cover;
    background-color: white;
}

.radio-field-text:hover {
    color: #BB9A6B;
}

.radio-field {
    margin-right: 3rem;
    font-weight: 700;
}

.overseaphone {
    margin-right: 1rem;
    display: none;
}

.btn-more {
    display: none;
    align-items: center;
    justify-content: center;
    border: 1px solid;
    text-align: center;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0.5rem;
    font-size: 1.2rem;
    font-weight: 700;
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.btn-more.active {
    display: flex;
}

.btn-more img {
    width: 1rem;
    margin-right: 0.5rem;
}

.form-input textarea {
    width: 100%;
    background-color: white;
    border-radius: 1rem;
    padding: 2rem;
    resize: vertical;
}

/*送信ボタン*/
.confirm_submit {
    cursor: pointer;
    position: relative;
    display: block;
    width: 100%;
    color: white;
    background: #009DDA;
    border-radius: 0.5rem;
    padding: 2rem 1rem;
    margin-top: 2rem;
    font-size: 1.4rem;
    font-weight: bold;
}

.confirm_submit_wrapper {
    position: relative;
    display: block;
}

.confirm_submit_wrapper::after {
    content: "";
    position: relative;
    background: url(../img/icon-finger.svg) no-repeat;
    display: inline-block;
    width: 5rem;
    height: 5rem;
    bottom: 1.5rem;
    left: 46%;
    background-size: cover;
    vertical-align: middle;
    z-index: 100;
}

@media screen and (max-width: 540px) {
    .confirm_submit_wrapper::after {
        content: "";
        position: relative;
        bottom: 0.8rem;
        left: 40%;
    }
}

.confirm_color {
    background: #79a6a9;
}

@media screen and (max-width: 540px) {
    .confirm_submit {
        padding: 1rem 5rem;
    }
}

.confirm_submit:hover {
    color: #009DDA;
    background-color: white;
}

.confirm_submit[disabled] {
    background-color: #C1C1C1;
}

.confirm_submit[disabled]:hover {
    opacity: 1;
}

.attention {
    margin-top: 1.4rem;
    font-size: 0.95rem;
    letter-spacing: normal;
}

@media screen and (max-width: 540px) {
    .attention {
        font-size: 1.1rem;
    }

}


.attention a {
    color: #333;
}

.form-option {
    display: block; 
}

.form-option.active {
    display: block;
}

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

/*---------------------------------------------

	セクション ｜ 店舗画像

---------------------------------------------*/
.secCompany-image {
	margin: 50px auto;
	width: 70%;
}
@media screen and (max-width: 540px) {
	.secCompany-image {
		width: 100%;
	}
}
.secCompany-image-main img {
	width: 100%;
}
.secCompany-image-thumbnail > ul {
	overflow: hidden;
	margin: 0px auto 30px;
}
.secCompany-image-thumbnail > ul > li {
	display: inline-block;
	float: left;
	width: calc(100% / 2);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin-top: 20px;
	margin-bottom: 35px;
	justify-content: space-evenly;
	padding: 10px;
}
.secCompany-image-thumbnail img {
	width: 100%;
	padding: 3px;
	border: 2px solid #FFF;
	box-shadow: 0 0 8px #777;
}

/*---------------------------------------------

	セクション ｜ 会社概要

---------------------------------------------*/
.sec-company {
    background-color: white;
    padding: 6rem 0 4rem 0;
}

@media screen and (max-width: 540px) {
    .sec-company {
        padding: 4rem 0 3rem 0;
    }
}

.secCompany-title {
    font-size: 1.4rem;
    letter-spacing: normal;
    font-weight: 700;
}

.secCompany-content {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

@media screen and (max-width: 540px) {
    .secCompany-content {
        display: block;
        width: 100%;
    }
}

.secCompany-content {
    margin-top: 2rem;
}

.secCompany-sentence {
    width: 60%;
    text-align: left;
    letter-spacing: normal;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

@media screen and (max-width: 1030px) {
    .secCompany-sentence {
        width: 100%;
        padding-top: 0;
        padding-bottom: 1rem;
    }
}

.company-row {
    display: flex;
    margin-top: 2rem;
    font-size: 1.2rem;
}

.company-row:first-child {
    margin-top: 0rem;
}

.secCompany-ill {
    width: 40%;
    display: flex;
    align-items: flex-end;
}

.secCompany-ill img {
    width: 100%;
}

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

    .secCompany-ill {
        width: 85%;
        display: block;
        text-align: right;
        margin: 0 auto;
        margin-bottom: 1rem;
    }
}

.secCompany-item {
    width: 16rem;
    font-weight: 700;
}

@media screen and (max-width: 540px) {
    .secCompany-item {
        width: 30vw;
    }
}

.secCompany-detail {
    flex: 1;
}

.secCompany-map {
    width: 100%;
    margin-top: 1rem;
}

.gmap {
    height: 0;
    overflow: hidden;
    padding-bottom: 56.25%;
    position: relative;
}

.gmap iframe {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
}

.secFooter {
    margin-top: 0rem;
    text-align: center;
}

.copy {
    letter-spacing: normal;
    font-size: 0.8rem;
}

.btn-pagetop {
    width: 2rem;
    margin-top: 1rem;
}

/*---------------------------------------------

	モーダル

---------------------------------------------*/
.btn-modalopen {
    cursor: pointer;
}

.modal-bg {
    position: fixed;
    z-index: 4;
    top: 0;
    left: 0;
    color: #000;
    background: rgba(0, 0, 0, 0.5);
    text-align: center;
    width: 100%;
    display: none;
    opacity: 0;
    transition: opacity .6s ease, visibility .6s ease;
    height: 100vh;
    z-index: 100;
}

.modal {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 4px solid;
}

.modal-box {
    position: relative;
    padding: 3rem 3rem 3rem 3rem;
    border-radius: 1rem;
    width: 50rem;
    max-width: 90vw;
    /*    margin: 0 auto;*/
    background-color: white;
    display: none;
    opacity: 0;
}

.modal-title {
    font-size: 2rem;
    font-weight: 700;
}

.modal-title span {
    font-size: 2.4rem;
    color: #FF6B3B;
    font-weight: 700;
}

@media screen and (max-width: 540px) {
    .modal-title {
        font-size: 1.6rem;
        font-weight: 700;
    }

    .modal-title span {
        font-size: 1.8rem;
        color: #FF6B3B;
        font-weight: 700;
    }
}


.modal-content {
    margin-top: 1rem;
}

.modal-sentence {
    text-align: left;
    margin-bottom: 1.5rem;
    min-height: 3rem;
}

@media screen and (max-width: 540px) {
    .modal-sentence {
        min-height: 7rem;
    }
}

.modal-bg.active {
    display: block;
    opacity: 1;
}

.modal-content img {
    height: 50Vh;
    max-height: 28rem;
}

@media screen and (max-width: 540px) {
    .modal-content img {
        height: auto;
        max-height: auto;
        width: 100%;
    }
}

.btn-modalclose {
    position: absolute;
    width: 2rem;
    right: 1rem;
    top: 1rem;
    cursor: pointer;
}

.modal-pre {
    position: absolute;
    width: 3rem;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    cursor: pointer;
}

.modal-next {
    position: absolute;
    width: 3rem;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    cursor: pointer;
}

.modal-2ldk,
.modal-1ldk,
.modal-1dk,
.modal-1k,
.modal-1r {
    display: none;
}

.modal-2ldk.active,
.modal-1ldk.active,
.modal-1dk.active,
.modal-1k.active,
.modal-1r.active {
    display: block;
    opacity: 1;
}

/*---------------------------------------------

	ページ｜送信完了

---------------------------------------------*/
.page {
    width: 100%;
    height: 90vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

@media screen and (max-width: 820px) {
    .page {
        height: 70vh;
        width: 80%;
        margin: 0 auto;
    }
}

@media screen and (max-width: 540px) {
    .page {
        padding-top: 10vh;
        height: 80vh;
        width: 100%;
    }
}

/*スマホ（iPhoneX以上の縦幅）*/
@media screen and (max-width: 540px) and (min-height: 600px) {
    .page {
        padding-top: 10vh;
        height: 75vh;
        width: 100%;
    }
}

.page-title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 2rem;
}

@media screen and (max-width: 820px) {
    .page-title {
        font-size: 1.2rem;
        font-weight: 700;
        margin-bottom: 0rem;
        letter-spacing: normal;
    }
}

@media screen and (max-width: 540px) {
    .page-title {
        font-size: 1.8rem;
        font-weight: 700;
        margin-bottom: 1rem;
    }
}

.page-content {
    display: flex;
    align-items: center;
}

.pageContent-ill {
    width: 12rem;
}


@media screen and (max-width: 820px) {
    .pageContent-ill {
        width: 7rem;
    }
}

.pageContent-text {
    font-size: 1.4rem;
    letter-spacing: normal;
}

@media screen and (max-width: 820px) {
    .pageContent-text {
        font-size: 1.15rem;
        line-height: 1.2;
        width: 80%;
        margin: 0 auto;
    }
}


@media screen and (max-width: 540px) {
    .pageContent-text {
        width: 100%;

        font-size: 1.2rem;
        line-height: 1.4;
    }
}

.btn-back {
    color: white;
    letter-spacing: normal;
    display: inline-block;
    padding: 1rem 5rem;
    background-color: #009DDA;
    border-radius: 0.5rem;
    text-decoration: none;
    font-size: 1.2rem;
    font-weight: bold;
}

@media screen and (max-width: 820px) {
    .btn-back {
        margin-bottom: 1rem;
    }
}

@media screen and (max-width: 540px) {
    .btn-back {
        margin-top: 1rem;
        margin-bottom: 1rem;
    }
}


.pageContent-ill2 {
    width: 70vw;
    margin: 0 auto;
    text-align: center;
    margin-top: 2rem;
}

@media screen and (max-width: 540px) {
    .pageContent-ill2 {

        margin-top: 0rem;
    }

}


.btn-follow {
    display: none;
    opacity: 0;
    position: fixed;
    width: 8rem;
    top: 2rem;
    right: 2rem;
    z-index: 100;
}

.btn-follow:hover {
    z-index: 100;
}

.btn-follow-wrapper:hover {
    opacity: 1;
}



@media screen and (max-width: 540px) {
    .btn-follow {
        display: none;
        opacity: 0;
        position: fixed;
        width: 4.4rem;
        top: 1rem;
        right: 1rem;
        z-index: 100;
    }
}


.btn-follow.active {
    display: block;
    opacity: 1;
}

.feedback-image {
    margin: auto;
    width: 50%;
}
@media screen and (max-width: 540px) {
	.feedback-image {
		width: 75%;
	}
}
.feedback-image img {
    width: 100%;
}

/* ↓ PCとSP表示切り替え（末尾に設置） ------------------------*/
.pcArea {
    display: block;
}

.spArea {
    display: none;
}

@media screen and (max-width: 540px) {
    .pcArea {
        display: none;
    }

    .spArea {
        display: block;
    }
}
@media screen and (max-height: 700px) and (min-width: 950px) {
    .fv-btn {
        height: 100px;
    }
}

/*---------------------------------------------

	セクション ｜ ハウス

---------------------------------------------*/
.sec-house {
    background-color: white;
    padding: 6rem 0 7rem 0;
}

@media screen and (max-width: 540px) {
    .sec-house {
        padding: 4rem 0 6rem 0;
    }
}

.slider {
    pointer-events: none;
}

.housecard-outer {
    display: block;
    width: 20rem;
    margin: 0 1rem;
    padding-top: 2rem;
    text-decoration: none;
    color: #333;
}

.housecard-inner {
    border: 3px solid #D7D7D7;
    color: #333;
    text-align: center;
    border-radius: 1rem;
    position: relative;
}

.housecard-fukidashi {
    position: absolute;
    top: -2rem;
    right: 0.5rem;
    width: 5rem;
}

.housecard-sentence {
    padding: 2rem;
}

.housecard-name {
    font-size: 1.4rem;
    margin-bottom: 0.8rem;
    font-weight: 700;
    line-height: 1.4;
}

.housecard-message {
    letter-spacing: normal;
    text-align: left;
    font-size: 0.95rem;
    font-weight: 300;
    min-height: 13rem;
}
.housecard-message2 {
    letter-spacing: normal;
    text-align: left;
    font-size: 0.95rem;
    font-weight: 300;
    min-height: 17rem;
}

@media screen and (max-width: 540px) {
    .housecard-message {
        font-size: 1.2rem;
        min-height: 15rem;
    }
    .housecard-message2 {
        font-size: 1.2rem;
        min-height: 20rem;
    }
}


.housecard-ph img {
    width: 100%;
    border-radius: 0.5rem 0.5rem 0 0;
}