@charset "utf-8";

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;200;300;400;500;600;700;800;900&display=swap");
/* font-family: 'Noto Sans JP', sans-serif; */
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap");
/* font-family: 'Noto Serif JP', serif; */
@import url('https://fonts.googleapis.com/css2?family=Yuji+Boku&display=swap');

/*===================================
  基本設定
===================================*/

html {
    font-family: "Noto Sans JP", sans-serif;
    color: #666;
    letter-spacing: 3px;
    background: #fcf8f4;
}

.fead-left {
    opacity: 0;
    -webkit-transform: translateX(12%);
    transform: translateX(12%);
}
.fead-left.mv {
    opacity: 1;
    -webkit-transition: opacity 1.4s 0.3s,-webkit-transform 1s 0.3s cubic-bezier(0, 0.4, 0.3, 1);
    transition: opacity 1.4s 0.3s,-webkit-transform 1s 0.3s cubic-bezier(0, 0.4, 0.3, 1);
    transition: opacity 1.4s 0.3s,transform 1s 0.3s cubic-bezier(0, 0.4, 0.3, 1);
    transition: opacity 1.4s 0.3s,transform 1s 0.3s cubic-bezier(0, 0.4, 0.3, 1),-webkit-transform 1s 0.3s cubic-bezier(0, 0.4, 0.3, 1);
}

.fead-text .str {
    display: inline-block;
    transition: transform 2.5s cubic-bezier(0.165,0.84,0.44,1),opacity 1.75s cubic-bezier(0.445,0.05,0.55,0.95),-webkit-transform 2.5s cubic-bezier(0.165,0.84,0.44,1);
    position: relative;
}

.fead-text .str:nth-of-type(odd) {
    -webkit-transform: translate3d(0px, 100px, 0px) rotate(-12deg);
    transform: translate3d(0px, 100px, 0px) rotate(-12deg);
}

.fead-text .str:nth-of-type(even) {
    -webkit-transform: translate3d(0px, 100px, 0px) rotate(12deg);
    transform: translate3d(0px, 100px, 0px) rotate(12deg);
}

.fead-text .str.textin {
    -webkit-transform: translateY(0);
    transform: translate3d(0px, 0%, 0px) rotate(0deg);
}
.c-01 {
    color: #edae77;
}

.bgc-01 {
    background: #fbf4ed;
}

.bgc-02 {
    background: #edae77;
}

.bgc-03 {
    background: #c7bdb3;
}

.color01 {
    color: #000;
}
.color02 {
    color: #000;
}
.color03 {
    color: #000;
}
.color04 {
    color: #000;
}
.bgcolor01 {
    background-color: #000;
}
.bgcolor02 {
    background-color: #000;
}
.bgcolor03 {
    background-color: #000;
}
.bgcolor04 {
    background-color: #000;
}

.bg-g {
    background: #edae77;
}

.text-g {
    color: rgb(59,94,134);
    background: #edae77;
}

.font-s {
    font-family: "Noto Serif JP", serif;
}
/* 共通コンテンツ間隔 */
.area {
    padding-top: 100px;
    padding-bottom: 100px;
}
@media (max-width: 599px) {
    html {
        font-size: 15px;
    }
    .area {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .up-d-con {
        display: contents;
    }
}
/* 共通要素読み込みコメント（取り込み後削除） */
[class*="load-"] {
    min-height: 50px;
    border: 3px solid #00bcd4;
    position: relative;
}
[class*="load-"]:before {
    content: "共通要素";
    display: block;
    font-weight: bold;
    color: #ff0;
    text-align: center;
    background: #00bcd4;
    position: absolute;
    z-index: 100;
}
/*===================================
  共通ブロック　block-cmn
==================================*/
/* 共通ブロック１ */
/*===================================
  共通タイトル　ttl-cmn
===================================*/
/* 共通タイトル１ */
.ttl-cmn01 {
    font-size: 28px;
    text-align: center;
}
@media (max-width: 599px) {
    .ttl-cmn01 {
        font-size: 24px;
    }
}
/*===================================
  共通リスト　list-cmn
==================================*/
/* 共通リスト１ */
/*===================================
  共通ボタン btn-cmn
===================================*/
/* 共通ボタン１ */
.btn-cmn01 {
    max-width: 180px;
    margin-top: 50px;
}
.btn-cmn01 a {
    display: block;
    padding: 5px 20px;
    color: #fff;
    text-align: center;
    background: #000;
    position: relative;
}
.btn-cmn01 a:after {
    content: "\f054";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 5px;
}
.btn-cmn01.btn-back a:after {
    content: "\f053";
    left: 5px;
    right: inherit;
}
/*===================================
  他共通エレメント -cmn
===================================*/
/*===================================
  共通要素
===================================*/
/*h1ページタイトル */
.pagettl {
    margin-bottom: 10px;
    font-size: 12px;
}
/**
ヘッダー
header
*/
.header .contents {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    justify-content: space-between;
}

.header .contents .logp-area {
    width: 75%;
}

.header .contents .sb-ttl {
    margin-top: 10px;
    letter-spacing: 3px;
    text-align: center;
    position: relative;
}

.header .contents .sb-ttl::before {
    content: "";
    width: 40px;
    height: 1px;
    background: #444;
    transform: translate(0 , -50%);
    position: absolute;
    top: 50%;
    left: 0;
}

.header .contents .sb-ttl::after {
    content: "";
    width: 40px;
    height: 1px;
    background: #444;
    transform: translate(0 , -50%);
    position: absolute;
    top: 50%;
    right: 0;
}

.header .logo img {
    max-height: 50px;
}
.header .text-area {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: end;
    justify-content: flex-end;
}
.header .text-area .txt {
    margin-right: 10px;
    line-height: 120%;
}
.header .text-area .txtin {
    display: block;
}
.header .text-area .tel {
    flex-shrink: 0;
    margin-left: 20px;
}
.header .text-area .tel a {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: 30px;
    line-height: 1;
    letter-spacing: 1px;
}
.header .text-area .tel a:before {
    content: "";
    width: 30px;
    height: 30px;
    display: block;
    flex-shrink: 0;
    margin-right: 5px;
    border-radius: 50%;
    background-image: url('/import/tenant_1/160.16.148.231/html/images/tel.webp');
    background-size: 20px 20px;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #edae77;
}
.header .text-area .con-btn {
    width: 100%;
    max-width: 200px;
    overflow: hidden;
    margin-left: 20px;
    border-radius: 0 0 5px 5px;
}
.header .text-area .con-btn a {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
    font-size: 18px;
    color: #fff;
    letter-spacing: 3px;
    background: #edae77;
    background-size: 150% auto;
}

.header .text-area .con-btn a:hover {
    background-position: 100% 50%;
}

.header .text-area .con-btn .img {
    max-width: 30px;
    margin-right: 10px;
    line-height: 0;
}

.header .text-area .sns {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: 20px;
}

.header .text-area .sns .logo {
    width: 40px;
    height: 40px;
    margin-left: 20px;
}

.header .text-area .sns .logo a {
    display: block;
}

.header .left a {
    width: 100%;
    display: block;
}

.header .text-area .gnav .sns {
    justify-content: flex-start;
    margin-left: 0px;
}

.header .text-area .gnav .sns .logo {
    margin-left: 0px;
    margin-right: 20px;
}

@media (max-width: 1024px) {
    .header .logo img {
        max-height: 32px;
    }
    .header .text-area {
        width: 0;
        margin-left: 10px;
    }
}
/**
グローバルナビ
gnav
*/
.gnav {
    padding: 10px 0;
    position: relative;
    z-index: 100;
}
.header .h-box {
    width: 100%;
}
.header .h-box.fixed {
    height: auto;
    background: #fcf8f4;
    box-shadow: 0 0 5px 0 #999;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 250;
}

.gnav .navlogo,
.gnav .address,
.header .gnav .sns {
    display: none;
}
.gnav .navlogo img {
    max-height: 40px;
}
.gnav .list01 {
    width: 100%;
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.gnav .item01 {
    margin-left: 25px;
    font-weight: 500;
    text-align: center;
}
.gnav .item01>a,
.gnav .item01 .itemin {
    display: block;
    padding: 10px 5px;
    font-weight: 500;
    letter-spacing: 3px;
    cursor: pointer;
}
.gnav .item01.-parent {
    position: relative;
}
.gnav .item01.-parent:hover .list02 {
    visibility: visible;
    opacity: 1;
}
.gnav .list02 {
    width: 200px;
    visibility: hidden;
    padding-top: 10px;
    background: rgba(255,255,255,0.8) content-box;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    position: absolute;
    top: 100%;
    left: 50%;
}
.gnav .item02 a {
    display: block;
    padding: 5px;
    letter-spacing: 3px;
}

.gnav .item02 a:hover {
    color: #fff;
    background: #edae77;
    opacity: 1;
}


@media (max-width: 1024px) {
    .gnav .item02 a:hover {
        color: #666;
        background: none;
    }
    .gnav .address {
        display: block;
        font-size: 12px;
    }
    .header .gnav .sns {
        display: flex;
    }
    .gnav .navlogo {
        opacity: 0;
        transition: transform 0.6s ease, opacity 0.2s ease;
        transform: translateX(50%);
    }
    .gnav.action .navlogo {
        opacity: 1;
        transition: transform 1s ease, opacity 0.9s ease;
        transform: translateX(0);
    }
    .gnav .address {
        opacity: 0;
        transition: transform 0.6s ease, opacity 0.2s ease;
        transform: translateX(50%);
    }
    .gnav.action .address {
        opacity: 1;
        transition: transform 1.2s ease, opacity 0.9s ease;
        transform: translateX(0);
    }
    .gnav .list01 {
        opacity: 0;
        transition: transform 0.6s ease, opacity 0.2s ease;
        transform: translateX(50%);
    }
    .gnav.action .list01 {
        opacity: 1;
        transition: transform 1.4s ease, opacity 0.9s ease;
        transform: translateX(0);
    }
    .gnav .sns {
        opacity: 0;
        transition: transform 0.6s ease, opacity 0.2s ease;
        transform: translateX(50%);
    }
    .gnav.action .sns {
        opacity: 1;
        transition: transform 1.6s ease, opacity 0.9s ease;
        transform: translateX(0);
    }
    .gnav {
        width: 100%;
        height: 100%;
        visibility: hidden;
        overflow: auto;
        padding: 30px;
        background: rgba(255,255,255,0.9);
        opacity: 0;
        transition: opacity 0.6s ease, visibility 0.6s ease;
        pointer-events: none;
        position: fixed;
        top: 0;
        right: 0;
    }
    .gnav.action {
        visibility: visible;
        opacity: 1;
        pointer-events: initial;
        z-index: 250;
    }
    .gnav .wrap {
        padding-bottom: 100px;
    }
    .gnav .navlogo {
        width: 100%;
        display: block;
        margin-bottom: 20px;
        padding-right: 40px;
        font-weight: bold;
        font-size: 20px;
    }
    .gnav .item01 {
        width: 100%;
        min-height: 40px;
        margin: 0 0 10px 0;
        text-align: left;
        border-bottom: solid 1px #ccc;
        position: relative;
    }

    .gnav .item01::after {
        content: "\f0da";
        font-family: "Font Awesome 5 Free";
        font-weight: bold;
        font-size: 20px;
        color: #edae77;
        position: absolute;
        top: 4px;
        right: 0;
    }

    .gnav .item01.-parent::after {
        content: "\f0d7";
    }

    .gnav .item01.openbox::after {
        content: "\f0d8";
    }

    .gnav .item02 {
        position: relative;
    }


    .gnav .list02 {
        width: 100%;
        visibility: visible;
        padding-top: 0;
        padding-left: 20px;
        color: #fff;
        background: none;
        background: #edae77;
        opacity: 1;
        -webkit-transform: none;
        transform: none;
        position: relative;
        top: 0;
        left: 0;
    }
    .gnav .list02 a {
        padding: 10px 0 10px 20px;
        position: relative;
    }
    .gnav .list02 a:before {
        content: "\f0da";
        font-family: "Font Awesome 5 Free";
        font-weight: bold;
        font-size: 20px;
        color: #fff;
        position: absolute;
        top: 6px;
        left: 0;
    }
}
[data-element-id] .gnav.fixed {
    position: relative;
}
/* ハンバーガーメニュー  */
.toggle {
    width: 42px;
    height: 42px;
    display: none;
    background: #edae77;
    cursor: pointer;
    position: relative;
    z-index: 1000;
}
.toggle .bar {
    width: 28px;
    height: 2px;
    display: block;
    margin-top: -1px;
    padding: 0;
    text-indent: 9999px;
    background: #fff;
    -webkit-transition: ease 0.4s;
    transition: ease 0.4s;
    position: absolute;
    top: 50%;
    left: 7px;
}
.toggle .bar:before,
.toggle .bar:after {
    content: "";
    width: 28px;
    height: 2px;
    display: block;
    background: #fff;
    position: absolute;
    left: 0;
}
.toggle .bar:before {
    top: -10px;
}
.toggle .bar:after {
    top: 10px;
}
.toggle.active .bar {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.toggle.active .bar:after,
.toggle.active .bar:before {
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    top: 0;
    left: 0;
}
@media (max-width: 1024px) {
    .toggle {
        display: block !important;
        position: fixed;
        top: 10px;
        right: 10px;
    }
}
.overlay {
    overflow: hidden;
}
.overlay:after {
    content: "";
    width: 100%;
    height: 100vh;
    background: #000;
    opacity: 0.3;
    -webkit-transform: translate3d(0, 0, 0) !important;
    transform: translate3d(0, 0, 0) !important;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 249;
}
/*トップへ戻る*/
.totop {
    width: 40px;
    height: 40px;
    font-size: 20px;
    color: #fff;
    line-height: 40px;
    text-align: center;
    border-radius: 50%;
    background: #edae77;
    cursor: pointer;
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 200;
}
.totop:before {
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    letter-spacing: 0px;
}
@media (max-width: 1024px) {
    .totop {
        bottom: 70px;
        right: 10px;
    }
}

/**
フッターナビ
fnav
*/
.fnav {
    padding: 50px 0;
    background: #eee;
}
.fnav .wrap {
    display: -webkit-box;
    display: flex;
}
.fnav .list01 {
    width: 50%;
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
}
.fnav .item {
    margin-bottom: 10px;
    padding-right: 10px;
    -webkit-column-break-inside: avoid;
    -moz-column-break-inside: avoid;
    break-inside: avoid;
}
.fnav .item a {
    display: block;
    padding-left: 12px;
    position: relative;
}
.fnav .item a:before {
    content: "";
    width: 4px;
    height: 4px;
    display: block;
    border-radius: 50%;
    background: #000;
    position: absolute;
    top: 10px;
    left: 0;
}
.fnav .list02 {
    width: 50%;
}
.fnav .datawrap {
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
}
.fnav .datattl {
    margin-bottom: 10px;
    padding-left: 12px;
    position: relative;
}
.fnav .datattl:before {
    content: "";
    width: 4px;
    height: 4px;
    display: block;
    border-radius: 50%;
    background: #000;
    position: absolute;
    top: 10px;
    left: 0;
}
.fnav .data {
    margin-bottom: 5px;
    padding-right: 10px;
    -webkit-column-break-inside: avoid;
    -moz-column-break-inside: avoid;
    break-inside: avoid;
}
.fnav .data a {
    padding-left: 12px;
    position: relative;
}
.fnav .data a:before {
    content: "";
    width: 5px;
    height: 1px;
    display: block;
    background: #000;
    position: absolute;
    top: 7px;
    left: 0;
}
@media (max-width: 1024px) {
    .fnav .wrap {
        flex-wrap: wrap;
    }
    .fnav .list01 {
        width: 100%;
        margin-bottom: 10px;
    }
    .fnav .list02 {
        width: 100%;
    }
}
@media (max-width: 599px) {
    .fnav .list01 {
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
    }
    .fnav .datawrap {
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
    }
}
/**
2カラムページ
*/
.column2 .inner {
    display: -webkit-box;
    display: flex;
    flex-wrap: nowrap;
    -webkit-box-pack: justify;
    justify-content: space-between;
}
.column2 .side {
    width: 240px;
}
.column2 .mainwrap {
    width: calc(100% - 280px);
}
@media (max-width: 1024px) {
    .column2 .inner {
        flex-wrap: wrap;
    }
    .column2 .side {
        width: 100%;
        -webkit-box-ordinal-group: 4;
        order: 3;
        margin-bottom: 50px;
    }
    .column2 .mainwrap {
        width: 100%;
        -webkit-box-ordinal-group: 3;
        order: 2;
        margin-bottom: 50px;
    }
}
/* サイドメニュー */
.side .list {
    margin-bottom: 30px;
    padding: 20px;
    border-radius: 10px;
    background: #fff;
}
@media (max-width: 1024px) {
    .side {
        display: -webkit-box;
        display: flex;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        justify-content: space-between;
    }
    .side .list {
        width: 48%;
    }
}
@media (max-width: 599px) {
    .side .list {
        width: 100%;
    }
}
.list-side .datattl {
    margin-bottom: 20px;
    padding: 10px;
    font-size: 20px;
    color: #fff;
    letter-spacing: 3px;
    text-align: center;
    border-radius: 2em;
    background: #edae77;
    position: relative;
}
.list-side .data {
    margin-bottom: 10px;
    padding-left: 10px;
}
.list-side a {
    display: block;
    padding-right: 20px;
    position: relative;
}
.list-side a:before {
    content: "\f054";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 5px;
}
@media (max-width: 1024px) {
    .list-side.type-archive .datawrap {
        display: -webkit-box;
        display: flex;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        justify-content: space-between;
    }
    .list-side.type-archive .datawrap .datattl {
        width: 100%;
    }
    .list-side.type-archive .datawrap .data {
        width: 48%;
    }
}
/*===================================
  各個別コンテンツ
===================================*/
/**
トップ
*/
/*ホームビジュアル（トップ）*/
.homevisual {
    position: relative;
}
.homevisual .img {
    min-height: 300px;
    max-height: 700px;
    position: relative;
}
.homevisual .img:before {
    content: "";
    display: block;
    padding-top: 40%;
    position: relative;
    z-index: -1;
}
.homevisual .img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    /*IE対策*/
    font-family: "object-fit: cover; object-position: 50% 50%;";
    position: absolute;
    top: 0;
    left: 0;
}
/*IE対策*/
.homevisual .head {
    font-weight: bold;
    font-size: 40px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute !important;
    top: 50%;
    left: 50%;
}
@media (max-width: 599px) {
    .homevisual .head {
        font-size: 28px;
    }
}
/* A-BiSUスライダー用 */
.mainimg {
    overflow: hidden;
    position: relative;
}
.mainimg img {
    width: 100%;
}
.mainimg .uk-slidenav-position {
    min-height: 300px;
    overflow: hidden;
    position: relative;
}
.mainimg .uk-slidenav-position:after {
    content: "";
    display: block;
    padding-top: 50%;
}
.mainimg .uk-slideshow {
    height: 100% !important;
    position: absolute;
    top: 0;
}
.mainimg .uk-slideshow li {
    height: 100% !important;
}
.mainimg .uk-slideshow .uk-flex {
    height: 100%;
}
.mainimg .uk-slideshow img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    /*IE対策*/
    font-family: "object-fit: cover; object-position: 50% 50%;";
}
/*IE対策*/
/**
下層共通
*/
/* トップビジュアル（下層共通） */
.topvisual {
    position: relative;
}
.topvisual .img {
    max-height: 600px;
    position: relative;
}
.topvisual .img:before {
    content: "";
    display: block;
    padding-top: 50%;
    position: relative;
    z-index: -1;
}
.topvisual .img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    font-family: "object-fit: cover; object-position: 50% 50%;";
    position: absolute;
    top: 0;
    left: 0;
}
.topvisual .head {
    width: 96%;
    max-width: 1000px;
    font-weight: bold;
    font-size: 50px;
    letter-spacing: 5px;
    text-align: center;
    text-shadow: 0 0 4px white, 0 0 4px white, 0 0 4px white, 0 0 4px white, 0 0 4px white, 0 0 4px white;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute !important;
    top: 50%;
    left: 50%;
}
@media (max-width: 599px) {
    .topvisual .img:before {
        padding-top: 100%;
    }
    .topvisual .head {
        font-size: 24px;
    }
}
/* ##### パンくずリスト breadcrumbs ##### */
.breadcrumbs {
    padding: 30px 0;
}

.breadcrumbs-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.breadcrumbs-list {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
}

.breadcrumbs-list li {
    display: inline;
    font-size: 14px;
    letter-spacing: 1px;
}

.breadcrumbs-list li.breadcrumbs-home,
.breadcrumbs-list li.breadcrumbs-prevpage a {
    font-weight: bold;
    color: #edae77;
}

.breadcrumbs-list li+li::before {
    content: "";
    width: 8px;
    height: 8px;
    display: inline-block;
    margin: 0 10px 0 0px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

@media (max-width: 1024px) {
    .breadcrumbs {
        padding: 20px 0;
        font-size: 14px;
    }

    .breadcrumbs-box {
        flex-direction: column;
        align-items: flex-start;
    }

    .breadcrumbs-list {
        width: 90%;
    }

    .breadcrumbs li {
        font-size: 12px;
    }

    .breadcrumbs li+li::before {
        width: 8px;
        height: 8px;
    }
}

@media (max-width: 599px) {
    .breadcrumbs {
        padding: 15px 0;
        font-size: 12px;
    }

    .breadcrumbs li+li::before {
        width: 6px;
        height: 6px;
    }
}

/* ##### パンくずリスト breadcrumbs ここまで ##### */
/* ページネーション */
.pagenation {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
    letter-spacing: 0;
}
.pagenation .item {
    margin: 0 10px;
}
.pagenation .prev {
    position: relative;
}
.pagenation .prev a:before {
    content: "\f053";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
}
.pagenation .next {
    position: relative;
}
.pagenation .next a:before {
    content: "\f054";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
}
.pagenation a,
.pagenation .now {
    font-weight: bold;
}
.pagenation .number a,
.pagenation .now,
.pagenation .next a,
.pagenation .prev a {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2px 8px;
    font-size: 20px;
    color: #000;
    text-align: center;
    border-radius: 50%;
}
.pagenation .number a:hover,
.pagenation .next a:hover,
.pagenation .prev a:hover,
.pagenation .now {
    color: #fff;
    background: #edae77;
    opacity: 1;
}
@media (max-width: 599px) {
    .pagenation .item {
        margin: 0 5px;
    }
    .pagenation .prev {
        margin-right: 10px;
    }
    .pagenation .next {
        margin-left: 10px;
    }
}
/**
各下層ページ
*/
/* 記事一覧ページ */
.list-article .cate span {
    display: inline-block;
    margin: 0 0.2rem 0.2rem 0;
    padding: 0 5px;
    color: #fff;
    letter-spacing: 2px;
    background: #edae77;
}
.list-article .time {
    letter-spacing: 2px;
}
/* 記事詳細ページ */
.articledtl01 .cate span {
    display: inline-block;
    margin: 0 0.2rem 0.2rem 0;
    padding: 0 5px;
    color: #fff;
    letter-spacing: 2px;
    background: #edae77;
}
.articledtl01 .time {
    letter-spacing: 2px;
}
/* フォーム */
.form .box {
    display: -webkit-box;
    display: flex;
    flex-wrap: nowrap;
    padding: 20px 0;
    border-bottom: 2px solid #999;
}
.form .datattl {
    width: 200px;
    display: -webkit-box;
    display: flex;
    -webkit-box-align: start;
    align-items: flex-start;
    -webkit-box-pack: justify;
    justify-content: space-between;
    flex-shrink: 0;
    font-weight: bold;
    color: #000;
}
.form .require {
    display: inline-block;
    margin-left: 10px;
    padding: 5px 10px;
    font-size: 14px;
    color: #fff;
    line-height: 1;
    background: #edae77;
}
.form .data {
    width: 100%;
    padding-left: 50px;
}
.form .data input {
    width: 100%;
    padding: 5px;
    box-sizing: border-box;
    border: 1px solid #999;
}
.form .data input[type="radio"] {
    display: none;
}
.form .data input[type="radio"]+label {
    margin-right: 20px;
    padding-left: 20px;
    box-sizing: border-box;
    line-height: 200%;
    position: relative;
}
.form .data input[type="radio"]+label::before {
    content: "";
    width: 10px;
    height: 10px;
    display: block;
    border: 1px solid #303841;
    border-radius: 50%;
    background: #fff;
    box-shadow: inset 1px 1px 0 1px #999;
    position: absolute;
    top: 4px;
    left: 0;
}
.form .data input[type="radio"]:checked+label::after {
    content: "";
    width: 7px;
    height: 7px;
    display: block;
    border-radius: 50%;
    background: #303841;
    position: absolute;
    top: 7px;
    left: 3px;
}
.form .data input[type="radio"]:checked+label {
    -webkit-transition: 0.6s;
    transition: 0.6s;
}
.form .data input[type="number"] {
    width: 70px;
    margin-right: 10px;
}
.form .data select {
    padding: 5px;
    box-sizing: border-box;
    color: inherit;
    border: 1px solid #999;
}
.form .data textarea {
    width: 100%;
    height: 170px;
    padding: 5px;
    box-sizing: border-box;
    font-family: inherit;
    font-size: inherit;
    color: inherit;
    border: 1px solid #999;
}
.form .data01 div {
    display: inline-block;
}
.form .btn {
    margin-top: 30px;
}
.form .btn button {
    border: none;
}
@media (max-width: 1024px) {
    .form .item {
        flex-wrap: wrap;
    }
    .form .datattl {
        display: block;
        margin-bottom: 10px;
    }
    .form .data {
        padding-left: 0;
    }
}

@media (max-width: 599px) {
    .form .box {
        flex-wrap: wrap;
    }
    .form .datattl {
        width: 100%;
    }
}

/*# sourceMappingURL=style.css.map */
.contact-area img {
    opacity: 0.6;
}
.contact-area .btn {
    width: 100%;
    max-width: 400px;
}

.contact-area .btn .img {
    margin-right: 10px;
    line-height: 0;
}

.contact-area .btn .img img {
    width: 100%;
    max-width: 50px;
    opacity: 1;
}
.contact-area .btn a {
    height: 75px;
    font-size: 26px;
    color: #edae77;
    border: solid 1px #fff;
    background: #fff;
}

.contact-area .btn a:hover {
    color: #fff;
    background: #edae77;
}

.contact-area .btn a img {
    -webkit-transition: 0.4s ease;
    transition: 0.4s ease;
}
.contact-area .btn a:hover img {
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
}

.contact-area .btn a .text-container {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.contact-area .h3ttl {
    color: #fff;
}

.contact-area .tel a {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: 40px;
    letter-spacing: 5px;
}

.contact-area .tel a:before {
    content: "";
    width: 50px;
    height: 50px;
    display: block;
    margin-right: 10px;
    border-radius: 50%;
    background-image: url('/import/tenant_1/160.16.148.231/html/images/tel.webp');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #edae77;
}

.contact-area .min-ttl .ja,
.contact-area .min-ttl .en,
.bgc-03 .min-ttl .ja,
.bgc-03 .min-ttl .en {
    color: #fff;
}

/* A-BiSUスライダー */
.main-visual .uk-slidenav-position {
    height: 100%;
}

.main-visual .uk-slideshow {
    height: 100% !important;
    max-height: 770px;
    overflow: hidden;
    position: relative;
}

.main-visual .uk-slideshow::after {
    content: "";
    display: block;
    padding-top: 60%;
}

.main-visual .uk-slideshow li {
    width: 100%;
    height: 100% !important;
    position: absolute;
    top: 0;
}

.main-visual .uk-slideshow li>div {
    height: 100% !important;
}

.main-visual .uk-slideshow img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
    font-family: "object-fit: cover; object-position: center center;";
}

.uk-dotnav>*>* {
    width: 10px;
    height: 10px;
}

.uk-dotnav .uk-active>* {
    -webkit-transform: scale(1);
    transform: scale(1);
}

.uk-dotnav li a:hover {
    opacity: 1;
}

.uk-dotnav-contrast>*>* {
    background: #ccc;
}

.uk-dotnav-contrast>.uk-active>* {
    background: #565656;
}

.uk-position-bottom {
    bottom: -30px;
}

@media (max-width: 1024px) {
    .main-visual .uk-slideshow::after {
        padding-top: 55%;
    }
}

@media (max-width: 599px) {
    .main-visual .uk-slideshow::after {
        padding-top: 100%;
    }
}

.text-ss {
    text-shadow: 0 0 5px black;
}

.box-ss {
    -webkit-box-shadow: 0px 2px 10px #dadada;
    box-shadow: 0px 2px 10px #dadada;
}

.catch {
    width: 95%;
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
    color: #fff;
    text-align: center;
    text-shadow: 0 0 8px #666;
    transform: translate(-50%,0);
    position: absolute;
    top: 50%;
    left: 50%;
}

.catch .ttl {
    margin-bottom: 30px;
    font-size: 50px;
    color: #fff;
    line-height: 1;
    letter-spacing: 15px;
}

.catch .sbttl {
    display: inline-block;
    font-size: 20px;
    letter-spacing: 5px;
    position: relative;
}
.catch .sbttl::before {
    content: "";
    width: 10px;
    height: 2px;
    background: #fff;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: -1em;
}
.catch .sbttl::after {
    content: "";
    width: 10px;
    height: 2px;
    background: #fff;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: -1em;
}


.bg-img-01 {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.bg-img-01.gr {
    filter: grayscale(100%);
}

.bg-img-02 {
    width: 100%;
    height: 100%;
    background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
    background-size: 30px 30px;
    background-repeat: repeat;
    background-position: center center;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.min-ttl {
    margin-bottom: 60px;
    font-family: "Noto Serif JP", serif;
}

.min-ttl .ja {
    font-weight: bold;
    font-size: 24px;
    color: #edae77;
    letter-spacing: 5px;
}

.min-ttl .ja .num {
    display: inline-block;
    font-weight: 400;
    font-size: 120px;
    line-height: 1;
    transform: translateY(15px);
}

.min-ttl .en {
    font-weight: bold;
    font-size: 70px;
    letter-spacing: 15px;
}
.news-area .item:not(:last-child) {
    margin-bottom: 25px;
}
.news-area .item a {
    display: flex;
    align-items: center;
    padding: 30px;
    padding-right: 45px;
    font-family: "Noto Sans JP", sans-serif;
    border-radius: 5px;
    background: #fff;
    position: relative;
}
.news-area .item a::after {
    content: "\f105";
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    font-size: 24px;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 25px;
}
.news .news-area .item a {
    display: block;
}
.news-area .date {
    flex-shrink: 0;
    margin-right: 20px;
    font-weight: 500;
    font-size: 14px;
    color: #999;
}
.up-left-1000 {
    margin-left: calc(50% - 500px);
}
.up-right-1000 {
    margin-right: calc(50% - 500px);
}
[class*=up-fxd-even]>.up-left-1000:nth-child(even),
[class*=up-fxd-odd]>.up-left-1000:nth-child(odd) {
    margin-left: 0;
    margin-right: calc(50% - 500px);
}
[class*=up-fxd-even]>.up-right-1000:nth-child(even),
[class*=up-fxd-odd]>.up-right-1000:nth-child(odd) {
    margin-left: calc(50% - 500px);
    margin-right: 0;
}
@media (max-width: 1024px) {
    .min-ttl .en {
        font-size: 40px;
    }
    .up-left-1000 {
        margin-left: 2%;
    }
    .up-right-1000 {
        margin-right: 2%;
    }
    [class*=up-fxd-even]>.up-left-1000:nth-child(even),
    [class*=up-fxd-odd]>.up-left-1000:nth-child(odd) {
        margin-left: 0;
        margin-right: 2%;
    }
    [class*=up-fxd-even]>.up-right-1000:nth-child(even),
    [class*=up-fxd-odd]>.up-right-1000:nth-child(odd) {
        margin-left: 2%;
        margin-right: 0;
    }
}
@media (max-width: 599px) {
    .up-left-1000 {
        margin-right: 2%;
    }
    .up-right-1000 {
        margin-left: 2%;
    }
    [class*=up-fxd-even]>.up-left-1000:nth-child(even),
    [class*=up-fxd-odd]>.up-left-1000:nth-child(odd) {
        margin-left: 2%;
        margin-right: 2%;
    }
    [class*=up-fxd-even]>.up-right-1000:nth-child(even),
    [class*=up-fxd-odd]>.up-right-1000:nth-child(odd) {
        margin-left: 2%;
        margin-right: 2%;
    }
}
.cats-btn {
    position: fixed;
    top: 75%;
    right: 0;
    z-index: 10;
    /*   transition:.3s; */
}



[data-element-id].cats-btn {
    opacity: 1;
    transform: translateX(0%);
        position: absolute;
    top: 100%;
        width: 230px;
}

[data-element-id].cats-btn .tel{
      margin-top: 200px;
}
[data-element-id].cats-btn .tel a{
      width: 100%;
    height: 100%;
    flex-direction: row;
    padding: 10px;
    font-size: 14px;
    letter-spacing: 1px;
    outline-offset: -5px;
    border-radius: 0;
}


.cats-btn .img {
    margin-bottom: 5px;
}
.cats-btn a {
    width: 170px;
    height: 170px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #fff;
    line-height: 1.2;
    letter-spacing: 3px;
    text-align: center;
    outline: 2px solid white;
    outline-offset: -10px;
    border-radius: 50%;
    background: #edae78;
    transition: 0.3s;
    position: relative;
}

.cats-btn .ab-a a {
    width: 170px;
    height: 170px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #fff;
    line-height: 1.2;
    letter-spacing: 3px;
    text-align: center;
    outline: 2px solid white;
    outline-offset: -10px;
    border-radius: 50%;
    background: #edae78;
    transition: 0.3s;
    position: relative;
    right: 20px;
}

.cats-btn .ab-b a {
    width: 230px;
    height: 100px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #fff;
    line-height: 1.2;
    letter-spacing: 3px;
    text-align: center;
    outline: 2px solid white;
    outline-offset: -10px;
    border-radius: 50%;
    border-radius: 50px 0 0 50px;
    background: #78a6ed;
    transition: 0.3s;
    position: relative;
    right: 0px;
}

.list-cmp09 .item {
    margin-bottom: 30px;
}
.list-cmp09 .datattl {
    padding: 15px 40px 15px 60px;
    font-weight: 500;
    font-size: 18px;
    border-radius: 10px;
    background: #fff;
    cursor: pointer;
    position: relative;
}
.list-cmp09 .datattl:before {
    content: "Q";
    width: 48px;
    height: 100%;
    display: flex;
    justify-content: center;
    padding: 15px 1rem;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    line-height: 1;
    border-radius: 10px 0 0 10px;
    background: #edae77;
    position: absolute;
    top: 0;
    left: 0;
        align-items: center;
}
.list-cmp09 .data {
    display: none;
    margin-top: 10px;
    padding: 15px 10px 15px 60px;
    border-radius: 10px;
    background: #fff;
    position: relative;
}
.list-cmp09 .data:before {
    content: "A";
    width: 48px;
    height: 100%;
    display: flex;
    justify-content: center;
    padding: 15px 1rem;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    line-height: 1;
    border-radius: 10px 0 0 10px;
    background: #ffd63c;
    position: absolute;
    top: 0;
    left: 0;
        align-items: center;
}

.plmi span::before,
.plmi span::after {
    content: "";
    width: 15px;
    height: 3px;
    display: block;
    border-radius: 5px;
    background: #edae77;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 15px;
}

.plmi span::after {
    background: #edae77;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg);
}

.is-parent .plmi span::after {
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: rotate(0);
    transform: rotate(0);
}

@media (max-width: 1024px) {
    .cats-btn {
        width: 100%;
        display: flex;
        top: initial;
        bottom: 0;
        left: 0;
        right: initial;
        z-index: 10;
    }
    .cats-btn a,
    .cats-btn .ab-a a,
    .cats-btn .ab-b a {
        width: 100%;
        height: 100%;
        flex-direction: row;
        padding: 10px;
        font-size: 14px;
        letter-spacing: 1px;
        outline-offset: -5px;
        border-radius: 0;
        right: 0;
    }
    .cats-btn .img {
        max-width: 35px;
        margin-bottom: 0px;
        margin-right: 5px;
    }
}

@media (max-width: 599px) {
    .list-cmp09 .item {
        margin-bottom: 20px;
    }
    .list-cmp09 .datattl {
        padding-left: 25px;
        padding-right: 30px;
        font-size: 16px;
    }
    .list-cmp09 .datattl:after {
        width: 20px;
        height: 20px;
        font-size: 16px;
        line-height: 18px;
    }
    .list-cmp09 .data {
        padding-left: 25px;
    }
}

.text-2 {
    width: 100%;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: inherit;

    -webkit-line-clamp: 2;
}

.map {
    padding-top: 30%;
}

.table-cmp02 .head {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 18px;
    text-align: center;
}
.table-cmp02 .txt {
    margin-top: 5px;
    text-align: right;
}
.table-cmp02 .wrap {
    overflow: auto;
}
.table-cmp02 .table {
    width: 100%;
    border-collapse: collapse;
}
.table-cmp02 .datattl01 {
    padding: 15px;
}
.table-cmp02 .datattl02,
.table-cmp02 .data {
    padding: 15px 5px;
}
.table-cmp02 .data {
    text-align: center;
}

.table-cmp02 tr {
    border-bottom: solid 1px #fff;
}

.overview .map {
    margin-bottom: 50px;
    border-radius: 10px;
}

.overview .f-btn {
    display: flex;
}

.overview .f-btn .btn {
    width: 100%;
    max-width: 230px;
    margin-right: 15px;
}

.overview .f-btn .btn a {
    color: #edae77;
    border: solid 1px #fff;
    background: #fff;
}

.overview .f-btn .btn a:hover {
    color: #fff;
    background: #edae77;
}

.overview .tel a,
.overview02 .tel a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-weight: 500;
    font-size: 40px;
    letter-spacing: 5px;
}
.overview02 .tel a {
    justify-content: center;
}

.overview .tel a::before,
.overview02 .tel a::before {
    content: "";
    width: 45px;
    height: 45px;
    display: block;
    margin-right: 15px;
    border-radius: 50%;
    background-image: url('/import/tenant_1/160.16.148.231/html/images/tel.webp');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #edae77;
}

.f-nav .ttl {
    margin-bottom: 30px;
    padding-left: 25px;
    position: relative;
}

.f-nav .ttl::before {
    content: "";
    width: 15px;
    height: 15px;
    background: #666;
    position: absolute;
    top: 5px;
    left: 0;
}

.f-nav .item {
    margin-bottom: 10px;
    padding-left: 35px;
    position: relative;
}
.f-nav .item::after {
    content: "";
    width: 3px;
    height: 2px;
    background: #666;
    position: absolute;
    top: 10px;
    left: 20px;
}

.f-nav .item.ori {
    width: 100%;
}

.f-nav .sns {
    display: flex;
    align-items: center;
    justify-content: center;
}

.f-nav .sns .logo {
    width: 40px;
    height: 40px;
    margin-right: 20px;
}

.f-nav .sns .logo a {
    display: block;
}

.f-nav .sns .logo img {
    max-height: 50px;
}

.up-ls-3 {
    letter-spacing: 3px;
}

@media (max-width: 1024px) {
    .header .contents {
        padding: 10px 0 10px;
    }
    .header .contents .sb-ttl::before,
    .header .contents .sb-ttl::after {
        width: 20px;
    }
    .catch .ttl {
        font-size: 38px;
    }
    .catch .sbttl {
        margin-top: 15px;
        font-size: 16px;
    }
    .min-ttl .ja {
        font-size: 24px;
    }
    .min-ttl .ja .num {
        font-size: 80px;
    }
    .contact-area .tel a {
        font-size: 24px;
    }
    .contact-area .btn .img img {
        max-width: 40px;
    }
    .overview .tel a {
        font-size: 28px;
    }
    .table-cmp02 .datattl01 {
        padding: 8px;
    }
    .header .contents .logp-area {
        width: 100%;
    }
    .pagettl {
        padding-right: 40px;
    }
}

@media (max-width: 599px) {
    .catch .sbttl {
        font-size: 14px;
    }
    .table-cmp02 .datattl01 {
        padding: 5px;
    }
    .f-nav .item {
        font-size: 14px;
    }
    .overview .tel a {
        justify-content: center;
    }
    .overview .f-btn .btn {
        margin: 0 10px;
    }
    .contact-area .btn a {
        font-size: 20px;
    }
    .contact-area .btn .img img {
        max-width: 30px;
    }
    .contact-area .tel a,
    .overview02 .tel a {
        font-size: 30px;
    }
    .min-ttl .ja {
        font-size: 20px;
        letter-spacing: 5px;
    }
    .min-ttl .en {
        font-size: 32px;
        letter-spacing: 5px;
    }
    .list-cmp09 .datattl:before,
    .list-cmp09 .data:before {
        width: 35px;
        padding: 15px 0.5rem;
    }
    .list-cmp09 .data,
    .list-cmp09 .datattl {
        padding-left: 40px;
    }
    .catch .ttl {
        font-size: 28px;
    }
    .header .left a {
        margin: auto;
    }
    .header .contents .sb-ttl {
        font-size: 12px;
    }
    .min-ttl .ja .num {
        font-size: 60px;
        transform: translateY(5px);
    }
}

.d-none-tb,
.d-none-sp {
    display: block;
}
.d-b-tb,
.d-b-sp {
    display: none;
}
@media (max-width: 1024px) {
    .d-b-tb {
        display: block;
    }
    .d-none-tb {
        display: none;
    }
}
@media (max-width: 599px) {
    .d-none-sp {
        display: none;
    }
    .d-b-sp {
        display: block;
    }
}

.br-10 img {
    border-radius: 10px;
}

.bgi-c {
    position: relative;
}

.bgi-c::before {
    content: "";
    width: 100%;
    height: 100%;
    border-radius: 15px;
    background: #edae77;
    position: absolute;
    top: 30px;
    left: 30px;
}
@media (max-width: 599px) {
    .bgi-c::before {
        top: 10px;
        left: 10px;
    }
    .bgi-c {
        margin-right: 10px;
    }
}

.list_cmn02 .item {
    margin-bottom: 10px;
    padding-left: 25px;
    font-weight: bold;
    line-height: 150%;
    position: relative;
}
.list_cmn02 .item:before {
    content: "";
    width: 5px;
    height: 5px;
    display: block;
    border: 8px solid #edae77;
    border-radius: 50%;
    position: absolute;
    top: 6px;
    left: 0;
}
.t-btn .tel {
    display: flex;
    align-items: center;
    justify-content: center;
}
.t-btn .tel a {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 5px;
}

.t-btn .tel a:before {
    content: "";
    width: 40px;
    height: 40px;
    display: block;
    margin-right: 15px;
    border-radius: 50%;
    background-image: url('/import/tenant_1/160.16.148.231/html/images/tel.webp');
    background-size: auto;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #fff;
}
.t-btn .btn .img {
    margin-right: 10px;
    line-height: 0;
}

.s-headline {
    display: inline-block;
    margin-bottom: 15px;
    padding-bottom: 5px;
    font-weight: bold;
    font-size: 20px;
    border-bottom: solid 2px #edae77;
}

.s-headline2 {
    display: inline-block;
    margin-bottom: 10px;
    padding: 0.1rem 1rem;
    font-weight: 500;
    font-size: 20px;
    color: #fff;
    letter-spacing: 5px;
    white-space: nowrap;
    border-radius: 10px;
    background: #edae77;
}
.s-headline2:after {
    content: " ";
    margin-left: -5px;
}
.s-headline3 {
    margin-bottom: 15px;
    padding-bottom: 15px;
    padding-left: 25px;
    font-size: 20px;
    border-bottom: solid 2px #edae77;
    position: relative;
}
.s-headline3::before {
    content: "";
    width: 15px;
    height: 15px;
    background: #edae77;
    position: absolute;
    top: 8px;
    left: 0;
}

@media(max-width:1024px) {
    .s-headline {
        display: block;
    }
}

@media(max-width:599px) {
    .s-headline3 {
        font-size: 18px;
    }
    .flow-area .item>* .titbox {
        font-size: 20px;
    }

    .flow-area .item>* .txt {
        margin-top: 10px;
    }

    .flow-area .item>* .titbox .num {
        width: 60px;
    }
}


.company .box {
    overflow: hidden;
    border: 1px solid #edae77;
    border-radius: 5px;
}

.company .item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.company .item>* {
    padding: 20px;
}

.company .item .tit {
    width: 220px;
    font-weight: bold;
    color: #fff;
    letter-spacing: 3px;
    background: #edae77;
}

.company .item+.item .tit {
    border-top: 1px solid #fff;
}

.company .item .txt {
    width: calc(100% - 220px);
    background: #fff;
}

.company .item+.item .txt {
    border-top: 1px solid#edae77;
}
@media(max-width:599px) {
    .company .item .tit,
    .company .item .txt {
        width: 100%;
    }
    .company .item .tit{
      padding: 10px 20px;
    }
    .company .box{
      border: none;
    }
}

.g-map .map {
    padding-top: 50%;
    border-radius: 10px;
}

.access .overview {
    display: none;
}

.table-01 {
    width: 100%;
    overflow: hidden;
    border: 1px solid #fff;
    border-radius: 10px;
}

.table-01 tr {
    display: flex;
    flex-wrap: wrap;
}

.table-01 tr th,
.table-01 tr td {
    width: 50%;
    display: flex;
    padding: 15px 40px;
    font-size: 18px;
    line-height: 2;
    text-align: center;
    text-align: left;
}

.table-01 tr .table-title {
    color: white;
    background: #edae77;
}

.table-01 tr:nth-of-type(n+2) {
    border-top: 1px solid #fff;
}

.table-01 tr th {
    border-left: 1px solid white;
}

.table-01 tr td {
    border-left: 1px solid #fff;
    background: #ffecdc;
}

@media (max-width: 1024px) {
    .table-01 tr th,
    .table-01 tr td {
        font-size: 16px;
    }
}

@media (max-width: 599px) {
    .s-headline2 {
        font-size: 16px;
    }
    .table-01 tr th,
    .table-01 tr td {
        width: 100%;
    }
    .table-01 tr td+td {
        border-top: 1px solid #fff;
        border-left: none;
    }
    [class*="up-gapy-"]>*:last-child {
        padding-bottom: 0;
    }
}


.check li {
    margin-bottom: 10px;
    padding-left: 30px;
    font-size: 18px;
    line-height: 2;
    position: relative;
}

.check li:before {
    content: "";
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #edae77;
    position: absolute;
    top: 8px;
    left: 0;
}
.check li:after {
    content: "\f00c";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 12px;
    color: #fff;
    position: absolute;
    top: 8px;
    left: 5px;
}

.title-left-deco {
    margin-bottom: 15px;
    padding-bottom: 5px;
    font-weight: bold;
    font-size: 20px;
    border-bottom: solid 3px #dfe3ed;
    position: relative;
}
.title-left-deco::before {
    content: "";
    width: 50px;
    height: 3px;
    display: block;
    background-color: #edae77;
    position: absolute;
    bottom: -3px;
    left: 0;
}

.border-10 {
    overflow: hidden;
    border-radius: 10px;
}

.reco li {
    margin-bottom: 15px;
    padding-bottom: 15px;
    padding-left: 50px;
    font-size: 18px;
    line-height: 2.5;
    border-bottom: dashed 1px silver;
    position: relative;
}

.reco li:last-child {
    margin-bottom: 0px;
}

.reco li .num {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    border-radius: 50%;
    background: #edae77;
    position: absolute;
    top: 0px;
    left: 0;
}

@media (max-width: 599px) {
  .table-01 tr .table-title{
       padding: 10px 40px;
  }
    .reco li {
        font-size: 16px;
    }
}

.detail-content-text h2 {
    margin-top: 50px;
    margin-bottom: 20px;
    padding: 0.5em;
    font-weight: bold;
    font-size: 22px;
    letter-spacing: 2px;
    border-bottom: 3px solid  #edae77;
}

.detail-content-text h3 {
    margin-top: 50px;
    margin-bottom: 20px;
    padding: 0.5em 1em;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    letter-spacing: 2px;
    background: #edae77;
}

.detail-content-text h4 {
    margin-top: 50px;
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 18px;
    color: #edae77;
    letter-spacing: 2px;
}
.detail-content-text ol {
    counter-reset: count 0;
}
.detail-content-text ol li {
    margin: 10px 0;
    padding-left: 20px;
    font-size: 16px;
    color: #000;
    position: relative;
}
.detail-content-text ol li::before {
    content: counter(count) ". ";
    display: inline-block;
    counter-increment: count 1;
    color: #edae77;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 0;
}
.detail-content-text ul li {
    margin: 10px 0;
    padding-left: 20px;
    font-size: 16px;
    color: #000;
    position: relative;
}

.detail-content-text ul li::before {
    content: "";
    width: 15px;
    height: 15px;
    display: inline-block;
    border-radius: 50%;
    background: #edae77;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 0;
}
.detail-content-text ol li marker {
    display: none;
}

.list-cmp03 .item {
    padding: 20px;
}
.list-cmp03 .item:not(:last-child) {
    border-bottom: 1px dashed #edae77;
}
.list-cmp03 .datattl {
    width: 150px;
    flex-shrink: 0;
    margin-right: 20px;
}
@media (max-width: 599px) {
    .list-cmp03 .item {
        flex-wrap: wrap;
        padding: 20px 10px;
    }
    .list-cmp03 .datattl {
        width: 100%;
        margin-bottom: 5px;
    }
    .list-cmp03 .data {
        width: 100%;
    }
}

.affiliation {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 40px 20px 20px;
    border-radius: 0 50px 0 0;
    background: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
}

.m-btn a,
.m-btn button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1.5em;
    font-family: "Noto Serif JP", serif;
    font-weight: 500;
    border: solid 1px;
    border-radius: 5px;
}

.m-btn a:hover,
.m-btn button:hover {
    color: #fff;
    border: solid 1px #edae77;
    background: #edae77;
    opacity: 1;
}

.m-btn button {
    width: 100%;
    max-width: 250px;
    background: none;
}
.m-btn.min a {
    width: 100%;
    max-width: 170px;
    padding: 15px;
}
.consept-area .min-ttl .en,
.consept-area .min-ttl .ja,
.consept-area .m-btn {
    color: #fff;
}

.consept-area .imgs li:nth-child(odd) {
    margin-top: 20px;
}

.consept-area .text {
    color: #fff;
    position: relative;
    z-index: 1;
}
.consept-area::after {
    content: "";
    width: 42%;
    height: 100%;
    background: #534a41;
    opacity: 0.8;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}
.consept-area::before {
    content: "";
    width: 58%;
    height: 100%;
    background: #fff;
    opacity: 0.3;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 0;
}

.consept-area .sb-ttl {
    margin-bottom: 50px;
    font-family: "Noto Serif JP", serif;
    font-size: 46px;
    color: #fff;
    line-height: 1;
}

.consept-area .m-btn a {
    width: 100%;
    max-width: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.text-01 {
    margin-bottom: 30px;
    padding-left: 4rem;
    font-weight: 600;
    font-size: 18px;
    color: #edae77;
    line-height: 1;
    letter-spacing: 3px;
    position: relative;
}
.text-01::after {
    content: "";
    width: 3rem;
    height: 2px;
    background: #edae77;
    position: absolute;
    top: 70%;
    left: 0;
}

.reason-area .sbtext {
    margin-bottom: 20px;
    font-weight: 600;
    font-size: 26px;
    line-height: 1.8;
}

.reason-area .sb-ttl {
    margin-bottom: 50px;
    font-size: 20px;
    line-height: 2;
    letter-spacing: 15px;
    text-align: center;
}

.reason-area .text-area {
    width: 42%;
}

.reason-area .img-area {
    width: 53%;
}


.border-r10 {
    overflow: hidden;
    border-radius: 10px;
}

.service-area .box {
    padding: 20px;
    text-align: center;
    border-radius: 10px;
    background: #fff;
    -webkit-box-shadow: 0px 2px 10px #dadada;
    box-shadow: 0px 2px 10px #dadada;
}
.service-area .img {
    max-width: 110px;
    margin: 0 auto 20px;
}
.service-area .ttl {
    font-family: "Noto Serif JP", serif;
    font-weight: 600;
    font-size: 30px;
    text-align: center;
}
.service-area .sb-ttl {
    margin-bottom: 50px;
    font-size: 20px;
    line-height: 2;
    letter-spacing: 15px;
    text-align: center;
}
.service-area::after {
    content: "";
    width: 900px;
    height: 80%;
    border-radius: 10px;
    background: #f9e8d8;
    transform: translateX(-50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: -1;
}

.works-area .img img {
    -webkit-mask-image: url('/import/tenant_1/160.16.148.231/html/images/hg.webp');
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
    mask-image: url('/import/tenant_1/160.16.148.231/html/images/hg.webp');
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
}
.works-area a {
    position: relative;
}
.works-area .text-box {
    width: 60%;
    padding: 1em;
    color: #fff;
    border-radius: 10px;
    background: #edae78;
    position: absolute;
    bottom: -6%;
    right: 0;
}
.works-area .slick-arrow {
    width: 70px;
    height: 70px;
    display: flex!important;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    border: solid 1px;
    border-radius: 50px;
    cursor: pointer;
    position: absolute;
    top: -150px;
    right: 200px;
    z-index: 1;
}
.works-area .btn-next.slick-arrow {
    left: initial;
    right: 100px;
}

.works-area .m-btn a,
.ar-area .m-btn a {
    width: 100%;
    max-width: 300px;
}

.ar-area .m-btn a {
    background: #fff;
}

.works-area .slick-width {
    max-width: 1500px;
    margin: auto;
}

.recruit-area {
    background: #c7bdb3;
}
.recruit-area .box a {
    width: 96%;
    max-width: 800px;
    height: 300px;
    display: block;
    margin: auto;
    border: solid 5px #453325;
    border-radius: 10px;
    position: relative;
    animation: move_c 1s infinite;
}
@keyframes move_c {
    0% {transform: translate(0px, 0)}
    50% {transform: translate(0px, 0) rotateZ(5deg)}
}
[data-element-id] .recruit-area .box a{
  animation: none;
}
.recruit-area .min-ttl {
    width: 55%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
    padding: 10px 0;
    font-weight: bold;
    font-size: 50px;
    color: #fff;
    line-height: 1;
    letter-spacing: 15px;
    border-radius: 0 10px 10px 0;
    background: #453325;
    position: relative;
    z-index: 1;
}

.recruit-area .img {
    width: 100%;
    max-width: 250px;
    position: absolute;
    bottom: -16px;
    left: 55%;
    z-index: 2;
}

.recruit-area .bg-img {
    width: 100%;
    height: 100%;
    background-repeat: repeat;
    background-position: center center;
    background-color: #fff;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}

.recruit-area .txt-01 {
    width: 250px;
    padding: 5px;
    font-size: 30px;
    color: #fff;
    transform: rotate(-5deg);
    position: absolute;
    top: 50%;
    left: 10%;
    z-index: 1;
}


.recruit-area .txt-02 {
    width: 250px;
    padding: 5px;
    font-size: 30px;
    color: #fff;
    text-align: center;
    transform: rotate(-5deg);
    position: absolute;
    top: 70%;
    left: 25%;
    z-index: 1;
}
.recruit-area .txt-01::after,
.recruit-area .txt-02::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-image: url('/import/tenant_1/160.16.148.231/html/images/bgc.webp');
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    transform: rotate(5deg);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;

    scale: 1.5;
}

.blog-area {
    margin: 80px 0;
}

.blog-area::after,
.bg-area::after {
    content: "";
    width: 96%;
    max-width: 800px;
    height: 100%;
    border-radius: 10px;
    background: #f9e8d8;
    transform: translateX(-50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: -1;
}

.mainwrap .blog-area::after{
  content: none;
}

.blog-area .box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 30px;
    border-radius: 10px;
    background: #fff;
    -webkit-box-shadow: 0px 2px 10px #dadada;
    box-shadow: 0px 2px 10px #dadada;
}

.blog-area .box .img {
    width: 30%;
    border-radius: 10px;
}
.blog-area .box .text-area {
    width: 65%;
}

.blog-area .box .btn {
    color: #edae77;
    text-align: right;
}

.blog-area .box .date {
    flex-shrink: 0;
    margin-right: 20px;
    font-weight: 500;
    font-size: 14px;
    color: #999;
}

.blog-area .m-btn a {
    width: 100%;
    max-width: 300px;
}


.blog .blog-area {
    margin: 0;
}

.blog .blog-area::after {
    content: none;
}

.blog .blog-area .box .img {
    width: 20%;
    border-radius: 10px;
}
.blog .blog-area .box .text-area {
    width: 75%;
}
.text-02 {
    width: 100%;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: inherit;

    -webkit-line-clamp: 2;
}

.contact-area .img-box {
    clip-path: polygon(50% 0%, 100% 20%, 100% 100%, 0 100%, 0 20%);
}

.contact-area .tel-box {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 30px;
    border-radius: 999px;
    background: #fff;
}
.contact-area .en,
.contact-area .ja {
    color: #fff;
}
.contact-area .ttl {
    margin-bottom: 10px;
    font-weight: 500;
    font-size: 20px;
    color: #2ca09a;
    letter-spacing: 2px;
    text-align: center;
}
.contact-area .tim {
    font-size: 18px;
    text-align: center;
}
.contact-area .right {
    width: 100%;
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
}
.contact-area .right .mail-box a {
    margin-bottom: 20px;
    color: #fff;
    letter-spacing: 3px;
    border: solid 1px #2ca09a;
    border-radius: 9999px;
    background: #2ca09a;
}
.contact-area .right .mail-box,
.contact-area .right .line-box {
    overflow: hidden;
}

.contact-area .right .mail-box a,
.contact-area .right .line-box a {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px 15px;
    font-size: 20px;
}
.contact-area .right .mail-box .icon {
    line-height: 0;
}
.contact-area .right .line-box .icon {
    font-size: 25px;
    line-height: 0;
}
.contact-area .right .mail-box .icon img {
    width: 20px;
}
.contact-area .right .icon {
    margin-right: 5px;
}
.contact-area .right .line-box a {
    color: #fff;
    letter-spacing: 3px;
    border: solid 1px  #00b900;
    border-radius: 9999px;
    background: #00b900;
}
.contact-area .right .mail-box a:hover {
    color: #2ca09a;
    background: #fff;
    opacity: 1;
}
.contact-area .right .line-box a:hover {
    color: #00b900;
    background: #fff;
    opacity: 1;
}
.contact-area .right .address {
    font-size: 12px;
    color: #2ca09a;
}
.contact-area .right .txt {
    margin-right: 10px;
    line-height: 120%;
}
.contact-area .right .txtin {
    display: block;
}
.contact-area .right .tel a {
    font-weight: bold;
    font-size: 30px;
}
.contact-area .right .tel a:before {
    content: "\f879";
    margin-right: 5px;
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
    font-size: 24px;
}
.contact-area .right .mail-box a,
.contact-area .right .line-box a {
    width: 100%;
    max-width: 346px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    justify-content: center;
    padding: 5px 15px 5px 20px;
}
.contact-area .left {
    width: 100%;
    max-width: 170px;
    padding: 30px;
    border-radius: 0 40px 40px 0;
    background: #fff;
    position: absolute;
    left: 0;
    z-index: 10;
}

.contact-area .sb-ttl {
    margin-bottom: 50px;
    font-size: 20px;
    color: #fff;
    line-height: 2;
    letter-spacing: 15px;
    text-align: center;
}
.contact-area .box.mail-box {
    height: 100%;
}
.contact-area .box.mail-box a {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 30px;
    font-size: 28px;
    color: #fff;
    border-radius: 9999px;
    background: #edae77;
}

.contact-area .box.mail-box a img {
    opacity: 1;
}
.contact-area .box.mail-box a .img {
    width: 55px;
    margin-right: 15px;
}

.copy {
    width: 100%;
    margin-top: 50px;
    text-align: center;
}

.mail-btn a {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 30px;
    font-size: 28px;
    color: #fff;
    letter-spacing: 5px;
    border-radius: 10px;
    background: #edae77;
}

.mail-btn a .img {
    width: 55px;
    margin-right: 15px;
}

.add-area {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 50px;
    padding: 80px 0;
    border-bottom: solid 1px #ccc;
}

.add-area .logo {
    max-width: 250px;
    margin-bottom: 30px;
}

@media (max-width: 1024px) {
    .consept-area .sb-ttl {
        font-size: 20px;
    }
    .reason-area .sbtext {
        font-size: 20px;
    }
    .service-area .ttl {
        font-size: 24px;
    }
    .works-area .slick-arrow {
        width: 50px;
        height: 50px;
        right: 170px;
        padding: 0;
    }
    .blog-area .box {
        padding: 30px 15px;
    }
    .blog-area .box .date {
        margin-right: 18px;
    }
    .blog-area .box .btn {
        font-size: 14px;
    }
    .contact-area .img-box {
        clip-path: polygon(50% 0%, 100% 10%, 100% 100%, 0 100%, 0 10%);
    }

    .contact-area .sb-ttl {
        font-size: 18px;
    }
    .contact-area .box.mail-box a,
    .mail-btn a {
        padding: 15px;
        font-size: 20px;
    }
    .contact-area .tel-box {
        padding: 15px;
    }
    .contact-area .tel a:before {
        width: 40px;
        height: 40px;
    }
    .contact-area .box.mail-box a .img,
    .mail-btn a .img {
        width: 45px;
    }
    .f-nav .item {
        font-size: 14px;
    }
    .m-btn a {
        padding: 1em;
    }
}

@media (max-width: 599px) {
  .works-area .slick-arrow{
        width: 50px;
    height: 50px;
    right: initial;
    left: 10px;
    padding: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .works-area .btn-next.slick-arrow {
    left: initial;
    right: 10px;
}
  .works-area .text-box{
        width: 85%;
    padding: 0.5em;
        font-size: 14px;
  }
  .reason-area .sb-ttl{
        line-height: 2;
    letter-spacing: 1px;
    font-size: 16px;
  }
  .blog-area::after,
.bg-area::after {
  width: 86%;
}
    .reason-area .text-area {
        width: 100%;
    }

    .reason-area .img-area {
        width: 100%;
    }
    .consept-area .sb-ttl {
        margin-bottom: 30px;
    }
    .overview .map {
        margin-bottom: 0;
    }
    .map {
        padding-top: 60%;
    }
    .contact-area .box.mail-box a,
    .mail-btn a {
        font-size: 18px;
    }
    .contact-area .tel a {
        font-size: 24px;
    }
    .contact-area .sb-ttl {
        font-size: 16px;
        letter-spacing: 5px;
    }
    .blog-area .box .date {
        width: 100%;
        margin-bottom: 10px;
        margin-right: 0;
    }
    .blog-area .box .btn,
    .blog .blog-area .box .img,
    .blog-area .box .img,
    .blog .blog-area .box .text-area {
        width: 100%;
    }
    .blog-area .box .img {
        width: 100%;
    }
    .blog-area .box .text-area {
        width: 100%;
    }
    .blog-area .box {
        flex-wrap: wrap;
        padding: 10px;
    }
    .m-btn.min a {
        padding: 10px;
    }
    .service-area .ttl {
        font-size: 16px;
    }
    .service-area .img {
        max-width: 80px;
    }
    .service-area .box {
        padding: 10px;
    }
    .service-area .sb-ttl {
        font-size: 16px;
        letter-spacing: 5px;
    }
    .consept-area .m-btn a {
        margin: auto;
    }
    .consept-area::after {
        width: 100%;
    }
    .min-ttl {
        margin-bottom: 40px;
    }
    .affiliation {
        width: 80%;
        padding: 10px 30px 10px 10px;
    }
    .catch .ttl {
        font-size: 26px;
        letter-spacing: 5px;
    }
    .slick01>li:nth-child(n+4) {
        display: none!important;
    }
    .recruit-area .min-ttl {
        width: 90%;
        font-size: 28px;
    }
    .recruit-area .txt-01,
    .recruit-area .txt-02 {
        width: 50%;
        font-size: 20px;
        top: 35%;
    }
    .recruit-area .txt-02 {
        top: 55%;
        left: 15%;
    }
    .recruit-area .txt-01::after,
    .recruit-area .txt-02::after {
        scale: 1.2;
    }
    .recruit-area .img {
        width: 100%;
        max-width: 150px;
        position: absolute;
        bottom: -10px;
        left: initial;
        right: 0;
    }
}

.bg-area .box {
    padding: 30px;
    line-height: 2;
    border-radius: 10px;
    background: #fff;
    -webkit-box-shadow: 0px 2px 10px #dadada;
    box-shadow: 0px 2px 10px #dadada;
}

.flow-area .img {
    overflow: hidden;
    border-radius: 10px;
}
.cmn-flow-02 li+li {
    margin-top: 50px;
}

.markerY {
    background-image: -webkit-gradient(linear, left top, left bottom, color-stop(70%, rgba(0 0 0 / 0)), color-stop(70%, #f1eb49));
    background-image: linear-gradient(rgba(0 0 0 / 0) 70%, #f1eb49 70%);
}

.bg-border {
    overflow: hidden;
    padding: 40px;
    outline: 2px solid #edae77;
    outline-offset: -10px;
    border-radius: 15px;
    background: #fff;
    -webkit-box-shadow: 0px 2px 10px #dadada;
    box-shadow: 0px 2px 10px #dadada;
    position: relative;
}
.br10 img {
    filter: drop-shadow(10px 10px 1px #8d8d8d);
}

@media (max-width: 599px) {
    .bg-border {
        padding: 20px;
    }
}

.price-form-unit {
    display: none;
}
.price1 .h4r.tit {
    margin-bottom: 35px;
    padding-bottom: 5px;
    font-weight: 600;
    font-size: 28px;
    border-bottom: 3px solid #edae77;
}
.price1 #price1 {
    max-width: 148px;
    vertical-align: middle;
    margin: 0 16px;
    padding: 0 5px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 28px;
    line-height: 50px;
    text-align: center;
    border: 1px solid #bfbfbf;
}
.price-form dt {
    width: 70%;
    padding: 0 0 20px 0;
}
.price-form  dd {
    width: 30%;
    padding: 0 0 20px 0;
}
.price1 #check1 {
    width: 100%;
    height: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 10px;
    font-weight: bold;
    color: #fff;
    line-height: 1.2;
    text-align: center;
    border: none;
    border-radius: 25px / 50%;
    background: #edae77;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    position: relative;
}

.price1 #check1 .ar{
      position: absolute;
    right: 15px;
}

.price1 #check1:hover {
    opacity: 0.5;
    cursor: pointer;
}

.price1 .img {
    margin-top: -40px;
    margin-bottom: -5px;
    text-align: right;
}
.price1 .img .l {
    width: 16%;
    display: inline-block;
}
.price2 {
    padding: 30px;
    border: 2px solid #edae77;
    border-radius: 10px;
    background: #fff;
}
.price2 .in {
    max-width: 740px;
    margin: 0 auto;
}
.price2 .h4r {
    margin-bottom: 20px;
    font-weight: 600;
    font-size: 24px;
    text-align: center;
}
.price2 .box-flexb dl {
    width: 48%;
    padding-bottom: 30px;
}
.price2 .box-flexb dt {
    width: 100%;
    display: block;
    color: #1522c9;
    text-align: center;
}
.price2 .box-flexb dl:first-child dt {
    color: #edae77;
}
.price2 .box-flexb dd input {
    max-width: 150px;
    display: inline-block;
    vertical-align: middle;
    margin: 0 16px;
    padding: 6px 5px;
    font-size: 28px;
    text-align: right;
    border: 1px solid #bfbfbf;
    border-radius: 25px;
}
.price2 .box-flexb dd {
    width: 100%;
    padding-bottom: 20px;
}
.price2 .info dt {
    width: 100%;
    float: right;
    padding: 30px 5px;
    color: #fff;
    line-height: 2;
    text-align: center;
    border-radius: 9999px;
    background: #edae77;
    position: relative;
}
.price2 .info dd {
    margin-top: -20px;
    padding-bottom: 0;
}

.result-price {
    font-size: 30px;
}
.reason-m .tit{
  font-size: 24px;
}
.reason-m .img{
  position: relative;
}

.reason-m .img img{
  border-radius: 10px;
}

.reason-m .re-text{
    position: absolute;
    bottom: -29px;
    background: #edae77;
    color: #fff;
    padding: 0.5em 1em;
    border-radius: 10px;
    left: 10px;
    font-weight: bold;
    border: solid 3px #a2a09f;
}
@media (max-width: 599px) {
  .reason-m .tit{
  font-size: 20px;
}
    .price1 .h4r.tit {
        font-size: 24px;
    }
    .price-form dt {
        width: 100%;
        display: flex;
    }
    .price1 #price1 {
        max-width: 130px;
    }
    .price-form dd {
        width: 60%;
        margin: auto;
    }
    .price2 .box-flexb dl {
        width: 100%;
    }
    .price2 .box-flexb dd {
        text-align: center;
    }
    .price2 {
        padding: 15px;
    }
}
.price3 .table {
    background: #fff;
}
.price3 .table dl {
    padding: 18px 3%;
    border-bottom: 1px solid #bfbfbf;
}
.price3 .table dd {
    font-size: 18px;
    text-align: right;
}
.price3 .table dt {
    font-size: 18px;
}
.price3 .table dd strong {
    font-size: 36px;
    color: #edae77;
}
@media (max-width: 599px) {
    .price3 .table dt {
        width: 100%;
    }
    .price3 .table dd {
        width: 100%;
    }
}
.price4 .wrap {
    padding: 35px 3% 0 3%;
    border: 2px solid #edae77;
    background: #fff;
}
.price4 .tit {
    padding: 0 0 30px 0;
    text-align: center;
}
.price4 .tit .h4r {
    padding-bottom: 10px;
    font-weight: normal;
}
.price4 p {
    padding: 0 0 20px 0;
}
.price4 dl {
    padding-bottom: 30px;
}
.price4 ul {
    padding: 0 0 30px 0;
}
.price4 .tbox {
    width: 64%;
}
.price4 .imgs {
    width: 30%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    align-items: flex-end;
    -ms-flex-align: end;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}
.price4 dl.r dt {
    color: #edae77;
}
.price4 dl.b dt {
    color: #1522c9;
}
.price4 dl dd strong {
    font-size: 36px;
}
.price4 dl.r dd strong {
    color: #edae77;
}
.price4 dl.b dd strong {
    color: #1522c9;
}
.price4 .imgs p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    text-align: center;
}
.price4 .imgs p:before {
    content: "";
    width: 1px;
    height: 60px;
    display: inline-block;
    vertical-align: bottom;
    background: #edae77;
    -webkit-transform: rotate(-30deg);
    transform: rotate(-30deg);
}
.price4 .imgs p:after {
    content: "";
    width: 1px;
    height: 60px;
    display: inline-block;
    vertical-align: bottom;
    background: #edae77;
    -webkit-transform: rotate(30deg);
    transform: rotate(30deg);
}
.price4 .imgs .w {
    display: inline-block;
    padding: 0 1.5em;
}
.price4 .imgs p .b {
    font-weight: bold;
    font-size: 24px;
}
.price4 .imgs p .r {
    color: #edae77;
}
@media (max-width: 599px) {
    .price2 .box-flexb dd input {
        max-width: 110px;
        font-size: 16px;
    }
    .price4 .tbox {
        width: 100%;
    }
    .price4 .imgs {
        width: 100%;
    }
}

[data-element-id] .price-form-unit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 50px 0;
    padding: 70px 50px 50px;
    border: 2px solid green;
    position: relative;
}

[data-element-id] .price-form-unit::before {
    content: "シミュレーションの計算を行うときの単価はこちらで設定してください";
    width: 100%;
    display: block;
    padding: 5px;
    font-weight: bold;
    font-size: 12px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: green;
    position: absolute;
    top: 0;
    left: 0;
}

[data-element-id] .unit1,
[data-element-id] .unit2,
[data-element-id] .unit3,
[data-element-id] .unit4 {
    min-width: 120px;
    display: inline-block;
    margin: 0 5px;
    padding-top: 35px;
    text-align: center;
    border: 2px solid #c8161d;
    position: relative;
}

[data-element-id] .unit3,
[data-element-id] .unit4 {
    border: 2px solid darkblue;
}

[data-element-id] .unit1::before,
[data-element-id] .unit2::before,
[data-element-id] .unit3::before,
[data-element-id] .unit4::before {
    width: 100%;
    display: block;
    padding: 5px;
    font-weight: bold;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: #c8161d;
    position: absolute;
    top: 0;
    left: 0;
}

[data-element-id] .unit3::before,
[data-element-id] .unit4::before {
    background-color: darkblue;
}

[data-element-id] .unit1::before {
    content: "PHB HOMEの足場単価";
}
[data-element-id] .unit2::before {
    content: "PHB HOMEの塗装単価";
}
[data-element-id] .unit3::before {
    content: "一般的な足場単価";
}
[data-element-id] .unit4::before {
    content: "一般的な塗装単価";
}

.estimate-note li {
    padding-left: 25px;
    position: relative;
}
.estimate-note li:not(:last-child) {
    margin-bottom: 10px;
}

.estimate-note li::after {
    content: "※";
    position: absolute;
    top: 0px;
    left: 0px;
}
.cat {
    flex-grow: 1;
}
.cat span {
    display: inline-block;
    margin: 0 0.5% 0.5% 0;
    padding: 0.5%;
    font-size: 14px;
    color: #fff;
    border-radius: 5px;
    background: #edae77;
}

.contact-box .box {
    padding: 2em 3em;
    border-radius: 2em;
    background: #fff;
}

.contact-box dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 40px;
}

.contact-box dt {
    width: 200px;
}

.contact-box dt .tit {
    width: 100%;
}

.contact-box dd {
    width: calc(100% - 200px);
}

.contact-box .form dt .label {
    display: inline-block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 2px 10px;
    font-size: 12px;
    color: #fff;
    border-radius: 5px;
    background: red;
}

.contact-box .form .form_shape li {
    display: inline-block;
    margin-bottom: 10px;
    margin-right: 20px;
}

.contact-box .form .form_shape input {
    display: none;
}

.contact-box .form .form_shape label {
    padding-left: 25px;
    line-height: 28px;
    position: relative;
    z-index: 0;
}

.contact-box .form .form_shape label:before {
    content: "";
    width: 18px;
    height: 18px;
    display: inline-block;
    border: 2px solid;
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 0;
}

.contact-box .form .form_shape label:after {
    content: "";
    width: 12px;
    height: 12px;
    display: block;
    display: none;
    border-radius: 50%;
    background: var(--back-color-03);
    position: absolute;
    top: 3px;
    left: 3px;
}

.contact-box .form .form_shape input:checked+label:after {
    display: block;
}

.contact-box .form dd input,
.contact-box .form dd textarea {
    width: 100%;
    height: 100%;
    padding: 10px 10px;
    border: none;
    border: solid 1px #ccc;
    border-radius: 5px;
}

.contact-box .form .address-code dd input {
    width: 50%;
}

.contact-box .form .address {
    margin-bottom: 20px;
}

.contact-box .form .address .txt {
    display: inline-block;
    padding-left: 30px;
    position: relative;
}

.contact-box .form .address .txt input {
    width: 100px;
    position: relative;
    z-index: 0;
}

.contact-box .form dd.radiobtn {
    padding: 0.5em;
}

.contact-box .form dd.radiobtn label {
    display: inline-block;
    margin: 0.5em 0;
    padding: 0 10px 0 30px;
    position: relative;
}

.contact-box .form dd.radiobtn label::before {
    content: "";
    width: 20px;
    height: 20px;
    display: block;
    border: 2px solid #dcdcdc;
    border-radius: 3px;
    background-color: white;
    position: absolute;
    top: 0.2em;
    left: 0;
}

.contact-box .form dd.radiobtn label:hover {
    text-decoration: underline;
    cursor: pointer;
}

.contact-box .form dd.radiobtn input {
    display: none;
}

.contact-box .form dd.radiobtn input:checked+label {
    text-decoration: underline;
}

.contact-box .form dd.radiobtn input:checked+label::after {
    content: "\f00c";
    width: 0;
    height: 0;
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 20px;
    color: var(--txt-color-03);
    line-height: 1;
    background-color: transparent;
    position: absolute;
    top: 0;
    left: 2px;
}

.contact-box .form dd.radiobtn input+label {
    margin-left: 15px;
}

.m-btn.d-fl {
    width: 45%;
    text-align: center;
}

@media (max-width: 1024px) {
    .contact-box .box {
        padding: 2em;
    }
}

@media (max-width: 599px) {
    .contact-box .box {
        padding: 2em 1em;
    }

    .contact-box dt {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
    }

    .contact-box dt .tit {
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
    }

    .contact-box .form dt .label {
        margin-left: 1em;
    }

    .contact-box dt,
    .contact-box dd {
        width: 100%;
    }

    .contact-box dd {
        margin-top: 0.5em;
    }

    .contact-box .form dd.radiobtn {
        padding: 0.5em 0;
    }
}
.boxno1 .txtbox {
    margin-top: -25px;
    position: relative;
    z-index: 0;
}
.txtbox .tit.num {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 10px;
    padding: 10px;
    font-weight: bold;
    font-size: 18px;
    color: #edae78;
    text-align: center;
    border: solid 3px;
    border-radius: 50%;
    background: #fff;
}

.ttl-deta {
    margin: 20px 0;
    padding-left: 10px;
    font-size: 26px;
    letter-spacing: 2px;
    position: relative;
}
.ttl-deta::after {
    content: "";
    width: 3px;
    height: 40px;
    background: #edae78;
    position: absolute;
    top: 0;
    left: 0;
}
.uk-lb {
    -webkit-transition: 0.4s ease;
    transition: 0.4s ease;
}
.uk-lb:hover {
    opacity: 0.6;
    cursor: pointer;
}
@media (max-width: 599px) {
  .ttl-deta{
    font-size: 20px;
  }
}

[data-element-id] [data-ab-test-contents] {
    width: 100%;
    border: 3px solid #2ca09a;
    position: absolute;
}

[data-element-id] [data-ab-test-contents] a {
    margin-top: 20px;
    right: 0;
}

[data-element-id] [data-ab-test-contents] li {
    padding-top: 20px;
}

[data-element-id] [data-ab-test-contents]::before {
    content: "Aパターン";
    width: 100%;
    display: block;
    padding: 0.5em 0.2em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: #2ca09a;
    position: absolute;
    top: 0;
    left: 0;
}

[data-element-id] [data-ab-test-contents]+[data-ab-test-contents] {
    border: 3px solid #24ac50;
}

[data-element-id] [data-ab-test-contents]+[data-ab-test-contents]::before {
    content: "Bパターン";
    background-color: #24ac50;
    z-index: 1;
}

[data-element-id] .up-d-none{
display: block;
  border: solid 4px black;
    position: relative;
}
[data-element-id] .up-d-none:after{
   content: "モバイル用";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: black;
}
[data-element-id].fead-order>* {
    opacity: 1;
    -webkit-transition: 0.5s ease-out;
    transition: 0.5s ease-out;
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

.h1-box{
  display: none;
}

.fead-bound {
    -webkit-transition: 0.4s cubic-bezier(0.68, -0.6, 0.32, 2);
    transition: 0.4s cubic-bezier(0.68, -0.6, 0.32, 2);
    -webkit-transform-origin: center center;
    transform-origin: center center;
}

.fead-bound.mv {
    -webkit-animation: bound 2.4s ease-in-out;
    animation: bound 2.4s ease-in-out;
}

@-webkit-keyframes bound {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    10% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    15% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    33% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    43% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    48% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    66% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    76% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    81% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}

@keyframes bound {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    10% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    15% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    33% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    43% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    48% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    66% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    76% {
        -webkit-transform: scale(1.05);
        transform: scale(1.05);
    }

    81% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}

.lightbox-img {
    overflow: hidden;
    border-radius: 10px;
    position: relative;
}

.lightbox-img::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: 0.1s linear;
    transition: 0.1s linear;
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.lightbox-img:hover::before {
    background: none;
}

.lightbox-img .search-icon {
    width: 20%;
    margin: auto;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    z-index: 1;
}

[data-element-id] .h1-box{
display: block;
  border: solid 4px #00ff50;
    position: relative;
    margin-bottom: 50px;
}
[data-element-id] .h1-box:after{
   content: "h1の変更はこちらでお願いいたします。";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #00ff50;
}

[data-element-id] .gnav .list02{
    visibility: visible;
    opacity: 1;
    border: solid 2px #f48100;
    padding: 0;
    top: 0;
    position: relative;
}
[data-element-id] .gnav .list02:after{
  display: block;
  content: "事業内容";
  color: #fff;
  font-weight: 700;
  background: #f48100;
  text-align: center;
  font-size: 12px;
  text-shadow: 0 0 black;
}

[data-element-id] .up-sp-txt {
    width: 375px;
    margin: auto;
}
[data-element-id] .up-sp-txt .min-ttl .en {
    font-size: 32px;
    letter-spacing: 5px;
}
[data-element-id] .up-sp-txt .min-ttl .ja {
    font-size: 20px;
    letter-spacing: 5px;
}
[data-element-id] .reason-area .up-sp-txt .sbtext {
    font-size: 20px;
}
[data-element-id] .main-visual .up-sp-txt{
  transform: translate(-50%,0);
    position: absolute;
    top: 25%;
    left: 50%;
}
[data-element-id] .up-sp-txt .catch{
      transform: none;
    position: relative;
    top: initial;
    left: initial;
}
[data-element-id] .up-sp-txt .catch .sbttl {
    font-size: 14px;
}
[data-element-id] .up-sp-txt .catch .ttl {
    font-size: 26px;
    letter-spacing: 5px;
}
[data-element-id] .consept-area .up-sp-txt{
    position: absolute;
    top: -100px;
    left: 0;
}

[data-element-id] .topvisual .up-sp-txt{
  transform: translate(-50%, -50%);
    position: absolute !important;
    top: 60%;
    left: 50%;
}
[data-element-id] .topvisual .up-sp-txt .head{
      transform: none;
    position: relative!important;
    top: initial;
    left: initial;
    font-size: 24px;
}
[data-element-id] .cmn-flow-02 .up-sp-txt{
      position: absolute;
    right: 0;
    top: -10%;

}

[data-element-id] .slick01{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

[data-element-id] .slick01 > div{
      display: contents;
}

[data-element-id] .slick01 li{
  width: 25%;
}

[data-element-id] .blog-area .box .date{
  flex-shrink: 1;
}

[data-element-id] .gnav .list01 .item01{
  height: 100%;
}

[data-element-id] .list-cmp09 .data{
  display: block;
}

[data-element-id] .attached-altlist{
      display: block;
    border: solid 4px #009fff;
    position: relative;
}

[data-element-id] .attached-altlist:after {
    content: "altlistとalt有！";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #009fff;
    width: 100%;
}

[data-element-id] .not-altlist.not-alt{
      display: block;
    border: solid 4px #ff0000;
    position: relative;
}

[data-element-id] .not-altlist.not-alt:after {
    content: "altlistとalt無し！";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #ff0000;
    width: 100%;
}

[data-element-id] .not-altlist{
      display: block;
    border: solid 4px #ffed00;
    position: relative;
}

[data-element-id] .not-altlist:after {
    content: "altlist無し！";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #000;
    text-align: center;
    background: #ffed00;
    width: 100%;
}


[data-element-id] .not-alt{
      display: block;
    border: solid 4px #b600ff;
    position: relative;
}

[data-element-id] .not-alt:after {
    content: "altlist有、alt無し！";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #b600ff;
    width: 100%;
}

[data-ab-test-block] [data-ab-test-contents]+[data-ab-test-contents] {
  display: none;
  
}

[data-element-id] .reason-m .up-sp-txt .tit{
  font-size: 20px;
}

.ownername{
  font-family: "Yuji Boku", serif;
  font-size: 38px;
  font-weight: 600;
}
