@import url("style.css");

.t-c {
	text-align: center;
	justify-content: center;
}

.none_pc {
	display: none;
}

.w40p {
	width: 40% !important;
}
.w80p {
	width: 80% !important;	
}
.mb20 {
	margin-bottom: 20px;
}
.mb50 {
	margin-bottom: 50px !important;
	line-height: 180%;
}
.mb100 {
	margin-bottom: 100px !important;
}

.other-wrap {
	width: 980px;
	margin: 0 auto;
}
.other-wrap p {
	margin-bottom: 20px;
	font-size: 18px;
line-height: 180%;
word-break:break-all;
}
.other-wrap img {
	height: auto;
	object-fit: fill;
}

.flex-box01, .flex-box02 {
	display: flex;
	justify-content: space-between;
	gap: 4%;
	flex-wrap: wrap;
}
.flex-box01 > div {
	width: 48%;
	margin-bottom: 20px;
}
.flex-box02 > div:first-child {
	width: 58%;
}
.flex-box02 > div:last-child {
	width: 38%;
}

.other-title {
	text-align: center;
	padding: 160px 0px 70px 0px;
}
p.other-lead {
	font-size: 130%;
	line-height: 1.7;
	text-align: center;
	margin: 0 0 80px;
}
p.other-lead-left {
	font-size: 130%;
	line-height: 1.7;
	text-align: left;
	margin: 0 0 80px;
}

.outpatient-bg {
	background-image: url(/wp/images/outpatient/outpatient_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.medicalsub-bg {
	background-image: url(/wp/images/medicalsub/medicalsub_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.obesity-bg {
	background-image: url(/wp/images/obesity/obesity_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.hospitalization-bg {
	background-image: url(/wp/images/hospitalization/hospitalization_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.rehabilitation-bg {
	background-image: url(/wp/images/rehabilitation/rehabilitation_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
/*.recruit-bg {
	background-image: url(/wp/images/recruit/recruit_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	padding-top: 450px;
}
.recruit-bg h2 {
	display: none;
}*/

.outpatient-list {
	width: 70%;
	margin: 0 auto 30px;
}
.outpatient-list > li {
	padding-left: 50px;
	position: relative;
	margin-bottom: 50px;
}
.outpatient-list > li > p {

}
.outpatient-list > li .t-c{
	text-indent: 0;
}
.outpatient-list li h4 {
	margin-bottom: 20px;
	display: flex;
	align-items: baseline;
	gap: 20px;
	line-height: 1.5;
	word-break: keep-all;
	padding-left: 4.3rem;
	text-indent: -4.3rem;
}
.outpatient-list li h4::before {
	content: "■";
	color: #f4d7e1;
	font-size: 80%;
}
.outpatient-list-title {
	font-size: 130%;
	position: relative;
	margin-bottom: 20px;
}
.outpatient-list-title span {
	font-size: 110%;
	color: #c24b5c;
	position: absolute;
	left: -50px;
	top:-2.0px;
}

.phone-number {
	font-size:  170%;
	font-weight: bold;
}

.outpatient-link {
	max-width: 480px;
	display: inline-block;
	margin-top: 70px;
	margin-bottom: 10px;
}

.medicalsub-box {
	display: flex;
	gap: 4%;
	line-height: 2;
	margin-bottom: 100px;
}
.medicalsub-box p {
	line-height: 2;
}
.medicalsub-box > div:first-child {
	width: 28%;
}
.medicalsub-box > div:last-child {
	width: 68%;
}

.medicalsub-h3 {
	font-size: 150%;
	border-bottom: 1px solid #bd7181;
	padding-bottom: 5px;
	margin-bottom: 20px;
}

.obesity-section {
	border-top: 1px solid #a9465c;
	padding: 100px 0;
}

.obesity-h3 {
	font-size: 150%;
	margin-bottom: 50px;
line-height: 150%;
}

.obesity-list li {
	margin-bottom: 20px;
	padding-left: 1.5rem;
	text-indent: -1.5rem;
font-size: 18px;
line-height: 140%;
}
ul.pink-circle li {
	margin-bottom: 20px;
}
.obesity-list li::before, ul.pink-circle li::before {
	content: "●";
	color: #f4d7e1;
	font-size: 80%;
	margin-right: 10px;	
}

.obesity-bmi {
	background: #f2f2f2;
	width: 80%;
	margin: 40px auto;
	padding: 30px 20px;
	text-align: center;
	line-height: 1.8;
	font-size: 150%;
}

.obesity-section img {
	margin-bottom: 20px;
}

.hospitalization-h3, .rehabilitation-h3 {
	font-size: 150%;
	margin: 100px 0 30px;
	color: #a9465c;
	text-align: center;
}

.hospitalization-pre {
	border: 1px solid #b0576b;
	display: flex;
	padding: 30px 50px 10px 50px;
	justify-content: space-between;
	margin-bottom: 40px;
}
.hospitalization-pre > div {
	width: 47%;
}
.hospitalization-pre ul li {
	margin-bottom: 20px;
}
.hospitalization-pre ul li input {
	margin-right: 15px;
}
.hospitalization-pre div:last-child ul li, .pink-circle li {
	text-indent: -1.4em;
	padding-left: 1.4em;
}

.hospitalization-flex > div {
	margin-bottom: 20px;
	width: 45%;
}
.hospitalization-flex > div > img {
	margin-bottom: 10px;
}
.hospitalization-flex > div > img + p {
	text-align: center;
}

.hospitalilzation-list li {
	width: 48%;
}

.etc-list {
	margin-bottom: 50px;
}
.etc-list li {
	margin-bottom: 40px;
line-height: 160%;
}

.recruit-h3 {
	font-size: 150%;
	margin-bottom: 40px;
	margin-top: 150px;
	color: #3a546a;
	text-align: center;
}
.recruit-h3:first-child {
	margin-top: 0;
}
.recruit-h3 + .other-lead {
	margin-top: 50px;
}

.recruit-h3 + .other-lead-left {
	margin-top: 50px;
}

.recruit-table {
	width: 100%;
	border-collapse: collapse;
max-width: 980px;
margin: 0 auto;
}
.recruit-table th, .recruit-table td {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	padding: 30px 0;
	text-align: left;
}
.recruit-table th {
	width: 15%;
font-size: 16px;
line-height: 150%;
}
.recruit-table td {
	width: 85%;
	padding-left: 20px;
	word-break: break-word;
font-size: 16px;
line-height: 160%;
}

.recruit-flex {
	display: flex;
	gap: 50px 6%;
	flex-wrap: wrap;
	word-break: break-word;
}
.recruit-flex a {
	width: 29%;
}
.recruit-flex > a > div {
	display: block;
}
.recruit-flex > a > div > img {
	margin-bottom: 20px;
}
.recruit-flex-content {
	display: flex;
	justify-content: space-between;
}
.recruit-flex-content p {
	margin-bottom: 0;
}
.recruit-flex-content > div:first-child {
	width: 15%;
}
.recruit-flex-content > div:last-child {
	width: 78%;
}
.recruit-flex .link-btn {
	width: 20%;
	margin: 20px auto 0;
}
.recruit-flex a {
	display: flex;
	align-items: center;
	justify-content: center;
}
.recruit-flex .more-btn-icon {
	display: inline-block;
}
.recruit-flex a:hover .more-btn-icon {
	display: inline-block;
}
.recruit-flex a:hover .more-btn-icon {
	transform: translateX(5px);
}

.rehabilitation-flex01, .rehabilitation-flex02 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.rehabilitation-flex01 > div {
	width: 30%;
	text-align: center;
}
.rehabilitation-flex01 > div img {
	margin-bottom: 10px;
}

.rehabilitation-flex02 > div:first-child {
	width: 20%;
}
.rehabilitation-flex02 > div:last-child {
	width: 78%;
}

.rehabilitation-h4 {
	color: #a9465c;
	font-size: 135%;
	border-bottom: 1px solid #a9465c;
	padding-bottom: 15px;
	margin: 50px 0 20px;
	line-height: 1.6;
}

.overview-h3 {
font-size: 28px;
margin: 10px 0 70px;
color: #a9465c;
text-align: center;
}

.tabu-h3 {
font-size: 28px;
margin: 4em 0em 3em 0em;
color: #39546b;
text-align: center;
}

.contx {
font-size: 28px;
margin: 4em 0em 1.5em 0em;
color: #39546b;
text-align: center;
}

.tabu-h3-pink {
font-size: 28px;
margin: 4em 0em 3em 0em;
color: #a9465c;
text-align: center;
}

.over_border{
border: none;         /* 既定の枠線を消す */
height: 4px;          /* 太さ 4px */
background: #f5d7e1;  /* 線の色 */
margin: 7em 0em;
}

.gaiyou_border{
border: none;         /* 既定の枠線を消す */
height: 1px;          /* 太さ 4px */
background: #cccccc;  /* 線の色 */
margin: 2em 0em;
}

.rinen{
font-size: 21px;
font-weight: bold;
text-align: center;
line-height: 2.1;
color: #333333;
}

.usulist {
	/*border: 1px solid #b0576b;*/
	display: flex;
	padding: 20px 50px 20px 50px;
	justify-content: space-between;
	margin-bottom: 40px;
}
.usulist > div {
	width: 47%;
}
.usulist ul li {
	margin-bottom: 20px;
}
.usulist ul li input {
	margin-right: 15px;
}
.usulist div:last-child ul li, .usu-circle li {
	text-indent: -1.4em;
	padding-left: 1.4em;
}

ul.usu-circle li {
	margin-bottom: 10px;
}
ul.usu-circle li::before {
	content: "●";
	color: #ab485d;
	font-size: 60%;
	margin-right: 10px;	
}

ul.rec-circle li {
	margin-bottom: 10px;
	text-indent: -1.4em;
	padding-left: 1.4em;
    font-size: 18px;
    line-height: 180%;
    word-break: break-all;
}
ul.rec-circle li::before {
	content: "●";
	color: #ab485d;
	font-size: 60%;
	margin-right: 10px;	
}

.recruitimg{
width: 100%;
padding-top: 0em;
}

.senpaiwaku{
background-color: #fff8ea;
padding: 3em;
}

.senflex01{
display: flex;
gap:3em;
}

.senflex02{
display: flex;
gap:1.5em;
}

.senpai01{
width: 70%;
}

.senpai02{
width: 30%;
}

.senpaitxt{
font-size: 18px;
line-height: 180%;
word-break: break-all;
width:92.5%;
}

.senpaittl{
font-size: 23px;
display:inline-block;
padding-bottom:18px;
padding-top: 16px;
}

.senpaino{
width:7.5%;
}

.senflex01_hanten{
display: flex;
flex-direction:row-reverse; 
gap:3em;
}

.form-wrap {
padding-top: 0 !important;
}

.form-box {
width: 100%;
max-width: 980px;
margin: 1em auto 0em;
text-align: center;
background-color: #eef4fb;
border-radius: 12px;
padding: 0.3em 0em 3em 0em;
margin-top: 0.5em;
}

.form-table {
width: 100%;
max-width: 898px;
margin: 0px auto;
border-collapse: separate;
border-spacing: 10px;
padding: 0em 0em 0em 0em;
margin-top: 2em !important;
}

.form-table th {
display: block;
padding: 0.2em 0.5em;
text-align: left;
vertical-align: top;
color: #214961;
width: 100%;
font-size: 17px;
line-height: 180%;
font-weight: bold;
}

.form-table td {
display: block;
padding: 0em 0.5em 0.5em 0em;
text-align: left;
vertical-align: top;
color: #000;
width: 100%;
font-size: 17px;
line-height: 180%;
font-weight: 400;
}

::placeholder {
color: #c3c3c3;
}

.doui {
display: block;
padding: 0em 2.8em;
line-height: 180%;
text-align: center;
vertical-align: top;
color: #5f3700;;
width: 100%;
font-size: 18px;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 600;
}

.cyuui{
color: red;
font-size: 16px;
}

.douinoue{
color: #000;
font-size: clamp(15.5px, 1.0vw, 21px);
font-family: 'Noto Sans JP', sans-serif;
font-weight: 600;
line-height: 170%;
word-break: break-all;
text-align: center;
margin-bottom: 3em;
}

.douinoue a{
color: #4169e1;
text-decoration: underline;
}

.btn-contact03{
width: 370px;
margin: 0 auto;
margin-top: 1em;
display: flex;
justify-content: center;
padding: 0.7em;
border: 2px solid;
border-color: #ab485d;
/*border-radius: 150px;*/
background-color: #ab485d !important;
color: #FFFFFF;
font-weight: 600;
font-size: 20px;
border-radius: 100px;
}

.btn-contact03:hover{
background-color: #FFFFFF !important;
color: #ab485d;
border: 2px solid;
border-color: #ab485d;
/*border-radius: 150px;*/
}

input, select {
  border: solid 1px #CCC;
  background-color: #FFFFFF !important;
  color: #333333;
  padding: 0.5em;
  margin: 0.5em;
  line-height:1.5 !important;
  /*cursor: pointer;*/
  vertical-align: middle;
}
textarea {
  border: solid 1px #CCC;
  background-color: #FFFFFF !important;
  color: #333333;
  padding: 0.5em;
  margin: 0.5em;
}
input#submit_button {
  width: 18%;
  cursor: pointer;
}
input#reset_button {
  width: 18%;
  cursor: pointer;
}

::placeholder {
  color:#CCC;
  font-size: 1em;
}

.hissu {
  text-align: center;
  font-size: 12px;
  line-height: 140%;
  color: #FFF;
  background-color: #ff5555;
  display: inline-block;
  padding: 3px 5px;
  margin: 0px 0 0 4px;
border-radius: 4px;
}

.btnnin{
background-color: var(--color--primary);
border-radius: 16px;
padding: 3px 14px;
color: #FFFFFF;
font-weight: normal;
border: 2px solid var(--color--primary) !important;
}

/* 幅を固定するときの“おまじない” */
.ov4 {
table-layout: fixed;   /* 幅計算を先に確定させる */
width: 100%;           /* （任意）テーブル自体の幅 */
max-width: 650px;
font-size: 18px;
line-height: 180%;
word-break: break-all;
}

/* 列ごとの幅指定 */
.ov4 th        { text-align: left; width:25%; }          /* 見出しセル */
.ov4 td:nth-child(2) { text-align: left; width: 50%; }    /* 1 列目の td  */
.ov4 td:nth-child(3) { width: 25%; text-align: right;}    /* 2 列目の td  */

.contel{
font-size: 30px;
font-weight: bold;
text-align: center;
}

.footerborder{
border-bottom: 1px solid #ccc;
height: 0;
margin: 7em 0em 1.5em 0em;
}

/* ===================
 ページトップへ
====================== */
#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 10px;
  bottom: 10px;
  background: #ab485d;
  opacity: 0.8;
  border-radius: 50%;
z-index: 5000;
}
#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before {
  font-family: FontAwesome;
  content: '\f106';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 40px;
  top: 10;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}



@media screen and (max-width: 767px) {

	.w40p, .w80p {
		width: 100% !important;
	}

	.none_pc {
		display: block;
	}

	.other-wrap {
		width: 90%;
	}
	.other-wrap p {
		font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break:break-all;
	}

	.flex-box01, .medicalsub-box {
		display: block;
	}
	.flex-box01 > div, .flex-box02 > div, .medicalsub-box > div, .flex-box01 > li {
		width: 100% !important;
		margin-bottom: 20px !important;
	}

	.outpatient-list {
		width: 100%;
	}

	.outpatient-list li h4 {
		padding-left: 0;
		text-indent: 0;
		gap: 5px;
	}

	.outpatient-list > li {
		padding-left: 0;
		text-indent: 0;
	}
	.outpatient-list-title span {
		position: relative;
		margin-right: 20px;
		left: 0;
	}

	.obesity-section {
		padding: 50px 0;
	}

	.obesity-bmi {
		width: 100%;
	}

	.hospitalization-pre {
		display: block;
	}
	.hospitalization-pre > div {
		width: 100%;
	}

	.usulist {
		display: block;
	}
	.usulist > div {
		width: 100%;
	}


	.rehabilitation-flex01 > div {
		width: 48%;
	}
	.rehabilitation-flex02 > div {
		width: 100% !important;
	}
	.rehabilitation-flex02 > div:first-child {
		margin-bottom: 20px;
	}

	/*.recruit-bg {
		background-image: url(/wp/images/recruit/recruit_bg.jpg);
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
		padding-top: 410px;
	}*/

	.recruit-flex {
		gap: 50px 4%;
	}
	.recruit-flex a {
		width: 48%;
	}
.obesity-list li {
margin-bottom: 20px;
padding-left: 1.5rem;
text-indent: -1.5rem;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 160%;
}
	
.pink-circle li {
margin-bottom: 20px;
padding-left: 1.5rem;
text-indent: -1.5rem;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 160%;
}

.hospitalization-pre {
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
padding: 1.5em 1em 1.5em 1em;
line-height: 160%;
}

.usu-circle li {
margin-bottom: 20px;
padding-left: 1.5rem;
text-indent: -1.5rem;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 160%;
}

.rec-circle li {
margin-bottom: 20px;
padding-left: 1.5rem;
text-indent: -1.5rem;
font-size: clamp(1.2rem, 2.5vw, 1.125rem) !important;
line-height: 180%;
word-break: break-all;
}

.usulist {
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
padding: 1.5em 1em 1.5em 1.5em;
line-height: 160%;
margin-bottom: 20px;
}

.outpatient-list-title span {
top:0.5px;
}

.other-title {
text-align: center;
padding: 120px 0px 70px 0px;
}

.overview-h3 {
font-size: 150%;
margin: 20px 0 50px;
color: #a9465c;
text-align: center;
}

.tabu-h3 {
font-size: 150%;
margin: 4em 0em 3em 0em;
color: #39546b;
text-align: center;
}

.contx {
font-size: 150%;
margin: 4em 0em 1em 0em;
color: #39546b;
text-align: center;
}

.tabu-h3-pink {
font-size: 150%;
margin: 4em 0em 3em 0em;
color: #a9465c;
text-align: center;
}

.rinen{
font-size: 19px;
font-weight: bold;
text-align: center;
line-height: 2.1;
color: #333333;
}

.over_border{
border: none;         /* 既定の枠線を消す */
height: 4px;          /* 太さ 4px */
background: #f5d7e1;  /* 線の色 */
margin: 4em 0em;
}

.gaiyou_border{
border: none;         /* 既定の枠線を消す */
height: 1px;          /* 太さ 4px */
background: #cccccc;  /* 線の色 */
margin: 4em 0em;
}

.recruit-table {
width: 100%;
border-collapse: collapse;
max-width: 980px;
margin: 0 auto;
}
.recruit-table th, .recruit-table td {
text-align: left;
display: block;
}
.recruit-table th {
width: 100%;
font-size: 16px;
line-height: 150%;
border-top: 1px solid #000;
border-bottom: 0px solid #000;
padding: 1em 0em 0.5em 0em;
}
.recruit-table td {
width:100%;
padding-left: 0px;
word-break: break-word;
font-size: 16px;
line-height: 160%;
border-top: 0px solid #000;
border-bottom: 0px solid #000;
padding: 0.5em 0em 1em 0em;
}
	
.recruit-table tr:last-child td {
border-bottom: 1px solid #000;   /* 下線を付ける */
}

.recruitimg{
width: 100%;
padding-top: 4.2em;
}

.senpaiwaku{
background-color: #fff8ea;
padding: 2em 1.2em;
}

.senflex01{
display: flex;
flex-direction: column;
gap:3em;
}

.senflex02{
display: flex;
gap:1.0em;
}

.senpai01{
width: 100%;
}

.senpai02{
width: 100%;
}

.senpaitxt{
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
width: 85%;
}

.senpaittl{
font-size: 23px;
display:inline-block;
padding-bottom:18px;
padding-top: 9px;
}

.senpaino{
width: 15%;
}

.senflex01_hanten{
display: flex;
flex-direction: column;
gap:3em;
}
	
.form-wrap {

}

.form-box {
width: 100%;
max-width: 980px;
margin: 1em auto 0em;
text-align: center;
background-color: #eef4fb;
border-radius: 12px;
padding: 0.0em 0em 2.5em 0em;
margin-top: 2.5em;
}

.form-table {
width: 100%;
max-width: 898px;
margin: 0px auto;
border-collapse: separate;
border-spacing: 10px;
padding: 1em 0em 0em 0em;
margin-top: 2em !important;
}

.form-table th {
display: block;
padding: 0.2em 0.5em;
line-height: 180%;
text-align: left;
vertical-align: top;
color: #214961;
width: 100%;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
}

.form-table td {
display: block;
padding: 0em 0.5em 0.5em 0em;
line-height: 180%;
text-align: left;
vertical-align: top;
color: #000;
width: 97%;
font-size: max(1.0625rem, 12px);
font-family: 'Noto Sans JP', sans-serif;
font-weight: 400;
}

::placeholder {
color: #c3c3c3;
}

.doui {
display: block;
padding: 0em 2.8em;
line-height: 180%;
text-align: center;
vertical-align: top;
color: #5f3700;;
width: 100%;
font-size: 18px;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 600;
}

.cyuui{
color: red;
font-size: 16px;
}

.douinoue{
color: #000;
font-size: max(1.0625rem, 12px);
font-family: 'Noto Sans JP', sans-serif;
font-weight: 600;
line-height: 170%;
word-break: break-all;
text-align: center;
margin: 0 auto;
margin-bottom: 2em;
width: 90%;
}

.douinoue a{
color: #4169e1;
text-decoration: underline;
}

.btn-contact03{
width: 80%;
margin: 0 auto;
margin-top: 1em;
display: flex;
justify-content: center;
padding: 0.7em;
border: 2px solid;
border-color: #ab485d;
/*border-radius: 150px;*/
background-color: #ab485d !important;
color: #FFFFFF;
font-weight: 600;
font-size: max(1.0625rem, 12px);
border-radius: 100px;
}

.btn-contact03:hover{
background-color: #FFFFFF !important;
color: #ab485d;
border: 2px solid;
border-color: #ab485d;
/*border-radius: 150px;*/
}

input, select {
  border: solid 1px #CCC;
  background-color: #FFFFFF !important;
  color: #333333;
  padding: 0.5em;
  margin: 0.5em;
  
  /*cursor: pointer;*/
  vertical-align: middle;
}
textarea {
  border: solid 1px #CCC;
  background-color: #FFFFFF !important;
  color: #333333;
  padding: 0.5em;
  margin: 0.5em;
}
input#submit_button {
  width: 18%;
  cursor: pointer;
}
input#reset_button {
  width: 18%;
  cursor: pointer;
}

::placeholder {
  color:#CCC;
  font-size: 1em;
}

.hissu {
  text-align: center;
  font-size: 11px;
  line-height: 140%;
  color: #FFF;
  background-color: #ff5555;
  display: inline-block;
  padding: 3px 5px;
  margin: 0px 0 0 4px;
border-radius: 4px;
}	

.btnnin{
background-color: var(--color--primary);
border-radius: 16px;
padding: 3px 14px;
color: #FFFFFF;
font-weight: normal;
border: 2px solid var(--color--primary) !important;
margin-bottom:0.5em;
margin-top:1em;
font-size: 1em;
}

/* 幅を固定するときの“おまじない” */
.ov4 {
table-layout: fixed;   /* 幅計算を先に確定させる */
width: 100%;           /* （任意）テーブル自体の幅 */
margin: 0 auto;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
}

/* 列ごとの幅指定 */
.ov4 th        { width:100%; text-align: left; display: block;}          /* 見出しセル */
.ov4 td:nth-child(2) { width: 100%; display: block;}    /* 1 列目の td  */
.ov4 td:nth-child(3) { width: 100%; text-align: right; display: block;}    /* 2 列目の td  */

/*=================
 ページトップへ
====================== */
#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 10px;
  bottom: 20px;
  background: #ab485d;
  opacity: 0.8;
  border-radius: 50%;
z-index: 5000;
}
#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before {
  font-family: FontAwesome;
  content: '\f106';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 40px;
  top: 10;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

}

.footerborder{
border-bottom: 1px solid #ccc;
height: 0;
margin: 4em 0em 1.5em 0em;
}






/*-----iPad用------*/
/*　画面サイズが768pxから979pxまではここを読み込む　*/	
@media screen and (min-width:820px) and (max-width:1180px) {

.medicalsub-h3 {
font-size: 20px;
border-bottom: 1px solid #bd7181;
padding-bottom: 5px;
margin-bottom: 20px;
}

.other-title {
text-align: center;
padding: 120px 0px 70px 0px;
}

.outpatient-bg {
	background-image: url(/wp/images/outpatient/outpatient_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
    padding-top: 9em !important;
}

.recruitimg{
padding-top: 4.2em;
}

.senpaiwaku{
background-color: #fff8ea;
padding: 4em 3em;
}

.senflex01{
display: flex;
flex-direction: column;
gap:3em;
}

.senflex02{
display: flex;
gap:1.0em;
}

.senpai01{
width: 100%;
}

.senpai02{
width: 50%;
margin: 0 auto;
}

.senpaitxt{
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
width: 92.5%;
}

.senpaittl{
font-size: 23px;
display:inline-block;
padding-bottom:18px;
padding-top: 9px;
}

.senpaino{
width: 7.5%;
}

.senflex01_hanten{
display: flex;
flex-direction: column;
gap:3em;
}

.overview4-top-nav-list li {
flex: 0 0 20% !important;
text-align: center;
}

}






/* file: styles.css */

* { box-sizing: border-box; }


/* Header / Nav */
.overview4-site-header {
  margin: 0 auto;
  width: 100%;
  max-width: 1200px;
  padding: 12px 0;               /* 子ナビの高さ分を確保 */
}

/* ナビ UL：絶対配置をやめて折り返し */
.overview4-top-nav-list {
  display: flex;
  flex-wrap: wrap;               /* 折り返しを許可 */
  gap: 1px;
  list-style: none;
  margin: 0 auto;                /* 中央寄せ */
  padding: 0px 16px;
  justify-content: center;
  align-items: flex-end;
 position: absolute; 
bottom: 0;
right: 0; left: 0; 
  font-weight: normal;
}

/* 列幅指定：PC 4列 */
.overview4-top-nav-list li {
  flex: 0 0 12%;
  text-align: center;
}

/* ボタン：既存維持＋ブロック化で安定 */
.overview4-top-nav-list a {
  display: block;                /* 領域安定＆タップしやすさ */
  text-decoration: none;
  color: #222;
  font-weight: 500;
  padding: 1em 0em;             /* 既存維持。スマホで広すぎれば後述で調整 */
  border-radius: 6px 6px 0px 0px;
  border: #FFF 1px solid;
font-size: 18px;
}

.overview4-top-nav-list a.overview4-active {
  background: #faf5f3;
  color: #222;
}

/* スマホ：2列に切り替え */
@media (max-width: 767px) {
  .overview4-top-nav-list li {
    flex: 0 0 40%;
font-size: 14px !important;
  }
.overview4-top-nav-list a {
font-size: 15px;
/*padding: 10px 24px;*/
}
}

/* Container */
.overview4-container {
  /*max-width: 860px;*/
  margin: 28px auto 64px;
  padding: 0 16px;
}

/* Title */
.overview4-page-title {
  text-align: center;
  font-size: 20px;
  color: #39546b;
  margin: 8px 0 24px;
  font-weight: 700;
}

/* Lead */
.overview4-lead {
  text-align: left;
  margin-bottom: 2em;
    font-size: 18px;
    line-height: 180%;
    word-break: break-all;
}

/* Sections */
.overview4-section {
  margin-top: 2em;
}
.overview4-section-title {
  font-size: 18px;
line-height: 180%;
  padding-left: 0.9em;
  position: relative;
  margin: 16px 0 8px;
}
.overview4-section-title::before {
  content: "◆";
  position: absolute;
  left: 0;
  color: #;
}

.overview4-section p{
font-size: 18px;
line-height: 180%;
word-break: break-all;
}

.overview4-section-title02 {
  font-size: 16px;
  padding-left: 0.9em;
  position: relative;
  margin: 16px 0 8px;
}
.overview4-section-title02::before {
  content: "";
  position: absolute;
  left: 0;
  color: #;
}


/* Lists */
.overview4-bullets {
  margin: 0 0 8px 0;
  padding-left: 1.25em;
}
.overview4-bullets li {
  margin: 4px 0;
font-size: 18px;
line-height: 180%;
word-break: break-all;
}
.overview4-two-cols {
  columns: 1;
  column-gap: 24px;
}

/* Table */
.overview4-table-wrap {
  border: 1px solid #;
  border-radius: 0px;
  overflow: auto;
}
.overview4-table {
  width: 100%;
  border-collapse: collapse;
  max-width: 1000px;
font-size: 18px;
line-height: 180%;
word-break: break-all;
}
.overview4-table th, .overview4-table td {
	border: 1px #CCC solid;
  border-width: 1px 1px 1px 1px;   
  padding: 1em;
  text-align: left;
  vertical-align: top;
}
.overview4-table thead th {
  background: #;
  font-weight: 700;
}

/* Notes */
.overview4-note {
  color: #;
  font-size: 13px;
  margin-top: 8px;
}
.overview4-small-note {
  color: #;
  font-size: 12px;
}

/* Footer */
.overview4-site-footer {
  border-top: 1px solid #;
  padding: 16px;
  text-align: center;
  color: #;
  font-size: 13px;
}

/* ▼追加分 : 文書料テーブル用微調整 ------------- */

.overview4-table-wrap02 {
  border: 1px solid #;
  border-radius: 0px;
  overflow: auto;
}

.overview4-table02 {
  width: 80%;
  border-collapse: collapse;
  min-width: 640px;
}


table.table-z01 {
  width: 80%;
  border: 0px #ccc solid;
}
table.table-z01 th {
  padding: 1em;
  font-weight:normal;
  color: #000;
  line-height: 120%;
  text-align: left;
  font-size: 15px;
  margin: 0px 0 5px 0px;
  vertical-align: middle;
  /*background-color: #F8F8F8;*/
  border: 0px #CCC solid;
  border-width: 0 0px 0px 0px;
width:70%;
}
table.table-z01 td {
  padding: 1em;
  border: 0px #CCC solid;
  border-width: 0 0px 0px 0px;
  line-height: 130%;
  text-align: right;
  vertical-align: middle;
  font-size: 15px;
  /*background-color: #FFF;*/
}


.overview4-box{
border:1px #222 solid;
padding:1em 2em;
max-width: 700px;
}

.overview4-bg {
	background-image: url("/wp/images/overview2/overview4_bg.jpg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
}

@media(max-width:600px){
  .overview4-doc-fee th{width:60%;}



	
	
@media (max-width: 767px) {
	
.overview4-lead {
text-align: left;
margin-bottom: 2em;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
}

.overview4-section-title {
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
padding-left: 0.9em;
position: relative;
margin: 16px 0 8px;
}

.overview4-section p{
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
}

.overview4-bullets {
padding-left: 0em;
}

.overview4-bullets li {
margin: 4px 0;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
}

.overview4-box{
border:1px #222 solid;
padding:1em 0.5em;
}

.overview4-table {
  width: 800px;
  border-collapse: collapse;
font-size: clamp(1.2rem, 2.5vw, 1.125rem);
line-height: 180%;
word-break: break-all;
}

}
	
	
	
	
	
/*iphone5&SE用*/
@media screen and (min-width: 320px) and (max-width: 374px){

/*.form-table th {
width: 82%;
}

.form-table td {
width: 82%;
}*/

}
	
	
	
	
	
	
	
	