@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:normal;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}

/*================================================
 *  一般・共通設定
 ================================================*/
body {
	font-size: 14px;
	color: #333;
	font-family: "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
	line-height: 1.6;
	background-color: #fff;
}

body.fixed {
    width: 100%;
    height: 100%;
    position: fixed;
}

.header_info {
    width: 980px;
    margin-right: auto;
    margin-left: auto;
    padding: 0;
    display: grid;
    grid-template-columns: 240px auto auto;
    grid-template-rows: auto auto auto;
    grid-template-areas: 
        'g0 g0 g1' 
        'g2 g2 g2' 
        'g3 g4 g5';
}
.area-g0 {
    grid-area: g0;
    margin: 0;
    padding: 0;
}

.area-g1 {
    grid-area: g1;
    display: none;
}

.area-g2 {
    grid-area: g2;
    text-align: right;
    font-size: 12px;
    margin: 0;
    padding: 0;
}

.area-g2 > ul li {
    display: inline;
    height: 10px;
    padding: 0;
    margin: 0;
    padding: 0;
    padding-right: 4px;
    border-right: 2px solid #CCCC;
}

.area-g3 {
    grid-area: g3;
    margin-bottom: 5px;
    height: 100%;
}

.area-g3 h1 {
    width: 100%;
    height: 100%;
    text-align: left;
    vertical-align: bottom;
}

.area-g3 img {
    width: 90%;
    margin-top: 12px; /*下揃えにできない*/
}

.area-g4 {
    grid-area: g4;
    width: 100%;
    margin: 5px;
}

.area-g5 {
    grid-area: g5;
    width: 100%;
    display: flex;
    align-items: flex-end;
    margin-bottom: 4px;
    text-align: right;
    vertical-align: bottom;
}

.side_btn {
	height: 60px;
	margin-left: 4px;
}

.header_load {
	box-sizing: border-box;
	z-index: 10;
	position: fixed;
	top: 0;
	left: 0;
	width: 980px;
}

.h_list > ul{
    width: 980px;
    margin: 0 0 0 auto;
    display: flex;
}

.h_list > li {
    margin: 0 0 0 auto;
}
nav {
	width: 100%;
}

nav:after {
	content: '';
	display: block;
	clear: both;
}

nav > .gnav {
    width: 980px;
    height: 46px;
    margin-right: auto;
    margin-left: auto;
}

#contents {
	box-sizing: border-box;
	overflow: hidden;
	width: 980px;
	margin: 0px auto;
	padding: 0;
}

#main {
	box-sizing: border-box;
	overflow: hidden;
	float: left;
	width: 100%;
	padding: 10px;
	background: #fff;
}

.img_center {
    text-align: center;
}

#sub {
	box-sizing: border-box;
	overflow: hidden;
	float: right;
	width: 28%;
	padding: 10px;
	background: #fff;
}

#wide {
	box-sizing: border-box;
	padding: 10px;
	background: #fff;
}

footer {
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto;
}

a {
	color: #2a8064;
	text-decoration: underline;
}
a:hover {
	color: #2a8064;
	text-decoration: none;
}

h2 {
	padding: 30px 0;
	font-size: 26px;
	color: #2a8064;
	text-align: center;
	background: #e0e0e0;
}

h3 {
	margin: 0 0 0.5em 0;
	padding: 3px 5px;
	color: #fff;
	font-size: 16px;
	background: #3366cc;
}

h4 {
	margin-bottom: 0.25em;
	font-size: 20px;
	color: #000000;
	border-bottom: 3px solid #3366cc;
}

h5 {
	position: relative;
	margin-bottom: 0.25em;
	padding-left: 10px;
	color: #000000;
	font-size: 15px;
}
h5:before {
	content: "";
	margin-top: -8.8px;
	position: absolute;
	top: 50%;
	left: 0;
	width: 5px;
	height: 14px;
	background: #0066cc;
}

h6 {
	margin-bottom: 0.25em;
	font-size: 15px;
	color: #000000;
	border-bottom: 2px solid #3366cc;
}

p {
	margin: 0 0 1em 0;
}

p.text1 { font-size: large; }

em {
	font-weight: bold;
	color: #0000ff;
}

strong {
	font-weight: bold;
	color: #ff0000;
}

pre {
	margin: 1em 0;
	padding: 1em;
}

blockquote {
	margin-bottom: 1em;
	padding: 1em;
	border: 1px dotted #ddd;
	border-left: 5px solid #ddd;
}

ul,ol,dl {
	margin: 0 0 1em 0;
}

ol li {
	list-style: decimal;
}

li {
	margin-left: 2em;
}

ul.list1{
  padding: 0;
  width:100%;
  list-style: none;
}
ul.list1 li{
  position: relative;
  padding: 0.5em 1em 0.5em 2.3em;
  margin-bottom:5px;
  border-bottom: 1px solid rgba(129,194,250, 0.5);

}
ul.list1 li:after,
ul.list1 li:before{
  content: "";
  position: absolute;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
ul.list1 li:after{
  top: 0.7em;
  left: 0.2em;
  width: 12px;
  height: 12px;
  border:2px solid #4169e1;
}
ul.list1 li:before{
  top: 0.9em;
  left: 0.7em;
  width: 14px;
  height: 14px;
  background: #0099cc;
  -webkit-transform: rotate(60deg);
  -moz-transform: rotate(60deg);
  -o-transform: rotate(60deg);
  -ms-transform: rotate(60deg);
  transform: rotate(60deg);
}
  
dt {
	margin-bottom: 0.5em;
	border-bottom: 1px dotted #ddd;
}
dt:before {
	content: "\0025a0";
}
dd {
	margin-bottom: 0.5em;
	border-bottom: 1px dotted #ddd;
}

table {
	width: 100%;
	margin-bottom: 1em;
	border-collapse: collapse;
	border: 1px solid #ddd;
	background: #fff;
}

th {
	padding: 10px;
	text-align: left;
	vertical-align: middle;
	border: 1px solid #ddd;
	background: #0099cc;
	color: #FFF;
	width: 30%;
}
td {
	padding: 10px;
	text-align: left;
	border: 1px solid #ddd;
	width: 70%
}

#menu-btn-check {
    position: fixed;
    top: 0;
    left: 20px;
    display: content;
}

/*================================================
 *  ヘッダー
 ================================================*/
.inner {
	position: relative;
	width: 100%;
	height: auto;
	margin: 0 auto;
	box-sizing:border-box;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	align-items: center;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: censpace-betweenter;
	justify-content: space-between;
	padding: 0;
}

.summary {
	position: relative;
	margin: 0;
	padding-bottom: 5px;
	font-size: 12px;
}

.header_tel {
	line-height: 1.2;
    width: 100%;
}

.header_tel .phonenumber {
	font-size: 24px;
	font-weight: bold;
	line-height: 1.0;
}

.header_tel .open {
	font-size: 12px;
}

.header_require {
	margin: 0 20px;
}
.header_require a {
	display: block;
	padding: 10px 20px;
	color: #fff;
	font-weight: bold;
	border: 2px solid #3ebf96;
	border-radius: 5px;
	text-decoration: none;
	background: #3ebf96;
}
.header_require a:hover {
	color: #999;
	border: 2px solid #3ebf96;
	background: none;
}
.header_contact a {
	display: block;
	padding: 10px 20px;
	color: #fff;
	font-weight: bold;
	border: 2px solid #3ebf96;
	border-radius: 5px;
	text-decoration: none;
	background: #3ebf96;
}
.header_contact a:hover {
	color: #999;
	border: 2px solid #3ebf96;
	background: none;
}

/*================================================
 *  グローバルナビゲーション
 ================================================*/
@media print, screen and (min-width:768px) {
	nav {
		background: #3366cc;
		z-index: 3;
	}

	/* 共通 */
	nav ul {
		width: 980px;
    	justify-content: start;
        margin: 0;
		padding: 0;
	}

	nav ul li {
		position: relative;
		margin: 0;
		padding: 0;
		list-style: none;
	}

	nav ul li a {
		display: block;
		margin: 0;
		padding: 16px 0;
		background: #3366cc;
		color: #fff;
		font-size: 14px;
		font-weight: bold;
		line-height: 1;
		text-decoration: none;
	}

	nav ul li:hover > a {
		color: #fff;
		background: #3399cc;
	}

	/* 1段目 */
	nav ul.gnav > li {
		position: relative;
		width: 20%;
		float: left;
		margin: 0;
		padding: 0;
		text-align: center; 
		list-style: none;
	}

	nav ul.gnav > li:first-child {
		width: 20%;
	}

	nav ul.gnav > li.subnav a {
		padding-right: 20px;
	}

	nav ul.gnav > li.subnav > a:after {
		position: absolute;
		content: "";
		top: 20px;
		width: 0;
		height: 0;
		margin-left: 10px;
		border: 5px solid transparent;
		border-top-color: #fff;
	}

	/* 2段目 */
	nav ul li ul {
		position: absolute;
		z-index: 3;
		top: 100%;
		left: 0;
		width: 100%;
		margin: 0;
		padding: 0;
	}

	nav ul li ul li {
		overflow: hidden;
		width: 150%;
		height: 0;
		color: #fff;
		transition: .2s;
	}

	nav ul li ul li a {
		padding: 13px 15px;
		text-align: left;
		background: #3366cc;
		font-weight: normal;
	}

	nav ul li ul li a:hover {
		background: #3399cc;
	}

	nav ul li:hover > ul > li {
		overflow: visible;
		height: 40px;
		border-bottom: 1px solid #fff;
	}

	nav ul li:hover ul li:last-child {
		border-bottom: none;
	}

	nav ul.gnav > li:last-child > ul {
		left: -50%;
	}

	nav ul li ul li ul:before {
		position: absolute;
		content: "";
		top: 13px;
		left: -20px;
		width: 0;
		height: 0;
		border: 5px solid transparent;
		border-left-color: #fff;
	}

	nav ul.gnav > li:last-child ul li ul:before {
		position: absolute;
		content: "";
		top: 13px;
		left: 200%;
		margin-left: -20px;
		border: 5px solid transparent;
		border-right-color: #fff;
	}

	/* 3段目 */
	nav ul li ul li ul {
		top: 0;
		left: 100%;
	}

	nav ul li ul li ul li {
		width: 100%;
	}

	nav ul li ul li:hover > ul > li {
		border-bottom: 1px solid #464545;
	}

	nav ul.gnav > li:last-child > ul li ul {
		left: -100%;
	}

	nav ul li ul li ul li a {
		background: #3d3d3d;
	}

	nav ul li ul li ul li a:hover {
		background: #363535;
	}

	.gnav {
		display: block !important;
	}

	#spMenu {
		display: none;
	}
}

/*================================================
 *  トピックパス（パンくずリスト）
 ================================================*/
#topicpath {
	font-size: 12px;
	padding: 0;
	background: #fcfcfc;
}

#topicpath .inner {
	width: 980px;
	margin: 0 auto;
	padding: 10px;
	-webkit-justify-content: start;
	justify-content: start;
}

/*================================================
 *  サブコンテンツ
 ================================================*/
.submenu li {
	margin: 0;
	padding: 0;
	list-style: none;
}
.submenu li a:before {
	content: "\0025a0";
	color: #000;
}
.submenu li a {
	display: block;
	padding: 10px 2px;
	color: #000;
	border-bottom: 1px dotted #ddd;
	text-decoration: none;
}
.submenu li a:hover {
	background: #eee;
}

.bnr {
	overflow: hidden;
}
.bnr ul {
	overflow: hidden;
}
.bnr li {
	margin: 0 0 10px 0;
	padding: 0;
	list-style: none;
}
.bnr li a:hover {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}
.bnr img {
	width: 100%;
}

/*================================================
 *  フッター
 ================================================*/
footer {
	clear: both;
}

.footmenu {
	width: 100%;
	padding: 20px 0;
	overflow: hidden;
	background: #fff;
}
.footmenu ul {
	position: relative;
	float: left;
	left: 50%;
	margin: 0;
	padding: 0;
}
.footmenu li {
	position: relative;
	left: -50%;
	float: left;
	list-style: none;
	margin: 0;
	padding: 0 15px;
	font-size: 12px;
	text-align: center;
}
.footmenu a {
	color: #333;
	text-decoration: none;
}
.footmenu a:hover {
	color: #2a8064;
	text-decoration: underline;
}

.copyright {
	clear: both;
	padding: 20px 0;
	font-size: 11px;
	text-align: center;
	color: #efede9;
	background: #3366cc;
}

/*================================================
 *  ページトップへの戻り
 ================================================*/
.totop {
	position: fixed;
	bottom: 15px;
	right: 15px;
}
.totop a {
	display: block;
	text-decoration: none;
}
.totop img {
	background: #666;
}
.totop img:hover {
	background: #555;
}

/*================================================
 *  クラス
 ================================================*/
.list {
	padding: 0 0 0 0.5em;
}
.list li {
	margin: 0;
	padding: 0 0 0 15px;
	list-style: none;
	background: url(../images/check.png) 0 5px no-repeat;
}

.info dt {
	border-bottom: none;
}
.info dd {
	padding-bottom: 1em;
	border-bottom: 1px solid #ddd;
}

.col_two_one {
	overflow: hidden;
}

.col_two_one ul {
	overflow: hidden;
	margin: 2% -2% 0 0;
}
.col_two_one li {
	list-style: none;
	float: left;
	width: 48%;
	margin: 0 2% 2% 0;
}
.col_two_one li:nth-child(2n+1) {
	clear: both;
}
.col_two_one li img {
	width: 100%;
	margin-bottom: 2.5%;
}

.pmargin{
	text-indent:1em;
}

.DivLink{
    position:relative;
    width:100%;
    height:96px;
    background-color:#fffbb6;
    border:1px solid #ff6a00;
}

.DivLink .Link{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*================================================
 *  スライドショー
 ================================================*/
/* スライドショー */
.slide {
	display: none;
	position: relative;
	overflow: hidden;
}

.slidePrev {
	position: absolute;
	cursor: pointer;
	z-index: 2;
}

.slideNext {
	position: absolute;
	cursor: pointer;
	z-index: 2;
}

.slidePrev img {
	position: absolute;
	width: 50px !important;
	height: 60px !important;
}

.slideNext img {
	position: absolute;
	width: 50px !important;
	height: 60px !important;
}

.slideInner {
	position: relative;
	margin: 0 0 5px 0;
	padding: 0;
}
.slideInner li {
	float: left;
	margin: 0;
	padding: 0;
	list-style: none;
}
.slideInner li img {
	margin: 0 5px;
	padding: 0;
}

.filterPrev {
	position: absolute;
	left: 0;
	opacity: 0.5;
	filter: alpha(opacity=50);
	background-color: #fff;
}

.filterNext {
	position: absolute;
	right: 0;
	opacity: 0.5;
	filter: alpha(opacity=50);
	background-color: #fff;
}

.controlNav {
	position: relative;
	float: left;
	left: 50%;
}
.controlNav span {
	position: relative;
	left: -50%;
	float: left;
	margin: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	width: 10px;
	height: 10px;
	overflow: hidden;
	background: #ccc;
	text-indent: -9999px;
	vertical-align: middle;
}
.controlNav span:hover {
	background: #999;
	cursor: pointer;
}
.controlNav span.current {
	background: #3ebf96;
}

/*================================================
 *  タブレット向けデザイン
 ================================================*/
/* スクロールバーを考慮して20px大きいサイズで切り替え */
@media screen and (max-width:979px) {
	header > .inner {
		padding: 0 10px;
	}

	.inner {
		width: 100%;
	}

	#contents {
		width:100%;
		margin: 10px 0;
		padding: 0 10px;
	}

	#wide {
		width:100%;
		margin: 10px 0;
		padding: 10px;
	}

	#topicpath .inner {
		width: 100%;
	}

	footer {
		width: 100%;
	}
}

/*================================================
 *  スマートフォン向けデザイン
 ================================================*/
@media screen and (max-width:767px) {
	.lock {
		position: fixed;
		z-index: -1;
		width: 100%;
		height: 100%;
		top: 0;
		right: 0;
	}

	header {
        padding-top: 15px;
        padding-left: 10px;
        padding-right: 10px;
        padding-bottom: 0;
	}

	header > .inner {
		display: block;
		padding: 0;
	}

    .footmenu {
        display: none;
    }

	h1 {
        width: 100%;
		margin-bottom: 10px;
	}

    img {
        width: 100%;
        vertical-align: bottom;
    }

	.summary {
		margin-right: 40px;
		font-size: 10px;
	}

	.header_tel .phonenumber {
		font-size: 18px;
	}

	.header_tel .open {
		font-size: 10px;
	}

	nav > .gnav {
        display: none;
    }

	#main {
		float: none;
		width: 100%;
	}

    #contents {
        margin: 0;
    }

	.header_info {
		width: 100%;
		margin: auto;
		display: grid;
		grid-template-columns: auto auto auto;
		grid-template-rows: auto auto 72px;
		grid-template-areas:
			'g0 g1 g1'
			'g3 g4 g4';
	}
    .area-g0 {
        width: 250px;
        margin: 0;
        padding: 0;
        text-align: left;
        font-size: 8px;
        word-wrap: break-word;
    }
    .area-g1 {
        grid-area: g1;
        display: contents;
    }
    .area-g2{
        display: none;
    }
    .area-g3 {
        margin: 0;
        padding: 0;
        vertical-align: bottom;
    }
    .area-g3 img {
        margin: 0px;
    }
    .area-g5 {
        grid-area: g4;
        width: 100%;
    }
    .area-g5 > .header_tel {
        width: 100%;
        text-align: right;
        margin-right: 10px;
    }
    .area-g4{
        display: none;
    }

    /*----------------------------
    * メニュー開閉ボタン
    *----------------------------*/
    .menu-btn {
        position: fixed;
        top: 5px;
        right: 20px;
        display: flex;
        height: 14px;
        width: 14px;
        justify-content: center;
        align-items: center;
        z-index: 90;
        border-radius: 50px;
        background-color: #3366CC;
    }
    .menu-btn span,
    .menu-btn span:before,
    .menu-btn span:after {
        content: '';
        display: block;
        height: 3px;
        width: 20px;
        border-radius: 3px;
        background-color: #ffffff;
        position: absolute;
    }
    .menu-btn span:before {
        bottom: 8px;
    }
    .menu-btn span:after {
        top: 8px;
    }

    /*----------------------------
    * メニュー本体
    *----------------------------*/
    .menu{
        position: fixed;
        top: 0;
        right: 0;
        z-index: 1;
        width: 90vw;
        height: 100vh;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        background: #CCCCCC;
    }
    .menu a {
        display: block;
        padding: 12px;
        text-decoration: none;
        color: #fff;
        font-size: 18px;
        padding-bottom: 2px;
        margin-bottom: 2px;
    }
    label {
        display: block;
        margin: 0 0 4px 0;
        padding : 12px;
        line-height: 1;
        color :#fff;
        background : #3366CC;
        cursor :pointer;
        font-size: 18px;
    }
    
    input {
        display: none;
    }
    
    .menu ul {
        margin: 0;
        padding: 0;
        background :#3399CC;
        list-style: none;
    }
    
    .menu li {
        height: 0;
        overflow: hidden;
        -webkit-transition: all 0.5s;
        -moz-transition: all 0.5s;
        -ms-transition: all 0.5s;
        -o-transition: all 0.5s;
        transition: all 0.5s;
    }
    
    /* ハンバーガーメニューの項目追加/削除はここを修正 */
    #menu_bar01:checked ~ #links01 li,
    #menu_bar02:checked ~ #links02 li,
    #menu_bar03:checked ~ #links03 li,
    #menu_bar04:checked ~ #links04 li {
        height: 42px;
        opacity: 1;
    }
    .menu__item{
        width: 100%;
        height: auto;
        text-align: center;
        color: #fff;
        box-sizing: border-box;
        background-color: #3366CC;
        margin-bottom: 2px;
    }

    /*----------------------------
    * アニメーション部分
    *----------------------------*/

    /* アニメーション前のメニューの状態 */
    .menu{
        transform: translateX(100vw);
        transition: all .2s linear;
    }
    /* アニメーション後のメニューの状態 */
    .menu.is-active{
        transform: translateX(0);
    }
}
