@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");

/* # root1 START # */
/* :root {
    --color01: #fd87a0;
    --color02: #fef6f8;
    --color03: #feb9c8;
    --color04: #000;
    --bg01: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/circle_pink.webp');
    --bg02: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/tel_pink.webp');
    --bg03: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon_pink.webp');
    --bg04: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg03_pink.webp');
    --bg05: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon02_pink.webp');
    --bg06: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi_pink.webp');
    --bg07: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg04_pink.webp');
    --bg08: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bgcircle_pink.webp');
    --bg09: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg01_pink.webp');
    --bg10: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi2_pink.webp');
    --bg11: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/check_pink.webp');
    --bg12: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/icon03_pink.webp');
    --bg13: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot02_pink.webp');
    --bg14: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot03_pink.webp');
    --bg15: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg-dot_pink.webp');
    --bg16: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon05_pink.webp');
    --bg17: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/merit_pink.webp');
    --bg18: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/point_pink.webp');
    --bg19: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/deco130_pink.webp');
    --bg20: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi3_pink.webp');
} */
/* # root1 END # */

/* # root2 START # */
:root {
  --color01: #ff9046;
  --color02: #feebdd;
  --color03: #ffc6a0;
  --color04: #000;
  --bg01: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/circle_orange.webp');
  --bg02: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/tel_orange.webp');
  --bg03: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon_orange.webp');
  --bg04: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg03_orange.webp');
  --bg05: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon02_onrage.webp');
  --bg06: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi_orange.webp');
  --bg07: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg04_orange.webp');
  --bg08: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bgcircle_orange.webp');
  --bg09: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg01_orange.webp');
  --bg10: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi2_orange.webp');
  --bg11: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/check_orange.webp');
  --bg12: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/icon03_orange.webp');
  --bg13: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot02_orange.webp');
  --bg14: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot03_orange.webp');
  --bg15: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg-dot_orange.webp');
  --bg16: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon05_orange.webp');
  --bg17: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/merit_orange.webp');
  --bg18: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/point_orange.webp');
  --bg19: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/deco130_orange.webp');
  --bg20: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi3_orange.webp');
}
/* # root2 END # */

/* # root3 START # */
/* :root {
  --color01: #2fa4b4;
  --color02: #effdfe;
  --color03: #b3dee5;
  --color04: #000;
  --bg01: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/circle_blue.webp');
  --bg02: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/tel_blue.webp');
  --bg03: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon_blue.webp');
  --bg04: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg03_blue.webp');
  --bg05: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon02_blue.webp');
  --bg06: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi_blue.webp');
  --bg07: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg04_blue.webp');
  --bg08: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bgcircle_blue.webp');
  --bg09: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg01_blue.webp');
  --bg10: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi2_blue.webp');
  --bg11: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/check_blue.webp');
  --bg12: url('/import/tenant_2/soh-shika.a-bisu.jp/images/07ippan/icon03_blue.webp');
  --bg13: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot02_blue.webp');
  --bg14: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/dot03_blue.webp');
  --bg15: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/bg-dot_blue.webp');
  --bg16: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/icon05_blue.webp');
  --bg17: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/merit_blue.webp');
  --bg18: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/point_blue.webp');
  --bg19: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/deco130_blue.webp');
  --bg20: url('/import/tenant_2/soh-shika.a-bisu.jp/images/common/fukidashi3_blue.webp');
} */
/* # root3 END # */

html {
    font-family: "Noto Sans JP",system-ui;
    font-size: 14px;
    color: #414141;
    min-width: 375px;
}

a {
    color: #414141;
}

.tel[data-ab-test-conversion-button=""]{
  pointer-events: auto;
}

/********************************
    ベース（基本設定）
*******************************/
.color01 {
    color: var(--color01);
}

.color02 {
    color: var(--color02);
}

.color03 {
    color: var(--color03);
}

.color04 {
    color: var(--color04);
}

.bgcolor01 {
    background-color: var(--color01);
}

.bgcolor02 {
    background-color: var(--color02);
}

.bgcolor03 {
    background-color: var(--color03);
}

.bgcolor04 {
    background-color: var(--color04);
}




/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝

ココから下元々のコード 

＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
*/

.fs16 {
    font-size: 16px;
}

.fs18 {
    font-size: 18px;
}

.fs22 {
    font-size: 22px;
}

.bold {
    font-weight: bold;
}

.red {
    color: red;
}

.white {
    color: #fff;
}

img {
    max-width: 100%;
    vertical-align: top;
    border: none;
}

img:not([src*="."]) {
    display: none;
}

.pic {
    width: 100%;
    text-align: center;
}

.pic img {
    width: 100%;
}

/*カラム*/
/* ##### pcで4分割のグリッド ##### */
.gr421 {
    width: 23%;
    margin: 0 1% 6% 1%;
}

/* ##### pcで3分割のグリッド ##### */
.gr321 {
    width: 29%;
    margin: 0 2% 6% 2%;
}

/* ##### pcで2分割のグリッド ##### */
.gr221 {
    width: 46%;
    margin: 0 2% 6% 2%;
}

.w65 {
    width: 65%;
}

.w50 {
    width: 50%;
}

.w48 {
    width: 48%;
}

.w30 {
    width: 30%;
}

[data-element-id] #wrapper {
    opacity: 1;
}

#wrapper {
    overflow: hidden;
}

@media (max-width: 1024px) {
    .fs22 {
        font-size: 20px;
    }

    a[href*="tel"] {
        pointer-events: initial !important;
    }

    .flex {
        margin: 0 auto;
    }

    /* カラム */

    /* ##### タブレッドで2分割のグリッド ##### */
    .gr421,
    .gr321 {
        width: 46%;
    }

    .inner {
        width: 93%;
        max-width: 768px;
    }

    .inner.-wide {
        width: 100%;
        max-width: inherit;
    }
}

@media (max-width: 599px) {
    .fs18 {
        font-size: 16px;
    }

    .fs22 {
        font-size: 18px;
    }

    /* カラム */
    /* ##### スマホで1分割のグリッド ##### */
    .gr421,
    .gr321,
    .gr311,
    .gr221 {
        width: 96%;
    }

    .w65 {
        width: 100%;
        margin: 2% 0;
    }

    .w60 {
        width: 100%;
        margin: 2% 0;
    }

    .w50 {
        width: 100%;
        margin: 2% 0;
    }

    .w48 {
        width: 100%;
        margin: 2% 0;
    }

    .w30 {
        width: 100%;
        margin: 2% 0;
    }

    .pic {
        width: 80%;
        margin: 0 auto;
    }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝

元々のコード終了 

＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
*/

/*********************************************
    リセット
*********************************************/
figure {
    margin: 0;
}

/*********************************************
    汎用クラス
*********************************************/
/**
エリア
*/
.area {
    padding: 80px 0;
}

.area80 {
    padding: 80px 0;
}

.area60 {
    padding: 60px 0;
}

.area40 {
    padding: 40px 0;
}

.area20 {
    padding: 20px 0;
}

.areab {
    padding-bottom: 80px;
}

.area80b {
    padding-bottom: 80px;
}

.area60b {
    padding-bottom: 60px;
}

.area40b {
    padding-bottom: 40px;
}

.area20b {
    padding-bottom: 20px;
}

.areat {
    padding-top: 80px;
}

.area80t {
    padding-top: 80px;
}

.area60t {
    padding-top: 60px;
}

.area40t {
    padding-top: 40px;
}

.area20t {
    padding-top: 20px;
}

@media (max-width: 1024px) {
    .area {
        padding: 40px 0;
    }

    .area80 {
        padding: 60px 0;
    }

    .area60 {
        padding: 40px 0;
    }

    .area40 {
        padding: 20px 0;
    }

    .areab {
        padding-bottom: 40px;
    }

    .area80b {
        padding-bottom: 60px;
    }

    .area60b {
        padding-bottom: 40px;
    }

    .area40b {
        padding-bottom: 20px;
    }

    .areat {
        padding-top: 40px;
    }

    .area80t {
        padding-top: 60px;
    }

    .area60t {
        padding-top: 40px;
    }

    .area40t {
        padding-top: 20px;
    }
}

/*********************************************
    汎用レイアウト（全ページ共通）
*********************************************/
/*汎用レイアウト1（全ページ共通）*/
.layout_cmn01 .ttl {
    margin-bottom: 50px;
}

.layout_cmn01 .ttl_cmn02.ttl{
  margin-bottom: 30px;
}

.layout_cmn01 .cap {
    margin-bottom: 10px;
}

.layout_cmn01 .fig {
    margin-bottom: 5px;
}

@media (max-width: 599px) {
    .layout_cmn01 .ttl {
        margin-bottom: 30px;
    }
    
    .layout_cmn01 .ttl_cmn02.ttl{
      margin-bottom: 10px;
    }
}

/*汎用レイアウト2（全ページ共通）*/
.layout_cmn02 .ttl {
    margin-bottom: 20px;
}

.layout_cmn02 .cap {
    margin-bottom: 10px;
}

.layout_cmn02 .fig {
    margin-bottom: 5px;
}

/*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 .main {
    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: 5%;
    }

    .column2 .main {
        width: 100%;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
        margin-bottom: 5%;
    }
}

/*左右の要素を入れ替え*/
.change {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

/*左右の要素を順に入れ替え*/
.alternate .flexb:nth-of-type(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

/*********************************************
    汎用画像クラス　img
*********************************************/
.img {
    text-align: center;
}

/*背景画像*/
.bgimg {
    position: relative;
}

.img.-bgimg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.img.-bgimg 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%;";
}

/* line-cmn */
.line-cmn-01 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;

    -webkit-line-clamp: 1;
}

.line-cmn-02 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;

    -webkit-line-clamp: 2;
}

/* indent-cmn */
.indent-half {
    text-indent: -10px;
}

.indent-cmn-01 {
    padding-left: 1em;
    text-indent: -1em;
}

.indent-cmn-02 {
    padding-left: 1em;
    position: relative;
}

.indent-cmn-02 {
    content: "\f058";
    font-family: var(--ff99);
    font-weight: bold;
    position: absolute;
    top: 0;
    left: 0;
}

/*object-fit(cover)IE対応*/
.img.-cover 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%;";
}

/*角丸画像*/
.img.-round {
    overflow: hidden;
    border-radius: 20px;
}

.list_cmn05 .item .img.-round{
  border-radius: 10px;
}

/*********************************************
    fead系
*********************************************/
.fead-right {
    opacity: 0;
    -webkit-transition: 1s;
    transition: 1s;
    -webkit-transform: translate3d(-100vw, 0, 0);
    transform: translate3d(-100vw, 0, 0);
}

.fead-right.mv {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.fead-left {
    opacity: 0;
    -webkit-transition: 1s;
    transition: 1s;
    -webkit-transform: translate3d(100vw, 0, 0);
    transform: translate3d(100vw, 0, 0);
}

.fead-left.mv {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

/*********************************************
    共通ボックス　box-cmn
*********************************************/
/*********************************************
    共通ブロック　block-cmn
*********************************************/
/*共通ブロック１（お問い合わせ）*/
.block_cmn01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.block_cmn01 .block_left,
.block_cmn01 .block_right {
    width: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-line-pack: center;
    align-content: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 20px 30px;
}

.block_cmn01 .block_left {
    background: var(--color01);
    position: relative;
}

.block_cmn01 .block_left:after {
    content: var(--bg05);
    -webkit-transform: translate(50%, -50%);
    transform: translate(50%, -50%);
    position: absolute;
    top: 50%;
    right: 0;
}

.block_cmn01 .block_right {
    background: var(--color02);
}

.block_cmn01 .txt_tel {
    margin-bottom: 20px;
    font-weight: bold;
    font-size: 20px;
    color: #fff;
    line-height: 130%;
    text-align: center;
}

.block_cmn01 .tel 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;
    font-weight: bold;
    font-size: 40px;
    color: #fff;
    letter-spacing: 0.1em;
}

.block_cmn01 .tel a:before {
    content: "\f879";
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    transform: scale(-1, 1);
}

.block_cmn01 .block_right a {
    width: 100%;
    display: block;
    padding-right: 50px;
    font-weight: bold;
    font-size: 32px;
    color: var(--color01);
    line-height: 130%;
    text-align: center;
    position: relative;
}

.block_cmn01 .block_right a:after {
    content: "\f0e0";
    font-family: "Font Awesome 5 Free";
    font-weight: normal;
    font-size: 50px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 0;
}

@media (max-width: 1024px) {
    .block_cmn01 .tel a {
        font-size: 26px;
    }

    .block_cmn01 .block_right a {
        padding-right: 36px;
        font-size: 22px;
    }

    .block_cmn01 .block_right a:after {
        font-size: 36px;
    }
}

@media (max-width: 599px) {
    .block_cmn01 .block_left,
    .block_cmn01 .block_right {
        width: 100%;
    }

    .block_cmn01 .block_left {
        padding-bottom: 40px;
    }

    .block_cmn01 .block_left:after {
        width: 90px;
        height: 90px;
        line-height: 140px;
        text-align: center;
        border-radius: 50%;
        background: var(--color03);
        -webkit-transform: translate(50%, -50%) scale(0.7);
        transform: translate(50%, -50%) scale(0.7);
        -webkit-transform-origin: center;
        transform-origin: center;
        top: 100%;
        right: 50%;
    }

    .block_cmn01 .block_right {
        padding-top: 40px;
    }

    .block_cmn01 .txt_tel {
        margin-bottom: 10px;
    }

    .block_cmn01 .txt a {
        font-size: 20px;
    }

    .block_cmn01 .block_right 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;
        font-size: 22px;
    }

    .block_cmn01 .block_right a:after {
        margin-left: 20px;
        font-size: 30px;
        -webkit-transform: none;
        transform: none;
        position: relative;
        top: inherit;
    }
}

/*********************************************
    共通タイトル　ttl-cmn
*********************************************/
/*共通タイトル1*/
.ttl_cmn01 {
    font-weight: bold;
    font-size: 24px;
}

.ttl_cmn01 .ttlin {
    line-height: 2em;
    padding-bottom: 5px;
    border-bottom: 5px solid var(--color03);
}

.ttl_cmn01.-center {
    text-align: center;
}

.ttl_cmn01.-caution {
    padding: 0 100px;
}

.ttl_cmn01.-caution .cautionin {
    position: relative;
}

.ttl_cmn01.-caution .cautionin:before {
    content: var(--bg12);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: -10px;
    left: -40px;
}

[data-element-id] .show\@sp .ttl_cmn01 {
    font-size: 20px;
}

[data-element-id] .show\@sp .ttl_cmn01.-caution {
    padding: 0 60px;
}

[data-element-id] .ttl_cmn01.-caution .cautionin:before {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    display: block;
    margin-right: auto;
    -webkit-transform: none;
    transform: none;
    position: relative;
    top: auto;
    left: auto;
}

@media (max-width: 599px) {
    .ttl_cmn01 {
        font-size: 20px;
    }

    .ttl_cmn01 .ttlin {
        padding-bottom: 2px;
    }

    .ttl_cmn01.-caution {
        padding: 0 60px;
    }

    .ttl_cmn01.-caution .cautionin:before {
        -webkit-transform: scale(0.8) translate(-50%, -50%);
        transform: scale(0.8) translate(-50%, -50%);
        top: -20px;
    }
}

/*共通タイトル２*/
.ttl_cmn02 {
    font-size: 16px;
    color: #fff;
    line-height: 130%;
    text-align: center;
}

.ttl_cmn02 .ttlin {
    width: 240px;
    height: 80px;
    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 auto;
    padding-bottom: 17px;
    background: var(--bg10) no-repeat center;
    background-size: contain;
}

.ttl_cmn02.-dark .ttlin {
    background: var(--bg10) no-repeat center;
    background-size: contain;
}

@media(max-width:599px){
  .ttl_cmn02{
    margin-bottom: 10px;
  }
  .ttl_cmn02 .ttlin{
    width: 250px;
    height: 90px;
  }
}

/*共通タイトル３*/
.ttl_cmn03 {
    font-weight: bold;
    font-size: 34px;
    color: var(--color01);
    text-align: center;
}

[data-element-id] .show\@sp .ttl_cmn03 {
    font-size: 26px;
}

@media (max-width: 599px) {
    .ttl_cmn03 {
        font-size: 26px;
    }
}

/*共通タイトル４*/
.ttl_cmn04 {
    max-width: 500px;
    font-weight: bold;
    font-size: 20px;
    border-bottom: 4px solid var(--color01);
    position: relative;
}

.ttl_cmn04 .img {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-animation: anim_v 2s ease-in-out infinite alternate;
    animation: anim_v 2s ease-in-out infinite alternate;
    position: absolute;
    top: -20px;
    left: -50px;
}

.ttl_cmn04 .img::before {
    content: "";
    width: 130px;
    display: block;
    background: var(--bg19);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ttl_cmn04 .ttlin {
    position: relative;
    z-index: 2;
}

/*********************************************
    show hide
*********************************************/
.show\@pc {
    display: block;
}

.hide\@pc {
    display: none;
}

[data-element-id] .show\@tb {
    max-width: 375px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    border: solid 4px green;
    position: relative;
}

[data-element-id] .show\@tb:after {
    content: "モバイル用";
    display: block;
    padding: 5px;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    text-shadow: none;
    background: green;
}

[data-element-id] .show\@tb.indention {
    width: 30px;
    display: inline-block;
}

[data-element-id] .show\@tb.indention:after {
    content: "SP時改行";
    padding: 0;
    font-size: 10px;
    letter-spacing: -1px;
}

[data-element-id] .show\@pc.indention {
    width: 30px;
    display: inline-block;
}

[data-element-id] .show\@pc.indention:after {
    content: "PC時改行";
    display: block;
    padding: 0;
    font-weight: 700;
    font-size: 10px;
    color: #fff;
    letter-spacing: -1px;
    text-align: center;
    text-shadow: none;
    border: 2px solid blue;
    background: blue;
}

[data-element-id] .show\@sp {
    max-width: 375px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    border: solid 4px green;
    position: relative;
}

[data-element-id] .show\@sp:after {
    content: "モバイル用";
    display: block;
    padding: 5px;
    font-weight: 700;
    font-size: 12px;
    color: #fff;
    text-align: center;
    text-shadow: none;
    background: green;
}

[data-element-id] .show\@sp.indention {
    width: 30px;
    display: inline-block;
}

[data-element-id] .show\@sp.indention:after {
    content: "SP時改行";
    padding: 0;
    font-size: 10px;
    letter-spacing: -1px;
}

@media (max-width: 1024px) {
    .show\@tb {
        display: block;
    }

    .hide\@tb {
        display: none;
    }
}

@media (max-width: 599px) {
    .show\@sp {
        display: block;
    }

    .hide\@sp {
        display: none;
    }
}


/*********************************************
    共通リスト　list-cmn
*********************************************/
/*ページネーション１*/
.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,
.pagenation .next {
    position: relative;
}

.pagenation .prev a,
.pagenation .next a {
    width: 30px;
    height: 30px;
    display: block;
    font-size: 16px;
    color: #fff;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
}

.pagenation .prev a:before,
.pagenation .next a:before {
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
}

.pagenation .prev {
    margin-right: 10px;
}

.pagenation .prev a:before {
    content: "\f060";
}

.pagenation .next {
    margin-left: 10px;
}

.pagenation .next a:before {
    content: "\f061";
}

.pagenation .number a,
.pagenation .now {
    display: block;
    font-size: 24px;
    text-align: center;
}

.pagenation .number a:hover,
.pagenation .now {
    color: var(--color01);
    opacity: 1;
}

/*共通リスト1(お知らせ)
「トップ、お知らせ」*/
.list_cmn01 .item {
    padding: 15px 0;
    border-bottom: 2px solid var(--color03);
}

.list_cmn01 .item:last-child {
    border-bottom: none;
}

.list_cmn01 .meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.list_cmn01 .time {
    display: block;
    margin-bottom: 5px;
    margin-right: 20px;
}

.list_cmn01 .category {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-line-pack: start;
    align-content: flex-start;
}

.list_cmn01 .category span {
    margin-bottom: 5px;
    margin-right: 10px;
    padding: 0 10px;
    color: #fff;
    border-radius: 5px;
    background: var(--color03);
}

.list_cmn01 .head a {
    font-weight: bold;
    font-size: 16px;
}

@media (max-width: 599px) {
    .list_cmn01 .time {
        width: 100%;
    }

    .list_cmn01 .meta {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_cmn01 .head a {
        font-size: 14px;
    }
}

/*共通リスト２（フォトギャラリー）*/
[data-element-id] .list_cmn02 {
    max-height: 300px;
    overflow: hidden;
}

.list_cmn02 .item {
    padding: 10px;
    cursor: pointer;
    position: relative;
}

.list_cmn02 .item:after {
    content: url('/import/tenant_2/soh-shika.a-bisu.jp/images/18photo/icon.webp');
    width: calc(100% - 20px);
    height: calc(100% - 20px);
    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;
    visibility: hidden;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    pointer-events: none;
    position: absolute;
    top: 50%;
    left: 50%;
}

.list_cmn02 .item:hover:after {
    visibility: visible;
    opacity: 1;
}

/*共通リスト３（タイムテーブル）*/
.list_cmn03 table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
}

.list_cmn03 th,
.list_cmn03 td {
    padding: 5px 2px;
    text-align: center;
    border-bottom: 1px solid #000;
}

.list_cmn03 th {
    border-top: 1px solid #000;
}

.list_cmn03 th:not(:first-child) {
    width: 45px;
    letter-spacing: 0em;
}

.list_cmn03 tr>*:first-of-type {
    min-width: 100px;
    border-top: 1px solid #000;
}

.list_cmn03 td:not(:first-child) {
    color: var(--color01);
}

.list_cmn03 .txt {
    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;
    margin-top: 10px;
}

.list_cmn03 .txtin {
    margin-left: 10px;
}

/*共通リスト４（流れ）*/
.list_cmn04 {
    counter-reset: item;
}

.list_cmn04 .item {
    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;
    padding: 30px 0 30px 100px;
    position: relative;
}

.list_cmn04 .item:before {
    content: counter(item);
    width: 50px;
    height: 50px;
    display: block;
    counter-increment: item;
    font-size: 30px;
    color: #fff;
    line-height: 50px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
}

.list_cmn04 .item:after {
    content: "";
    width: 2px;
    height: 100%;
    display: block;
    background: var(--color03);
    position: absolute;
    top: 50%;
    left: 25px;
}

.list_cmn04 .item:last-child:after {
    content: none;
}

.list_cmn04 .item:nth-child(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.list_cmn04 .block_img,
.list_cmn04 .block_txt {
    width: 48%;
}

.list_cmn04 .number {
    margin-bottom: 20px;
    color: var(--color03);
}

.list_cmn04 .number:after {
    content: counter(item);
}

.list_cmn04 .head {
    margin-bottom: 10px;
    font-size: 18px;
}

@media (max-width: 1024px) {
    .list_cmn04 .item {
        padding-left: 60px;
    }
}

@media (max-width: 599px) {
    .list_cmn04 .item {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        padding-top: 0;
        padding-bottom: 50px;
    }

    .list_cmn04 .item:before {
        -webkit-transform: none;
        transform: none;
        top: 0;
    }

    .list_cmn04 .item:after {
        top: 0;
    }

    .list_cmn04 .block_img,
    .list_cmn04 .block_txt {
        width: 100%;
    }

    .list_cmn04 .block_img {
        margin-bottom: 20px;
    }

    .list_cmn04 .number {
        margin-bottom: 10px;
    }
}

/*共通リスト５*/
.list_cmn05 .item {
    margin-top: 50px;
    padding: 70px 20px 30px;
    border: 3px solid #ede9ea;
    border-radius: 10px;
    background: #fff;
    position: relative;
}

.list_cmn05 .item.gr421{
    padding: 30px 20px 30px;
}

.list_cmn05 .head01 {
    width: 110px;
    height: 110px;
    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;
    line-height: 110%;
    text-align: center;
    border: 3px solid #fff;
    border-radius: 50%;
    background: var(--color03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 1;
}

.list_cmn05 .img {
    margin-bottom: 10px;
}

.list_cmn05 .head02 {
    margin-bottom: 10px;
    font-size: 16px;
    font-size: 16px;
    color: var(--color01);
    line-height: 130%;
    text-align: center;
}

.list_cmn05 .head02 span {
    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;
}

.list_cmn05 .btn {
    margin-top: 20px;
}

.list_cmn05.-type01 {
    counter-reset: item -1;
}

.list_cmn05.-type01 .headin01:before {
    content: "C"counter(item);
    display: block;
    counter-increment: item;
    margin-bottom: 7px;
    font-size: 22px;
    color: #fff;
}

.list_cmn05.-type02 {
    counter-reset: item;
}

.list_cmn05.-type02 .item {
    margin-top: 20px;
    padding-top: 40px;
}

.list_cmn05.-type02 .head01 {
    width: 50px;
    height: 50px;
}

.list_cmn05.-type02 .head01:before {
    content: counter(item);
    display: block;
    counter-increment: item;
    font-size: 22px;
    color: #fff;
}

.list_cmn05.-type03 {
    counter-reset: item;
}

.list_cmn05.-type03 .headin01 {
    font-size: 16px;
    color: #fff;
}

.list_cmn05.-type03 .headin01:after {
    content: "0"counter(item);
    display: block;
    counter-increment: item;
    margin-top: 7px;
    font-size: 24px;
}

@media (max-width: 599px) {
    .list_cmn05 .item {
        max-width: 350px;
        margin-left: auto;
        margin-right: auto;
    }
}

/*共通リスト６*/
.list_cmn06>.item {
    width: 90%;
    margin: 60px auto 0;
    padding: 20px;
    background: #fff;
    -webkit-box-shadow: 0 0 5px 0 #999;
    box-shadow: 0 0 5px 0 #999;
    position: relative;
}

.list_cmn06>.item:before {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 0;
}

.list_cmn06 .head,.home05 .head {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 16px;
    color: var(--color01);
}

.list_cmn06.-check>.item:before {
    content: var(--bg11);
}

.list_cmn06.-merit>.item:before {
    content: var(--bg17);
}

.list_cmn06.-point>.item:before {
    content: var(--bg18);
}

@media (max-width: 599px) {
    .list_cmn06>.item {
        margin-right: 0;
    }

    .list_cmn06>.item:before {
        -webkit-transform: translate(-50%, -50%) scale(0.9);
        transform: translate(-50%, -50%) scale(0.9);
    }
}

/*共通リスト７（チェック付）*/
.list_cmn07 {
    /* padding: 30px 50px; */
    padding: 30px 8%;
    background: var(--bg15);
}

.list_cmn07 .item {
    margin-bottom: 20px;
    padding-left: 40px;
    font-weight: bold;
    position: relative;
}

.list_cmn07 .item:last-child{
  margin-bottom: 0;
}

.list_cmn07 .item:before {
    content: var(--bg16);
    position: absolute;
    top: -3px;
    left: 0;
}

.list_cmn07.-col2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: flex-start;
    -ms-flex-pack: flex-start;
    justify-content: flex-start;
}

.list_cmn07.-col2 .item {
    width: 50%;
    padding-right: 20px;
}

.list_cmn07.-dark .item:before {
    content: var(--bg16);
}

@media(max-width:1024px){
  .list_cmn07{
    padding: 30px 15px; 
  }
}

@media (max-width: 599px) {
    .list_cmn07 {
        padding: 20px;
    }

    .list_cmn07.-col2 .item {
        width: 100%;
        padding-right: 0;
    }
    
    .list_cmn07.-col2 .item:last-child{
      margin-bottom: 0;
    }
}

/*共通リスト８（丸付き）*/
.list_cmn08 .item {
    display: block;
    margin-bottom: 5px;
    padding-left: 20px;
    font-size: 16px;
    color: var(--color01);
    position: relative;
}

.list_cmn08 .item:before {
    content: "";
    width: 8px;
    height: 8px;
    display: block;
    border: 2px solid var(--color03);
    border-radius: 50%;
    position: absolute;
    top: 9px;
    left: 0;
}

/*共通リスト９（テーブル１）*/
.list_cmn09 {
    width: 100%;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.list_cmn09 table {
    width: 100%;
    border-collapse: collapse;
}

.list_cmn09 .datattl,
.list_cmn09 .data {
    padding: 5px 10px;
    border: 1px solid var(--color03);
}

.list_cmn09 .datattl {
    color: #fff;
    background: var(--color03);
}

.list_cmn09 .data {
    width: 50%;
}

.list_cmn09 .data:first-child {
    text-align: center;
}

.list_cmn09 .data:last-child {
    text-align: right;
}

.list_cmn09 .txt {
    margin-top: 5px;
    text-align: right;
}

@media(max-width:599px){
  .list_cmn09.type02 .data:first-of-type {
    width: 65%;
  }
}

/*共通リスト１０（テーブル２）*/
.list_cmn10 {
    width: 100%;
    overflow: auto;
}

.list_cmn10 table {
    width: 100%;
    border-collapse: collapse;
}

.list_cmn10 .datattl,
.list_cmn10 .data {
    border: 1px solid var(--color03);
}

.list_cmn10 .datattl {
    padding: 5px 10px;
    color: #fff;
    background: var(--color03);
}

.list_cmn10 .datattl:not(:last-child) {
    border-right: 1px solid #fff;
}

.list_cmn10 .data {
    width: 20%;
    min-width: 100px;
    padding: 20px 10px;
    line-height: 130%;
}

.list_cmn10 .data:first-child,
.list_cmn10 .data:last-child {
    text-align: center;
}

/*********************************************
    共通ボタン　btn-cmn
*********************************************/
/*ボタン１*/
.btn_cmn01 a {
    width: 80px;
    height: 80px;
    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;
    color: #fff;
    line-height: 150%;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
    position: relative;
}

.btn_cmn01 a:before,
.btn_cmn01 a:after {
    content: "";
    width: 100%;
    height: 100%;
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
    border-radius: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.btn_cmn01 a:before {
    border: 2px solid transparent;
}

.btn_cmn01 a:after {
    border: 0 solid transparent;
}

.btn_cmn01 a:hover {
    color: var(--color01);
    background: none;
}

.btn_cmn01 a:hover:before {
    border-top-color: var(--color01);
    border-bottom-color: var(--color01);
    border-right-color: var(--color01);
    -webkit-transition: border-top-color 0.15s linear, border-right-color 0.15s linear 0.1s, border-bottom-color 0.15s linear 0.2s;
    transition: border-top-color 0.15s linear, border-right-color 0.15s linear 0.1s, border-bottom-color 0.15s linear 0.2s;
}

.btn_cmn01 a:hover:after {
    border-top: 2px solid var(--color01);
    border-left-width: 2px;
    border-right-width: 2px;
    -webkit-transition: border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    transition: border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    transition: transform 0.4s linear 0s, border-left-width 0s linear 0.35s;
    transition: transform 0.4s linear 0s, border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    -webkit-transform: rotate(270deg);
    transform: rotate(270deg);
}

/*ボタン２*/
.btn_cmn02 a {
    max-width: 300px;
    display: block;
    padding: 5px;
    color: var(--color01);
    text-align: center;
    border: 1px solid var(--color01);
    border-radius: 5px;
    -webkit-transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: transform ease-out 0.1s, background 0.2s;
    transition: transform ease-out 0.1s, background 0.2s, -webkit-transform ease-out 0.1s;
}

.btn_cmn02 a:after {
    content: "";
    width: 100%;
    height: 100%;
    padding: 0;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 5px;
    -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.btn_cmn02 a:hover {
    background: rgba(255, 255, 255, 0.05);
    opacity: 1;
    -webkit-transform: scale(0.93);
    transform: scale(0.93);
}

.btn_cmn02 a:hover:after {
    -webkit-animation: sonarEffect 1.3s ease-out 75ms;
    animation: sonarEffect 1.3s ease-out 75ms;
}

.btn_cmn02.-center a {
    margin: 0 auto;
}

.btn_cmn02.-small a {
    width: 200px;
}

.btn_cmn02.-bgwhite a {
    background: #fff;
}

/*ボタン３*/
.btn_cmn03 .btnin {
    padding: 0 10px 5px;
    border-bottom: 4px solid var(--color03);
}

.btn_cmn03 a {
    font-weight: bold;
    font-size: 16px;
}

.btn_cmn03.-prev a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.btn_cmn03.-prev a:before {
    content: "\f060";
    width: 30px;
    height: 30px;
    display: block;
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    font-size: 16px;
    color: #fff;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
}

.btn_cmn03.-next a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.btn_cmn03.-next a:after {
    content: "\f061";
    width: 30px;
    height: 30px;
    display: block;
    margin-left: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    font-size: 16px;
    color: #fff;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
}

@-webkit-keyframes sonarEffect {
    0% {
        opacity: 0.3;
    }

    40% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0.5;
    }

    100% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0;
        -webkit-transform: scale(1.2);
        transform: scale(1.2);
    }
}

@keyframes sonarEffect {
    0% {
        opacity: 0.3;
    }

    40% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0.5;
    }

    100% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px var(--color01), 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0;
        -webkit-transform: scale(1.2);
        transform: scale(1.2);
    }
}

/*********************************************
    他共通エレメント　txt-cmn img-cmn
*********************************************/
/*共通テキスト１（吹き出し）*/
.txt_cmn01 .txtin {
    display: inline-block;
    padding: 0 20px 50px 30px;
    font-size: 18px;
    color: var(--color01);
    text-align: center;
    background: var(--bg20) no-repeat bottom center;
    background-size: 100% 100%;
}

@media (max-width: 599px) {
    .txt_cmn01 .txtin {
        padding: 0 20px 30px 30px;
        font-size: 14px;
    }
}

/*共通アニメーション１*/
.anime_cmn01 img,
.anime_cmn01::before {
    -webkit-animation: anim_v 2s ease-in-out infinite alternate;
    animation: anim_v 2s ease-in-out infinite alternate;
}

/*共通装飾１（歯）*/
.deco_cmn01 {
    margin-top: 40px;
    position: relative;
}

.deco_cmn01:after {
    content: var(--bg03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 50%;
}

/*共通装飾２（線、歯）*/
.deco_cmn02 {
    height: 5px;
    margin-top: 40px;
    margin-bottom: 40px;
    background: var(--color03);
    position: relative;
}

.deco_cmn02:after {
    content: var(--bg03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: calc(50% - 10px);
    left: 50%;
    z-index: 1;
}

@-webkit-keyframes anim_v {
    0% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }

    100% {
        -webkit-transform: translate(0, -15px);
        transform: translate(0, -15px);
    }
}

@keyframes anim_v {
    0% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }

    100% {
        -webkit-transform: translate(0, -15px);
        transform: translate(0, -15px);
    }
}

/*********************************************
    モジュール（共通機能群）
*********************************************/
/*フォーム*/
.form .item {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    padding: 10px 0;
}

.form .datattl {
    width: 200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    font-weight: bold;
    font-size: 16px;
}

.form .require {
    margin-left: 10px;
}

.form .data {
    width: 100%;
    padding-left: 50px;
}

.form .data.age{
  width: 200px;
}

.form .data input {
    width: 100%;
    margin-top: 5px;
    margin-bottom: 5px;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: none;
}

.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: 13px;
    height: 13px;
    display: block;
    border: 1px solid #303841;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    top: 4px;
    left: 0;
}

.form .data input[type="radio"]:checked+label::after {
    content: "";
    width: 9px;
    height: 9px;
    display: block;
    border-radius: 50%;
    background: #303841;
    position: absolute;
    top: 6px;
    left: 2px;
}

.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;
}

.form .data textarea {
    width: 100%;
    height: 170px;
    padding: 5px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-family: "游ゴシック", YuGothic, Hiragino Sans, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 14px;
    border: none;
}

.form .data01 div {
    display: inline-block;
}

.form .btn {
    margin-top: 30px;
}

.form .btn button {
    width: 200px;
    display: block;
    margin: 5px 20px;
    padding: 5px;
    color: var(--color01);
    text-align: center;
    border: 1px solid var(--color01);
    border-radius: 5px;
    background: #fff;
    -webkit-transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: transform ease-out 0.1s, background 0.2s;
    transition: transform ease-out 0.1s, background 0.2s, -webkit-transform ease-out 0.1s;
}

.form .btn button:after {
    content: "";
    width: 100%;
    height: 100%;
    padding: 0;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 5px;
    -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.form .btn button:hover {
    background: rgba(255, 255, 255, 0.05);
    opacity: 1;
    -webkit-transform: scale(0.93);
    transform: scale(0.93);
}

.form .btn button:hover:after {
    -webkit-animation: sonarEffect 1.3s ease-out 75ms;
    animation: sonarEffect 1.3s ease-out 75ms;
}

@media (max-width: 1024px) {
    .form .item {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .form .datattl {
        display: block;
        margin-bottom: 5px;
    }

    .form .data {
        padding-left: 0;
    }
}

/**************************************
    共通要素
**************************************/
/**
ヘッダー
header
*/
.header {
    position: relative;
    z-index: 200;
}

.header .circle,
.top_cmn01 .circle {
    opacity: 0.5;
    position: absolute;
    top: -300px;
    left: -100px;
    z-index: -1;
}

.header .circle {
    top: -100px;
}

.header .circle::before,
.top_cmn01 .circle::before {
    content: "";
    width: 521px;
    display: block;
    background: var(--bg01);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.header.fixed {
    width: 100%;
    height: auto;
    background: #fff;
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.1);
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.1);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 251;
}

@media (max-width: 1024px) {
    .top_cmn01 .circle {
        top: -200px;
    }

    .header .circle::before,
    .top_cmn01 .circle::before {
        width: 350px;
    }
}

@media (max-width: 599px) {
    .top_cmn01 .circle {
        top: -150px;
    }

    .header .circle::before,
    .top_cmn01 .circle::before {
        width: 250px;
    }
}

.home .header {
    z-index: 200;
}

.header_contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-align: flax-start;
    align-items: flax-start;
    -ms-flex-align: flax-start;
    justify-content: flex-end;
    margin-bottom: 0;
    padding: 5px 0 5px;
}

.header-common {
    display: contents;
}

[data-element-id] .header-common{
  display: block;
}

.header_contents .logo {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 10px 20px 0;
}

.header_contents .logo a {
    display: block;
}

@media (max-width: 1024px) {
    .header_contents {
        padding: 10px 0;
    }

    .header_contents .sitettl {
        display: none;
    }

    .header_contents .logo img {
        height: 50px;
    }

    .header_contents .header_contact {
        display: none;
    }
}

@media (max-width: 599px) {
    .header_contents {
        margin-bottom: 0;
        justify-content: flex-start;
    }
}

.header_contact {
    min-width: 320px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    height: fit-content;
}

.header_contact .telephone::before {
    content: "";
    width: 45px;
    display: block;
    background: var(--bg02);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.header_contact .telephone img {
    height: 45px;
}

.header_contact .block_txt {
    padding: 0 10px;
}

.header_contact .tel {
    margin-bottom: 3px;
    padding: 0 10px 5px;
    border-bottom: 2px solid var(--color01);
}

.header_contact .tel a {
    display: block;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: center;
}

.header_contact .address {
    font-weight: bold;
    text-align: center;
}

.header_contact .mail a {
    width: 50px;
    height: 50px;
    display: block;
    font-size: 24px;
    color: #fff;
    line-height: 50px;
    text-align: center;
    border-radius: 5px;
    background: var(--color03);
    -webkit-transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: transform ease-out 0.1s, background 0.2s;
    transition: transform ease-out 0.1s, background 0.2s, -webkit-transform ease-out 0.1s;
}

.header_contact .mail a:before {
    content: "\f0e0";
    font-family: "Font Awesome 5 Free";
    font-weight: normal;
}

.header_contact .mail a:after {
    content: "";
    width: 100%;
    height: 100%;
    padding: 0;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 5px;
    -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.header_contact .mail a:hover {
    background: rgba(255, 255, 255, 0.05);
    opacity: 1;
    -webkit-transform: scale(0.93);
    transform: scale(0.93);
}

.header_contact .mail a:hover:before {
    color: var(--color01);
}

.header_contact .mail a:hover:after {
    -webkit-animation: sonarEffect 1.3s ease-out 75ms;
    animation: sonarEffect 1.3s ease-out 75ms;
}

.fixed_contact {
    position: fixed;
    bottom: 80px;
    right: 15px;
    z-index: 100;
}

[data-element-id] .fixed_contact {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    position: relative;
    bottom: auto;
    right: auto;
}

.fixed_contact .telephone {
    margin-bottom: 15px;
    cursor: pointer;
    position: relative;
}

.fixed_contact .telephone a {
    display: block;
}

.fixed_contact .telephone a::before {
    content: "";
    width: 45px;
    display: block;
    background: var(--bg02);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.fixed_contact .telephone.abtest-b a::before{
    -webkit-transition: 1s cubic-bezier(0.68, -0.6, 0.32, 2);
    transition: 1s cubic-bezier(0.68, -0.6, 0.32, 2);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation: bound 2s ease-in-out infinite;
    animation: bound 2s ease-in-out infinite;
}

@-webkit-keyframes bound {
     0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
    
    50% {
        -webkit-transform: translateY(-5px);
        transform: translateY(-5px);
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

@keyframes bound {
     0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
    
    50% {
        -webkit-transform: translateY(-5px);
        transform: translateY(-5px);
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

.fixed_contact .telephone img {
    height: 45px;
}

.fixed_contact .number {
    width: 0;
    overflow: hidden;
    padding: 0;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: center;
    white-space: nowrap;
    border-bottom: 2px solid var(--color01);
    -webkit-transition: 0.5s;
    transition: 0.5s;
    position: absolute;
    bottom: 0;
    right: 100%;
}

.fixed_contact .number.active {
    width: 200px;
    padding: 0 10px;
}

.fixed_contact .mail a {
    width: 50px;
    height: 50px;
    display: block;
    font-size: 24px;
    color: #fff;
    line-height: 50px;
    text-align: center;
    border-radius: 5px;
    background: var(--color03);
    -webkit-transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: transform ease-out 0.1s, background 0.2s;
    transition: transform ease-out 0.1s, background 0.2s, -webkit-transform ease-out 0.1s;
}

.fixed_contact .mail a:before {
    content: "\f0e0";
    font-family: "Font Awesome 5 Free";
    font-weight: normal;
}

.fixed_contact .mail.-calender a:before{
  content: "\f073";
}

.mail + .mail{
  margin-top: 10px;
}

.fixed_contact .mail a:after {
    content: "";
    width: 100%;
    height: 100%;
    padding: 0;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 5px;
    -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.fixed_contact .mail a:hover {
    background: rgba(255, 255, 255, 0.05);
    opacity: 1;
    -webkit-transform: scale(0.93);
    transform: scale(0.93);
}

.fixed_contact .mail a:hover:before {
    color: var(--color01);
}

.fixed_contact .mail a:hover:after {
    -webkit-animation: sonarEffect 1.3s ease-out 75ms;
    animation: sonarEffect 1.3s ease-out 75ms;
}

@media (max-width: 599px) {
    .fixed_contact {
        bottom: 70px;
    }

    .fixed_contact .telephone {
        margin-bottom: 10px;
    }
}

[data-element-id] .fixed_contact .number {
    width: 220px;
    padding: 0 10px;
    overflow: visible;
    position: relative;
    bottom: auto;
    right: auto;
}

.totop {
    width: 40px;
    height: 40px;
    font-size: 20px;
    color: #fff;
    line-height: 40px;
    text-align: center;
    border-radius: 50%;
    background: var(--color01);
    cursor: pointer;
    position: fixed;
    bottom: 20px;
    right: 20px;
}

[data-element-id] .totop {
    margin-top: 10px;
    margin-left: auto;
    margin-right: 5px;
    position: relative;
    bottom: auto;
    right: auto;
}

.totop:before {
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
}

/**
グローバルナビ
gnav
*/
.accordion-body {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

@media (max-width: 1024px) {
    .accordion-body {
        height: 100%;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        overflow: auto;
        padding: 0 10px 80px;
    }
}

[data-element-id] .accordion-body {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-bottom: 280px;
}

.nav_logo {
    display: none;
    margin-right: 20px;
}

.nav_logo a {
    display: block;
}

.nav_logo img {
    max-height: 30px;
}

@media (max-width: 1024px) {
    .nav_logo {
        width: 100%;
        display: block;
        margin-right: 0;
        padding: 20px 40px;
    }

    .nav_logo a {
        text-align: center;
    }

    .nav_logo img {
        max-height: 50px;
    }
}

[data-element-id] .nav_logo {
    display: block;
}

.nav_global01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 10;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-positive: 10;
    flex-grow: 10;
}

[data-element-id] .nav_global01 {
    -webkit-box-align: start;
    align-items: flex-start;
    -ms-flex-align: start;
}

.nav_global01>.item {
    position: relative;
}

.nav_global01>.item:not(:last-child):after {
    content: "";
    width: 5px;
    height: 5px;
    display: block;
    border: 2px solid var(--color03);
    border-radius: 50%;
    -webkit-transform: translate(50%, -50%);
    transform: translate(50%, -50%);
    position: absolute;
    top: 50%;
    right: 0;
}

.nav_global01>.item>a,
.nav_global01>.item>.a {
    display: block;
    padding: 15px 30px;
    font-size: 16px;
    text-align: center;
}

.nav_global01 .parent {
    position: relative;
    z-index: 1;
}

.nav_global01 .nav_wrap {
    width: 250px;
    max-width: 100vw;
    visibility: hidden;
    padding-top: 30px;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translate(-50%, 50px);
    transform: translate(-50%, 50px);
    position: absolute;
    left: 50%;
}

[data-element-id] .nav_global01 .nav_wrap {
    visibility: visible;
    border: 3px solid deeppink;
    opacity: 1;
    -webkit-transform: none;
    transform: none !important;
    position: relative;
    top: auto !important;
    left: auto !important;
}

[data-element-id] .nav_global01 .nav_wrap::before {
    content: "診療内容";
    width: 100%;
    display: block;
    margin-top: -30px;
    padding: 5px 0 5px;
    font-weight: 600;
    font-size: 14px;
    color: #fff;
    text-align: center;
    background: deeppink;
}

.nav_global01 .nav_second {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    padding: 20px 5px;
    border-radius: 20px;
    background: #fff;
}

.nav_first>*,.nav_second>* {
    margin: 5px 0;
}

.nav_global01 .parent:hover .nav_wrap {
    visibility: visible;
    opacity: 1;
    -webkit-transform: translate(-50%, 0px);
    transform: translate(-50%, 0px);
}

.nav_global01 .nav_third .head {
    margin-bottom: 5px;
    font-weight: bold;
    font-size: 16px;
    color: var(--color01);
}

.nav_global01 .nav_third a {
    display: block;
    padding: 5px 0 5px 20px;
    position: relative;
}

.nav_global01 .nav_third a:before {
    content: ">";
    position: absolute;
    top: 5px;
    left: 5px;
}

@media (max-width: 1024px) {
    .nav_global01 {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .nav_global01>.item {
        width: 100%;
    }

    .nav_global01>.item:not(:last-child):after {
        content: none;
    }

    .nav_global01>.item>a,.nav_global01>.item>.a {
        padding: 10px 0;
        text-align: left;
    }

    .nav_global01 .nav_wrap {
        width: auto;
        visibility: visible;
        padding-top: 0;
        opacity: 1;
        -webkit-transform: none;
        transform: none;
        position: relative;
        left: 0;
    }

    .nav_global01 .parent:hover .nav_wrap {
        -webkit-transform: none;
        transform: none;
    }

    .nav_global01 .nav_second {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .nav_global01 .nav_second>.item {
        width: 100%;
        margin-bottom: 10px;
    }
}

.nav_global02 {
    display: none;
}

.nav_global02 a {
    display: block;
    padding: 10px 0px;
    font-size: 16px;
}

@media (max-width: 1024px) {
    .nav_global02 {
        display: block;
        padding: 0;
    }
}

[data-element-id] .nav_global02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

[data-element-id] .nav_global02 a {
    padding: 10px;
}

.gnav{
  padding: 5px 0;
}

.gnav.fixed {
    width: 100%;
    height: auto;
    background: #fff;
    cursor: pointer;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
}

.gnav.fixed .nav_logo {
    display: block;
}

.gnav.fixed .nav_global01>.item>a,
.gnav.fixed .nav_global01>.item>.a {
    padding: 15px 20px;
    white-space: nowrap;
}

[data-element-id] .gnav.fixed {
    padding: 0;
    position: relative;
}

@media (max-width: 1024px) {
    .gnav {
        width: 300px;
        height: 100vh;
        -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;
    }

    .drawer-active .gnav {
        -webkit-transform: translate3d(0%, 0, 0);
        transform: translate3d(0%, 0, 0);
        z-index: 250;
    }

    .toggle {
        width: 42px;
        height: 42px;
        display: block !important;
        background: var(--color01);
        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;
    }

    .drawer-active .toggle .bar {
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }

    .drawer-active .toggle .bar:after,
    .drawer-active .toggle .bar:before {
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
        top: 0;
        left: 0;
    }

    .drawer-active: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: 150;
    }
}

[data-element-id]#wrapper {
    padding-top: 0 !important;
}

[data-element-id] .gnav .no-pc {
    display: block;
}

[data-element-id] .gnav.fixed {
    position: relative;
}

/**
フッター
footer
*/
.footer {
    margin-top: 50px;
    padding-top: 80px;
    background: var(--color02);
    position: relative;
}

.footer:after {
    content: var(--bg03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 50%;
}

.footer .footer_reserve {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 0;
    left: 5%;
}

.footer .footer_reserve a {
    width: 142px;
    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;
    font-weight: 800;
    font-size: 13px;
    color: #fff;
    line-height: 1.3;
    text-align: center;
    background: var(--bg06);

    aspect-ratio: 142 / 90;
}

@media (max-width: 599px) {
    .footer {
        padding-top: 50px;
    }

    .footer .footer_reserve {
        margin: 0 auto;
        margin-bottom: 30px;
        -webkit-transform: none;
        transform: none;
        position: relative;
        left: 0;
    }

    .footer .footer_reserve a {
        text-align: center;
    }

    .footer .footer_reserve img {
        width: 120px;
    }
}

.footer_contents {
    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;
}

.footer_contents .footer_left {
    width: 50%;
}

.footer_contents .footer_right {
    width: 40%;
}

.footer_contents .footer_map {
    width: 100%;
    margin-top: 50px;
}

@media (max-width: 1024px) {
    .footer_contents .footer_right {
        width: 48%;
    }
}

@media (max-width: 599px) {
    .footer_contents .footer_left {
        width: 100%;
        margin-bottom: 40px;
    }

    .footer_contents .footer_right {
        width: 100%;
    }
}

.footer_left .list {
    margin-bottom: 20px;
}

.footer_left .logo {
    margin-bottom: 10px;
}

.footer_left .telephone {
    margin-top: 20px;
}

.footer_right .list {
    margin-bottom: 30px;
}

.nav_footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 20px;
    background: #fff;
}

.nav_footer .item {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.nav_footer .item:not(:last-child) {
    margin-right: 30px;
}

.nav_footer .item02 a {
    padding-left: 20px;
    position: relative;
}

.nav_footer .item02 a:before {
    content: "ー";
    position: absolute;
    top: 0px;
    left: 0;
}

.footer_contact a {
    display: block;
    padding: 10px;
    font-size: 16px;
    color: #fff;
    text-align: center;
    border-radius: 5px;
    background: var(--color03);
}

.footer_contact .itemin {
    display: inline-block;
    padding-left: 40px;
    position: relative;
}

.footer_contact .itemin:before {
    content: "\f0e0";
    font-family: "Font Awesome 5 Free";
    font-weight: normal;
    font-size: 30px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 0;
}

.footer_contact.satellite .itemin {
    padding-left: 35px;
}

.footer_contact.satellite .itemin:before {
    content: "";
    background: url(/upload/tenant_2/implant.webp) no-repeat;
    aspect-ratio: 1;
    width: 35px;
    display: block;
    z-index: 2;
    background-size: contain;
}

.footer_map .map {
    min-height: 350px;
}

.copy {
    margin-top: 10px;
    padding: 15px 0;
    text-align: center;
}

@media(max-width:599px){
  .nav_footer{
    padding: 15px 8px;
  }
  .nav_footer .item:not(:last-child){
    margin-right: 5px;
  }
}

/**
ボトムメニュー
bottom
*/
.bottom .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    -webkit-box-align: start;
    align-items: flex-start;
    -ms-flex-align: start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.bottom .section {
    width: 48%;
    margin-bottom: 50px;
    padding-top: 50px;
    padding-left: 80px;
    position: relative;
}

.bottom .circle {
    position: absolute;
    top: 0;
    left: 0;
}

.bottom .list-side01 {
    z-index: 2;
    position: relative;
}

.bottom .circle::before {
    content: "";
    width: 130px;
    display: block;
    background: var(--bg19);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

@media (max-width: 599px) {
    .bottom .section {
        width: 100%;
        padding-top: 40px;
        padding-left: 50px;
    }
}

.list-side01 .datattl {
    margin-bottom: 20px;
    font-weight: bold;
    font-size: 24px;
    border-bottom: 5px solid var(--color03);
}

.list-side01 .data {
    margin-bottom: 5px;
}

.list-side01 a {
    display: block;
    padding-left: 20px;
    font-size: 16px;
    position: relative;
}

.list-side01 a:before {
    content: "";
    width: 6px;
    height: 6px;
    display: block;
    border: 2px solid var(--color03);
    border-radius: 50%;
    position: absolute;
    top: 7px;
    left: 0;
}

.list-side01.-archive {
    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;
    position: relative;
    z-index: 2;
}

.list-side01.-archive .datattl {
    width: 100%;
}

.list-side01.-archive .data {
    width: 48%;
}

[data-element-id] .list-side01.-archive>div {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

/*********************************************
    各個別コンテンツ
*********************************************/
/**
トップページ
*/
/*ヘッダー（トップ）*/
@media (max-width: 1024px) {
    .home .header {
        width: 100%;
        padding: 10px 0px;
        position: absolute;
        z-index: 250;
    }

    .header .logo {
        padding: 0;
    }
}

@media (max-width: 599px) {
    .header .logo img {
        height: 32px;
    }
}

/*メインビジュアル*/
.mainimg {
    overflow: hidden;
    position: relative;
}

.mainimg img {
    width: 100%;
}

.mainimg .uk-slidenav-position {
    height: 100% !important;
    max-height: 800px;
    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対策*/
.homevisual {
    position: relative;
}

.homevisual .img {
    min-height: 400px;
    position: relative;
}

.homevisual .img:before {
    content: "";
    display: block;
    padding-top: 50%;
}

.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 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: "游ゴシック", YuGothic, Hiragino Sans, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    flex-flow: "游ゴシック", YuGothic, Hiragino Sans, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-weight: bold;
    font-size: 38px;
    text-align: center;
    -webkit-transform: translate(-50%, 0%);
    transform: translate(-50%, 0%);
    position: absolute;
    bottom: 15%;
    left: 50%;
}

.homevisual .headin {
    display: inline-block;
    padding: 10px 30px;
    color: var(--color01);
    text-align: left;
    border-radius: 50px;
    background: #fff;
}

.homevisual .headin01 {
    margin-bottom: 20px;
    margin-right: 100px;
}

.homevisual .headin02 {
    margin-left: 100px;
}

[data-element-id] .homevisual .head .show\@sp {
    font-size: 18px;
    line-height: 130%;
    text-align: left;
}

[data-element-id] .homevisual .head .show\@sp .headin01 {
    margin-right: 50px;
}

[data-element-id] .homevisual .head .show\@sp .headin {
    padding: 5px 10px;
}

@media (max-width: 1024px) {
    .homevisual .head {
        font-size: 26px;
        bottom: 5%;
    }

    .homevisual .headin {
        padding: 5px 10px;
    }

    .homevisual .headin01 {
        margin-right: 50px;
    }

    .homevisual .headin02 {
        margin-left: 50px;
    }
}

@media (max-width: 599px) {
    .homevisual .head {
        font-size: 18px;
        line-height: 130%;
        text-align: left;
    }
    .mainimg .uk-slidenav-position:after {
        padding-top: 100%;
    }
}

/*お知らせ（トップ）*/
.home02 .box {
    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;
}

.home02 .show\@pc,
.home02 .show\@sp {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 50px;
}

.home02 .list {
    -webkit-box-flex: 10;
    -ms-flex-positive: 10;
    flex-grow: 10;
}

@media (max-width: 599px) {
    .home02 .box {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .home02 .ttl {
        width: 100%;
        text-align: center;
    }

    .home02 .list {
        width: calc(100% - 80px);
    }

    .home02 .btn {
        width: 80px;
    }
}

/*こんあお悩みありませんか（トップ）*/
.list_home03 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.list_home03 .item {
    width: 16.666%;
    padding: 1%;
}

.list_home03 a {
    height: 100%;
    display: block;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 20px;
    background: var(--color02);
    position: relative;
}

.list_home03 a:after {
    content: "";
    width: 100%;
    height: 100%;
    visibility: hidden;
    border-radius: 20px;
    background: var(--color01);
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    position: absolute;
    top: 0;
    left: 0;
}

.list_home03 .itemin {
    display: block;
    font-weight: bold;
    font-size: 20px;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: tb-rl;
    writing-mode: tb-rl;
    -webkit-transition: 0.5s;
    transition: 0.5s;
}

.list_home03 .itemin01 {
    padding: 30px 10px;
}

.list_home03 .itemin02 {
    visibility: hidden;
    padding: 30px 0;
    color: #fff;
    opacity: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 5;
}

.list_home03 .itemin03 {
    display: block;
}

.list_home03 .item:hover a:hover {
    opacity: 1;
}

.list_home03 .item:hover a:after {
    visibility: visible;
    opacity: 0.9;
}

.list_home03 .item:hover .itemin02 {
    visibility: visible;
    opacity: 1;
}

[data-element-id] .list_home03 .item:hover a:after {
    visibility: hidden;
    opacity: 0;
}

@media (max-width: 599px) {
    .list_home03 {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_home03 .item {
        width: 25%;
        margin-bottom: 5%;
    }

    .list_home03 .itemin {
        font-size: 16px;
    }
}

[data-element-id] .list_home03 .itemin02 {
    visibility: visible;
    color: #fff;
    background: #999;
    opacity: 1;
    -webkit-transform: none;
    transform: none;
    position: relative;
    left: 0;
}

/*診療内容（トップ）*/
.list_home04 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.list_home04 .item {
    padding: 30px 20px;
    background: #fff;
    -webkit-box-shadow: 0 0 5px 0 #d2d2d2;
    box-shadow: 0 0 5px 0 #d2d2d2;
}

.list_home04 .item01 {
    width: calc(33% - 20px);
    margin: 0 auto 5%;
}

.list_home04 .item01 .img {
    margin-bottom: 10px;
}

.list_home04 .item01 .head {
    margin-bottom: 10px;
    text-align: center;
}

.list_home04 .item01 .btn {
    margin-top: 10px;
}

.list_home04 .item01 .btn a {
    margin: 0 auto;
}

.list_home04 .item02 {
    width: calc(100% - 20px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: 0 auto 5%;
}

.list_home04 .item02 .img {
    width: 30%;
}

.list_home04 .item02 .block_txt {
    width: 68%;
    position: relative;
}

.list_home04 .item02 .head {
    margin-bottom: 20px;
    padding-right: 280px;
}

.list_home04 .item02 .btn {
    width: 270px;
    position: absolute;
    top: 0;
    right: 0;
}

.list_home04 .head {
    font-size: 20px;
    color: var(--color01);
}

@media (max-width: 1024px) {
    .list_home04 .item01 {
        width: calc(50% - 20px);
    }

    .list_home04 .item02 {
        width: calc(100% - 20px);
    }

    .list_home04 .item02 .img {
        width: 40%;
    }

    .list_home04 .item02 .block_txt {
        width: 58%;
    }

    .list_home04 .item02 .head {
        padding-right: 0;
    }

    .list_home04 .item02 .btn {
        width: auto;
        margin-top: 10px;
        position: relative;
    }

    .list_home04 .item02 .btn a {
        margin-left: auto;
    }
}

@media (max-width: 599px) {
    .list_home04 .item01 {
        width: 100%;
        max-width: 400px;
    }

    .list_home04 .item02 {
        width: 100%;
        max-width: 400px;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_home04 .item02 .img {
        width: 100%;
        margin-bottom: 10px;
    }

    .list_home04 .item02 .block_txt {
        width: 100%;
    }

    .list_home04 .item02 .head {
        margin-bottom: 10px;
        text-align: center;
    }

    .list_home04 .item02 .btn a {
        margin: 0 auto;
    }
}

/*ごあいさつ（トップ）*/
.home05 .block_img {
    position: relative;
}

.home05 .circle {
    opacity: 0.5;
    -webkit-transform: translate(50%, -30%);
    transform: translate(50%, -30%);
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
}

.home05 .circle::before {
    content: "";
    width: 204px;
    display: block;
    background: var(--bg04);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.home05 .block_txt {
    position: relative;
    z-index: 2;
}

@media (max-width: 1024px) {
    .home05 .circle img {
        height: 150px;
    }
}

@media (max-width: 599px) {
    .home05 .circle {
        -webkit-transform: translate(-20%, 50%);
        transform: translate(-20%, 50%);
        top: inherit;
        bottom: 0;
        left: 0;
        right: inherit;
    }
}

/*ブログ（トップ）*/
.list_home06 .img {
    margin-bottom: 10px;
}

.list_home06 .img a {
    display: block;
}

.list_home06 .time {
    display: block;
    margin-bottom: 10px;
    text-align: center;
}

.list_home06 .timein {
    border-bottom: 2px solid var(--color03);
}

/**
下層ページ共通要素
*/
.lower #main {
    position: relative;
    z-index: 2;
}

/*パンくずリスト*/
.breadcrumb {
    margin-top: 10px;
}

.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;
    color: var(--color01);
}

.breadcrumb .item a {
    font-weight: bold;
    color: var(--color01);
}

.breadcrumb a:hover {
    color: var(--color01);
}

/*下層トップタイトル*/
.top_cmn02 {
    padding: 40px 0 40px;
    position: relative;
}

.top_cmn02 .circle01 {
    position: absolute;
    top: 0px;
    right: -40px;
    z-index: 1;
}

.top_cmn02 .circle01::before {
    content: "";
    width: 299px;
    display: block;
    background: var(--bg07);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.top_cmn02 .circle02 {
    position: absolute;
    top: 100%;
    right: 10%;
}

.top_cmn02 .circle02::before {
    content: "";
    width: 217px;
    display: block;
    background: var(--bg08);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

@media (max-width: 1024px) {
    .top_cmn02 .circle01::before {
        width: 220px;
    }

    .top_cmn02 .circle02::before {
        width: 150px;
    }
}

@media (max-width: 599px) {
    .top_cmn02 {
        padding: 20px 0 20px;
    }

    .top_cmn02 .circle01::before {
        width: 150px;
    }

    .top_cmn02 .circle02::before {
        width: 100px;
    }
}

/**
下層ページ各コンテンツ
*/
/*当院のご案内*/
/*ごあいさつ（トップ）*/
.about02 .block_left,
.about02 .block_right {
    width: 48%;
}

.about02 .logo {
    margin-bottom: 20px;
}

.about02 .telephone {
    margin-top: 20px;
}

.about02 .access {
    margin-bottom: 20px;
}

.about02 .map {
    height: 100%;
    min-height: 300px;
}

@media (max-width: 1024px) {
    .about02 .block_left {
        width: 80%;
        margin: 0 auto 50px;
    }

    .about02 .block_right {
        width: 100%;
    }
}

@media (max-width: 599px) {
    .about02 .block_left {
        width: 100%;
    }
}

/*スタッフ紹介*/
.staff01 .block_img {
    position: relative;
}

.staff01 .circle {
    opacity: 0.5;
    -webkit-transform: translate(50%, 50%);
    transform: translate(50%, 50%);
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
}

.staff01 .circle::before {
    content: "";
    width: 200px;
    display: block;
    background: var(--bg04);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.staff01 .block_txt {
    position: relative;
    z-index: 2;
}

@media (max-width: 1024px) {
    .staff01 .circle img {
        height: 150px;
    }
}

@media (max-width: 599px) {
    .staff01 .circle {
        -webkit-transform: translate(-20%, 50%);
        transform: translate(-20%, 50%);
        top: inherit;
        bottom: 0;
        left: 0;
        right: inherit;
    }
}

.staff02 .ttl {
    padding-top: 35px;
    padding-left: 60px;
    font-weight: bold;
    font-size: 24px;
    border-bottom: 4px solid var(--color03);
    position: relative;
}

.staff02 .ttl:before {
    content: var(--bg03);
    position: absolute;
    top: 0;
    left: 0;
}

@media (max-width: 599px) {
    .staff02 .ttl {
        font-size: 20px;
    }
}

.list_staff02>.item {
    padding: 30px 20px;
    background: #fff;
    -webkit-box-shadow: 0px 0px 5px 0px #b9b9b9;
    box-shadow: 0px 0px 5px 0px #b9b9b9;
    position: relative;
    z-index: 1;
}

.list_staff02>.item:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.list_staff02>.item:before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: var(--bg09) right bottom;
    background-size: 100%;
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: -2;
}

.list_staff02 .head {
    margin-bottom: 30px;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    position: relative;
}

.list_staff02 .head:after {
    content: "";
    width: 100px;
    height: 5px;
    display: block;
    margin: 0 auto;
    background: var(--color03);
}

.list_staff02 .list01 .item {
    margin-bottom: 10px;
}

.list_staff02 .list02 .item {
    margin-bottom: 10px;
}

.list_staff02 .head01 {
    margin-bottom: 5px;
    font-size: 16px;
}

.list_about03a {
    height: 300px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 20px;
    position: relative;
}

.list_about03a .item {
    height: 100%;
}

.list_about03a .item01 {
    width: 30%;
}

.list_about03a .item01 .img {
    height: 100%;
}

.list_about03a .item02 {
    width: 25%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-line-pack: justify;
    align-content: space-between;
}

.list_about03a .item02 .img {
    width: 100%;
    height: 48%;
}

.list_about03a .item03 {
    width: 40%;
}

.list_about03a .item03 .img {
    height: 100%;
}

@media (max-width: 599px) {
    .list_about03a {
        height: 400px;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_about03a .item {
        height: 48%;
    }

    .list_about03a .item01 {
        width: 65%;
        margin-bottom: 20px;
    }

    .list_about03a .item02 {
        width: 30%;
    }

    .list_about03a .item03 {
        width: 100%;
    }
}

.list_about03b {
    height: 300px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
}

.list_about03b .item {
    height: 100%;
}

.list_about03b .item01 {
    width: 68%;
}

.list_about03b .item01 .img {
    height: 100%;
}

.list_about03b .item02 {
    width: 30%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-line-pack: justify;
    align-content: space-between;
}

.list_about03b .item02 .img {
    width: 100%;
    height: 48%;
}

@media (max-width: 599px) {
    .list_about03b {
        height: 200px;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse;
    }

    .list_about03b .item01 {
        width: 55%;
        margin-bottom: 20px;
    }

    .list_about03b .item02 {
        width: 40%;
    }
}

/*ブログ*/
.list_blog01 .item {
    margin-top: 40px;
    position: relative;
}

.list_blog01 .time {
    width: 80px;
    height: 80px;
    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;
    color: #fff;
    line-height: 110%;
    text-align: center;
    border: 3px solid #fff;
    border-radius: 50%;
    background: var(--color03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 1;
}

.list_blog01 .day {
    margin-top: 3px;
    font-size: 20px;
    letter-spacing: 0.1em;
}

.list_blog01 .img {
    margin-bottom: 10px;
}

.list_blog01 .img a {
    display: block;
}

.list_blog01 .head {
    margin-bottom: 10px;
}

.list_blog01 .category {
    color: var(--color01);
}

@media (max-width: 599px) {
    .list_blog01 .item {
        max-width: 350px;
        margin-left: auto;
        margin-right: auto;
    }
}

/*記事詳細（新着情報、ブログ）*/
.article01 .time {
    display: block;
    text-align: center;
}

.article01 .category {
    margin-bottom: 20px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    align-items: flex-start;
}

.article01 .category span {
    padding: 0 10px;
    color: #fff;
    border-radius: 5px;
    background: var(--color03);
}

.article01 .ttl {
    margin-bottom: 50px;
    padding-bottom: 10px;
    font-weight: bold;
    font-size: 16px;
    text-align: center;
    border-bottom: 3px solid var(--color03);
}

.article01 .txt {
    padding: 0 50px;
    font-size: 16px;
}

.article01 .txt h2 {
    margin: 3rem 0 1rem;
    padding: 1rem;
    font-weight: 500;
    font-size: 22px;
    color: #fff;
    line-height: 1.4;
    background-color: var(--color01);
    position: relative;
}

.article01 .txt h3 {
    margin: 3rem 0 1rem;
    padding: 0.6em;
    font-weight: 600;
    font-size: 20px;
    line-height: 1.4;
    border-left: 10px solid var(--color01);
}

.article01 .txt h4 {
    margin: 3rem 0 1rem;
    padding: 0.4em;
    font-weight: 600;
    font-size: 18px;
    border-bottom: 2px solid var(--color01);
}

.article01 .txt ul li {
    padding-left: 1.2em;
    position: relative;
}

.article01 .txt ul li::before {
    content: "■";
    color: var(--color01);
    position: absolute;
    top: 0;
    left: 0;
}

.article01 .txt ol li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    align-items: baseline;
    -ms-flex-align: baseline;
    list-style-type: none;
    counter-increment: cnt;
}

.article01 .txt ol li::before {
    content: ""counter(cnt)".";
    margin-right: 10px;
    font-weight: bold;
    font-size: 150%;
    color: var(--color01);
}

.article01 .txt iframe[src*="youtube"] {
    height: auto;
    margin-top: 1em;
    margin-bottom: 1em;

    aspect-ratio: 16 / 9;
}

.article01 .btn_wrap {
    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;
    margin-top: 80px;
}

@media (max-width: 599px) {
    .article01 .txt {
        padding: 0;
    }
}

/*診療内容*/
.list_service01 .item {
    margin-top: 60px;
    position: relative;
}

.list_service01 .head {
    width: 120px;
    height: 120px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.list_service01 .head 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;
    font-size: 15px;
    line-height: 1.3;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
    position: relative;
}

.list_service01 .head a:before,
.list_service01 .head a:after {
    content: "";
    width: 100%;
    height: 100%;
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
    border-radius: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.list_service01 .head a:before {
    border: 3px solid #fff;
}

.list_service01 .head a:after {
    border: 0 solid transparent;
}

.list_service01 .head a:hover {
    font-weight: bold;
    color: var(--color01);
    background: #fff;
}

.list_service01 .head a:hover:before {
    border-top-color: var(--color01);
    border-bottom-color: var(--color01);
    border-right-color: var(--color01);
    -webkit-transition: border-top-color 0.15s linear, border-right-color 0.15s linear 0.1s, border-bottom-color 0.15s linear 0.2s;
    transition: border-top-color 0.15s linear, border-right-color 0.15s linear 0.1s, border-bottom-color 0.15s linear 0.2s;
}

.list_service01 .head a:hover:after {
    border-top: 3px solid var(--color01);
    border-left-width: 3px;
    border-right-width: 3px;
    -webkit-transition: border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    transition: border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    transition: transform 0.4s linear 0s, border-left-width 0s linear 0.35s;
    transition: transform 0.4s linear 0s, border-left-width 0s linear 0.35s, -webkit-transform 0.4s linear 0s;
    -webkit-transform: rotate(270deg);
    transform: rotate(270deg);
}

.list_service01 .img a {
    display: block;
}

@media (max-width: 599px) {
    .list_service01 .item {
        max-width: 350px;
        margin-left: auto;
        margin-right: auto;
    }

    .list_service01 .head {
        width: 115px;
        height: 115px;
    }

    .list_service01 .head a {
        font-size: 14px;
    }
}

/*一般歯科*/
.ippan05 {
    position: relative;
    z-index: 1;
}

.ippan05 .circle_wrap {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.ippan05 .dot01 {
    position: absolute;
    top: -50px;
    right: -50px;
    z-index: 1;
}

.ippan05 .dot01::before {
    content: "";
    width: 299px;
    display: block;
    background: var(--bg07);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .dot02 {
    position: absolute;
    top: 40px;
    left: 10%;
}

.ippan05 .dot02::before {
    content: "";
    width: 194px;
    display: block;
    background: var(--bg13);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .dot03 {
    position: absolute;
    top: 240px;
    left: 4%;
}

.ippan05 .dot03::before {
    content: "";
    width: 92px;
    display: block;
    background: var(--bg14);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .circle01 {
    position: absolute;
    top: 100px;
    right: 10%;
}

.ippan05 .circle01::before {
    content: "";
    width: 217px;
    display: block;
    background: var(--bg08);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .circle02 {
    position: absolute;
    top: 300px;
    right: 3%;
}

.ippan05 .circle02::before {
    content: "";
    width: 118px;
    display: block;
    background: var(--bg08);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .circle03 {
    position: absolute;
    top: -50px;
    left: 0;
}

.ippan05 .circle03::before {
    content: "";
    width: 159px;
    display: block;
    background: var(--bg08);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

.ippan05 .circle04 {
    position: absolute;
    top: 290px;
    left: 15%;
}

.ippan05 .circle04::before {
    content: "";
    width: 118px;
    display: block;
    background: var(--bg08);
    background-size: contain;
    background-repeat: no-repeat;

    aspect-ratio: 1/1;
}

@media (max-width: 1024px) {
    .ippan05 .dot01::before {
        width: 230px;
    }

    .ippan05 .dot02::before {
        width: 150px;
    }

    .ippan05 .dot03 {
        top: 180px;
    }

    .ippan05 .dot03::before {
        width: 50px;
    }

    .ippan05 .circle01::before {
        width: 140px;
    }

    .ippan05 .circle02 {
        top: 250px;
    }

    .ippan05 .circle02::before {
        width: 80px;
    }

    .ippan05 .circle03::before {
        width: 100px;
    }

    .ippan05 .circle04 {
        top: 230px;
    }

    .ippan05 .circle04::before {
        width: 60px;
    }
}

@media (max-width: 1024px) and (max-width: 599px) {
    .ippan05 .dot01::before {
        width: 150px;
    }

    .ippan05 .dot02 {
        top: 0px;
    }

    .ippan05 .dot02::before {
        width: 100px;
    }

    .ippan05 .dot03 {
        top: 100px;
    }

    .ippan05 .circle01 {
        top: 30px;
    }

    .ippan05 .circle01::before {
        width: 100px;
    }

    .ippan05 .circle02 {
        top: 140px;
    }

    .ippan05 .circle02::before {
        width: 40px;
    }

    .ippan05 .circle03::before {
        width: 70px;
    }

    .ippan05 .circle04 {
        top: 130px;
    }

    .ippan05 .circle04::before {
        width: 40px;
    }
}

/*小児歯科*/
.child02 .block_txt {
    padding: 20px;
    background: var(--bg15);
}

.child02 .block_txt .cap {
    font-weight: bold;
}

.list_child02a {
    counter-reset: item;
}

.list_child02a .item {
    margin-bottom: 20px;
    padding-top: 2px;
    padding-left: 40px;
    position: relative;
}

.list_child02a .item:before {
    content: counter(item);
    width: 30px;
    height: 30px;
    counter-increment: item;
    color: #fff;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
    position: absolute;
    top: 0;
    left: 0;
}

.child03 .list .img div {
    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;
}

/*義歯*/
.list_gishi03 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    counter-reset: item;
}

.list_gishi03 .item {
    width: 25%;
    padding: 30px 10px 30px 50px;
    background: #fff;
    -webkit-box-shadow: 0 0 3px 0 #ccc;
    box-shadow: 0 0 3px 0 #ccc;
    position: relative;
}

.list_gishi03 .item:after {
    content: counter(item);
    width: 40px;
    height: 40px;
    display: block;
    counter-increment: item;
    font-size: 22px;
    color: #fff;
    line-height: 40px;
    text-align: center;
    border: 3px solid #fff;
    border-radius: 50%;
    background: var(--color03);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 0;
    left: 20px;
}

.list_gishi03 .item:before {
    content: "";
    width: 50px;
    height: 100%;
    display: block;
    background: url('/import/tenant_2/soh-shika.a-bisu.jp/images/13gishi/deco03.webp') no-repeat right center;
    background-size: 120%;
    position: absolute;
    top: 0;
    left: -5px;
}

.list_gishi03 .item:first-child:before {
    content: none;
}

.list_gishi03 .img {
    margin-bottom: 10px;
}

.list_gishi03 .imgin {
    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;
}

.list_gishi03 .txt {
    line-height: 150%;
}

@media (max-width: 1024px) {
    .list_gishi03 {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_gishi03 .item {
        width: 50%;
        padding-bottom: 40px;
    }

    .list_gishi03 .item:after {
        -webkit-transform: none;
        transform: none;
        top: 5px;
    }

    .list_gishi03 .item:nth-child(3):before {
        content: none;
    }
}

@media (max-width: 599px) {
    .list_gishi03 .item {
        width: 100%;
        padding: 40px 20px;
    }

    .list_gishi03 .item:before {
        content: none;
    }
}

/*ブリッジ*/
.bridge04 .txt01 {
    margin-bottom: -50px;
    text-align: center;
}

.bridge04 .txt01 .txtin {
    margin-right: 400px;
}

.bridge04 .ttl {
    width: 200px;
    min-width: 220px;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 1024px) {
    .bridge04 .txt01 {
        margin-bottom: 0;
        text-align: left;
    }

    .bridge04 .txt01 .txtin {
        margin-left: 10%;
        margin-right: 0;
    }

    .bridge04 .ttl {
        width: auto;
    }
}

@media (max-width: 599px) {
    .bridge04 .txt01 .txtin {
        margin-left: 0;
    }
}

/*定期健診*/
.check02 .txt01 {
    text-align: center;
}

.check02 .txt01 .txtin {
    margin-right: 400px;
}

.check02 .ttl {
    width: 200px;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 1024px) {
    .check02 .txt01 {
        margin-bottom: 0;
        text-align: left;
    }

    .check02 .txt01 .txtin {
        margin-left: 10%;
        margin-right: 0;
    }

    .check02 .ttl {
        width: auto;
    }
}

@media (max-width: 599px) {
    .check02 .txt01 .txtin {
        margin-left: 0;
    }
}

/*求人情報*/
.recruit02 .ttl {
    width: 140px;
    height: 140px;
    margin-bottom: -70px;
    margin-left: 5%;
    font-size: 24px;
    line-height: 140px;
    text-align: center;
    border-radius: 50%;
    background: var(--color03);
    position: relative;
    z-index: 1;
}

.recruit02 .box {
    padding: 100px;
    border: 4px solid #ede9ea;
}

@media (max-width: 1024px) {
    .recruit02 .box {
        padding: 100px 50px 50px;
    }
}

@media (max-width: 599px) {
    .recruit02 .box {
        padding: 100px 10px 30px;
    }
}

.list_recruit02 .item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 10px;
    border-bottom: 2px solid #ede9ea;
}

.list_recruit02 .datattl,
.list_recruit02 .data {
    width: 100%;
    font-size: 16px;
}

.list_recruit02 .datattl {
    width: 200px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.list_recruit02 .item .data>.item:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.list_recruit02 .data>.item .datattl {
    width: 120px;
}

@media (max-width: 1024px) {
    .list_recruit02 .datattl {
        width: 150px;
    }
}

@media (max-width: 599px) {
    .list_recruit02 .item {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list_recruit02 .datattl,
    .list_recruit02 .data {
        width: 100%;
    }

    .list_recruit02 .datattl {
        margin-bottom: 10px;
        font-weight: bold;
    }
}

/*お問い合わせ*/
.contact01 .txt01 {
    margin-bottom: -15px;
    position: relative;
    z-index: 1;
}

.contact01 .box {
    padding: 30px 100px 50px;
    border: 4px solid #ede9ea;
}

.add-txt {
    margin-bottom: 50px;
    font-weight: 500;
    text-align: center;
}

.add-txt .red {
    color: red;
}

@media (max-width: 1024px) {
    .contact01 .box {
        padding: 30px 50px 50px;
    }
}

@media (max-width: 599px) {
    .contact01 .box {
        padding: 30px 10px 50px;
    }
}

/*フォトギャラリー*/
.list_photo01 .item {
    margin-top: 40px;
    position: relative;
}

.list_photo01 .time {
    width: 80px;
    height: 80px;
    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;
    color: #fff;
    line-height: 110%;
    text-align: center;
    border: 3px solid #fff;
    border-radius: 50%;
    background: var(--color03);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 1;
}

.list_photo01 .day {
    margin-top: 3px;
    font-size: 20px;
    letter-spacing: 0.1em;
}

.list_photo01 .img {
    margin-bottom: 10px;
    cursor: pointer;
    position: relative;
}

.list_photo01 .img:after {
    content: url('/import/tenant_2/soh-shika.a-bisu.jp/images/18photo/icon.webp');
    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;
    visibility: hidden;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    pointer-events: none;
    position: absolute;
    top: 50%;
    left: 50%;
}

.list_photo01 .img:hover:after {
    visibility: visible;
    opacity: 1;
}

.list_photo01 .head {
    margin-bottom: 10px;
}

.list_photo01 .category {
    color: var(--color01);
}

@media (max-width: 599px) {
    .list_photo01 .item {
        max-width: 350px;
        margin-left: auto;
        margin-right: auto;
    }
}

.dot-list li {
    padding-left: 15px;
    position: relative;
}

.dot-list li::after {
    content: "";
    width: 10px;
    border-radius: 50%;
    background: #000;
    position: absolute;
    top: 5px;
    left: 0;

    aspect-ratio: 1;
}


/*ライトボックス設定*/
.uk-open .uk-modal-dialog-lightbox {
    width: calc(100% - 50px) !important;
    height: calc(100% - 50px) !important;
    top: 10px !important;
}

.uk-lightbox-content {
    width: 100%;
    height: 100%;
}

.uk-lightbox-content img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;

/*IE対策*/
    font-family: "object-fit: contain; object-position: 50% 50%;";
}
