body {
	font-family: "Kosugi Maru", sans-serif;
  	font-weight: 400;
  	font-style: normal;
	line-height:1.6;
	color:#333;
    background: #fff;
	margin:0;
	padding:0;
	overflow-x:hidden;
	-webkit-font-smoothing:antialiased
}
ul {
	margin:0;
	padding:0;
	list-style:none
}
h1 {
	font-size:60px
}
h2 {
	color:#F90;
	font-weight:300;
	margin-bottom:30px
}
h3, h4, h5 {
	color:#333c4d;
	font-weight:400;
	margin-bottom:20px
}
p {
	font-family: "Kosugi Maru", sans-serif;
	font-weight:400;
	font-size:16px;
	/*color:#828282;*/
	padding-bottom:15px
}
@font-face {
font-family:FontAwesome;
src:local('FontAwesome')
}
ul li {
	font-family: "Kosugi Maru", sans-serif;
	font-size:16px;
	list-style-type:none;
	padding-bottom: 12px;
	/*color:#828282*/
}
a {
	color:#085
}
a:hover {
	color:#0785f2
}
a h4:hover {
	text-decoration:underline
}
img {
	max-width:100%;
	height:auto
}
.branding img#logo {
	max-width:initial;
	margin-left:-25px
}
@media (max-width:768px) {
.branding img#logo {
	margin-left:5px
}
	
h3 strong{
		display: block;
	}
}

/*wp読み込み部分のcss　-------------------------------------------------------------*/

/*お知らせ*/
.news-list{
  list-style: none outside;
  margin: 0 20px;
  padding: 10px; 
overflow:auto;
overflow-y:scroll;
	height: 300px;
}

.news-list dt{
	border-top: 1px solid #CCC;
	margin-top: 5px;
	padding: 10px 0;
}
.news-list .item{
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  color: #333;
  padding: 10px auto 5px 0;
}

.news-list .item .date{
  margin: 0;
  min-width: 120px;
  font-size: 16px;
	color: #999;
  /*padding: 0 20px 0 0;*/
}
.news-list .item .title{
  margin: 0 20px 0 10px;
	white-space: nowrap;
	min-width: 150px;
	text-align: left;
}

@media (max-width:480px) {

.news-list .item{
	display: block;
}

.news-list .item .title{
	margin: 5px 0;
	font-size: 1.8rem;
	display: block;
}

.news-list{
	margin: 0 10px;
	padding: 10px;
	height: 150px;
	}

.nowr{
		white-space: nowrap
	}
}



/*newマーク*/
em.newicon{
	background: #085;
	color: #fff;
	font-size: 10px;
	padding: 3px 5px;
	margin: 2px;
	border-radius: 2px;
	font-style: normal;
}
/*　/お知らせ -------------------------------------------------------------------------*/

.wp-post h2 {
  position: relative;
  padding: 2rem 1rem;
  border-bottom: 6px solid #094;
	color: #085;
	margin: 25px auto 10px auto;
}

.wp-post h2:before {
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 20%;
  height: 6px;
  content: '';
  background: #00cc5b;
}	

/* 吹き出し本体 */
.wp-post h3{
  position: relative;
  padding: 20px;
  background-color: #fff;
  border: 3px solid rgba(0,136,85,0.5);
}

/* beforeで枠線の三角を表現 */
.wp-post h3::before{
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  left: 20px;
  top: -15px;
  border-right: 15px solid transparent;
  border-bottom: 15px solid rgba(0,136,85,0.5);
  border-left: 15px solid transparent;
}

/* beforeで本体の三角を表現 */
.wp-post h3::after{
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  left: 20px;
  top: -12px;
  border-right: 15px solid transparent;
  border-bottom: 15px solid #fff;
  border-left: 15px solid transparent;
}

.wp-post table{
	margin-bottom: 5px;
}
.wp-post table.biz-hour th,
.wp-post table.biz-hour td{
	white-space: nowrap;
	text-align: center;
}



@media only screen and (min-width: 768px) {
  /* ここにパソコン向けのCSSを記述 */ 
	.wp-post table.biz-hour{
			width: 100%;
			display:table;
}
}

/*20240803 修正*/
.wp-post table.biz-hour .amtime td{
		color: #f93;
	}
.wp-post table.biz-hour .pmtime td{
		color: #66f;
	}
.wp-post table.biz-hour th{
		background: initial!important;/*引き継がない*/
	}
.wp-post table.biz-hour,
.wp-post table.biz-hour th,
.wp-post table.biz-hour td{
		border: 1px solid #ccc!important;
	}
.wp-post table.biz-hour tr:nth-child(1) th{
		background: rgba(0,136,85,0.2)!important;
	}

.wp-post table.biz-hour02 tr:nth-child(1) th{
		background: rgba(255,192,203,0.5)!important;
	}
.wp-post table.biz-hour tr:nth-child(2) td{
	font-size: 90%
	}
.wp-post table.biz-hour .time{
		text-align: center;
		background: rgba(255, 255, 255, 0.95);
		
}




.clear {
	clear:both
}
.container {
	padding-right: 10px;
	padding-left: 10px;
	margin-right:auto;
	margin-left:auto
}
.caption {
	text-align:center;
	margin-bottom:70px
}
.btn-cta-primary {
	color:#fff!important;
	padding:15px 30px!important;
	border-radius:0;
	font-size:12px;
	letter-spacing:2px;
	transition:all .2s ease-in-out;
	position:relative;
	margin-top:25px;
	text-transform:uppercase;
	font-weight:500;
}
.btn-cta-blue {
	background-color:#0785f2
}
.btn-cta-blue:hover {
	background-color:#fff;
	color:#0785f2!important
}
a.more {
transition:all .2s ease-in-out;
	font-size:14px!important;
	margin-top:10px;
	font-weight:400
}
a.more:hover * {
	color:#0785f2;
	padding-left:10px
}
a.more i.fa {
	font-size:15px!important;
	font-weight:700;
	border:none;
	cursor:pointer;
	margin-right:5px;
	transition:all .2s ease-in-out
}
a.more i.fa:hover {
	color:#009be3
}
#top-nav {
	transition:all .2s linear 0s
}
.navbar-fixed-top {
	background-color:transparent;
	border:none
}
.navbar-fixed-top li a {
	color:#fff;
	font-size:18px;
	font-weight: 400;
	transition:color .3s, border .3s;
}
.navbar-fixed-top .navbar-nav .activenav a {
	color:#fff;
	border-bottom:1px solid #fff
}
.navbar-nav>li>a {
	border-bottom:1px solid transparent;
	transition:color .3s, border .3s
}
.navbar-default .navbar-nav>li>a {
    color: #022d5c;
}
.navbar-fixed-top .navbar-nav>li>a:hover {
	font-weight: bold;
	border-bottom:1px solid #022d5c;
}


/* ヘッダー追加 */
.header-flex {
  display: flex;
  align-items: flex-end;
}

/* ===== 上段（巨大ロゴ＋TEL） ===== */
.cl-brand-bar{background:#fff;border-bottom:1px solid #eee;padding:12px 0;}
/* ★巨大ロゴ：PCで大きく */
.cl-brand-logo img{max-height:92px;height:auto;width:auto;}
@media (max-width:1199px){ .cl-brand-logo img{max-height:84px;} }

.cl-brand-phone{display:inline-flex;align-items:center;gap:10px;text-decoration:none;}
.cl-phone-ico{width:40px;height:40px;border-radius:50%;background:#4aaaf0;display:inline-flex;align-items:center;justify-content:center;}
.cl-phone-ico i{color:#fff;font-size:28px;line-height:1;}
.cl-phone-num{font-size:38px;font-weight:700;color:#222;}

/*  PCメニュー */
.cl-menu-bar { background:#ffebeb; }
.cl-menu-list{
  margin:0; padding:0 10px;
  display:flex; justify-content:center; align-items:center; /* 左右＆上下中央 */
  min-height:56px;
}
.cl-menu-list>li{ float:none; display:inline-block; padding-bottom: 0;}
.cl-menu-list>li>a{
  display:flex;
  align-items:center;
  justify-content:center;
  height:56px;
  padding:0 16px;
  font-size:21px;
  color:#022d5c;
  border-radius: 0;
}
.cl-menu-list>li>a:hover,.cl-menu-list>li>a:focus{
  background:rgba(255,255,255,.8);
  text-decoration:none;
}

/* ===== PC：固定ヘッダー（#cl-sticky）もメニュー中央＆上下中央 ===== */
#cl-sticky{
  background:rgba(255,255,255,0.92);
  border:none; box-shadow:0 2px 6px rgba(0,0,0,.08);
  transform:translateY(-100%); opacity:0;
  transition:transform .25s ease,opacity .25s ease;
  min-height:54px; /* 固定ヘッダーの基準高 */
}
#cl-sticky.is-visible{ transform:translateY(0); opacity:1; }

/* PC 固定ヘッダー */
@media (min-width: 992px){
  body.cl-nav-stuck{ padding-top: 0 !important; } 
  #cl-sticky{
    position: fixed; top: 0; left: 0; right: 0; z-index: 1100;
    will-change: transform, opacity;
  }
}


.cl-sticky-logo{
  display: block;
  max-height: 38px;
  height: auto;
  width: auto;
}

#cl-sticky .cl-sticky-inner{
  position:relative;
}
#cl-sticky .navbar-header{
  float:none;
} 
#cl-sticky .navbar-brand{
  position:absolute;
  left:15px;
  bottom:0;
} 
#cl-sticky .navbar-collapse{
  float:none;
  text-align:center;
}
#cl-sticky .cl-sticky-nav{
  float:none !important;  
  display:flex;
  justify-content:flex-end;
  width:100%;
}
#cl-sticky .cl-sticky-nav>li{
  float:none;
  display:inline-block;
  padding-bottom: 0;
}
#cl-sticky .cl-sticky-nav>li>a{
  padding:15px 18px;
  font-size:18px;
}


/* ===== スマホ===== */
@media (max-width: 991px){

  /* ナビ自体を固定＆前面 */
  .navbar.visible-sm.visible-xs{
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1100;
    background: #fff;
    border-bottom: 1px solid #eee;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
  }


  body{ padding-top: 81px; }


  .navbar.visible-sm.visible-xs .navbar-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .navbar.visible-sm.visible-xs .navbar-brand{
    float: none;
    height: 56px;
    padding: 8px 15px;
  }
  .navbar.visible-sm.visible-xs .cl-sp-logo{
    max-height: 40px; height: auto; width: auto;
  }

  /* ハンバーガーボタンの見た目 */
  .navbar.visible-sm.visible-xs .navbar-toggle{
    margin-top: 10px;
    margin-right: 20px;
    padding: 8px 10px;
  }
  .navbar.visible-sm.visible-xs .navbar-toggle .icon-bar{
    background: #666;      /* 線の色 */
    height: 3px;           /* 線の太さ */
    width: 24px;
    border-radius: 1px;
    margin: 4px auto;
    transition: transform .2s ease, opacity .2s ease;
  }

  .navbar-toggle:not(.collapsed) .icon-bar:nth-of-type(2){  /* 1本目 */
    transform: translateY(7px) rotate(45deg);
  }
  .navbar-toggle:not(.collapsed) .icon-bar:nth-of-type(3){  /* 2本目（消す） */
    opacity: 0;
  }
  .navbar-toggle:not(.collapsed) .icon-bar:nth-of-type(4){  /* 3本目 */
    transform: translateY(-7px) rotate(-45deg);
  }

  /* PC用ヘッダーはスマホでは非表示（被り防止） */
  .cl-brand-bar, .cl-menu-bar, #cl-sticky{ display: none !important; }
}






/* ===== トップページ専用 画像エリア ===== */
.top-hero {
  width: 100%;
  text-align: center;   /* 中央寄せ */
}

.top-hero picture,
.top-hero img {
  max-width: 1080px;    /* 最大幅を1920pxに制限 */
  width: 100%;          /* 画面幅に合わせて拡大縮小 */
  height: auto;
  margin: 0 auto;       /* 左右中央に配置 */
  display: block;
}


/* スマホで“正方形っぽく”見せたい場合の保険（スマホ用画像が正方形でない時） */
@media (max-width: 767px){
  .top-hero img {
    aspect-ratio: 1 / 1;   /* モダン環境ならこれで正方形表示 */
    object-fit: cover;     /* はみ出しをトリミング */
  }
}

/* トップページ専用 画像エリア（オーバーレイなし） */
.top-hero { width: 100%; overflow: hidden; }
.top-hero picture, .top-hero img { display: block; width: 100%; height: auto; }

/* スマホで“正方形っぽく”見せたい場合の保険（スマホ用画像が正方形でない時） */
@media (max-width: 767px){
  .top-hero img {
    aspect-ratio: 1 / 1;   /* モダン環境ならこれで正方形表示 */
    object-fit: cover;     /* はみ出しをトリミング */
  }
}


/* 追加ここまで */




.fixed-header {
	background:rgba(255,255,255,0.8)!important;
	box-shadow:0 6px 4px -4px rgba(0, 0, 0, .1)
}
.fixed-header .navbar-nav>li>a {
	color:#828282;
	opacity:1;
	text-shadow: none;
}
.fixed-header .navbar-nav .activenav a {
	color:#222!important;
	border-bottom:1px solid #0785f2
}
.fixed-header .navbar-nav .activenav a:hover {
	border-bottom:1px solid #0785f2
}
.fixed-header .navbar-nav>li>a:hover {
	font-weight: bold;
	border-bottom:1px solid #333
}
#top-nav.navbar-scroll-changed {
	background: #FFFFDB;
	margin:0 auto;
	border:0;
}
.hero-overlay {
	background:rgba(165, 199, 177, 0.25); /* rgba(0, 0, 0, .15); */
	height:700px;
	top:0;
	left:0;
	bottom:0;
	right:0
}

.hero-image #home {
	background:url(../images/home-hero-2.jpg) center no-repeat;
	position:relative;
	width:100%;
	background-size:cover;
	overflow:hidden;
	margin-top: 100px;
}
.main-message {
	position:absolute;
	text-align:center;
	top:30%;
	transform:translateY(-50%);
	-o-transform:translateY(-50%);
	-webkit-transform:translateY(-50%);
	-moz-transform:translateY(-50%);
	-ms-transform:translateY(-50%);
	width:100%
}
/*アンカーずれ*/
hr{
padding-top: 20px;
  margin-top:-20px;
	height: 0;
	border: none;
}
.main-message h1 {
	font-family: "Kosugi Maru", sans-serif;
	font-weight:400;
	font-size:60px;
	color:#fff
}
.title {
	text-align:center;
	/*margin-bottom:70px*/
}
.title p {
	font-size:14px;
	/*color:#9d9d9d*/
}
.title h2 {
	margin-bottom:15px!important;
}
p.description {
	font-size:14px;
	font-weight:400;
	text-align:left!important;
	padding-bottom:5px;
	margin:0 auto
}
p.description-image {
	color:#FF0;
	font-size:17px;
	font-weight:400;
	letter-spacing:.4px;
	padding:15px 230px;
	line-height:25px
}
.zig-zag {
	margin-bottom:100px
}
.zig-zag-right h2, .zig-zag-right p {
	text-align:right
}
#features {
	margin-bottom:70px;
	padding-top:50px;
	background-color:#f6f8fa
}
#features i.fa {
	font-size:50px;
	color:#0785f2;
	position:relative;
	text-align:center;
	margin-bottom:10px
}
#features h3 {
	color:#222
}
#features .caption p {
	padding-left:10px;
	padding-right:10px
}
#testimonials .carousel-indicators li {
	background-color:#000;
	background-color:rgba(70, 70, 70, .25)
}
#testimonials .carousel-indicators .active {
	background-color:transparent;
	border:2px solid #0785f2
}
.carousel-inner .item {
	min-height:320px
}
#testimonials .carousel-inner blockquote {
	font-size:30px;
	line-height:40px;
	margin:0;
	font-weight:300;
	color:#111
}
.carousel-indicators {
	top:110%
}
a.company img {
	margin:0 auto 30px;
	width:auto
}
span.author {
	font-size:13px;
	color:#828282!important;
	font-weight:500
}
span.author img {
	display:block;
	height:54px;
	margin:30px auto 10px;
	width:auto
}
#services a img {
transition:all .2s ease-in-out;
	border:2px solid #fff
}
#services a img:hover {
	border:2px solid #0785f2
}
#plan {
	padding-bottom:70px
}
.price-table {
	padding-top:40px;
	padding-bottom:30px;
	text-align:center;
	background-color:#fff;
	border:1px solid #d6d6d6;
transition:all .2s ease-in-out;
	cursor:pointer;
	margin-left:0
}
.price-table i.fa {
	color:#d6d6d6;
	font-size:40px
}
.price-table h6 {
	letter-spacing:2px;
	text-transform:uppercase;
	color:#828282;
	font-weight:400
}
span.price {
	font-size:70px;
	font-weight:300;
	color:#333c4d
}
span.dollar {
	vertical-align:top;
	font-size:17px!important;
	display:inline-block;
	margin-top:15px;
	color:#222
}
.price-table ul.features {
	margin-top:10px
}
.price-table ul.features li {
	font-size:14px;
	line-height:37px
}
.price-table:hover {
	background-color:#0785f2;
	margin-top:-20px;
	z-index:10;
	border:none
}
.price-table:hover * {
	color:#fff!important
}
#contact h2 {
	color:#FF0;
}
@media (max-width:1024px) {
.hero-overlay {
height:250px
}
}
@media (min-width:1024px) {
.hero-overlay {
/*height:750px*/
height:250px
}
}
@media (max-width:768px) {
.hero-overlay {
height:150px;
}
.navbar-fixed-top {
background:rgba(255,255,255,0.95)!important;
box-shadow:0 6px 4px -4px rgba(0, 0, 0, .1)
}
.navbar-default .navbar-nav>li>a {
color:#828282;
opacity:1;
line-height:20px!important;
margin-left:0!important
}
.navbar-fixed-top .navbar-toggle .icon-bar {
background-color:#757d8a!important
}
.navbar-fixed-top .navbar-nav .activenav a {
color:#222;
border-bottom:1px solid #0785f2
}
}
@media (max-width:990px) {
p.description-image {
padding:0!important
}
}
@media (max-width:990px) {
.zig-zag {
text-align:center;
margin-bottom:40px
}
.zig-zag-right * {
text-align:center!important;
margin-bottom:20px
}
.carousel-indicators {
position:relative;
clear:both;
margin-bottom:30px;
left:50%
}
}
@media (max-width:450px) {
.social {
float:left!important;
margin-bottom:20px;
margin-top:-15px
}
.zig-zag h2 {
margin-top:30px
}
}
@media (max-width:600px) {
.main-message h1 {
font-size:40px!important
}
}

/* #footer {
	margin-bottom:0;
	background-color:#222;
	padding-top:50px
}
.footer-section {
	margin-bottom:30px
}
img.logo-footer {
	margin-top:-15px
} */



p.copyright {
	font-size: small;
	background: #e9dfd3;
    text-align: center;
}
.social {
	float:right;
	margin-right:-15px
}
.social a {
	padding-right:15px;
	font-size:19px
}

.map-wrap {
  max-width: 50%; 
}
 
.map {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 75%;
}
 
/* Google Mapのiframe */
.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*テーブル*/
.biz-hour {
  border-collapse: collapse;
  /* overflow-x: scroll;で、
  スマホ画面幅に表が入りきらない場合は
  横スクロールしてくれます */
  overflow-x: scroll;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.biz-hour th, .biz-hour td {
  padding: 10px;
  text-align: center;
  /* 枠線。色を変えたい時は#ff6680というところをお好みで */
  border: 1px solid #90ee90 ;
}

/* 最上段の表の見出し。background-colorを書き換えれば背景色が変わります。 */
.biz-hour th {
  background-color:#e0ffff  ;
  font-weight: normal;
}

/* 「土」の文字色 */
.biz-hour th.sat {
  color: #3db2da;
}

/* 「日」の文字色 */
.biz-hour th.sun {
  color: #e66a6a;
}

img#logo{
		width: auto;
		height: 50px;
	}
a img#logo{
	display: block;
}

h2 {
  padding: 2rem 3rem;
  color: #fff;
  /*border-radius: 100vh;
  background-image: -webkit-gradient(linear, right top, left top, from(#9be15d), to(#00e3ae));
  background-image: -webkit-linear-gradient(right, #9be15d 0%, #00e3ae 100%);
  background-image: linear-gradient(to left, #9be15d 0%, #00e3ae 100%);*/
}
#contact h2{
	color: #fff!important;	
	}
.flexlayout{
    padding: 5px;
    text-align: center;
    display: flex;
    justify-content: center;  
}
@media (max-width:480px) {
.flexlayout {
       flex-wrap: wrap;
   }

.flexlayout div{
       width: 100%;
   }
}


.flexlayout div{
	padding: 10px;
	}
.flexlayout ul{
	font-weight: bold;
	font-family: "Kosugi Maru", sans-serif;
font-size: 2rem!important;
		text-align: left;
	}
ul#name{
	border: 1px solid #ccc;
	padding: 20px;
	}
/*アクセス部分 ---------------------------------------------------------*/
@media (max-width:480px) {
	.access strong{display: block}
}


.access {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	line-height:2.5em;
	margin-bottom: 25px;
	margin-top: 150px;
}
.access a{
	text-decoration:none;
}
	.access ol{
		list-style: none;
	}
.access-description {
    /*background: url(../images/cl-image.jpg) no-repeat;*/
	background: #085;
	background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: right;
    -webkit-box-align: center;
    -ms-flex-align: center;
    /*align-items: center;*/
    -webkit-box-flex: 0;
    -ms-flex: 0 1 50%;
    flex: 0 1 50%;
	color: #fff;
	padding: 0;
}
.access-description-on {
	background:  rgba(0,135,85,0.8);
	margin: 0;
	max-width:600px; /*追加 */
}

.access-description-inner {
    -webkit-box-flex: 0;
    -ms-flex: 0 1 460px;
    flex: 0 1 460px;
	margin:20px 10px;
}
*, ::before, ::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.access-mean-list span {
    color: #fff;
    font-size: 1.6rem;
}
ol.access-mean-list{
	margin-left: -1.5em;
}
.access-address {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 40px;
	margin-left: 5px;
	margin-right: 5px;
}
.access-map {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
}
@media (max-width: 767px) {
  .access-map {
    position: relative;
    height: auto;
    padding-top: 0;
    aspect-ratio: 1 / 1;
  }
  .access-map iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
}

.access-title {
  /*font-size: 3.2rem;*/
  font-weight: normal;
  margin-bottom: 40px;
background:none;
}
.access-mean-title {
    /*font-size: 2rem;*/
    font-weight: normal;
    border-bottom: 1px solid #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 10px;
    padding-bottom: 6px;
}
.label {
    border: solid 1px #fff;
    display: inline-block;
    font-family: "Kosugi Maru", sans-serif;
    padding: 0.2rem .6rem;
    font-size: 1.4rem;
    margin-left: 10px;
}
.button-tertiary-irregular a {
    background-color: transparent !important;
    border: 1px solid #fff !important;
    color: #fff !important;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.25);
}
.button-access a {
    display: block;
    font-size: 1.5rem;
    font-weight: 500;
    padding: 1rem;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    border-radius: 35px;
    text-align: center;
}
.button-primary-irregular a {
    background-color: #fff;
    border: 1px solid transparent;
    color: #085;
	font-size:20px;
}
a.access-button {
    font-size: 2.3rem;
    padding:1.8rem 1rem;
	margin:20px auto;
    vertical-align: middle;
    text-align: center;
    background-color: #085;
    border: solid 1px #fff;
    border-radius: 26px;
    color: #fff;
    display: inline-block;
    width: 180px;
    line-height: 1;
    font-family: 'icomoon';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
	text-decoration:none;
}

.icon-car::before {
  font-family: "Material Icons";
	content: "\e531";

}
.icon-train::before {
  font-family: "Material Icons";
  content: "\e570";
}
.icon-bus::before {
  font-family: "Material Icons";
  content: "\e98f";
}
a[target="_blank"]::after {
   font-family: "Material Icons";
  content: "\e89e";
}
a[target="_blank"]::after img{
	content: none!important;
}


#news{
	width: 100%;
	background: rgba(255,255,255,0.7);
	padding: 10px;
	margin-left:auto;
	margin-right:auto;
	border-radius: 10px;
	color: #000;
    overflow-y: scroll;
  /*縦方向はスクロール可*/
  overflow-x: hidden;
  /*横方向はスクロール不可*/
  height:220px; 
	}
#news em{ color: #CB0104;
font-weight: normal;
font-style: normal;
margin-left: 2px;}

#news dt{
	margin-top: 15px;
	color: #333
}
#news dt span{
	font-size: 12px!important;
	color: #333;
	letter-spacing: 0;
}
#news dt h1{
	font-size: 2rem;
	font-weight: bold;
	  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #494949;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #7db4e6;/*左線*/
}

#news dd{
	border-bottom: 1px dotted #333;
	padding-bottom: 10px;
	margin-top: 2px;
}

/*スマホここから*/
@media screen and (max-width: 640px) {
.access {
    display: block;
}
.access h2{
	margin: 5px;
}
	img#logo{
		height: 40px;
	}

footer span{
	display: block;
	margin: 0;
	}
}
/*スマホここまで*/

footer{
		text-align: center;
	}


ul#kamoku{
	display:flex;
	justify-content:center;
}
ul#kamoku li{
	margin: 15px 5px;
	padding:25px;
	border: 3px solid #ddd;
	border-radius: 50%;
	font-size: 4rem;
}


/*202506追加 □□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□*/
/*--スマートフォン--*/
/*--メディアクエリの記述なし--*/
.ullist ul {
	width: 100%;
	margin: 0 auto;
	padding: 2em;
	box-sizing: border-box;
	/*background: #f9f9f9;*/
}

.ullist ul li {
	border: solid 1px #cccccc;
	background-color: #ffffff;
	padding: 2em;
	box-sizing: border-box;
	list-style: none;
}

.ullist ul li img {
	width: 100%;
	text-align: center;
}

.ullist ul li h3 {
	font-size: 2rem;
	border-bottom: 1px dotted #333;
	font-weight: bold;
	padding: .5em 0;
}

/*.ullist ul li p {font-size: 1rem;}*/
	
.ullist ul li p:first-of-type {
	padding-top: 0;
	margin-bottom: 0;
}
.ullist ul li + li {margin-top: 2em;}

/*--PC--*/
@media screen and (min-width: 1025px){
	.ullist ul {width: 100%;}
	
	.ullist ul li {overflow: hidden;}
	
	.ullist ul li img {
		width: 200px;
		float: left; /*--フロートを指定--*/
		margin-right: 2em;
	}
}

/*アイコン*/
a[href$='.pdf'] {
	background:url("../images/ico_pdf.png") no-repeat 0px center;
	background-size: 20px;
	padding-left: 22px;
	padding-top: 7px;
	padding-bottom: 7px;
}
a[href$='.xls'] {
	background:url("../images/ico_exl.png") no-repeat left;
	background-size: 20px;
	padding-left: 22px;
}
a[href$='.doc'] {
	background:url("../images/ico_word.png") no-repeat left;
	background-size: 20px;
	padding-left: 22px;
}

/*スクロール*/
.scroll_lists {
  width: 180px;
  height: 400px;
  overflow-y: scroll;
  overflow-x: none;
}

@media (max-width: 767px){
  .scroll_lists {
    height: 310px;
  }
}

.scroll_lists li {
  padding: 20px 0;
}

.scroll_lists::-webkit-scrollbar {
    width: 16px;
}
 
.scroll_lists::-webkit-scrollbar-track {
    background-color: #e4e4e4;
    border-radius: 100px;
}
 
.scroll_lists::-webkit-scrollbar-thumb {
  background-image: linear-gradient( 135deg, #070 10%, #085 100%);
  box-shadow: inset 2px 2px 5px 0 rgba(#fff, 0.5);
  border-radius: 100px;
}

/* 通常時 */ 
.coco li a {
  color: #333;
}

/* カレント表示 */
.coco a.current  {
	font-weight: bold;
	border-bottom: 1px solid;
}



/*=================================================================*/
/* 共通 */
.pan {
	margin-left: 10px;
    margin-bottom: 50px;
}
.fa-li {
	color: #6C9FCE;
}
.mb-0 {
	margin-bottom: 0;
}
.mt-10 {
	margin-top: 10px;
}
.mb-10 {
	margin-bottom: 10px;
}
.mt-50 {
	margin-top: 50px;
}
.mb-50 {
	margin-bottom: 50px;
}
.mt-100 {
	margin-top: 100px;
}
.mb-100 {
	margin-bottom: 100px;
}
.ma-a{
	margin: auto;
}

.pt-0 {
	padding-top: 0;
}
.pb-0 {
	padding-bottom: 0;
}
.pl-5 {
	padding-left: 5px;
}
.pb-5 {
	padding-bottom: 5px;
}
.pt-30 {
	padding-top: 30px;
}
.pt-100 {
	padding-top: 100px;
}
.pb-100 {
	padding-bottom: 100px;
}

.bg-gr {
  background: rgba(0, 136, 85, 0.2);
}

.btn-common {
  display: inline-block;
  padding: 12px 24px;
  margin-top: 10px;
  margin-bottom: 15px;
  font-size: 18px;
  color: #fff !important;
  background-color: #085;
  border: 1px solid #085;
  border-radius: 4px;
  transition: all 0.3s ease;
  text-decoration: none;
  white-space: normal;
  min-width: 400px;
}
.btn-common:hover {
  background-color: #fff;
  color: #085 !important;
  text-decoration: none;
}
.btn-common i {
  margin-left: 6px;
}
.btn-area {
  text-align: left;
}
@media (max-width: 767px){
  .btn-common {
    width: 100%;
    min-width: auto;
  }
  .btn-area { text-align: center; }
}

/* グレー背景の見出し */
.wp-post h3.bg-gray {
  background: #f2f2f2;
  padding: 12px 16px;
  margin: 30px 0 20px 0;
  border: none;
  font-weight: 600;
  color: #333;
}
.wp-post h3.bg-gray::before,
.wp-post h3.bg-gray::after {
  display: none;
}

.bga-green {
  padding: 20px;
  line-height: 1.6;
  background: #f2fcf4;
}

/* -------------------------- index ----------------------------- */
#top-about {
  background-image: linear-gradient(123deg, rgba(252, 254, 252, 1), rgba(196, 253, 196, 1));
}

@media (max-width: 767px){
  #top-about {
    margin-top: 10px;
  }
}

/* 診療のご案内 */
@media (max-width: 1199px){
  #top-guide.btn-common {
    min-width: auto;
  }
}
.top-guide-box{
	background: #fff;
    box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.3);
    padding: 25px;
}

#top-guide .col-xs-12,.col-md-7{
	padding-right: 0;
    padding-left: 0;
}

.top-guide-ttl {
  text-align: center;
  border: solid 1px #085 !important;
}
.top-guide-ttl:before {
  display: none;
}
.dept-circles {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
}
.dept-circles > li {
  display: inline-block;
  margin: 0 12px 12px 0;
}
.dept-circles > li:last-child {
  margin-right: 0;
}

.circle{
  width: 96px;
  height: 96px;
  border-radius: 50%;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  text-align: center;
  font-weight: bold;
  line-height: 1.2;
  color:#222;
}
.circle span{
  display:block;
  margin-right: -8px;
  letter-spacing: 2;
}

.circle.c1{ background:#c9b59f; }   /* 内科 */
.circle.c2{ background:#f4bb59; }   /* 胃腸科 */
.circle.c3{ background:#9cde99; }   /* 泌尿器科 */

.lead-sm{ font-size:16px; margin-top:24px; }

@media (min-width: 992px){
  .circle{
    width:180px;
    height:180px;
    font-size: 24px;
  }
  .lead-sm{
    margin-top:40px;
  }
}
/*　外来　*/
#top-gairai  {
    background-image: url(../images/gairai_img.jpg);
    background-repeat: no-repeat;
    background-position: right top;
    background-size: cover;
}
#top-gairai h2{
	text-shadow:
    -1px -1px 0 #fff,
     1px -1px 0 #fff,
    -1px  1px 0 #fff,
     1px  1px 0 #fff,
    0 0 4px rgba(255,255,255,0.9),
    0 0 8px rgba(255,255,255,0.7),
    0 0 16px rgba(255,255,255,0.5);
}
.doctor-box {
    background: rgba(255,255,255,0.95);
    border:1px solid #e5e5e5;
    padding:10px 12px;
    width: 100%;
    margin-top: 20px;
    display:inline-block;
}
@media (max-width: 767px){
	#top-gairai {
		margin-bottom: 0;
	}
	#top-gairai .container{
	background: rgb(255, 255, 255, 0.5);
}
	.doctor-box{
    display:block;
    width:100%;
  }
}

/*時計*/
.dli-clock {
  display: inline-block;
  vertical-align: middle;
/*color: #333;*/
  line-height: 1;
  position: relative;
  width: 1em;
  height: 1em;
  border: 0.1em solid currentColor;
  border-radius: 50%;
  box-sizing: content-box;
  margin: 0 5px 5px 0;
}
h2.dli-clock {color: #32cd32}
	
.dli-clock::before, .dli-clock::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 50%;
  background: currentColor;
  border-radius: 0.1em;
  transform: translate(-0.05em, 0.05em);
}

.dli-clock::before {
  width: 0.1em;
  height: 0.4em;
}

.dli-clock::after {
  width: 0.35em;
  height: 0.1em;
}

.btn-top-gairai {
  text-align: center;
  margin: 10px;
}


/* 訪問　*/
#top-houmon {
	background-image: url(../images/bg_town.jpg);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
    height: auto;
    padding-bottom: 150px;
    padding-top: 100px;
}
@media (max-width: 767px){
	#top-houmon {
		padding-top: 0;
	}
}

/* -------------------------- about ----------------------------- */
#about .lead h1 {
	font-size: 3rem;
	margin-bottom: 20px;
}
#about .lead p {
	padding: 20px;
  line-height: 1.6;
	background: #f2fcf4;
}

@media screen and (max-width:559px){
	.container, .main {
		width: 100%;
	}
	.lead {
		padding: 10px;
	}
	.lead h1 {
		font-size: 2.5rem;
	}
}

.wp-content {
  text-align: center;
  display: block;
}

.wp-content p {
  text-align: left;
  display: inline-block;
  color: #7b7b7b;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.7;
}

.doctor h3 {
  padding: 0;
  background: none;
  border: none;
}
.doctor h3::before {
  display: none;
}
.doctor h3::after {
  display: none;
}
@media (max-width: 767px){
.doctor {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: left;
  }
}

/* -------------------------- gairai ----------------------------- */
.wp-post h3.bg-gray {
  background: #f2f2f2;
  padding: 12px 16px;
  margin: 20px 0;
  border: none;
  font-weight: 600;
  color: #333;
}

.wp-post h3.bg-gray::before,
.wp-post h3.bg-gray::after {
  display: none;
}



/* -------------------------- houmon ----------------------------- */
#houmon h3 {
  margin-top: 50px;
}
.houmon-lead{
  padding: 10px;
  border-radius: 10px;
  background: #f2f2f2;
  font-size: 21px;
}



/* -------------------------- guide ----------------------------- */
.kensa h3 {
  font-size:16px;
}

/* カード共通 */
.cl-card {
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  padding: 28px 22px;
  border-radius: 4px;
  color: #fff;
  background: #085;               /* 初期色（緑系） */
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 3px 10px rgba(0,0,0,0.12);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
  min-height: 140px;
}

.cl-card__icon {
  display: block;
  font-size: 68px;                /* fa-4x 相当（調整しやすいようpx指定） */
  line-height: 1;
  color: #fff;
}

.cl-card__title {
  margin: 0;
  font-size: 36px;
  font-weight: 700;
  color: #fff;
}
.cl-card__text {
  margin: 0;
}
.jushin a:hover{
  color: #fff;
}

.cl-card:hover,
.cl-card:focus {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.18);
  text-decoration: none;
  filter: brightness(1.03);
}

.cl-card--green { background: #339999; }
.cl-card--pink  { background: #FF9999; } 

.cl-card--green:hover,
.cl-card--green:focus { background: #007E80; }

.cl-card--pink:hover,
.cl-card--pink:focus  { background: #FF7B7B; }

@media (max-width: 767px) {
  .cl-card {
    margin-bottom: 15px;
    padding: 22px 18px;
    min-height: 0;  
  }
  .cl-card__icon  { font-size: 48px; margin-bottom: 8px; }
  .cl-card__title { font-size: 26px; }
  .cl-card__text  { font-size: 13px; }
}



/* -------------------------- contact  ----------------------------- */
.flex-center {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.contact-box {
  background: #fff;
  padding: 20px 25px;
  margin: 0 auto 30px auto;
  border-radius: 8px;
  box-shadow: 2px 4px 10px rgba(0,0,0,0.1);
  max-width: 500px;
}

.contact-box h4{
  background: #085;
  padding: 7px 0;
  color: #fff;
}

.label-gray {
  display: inline-block;
  background: #eee;
  color: #333;
  font-weight: bold;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 16px;
  vertical-align: middle;
  margin-right: 10px;
}

.contact-box p {
  font-size: 48px;
  margin: 0;
}

@media (max-width: 767px) {
  .contact-box {
    max-width: 100%;
  }
  .contact-box p {
    font-size: 32px;
  }
  .label-gray {
    font-size: 14px;
    padding: 3px 8px;
  }
}
.txt-area {
	border: solid 1px #ccc;
	display: inline-block;
	padding: 20px;
}

/* -------------------------- footer ----------------------------- */
#footer {
  background:#e9dfd3;
  padding:20px 0;
  color:#000;
}
.footer-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
}

.footer-box .corp {
  font-size:12px;
  margin:0 0 2px;
}
.footer-box .clinic {
  color: #085;
  margin:0 !important;
  padding: 10px 0; 
  font-size: 26px;
  font-weight: bold;
}
.footer-box .clinic small {
  font-size:14px;
  color: #666;
}
#footer .tel{
  font-size: 26px;
  font-weight: 600px;
  line-height: 1;
  padding-bottom: 0!important;
  margin-bottom: 10px!important;
}

@media (max-width: 767px){
  .footer-inner > [class*="col-"] {
    margin-bottom: 20px;
  }
  .footer-inner > [class*="col-"]:last-child {
    margin-bottom: 0;
  }
  .footer-desc p{
    font-size:.8em;
  }
}

/* お問い合わせボックス */
.contact-cta {
  background: #fff;
  text-align: center;
  padding: 16px 20px 20px;
  border-radius: 8px;
  border: 1px solid #eee;
  max-width: 720px;
  margin: 100px auto 0;
}
.contact-cta .contact-lead {
  margin: 0 0 8px;
  font-size: 24px;
}

@media (max-width: 767px){
  .contact-cta .contact-lead{
    font-size: 20px;
  }
}

.tel-line {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%; 
}
/*.tel-icon {
  width: 44px;
  height: 44px;
  margin-right: 10px;
}*/
.tel-number {
  font-size: 58px;
  line-height: 1;
  color: #000;
  font-weight: 600;
  letter-spacing: .5px;
  display: inline-block;
}

.fax-line {
  display: block;
  background: #f5f5f5;
  padding: 6px 14px;
  font-size: 22px;
  margin-top: 10px;
  color: #333;
  border-radius: 3px;
}

@media (max-width: 767px) {
  .contact-cta {
    width: auto;
    padding: 14px 12px 16px;
    margin-right: 15px;
    margin-left: 15px;
    font-size: 20px;
  }
  .tel-icon { width: 32px; height: 32px; }
  .tel-number { font-size: 10vw; }
  .fax-line { font-size: 16px; }
}


