@charset "UTF-8";




:root {
  /* メインブランドカラー */
  --color-brand-primary: #F29600;     /* メイングリーン */
  --color-brand-accent: #8dc21f;      /* アクセントオレンジ */
  
  /* プライマリカラー（グリーン）のバリエーション */
  --color-brand-green-light: #def4a2;  /* #DEF4A2 */
  --color-brand-green-middle:#3b7500; /* #82AE46 #649b00*/
  --color-brand-green-dark: #175100;
  
  /* アクセントカラー（オレンジ）のバリエーション */
  --color-brand-orange-light:#ffcf4f;
  --color-brand-orange-middle: #e27600;
  --color-brand-orange-dark: #e27600;
  

  /* 背景色として使用できるバリエーション */
  --color-bg-primary-pale: #fff8e8;   /* 薄い背景 #f2f8e6 #fff9ee */
  --color-bg-accent-pale: #fff5e6;    /* 薄いオレンジ背景 */
  --color-bg-tertiary-pale: #F9F5F0;    /* 薄いベージュ背景 */
}
/* var() で書けば色変えたら反映されるので使いやすいかも。  */

.txt_primary{
  color:var(--color-brand-primary);
}
.txt_accent{
  color:var(--color-brand-accent);
}

/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Layout & Structure Classes

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/



.wrap {
margin: 0 auto;
}


.inner {
    width: calc(100% - 50px);
    max-width: 1000px;
    margin: 0 auto;
}

@media (max-width: 768px) {
  .inner {
    width: calc(100% - 50px);
    }
}



.content__w{
  position: relative;
  padding-bottom: 10rem;

}
/*sp*/
@media (max-width: 768px) {
.content__w{
  padding-bottom: 6rem;
}
}
.content__w::before {
    content: "";
    position: absolute;
    top: 0px;
    left: auto;
    right: auto;
    height: 100%;
    width: 100%;
    z-index: -1;
    background: url(../images/silhouette_beige.svg) no-repeat;
    background-size: cover;
    background-position: right;
    background-position: top;
    opacity: 0.3;
}
/*sp*/
@media (max-width: 768px) {
  .content__w::before {
    content: "";
    position: absolute;
    height: 100%;
    background-position: right;
    opacity: 0.5;
}
}

.laneboxwrap{
  display: flex;
  gap:3rem 4rem;
  display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  text-align: left;
}


.doctor .inner{
max-width: 900px;
}
.doctor_career .inner{
max-width: 860px;
}


/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Header & Navigation Classes

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/








/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Mainvisual/firstview & catch Classes

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/

.catchtop_img {
  background-image: url("../images/pre-mainimage-pc.jpg");
  background-size: cover;
}
.catchtop {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat
}
.catch_main_wrap {
  display: grid;
  position: relative;
  justify-content: center;
  text-align: center;
  position: absolute;
  z-index: 2;
  left: 0;
  right: 0;
  gap: 1rem;
}
@media (max-width: 768px) {
  .catch_main_wrap {
    display: grid;
    justify-content: center;
    text-align: center;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 2;
    gap: 1rem;
  }
}



.catch_main_ttl{
      font-size: 2.8rem;
  font-size: 3.2rem;
      background: rgba(242, 251, 253, 0.6);
  background: rgba(255, 255, 255, 0.6);
    padding: 1.6rem 2rem 1.6rem 2rem;
    border-radius: 2rem;
    justify-self: center;
}
@media (max-width: 768px) {
.catch_main_ttl {
      font-size: 2.2rem;
   padding: 1rem 1.4rem;
        border-radius: 1rem;
}
}
.catch_main_ttl span{
    color: #004e9c;
  padding-left: 1rem;
}
.catch_main_ttl img{
  max-width: 600px;
  width: 100%;
}
@media (max-width: 768px) {
.catch_main_ttl img{
  width: 100%;
}
}


.catch_main_ttl .mv_title_sub {
    font-size: 20px;
    font-weight: 700;
  background-color: var(--color-brand-primary);
  color: #fff;
    border-radius: 50vh;
  border-radius: 1.2rem;
    padding: 0.4rem 1rem;
    max-width: 460px;
}
@media (max-width: 768px) {
  .catch_main_ttl .mv_title_sub {
    font-size: 16px;
  }
}


.catch_main_txt{
  font-size: 1.8rem;
    font-size: 2.6rem;
}
@media (max-width: 768px) {
.catch_main_txt{
  font-size: 1.5rem;
}
}

.catch_main_txt span{
  background: linear-gradient(transparent 60%, #f2fbfd 60%);
}



.catch_contents{
    background: rgba(255, 255, 255, 0.7);
  background: rgba(242, 251, 253, 0.7);
    position: absolute;
    padding: 2rem 1.6rem;
  /*  border-radius: 1.6rem; */
    top: calc(74% - 100px);
    right: 0;
    background-size: 100% auto;
    width: 520px;
    height: 200px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;

    width: 100%;
    height: 120px;
    top: calc(90% - 40px);
    right: 0;
    background-size: 100% auto;
}
@media (max-width: 768px) {
.catch_contents{
    width: 85%;
         height: 124px;
        left: 0;
        right: 0;
        margin: 0 auto;
        width: 100%;
        top: calc(95% - 100px);
        padding: 1.2rem 1.6rem 1rem;
}
}


.catch_subcontents {
    position: absolute;
    top: calc(100vh - 170px);
    width: 75%;
    z-index: 1;
}
@media (max-width: 768px) {
  .catch_subcontents {
    position: absolute;
    top: calc(100vh - 160px);
    width: 90%;
    z-index: 1;
}
}

.catch_sub_wrap{
    /*  text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, 0 -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF; */
      display: flex;
    flex-wrap: wrap;
    justify-content: center;
  background: rgba(242, 251, 253, 0.7);
   padding: 2rem 2rem;
    padding-left: 8%;
    width: 100%;
    border-top-right-radius: 1rem;
    border-bottom-right-radius: 1rem;
    gap: 1rem 10%;
}
@media (max-width: 768px) {
  .catch_sub_wrap{
      padding: 1.6rem 2rem;
  }
}

.catch_sub{
    font-size: 2.5rem;
    letter-spacing: 2.1px;
      font-weight: 500;
    padding-bottom: 0.6rem;
      font-size: 3rem;
    font-weight: 600;
}
@media (max-width: 768px) {
.catch_sub{
  font-size: 1.6rem;
font-size: 1.8rem;
        line-height: 1.2;
}
}

.catch_sub_ttl{
    font-weight: 600;
    font-size: 4rem;
    display: flex;
    gap: 1rem;
    vertical-align: middle;
    align-items: baseline;
    justify-content: center;
  font-weight: 600;
    font-size: 3rem;
    display: flex;
    gap: 1rem;
    vertical-align: middle;
    align-items: baseline;
    letter-spacing: 0.05em;
}
@media (max-width: 768px) {
.catch_sub_ttl{
    font-size: 2.6rem;
    display: flex;
    gap: 0.4rem;
  flex-wrap: wrap;
}
}

.catch_sub_ttl span{
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    font-size: 7.2rem;
  color: #004e9c;
}
@media (max-width: 768px) {
.catch_sub_ttl span{
  font-size: 4.4rem;
}
}

.catch_sub_txt{
    font-size: 5rem;
    font-weight: 700;
    letter-spacing: 0.15em;
}
@media (max-width: 768px) {
.catch_sub_txt{
  font-size: 3.4rem;
}
}



.firstview{
  position: relative;
    padding: 1rem;

}



.toparea_back {
  background: url("../images/topmv/topmv.jpeg");
  background-size: cover;
          height: calc(100vh - 50px);
  background-position: center;
  border-radius: 1rem;
}

/*sp*/
@media all and (max-width:1024px) {
  .toparea_back {
 /* background: url(../images/bg_ornament_2.png);*/
  background-size: cover;
        height: calc(100vh - 140px);
            max-height: 620px;
  }
}

/*sp*/
@media all and (max-width:768px) {
  .toparea_back {
 /* background: url(../images/bg_ornament_2.png);*/
  background-size: cover;
        height: calc(100vh - 140px);
            max-height: 600px;
  }
}








/*　左右分割タイプ　*/

.mv_bg{
        position: relative;
        overflow: hidden;
      /*  background: linear-gradient(350deg, transparent 0%, transparent 60%, #e3f3fc 50%, #e3f3fc 100%); */
     /*   width: calc(100vw - 62px / 2); */
}
@media screen and (max-width: 768px) {
  .mv_bg{
    position: relative;
    overflow: hidden;
   /* background: linear-gradient(350deg, transparent 0%, transparent 60%, #e3f3fc 50%, #e3f3fc 100%);*/
  }
}

.mv_bg::before{
  content: "";
    position: absolute;
    top: 0;
    left: 0;
  height: 100%;
    width: 100%;
    background: url("../images/bg/svg_wave_orange.svg") no-repeat right top / 100% auto;
  transform: rotate(180deg);
}
@media screen and (max-width: 768px) {
  .mv_bg::before{
  content: "";
    position: absolute;
    top: 0;
    left: 0;
  height: 100%;
    width: 100%;
    background: url("../images/bg/svg_wave_orange.svg") no-repeat left top / auto ;
}
}

.mv_bg::after{
  content: "";
    position: absolute;
 top:0;
  z-index:-1;
    left: 0;
    height: 100%;
    width: 100%;
    background: url("../images/bg/light-orange_wave_bg.svg") no-repeat right top / 100% auto;
}



.mv_wrap{
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    position: relative;
    margin-left: auto;
    margin-right: auto;
    gap: 2rem 8rem;
    margin-top: 2.8rem;
    margin-bottom: 10rem;
    padding: 0 2rem;  
    }
@media screen and (max-width: 1024px) {
  .mv_wrap {
    flex-direction: column-reverse;
    padding: 0 2rem;
    margin-top: 2rem;
    margin-bottom: 4rem;
  }
}




.mv_banner{
  display: grid;
  grid-template-columns: repeat(3, minmax(100px, 1fr));
 /* margin: 0 auto; */
  grid-gap: 1em; 
  align-items: center;
          max-width: 550px;
        margin-top: 4rem;
}

.mv_catch{

}

.mv_img{
    width: 100%;
    height: 100%;
    border-top-left-radius: 2rem;
    border-bottom-left-radius: 2rem;
  border-radius: 2rem;
    overflow: hidden;
    margin-left: auto;
    object-fit: cover;
    object-position: top;
    /* display: block; */
    /* box-sizing: border-box; */
    height: 740px;
      height: calc(100vh - 6rem); /* 大体mv_wrapのmargin分くらいひいてる */
      background: #FFF;
  border: solid 2px var(--color-brand-primary);
  }

@media screen and (max-width: 1024px) {
.mv_img {
        margin-left: auto;
        width: 100%;
        border-radius: 1rem;
        margin-left: auto;
        height: auto;
        height: calc(100vh - 18em);
          max-height: 480px;
  }
}

  .mv_img img{
        width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.7;
  }



.mv_leftContents {
  /* display: flex;
  flex: 1; */
              text-align: center;
  align-items: center;
  justify-content: center;
    width: calc(70% - 80px);
    padding-left: 6rem;
  /* max-width: 660px; */
  min-width: 450px;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .mv_leftContents {
     width: 100%;
    padding-left: 0rem;
        min-width: fit-content;
  }
  }
@media screen and (max-width: 768px) {
  .mv_leftContents {
        padding: 0;
        width: 100%;
  }
}

.mv_title{
/*
  display: flex;
flex-wrap: wrap;
*/
}

.mv_title h1{
    font-size: 4rem;
    font-weight: 700;
    height: auto;
    letter-spacing: 0.07em;
    line-height: 1.55;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

@media screen and (max-width: 768px) {
.mv_title h1 {
    font-size: 2.4rem;
  }
}

.mv_title_sub{
    font-size: 24px;
    font-weight: 700;
  }

.mv_title_main{
font-size: 40px
  }



@media screen and (max-width: 768px) {

  .mv_banner{
      display: flex;
      margin: 0 auto;
        grid-gap: 1em;
        align-items: center;
        padding: 0 30px;
        width: auto;
        max-width: 100%;
  }

.mv_title_main h1{
    font-size: 28px;
    line-height: 1.5;
  font-weight: 700;
  }

.mv_banner img{
  width: 30%;
  }


  .mv_title_sub{
        font-size: 16px;
    font-weight: 700;
  }

}


.opening-date_wrap{
    width: 100%;
    position: relative;
}

.opening-date_ttl {
position: absolute;
    text-align: center;
    align-items: center;
    justify-content: center;
    display: flex;
    font-size: 2.6rem;
    font-weight: 600;
    z-index: 1;
    left: -2px;
    right: 0;
    width: 36%;
  max-width: 500px;
    top: calc(100vh - 12rem);
    padding: 0.6rem 2rem;
    box-shadow: 0px -5px #c5eb6b, 0px 5px #c5eb6b;
    border-top: 3px solid #fff;
    border-bottom: 3px solid #fff;
    background-color: #c5eb6b;
  color: var(--color-brand-green-middle);
}

@media screen and (max-width: 1024px) {
.opening-date_ttl {
    position: absolute;
    font-size: 1.7rem;
    z-index: 2;
    left: -2px;
    right: 0;
    width: 72%;
    max-width: 270px;
    top: 52vh;
    padding: 0rem 2rem;
          top: 6vh;
        padding: 0.8rem 2rem 0.2rem;
        line-height: 1.2;
        width: 50%;
        text-align: left;
  }
}

.opening-date_ttl::after {
    position: absolute;
    content: '';
    top: -8px;
    width: 0px;
    height: 0px;
    border-color: transparent var(--color-bg-primary-pale);
    border-style: solid;
    right: 0;
    border-width: 1.8em 0.8em 1.8em 0px;
}
@media screen and (max-width: 1024px) {
.opening-date_ttl::after {
border-color: transparent #F8F9FC;
      border-width: 2.4em 0.8em 2.4em 0px;
  }
}


.opening-date_ttl .num{
  font-size: 3.6rem;
}
@media screen and (max-width: 1024px) {
.opening-date_ttl .num {
    font-size: 2.8rem;
}
}

.opening-date_ttl p{
  position: relative;
}

/*
.opening-date_ttl p::before {
      content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -20px;
    width: 5px;
    height: 45%;
    border-radius: 2rem;
    background-color: var(--color-brand-primary);
}

@media screen and (max-width: 1024px) {
.opening-date_ttl p::before {
    background-color: transparent;
  }
}
*/








/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Swiper Classes (Slider)

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/


/* slider */
.swiper__w{
width: 100%;
  background: #efefec;
  position: relative;
  }


.swiper {
  /*width: calc(100vw - 280px);
  height: 100%;
  max-height: calc(80vh - 150px);
  overflow: hidden;
  margin-top: 150px;
  margin-left: unset !important;
  opacity: 0;
  transition: opacity 1s ease-out;*/
}






/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Component Classes

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/



.txt_green{
color: var(--color-brand-green-middle);
}

.txt_red{
color: #e64949;
}

.txt_center{
    text-align: center;
}

.marker_y {
    text-decoration: underline;
    text-decoration-thickness: 0.5em;
    text-decoration-color: rgba(255, 228, 0, 0.4);
    text-underline-offset: -0.2em;
    text-decoration-skip-ink: none;
}

.underline{
  background:linear-gradient(transparent 60%, var(--color-bg-primary-pale) 60%)
}

.solid_whitechara{
background-color: var(--color-brand-orange-light);
    /* color: #fff; */
    font-weight: 700;
    border-radius: 0.6rem;
    font-size: 1.5rem;
}
@media (max-width: 768px) {
.solid_whitechara{
  font-size: 1.4rem;
}
}



.headline{
  position: relative;
text-align: center;
    padding-bottom: 12rem;
    font-size: 3.6rem;
    letter-spacing: .2rem;
    line-height: 1;
    font-weight: 700;
}
@media (max-width: 768px) {
.headline{
    font-size: 2.8rem;
          padding-bottom: 6rem;
  }
}

.headline:before {
    content: '';
    position: absolute;
      background-color: var(--color-brand-primary);
    bottom: 0px;
    border-radius: 3px;
    top: 6.4rem;
    left: 50%;
    transform: translateX(-50%);
    width: 140px;
    height: 3px;
}
@media (max-width: 768px) {
.headline:before {
    content: '';
    top: 4.4rem;
  }
}


.headline:after {
content: '';
    position: absolute;
    width: 45px;
    height: 45px;
    background-image: url(../images/logo/logo_icon.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    top: -4rem;
    left: 50%;
    transform: translate(-50%, -50%);
}



.headline .jp{

}

.headline .en {
    font-size: 1.6rem;
    color: var(--color-brand-accent);
}




.ttl{
width: 100%;
}

.ttl h3{
font-size: 3.0rem;
font-size: clamp(1.25rem, 1.023rem + 1.14vw, 1.875rem);
text-align: center;
color: #454458;
letter-spacing: .2rem;
font-weight: 600;
    margin: 0 0 20px 0;
    font-family: 'Zen Maru Gothic', sans-serif;
}

/*
@media (max-width: 768px) {
.ttl h3{
font-size: 2rem;
}
}
*/

.ttl h3::first-letter{
color: #00947A;
}



.sub_ttl{
width: 100%;
}

.sub_ttl h3{font-size: 2.2rem;letter-spacing: .2rem;font-weight: 600;
}

@media (max-width: 768px) {
.sub_ttl h3{
font-size: 1.8rem;
}
}
/*
.sub_ttl h3::first-letter{
color: #00947A;
}
*/



/* ---------------------------------------------

   btn_pagetop   

--------------------------------------------- */

.pagetop {
    height: 50px;
    width: 50px;
    position: fixed;
right: 28px;
    bottom: 50px;
    background: var(--color-brand-primary);
    border: solid 0px #d4f5ff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;

}

.pagetop__arrow {
    height: 10px;
    width: 10px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}
.sticky {

    right: 20px;
    bottom: 20px;
  align-self: flex-end;
}



/*sp*/
@media all and (max-width:768px) {

  .pagetop {
    height: 40px;
    width: 40px;
    position: fixed;
    right: 30px;
    bottom: 20px;
    background: #003B79;
    border: solid 2px #d4f5ff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
    display: none;
}

.pagetop__arrow {
    height: 10px;
    width: 10px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}

}



/*   -----ボタン------    */

.btn_01 {
  width: 20rem;
  border-radius: 50vh;
 border: solid 1px #00947A;
}

.btn_01 a {
  align-self: center;
  display: flex;
  gap: 0.4rem;
  justify-content: space-between;
  color: #00947A;
  padding: 0.6rem 2.2rem;
}


/*sp*/
@media all and (max-width:768px) {
  .btn_01 {
    width: 16rem;
  }

.btn_01 a {
  justify-content: center;
}
}


.arrow_right{
  width: 2rem;
  position: relative;
}

.btn_01:hover.arrow_right {
    right: 1.8rem;
}


.btn_01:hover {
  transform: translateX(+5px);
  transition-duration: 0.3s, 2s;
}


.btn_02 {
      width: 20rem;
    border-radius: 50vh;
    border: solid 1px var(--color-brand-orange-middle);
    background-color: var(--color-brand-orange-middle);
    overflow: hidden;
}

.btn_02 a {
  align-self: center;
  display: flex;
  gap: 0.4rem;
  justify-content: space-between;
  color: #fff;
  padding: 0.6rem 2.2rem;
}


/*sp*/
@media all and (max-width:768px) {
  .btn_02 {
    width: 16rem;
  }

.btn_02 a {
  justify-content: center;
}
}


.btn_02:hover.arrow_right {
    right: 1.8rem;
}


.btn_02:hover {
  transform: translateX(+5px);
  transition-duration: 0.3s, 2s;
}



/* ここから時間差フェードインアニメーション */
/* 2秒間かけてフェードイン */
.fadeIn1s {
    animation-name: fadeIn1s;
    animation-delay: 2s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(-50px);
    opacity: 0;
}
@keyframes fadeIn1s {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}






.line_bt {
  border-bottom: solid 1px var(--color-brand-orange-light);
    margin-bottom: 2rem;
    padding-bottom: 1rem;
  
}
/*sp*/
@media (max-width: 768px) {
  .line_bt {
        margin-bottom: 2rem;
        padding-bottom: 0.6rem;
  }
}
.prof {
  display: flex;
  /*  border-bottom: solid 1px #ededed;
  padding-bottom: 6px;
  */
}
.date {
  width: 80px;
  min-width: 80px;
  color: #00947A;
}
/*sp*/
@media (max-width: 768px) {
  .date {
    width: 64px;
    min-width: 64px;
  }
}
.dot {
  width: 16px;
  min-width: 16px;
  color: #00947A;
}
/*sp*/
@media (max-width: 768px) {
  .dot {
    width: 16px;
    min-width: 16px;
  }
}




.map {
  width: 48.5%;
  width: 100%;
  /*    max-width: 560px; */
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-self: flex-end;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 1px 2px 2px 0 rgba(188, 225, 250, 0.2);
}
.map iframe {
  width: 100%;
      height: 320px;
}
/*sp*/
@media (max-width: 768px) {
  .map {
    width: 100%;
    text-align: center;
    gap: 2rem;
  /*  justify-content: flex-start; */
  }
  .map iframe {
    height: 300px;
  }
}



/* Google Maps */
.gm_w{
width:100%;
margin:20px auto 0;
text-align:center;
z-index: 3;
}

.gm_w iframe{
width:100%;
height:500px;
border-radius: 10px;
z-index: 3;}

















/* ------------------------------------------------------------------------------------------

     ST　診療時間表_Table Classes 

------------------------------------------------------------------------------------------ */

/* -------------------------------------------------------------------------------------------
   時間関連情報のスタイル
   ------------------------------------------------------------------------------------------ */

/* 時間情報のラッパー */
.timeinfo_wrap {
  /* 空のルールセットですが、メディアクエリがあるため保持 */
}
@media all and (max-width: 768px) {
  .timeinfo_wrap {
    order: 2;
  }
}

/* 時間情報のテキスト */
.t_timeInfo {
  font-size: 1.4rem;
  width: 100%;
  line-height: 1.8;
  background-color: #f3eada;
  background-color: #fff;
  border-radius: 1rem;
  padding: 1.4rem 2rem 1.2rem;
  border:solid 1px var(--color-brand-orange-light);
}

@media all and (max-width: 768px) {
  .t_timeInfo {
    font-size: 1.3rem;
    width: 100%;
    margin: 0 auto;
    padding: 1rem 1.2rem;
  }
}

/* タイムテーブルのラッパー */
.t_timetable_wrap {
  margin-bottom: 1.5rem;
}

@media all and (max-width: 768px) {
  .t_timetable_wrap {
    width: 100%;
    margin-bottom: 1rem;
  }
}

/* タイムテーブル本体 */
.t_timetable {
  width: 100%;
}

@media all and (max-width: 768px) {
  .t_timetable {
    width: 100%;
    border-spacing: 0;
    border-collapse: separate;
  }
}

/* タイムテーブルのセル共通スタイル */
.t_timetable th, 
.t_timetable td {
  border-bottom: 1px solid #efefef;
  vertical-align: middle;
  width: 7%;
  text-align: center;
}

/* タイムテーブルのタイトル */
.t_timetable_ttl {
  font-size: 1.6rem;
  letter-spacing: 0.4rem;
}

/* タイムテーブルの最初の見出しセル */
.t_timetable th:first-child {
  width: 25%;
  height: 60px;
  vertical-align: middle;
  padding-left: 1rem;
  text-align: left;
}

@media all and (max-width: 768px) {
  .t_timetable th:first-child {
    width: 28%;
    text-align: center;
    height: 40px;
    padding-left: 0;
    padding-right: 1rem;
  }
}

/* タイムテーブルのデータセル */
.t_timetable td {
  font-size: 1.8rem;
  vertical-align: middle;
  line-height: 1.3;
  letter-spacing: 0;
}

@media all and (max-width: 768px) {
  .t_timetable td {
    font-size: 1.3rem;
  }
}

/* タイムテーブル3 - 現在は空ですが、将来の拡張性のために保持 */
.t_timetable3 {
  /* 空のルールセットですが、将来の拡張性のために保持 */
}

/* フッタータイムテーブルのデータセル */
@media all and (max-width: 768px) {
  .f_timetable td {
    font-size: 1.3rem;
  }
}



/* 太字テキスト */
.txt_bold {
  font-weight: bold;
}

/* 定義リストのスタイル (profクラス内) */
.prof dt, 
.prof dd {
  line-height: 1.5;
}

/* 
  注釈：元のCSSには以下のコメントアウトされたスタイルがあります
  .f_timetable{
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
  }
*/

/* ------------------------------------------------------------------------------------------
   テーブル関連のスタイル (使用されていないが保持)
   ------------------------------------------------------------------------------------------ */

/* tb_02テーブルの基本スタイル */
.tb_02 {
  /* 空のルールセットですが、将来の拡張性のために保持 */
}

@media (max-width: 768px) {
  .tb_02 {
    /* メディアクエリ内も空ですが、一貫性のために保持 */
  }
}

/* tb_02テーブルのtbody要素 */
.tb_02 tbody {
  display: grid;
  gap: 2rem;
}

@media (max-width: 768px) {
  .tb_02 tbody {
    display: grid;
     gap: 1.6rem;
  }
}

/* tb_02テーブルの行 */
.tb_02 tr {
  flex-wrap: wrap;
  display: grid;
  flex-wrap: nowrap;
  grid-template-columns: 100px 1fr;
  gap: 1.6rem;
  align-items: baseline;
  font-size: 1.6rem;
}

@media (max-width: 768px) {
  .tb_02 tr {
    grid-template-columns: 28% 1fr;
    gap: 1.2rem;
    flex-wrap: wrap;
    font-size: 1.5rem;
  }
}

/* tb_02テーブルの見出しセル */
.tb_02 th {
  min-width: 20%;
  font-weight: 600;
}

@media (max-width: 768px) {
  .tb_02 th {
    width: 100%;
    padding: 2px 0;
  }
}

/* tb_02テーブルのデータセル */
.tb_02 td {
  line-height: 1.5;
}

@media (max-width: 768px) {
  .tb_02 td {
    line-height: 1.4;
    text-align: justify;
  }
}

/* ラベルのスタイル */
.label span {
  border-left: solid 4px #00947A;
  padding-left: 0.6rem;
  font-weight: 700;
}

/* コンタクトフォームのラベル */
.contact_form_tbl label {
  cursor: pointer;
}

/* 確認画面のラベル */
.confirm_wrap label {
  cursor: pointer;
}
/* ------------------------------------------------------------------------------------------

     ST　診療時間表_Table Classes 

------------------------------------------------------------------------------------------ */






/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

Section Classes

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/

/* ---------------------------------------------

  挨拶＿greeting   

--------------------------------------------- */

.greeting {
padding: 0rem 0px 10rem 0px;
  position: relative;
  background-size: cover;
}

@media (max-width: 768px) {
  .greeting {
    padding: 7rem 0px 7rem 0px;
    padding: 6rem 0px 2.8rem 0px;
  }
}


.greeting .headline {
padding-bottom: 10rem;
}

@media (max-width: 768px) {
  .greeting .headline {
padding-bottom: 6rem;
}
}
/*
.greeting .headline::before{
  content: "";
    position: absolute;
    top: -22px;
    left: auto;
    right: auto;
    height: 78px;
    width: 66px;
    z-index: -1;
    background: url("../images/silhouette_white.svg") no-repeat;
    background-size: cover;
}
*/


.greeting .txt {
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  line-height: 2.2;
  line-height: 2.4;
  font-size: 1.7rem;
  max-width: 70em;
      text-align: center;
}
/*sp*/
@media (max-width: 768px) {
  .greeting .txt {
    justify-content: space-between;
    line-height: 2;
    font-size: 1.5rem;
    text-align: left;
    text-align: justify;
  }
}
/*
.greeting .txt span {
  color: #00947A;
  
}

*/






/* ---------------------------------------------

  名前＿   

--------------------------------------------- */


.doctor{
    padding-bottom: 6rem;
}

/*sp*/
@media (max-width: 768px) {
.doctor{
  padding-bottom: 4rem;
}
}



.name_grid{
display: flex;
    flex-wrap: nowrap;
    gap: 6rem;
    justify-content: space-between;
gap: 6rem;
    justify-content: center;
}

/*sp*/
@media (max-width: 768px) {
.name_grid{
  flex-wrap: wrap;
          gap: 3.2rem;
        flex-direction: column-reverse;
        justify-content: flex-start;
}
}


.doctor_img{
}

.doctor_img img{
  width: 360px;
border-radius: 1rem;
}









/* ---------------------------------------------

  経歴＿career   

--------------------------------------------- */

.doctor_career{

}



.doctor_career .inner {
    margin: 0 auto;
      display: grid;
    gap: 4rem;
}

/*sp*/
@media (max-width: 768px) {
.doctor_career .inner {
  gap:3.2rem;
  gap:0;
    border-radius: 10px;
  }
}


.career_wrap {
    border-radius: 1rem;
  padding: 20px 32px 40px;
      padding: 24px 30px 36px;
   /* box-shadow: 1px 2px 2px 0 rgba(0, 148, 122, 0.2); */
}

/*sp*/
@media (max-width: 768px) {
  .career_wrap {
    padding: 0;
    box-shadow: none;
}
}


.career_grid {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  gap: 4rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
      border-radius: 1rem;
 /*  background-color: var(--color-bg-primary-pale); */
}

/*sp*/
@media (max-width: 768px) {
  .career_grid {
  gap: 3.2rem;
      gap: 0;

}
}

.career_box {
  width: 100%;
  align-items: flex-start;
  border-radius: 16px;
  height: 100%;
}


.career_list {
text-align: left;
    gap: 1rem;
    display: grid;
    /* font-size: 1.6rem; */
    /* font-weight: 400;*/
}

/*sp*/
@media (max-width: 768px) {
  .career_list {
  font-size: 1.4rem;
}
}

.career_list li {
    border-bottom: solid 1px #efefef;
  padding-bottom: 2px;
}

.career_grid .prof {
    border-bottom: solid 1px #efefef;
    padding-bottom: 4px;
}




.doctor_name{
  letter-spacing: 0.1rem;
    align-content: center;
    /* padding: 0 12px;*/
}

@media (max-width: 768px) {
 .doctor_name {
    padding: 0;
    }
}

.post{

}

.name_jp{
  font-size: 3.2rem;
width: 100%;
font-weight: 500;
}
/*sp*/
@media (max-width: 768px) {
.name_jp{
 font-size: 2.2rem;
}
}


.name_en{
  font-size: 1.5rem;
  padding-left: 1.6rem;
      color: var(--color-brand-orange-middle);
}



/*    --------------------    */
.doctor_career dl{
      display: grid;
    gap: 1rem;
}

/*sp*/
@media (max-width: 768px) {
  .doctor_career dl{

}
}


.list-dot{
  display: flex; /* 点とリストを横並びに */
/*  align-items: center;*/
}
.list-dot::before{
 content: "・"; /* 記号(黒丸)を挿入 */
 color: var(--color-brand-primary); /* 好きな色にする */
 margin-right: 0.4em; /* 点とテキストの距離 */
}








/* ------------------------------------------------------------------------------------------

     ST　footer 

------------------------------------------------------------------------------------------ */
.footer{
width: 100%;
    background-color: var(--color-bg-primary-pale);
}
.footer_logo{
  display: flex;
  justify-content: center;
}

/* ---------------------------------------------
  ST コピーライト_copyright   
--------------------------------------------- */

.footer-bottom{
    padding: 20px 0 20px;
  color: var(--color-brand-green-dark);
   background-color: var(--color-brand-orange-light);
}
/*sp*/
@media (max-width: 768px) {
  .footer-bottom {
padding: 4rem 0 5rem;
  }
}
.footer-bottom .inner{
  flex-wrap: wrap;
    display: flex;
    justify-content: space-between;
}
@media (max-width: 768px) {
  .footer-bottom .inner{
    gap:2.4rem;
  }
}

.copyright {
  font-size: 1.2rem;
}
/*sp*/
@media (max-width: 768px) {
  .copyright {
    font-size: 1rem;
  }
}

.footer-bottom__list{
    font-size: 1.2rem;
      display: flex;
    gap: 1.2rem;
}
/*sp*/
@media (max-width: 768px) {
.footer-bottom__list{
      font-size: 1rem;
}
}
.footer-bottom__list a:hover {
        text-decoration: underline;
    }
.footer-bottom__list a{
    color: var(--color-brand-green-dark);
}
.footer-bottom__list a:hover {
    opacity: 1;
}



/* ---------------------------------------------
  END コピーライト_copyright   
--------------------------------------------- */


/* ---------------------------------------------
  ST アクセス_access   
--------------------------------------------- */
.access{
   /* background: repeating-linear-gradient(-60deg, #EFF4FE, #EFF4FE 2px, #faf8f5 0, #faf8f5 10px); */
      padding: clamp(1.25rem, 0.074rem + 5.88vw, 3.75rem) 0;
      padding: 10rem 0px 8rem 0px;
border-top: 3px solid var(--color-brand-orange-light);
}


@media (max-width: 768px) {
    .access {
          display: flex;
    justify-content: center;
    margin: 0 auto;
        padding: 7rem 0px 4rem 0px;
    }
}

@media (max-width: 768px) {
    .access .inner {
display: grid;
    }
}

.access_logo{
  display: flex;
  justify-content: center;
    max-width: 500px;
  width: 90%;
}
@media (max-width: 768px) {
  .access_logo{
    width: 100%;
  }
  }


@media (max-width: 768px) {
.access .headline{
        padding-bottom: 3.2rem;
}
}


.access__w{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
}

/*sp*/
@media (max-width: 768px) {
.access__w{
width: 100%;
margin: 0 auto;
gap:3.2rem;

}
}



.address{
    width: 48.5%;
  width: 100%;
/*    max-width: 560px; */
display: flex;
display: grid;
flex-wrap: wrap;
    gap: 4rem;
}

/*sp*/
@media (max-width: 768px) {
.address{
width: 100%;
  order: 1;
}
}

/* ---------------------------------------------
  END アクセス_access   
--------------------------------------------- */

/* ------------------------------------------------------------------------------------------

     END　footer 

------------------------------------------------------------------------------------------ */













/* ------------------------------------------------------------------------------------------

     ST　特徴＿feature 

------------------------------------------------------------------------------------------ */

.grad{
  background: rgb(255,255,255);
background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(242,251,253,1) 4%, rgba(242,251,253,1) 24%, rgba(255,255,255,0) 36%);
}

.feature-top-ornament{
  position: relative
}
.feature-top-ornament{
  content: "";
    position: absolute;
  margin-top: -3rem;
    left: 0;
    height: 100%;
    width: 100%;
    background: url("../images/bg/lightorange_wave_bg_2.svg") no-repeat right top / 100% auto;
}
@media (max-width: 768px) {
  .feature-top-ornament{
    margin-top: -1rem;
  }
}

.feature  {
    background: url(../images/bg/bg_ornament_1.png) no-repeat center;
      background-color: rgba(255, 255, 255, 0.6);
    background-blend-mode: lighten;
  background-size: cover;
  padding-bottom: 24rem;
      padding-top: 24rem;
}
@media (max-width: 768px) {
.feature{
  padding-bottom: 10rem;
  padding-top: 15rem;
}
}




.feature_wrap{
          display: flex;
        flex-wrap: wrap;
  gap:18rem;
}

.feature_wrap_3cl{
    display: grid;
    align-items: flex-start;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
  

@media (max-width: 768px) {
.feature_wrap{
  gap:4rem;
}
}



.feature .grid {

      display: flex
;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 28px 40px;
}

@media (max-width: 768px) {
.feature .grid{
  gap: 22px;
}
}

.box_img{
    width: 52%;
}
@media (max-width: 768px) {
.box_img{
        width: 100%;
        /*  padding: 0 8px; */
}
}


.box_img img{
      aspect-ratio: 3 / 2;
      border-radius: 16px;
      border-radius: 1rem;
      /*    box-shadow: 8px 7px 0px 0 rgba(188, 225, 250, 1); */
}
/*
.box_txt {
  width: 47.5%;
  gap: 24px;
  display: grid;
    position: relative;
      gap: 6px;
border-radius: 1.6rem;
    background-color: #f2fbfd;
    padding: 2rem;
}
*/
.box_txt {
  width: 40%;
  gap: 18px;
  display: grid;
}

@media (max-width: 768px) {
.box_txt{
        width: 100%;
        display: grid
;
        gap: 16px;
          gap: 6px;
          padding: 0 6px;
}
}

.text-area{
  display: grid;
  gap: 28px;
}
@media (max-width: 768px) {
.text-area{
  gap:14px;
}

}

.card_ttl {
  font-size: 3.2rem;
    font-size: 3rem;
  line-height: 1.5;
  /* text-align: justify; */
  display: flex;
  align-items: center;
  font-weight: 600;
  letter-spacing: 0.05em;
}
@media (max-width: 768px) {
.card_ttl {
  font-size: 2.4rem;
}

}

.card_txt {
  line-height: 1.6;
  line-height: 2em;
  letter-spacing: .05em;
}
@media (max-width: 768px) {
.card_txt {
    line-height: 1.8em;
}

}



.row_reverse{
  flex-direction: row-reverse;
}

@media (max-width: 768px) {
.row_reverse{
  flex-direction: inherit;
}
}


.column_reverse{
  flex-direction: inherit;
}

@media (max-width: 768px) {
.column_reverse{
  flex-direction: column-reverse;

}
}



.feature .number_wrap {
  color: var(--color-brand-primary);
  position: relative;
  font-family: "Josefin Sans", sans-serif;
  font-size: 2.4rem;
}
@media (max-width: 768px) {
.feature .number_wrap {
   font-size: 2rem;
  }
}
  
.feature .number {
  position: relative;
  font-size: 3.2rem;
  line-height: 1;
  font-weight: 700;
  /* text-shadow: 1px 1px 0 #82AE46, -1px -1px 0 #82AE46, -1px 1px 0 #82AE46, 1px -1px 0 #82AE46, 0px 1px 0 #82AE46, 0 -1px 0 #82AE46, -1px 0 0 #82AE46, 1px 0 0 #82AE46; */
}
@media (max-width: 768px) {
.feature .number {
  font-size: 2rem;
}

}
/*
.feature .number_wrap:before {
        content: '';
        position: absolute;
        left: 0;
        bottom: -20px;
        display: inline-block;
        width: 130px;
        height: 1px;
        background-color: #036dd0;
    }
@media (max-width: 768px) {
  .feature .number_wrap:before {
bottom: -5px;
        width: 110px;
        height: 1px;
  }
}

*/



/*
.feature .number:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  display: inline-block;
  width: 50px;
  height: 1px;
  background-color: #036dd0;
}
*/

@media (max-width: 768px) {


}
/* ------------------------------------------------------------------------------------------

     END　特徴＿feature 

------------------------------------------------------------------------------------------ */







/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

ST privacy-policy

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/

.privacy-policy .inner{
    max-width: 800px;
    gap: 8rem;
    display: grid;
}

@media (max-width: 768px) {
  .privacy-policy .inner{
    gap: 6rem;
}
}

.privacy-policy .text-area {
    gap: 16px;
}

.privacy-policy .card_ttl {
    font-size: 2.4rem;
}

@media (max-width: 768px) {
.privacy-policy .card_ttl {
    font-size: 1.8rem;
}
}


.inspection_list {
 list-style: none;
}
.inspection_list li{
  display: flex; /* 点とリストを横並びに */
/*  align-items: center;*/
}
.inspection_list li::before{
 content: "⚫︎"; /* 記号(黒丸)を挿入 */
 color: var(--color-brand-green-middle); 
 font-size: 0.6em; /* 点の大きさ */
 margin-right: 1em; /* 点とテキストの距離 */
 margin-top: 0.6rem;
}

/*
-----------------------------------------------------------------------------------------------
------------------------------------------------------------

END privacy-policy

------------------------------------------------------------
-----------------------------------------------------------------------------------------------
*/





