@charset "utf-8";
/*===================================
  基本設定
===================================*/

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
/* font-family: 'Noto Sans JP', sans-serif; */
@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@300;400;500;700;900&display=swap");

/* font-family: 'Zen Maru Gothic', sans-serif; */
@font-face {
    font-family: "lucida handwriting italic";
    src: url("/upload/tenant_1/lucida handwriting italic.ttf");
}

/* font-family: 'lucida handwriting italic', sans-serif; */
.color01,
.c-p {
    color: #ef8b68;
}

.i-text-s i {
    font-size: 20px;
    color: #fff;
    text-shadow: 0 0 2px black;
}

.i-text-s .c-bs i {
    color: #cefaff;
}

.color02 {
    color: #724717;
}

.color03 {
    color: #f7ebd7;
}

.color04 {
    color: #000;
}

.bgcolor01 {
    background-color: #f7ebd7;
}

.bgcolor02 {
    background: #ef8b68;
}

.bgcolor03 {
    background-color: #000;
}

.bgcolor04 {
    background-color: #000;
}

.m-n40 {
    margin-top: -40px;
}

.area.m-n40 {
    padding-top: 120px;
}

/* 共通コンテンツ間隔 */
.area {
    padding-top: 80px;
    padding-bottom: 80px;
}

@media (max-width: 599px) {
    .area {
        padding-top: 50px;
        padding-bottom: 50px;
    }
}

/* 共通要素読み込みコメント（取り込み後削除） */
[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 {
    padding: 0 5px;
    font-size: 12px;
    position: absolute;
    top: 0;
    z-index: 201;
}

/**
ヘッダー
header
*/
.mask-top {
    background: #fff;
}

.header.fixed {
    width: 100%;
    height: auto;
    background: #fff;
    -webkit-box-shadow: 0 0 7px 0 #999;
    box-shadow: 0 0 7px 0 #999;
    cursor: pointer;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 203;
}

.header .contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.header.fixed .contents {
    padding-bottom: 0;
}

.header .logo img {
    max-height: 50px;
}

.header .left {
    width: 20%;
}

.header .left .logo a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.header .right {
    width: 260px;
    padding: 30px 10px 60px;
    color: #fff;
    background: #fff;
    background: #ef8b68;
}

.header.fixed .right {
    padding: 10px;
}

.header .right .txt {
    margin-right: 10px;
    line-height: 120%;
}

.header .right .txtin {
    display: block;
}

.header .right .tel-num {
    line-height: 1;
}

.header .right .tel-num {
    font-weight: bold;
    font-size: 30px;
}

.header .right i {
    margin-right: 10px;
    font-size: 24px;
}

.header .right .border-b-s a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: end;
    align-items: flex-end;
    -ms-flex-align: end;
    -webkit-box-pack: end;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding-bottom: 5px;
    border-bottom: solid 2px #fff;
}

/* .header .right .tel-num a:before {
  margin-right: 5px;
  content: '\f879';
  font-weight: 600;
  font-size: 24px;
  font-family: 'Font Awesome 5 Free';
} */
@media (max-width: 1024px) {
    .header {
        padding: 5px 0;
    }

    .header .logo img {
        max-height: 32px;
    }

    .header .right {
        display: none;
    }
}

/* 下部固定コンテンツ */
.fix-bottom {
    display: none;
}

@media (max-width: 1024px) {
    .fix-bottom {
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 250;
    }

    .fix-bottom .item {
        width: 50%;
        text-align: center;
    }

    .fix-bottom a {
        height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 10px 5px;
    }

    .fix-bottom .tel {
        font-size: 14px;
        color: #fff;
        background: #000;
    }

    .fix-bottom .tel a:before {
        content: "\f879";
        margin-right: 5px;
        font-family: "Font Awesome 5 Free";
        font-weight: 600;
    }

    .fix-bottom .contact {
        color: #000;
        background: #eee;
    }

    .fix-bottom .contact a:before {
        content: "\f0e0";
        margin-right: 5px;
        font-family: "Font Awesome 5 Free";
        font-weight: 600;
    }
}

/**
グローバルナビ
gnav
*/
.gnav {
    width: calc(80% - 230px);
    padding: 10px 0;
    position: relative;
    z-index: 100;
    z-index: 204;
}

.gnav.fixed {
    width: 100%;
    height: auto;
    background: #fff;
    -webkit-box-shadow: 0 0 7px 0 #999;
    box-shadow: 0 0 7px 0 #999;
    cursor: pointer;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 200;
}

.gnav .wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.gnav .navlogo {
    display: none;
}

.gnav .navlogo img {
    max-height: 40px;
}

.gnav .list01 {
    width: 100%;
    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;
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.gnav .item01 {
    font-size: 16px;
    text-align: center;
}

.gnav .item01.sns {
    width: 50px;
}

.gnav .item01>a,
.gnav .item01 .itemin {
    display: block;
    padding: 5px;
    font-weight: 500;
    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;
}

.gnav .item02 a:hover {
    color: #fff;
    background: #ef8b68;
    opacity: 1;
}

.footer .sns-box {
    position: absolute;
    bottom: 30px;
    right: 50px;
}

.footer .sns-box .item01.sns {
    width: 50px;
}

@media (max-width: 1024px) {
    .gnav .item02 a:hover {
        color: #fff;
        background: #ef8b68;
        opacity: 1;
    }

    .nav-open {
        position: relative;
    }

    .nav-open::before {
        content: "＋";
        position: absolute;
        right: 20px;
    }

    .nav-open.open::before {
        content: "−";
    }

    .gnav {
        width: 100%;
        max-width: 300px;
        height: 100%;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        background: rgba(255, 255, 255, 0.9);
        -webkit-transition: -webkit-transform ease 0.5s;
        transition: -webkit-transform ease 0.5s;
        transition: transform ease 0.5s;
        transition: transform ease 0.5s, -webkit-transform ease 0.5s;
        -webkit-transform: translate3d(100%, 0, 0);
        transform: translate3d(100%, 0, 0);
        position: fixed;
        top: 0;
        right: 0;
    }

    .gnav.action {
        -webkit-transform: translate3d(0%, 0, 0);
        transform: translate3d(0%, 0, 0);
        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;
    }

    .gnav .list02 {
        width: 100%;
        visibility: visible;
        padding-top: 0;
        padding-left: 20px;
        color: #fff;
        background: none;
        background: #ef8b68;
        opacity: 1;
        -webkit-transform: none;
        transform: none;
        position: relative;
        top: 0;
        left: 0;
    }

    .gnav .list02 a {
        padding: 2px 0 2px 20px;
        position: relative;
    }

    .gnav .list02 a:before {
        content: "";
        width: 10px;
        height: 1px;
        display: block;
        background: #fff;
        position: absolute;
        top: 13px;
        left: 0;
    }

    .gnav .list02 {
        display: none;
        -webkit-transition: none;
        transition: none;
    }
}

[data-element-id] .gnav.fixed {
    position: relative;
}

/* ハンバーガーメニュー  */
.toggle {
    width: 42px;
    height: 42px;
    display: none;
    background: #ef8b68;
    opacity: 0.8;
    cursor: pointer;
    position: fixed !important;
    top: 0px;
    right: 0px;
    z-index: 251;
}

.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);
    transform: rotate(-45deg);
}

.toggle.active .bar:after,
.toggle.active .bar:before {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    top: 0;
    left: 0;
}

@media (max-width: 1024px) {
    .toggle {
        display: block !important;
    }
}

.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: #ef8b68;
    cursor: pointer;
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 200;
}

.totop:before {
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
}

@media (max-width: 1024px) {
    .totop {
        bottom: 60px;
        right: 10px;
    }
}

/**
フッター
footer
*/
.footer .copy {
    padding: 5px 0;
    color: #fff;
    text-align: center;
    background: #473e2f;
}

.footer {
    background-image: url("/import/tenant_1/153.121.66.87/html/images/t-d.webp");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.footer .logo {
    max-width: 210px;
}

.footer .left {
    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: start;
    align-items: flex-start;
    -ms-flex-align: start;
}

@media (max-width: 1024px) {
    .footer .copy {
        padding-bottom: 60px;
    }
}

/**
フッターナビ
fnav
*/
.fnav {
    padding: 50px 0;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.fnav .wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.fnav .list01 {
    width: 50%;
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
}

.fnav .item {
    margin-bottom: 15px;
}

.fnav .item.w-100 {
    width: 100%;
}

.fnav .item a {
    display: block;
    padding-left: 20px;
    position: relative;
}

.fnav .ttl {
    margin-bottom: 15px;
    padding-left: 20px;
    position: relative;
}

.fnav .ttl:before {
    content: "";
    width: 15px;
    height: 15px;
    display: block;
    border-radius: 50%;
    background: #ef8b68;
    -webkit-filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
    filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
    -webkit-transform: translatey(-50%);
    transform: translatey(-50%);
    position: absolute;
    top: 50%;
    left: 0;
}

.fnav .list02 {
    width: 50%;
}

.fnav .datawrap {
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
}

.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 {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .fnav .list01 {
        width: 100%;
        margin-bottom: 10px;
    }

    .fnav .list02 {
        width: 100%;
    }
}

@media (max-width: 599px) {
  .totop{
    bottom: 100px;
  }
    .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: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.column2 .side {
    width: 200px;
}

.column2 .mainwrap {
    width: calc(100% - 250px);
}

@media (max-width: 1024px) {
    .column2 .inner {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .column2 .side {
        width: 100%;
        -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
        order: 3;
        margin-bottom: 50px;
    }

    .column2 .mainwrap {
        width: 100%;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
        margin-bottom: 50px;
    }
}

/* サイドメニュー */
.side .list {
    margin-bottom: 30px;
    padding: 30px;
    border-radius: 20px;
    background: #fff;
}

@media (max-width: 1024px) {
    .side {
        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;
    }

    .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;
    text-align: center;
    border-radius: 2em;
    background: #ef8b68;
    position: relative;
}

.list-side .data {
    margin-bottom: 10px;
    padding-left: 10px;
}

.list-side a {
    display: inline-block;
    padding-left: 20px;
    position: relative;
}

.list-side a:before {
    content: ">";
    color: #ef8b68;
    position: absolute;
    left: 0;
}

@media (max-width: 1024px) {

    .list-side.type-archive .datawrap {
        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;
    }

    .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スライダー用 */
.bg-img {
    background-image: url("/import/tenant_1/153.121.66.87/html/images/bg0.webp");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.mainimg {
    height: 950px;
/*     background-image: url("/import/tenant_1/153.121.66.87/html/images/mv.webp"); */
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: relative;
}

.mainimg img {
    width: 100%;
}

.mainimg .box {
    max-width: 1000px;
    height: 900px;
    margin: auto;
    position: relative;
}

.mainimg .box .img {
    width: 100%;
    max-width: 700px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 30%;
    left: 50%;
    z-index: 3;
}

.mainimg .box .img2 {
    width: 100%;
    max-width: 450px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
    position: absolute;
    top: 20%;
    left: -17%;
    z-index: 2;
}

.mainimg .box .img2 img {
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul01.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul01.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
}

.mainimg .box .img3 {
    width: 100%;
    max-width: 320px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: absolute;
    top: 15%;
    right: -17%;
    z-index: 2;
}

.mainimg .box .cons-box.new {
    width: 100%;
    max-width: 320px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: absolute;
    top: 30%;
    right: -6%;
    z-index: 3;
}

.mv-text-box .cons-box.new {
    max-width: 100%;
    margin-top: 30px;
}

.mainimg .box .img3 img {
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul02.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul02.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
}

.mainimg .box .img4 {
    width: 80%;
    max-width: 1025px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;
}

.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 {
    width: 100%;
    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対策*/
/* スリックスライダー（トップ） */
.slick01 {
    padding: 0 20px;
}

.slick01.slick-dotted {
    margin-bottom: 50px;
}

.slick01 .btn-slick {
    font-size: 30px;
    cursor: pointer;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    z-index: 1;
}

.slick01 .btn-slick.btn-back {
    left: 0;
}

.slick01 .btn-slick.btn-next {
    right: 0;
}

.slick01 .btn-slick::before {
    width: 70px;
    height: 70px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0;
    padding: 0;
    font-weight: 600;
    font-size: 24px;
    color: #ef8b68;
    line-height: 1;
    border: solid 1px #ef8b68;
    border-radius: 50%;
    background: #fff;
}

.slick01 .slick-dots {
    bottom: -40px;
    left: 0;
}

.slick01 li {
    overflow: hidden;
    margin-bottom: 10px;
    border-radius: 15px;
    background: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.slick01 .head {
    font-size: 24px;
    text-align: center;
}
@media (max-width: 1024px) {
  .slick01 .head {
    font-size: 20px;
}
  .slick01 .btn-slick::before{
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 599px) {
    .mv-text-box .cons-box.new {
        margin-top: 10px;
    }

    .slick01 .btn-slick::before {
        width: 40px;
        height: 40px;
        font-size: 14px;
    }

    .slick01 .head {
        font-size: 20px;
    }

    .slick01 {
        padding: 0 10px;
    }

    .slick01 .btn-slick {
        font-size: 20px;
    }
}

/**
下層共通
*/
/* トップビジュアル（下層共通） */
.topvisual {
    position: relative;
}

.topvisual .img {
    min-height: 200px;
    max-height: 400px;
    position: relative;
}

.topvisual .img:before {
    content: "";
    display: block;
    padding-top: 30%;
    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: 34px;
    text-align: center;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute !important;
    top: 50%;
    left: 50%;
}

@media (max-width: 599px) {
    .topvisual .head {
        font-size: 24px;
    }
}

/* パンくずリスト */
.breadcrumb {
    padding: 50px 0;
}

.breadcrumb .item {
    display: inline-block;
}

.breadcrumb .item:not(:last-of-type):after {
    content: "\f054";
    display: inline-block;
    margin-left: 10px;
    margin-right: 5px;
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
}

.breadcrumb .home {
    color: #000;
}

.breadcrumb .now {
    color: #000;
}

/* ページネーション */
.pagenation {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.pagenation .item {
    margin: 0 10px;
}

.pagenation .prev {
    margin-right: 20px;
    position: relative;
}

.pagenation .prev a:before {
    content: "\f053";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
}

.pagenation .next {
    margin-left: 20px;
    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 {
    width: 30px;
    height: 30px;
    display: block;
    padding: 2px 8px;
    font-size: 20px;
    color: #000;
    line-height: 28px;
    text-align: center;
    border-radius: 50%;
}

.pagenation .number a:hover,
.pagenation .now {
    color: #fff;
    background: #ef8b68;
    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 5px 2px 0px;
    padding: 0 5px;
    color: #fff;
    background: #ef8b68;
}

/* 記事詳細ページ */
.articledtl01 {
    padding: 30px;
    border-radius: 20px;
    background: #fff;
}

.articledtl01 .cate span {
    display: inline-block;
    margin: 0 5px 2px 0px;
    padding: 0 5px;
    color: #fff;
    background: #ef8b68;
}

/* ギャラリー */
.list-gallery01 a {
    display: block;
    position: relative;
}

.list-gallery01 .img {
    opacity: 1;
    -webkit-transition: 0.5s;
    transition: 0.5s;
}

.list-gallery01 .block-txt {
    width: 100%;
    height: 100%;
    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;
    visibility: hidden;
    overflow: hidden;
    padding: 10px;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    position: absolute;
    top: 0;
    left: 0;
}

.list-gallery01 .cate {
    margin-bottom: 5px;
    font-size: 14px;
}

.list-gallery01 .head {
    font-size: 18px;
}

.list-gallery01 a:hover {
    opacity: 1;
}

.list-gallery01 a:hover .img {
    opacity: 0.5;
}

.list-gallery01 a:hover .block-txt {
    visibility: visible;
    opacity: 1;
}

@media (max-width: 599px) {
    .list-gallery01 .block-txt {
        display: none;
    }

    .list-gallery01 .head {
        font-size: 14px;
    }
}

/* ギャラリー詳細 */
.gallerydtl01 .thumbnail {
    cursor: pointer;
}

/* フォーム */
.form .box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    padding: 20px 0;
    border-bottom: 2px solid #999;
}

.form .datattl {
    width: 200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    align-items: flex-start;
    -ms-flex-align: start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    font-weight: bold;
    color: #000;
}

.form .require {
    display: inline-block;
    margin-left: 10px;
    padding: 0 4px;
    font-size: 14px;
    color: #fff;
    line-height: 1.6em;
    background: #000;
}

.form .data {
    width: 100%;
    padding-left: 50px;
}

.form .data input {
    width: 100%;
    margin-top: 5px;
    margin-bottom: 5px;
    padding: 5px;
    -webkit-box-sizing: border-box;
    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;
    -webkit-box-sizing: border-box;
    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;
    -webkit-box-shadow: inset 1px 1px 0 1px #999;
    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;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    border: 1px solid #999;
}

.form .data textarea {
    width: 100%;
    height: 170px;
    padding: 5px;
    -webkit-box-sizing: border-box;
    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 {
    width: 200px;
    margin: 10px 20px;
    padding: 0.2em;
    color: #fff;
    text-align: center;
    border: none;
    border-radius: 2em;
    background: #000;
    -webkit-transition: 0.3s all ease;
    transition: 0.3s all ease;
}

.form .btn button:hover {
    opacity: 0.6;
    cursor: pointer;
}

@media (max-width: 1024px) {
    .form .item {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .form .datattl {
        display: block;
        margin-bottom: 10px;
    }

    .form .data {
        padding-left: 0;
    }
}

.mv-text-box {
    width: 46%;
    /* position: absolute;
  bottom: 20%;
  left: 0%; */
    max-width: 630px;
    margin-right: 30px;
    color: #724717;
    z-index: 1;
}

.mv-text-box .imgs {
    width: 95%;
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
    position: absolute;
    top: 25%;
    z-index: -1;
}

.cons-box {
    width: 100%;
    /* position: absolute;
 bottom: 15%;
 right: 0%; */
    max-width: 510px;
    overflow: hidden;
    border-radius: 15px;
    background: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    z-index: 3;
}

.footer .cons-box {
    overflow: hidden;
    border-radius: 15px;
    background: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: relative;
    bottom: initial;
    right: inherit;
    z-index: 3;
}

.footer .cons-box .ttl {
    margin-bottom: 10px;
    padding: 5px;
    font-size: 24px;
    color: #fff;
    letter-spacing: 10px;
    text-align: center;
    text-shadow: none;
    background: #ef8b68;
}

.biz-hour {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.biz-hour th,
.biz-hour td {
    padding: 10px 5px;
    font-size: 14px;
    text-align: center;
    border-right: 1px solid #a28c63;
}

.biz-hour td.new {
    padding-top: 20px;
    padding-bottom: 5px;
}

.biz-hour td {
    width: 50px;
}

.biz-hour tr td:first-child {
    width: auto;
}
.biz-hour .img{
      width: 26px;
    margin: auto;
        filter: drop-shadow(0px 0px 1px #878787);
}
@media screen and (max-width: 559px) {
    .biz-hour th,
    .biz-hour td {
        padding: 10px 10px;
    }
}

.biz-hour tbody {
    color: #724717;
}

.biz-hour th {
    padding: 0;
    font-weight: normal;
}

.biz-hour th span {
    display: block;
    margin-top: 10px;
    padding: 10px 0;
    background: #f7ebd7;
}

.biz-hour th span.t {
    color: #f7ebd7;
}

.scroll-logo {
    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: 15px 10px;
    color: #fff;
    border-radius: 25px;
    background: #ef8b68;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    -webkit-animation: arrowmove 1s ease-in-out infinite;
    animation: arrowmove 1s ease-in-out infinite;
    position: absolute;
    bottom: 0;
    left: 50%;
}

.scroll-logo img {
    width: 20px;
}

@-webkit-keyframes arrowmove {
    0% {
        bottom: 1%;
    }

    50% {
        bottom: 4%;
    }

    100% {
        bottom: 1%;
    }
}

@keyframes arrowmove {
    0% {
        bottom: 1%;
    }

    50% {
        bottom: 4%;
    }

    100% {
        bottom: 1%;
    }
}

/* 共通リスト３ */
.list-cmp03 {
    padding: 0 50px 0 100px;
    border-radius: 50px;
    background: #fff;
}

.list-cmp03 .item {
    padding: 20px;
    position: relative;
}

.list-cmp03 .item:before {
    content: "\f054";
    width: 25px;
    height: 25px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0;
    padding: 0;
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
    font-size: 1.6rem;
    font-size: 14px;
    color: #ef8b68;
    line-height: 1;
    border: solid 1px;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    top: calc(50% - 0.8rem);
    right: 1rem;
}

.list-cmp03 .item:not(:last-child) {
    border-bottom: 1px solid #808080;
}

.list-cmp03 .datattl {
    width: 150px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 20px;
}

.list-cmp03 .datattl span {
    padding: 5px 10px;
    font-size: 18px;
    color: #fff;
    letter-spacing: 2px;
    text-align: center;
}

.list-cmp03 .datattl .p {
    background: #ef8b68;
}

.list-cmp03 .datattl .b {
    background: #473d31;
}

@media (max-width: 599px) {
    .list-cmp03 .datattl span {
        font-size: 14px;
    }

    .list-cmp03 .item {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        padding: 20px 10px;
    }

    .list-cmp03 .datattl {
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin-bottom: 5px;
    }

    .list-cmp03 .data {
        width: 100%;
    }
}

.m-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.m-btn.l-0 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: left;
    -ms-flex-pack: left;
    justify-content: left;
}

.m-btn a,
.m-btn button {
    padding: 1rem 3.5rem;
    color: #fff;
    border-radius: 15px;
    background-color: #ef8b68;
    position: relative;
}

.m-btn button {
    border: 0;
}

.m-btn.pdf a {
    padding: 1rem 3rem 1rem 1.5rem;
}

.m-btn.gree a {
    padding: 1rem 3rem 1rem 1rem;
    font-size: clamp(0.75rem, -0.714rem + 2.29vw, 1rem);
    background: #67b11e;
}

.m-btn.gree a::before {
    color: #67b11e;
}

.m-btn.l-0.tel a {
    padding: 0.4rem 2rem;
    color: #724717;
    border: solid 1px #ef8b68;
    background: #fff;
}

.m-btn.l-0.tel.new a {
    padding: 0;
    border: none;
    background: none;
}

.m-btn a i.fa {
    margin-right: 1rem;
}

.m-btn button:before,
.m-btn a:before {
    content: "\f054";
    width: 25px;
    height: 25px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0;
    padding: 0;
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
    font-size: 1.6rem;
    font-size: 14px;
    color: #ef8b68;
    line-height: 1;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    top: calc(50% - 0.8rem);
    right: 1rem;
}

.m-btn.tel a:before {
    display: none;
}

.m-btn.mail-logo a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.m-btn.mail-logo a i.fa {
    font-size: 28px;
}

.m-btn.tel a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    align-items: flex-end;
    -ms-flex-align: end;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.m-btn.tel a i {
    margin-right: 10px;
    font-size: 24px;
}

.m-btn.tel a .b {
    font-family: "lucida handwriting italic", sans-serif;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 34px;
    line-height: 1;
}

.m-btn.tel a .b.new {
    font-size: clamp(1.5rem, -2.161rem + 5.71vw, 2.125rem);
}

.checkmark-text li {
    margin-bottom: 30px;
    padding-left: 45px;
    line-height: 1.8;
    position: relative;
}

.checkmark-text li::after {
    content: "";
    width: 50px;
    height: 50px;
    display: inline-block;
    background-image: url("/import/tenant_1/153.121.66.87/html/images/t-t.webp");
    background-size: cover;
    background-position: center;
    position: absolute;
    top: -5px;
    left: 0;
}

.text-bot-line {
    display: inline-block;
    font-weight: 500;
    font-size: 24px;
    position: relative;
}

.text-bot-line::after {
    content: "";
    width: 100%;
    height: 3px;
    background: #ef8b68;
    position: absolute;
    bottom: -5px;
    left: 0;
}

.text-bot-line.new {
    padding: 20px 0 0;
    font-weight: bold;
    font-size: 20px;
    color: #724717;
    text-align: center;
}

.treat .img {
    overflow: hidden;
    border-radius: 50%;
}

.treat .sb .img {
    width: 80%;
    overflow: initial;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: relative;
}

.treat .sb .img img {
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul08.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul08.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
}

.treat .sb .ttl {
    width: 100%;
    font-weight: bold;
    font-size: 20px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 1;
}

.treat .sb .text {
    width: 100%;
    position: absolute;
    bottom: 5px;
}

.treat .box {
    padding: 30px 0;
    border-radius: 15px;
    background: #fff;
}

.treat .text {
    z-index: 1;
}
.mask{
    margin-top: -40px;
    height: 104%;
    /*  z-index: 202; */
}
.mask img{
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/maska10.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/maska10.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
}

.mask02,
.mask03,
.mask04 {
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.mask02 img {
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul05.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul05.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
}

.mask03 img {
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));

    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul06.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul06.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
}

.mask04 img {
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));

    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul07.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul07.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
}

.mainimg .ttl {
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: bold;
    font-size: 50px;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.mainimg .text {
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 2px;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.mainimg .cons-box .ttl {
    margin-bottom: 10px;
    padding: 5px;
    font-size: 24px;
    color: #fff;
    letter-spacing: 10px;
    text-align: center;
    text-shadow: none;
    background: #ef8b68;
}

.ja {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 30px;
    color: #333;
    letter-spacing: 2px;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.en {
    font-family: "lucida handwriting italic", sans-serif;
    font-size: 30px;
    color: #ef8b68;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.ja.min,
.en.min {
    font-size: 24px;
}

.top-news {
    position: relative;
}

.top-news .img1,
.top-news .img2 {
    max-width: 170px;
    position: absolute;
    bottom: -100px;
}

.top-news .img1 {
    left: -50px;
}

.top-news .img2 {
    max-width: 100px;
    right: -50px;
}

.bg-ho {
    position: relative;
}

.bg-ho .img {
    width: 50%;
    -webkit-transform: translate(-50%, -30%);
    transform: translate(-50%, -30%);
    position: absolute;
    top: 0;
    left: 50%;
}

.bg-ho .ja,
.bg-ho .en {
    position: relative;
    z-index: 1;
}

.tx-s {
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.top-policy .img1,
.top-policy .img2 {
    max-width: 200px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: absolute;
    bottom: 0px;
}

.top-policy .img1 img {
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul03.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul03.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
}

.top-policy .img2 {
    top: 5%;
    bottom: initial;
    right: 0;
}

.top-policy .img2 img {
    -webkit-mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul04.webp");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: 100% 100%;
    mask-image: url("/import/tenant_1/153.121.66.87/html/images/cul04.webp");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100% 100%;
}

.top-wor .img {
    max-width: 200px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 5px;
    -webkit-filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
    filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
}

.top-wor .img1,
.top-wor .img2 {
    max-width: 110px;
    position: absolute;
    bottom: 0px;
    left: -35px;
}

.top-wor .img2 {
    max-width: 200px;
    left: inherit;
    right: -35px;
}

.top-choose {
    background-image: url("/import/tenant_1/153.121.66.87/html/images/bg-4.webp");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.num {
    font-family: "lucida handwriting italic", sans-serif;
    font-weight: 500;
    color: #ef8b68;
}

.treat .img {
    width: 50%;
}

.top-voice .img1,
.top-voice .img2 {
    max-width: 170px;
    position: absolute;
    bottom: -80px;
}

.top-voice .img1 {
    max-width: 230px;
    left: -35px;
}

.top-voice .img2 {
    right: 0;
}

.faq-list {
    overflow: hidden;
    border-radius: 20px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.faq-list .faq-box .faq-inner p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    font-size: 18px;
}

.faq-list .faq-box .faq-inner .q-logo {
    width: 60px;
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: auto;
    padding-left: 2px;
    font-size: 22px;
    color: #fff;
    line-height: 25px;
    text-align: center;
    border-radius: 50%;
    background: #ef8b68;
}

.faq-list .faq-box .faq-inner .q-text {
    width: calc(100% - 160px);
}

.faq-list .faq-box .qu {
    background: #fff;
}

.faq-list .faq-box .ans {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    padding: 30px 55px 30px 30px;
    background: #fff6e0;
}

.faq-list .faq-box .ans .img {
    width: 150px;
    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;
    margin-right: 10px;
}

.faq-list .faq-box .ans .img .text {
    padding: 0.1em 1em;
    font-size: 10px;
    border-radius: 9999px;
    background: #fff;
}

.faq-list .faq-box .ans img {
    width: 60px;
    height: 60px;
    display: inline-block;
    margin-bottom: 5px;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    border-radius: 50%;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.w-150 {
    width: 150px;
}

.a-text {
    width: calc(100% - 160px);
}

.faq-inner {
    padding: 30px 55px 30px 30px;
    position: relative;
}

.plas::before,
.plas::after {
    content: "";
    width: 25px;
    height: 3px;
    display: block;
    border-radius: 5px;
    background: #000;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 15px;
}

.plas::after {
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg);
}

.plas.is-parent::after {
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: rotate(0);
    transform: rotate(0);
}

.bner-box .border-20 {
    overflow: hidden;
    border-radius: 20px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.bner-s .tbox {
    z-index: 1;
}

.bner-s img {
    width: 60%;
}

.bner-s .sh {
    content: "";
    width: 50%;
    height: 100%;
    background: rgb(255, 255, 255);
    background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 1)), color-stop(80%, rgba(255, 255, 255, 1)), to(rgba(255, 255, 255, 0)));
    background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 80%, rgba(255, 255, 255, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff", endColorstr="#ffffff", GradientType=1);
    position: absolute;
    top: 0;
    left: 0;
}

.map {
    padding-top: 20%;
}

.map iframe {
    border-radius: 15px;
}

.mv-b-text {
    width: 98%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    position: absolute;
    bottom: 15%;
    left: 50%;
    z-index: 3;
}

.header .right .con {
    display: none;
}

.header .right.ab {
    background: #729f3d;
}

@media (max-width: 1024px) {
  .mask{
    height: 98%;
  }
    .header .right,
    .header .right.ab {
        background: none;
    }

    .header .right .tel {
        background: #ef8b68;
    }

    .header .right.ab .tel {
        background: #729f3d;
    }

    .header .right {
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding: 0;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 203;
    }

    .header .right .con {
        width: 50%;
        display: block;
    }

    .header .right .con a {
        width: 100%;
        height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 5px;
        font-weight: bold;
        font-size: 18px;
        color: #ef8b68;
        border: solid 1px #ef8b68;
        background: #fff;
    }

    .header .right .border-b-s {
        width: 50%;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .header .right .border-b-s a {
        width: 100%;
        height: 100%;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 5px;
        /* padding-bottom: 0; */
        border: solid 1px #ef8b68;
    }

    .header .right.ab .border-b-s a {
        border: solid 1px #729f3d;
    }

    .header .right .tel-num {
        font-size: 24px;
    }

    .header .left {
        width: 100%;
        margin-top: 50px;
    }

    .header .left .logo a {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .mainimg .box .img {
        width: 50%;
    }

    .mainimg .box .img2 {
        max-width: 300px;
        left: -40px;
    }

    .mainimg .box .img3 {
        max-width: 230px;
        right: -40px;
    }

    .mainimg .box .img4 {
        max-width: 500px;
    }

    .mainimg .ttl {
        font-size: 30px;
    }

    .mainimg .text {
        font-size: 18px;
    }

    .mainimg .cons-box .ttl {
        font-size: 18px;
    }

    .mv-text-box {
        width: 100%;
        max-width: 460px;
        margin-right: 20px;
        bottom: 30%;
        left: 10px;
    }

    .cons-box {
        width: 100%;
        max-width: 500px;
        bottom: 15%;
        right: 10px;
    }

    .biz-hour td {
        width: 46px;
    }

    .mask {
        margin-top: 30px;
    }

    @-webkit-keyframes arrowmove {
        0% {
            bottom: 10px;
        }

        50% {
            bottom: 20px;
        }

        100% {
            bottom: 10px;
        }
    }

    @keyframes arrowmove {
        0% {
            bottom: 10px;
        }

        50% {
            bottom: 20px;
        }

        100% {
            bottom: 10px;
        }
    }

    .top-news .img1,
    .top-news .img2 {
        bottom: -160px;
        left: 0;
    }

    .top-news .img2 {
        left: initial;
        right: 0;
    }

    .top-policy .img1,
    .top-policy .img2 {
        max-width: 130px;
    }

    .top-policy .img2 {
        max-width: 150px;
        top: -15%;
    }

    .top-wor .img1,
    .top-wor .img2 {
        max-width: 110px;
        bottom: -65px;
        left: 0;
    }

    .top-wor .img2 {
        left: inherit;
        right: 0;
    }

    .top-voice .img1 {
        max-width: 180px;
        left: 0;
    }

    .top-voice .img2 {
        max-width: 160px;
    }

    /* .faq-inner{
  padding: 15px 55px 15px 60px;
} */
    .faq-list .faq-box .ans {
        padding: 15px 55px 15px 30px;
    }

    .footer .logo {
        max-width: 250px;
    }

    .footer .left {
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
    }

    .footer .biz-hour td {
        width: 60px;
    }

    .map {
        padding-top: 35%;
    }

    .footer .cons-box {
        max-width: 80%;
        margin: 50px auto 0;
    }

    .ja,
    .en {
        font-size: 26px;
    }
}

@media (max-width: 820px) {
    .biz-hour th,
    .biz-hour td {
        padding: 10px 1px;
    }

    .biz-hour td {
        width: 40px;
    }

    .mainimg .box .img {
        width: 75%;
        top: 25%;
    }

    .mainimg .box .img4 {
        max-width: 440px;
        top: 30%;
    }

    .mv-text-box {
        max-width: 330px;
        bottom: 40%;
    }

    .cons-box {
        max-width: 400px;
        bottom: 20%;
    }
}

@media (max-width: 599px) {
    .header .left {
        margin-top: 10px;
    }

    .w-150 {
        width: 60px;
    }

    .a-text {
        width: 100%;
    }

    .mainimg .box {
        height: 1150px;
        margin-top: -10px;
    }

    .mainimg {
        height: 1200px;
    }

    .faq-list .faq-box .faq-inner .q-text {
        width: calc(100% - 70px);
    }

    .text-bot-line {
        font-size: 20px;
    }

    .header .right .tel-num {
        font-size: 20px;
    }

    .faq-list .faq-box .ans {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        /*   padding: 15px 15px 15px 0px; */
        padding: 10px;
    }

    .faq-inner {
        padding: 15px 55px 15px 15px;
    }

    .ja,
    .en {
        font-size: 22px;
    }

    .m-btn.tel a .b {
        font-size: 27px;
    }

    .footer .cons-box {
        margin: 30px auto 0;
    }

    .footer .biz-hour td {
        width: 35px;
    }

    .footer .cons-box {
        width: 100%;
        max-width: 100%;
    }
}

.d-none-tb,
.d-none-sp {
    display: block;
}

.d-b-tb2,
.d-b-tb,
.d-b-sp {
    display: none;
}

@media (max-width: 1024px) {
    .top-news .img1,
    .top-news .img2 {
        width: 80px;
    }

    .d-b-tb {
        display: block;
    }

    .d-none-tb {
        display: none;
    }

    .faq-list .faq-box .ans .img {
        min-width: 120px;
    }
}

@media (max-width: 820px) {
    .d-b-tb2 {
        display: block;
    }
}

@media (max-width: 599px) {
    .faq-list .faq-box .ans .img {
        margin: auto;
        margin-bottom: 20px;
    }

    .top-wor .img1,
    .top-wor .img2 {
        max-width: 90px;
        bottom: -50px;
    }

    .top-wor .img2 {
        max-width: 100px;
    }

    .treat .sb .ttl {
        font-size: 14px;
    }

    .d-none-sp {
        display: none;
    }

    .d-b-sp {
        display: block;
    }

    .top-voice .img1 {
        max-width: 90px;
        bottom: -50px;
    }

    .top-voice .img2 {
        max-width: 100px;
        bottom: -50px;
    }

    .m-btn a:before {
        right: 10px;
    }

    .m-btn a {
        width: 150px;
        padding: 10px;
        font-size: 14px;
    }

    .m-btn.gree a {
        width: auto;
        font-size: 12px;
    }

    .m-btn.l-0.tel.new a {
        width: 100%;
    }

    .footer .left {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
    }

    .m-btn.tel a .b {
        font-size: 20px;
    }

    .footer .logo {
        margin: auto;
    }

    .m-btn.mail-logo a i.fa {
        margin-right: 5px;
        font-size: 18px;
    }

    .m-btn.l-0.tel a {
        width: 100%;
        padding: 5px;
    }

    .m-btn.tel a i {
        font-size: 18px;
    }

    .m-btn.mail-logo a {
        width: 160px;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .bner-s img {
        width: 100%;
    }

    .bner-s .sh {
        width: 200%;
        opacity: 0.5;
    }

    .bg-ho .img {
        width: 100%;
    }

    .top-policy .img2 {
        max-width: 90px;
        top: initial;
        bottom: -30px;
    }

    .top-policy .img1 {
        max-width: 100px;
        bottom: -30px;
    }

    .top-news .img1 {
        max-width: 100px;
    }

    .top-news .img2 {
        max-width: 70px;
    }

    .top-news .img1,
    .top-news .img2 {
        bottom: -140px;
    }

    .list-cmp03 {
        padding: 0 30px;
    }

    .mainimg .box .img2 {
        max-width: 200px;
        top: 12%;
        left: 45px;
    }

    .mainimg .box .img3 {
        max-width: 170px;
        top: 7%;
    }

    .scroll-logo img {
        width: 10px;
    }

    .scroll-logo {
        padding: 15px 5px;
    }

    .header .logo img {
        max-height: 24px;
    }

    .mainimg .box .img {
        top: 20%;
    }

    .mainimg .box .img4 {
        max-width: 270px;
        top: 25%;
    }

    .mv-b-text {
        bottom: 13%;
    }

    .mv-b-text {
        width: 96%;
    }

    .mv-text-box {
        max-width: 100%;
        margin: auto;
        margin-bottom: 10px;
    }

    .pagettl {
        padding-left: 0;
        padding-right: 40px;
        position: relative;
    }

    .gnav .item01 .m-btn.l-0 {
        width: 100%;
    }

    .gnav .item01 .m-btn.tel a {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .gnav .item01 .m-btn.tel a .b {
        font-size: 30px;
    }
}

/*装飾エフェクト*/
.deco-effect-01 {
    display: block;
    -webkit-transform-origin: bottom left 32px;
    transform-origin: bottom left 32px;
    -webkit-animation: swing01 linear 6s infinite;
    animation: swing01 linear 6s infinite;
}

.deco-effect-01.pattern-01 {
    display: block;
    -webkit-transform-origin: bottom left 32px;
    transform-origin: bottom left 32px;
    -webkit-animation: swing01 linear 10s infinite;
    animation: swing01 linear 10s infinite;
}

@-webkit-keyframes swing01 {
    0%,
    50%,
    100% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    25% {
        -webkit-transform: rotate(5deg);
        transform: rotate(5deg);
    }

    75% {
        -webkit-transform: rotate(-5deg);
        transform: rotate(-5deg);
    }
}

@keyframes swing01 {
    0%,
    50%,
    100% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    25% {
        -webkit-transform: rotate(5deg);
        transform: rotate(5deg);
    }

    75% {
        -webkit-transform: rotate(-5deg);
        transform: rotate(-5deg);
    }
}

.deco-effect-02 {
    display: block;
    -webkit-transform-origin: bottom left 32px;
    transform-origin: bottom left 32px;
    -webkit-animation: swing02 linear 6s infinite;
    animation: swing02 linear 6s infinite;
}

.deco-effect-02.pattern-01 {
    display: block;
    -webkit-transform-origin: bottom left 32px;
    transform-origin: bottom left 32px;
    -webkit-animation: swing02 linear 10s infinite;
    animation: swing02 linear 10s infinite;
}

@-webkit-keyframes swing02 {
    0%,
    50%,
    100% {
        -webkit-transform: rotate(0deg) translateX(0vw);
        transform: rotate(0deg) translateX(0vw);
    }

    25% {
        -webkit-transform: rotate(5deg) translateX(-1vw);
        transform: rotate(5deg) translateX(-1vw);
    }

    75% {
        -webkit-transform: rotate(-5deg) translateX(1vw);
        transform: rotate(-5deg) translateX(1vw);
    }
}

@keyframes swing02 {
    0%,
    50%,
    100% {
        -webkit-transform: rotate(0deg) translateX(0vw);
        transform: rotate(0deg) translateX(0vw);
    }

    25% {
        -webkit-transform: rotate(5deg) translateX(-1vw);
        transform: rotate(5deg) translateX(-1vw);
    }

    75% {
        -webkit-transform: rotate(-5deg) translateX(1vw);
        transform: rotate(-5deg) translateX(1vw);
    }
}

.deco-effect-03 {
    display: block;
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-name: swing03;
    animation-name: swing03;
    -webkit-animation-duration: 4000ms;
    animation-duration: 4000ms;
    -webkit-animation-play-state: running;
    animation-play-state: running;
    -webkit-animation-timing-function: steps(2, end);
    animation-timing-function: steps(2, end);
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;

    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

@-webkit-keyframes swing03 {
    0%,
    100% {
        -webkit-transform: rotate(10deg);
        transform: rotate(10deg);
    }

    50% {
        -webkit-transform: rotate(-10deg);
        transform: rotate(-10deg);
    }
}

@keyframes swing03 {
    0%,
    100% {
        -webkit-transform: rotate(10deg);
        transform: rotate(10deg);
    }

    50% {
        -webkit-transform: rotate(-10deg);
        transform: rotate(-10deg);
    }
}

[data-element-id] .deco-effect-01,
[data-element-id] .deco-effect-02,
[data-element-id] .deco-effect-03 {
    -webkit-animation: inherit;
    animation: inherit;
}

.f-img a .img {
    overflow: hidden;
}

.f-img a .img img {
    -webkit-transition: 0.4s ease;
    transition: 0.4s ease;
}

.f-img a:hover .img img {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
}

.mv-pic {
    width: 100%;
    display: block;
    position: relative;
}

.mv-pic img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.mv-pic:after {
    content: "";
    display: block;
    padding-top: 50%;
}

.mv-pic .ttl {
    width: 90%;
    max-width: 700px;
    padding: 20px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: bold;
    font-size: 30px;
    text-align: center;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
    border-radius: 9999px;
    /* background: rgba(255,255,255,0.8); */
    -webkit-filter: drop-shadow(0px 0px 5px #fff);
    filter: drop-shadow(0px 0px 5px #fff);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
}

@media (max-width: 599px) {
    .welcome .top-wor .img2 {
        max-width: 70px;
        bottom: -80px;
    }
}

.sh2 {
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.5);
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
}

.medical .ttl {
    margin-bottom: 20px;
    font-weight: bold;
    font-size: 20px;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}

.medical .box {
    padding: 20px;
    border-radius: 20px;
    background: #f7ebd7;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

/* .medical li:nth-of-type(2) .box{
  background: #ffe8ce;
}
.medical li:nth-of-type(3) .box{
  background: #f8dff0;
}
.medical li:nth-of-type(4) .box{
  background: #d7e8d7;
} */
.f-img-box {
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.border-r20 {
    overflow: hidden;
    border-radius: 20px;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.method .img01 {
    width: 100%;
    max-width: 150px;
    max-width: 130px;
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 1;
}

@media (max-width: 1024px) {
    .method .img01 {
        max-width: 130px;
    }
}

@media (max-width: 599px) {
    .medical .ttl {
        font-size: 16px;
    }

    .method .img01 {
        max-width: 60px;
    }

    .mv-pic .ttl {
        font-size: 20px;
    }
}

.information .list-cmp03 .item:before {
    content: none;
}

.sb-ttls {
    display: inline-block;
    padding: 5px 15px 5px;
    color: #fff;
    line-height: 1.8;
    border-radius: 15px;
    background: #ef8b68;
}

.information .treat .img {
    width: 48%;
    border-radius: 15px;
}

.information .treat .box {
    padding: 15px;
}

.map360 iframe {
    width: 100%;
    max-width: initial;
    height: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
}

.map360,
.access-map .map {
    height: 100%;
    overflow: hidden;
    padding-top: 35%;
    border-radius: 15px;
    position: relative;
}

@media (max-width: 599px) {
    .information .treat .img {
        width: 100%;
    }

    .map360,
    .access-map .map {
        min-height: 288px;
    }
}

.staff1 .img {
    width: 30%;
    margin-bottom: 30px;
}

.staff1 .tbox {
    width: 30%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    align-items: flex-end;
    -ms-flex-align: end;
    margin-bottom: 30px;
}

.staff1 .in {
    width: 100%;
}

.staff1 .logo {
    width: 100%;
    max-width: 200px;
    margin-bottom: 15px;
    -webkit-filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
    filter: drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff)drop-shadow(0px 0px 5px #fff);
}

.staff1 .logo div:after {
    padding-top: 21.5%;
}

.h4name {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 20px 0;
    font-weight: bold;
    font-size: 30px;
}

.h4name .f14 {
    font-size: 14px;
}

.h4name .y {
    display: inline-block;
    padding-right: 1em;
    font-size: 16px;
    color: #ef8b68;
}

.list-box {
    padding: 30px;
    border-radius: 50px;
    background: #fff;
}

.list-cmp03.new {
    padding: 30px;
}

.mess {
    position: relative;
}

.mess .img01 {
    width: 100%;
    max-width: 200px;
    position: absolute;
    top: 10%;
    right: 10%;
}

.staff3 .namae {
    width: 30%;
}

.staff3 dl {
    width: 65%;
    padding: 0 0 20px 0;
}

.staff3 .logo {
    max-width: 200px;
    padding: 0 0 15px 0;
}

.staff3 dt,
.staff3 .mas {
    display: inline-block;
    margin-bottom: 10px;
    padding: 5px 15px 5px;
    color: #fff;
    line-height: 1.8;
    border-radius: 15px;
    background: #ef8b68;
}

.staff3 dd {
    padding: 0 0 5px 0;
}

@media (max-width: 1024px) {
    .mess .img01 {
        max-width: 140px;
    }
}

@media (max-width: 599px) {
    .staff1 .tbox {
        width: 100%;
        text-align: right;
    }

    .staff1 .img {
        width: 100%;
        max-width: 490px;
        margin-left: auto;
        margin-right: auto;
    }

    .staff1 .logo {
        margin-left: auto;
    }

    .h4name {
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        font-size: 24px;
    }

    .h4name.new {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .mess .img01 {
        max-width: 80px;
        top: 1%;
    }

    .staff3 .namae {
        width: 100%;
    }

    .staff3 dl {
        width: 100%;
    }
}

.m-d {
    position: relative;
    z-index: 1;
}

.m-d .box {
    background: #fff;
}

.m-d .ttl {
    padding: 5px;
    font-size: 24px;
    color: #fff;
    letter-spacing: 10px;
    text-align: center;
    background: #ef8b68;
}

.m-d .box li {
    margin-bottom: 10px;
    padding-left: 15px;
    position: relative;
}

.m-d .box li::before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #ef8b68;
    position: absolute;
    top: 7px;
    left: 0;
}

.m-d .box li:last-child {
    margin-bottom: 0;
}

.menulist dl {
    padding: 30px 0 10px;
    border-bottom: 3px solid #ef8b68;
}

.menulist dt {
    display: inline-block;
    margin-bottom: 10px;
    padding: 5px 15px 5px;
    color: #fff;
    line-height: 1.8;
    border-radius: 15px;
    background: #ef8b68;
}

.menulist dd+dd {
    font-weight: normal;
    text-align: right;
}

.menulist .table {
    padding: 30px;
    background: #fff;
}

.min-200 {
    min-height: 200px;
}

.min-200-b {
    min-height: 200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.squirrel .img2 {
    top: 0;
    bottom: initial;
}

.voice .voice-box {
    overflow: hidden;
    margin-bottom: 10px;
    border-radius: 15px;
    background: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.voice .voice-box .head {
    font-size: 24px;
    text-align: center;
}

.voice .title-sub {
    margin: 0 auto 10px;
    padding: 0 10px 10px;
    border-bottom: 3px solid #ef8b68;
    position: relative;
}

.v-box a,
.v-box-detail {
    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: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    overflow: hidden;
    padding: 30px;
    border-radius: 20px;
    background-color: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.img-voi {
    max-width: 80px;
}

.img-voi img {
    width: 80px;
    height: 80px;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 50%;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
}

.m-btn.back a {
    padding: 1rem 1.5rem 1rem 3rem;
    text-align: center;
}

.m-btn.back button:before,
.m-btn.back a:before {
    content: "\f053";
    left: 1rem;
    right: initial;
}

@media (max-width: 599px) {
    .cmn-contact-01 .method .img01 {
        top: initial;
        bottom: 15px;
    }

    /*   .m-btn button{
    padding: 1rem 0.5rem 1rem 2rem;
} */
    /*   .m-btn.back button, */
    .m-btn.back a {
        padding: 1rem 0.5rem 1rem 2rem;
    }

    .voice .voice-box .head {
        font-size: 20px;
    }

    .m-d .ttl {
        font-size: 20px;
    }

    .welcome .squirrel .img2 {
        top: 0;
        bottom: initial;
    }

    .m-btn.pdf a {
        padding: 1rem 2rem 1rem 0.5rem;
    }

    .m-btn.pdf a:before {
        right: 5px;
    }
}

.detail-content-text h2 {
    margin-bottom: 20px;
    padding: 0.5em;
    font-weight: bold;
    font-size: 22px;
    border-bottom: 3px solid #ef8b68;
}

.detail-content-text h3 {
    margin-bottom: 20px;
    padding: 0.5em 1em;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    background: #ef8b68;
}

.detail-content-text h4 {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 18px;
    color: #ef8b68;
}

.detail-content-text ol {
    list-style-type: decimal;
    padding-left: 1em;
}

.detail-content-text ul {
    list-style-type: disc;
    padding-left: 1.2em;
}

/*cmn-contact*/
.cmn-contact-01 input,
.cmn-contact-01 textarea {
    width: 100%;
    padding: 10px 10px;
    border: solid 1px #ccc;
    border-radius: 5px;
}

.cmn-contact-01 .form textarea {
    height: 300px;
}

.cmn-contact-01 .form dl {
    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;
    padding-bottom: 20px;
}

.cmn-contact-01 .form dl+dl {
    padding-top: 20px;
    border-top: 1px solid var(--txt-color-04);
}

.cmn-contact-01 .form dt {
    width: 270px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    padding-right: 20px;
}

.cmn-contact-01 .form dt .tit {
    width: 170px;
    padding-right: 10px;
}

.cmn-contact-01 .form dt .label {
    width: 50px;
    font-size: 14px;
    text-align: center;
    border-radius: 70px;
}

.cmn-contact-01 .form dd {
    width: calc(100% - 270px);
}

.cmn-contact-01 .form dd.radiobtn label {
    display: inline-block;
    padding: 5px 10px 5px 35px;
    position: relative;
}

.cmn-contact-01 .form dd.radiobtn label::before {
    content: "";
    width: 25px;
    height: 25px;
    border: 2px solid #ef8b68;
    border-radius: 5px;
    background: #fff;
    position: absolute;
    top: 5px;
    left: 0;
}

.cmn-contact-01 .form dd.radiobtn label:hover {
    cursor: pointer;
}

.cmn-contact-01 .form dd.radiobtn input {
    display: none;
}

.cmn-contact-01 .form dd.radiobtn input:checked+label::after {
    content: "\f00c";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 21px;
    color: #ef8b68;
    position: absolute;
    top: 3px;
    left: 2px;
    z-index: 1;
}

.cmn-contact-01 .form dd.radiobtn input+label {
    margin-left: 10px;
}

@media (max-width: 599px) {
    .cmn-contact-01 .form {
        margin-left: 10px;
        margin-right: 10px;
    }

    .cmn-contact-01 .form textarea {
        height: 200px;
    }

    .cmn-contact-01 .form dt {
        width: 100%;
        padding-right: 0;
    }

    .cmn-contact-01 .form dt .tit {
        -webkit-box-flex: 1;
        -ms-flex-positive: 1;
        flex-grow: 1;
    }

    .cmn-contact-01 .form dd {
        width: 100%;
        margin-top: 10px;
    }

    .cmn-contact-01 .form dd.radiobtn label {
        padding: 5px 10px 5px 30px;
    }

    .cmn-contact-01 .form dd.radiobtn input+label {
        margin-left: 0;
    }

    .cmn-contact-01 .form dd.radiobtn label::before {
        width: 20px;
        height: 20px;
        top: 9px;
    }

    .cmn-contact-01 .form dd.radiobtn input:checked+label::after {
        font-size: 18px;
        color: #ef8b68;
        position: absolute;
        top: 6px;
        left: 2px;
    }
}

.uk-lb {
    cursor: pointer;
}

.ind2 {
    width: 100%;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: inherit;

    -webkit-line-clamp: 2;
}

.balloon1-left {
    min-width: 120px;
    max-width: 100%;
    display: inline-block;
    margin: 1.5em 0 1.5em 15px;
    padding: 7px 10px;
    font-size: 16px;
    color: #555;
    border-radius: 10px;
    background: #fff;
    -webkit-filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
    position: relative;
}

.balloon1-left:before {
    content: "";
    margin-top: -15px;
    border: 15px solid transparent;
    border-right: 15px solid #fff;
    position: absolute;
    top: 50%;
    left: -30px;
}

.line-btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0.5rem 3.5rem;
    color: #fff;
    border-radius: 15px;
    background-color: #06c755;
    position: relative;
}

.method.line .img01 {
    top: 50%;
    right: 10%;
}

@media (max-width: 599px) {
    .method.line .img01 {
        top: 85%;
        right: 2%;
    }

    .line-btn a {
        padding: 0.5rem 1.5rem;
    }

    .balloon1-left {
        margin: 1.5em 0;
    }

    .balloon1-left:before {
        content: "";
        margin-top: 0;
        margin-left: -15px;
        border: 15px solid transparent;
        border-bottom: 15px solid #fff;
        position: absolute;
        top: -30px;
        left: 50%;
    }
}

.car-logo{
background: #e0752c;
    color: #fff;
    border-radius: 50%;
    width: 30px;
    display: flex;
    height: 30px;
    text-align: center;
    margin-right: 10px;
    justify-content: center;
    align-items: center;
}

[data-element-id] .fead-order>* {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

[data-element-id] .slick01>div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

[data-element-id] .slick01>div li {
    width: 30%;
}

[data-element-id] .scroll-logo {
    -webkit-animation: none;
    animation: none;
}

[data-element-id] .gnav .list02 {
    visibility: visible;
    padding-top: 0;
    border: solid 3px red;
    opacity: 1;
    position: relative;
}

[data-element-id] .gnav .list02:before {
    content: "モバイル用";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: red;
}

[data-element-id] .gnav .list02.car01:before {
    content: "初めての方へ内のテキスト";
}

[data-element-id] .gnav .list02.car02:before {
    content: "医院情報内のテキスト";
}

[data-element-id] .gnav .list02.car03:before {
    content: "診療内容へ内のテキスト";
}

[data-element-id] .up-d-none {
    display: block;
    border: solid 3px #000;
    position: relative;
}

[data-element-id] .up-d-none:before {
    content: "モバイル用";
    display: block;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #000;
}








/*////////////////////////////2023/7/14/神野追記///////////////////////////////////////////////////////////////////*/

#footer .map{
  min-height:200px;
}

#footer .m-btn.bls a{
  padding: 0.7rem 4rem 0.7rem 2rem;
}

.down-arrow{
  display:none;
}

.new-item01 .tx-s{
  position:relative;
  margin-left:42px;
}

.new-item01 .tx-s .num{
  position:absolute;
  display:inline-block;
  top:0;
  width:42px;
  text-align:center;
  right:100%;
  line-height:1.4em;
}

@media(max-width:599px){
  .down-arrow{
    display:block;
    margin-top:-30px;
  }
  
  #footer .m-btn.bls a{
  width:240px;
  padding: 0.7rem 3rem 0.7rem 1rem;
}
}


/* 2023/08/25 */
.staff .mv-pic .ttl {
    top: 70%;
}

.m-btn.tel a i {
    position: relative;
}

.m-btn.tel a i.fa-mobile-screen-button:before {
    font-family: "font awesome 5 Free";
    font-weight: bold;
    content: "\f3cd";
    font-style: normal;
}

.header .right i {
    position: relative;
}

.header .right i:before {
    content: "\f3cd";
    font-family: "font awesome 5 Free";
    font-weight: bold;
    font-style: normal;
}

i.fa-mobile-screen-button {
    position: relative;
}

i.fa-mobile-screen-button:before {
    font-family: "font awesome 5 Free";
    font-weight: bold;
    content: "\f3cd";
    font-style: normal;
}

/* 0826追記 */

@media only screen and (max-width: 599px){
  .m-btn.sp-w150 a{
    width: 165px !important;
}
}

/* 02/13 追記 */

.contact-page .attention{
  margin-bottom: 50px;
}

.contact-page .attention div {
    text-align: center;
    color: red;
    font-weight: bold;
    font-size: clamp(0.875rem, 0.781rem + 0.47vw, 1.25rem);
    letter-spacing: 2px;
    text-shadow: 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white, 0 0 7px white;
}
