@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300;400;500&family=Lobster&family=Noto+Sans+JP:wght@300;400;500;700&family=Playball&display=swap');

html {
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 1.2px;
  line-height: 1.5;
  font-weight: 500;
}

/*===================================
  基本設定
===================================*/
.color01 {
  color: #284b8f;
}

.color02 {
  color: #95b6c9;
}

.color03 {
  color: #45464a;
}

.color04 {
  color: #e4ab76;
}

.color05 {
  color: #4167a8;
}

.color06{
  color: #ff6b3c;
}

.bgcolor01 {
  background-color: #4a6aa3;
}

.bgcolor02 {
  background-color: #e1ebf4;
}

.bgcolor03 {
  background-color: #f8f9fd;
}

.bgcolor04 {
  background-color: #84b5d3;
}

.bgcolor05 {
  background-color: #e89644;
}

.bgcolor06 {
  background-color: #3f619e;
}

/*bgc-box*/
.bgwhite-box {
  background-color: #fff;
  border-radius: 50px;
  margin: 50px 30px;
  padding: 30px;
}

.bgwhite-box02 {
  background-color: #fff;
  border-radius: 10px;
  padding: 30px;
  border: 2px solid #aac5d8;
}

@media (max-width:599px) {
  .bgwhite-box {
    border-radius: 30px;
    margin: 10px 5px;
    padding: 20px 15px 20px;
  }
}

/* 共通フォント */
.font01 {
  font-family: 'Lobster',
    cursive;
}

.font02 {
  font-family: 'Kiwi Maru',
    serif;
}

/* 共通タイトル */

.title01 {
  font-family: 'Playball',
    cursive;
  font-size: 50px;
}

.title02 {
  font-size: 24px;
  color: #255095;
  font-weight: 500;
  border-bottom: 4px solid #aac5d8;
  width: fit-content;
  padding-bottom: 2px;
}

.title02.min{
  font-size: 20px;
}

.title02.other {
  color: #fff;
  border-bottom: 4px solid #c1e2f7;
}

.title03 {
  display: flex;
  flex-direction: column;
  width: fit-content;
  margin: 0 auto;
}

.title03 .en {
  font-family: 'Playball',
    cursive;
  font-size: 50px;
  margin-left: -50px;
}

.title03 .ja {
  font-family: 'Kiwi Maru', serif;
  border-bottom: 4px solid #aac5d8;
  width: fit-content;
  padding-bottom: 2px;
  color: #355f99;
  font-size: 28px;
  margin: 0 auto;
  text-align: center;
}

.title03 .ja02 {
  border-bottom: 4px solid #e4ab76;
}

.title03 .ja03 {
  color: #fff;
}

.title03 .ja04 {
  border-bottom: 4px solid #ffffff;
  color: #fff;
}

.title04 {
  font-size: 18px;
  color: #355f99;
  display: flex;
  font-family: 'Kiwi Maru', serif;
  font-weight: 500;
}

.title04::before {
  content: "●";
}

.title05 {
  font-size: 26px;
  font-family: 'Kiwi Maru', serif;
  color: #fff;
  background: #85b5d3;
  padding: 0.3em 1em;
  width: 100%;
  text-align: center;
  margin-bottom: 30px;
  border-radius: 5px;
}

@media (max-width:1024px) {
  .title01 {
    font-size: 36px;
  }

  .title03 .en {
    font-family: 'Playball',
      cursive;
    font-size: 36px;
  }

  .title03 .ja {
    font-size: 24px;
  }
}

@media (max-width:599px) {
  .title02 {
    font-size: 20px;
  }
  
  .title02.min{
  font-size: 18px;
}

  .title03 {
    text-align: center;
  }

  .title03 .en {
    margin: 0px;
  }

  .title03 .ja {
    font-size: 22px;
  }

  .title03 .ja.min {
    font-size: 20px;
  }
}

/* border-radius */
.br30 {
  border-radius: 30px;
  overflow: hidden;
}

/* box-shadow */
.b-shadow01>*>* {
  box-shadow: 4px 2px 10px #d5d5d5;
}

/* 共通背景画像 */
.common-bgi01 {
  background-color: #eff1f7;
  background-image: url('/upload/tenant_1/bgc01_1.webp');
  background-size: cover;
  background-repeat: no-repeat;
}

.common-bgi02 {
  background-color: #f5f9fa;
  background-image: url('/upload/tenant_1/bgc04_1.webp');
  background-size: cover;
  background-repeat: no-repeat;
}

.common-bgi03 {
    background-color: #d6e9f2;
    background-image: url(/upload/tenant_1/bgc02.webp);
    background-size: contain;
    background-repeat: no-repeat;
}

.common-bgi04 {
  background-color: #3e629f;
  background-position: top right;
background-size: 100% auto;
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/bgc03.webp');
  background-repeat: no-repeat;
  overflow: hidden;
}

.common-bgi05 {
  background-color: #84b5d3;
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/bgc06.webp');
  background-size: cover;
  background-repeat: no-repeat;
  overflow: hidden;
}

.common-bgi07 {
  background-color: #84b5d3;
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/bgc07.webp');
  background-size: cover;
  background-repeat: no-repeat;
  overflow: hidden;
}


@media (max-width:599px) {

  .common-bgi01,
  .common-bgi02,
  .common-bgi03,
  .common-bgi04,
  .common-bgi05 {
    background-size: contain;
  }
}

/* 画像切り抜き */
.img-left {
  border-radius: 0 50px 0 0;
  overflow: hidden;
}

.img-right {
  border-radius: 50px 0 0 0;
  overflow: hidden;
}


/* 共通コンテンツ間隔 */

[class*="section-m"],
[class*="section-p"] {
  --section-xlarge: 100px;
  --section-large: 80px;
  --section-medium: 60px;
  --section-small: 50px;
  --section-xsmall: 30px;
}

.section-my-xlarge {
  margin-top: var(--section-xlarge);
  margin-bottom: var(--section-xlarge);
}

.section-mt-xlarge {
  margin-top: var(--section-xlarge);
}

.section-mb-xlarge {
  margin-bottom: var(--section-xlarge);
}

.section-my-large {
  margin-top: var(--section-large);
  margin-bottom: var(--section-large);
}

.section-mt-large {
  margin-top: var(--section-large);
}

.section-mb-large {
  margin-bottom: var(--section-large);
}

.section-my-medium {
  margin-top: var(--section-medium);
  margin-bottom: var(--section-medium);
}

.section-mt-medium {
  margin-top: var(--section-medium);
}

.section-mb-medium {
  margin-bottom: var(--section-medium);
}

.section-my-small {
  margin-top: var(--section-small);
  margin-bottom: var(--section-small);
}

.section-mt-small {
  margin-top: var(--section-small);
}

.section-mb-small {
  margin-bottom: var(--section-small);
}

.section-my-xsmall {
  margin-top: var(--section-xsmall);
  margin-bottom: var(--section-xsmall);
}

.section-mt-xsmall {
  margin-top: var(--section-xsmall);
}

.section-mb-xsmall {
  margin-bottom: var(--section-xsmall);
}

@media (max-width: 1024px) {
  .section-my-xlarge {
    margin-top: calc(var(--section-xlarge) * 0.8);
    margin-bottom: calc(var(--section-xlarge) * 0.8);
  }

  .section-mt-xlarge {
    margin-top: calc(var(--section-xlarge) * 0.8);
  }

  .section-mb-xlarge {
    margin-bottom: calc(var(--section-xlarge) * 0.8);
  }

  .section-my-large {
    margin-top: calc(var(--section-large) * 0.8);
    margin-bottom: calc(var(--section-large) * 0.8);
  }

  .section-mt-large {
    margin-top: calc(var(--section-large) * 0.8);
  }

  .section-mb-large {
    margin-bottom: calc(var(--section-large) * 0.8);
  }

  .section-my-medium {
    margin-top: calc(var(--section-medium) * 0.8);
    margin-bottom: calc(var(--section-medium) * 0.8);
  }

  .section-mt-medium {
    margin-top: calc(var(--section-medium) * 0.8);
  }

  .section-mb-medium {
    margin-bottom: calc(var(--section-medium) * 0.8);
  }

  .section-my-small {
    margin-top: calc(var(--section-small) * 0.8);
    margin-bottom: calc(var(--section-small) * 0.8);
  }

  .section-mt-small {
    margin-top: calc(var(--section-small) * 0.8);
  }

  .section-mb-small {
    margin-bottom: calc(var(--section-small) * 0.8);
  }

  .section-my-xsmall {
    margin-top: calc(var(--section-xsmall) * 0.8);
    margin-bottom: calc(var(--section-xsmall) * 0.8);
  }

  .section-mt-xsmall {
    margin-top: calc(var(--section-xsmall) * 0.8);
  }

  .section-mb-xsmall {
    margin-bottom: calc(var(--section-xsmall) * 0.8);
  }
}

@media (max-width: 599px) {
  .section-my-xlarge {
    margin-top: calc(var(--section-xlarge) * 0.6);
    margin-bottom: calc(var(--section-xlarge) * 0.6);
  }

  .section-mt-xlarge {
    margin-top: calc(var(--section-xlarge) * 0.6);
  }

  .section-mb-xlarge {
    margin-bottom: calc(var(--section-xlarge) * 0.6);
  }

  .section-my-large {
    margin-top: calc(var(--section-large) * 0.6);
    margin-bottom: calc(var(--section-large) * 0.6);
  }

  .section-mt-large {
    margin-top: calc(var(--section-large) * 0.6);
  }

  .section-mb-large {
    margin-bottom: calc(var(--section-large) * 0.6);
  }

  .section-my-medium {
    margin-top: calc(var(--section-medium) * 0.6);
    margin-bottom: calc(var(--section-medium) * 0.6);
  }

  .section-mt-medium {
    margin-top: calc(var(--section-medium) * 0.6);
  }

  .section-mb-medium {
    margin-bottom: calc(var(--section-medium) * 0.6);
  }

  .section-my-small {
    margin-top: calc(var(--section-small) * 0.6);
    margin-bottom: calc(var(--section-small) * 0.6);
  }

  .section-mt-small {
    margin-top: calc(var(--section-small) * 0.6);
  }

  .section-mb-small {
    margin-bottom: calc(var(--section-small) * 0.6);
  }

  .section-my-xsmall {
    margin-top: calc(var(--section-xsmall) * 0.6);
    margin-bottom: calc(var(--section-xsmall) * 0.6);
  }

  .section-mt-xsmall {
    margin-top: calc(var(--section-xsmall) * 0.6);
  }

  .section-mb-xsmall {
    margin-bottom: calc(var(--section-xsmall) * 0.6);
  }
}

.section-py-xlarge {
  padding-top: var(--section-xlarge);
  padding-bottom: var(--section-xlarge);
}

.section-pt-xlarge {
  padding-top: var(--section-xlarge);
}

.section-pb-xlarge {
  padding-bottom: var(--section-xlarge);
}

.section-py-large {
  padding-top: var(--section-large);
  padding-bottom: var(--section-large);
}

.section-pt-large {
  padding-top: var(--section-large);
}

.section-pb-large {
  padding-bottom: var(--section-large);
}

.section-py-medium {
  padding-top: var(--section-medium);
  padding-bottom: var(--section-medium);
}

.section-pt-medium {
  padding-top: var(--section-medium);
}

.section-pb-medium {
  padding-bottom: var(--section-medium);
}

.section-py-small {
  padding-top: var(--section-small);
  padding-bottom: var(--section-small);
}

.section-pt-small {
  padding-top: var(--section-small);
}

.section-pb-small {
  padding-bottom: var(--section-small);
}

.section-py-xsmall {
  padding-top: var(--section-xsmall);
  padding-bottom: var(--section-xsmall);
}

.section-pt-xsmall {
  padding-top: var(--section-xsmall);
}

.section-pb-xsmall {
  padding-bottom: var(--section-xsmall);
}

@media (max-width: 1024px) {
  .section-py-xlarge {
    padding-top: calc(var(--section-xlarge) * 0.8);
    padding-bottom: calc(var(--section-xlarge) * 0.8);
  }

  .section-pt-xlarge {
    padding-top: calc(var(--section-xlarge) * 0.8);
  }

  .section-pb-xlarge {
    padding-bottom: calc(var(--section-xlarge) * 0.8);
  }

  .section-py-large {
    padding-top: calc(var(--section-large) * 0.8);
    padding-bottom: calc(var(--section-large) * 0.8);
  }

  .section-pt-large {
    padding-top: calc(var(--section-large) * 0.8);
  }

  .section-pb-large {
    padding-bottom: calc(var(--section-large) * 0.8);
  }

  .section-py-medium {
    padding-top: calc(var(--section-medium) * 0.8);
    padding-bottom: calc(var(--section-medium) * 0.8);
  }

  .section-pt-medium {
    padding-top: calc(var(--section-medium) * 0.8);
  }

  .section-pb-medium {
    padding-bottom: calc(var(--section-medium) * 0.8);
  }

  .section-py-small {
    padding-top: calc(var(--section-small) * 0.8);
    padding-bottom: calc(var(--section-small) * 0.8);
  }

  .section-pt-small {
    padding-top: calc(var(--section-small) * 0.8);
  }

  .section-pb-small {
    padding-bottom: calc(var(--section-small) * 0.8);
  }

  .section-py-xsmall {
    padding-top: calc(var(--section-xsmall) * 0.8);
    padding-bottom: calc(var(--section-xsmall) * 0.8);
  }

  .section-pt-xsmall {
    padding-top: calc(var(--section-xsmall) * 0.8);
  }

  .section-pb-xsmall {
    padding-bottom: calc(var(--section-xsmall) * 0.8);
  }
}

@media (max-width: 599px) {
  .section-py-xlarge {
    padding-top: calc(var(--section-xlarge) * 0.6);
    padding-bottom: calc(var(--section-xlarge) * 0.6);
  }

  .section-pt-xlarge {
    padding-top: calc(var(--section-xlarge) * 0.6);
  }

  .section-pb-xlarge {
    padding-bottom: calc(var(--section-xlarge) * 0.6);
  }

  .section-py-large {
    padding-top: calc(var(--section-large) * 0.6);
    padding-bottom: calc(var(--section-large) * 0.6);
  }

  .section-pt-large {
    padding-top: calc(var(--section-large) * 0.6);
  }

  .section-pb-large {
    padding-bottom: calc(var(--section-large) * 0.6);
  }

  .section-py-medium {
    padding-top: calc(var(--section-medium) * 0.6);
    padding-bottom: calc(var(--section-medium) * 0.6);
  }

  .section-pt-medium {
    padding-top: calc(var(--section-medium) * 0.6);
  }

  .section-pb-medium {
    padding-bottom: calc(var(--section-medium) * 0.6);
  }

  .section-py-small {
    padding-top: calc(var(--section-small) * 0.6);
    padding-bottom: calc(var(--section-small) * 0.6);
  }

  .section-pt-small {
    padding-top: calc(var(--section-small) * 0.6);
  }

  .section-pb-small {
    padding-bottom: calc(var(--section-small) * 0.6);
  }

  .section-py-xsmall {
    padding-top: calc(var(--section-xsmall) * 0.6);
    padding-bottom: calc(var(--section-xsmall) * 0.6);
  }

  .section-pt-xsmall {
    padding-top: calc(var(--section-xsmall) * 0.6);
  }

  .section-pb-xsmall {
    padding-bottom: calc(var(--section-xsmall) * 0.6);
  }
}

/* fead */

.fead-mv.mv {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.fead-up.mv {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

.fead-order>* {
  opacity: 0;
}

.fead-order>.mv {
  opacity: 1;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.fead-text>* {
  opacity: 0;
}

.fead-text .mv {
  opacity: 1;
  -webkit-transition: 1s;
  transition: 1s;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

/* show hide */

.show\@pc {
  display: block;
}

.hide\@pc {
  display: none;
}

[data-element-id] .show\@tb {
    display: block;
    border: solid 4px #51ab51 !important;
    position: relative;
    background: #fff;
    z-index: 200;
}

[data-element-id] .show\@tb:after {
  display: block;
  content: "モバイル用";
  color: #fff;
  font-weight: 700;
  background: #51ab51 !important;
  padding: 5px;
  text-align: center;
  font-family: 'Kiwi Maru', serif;
  text-shadow: none;
}

[data-element-id] .show\@tb.indention:after {
  content: "モバイル用はここで改行";
  padding:0;
  font-family: 'Kiwi Maru', serif;
}

[data-element-id] .show\@pc.indention:after {
  content: "PC用はここで改行";
  display: block;
  color: #fff;
  font-weight: 700;
  background: #ff774c;
  padding: 5px;
  text-align: center;
  text-shadow: none;
  font-size: 12px;
  font-family: 'Kiwi Maru', serif;
}

[data-element-id] .show\@sp {
  display: block;
  border: solid 4px #51ab51 !important;
  position: relative;
}

[data-element-id] .show\@sp:after {
  display: block;
  content: "モバイル用";
  color: #fff;
  font-weight: 700;
  background: #51ab51 !important;
  padding: 5px;
  text-align: center;
  text-shadow: none;
}

[data-element-id] .show\@sp.indention:after {
  content: "モバイル用はここで改行";
  padding:0;
}

@media (max-width: 1024px) {
  .show\@tb {
    display: block;
  }

  .hide\@tb {
    display: none;
  }
}

@media (max-width: 599px) {
  .show\@sp {
    display: block;
  }

  .hide\@sp {
    display: none;
  }
}

/* ##### フロート float ##### */
.up-fl-left {
  float: left;
}

.up-fl-right {
  float: right;
}

.up-fl-none {
  float: none;
}

.up-flc-left {
  clear: left;
}

.up-flc-rigjt {
  clear: right;
}

.up-flc-both {
  clear: both;
}

.float-box {
  display: block;
}

.float-box-img {
  float: right;
}

.float-box-title {
  float: left;
}

.float-box-content {
  float: left;
}

.float-box-wrap.-noinner .float-box:nth-child(odd) .noinner {
  margin-left: auto;
}

.float-box-wrap.-noinner .float-box:nth-child(odd) [class*=btn] {
  margin-right: 0;
}

.float-box-wrap.-noinner .float-box:nth-child(even) .noinner {
  margin-right: auto;
}

.float-box-wrap.-noinner .float-box:nth-child(even) [class*=btn] {
  margin-left: 0;
}

.float-box-wrap.-rowr .float-box:nth-of-type(odd) .float-box-img {
  float: left;
}

.float-box-wrap.-rowr .float-box:nth-of-type(odd) .float-box-title {
  float: right;
}

.float-box-wrap.-rowr .float-box:nth-of-type(odd) .float-box-content {
  float: right;
}

.float-box-wrap.-rowr .float-box:nth-of-type(even) .float-box-img {
  float: left;
}

.float-box-wrap.-rowr .float-box:nth-of-type(even) .float-box-title {
  float: right;
}

.float-box-wrap.-rowr .float-box:nth-of-type(even) .float-box-content {
  float: right;
}

.float-box-wrap.-rowr.-noinner .float-box:nth-child(odd) .noinner {
  margin-left: 0;
  margin-right: auto;
}

.float-box-wrap.-rowr.-noinner .float-box:nth-child(odd) [class*=btn] {
  margin-left: 0;
  margin-right: 0;
}

.float-box-wrap.-rowr.-noinner .float-box:nth-child(even) .noinner {
  margin-left: auto;
  margin-right: 0;
}

.float-box-wrap.-rowr.-noinner .float-box:nth-child(even) [class*=btn] {
  margin-left: 0;
  margin-right: 0;
}

.float-box-wrap.-alternate .float-box:nth-of-type(odd) .float-box-img {
  float: right;
}

.float-box-wrap.-alternate .float-box:nth-of-type(odd) .float-box-title {
  float: left;
}

.float-box-wrap.-alternate .float-box:nth-of-type(odd) .float-box-content {
  float: left;
}

.float-box-wrap.-alternate .float-box:nth-of-type(even) .float-box-img {
  float: left;
}

.float-box-wrap.-alternate .float-box:nth-of-type(even) .float-box-title {
  float: right;
}

.float-box-wrap.-alternate .float-box:nth-of-type(even) .float-box-content {
  float: right;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(odd) .float-box-img {
  float: left;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(odd) .float-box-title {
  float: right;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(odd) .float-box-content {
  float: right;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(even) .float-box-img {
  float: right;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(even) .float-box-title {
  float: left;
}

.float-box-wrap.-alternate.-rowr .float-box:nth-of-type(even) .float-box-content {
  float: left;
}

@media (max-width: 1024px) {
  .up-fl-left\@tb {
    float: left;
  }

  .up-fl-right\@tb {
    float: right;
  }

  .up-fl-none\@tb {
    float: none;
  }

  .up-flc-left\@tb {
    clear: left;
  }

  .up-flc-rigjt\@tb {
    clear: right;
  }

  .up-flc-both\@tb {
    clear: both;
  }
}

@media (max-width: 599px) {
  .up-fl-left\@sp {
    float: left;
  }

  .up-fl-right\@sp {
    float: right;
  }

  .up-fl-none\@sp {
    float: none;
  }

  .up-flc-left\@sp {
    clear: left;
  }

  .up-flc-rigjt\@sp {
    clear: right;
  }

  .up-flc-both\@sp {
    clear: both;
  }

  .float-box-wrap.-alternate.-rowr .float-box:nth-of-type(odd) .float-box-title {
    float: right;
    width: 100%;
  }
}

/*===================================
  共通ブロック　block-cmn
==================================*/
/* 共通ブロック１ */
/*===================================
  共通タイトル　ttl-cmn
===================================*/
/* 共通タイトル１ */
.ttl-cmn01 {
  text-align: center;
  font-size: 28px;
}

@media only screen and (max-width: 599px) {
  .ttl-cmn01 {
    font-size: 24px;
  }
}

/*===================================
  共通リスト　list-cmn
==================================*/
/* 共通リスト１ */
/*===================================
  共通ボタン btn-cmn
===================================*/
/* 共通ボタン１ */
.btn01 a {
  width: 220px;
  display: block;
  padding: 15px 20px;
  background: #3f629e;
  border-radius: 10px;
  font-size: 14px;
  color: #fff;
  text-align: center;
  position: relative;
}

.btn01 a:hover {
  box-shadow: 0 5px 5px rgb(179 179 179);
  background: #fff;
  color: #3f629e;
  opacity: 1;
}

.btn01.other a {
  background: #e89644;
}

.btn01.other a:hover {
  box-shadow: 0 5px 5px rgb(179 179 179);
  background: #fff;
  color: #e89644;
  opacity: 1;
}

.btn01 a:after {
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  content: "\f054";
  font-size: 12px;
  font-weight: 600;
  font-family: 'Font Awesome 5 Free';
  width: 27px;
  height: 27px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color: #3f629e;
  border-radius: 50%;
}

.btn01.other a:after {
  color: #e89644;
}

.btn01.btn-back a:after {
  content: "\f053";
  right: inherit;
  left: 15px;
}

.btn02>* {
  width: 280px;
  display: flex;
  padding: 15px 20px;
  background: #e89644;
  border-radius: 10px;
  font-size: 14px;
  color: #fff;
  text-align: center;
  position: relative;
  justify-content: space-between;
  align-items: center;
}

.btn02 .duck-pc img {
  width: 45px;
  margin-right: 10px;
}

.btn02>* .right {
  font-size: 12px;
  font-weight: 600;
  font-family: 'Font Awesome 5 Free';
  width: 27px;
  height: 27px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color: #e89644;
  border-radius: 50%;
}

.btn02 a:hover {
  box-shadow: 0 5px 5px rgb(179 179 179);
  color: #fff;
  background: #e7b685;
  opacity: 1;
}

.btn02 a:hover .right {
  background: none;
  color: #fff;
}

/*===================================
  他共通エレメント -cmn
===================================*/
/*===================================
  共通要素
===================================*/
/*h1ページタイトル */
.pagettl {
  font-size: 12px;
  padding: 5px 0;
      font-family: 'Kiwi Maru', serif;
}

@media (max-width:1024px) {
  .pagettl {
    padding: 5px 30px 5px 0;
  }
}

/**
ヘッダー
header
*/
.header {
  width: 90%;
  background: #fff;
  border-radius: 0 0 30px 30px;
  position: fixed;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0%);
  z-index: 100;
  opacity: 1;
}

.header .header-tel {
    margin-left: 70px;
    margin-top: -20px;
    font-size: 22px;
    font-weight: 700;
    display: flex;
    align-items: baseline;
    flex-direction: column;
}

.header .header-tel a::before {
  content: "\f879";
  font-family: "Font Awesome 5 Free";
  font-size: 80%;
  line-height: 1;
  margin-right: 5px;
}

.header .logo .logo-img img {
  max-height: 60px;
}

.header .logo .logo-tit img {
  max-height: 40px;
  margin-left: 10px;
}

[data-element-id].header{
  position: relative;
}

.fix-bottom{
  font-family: 'Kiwi Maru', serif;
}

.fix-bottom .contact>* {
    width: 100%;
    font-family: 'Kiwi Maru', serif;
    background: #30498c;
    display: block;
    text-align: center;
    writing-mode: vertical-rl;
    text-orientation: upright;
    color: #fff;
    padding: 20px 15px;
    border-radius: 20px 0 0 20px;
    display: flex;
    align-items: center;
    justify-content: center;
        min-height: 250px;
    border-top: 2px solid #30498c;
    border-bottom: 2px solid #30498c;
    border-left: 2px solid #30498c;
}

.fix-bottom .contact:nth-of-type(3)>* {
    background: #e8bf86;
    border-top: 2px solid #e8bf86;
    border-bottom: 2px solid #e8bf86;
    border-left: 2px solid #e8bf86;
    min-height: 200px;
}

.fix-bottom .contact a:hover{
  background: #fff;
  color: #30498c;
}

.fix-bottom .contact:nth-of-type(3) a:hover{
  background: #fff;
  color: #e8bf86;
}

@media only screen and (max-width: 1024px) {
  .header {
    width: 100%;
    background: #fff;
    border-radius: 0;
    position: unset;
    transform: none;
    opacity: 1;
  }
  
  .header .logo .logo-img img {
    max-height: 40px;
}

  .header .logo .logo-tit img{
    max-height: 25px;
  }
  
  .fix-bottom>* {
    width: 50%;
  }
  
  .fix-bottom .contact>*{
  min-height: 150px;
}
}

@media(max-width:599px){
  .header .logo .logo-img img {
    max-height: 30px;
}
.header .logo .logo-tit img {
    max-height: 20px;
}
}

/* 下部固定コンテンツ */

@media only screen and (max-width: 1024px) {
  .fix-bottom {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 250;
    display: flex;
    width: 100%;
    font-family: 'Kiwi Maru',
      serif;
  }

  .fix-bottom .item {
    width: 50%;
    text-align: center;
  }

  .fix-bottom .contact>* {
    background: #30498c;
    padding: 10px 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    line-height: 1;
    color: #fff;
}
}

@media only screen and (max-width: 599px) {
  .fix-bottom .contact>* {
    padding: 5px 5px;
    font-size: 14px;
  }
}


/**
グローバルナビ
gnav
*/
.gnav {
  position: relative;
  z-index: 100;
  padding: 10px 0;
}

.gnav.fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 200;
  width: 100%;
  height: auto;
  background: #fff;
  box-shadow: 0 0 5px 0 #999;
  cursor: pointer;
}

.gnav .navlogo {
  display: none;
}

[data-element-id].gnav .navlogo {
  display: block;
  width: 300px;
}

.gnav .navlogo img {
  max-height: 40px;
}

.gnav .nav-list {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  width: 100%;
}

.gnav .item01 {
  text-align: center;
  width: 14%;
  border-right: 1px solid #88adc8;
}

.gnav .item01:last-child {
  border-right: none;
  padding-bottom: 0px;
}

.gnav .item01>* {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  align-items: center;
}

.gnav .item01>* .tit {
  font-size: 12px;
  margin-top: 5px;
}

.gnav .item01>* .icon {
  width: 35px;
  height: 35px;
}


.gnav .item01.-parent {
  position: relative;
}

.gnav .item01.-parent:hover .nav-list-drop {
  visibility: visible;
  opacity: 1;
}

.gnav .nav-list-drop {
  position: absolute;
  top: 100%;
  left: 50%;
  visibility: hidden;
  margin-top: 10px;
  width: 200px;
  border-radius: 20px;
  background: #4a6aa3;
  color: #fff;
  padding: 10px;
  opacity: 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.gnav .item02 a {
  display: block;
  padding: 5px;
  position: relative;
  width: fit-content;
  margin: 0 auto;
}

.gnav .item02 a:hover {
  opacity: 1;
}

.gnav .item02 a:hover::before {
  content: "";
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco.webp');
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 490/447;
  width: 20px;
  position: absolute;
  top: 50%;
  left: -20px;
  transform: translate(0px, -50%);
}

[data-element-id].gnav {
  width: 100%;
}

[data-element-id].gnav .nav-list{
  justify-content: flex-start;
}

[data-element-id].gnav .item01:last-child {
    padding-bottom: 0;
}

[data-element-id].gnav .nav-list-drop {
    opacity: 1;
    visibility: visible;
    position: relative;
    transform: none;
    top: auto;
    left: auto;
    width: 150px;
    font-size: 12px;
}

[data-element-id].gnav .item01 {
    width: 14%;
}

[data-element-id].gnav .item01>*{
  font-size: 14px;
}

[data-element-id].gnav .item02 a:hover::before{
  content: none;
}

@media only screen and (max-width: 1024px) {
  .gnav {
    position: fixed;
    top: 0;
    right: 0;
    overflow: auto;
    width: 100%;
    max-width: 300px;
    height: 100%;
    background: #dce6f0;
    color: #3f619e;
    -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);
    -webkit-overflow-scrolling: touch;
  }

  .gnav.action {
    z-index: 250;
    -webkit-transform: translate3d(0%, 0, 0);
    transform: translate3d(0%, 0, 0);
  }

  .gnav .navlogo {
    display: block;
    width: 85%;
    margin: 50px auto 30px;
  }

  .gnav .navlogo a {
    background: #fff;
    padding: 10px 20px;
    border-radius: 10px;
    display: block;
  }

  .gnav .item01 {
    margin: 0 0 10px 0;
    min-height: auto;
    width: 100%;
    text-align: left;
    border: none;
    font-family: 'Kiwi Maru';
  }

  .gnav .item01>* {
    align-items: flex-start;
  }

  .gnav .item01>* .icon {
    display: none;
  }

  .gnav .item01>* .tit {
    font-size: 16px;
    margin-top: 10px;
  }

  .gnav .nav-list {
    padding: 0 20px;
  }

  .gnav .nav-list-drop {
    position: relative;
    top: 0;
    left: 0;
    visibility: visible;
    padding-left: 20px;
    padding-top: 0;
    background: none;
    opacity: 1;
    transform: none;
    margin-top: 5px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .gnav .nav-list-drop a {
    position: relative;
    padding: 2px 0 2px 20px;
    color: #3f619e;
  }

  .gnav .nav-list-drop a:before {
    position: absolute;
    top: 13px;
    left: 0;
    display: block;
    width: 10px;
    height: 1px;
    background: #3f619e;
    content: '';
  }
}

[data-element-id] .gnav.fixed {
  position: relative;
}

/* ハンバーガーメニュー  */
.toggle {
  position: fixed !important;
      top: 7px;
    right: 7px;
  z-index: 251;
  width: 45px;
  height: 45px;
  opacity: 1;
  cursor: pointer;
  display: none;
  background: #476aa3;
  border-radius: 5px;
}

.toggle::before {
  content: "";
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco.webp');
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 490/447;
  width: 22px;
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}

.toggle::after {
  content: "メニュー";
  font-family: 'Kiwi Maru',
    serif;
  font-size: 10px;
  position: absolute;
  width: 50px;
  font-weight: 700;
  color: #fff;
  scale: 0.7;
  top: 72%;
  left: 38%;
  transform: translate(-50%, -50%);
  z-index: 5;
  flex-shrink: 0;
}

.toggle .bar {
  position: absolute;
  top: 50%;
  left: 8px;
  display: block;
  margin-top: -1px;
  padding: 0;
  width: 28px;
  height: 2px;
  background: #4a6aa3;
  text-indent: 9999px;
  transition: ease 0.4s;
  -webkit-transition: ease 0.4s;
  display: flex;
    flex-direction: column;
}

.toggle .bar:before,
.toggle .bar:after {
  position: absolute;
  left: 0;
  display: block;
  width: 28px;
  height: 2px;
  background: #4a6aa3;
  content: '';
}

.toggle .bar:before {
  top: -10px;
}

.toggle .bar:after {
  top: 10px;
}

.toggle.active {
  background-color: #fff;
}

.toggle.active::before,
.toggle.active::after {
  display: none;
}

.toggle.active .bar {
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
}

.toggle.active .bar:after,
.toggle.active .bar:before {
  top: 0;
  left: 0;
  transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
}

@media only screen and (max-width: 1024px) {
  .toggle {
    display: flex;
    background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco.webp');
  }
}
@media only screen and (max-width: 599px) {
    .toggle {
      top: 3px;
      right: 3px;
  }
}
.overlay:after {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 249;
  width: 100%;
  height: 100vh;
  background: #000;
  content: '';
  opacity: 0.3;
  transform: translate3d(0, 0, 0) !important;
  -webkit-transform: translate3d(0, 0, 0) !important;
}

/*トップへ戻る*/
.totop {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 200;
  width: 40px;
  height: 41px;
  border-radius: 50%;
  background: #f8f9fd;
  color: #3f629e;
  text-align: center;
  font-size: 20px;
  line-height: 40px;
  cursor: pointer;
}

.totop:before {
  content: '\f077';
  font-weight: bold;
  font-family: 'Font Awesome 5 Free';
}

@media only screen and (max-width: 1024px) {
  .totop {
    right: 10px;
    bottom: 10px;
}
}

@media only screen and (max-width: 599px) {
  .totop {
    bottom: 15px;
  }
}

/**
フッター
footer
*/
.footer .copy {
  padding: 5px 0;
  background: #3F629E;
  color: #fff;
  text-align: center;
  z-index: 4;
  position: relative;
}

@media only screen and (max-width: 1024px) {
  .footer .copy {
    padding-bottom: 70px;
  }
}

/**
フッターナビ
fnav
*/
.footer .fnav {
  padding: 80px 0;
  background: #3F629E;
  position: relative;
}

.footer .fnav .bgi {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
  z-index: 1;
}

.footer .fnav .duck-all {
  position: absolute;
  bottom: 0;
  left: 20%;
  width: 20%;
  display: flex;
  align-items: flex-end;
  z-index: 3;
}

.footer .fnav .duck-all .big {
  width: 70px;
}

.footer .fnav .duck-all .min {
  width: 35px;
}

.footer .fnav .info .logo-area>* {
  column-gap: 10px;
  align-items: center;
  display: flex;
}

.footer .fnav .info .logo-area .logo-img img {
  max-height: 70px
}

.footer .fnav .info .logo-area .logo-tit img {
  max-height: 45px;
  filter: brightness(10);
}

.footer .fnav .info .mv-table {
  position: relative;
  bottom: auto;
  left: auto;
  transform: none;
}

@media (max-width:1024px) {
  .footer .fnav .info .mv-table {
    scale: 0.8;
  }
}

@media (max-width: 599px) {
  .footer .fnav .info .mv-table {
    width: max-content;
  }

  .footer .fnav .info .logo-area {
    justify-content: center;
  }

  .footer .fnav .duck-all {
    width: 40%;
  }
  
  .footer .fnav .info .logo-area>*{
    justify-content: center;
  }
  
  .footer .fnav .info .logo-area .logo-tit img{
    max-height: 25px;
  }
  
  .footer .fnav .info .logo-area .logo-img img {
    max-height: 50px;
}
}

/**
2カラムページ
*/
.column2 .inner {
  display: -webkit-box;
  display: flex;
  flex-wrap: nowrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
}

.column2 .side {
  width: 200px;
}

.column2 .mainwrap {
  width: calc(100% - 250px);
}

@media only screen and (max-width: 1024px) {
  .column2 .inner {
    flex-wrap: wrap;
  }

  .column2 .side {
    -webkit-box-ordinal-group: 4;
    order: 3;
    width: 100%;
  }

  .column2 .mainwrap {
    -webkit-box-ordinal-group: 3;
    order: 2;
    margin-bottom: 50px;
    width: 100%;
  }
}

/* サイドメニュー */
.side .list {
  margin-bottom: 30px;
  background: #fff;
  box-shadow: 4px 2px 10px #d5d5d5;
  border-radius: 30px;
  padding: 20px;
}

@media only screen and (max-width: 1024px) {
  .side {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .side .list {
    width: 48%;
  }
}

@media only screen and (max-width: 599px) {
  .side .list {
    width: 100%;
  }
}

.list-side .datattl {
  position: relative;
  margin-bottom: 10px;
  text-align: center;
  font-size: 22px;
  font-family: 'Playball', cursive;
  font-weight: 600;
}

.list-side.category .datattl {
  color: #0e3b7c;
}

.list-side.archive .datattl {
  color: #e79235;
}

.list-side .data {
  margin-bottom: 15px;
}

.list-side a {
  display: flex;
  align-items: baseline;
  line-height: 1;
}

.list-side a:before {
  color: #b8d3e9;
  content: '●';
  font-size: 80%;
  margin-right: 5px;
}

@media only screen and (max-width: 1024px) {
  .list-side.archive .datawrap {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    justify-content: space-between;
  }

  .list-side.archive .datawrap .datattl {
    width: 100%;
  }

  .list-side.archive .datawrap .data {
    width: 48%;
  }
}

/*===================================
  各個別コンテンツ
===================================*/
/**
トップ
*/
/*ホームビジュアル（トップ）*/
.homevisual {
  position: relative;
}

.homevisual .img {
  position: relative;
  min-height: 300px;
  max-height: 800px;
}

.homevisual .img:before {
  position: relative;
  z-index: -1;
  display: block;
  padding-top: 60%;
  content: '';
}

.homevisual .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-family: 'object-fit: cover; object-position: 50% 50%;';
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: 50% 50%;
  object-position: 50% 50%;
}

.homevisual .head {
  position: absolute !important;
  top: 39%;
  left: 50%;
  font-weight: bold;
  transform: translate(-50%, -50%);
  z-index: 5;
}

.homevisual .head>* {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  row-gap: 30px;
}

.homevisual .head .catch {
    background: rgb(255 255 255 / 60%);
    width: fit-content;
    font-size: 32px;
    color: #3F629E;
    padding: 0.1em 0.5em;
}

.homevisual .head .mv-duck {
  position: absolute;
  bottom: -120px;
  right: 0;
  width: 20%;
}

.mv-fix {
    width: 70px;
    position: fixed;
    right: 0;
    top: 10%;
    z-index: 300;
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}

.mv-fix>*>*>* {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: #fff;
  padding: 20px 15px;
  border-radius: 20px 0 0 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 20px;
  width: 100%;
  min-height: 250px;
}

.mv-fix .ab-test-a a {
    background: #e89643;
    border-top: 2px solid #e89643;
    border-bottom: 2px solid #e89643;
    border-left: 2px solid #e89643;
}

[data-element-id] .mv-fix .ab-test-a a{
  display: flex;
}

[data-element-id] .mv-fix .ab-test-b a{
  display: flex;
}

.mv-fix .ab-test-b a{
  background: #b2cbe4;
}

.mv-fix .mv-dack-pc img,
.mv-fix .mv-dack-pc02 img {
  width: 40px;
}

.mv-fix a:hover {
  opacity: 1;
}

.mv-fix .ab-test-a a:hover{
  background: #fff;
  color: #e89643;
  border-top: 2px solid;
  border-bottom: 2px solid;
  border-left: 2px solid;
}

.mv-fix .ab-test-b a:hover{
  background: #fff;
  color: #b2cbe4;
  border-top: 2px solid;
  border-bottom: 2px solid;
  border-left: 2px solid;
}

.mv-fix a .tit {
    flex-shrink: 0;
    display: flex;
    flex-direction: row;
}

.mv-fix a .mv-dack-pc {
  display: block;
}

.mv-fix a:hover .mv-dack-pc {
  display: none;
}

.mv-fix a .mv-dack-pc02 {
  display: none;
}

.mv-fix a:hover .mv-dack-pc02 {
  display: block;
}

.mv-table {
  width: 450px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
  overflow: hidden;
  position: absolute;
  bottom: 4%;
  left: 5%;
  background: #fff;
}

.mv-table .table-head .deco {
  width: 30px;
}

.mv-table .table01 {
  padding: 20px;
  background: #fff;
}

.mv-table tr:first-child {
  background: #dae6ee;
  color: #3F629E;
}

.mv-table td,
.mv-table th {
  padding: 5px 10px;
  text-align: center;
  font-size: 14px;
  color: #3F629E;
  border-right: 1px solid #bac6db;
}

.mv-table td:first-child,
.mv-table th:first-child {
  border-left: 1px solid #bac6db;
}

.mv-table tr:first-child {
  border-top: 1px solid #bac6db;
}

.mv-table tr:last-child {
  border-bottom: 1px solid #bac6db;
}

.mv-deco {
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
}

@media(max-width:1024px) {
  .homevisual .head {
  top: 45%;
  }

  .mv-table {
    scale: 0.7;
    left: -7%;
  }
  
  .homevisual .head .catch {
    font-size: 26px;
  }

  .homevisual .head p {
    font-size: 28px;
  }
  
  .mv-fix {
    bottom: 10%;
    top: auto;
    width: 50px;
}

.mv-fix>*>*>* {
    padding: 10px 5px;
    column-gap: 10px;
    width: 100%;
    min-height: 130px;
}

  .mv-fix .mv-dack-pc img {
    width: 35px;
  }
  
  .fix-bottom .contact:nth-of-type(3)>*{
    min-height: 130px;
  }
}

@media only screen and (max-width: 599px) {

  .mv-table {
    width: 350px;
    bottom: 4%;
    left: 50%;
    transform: translate(-50%, 0px);
  }

  .homevisual .head .mv-duck {
    bottom: -85px;
    right: 0px;
    width: 35%;
  }

  .homevisual .head {
    top: auto;
    bottom: 8%;
}

  .homevisual .head .catch {
    font-size: 20px;
  }

  .homevisual .head>* {
    row-gap: 10px;
  }

.mv-fix {
    width: 45px;
}

  .mv-fix>* {
    column-gap: 5px;
    font-size: 13px;
  }
}

/* A-BiSUスライダー用 */

.uk-slideshow {
    height: 100vh !important;
    position: relative;
}

.uk-slideshow:before {
    display: block;
    content: "";
    padding-top: 60%;
}

[data-element-id] .uk-slideshow>li {
    opacity: 1;
}

.uk-slideshow>li {
    width: 100%;
    height: 100% !important;
    position: absolute;
    top: 0;
    left: 0;
}

.uk-slideshow>li>div {
    height: 100% !important;
}

.uk-slideshow>li>div>img {
    width: 100%;
    height: 100%;
    font-family: 'object-fit: cover; object-position: 50% 50%;';
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
}

.uk-slideshow+* {
    margin-top: 10px !important;
}

.uk-slider {
    height: 100px;
    margin-left: -10px;
}

.uk-slider li {
    height: 100%;
    padding-left: 10px;
}

.uk-slider li>div {
    height: 100% !important;
}

.uk-slider li>div img {
    width: 100%;
    height: 100%;
    font-family: 'object-fit: cover; object-position: 50% 50%;';
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
}

@media (max-width: 1024px) {
  .uk-slideshow {
    height: auto !important;
}

    .uk-slider {
        height: 90px;
    }

    .first_view .uk-slideshow:before {
        padding-top: 60%;
    }
    
    .uk-slideshow:before {
    padding-top: 75%;
}
}

@media (max-width: 599px) {
    .uk-slider {
        height: 80px;
    }

    .uk-slider li {
        width: 33.333%;
    }

    .first_view .uk-slideshow:before {
        padding-top: 100%;
    }
    
    .uk-slideshow:before {
    padding-top: 72vh;
}

    .uk-slideshow>li>div>img {
    width: 100%;
    height: 100%;
    font-family: 'object-fit: cover; object-position: 50% 50%;';
    -o-object-fit: cover;
    object-fit: cover;
}
}


/* スクロールダウン */
.scrolldown4 {
  position: absolute;
  bottom: 1%;
  right: 50%;
  animation: arrowmove 1s ease-in-out infinite;
}

@keyframes arrowmove {
  0% {
    bottom: 1%;
  }

  50% {
    bottom: 4%;
  }

  100% {
    bottom: 1%;
  }
}

.scrolldown-box {
  width: 70px;
  height: 70px;
  background: #3f619e;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: 2%;
  left: 50%;
  transform: translate(-50%, 0);
  border-radius: 50%;
}

.scrolldown4 span {
  position: absolute;
  left: -20px;
  bottom: 38px;
  color: #fff;
  font-size: 10px;
  width: 45px;
}

.scrolldown4:before {
  content: "";
  position: absolute;
  bottom: 17px;
  right: -5px;
  width: 10px;
  height: 10px;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
  background: none;
  transform: rotate(-45deg);
}

.scrolldown4:after {
  content: "";
  position: absolute;
  bottom: 15px;
  right: 0;
  width: 1px;
  height: 20px;
  background: #fff;
}

@media (max-width:599px) {
  .scrolldown-box {
    scale: 0.9;
  }
}

/* index-intro（トップ） */
.index-intro {
  position: relative;
}

.index-intro .listbox .box .img {
  background: #fff;
  border-radius: 50%;
  width: 180px;
  height: 180px;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 4px 2px 10px #d5d5d5;
  margin: 0 auto;
}

.index-intro .listbox .box .tit {
  text-align: center;
  margin-top: 20px;
  font-weight: 700;
  color: #2f5a91;
  font-size: 18px;
}

.index-intro .listbox .box .img img {
  width: 70px;
}

.index-intro .content .item .deco .ilst {
    width: 20%;
    width: 300px;
    position: absolute;
    top: 30%;
    right: 35%;
}

.index-intro .content .duck-img {
  width: 33%;
  max-width: 600px;
  -webkit-mask-image: url('/import/tenant_1/59.106.191.134/html/images/01.index/introduction/frame-duck.png');
  -webkit-mask-size: cover;
  mask-position: left;
  aspect-ratio: 800/793;
  position: absolute;
  right: -2%;
  bottom: 30%;
}

.index-intro.detail .content .duck-img {
    width: 25%;
    max-width: 400px;
    -webkit-mask-image: url(/import/tenant_1/59.106.191.134/html/images/01.index/introduction/frame-duck.png);
    -webkit-mask-size: cover;
    mask-position: left;
    aspect-ratio: 800/793;
    position: absolute;
    right: 5%;
    bottom: 5%;
}

@media (max-width:1024px) {
  .index-intro .listbox .box .img {
    width: 130px;
    height: 130px;
  }

  .index-intro .listbox .box .img img {
    width: 50px;
  }

  .index-intro .listbox .box .tit {
    font-size: 14px;
  }

  .index-intro .content .duck-img {
    width: 45%;
  }

  .index-intro.detail .content .duck-img {
    width: 35%;
  }
}

@media (max-width:599px) {
  .index-intro .content .item {
    z-index: 2;
    position: relative;
}

  .index-intro .content .item .deco .ilst {
    width: 30%;
    margin-right: 30px;
    top: 20%;
    right: -5%;
}

  .index-intro .listbox .box .img {
    width: 150px;
    height: 150px;
  }

  .index-intro .content .duck-img {
    width: 70%;
    margin: 40px auto 0;
    position: absolute;
    z-index: 1;
    opacity: 0.5;
}

  .index-intro.detail .content .duck-img {
    position: absolute;
    width: 80%;
    margin: 30px auto 0;
}
}

/* index-feature（トップ） */
.index-feature .feature-list .item {
  border-radius: 50px;
  display: flex;
  overflow: hidden;
  align-items: center;
}

.index-feature .feature-list li:nth-of-type(odd) .item {
  background: #e0eaf0;
}

.index-feature .feature-list li:nth-of-type(even) .item {
  background: #faf2e7;
}

.index-feature .feature-list .item>* {
  padding: 10px 15px;
}

.index-feature .feature-list .item .num {
  color: #f5f9fa;
  width: 15%;
  font-size: 30px;
  text-align: center;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}

.index-feature .feature-list li:nth-of-type(odd) .item .num {
  background-color: #85b5d3;
}

.index-feature .feature-list li:nth-of-type(even) .item .num {
  background-color: #e89644;
}

.index-feature .feature-list .item .txt {
  width: 85%;
  color: #595757;
  font-weight: 500;
  display: flex;
  align-items: center;
}

@media (max-width:599px) {
  .index-feature .feature-list .item .num {
    width: 25%;
    font-size: 28px;
  }
}

/* index-article（トップ） */
.index-article .box {
  margin-top: 40px;
  background: #fff;
  row-gap: 10px;
  display: flex;
  flex-direction: column;
}

.index-article .box.blog-box {
  border-radius:50px 0 0 50px;
  padding: 30px;
}

.index-article .box.news-box {
  border-radius: 0 50px 50px 0;
  padding: 30px;
}

.index-article .content .box li {
  border-bottom: 1px solid;
  padding-bottom: 10px;
  margin-bottom: 10px;
  width: 80%;
  position: relative;
  height: 100%;
}

.index-article .content .box .item::after {
  content: "";
  width: 15px;
  height: 15px;
  border-top: solid 1px #8d8d8d;
  border-right: solid 1px #8d8d8d;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0%, -50%) rotate(45deg);
}

.index-article .content .box li:last-child {
  border: none;
  padding: 0;
  margin-bottom: 0;
}

.index-article .content .box.blog-box li {
  height: calc(100% / 3 - 3px);
  margin-right: auto;
}

.index-article .content .box .item .text .tit {
    margin-top: 10px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    width: 90%;
}

.index-article .content .box.news-box li {
    height: calc(100% / 4 - 4px);
    margin-left: auto;
}

.index-article .content .box .item .date {
  text-align: center;
}

.index-article .content .box .item .cate {
  margin-top: 5px;
}

.index-article .content .box .item .cate span {
  background: #edab69;
  color: #fff;
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 15px;
  width: 100%;
  display: block;
  text-align: center;
}

@media (max-width:1024px) {
  .index-article .content .box .item {
    width: 95%;
  }

  .index-article .content .box .item .date {
    font-size: 14px;
  }

  .index-article .content .box .item::after {
    width: 10px;
    height: 10px;
    right: 0px;
  }
}

@media (max-width:1024px) {
  .index-article .box.blog-box {
    margin-left: 20px;
  }

  .index-article .box.news-box {
    margin-right: 20px;
  }
  
  .index-article .content .box li {
    width: 100%;
  }
}

/* index-medical */
.index-medical {
    position: relative;
}

.index-medical .bgi-img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0.2;
}

.index-medical .gallery-list .img{
  border-radius: 20px;
  overflow: hidden;
}

.index-medical .gallery-list .img .bgi img{
  filter: brightness(0.9);
}

.index-medical .gallery-list .dtl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: center;
}

.index-medical .gallery-list .dtl .icon {
    background: #fff;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.index-medical .gallery-list .dtl .icon img {
    height: 50%;
    filter: brightness(1.1);
}

.index-medical .gallery-list .dtl .tit {
    margin-top: 20px;
    background: #fff;
    padding: 0 20px 3px;
    font-family: 'Kiwi Maru', serif;
    color: #3f629e;
    font-size: 22px;
    text-align: center;
    border-radius: 30px;
        min-width: 150px;
}

.index-medical .fa-chevron-right:before, .index-medical .fa-chevron-left:before {
    color: #e4ab76;
    background: #ffffffbf;
    height: 50px;
    width: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    border-radius: 50%;
    border: 2px solid;
}

.index-medical .slick-dots li button:before {
    font-family: slick;
    font-size: 6px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: '■';
    text-align: center;
    opacity: 1;
    color: #ffffff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.index-medical .slick-dots li.slick-active button:before {
    color: #e4ab76;
}

@media(max-width:599px){
  .index-medical .gallery-list .dtl .icon {
      width: 110px;
      height: 110px;
  }
  
  .index-medical .gallery-list .dtl .tit {
      margin-top: 10px;
      padding: 0 10px 3px;
      font-size: 16px;
  }
}

/* index-faq（トップ） */
.index-faq.common-bgi04 {
  position: relative;
}

.index-faq .bgi-bear {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
  z-index: 1;
}

.index-faq .accordion .list-cmp09 {
  border-radius: 50px;
  background: #fff;
}

.index-faq .accordion .list-cmp09 .item:last-child .data {
  border-radius: 0 0 50px 50px;
}

.index-faq .accordion .list-cmp09 .item {
  position: relative;
}

.index-faq.detail .accordion .list-cmp09 .item {
  position: static;
}

.index-faq .accordion .list-cmp09 .item::after {
  position: absolute;
  width: 95%;
  height: 1px;
  background: #aaa;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
  z-index: 5;
  display: block;
  content: "";
}

.index-faq .accordion .list-cmp09 .item:last-child:after {
  content: none;
}

.index-faq .accordion .list-cmp09 .item .datattl {
  position: relative;
}

.index-faq .accordion .list-cmp09 .item .datattl.is-parent::after {
    transform: translate(0, -50%) rotate(90deg);
}

.index-faq .accordion .list-cmp09 .item .datattl::before {
    content: "";
    right: 30px;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    width: 1.5em;
    height: 1.5px;
    background: #6a6a6a;
}

.index-faq .accordion .list-cmp09 .item .datattl::after {
    content: "";
    right: 30px;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    width: 1.5em;
    height: 1.5px;
    background: #6a6a6a;
    transition: .3s linear;
}

.index-faq .accordion .list-cmp09 .item .data {
  background: #faf2e7;
}

.index-faq.detail .accordion .list-cmp09 .item .data .link {
  padding: 20px 10% 10px;
}

.index-faq.detail.vc .accordion .list-cmp09 .item .data .link {
  padding: 20px 9% 10px;
}

.index-faq.detail .accordion .list-cmp09 .item .data .link li a {
  background: #e4ab76;
  color: #fff;
  min-width: 170px;
  margin: 0 auto;
  display: block;
  border: 2px solid #fff;
  padding: 10px 5px;
  font-size: 12px;
  border-radius: 10px;
  text-align: center;
  box-shadow: 1px 1px 3px #c3c3c3;
  position: relative;
}

.index-faq.detail .accordion .list-cmp09 .item .data .link li a::after {
    content: "";
    width: 7px;
    height: 7px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    position: absolute;
    top: 50%;
    right: 5px;
    transform: translate(0%, -50%) rotate(45deg);
    z-index: 3;
}

.index-faq .accordion .list-cmp09 .item .txt {
  display: flex;
  align-items: baseline;
  width: 95%;
  margin: 0 auto;
  padding: 30px 10%;
}

.index-faq .accordion .list-cmp09 .item:last-child .txt {
  border: none;
}

.index-faq .accordion .list-cmp09 .item .tit {
  padding: 20px 10%;
  font-size: 20px;
  font-family: 'Kiwi Maru';
  color: #355f99;
  text-align: center;
}

.index-faq .accordion .list-cmp09 .item .txt .q,
.index-faq .accordion .list-cmp09 .item .txt .a {
  font-family: 'Playball',
    cursive;
  font-size: 40px;
  width: 80px;
  flex-shrink: 0;
}

.index-faq .accordion .list-cmp09 .item .txt .q {
  color: #0e3b7c;
}

.index-faq .accordion .list-cmp09 .item .txt .a {
  color: #e79235;
}

@media (max-width:1024px) {
  .index-faq .accordion .list-cmp09 .item .txt {
    padding: 20px 10%;
  }
}

@media (max-width:599px) {
  .index-faq .accordion .list-cmp09 {
    border-radius: 30px;
  }

  .index-faq .accordion .list-cmp09 .item:last-child .data {
    border-radius: 0 0 30px 30px;
  }

  .index-faq .accordion .list-cmp09 .item .txt {
    width: 90%;
    margin: 0 auto 0;
  }

  .index-faq .accordion .list-cmp09 .item .data .txt {
    /* width: 100%; */
  }

  .index-faq .accordion .list-cmp09 .item .txt .q,
  .index-faq .accordion .list-cmp09 .item .txt .a {
    width: 40px;
    font-size: 30px;
  }
  
  .index-faq .accordion .list-cmp09 .item .datattl::before{
    right: 20px;
  }

  .index-faq .accordion .list-cmp09 .item .datattl::after {
    right: 20px;
  }
}

/* index-access（トップ） */
.index-access {
  background-image: url('/upload/tenant_1/bgc03.webp');
  background-size: cover;
  background-repeat: no-repeat;
}

.index-access .banner-area .box .tel>* {
  background: #fff;
  padding: 10px 40px 10px 30px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0 auto;
  column-gap: 10px;
}

.index-access .banner-area .box .tel .tel-icon {
  font-size: 22px;
  color: #233979;
  font-weight: 600;
}

.index-access .banner-area .box .tel .tel-icon::before {
  content: "\f879";
  font-family: "Font Awesome 5 Free";
  font-size: 80%;
  line-height: 1;
  margin-right: 5px;
}

.index-access .banner-area .box .tel .logo-img img {
  max-height: 70px;
}

.index-access .banner-area .box .tel .logo-title img {
  max-height: 40px;
}

.index-access .banner-area .box>* {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  height: 100%;
}

.index-access .banner-area .box .bgi {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.index-access .banner-area .box .tit {
  padding: 10px 40px;
  background: #fff;
  width: fit-content;
  font-size: 22px;
  color: #294072;
  border-radius: 50px;
  margin: 0 auto;
  font-weight: 500;
}

.index-access .banner-area .box .txt {
  font-size: 18px;
  color: #1d476f;
  font-weight: 500;
  text-align: center;
  text-shadow: 1px 5px 5px #fff, -2px -4px 5px #fff, -2px 2px 5px #fff, 2px -2px 5px #fff, 0px 2px 5px #fff, 0 -2px 5px #fff, -1px 0 5px #fff, 2px 0 5px #fff, 2px -2px 5px #fff, 0px 2px 5px #fff, 0 -2px 5px #fff, -1px 0 5px #fff, 2px 0 5px #fff, 2px -2px 5px #fff, 0px 2px 5px #fff, 0 -2px 5px #fff, -1px 0 5px #fff, 2px 0 5px #fff;
  margin-top: 30px;
}

[data-element-id].index-access .banner-area .box .tel{
  background: #fff;
  padding: 10px 40px 10px 30px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0 auto;
  column-gap: 10px;
}

[data-element-id].index-access .banner-area .box .tel>* {
  background:none;
  padding: 0;
  border-radius: 0;
  display: block;
  width: 100%;
  margin: 0;
  column-gap: 0;
}

@media (max-width:1024px) {
  .index-access {
    background-position: top;
  }

  .index-access .banner-area .box .tel .logo-img img {
    max-height: 60px;
  }

  .index-access .banner-area .box .tel .logo-title img {
    max-height: 30px;
  }

  .index-access .banner-area .box .tel .tel-icon {
    font-size: 20px;
  }

  .index-access .banner-area .box .tit {
    padding: 10px 30px;
    font-size: 20px;
  }

  .index-access .banner-area .box .txt {
    margin-top: 20px;
    font-size: 16px;
  }

}

/* A-BiSUスライダー用 */
.mainimg {
  position: relative;
  overflow: hidden;
}

.mainimg img {
  width: 100%;
}

.mainimg .uk-slidenav-position {
  position: relative;
  overflow: hidden;
  min-height: 300px;
}

.mainimg .uk-slidenav-position:after {
  display: block;
  padding-top: 50%;
  content: '';
}

.mainimg .uk-slideshow {
  position: absolute;
  top: 0;
  height: 100% !important;
}

.mainimg .uk-slideshow li {
  height: 100% !important;
}

.mainimg .uk-slideshow .uk-flex {
  height: 100%;
}

.mainimg .uk-slideshow img {
  width: 100%;
  height: 100%;
  /*IE対策*/
  font-family: 'object-fit: cover; object-position: 50% 50%;';
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: 50% 50%;
  object-position: 50% 50%;
}

/*IE対策*/
/* スリックスライダー（トップ） */
.slick01 {
  padding: 0 20px;
}

.slick01.slick-dotted {
  margin-bottom: 50px;
}

.slick01 .btn-slick {
  position: absolute;
  z-index: 1;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 30px;
  cursor: pointer;
}

.slick01 .btn-slick.btn-back {
  left: 0;
}

.slick01 .btn-slick.btn-next {
  right: 0;
}

.slick01 .slick-dots {
  bottom: -40px;
  left: 0;
}

[data-element-id].list01.slick02 {
    display: flex;
    overflow-x: scroll;
    border: 20px solid #e89644;
}

[data-element-id].list01.slick02::after {
    content: "▲スクロールするとすべての画像が変更可能です▲";
    width: 100%;
    height: 20px;
    line-height: 1.5;
    font-size: 14px;
    text-align: center;
    display: block;
    background: #e89644;
    color: #fff;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
    font-family: 'Kiwi Maru', serif;
}

[data-element-id].list01.slick02 .item {
    width: 300px;
    flex-shrink: 0;
}

[data-element-id].gallery-list.slick01{
  display: flex;
  flex-wrap: wrap;
  row-gap: 20px;
}

[data-element-id].gallery-list.slick01 .slick01-box{
  width: 30%;
}

@media only screen and (max-width: 599px) {
  .slick01 {
    padding: 0 10px;
  }

  .slick01 .btn-slick {
    font-size: 20px;
  }
}

/**
下層共通
*/
/* トップビジュアル（下層共通） */
.topvisual {
  position: relative;
  background-color: #3f619e;
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/bgc03.webp');
  background-size: cover;
  background-repeat: no-repeat;
}

.topvisual .img {
  position: relative;
  min-height: 200px;
  max-height: 400px;
}

.topvisual .img:before {
  position: relative;
  z-index: -1;
  display: block;
  padding-top: 30%;
  content: '';
}

.topvisual .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-family: 'object-fit: cover; object-position: 50% 50%;';
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: 50% 50%;
  object-position: 50% 50%;
  opacity: 0.3;
}

.topvisual .head {
  position: absolute !important;
  width: 96%;
  max-width: 1000px;
  text-align: center;
  top: 50%;
  left: 50%;
  font-weight: bold;
  font-size: 34px;
  transform: translate(-50%, -50%);
  color: #fff;
  font-family: 'Kiwi Maru',
    serif;
}

@media only screen and (max-width: 599px) {
  .topvisual .head {
    font-size: 24px;
  }
}

/* ##### パンくずリスト breadcrumbs ##### */
.breadcrumbs {
  padding: 30px 0;
}

.breadcrumbs-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  align-items: center;
  -ms-flex-align: center;
}

.breadcrumbs-list li {
  display: inline;
  font-size: 14px;
  letter-spacing: 1px;
}

.breadcrumbs-list li.breadcrumbs-home,
.breadcrumbs-list li.breadcrumbs-prevpage {
  font-weight: bold;
  color: #284b8f;
}

.breadcrumbs-list li+li::before {
  content: "";
  width: 8px;
  height: 8px;
  display: inline-block;
  margin: 0 10px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media (max-width: 1024px) {
  .breadcrumbs {
    padding: 20px 0;
    font-size: 14px;
  }

  .breadcrumbs-box {
    flex-direction: column;
    align-items: flex-start;
  }

  .breadcrumbs-list {
    width: 90%;
    margin-top: 1em;
  }

  .breadcrumbs li {
    font-size: 12px;
  }

  .breadcrumbs li+li::before {
    width: 8px;
    height: 8px;
    margin: 0 5px 1px;
  }
}

@media (max-width: 599px) {
  .breadcrumbs {
    padding: 15px 0;
    font-size: 12px;
  }

  .breadcrumbs li+li::before {
    width: 6px;
    height: 6px;
  }
}

/* ##### パンくずリスト breadcrumbs ここまで ##### */

/* ページネーション */
.pagenation {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
}

.pagenation .item {
  margin: 0 10px;
}

.pagenation .prev {
  position: relative;
  margin-right: 20px;
}

.pagenation .prev a:before {
  content: "\f053";
  font-weight: 600;
  font-family: "Font Awesome 5 Free";
  color: #0e3b7c;
}

.pagenation .prev a:hover:before,
.pagenation .next a:hover:before {
  color: #e79235;
  opacity: 1;
}

.pagenation .next {
  position: relative;
  margin-left: 20px;
}

.pagenation .next a:before {
  content: "\f054";
  font-weight: 600;
  font-family: "Font Awesome 5 Free";
  color: #0e3b7c;
}

.pagenation a,
.pagenation .now {
  font-weight: bold;
}

.pagenation .number a,
.pagenation .now {
  display: block;
  padding: 2px 8px;
  color: #0e3b7c;
  font-family: 'Kiwi Maru', serif;
  text-align: center;
  font-size: 20px;
  line-height: 28px;
}

.pagenation .number a:hover,
.pagenation .now {
  color: #edab69;
  opacity: 1;
  position: relative;
}

.pagenation .now::before {
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco03.webp');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  content: "";
  aspect-ratio: 490/447;
  width: 18px;
  position: absolute;
  top: -7px;
  left: 45%;
  transform: translate(-50%, 0);
}

@media only screen and (max-width: 599px) {
  .pagenation .item {
    margin: 0 5px;
  }

  .pagenation .prev {
    margin-right: 10px;
  }

  .pagenation .next {
    margin-left: 10px;
  }
}

/**
各下層ページ
*/
/* 初めての方へ（下層） */
.other-note .other-note-list .box li {
  display: flex;
  align-items: baseline;
}

.other-note .other-note-list .box li::before {
  content: "";
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco02.webp');
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 490/447;
  width: 25px;
  margin-right: 10px;
  flex-shrink: 0;
}

/* クリニック紹介（下層） */
.overview .overview-box {
  background: #fff;
  border-radius: 30px;
  padding: 30px;
  box-shadow: 4px 2px 10px #d5d5d5;
}

.overview .overview-box dl {
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid #e1ebf3;
  padding-bottom: 10px;
}

.overview .overview-box dl:last-child {
  border: none;
  margin: 0;
  padding: 0;
}

.overview .overview-box dt {
  width: 20%;
  text-align: center;
  color: #355f9f;
  font-family: 'Kiwi Maru';
  font-weight: 600;
  font-size: 18px;
}

.overview .overview-box dd {
  width: 78%;
}

.clinic-features .box:nth-of-type(odd) {
  flex-direction: row-reverse;
}

.clinic-features .box:nth-of-type(odd) .img-left {
  border-radius: 50px 0 0 0;
}

.clinic-features .box:nth-of-type(odd) .img-left+*>* {
  margin-left: auto;
}

@media (max-width:599px) {
  .clinic-features .box:nth-of-type(odd) .img-left+*>* {
    margin: 0 auto;
  }
  
  .overview .overview-box dt {
       width: 30%;
    font-size: 14px;
}

  .overview .overview-box dd {
   width: 68%;
    font-weight: 400;
    font-size: 14px;
}
}

/* 医院ギャラリー */
.gallery .gallery-list .box img {
  overflow: hidden;
  border-radius: 30px;
}

.gallery .slick-dots li button:before {
  font-family: slick;
  font-size: 6px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '■';
  text-align: center;
  opacity: 1;
  color: #e4ab76;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.gallery .slick-dots li.slick-active button:before {
  opacity: 1;
  content: "";
  background-image: url('/upload/tenant_1/process/0df984b9bb940e01ac346538f250b93e.webp');
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 490/447;
  width: 55px;
  flex-shrink: 0;
  z-index: 4;
}

.gallery .fa-chevron-right:before,
.gallery .fa-chevron-left:before {
  color: #e4ab76;
  background: #ffffffbf;
  height: 50px;
  width: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  border-radius: 50%;
  border: 2px solid;
}

.gallery .fa-chevron-right:before {
  content: "\f054";
  padding-left: 2px;
}

.gallery .fa-chevron-left:before {
  content: "\f053";
  padding-right: 2px;
}

.gallery .slick01 .btn-slick.btn-next {
  right: -40px;
}

@media(max-width:1024px) {
  .gallery .slick01 .btn-slick.btn-next {
    right: -10px;
  }

  .gallery .slick01 .btn-slick.btn-back {
    left: -10px;
  }

}

@media(max-width:599px) {
  .gallery .gallery-list .box .img {
    width: 90%;
    margin: 0 auto;
  }

  .gallery .fa-chevron-right:before,
  .gallery .fa-chevron-left:before {
    height: 40px;
    width: 40px;
  }

  .gallery .slick01 .btn-slick.btn-next {
    right: 0px;
  }

  .gallery .slick01 .btn-slick.btn-back {
    left: 0px;
  }

}

/* 医院紹介（下層） */
.staff .box:nth-of-type(odd) {
  flex-direction: row-reverse;
}

.staff .history {
    background: #fff;
    margin-top: 20px;
    border-radius: 20px;
    padding: 20px;
    font-size: 14px;
        font-family: 'Kiwi Maru', serif;
}

.staff .history>*{
  display: flex;
}

.staff .history span{
  flex-shrink: 0;
}

/* アクセス（下層） */
.access .text-block .tit-box .img {
  width: 80px;
}

.access .text-block .tit-box .tit {
  font-size: 22px;
  font-family: 'Kiwi Maru';
  color: #35609a;
  font-weight: 600;
  margin-left: 20px;
}

.access .text-block .tit-sub {
  color: #ffffff;
  background: #95b6c9;
  padding: 0.2em 1em;
  border-radius: 50px;
  text-align: center;
}

.map-area iframe {
  height: 300px !important;
  border-radius: 30px;
  overflow: hidden;
}

/* 記事一覧ページ */
.article-area .mainwrap .list-article .item>* {
  margin-bottom: 30px;
  box-shadow: 4px 2px 10px #d5d5d5;
  background: #fff;
  display: block;
}

.article-area .mainwrap .list-article .item>*:last-child {
  margin-bottom: 0px;
}

.article-area .mainwrap .news .list-article .item>* {
  border-radius: 70px;
  padding: 20px 30px;
  position: relative;
  width: 100%;
}

.article-area .mainwrap .blog .list-article .item>* {
  border-radius: 30px;
  padding: 30px;
  height: 100%;
}

.article-area .mainwrap .news .list-article .item>*::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 2px #3f629e;
  border-right: solid 2px #3f629e;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translate(0%, -50%) rotate(45deg);
}

.blog .list-article .item .head {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.news .list-article .item .head {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.article-area .mainwrap .list-article .cate span {
  display: block;
  background: #edab69;
  border-radius: 20px;
  line-height: 1;
  font-size: 12px;
  color: #fff;
  padding: 0.5em 1.5em;
  margin: 0 5px 2px 0px;
  width: fit-content;
}

.article-area .mainwrap .list-article .item .head a {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media (max-width:1024px) {
  .article-area .mainwrap .news .list-article .item>* {
    border-radius: 30px;
  }
}

@media (max-width:599px) {
  .article-area .mainwrap .news .list-article .item>* {
    border-radius: 20px;
  }
}

/* 記事詳細ページ */
.article-area .mainwrap .html-box {
  background-color: #fff;
  border-radius: 50px;
  padding: 30px;
}

.article-area .mainwrap .html-box .tit {
  font-size: 22px;
  color: #30498c;
  font-family: 'Kiwi Maru';
  font-weight: 600;
  position: relative;
  padding-bottom: 10px;
  margin-bottom: 20px;
}

.article-area .mainwrap .html-box .tit::after {
  content: "";
  background-color: #30498c;
  height: 3px;
  width: 100%;
  border-radius: 10px;
  position: absolute;
  bottom: 5px;
  left: 50%;
  transform: translate(-50%, 0);
}

.html-box .html-detail h2 {
  color: #fff;
  font-size: 22px;
  background: #e89643;
  font-family: 'Kiwi Maru';
  line-height: 1;
  padding: 0.5em 1em;
  margin: 1em 0;
  font-weight: 500;
  border-radius: 5px;
}

.html-box .html-detail h3 {
  font-size: 20px;
  border-left: solid 10px #30498c;
  font-family: 'Kiwi Maru';
  line-height: 1;
  padding: 0.5em;
  margin: 1em 0;
  font-weight: 500;
}

.html-box .html-detail h4 {
  font-size: 18px;
  padding-bottom: 0.5em;
  margin: 1em 0;
  font-weight: 500;
  display: flex;
  align-items: baseline;
}

.html-box .html-detail h4::before {
  content: "";
  background-image: url('/import/tenant_1/59.106.191.134/html/images/common/ducl_deco03.webp');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  content: "";
  aspect-ratio: 490/447;
  width: 25px;
  margin-right: 5px;
  flex-shrink: 0;
}

/* よくある質問（下層） */
.index-faq.detail .accordion .list-cmp09 {
  border-radius: 0;
  background: none;
}

.index-faq.detail .accordion .list-cmp09 .item {
  border-radius: 30px;
  background-color: #fff;
  margin-bottom: 30px;
}

.index-faq.detail .accordion .list-cmp09 .item::after {
  content: none;
}

.index-faq.detail .accordion .list-cmp09 .item .data {
  border-radius: 0 0 30px 30px;
}

@media (max-width:599px) {
  .index-faq.detail .accordion .list-cmp09 .item {
    border-radius: 30px;
  }

  .index-faq.detail .accordion .list-cmp09 .item .datattl::after {
    right: 20px;
    height: 1px;
}

  .index-faq.detail .accordion .list-cmp09 .item .tit {
    font-size: 18px;
  }
}

/* お問い合わせ（下層） */
.form .box {
  display: flex;
  flex-wrap: nowrap;
  padding: 20px 0;
}

.form .datattl {
  display: flex;
  flex-shrink: 0;
  -webkit-box-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  align-items: flex-start;
  width: 210px;
  font-weight: 600;
  font-family: 'Kiwi Maru', serif;
  font-size: 18px;
  color: #284b8f;
}

.form .require {
  display: inline-block;
  margin-left: 10px;
  padding: 0 4px;
  background: #e69743;
  color: #fff;
  font-size: 14px;
  line-height: 1.6em;
  font-weight: 500;
}

.form .data {
    padding-left: 50px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}

.form .data input {
  box-sizing: border-box;
  margin-top: 5px;
  margin-bottom: 5px;
  padding: 10px 20px;
  width: 100%;
  border: none;
  border-radius: 20px;
}

.form .data input[type='radio'] {
  display: none;
}

.form .data input[type='radio']+label {
  position: relative;
  box-sizing: border-box;
  margin-right: 20px;
  padding-left: 20px;
  line-height: inherit;
}

.form .data input[type='radio']+label::before {
  position: absolute;
  top: 7px;
  left: 0;
  display: block;
  width: 13px;
  height: 13px;
  border: 2px solid #284b8f;
  border-radius: 50%;
  background: #fff;
  content: '';
}

.form .data input[type='radio']:checked+label::after {
  position: absolute;
  top: 8px;
  left: 1px;
  display: block;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #284b8f;
  content: '';
}

.form .data input[type='radio']:checked+label {
  -webkit-transition: 0.6s;
  transition: 0.6s;
}

.form .data input[type='number'] {
  margin-right: 10px;
  width: 70px;
}

.form .data select {
  box-sizing: border-box;
  padding: 5px;
  border: 1px solid #999;
  color: inherit;
}

.form .data textarea {
  box-sizing: border-box;
  padding: 20px;
  width: 100%;
  height: 170px;
  border: none;
  border-radius: 30px;
  color: inherit;
  font-size: inherit;
  font-family: inherit;
}

.form .data01 div {
  display: inline-block;
}

.form .form-btn {
  margin-top: 30px;
}

.form .form-btn button {
  width: 100%;
  display: block;
  padding: 15px 20px;
  background: #3f629e;
  border-radius: 10px;
  font-size: 14px;
  color: #fff;
  text-align: center;
  position: relative;
  border: none;
}

.form .form-btn button:after {
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  content: "\f054";
  font-size: 12px;
  font-weight: 600;
  font-family: 'Font Awesome 5 Free';
  width: 27px;
  height: 27px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color: #3f629e;
  border-radius: 50%;
}

.form .form-btn .back:after {
  content: "\f053";
  right: inherit;
  left: 5px;
}

.form .form-btn button:hover {
  box-shadow: 0 5px 5px rgb(179 179 179);
  background: #fff;
  color: #3f629e;
  opacity: 1;
}

input[type="text"]:focus,
.form .data textarea:focus {
  outline: none;
  background: #4a6aa3;
  color: #fff;
}

@media only screen and (max-width: 1024px) {
  .form .item {
    flex-wrap: wrap;
  }

  .form .datattl {
    display: block;
    margin-bottom: 10px;
  }

  .form .data {
    padding-left: 30px;
  }
}

@media (max-width:599px) {
  .form .box {
    flex-wrap: wrap;
  }

  .form .data {
    padding-left: 0px;
  }
}

/* 採用情報（下層） */

.application .listbox .item>* {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px;
  overflow: hidden;
  border-radius: 30px;
  background-color: #fff;
  min-height: 200px;
}

.application .listbox .item>*::after {
    content: "";
    width: 15px;
    height: 15px;
    border-top: solid 2px #000;
    border-right: solid 2px #000;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translate(0%, -50%) rotate(45deg);
    z-index: 2;
}

.application .listbox .item .tit {
  font-family: 'Kiwi Maru';
  font-size: 30px;
  z-index: 2;
  position: relative;
  text-align: center;
}

.application.other .listbox .item .tit {
  font-size: 22px;
  text-align: center;
}

.application .listbox .item a {
  display: flex;
  align-items: center;
}

.application .listbox .item .rec-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
  z-index: 1;
  overflow: hidden;
  border-radius: 30px;
}

.apl-flow .listbox .box {
  position: relative;
}

.apl-flow .listbox .box>* {
  display: flex;
  justify-content: space-between;
  background: #fff;
  border-radius: 120px;
  overflow: hidden;
  box-shadow: 4px 2px 10px #d5d5d5;
  margin-bottom: 50px;
}

.apl-flow .listbox:nth-of-type(even) .box>* {
  flex-direction: row-reverse;
}

.apl-flow .listbox:nth-of-type(even) .box>* .txt {
  padding: 20px 20px 20px 70px;
}

.apl-flow .listbox .box::after {
  content: "";
  border-top: 20px solid #255095;
  border-right: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid transparent;
  position: absolute;
  bottom: -25%;
  left: 50%;
  transform: translate(-50%, 0);
}

.apl-flow .listbox .box:last-child:after {
  content: none;
}


.apl-flow .listbox .box .img {
  width: 30%;
}

.apl-flow .listbox .box .tit {
  width: 70%;
  padding: 30px;
  display: flex;
  align-items: center;
  font-size: 18px;
  color: #45464a;
}

.apl-flow .listbox .box .txt {
  width: 70%;
  padding: 30px;
  display: flex;
  align-items: center;
  color: #45464a;
  font-size: 16px;
  line-height: 2;
}

[data-element-id].application .listbox .item>*{
  flex-direction: column;
  height: 100%;
  justify-content: flex-start;
}

@media (max-width:1024px) {
  .apl-flow .listbox .box>* {
    border-radius: 50px;
  }

  .apl-flow .listbox .box::after {
    bottom: -35%;
  }

  .apl-flow.other .listbox .box::after {
    bottom: -50px;
  }

  .application .listbox .item>* {
    min-height: 150px;
    padding: 20px;
  }

  .application .listbox .item .tit {
    font-size: 24px;
  }

  .application.other .listbox .item>* {
    width: 100%;
    min-height: 100px;
    padding: 10px;
    border-radius: 30px;
  }

  .application.other .listbox .item .tit {
    font-size: 18px;
  }

}

@media (max-width:599px) {
  .application .listbox .item>* {
    width: 90%;
    margin: 0 auto;
    min-height: 150px;
  }

  .application .listbox .item .tit {
    font-size: 22px;
  }

  .apl-flow .listbox .box::after {
    bottom: -60%;
  }

  .apl-flow.other .listbox .box::after {
    bottom: -15%;
  }

  .apl-flow .listbox .box::after {
    border-top: 15px solid #255095;
    border-right: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 15px solid transparent;
  }

  .apl-flow .listbox .box .tit {
    font-size: 16px;
  }

  .apl-flow.other .listbox .box>* {
    position: relative;
    border-radius: 50px;
  }

  .apl-flow.other .listbox .box>* .img {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0.3;
    z-index: 1;
  }

  .apl-flow.other .listbox .box>* .txt {
    width: 100%;
    z-index: 3;
    position: relative;
  }

  .apl-flow .listbox:nth-of-type(even) .box>* .txt {
    padding: 30px;
  }
}

/*# sourceMappingURL=style.css.map */

/* featherlight（ワクチン） */
.vacci {
  display: none;
}

.vacci .tit {
  padding: 20px 10%;
  font-size: 26px;
  font-family: 'Kiwi Maru';
  color: #355f99;
  text-align: center;
}

.featherlight .featherlight-content {
  margin-left: 15%;
  margin-right: 15%;
}

.featherlight .featherlight-close-icon {
  line-height: 35px;
  width: 35px;
  font-size: 20px;
  text-align: center;
  font-family: 'Noto Sans JP';
  color: #355f99;
  font-weight: 900;
}

.category-block .cate>* {
  padding: 0.5em 1em;
  font-size: 14px;
  text-align: center;
  border-radius: 5px;
}

.category-block .cate01>* {
  background: #e1ebf3;
  color: #355f99;
  border: 1px solid;
}

.category-block .cate02>* {
  background: #e4ab76;
  color: #fff;
  border: 1px solid;
}

.category-block .cate03>* {
  background: #355f99;
  color: #fff;
  border: 1px solid;
}

.category-block .cate04>* {
  background: #fffaf5;
  color: #e4ab76;
  border: 1px solid;
}

/* modal */
.modal {
  position: fixed;
  opacity: 0;
  bottom: 100%;
  transition: 0.4s;
  -webkit-transition: 0.4s;
  -ms-transition: 0.4s;
}

.modal:before {
  display: block;
  content: "";
  width: 30px;
  height: 3px;
  background: #fff;
  position: fixed;
  top: 5%;
  right: 5%;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
}

[data-element-id].modal:before {
    display: block;
    content: "";
    width: 30px;
    height: 3px;
    background: #40629d;
    position: absolute;
    top: 30px;
    right: 5%;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
}

.modal:after {
  display: block;
  content: "";
  width: 30px;
  height: 3px;
  background: #fff;
  position: fixed;
  top: 5%;
  right: 5%;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
}

[data-element-id].modal:after {
  display: block;
  content: "";
  width: 30px;
  height: 3px;
  background: #40629d;
  position: absolute;
  top: 30px;
  right: 5%;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
}

.modal.active {
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.4);
  opacity: 1;
  z-index: 500;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
}

.modal.active .modalinn {
  width: 90%;
  max-width: 1000px;
  max-height: 70vh;
  overflow: auto;
  background: #fff;
  padding: 30px;
  margin: auto;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  box-sizing: border-box;
  box-shadow: 1px 1px 10px #555;
  -webkit-overflow-scrolling: touch;
}

.modal .modalinn>* {
  display: none;
}

.modal.active .modalinn>* {
  display: block;
}

[data-element-id].modal {
    position: relative;
    opacity: 1;
    bottom: auto;
    transition: none;
    -webkit-transition: none;
    background: #fff;
    box-shadow: 3px 3px 4px 4px #ccc;
    padding: 10px;
    z-index: 3;
        border: 5px solid #40629d;
}

[data-element-id].modal.active {
    position: relative;
    width: 100%;
    height: 300px;
    opacity: 1;
}

[data-element-id].modal .modalinn>* {
    display: block;
}

[data-element-id].modal.active .modalinn {
    width: 100%;
    max-height: 30vh;
    overflow-y: scroll;
    background: #fff;
    padding: 30px;
    position: relative;
}
[data-element-id].modalinn >* div >* {
    width: 100%;
}

@media (max-width:599px) {
  .modal.active .modalinn {
    padding: 20px;
  }

  .index-faq.detail .accordion .list-cmp09 .item .modal.active .tit {
    font-size: 22px;
  }
}

/* Tab切り替え（こんな時は） */
.tabItem {
  display: none;
}

[data-element-id].tabItem {
  display: block;
}

[data-element-id] .tabItem:nth-child(1) {
    border: 5px solid #ffb4ce;
    background: #ffb4ce;
    margin-bottom: 30px;
}

[data-element-id] .tabItem:nth-child(1):before {
    content: "発熱時には";
    background-color: #ffb4ce;
    color: #fff;
    font-family: 'Kiwi Maru', serif;
    width: 100%;
    display: block;
    text-align: center;
}

[data-element-id] .tabItem:nth-child(2) {
    border: 5px solid #f44336;
    background: #f44336;
    margin-bottom: 30px;
}

[data-element-id] .tabItem:nth-child(2):before {
    content: "下痢・嘔吐時には";
    background-color: #f44336;
    color: #fff;
    font-family: 'Kiwi Maru', serif;
    width: 100%;
    display: block;
    text-align: center;
}

[data-element-id] .tabItem:nth-child(3) {
    border: 5px solid #7282dd;
    background: #7282dd;
}

[data-element-id] .tabItem:nth-child(3):before {
    content: "くすりの飲ませ方";
    background-color: #7282dd;
    color: #fff;
    font-family: 'Kiwi Maru', serif;
    width: 100%;
    display: block;
    text-align: center;
}

.tabItem.active {
  display: block;
}

.tab-btn>* {
  background: #fff;
  color: #255095;
  display: block;
  text-align: center;
  font-size: 14px;
  padding: 1em 2em;
  border-radius: 30px;
  border: 1px solid;
  cursor: pointer;
}

.tab-btn.active>*,
.tab-btn>*:hover {
  background: #255095;
  color: #fff;
  border: 1px solid #255095;
}

@media (max-width:599px) {
  .tab-btn>* {
    padding: 1em;
  }
}


[data-element-id].ab-test {
    border: 10px solid #87adc9 !important;
    box-shadow: none !important;
}

[data-element-id].ab-test::before {
    content: "ABテスト";
    color: #fff;
    background: #87adc9;
    display: block;
    font-size: 12px;
    width: 75px;
    text-align: center;
    padding: 10px 0;
    margin-left: -10px;
    font-family: 'Kiwi Maru', serif;
}

[data-ab-test-block] [data-ab-test-contents] + [data-ab-test-contents] { display: none;}



/* 2023.04.19 */





.monshinbanar{
  width: 540px;
    margin: 60px auto 0;
}

.monshinbanar img{
  width: 100%;
}

.flortjizen a{
  background: #6291cd !important;
  border-top: 2px solid #6291cd !important;
    border-bottom: 2px solid #6291cd !important;
    border-left: 2px solid #6291cd !important;
}

.flortjizen a:hover {
    background: #fff !important;
    color: #6291cd !important;
}

@media (max-width:1024px) {
.ahiruimg{
  top: 8% !important;
    right: 9% !important;
}
}

@media (max-width:599px) {
.ahiruimg {
    top: 18% !important;
    right: 0% !important;
}


.monshinbanar {
    width: 320px;
    margin: 40px auto 0;
}
}

.preliminaryimg{
  bottom: -120% !important;
    border-radius: 0px !important;
    background: none;
    width: 400px;
    left: 60%;
    position: absolute;
}

.monshinbanar{
  display: none;
}

@media (max-width:1024px) {
.preliminaryimg {
    bottom: -83% !important;
    border-radius: 0px !important;
    background: none;
    width: 400px;
    left: 52%;
}

.homevisual .head {
    top: 36%;
}

.homevisual .head .mv-duck {
    bottom: -100px;
    
}


}


@media (max-width: 1020px){
.preliminaryimg {
    bottom: -91% !important;
    border-radius: 0px !important;
    background: none;
    width: 430px;
    left: 52%;
}
}

@media (max-width:599px) {
  .monshinbanar{
    display: block;
    margin: 0px auto 20px;
    width: 90%;
  }
  
  .preliminaryimg {
  display: none !important;
}
}


.aimonshinp{
  display: none;
}

.aimonshinppc{
  font-size: 16px;
    margin-bottom: -15px;
    text-shadow: 1px 2px 3px #ffffff;
}


@media (max-width:1024px) {
  .aimonshinppc{
  display: none;
  }
}


@media (max-width:599px) {
  .aimonshinp{
  display: block;
  width: 90%;
    margin: 0 auto 8px;
    font-size: 12px;
}

  
.aimonshinppc{
  display: none;
}
}


.doctors{
  width: 45%;
    margin: 30px auto;
}

.doctors img{
  width: 100%;
}

@media (max-width: 1024px) {
  .doctors {
    width: 60%;
    margin: 30px auto;
}
}

@media (max-width:599px) {
      .doctors {
        width: 100%;
        margin: 0px auto;
    }
}

.flex-block{
  display: flex;
  justify-content: center;
}

.flex-block div{
  width: 45%;
  margin: 30px 20px 30px 0;
}

.monshin-banar{
  width: 30% !important;
    margin: 30px 0 30px 15px !important;
}

@media (max-width:599px) {
.flex-block {
    display: block;
}

.flex-block div {
    width: 95%;
    margin: 5px auto;
}

.monshin-banar {
    width: 85% !important;
    margin: 30px auto 10px !important;
}
}

.jien02{
  display: none;
}

.gnav .item01 {
    width: 12%;
    
}
@media (max-width: 1024px) {
.jien02{
  display: block;
}

.jizen02 a{
  background: #399f9d !important;
}

.fix-bottom .contact:nth-of-type(3)>* {
        min-height: 100px;
    }
    
.jizen02 a{
  min-height: 120px;
}

.navi-monshin{
  display: none;
}

.gnav .item01 {
    width: 100%;
}

.mv-fix {
        bottom: 7%;
}
}

/* 2025/08/19 */
@media(max-width:599px) {
.uk-slideshow li:first-child img{
  object-position: right;
  transform: scale(1.5);
}
}

/*訪問診療ページ改修*/
.priceinfo {
  width: 100%;
}
.priceinfo table {
  width: 100%;
  background: #fff;
}
.priceinfo table , .priceinfo td {
	border: 1px solid #858585;
	border-collapse: collapse;
}
.priceinfo td {
	padding: 2%;
	width: 20%;
}
.priceinfo .p-header {
	background: #e4ab76;
	color: #fff;
	text-align: center;
	font-size: 18px;
}
.priceinfo.info01 td {
  width: 30%;
}
.priceinfo.info01 td.kigou {
  padding: 1%;
  width: 5%;
  text-align: center;
  font-weight: bold;
}
.txt-in .mtitle {
  font-size: 24px;
  font-family: 'Kiwi Maru', serif;
}
.mt20 {
  margin-top: 20px;
}
.c-blue {
  color: #355f99;
}
.c-beige {
  color: #feeaad;
}

@media (max-width: 1024px){
  .txt-in .mtitle {
    font-size: 20px;
  }
}

@media (max-width: 599px){
  .index-intro.detail .content .duck-img {
    opacity: 0.3;
  }
  .priceinfo td {
    font-size: 14px;
  }
  .priceinfo .p-header {
    font-size: 16px;
  }
  .priceinfo.info01 td.kigou {
    padding: 5px;
  }
  .txt-in .mtitle {
    font-size: 18px;
  }
}

/* 2025/12/04 */

/* 訪問診療タブ（現行DOMに合わせて再定義） */

  #visit .visit-tab-head .js-visit-tab-nav{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 50px;

  /* 2枚目っぽい“帯の中の余白”を作る */
  padding: 18px 0 28px;
  margin: 0;

  list-style: none;
}

  #visit .visit-tab-head .js-visit-tab-nav li{
  margin: 0;
}

/* ★aではなくbuttonを装飾 */
  #visit .visit-tab-head .js-visit-tab-nav [role="tab"]{
  min-height: 50px;
  padding: 0 18px;
  border-radius: 10px;

  background: #30498c;
  border: 1px solid transparent;
  color: #fff;

  display: flex;
  align-items: center;
  justify-content: center;

  cursor: pointer;
  font: inherit;              /* フォント崩れ防止 */
  line-height: 1;             /* 高さ暴れ防止 */
  white-space: nowrap;        /* 1行固定 */
  -webkit-appearance: none;   /* iOS/Safariのボタン癖対策 */
  appearance: none;
}

/* 非アクティブ（白背景＋枠） */
  #visit .visit-tab-head .js-visit-tab-nav [role="tab"]:not(.is-active){
  background: #fff;
  border-color: #30498c;
  color: #30498c;
}

/* hover（確実版） */
  #visit .visit-tab-head .js-visit-tab-nav [role="tab"]:hover{
  background-color: #fff !important;
  border-color: #30498c !important;
  color: #30498c !important;
  opacity: 1;
}

  #visit .visit-tab-head .js-visit-tab-nav [role="tab"]:not(.is-active):hover{
  background-color: #30498c !important;
  border-color: #fff !important;
  color: #fff !important;
  opacity: 1;
}


/* キーボード操作時の視認性（アクセシビリティ） */
  #visit .visit-tab-head .js-visit-tab-nav [role="tab"]:focus-visible{
  outline: 2px solid #30498c;
  outline-offset: 3px;
}

/* SPだけ詰める（必要なら） */
@media (max-width: 599px){
    #visit .visit-tab-head .js-visit-tab-nav{
    gap: 14px;
    padding: 14px 0 20px;
    flex-wrap: wrap;
  }
    #visit .visit-tab-head .js-visit-tab-nav [role="tab"]{
    min-height: 44px;
    padding: 0 12px;
  }
}

/* #visit .index-intro .link-list{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 50px;  
}

#visit .index-intro .link-list li{
  height: 50px;
  display: grid;
  place-content: center;
  padding: 0px 10px;
  border-radius: 10px;
  background: #30498c;
}

#visit .index-intro .link-list li:last-of-type{
  background-color: #fff;
  border: 1px solid #30498c;
}

#visit .index-intro .link-list li a{
  width: 100%;
  height: 100%;
  color: #fff;
}

#visit .index-intro .link-list li:last-of-type a{
  color: #30498c;
}

#visit .index-intro .link-list li:hover{
  border: 1px solid #30498c;
  background-color: #fff;
}

#visit .index-intro .link-list li:hover a{
  color: #30498c;
}


#visit .index-intro .link-list li:last-of-type:hover{
  border: 1px solid #fff;
  background-color: #30498c;
}

#visit .index-intro .link-list li:last-of-type:hover a{
  color: #fff;
}
 */
/* ============================================
   ダウンロードボタン - hover時アイコン切り替え
============================================ */

#visit .index-intro .download-btn {
  height: 50px;
  border-radius: 10px;
  background: #6291cd;
  width: 42%;
  margin-bottom: 15px;
  border: 2px solid #6291cd;
  transition: background 0.3s ease, border-color 0.3s ease;
}

#visit .index-intro .download-btn:hover {
  background: #fff;
  border-color: #6291cd;
}

#visit .index-intro .download-btn a {
  color: #fff;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s ease;
}

#visit .index-intro .download-btn:hover a {
  color: #6291cd;
}

#visit .index-intro .download-btn a span.link-txt {
  margin-right: 10px;
}

#visit .index-intro .download-btn a span.link-icn {
  width: 20px;
  height: 20px;
  display: block;
  position: relative;
}

/* 通常時のアイコン */
#visit .index-intro .download-btn a span.link-icn .icon-default {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 0.3s ease;
}

/* hover時のアイコン（通常は非表示） */
#visit .index-intro .download-btn a span.link-icn .icon-hover {
  width: 100%;
  height: 100%;
  object-fit: contain;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* hover時：通常アイコンを非表示、hoverアイコンを表示 */
#visit .index-intro .download-btn:hover a span.link-icn .icon-default {
  opacity: 0;
}

#visit .index-intro .download-btn:hover a span.link-icn .icon-hover {
  opacity: 1;
}


/* ============================================
   HTML構造（参考）
   
   <div class="download-btn">
     <a href="javascript:void(0)" data-href="">
       <span class="link-txt">当院訪問診療のパンフレット</span>
       <span class="link-icn">
         <img class="icon-default" src="/upload/tenant_1/ダウンロードアイコン.png" alt="アイコン">
         <img class="icon-hover" src="/upload/tenant_1/ダウンロードアイコン_hover.png" alt="アイコン">
       </span>
     </a>
   </div>
   
============================================ */
/* #visit .index-intro .download-btn:hover{
 background-color: #fff;
 color: #30498c;
 border: 1px solid #30498c;
}


#visit .index-intro .download-btn:hover a{
 color: #30498c;
} */

@media screen and (min-width:600px) and (max-width:1024px) {
#visit .index-intro.detail .content .duck-img{
  bottom: 17%;  
}

#visit .index-intro .download-btn{
width: 68%;
}
}

@media screen and (max-width:599px) {
#visit .index-intro.detail .content .duck-img{
  bottom: 23%;  
}

#visit .index-intro .link-list{
    flex-direction: column;
    gap: 10px;
    margin-top: 50px;
}

#visit .index-intro .link-list li{
  width: 80%;
}

#visit .index-intro .download-btn{
  width: 68%;
  margin-right: auto;
  margin-left: auto;
}

#visit .index-intro .download-btn {
  width: 80%;
    margin-bottom: 15px;
}
}

/* 目次 */

.tablelist ul {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    background: #f0f5f8;
    padding: 20px;
    border-radius: 10px;
}

.tablelist ul li {
    font-size: 16px;
    color: #30498c;
    width: 100%;
    border-bottom: 1px dashed;
    font-weight: bold;
}

/* ============================================
       5つの特徴セクション (#visit内限定)
   ============================================ */
/* #visit .features-section {
  padding: 80px 0 100px;
  background: #ecf1f6;
  position: relative;
  overflow: hidden;
} */

#visit .features-container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
}

/* セクションヘッダー */
#visit .features-header {
  text-align: center;
  margin-bottom: 50px;
}

#visit .features-header__en {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 2.5rem;
  font-weight: 400;
  color: #4A7C9B;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}

#visit .features-header__ja {
  font-size: 1.4rem;
  font-weight: 500;
  color: #4A7C9B;
  letter-spacing: 0.1em;
}

/* 上段：2カラム */
#visit .features-top-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  margin-bottom: 30px;
}

/* 下段：3カラム */
#visit .features-bottom-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

/* 特徴アイテム */
#visit .feature-item {
  display: flex;
  flex-direction: column;
}

/* 特徴ヘッダー部分 */
#visit .feature-item__header {
  background: #84b5d3;
  padding: 20px 25px;
  display: flex;
  align-items: center;
  gap: 15px;
  border-radius: 10px 10px 0 0;
  min-height: 80px;
}

#visit .feature-item__number {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.2);
  border: 2px solid rgba(255, 255, 255, 0.6);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem;
  font-weight: 500;
  color: #fff;
  flex-shrink: 0;
}

#visit .feature-item__title {
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

/* 特徴コンテンツ部分 */
#visit .feature-item__content {
  padding: 20px 25px;
  background: #fff;
  border: 1px solid #e5e5e5;
  border-top: none;
  border-radius: 0 0 10px 10px;
  flex-grow: 1;
}

#visit .feature-item__text {
  font-size: 16px;
  line-height: 1.9;
}

/* ============================================
       タブレット（1024px以下）
   ============================================ */
@media screen and (max-width: 1024px) {
  #visit .features-section {
    padding: 60px 0 80px;
  }

  #visit .features-header {
    margin-bottom: 40px;
  }

  #visit .features-header__en {
    font-size: 2rem;
  }

  #visit .features-header__ja {
    font-size: 1.2rem;
  }

  #visit .features-top-row {
    gap: 20px;
    margin-bottom: 20px;
  }

  #visit .features-bottom-row {
    gap: 20px;
  }

  #visit .feature-item__header {
    padding: 15px 20px;
    gap: 12px;
    min-height: 70px;
  }

  #visit .feature-item__number {
    width: 36px;
    height: 36px;
    font-size: 1.2rem;
  }

  #visit .feature-item__title {
    font-size: 0.9rem;
  }

  #visit .feature-item__content {
    padding: 15px 20px;
  }

  #visit .feature-item__text {
    font-size: 0.85rem;
    line-height: 1.8;
  }
}

/* ============================================
       スマートフォン（599px以下）
   ============================================ */
@media screen and (max-width: 599px) {
  #visit .features-section {
    padding: 50px 0 60px;
  }

  #visit .features-container {
    padding: 0 15px;
  }

  #visit .features-header {
    margin-bottom: 30px;
  }

  #visit .features-header__en {
    font-size: 1.75rem;
  }

  #visit .features-header__ja {
    font-size: 1.05rem;
  }

  #visit .features-top-row {
    grid-template-columns: 1fr;
    gap: 15px;
    margin-bottom: 15px;
  }

  #visit .features-bottom-row {
    grid-template-columns: 1fr;
    gap: 15px;
  }

  #visit .feature-item__header {
    padding: 15px;
    gap: 12px;
    min-height: auto;
    border-radius: 8px 8px 0 0;
  }

  #visit .feature-item__number {
    width: 32px;
    height: 32px;
    font-size: 1.1rem;
  }

  #visit .feature-item__title {
    font-size: 18px;
  }

  #visit .feature-item__content {
    padding: 15px;
    border-radius: 0 0 8px 8px;
  }

  #visit .feature-item__text {
    font-size: 16px;
    line-height: 1.8;
    
  }
}

/* 訪問診療とは */

#visit .aboutarea .mtitle{
    font-size: 24px;
    font-family: 'Kiwi Maru', serif;

}

#visit #recommend .sub-ttl{
    font-size: 24px;
    font-family: 'Kiwi Maru', serif;
    margin-bottom: 50px;
    color: #355f99;
}

/* ============================================
       流れセクション (#visit内限定)
   ============================================ */
#visit .flow-section {
  padding: 80px 0 100px;
  background: linear-gradient(135deg, #d0dce5 0%, #b8c9d8 50%, #a0b5c8 100%);
  position: relative;
  overflow: hidden;
}

#visit .flow-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
}

/* セクションヘッダー */
#visit .flow-header {
  text-align: center;
  margin-bottom: 60px;
}

#visit .flow-header__en {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 2.5rem;
  font-weight: 400;
  color: #4A7C9B;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}

#visit .flow-header__ja {
  font-size: 1.4rem;
  font-weight: 500;
  color: #4A7C9B;
  letter-spacing: 0.1em;
}

/* ステップグリッド - 2x2 */
#visit .flow-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 35px;
}

/* 各ステップカード */
#visit .flow-card {
  background: #fff;
  border-radius: 15px;
  box-shadow: 0 5px 30px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

#visit .flow-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

/* 画像エリア */
#visit .flow-card__image {
  position: relative;
  height: 340px;
  overflow: hidden;
}

#visit .flow-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

#visit .flow-card:hover .flow-card__image img {
  transform: scale(1.05);
}

/* 画像プレースホルダー */
#visit .flow-card__image-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #4A7C9B 0%, #5a8fad 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

#visit .flow-card__image-placeholder span {
  color: #fff;
  font-size: 1rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.8;
}

/* ナンバーバッジ */
#visit .flow-card__number {
  position: absolute;
  top: 15px;
  left: 15px;
  width: 45px;
  height: 45px;
  z-index: 11;
  background: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: #4A7C9B;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

/* コンテンツエリア */
#visit .flow-card__content {
  padding: 25px 30px 30px;
}

#visit .flow-card__header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid #e8e8e8;
}

#visit .flow-card__title {
  font-size: 1.2rem;
  font-weight: 700;
  color: #4A7C9B;
}

#visit .flow-card__subtitle {
  font-size: 0.85rem;
  font-weight: 400;
  color: #888;
}

#visit .flow-card__tel {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 20px;
  background: #4A7C9B;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 500;
  text-decoration: none;
  border-radius: 25px;
  transition: background 0.3s ease;
  margin-left: auto;
}

#visit .flow-card__tel:hover {
  background: #3d6a87;
}

#visit .flow-card__text {
  font-size: 0.9rem;
  line-height: 1.9;
  color: #555;
}

#visit .flow-card__text div {
  margin-bottom: 10px;
  color: #000;
}

#visit .flow-card__text p:last-child {
  margin-bottom: 0;
}

#visit .flow-card__label {
  font-weight: 700;
  color: #4A7C9B;
  display: block;
  margin-top: 12px;
  margin-bottom: 5px;
  font-size: 0.9rem;
}

/* ============================================
       タブレット（1024px以下）
   ============================================ */
@media screen and (max-width: 1024px) {
  #visit .flow-section {
    padding: 60px 0 80px;
  }

  #visit .flow-header {
    margin-bottom: 45px;
  }

  #visit .flow-header__en {
    font-size: 2rem;
  }

  #visit .flow-header__ja {
    font-size: 1.2rem;
  }

  #visit .flow-grid {
    gap: 25px;
  }

  #visit .flow-card__image {
    height: 180px;
  }

  #visit .flow-card__number {
    width: 40px;
    height: 40px;
    font-size: 1.2rem;
  }

  #visit .flow-card__content {
    padding: 20px 25px 25px;
  }

  #visit .flow-card__title {
    font-size: 1.1rem;
  }

  #visit .flow-card__text {
    font-size: 0.85rem;
  }

  #visit .flow-card__tel {
    font-size: 0.85rem;
    padding: 6px 15px;
  }
}

/* ============================================
       スマートフォン（599px以下）
   ============================================ */
@media screen and (max-width: 599px) {
  #visit .flow-section {
    padding: 50px 0 60px;
  }

  #visit .flow-container {
    padding: 0 15px;
  }

  #visit .flow-header {
    margin-bottom: 35px;
  }

  #visit .flow-header__en {
    font-size: 1.75rem;
  }

  #visit .flow-header__ja {
    font-size: 1.05rem;
  }

  #visit .flow-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  #visit .flow-card {
    border-radius: 12px;
  }

  #visit .flow-card__image {
    height: 200px;
  }

  #visit .flow-card__image-placeholder span {
    font-size: 0.95rem;
  }

  #visit .flow-card__number {
    width: 38px;
    height: 38px;
    font-size: 1.1rem;
    top: 12px;
    left: 12px;
  }

  #visit .flow-card__content {
    padding: 20px;
  }

  #visit .flow-card__header {
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 12px;
  }

  #visit .flow-card__title {
    font-size: 1.05rem;
  }

  #visit .flow-card__subtitle {
    width: 100%;
    order: 3;
  }

  #visit .flow-card__tel {
    width: 100%;
    justify-content: center;
    margin-left: 0;
    margin-top: 8px;
    order: 4;
    padding: 10px 20px;
  }

  #visit .flow-card__text {
    font-size: 0.85rem;
    line-height: 1.8;
  }
}
/* セクションヘッダー */
#visit .cost-header {
  text-align: center;
  margin-bottom: 40px;
}

#visit .cost-header__en {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 2.5rem;
  font-weight: 400;
  color: #4A7C9B;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}

#visit .cost-header__ja {
  font-size: 1.4rem;
  font-weight: 500;
  color: #4A7C9B;
  letter-spacing: 0.1em;
}

/* 説明ボックス */
#visit .cost-intro {
  background: #fff;
  border-radius: 15px;
  padding: 30px 35px;
  margin-bottom: 40px;
  box-shadow: 0 3px 15px rgba(74, 124, 155, 0.08);
  position: relative;
}

#visit .cost-intro::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  background: linear-gradient(90deg, #4A7C9B, #7BA3B8);
  border-radius: 15px 15px 0 0;
}

#visit .cost-intro__text {
  font-size: 16px;
  line-height: 2;
}

/* 保険診療エリア */
#visit .cost-insurance {
  background: #fff;
  border-radius: 15px;
  padding: 35px;
  box-shadow: 0 3px 15px rgba(74, 124, 155, 0.08);
}

#visit .cost-insurance__header {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 20px;
}

#visit .cost-insurance__icon {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, #4A7C9B 0%, #6a9bb5 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

#visit .cost-insurance__icon svg {
  width: 26px;
  height: 26px;
  fill: #fff;
}

#visit .cost-insurance__title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #4A7C9B;
}

#visit .cost-insurance__notes {
  background: #f5f8fa;
  border-radius: 10px;
  padding: 15px 20px;
  margin-bottom: 30px;
  border-left: 4px solid #4A7C9B;
}

#visit .cost-insurance__note {
  font-size: 0.9rem;
  margin-bottom: 5px;
}

#visit .cost-insurance__note:last-child {
  margin-bottom: 0;
}

#visit .cost-insurance__example {
  font-size: 0.85rem;
}

/* 料金カード */
#visit .cost-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px;
}

#visit .cost-card {
  border: 1px solid #e0e8ed;
  border-radius: 12px;
  overflow: hidden;
  transition: box-shadow 0.3s ease;
}

#visit .cost-card:hover {
  box-shadow: 0 5px 20px rgba(74, 124, 155, 0.12);
}

#visit .cost-card__header {
  background: linear-gradient(135deg, #4A7C9B 0%, #5a8dad 100%);
  color: #fff;
  padding: 15px 20px;
  text-align: center;
}

#visit .cost-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

#visit .cost-card__body {
  padding: 0;
}

#visit .cost-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
  border-bottom: 1px solid #f0f0f0;
}

#visit .cost-card__row:last-child {
  border-bottom: none;
}

#visit .cost-card__row:nth-child(odd) {
  background: #fafcfd;
}

#visit .cost-card__label {
  font-size: 0.9rem;
}

#visit .cost-card__price {
  font-size: 1.1rem;
  font-weight: 700;
  color: #4A7C9B;
}

#visit .cost-card__price small {
  font-size: 0.8rem;
  font-weight: 400;
}

/* ============================================
       タブレット（1024px以下）
   ============================================ */
@media screen and (max-width: 1024px) {
  #visit .cost-section {
    padding: 60px 0 80px;
  }

  #visit .cost-header {
    margin-bottom: 35px;
  }

  #visit .cost-header__en {
    font-size: 2rem;
  }

  #visit .cost-header__ja {
    font-size: 1.2rem;
  }

  #visit .cost-intro {
    padding: 25px 30px;
    margin-bottom: 35px;
  }

  #visit .cost-intro__text {
    font-size: 0.9rem;
  }

  #visit .cost-insurance {
    padding: 30px;
  }

  #visit .cost-insurance__title {
    font-size: 1.15rem;
  }

  #visit .cost-cards {
    gap: 20px;
  }

  #visit .cost-card__header {
    padding: 12px 15px;
  }

  #visit .cost-card__title {
    font-size: 1rem;
  }

  #visit .cost-card__row {
    padding: 12px 15px;
  }

  #visit .cost-card__label {
    font-size: 0.85rem;
  }

  #visit .cost-card__price {
    font-size: 1rem;
  }
}

/* ============================================
       スマートフォン（599px以下）
   ============================================ */
@media screen and (max-width: 599px) {
  #visit .cost-section {
    padding: 50px 0 60px;
  }

  #visit .cost-container {
    padding: 0 15px;
  }

  #visit .cost-header {
    margin-bottom: 30px;
  }

  #visit .cost-header__en {
    font-size: 1.75rem;
  }

  #visit .cost-header__ja {
    font-size: 1.05rem;
  }

  #visit .cost-intro {
    padding: 20px;
    margin-bottom: 25px;
    border-radius: 12px;
  }

  #visit .cost-intro__text {
    font-size: 0.85rem;
    line-height: 1.9;
  }

  #visit .cost-insurance {
    padding: 20px;
    border-radius: 12px;
  }

  #visit .cost-insurance__header {
    gap: 12px;
    margin-bottom: 15px;
  }

  #visit .cost-insurance__icon {
    width: 42px;
    height: 42px;
  }

  #visit .cost-insurance__icon svg {
    width: 22px;
    height: 22px;
  }

  #visit .cost-insurance__title {
    font-size: 1.1rem;
  }

  #visit .cost-insurance__notes {
    padding: 12px 15px;
    margin-bottom: 20px;
  }

  #visit .cost-insurance__note {
    font-size: 0.85rem;
  }

  #visit .cost-insurance__example {
    font-size: 0.8rem;
  }

  #visit .cost-cards {
    grid-template-columns: 1fr;
    gap: 15px;
  }

  #visit .cost-card {
    border-radius: 10px;
  }

  #visit .cost-card__header {
    padding: 12px 15px;
  }

  #visit .cost-card__title {
    font-size: 0.95rem;
  }

  #visit .cost-card__row {
    padding: 12px 15px;
  }

  #visit .cost-card__label {
    font-size: 0.85rem;
  }

  #visit .cost-card__price {
    font-size: 1rem;
  }
}

/* ============================================
       関係機関向けセクション (#visit内限定)
   ============================================ */
#visit .partners-section {
  padding: 80px 0;
  background: #eff1f7;
  position: relative;
  overflow: hidden;
}

/* 背景装飾 */
#visit .partners-section::before {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 300px;
  height: 300px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 50%;
}

#visit .partners-section::after {
  content: '';
  position: absolute;
  bottom: -80px;
  left: -80px;
  width: 250px;
  height: 250px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 50%;
}

#visit .partners-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
}

/* ヘッダー */
#visit .partners-header {
  text-align: center;
  margin-bottom: 40px;
}

#visit .partners-header__en {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 2.2rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}

#visit .partners-header__title {
display: inline-block;
    font-size: 1.2rem;
    font-weight: 500;
    color: #4a7c9b;
    letter-spacing: 0.08em;
    padding: 12px 35px;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 50px;
    background: #fff;
}

/* コンテンツ */
#visit .partners-content {
  background: #fff;
  border-radius: 15px;
  padding: 35px 40px;
  margin-bottom: 30px;
  backdrop-filter: blur(5px);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

#visit .partners-list {
  list-style: none;
}

#visit .partners-list__item {
    position: relative;
    padding-left: 20px;
    margin-bottom: 18px;
    font-size: 0.95rem;
    font-weight: bold;
    line-height: 1.9;
    color: #4a7c9b;
}

#visit .partners-list__item:last-child {
  margin-bottom: 0;
}

#visit .partners-list__item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 8px;
  background: #fff;
  border-radius: 50%;
  opacity: 0.8;
}

/* フッターメッセージ */
#visit .partners-footer {
    background: rgb(76 126 156);
    border-radius: 12px;
    padding: 25px 35px;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

#visit .partners-footer__text {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.9;
  color: #fff;
  letter-spacing: 0.03em;
}

/* ============================================
       タブレット（1024px以下）
   ============================================ */
@media screen and (max-width: 1024px) {
  #visit .partners-section {
    padding: 60px 0;
  }

  #visit .partners-header {
    margin-bottom: 35px;
  }

  #visit .partners-header__en {
    font-size: 1.8rem;
  }

  #visit .partners-header__title {
    font-size: 1.1rem;
    padding: 10px 30px;
  }

  #visit .partners-content {
    padding: 30px;
    margin-bottom: 25px;
  }

  #visit .partners-list__item {
    font-size: 0.9rem;
    margin-bottom: 15px;
  }

  #visit .partners-footer {
    padding: 20px 30px;
  }

  #visit .partners-footer__text {
    font-size: 0.95rem;
  }
}

/* ============================================
       スマートフォン（599px以下）
   ============================================ */
@media screen and (max-width: 599px) {
  #visit .partners-section {
    padding: 50px 0;
  }

  #visit .partners-section::before,
  #visit .partners-section::after {
    display: none;
  }

  #visit .partners-container {
    padding: 0 15px;
  }

  #visit .partners-header {
    margin-bottom: 25px;
  }

  #visit .partners-header__en {
    font-size: 1.5rem;
    margin-bottom: 8px;
  }

  #visit .partners-header__title {
    font-size: 0.95rem;
    padding: 10px 20px;
    letter-spacing: 0.03em;
  }

  #visit .partners-content {
    padding: 25px 20px;
    margin-bottom: 20px;
    border-radius: 12px;
  }

  #visit .partners-list__item {
    font-size: 0.85rem;
    line-height: 1.85;
    padding-left: 18px;
    margin-bottom: 15px;
  }

  #visit .partners-list__item::before {
    width: 6px;
    height: 6px;
    top: 10px;
  }

  #visit .partners-footer {
    padding: 20px 15px;
    border-radius: 10px;
  }

  #visit .partners-footer__text {
    font-size: 0.85rem;
    line-height: 1.8;
  }
}

/* 2025/12/16 */

#visit #link04 .overx-hide{
 overflow-x: hidden;  
}

#visit #link04 .b-radius30{
  border-radius: 30px;
}

@media screen and (max-width:599px) {
#visit #link04 .b-radius30 img{
  width: 100%;
}
}

#visit .index-intro.bgc-blue{
  background-color: #ecf1f6;
}

#visit .visit-tab-head.bgc-blue{
  background-color: #ecf1f6;
}

#visit .section-py-medium.bgc-blue{
  background-color: #bcdae9;
}

   #visit .tp260305{
  padding-top: 20px;
}

/* 2026/03/06 */
/* 処置リスト */
  #visit .treatment-list ol {
  counter-reset: treatment-counter;
  columns: 2;
  column-gap: 40px;
  list-style: none;
  padding: 0;
  margin: 0;
}

  #visit .treatment-list ol li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 16px;
  line-height: 2;
  padding: 7px 0;
  border-bottom: 1px solid #e8f2f8;
  break-inside: avoid;
}

  #visit .treatment-list ol li::before {
  content: '';
  display: inline-block;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  background: #355f9f;
  border-radius: 50%;
  margin-top: 7px;
  position: relative;
    top: -2px;
}

/* タブレット: 1024px以下 */
@media (max-width: 1024px) {
    #visit .treatment-list ol {
    column-gap: 28px;
  }
}

/* SP: 599px以下 */
@media (max-width: 599px) {
    #visit .treatment-list ol {
    columns: 1;
  }
}

  #visit .cost-insurance.pi-0{
  padding: 0px !important;
}

  #visit #link04 .overview-box .cost-insurance__icon {
  background: #355f9f;
}

  #visit #link04 .cost-insurance__title {
  color: #355f9f;
}

@media screen and (max-width:599px) {
  #visit .treatment-list ol li {
  font-size: 14px;
} 
}

