@charset "utf-8";

/* ----------------------------------------------------------------------------------
	common
---------------------------------------------------------------------------------- */
body {
  font-size: 1.4rem;
  line-height: 1.6;
}

/* Font
-------------------------------*/
@font-face {
  font-family: "LogoTypeGothic";
  src: url('../font/07LogoTypeGothic7.ttf') format('truetype');
}
.bold {
  font-weight: bold;
}
.green {
  color: #60C0BD;
}
.grey {
  color: #999;
}
.underline {
  text-decoration: underline;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.font-s {
  font-size: 75%;
}
.font-b {
  font-size: 105%;
  font-weight: bold;
  color: #319E99;
  border-bottom: none;
  margin-bottom: 0.5rem;
  padding: 0.5rem 0.5rem 0.5rem 0;
}
.font-b::before {
  content: none;
}

/* InnerFrame
-------------------------------*/
.inner, .innerM, .innerMM {
  padding: 0;
}

/* Link
-------------------------------*/
a:link, a:visited {
  color: #2990D0;
}
a:hover {
  color: #ff9900;
}

/* 表示・非表示
-------------------------------*/
.sp_n {
  display: none;
}
.pc_n {
  display: block;
}
.pcsp_n {
  display: none;
}
@media screen and (min-width: 48em), print {
  .sp_n {
    display: block;
  }
  .pc_n {
    display: none;
  }
  .pcsp_n {
    display: none;
  }
}

/* -----------------------------------------------------------
　共通
----------------------------------------------------------- */

/* Title
-------------------------------*/
.h1_area {
  background-image: url(../images/h1_back.png);
  background-repeat: no-repeat;
  background-position: center center;
  text-align: center;
  padding: 2.4rem 0.5rem 2rem;
}
#Lower h1 {
  font-size: 150%;
  font-weight: normal;
  line-height: 2.4rem;
}
#Lower h1 span {
  font-size: 50%;
}
h2 {
  background-image: url(../images/logo_face.png);
  background-repeat: no-repeat;
  background-position: center center;
  color: #60C0BD;
  font-size: 180%;
  padding: 15rem 0 0;
  margin: 0 auto 2rem;
  line-height: 2.6rem;
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.3rem;
}
h2 span {
  display: block;
  font-size: 55%;
  color: #c3c3c3;
  font-weight: normal;
  letter-spacing: 0.4rem;
}
#Lower h2 {
  background-image: url(../images/logo_face.png);
  background-repeat: no-repeat;
  background-position: top center;
  padding: 7.5rem 0 0;
  font-size: 160%;
  letter-spacing: 0;
}
.area_feature h2 {
  background-image: url(../images/logo_face_w.png);
  background-repeat: no-repeat;
  background-position: center center;
}
.area_feature h2, .area_feature h2 span {
  color: #ffffff;
}
h3 {
  border-bottom: 0.1rem solid #30A3AF;
  color: #30A3AF;
  font-size: 120%;
  font-weight: bold;
  margin-bottom: 1rem;
  padding: 0.6rem 0.6rem 0.6rem 0;
}
h3::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0fa\00a0";
}
h4 {
  border-bottom: 1px dashed #428CAC;
  color: #428CAC;
  font-size: 110%;
  font-weight: bold;
  margin-bottom: 0.5rem;
  padding: 0.5rem 0.5rem 0.5rem 0;
}
h4::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0fe\00a0";
}
h5 {
  font-weight: normal;
  border-bottom: 1px dashed #319E99;
  color: #319E99;
  font-size: 100%;
  margin-bottom: 0.5rem;
  padding: 0.5rem 0.5rem 0.5rem 0;
}
h5::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0da\00a0";
}

/* Header
-------------------------------*/
header {
  background-color: #ffffff;
  padding: 1rem;
}
.head_info {
  
/* flex化 */
  display: flex;
  display: -webkit-flex;
}
.head_left {
  width: 100%;
  text-align: center;
}

/* Navigation
-------------------------------*/
nav {
  display: block;
  background-color: transparent;
  font-weight: 500;
}
nav .inner {
  padding: 0;
}
nav ul {
  font-size: 0;
}
nav li {
  display: inline-block;
  background-color: #61C1BD;
  width: 50%;
}
nav li:nth-child(2), nav li:nth-child(4), nav li:nth-child(6) {
  border-left: 1px solid #ffffff;
}
nav li:nth-child(1), nav li:nth-child(2), nav li:nth-child(3), nav li:nth-child(4) {
  border-bottom: 1px dashed #DBDBDB;
}
nav li span {
  font-size: 1rem;
  display: none;
  color: #B5E1DE;
}
nav li a {
  display: block;
  color: #ffffff;
  text-align: center;
  font-size: 1.4rem;
  line-height: 1.6rem;
  letter-spacing: 0.1rem;
  padding: 1rem;
}
nav li a:hover {
  background-color: rgba(255, 255, 255, 0.3);
  color: #ff0000;
}
nav li a:link, nav li a:visited {
  color: #ffffff;
}

/* Main
-------------------------------*/
.mainarea {
  background-color: #FDF4CE;
  padding: 2rem;
}

/* SideNavi
-------------------------------*/
.sidenavi {
  width: 100%;
}
.sidenavi ul {
  
/* flex化 */
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  padding: 0;
}
.sidenavi ul li {
  text-align: center;
  width: 50%;
}

/* Footer
-------------------------------*/
footer {
  background-color: #60C0BD;
  font-size: 1.6rem;
  line-height: 1.6;
  text-align: center;
  padding-top: 3rem;
}

/* FooterLink
-------------------------------*/
footer .footnavi li {
  display: inline-block;
  margin-right: 1em;
}
footer .footnavi li a:link, footer .footnavi li a:visited {
  color: #2990D0;
}
footer .footnavi li a:hover {
  color: #ff9900;
}
footer .footnavi li::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0da \00a0";
  color: #2990D0;
}

/* Copyright
-------------------------------*/
small {
  margin: 3rem auto 0 !important;
  display: block;
}
.copyright {
  width: 100%;
  color: #ffffff;
  text-align: center;
  border-top: 1px solid #ffffff;
  font-size: 0.8rem;
  padding: 0.5rem 0;
}

/* ----------------------------------------------------------------------------------
	トップ
---------------------------------------------------------------------------------- */

/* キービジュアル
-------------------------------*/
.keyv_area {
  background-color: #D1F0EF;
  text-align: center;
}
.keyv_area li img {
  margin: 0 auto;
}

/* お知らせ
-------------------------------*/
.notice {
  margin-bottom: 2rem;
  height: 35rem;
  overflow-y: scroll;
  padding: 2rem;
}
.notice .news_title {
  font-size: 1.7rem;
  font-weight: bold;
  color: #61C1BC;
}
.notice .news_body {
  margin-left: 1rem;
}
.notice dt {
  border-top: 0.1rem dotted #999;
  padding-top: 1rem;
  cursor: pointer;
}
.notice dt:first-child {
  padding-top: 0;
  border: none;
}
.notice dd {
  padding-bottom: 1rem;
}
.notice dt:before {
  content: "▼ ";
  display: inline-block;
}
.notice dt.active:before {
  content: "▲ ";
}
.notice-corona {
  margin-bottom: 2rem;
  height: 35rem;
  overflow-y: scroll;
  padding: 2rem;
}
.notice-corona .news_title {
  font-size: 1.7rem;
  font-weight: bold;
  color: #61C1BC;
}
.notice-corona .news_body {
  margin-left: 1rem;
}
.notice-corona dt {
  border-top: 0.1rem dotted #999;
  padding-top: 1rem;
  cursor: pointer;
}
.notice-corona dt:first-child {
  padding-top: 0;
  border: none;
}
.notice-corona dd {
  padding-bottom: 1rem;
}
.notice-corona dt:before {
  content: "▼ ";
  display: inline-block;
}
.notice-corona dt.active:before {
  content: "▲ ";
}
.news1st dt:nth-of-type(n+6), .news1st dd:nth-of-type(n+6) {
  display: none;
}
.news2nd dt:nth-of-type(6), .news2nd dd:nth-of-type(6) {
  display: none;
}
.infotitle {
  text-align: center;
  background-color: #61C1BC;
  color: #FFFFFF;
  width: 100%;
  height: 100%;
  padding: 3rem 2rem 2rem 2rem;
  background-image: url(../images/info_back.png);
  background-repeat: no-repeat;
  background-position: right bottom;
}
.infotitle p {
  font-size: 2.6rem;
  letter-spacing: 0.4rem;
  font-weight: bold;
  line-height: 2.6rem;
  margin-bottom: 0 !important;
}
.infotitle p span {
  color: #E5E5E5;
  letter-spacing: 0.14rem;
  display: block;
  font-size: 70%;
  font-weight: normal;
}

/* バナー
-------------------------------*/
ul.bnr {
  /*display: flex;
	text-align: center;
	justify-content: space-between;
	margin: 0 auto;*/
  width: 100%;
}
ul.bnr li {
  text-align: center;
  margin-bottom: 1rem;
}
@media print, screen and (min-width: 46.875em) {
  /*ul.bnr{
	width: 800px;
}	
ul.bnr li{
	width: 49%;
}*/
}

/* 医院概要
-------------------------------*/
.overview dl {
  margin-bottom: 1rem;
}
.overview dt, .overview dd {
  margin-bottom: 0.3rem;
}
.overview dt {
  float: left;
  width: 10rem;
}
.overview dd {
  margin-left: 10rem;
}
.overview dd::after {
  content: '';
  display: block;
  clear: both;
}
.overview .title {
  text-align: center;
  font-size: 2.2rem;
}

/* フレーム
-------------------------------*/
.frame_red {
	width: 100%;
	display: block;
	margin: 0 auto;
	padding: 1rem;
	background: #fff;
	border: 1px solid red;
	border-radius: .4rem;
	color: red;
    font-size: 1.2rem;
	text-align: left;
}

/* 院長紹介
-------------------------------*/
.bio dt {
  float: left;
  width: 7rem;
  clear: both;
}
.bio dd {
  margin-left: 7rem;
}

/* ----------------------------------------------------------------------------------
	Modules
---------------------------------------------------------------------------------- */

/* flex setting
-------------------------------*/
.flex_LRTB, .flex_RLTB {
  display: flex;
  display: -webkit-flex;
  flex-direction: column;
  -webkit-flex-direction: column;
}

/* テキスト＋挿絵専用コンポーネント float_TB */
.float_TB::after {
  height: 0;
  content: "";
  display: block;
  clear: both;
}
.L20, .L30, .L40, .L50, .L60, .L70, .L80, .R20, .R30, .R40, .R50, .R60, .R70, .R80 {
  width: 100%;
  float: none;
}

/* signature
-------------------------------*/
.signature {
  font-size: 2rem;
}
.signature span {
  font-size: 1.6rem;
}
.signature span:after {
  content: "　";
}

/* GoogleMaps
-------------------------------*/
.gmap {
  width: 100%;
  min-height: 40rem;
  margin-bottom: -0.8rem;
}

/* マージン
-------------------------------*/
.mt20 {
  margin-top: 2rem;
}

/* List
-------------------------------*/
.list_dot {
  padding-left: 1rem;
}
.list_dot li {
  list-style-type: disc;
  margin-left: 1em;
}
.list_caution {
  margin-bottom: 2rem;
}
.list_caution li {
  text-indent: -1.75rem;
  margin-left: 1.75rem;
}
.list_caution li:before {
  content: "※ ";
}
.list_no {
  padding-left: 1em;
  margin-left: .3em;
}
.list_no li {
  list-style-type: decimal;
}
.list_inline li {
  display: inline-block;
  margin-right: 2rem;
}
.list_inline li:before {
  content: "・";
}
li.nad {
  list-style-type: none !important;
  text-align: right;
}
li.nad:before {
  content: "" !important;
}
.list_treat {
  font-size: 0;
}
.list_treat li {
  display: inline-block;
  width: 50%;
  text-align: center;
  padding: 1rem;
}
.list_check li {
  display: inline-block;
  text-indent: -1.75rem;
  margin: 0 2rem 1rem 1.75rem;
}
.list_check li::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f14a\00a0";
  color: #1EBFB9;
}

/* ColoredBox
-------------------------------*/
.colorbox {
  background-image: url(../images/back_cloth.png);
  padding: 2rem;
  margin-bottom: 2rem;
}
.colorbox .title {
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 1rem;
  color: #68472C;
}

/* Link Button
-------------------------------*/
.linkbox a:link {
  display: inline-block;
  padding: 0.3rem 2rem;
  color: #ffffff;
  background-color: #61A9A5;
}
.linkbox a:visited {
  color: #ffffff;
  background-color: #61A9A5;
}
.linkbox a:hover {
  color: #ffffff;
  background-color: #37827D;
}
.linkbox2 a:link {
  font-size: 2rem;
  display: inline-block;
  padding: 0.3rem 2rem;
  color: #ffffff;
  background-color: #288B86;
}
.linkbox2 a:visited {
  color: #ffffff;
  background-color: #288B86;
}
.linkbox2 a:hover {
  color: #ffffff;
  background-color: #4D9691;
}
.btn_blue .linkbox2 a:link {
  font-size: 2rem;
  display: inline-block;
  padding: 0.3rem 2rem;
  color: #ffffff;
  background-color: #32738E;
}
.btn_blue .linkbox2 a:visited {
  color: #ffffff;
  background-color: #32738E;
}
.btn_blue .linkbox2 a:hover {
  color: #ffffff;
  background-color: #649CB3;
}

/* GoToTop
-------------------------------*/
#pageTop {
  display: block;
  position: fixed;
  bottom: -10rem;
  right: 2rem;
  transition: .5s;
}
#pageTop a:before {
  content: "\f0d8";
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
}
#pageTop a {
  display: block;
  color: #ffffff;
  text-align: center;
  text-decoration: none;
  background-color: #239793;
  border-radius: 10rem;
  font-size: 1.4rem;
  line-height: 1.4rem;
  padding: 0.5rem 0.77rem;
}
#pageTop a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha(opacity=80)";
  display: block;
}

/* for flowdesign
-------------------------------*/
.flowbox {
  background-color: #ffffff;
  border-radius: 1rem;
  border: 2px solid #60C0BD;
  padding: 2rem;
  margin: 1rem 0;
}
.flowbox .title {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 0.5rem;
  color: #1E8680;
}
.flowallow {
  text-align: center;
  color: #D8A100;
}
table.timetableR {
  background-color: #fff;
  border-collapse: separate;
  border-spacing: 0px;
  empty-cells: show;
  width: 90%;
  margin: 0 auto;
  caption-side: bottom;
  border: 2px solid #61A7A5;
}
.timetableR th {
  color: #ffffff;
  background-color: #61A7A5;
  font-weight: normal;
  text-align: center;
  padding: 3px;
  margin: 0px;
}
.timetableR th.tableL {
  width: 40%;
}
.timetableR td {
  background-color: #fff;
  color: #61A7A5;
  font-weight: normal;
  text-align: center;
  padding: 3px;
}
.area_pedia {
  padding: 1rem;
  background-image: url(../images/back_cloth_sp.png);
  background-repeat: repeat-x;
  background-position: center bottom;
}
.widS {
  width: 80%;
}
.pedlink {
  background-image: url(../images/top_childs_flower.png);
  background-repeat: no-repeat;
  background-position: right 50px bottom;
  height: 6rem;
  padding-top: 5.7rem;
}
.area_white, .area_feature {
  padding: 4rem 0;
}
#Lower .area_white, #Lower .area_cloth {
  padding: 3rem 1rem;
}
.area_cloth {
  background-image: url(../images/back_cloth.jpg);
}
.area_feature {
  padding: 0 0 5rem;
  background-image: url(../images/feature_back.png);
}
.area_ov {
  background-image: url(../images/ov_back.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 4rem 0;
  font-size: 1.2rem;
}
.ovtitle {
  border-bottom: 1px solid #61C1BC;
  padding-bottom: 1rem;
}
.whitebox {
  background-color: rgba(255, 255, 255, 0.50);
  padding: 1rem;
  margin: 1rem;
}
.photos ul {
  
/* flex化 */
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
}
.photos li {
  width: 50%;
  padding: 0.5rem;
  font-size: 1rem;
  text-align: center;
}
.photos img {
  margin-bottom: 0.5rem;
}
.table001 {
  border: 1px solid #0E6083;
  border-collapse: collapse;
  margin-bottom: 2rem;
  width: 100%;
}
.table001 th, .table001 td {
  padding: 0.7rem 1rem;
  border: 1px solid #0E6083;
  font-size: 80%;
  font-weight: normal;
}
.table001 th {
  background-color: #D6EFF9;
  color: #0E6083;
}
.button {
  width: 100%;
  color: #495256;
  font-weight: bold;
  border: .1rem solid #30A3AF;
  font-size: 1.6rem;
  background: none;
  padding: 2rem;
}
.align-center {
  text-align: center;
  color: #495256;
  font-weight: bold;
  font-size: 1.7rem;
}
.red {
  color: #db383e;
  font-weight: bold;
}
.block {
  display: block;
}
.pt20 {
  padding-top: 2rem;
}
.pb40 {
  padding-bottom: 4rem;
}
.pt40 {
  padding-top: 4rem;
}
.mt40 {
  margin-top: 4rem;
}
.qr p > img {
  width: 50%;
}
.border-p {
  padding: 2rem;
}
.border-lightBule {
  border: 0.1rem solid #30A3AF;
}

/* -----------------------------------------------------------------------------------------------------------------------------------
	PC
----------------------------------------------------------------------------------------------------------------------------------- */
@media print, screen and (min-width: 46.875em) {
  
/* Common
-------------------------------*/
  body {
    font-size: 1.6rem;
    min-width: 1170px; 
/* リキッドの際は外す */
  }
  #Lower h1 {
    font-size: 200%;
    padding: 2rem 3rem 1.6rem;
  }
  #Lower h2 {
    padding: 9rem 0 0;
  }
  h3 {
    padding: 0.4rem 0.6rem 0.4rem 0;
  }
  h4 {
    padding: 0.3rem 0.5rem 0.3rem 0;
  }
  h5 {
    padding: 0.5rem 0.5rem 0.5rem 0;
  }
  
/* InnerFrame
-------------------------------*/
  .inner {
    margin: 0 auto;
    max-width: 117rem;
  }
  .innerM {
    margin: 0 auto;
    padding: 0;
    max-width: 80rem;
  }
  .innerMM {
    margin: 0 auto;
    padding: 0;
    max-width: 100rem;
  }
  
/* Header
-------------------------------*/
  .head_info {
    
/* 両端に配置 */
    justify-content: space-between;
    -webkit-justify-content: space-between;
    
/* 上下配置中央 */
    align-items: center;
    -webkit-align-items: center;
  }
  .head_left {
    width: auto;
  }
  .head_right {
    
/* flex化 */
    display: flex !important;
    display: -webkit-flex !important;
    
/* 上下配置中央 */
    align-items: center;
    -webkit-align-items: center;
  }
  
/* GlovalNavi
-------------------------------*/
  nav {
    background-color: #61C1BD;
  }
  nav li {
    width: calc(100% / 5);
  }
  nav li:first-child {
    display: inline-block;
  }
  nav li a {
    font-size: 1.6rem;
    padding: 1.6rem;
  }
  nav .inner {
    padding: 0;
  }
  nav li span {
    display: block;
    font-size: 1.2rem;
  }
  nav li:nth-child(2), nav li:nth-child(4), nav li:nth-child(6) {
    border-left: none;
  }
  nav li:nth-child(1), nav li:nth-child(2), nav li:nth-child(3), nav li:nth-child(4) {
    border-bottom: none;
  }
  nav li {
    border-right: 1px solid #ffffff;
  }
  nav li:first-child {
    border-left: 1px solid #ffffff;
    border-right: 1px solid #ffffff;
  }
  
/* Main
-------------------------------*/
  .mainarea {
    width: 87rem;
    -ms-flex-negative: 0;
    flex-shrink: 0;
  }
  
/* SideNavi
-------------------------------*/
  .sidenavi {
    width: 30rem;
    background-color: #E5D38C;
    -ms-flex-negative: 0;
    flex-shrink: 0;
  }
  .sidenavi ul {
    padding: 2rem;
  }
  .sidenavi ul li {
    text-align: left;
    width: 100%;
  }
  
/* Footer
-------------------------------*/
  footer .inner {
    padding: 1rem 0;
  }
  
/* ----------------------------------------------------------------------------------
	Modules
---------------------------------------------------------------------------------- */
  
/* PCで左→右に配置／SPで上→下に配置 */
  .flex_LRTB {
    flex-direction: row;
    -webkit-flex-direction: row;
  }
  
/* PCで右→左に配置／SPで上→下に配置 */
  .flex_RLTB {
    flex-direction: row-reverse;
    -webkit-flex-direction: row-reverse;
  }
  
/* テキスト＋挿絵専用コンポーネント float_TB */
  .L20 {
    float: left;
    width: 20%;
  }
  .L30 {
    float: left;
    width: 30%;
  }
  .L40 {
    float: left;
    width: 40%;
  }
  .L50 {
    float: left;
    width: 50%;
  }
  .L60 {
    float: left;
    width: 60%;
  }
  .L70 {
    float: left;
    width: 70%;
  }
  .L80 {
    float: right;
    width: 80%;
  }
  .R20 {
    float: right;
    width: 20%;
  }
  .R30 {
    float: right;
    width: 30%;
  }
  .R40 {
    float: right;
    width: 40%;
  }
  .R50 {
    float: right;
    width: 50%;
  }
  .R60 {
    float: right;
    width: 60%;
  }
  .R70 {
    float: right;
    width: 70%;
  }
  .R80 {
    float: right;
    width: 80%;
  }
  .LBP {
    padding: 0 2rem 1rem 0 !important;
  }
  .RBP {
    padding: 0 0 1rem 2rem !important;
  }
  #pageTop a {
    padding: 1rem;
  }
  .pedlink {
    background-position: right 50px center;
    margin-top: 1rem;
    padding-top: 2rem;
  }
  .list_treat li {
    width: 25%;
    margin-bottom: 3rem;
  }
  .area_feature {
    padding: 3rem 1rem 5rem;
    background-image: url(../images/feature_back.png);
  }
  .area_pedia {
    background-image: url(../images/back_cloth.png);
    background-repeat: repeat-x;
    background-position: center center;
  }
  .area_ov {
    font-size: 1.8rem;
  }
  .infotitle {
    padding: 12rem 0 0 0;
  }
  .infotitle p {
    margin-bottom: 1rem;
  }
  .whitebox {
    padding: 4rem;
    margin: 0;
  }
  .photos li {
    width: 33.3333%;
    font-size: 1.4rem;
    padding: 1rem;
  }
  .table001 th, .table001 td {
    font-size: 1.6rem;
  }
  .bx-wrapper .bx-controls-direction a {
    line-height: 3;
  }
  .bx-wrapper .bx-pager {
    bottom: 52px !important;
  }
  .bx-wrapper .bx-pager.bx-default-pager a.active {
    background: #61c1bd !important; 
/*  */
  }
  .bx-wrapper .bx-pager.bx-default-pager a:hover {
    background: #61c1bd !important;
  }
  .bx-wrapper .bx-pager.bx-default-pager a {
    background: rgb(192, 190, 190) !important;
  }
  .table001.private {
    margin: 0 auto 2rem;
    width: fit-content;
    min-width: 650px;
    max-width: 100%;
  }
/* フレーム
-------------------------------*/
.frame_red {
	width: 870px;
	display: block;
	margin: 0 auto;
	padding: 1rem;
	background: #fff;
	border: 1px solid red;
	border-radius: .4rem;
	color: red;
    font-size: 1.4rem;
	text-align: left;
}
}
.pick {
  border: 1px solid #61C1BE;
  padding: 0.5rem 1rem;
  display: inline-block;
  color: #239793;
  font-weight: bold;
}
.tbl_recruit {
  width: 100%;
  border-bottom: 2px solid #61C1BE;
}
.tbl_recruit th, .tbl_recruit td {
  border-top: 2px solid #61C1BE;
  text-align: left;
}
.tbl_recruit th {
  white-space: nowrap;
  padding: 0.75em 0.75em 0.75em 0;
}
.tbl_recruit td {
  padding: 0.75em 0;
}
.bnr_recruit {
  text-align: center;
  padding: 0 1rem 2rem;
}
.bnr_recruit a {
  display: block;
  text-align: left;
  border: 2px solid #60C0BD;
  padding: 1em;
  color: #60C0BD;
  font-weight: bold;
  background-image: url(../images/bnr_recruit_bg.png);
  background-position: right 1em bottom 1em;
  background-repeat: no-repeat;
  background-size: auto 45%;
}
.bnr_recruit a span.tit {
  display: block;
  font-size: 1em;
  line-height: 1.4;
  padding: 0 0 0.5em;
}
.bnr_recruit a span.btn {
  position: relative;
  display: inline-block;
  background: #60C0BD;
  color: #fff;
  padding: 0.2em 1.5em 0.2em 0.8em;
  border-radius: 1em;
}
.bnr_recruit a span.btn::after {
  content: '';
  width: 0;
  height: 0;
  border: solid 4px transparent;
  border-left: solid 6px #fff;
  position: absolute;
  top: 50%;
  right: 0.5em;
  margin-top: -0.3em;
}
@media print, screen and (min-width: 46.875em) {
  .bnr_recruit {
    text-align: center;
    padding: 0 1rem;
  }
  .bnr_recruit a {
    display: inline-block;
    padding: 1em 13em 1em 1em;
    background-size: auto 80%;
    background-position: right 1em center;
  }
  .bnr_recruit a span.tit {
    font-size: 1.25em;
  }
}
.arrow {
  padding-bottom: 2em;
  position: relative;
}
.arrow::after {
  content: "\f078";
  font-family: FontAwesome;
  color: #30A3AF;
  position: absolute;
  bottom: 0em;
  left: 50%;
  font-size: 150%;
}

/* bxslider */
.bxslider-wrap {
  overflow: hidden !important;
}
.bxslider-wrap .bxslider {
  max-width: 1170px;
  width: 100%;
  margin: 0 auto;
}
.bxslider-wrap ul li img {
  width: 100%;
  height: auto;
}
.bxslider-wrap .bx-viewport {
  overflow: visible !important;
}
.bx-wrapper .bx-controls-direction a {
  text-indent: 0px !important;
  width: 50px !important;
  height: 50px !important;
  background-color: #b5b5b59e;
  border-radius: 50%;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.container .bx-wrapper .bx-controls-direction a.bx-prev {
  left: -5%;
}
.container .bx-wrapper .bx-controls-direction a.bx-next {
  right: -5%;
}

/* -----------------------------------------------------------
　モーダル
----------------------------------------------------------- */
#c-modal_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 100%;
  cursor: pointer;
  background: rgba(0, 0, 0, 0.6);
}
#c-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 9999;
  width: 90%;
  height: auto;
  transform: translate(-50%, -50%);
  padding: 20px;
  box-sizing: border-box;
  background: #ffffff;
}
.modal_tit {
  font-size: 1.6rem;
  color: #fff;
  text-align: center;
  font-weight: normal;
  margin: 5px 0 10px 0;
  height: auto;
  background: #30A3AF;
  padding: 8px 0;
  line-height: 100%;
}
#c-modal .list_normal li {
  font-size: 1.2rem;
  margin: 0 0 10px 15px;
}
#c-modal_close {
  padding: 5px 20px;
  cursor: pointer;
  background: #C9EAE8;
  border: 1px solid #61C1BD;
  border-radius: 5px;
  width: fit-content;
  margin: 0 auto 1rem;
  font-size: 1.3rem;
}
#c-modal .nexttime {
  text-align: center;
  font-size: 1.2rem;
  margin: 10px 0 0;
}
@media screen and (min-width: 768px) {
  #c-modal_bg {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100%;
    cursor: pointer;
    background: rgba(0, 0, 0, 0.6);
  }
  #c-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    z-index: 9999;
    width: 600px;
    height: fit-content;
    transform: translate(-50%, -50%);
    background: #ffffff;
    padding: 4rem;
  }
  .modal_tit {
    font-size: 2.7rem;
    font-weight: normal;
    margin: 0 0 3rem 0;
  }
  #c-modal .list_normal li {
    font-size: 1.6rem;
    margin: 0 0 15px 15px;
  }
  #c-modal_close {
    padding: 0.8rem 2.5rem;
    cursor: pointer;
    border-radius: 8px;
    width: fit-content;
    margin: 0 auto 1.5rem;
    font-size: 1.4rem;
  }
  #c-modal .nexttime {
    font-size: 1.4rem;
  }
}

/* カレンダー ---------------------------------------- */
.calendar-item {
  .caledit {
    width: 100%;
    border-spacing: 0;
    font-size: 1.3rem;
    margin: 0 auto;
    border: 0.1rem solid #30A3AF;
    border-collapse: separate;
    border-radius: 1rem;
    overflow: hidden;
    th, td {
      border: none;
    }
    .month {
      th {
        font-weight: normal;
        background: #30A3AF;
        color: #fff;
        padding: 0.75em 0;
        line-height: 1;
      }
    }
    .week {
      th {
        position: relative;
        padding: 0.625em 0;
        line-height: 1;
        font-size: 1.3rem;
        background: #fff;
        color: #30A3AF;
        font-weight: bold;
        border-bottom: 0.1rem solid #30A3AF;
      }
    }
    .day {
      td {}
    }
  }
}
ul.calendar-cellcolor {
  margin-top: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  .calendar-clr {
    display: flex;
    align-items: center;
    margin-right: 1.5em;
    &::before {
      content: "";
      display: inline-block;
      width: 1em;
      height: 1em;
      margin-right: 0.4em;
      position: relative;
      border: 1px solid #ccc;
    }
    &.open::before {
      background: #fff;
    }
    &.reschedule::before {
      background: #b7e3e1;
    }
    &.amOnly::before {
      background: #ecffcc;
    }
    
/* &.pmOnly::before {background:#CCFFCC;} */
    &.outPatient::before {
      background: #FFCCCC;
    }
    
/* &.extraOutPatient::before { background: #FFCCCC ;} */
  }
}

/* PC用 */
@media screen and (min-width: 1025px) {
  .calendar-item {
    .caledit {
      font-size: 2.2rem;
      border-radius: 2rem;
      th, td {
        border: none;
      }
      td {
        padding: 0.2em 0.1em;
      }
      .month {
        th {
          font-size: 2.4rem;
          padding: 0.75em 0;
        }
      }
      .week {
        th {
          font-size: 1.8rem;
        }
      }
      .day {
        td {}
      }
    }
  }
}

/* -----------------------------------------------------------------------------------------------------------------------------------
	Tablet 73.063=1169px  60em=960px
----------------------------------------------------------------------------------------------------------------------------------- */
/*
@media screen and (min-width: 46.875em) and (max-width: 73.063em){
}

*/