header#top{
	position: absolute;
	top:50px;
	left: 0;
	right: 0;
	margin: auto;
}

.mv{
	position: relative;
}
.mv img,.mv_bg img{
	width: 100%;
}
.mv_bg{
	line-height: 0;
	position: relative;
	margin-top: -63px;
}
.mv_bg p{
	position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
	margin: 0;
	color: white;
	font-size: 32px;
	font-weight: 500;
	text-align: center;
    letter-spacing: .7rem;
    line-height: 2.1;
    width: 100%;
}

.mv img.sp,.mv_bg img.sp,.logo_sp_{
  display: none;
}


@media screen and (max-width: 567px) {
.mv img.pc,.mv_bg img.pc{
  display: none;
}
.mv img.sp,.mv_bg img.sp,.logo_sp_{
  display: block;
}
.logo_sp_{
display:none;
  width: 114px;
  position: absolute;
  top:0;
  left: 0;
  right: 0;
  margin: auto;
}
.mv_bg{
	margin-top: -12px;
}
}





/*mp4*/
.mv-video-wrapper {
  position: relative;
  width: 100%;
  height: 100vh; /* 画面いっぱいに表示したい場合 */
  overflow: hidden;
}

.mv-video-wrapper video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
}

/* スマホ用調整（画面幅768px以下） */
@media screen and (max-width: 768px) {
  .mv-video-wrapper {
    height: auto; 
    aspect-ratio: 16 / 9;
  }
  .mv-video-wrapper video {
    position: static;
    transform: none;
    width: 100%;
    height: auto;
    object-fit: contain;
  }
}





/*youtube*/
.youtube-container {
    text-align: center;
}
.home .youtube-container {
	margin: 10px auto 100px;
}
@media screen and (max-width: 567px) {
.youtube-container {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
.home .youtube-container {
    margin: 50px auto;
}
.youtube-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
}

.lp_img{
	text-align:center;
}
.lp_img img{
	max-width:1000px;
	width:100%;
	margin:auto;
}
@media (max-width: 567px) {
	.lp_img{
		padding:0 2%;
	}
}




.fot{
	position: fixed;
	top:0;
	right: 0;
	display: flex;
	flex-direction: column;
	z-index: 999;
}
.fot a{
	line-height: 0;
}
.fot img{
	width: 94px;
}

@media screen and (max-width: 768px) {
  .fot img{
  width: 70px;
}
}
























@media screen and (max-width: 992px) {
.mv_bg p {
  font-size: 18px;
  color: rgb(255, 255, 255);
  line-height: 2;
	letter-spacing:.3rem;
}

}





/* メニュー
--------------------------------------------- */
/*ロゴ*/
.menu-logo-wp{
	line-height: 0;
}
/* 親メニュー全体のスタイル */
.main-navigation {
  position: relative;
  font-family: sans-serif;
}
.main-menu {
list-style: none;
    margin: 0 100px 0 0;
    padding: 0;
    display: flex;
    justify-content: end;
}
.home .main-menu{
	margin: 0;
}
.home .main-menu {
justify-content:center;
}
.main-menu>li {
  position: relative;
  margin-right: 20px;
}
.main-menu>li:last-child{
	margin-right: 0;
}
.main-menu>li>a{
text-align: center;
}
.main-menu a {
  display: inline-block;
  text-decoration: none;
  padding: 10px 15px;
  color: initial;
}
.home .main-menu a {
color: white;
}
.menu-title {
  display: block;
  font-size: 18px;
  font-weight: 600;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: .2rem;
}
.menu-subtitle {
  display: block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .2rem;
}
@media screen and (min-width: 992px) {
.main-navigation .sub-menu {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  background: white;
  padding: 10px 0;
  margin: 0;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  z-index: 9999;
}
.main-navigation .sub-menu li {
  padding: 0;
  margin: 0;
  list-style: none;
}
.main-navigation .sub-menu a {
  padding: 10px 20px;
  display: block;
  white-space: nowrap;
  color: #000;
}
.main-navigation .sub-menu a .menu-title {
  font-size: 15px;
}
.main-navigation .sub-menu a:hover {
	background: #d2f9f7;
	opacity: 1;
}
.main-navigation .menu-item-has-children:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
}











/* ロゴ */
.home .main-menu.top>li:nth-child(3) {
    position: relative;
    margin-right: 100px;
}
.home .main-menu.top>li:nth-child(3):after{
    content: '';
    background: center / contain no-repeat url(http://umygame9.xsrv.jp/dental-tanizawa/wp-content/uploads/2025/08/logo.png);
    width: 143px;
    height: 168px;
    position: absolute;
    top:0;
    right: -180px;
    pointer-events: none;
    line-height: 0;
}
.home .main-menu.top>li:nth-child(4) {
    position: relative;
    margin-left: 100px;
}












/* フッターメニュー */
.main-navigation.footer>ul{
width: 100%;
position: relative;
}
.main-navigation.footer .sub-menu{
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	top: 100%;
	width: 100%;
}
.main-menu.footer>li{
	position: unset;
}




@media screen and (max-width: 992px) {
	.home .main-menu.top>li:nth-child(3):after{
		display: none;
	}
	.home .main-menu.top>li:nth-child(3){
		margin-right: 0;
	}
	.home .main-menu.top>li:nth-child(4){
		margin-left: 0;
	}
}

























/*下層*/
.main-navigation.lower>ul>li>a{
color: #000;
padding: 10px 0;
}

/*サイドメニュー*/
.sidebar::-webkit-scrollbar{
  display: none;
}
.sidebar {
	-ms-overflow-style: none;
	scrollbar-width: none;
  width: 280px;
  background: #00b4aa;
  color: #fff;
  padding: 30px 15px;
  height: 100vh;
  overflow-y: auto;
  z-index: 999;
  position: sticky;
      top: 0;
      align-self: flex-start;
}
.sidebar ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sidebar a {
  color: #fff;
  text-decoration: none;
  font-weight: bold;
}
.sidebar a:hover {
  text-decoration: underline;
}

/* サブメニュー非表示 */
.sidebar .sub-menu {
  display: none;
}
.sidebar_logo{
	margin: 30px 0 100px;
}
.sidebar_logo img{
	width: 100%;
	    padding: 0 21px;
}
.sidebar ul li a {
  display: flex;
  align-items: center;
  font-size: 18px;
  font-weight: normal;
  padding: 7px 0;
  color: #fff;
  text-decoration: none;
  position: relative;
  padding-left: 10px;
  transition: transform 0.3s ease;
    display: flex;
  align-items: center;
  justify-content: space-between;
}
.sidebar ul li a::after {
  content: '';
  width: 9px;
  height: 14px;
  background-size: contain;
  background-repeat: no-repeat;
  transition: transform 0.3s ease;
}
.sidebar ul li a::after {
  background-image: url('../img/arrow.png');
}
.sidebar ul li.current-menu-item a::after {
  background-image: url('../img/current.png');
}
.sidebar>ul>li.open > a::after {
  transform: rotate(90deg);
}
.sidebar>ul>li{
  border-top: 1px solid white;
  padding: 13px 10px;
}
.sidebar>ul>li:last-child{
  border-bottom: 1px solid white;
}
.sidebar>ul>li>a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
.sidebar>ul>li.open > a .arrow {
  transform: rotate(90deg);
}
.sidebar ul li ul.sub-menu li {
  margin: 8px 0;
}
.sidebar ul li ul.sub-menu a {
  font-weight: 500;
  font-size: 16px;
  letter-spacing: .07rem;
}
.sidebar>ul>li>a {
  display: flex;
  justify-content: space-between;
  align-items: center;
    font-weight: 500;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: .07rem;
  cursor: pointer;
}










.content{
	max-width: 1030px;
	margin: auto;
	padding: 0 15px;
}
@media (max-width: 992px) {
.content{
	max-width: 100%;
}
}

main.contents {
  overflow-y: auto;
  background-color: #f9f9f9;
  padding: 40px 20px;
  flex: 1;
}
@media (max-width: 992px) {
main.contents{
  padding: 40px 0;
}
}
main.contents>.wp{
	max-width: 1000px;
	margin: 100px auto 0;
}
.contents article p {
  font-size: 17px;
  line-height: 2.1;
  letter-spacing: .2rem;
  font-weight: 500;
}




.sub_tlt{
	font-family: "Josefin Sans", sans-serif;
font-size: 100px;
  color: rgba(0, 177, 168, 0.059);
  font-weight: 600;
  line-height: 1.047;
}




.content-box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 60px;
  margin-top: 100px;
}
.content-image img {
  max-width: 100%;
  height: auto;
  object-fit: cover;
}
.content-image {
  flex: 1;
  min-width: 250px;
}
.content-text {
  flex: 1;
  position: relative;
}
.content-text p{
	font-weight: 500;
}
.title {
  font-size: 32px;
  font-family: "Noto Sans JP";
  font-weight: 500;
  color: rgb(0, 0, 0);
  line-height: 2.1;
  letter-spacing: .8rem;
  text-align: justifyLeft;
  font-feature-settings: "palt";
}
.description {
font-weight: 500;
}
.content-text .sub_tlt{
position: absolute;
    top: -12px;
    left: 69px;
}

/* レスポンシブ対応 */
@media screen and (max-width: 992px) {
   .title {
  font-size: 26px;
}
}

@media screen and (max-width: 768px) {
  .content-box {
    flex-direction: column;
  }
  .content-text {
    padding: 0;
  }
  .title {
  font-size: 22px;
}
.content-text .sub_tlt {
    top: 200px;
    left: auto;
    right: 0;
    font-size: 70px;
}
}

@media screen and (max-width: 567px) {
	.content-box{
		margin-top:45px;
		gap:0;
	}
	.content-image img.topdr{
		max-width:280px;
	}
}



.link_more{
	    display: flex;
    justify-content: center;
}
.link_more a{
  font-size: 18px;
font-family: "Josefin Sans", sans-serif;
  color: rgb(0, 0, 0);
  font-weight: 600;
  line-height: 31px;
  text-align: center;
  text-decoration: none;
    position: relative;
  display: inline-block;
  padding: 0.6rem 2rem;
  border: 2px solid #000;
  background: transparent;
  box-sizing: border-box;
  width: 208px;
  height: 48px;
}
.link_more a::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: auto;
    top: 50%;
    width: 20px;
    height: 2px;
    background: #000;
    transition: .2s;
}
.link_more a:hover{
	color:white;
	background-color: #000;
}
.link_more a:hover::after{
	background: white;
}

/*@media screen and (max-width: 567px) {
	.link_more a{
		width: 100%;
		height: auto;
		font-size: 14px;
		line-height: 1;
	}
}*/



/* アーカイブ */
.entry-archive .entry-title{
	font-size: 20px;
}
.entry-archive a,.posted-on a{
	text-decoration: none;
	color: initial;
}
/* シングル */
.entry-single .entry-title{
	font-size: 22px;
	font-weight:500;
	background: #15eade38;
    padding: 15px 10px;
}
.single .entry-content h2{
	font-size: 22px;
    color: rgb(0, 177, 168);
    line-height: 1.75;
    border-bottom: 1px solid rgb(0, 177, 168);
    letter-spacing: .2rem;
}
.single .entry-content h3{
	font-size: 20px;
    color: white;
    line-height: 1.75;
    letter-spacing: .2rem;
    background-color: rgb(0, 177, 168);
    display: inline-block;
    padding: 0 1rem;
}
.single .entry-content h4{
	font-size: 20px;
    color: rgb(0, 177, 168);
}

@media screen and (max-width: 992px) {
.archive main.contents>.wp,.single main.contents>.wp{
	padding:0 15px
}
}

/*ページネーション*/
.wp-pagenavi{
	text-align:center;
	margin:50px auto 100px;
}
.wp-pagenavi a, .wp-pagenavi span{
	border:none!important;
	background: rgb(0, 177, 168);
	color:white;
	padding:10px 15px!important;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current{
	border:none;
}
.wp-pagenavi span.current{
opacity:.7;
}







.two1-column-wp{
	margin: 50px auto;
	overflow: hidden;
}
.two1-column {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  margin: 70px auto;
  position: relative;
}
.two1-column .column {
  flex: 1;
  min-width: 280px;
}
.two1-column .column.left{
	flex: 1 1 300px;
	position: relative;
}
.two1-column .column.right{
	flex: 2 1 500px;
}
.column.left h3,.two2-column .column.right h3{
	font-size: 26px;
	font-weight: 500;
	line-height: 2.1;
	letter-spacing: .15rem;
	position: relative;
}
.two1-column .column.right{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.two1-column .column.right>div{
	flex: 1;
}
.two1-column .sub_tlt{
	    position: absolute;
	    line-height: .5;
	}
.two1-column.num1 .sub_tlt{
    left: -3rem;
}
.two1-column.num2 .sub_tlt{
    left: -5rem;
}
.two1-column.num3 .sub_tlt{
    left: -10rem;
}
.column.right p{
	text-align: center;
	line-height: 1.8;
	font-weight: 500;
}
.two1-column .num,.two2-column .num{
  font-size: 72px;
  font-family: "Josefin Sans", sans-serif;
  color: rgb(0, 177, 168);
  font-weight: 600;
  letter-spacing: .2rem;
      display: inline-block;
}
.two1-column .num:after,.two2-column .num:after{
	content:'';
	width: 5rem;
	height: 1px;
	display: block;
	margin: auto;
	background-color: rgb(0, 177, 168);
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .two1-column-wp{
  margin: 0 auto 50px;
  }
  .two1-column {
    flex-direction: column;
  }
  .two1-column .column.left{
  	flex: 1;
  }
  .two1-column .column.right{
  	gap:50px;
  }
  .two1-column .column.right>div{
  	text-align: center;
  	width: 100%;
  }
  .two1-column img{
  	margin: auto;
  	width: 100%;
  }
  .two1-column .sub_tlt{
  	display: none;
  }
}





.bg_light_green {
  background-color: #eaf1f1;
}
.two2-wave1,.two2-wave2{
	line-height: 0;
}
.to_2{
	padding: 50px 0;
	overflow: hidden;
}
.two2-column {
  display: flex;
  gap: 30px;
  margin: 0 auto 100px;
  position: relative;
}
.two2-column .column.left{;
	text-align: center;
	flex: 2;
}
.two2-column .column.right{
	position: relative;
	flex: 1;
}
.two2-column .column.left>div{
	display: flex;
	align-items: center;
	gap: 15px;
	margin-bottom: 40px;
}
.two2-column .column.left>div:last-child{
	margin-bottom: 0;
}
.two2-column .column.left>div p{
	margin-top: 0;
	    line-height: 1.8;
	    font-weight: 500;
}
.two2-column .column.left>div div{
	flex: 1;
}
.two2-column .sub_tlt{
position: absolute;
left: -3rem;
}
.two2-column.num3{
	margin-bottom: 0;
}






.two1-column-2-wp{
margin: 50px auto;
overflow: hidden;
}




.two-column {
  display: flex;
  width: 100%;
  min-height: 660px;
}
.image-column {
  width: 35%;
  background-image: url('../img/two-column.jpg');
  background-size: cover;
  background-position: center;
display: flex;
    align-items: end;
    justify-content: flex-end;
}
.image-column .bg_tlt{
  font-size: 143px;
  color: rgb(16, 179, 171);
  line-height: 1.047;
  margin: 0;
      font-family: "Josefin Sans", sans-serif;
    font-weight: 600;
}
.text-column {
  width: 65%;
  padding: 2rem 17% 2rem 5%;
  box-sizing: border-box;
  background-color: rgb(16, 179, 171);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.text-column *{
 color: white!important;
}

/* レスポンシブ対応 */
@media (max-width: 992px) {
	.two2-column .sub_tlt{
		display: none;
	}
}

@media (max-width: 768px) {
	.two-column{
		 flex-direction: column;
	}
  .two2-column {
    flex-direction: column;
    margin-bottom: 50px;
  }
  .two2-column .column.left{
  	order: 2;
  }
  .two2-column .column.right{
  	order: 1;
  }
  .two2-column .column.left>div,
  .two1-column .column.right{
  	flex-direction: column;
  	        width: 100%;
	  flex:auto;
  }
  .two2-column .column.left>div div{
  	width: 100%;
  }
 .two2-column img{
  	margin: auto;
  	width: 100%;
  }
  .image-column,
  .text-column {
    width: 100%;
  }
  .text-column{
    padding: 2rem;
  }
  .image-column {
    height: 380px;
  }
   .image-column img{
   	width: 40%;
   }
  .two1-column-2-wp{
  	margin: 0 auto 30px;
  }
  .image-column{
  	align-items: end;
    justify-content: start;
  }
}

@media screen and (max-width: 567px) {
	.two-column{
		min-height:auto;
	}
	.two1-column{
		margin-bottom:20px;
		margin-top:0;
		gap:0;
	}
	.column.left h3{
	font-size:22px;
	}
}

@media (max-width: 567px) {
	.to_2{
		padding:0;
	}
	.two2-column .column.right h3{
		font-size:22px;
		margin-bottom:0;
	}
	.two2-column {
        margin-bottom: 30px;
    }
	.two2-column.num3{
		margin-bottom:30px;
	}
	.text-column.top{
		padding:1rem 15px;
	}
	.text-column.top h2{
		font-size:20px;
	}
}

.treatment{
	padding: 50px 0;
}
.treatment h2{
	font-family: "Josefin Sans", sans-serif;
  color: rgb(0, 0, 0);
  font-weight: 600;
  font-size: 72px;
}
.treatment h2 span{
  font-size: 24px;
  color: rgb(16, 179, 171);
  display: block;
  letter-spacing: 1.2rem;
  margin-top: 1rem;
}
.grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5rem 1.5rem;
  padding: 2rem;
}
.grid-item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.top-row {
  display: flex;
  align-items: flex-start;
  justify-content: end;
}
.text-vertical {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: 20px;
  font-weight: 500;
  font-feature-settings: "palt";
  margin: 0;
}
.grid-item .icon {
  margin-left: 1rem;
  width: 200px;
}
.grid-item .icon img{
	width: 100%;
}
.grid-item .link_more {
	align-self: flex-end;
  margin-top: 1rem;
  width: 200px;
}

/* レスポンシブ対応 */
@media (max-width: 992px) {
  .grid-item .icon{
  	width: auto;
  }
}

@media (max-width: 768px) {
	.treatment h2{
		font-size: 36px;
	}
	.treatment h2 span{
		font-size: 18px;
	}
  .grid-container {
    grid-template-columns: repeat(2, 1fr);
    padding: 0;
  }
  .top-row {
    justify-content: center;
}
  .grid-item .link_more {
    align-self: center;
}
.text-vertical{
	font-size: 14px;
}
.grid-item .link_more{
	width: 100%;
	justify-content: end;
}
}

@media (max-width: 567px) {
	.treatment{
	padding: 0 0 50px;
}
.grid-container{
  display: flex;
  flex-wrap: wrap;
}
.grid-item{
  width: 45%;
}
.grid-item .icon img {
    min-width: 118px;
}
	.treatment .link_more a{
		width:auto;
	}
}




.post_news{
	background-color: #eaf1f1;
	padding: 80px 0;
}
.news-section {
  display: flex;
  flex-wrap: wrap;
}
  .left-column,
  .right-column {
   flex:1;
  }
.left-column {
  width: 30%;
  box-sizing: border-box;
}
.section-title{
		font-family: "Josefin Sans", sans-serif;
  color: rgb(0, 0, 0);
  font-weight: 600;
  font-size: 72px;
  margin-top: 0;
      line-height: 1.2;
}
.section-title span {
  font-size: 24px;
  color: rgb(16, 179, 171);
  display: block;
  letter-spacing: 1.2rem;
}
.view-all {
  display: inline-block;
  margin-top: 1rem;
  color: #007acc;
  text-decoration: none;
  font-weight: bold;
}
.right-column {
  width: 70%;
  box-sizing: border-box;
}
.news-list {
  margin: 0;
}
.news-item {
  border-bottom: 1px solid #000;
  padding: 1rem 2rem;
}
.news-item:first-of-type {
  border-top: 1px solid #000;
}
.news-item dt {
  font-weight: 500;
  color: #c0c0c0;
}
.news-item dd {
  margin: 0.3rem 0 0 0;
  font-size: 18px;
}
.news-item a{
	color: initial;
	text-decoration: none;
}
.link_more.gn{
	justify-content: flex-start;
}
.link_more.gn a{
	color: rgb(16, 179, 171);
	border-color: rgb(16, 179, 171);
}
.link_more.gn a:after{
background: rgb(16, 179, 171);
}
.link_more.gn a:hover{
	color:white;
	background-color: rgb(16, 179, 171);
}
.link_more.gn a:hover::after{
	background: white;
}
 .link_more.sp{
  	display: none;
  }

/* レスポンシブ */
@media (max-width: 768px) {
  .news-section {
    flex-direction: column;
    margin-bottom: 50px;
  }
  .left-column,
  .right-column {
    width: 100%;
  }
  .section-title{
  	font-size: 36px;
  }
  .section-title span{
  	font-size: 18px;
  }
  .view-all {
    margin-top: 0.5rem;
    display: block;
  }
  .link_more.pc{
  	display: none;
  }
  .link_more.sp{
  	display: flex;
  }
  .link_more.gn{
  	justify-content: center;
  }
}




.slider-container h2{
  font-size: 72px;
font-family: "Josefin Sans", sans-serif;
  font-weight: 600;
  margin: 0 0 50px;
  line-height: 1.2;
}
.slider-container h2 span{
  font-size: 24px;
  color: rgb(16, 179, 171);
  display: block;
  letter-spacing: 1.2rem;
  margin-top: 1rem;
}
/* コラム用 ループ */
    .slider-container {
      width: 100%;
padding: 80px 0;
      overflow: hidden;
    }
    .slider-track {
      display: flex;
      will-change: transform;
    }
    .card {
      flex: 0 0 auto;
      width: 300px;
      height: 390px;
      margin: 10px;
      background: #fff;
      overflow: hidden;
      display: flex;
      flex-direction: column;
    }
    .card img {
      width: 100%;
      height: 200px;
      object-fit: cover;
    }
    .card-content {
      padding: 20px 30px 20px;
    }
    .column_date {
      margin-bottom: 5px;
  font-size: 16px;
  color: rgb(192, 192, 192);
  letter-spacing: .1rem;
    }
    .column_title {
      font-size: 16px;
      letter-spacing: .1rem;
      margin: 10px 0 0;
    }
    .card-content p{
    	margin: 0;
    	font-size: 15px;
		line-height:1.4;
    }
.slider-container .link_more{
justify-content: center;
margin: 50px 0 0;
}
.splide a{
	color: initial;
	text-decoration: none;
}

 @media (max-width: 768px) {
 	.slider-container {
    padding: 50px 0 0;
}
.slider-container h2{
	font-size: 36px;
}
.slider-container h2 span{
	font-size: 18px;
}
 }

    @media (max-width: 640px) {
      .card img {
        height: 200px;
      }
      .column_title {
        font-size: 0.9rem;
      }
    }



.site-info{
overflow: hidden;
}
.clinic_info_wp{
	position: relative;
	padding: 100px 100px;
	background-color: white;
	max-width: 1200px;
	margin: 0 auto 100px;
}
.clinic_info_wp:before{
content: '';
    background-color: white;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
left: auto;
    right: -100%;
}
.clinic_info{
	position: relative;
	margin-bottom: 100px;
}
.clinic_info .content{
	position: relative;
}
.info_wp{
	display: flex;
	align-items: end;
	gap: 30px;
}
.info_wp .left{
	flex: 1.6;
}
.info_wp .right{
	flex: 1 ;
}
.info_wp .right>div:first-child{
	margin-bottom: 2rem;
}
.info_wp .left h2{
  font-size: 72px;
font-family: "Josefin Sans", sans-serif;
  font-weight: 600;
}
.info_wp .left h2 span{
  font-size: 24px;
  color: rgb(16, 179, 171);
  display: block;
  letter-spacing: .05rem;
  margin-top: 1rem;
}
.info_wp .left dl{
	display: flex;
	align-items: flex-start;
	padding: 20px 0;
	border-top: 1px solid #000;
	margin: 0;
}
.info_wp .left dl:last-of-type{
	border-bottom: 1px solid #000;
}
.info_wp .left dt{
	font-family: "Josefin Sans", sans-serif;
	 color: rgb(16, 179, 171);
	 line-height: 1.6;
	 width: 20%;
	 letter-spacing: .05rem;
}
.info_wp .left dd{
	font-weight: 500;
	font-size: 16px;
	margin: 0;
	letter-spacing: .02rem;
}
.info_wp .left p.txt{
	text-align: center;
	margin: 0;
	font-size: 16px;
}
.info_wp .left p.txt span{
	color: rgb(16, 179, 171);
}

table.medicalhours {
	width: 100%;
	margin-top: 3rem;
	margin-bottom: 15px;
	border-collapse: collapse;
}
table.medicalhours th, table.medicalhours td {
	border: 1.5px solid black;
	text-align: center;
	padding: 13px 7px;
	letter-spacing: .1rem;
	font-weight: 500;
	font-size: 17px;
}
table.medicalhours th {
	line-height: 1;
}
table.medicalhours tr:nth-child(1) th {
	border-top: none;
}
table.medicalhours tr th:nth-child(1) {
	border-left: none;
}
table.medicalhours .maincolor {
	color: rgb(16, 179, 171);
}

@media(max-width:992px) {
	.clinic_info_wp{
		width: 100%;
		padding: 50px 0;
	}
	.info_wp{
		flex-direction: column;
	}
	.info_wp .left,.info_wp .right {
    flex: 1;
    width: 100%;
}
.info_wp .left h2{
	font-size: 36px;
}
.info_wp .left h2 span{
	font-size: 18px;
}
	.medical-item {
		max-width: 100%;
		flex-wrap: wrap;
		justify-content: center;
		margin: 0;
	}
}
@media(max-width:576px) {
  .info_wp .left dl{
    flex-direction: column;
  }
	 table.medicalhours {
		margin-bottom: 5px;
	}
	 table.medicalhours th,  table.medicalhours td {
		font-size: 13px;
	}
	#medicalhour table.medicalhours {
		margin-bottom: 3px;
	}
	table.medicalhours th, table.medicalhours td {
		padding: 5px;
	}
  .info_wp .right iframe{
    height: 350px;
  }
}


.bnr{
	display: flex;
	justify-content: space-between;
	gap:30px;
	position: relative;
}
@media(max-width:768px) {
	.bnr{
	flex-direction: column;
	justify-content: center;
  padding: 0 20px;
}
.bnr img{
	width: 100%;
}
}



/* フッター */
.footer_manu_wp{
	padding: 70px 0 150px;
}
.site-footer{
position: relative;
z-index: 999;
}
.home .site-footer{
padding: 100px 0 0;
}
.footer_m_area{
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.footer_logo{
	flex: 1;
}
.footer_menu{
flex: 3;
}
.footer_m_area .main-navigation ul{
	        justify-content: end;
}
.main-menu.footer{
	margin-right: 0;
}
.main-menu.footer>li>a{
padding: 10px 0;
}
footer .contact{
	display: flex;
	justify-content: end;
	gap:20px;
	margin-top: 80px;
}
.footer .main-menu a .menu-subtitle {
color: #000;
font-size: 13px;
}
.footer .main-menu>li>a .menu-title {
color: rgb(0, 177, 168);
font-size: 18px;
}
.footer .main-menu .sub-menu a{
	padding: 10px 10px;
}
.footer .main-menu .sub-menu a .menu-title {
	color: #000;
font-size: 14px;
}

@media(max-width:992px) {
	.footer_logo img{
		max-width: 300px;
		margin: auto;
	}
	.footer_m_area{
		flex-direction: column;
	}
.main-navigation.footer {
	display: block!important;
}
.main-navigation.footer>ul {
	flex-direction: column;
}
.main-menu.footer>li>a{
	text-align: left;
}
.main-navigation.footer .sub-menu{
	margin: 0;
	padding: 0;
	list-style: none;
	justify-content: start;
}
}

@media(max-width:768px) {
footer .contact {
    flex-direction: column;
    justify-content: center;
    padding: 0 30px;
}
footer .contact img{
	width: 100%;
}
}

@media(max-width:567px) {
	.footer_logo{
		margin-bottom:30px;
	}
.footer_logo img{
		max-width: 250px;
	}
	.footer_manu_wp {
    padding: 40px 0 100px;
}
}





.container {
  display: flex;
}








.page_tlt{
	margin-bottom:100px;
}
.archive .page_tlt,.single .page_tlt{
	margin-bottom:0;
}
.archive h1.entry-title,.single h1.entry-title{
	margin-bottom:100px;
}
.page_tlt>p{
  font-size: 20px;
  font-family: "Josefin Sans", sans-serif;
  text-transform: uppercase;
  color: rgb(0, 177, 168);
  font-weight: 600;
  margin: 0;
}
.entry-title{
  font-size: 48px;
letter-spacing: .24rem;
margin-top: .5rem;
}

@media(max-width:992px) {
  .page_tlt{
    padding: 0 15px;
  }
  .entry-title{
    font-size: 28px;
  }
}















/* 目次 */
#ez-toc-container{
	border: none;
	padding: 50px 50px 30px;
}
div#ez-toc-container ul li, div#ez-toc-container ul li a {
	font-size: 18px;
	letter-spacing: .2rem;
	font-weight: 500;
	display: flex;
	align-items: center;
  text-decoration: none;
  color: initial;
  transition: color 0.2s ease;
}
.ez-toc-counter nav ul li a::before {
	content: counters(item, '.', decimal-leading-zero);
  font-size: 28px;
  font-family: "Josefin Sans", sans-serif;
  color: rgb(0, 177, 168);
  font-weight: 600;
  line-height: 1;
  margin-right: 1rem;
}
#ez-toc-container a:visited{
	color: initial;
}

@media screen and (max-width: 768px) {
  div#ez-toc-container {
    width: 100%;
    padding: 30px 15px 30px;
    margin-bottom: 50px;
}
div#ez-toc-container ul li, div#ez-toc-container ul li a{
  font-size: 16px;
}
}






/* ページトップ */
#pageTop {
      position: fixed;
      bottom: 40px;
      right: 5px;
      display: none;
      background-color: rgb(0, 177, 168);
      color: white;
      padding: 12px 16px;
      border-radius: 8px;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 4px 8px rgba(0,0,0,0.2);
      z-index: 1000;
    }
    #pageTop:hover {
      opacity: 0.8;
    }





.contents article .entry-content h2{
  font-size: 30px;
  color: rgb(0, 177, 168);
  line-height: 1.75;
  border-bottom: 1px solid rgb(0, 177, 168);
  letter-spacing: .2rem;
}
.contents article .entry-content h3{
  font-size: 22px;
  color: white;
  line-height: 1.75;
  letter-spacing: .2rem;
  background-color: rgb(0, 177, 168);
  display: inline-block;
  padding: 0 1rem;
}
.contents article .entry-content h4{
  font-size: 20px;
  color: rgb(0, 177, 168);;
  line-height: 1.75;
  letter-spacing: .2rem;
}

@media screen and (max-width: 992px) {
  .contents article .entry-content h2{
    margin-left: 15px;
    margin-right: 15px;
    font-size: 26px;
    line-height: 1.5;
  }
  .contents article .entry-content h3{
    display: block;
    padding-top: 10px;
    padding-bottom: 10px;
	  font-size: 20px;
  }
	.contents article .entry-content h4{
		padding:0 15px;
	}
}










.content_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin: 40px 0;
}
.text_content {
  flex: 1.5;
  min-width: 280px;
}
.text_content h2 {
  font-size: 1.8em;
  margin-bottom: 0.5em;
}
.text_content p {
  font-size: 22px;
  line-height: 2.1;
  letter-spacing: .2rem;
  font-weight: 500;
}
.image_content {
  flex: 1;
  min-width: 280px;
  text-align: right;
  line-height: 0;
}
.image_content img {
  max-width: 100%;
  height: auto;
}
.square .image_content img{
	max-width: 350px;
}

/* レスポンシブ対応（スマホなど） */
@media screen and (max-width: 992px) {
  .content_box {
    flex-direction: column;
    gap: 0;
  }
  .text_content{
    order: 2;
  }
  .text_content p{
    padding: 0 15px;
  }
  .image_content {
    width: 100%;
    text-align: center;
    order: 1;
  }
  .image_content img{
    width: 100%;
    max-width: 100%!important;
  }
  .content_box .text_content h3{
    margin-top: 0;
  }
}


.white_box{
	background-color: white;
}
.white_box ul{
	padding: 2rem 2rem 2rem 3rem;
	margin: 0;
}
.white_box li{
	font-size: 18px;
	margin: 1.5rem 0;
}




/* アコーディオン */
.qa{
  max-width: 100%;
  margin: auto;
	margin-bottom:60px;
}
.qa dl {
  position: relative;
  margin: 30px 0 0;
  cursor: pointer;
  border: 1px solid rgb(0, 177, 168);
}
.qa dl:first-child {
  margin-top: 0;
}
.qa dl::after {
  position: absolute;
  top: 27px;
  right: 26px;
  display: block;
  width: 7px;
  height: 7px;
  margin: auto;
  content: '';
  transform: rotate(135deg);
  border-top: 2px solid white;
  border-right: 2px solid white;
}
.qa .on::after {
  transform: rotate(-45deg);
}
.qa dl dt {
  position: relative;
  margin: 0;
  padding: 20px 50px 20px 60px;
  font-weight: 500;
  font-size: 20px;
  line-height: 1.5;
  background: rgb(0, 177, 168);
  color: white;
}
.qa dl dt::before {
  font-size: 22px;
  line-height: 1;
  position: absolute;
  top: 20px;
  left: 20px;
  display: block;
  content: 'Q.';
  color: white;
}
.qa dl dd::before {
  font-size: 22px;
  line-height: 1;
  position: absolute;
  left: 20px;
  display: block;
  content: 'A.';
  font-weight: bold;
}
.qa dl dd {
  position: relative;
  margin: 0;
  padding: 20px 20px 20px 60px;
  display: none;
}
.qa dl dd p {
  margin: 30px 0 0;
}
.qa dl dd p:first-child{
  margin-top: 0;
}
.qa h4{
  font-size: 100%;
  margin: 30px 0 0;
}
.qa p.txt{
  margin: 10px 0 0;
}

@media screen and (max-width: 767px) {
  .qa{
    padding: 0 15px;
  }
  .qa dl {
    margin: 10px 0 0;
  }
  .qa dl:after {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
  }
  .qa dl dt {
    padding: 16px 26px 16px 50px;
    font-size: 16px;
  }
  .qa dl dt::before {
    font-size: 14px;
    top: 20px;
    left: 20px;
  }
  .qa dl dd::before {
    font-size: 14px;
    left: 20px;
    margin-top: 5px;
  }
  .qa dl dd {
    margin: 0;
    padding: 16px 16px 16px 50px;
    font-size: 14px;
  }
  .qa dl dd p {
    margin: 30px 0 0;
    font-size: 15px;
  }
  .qa dl dd p:first-child{
    margin-top: 0;
  }
}



/* フローチャート */
.flow-container {
  max-width: 100%;
  margin: 0 auto;
  padding: 30px 0;
}
.flow-container h2 {
  text-align: center;
  font-size: 24px;
  margin-bottom: 30px;
  color: #333;
}
.flow-block {
display: flex;
    flex-wrap: wrap;
    margin-bottom: 25px;
    padding: 2rem;
    background-color: #fff;
    border-left: 6px solid #04b1a9;
}
.flow-block:last-of-type{
	margin-bottom: 0;
}
.flow-container .time {
    width: 30%;
    min-width: 120px;
    font-size: 20px;
    font-weight: bold;
    color: #04b1a9;
}
.flow-container .task {
  width: 70%;
  min-width: 200px;
}
.flow-container .main-task {
font-weight: bold;
    font-size: 18px;
    margin-bottom: 15px;
}
.flow-container .details {
margin: 0;
}

/* レスポンシブ対応 */
@media screen and (max-width: 992px) {
  .flow-container{
    padding: 0 15px;
  }
  .flow-block {
    flex-direction: column;
  }
  .flow-container .time, .flow-container .task {
    width: 100%;
  }
  .flow-container .time {
    margin-bottom: 5px;
	  margin-top: 0;
        font-size: 22px;
  }
}






/* テーブルデザイン */
.employment-conditions {
  max-width: 100%;
  margin: 40px auto;
}
.table-wrapper {
  overflow-x: auto;
}
.responsive-table {
  width: 100%;
  border-collapse: collapse;
  background-color: #fff;
  overflow: hidden;
}
.responsive-table th,
.responsive-table td {
  padding: 20px;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.responsive-table th {
  width: 30%;
  background-color: #f0f5f9;
  font-weight: bold;
  font-size: 18px;
  text-align: center;
}
.responsive-table td {
  font-size: 18px;
  line-height: 1.8;
}

/* モバイル対応（縦型表示） */
@media screen and (max-width: 992px) {
 .employment-conditions{
padding: 30px 15px;
  }
  .responsive-table,
  .responsive-table thead,
  .responsive-table tbody,
  .responsive-table tr,
  .responsive-table th,
  .responsive-table td {
    display: block;
    width: 100%;
  }
  .responsive-table tr {
    padding-bottom: 10px;
  }
  .responsive-table th {
    padding: 15px 0;
    border: none;
  }
  .responsive-table td {
    border-bottom: none;
  }
  .responsive-table th{
    font-size: 16px;
  }
  .responsive-table td{
    font-size: 15px;
  }
}



/* テーブルリスト */
.table-list-container {
  max-width: 100%;
  margin: 50px auto;
  padding: 30px 20px;
  background-color: #fff;
}
.table-list-container h2 {
  font-size: 24px;
  text-align: center;
  color: #2c3e50;
  margin-bottom: 30px;
  letter-spacing: 1px;
  border-bottom: 1px solid #eee;
  padding-bottom: 10px;
}
.table-list {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 12px;
}
.table-list th{
	  width: 30%;
  font-weight: bold;
  padding: 16px 20px;
  background-color: #eaf1f1;
  border-left: 6px solid rgb(0, 177, 168);
  text-align: left;
  vertical-align: middle;
}
.table-list td {
  padding: 16px 20px;
  vertical-align: top;
  background-color: white;
  line-height: 1.8;
}

/* レスポンシブ対応 */
@media screen and (max-width: 992px) {
  .table-list{
    padding: 0 15px;
  }
  .table-list th,
  .table-list td {
    display: block;
    width: 100%;
    margin-bottom: 10px;
  }
  .table-list {
    border-spacing: 0 6px;
  }
}


/* 流れ */
.first-flow-container {
  max-width: 100%;
  margin: 50px auto;
  padding: 30px 20px;
  background-color: #fff;
}
.first-flow-step {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
  padding-bottom: 40px;
  gap: 20px;
  flex-wrap: wrap;
  border-bottom: 1px dashed #ccc;
}
.first-step-text {
  display: flex;
  align-items: flex-start;
  flex: 1;
  min-width: 250px;
}
.first-step-number {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  background: linear-gradient(145deg, #ffcd00, #ffcd00);
  color: #fff;
  font-weight: bold;
  border-radius: 50%;
  text-align: center;
  line-height: 48px;
  margin-right: 20px;
}
.first-step-content h3 {
  margin: 0 0 8px;
  color: #2c3e50;
}
.first-step-content p {
  margin: 0;
  color: #555;
  font-size: 15px;
  line-height: 1.6;
}
.first-step-image {
  flex-shrink: 0;
}
.first-step-image img {
  width: 250px;
  height: auto;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .first-flow-step {
    flex-direction: column;
    align-items: flex-start;
  }
  .first-step-text {
    flex-direction: row;
    margin-bottom: 15px;
  }
  .first-step-image img {
    width: 100%;
    max-width: 100%;
  }
}




/* aboutコンテンツ */
.about-container dl{
	background: #fff;
    padding: 15px;
}
.about-container dl dt{
	    background: #eaf1f1;
    padding: 10px;
}
.about-container dl dd{
	margin: 0;
	padding: 10px;
}



/* 料金表 */
.price-dl-container {
  max-width: 100%;
  margin: 0 auto 50px;
  padding: 30px 20px;
  background-color: #fff;
}
.price-list {
  margin: 0;
  padding: 0;
}
.price-item {
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #eee;
  padding: 15px 0;
}
.price-item dt {
  width: 50%;
  font-weight: bold;
  background: #f0f0f0;
    padding: 10px 15px;
}
.price-item dd {
  width: 50%;
  margin: 0;
  background: #f0f0f0;
  color: #555;
  font-size: 17px;
  display: flex;
    align-items: center;
}
.price-item .price {
  font-weight: bold;
  color: #b88900;
  margin-right: 10px;
}
.price-item .note {
  font-size: 14px;
  color: #888;
}
.price-item>p{
font-size: 16px!important;
margin: 0;
padding: 15px 15px;
}

/* レスポンシブ対応 */
@media screen and (max-width: 992px) {
  .price-item dt,
  .price-item dd {
    width: 100%;
    margin-bottom: 8px;
  }
  .price-item dd {
    padding-left: 10px;
  }
}

@media screen and (max-width: 567px) {
  .price-item dd{
    padding:10px 15px;
}
}




/* スタッフ紹介 */
.staff-card {
  max-width: 100%;
  margin: 0 auto 20px;
  display: flex;
  flex-wrap: wrap;
  background-color: #fff;
  overflow: hidden;
}
.staff-card .staff-img {
  flex: 1 1 250px;
  min-width: 200px;
  text-align: center;
}
.staff-card .staff-img img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}
.staff-card .staff-info {
  flex: 2 1 400px;
  padding: 20px 30px;
}
.staff-card .position {
  font-size: 16px;
  color: #888;
  margin-bottom: 4px;
}
.staff-card .name {
  font-size: 22px!important;
  color: #2c3e50!important;
  margin: 0 0 20px!important;
  border-bottom: 1px solid #ddd;
  padding-bottom: 10px;
  background: none!important;
}
.staff-card .section {
  margin-bottom: 20px;
}
.staff-card .section h4 {
  font-size: 16px!important;
  color: #555!important;
  margin-bottom: 8px;
  border-left: 4px solid #d4af37;
  padding-left: 10px;
}
.staff-card .section ul {
  list-style: disc;
  padding-left: 20px;
  margin: 0;
}
.staff-card .section p {
  margin: 0;
  line-height: 1.6;
  color: #444;
  font-size: 15px!important;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .staff-card {
    flex-direction: column;
    padding-top: 30px;
  }
  .staff-img {
    width: 100%;
    padding: 0 50px;
  }
  .staff-info {
    padding: 20px;
  }
}




.numbered-list {
  max-width: 100%;
  margin: 40px auto;
  padding: 0 20px;
}
.numbered-list .item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 24px;
  background: #fff;
  border-left: 6px solid rgb(0, 177, 168);
  padding: 20px 20px 20px 16px;
}
.numbered-list .number {
  width: 36px;
  height: 36px;
  background-color: rgb(0, 177, 168);
  color: white;
  font-weight: 600;
  font-size: 16px;
  border-radius: 50%;
  text-align: center;
  line-height: 36px;
  margin-right: 18px;
  flex-shrink: 0;
}
.numbered-list .cols h4 {
  margin: 0 0 6px;
  line-height: 1.2!important;
}
.numbered-list .cols p {
  margin: 0;
}


/* 比較テーブル */
.comparison_table {
      max-width: 100%;
      overflow-x: auto;
      background: #fff;
      border-radius: 10px;
      box-shadow: 0 4px 12px rgba(0,0,0,0.1);
      padding: 1rem;
    }
    .comparison_table table {
      width: 100%;
      border-collapse: collapse;
      min-width: 600px;
    }
    .comparison_table thead th {
      background: rgb(0, 177, 168);
      color: #fff;
      border-right: 1px solid #fff;
      padding: 0.9rem;
      font-weight: bold;
      font-size: 1rem;
      width: 25%;
    }
    .comparison_table tbody td {
      padding: 0.8rem;
      border-bottom: 1px solid #ddd;
      border-left: 1px solid #ddd;
      font-size: 0.95rem;
    }
    .comparison_table tbody td:last-child {
      border-right: 1px solid #ddd;
    }
    .comparison_table::-webkit-scrollbar {
      height: 8px;
    }
    .comparison_table::-webkit-scrollbar-thumb {
      background-color: #aaa;
      border-radius: 4px;
    }

    @media(max-width: 992px){
.comparison_table thead th,
.comparison_table tbody td {
      white-space: nowrap;
    }
    }




/* メリット・デメリット */
    .merit .wp {
      max-width: 960px;
      margin: auto;
      display: flex;
      flex-wrap: wrap;
      gap: 1.5rem;
    }
    .merit .column {
      flex: 1 1 45%;
      background: #fff;
      padding: 1.5rem;
      border-radius: 12px;
      box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    }
    .merit .column h4 {
      font-size: 1.3rem;
      margin-top: 0;
      margin-bottom: 1rem;
      border-left: 5px solid #00b1a8;
      padding-left: 0.6rem;
      color: #00b1a8;
    }
    .merit ul {
      padding-left: 1.2rem;
      margin: 0;
    }
    .merit ul li {
      margin-bottom: 0.8rem;
    }
    .merit ul li:last-child {
      margin-bottom: 0;
    }

    /* レスポンシブ対応 */
    @media (max-width: 992px) {
      .merit{
        padding: 0 15px;
      }
      .merit .column {
        flex: 1 1 100%;
      }
    }

/* ステップ */
    .steps {
      max-width: 100%;
      margin: auto;
      display: flex;
      flex-direction: column;
      gap: 2rem;
    }
    .step {
      display: flex;
      align-items: flex-start;
      gap: 1.2rem;
      background: #fff;
      padding: 1.2rem 1.6rem;
    }
    .step-number {
      flex-shrink: 0;
      width: 50px;
      height: 50px;
      background: #00b1a8;
      color: #fff;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: bold;
      font-size: 1.2rem;
    }
    .step-content h3 {
      margin: 0;
      padding: 0!important;
      font-size: 1.1rem!important;
      background: none!important;
      color: rgb(0, 177, 168)!important;
    }
    .step-content p {
      margin: 0.2rem 0 0;
      font-size: 0.95rem;
    }

    /* レスポンシブ */
    @media (max-width: 992px) {
      .step {
        flex-direction: column;
        align-items: center;
        text-align: center;
      }
      .step-content p{
      	text-align: left;
      }
    }


    .access-info {
      display: flex;
      flex-wrap: wrap;
	align-items:center;
      background: #fff;
      margin-bottom: 40px;
    }
    .access-info .image {
      flex: 1 1 300px;
    }
    .access-info .image img {
      width: 100%;
      height: auto;
    }
    .access-info .text {
      flex: 1 1 400px;
      padding: 20px;
    }
    .access-info .text h2 {
      margin-top: 0;
      color: #007777;
    }
    .access_info_michi{
    	display: flex;
      flex-wrap: wrap;
      margin-bottom: 40px;
    }
    .access_info_michi .image {
      flex: 1 1 200px;
    }
    .access_info_michi .text {
      flex: 1 1 500px;
      padding: 20px;
    }
    .access_link{
    	display: flex;
    	flex-wrap: wrap;
    	justify-content: center;
    	gap: 10px;
    	list-style: none;
    	margin: 0;
    	padding: 0;
    }
    .access_link li a{
    	color: rgb(16, 179, 171);
    border-color: rgb(16, 179, 171);
        display: block;
    width: 100%;
    max-width: 300px;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.1em;
    background: white;
    color: #13BCCB;
    padding: 15px 25px 15px 15px;
    box-sizing: border-box;
    position: relative;
    border: 1px solid #13BCCB;
    text-decoration: none;
    }
    .accessmap {
      margin-bottom: 40px;
    }
    .accessmap iframe {
      width: 100%;
      height: 400px;
      border: 0;
      border-radius: 8px;
    }
    table.clinic-table {
      width: 100%;
      border-collapse: collapse;
      background: #fff;
      overflow: hidden;
    }
    .clinic-table th,
    .clinic-table td {
      padding: 12px 16px;
      border-bottom: 1px solid #eee;
      text-align: left;
    }
    .clinic-table th {
      background-color: #f0f5f9;
      width: 30%;
      color: #333;
    }

    @media screen and (max-width: 768px) {
      .access-info {
        flex-direction: column;
      }
      .access-info .image img {
        border-radius: 8px 8px 0 0;
      }
      .access-info .text {
        padding: 16px;
      }
      .clinic-table th,
      .clinic-table td {
        display: block;
        width: 100%;
      }
      .clinic-table th {
        background-color: #e0f7f7;
      }
      .access_link li{
        width: 90%;
        text-align: center;
        margin: auto;
      }
      .access_link li a{
        max-width: 100%;
      }
    }

















/* ハンバーガー */
.menu-toggle {
  display: none;
          position: fixed;
	top: 1rem;
    left: 1rem;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 40px;
  height: 30px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 1001;
}
.bar {
  height: 3px;
  width: 30px;
  background: #333;
  border-radius: 2px;
  transition: 0.3s;
}
.home .bar{
background: #fff;
}
/* バツアニメーション */
.menu-toggle.active .bar1 {
  transform: rotate(45deg) translate(7px, 5px);
}
.menu-toggle.active .bar2 {
  opacity: 0;
}
.menu-toggle.active .bar3 {
  transform: rotate(-45deg) translate(7px, -6px);
}

/* オーバーレイ */
.menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
  z-index: 999;
  display: none;
}

/* メニュー本体（スライド） */
.global-nav {
  position: fixed;
  top: 0;
  right: -300px;
  width: 300px;
  height: 100vh;
  background: #fff;
  padding: 40px 20px;
  box-shadow: -2px 0 10px rgba(0,0,0,0.1);
  transition: right 0.3s ease;
  z-index: 1000;
  overflow-y: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.global-nav::-webkit-scrollbar{
  display: none;
}
.global-nav.active {
  right: 0;
}
.menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.menu li {
  border-bottom: 1px solid #eee;
  padding: 10px 0;
}
.global-nav .menu li a{
	color: #000;
	text-decoration: none;
}
.menu li.menu-item-has-children > a::after {
  content: '▼';
  float: right;
  font-size: 0.8em;
  margin-left: 5px;
  margin-top: -2rem;
  transition: transform 0.3s ease;
}
.menu li.open > a::after {
  transform: rotate(180deg);
}
.menu ul {
  display: none;
  padding-left: 15px;
  list-style: none;
  padding: 0;
}
.menu li > ul .menu-title{
font-size: 14px;
}
.menu li a{
	color: #000;
	text-decoration: none;
}
.menu li > ul > li:last-child{
border-bottom:none;
}
.menu li.open > ul {
  display: block;
}


/* レスポンシブ */
@media (min-width: 992px) {
  .menu-toggle,
  .menu-overlay,
  .global-nav {
    display: none;
  }
}


/* ハンバーガー表示（スマホ） */
@media (max-width: 992px) {
	.main-navigation.pc,.sidebar{
display: none;
	}
  .menu-toggle {
    display: flex;
  }
  .home .main-menu a{
  	color: #000;
  }
}



@media (max-width: 992px) {
  .footer_menu{
    display: none;
  }
.home .footer_menu{
    display: block!important;
  }
}



/* --- Job Apply Form Styles (responsive) --- */
.job-apply-form { 
  max-width: 980px;
  margin: 0 auto 50px;
  padding: 20px;
  box-sizing: border-box;
  background: #ffffff;
  border-radius: 10px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.06);
  color: rgb(0 121 115);
}

/* grid */
.job-apply-form .row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.job-apply-form .full { margin-bottom: 12px; }

.job-apply-form label {
  display: block;
  line-height: 1.4;
}

.job-apply-form label .req { color: #c0392b; margin-left: 4px; font-weight: 700; }

/* inputs */
.job-apply-form input[type="text"],
.job-apply-form input[type="email"],
.job-apply-form input[type="tel"],
.job-apply-form input[type="url"],
.job-apply-form input[type="number"],
.job-apply-form input[type="date"],
.job-apply-form select,
.job-apply-form textarea,
.job-apply-form input[type="file"] {
  width: 100%;
  padding: 10px 12px;
  box-sizing: border-box;
  border: 1px solid #d6dbe8;
  border-radius: 6px;
  background: #fff;
  margin-top: 6px;
}

/* small helper */
.job-apply-form small { margin-top: 6px; font-size: 12px; }

/* consent */
.job-apply-form .consent {
  margin: 14px 0;
}
.job-apply-form .consent input[type="checkbox"] {
  transform: scale(1.05);
  margin-right: 8px;
}

/* actions */
.job-apply-form .actions {
  text-align: left;
  margin-top: 10px;
}
.job-apply-form .actions input[type="submit"],
.job-apply-form .actions button {
  display: inline-block;
  padding: 12px 22px;
  border-radius: 8px;
  border: none;
  background: #00b4aa;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  font-size: 15px;
  box-shadow: 0 6px 18px rgba(33,58,112,0.15);
}
.job-apply-form .actions input[type="submit"]:hover {
  transform: translateY(-2px);
}

/* desktop 2-column layout */
@media (min-width: 760px) {
  .job-apply-form .row {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
  .job-apply-form .full { grid-column: 1 / -1; }
  .job-apply-form .consent { grid-column: 1 / -1; text-align:center;}
  .job-apply-form .actions { grid-column: 1 / -1; text-align:center;}
}

/* wider screens padding */
@media (min-width: 1100px) {
  .job-apply-form { padding: 32px; }
}

/* focus */
.job-apply-form input:focus,
.job-apply-form textarea:focus,
.job-apply-form select:focus {
  outline: none;
  border-color: rgba(33,58,112,0.9);
  box-shadow: 0 0 0 3px rgba(33,58,112,0.08);
}

/* accessibility: required visual indicator */
.job-apply-form .req { font-size: 13px; }

/* error / validation styles (CF7 adds .wpcf7-not-valid) */
.job-apply-form .wpcf7-not-valid {
  border-color: #c0392b !important;
  background: #fff6f6;
}

/* file input - improve appearance on desktop */
.job-apply-form input[type="file"] {
  padding: 8px 10px;
}

/* link in consent */
.job-apply-form .consent a { color: rgb(0 121 115); text-decoration: underline; }


.job-link-section {
  padding: 40px 20px;
  background: #f6f8fb;
}

.job-link-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.job-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  color: #213a70;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.job-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0,0,0,0.12);
}

.job-card-image img {
  width: 100%;
  height: auto;
  display: block;
}

.job-card-body {
  padding: 16px;
  text-align: center;
}

.job-card-body h3 {
  font-size: 1.2rem;
  line-height: 1.4;
  margin: 0;
  font-weight: 700;
	width:100%;
}

.job-link-container .job-card:nth-child(2) .job-card-body h3{
	background:rgb(255 144 182);
}
.job-link-container .job-card:nth-child(3) .job-card-body h3{
	background:#fac72e;
}

/* タブレット（2カラム） */
@media (min-width: 600px) {
  .job-link-container {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* PC（3カラム） */
@media (min-width: 900px) {
  .job-link-container {
    grid-template-columns: repeat(3, 1fr);
  }
}


.fixed-side-buttons {
  position: fixed;
  bottom: 100px;
  right: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 1000;
}

.fixed-side-buttons .side-btn {
  display: inline-block;
  text-align: center;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  white-space: nowrap;
}

.fixed-side-buttons .side-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.2);
}

.fixed-side-buttons .web-btn {
  background-color: #213a70;
}

.fixed-side-buttons .line-btn {
  background-color: #06c755;
}

/* スマホ */
@media (max-width: 600px) {
  .fixed-side-buttons {
    bottom: 10px;
    right: auto;
	  left:10px;
    gap: 8px;
  }
  .fixed-side-buttons .side-btn {
    font-size: 12px;
    padding: 8px 10px;
  }
}


/* スマホのみ適用（幅768px以下） */
@media (max-width: 768px) {
  .price-dl-container {
    display: none;
    margin-bottom: 1.5rem;
  }
  h2.sp_oc {
    cursor: pointer;
    position: relative;
    padding-right: 2rem;
  }
  h2.sp_oc::after {
    content: "＋";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    font-weight: bold;
    font-size: 1.2rem;
  }
  h2.sp_oc.active::after {
    content: "−";
  }
}


:root {
  --dds: rgb(0, 177, 168);
  --bgds: #fff;
  --radiusds: 12px;
  --shadowds: 0 6px 18px rgba(0,0,0,0.06);
}
.cardds {
  max-width: 1000px;
  margin: 0 auto;
  background: var(--bgds);
  border-radius: var(--radiusds);
  box-shadow: var(--shadowds);
  padding: 24px;
}
.cardds h3 {
  font-size: 1.6rem!important;
  color: var(--dds)!important;
background:none!important;
  margin-bottom: 10px;
  border-left: 6px solid var(--dds);
  padding: 0 0 0 10px!important;
}
.featuresds {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 20px;
}
.featureds {
  border: 1px solid rgba(0,177,168,0.2);
  border-radius: var(--radiusds);
  padding: 16px;
  background: #fcfefe;
}
.featureds h4 {
  font-size: 1.1rem;
  margin: 0 0 8px;
  color: var(--dds);
}
.featureds p {
  margin: 0;
  font-size: 0.95rem;
}
.cardds .content_box{
	margin:0;
}
@media (min-width: 700px) {
  .featuresds {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
	.cardds h3 {
		font-size: 1.4rem !important;
		        line-height: 1.4 !important;
	}
	.cardds .content_box .text_content h3{
		margin-top:1rem!important;
	}
}

:root {
--brandst: rgb(0, 177, 168);
--bgst: #fff;
--radiusst: 12px;
--shadowst: 0 6px 18px rgba(0,0,0,0.06);
}
.flowst {
display: grid;
grid-template-columns: 1fr;
gap: 24px;
max-width: 1100px;
margin: 0 auto;
}
.stepst {
display: flex;
flex-direction: column;
background: var(--bgst);
border-radius: var(--radiusst);
overflow: hidden;
box-shadow: var(--shadowst);
}
.stepst img {
width: 100%;
height: 200px;
object-fit: cover;
}
.stepst-content {
padding: 18px 20px;
}
.stepst-number {
display: inline-block;
background: var(--brandst);
color: #fff;
font-weight: bold;
font-size: 0.9rem;
padding: 4px 10px;
border-radius: 20px;
margin-bottom: 10px;
}
.stepst h3 {
margin: 0 0 10px;
color: var(--brandst)!important;
background: none !important;
display:block!important;
}
.stepst p {
margin: 0;
font-size: 0.95rem;
}
@media (min-width: 768px) {
.flowst {
  grid-template-columns: 1fr 1fr;
}
.stepst img {
  height: 220px;
}
}

.list_content {
  max-width: 100%;
  margin: 40px auto;
}
.list_content ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.list_content li {
  position: relative;
  background: #fff;
  border-left: 6px solid rgb(0, 177, 168);
  margin-bottom: 20px;
  padding: 16px 20px 16px 50px;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  font-size: 1rem;
	font-weight: 500;
  line-height: 1.6;
}
.list_content li::before {
  content: "✔";
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  color: rgb(0, 177, 168);
  font-weight: bold;
}
/* レスポンシブ対応 */
@media (max-width: 600px) {
  .list_content li {
    font-size: 0.95rem;
    padding: 14px 16px 14px 44px;
  }
  .list_content li::before {
    left: 12px;
    font-size: 1rem;
  }
}

.section_koujyo {
  margin-top: 30px;
  padding: 20px;
  border-radius: 10px;
  background: #fff;
  border-left: 6px solid rgb(0, 177, 168);
}
.section_koujyo h3 {
  color: rgb(0, 177, 168);
  font-size: 1.2rem;
  margin-bottom: 10px;
}
.section_koujyo ul {
  margin: 10px 0 0 20px;
}
.highlight_t {
  background: #eaf1f1;
  border: 1px solid rgb(0, 177, 168);
  padding: 15px;
  border-radius: 8px;
  margin-top: 10px;
}
.formula_f {
  background: #eaf1f1;
  border: 1px dashed rgb(0, 177, 168);
  padding: 12px;
  border-radius: 6px;
  font-weight: bold;
  text-align: center;
  margin: 15px 0;
}
.table-wrap_w {
  overflow-x: auto;
}
.table-wrap_w table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
  background: #fff;
}
.table-wrap_w th, .table-wrap_w td {
  border: 1px solid #ccc;
  padding: 10px;
  text-align: center;
  font-size: 0.9rem;
}
.table-wrap_w th {
  background: #eaf1f1;
}
.notice_n {
  background: #eaf1f1;
  border-left: 4px solid rgb(0, 177, 168);
  padding: 10px 15px;
  margin-top: 15px;
  border-radius: 6px;
}
@media (max-width: 600px) {
  .table-wrap_w th, .table-wrap_w td { font-size: 0.8rem; }
}