@charset "utf-8";
/*===============================================================
	
	2016/6/6
	
===============================================================*/

/* 初期化
----------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
	outline: none;
}
blockquote, q {	quotes: none;	}
blockquote:before, blockquote:after,
q:before, q:after {	content: '';	content: none;}
input, textarea { margin: 0;	padding: 0;}
table{	border-collapse: collapse; border-spacing:0;	}
body { font-family:'Hiragino Kaku Gothic Pro','メイリオ','Meiryo','ＭＳ Ｐゴシック',Osaka,sans-serif; }
h1,h2,h3,h4,h5,h6,p,li,th,td,dt,dd { font-size:14px; line-height:22px; }
caption,th,td { text-align:left; vertical-align:top; }
img { vertical-align:top; border:0; }
ul,li { list-style:none; }
option { padding-right:1em; }
address,caption { font-style:normal; font-weight:normal; }
a {	outline:none;	text-decoration:underline; }
a:focus {	outline:none;	}
ul a ,li a {	zoom:1;	}
strong{ font-weight: bold; }
em{ font-style: italic; }

/* HTML5
----------------------------------------------------------------*/
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

/* 文字サイズ、装飾
----------------------------------------------------------------*/
.bold	{	font-weight:bold; }
.cap {
	font-size:12px;
	line-height:15px;
	}		
.red	{	color:#943023;		}
.yellow	{	color:#cbb847;		}
.blue	{	color:#0047a2;		}
.lightblue { color:#00afd7; }
.green	{	color:#5b9000;	}
.brown	{	color:#633;		}
.pink	{	color:#f3c;		}
.gray	{	color:#eaeeed;		}
.deepgray { color:#92999f ;}
.align_center	{	text-align:center;		}
.align_right	{	text-align:right;		}
.replace {	overflow:hidden;	white-space:nowrap;	text-indent:100%;	}

/* フロート関係
----------------------------------------------------------------*/
.clear {
	width:100%;
	overflow:hidden;
}
.clearboth {
	clear:both;
}
.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
  *zoom: 1;
}
.flol {
	float:left;
}
.flor {
	float:right;
}
/* マージン
----------------------------------------------------------------*/
.mt0	{	margin-top:0px !important; }
.mt05	{	margin-top:5px;		}
.mt10	{	margin-top:10px;	}
.mt15	{	margin-top:15px;	}
.mt20	{	margin-top:20px;	}
.mt25	{	margin-top:25px;	}
.mt30	{	margin-top:30px;	}
.mt40	{	margin-top:40px;	}
.mt50	{	margin-top:50px;	}
.mt60	{	margin-top:60px;	}
.mt70	{	margin-top:70px;	}
.mt80	{	margin-top:80px;	}
.mt90	{	margin-top:90px;	}
.mt100	{	margin-top:100px;	}

.mb05	{	margin-bottom:5px;	}
.mb10	{	margin-bottom:10px;	}
.mb15	{	margin-bottom:15px;	}
.mb20	{	margin-bottom:20px;	}
.mb25	{	margin-bottom:25px;	}
.mb30	{	margin-bottom:30px;	}
.mb40	{	margin-bottom:40px;	}
.mb50	{	margin-bottom:50px;	}

/*===============================================================
	
	noto sans
	
===============================================================*/
@font-face {
   font-family: 'Noto Sans JP';
   font-style: normal;
   font-weight: 400;
   /* src: local("Noto Sans CJK JP"),
   	url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype'); */
 }
 
/* @font-face {
   font-family: 'Noto Sans JP';
   font-style: normal;
   font-weight: 700;
   src: url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.otf) format('opentype');
 } */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');

/* html/body設定
----------------------------------------------------------------*/
html {
}
body {
	font-family: 'Noto Sans JP', sans-serif;
	/*font-feature-settings:"pkna";*/
	width: 100%;
	color:#333;
	background:#173887;
	text-align:left;
	font-size:14px;
	line-height:1.6;
	-webkit-text-size-adjust:none; /* 縦横文字サイズ同じ */
	-webkit-font-smoothing: antialiased;
}
a {
	color:#36C;
	-webkit-transition: background-color 0.1s linear, color 0.1s linear, border-color 0.1s linear, border-width 0.1s linear, opacity 0.1s linear;
	-ms-transition: background-color 0.1s linear, color 0.1s linear, border-color 0.1s linear, border-width 0.1s linear, opacity 0.1s linear;  
	-moz-transition: background-color 0.1s linear, color 0.1s linear, border-color 0.1s linear, border-width 0.1s linear, opacity 0.1s linear;
	-o-transition: background-color 0.1s linear, color 0.1s linear, border-color 0.1s linear, border-width 0.1s linear, opacity 0.1s linear;
}
a:hover { color:#39F }

.boxshadow {
	-moz-box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.20);
	-webkit-box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.20);
	box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.20);
}
/* タブレット以下 */
@media screen and (max-width: 960px) {
	
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～640px */
@media only screen and (max-width: 736px) {
	
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	基本文字サイズ
	
===============================================================*/
h2 {
	/*font-size:172%;	/* 24px */
	font-weight:bold;
}
h3 {
	/*font-size:172%;	/* 24px */
	font-weight:bold;
}
h4 {
	/*font-size:115%;	/* 16px */
	line-height:1.4;
	font-weight:bold;
}
p {
	font-size:115%;	/* 14px */
	line-height:1.8;
}
sup {
	margin:0;
	padding:0;
	font-size:12px;
	line-height:15px;
}
/*===============================================================
	
	PC/SP/TABLET
	
===============================================================*/
.sp {
	display:none;
}
.pc {
}
.tablet {
	display:none;
}
.sp {
	display:none;
}
.sp_tablet {
	display:none;
}
.none {
	display:none;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.pc {
	display:none;
}
.tablet,
.pc_tablet,
.sp_tablet {
	display:block;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.sp {
	display:block;
}
.pc_tablet,
.tablet {
	display:none;
}
}	/* for SP max-width: 736px */

/*===============================================================
	
	img fig
	
===============================================================*/
.fig img,
.fitimg img, 
.photo img {
	width:100%;
	height:auto;
}

.fig {
	border:solid 1px #ddd;
}
.content .fig {
	margin-top:30px;
}
.borderimg {
	border:solid 1px #eee;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.content .fig {
	margin-top:15px;
}
}	/* for SP max-width: 736px */

/*===============================================================
	
	レイアウト
	
===============================================================*/
.wrapper {
}
.wide_width_1400 {
	width:auto;
	max-width:1400px;
	margin-left:auto;
	margin-right:auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.wide_width_1300 {
	width:auto;
	max-width:1300px;
	margin-left:auto;
	margin-right:auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.wide_width_1200 {
	width:auto;
	max-width:1200px;
	margin-left:auto;
	margin-right:auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.content_width_1100 {
	width:auto;
	max-width:1100px;
	margin-left:auto;
	margin-right:auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.narrow_width_800 {
	width:auto;
	max-width:800px;
	margin-left:auto;
	margin-right:auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*===============================================================
	
	ヘッダ
	
===============================================================*/
.header_wrp {
	width:100%;
	background:#fff;
	position:relative; 
}
.header {
	width:100%;
	height:80px;
	margin:0 auto;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
	background:#fff; 
   display: flex;
   justify-content: space-between;
}
.header .logo {
	width:260px;
	height:40px;
	padding:30px;
}
.header .logo img {
	width:100%;
	height:auto;
}
.header .description {
	font-size:12px;
	line-height:20px;
	padding:20px 0;
   width: calc(60% - 260px);
}
.header .nav ul li {
	float:left;
	font-size:20px;
	line-height:40px;
	font-weight:bold;
	border-left:1px solid #ddd;
}
.header .nav ul li:last-child {
	border-right:1px solid #ddd;
}
.header .nav ul li a {
	display:block;
	text-decoration:none;
	color:#173887;
	padding:20px 35px;
}
.header .nav ul li a:hover {
	background:#f0f1f3;
}
.header .nav ul li a span {
	display:inline-block;
	vertical-align:middle; 
	color:#333;
	font-size:15px;
	line-height:20px;
	padding-left:10px;
	margin-top:-5px;
}
.header .nav {
   width: 40%;
   float: none;
   display: flex;
   justify-content: end;
}
/* タブレット以下 */
@media screen and (max-width: 1160px) {
.header .logo {
	width:230px;
	height:35px;
	padding:22.5px 15px;
}
.header .nav ul li {
	font-size:15px;
}
.header .nav ul li a {
	padding:20px 12.5px;
}	
.header .nav ul li a span {
	font-size:12px;
	line-height:20px;
	padding-left:5px;
}
.header .description {
   width: calc(70% - 250px);
}
.header .nav {
   width: 30%;
}
}	/* for tablet max-width: 1160px */

/* タブレット以下 */
@media screen and (max-width: 960px) {
.header_wrp {
	height:40px;
}
.header {
	width:100%;
	height:40px;
	position:fixed;
	z-index:500;
	box-shadow:0px 0px 3px rgba(0, 0, 0, 0.20);
	padding:10px;
   justify-content: start;
}
.header .logo {
	width:130px;
	height:20px;
	padding:0;
}
.header .description {
	display:none; 
}
.header .nav {
	display:none;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
}	/* for SP max-width: 736px */

/*===============================================================
	
	navigation
	
===============================================================*/
.navigation_outer {
	width:100%;
	height:60px;
	background:#173887;
}
.navigation_wrp {
	width:100%;
	position:relative;
	z-index:999;
	background:#173887;
}

/* 1400px以下 */
@media screen and (max-width: 1400px) {
.navigation_wrp {
	width:100%;
}
}	/* for tablet max-width: 1400px */

/* タブレット以下 */
@media screen and (max-width: 1160px) {
	
}	/* for tablet max-width: 1160px */

/* タブレット以下 */
@media screen and (max-width: 960px) {
.navigation_outer {
	display:none; 
}
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	navigation	
-------------------------------------------------------------*/
.navigation {
	position:relative;
}
.navigation ul {
	width:100%;
	overflow:hidden;
}
.navigation ul li {
	width:16.6666%;
	float:left;
	border-left:1px solid rgba(255,255,255,0.1);
	-webkit-box-sizing:border-box; 
	box-sizing:border-box;
}
.navigation ul li:last-child {
	border-right:1px solid rgba(255,255,255,0.1);
}
.navigation ul li a {
	display:block;
	color:#fff;
	font-size:18px;
	line-height:60px;
	text-align:center;
	text-decoration:none;
	transition:all .3s;
}
.navigation ul li.current > a {
	background:#1b46ac;
}
.navigation ul li a:hover,
.navigation ul li.active a,
.navigation ul li.active a:hover {
	color:#173887;
	font-weight:bold; 
	background:#f0f1f3;
}

.navigation ul li .subnav {
	display:none;
	position:absolute;
	top:60px;
	left:0;
	width:100%;
	padding:30px;
	background:#f0f1f3;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	box-shadow:0px 2px 3px 0px rgba(0, 0, 0, 0.10);
}
.navigation ul li .subnav ul {
	width:auto;
	max-width:1100px;
	margin:0 auto;
}
.navigation ul li .subnav li {
	width:25%;
	float:left;
}
.navigation ul li .subnav li a {
	position:relative;
	text-align:left;
	padding-left:20px;
	font-size:17px;
	line-height:40px;
	color:#173887;
	border-bottom:solid 2px #f0f1f3;
}
.navigation ul li .subnav li a:hover {
	/*font-weight:normal;*/
	/*text-decoration:underline;  */
	border-bottom:solid 2px #173887;
}
.navigation ul li .subnav li a:after {
	position:absolute;
	content:" ";
	width:7px; height:7px;
	top:0; bottom:0; left:0; right:auto;
	margin:auto;
	border-top:solid 1px #173887;
	border-left:solid 1px #173887;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
/* タブレット以下 */
@media screen and (max-width: 1160px) {
.navigation ul li a {
	font-size:15px;
}
.navigation ul li .subnav li a {
	padding-left:15px;
	font-size:15px;
}
.navigation ul li .subnav li a:after {
	width:5px; height:5px;
}	

}	/* for tablet max-width: 1160px */


/* タブレット以下 */
@media screen and (max-width: 960px) {
.navigation_wrp .navigation {
	display:none;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */
/*-------------------------------------------------------------
	subnav	
-------------------------------------------------------------*/
.subnav .icon {
	margin-left:5px;
	font-weight:bold;
}
.navigation_wrp .subnav .icon {
	color:#6d6886;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*===============================================================
	
	フッタ
	
===============================================================*/
.footer_wrp {	
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.footer_sitemap
-------------------------------------------------------------*/
.footer_sitemap_wrp {
	width:100%;
	background:#fff;
	padding:50px 0;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
}
.footer_sitemap {
	text-align:left;
}
.footer_sitemap a {
	text-decoration:none;
	color:#333;
}
.footer_sitemap a:hover {
	text-decoration:underline;
}
.footer_sitemap .blank_link a {
	background-repeat:no-repeat;
	background-image:url(../images/asset/icon-blank-pc.gif);
	background-position:right -3px;
	padding-right:20px;
}
.footer_sitemap ul {
	width:20%;
	float:left;
}
.footer_sitemap ul > li {
	font-size:15px;
	line-height:25px;
	font-weight:500;
}
.footer_sitemap ul > li + li {
	margin-top:40px;
}
.footer_sitemap ul li ul {
	width:100%;
	float:none;
	padding-top:5px
}
.footer_sitemap ul li ul li {
	font-size:13px;
	line-height:20px;
	font-weight:normal;
	margin-top:10px;
}
.footer_sitemap ul li ul.half {
	width:50%;
	float:left;
}


.footer_sitemap_wrp .menubtn {
	display:none;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.footer_sitemap_wrp {
	padding:50px 20px;
}

}	/* for tablet max-width: 1160px */

/* タブレット以下 */
@media screen and (max-width: 960px) {
.footer_sitemap {
	display:none;
}
.footer_sitemap_wrp .menubtn {
	display:block;
}
.footer_sitemap_wrp .menubtn a {
	display:block;
	border:solid 1px #bfbfbf;
	width:100px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	margin:0 auto;
	color:#333;
	font-size:14px;
	line-height:35px;
	text-align:center;
	text-decoration:none;
}

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.footer_sitemap_wrp {
	padding:15px 10px;
}		

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	footer_txt_wrp	
-------------------------------------------------------------*/
.footer_txt_wrp {
	color:#fff;
	width:100%;
	background:#173887;
	padding:50px 0;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
}
.footer {
	position:relative;
}
.footer .address .logo {
	width:175px;
	height:25px;
}
.footer .address .logo img {
	width:100%;
	height:auto;
}
.footer .address p {
	font-size:13px;
	line-height:20px;
	margin-top:20px;
}
.footer .address p a {
	color:#fff;
	text-decoration:none; 
}
.footer .address p a:hover {
	text-decoration:underline; 
}
.footer .copyright {
	position:absolute;
	bottom:0;
	right:0;
	font-size:13px;
	line-height:20px;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.footer_txt_wrp {
	padding:50px 20px;
}
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.footer_txt_wrp {
	padding:15px 10px;
	text-align:center; 
}
.footer .address .logo {
	width:115px;
	height:15px;
	margin:0 auto; 
}
.footer .address p {
	font-size:12px;
	line-height:18px;
	margin-top:10px;
}
.footer .copyright {
	position:static;
	font-size:12px;
	line-height:18px;
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	MENU
	
===============================================================*/

/* タブレット以下 */
@media screen and (max-width: 960px) {
.menu_bg {
	background:#173887;
	position:absolute;
	z-index:300;
	top:0;
	left:0;
}
.menu_icon {
	position:absolute;
	position:fixed;
	top:10px;
	right:10px;
	z-index:300;
}
.menu .menu_nav {
	background:#173887;
	position:absolute;
	top:40px;
	width:100%;
	z-index:300;
}
.menu .navlist {
	width:100%;
	overflow:hidden;
}
.menu .navlist li a {
	position:relative;
	width:100%;
	display:block;
	border-top:solid 1px rgba(255,255,255,0.05);
	font-size:14px;
	line-height:40px;
	text-decoration:none;
	padding:0 20px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	color:#fff;
}	
.menu .navlist li.head > a:before,
.menu .navlist li.head > a:after {
	content:"";
	position:absolute;
	top:0;
	bottom:0;
	right:15px;
	margin:auto;
	width:25px;
	height:1px;
	background:#e0e2e7;
}	
.menu .navlist li.head a:after {
	-webkit-transition:all .1s linear; 
	-moz-transition:all .1s linear; 
	-ms-transition:all .1s linear; 
	transition:all .1s linear; 
	-webkit-transform:rotate(90deg); 
	-moz-transform:rotate(90deg); 
	-ms-transform:rotate(90deg); 
	transform:rotate(90deg);
}	
.menu .navlist li.head.active > a:after {
	-webkit-transform:rotate(0deg); 
	-moz-transform:rotate(0deg); 
	-ms-transform:rotate(0deg); 
	transform:rotate(0deg); 
}	

.menu .navlist li.head:nth-child(1) a:after {
	width:12px; height:12px;
	background:none;
	top:0; bottom:0; left:auto; right:24px;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.menu .navlist li.head:nth-child(1) a:before {
	background:none;
}

/*
.menu .navlist li a:after {
	position:absolute;
	content:" ";
	width:12px; height:12px;
	top:0; bottom:0; left:auto; right:18px;
	margin:auto;
	border-top:solid 2px #fff;
	border-left:solid 2px #fff;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
*/
.menu .navlist li .subnav li a {
	font-weight:normal;
	font-size:14px;
	line-height:40px;
	padding:0 20px;
	color:#173887;
	background:#fff;
	border-bottom:solid 1px rgba(0,0,0,0.1);
}
.menu .navlist li .subnav li a:after {
	width:10px; height:10px;
	top:0; bottom:0; left:auto; right:20px;
	margin:auto;
	border-top:solid 1px #999;
	border-left:solid 1px #999;
}
.menu .closebtn {
	border-top:solid 1px rgba(255,255,255,0.05);
	padding:30px 0;
}
.menu .closebtn a {
	display:block;
	border:solid 1px #f0f1f3;
	width:100px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	margin:0 auto;
	color:#f0f1f3;
	font-size:14px;
	line-height:35px;
	text-align:center;
	text-decoration:none;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	menu-trigger
-------------------------------------------------------------*/
/* タブレット以下 */
@media screen and (max-width: 960px) {
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .3s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 30px;
	height: 20px;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #173887;
	border-radius: 2px;
}
.menu-trigger span:nth-of-type(1) {
	top: 0;
}
.menu-trigger span:nth-of-type(2) {
	top: 10px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 0;
}
/* animation */
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(10px) rotate(-45deg);
	-moz-transform: translateY(10px) rotate(-45deg);
	-ms-transform: translateY(10px) rotate(-45deg);
	transform: translateY(10px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
	-webkit-transform: translateY(0) rotate(180deg);
	-moz-transform: translateY(0) rotate(45deg);
	-ms-transform: translateY(0) rotate(45deg);
	transform: translateY(0) rotate(45deg);
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-10px) rotate(45deg);
	-moz-transform: translateY(-10px) rotate(45deg);
	-ms-transform: translateY(-10px) rotate(45deg);
	transform: translateY(-10px) rotate(45deg);
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*===============================================================
	
	grid
	
===============================================================*/
.gridconatiner {
	margin-top:-50px;
}
.gridconatiner_mt {
	margin-top:-20px;
}
.gridconatiner .grid {
	float:left;
}
.gridconatiner .grid_flor {
	float:right;
}
.grid {
	margin-top:50px;
}

/* ------------------------------------------------ */
/*	gridSize :530 gutterSize :40 column :2 */
/* ------------------------------------------------ */
.gridwrp_2 { width:103.636%;}
.gridwrp_2 .grid_2 { width:96.491%; margin-right:3.509%; }
.gridwrp_2 .grid_1 { width:46.491%; margin-right:3.509%; }
.gridwrp_2 .grid:nth-child(2n+1) {
	clear:both;
}

/* ------------------------------------------------ */
/*	gridSize :340 gutterSize :40 column :3 */
/* ------------------------------------------------ */
.gridwrp_3 { width:103.636%;}
.gridwrp_3 .grid_3 { width:96.491%; margin-right:3.509%; }
.gridwrp_3 .grid_2 { width:63.158%; margin-right:3.509%; }
.gridwrp_3 .grid_1 { width:29.824%; margin-right:3.509%; }
.gridwrp_3 .grid:nth-child(3n+1) {
	clear:both;
}

/* ------------------------------------------------ */
/*	gridSize :245 gutterSize :40 column :4 */
/* ------------------------------------------------ */
.gridwrp_4 { width:103.636%;}
.gridwrp_4 .grid_4 { width:96.491%; margin-right:3.509%; }
.gridwrp_4 .grid_3 { width:71.491%; margin-right:3.509%; }
.gridwrp_4 .grid_2 { width:46.491%; margin-right:3.509%; }
.gridwrp_4 .grid_1 { width:21.491%; margin-right:3.509%; }
.gridwrp_4 .grid:nth-child(4n+1) {
	clear:both;
}

.column + .gridconatiner {
	margin-top:-20px;
} 

/* タブレット以下 */
@media screen and (max-width: 1160px) {

}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.gridconatiner {
	margin-top:-10px;
}
.gridconatiner_mt {
	margin-top:0;
}	
.gridwrp_3,
.gridwrp_3 .grid_2,	
.gridwrp_3 .grid_1,
.gridwrp_2,
.gridwrp_2 .grid_1 {
	width:100%; margin-right:0;
}
.gridwrp_4 { width:105.000%;}
.gridwrp_4 .grid_1 { width:45.238%; margin-right:4.762%; }

.grid {
	margin-top:15px;
}
.grid:first-child {
	/*margin-top:0px;*/
}
.gridwrp_4 .grid:nth-child(2) {
	/*margin-top:0;*/
}

.sp_gridwrp2 .gridwrp_3 { width:105.319%;}
.sp_gridwrp2 .gridwrp_3 .grid_2 { width:94.949%; margin-right:5.051%; }
.sp_gridwrp2 .gridwrp_3 .grid_1 { width:44.949%; margin-right:5.051%; }
.sp_gridwrp2 .gridwrp_3 .grid:nth-child(2n+1),
.gridwrp_4 .grid:nth-child(2n+1) {
	clear:both;
}
.sp_gridwrp2 .gridwrp_3 .grid:nth-child(3n+1) {
	clear:none;
}
.sp_gridwrp2 .gridwrp_2 { width:105.319%;}
.sp_gridwrp2 .gridwrp_2 .grid_2 { width:94.949%; margin-right:5.051%; }
.sp_gridwrp2 .gridwrp_2 .grid_1 { width:44.949%; margin-right:5.051%; }
.sp_gridwrp2 .gridwrp_2 .grid:nth-child(2n+1) {
	clear:both;
}
.sp_gridwrp2 .gridwrp_2 .grid:nth-child(3n+1) {
	clear:none;
}
.sp_gridwrp2 .linkarea p {
	padding: 0;
}
.column + .gridconatiner {
	margin-top:0;
} 
}	/* for SP max-width: 736px */

/*===============================================================
	
	fixed
	
===============================================================*/
.fixed {
	position: fixed;
	top: 0;
}
.bg_fixed {
	background-attachment: fixed;
}
/* タブレット以下 */
@media screen and (max-width: 940px) {
.fixed {
	position: fixed;
	top: 0;
}
}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*===============================================================
	
	PAGETOP
	
===============================================================*/
#btn_pagetop {
	width:100%;
	overflow:hidden;
}
#btn_pagetop a {
	display:block;
	position:fixed;
	right:-300px; top:0;
	width:50px; height:50px;
	color:#fff;
	background-color:#d2191a;
	text-indent:100%;
	overflow:hidden;
	white-space:nowrap;
	z-index:101;
	border-radius:30px;
}
#btn_pagetop a:hover {
	background-color:#c00;
}
#btn_pagetop a:after {
	position:absolute;
	content:" ";
	width:14px; height:14px;
	top:20px; left:0; right:0; bottom:auto;
	margin:auto;
	border-top:solid 2px #fff;
	border-left:solid 2px #fff;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	border-radius:2px;
}

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
#btn_pagetop a {
	width:40px;
	height:40px;
	background-size:40px 40px;
}
#btn_pagetop a:after {
	width:12px; height:12px;
	top:17px; left:0; right:0; bottom:auto;
}
}	/* for SP max-width: 736px */


/*===============================================================
	
	フォーム
	
===============================================================*/
.form {
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*===============================================================
	
	btn_detail
	
===============================================================*/
.btn_detail {
	width:auto;
	max-width:400px;
	margin:0 auto;
	margin-top:50px;
	box-shadow: 5px 5px 10px 0 rgba(0,0,0,0.1);;
}
.btn_detail a {
	position:relative;
	text-decoration:none;
	display:block;
	background-color:#173887;
	text-align:center;
	color:#fff;
	font-size:15px;
	line-height:20px;
	padding:20px 0;
}
.btn_detail a:after {
	position:absolute;
	content:"";
	width:7px; height:7px;
	top:0; left:auto; bottom:0; right:10px;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}
.btn_detail.arw_prev a:after {
	position:absolute;
	content:"";
	width:7px; height:7px;
	top:0; left:10px; bottom:0; right:auto;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform:rotate(-45deg);
	-moz-transform:rotate(-45deg);
	-ms-transform:rotate(-45deg);
	transform:rotate(-45deg);
}
.btn_detail a:hover {
	text-decoration:none;
	background-color:#1b46ac;
}
.btn_detail.btn_back a:after {
	right:auto;
	left:10px;
	-webkit-transform:rotate(-45deg);
	-moz-transform:rotate(-45deg);
	-ms-transform:rotate(-45deg);
	transform:rotate(-45deg);
}
.btn_detail_pdf a {
	padding:12.5px 0;
}
.btn_detail_pdf a {
	background-image:url(../images/asset/icon_pdf.png);
	background-repeat:no-repeat;
	background-size:25px 30px;
	background-position:center right 10px;
}
.btn_detail_pdf a:after {
	display:none; 
}
.btn_detail_pdf a span {
	display:block; 
	font-size:12px;
	line-height:15px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.btn_detail {
	width:95%;
	max-width:95%;
	margin:0 auto;
	margin-top:10px;
}
.btn_detail a {
	font-size:13px;
	padding:10px 0;
}
.btn_detail a:after {
	width:5px; height:5px;
}
.btn_detail_pdf a {
	padding:10px 0;
	background-size:20px 24px;
	background-position:center right 10px;
}
.btn_detail_pdf a span {
	font-size:10px;
	line-height:12.5px;
}	
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	btns_2
	
===============================================================*/
.btns_2 {
	margin-top:-50px;
}
.btns_2 .item {
	float:left;
	width:47.5%;
	margin-right:5%;
}
.btns_2 .item:nth-child(even) {
	margin-right:0;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.btns_2 .item {
	float:left;
	width:48%;
	margin-right:4%;
}

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.btns_2 {
	margin-top:-20px;
}		
.btns_2 .item {
	width:100%;
	margin-right:0;
}
.btns_2 .item + .item .btn_detail {
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	btn_pdf
	
===============================================================*/
.btn_pdf {
	width:auto;
	max-width:900px;
	padding:40px;
	margin:0 auto;
	background:#ebf1ff;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
}
.btn_pdf .txt {
	float:left;
	width:48%;
	margin-right:4%;
}
.btn_pdf .txt .normal_p {
	color:#173887;
	font-weight:500;
}
.btn_pdf .btn {
	float:right;
	width:48%;
}
.btn_pdf .btn .btn_detail {
	margin-top:0;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.btn_pdf {
	padding:30px;
}
.btn_pdf .txt {
	text-align:center; 
	float:none;
	width:100%;
	margin-right:0;
}
.btn_pdf .btn {
	float:none;
	width:100%;
	margin-top:20px;
}

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.btn_pdf {
	padding:10px;
}
.btn_pdf .txt {
	text-align:left; 
}
.btn_pdf .btn {
	margin-top:10px;
}
.btn_pdf .btn .btn_detail {
	width:100%;
	max-width:100%;
}	
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	btns_4
	
===============================================================*/
.btns_4 {
	margin-top:-50px;
}
.btns_4 .item {
	float:left;
	width:22.3%;
	margin-right:3.6%;
}
.btns_4 .item:nth-child(4) {
	margin-right:0;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.btns_4 .item {
	float:left;
	width:48%;
	margin-right:4%;
}
.btns_4 .item:nth-child(3) .btn_detail,
.btns_4 .item:nth-child(4) .btn_detail {
	margin-top:20px;
}
.btns_4 .item:nth-child(even) {
	margin-right:0;
}

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.btns_4 {
	margin-top:-20px;
}	
.btns_4 .item {
	width:100%;
	margin-right:0;
}
.btns_4 .item + .item .btn_detail {
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	背景
	
===============================================================*/
.bg_graytile {
	background-image:url(../images/asset/bg_graytile.jpg);
	background-position:top center;
	background-repeat:repeat;
}
.bg_bordertop {
	border-top:1px solid #ddd;
}
.bg_borderbottom {
	border-bottom:1px solid #ddd;
}

/*===============================================================
	
	seciton
	headlineとcontentなど、複数の要素、機能を取りまとめるコンテナ的な親要素。
	幅はsection_innerに記述する
	
===============================================================*/
.section_wrp {
	background:#fff; 
}
.section {
	width:100%;
}
.section_inner {
	margin:0 auto;
	padding:50px 0 90px;
}
.section_inner2 {
	margin:0 auto;
	padding:50px 0 50px;
}
.section_inner3 {
	margin:0 auto;
	padding:30px 0 30px;
}

/* タブレット以下 */
@media screen and (max-width: 1300px) {
.section_inner {
	margin:0 auto;
	padding:50px 20px 90px;
}
.section_inner2 {
	margin:0 auto;
	padding:50px 20px 50px;
}	
.section_inner3 {
	margin:0 auto;
	padding:30px 20px;
}		
}	/* for tablet max-width: 1300px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_inner,
.section_inner2 {
	margin:0 auto;
	padding:20px;
	padding-bottom:40px;
}		
.section_inner3 {
	padding:20px;
}		
	
}	/* for SP max-width: 736px */
/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.section_inner,
.section_inner2 {
	padding:20px 10px;
	padding-bottom:30px;
}	
.section_inner3 {
	padding:20px 10px;
}	
}	/* for SP max-width: 320px */


/*===============================================================
	
	content 
	個別のコンテンツ
	
===============================================================*/
.content {
}
.headline + .content {
	padding-top:40px;
}
.content + .content {
	padding-top:60px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.content {
	width:100%;
	margin:0 auto;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.content {
	width:100%;
	margin:0 auto;
}
.headline + .content {
	padding-top:20px;
}
.content + .content {
	padding-top:30px;
}
}	/* for SP max-width: 736px */


/*===============================================================
	
	txtlink 2016/11/16
	
===============================================================*/
.txtlink a {
	padding-left:15px;
	color:#333;
	text-decoration:none;
	position:relative;
	display:inline-block;
}
.txtlink a:hover {
	text-decoration:underline; 
}
.txtlink a:after {
	position:absolute;
	content:" ";
	width:7px; height:7px;
	top:0; bottom:0; left:0; right:auto;
	margin:auto;
	border-top:solid 1px #333;
	border-left:solid 1px #333;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.txtlink.arw_prev a {
}
.txtlink.arw_prev a:after {
	top:0; bottom:0; left:0; right:auto;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.txtlink.arw_after a {
	padding-left:0;
	padding-right:15px;
}
.txtlink.arw_after a:after {
	left:auto; right:2px;
}
.txtlink.arw_down a:after {
	top:0; bottom:0; left:0; right:auto;
	-webkit-transform: rotate(-135deg);
	-moz-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
.txtlink.arw_after_down a {
	padding-left:0;
	padding-right:10px;
}
.txtlink.arw_after_down a:after {
	top:0; bottom:0; left:auto; right:0;
	-webkit-transform: rotate(-135deg);
	-moz-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
/*	arw_box */
.txtlink.arw_box a {
	padding-left:25px;
}
.txtlink.arw_box a:before {
	content:' ';
	width:20px;
	height:20px;
	background:#333;
	position:absolute;
	top:2px; bottom:auto; left:0; right:auto; margin:auto;
}
.txtlink.arw_box a:after {
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	top:8px; bottom:auto; left:5px; right:auto;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.txtlink a {
	padding-left:10px;
}	
.txtlink a:after {
	width:5px; height:5px;
}
.txtlink.arw_after a {
	padding-right:10px;
}	

	
}	/* for SP max-width: 736px */

/*===============================================================
	
	modal 2016/10/11
		
===============================================================*/
.modal_bg {
	position:absolute;
	top:0;
	left:0;
	background:#000;
	display:none;
	z-index:9998;
}
.modal {
	position:absolute;
	top:0;
	left:0;
	width:800px;
	display:none;
	z-index:9999;
	
	transition:top 0.2s linear,left 0.1s linear;
	-moz-transition:top 0.2s linear,left 0.1s linear;
	-ms-transition:top 0.2s linear,left 0.1s linear;
	-o-transition:top 0.2s linear,left 0.1s linear;
	-webkit-transition:top 0.2s linear,left 0.1s linear;
}
.modal .close {
	position:absolute;
	width:30px; height:30px;
	top:0; right:0;
	text-indent:100%;
	overflow:hidden;
	white-space:nowrap;
	cursor:pointer;
	z-index:9999;
}
.modal .close:before {
	content:" ";
	position:absolute;
	width:30px; height:2px;
	background:#fff;
	top:10px; right:0;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}
.modal .close:after {
	content:" ";
	position:absolute;
	width:30px; height:2px;
	background:#fff;
	top:10px; right:0;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.modal .close:hover {
	opacity:0.7;
}
.modal .modal_container {
	padding:0;
	position:relative;
}
.modal .modal_contents_wrp {
	position: relative;
	padding:40px;
	width: 100%;
	height: 100%;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.modal .modal_inner {
	padding:30px;
}
.modal .modal_contents_wrp::-webkit-scrollbar {
  display: none;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.modal {
	width:100%;
}
.modal .modal_container {
}
.modal .close {
	top:5px; right:0px;
}

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.modal .modal_pager
-------------------------------------------------------------*/
.modal .modal_pager li a {
	position:absolute;
	top:0; bottom:0;
	margin:auto;
	display:block;
	width:30px;
	height:30px;
	white-space:nowrap;
	text-indent:100%;
	overflow:hidden;
}
.modal .modal_pager li a:after {
	position:absolute;
	content:" ";
	width:15px; height:15px;
	top:6px; left:0;
	border-top:solid 2px #fff;
	border-left:solid 2px #fff;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.modal .modal_pager li.prev a {
	left:0;
	-webkit-transform: rotate(-180deg);
	-moz-transform: rotate(-180deg);
	-ms-transform: rotate(-180deg);
	transform: rotate(-180deg);
}
.modal .modal_pager li.next a {
	right:0;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*-------------------------------------------------------------
	.modal_container
-------------------------------------------------------------*/
.modal .modal_container .modal_header {
}
.modal .modal_container .modal_header h3 {
	font-size:25px;
	line-height:50px;
	text-align:center;
	font-weight:bold;
	text-shadow:none;
}
.modal .modal_container .modal_header p {
	font-size:14px;
	line-height:20px;
	text-align:center;
	font-weight:bold;
}
.modal .btn {
	width:560px;
	margin:0 auto;
	margin-top:40px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

.modal .modal_container .modal_header h3 {
	font-size:20px;
	line-height:25px;
	padding-top:5px;
}
.modal .btn {
	width:100%;
	margin:0 auto;
	margin-top:40px;
}
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.modal_container .btn
-------------------------------------------------------------*/
.modal_container .btn {
	width:450px;
	margin:0 auto;
	margin-top:30px;
}
.modal_container .btn a {
	position:relative;
	display:block;
	background-color:#e63412;
	text-align:center;
	color:#fff;
	font-size:18px;
	line-height:20px;
	font-weight:bold;
	padding:20px 0;
	border-radius:5px;
	-webkit-box-shadow:rgba(0, 0, 0, 0.2) 0px 3px 0px 0px;
	-moz-box-shadow:rgba(0, 0, 0, 0.2) 0px 3px 0px 0px;
	box-shadow:rgba(0, 0, 0, 0.2) 0px 3px 0px 0px;
	text-decoration:none;
}
.modal_container .btn a:hover {
	text-decoration:none;
	background-color:#ff6600;
}
.modal_container .btn a:after {
	position:absolute;
	content:" ";
	width:13px; height:13px;
	top:0; left:auto; bottom:0; right:10px;
	margin:auto;
	border-top:solid 2px #fff;
	border-left:solid 2px #fff;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.modal_container .btn {
	width:100%;
	margin:0 auto;
	margin-top:15px;
}
.modal_container .btn a {
	font-size:16px;
}
}	/* for SP max-width: 736px */
/*-------------------------------------------------------------
	nodata	
-------------------------------------------------------------*/
.modal .nodata {
	padding:50px 15px;
	text-align:center;
}
.modal .nodata h3 {
	font-size:16px;
	color:#fff;
}
.modal .closebtn a {
	display:block;
	width:120px;
	margin:0 auto;
	line-height:30px;
	border:solid 1px #fff;
	text-align:center;
	margin-top:20px;
	color:#fff;
}
.modal_gamedetail .closebtn a:hover {
	color:#000;
	background:#fff;
	text-decoration:none;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.modal .close {
	top:30px;
	right:0px;
}
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	モーダル制作時の確認用
-------------------------------------------------------------*/
.modal {
	/*display:block;*/
}
.modal_demo1 .modal_inner,
.modal_demo2 .modal_inner {
	color:#fff;
	background:#333;
	padding:30px;
}

/*===============================================================
	
	電話番号リンクPC解除
	
===============================================================*/

a[href^="tel:"] {
	cursor:default !important;
}
a[href^="tel:"]:hover {
	text-decoration:none !important;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*===============================================================
	
	top_attention
	
===============================================================*/
.top_attention {
	padding:10px;
	background:#87173c;
}
.top_attention p {
	color:#fff;
	text-align:center;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	.mainvisual　メインビジュアル
	
===============================================================*/

/*===============================================================
	
	.carousel_slider .slider
	
===============================================================*/
.carousel_slider .slider {
	position:relative;
	background:#fff;
}
.carousel_slider .slider .slide {
	width:100%;
	position:relative;
}
.carousel_slider .slider .owl-controls {
	display:none;
}
/*
.carousel_slider .owl-stage-outer .owl-item:not(.center):after {
	content:"";
	width:100%;
	height:100%;
	background:rgba(255,255,255,0.5);
	position:absolute;
	top:0;
	bottom:0;
}
*/

/* タブレット以下 */
@media screen and (max-width: 1400px) {
.carousel_slider .slider .slide {
	width:100% !important;
}
}	/* for tablet max-width: 1400px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.carousel_slider .slider .slide ,
.carousel_slider .slider .slide:nth-child(even) {
	float:none;
	width:100%;
}
.carousel_slider .slider .slide img {
	width:100%;
}
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.carousel_slider .slider .pager
-------------------------------------------------------------*/
.carousel_slider .slider .pager {
	display:none; 
	position:absolute;
	top:0;
	bottom:0;
	margin:auto;
	width:50px;
	height:50px;
	z-index:1000;
}
.carousel_slider .slider .prev {
	left:10px;
}
.carousel_slider .slider .next {
	right:10px;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.carousel_slider .slider .pager a
-------------------------------------------------------------*/
.carousel_slider .slider .pager a {
	display:block;
	width:50px;
	height:50px;
	border:solid 1px #fff;
	border-radius:50% 50%;
	overflow:hidden;
	text-indent:-200%;
	position:relative;
}
.carousel_slider .slider .pager a:hover {
	background:rgba(255,255,255,0.3);
}
.carousel_slider .slider .pager a:after {
	content:'';
	position:absolute;
	top:0; bottom:0; left:0; right:0; margin:auto;
	border-right:solid 1px #fff;
	border-bottom:solid 1px #fff;
	width:12px;
	height:12px;
	-webkit-transform: rotate(-45deg) translate(-2px,-2px);
	-moz-transform: rotate(-45deg) translate(-2px,-2px);
	-ms-transform: rotate(-45deg) translate(-2px,-2px);
	transform: rotate(-45deg) translate(-2px,-2px);
	transition: all .3s;
}
.carousel_slider .slider .prev a:after {
	-webkit-transform: rotate(135deg) translate(-2px,-2px);
	-moz-transform: rotate(135deg) translate(-2px,-2px);
	-ms-transform: rotate(135deg) translate(-2px,-2px);
	transform: rotate(135deg) translate(-2px,-2px);
}
.carousel_slider .slider .pager a:hover:after {
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */


/*-------------------------------------------------------------
	.carousel_slider .slider .slide .photo
-------------------------------------------------------------*/
.carousel_slider .slider .slide .photo img {
	width: inherit;
	max-width: 100%;
	min-width: 100%;
	height: auto;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.carousel_slider .slider .slide .txt
-------------------------------------------------------------*/
.carousel_slider .slider .slide .txt {
	position:absolute;
	width:400px;
	height:160px;
	top:0; bottom:0; left:0; right:0; margin:auto;
	text-align:center;
	background:rgba(0,0,0,0.5);
	padding:20px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.carousel_slider .slider .slide .txt h3 {
	font-size:25px;
	line-height:30px;
}
.carousel_slider .slider .slide .txt .btn {
	width:200px;
	margin:0 auto;
	margin-top:20px;
}
.carousel_slider .slider .slide .txt .btn a {
	display:block;
	font-size:16px;
	line-height:20px;
	padding:10px 0;
	text-align:center;
	color:#fff;
	text-decoration:none;
	border:solid 3px #fff;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.carousel_slider .slider .slide .txt .btn a:hover {
	background:#fff;
	color:#000;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.carousel_slider .owl-stage-outer .owl-item
-------------------------------------------------------------*/
.carousel_slider .owl-stage-outer .owl-item,
.carousel_slider .owl-stage-outer .active + .active {
	opacity:0.7;
	transition:opacity 0.5s, filter 0.5s;
	/*filter: blur(20px);
	-webkit-filter: blur(20px);
  	-ms-filter: blur(20px);*/
	
	
	/*-webkit-filter: saturate(20%);*/
	z-index:-1;
	opacity:0.7;
}
.carousel_slider .owl-stage-outer .active {
	opacity:1;
	transition:opacity 1s, filter 1s;
	filter: blur(0);
	-webkit-filter: blur(0);
  	-ms-filter: blur(0);
	z-index:1;
	opacity:1;
}


/*===============================================================
	
	bg
	
===============================================================*/
.bg_gray {
	background:#f0f1f3;
}


/*===============================================================
	
	トップページ
	
===============================================================*/

/*===============================================================
	
	section_top_catch　キャッチ部分
	
===============================================================*/
.section_top_catch {
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	catch	
-------------------------------------------------------------*/
.section_top_catch .catch {
	position:relative;
	z-index:100;
	width:50%;
	padding:40px;
	margin-top:-100px;
	background:#fff; 
	box-shadow:5px 5px 10px rgba(0,0,0,0.1);
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
}
.section_top_catch .catch:before {
	content:"";
	position:absolute;
	top:-10px;
	left:-10px;
	width:30px;
	height:30px;
	background:#ffcc33;
}
.section_top_catch .catch:after {
	content:"";
	position:absolute;
	top:20px;
	left:20px;
	width:10px;
	height:10px;
	background:#ffcc33;
}
.section_top_catch h2 {
	color:#173887;
	font-size:30px;
	line-height:1;
	position: relative;
}
.section_top_catch h2 .advanced {
	position:absolute;
	display: block;
	top: 0; bottom: 0; right: 0;
	margin: auto;
	font-size: 16px;
	line-height: 26px;
	border: solid 1px #ffcc33;
	padding: 0 10px;
	vertical-align: top;
	background: #ffcc33;
}
.section_top_catch p {
	font-size:16px;
	line-height:2.2;
	margin-top:15px;
}
.section_top_catch p a {
	color:#333;
	text-decoration:underline;
}
.section_top_catch p a:hover {
	color:#ffcc33;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.section_top_catch .catch {
	position:relative;
	z-index:100;
	width:100%;
	padding:30px;
	margin-top:-50px;
}
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_catch .catch {
	padding:20px;
	margin-top:-30px;
	box-shadow:3px 3px 6px rgba(0,0,0,0.1);
}
.section_top_catch .catch:before {
	top:-5px;
	left:-5px;
	width:15px;
	height:15px;
}
.section_top_catch .catch:after {
	top:10px;
	left:10px;
	width:5px;
	height:5px;
}
.section_top_catch h2 {
	font-size:20px;
}
.section_top_catch h2 .advanced {
	position:static;
	display: inline-block;
	font-size: 14px;
	line-height: 16px;
	padding: 2px 10px;
	margin-bottom: 10px;
}
.section_top_catch p {
	font-size:14px;
	line-height:1.8;
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	link	
-------------------------------------------------------------*/
.section_top_catch .link {
	width:47.5%;
	margin-top:-10px;
}
.section_top_catch .link li {
	float:left;
	width:49%;
	font-size:16px;
	line-height:20px;
	margin-top:10px;
}
.section_top_catch .link li:nth-child(odd) {
	margin-right:2%;
}
.section_top_catch .link li a {
	position:relative; 
	display:block; 
	color:#173887;
	text-decoration:none; 
	padding:19px;
	background:#fff; 
	box-shadow: 5px 5px 10px 0 rgba(0,0,0,0.1);
	border: solid 1px #fff;
	box-sizing: border-box;
}
.section_top_catch .link li a:after {
	position:absolute;
	content:"";
	width:7px;
	height:7px;
	top:0;
	bottom:0;
	right:10px;
	margin:auto;
	border-top:solid 1px #173887;
	border-left:solid 1px #173887;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}
.section_top_catch .link li a:hover {
	border: solid 1px #1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.section_top_catch .link {
	width:100%;
	padding-top:10px;
	margin-top:0;
}
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_catch .link {
	padding-top:5px;
}
.section_top_catch .link li {
	float:left;
	width:49%;
	font-size:14px;
	line-height:20px;
	margin-top:5px;
}
.section_top_catch .link li a {
	padding: 12px 7.5px;
}
.section_top_catch .link li a:after {
	width:5px;
	height:5px;
	right:5px;
}
}	/* for SP max-width: 736px */

/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.section_top_catch .link li {
	font-size:12px;
	line-height:15px;
}
}	/* for SP max-width: 320px */


/*===============================================================
	
	section_top_twolink　２分割のリンク
	
===============================================================*/
.section_top_twolink {

}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	items	
-------------------------------------------------------------*/
.section_top_twolink .items {
	display:table;
	table-layout:fixed;
	width:100%;
}
.section_top_twolink .item {
	display:table-cell;
	width:50%;
	color:#fff;
	padding:50px;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box;
}
.section_top_twolink .item.item_blue {
	background:url(../images/top/bg_blue.jpg) no-repeat center center;
	background-size:cover;
}
.section_top_twolink .item.item_green {
	background:url(../images/top/bg_green.jpg) no-repeat center center;
	background-size:cover;
}
.section_top_twolink .item.item_blue .inner {
	width:auto;
	max-width:700px;
	margin-left:auto;
	margin-right:0;
}
.section_top_twolink .item.item_green .inner {
	width:auto;
	max-width:700px;
	margin-left:0;
	margin-right:auto;
}
.section_top_twolink .item h3 {
	font-size:30px;
	line-height:1;
	font-weight:normal;
}
.section_top_twolink .item p {
	font-size:16px;
	line-height:1.8;
	margin-top:20px;
}
.section_top_twolink .item p a {
	color:#fff;
	text-decoration:none; 
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.section_top_twolink .items {
	display:block; 
}	
.section_top_twolink .item {
	display:block;
	width:100%;
	padding:30px 20px;
}
.section_top_twolink .item.item_blue .inner,
.section_top_twolink .item.item_green .inner {
	max-width:100%;
	margin:0;
}	
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_twolink .item {
	padding:15px 10px;
	padding:20px;
}	
.section_top_twolink .item h3 {
	font-size:20px;
	font-weight:bold;
}
.section_top_twolink .item p {
	font-size:14px;
	line-height:1.6;
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */

/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.section_top_twolink .item {
	padding:20px 10px;
}	
}	/* for SP max-width: 320px */


/*-------------------------------------------------------------
	items link	
-------------------------------------------------------------*/
.section_top_twolink .link {
	padding-top:20px;
}
.section_top_twolink .link li {
	float:left;
	width:47%;
	font-size:16px;
	line-height:20px;
	margin-top:20px;
}
.section_top_twolink .link li:nth-child(odd) {
	margin-right:6%;
}
.section_top_twolink .link li a {
	position:relative; 
	display:block; 
	color:#fff;
	text-decoration:none; 
	padding:20px;
	border:1px solid rgba(255,255,255,0.4);
}
.section_top_twolink .link li a:after {
	position:absolute;
	content:"";
	width:7px;
	height:7px;
	top:0;
	bottom:0;
	right:10px;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}
.section_top_twolink .link li a:hover {
	background:rgba(255,255,255,0.2);
}

/*縦積みの仕様*/
.section_top_twolink .item_green .link li {
	float:none;
	width:47%;
}
.section_top_twolink .item_green .link li:nth-child(odd) {
	margin-right:0;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.section_top_twolink .link {
	padding-top:10px;
}	
.section_top_twolink .link li {
	width:49%;
	margin-top:10px;
}
.section_top_twolink .link li:nth-child(odd) {
	margin-right:2%;
}
/*縦積みの仕様*/
.section_top_twolink .item_green .link li {
	float:left;
	width:49%;
}
.section_top_twolink .item_green .link li:nth-child(odd) {
	margin-right:2%;
}	
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_twolink .link {
	padding-top:5px;
}
.section_top_twolink .link li {
	font-size:14px;
	line-height:20px;
	margin-top:5px;
}
.section_top_twolink .link li a {
	padding:7.5px;
	border:1px solid rgba(255,255,255,0.2);
	background: #173887;
}
.section_top_twolink .item_green .link li a {
	background: #028055;
}
.section_top_twolink .link li a:hover,
.section_top_twolink .item_green .link li a:hover {
	background:rgba(255,255,255,0.2);
}
.section_top_twolink .link li a:after {
	width:5px;
	height:5px;
	right:5px;
}
}	/* for SP max-width: 736px */
/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.section_top_twolink .link li {
	font-size:12px;
	line-height:15px;
}
}	/* for SP max-width: 320px */




/*===============================================================
	
	section_top_link　グリッドのリンクアイテム
	
===============================================================*/
.linkitem img {
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.1);
}
.section_top_link .linkitem img {
	border: solid 4px #fff;
	box-sizing: border-box;
}
.section_top_link .linkitem img:hover {
	/*border: solid 4px #173887;*/
}
/*-------------------------------------------------------------
	linkitem	
-------------------------------------------------------------*/
.linkitem p {
	font-size:18px;
	line-height:1.6;
	margin-top:10px;
}
.linkitem a {
	display:block; 
	color:#333;
	text-decoration:none;
}


/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.linkitem p {
	font-size:12px;
	line-height:1.4;
	margin-top:5px;
}
}	/* for SP max-width: 736px */


/*===============================================================
	
	section_top_info　３段積みのやつ
	
===============================================================*/
.section_top_info .box + .box {
	padding-top:80px;
}
.section_top_info .box .head {
	position:relative;
}
.section_top_info .box .head:after {
	content:"";
	position:absolute;
	top:0;
	bottom:0;
	left:-50px;
	margin:auto;
	width:35px;
	height:1px;
	background:#173887;
}
.section_top_info .box .head h3 {
	color:#173887;
	font-size:30px;
	line-height:1;
}
.section_top_info .box .head .txtlink {
	position:absolute;
	top:0;
	bottom:0;
	right:0;
	margin:auto;
	font-size:18px;
	line-height:30px;
}
.section_top_info .box .head .txtlink a {
}
.section_top_info .box .detail {
	margin-top:30px;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.section_top_info .box + .box {
	padding-top:50px;
}

}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_info .box + .box {
	padding-top:30px;
}
.section_top_info .box .head:after {
	display:none; 
}
.section_top_info .box .head h3 {
	font-size:20px;
}
.section_top_info .box .head .txtlink {
	font-size:12px;
	line-height:15px;
}
.section_top_info .box .detail {
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	timetable	
-------------------------------------------------------------*/
.timetable table {
	width:100%;
	border-collapse:collapse;
  border-spacing:0;
	border-bottom:solid 1px #ddd;
}
.timetable table thead th {
	font-size:18px;
	line-height:20px;
	text-align:center;
	padding:15px 5px;
	border:solid 1px #ddd;
	background:#f9f9fa;
	vertical-align:middle; 
}
.timetable table tbody th,
.timetable table tbody td {
	font-size:18px;
	line-height:20px;
	text-align:center;
	padding:27.5px 5px;
	border:solid 1px #ddd;
	vertical-align:middle;
}
.timetable table .time {
	width:18.1%;
}
.timetable table .date {
	width:11.7%;
}
.timetable table .red {
	color:#ff6666;
	font-weight:bold;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {
.timetable table .time {
	width:19.5%;
}
.timetable table .date {
	width:11.5%;
}
	
}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.timetable table thead th {
	font-size:12px;
	line-height:15px;
	padding:5px;
}
.timetable table tbody th,
.timetable table tbody td {
	font-size:12px;
	line-height:15px;
	padding:5px;
}	
.timetable table .time {
	text-align:left; 
	width:26.5%;
}
.timetable table .date {
	width:10.5%;
}	
.timetable table .sp_none {
	display:none; 
}	
.timetable .off {
	color:#ff6666;
	font-size:12px;
	line-height:15px;
	font-weight:bold;
	margin-top:10px;
}	
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	infolist	
-------------------------------------------------------------*/
.infolist dl{
	border-bottom:1px solid #ddd;
}
.infolist dt {
	float:left;
	width:150px;
	font-size:18px;
	line-height:20px;
	padding:20px 0;
	border-top:1px solid #ddd;
}
.infolist dd {
	font-size:18px;
	line-height:20px;
	padding:20px 0;
	margin-left:150px;
	border-top:1px solid #ddd;
}
.infolist dd a {
	display:block; 
	color:#333;
	text-decoration:none; 
}
.infolist dd a:hover {
	color:#1b46ac;
	text-decoration:underline; 
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.infolist dt {
	width:75px;
	font-size:13px;
	line-height:15px;
	padding: 12.5px 0;
}
.infolist dd {
	font-size:13px;
	line-height:15px;
	padding: 12.5px 20px;
	margin-left:75px;
}

}	/* for SP max-width: 736px */


/*-------------------------------------------------------------
	pager_num：数字のページング
-------------------------------------------------------------*/
.pager_num {
	position:relative;
	overflow:hidden;
}
.pager_num ul {
	position:relative;
	left:50%;
	float:left;
}
.pager_num ul li {
	position:relative;
	left:-50%;
	float:left;
	padding:0 10px;
}
.pager_num li a {
	display:block;
	margin:0 auto;
	text-decoration:none;
	text-align:center;
	font-weight:bold;
	font-size:18px;
	line-height:40px;
	width:40px;
	color:#fff;
	background:#173887;
	border:solid 2px #173887;
}
.pager_num li a:hover {
	background:#1b46ac;
	border:solid 2px #1b46ac;
}
.pager_num li.current a {
	color:#173887;
	background:#fff;
	border:solid 2px #173887;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.pager_num ul li {
	padding:0 5px;
}	
.pager_num li a {
	font-size:14px;
	line-height:30px;
	width:30px;
	border:solid 1px #173887;
}
.pager_num li a:hover {
	border:solid 1px #173887;
}
.pager_num li.current a {
	border:solid 1px #173887;
}
}	/* for SP max-width: 736px */


/*===============================================================
	
	section_googlemap　グーグルマップ埋め込み
	
===============================================================*/
.section_googlemap {
}
.section_googlemap .section_inner {
	padding:0;
}
.section_googlemap .gmap iframe {
	width:100%;
	height:380px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_googlemap .gmap iframe {
	height:190px;
}
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	下層ページの各エレメント
	
===============================================================*/

/*===============================================================
	
	pagehead_wrp　ページヘッド
	
===============================================================*/
.pagehead_wrp {
	height:auto;
}
.pagehead_wrp h3 {
	color:#fff;
	font-size:30px;
	line-height:40px;
	font-weight:500;
	text-align:center; 
	padding:30px 0;
	background:#1b46ac;
}
.pagehead_wrp .fixed {
	top:60px;
	width:100%;
	z-index:10;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
.pagehead_wrp .fixed {
	top:40px;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.pagehead_wrp h3 {
	font-size:18px;
	line-height:30px;
	padding:5px 0;
}
.pagehead_wrp .fixed {
	top:40px;
}
}	/* for SP max-width: 736px */

/*===============================================================
	
	localnav　ローカルナビ
	
===============================================================*/
.localnav {
	text-align:center;
	padding:20px 0 15px 0;
	background:#eee;
}
.localnav .navlist {
	width:100%;
	margin:0 auto;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.localnav {
	text-align:left;
	padding:0 0;
}
.localnav .navlist {
	overflow:auto;
	overflow-x:scroll;
	overflow-scrolling: touch;
	-webkit-overflow-scrolling: touch;
	padding:0 10px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.localnav .navlist ul
-------------------------------------------------------------*/
.localnav .navlist ul {
	letter-spacing:-.4em;
}
.localnav .navlist li {
	display:inline-block;
	margin:0;
	padding:0 25px;
	font-size:18px;
	line-height:20px;
	letter-spacing:normal;
}
.localnav .navlist li a {
	display:block;
	color:#173887;
	font-weight:bold;
	text-decoration:none;
	padding-bottom:5px;
	border-bottom:solid 2px #eee;
}
.localnav .navlist li a:hover {
	color:#1b46ac;
	font-weight:bold;
	text-decoration:none;
	border-bottom:solid 2px #1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.localnav .navlist {
	position: relative;
}
.localnav .navlist ul {
	margin-top:0;
	width:1000vw;
	position:static;
	left:0;
	float:none;
}
.localnav .navlist li {
	position:relative;
	left:0;
	float:left;
	font-size:12px;
	line-height:1.5;
	padding:10px 0;
	margin:0;
	margin-right:15px;
	padding-right:15px;
}
.localnav .navlist li:after {
	content:'';
	position:absolute;
	margin:auto;
	top:0; bottom:0;
	right:0px;
	width:1px;
	height:10px;
	background:rgba(0,0,0,0.5);
}
.localnav .navlist li:last-child:after {
	content:none;
}
.localnav .navlist li a {
	padding-bottom:0px;
}
.localnav .navlist li a:hover {
	/*color:#333;
	font-weight:normal;
	text-decoration:none;*/
}

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	mainread　リード文	
-------------------------------------------------------------*/
.mainread {
	font-size:20px;
	line-height:1.8;
	font-weight:normal;
	text-align:center; 
}
.content *+ .mainread {
	margin-top:20px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.mainread {
	font-size:14px;
	line-height:1.6;
	text-align:left;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	mainimg　トップ画像
-------------------------------------------------------------*/
.mainimg {
}
* + .mainimg {
	margin-top:50px;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.mainimg {
}
* + .mainimg {
	margin-top:10px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	headline　見出し
-------------------------------------------------------------*/
.headline {
	color:#173887;
	font-size:30px;
	line-height:1;
	text-align:center; 
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.headline {
	font-size:20px;
	line-height:1;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	subhead　サブ見出し
-------------------------------------------------------------*/
.subhead {
	font-size:24px;
	line-height:1;
	text-align:center; 
}
.headline + .subhead {
	margin-top:30px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.subhead {
	font-size:16px;
	line-height:1;
}
.headline + .subhead {
	margin-top:10px;
}	
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	normal_p　基本のp
-------------------------------------------------------------*/
.normal_p {
	font-size:18px;
	line-height:1.9;
}
* + .normal_p {
	margin-top:30px;
}
.subhead + .normal_p {
	margin-top:10px;
}
.normal_p a {
	color:#333;
	text-decoration:none; 
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.normal_p {
	font-size:14px;
	line-height:1.8;
   text-align: left;
}
* + .normal_p {
	margin-top:15px;
}	
.subhead + .normal_p {
	margin-top:10px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	normal_p.small　小さいp
-------------------------------------------------------------*/
.normal_p.small,
.normal_p .small {
	font-size:13px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.normal_p.small,
.normal_p .small {
	font-size:12px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	normal_p.link_p　リンクのp
-------------------------------------------------------------*/
.normal_p.link_p {
	margin-top:5px !important;
}
.normal_p.link_p a {
	color:#173887;
	text-decoration:none;
}
.normal_p.link_p a:hover {
	color:#1b46ac;
	text-decoration:underline;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	pctablet_center　PCタブレット時センター
-------------------------------------------------------------*/
.pctablet_center {
	text-align:center; 
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.pctablet_center {
	text-align:left; 
}

} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	attention
-------------------------------------------------------------*/
.attention {
	color:#fff;
	font-size:18px;
	line-height:1.8;
	font-weight:500;
	padding:30px;
	background:#87173c;
	margin-top:30px;
	text-align: center;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.attention {
	font-size:12px;
	line-height:1.6;
	padding:10px;
	margin-top:10px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	mapimg　マップ画像
-------------------------------------------------------------*/
.mapimg {
	margin:0 auto;
	margin-top:20px;
}
.mapimg.mapimg_1f {
	width:100%;
	height:auto;
}
.mapimg.mapimg_2f {
	width:auto;
	max-width:536px;
	height:auto;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.mapimg {
	margin-top:10px;
}
	
} /* for SP max-width: 736px */

/*===============================================================
	
	numberlist　リードリスト
	
===============================================================*/
.content_numberlist{
   padding-top: 40px;
}

.numberlist dl{
	border-bottom:1px solid #ddd;
   display: flex;
   flex-wrap: wrap;
   /* align-items: center; */
   width: 100%;
}
.numberlist dt, .numberlist dd{
   /* align-items: center; */
   display: flex;
}
.numberlist dt {
	/* float:left;
	width:70px; */
   width: 10%;
   color: #1b46ac;
   font-size: 36px;
   /* line-height: 40px; */
   padding: 40px 0 40px 0;
   text-align: center;
   border-top: 1px solid #ddd;
   align-items: center;
   display: flex;
   justify-content: center;
}
.numberlist dd {
   font-size: 18px;
   line-height: 30px;
   padding: 40px 0 40px 0;
   width: 90%;
   /* margin-left: 100px; */
   border-top: 1px solid #ddd;
   justify-content: start;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.content_numberlist{
   padding-top: 0;
}
/*
.numberlist dt {
	float:none;
	width:100%;
	font-size:20px;
	line-height:1;
	text-align:center;
	padding:10px 0 0 0;
}
*/

.numberlist dl{
   border-bottom: none;
   align-items: center;
}
.numberlist {

}
/* .numberlist dl{
   align-items: center;
} */
.numberlist dt {
	float:none;
	display: block;
	margin-top: 15px;
	/* width:40px; */
	height: 40px;
	font-size:18px;
	line-height:40px;
   align-items: center;
   justify-content: center;
   display: flex;
   width: 35px;
   height: 35px;
	text-align:center;
	padding:0;
	border-top:0px solid #ddd;
	background: #1b46ac;
	color: #fff;
	border-radius: 50%;
}
.numberlist dd {
   width: calc(100% - 55px);
   padding: 0;
	font-size:14px;
	line-height:1.6;
	margin-left:20px;
	margin-top:15px;
	border:none;
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	opelist　手術実績
	
===============================================================*/
* + .opelist {
	margin-top:40px;
}
.opelist dl {
	border-bottom:1px solid #ddd;
}
.opelist dt {
	float:left;
	width:190px;
	font-size:18px;
	line-height:30px;
	padding:20px 0 20px 10px;
	border-top:1px solid #ddd;
}
.opelist dd {
	font-size:18px;
	line-height:30px;
	text-align:right; 
	padding:20px 10px 20px 0;
	margin-left:200px;
	border-top:1px solid #ddd;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
* + .opelist {
	margin-top:15px;
}	
.opelist dt {
	width:120px;
	font-size:12px;
	line-height:1.6;
	padding:10px 0 10px 10px;
}
.opelist dd {
	font-size:12px;
	line-height:1.6;
	padding:10px 10px 10px 0;
	margin-left:130px;
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	diseaselist　病気リスト
	
===============================================================*/
.diseaselist dl{
	border-bottom:1px solid #ddd;
}
.diseaselist a {
	display:block; 
	color:#333;
	text-decoration:none;  
	clear: both;
}
.diseaselist a:hover {
	background:#ebf1ff;
}
.diseaselist dt {
	float:left;
	width:190px;
	font-size:22px;
	line-height:30px;
	font-weight:500;
	padding:20px 0 20px 10px;
	border-top:1px solid #ddd;
}
.diseaselist dt span {
	display:block; 
	font-size:14px;
	line-height:20px;
}
.diseaselist dd {
	position:relative;
	font-size:16px;
	line-height:1.8;
	padding:20px 10px 20px 0;
	padding-right:40px;
	margin-left:200px;
	border-top:1px solid #ddd;
}
.diseaselist dd:after {
	position:absolute;
	content:"";
	width:7px; height:7px;
	top:0; left:auto; bottom:0; right:10px;
	margin:auto;
	border-top:solid 1px #333;
	border-left:solid 1px #333;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.diseaselist dt {
	position:relative;
	float:none;
	width:100%;
	font-size:14px;
	line-height:20px;
	font-weight:bold;
	padding:10px 0 0 0;
}
.diseaselist dt span {
	display:inline-block;
	font-size:10px;
	line-height:15px;
	margin-left:10px;
}	
.diseaselist dt:after {
	position:absolute;
	content:"";
	width:5px; height:5px;
	top:auto; left:auto; bottom:5px; right:5px;
	margin:auto;
	border-top:solid 1px #333;
	border-left:solid 1px #333;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}	
.diseaselist dd {
	font-size:12px;
	line-height:1.6;
	padding:0 0 10px 0;
	margin-left:0;
	margin-top:5px;
	border:none;
	min-height:auto;
}
.diseaselist dd:after {
	display:none; 
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	txtlist　リンクリスト
	
===============================================================*/
.txtlist {
	padding-top:20px;
	margin-top:20px;
}
.txtlist + .txtlist {
	margin-top:40px;
}
.medical_index .txtlist + .txtlist {
	margin-top:60px;
}
.txtlist.txtlist_mtpt0 {
	padding-top:0;
	margin-top:0;
}
.txtlist .subhead {
	padding-bottom:20px;
	border-bottom:1px solid #ddd;
	text-align: left;
}
.txtlist .subhead a {
	color:#333;
	text-decoration:none; 
}
.txtlist .subhead a:hover {
	color:#1b46ac;
}
.txtlist ul {
	padding-top:10px;
}
.txtlist li {
	float:left;
	width:32%;
	font-size:16px;
	line-height:1.5;
	margin-top:20px;
	margin-right:2%;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
}
.txtlist li:nth-child(3n) {
	margin-right:0;
}
.txtlist ul li:nth-child(3n+1){
	clear: both;
}
.txtlist li a {
	color:#333;
	text-decoration:underline;
}
.txtlist li a span {
	font-size:14px;
}
.txtlist li a:hover {
	color:#1b46ac;
	/*font-weight:bold;*/
}
.txtlist li a:hover span {
	/*font-weight:bold;*/
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.txtlist {
	padding-top:20px;
	margin-top:10px;
}
.txtlist + .txtlist {
	margin-top:20px;
}	
.medical_index .txtlist + .txtlist {
	margin-top:20px;
}
.txtlist .subhead {
	padding-bottom:10px;
}
.txtlist ul {
	padding-top:0;
}
.txtlist li {
	width:48.5%;
	font-size:12px;
	margin-top:10px;
	margin-right:3%;
}
.txtlist li:nth-child(3n) {
	margin-right:3%;
}		
.txtlist ul li:nth-child(3n+1){
	clear:none;
}
.txtlist li:nth-child(2n) {
	margin-right:0;
}
.txtlist li a span {
	font-size:10px;
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	detail_item　詳細へのリンクアイテム
	
===============================================================*/
.detail_item {
	margin-top:60px;
}
.detail_item h5 {
	font-size:20px;
	line-height:1.3;
	font-weight:bold;
	text-align:center;
	margin-top:30px;
}
.detail_item h5 span {
	font-size:16px;
	font-weight:bold;
}
.detail_item h6 {
	font-size:16px;
	line-height:1.3;
	font-weight:500;
	text-align:center;
	margin-top:5px;
}
.detail_item p {
	font-size:16px;
	line-height:1.8;
	margin-top:15px;
}
.detail_item .btn_detail {
	margin-top:30px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.detail_item {
	margin-top:15px;
}
.detail_item + .detail_item {
	margin-top:30px;
}
.detail_item h5 {
	font-size:16px;
	margin-top:10px;
}
.detail_item h5 span {
	display:block; 
	font-size:12px;
	font-weight:bold;
}	
.detail_item h6 {
	font-size:14px;
}
.detail_item p {
	font-size:14px;
	line-height:1.6;
	margin-top:10px;
}
.detail_item .btn_detail {
	margin-top:10px;
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	link_confirm_dial　順番確認専用ダイヤルバナー
	
===============================================================*/
.link_confirm_dial {
	background:#ebf1ff;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box;
	text-align:center; 
}
.link_confirm_dial a {
	padding:30px;
	display:block; 
	color:#333;
	text-decoration:none;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_confirm_dial a {
	padding:10px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	left	
-------------------------------------------------------------*/
.link_confirm_dial .left {
	float:left;
	color:#173887;
	font-size:24px;
	line-height:60px;
	font-weight:bold;
	text-align:left;
	padding:0 20px;
	border:1px solid #173887;
	background:#fff;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_confirm_dial .left {
	float:none;
	line-height:40px;
	text-align:center;
	padding:0;
}

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_confirm_dial .left {
   font-size: 13px;
   line-height: 25px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	right	
-------------------------------------------------------------*/
.link_confirm_dial .right {
	display:inline-block;
	float:right;
	color:#173887;
	font-size:60px;
	line-height:1;
	font-weight:500;
	padding-left:40px;
	background:url(../images/icon_tel_blue.png) no-repeat left bottom 4px;
	background-size:32px 46px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_confirm_dial .right {
	float:none;
	margin-top:5px;
}
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_confirm_dial .right {
	font-size:34px;
	padding-left:22px;
	background:url(../images/icon_tel_blue.png) no-repeat left bottom 3px;
	background-size:17px 24px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	link_contact　お問い合わせバナー
	
===============================================================*/
.link_contact {
	background:#f0f1f3;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box;
	text-align:center; 
}
.link_contact a {
	padding:40px;
	display:block; 
	color:#333;
	text-decoration:none;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_contact a {
	padding:30px;
}	

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_contact a {
	padding:10px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	head_border	
-------------------------------------------------------------*/
.link_contact .head_border {
	position:relative;
	z-index:1;
	height:30px;
	text-align:center; 
}
.link_contact .head_border:before {
	position:absolute;
	z-index:2;
	content:"";
	top:15px;
	left:0;
	width:100%;
	height:1px;
	background:#333;
}
.link_contact .head_border span {
	position:absolute;
	top:0;
	left:0;
	right:0;
	margin:auto;
	z-index:3;
	display:inline-block;
	width:340px;
	font-size:24px;
	line-height:30px;
	background:#f0f1f3;
	padding:0 10px;	
}

/* タブレット以下 */
@media screen and (max-width: 840px) {

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_contact .head_border {
	height:20px;
}
.link_contact .head_border:before {
	top:10px;
}
.link_contact .head_border span {
	width:230px;
	font-size:16px;
	line-height:20px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	left	
-------------------------------------------------------------*/
.link_contact .left {
	float:left;
	font-size:18px;
	line-height:20px;
	font-weight:bold;
	text-align:left; 
	margin-top:20px;
}
.link_contact .left span {
	display:block;
	font-size:14px;
	line-height:20px;
	font-weight:bold;
	margin-top:10px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_contact .left {
	float:none;
	text-align:center;
	margin-top:10px;
}
.link_contact .left span {
	display:inline-block;
	margin-left:15px;
	margin-top:0;
}
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_contact .left {
	font-size:12px;
	line-height:15px;
	margin-top:5px;
}
.link_contact .left span {
	font-size:12px;
	line-height:15px;
	margin-left:10px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	right	
-------------------------------------------------------------*/
.link_contact .right {
	display:inline-block;
	float:right;
	font-size:60px;
	line-height:1;
	font-weight:500;
	padding-left:40px;
	margin-top:10px;
	background:url(../images/icon_tel_gray.png) no-repeat left bottom 4px;
	background-size:32px 46px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_contact .right {
	float:none;
}
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_contact .right {
	font-size:34px;
	padding-left:22px;
	margin-top:5px;
	background:url(../images/icon_tel_gray.png) no-repeat left bottom 3px;
	background-size:17px 24px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	link_reservation　専門外来予約バナー
	
===============================================================*/
.link_reservation {
	background:#f0f1f3;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box;
	text-align:center; 
}
.link_reservation a {
	padding:40px;
	padding-top:30px;
	display:block; 
	color:#333;
	text-decoration:none;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_reservation a {
	padding:30px;
	padding-top:20px;
}	

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_reservation a {
	padding:10px;
	padding-top:10px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	head_border	
-------------------------------------------------------------*/
.link_reservation .head_border {
	position:relative;
	z-index:1;
	height:30px;
	text-align:center; 
}
.link_reservation .head_border:before {
	position:absolute;
	z-index:2;
	content:"";
	top:15px;
	left:0;
	width:100%;
	height:1px;
	background:#333;
}
.link_reservation .head_border span {
	position:absolute;
	top:0;
	left:0;
	right:0;
	margin:auto;
	z-index:3;
	display:inline-block;
	width:240px;
	font-size:24px;
	line-height:30px;
	background:#f0f1f3;
	padding:0 10px;	
}

/* タブレット以下 */
@media screen and (max-width: 840px) {

}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_reservation .head_border {
	height:20px;
}
.link_reservation .head_border:before {
	top:10px;
}
.link_reservation .head_border span {
	width:160px;
	font-size:16px;
	line-height:20px;
}
	
} /* for SP max-width: 736px */

/*-------------------------------------------------------------
	left	
-------------------------------------------------------------*/
.link_reservation .left {
	float:left;
	font-size:18px;
	line-height:20px;
	font-weight:bold;
	text-align:left; 
	margin-top:20px;
}
.link_reservation .left span {
	display:block;
	font-size:14px;
	line-height:20px;
	font-weight:bold;
	margin-top:10px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_reservation .left {
	float:none;
	text-align:center;
	margin-top:10px;
}
.link_reservation .left span {
	display:inline-block;
	margin-left:15px;
	margin-top:0;
}
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_reservation .left {
	font-size:12px;
	line-height:15px;
	margin-top:5px;
}
.link_reservation .left span {
	font-size:12px;
	line-height:15px;
	margin-left:10px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	right	
-------------------------------------------------------------*/
.link_reservation .right {
	display:inline-block;
	float:right;
	font-size:60px;
	line-height:1;
	font-weight:500;
	padding-left:40px;
	margin-top:10px;
	background:url(../images/icon_tel_gray.png) no-repeat left bottom 4px;
	background-size:32px 46px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.link_reservation .right {
	float:none;
}
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_reservation .right {
	font-size:34px;
	padding-left:22px;
	margin-top:5px;
	background:url(../images/icon_tel_gray.png) no-repeat left bottom 3px;
	background-size:17px 24px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	timetable2　タイムテーブル２
	
===============================================================*/
.timetable2 {
}
.timetable2 table {
	width:100%;
	font-size:16px;
	line-height:25px;
	text-align:left;
	border-collapse:separate;
  border-spacing:0;
/*	border:solid 2px rgba(28, 65, 156, 0.3);*/
	border-right:0;
	border-bottom:solid 1px rgba(0,0,0,0.1);
/*	border-left:solid 1px rgba(28, 65, 156, 0.3);*/
}
.timetable2 table th {
	color:#333;
	font-size:16px;
	line-height:25px;
	font-weight:bold;
	padding:10px;
	border:solid 1px #ddd;
	border-right:0;
	border-bottom:0;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	vertical-align:middle;
}
.timetable2 table td {
	width:12%;
	height: 100px;
	color:#000;
	font-size:14px;
	line-height:25px;
	font-weight:normal;
	text-align:center;
	padding:10px;
	border:solid 1px rgba(0,0,0,0.1);
	border-right:solid 3px rgba(28, 65, 156, 0.3);
	border-bottom:0;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	vertical-align:middle;
}
.timetable2 table th + td {
	border-left:solid 3px rgba(28, 65, 156, 0.3);
}
.timetable2 table .week {
	font-size: 16px;
	font-weight: bold;
	height: auto;
}
.timetable2 table .sun {
	width:6%;
}
.timetable2 table .time {
	width:8%;
	text-align:center;
}
.timetable2 table .room {
	width:3%;
	text-align:center;
}
.timetable2 table td + td {
	border-left:0;
}
.timetable2 table thead td {
	text-align:center;
}

.timetable2 table .first {
	color:rgba(28,65,156,1);
	border-top:solid 1px rgba(28,65,156,0.3);
	background:rgba(28,65,156,0.05);
}
.timetable2 table .boldline .first ,
.timetable2 .bordertop,
.timetable2 table .boldline .time {
	border-top: solid 2px rgba(28, 65, 156, 0.8);
}
.timetable2 table .second {
	color:#434343;
	border-top:solid 1px rgba(135,23,60,0.3);
	background:rgba(135,23,60,0.05);
}
.timetable2 table .ope {
	color:rgba(27,62,10,1);
	border-top:solid 1px rgba(27,62,10,0.3);
	background:rgba(27,62,10,0.05);
}
.timetable2 table .opeday {
	background:rgba(90,183,44,0.3);
}
.timetable2 table .first,
.timetable2 table .second,
.timetable2 table .ope {
/*	border-bottom:solid 1px rgba(255,255,255,0.3);*/
}
.timetable2 table th.first {
	border-top:solid 1px rgba(28,65,156,1);
	background:rgba(28,65,156,1);
}
.timetable2 table th.second {
	border-top:solid 1px rgba(135,23,60,1);
	background:rgba(135,23,60,1);
}
.timetable2 table th.ope {
	border-top:solid 1px rgba(27,62,10,1);
	background:rgba(27,62,10,1);
}
.timetable2 table th.first ,
.timetable2 table th.second,
.timetable2 table th.ope {
	color:#fff;
	border-bottom:solid 1px rgba(255,255,255,0.3);
}
.darkgray {
	color:#434343;
}
.timetable2 .darkgray {
	color:#434343;
}
.timetable2 strong {
	font-weight: bold;
	font-size:16px;
}
.timetable2 table .bordertop {
	border-top: solid 2px rgba(28, 65, 156, 0.8);
}
.timetable2 table .senmon {
	background:rgba(27,62,10,0.8);
	padding: 5px;
	display: block;
	line-height: 1.5;
	color: #fff;
}
.timetable2 table .ope a {
	text-decoration: none;
	color: #fff;
}
.timetable2 table .ope a:hover {
	text-decoration: underline;
	color: #fff;
}
.timetable2 table .bg_pink {
	background: rgba(135, 23, 60, 0.8);
}
/* タブレット以下 */
@media screen and (max-width: 960px) {
.timetable2 {
	overflow-x:scroll;
	padding:0;
	overflow-scrolling:touch;
	-webkit-overflow-scrolling:touch;
}
.timetable2 table {
	width:960px;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.timetable2 table {
	padding:0;
	margin-top:0px;
}
.timetable2 table th,
.timetable2 table td {
	font-size:12px;
	line-height:1.5;
	padding:5px 5px;
	height: auto;
}
}	/* for SP max-width: 736px */

/*===============================================================
	
	doctor_list　医師一覧
	
===============================================================*/

/* タブレット以下 */
@media screen and (max-width: 960px) {

}/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.doctor_list .fitimg {
	/*
	width: 70%;
	margin: 0 auto;
	*/
}
}/* for SP max-width: 736px */

/*===============================================================
	
	doctor_detail　医師詳細
	
===============================================================*/
.doctor_detail .photo {
	width:40%;
}
.doctor_detail .txt {
	width:55%;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.doctor_detail .photo {
	float:none;
	width:60%;
	margin:0 auto;
}
.doctor_detail .txt {
	width:100%;
	margin-top:15px;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	txt	
-------------------------------------------------------------*/
.doctor_detail .txt h5 {
	color:#173887;
	font-size:18px;
	line-height:1;
	font-weight:bold;
}
.doctor_detail .txt * + h5 {
	margin-top:30px;
}
.doctor_detail .txt p {
	font-size:16px;
	line-height:1.8;
	margin-top:10px;
}
.doctor_detail .txt dl {
	border-bottom:1px solid #ddd;
	margin-top:15px;
}
.doctor_detail .txt dt {
	float:left;
	width:100px;
	font-size:16px;
	line-height:1.8;
	padding:15px 0;
	border-top:1px solid #ddd;
}
.doctor_detail .txt dd {
	font-size:16px;
	line-height:1.8;
	padding:15px 0;
	padding-left:100px;
	border-top:1px solid #ddd;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.doctor_detail .txt h5 {
	font-size:14px;
}
.doctor_detail .txt * + h5 {
	margin-top:20px;
}
.doctor_detail .txt p {
	font-size:12px;
	line-height:1.6;
	margin-top:5px;
}
.doctor_detail .txt dl {
	margin-top:10px;
}
.doctor_detail .txt dt {
	float:none;
	width:100%;
	font-size:12px;
	line-height:1.6;
	font-weight:500; 
	padding:10px 0 0 0;
}
.doctor_detail .txt dd {
	font-size:12px;
	line-height:1.6;
	padding:0 0 10px 0;
	border-top:none;
}

}	/* for SP max-width: 736px */

/*===============================================================
	
	access_map　アクセス地図
	
===============================================================*/
.access_map {
	position:relative;
	margin-top:30px;
}
.access_map .txt {
	width:38%;
	position:absolute;
	bottom:0;
	right:0;
}
.access_map .txt .normal_p {
	font-size:15px;
}
.access_map .txt .normal_p + .normal_p {
	margin-top:10px;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {
.access_map .txt .normal_p {
	font-size:14px;
}
	
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.access_map {
	position:static;
	margin-top:15px;
}
.access_map .txt {
	width:100%;
	position:static;
	margin-top:10px;
}
.access_map .txt .normal_p {
	font-size:12px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	access_howto　アクセス方法
	
===============================================================*/
.access_howto {
}
.access_howto a {
	color:#173887;
}
.access_howto a:hover {
	text-decoration:underline;
}

/* タブレット以下 */
@media screen and (max-width: 840px) {

	
	
}	/* for tablet max-width: 840px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.access_howto .fitimg {
	width:60%;
	margin:0 auto;
}
.access_howto .caption {
	width:60%;
	margin:0 auto;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	faq_wrp　Q&Aアコーディオン
	
===============================================================*/
.faq_accordion {
	text-align:left;
	margin-top:30px;
	border-top:1px solid #ddd;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.faq_accordion {
	margin-top:15px;
}

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.faq_btns
-------------------------------------------------------------*/
.faq_btns {
	width:400px;
	margin:0 auto;
}
.faq_btns .btn {
	width:190px;
	float:left;
}
.faq_btns .btn:first-child {
	margin-right:20px;
}
.faq_btns .btn a {
	display:block;
	color:#fff;
	font-size:15px;
	line-height:20px;
	text-align:center;
	text-decoration:none;
	padding:15px 0;
	background:#173887;
}
.faq_btns .btn a:hover {
	background:#1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.faq_btns {
	width:230px;
}
.faq_btns .btn {
	width:110px;
}
.faq_btns .btn:first-child {
	margin-right:10px;
}
.faq_btns .btn a {
	font-size:13px;
	padding:10px 0;
}

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.question
-------------------------------------------------------------*/
.question {
	position:relative;
	padding:30px 70px 30px 20px;
	cursor:pointer;
	transition:background .1s linear;
	border-bottom:1px solid #ddd;
	background:#fff;
}
.question:hover {
	background:#ebf1ff;
}
.question.active {
	background:#f0f1f3;
}
.question p {
	font-size:16px;
	line-height:1.8;
	font-weight:bold;
}
.question p:first-child::first-letter {
	color: #173887;
	font-size:30px;
}
.question .icon {
	position:absolute;
	width:32px;
	height:32px;
	right:20px;
	top:0;
	bottom:0;
	margin:auto;
	z-index:100;
}
.question .icon span {
	display:inline-block;
	transition:all .1s linear;
	box-sizing:border-box;
	position:absolute;
	top:0;
	bottom:0;
	right:12px;
	margin:auto;
	width:20px;
	height:2px;
	background-color:#ddd;
}
.question .icon span:nth-of-type(1) {
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}
.question .icon span:nth-of-type(2) {
	-webkit-transform:translateX(13px) rotate(-45deg);
	-moz-transform:translateX(13px) rotate(-45deg);
	-ms-transform:translateX(13px) rotate(-45deg);
	transform:translateX(13px) rotate(-45deg);
}
.question.active .icon span:nth-of-type(1) {
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.question.active .icon span:nth-of-type(2) {
	-webkit-transform:translateX(13px) rotate(45deg);
	-moz-transform:translateX(13px) rotate(45deg);
	-ms-transform:translateX(13px) rotate(45deg);
	transform:translateX(13px) rotate(45deg);
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.question {
	padding:15px 40px 15px 10px;
}
.question p {
	font-size:14px;
	line-height:1.6;
}
.question p:first-child::first-letter {
	font-size:20px;
}
.question .icon {
	width:20px;
	height:20px;
	right:10px;
}
.question .icon span {
	right:8px;
	width:15px;
	height:2px;
}
.question .icon span:nth-of-type(2) {
	-webkit-transform:translateX(10px) rotate(-45deg);
	-moz-transform:translateX(10px) rotate(-45deg);
	-ms-transform:translateX(10px) rotate(-45deg);
	transform:translateX(10px) rotate(-45deg);
}
.question.active .icon span:nth-of-type(2) {
	-webkit-transform:translateX(10px) rotate(45deg);
	-moz-transform:translateX(10px) rotate(45deg);
	-ms-transform:translateX(10px) rotate(45deg);
	transform:translateX(10px) rotate(45deg);
}	

}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	.answer
-------------------------------------------------------------*/
.answer	{
	padding:30px 20px 50px;
	border-bottom:1px solid #ddd;
}
.answer p	{
	font-size:16px;
	line-height:1.8;
}
.answer p:first-child::first-letter {
	color: #f44895;
	font-size:30px;
}
.answer .btns_2	{
	margin-top:0;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.answer	{
	padding:15px 10px 20px;
}
.answer p	{
	font-size:14px;
	line-height:1.6;
}
.answer p:first-child::first-letter {
	font-size:20px;
}
}	/* for SP max-width: 736px */

/*===============================================================
	
	content_detail　コンテントの詳細
	
===============================================================*/
.content_detail .head {
	color:#173887;
	font-size:26px;
	line-height:1.5;
	font-weight:bold;
	padding:5px 0 15px 20px;
	border-left:1px solid #173887;
	border-bottom:1px solid #173887;
	margin-left:-20px;
}
.content_detail .subhead {
	font-size:20px;
	line-height:1.4;
	font-weight:bold;
	text-align:left; 
	margin-top:25px;
}
.content_detail .tag {
	color:#fff;
	font-size:16px;
	line-height:26px;
	display:inline-block;
	padding:0 5px;
	margin-top:20px;
	background:#87173c;
}
.content_detail .tag + .normal_p {
	margin-top:5px;
}
.content_detail * + .normal_p {
	margin-top:20px;
}
.content_detail .subhead + .normal_p {
	margin-top:5px;
}
.content_detail .list {
	background:#ebf1ff;
	padding:30px;
	margin-top:30px;
}
.content_detail .list dt {
	float:left;
	color:#fff;
	font-size:16px;
	line-height:1.8;
	text-align:center; 
	font-weight:500;
	/*border-radius:50%; */
	background:#173887;
	padding:0 10px;
	margin-top:20px;
}
.content_detail .list dd {
	font-size:16px;
	line-height:1.8;
	font-weight:500;
	padding-left:40px;
	margin-top:20px;
}
.content_detail .list dt:nth-child(1),
.content_detail .list dd:nth-child(2) {
	margin-top:0;
}
.content_detail .item .name {
	font-size:20px;
	line-height:1.4;
	font-weight:bold;
	text-align:center; 
	margin-top:15px;
}
.content_detail .item .name span {
	font-size:16px;
	font-weight:bold;
}
.content_detail .item .normal_p {
	margin-top:0;
}
.content_detail .item .name + .normal_p {
	margin-top:10px;
}
.content_detail .item .normal_p + .normal_p {
	margin-top:20px;
}
.content_detail .item .caption {
	font-size:16px;
	line-height:1.4;
	margin-top:15px;
}
.content_detail .item .caption + .caption {
	margin-top:10px;
}
.content_detail .item .caption strong {
	color: #173887;
	display: block;
	padding-bottom: 5px;
	font-size: 120%;
}
.content_detail ul {
	margin-top:30px;
}
.content_detail li {
	font-size:16px;
	line-height:1.8;
	text-indent:-1em;
	padding-left:1em;
}
.content_detail li:nth-child(1) {
	margin-top:0;
}
.note_list {
	margin-top: 40px;
	padding: 20px;
	background: #f0f0f0;
}
.note_list li {
	margin-top: 0px;
	font-size: small;
}


/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.content_detail .head {
	color:#173887;
	font-size:16px;
	padding:15px 0 0 0;
	border:none;
	border-top:solid 1px #173887;
	margin-left:0;
}
.content_detail .subhead {
	font-size:16px;
	margin-top:20px;
	padding-top:20px;
	border-top:1px solid #ddd;
}
.content_detail .tag {
	font-size:12px;
	line-height:20px;
	padding:0 3px;
	margin-top:10px;
}
.content_detail * + .normal_p {
	margin-top:15px;
}
.content_detail .subhead + .normal_p {
	margin-top:10px;
}	
.content_detail .list {
	padding:10px;
	margin-top:15px;
}	
.content_detail .list dt {
	font-size:12px;
	line-height:1.6;
	padding:0 7px;
	margin-top:10px;
}
.content_detail .list dd {
	font-size:12px;
	line-height:1.6;
	padding-left:30px;
	margin-top:10px;
}
.content_detail .item .name {
	font-size:14px;
	margin-top:5px;
}
.content_detail .item .name span {
	font-size:14px;
}
.content_detail .item .name + .normal_p {
	margin-top:5px;
}
.content_detail .item .normal_p + .normal_p {
	margin-top:10px;
}	
.content_detail .item .caption {
	font-size:13px;
}	
.content_detail ul {
	margin-top:10px;
}	
.content_detail li {
	font-size:12px;
	line-height:1.6;
}
	
}	/* for SP max-width: 736px */


/*-------------------------------------------------------------
	subhead_check	チェックアイコン付き
-------------------------------------------------------------*/
.content_detail .subhead_check {
	padding-left:25px;
	position:relative;
}
.content_detail .subhead_check:before {
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	margin:auto;
	content:"";
	border:1px solid #999;
	width:15px;
	height:15px;
}
.content_detail .subhead_check:after {
	position:absolute;
	top:0px;
	left:6px;
	margin:auto;
	content:"";
	border-right:3px solid #5ab72c;
	border-bottom:3px solid #5ab72c;
	width:5px;
	height:15px;
	transform:rotate(45deg);
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.content_detail .subhead_check {
	padding-left:20px;
	position:relative;
}
.content_detail .subhead_check:before {
	top:22px;
	width:10px;
	height:10px;
}
.content_detail .subhead_check:after {
	position:absolute;
	top:22px;
	left:5px;
	margin:auto;
	content:"";
	border-right:2px solid #5ab72c;
	border-bottom:2px solid #5ab72c;
	width:4px;
	height:11px;
	transform:rotate(45deg);
}

}	/* for SP max-width: 736px */


/*===============================================================
	
	notfound_error　404エラー
	
===============================================================*/
.notfound_error {
	text-align:center;
}
.notfound_error h3 {
	color:#173887;
	font-size:30px;
	line-height:1;
	font-weight:bold;
}
.notfound_error h4 {
	font-size:20px;
	line-height:1.4;
	font-weight:500;
	margin-top:30px;
}
.notfound_error h4 + p {
	margin-top:5px;
}
.notfound_error p {
	font-size:16px;
	line-height:1.8;
	margin-top:30px;
}
.notfound_error .box {
	width:auto;
	max-width:380px;
	padding:30px;
	margin:0 auto;
	margin-top:30px;
	background:#ebf1ff;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
}
.notfound_error li {
	font-size:14px;
	line-height:1.8;
	text-align:left;
	text-indent:-1em;
	padding-left:1em;
}
.notfound_error li + li {
	margin-top:5px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

.notfound_error {
}	
.notfound_error h3 {
	font-size:18px;
}
.notfound_error h4 {
	font-size:14px;
	margin-top:15px;
}
.notfound_error p {
	font-size:12px;
	line-height:1.6;
	margin-top:10px;
}
.notfound_error .box {
	padding:10px;
	margin-top:10px;
}
.notfound_error li {
	font-size:12px;
	line-height:1.6;
}

}	/* for SP max-width: 736px */


/*===============================================================
	
	section_pagelist　フッターページ一覧リスト
	
===============================================================*/
.section_pagelist .section_inner {
	padding-top:30px;
}
.section_pagelist .subhead {
	font-weight:bold;
	margin-top:30px;
}
.section_pagelist .gridconatiner {
	margin-top:-10px;
}
.section_pagelist .grid {
	margin-top:40px;
}
.section_pagelist .linkitem p {
	font-size:15px;
}
.section_pagelist .normal_p {
	font-size:12px;
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {

}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_pagelist .section_inner {
	padding-top:15px;
}	
.section_pagelist .subhead {
	font-weight:bold;
	margin-top:20px;
}	
.section_pagelist .gridconatiner {
	margin-top:0;
}
.section_pagelist .grid {
	margin-top:15px;
}	
.section_pagelist .linkitem p {
	font-size:12px;
}	
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
	section_pagelist　フッターページ一覧リスト カレント表示
-------------------------------------------------------------*/
.section_pagelist .grid img {
	border: solid 4px #fff;
	box-sizing: border-box;
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.1);
}
.section_pagelist .grid.current img {
	border: solid 4px #1b46ac;
}
.section_pagelist .current a {
	position: relative;
	display: block;
}
.section_pagelist .current a::after {
	content: '現在のページ';
	position: absolute;
	top: -5px;
	left: -5px;
	font-size: 11px;
	line-height: 15px;
	color: #fff;
	background: #1b46ac;
	padding: 3px 10px;
}
.section_pagelist .current a::before {
	content:'';
	position:absolute;
	top: 15px; left: -5px;
	margin: auto;
	width:3px;
	height:3px;
	border-top: 3px solid #000;
	border-right: 3px solid #000;
	border-bottom: 3px solid transparent;
	border-left: 3px solid transparent;
	
	box-sizing:border-box;
	transition:all .3s;
	z-index: 5;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}/* for SP max-width: 736px */



/*-------------------------------------------------------------
	pankuzu	
-------------------------------------------------------------*/
.pankuzu {
	text-align:left;
}
.pankuzu li {
	display:inline-block;
	font-size:13px;
	line-height:1;
	padding-left:15px;
}
.pankuzu li:first-child {
	padding-left:0;
}
.pankuzu li a {
	position:relative;
	text-decoration:none;
	padding-right:20px;
	color:#173887;
}
.pankuzu li a:hover {
	color:#1b46ac;
	text-decoration:underline; 
}
.pankuzu li a:after {
	content:'';
	position:absolute;
	margin:auto;
	top:0; bottom:0;
	right:0;
	border-right:solid 1px #333;
	border-bottom:solid 1px #333;
	width:5px;
	height:5px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
	transition: all .3s;
	/*	逆向き
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
	*/
}

/* タブレット以下 */
@media screen and (max-width: 1160px) {

}	/* for tablet max-width: 1160px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.pankuzu li {
	font-size:12px;
	padding-left:5px;
}
.pankuzu li a {
	padding-right:10px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	info_detail　お知らせ詳細
	
===============================================================*/
.info_detail {
}
.info_detail .head {
	padding-bottom:5px;
	border-bottom:1px solid #333;
}
.info_detail .head .date {
	display:inline-block;
	float:right;
	font-size:20px;
	line-height:40px;
	font-weight:500;
	text-align:right; 
}
.info_detail .head h3 {
	font-size:28px;
	line-height:40px;
	font-weight:bold;
	padding-right:130px;
}
.info_detail .photo {
	width:auto;
	max-width:400px;
	margin:0 auto;
	margin-top:30px;
}
.info_detail .txt {
	margin-top:30px;
}
.info_detail .txt p {
	font-size:16px;
	line-height:1.8;
}
.info_detail .txt p + p {
	margin-top:20px;
}


/* タブレット以下 */
@media screen and (max-width: 960px) {
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.info_detail .head {
	padding-bottom:5px;
}
.info_detail .head .date {
	display:block; 
	float:none;
	font-size:14px;
	line-height:1;
	font-weight:normal;
	text-align:left; 
}
.info_detail .head h3 {
	font-size:18px;
	line-height:1.4;
	padding-right:0;
	margin-top:2px;
}
.info_detail .photo {
	margin-top:10px;
}	
.info_detail .txt {
	margin-top:10px;
}
.info_detail .txt p {
	font-size:12px;
	line-height:1.6;
}
.info_detail .txt p + p {
	margin-top:10px;
}	

	
}	/* for SP max-width: 736px */

/*===============================================================
	
	exarea　注釈エリア
	
===============================================================*/
.exarea {
	border: 1px solid #ddd;
	padding: 25px 0;
	margin: 0 auto;
	margin-top: 30px;
}
.exarea .subhead{
	border: none;
	font-size: 18px;
	padding-bottom: 0;
	text-align: center;
}
.exarea.subhead a {
	color:#333;
	text-decoration:none; 
}
.exarea.subhead a:hover {
	color:#1b46ac;
}
.exarea ul {
	padding-top:10px;
}
.exarea li {
	float:left;
	width:32%;
	font-size:16px;
	line-height:1.5;
	margin-top:20px;
	margin-right:2%;
	-webkit-box-sizing:border-box; 
	box-sizing:border-box; 
	text-align: center;

}
.exarea li:nth-child(3n) {
	margin-right:0;
}
.exarea ul li:nth-child(3n+1){
	clear: both;
}
.exarea li a {
	color:#333;
	text-decoration:underline;
}
.exarea li a span {
	font-size:14px;
}
.exarea li a:hover {
	color:#1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.exarea {
	margin-top: 20px;
	padding: 15px 0;
}
.exarea .subhead{
	font-size: 14px;
	padding-bottom: 5px;
}
.exarea ul {
	padding-top:0;
}
.exarea li {
	width:48.5%;
	font-size:12px;
	margin-top:10px;
	margin-right:3%;
}
.exarea li:nth-child(3n) {
	margin-right:3%;
}		
.exarea ul li:nth-child(3n+1){
	clear:none;
}
.exarea li:nth-child(2n) {
	margin-right:0;
}
.exarea li a span {
	font-size:10px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	localnavがactive時のスタイル
	
===============================================================*/
.localnav .navlist .active a{
	color:#1b46ac;
	font-weight:bold;
	text-decoration:none;
	border-bottom:solid 2px #1b46ac;
}
.localnav .navlist .active a:hover{
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
	
}	/* for SP max-width: 736px */

/*===============================================================
	
		次のカテゴリに行くワイドボタン
	
===============================================================*/
.section_widebtn {
	background: #173887;
	width: 100%;
}
.section_widebtn .btntitle {
	font-size: 24px;
	font-weight: bold;
	position: relative;
	line-height:3.5 ;
	text-align: center;
}
.section_widebtn .btntitle a {
	background: #173887;
	display: block;
	text-decoration: none;
	color: #fff;
}
.section_widebtn .btntitle span {
	position:absolute;
	width:10px; height:10px;
	top:0; left:auto; bottom:0; right:auto;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}
.section_widebtn .btntitle a:hover {
	background-color: #1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_widebtn .btntitle {
	font-size: 16px;
}
.section_widebtn .btntitle span {
	width:7px; height:7px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	ヘッダーロゴのテキスト化
	
===============================================================*/
.header .logo {
	position: relative;
}
.header .logo .txtlogo {
	color: #173887;
	line-height: 38px;
	font-size: 35px;
	font-weight: bold;
	text-decoration: none;
	letter-spacing: 0.05em;
	display: block;
	position: absolute;
	top: 20px;
	left: 18px;
}
.header .logo .txtlogo img {
	width: 40px;
	height: 40px;
	margin-right: 3px;
}

/*1160px以下*/
@media screen and (max-width: 1160px) {
.header .logo .txtlogo {
	line-height: 35px;
	font-size: 31px;
	top: 22.5px;
	left: 13px;
	}
.header .logo .txtlogo img {
	width: 35px;
	height: 35px;
}
}	/* for tablet max-width: 1160px */


/* タブレット以下 */
@media screen and (max-width: 960px) {
.header .logo {
	width: 150px;
}
.header .logo .txtlogo {
	line-height: 22px;
	font-size: 19px;
	top: 0px;
	left: 0px;
	}
.header .logo .txtlogo img {
	width: 22px;
	height: 22px;
}
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
	
}	/* for SP max-width: 736px */


/*===============================================================
	
	フッターロゴのテキスト化
	
===============================================================*/
.footer .address .txtlogo {
	color: #fff;
	line-height: 25px;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 0.05em;
}
.footer .address .txtlogo img {
	width:  25px;
	height: 25px;
	margin-right: 3px;
}

/*1160px以下*/
@media screen and (max-width: 1160px) {

}	/* for tablet max-width: 1160px */


/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.footer .address .txtlogo {
	width: 115px;
	margin: 0 auto;
	line-height: 15px;
	font-size: 15px;
	font-weight: 500;
}
.footer .address .txtlogo img {
	width:  15px;
	height: 15px;
}
	
}	/* for SP max-width: 736px */

/*===============================================================
	
	スマホ　ハンバーガーメニュー内にボタンと所在地等追加
	
===============================================================*/

/* タブレット以下 */
@media screen and (max-width: 960px) {

.menu_nav .btn_wrp {
	border-top:solid 1px rgba(255,255,255,0.05);
	padding-top:30px;
}
.menu_nav .btn_detail {
	width: 270px;
	margin-top: 0px;
	box-shadow: none;
}
.menu_nav .btn_detail a {
	width: 130px;
	float: left;
	border:solid 1px #f0f1f3;
	font-size: 14px;
	line-height: 35px;
	padding: 0;
	margin-right: 10px;
	box-sizing:border-box;
}
.menu_nav .btn_detail a:hover {
	background: #173887;
}
.menu_nav .btn_detail a:nth-of-type(2) {
	margin-right: 0px;
}
.menu_nav .footer {
	text-align: center;
	color: #fff;
	padding:30px 0;
}
	
}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {

}	/* for SP max-width: 736px */

/*===============================================================
	
	pict_icon
	
===============================================================*/
.pict_icon {
	position: relative;
}
.pict_icon img {
	width: 20px;
	height: auto;
	position: absolute;
	left: auto;
	right: auto;
	top: 0;
	bottom: 0;
	margin: auto;
}
.section_top_catch .link .pict_icon a {
	padding-left:40px;
}
.pict_icon a:before {
	content: "";
	background: url(../images/icon_first.png) center left no-repeat;
	background-size: contain;
	position: absolute;
	left: 19px;
	top: 1px;
	bottom: 0;
	right: auto;
	margin: auto;
	width: 17px;
	height: 17px;
}

/* タブレット以下 */
@media screen and (max-width: 940px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.section_top_catch .link .pict_icon a {
	padding-left:25px;
}
.pict_icon a:before {
	left: 7.5px;
	width: 15px;
	height: 15px;
}

}	/* for SP max-width: 736px */

/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.section_top_catch .link .pict_icon a {
	padding-left:23px;
}
.pict_icon a:before {
	width: 13px;
	height: 13px;
}

}	/* for SP max-width: 320px */

/*===============================================================
	
他細かい調整
	
===============================================================*/
/*-------------------------------------------------------------
	スマホトップ：順番案内確認電話番号設置
-------------------------------------------------------------*/
.bluelink a {
	text-decoration: underline;
}
.bluelink a:hover {
	color: #1b46ac;
}

/* タブレット以下 */
@media screen and (max-width: 940px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.link_confirm_dial .normal_p {
	margin-top: 0;
}
.link_confirm_dial .normal_p a {
	width: 150px;
	margin: 10px auto 0;
	padding: 0 0 10px 0;
}
	
}	/* for SP max-width: 736px */



/*===============================================================
	
	about_operation
	
===============================================================*/
.about_operation {
	border: solid 1px #ddd;
	padding: 30px;
	position: relative;
}
.about_operation .title {
	text-align: center;
	display: block;
	font-size: 25px;
	line-height: 1;
	width: 10em;
	position: absolute;
	top: -12px;  left: 0; right: 0;
	margin: auto;
	background: #fff;
	color: #173887;
}
.about_operation .photo {
/*	float: left;*/
	float: right;
	width: 200px;
}
.about_operation .txt {
/*	padding-left: 220px;*/
	padding-right: 220px;
}
.about_operation .profile {
	margin-top: 20px;
}
.about_operation .profile h4 {
	font-size: 18px;
}
.about_operation .profile h4 + p {
	margin-top: 5px;
}
.about_operation .profile h5 {
	font-weight: bold;
	margin-top: 10px;
	color: #173887;
}
.about_operation .txtlink {
	margin-top: 20px;
/*	float: right;*/
	font-size: 14px;
}

/* タブレット以下 */
@media screen and (max-width: 960px) {

}/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.about_operation {
	padding: 20px;
}
.about_operation .title {
	font-size: 18px;
}
.about_operation .photo {
	float: none;
	width: 60%;
	margin: 10px auto 0;
	}
.about_operation .txt {
/*	padding-left: 0;*/
	padding-right: 0;
	margin-top: 20px;
}
.about_operation .txt p {
	font-size: 14px;
}
.about_operation .profile h4 {
	font-size: 16px;
}
.about_operation .txtlink {
	text-align: center;
}

}	/* for SP max-width: 736px */

/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {
.about_operation .title {
	font-size: 16px;
}
.about_operation {
	padding: 15px 10px;
}
	
}	/* for SP max-width: 320px */

/*===============================================================
	
緑内障手術調整
	
===============================================================*/
 .wide_img_box {
	margin-top: 25px;
}
.gridconatiner_mt2 {
	margin-top: -40px;
}
.wide_img_box .left {
	width: 65%;
	float: left;
	box-sizing: border-box;
}
.wide_img_box .right {
	float: right;
	width: 35%;
	box-sizing: border-box;
	padding-left: 40px;
}
.content_detail .subhead.extra {
	border-top: 0;
}
.content_detail .subhead.mt {
	margin-top: 50px;
}
	/* タブレット以下 */
@media screen and (max-width: 940px) {

}	/* for tablet max-width: 940px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
 .wide_img_box {
	margin-top: 15px;
}
.gridconatiner_mt2 {
	margin-top: 0;
}
.content_detail .subhead.extra {
	margin-top: 0;
	padding-top: 15px;
}
.content_detail .wide_img_box .normal_p {
	margin-top: 15px;
}
.content_detail .subhead.mt {
	margin-top: 0;
}
.wide_img_box .left {
	width: 100%;
	float: none;
}
.wide_img_box .right {
	float: none;
	width: 100%;
	padding-left: 0;
}
	
}	/* for SP max-width: 736px */

/*-------------------------------------------------------------
2018/6/28
-------------------------------------------------------------*/
.btn_detail.extra {
	margin-top: 20px;
	margin-bottom: 40px;
}
.btn_detail.btn_extra {
	border:solid 1px #173887;
	box-sizing: border-box;
	margin-top: 30px;
/*	box-shadow: 0 0 0;*/
}
.btn_detail.btn_extra a {
	color: #173887;
	background:#fff;
}
.btn_detail.btn_extra a:after {
	border-color: #173887;
}
.btn_detail.btn_extra a:hover {
	color: #fff;
	background:#173887;
	border-color: #fff;
}
.btn_detail.btn_extra a:hover:after {
	border-color: #fff;
}

.content_detail * + .normal_p.normal_p_extra {
margin-top: 50px;
}

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.btn_detail.btn_extra {
	margin-top: 15px;
	margin-bottom: 0;
}
.content_detail * + .normal_p.normal_p_extra {
margin-top: 15px;
}
}	/* for SP max-width: 736px */


/*===============================================================
	
  コロナ対策 20201130
	
===============================================================*/
.top_attention_libk {
	padding:10px;
	background:#36C;
	text-align: center
}
.top_attention_libk a{
	color: #fff; 
	display: block;
	text-decoration: none;
	font-size: 18px;
	line-height: 1.9;
	position: relative;
	max-width: 200px;
	margin: auto;
}
.top_attention_libk a:hover{
	text-decoration: underline;
}
.top_attention_libk a:after {
	position:absolute;
	content:"";
	width:7px;
	height:7px;
	top:0;
	bottom:0;
	right:0;
	margin:auto;
	border-top:solid 1px #fff;
	border-left:solid 1px #fff;
	-webkit-transform:rotate(135deg);
	-moz-transform:rotate(135deg);
	-ms-transform:rotate(135deg);
	transform:rotate(135deg);
}
/* タブレット以下 */
@media screen and (max-width: 960px) {

}	/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.top_attention_libk a{
	font-size: 14px;
	line-height: 1.6;
	max-width: 160px;
}
}	/* for SP max-width: 736px */



/*===============================================================
	
	診療のご案内 20260519
	
===============================================================*/

.medical_btnarea_block{
   display: flex;
   flex-wrap: wrap;
   gap: 30px; 
}

.medical_btnarea_block .btn_detail{
    width: calc((100% - 60px) / 3);
    max-width: 100%;
    margin: 0;
    margin-top: 0;
}
/* タブレット以下 */
@media screen and (max-width: 960px) {
.medical_btnarea_block{
   gap: 10px; 
}
.medical_btnarea_block .btn_detail{
   width: calc((100% - 20px) / 3);
}
.medical_btnarea_block .btn_detail a{
   font-size: 14px;
}

}/* for tablet max-width: 960px */

/* SP向けレイアウトの指定：～736px */
@media only screen and (max-width: 736px) {
.medical_btnarea_block .btn_detail{
   width: 100%;
}
/* .medical_fee_surcharge .normal_p{
   margin-top: 15px;
} */
.medical_fee_surcharge .section_table .section_inner{
   padding: 30px 20px 40px;
}

/* .medical_btnarea_block .btn_detail a{
   padding: 12px 0;
} */
        

}	/* for SP max-width: 736px */

/* SP向けレイアウトの指定：～320px */
@media only screen and (max-width: 320px) {

}	/* for SP max-width: 320px */
