@charset "utf-8";
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, 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 { margin: 0; padding: 0; background: transparent; border: 0; outline: 0; }
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary { display: block; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
:focus { outline: 0; }
ins { text-decoration: none; }
del { text-decoration: line-through; }
img { vertical-align: top; }
a, a:link { color: #040404; text-decoration: none; }
a:visited { color: #040404; }
a:hover { color: #040404; }
a:active { color: #040404; }
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body { color: #333; font-size: 13px; line-height: 1.5; text-size-adjust: none; -webkit-text-size-adjust: none; background-color: #FFF; }
#container { text-align: left; }
.fl { float: left; }
.fr { float: right }
img { width: 100%; vertical-align: middle; }
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader { padding: 0 6%; }
#gHeader .logo img { width: 230px; margin-top: 20px }
#gHeader .ss { line-height: 100px; border-left: 1px solid rgba(85, 121, 91, .1); width: 13%; text-align: right; position: relative; }
#gHeader .ss input[type="text"] { width: 90%; line-height: 30px; height: 30px; background: #fff; border: 1px solid #dedede; padding: 0 36px 0 6px; box-sizing: border-box; border-radius: 15px; overflow: hidden; }
#gHeader .ss .submi { width: 30px; height: 30px; background: url(../../images/ss1.png) no-repeat center; background-size: 24px; position: absolute; padding: 0; right: 4px; top: 35px; border: none; cursor: pointer; }
#gHeader .phone{font-size:22px;color:#000;margin-top:35px;}
/*------------------------------------------------------------
	gNavi
------------------------------------------------------------*/
#gNavi { width: 60%; }
#gNavi li { width: 12.5%; text-align: center; float: left; }
#gNavi li>a { line-height: 100px; display: block; font-size: 17px; position: relative; }
#gNavi li>a:before { content: ""; position: absolute; left: 40%; right: 40%; height: 3px; background: #fff; bottom: 22px; border-radius: 2px; display: none; }
#gNavi li.on>a { color: #fff; background: #21772e; }
#gNavi li.on>a:before { display: block; }
#gNavi li .drop { position: absolute; left: 0; top: 100px; right: 0; padding: 30px 8%; z-index: 100; background: #fff; border-top: 1px solid #efefef; display: none; }
#gNavi li .drop a { display: inline-block; padding: 6px 20px; background: #ededed; color: #555; font-size: 15px; margin: 5px 10px; border-radius: 5px; }
#gNavi li .drop a:hover, #gNavi li .drop a.on { background: #21772e; color: #fff; }
.container { width: 82%; max-width: 1440px; margin: 0 auto; box-sizing: border-box; }
.sec .title { padding: 40px 0 20px; position: relative; text-align: center; }
.sec .title span { display: block; width: 45px; height: 5px; margin: 0 auto 8px; border-radius: 3px; background: linear-gradient(to left, #21772e, #5ec56d); }
.sec .title h2 { font-size: 36px; font-weight: 500; margin: 10px 0; position: relative; display: inline-block; }
/*.sec .title h2:before { content: ""; position: absolute; left: -220px; top: 50%; transform: translateY(-50%); width: 204px; height: 27px; background: url(../images/titleLeft.png) no-repeat right center; background-size: cover; }
.sec .title h2:after { content: ""; position: absolute; right: -220px; top: 50%; transform: translateY(-50%); width: 204px; height: 27px; background: url(../images/titleRight.png) no-repeat left center; background-size: cover; }*/
.sec .title p { font-size: 15px; color: #666 }
.sec .more a { display: block; width: 140px; line-height: 40px; color: #fff; font-size: 15px; text-align: center; margin: 0 auto; border-radius: 25px; background: #3e8249; box-shadow: 0 0 10px rgba(85, 121, 91, .4); }
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter { background: url(../images/bg4.jpg) no-repeat center; background-size: cover; padding: 40px 0 20px; color: #666; font-size: 15px; }
#gFooter .nav { margin-bottom: 20px; overflow: hidden; }
#gFooter .nav a { display: block; width: 10%; float: left; text-align: center; font-size: 15px; border-right: 1px dashed #fff; box-sizing: border-box; line-height: 18px; }
#gFooter .nav a:last-child { border-right: none; }
#gFooter .box1 { width: 40% }
#gFooter dt { font-weight: 600; font-size: 20px; color: #333; line-height: 30px; margin-bottom: 20px; }
#gFooter dd { overflow: hidden; }
#gFooter dd a { display: block; width: 33.33%; float: left; line-height: 30px; }
#gFooter a { color: #666; }
#gFooter .box2 { width: 35%; }
#gFooter .box2 dd { line-height: 30px; }
#gFooter .ewm { width: 20%; padding: 0 20px; box-sizing: border-box; text-align: center; margin-top: 60px; }
#gFooter .ewm .img { display: inline-block; width: 48%; }
#gFooter .ewm p { font-size: 14px; margin-top: 8px; }
#gFooter .ewm img { max-width: 120px; }
#gFooter .power { border-top: 1px solid #f3f3f3; padding-top: 20px; margin-top: 40px; text-align: center; }
.fLink { margin-top: 35px; }
.fLink h3 { font-size: 20px; color: #333; line-height: 30px; margin-bottom: 10px; }
#gFooter .fLink a { display: inline-block; color: #8aaec5; padding: 0 8px; line-height: 20px; }
.sp { display: none !important; }
.fixed { position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 999; display: none; }
.fixed li { color: #fff; position: relative; margin-top: 10px; }
.fixed li span { background: rgba(0,0,0,.4); display: block; width: 44px; line-height: 44px; border-radius: 3px 0 0 3px; text-align: center; position: relative; z-index: 100; }
.fixed li span img { width: 26px; }
.fixed li.li .tex { width: 200px; z-index: 99; position: absolute; left: -44px; top: 0; line-height: 44px; font-size: 18px; background: rgba(0,0,0,.4); text-align: center; border-right: 1px solid rgba(255,255,255,.2); transform: translateX(200px); transition: 0.3s; }
.fixed li.li .tex a { color: #fff; }
.fixed li.li .tex img { width: 80%; margin: 20px 0; }
.fixed li.li:hover .tex { transform: translateX(-156px); }
.fixed li:hover span { border-radius: 0; }
.fixed li.return { cursor: pointer; }
@media all and (min-width: 1024px) and (max-width: 1600px) {
#gNavi li>a { font-size: 16px; }
#gFooter { font-size: 14px; }
#gFooter dt { font-size: 18px; margin-bottom: 10px; }
#gFooter .box1 { width: 40%; }
#gFooter .ewm { width: 28%; padding: 0 10px; }
#gFooter .ewm .img img { width: 80%; }
#gFooter .box2 { width: 32%; }
.fLink h3 { font-size: 18px; }
#gFooter .power { margin-top: 20px; }
.sec .title h2 { font-size: 34px; }
.sec .title h2:before { width: 180px; left: -200px; }
.sec .title h2:after { width: 180px; right: -200px; }
.sec .title span { width: 38px; height: 4px; }
}
 @media all and (min-width: 1024px) and (max-width: 1440px) {
#gHeader { padding: 0 4%; }
#gHeader .logo img { width: 240px; margin-top: 19px; }
#gNavi { width: 64%; }
.sec .title { padding: 25px 0 16px; }
.sec .title h2 { font-size: 32px; }
#gFooter .container { width: 90%; }
#gFooter .ewm { width: 28%; }
#gFooter .box2 { width: 32%; }
}
 @media all and (min-width: 1024px) and (max-width: 1400px) {
.container { width: 85%; }
}
 @media all and (min-width: 1024px) and (max-width: 1366px) {
#gFooter { font-size: 13px; }
}
 @media all and (min-width: 1024px) and (max-width: 1280px) {
#gHeader { padding: 0 2%; }
.container { width: 90%; }
#gHeader .ss { width: 16%; }
#gNavi { width: 58%; }
#gNavi li>a { font-size: 15px; }
}
 @media all and (min-width: 0) and (max-width: 767px) {
.sp { display: block !important; }
.pc { display: none !important; }
.fl { float: inherit; }
.fr { float: inherit }
#gHeader { padding: 8px 12px; }
#gHeader .logo img { width: 200px; margin-top: 0px }
#gHeader .sbtn { width: 30px; position: absolute; right: 60px; top: 24px; z-index: 100; }
#gHeader .ss { line-height: inherit; border-left: none; width: 100%; text-align: left; padding: 30px 20px; display: none; box-sizing: border-box; background: #fff; position: absolute; left: 0; top: 67px; border-top: 1px solid #efefef; right: 0; z-index: 100 }
#gHeader .ss input[type="text"] { width: 100%; line-height: 36px; height: 36px; background: #fff; padding: 0 36px 0 6px; border-radius: 5px; }
#gHeader .ss .submi { right: 24px; top: 32px; }
#gHeader .menu { width: 34px; height: 34px; position: absolute; right: 12px; top: 18px; background: url(../images/menu.png) no-repeat center; background-size: 26px; }
#gHeader .menu.on { background: url(../images/close.png) no-repeat center; background-size: 24px; }
/*------------------------------------------------------------
		gNavi
	------------------------------------------------------------*/
#gNavi { width: 100%; position: absolute; top: 67px; left: 0; right: 0; padding: 20px 0; z-index: 990; background: #fff; border-top: 1px solid #efefef; display: none; }
#gNavi li { width: 100%; text-align: left; padding: 0 20px; box-sizing: border-box; float: inherit; }
#gNavi li>a { line-height: 40px; padding: 0 20px 0 10px; font-size: 16px; border-bottom: 1px dashed #eaeaea; position: relative; }
#gNavi li>a:after { content: ""; width: 20px; height: 20px; position: absolute; right: 10px; top: 10px; background: url(../images/icon17.png) no-repeat center; background-size: 14px; }
#gNavi li.on>a:before { display: none; }
#gNavi li.on>a { color: #fff; background: #21772e; border-color: #21772e; }
#gNavi li.on>a:after { background: url(../images/icon19.png) no-repeat center; background-size: 14px; }
#gNavi li:nth-child(2).on>a:after, #gNavi li:nth-child(3).on>a:after, #gNavi li:nth-child(6).on>a:after, #gNavi li:nth-child(7).on>a:after { background: url(../images/icon18.png) no-repeat center; background-size: 14px; }
#gNavi li .drop { position: inherit; left: inherit; top: inherit; right: inherit; padding: 10px 0; z-index: 100; overflow: hidden; }
#gNavi li.on .drop { display: block; }
#gNavi li .drop a { display: block; float: left; width: 48%; margin: 4px 1%; padding: 0; text-align: center; line-height: 32px; }
#gNavi li .drop a:hover, #gNavi li .drop a.on { background: #21772e; color: #fff; }
.container { width: 100%; padding: 0 10px; }
.sec .title { padding: 24px 0 15px; overflow: hidden; }
.sec .title span { width: 36px; height: 4px; }
.sec .title h2 { font-size: 26px; margin: 8px 0; }
.sec .title h2:before { display: none }
.sec .title h2:after { display: none }
.sec .title p { font-size: 13px; }
.sec .more a { width: 130px; line-height: 34px; font-size: 14px; border-radius: 17px; }
/*------------------------------------------------------------
		フッター
	------------------------------------------------------------*/
#gFooter { padding: 40px 0px 20px; font-size: 13px; }
#gFooter .nav { margin-bottom: 20px; }
#gFooter .nav a { margin-bottom: 12px; width: 20%; font-size: 14px; }
#gFooter .nav a:nth-child(5n) { border-right: none; }
#gFooter .box1 { width: 100% }
#gFooter dt { font-size: 17px; margin-bottom: 12px; }
#gFooter .box2 { width: 100%; }
#gFooter .ewm { width: 100%; padding: 0px; margin: 20px 0; }
#gFooter .ewm img { max-width: 130px; }
#gFooter .power { padding-top: 10px; margin-top: 20px; }
.fLink { margin-top: 20px; }
.fLink h3 { font-size: 17px; }
}
