/* CSS Document */

@media screen and (max-width:670px) {
	
body{
	font-size: 14px;
}
body,
#mainvisual .inner,
header,
footer{
	min-width: 100%;
}



/*============================================================================

	header

============================================================================*/

header {
	display:none;
}



/*============================================================================

	nav

============================================================================*/

nav{
	display:none;
}
.sp_navi {
	display:block;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	font-size:18px;
	font-weight:bold;
	z-index: 9998;
}
.sp_navi h1{
	text-align: center;
	width: 100%;
	padding: 8px 0 8px;
	background-color: rgba(255,255,255,0.85);
}
.sp_navi h1 span,
.sp_navi h1 img{
	display:block;
	width: 200px;
	height: 30px;
	margin: 0 auto;
}
.sp_navi h1 a{
	vertical-align:middle;
}
.sp_navi h1 img{
	z-index: 9999;
	position:relative;
}
.sp_navi dl {
}
.sp_navi dl dt {
	height: 56px;
	font-weight:bold;
	cursor:pointer;
	padding: 0;
	font-size:18px;
	display:block;
	color:#fff;
	line-height: 2;
	background-color: rgba(255,255,255,0.85);
}
.sp_navi dl dt i{
	margin-right:2%;
}
.sp_navi dl dd {
	display:none;
}
.sp_navi_wrap {
	width: 100%;
	height: calc(100vh - 56px);
	overflow: auto;
}
.nav_bnr_sp {
	padding: 15px 0 30px;
	text-align: center;
	background-color: #F8F6F2;
}
.sp_navi ul{
	background: #00A0E9;
}
.sp_navi ul li {
	display:block;
	width: 100% ;
	line-height:1;
	font-size:15px;
	font-weight:normal;
}
.sp_navi ul li i{
	margin-right: 4%;
	color: #fff;
	font-size: 28px;
	vertical-align: middle;
	position: relative;
	top: -2px;
	left: -6px;
}
.sp_navi ul li a {
	display:block;
	padding:4% 2% 4% 8%;
	width:90%;
	color:#fff;
	text-decoration:none;
    font-size: 16px;
	border-bottom:1px solid #fff;
}
.sp_link li div{
	display:none;
}
.sp_navi .sp_link li div ul {
	background-color: #008bcb;
}
.sp_navi ul li div ul li a {
	padding-left: 12%;
	width: 86%;
	font-size: 15px;
	letter-spacing: 0;
}
.sp_navi ul li div ul li a i {
	margin-right: 2%;
}

/*ボタンの動き*/
.sp_navi dt a {
    display: block;
	float: right;
    width: 56px;
    height:56px;
    position: relative;
    z-index: 9999999;
	background-color: #00A0E9;
}
.sp_navi dt a.sp_nav_btn::after {
	position: absolute;
	width: 56px;
	left: 0;
	bottom: 2px;
	content: 'MENU';
	font-size: 11px;
	text-align: center;
	color: #FFF;
}
.sp_navi dt a span {
    display: block;
    background: #fff;
    width: 26px;
    height: 2px;
    position: absolute;
    left: 15px;
    transition: all 0.4s;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
}
.sp_navi dt a span:first-child {
    top: 14px;
}
.sp_navi dt a span:nth-child(2) {
    margin-top: -1px;
    top: 23px;
}
.sp_navi dt a span:last-child {
    top: 30px;
}
.sp_navi dt a.sp_nav_btn.active::after {
	content: 'CLOSE';
}
.sp_navi dt a.active span:first-child {
    -webkit-transform: translateY(8px) rotate(45deg);
    -moz-transform: translateY(8px) rotate(45deg);
    -ms-transform: translateY(8px) rotate(45deg);
    transform: translateY(8px) rotate(45deg);
}
.sp_navi dt a.active span:nth-child(2) {
    opacity: 0;
}
.sp_navi dt a.active span:last-child {
    -webkit-transform: translateY(-8px) rotate(-45deg);
    -moz-transform: translateY(-8px) rotate(-45deg);
    -ms-transform: translateY(-8px) rotate(-45deg);
    transform: translateY(-8px) rotate(-45deg);
}

.sp_navi dt .sp_navi_tel a {
	display: block;
	float: left;
	width: 22%;
	height: auto;
	box-sizing: border-box;
	margin-top: 10px;
	margin-left: 1%;
	line-height: 38px;
	background-color: #D3C49F;
	border-radius: 4px;
	font-size: 14px;
	font-weight: bold;
	color: #fff;
	text-align: center;
}
.sp_navi dt .sp_navi_tel a img {
	height: 20px;
	width: auto;
	margin-right: 3px;
	vertical-align: middle;
}
.sp_navi dt .sp_navi_access a {
	display: block;
	float: left;
	width: 28%;
	height: auto;
	box-sizing: border-box;
	margin-top: 10px;
	margin-left: 1%;
	line-height: 38px;
	background-color: #D3C49F;
	border-radius: 4px;
	font-size: 14px;
	font-weight: bold;
	color: #fff;
	text-align: center;
}

.sp_navi dt .sp_navi_reserve a {
	display: block;
	float: left;
	width: 28%;
	height: auto;
	box-sizing: border-box;
	margin-top: 10px;
	margin-left: 1%;
	line-height: 38px;
	background-color: #D3C49F;
	border-radius: 4px;
	font-size: 14px;
	font-weight: bold;
	color: #fff;
	text-align: center;
}


/*============================================================================

	#mainvisual

============================================================================*/

#mainvisual{
	background-position: center ;
	background-attachment: scroll ;
	height: 220px;
	margin-top: 102px;
}
#mainvisual .inner{
	width: auto;
	height:inherit;
}
/* 下層ページヘッドライン */
#mainvisual h2{
	font-size:22px;
}
/* トップページキャッチフレーズ */
.main_catch{
	position: absolute;
	top:50px;
	width:100%;
	text-align:center;
}
.main_catch h2{
	margin-bottom: 10px;
}
.main_catch p{
	font-size: 15px;
}
.main_open{
	position: absolute;
	top:auto;
	bottom: 50px;
	right: 0;
	left: 0;
	width: 200px;
	margin: auto;
}

.mainvisual_headline h2 {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.mainvisual_headline h2 img {
	position: absolute;
	top: -40px;
	left: 50%;
	height: 300px;
	max-width: auto;
	max-width: inherit;
	width: auto;
	margin-left: -174px;
}


.header_insta {
	position: static;
	display: block;
	padding: 20px 0;
	text-align: center;
}
	.header_insta a img {
		margin-bottom: 10px;
	}

/*キャンセルポリシー*/
	a.header_cancelInfo {
		position: static;
		width: 90%;
		max-width: 320px;
		padding: 10px 0;
		margin: 0 auto 10px;
	}
	

/*============================================================================

	#contents

============================================================================*/

.box1{
	width:auto;
	margin:0 3% 60px;
}
.box2{
	width:auto;
	margin:0 3% 60px;
}
#contents{
	width:auto;
}
#container {
    padding-bottom: 30px;
}
#contents_left{
	width:auto;
	float:none;
	margin-right:0;
}
#contents_right{
	width:auto;
	margin-top: 90px;
	padding:0 6%;
	float:none;
}







/*============================================================================

	fotter

============================================================================*/

.footer_info {
    width: 94%;
    margin: 0 auto;
    padding-top: 40px;
    padding-bottom: 38px;
}
.footer_info_sec1 {
    float: none;
    width: 100%;
}
h3.footer_logo {
    width: 100%;
	max-width: 447px;
	height: auto;
	margin-bottom: 26px;
}
 h3.footer_logo img {
    width: 100%;
	height: auto;
	margin-bottom: 0;
}
.footer_info_sche {
    float: none;
    width: 100%;
	text-align: center;
	margin-bottom: 26px;
}
.footer_info dl{
	float:none;
	width: 100%;
	margin-bottom: 12px;
}
.footer_info dl dt{
	float: left;
	display: inline-block;
	width: 100px;
	height: auto;
	margin-right: 12px;
	line-height: 30px;
    font-size: 15px;
}
.footer_info_list {
	margin-bottom: 30px;
}
.footer_info_list dd {
	float: left;
	width: calc(100% - 112px);
    line-height: 1.8;
    padding-left: 0;
    letter-spacing:normal;
}
.footer_info_list dl:last-child dd a {
    font-size: 23px;
    letter-spacing: 2px;
	line-height: 30px;
}
.footer_info_list p.footer_message{
	position: relative;
	margin-left: 25px;
}
.footer_info_list p.footer_message::before{
/*top: 406px;
left: 112px;*/
	top: -5px;
	left: -25px;
width: 0;
height: 0;
border: 9px solid transparent;
border-bottom: 15px solid #1aaeeb;
position: absolute;
content: "";
}	
	
	
	
.footer_info_sec2 {
    float: none;
    width: 100%;
}
.footer_info_sec2 iframe {
    width: 100%;
	height: 300px;
}
.footer_access {
    width: 100%;
    height: auto;
	padding: 10px 0;
    line-height: 1.4;
    font-size: 15px;
    letter-spacing: normal;
}
.footer_access p:after {
    width: 90%;
    height: 12px;
    bottom: 0px;
}
.copy {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    height: auto;
	min-height: auto;
	min-height: inherit;
	line-height: 50px;
}

.sp_navi_btn_area {
    position: fixed;
    bottom: 0;
    width: 100%;
    height: 51px;
    z-index: 999;
    box-shadow: 5px 0 5px 0 #bbb;
    background-color: #fff;
}
.sp_navi_btn_area li {
    display: block;
    text-align: center;
}
.sp_navi_btn_area a {
    display: block;
    color: #fff;
    height: 43px;
    line-height: 45px;
    margin: 4px;
    padding-left: 4%;
    border-radius: 5px;
    font-size: 4vw;
    background: #d3c4ae;
}
.sp_navi_btn_area li i {
    position: relative;
    font-size: 1.5em !important;
    top: 3px;
    left: -9px;
    color: #fff;
}


/*============================================================================

	$top

============================================================================*/

.top_greeting {
    padding-top: 40px;
    padding-bottom: 38px;
	overflow: hidden;
}
.top_greeting .box1 {
	margin-bottom: 0;
}
.top_greeting h3.tit03 {
    margin-top: 0;
}
.greet_slide{
	float:none;
	width:100%;
	height:auto;
	margin-top: 0 !important;
}
.greet_slide .swiper-wrapper {
	padding-bottom: 50px;
}
.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 20px !important;
}
.top_greeting .text {
    position: relative;
    line-height: 1.8;
    letter-spacing: 1.2px;
}
.top_greeting h3.tit03:before {
    top: -14px;
    left: 50%;
	margin-left: -90px;
}


.top_medical {
    padding-top: 75px;
}
.top_medical.box1 {
    margin-bottom: 0;
}
.top_medical h3.tit02:before {
	top: -45px;
    left: -10px;
    margin-top: 0;
}
.top_medical_list {
	text-align: center;
}
.top_medical_list a {
    display: inline-block;
	float: none;
	height: auto;
    margin: 0 auto 58px;
}
.top_medical_list dd h4 {
    font-size: 20px;
	line-height: 1.4;
    margin-bottom: 5px;
}
@supports (-ms-ime-align: auto) {
	.top_medical_list dd.btn {
		width: auto;
		bottom: -60px;
	}
	.top_medical_list a {
		background-color: #fff;
	}
}
.top_medical_list dd p {
    margin: 0 auto 40px;
	width: auto;
}
/*レイアウト変更*/
/* ── top_medical_list：スマホは2カラム配置にする ───────────────── */
.top_medical_list{
  /* もともとの text-align: center; は不要になるので上書き */
  text-align: unset;

  /* グリッドでシンプルに2列化 */
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 16px;   /* 横のすき間 */
  row-gap: 72px;      /* 縦のすき間（btnが下にはみ出す分を考慮して広め） */
}

/* 各カード（a）をグリッドの幅いっぱいに。PC用の幅指定をリセット */
.top_medical_list a{
  display: block;   /* inline-block指定を上書き */
  width: 100%;      /* PC側の width:276px; を打ち消す */
  float: none;      /* float指定も消す */
  height: auto;     /* 念のため維持 */
  margin: 0;        /* グリッドが余白を持つのでマージンは不要 */
  box-sizing: border-box; /* 念のため */
}

/* 画像のはみ出し防止（任意） */
.top_medical_list dl dt img{
  max-width: 100%;
  height: auto;
}

/* タイトルが折り返しても崩れにくく（任意） */
.top_medical_list dd h4{
  word-break: keep-all;
}

/* PC用nth-childの右マージン調整を無効化（念のため上書き） */
.top_medical_list a:nth-child(4),
.top_medical_list a:nth-child(8){
  margin-right: 0;
}
/* PC用5番目でclearしてる指定も無効化 */
.top_medical_list a:nth-child(5){
  clear: none;
}
.top_medical_list .medical_blue p .marker_blue{
	background: linear-gradient(transparent 40%, #e5f5fd 40%);
}
.top_medical_list .medical_green p .marker_green{
	background: linear-gradient(transparent 40%, #eff8f1 40%);
}
.top_medical_list .medical_yellow p .marker_yellow{
	background: linear-gradient(transparent 40%, #fff9ea 40%);
}
.top_medical_list .medical_brown p .marker_brown{
	background: linear-gradient(transparent 40%, #faf5ee 40%);
}
	
.top_medical_list .medical_blue p:after{
	background: none;
}
.top_medical_list .medical_green p:after{
	background: none;
}
.top_medical_list .medical_yellow p:after{
	background: none;
}
.top_medical_list .medical_brown p:after{
	background: none;
}
.top_medical_list dd.btn {
	width: 136px;
	padding: 12px;
}
.top_medical_list dd.btn:before{
	right: 24px;	
}
/*ここまで*/

.top_features {
    padding-top: 40px;
}
.top_features h3.tit02 {
    margin-bottom: 25px;
}
.top_features h3.tit02 img {
    margin-bottom: 0;
}
.top_features_list dt {
    float: none;
    width: 100%;
    height: auto;
}
.top_features_list dt img {
	width: 97%;
	padding-bottom: 3%;
}
.top_features_list dt:before {
    height: 100%;
}
.top_features_list dl {
    margin-bottom: 40px;
}
.top_features_list dd {
    float: none;
    width: 100%;
    padding-top: 20px;
}
.top_features_list dd h4 {
    font-size: 20px;
    margin-bottom: 10px;
	line-height: 1.3;
}
.top_features_list dd p {
    line-height: 1.8;
    letter-spacing: normal;
}
.top_features_list dd .btn01 {
    margin-top: 24px;
}

/*==================================================================

	.top_informatin

==================================================================*/

/* かぎ括弧風ボックス */
.top_information {
   padding: 2em 1.5em;
}

.top_information p { 
	text-align: left;
}


/*============================================================================

	$breadcrumb ぱんくず

============================================================================*/

.breadcrumb {
	width:92%;
	margin:-10px 4% 40px;
}
.breadcrumb li{
	display:inline-block;
}



/*============================================================================

	$共通

============================================================================*/

#contents{
	padding-top: 40px;
	padding-bottom:60px;
}
.box{
	width:auto;
	padding: 0 3%;
}
.text{
	float:none;
	width: auto;
	padding:0;
	border:none;
}
 h3.tit01,
 h3.tit02,
 h3.tit03,
 h3.tit04,
 h3.tit05 {
    width: 100%;
	box-sizing:border-box;
	font-size: 22px;
	margin-bottom:30px;
    text-align: center;
}
h3.tit02 {
    padding: 0 0 0;
}
h3.tit02 span {
    font-size: 13px;
    margin-top: 0px;
	line-height: 1.3;
}
h4.tit01,
h4.tit02,
h4.tit04{
	font-size:19px;
	margin-bottom: 14px;
	line-height: 1.2;
}
h4.tit03 {
    margin-bottom: 18px;
    letter-spacing: 0.1em;
    line-height: 1.4;
    font-size: 18px;
}
h5.tit01{
    margin-bottom: 8px;
	font-size:16px;
	line-height: 1.4;
}
h3.tit02::before{
bottom:0;
left: 0;
right: 0;
margin: auto;
width: 40px;
height: 57px;
background-image: url(../images/tit02_bg.png);
background-repeat: no-repeat;
background-size: cover;
}
h3.tit04 span span::before{
	display:none;
}

.nowrap{
	white-space:normal;
}

/* リスト */
.list08{
	padding:6%;
}
/* テーブル */
.tb01{
	white-space:inherit;
}
.tb01 td, .tb01 th{

	padding:2% 3%;
}
.tb01 th{
width: 105px;
	font-size:12.5px;
}
.tb01 td{
		font-size:11px;
}
  .tb02 th {
    padding: 8px 13px 8px 0;
  }  
.tb03,.tb03 th{
	white-space:inherit;
}
.tb03.w075par{
	width:100%;
}

.table-scroll {
  margin-top: 10px;
  overflow-x: auto;
}

.table-scroll table{
  width: 100%;
  min-width: 600px;
  border-collapse: collapse;
}

.table-scroll th{
  width: 250px;
  padding: 15px;
}

.table-scroll td {
  width: 250px;
  padding: 15px;
}
  
.tb04,
.tb04 th{
	white-space:normal;
}
.tb04 th{
	font-size:13px;
}
.tb04 td, .tb04 th{
	padding:2%;
}
.tb05,
.tb05 th{
	white-space:normal;
}
.tb05 th, .tb05 td {
	font-size: inherit;
	display: block;
	padding: 3% 6%;
}
/* ボタン */
.btn01 a{
	display:block;
}
.btn02 a{
	font-size: 15px;
    padding: 16px 46px 16px 22px;
	letter-spacing: 0;
}
.btn02 a:after {
    right: 22px;
}


/* アンカーリンク */
.ank01{
	width:88%;
	padding:0 6%;
}
.ank01 li{
	width: 49%;
	margin-bottom:3%;
	margin-left:0;
}
.ank01 li:nth-child(even){
	margin-left:2%;
}
.ank02 li{
	float:none;
	width:100%;
	height:auto !important;
	margin-bottom:3%;
	margin-left:0;
}

.ank01 li span{
	font-size:12.5px;
}
	

#ank01, #ank02, #ank03, .anchor {
	margin-top: -60px;
	padding-top: 60px;
}
	
/* 画像右寄せ */
.img_fr{
	float:none;
	margin-left:0;
	text-align:center;
}
.img_fr img{
	margin-bottom:15px;
}

.img_flex {
	justify-content: space-between;
}
.img_flex img {
	width: 48%;
	height: auto;
	margin: 5px 2% 5px 0;
}
.img_flex img:nth-of-type(2n) {
	margin-right: 0;
}
.medi12_xray img{
	width: 150px;
}

/*============================================================================

	$doctor

============================================================================*/

/* ごあいさつ */
.doctor_greet.box2 {
	margin-bottom: 0;
}
.doctor_greet .doctor_img {
    float: none;
    width: 100%;
	margin-bottom: 20px;
	text-align: center;
}
.doctor_greet .text{
	float:none;
	width:auto;
}
.doctor_carr_sec1 {
    margin-top: 40px;
    width: 90%;
    padding: 8% 5%;
    font-size: 14px;
}

/* 経歴、資格 */
.doctor_carr_sec1{
	float:none;
	width:auto;
	margin-right:0;
	/*margin-bottom:0;*/
	margin-bottom:90px;
}
.doctor_carr_sec1 h4.tit01 {
	line-height: 1;
    margin-bottom: 6px;
}





/*============================================================================

	$clinic

============================================================================*/

/* 医院概要 */
.clinic_info.box2 {
	margin-bottom: 0;
}
.clinic_sec1 {
    width: 100%;
}
.clinic_sec1 li {
    padding: 14px 0;
}
.clinic_sec1 dt{
	width:30%;
	line-height: 1.2;
}
.clinic_sec1 dd{
	width:70%;
}
.clinic_sec1 li:last-of-type dt,
.clinic_sec1 li:last-of-type dd {
	display: block;
	width: 100%;
}
.clinic_sec1 li:last-of-type dt {
	margin-bottom: 10px;
}
.clinic_sec1 .schedule .tb01{
	width:100%;
}
.clinic_sec1:last-of-type ul {
    margin-bottom: 0;
}

/* 院内スライド */
.clinic_slides1 {
	margin-bottom:70px;
}
.clinic_slides1 .flexslider{
	float:none;
	width:100%;
}
.clinic_slides1 .flexslider .slides img {
width: auto;
height: auto;
}
.clinic_slides1 .flexslider li div{
position: static;
	display:block;
	margin-top:9%;
	margin-left:0;
	padding: 5%;
	text-align:center;
	width: auto;
	height: auto;
}
.clinic_slides1 .flexslider li div h4{
font-size: 16px;
line-height: 1.5;
padding:8px 0;
}
.clinic_slides1 .flexslider p{
	display:block;
	padding:8px 0;
	font-size: 14px;
	line-height: 1.4;
}
.clinic_slides1 .flex-control-nav.flex-control-thumbs{
	position: absolute;
	right: auto;
	width: auto;
	top:39%;
	z-index: 2;
}
.clinic_slides1 .flex-control-thumbs li {
    position: relative ;
    width: 14.3% ;
    margin: 0 0 4% 2% ;
}
.clinic_slides1 .flex-control-thumbs img{
	border: 3px solid #e0e0e0 ;
}



/*============================================================================

	$facilities

============================================================================*/



.facilities_equip2 dl{
	float:none;
	width:100%;
	height: auto !important;
}
.facilities_equip2 dl:nth-child(2n){
float:none;
}

/* 機器紹介名前 */
.facilities_equip2 dt{
}
.facilities_equip2 dd{
	padding:20px 3% 20px 0;
}
.facilities_equip2 dd h4{
	font-size:15px;
		margin-bottom: 7px;
}
.facilities_equip2 dd p{
font-size: 14px;
line-height: 1.3;
}





/*============================================================================

	$access

============================================================================*/

.access.box2 {
	margin-bottom: 0;
}
.access .footer_access {
    font-size: 16px;
	margin-bottom: 8px;
}
.access .footer_access p:after {
    width: 300px;
}
.access_map {
    margin-bottom: 26px;
}
.access_map dd iframe {
	height: 300px;
}
.access_info {
    padding: 18px 5% 2px;
}




/*============================================================================

	$first

============================================================================*/





/*============================================================================

	$medical

============================================================================*/

.layout01 dt{
	line-height:1.5;
	font-size: 16px;
	letter-spacing: 0;
}
.layout01 dt em{
	display:block;
	margin-right:0;
	font-size: 28px;
	text-align:center;
}
.layout01 dd {
    line-height: 1.5;
}
.layout03 dd h5 {
    font-size: 16px;
	letter-spacing: 0;
    line-height: 1.2;
}
.layout03 dd h5 em {
    font-size: 26px;
}
.layout03, .layout05 {
	padding-bottom: 0;
}
.layout03 dl:last-of-type, .layout05 dl:last-of-type {
    margin-bottom: 0;
}
.layout06 dd h5 {
    letter-spacing: 0;
	line-height: 1.4;
}
.layout06 dt {
    font-size: 16px;
	line-height: 1.4;
}
.layout06 dt em {
    font-size: 26px;
}


/* layout11 */
[class^="layout11_text"] dl dt,
[class^="layout11_text"] dl dd{
    margin-left: 0;
    width: 100%;
}
  [class^="layout11_text"] dl {
    flex-wrap: wrap;
  }
  
[class^="layout11_text"] dl dt{
    margin-bottom: 0;
}
[class^="layout11_text"] dl dd{
    margin-bottom: 10px;
}
.layout11_image02{
    flex-wrap: wrap;
}
.layout11_image02 span{
    width: 100%;
}
.layout11_image02 span:last-child{
    margin-top: 40px;
}
.layout11_image02 span:last-child::before{
    top: -32px;
    bottom: auto;
    left: 0;
    right: 0;
    justify-content: center;
    content: "\f078";
}

  .medical_video video {
    width: 100%;
  }
  
	/*----case----*/
	.top_case_wrap {
		width: 90%;
		padding: 20px 12px;
		}
	.top_case_wrap_inner {
		padding: 20px 12px 30px;
		background: rgba(255,255,255,0.9);
	}
	
/*============================================================================

	$news

============================================================================*/

.top_news {
    padding-top: 30px;
    padding-bottom: 40px;
}
.top_news .box1 {
	margin-bottom: 0;
}
.top_news h3.tit01 {
    float: none;
    width: 160px;
    height: 160px;
	margin-left: auto;
	margin-right: auto;
	background-size: cover;
    padding-top: 74px;
}
.top_news h3.tit01:before {
    top: 32px;
}
h3.tit01 span {
    font-size: 12px;
}
.top_news_flame {
    float: none;
    width: 100%;
    margin-top: 0;
}
.scroll_area{
	height: 120px;
}
.top_news .btn01 {
    margin-top: 14px;
}
.top_news ul li a em {
    float: none;
    width: 100px;
    height: 30px;
    line-height: 30px;
    margin-right: 0;
	margin-bottom: 5px;
	font-size: 14px;
}
.top_news ul li a {
	font-size: 14px;
}
.top_news ul li a span {
    float: none;
    width: 100%;
    padding: 0 0;
	line-height: 1.2;
}

.news.box2 {
	margin-bottom: 0;
}
.date {
    float: none;
    width: 100px;
    height: 32px;
    line-height: 32px;
    margin-right: 0;
	margin-bottom: 8px;
}
.news_text p {
    margin-bottom: 8px;
}
.news_text p strong {
    float: none;
    margin-left: 0;
    font-size: 17px;
    padding-top: 0;
	line-height: 1.5;
}
.news_text .line {
    padding-top: 0;
    margin-bottom: 30px;
}

.case_img > dl {
	width: 49%;
	margin-right: 2%;
	margin-bottom: 20px;
}
.case_img img {
	margin-top: 10px;
}
.case_img dt {
	font-size:16px;
}



}

@media screen and (max-width:320px) {
	
.main_open{
	position: absolute;
	top:auto;
	bottom: 50px;
	right: 0;
	left: 0;
	width: 50%;
	margin: auto;
}

/*============================================================================

	.layout

============================================================================*/

.layout02 dl{
	float:none;
	width:auto;
	height:auto !important;
	margin-right:0;
	padding: 7%;
}
.layout03 dt,
.layout03 dd{
	display:block;
}
.layout03 dt,
.layout03 dd:nth-child(2),
.layout03 dd:nth-child(3){
		width:auto;
}
.layout03 dt{
	padding:2% 20% 2%;
}
.layout03 dt img{
	margin-top:10px;
}
.layout03 dt,
.layout03 dd{
	display:block;
}
.layout03 dd{
	padding:5% 6% 2%;
}
.layout03 dd h5{
	font-size: 16px;
	text-align:center;
}
.layout03 dd h5 span{
	font-size:26px;
}



.layout04 dt,
.layout04 dd{
	display:block;
}
.layout04 dt,
.layout04 dd:nth-child(2),
.layout04 dd:nth-child(3){
		width:auto;
}
.layout04 dt{
	padding:0 15% 2%;
}



.layout05 dt,
.layout05 dd{
	display:block;
}
.layout05 dd{
	padding:5% 6% 2%;
}
.layout05 dd h5{
	font-size:16px;
}
.layout05 dd h5 span{
	font-size:26px;
}

.layout05 dt,
.layout05 dd:nth-child(2),
.layout05 dd:nth-child(3){
		width:auto;
}
.text .layout05 dd p {
	margin-bottom: 0;
}

.layout05 dt{
	padding:6% 15%
}
.layout05 dd:nth-child(3){
	border:none;
}


.layout06 dl:last-child:after {
    border-top: none;
}
.layout06 dt,
.layout06 dd{
	display:block;
}
.layout06 dt{
	line-height:1.5;
	font-size:16px;
	border-left: 1px dashed #B1B1B1;
	border-bottom: 1px dashed #B1B1B1;
}
.layout06 dt em{
	display:block;
	margin-right:0;
	line-height:1;
}
.layout06 dd{
	padding:3% 6% 2%;
}
.layout06 dd h5{
	font-size:15px;
}
.layout06 dd h5 span{
	font-size:26px;
}

.layout06 dt,
.layout06 dd:nth-child(2),
.layout06 dd:nth-child(3){
		width:auto;
}
.layout06 dt{
	padding:6% 15%
}
.layout06 dd:nth-child(3){
	border-left: none;

}

.layout08 dl{
	float:none;
	width:auto;
	height:auto !important;
	margin-right:0;
	padding: 7%;
}
.layout08 dl::before{
	display:none;
}






}
