@import url("//share.cr-cms.net/hp_agency/hpagency.css");
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700|Noto+Sans:400,700|Noto+Serif+JP:400,700|Noto+Serif:400,700&subset=japanese');

/* ジャパニーズ01 グリーン 右メイン */

/*-------------------------------------------
Common
-------------------------------------------*/


.pc{display:inline;}
.sp{display:none;}

.ta_c{text-align:center !important;}
.ta_r{text-align:right !important;}
.ta_l{text-align:left !important;}

.mb0{margin-bottom: 0px !important;}
.pb0{padding-bottom: 0px !important;}
.m_auto{margin-left: auto; margin-right: auto;}

.fw_b{font-weight: bold;}

.mt10{margin-top: 10px !important;}
.mb10{margin-bottom: 10px !important;}
.mt20{margin-top: 20px !important;}
.mb20{margin-bottom: 20px !important;}
.mt20{margin-top: 20px !important;}
.mb20{margin-bottom: 20px !important;}
.mt30{margin-top: 30px !important;}
.mb30{margin-bottom: 30px !important;}
.mt40{margin-top: 40px !important;}
.mb40{margin-bottom: 40px !important;}

.ml10{margin-left: 10px !important;}
.mr10{margin-right: 10px !important;}
.ml20{margin-left: 20px !important;}
.mr20{margin-right: 20px !important;}

.pt10{padding-top: 10px !important;}
.pb10{padding-bottom: 10px !important;}
.pt20{padding-top: 20px !important;}
.pb20{padding-bottom: 20px !important;}
.pt20{padding-top: 20px !important;}
.pb20{padding-bottom: 20px !important;}
.pt30{padding-top: 30px !important;}
.pb30{padding-bottom: 30px !important;}
.pt40{padding-top: 40px !important;}
.pb40{padding-bottom: 40px !important;}

body{ min-width: 1024px; overflow-x: auto;}

body,
#mainContents{
 	font-size: 16px;
 	line-height: 1.8;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400;
	font-feature-settings : "palt";
	letter-spacing: 0.5px;
  	color:#444;
}
.article img{
    max-width:100%;
}
*:first-child+html h1, h2, h3{
    font-family: "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
    font-weight: normal;
}

/*------------------------
header telLink
-------------------------*/
#sideContents .freeHtml #headerLink {
    position: absolute;
    top: -704px;
    /*--right: 115px;--*/
    left: 0; right: 0;
    margin-left: auto;
    margin-right: auto;
    z-index: 8;
    /*--width: 400px;
    text-align:center;--*/
    width: 1024px;
    height: 110px;
    text-align: right;
    padding-top: 10px;
    color: #444;

    
    /* overflow: hidden; */

}
#sideContents .freeHtml #headerLink a {
    display: block;
/*    background: url("/materials/158942345583601.png") no-repeat left center;*/
    background-size: 34px;
    font-size: 34px;
    font-family: "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", HGS明朝E, "ＭＳ Ｐ明朝", serif;
    /*--color: rgb(228, 91, 0);--*/
    color: #037d44;
    line-height: 1.35em;
    position:relative;
}
/*--
#sideContents .freeHtml #headerLink a:before {
    content: "";
    background: url(/materials/158942345583601.png) no-repeat left center;
    width: 38px;
    height: 38px;
    background-size: contain;
    margin-right: 8px;
    display: inline-block;
    position: relative;
    top: 4px;
}--*/
#sideContents .freeHtml #headerLink span {
    color: #555;
    display: block;
    line-height: 1.4em;
}
#sideContents .freeHtml #headerLink span.time {
    font-size: 13px;
    letter-spacing: 0em;
}

body.body-media-pc.ams-build #sideContents .freeHtml #headerLink {
    position: unset;
    width: auto;
    height: auto;
}

/*-------------------------------------------
Wrap
-------------------------------------------*/
#wrap {
/*
    width: 100%;
    position: relative;
    _overflow-x: hidden;
    top: 0;
    margin-top: -76px;
*/
top:0;

}
.ams-build #wrap{
/*    margin-top:0;*/
}
/*
#wrap {
    border-top: 25px solid #444;
  	min-width: 1024px;
}
#wrap_body {
    padding-top: 220px;
}
*/

/*-------------------------------------------
Box
-------------------------------------------*/
.box {
    position: relative;
    margin: 1em 0;
    padding: 1em 1em 0.5em;
    border: solid 3px #037d44;
    border-radius: 2px;
}
.box .box-title {
    position: absolute;
    display: inline-block;
    top: -12px;
    left: 10px;
    padding: 0 9px;
    line-height: 1;
    font-size: 16px;
    background: #FFF;
    color: #037d44;
    font-weight: bold;
}
.mainArticles .article .box p{
    margin-bottom:0;
} 
/*-------------------------------------------
column
-------------------------------------------*/
.col{
    display:flex;
}
.col_item{
    text-align:center;
    box-sizing:border-box;
}

.col_item p{text-align: left;}

.flexWrap{
    flex-wrap:wrap;
}
.spaceBetween{
    justify-content: space-between;
}
.col_2 .col_item{
    width:48%;
}
.col_3 .col_item{
    width:32%;
}

.card{
    border:solid 1px #ccc;
    padding:14px 10px;
}

.card-heading{
    padding-bottom:10px;
    margin-bottom:10px;
    border-bottom:solid 1px #ccc;
}

.card-heading img{width: 100%;}

.card-content{
    font-size:88%;
    text-align: left;
}

.policy .card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 14px 10px;
    background: #EAE6DB;
    box-shadow: 5px 5px 0 #e8ecef;
    border: solid 3px #9C8C86;
    font-weight: bold;
    color: #2C1F13;
}
.policy .card-content{
    text-align:center
}
/*-------------------------------------------
Link
-------------------------------------------*/
a {
	color: #39E;
	text-decoration: underline;
  	font-weight: normal;
}
a:hover {
	color: #f2ae35;
	text-decoration: none;
}
a img {
	text-decoration:none;
	border:none;
}
#title h1:hover,
#mainArticles a:hover img,
#sideBanners  a:hover img,
div.freeHtml a:hover img,
div.image img.gallery:hover,
#slider .slick-slide a:hover img {
  filter: alpha(opacity=75);
  -moz-opacity:0.75;
  opacity:0.75;
}


/*-------------------------------------------
Image
-------------------------------------------*/
#mainArticles img {
	border-radius: 1px;
}
.mainArticles .article .article_center .image,
.mainArticles .article .article_center .image img {
/*	max-width: 1024px;*/
}
.mainArticles .article img {
    margin: 0 0 15px;
}
.mainArticles .article_left .image {
    margin: 0 40px 0 0;
}
.mainArticles .article_right .image {
    margin: 0 0 0 40px;
}

/*-------------------------------------------
Title
-------------------------------------------*/
#title{
    width:100%;
    height: 137px;
    text-align:left;
    /*--background: url(/materials/158797941334001.jpg) repeat;--*/
    background: #fff;
    border-top: #037d44 5px solid;
    top:0;
}
div#title_outer {
/*    background:url('/materials/158755923209001.png') no-repeat right 10px;*/
    background-size:280px;
    /*--padding: 20px;--*/
    width: 1024px;
    margin: 0 auto;
/*
    padding: 14px;
    background: rgba(255,255,255,0.8);
*/
}
#title_body {
    padding-top: 0;
}
#title h1 a{
    margin-top: 20px;
    display:block;
    width: 390px;
    height: 90px;
    text-indent: -120%;
    overflow:hidden;
    background:url('/materials/177925583927901.jpg') no-repeat center;
    background-size:contain;
}
#title .description{
    color: #625d50;
    text-align: right;
    position: absolute;
    top: 12px;
    width: 1024px;
}
/*
#title{
    padding: 0;
    width: 100%;
  	min-width: 1024px;
    background: #333;
    height: 160px;
    position: absolute;
    top: 0;
}
#title_outer{
	height:auto;
	width: 1024px;
	margin:auto;
	background: url(/materials/155376820275002.png) no-repeat bottom right;
	padding-top: 5px;
}
ロゴ
#title h1 {
	margin: 20px 0 0;
	padding: 0;
	text-align: left;
	height: 110px;
	width: 360px;
}
#title h1 a {
	background: url(/materials/155376820275001.png) no-repeat scroll 0 0 / contain;
	display: inline-block;
	overflow: hidden;
	text-indent: 110%;
	white-space: nowrap;
	height: 100%;
	width: 100%;
}
#title .description {
    color: #CCC;
    font-size: 87.5%;
    margin: 0;
    padding: 20px 0 0 4px;
    text-align: left;
    letter-spacing: 0.5px;
    position: absolute;
    top: -45px;
}
*/

/*-------------------------------------------
Mainimage
-------------------------------------------*/
#mainImage {
/*
    margin-bottom: 0;
    width: 100%;
    min-width: 1024px;
    position: relative;
    min-height:400px;
*/
position: relative;
}
#mainImage_body img {
    width: 100%;
    height: 527px;
    object-fit: cover;
}
div#mainImage_outer {
/*    position: fixed;*/
    width:100%;
}
#mainImage_body{
    width:100%;
}
.mainImage img {
    width: 100%;
	min-width:1024px;
}
/*スライド*/
#slider .slick-slide {
	display: flex;
	justify-content: center;
}
.mainImage #slider li {
	height: auto !important;
}
.mainImage #slider li img {
	max-width: 100%;
	min-width: 1024px;
}

/*-------------------------------------------
Topmenu
-------------------------------------------*/
#topMenu{
    min-width: 1024px;
    height: auto;
    /*--padding-top: 80px;--*/
}
#topMenu_body{
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
#topMenu_outer{
    width: 100%;
    box-sizing: border-box;
    background: #037d44;
}
#topMenu .topMenu li.first {
    background: none;
    margin: 0;
}
#topMenu .topMenu li.first a {
    background-color: #fff;
    background: none;
    padding: 0;
    margin: 0;
}
#topMenu .topMenu li a{
    font-size: 14px;
    letter-spacing: 0.1em;
    color: #fff;
    font-weight: bold;
}
html #topMenu .topMenu li[class]{
    border:0;
    margin: 0;
    height: auto;
    width: auto;
    float: none;
}
html #topMenu .topMenu li[class] a{
    height: auto;
    width: 170px;
    padding: 1.5em 0;
}

#topMenu .topMenu li a:hover {
  color: #037d44;
  background: #bde0cc;
}

/*-------------------------------------------
contents
-------------------------------------------*/
#contents {
    background: #fff;
    margin: auto;
    padding: 0;
    width: 100%;
   	min-width: 1024px;
	box-sizing:border-box;
}
#contents_outer{
    padding-top: 30px;
}
body.index-page #contents_outer{
    padding-top: 10px;    
}
#mainContents {
    margin-top:0;
/*    width: 1024px;*/
}
.article p {
    margin-bottom: 0.8em;
}
.article p.ib {
    display: inline-block;
}
.article strong {
    /*display:inline-block;*/
    font-size:110%;
/*    color:#3BAA00;*/
    color:#f91515;
    font-weight: bold;
	/*padding: 0 0.2em;*/
}
.article u {
    font-size: 115%;
    padding-bottom: 2px;
    text-decoration: none;
    border-bottom: 1px solid;
}
.article, #mainTopics #mainTopics_body, .gallery .article_body{
    margin-bottom: 10px;
    padding-top:0;
    padding-bottom: 10px;
    overflow: visible;
  	border: none;
}
body.index-page #mainTopics_body>h2{
    margin-top:0;
}
#mainArticles, .mainArticles .article, .mainArticles div.gallery, 
#mainTopics, #listTopics ,#mainServices , #mainServices .services {
	width: 100%;
}

.mainTopics .topics {
    overflow: hidden;
    margin-top: 0;
}
/*-------------------------------------------
Heading
-------------------------------------------*/
.heading{
    font-size:26px;
    font-weight:bold;
}
/*h2*/
#mainArticles h2::after, #mainServices h2::after {
    position: absolute;
    bottom: -4px;
    left: 40%;
    z-index: 2;
    content: '';
    width: 20%;
    height: 4px;
    background: #037d44;
}
#mainArticles .article_body h2:after{
    display:none;
}
#mainArticles h2, #mainServices h2, #mainTopics h2, #listTopics h2 {
    position: relative;
    padding: 10px 0 20px;
    border-bottom: 4px solid #FFF;
    font-size: 170%;
    text-align: center;
    color: #037d44;
    margin: 20px 0 30px;
    background: none;
    line-height: 1.5;
    font-weight: normal;
    letter-spacing: 0.15em;
}
#mainArticles .article_body h2{
    font-size: 26px;
    color: #037d44;
    text-align: left;
    letter-spacing: 0.1em;
}
#mainTopics h2,
#mainArticles .article h3,
.mainContents div.gallery h3,
#listTopics h2{
    text-align: left;
    border-top: 0;
    padding-top: 0;
    padding-bottom: 0;
}

/*h3*/

#mainArticles .article h3, .mainContents div.gallery h3, .mainServices h2, #mainTopics h2, #listTopics h2 {
    margin-bottom: 30px;
    letter-spacing: 0.15em;
    background: url(/materials/177934766814001.png) no-repeat left center;
    padding-left: 30px;
    font-size: 22px;
    color: #037d44;
    border-bottom: #037d44 solid 2px;
}
.mainContents .article h3 a {
/*    color: #FFF;*/
}
/*h4*/
.mainContents .article h4 {
    position: relative;
    padding: 2px 0 2px 20px;
    line-height:1.5;
    font-size: 110%;
    text-align: left;
    margin: 20px 0 20px;
    color: #037d44;
    overflow: hidden;
    border-left: solid 6px #037d44;
}
/*h5*/
.mainContents .article h5::before {
    position: absolute;
    left: 0;
    top: 10%;
    content: '';
    width: 5px;
    height: 80%;
    background-color: #037d44;
}
.mainContents .article h5 {
    color: #037d44;
    font-size: 125%;
    margin: 30px 0 15px;
    padding: 4px 5px 6px 18px;
    line-height: 1.5;
    overflow: hidden;
/*    text-shadow: 1px 1px 1px #B92;*/
	position: relative;
}

/*-------------------------------------------
Side
-------------------------------------------*/
#sideContents {
    padding-top:0;
    /*--background: url(/materials/158797941334001.jpg) repeat;--*/
    background: #eee;
}
#sideContents_outer {
/*	width: 1024px;*/
/*	padding: 30px 0 10px;*/
/*	position: relative;*/
}

/*SideMenu*/
#sideServices_outer{
    background:none;
}
#sideServices h2{
    color: #745B4B;    
}
.sideServices h2 {
	font-size: 18px;
	color: #333;
}
.sideServices ul li a {
	font-size: 16px;
}
/*SideBlogs*/
.sideBlogCategories h2, .sideBlogDates h2 {
	font-size: 18px;
	color: #333;
}
.sideBlogCategories a, .sideBlogDates a {
	font-size: 16px;
}
/*SideMobile*/
.sideMobile h2 {
	font-size: 18px;
	color: #333;
}
.sideMobile p {
	font-size: 16px;
}


#sideContents .sideServices a {

}

/*SideContact*/
#sideContact {
/*    display: none;*/
}
/*--
#sideContents a{
    color: #fff;
}
#sideContents a:hover {
    color: #69dfff;
}--*/
/*sideBanners*/
#sideBanners {
    margin: 0;
    padding: 20px 0;
    box-sizing: border-box;
    background: rgba(228, 91, 0,0.25);
}
#sideBanners li {
    margin-bottom: 25px;
    text-align: center;
    margin: 0 auto;
}
#sideBanners li img {
    padding: 0px;
    background-color: #FFF;
}
/*FreeHTML*/
.freeHtml {
	font-size: 100%;
  	min-height: 1px;
}
.freeHtml_outer {
	padding: 0;
	/* background-color: #a3a8b2;*/
}

.side-logo {
    text-align: center;
    margin-top: 20px;
}
.side-logo img {
    width: 100%;
}
.side-text{
  	/*--text-align:center;--*/
    padding: 20px 16px;
    color: #333;
    font-size: 14px;
}

.side-text h3{
    width: 100%;
    min-width: fit-content;
    margin-bottom: 10px;
    padding: 10px;
    background: #fff;
    box-sizing: border-box;
    border: 1px solid #037d44;
}

.side-text h3::before{content: "■"; color: #037d44; margin-right: 5px;}

.shop-title{
    padding: 0 0 10px;
}
.shop {
    padding-bottom: 10px;
    font-weight: bold;
    font-size: 18px;
}
.add {
    padding: 10px 0;
    border-top: 1px solid #ccc;
}
.tel {
    border-top: 1px solid #ccc;
    padding-top: 20px;
}
.tel a {
    font-size: 20px;
    font-weight: normal;
}
.time{
}
#sideContents .text-link {
    background: #e45b00;
    text-decoration: none;
    padding: 10px 20px;
    color: #fff;
}
#sideContents .text-link:hover{
    color:#fff;
    opacity: 0.7;
}

table.sideTbl{
    background:none;
    color:#333;
}

table.sideTbl td {
    border-bottom: solid 1px #ccc;
    padding: 14px 0;
    font-size: 14px;
}

#sideServices {
    background: none;
    width: 100%;
}
.sideServices ul {
width: 230px;
    overflow: hidden;
    padding: 6px 20px 20px;
    background-color: #f5f5f5;
    box-sizing: border-box;
    margin: 0 auto;
}
html #sideContents .sideServices ul li{
    background:none;
    border-bottom: 1px solid #999;
}
html #sideContents .sideServices ul li a{
    color: #C4854D;
}
html #sideContents .sideServices ul li a:hover {
    filter: alpha(opacity=60);
    -moz-opacity: 0.60;
    opacity: 0.60;
}
#sideMobile {
    width: 100%;
    text-align: center;
}
#sideContact,
#sideFeed a, #sideContact a {
    width: 100%;
}

#sideBanners,
.sideBanner_body{
    width:100%;
}
/*-------------------------------------------
Footer
-------------------------------------------*/
.footer * {
    font-size: 16px;
}
#footer {
    /*--background: url(/materials/158797941334001.jpg) repeat;--*/
    background: #037d44;
	padding: 30px 0 10px;
   	min-width: 1024px;
}
#footer_outer {
	width: 1024px;
	margin: 0 auto;
}
.footer li a::before {
    color: #FFF;
    font-size: 65%;
    margin-right: 15px;
    transform: scaleX(0.75);
    display: inline-block;
    vertical-align: top;
}
.footer li a {
	color: #FFF;
	display: inline-block;
	padding-left: 0;
	font-size: 16px;
  	font-weight: normal;
}
#footer .footer .topMenu li a:hover, 
#footer .footer .services li a:hover, 
#footer .footer .copyright a:hover {
    color: #edc000;
/*    text-decoration: underline;*/
}
.footer .topMenu {
	width: 100%;
}
.footer .topMenu li {
    margin-right: 26px;
    width: auto;
    padding: 0;
    float: left;
}
.footer .topMenu li:last-of-type{
    margin-right:0;
}
html .footer .topMenu li a{
    color: #fff;
}
html .footer .topMenu li a:hover {
    filter: alpha(opacity=60);
    -moz-opacity: 0.60;
    opacity: 0.60;
}
.footer .topMenu li a::before {
    content: "\025b6";
    color: #fff;
}
.footer .services {
	background: none;
	display: block;
  	margin: 10px 0 0;
}
.footer .services li {
    margin-right: 50px;
    float: left;
    width: 20%;
    padding: 0;
    margin: 0;
}
.footer .services li a {
    color: #666;
    font-size: 13px;
    display: block;
    text-align: left;
}
.footer .services li a::before {
    content: "\025b6";
    color: #999;
}
.footer .copyright {
	padding: 0;
	text-align: right;
}
.footer .copyright ,
.footer .copyright a {
color: #fff;
	font-size: 12px;
}
.footer .copyright a:hover {
	text-decoration: none;
	color: #CCC;
}

#footer li a{color: #fff;}

/*-------------------------------------------
Topics
-------------------------------------------*/
#mainTopics ,
.mainTopics .topics {
    border: none;
}
#mainTopics .topics li{
    margin-bottom: 50px;
}
#mainTopics .topics li p.date ,
#listTopics .topics li p.date {
    font-size: 14px;
    color: #999;
}
.mainTopics .topics {
	width: 100%;
  	padding: 0;
}
#mainTopics .topics li h3 ,
#listTopics .topics li h3 {
    font-size: 18px;
    font-weight: normal;
}
.mainTopics .topics li h3 a{
    color: #666;
}
.mainTopics .topics li h3 a:hover{
    opacity: 0.6;
}
#mainTopics .topics li p.description ,
#listTopics .topics li p.description {
    color: #999;
    font-size: 16px;
}
#mainTopics .listview {
     font-size: 14px;
     border: 0;
}
#mainTopics .listview a{
        width: 30%;
    padding: 8px 0;
    display: inline-block;
    text-align: center;
    font-size: 14px;
    border: solid 1px #037d44;
    color: #fff;
    background: #037d44;
    border-radius: 30px;
}
#mainTopics .listview a:hover{
    background: #037d44;
    text-decoration: none;
    opacity: 0.6;
}
/*thumb*/
#mainTopics .topics li .thumb {
    max-width: 120px;
    max-height: 90px;
    margin-right: 30px;
}
#mainTopics .topics li .thumb img {
    max-width: 120px;
    max-height: 90px;
}
/*moreBtn*/
.mainTopics .topics li .more a {
    padding: 6px 10px;
    text-decoration: none;
    color: #037d44;
    font-size: 14px;
    border: 1px solid #037d44;
    margin-right: 10px;
}
.mainTopics .topics li .more a:hover {
    background: rgba(228, 91, 0,0.25);
}

/*-------------------------------------------
Table
-------------------------------------------*/
/*標準*/
table {
    border-collapse: collapse;
    border-spacing: 0;
	background-color: #FFF;
    width: 100%;
}
table th ,
table td {
	line-height: 1.5;
}
.article table p ,
.article table img {
	margin: 0;
}
/*縞々*/
.stripe table tr:nth-child(even) {
	background: #F7F7F7;
}
/*汎用*/
table.normalTbl {
    border-left: 1px solid #037d44;
    border-top: 1px solid #037d44;
    margin: 10px 0;
}
table.normalTbl th {
    background: #bde0cc;
    width:30%;
	height: auto;
	line-height: 150%;
	padding: 20px;
	text-align: center;
	vertical-align: middle;
	border-bottom: 1px solid #037d44;
/*	border-right: 1px solid #DDD;*/
    font-weight:normal;
    color: #037d44;
}
table.normalTbl td {
	border-bottom: 1px solid #037d44;
	border-right: 1px solid #037d44;
	height: auto;
	line-height: 150%;
	padding: 20px;
}
table.normalTbl.whalf {
	width: 55%;
}

/*汎用2*/
table.normalTbl2 {
  	width: 100%;
    border: none;
    margin: 0;
	background: #FFF;
}
table.normalTbl2 thead th {
	background: #DDD;
}
table.normalTbl2 th ,
table.normalTbl2 td {
	padding: 15px;
	vertical-align: middle;
	border-bottom: 1px solid #CCC;
}
table.normalTbl2 th {
	text-align: left;
    font-weight: normal;
}
table.normalTbl2.whalf {
	width: 55%;
}

/*下線のみバージョン*/
table.normalTbl.underLine {
    border: none;
}
table.normalTbl.underLine th ,
table.normalTbl.underLine td {
    border-bottom: 1px dashed #ccc;
    border-right: none;
}
/*フローテーブル*/
table.flow {
    border: none;
    margin: 10px auto;
    width: 100%;
}
table.flow td {
    background: #FFF;
    border: 1px solid #6CD;
    display: block;
    padding: 20px;
    position: relative;
    margin-bottom: 35px;
    background: #FFF;
}
table.flow td::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-top: 18px solid #6CD;
    border-right: 25px solid transparent;
    border-left: 25px solid transparent;
}
table.flow tr:last-child td::after {
    display:none;
}
table.flow td p {
    margin-bottom: 0.8em;
}
table.flow h6 {
    margin: 0px 0 10px;
    padding: 0;
    color: #333;
    font-size: 125%;
    letter-spacing: 0.1em;
}
table.flow h6::first-letter{
    letter-spacing: 0.2em;
    color: #ce2619;
	font-size: 125%;
}
table.flow td p.flowimg {
    float: right;
  	margin-left: 20px;
    margin-bottom:0;
}
table.flow td p.flowimg img{
    margin:0;
}
.cf {
    overflow: hidden;
}

#contents table.timeTbl{
  text-align: center;
  width: 100%;
  border-collapse: collapse;
  border-left: 1px solid #037d44;
  border-spacing: 0;
  border-top: 1px solid #037d44;
}

#contents table.timeTbl th{
	width:10%;
    background-color: #bde0cc;
}

#contents table.timeTbl th:first-child{
	width:20%
}

#contents table.timeTbl th,
#contents table.timeTbl td {
  border-right: 1px solid #037d44;
  border-bottom: 1px solid #037d44;
  padding: 2px;
}


/*-------------------------------------------
フロー図（記事）
-------------------------------------------*/
.mainArticles .article.articleFlow {
    background: #FFF;
    border: 4px solid #333;
    display: block;
    padding: 1.5%;
    position: relative;
    margin-bottom: 35px;
  	box-sizing: border-box;
}
.mainArticles .article.articleFlow::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-top: 20px solid #333;
    border-right: 30px solid transparent;
    border-left: 30px solid transparent;
}
.mainArticles .article.articleFlow.last::after {
    display: none;
}
.mainArticles .article.articleFlow .image ,
.mainArticles .article.articleFlow img {
	max-width: 240px;
}
.mainArticles .article.articleFlow h3 {
    position: absolute;
    top: -100px;
    left: 0;
}
.mainArticles .article.articleFlow h6 {
    margin: 0px 0 10px;
    padding: 10px 0;
    color: #333;
    font-size: 125%;
    letter-spacing: 0.1em;
}

/*-------------------------------------------
form
-------------------------------------------*/
table.contactTable {
	border-collapse: collapse;
	border-spacing: 0;
	margin: 10px auto;
	width: 100%;
    background: #fff;
}
table.contactTable tr th {
	height: auto;
	line-height: 150%;
	padding: 30px 15px;
	text-align: left;
	vertical-align: middle;
  	width: 30%;
    border-bottom: 1px solid #DDD;
}
table.contactTable tr.must th {
    background-position: 95% center;
    background-repeat: no-repeat;
    padding: 30px 40px 30px 15px;
}
table.contactTable td {
	height: auto;
	line-height: 150%;
	padding: 30px 15px;
    border-bottom: 1px solid #DDD;
}
table.contactTable tr:last-child th ,
table.contactTable tr:last-child td {
    border-bottom: none;
}
table.contactTable label input {
	margin-left: 10px;
  	margin-right: 5px;
    border: 0px;
}
table.contactTable input.textField {
	border:solid 1px #999;
	width: 98%;
}
table.contactTable .textField {
    width: 98%;
}
table.contactTable textarea {
    border: solid 1px #999;
}
table.contactTable input.button {
  	display:block;
    margin: 0 auto;
    font-size: 14px;
}
table.contactTable select {
    font-size: 100%;
    width: 100%;
}
table.contactTable label {
    font-size: 100%;
    width: 100%;
    display: inline-block;
}
table.contactTable input.button {
    background-image: none;
    background-color: #333;
    border: none;
    border-radius: 2px;
    color: #fff;
    display: block;
    font-size: 16px;
    height: 50px;
    letter-spacing: 5px;
    margin: 0 auto;
    outline: none;
    width: 150px;
}
table.contactTable input.button:hover {
    background-image: none;
    background-color:  #181818;
  	color: #edc000;
	cursor: pointer;
}
table.contactTable .th_headline {
	font-weight:bold;
	background-color: #eee;
	text-align:center;
}
table.contactTable p.contact-note {
	line-height: 1.5;
	margin: 8px 0;
	color: #666;
	font-size: 90%;
}
/*確認画面*/
table.contactTable input[type="button"] {
    background: #f1f1f1 none repeat scroll 0 0;
    border: 1px solid #ccc;
    color: #333;
    cursor: pointer;
    display: block;
    font-size: 16px;
    margin: 20px auto;
    padding: 15px 60px;
    text-align: center;
  	width: auto;
}
table.contactTable input[type="button"]:hover {
    background: #333;
    color: #FFF;
}

/*-------------------------------------------
List
-------------------------------------------*/
/*順序リスト*/
ol.orderList {
    padding-left: 2em;
}
ol.orderList li {
    list-style-type: decimal;
    padding: 5px;
}
/*単純リスト*/
ul.simpleList {
    list-style: none;
    padding:0;
    margin:0;
	overflow: hidden;
	padding: 0 0 15px;
	margin: 0 0 15px;
}
ul.simpleList li {
	padding-left: 1em;
	text-indent: -0.8em;
	overflow: hidden;
}
ul.simpleList li:before {
    content: "•";
    color: #666;
	line-height: 2;
	margin-right: 0.5em;
  	font-size: 85%;
}
/*No.リスト*/
ol.StyleOrderList {
    counter-reset: number 0;
    list-style: outside none none;
    padding-left: 0;
  	margin: 15px 0;
}
ol.StyleOrderList li::before {
    color: #7CC;
    content: counter(number, decimal);
    counter-increment: number 1;
    display: inline-block;
    height: 1.8em;
    margin-right: 13px;
    text-align: center;
    width: 1.8em;
    line-height: 1.8;
	margin-left: -50px;
	font-style: italic;
	font-size: 115%;
}
ol.StyleOrderList li {
    line-height: 1.5;
    margin-bottom: 0.7em;
  	padding-left: 50px;
  	font-size: 105%;
	border-bottom: 1px dashed #7CC;
	padding-bottom: 5px;
}
/*チェックマークリスト*/
ul.StyleCheckList {
    list-style: outside none;
    padding-left: 2.5em;
    margin-bottom: 20px;
}
ul.StyleCheckList li {
    position: relative;
  	font-size: 105%;
  	margin-bottom: 0.5em;
}
ul.StyleCheckList li::before {
    display: block;
    content: '';
    position: absolute;
    top: 0.4em;
    left: -2em;
    width: 1em;
    height: 0.50em;
    border-left: 3px solid #E66;
    border-bottom: 4px solid #E66;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/*任意マークリスト*/
ul.markList {
    padding-left: 3px;
}
ul.markList li {
    list-style-type: none;
  	padding: 10px 0 0 20px;
    font-size: 105%;
}
ul.markList li::before {
    color: #E44;
    content: "\025b6";
    display: inline-block;
    font-size: 70%;
    margin-right: 10px;
    margin-left: -20px;
}
ul.markList.kome li {
    list-style-type: none;
  	padding: 10px 0 0 20px;
    font-size: 80%;
}
ul.markList.kome li::before {
    color: #933;
    content: "※";
}

ul.ps {
  list-style-type: none;
  margin-left: 1em;
  /*--color: #666;--*/
}

ul.ps li::before {
  content: "※";
  margin-left: -1em;
  font-family: "メイリオ", sans-serif;
}

/*-------------------------------------------
FAQ
-------------------------------------------*/
/* FAQ */
dl.faq {
	width: 100%;
	margin: 0 auto;
  	font-size: 112.5%;
    border-bottom: 1px dotted #CCC;
    padding-bottom: 25px;
}
dl.faq dt {
    margin: 0;
    padding: 15px 10px 10px 80px;
    line-height: 40px;
}
dl.faq dt::before ,
dl.faq dd::before {
  	border-radius: 50%;
    float: left;
    height: 40px;
    line-height: 40px;
    margin: 0 0 0 -60px;
    text-align: center;
    width: 40px;
    color: #FFF;
    font-weight: bold;
	font-family: sans-serif;
}
dl.faq dd {
    background: none;
    padding: 15px 10px 10px 80px;
}
dl.faq dt::before {
    background-color: #302833;
    content: "Q";
}
dl.faq dd::before {
    background-color: #e9546b;
    content: "A";
}

/*-------------------------------------------
Button
-------------------------------------------*/
a.linkbtn {
    background-color: #037d44;
/*    border: 2px solid #333;*/
    border-radius: 2px;
    color: #fff !important;
    display: inline-block;
    margin: 20px auto;
    padding: 10px 5%;
    text-align: center;
    text-decoration: none;
    font-weight: normal;
    width: 30%;
    min-width: 400px;
    box-sizing: border-box;
    border: 1px solid #037d44;
}
a.linkbtn:hover {
    background-color:#fff;
    color: #037d44 !important;
    border: 1px solid #037d44;
}

.side-text a.linkbtn{
    width: 100%;
    min-width: fit-content;
}

/*-------------------------------------------
Gallery
-------------------------------------------*/
.gallery_grid li.galleryGrid .galleryGrid_outer {
    padding: 0 12px 10px;
}
.gallery_grid li.galleryGrid .image {
    margin-bottom: 8px;
}
.gallery_grid li.galleryGrid .comment {
	text-align: center;
	font-size: 14px;
}
/*実績用*/
.case .gallery_grid li.galleryGrid .comment {
	text-align: center;
	font-size: 14px;
	letter-spacing: 0;
	line-height: 1.5;
	min-height: 6em;
}
/*サイト案内*/
#siteGuide li.galleryGrid .image {
    margin-bottom: 0;
}
#siteGuide .comment  {
    font-size: 16px;
    padding: 5px 0;
    background: #EEE;
    color: #666;
    border-bottom: 2px solid #DDD;
}

/*-------------------------------------------
Blog
-------------------------------------------*/
div.blog_date {
	margin-top: 30px;
	display: inline-block;
	width: 100%;
	color: #999;
	font-size: 85%;
}

/*-------------------------------------------
Others
-------------------------------------------*/
.strong{
	font-weight:bold;
	color:#dc143c;
	display:inline-block;
	margin:0 4px;
	font-size:112%;
}


/*マーカー*/
span[style*="Lime"] {
    background-color: #FFF !important;
    color: #096;
    border-bottom: 1px dashed;
	font-weight:bold;
}
/*
span[style*="Yellow"] {
	background: linear-gradient(transparent 80%, #ffe266 80%) !important;
	border-radius:0px;
	font-weight: bold;
}
*/
span[style*="Yellow"] {
    background: linear-gradient(transparent 0%, #ffedab 0%) !important;
    border-radius: 0px;
    font-weight: bold;
}

/*線*/
hr.line {
	height: 0;
	margin: 0;
	padding: 0;
	border: 0;
	border-top: 1px solid #ddd;
	margin:15px 0;
}

/*ぱんくず*/
body.index-page #pankuz{
    display: none;
}
.pankuz p {
    margin-bottom: 15px;
    font-size: 13px;
    color: #999;
    text-align: left;
}

/*囲み*/
div.envelope {
    background-color: #fffcd2;
    border: 1px solid #037d44;
    border-radius: 2px;
    margin: 10px 0;
    padding: 15px;
}
div.envelope p {
	margin: 0;
}

/*記事下線*/
.mainArticles .article.underLine {
    border-bottom: 2px dashed #CCC;
    margin-bottom: 40px;
}

/*余白なし記事*/
.mainArticles .article.marginNone {
	margin: 0;
	padding: 0;
}


/*サイド固定バナー*/
#sideFixBnr {
	display: block;
  	width: 44px;
  	height: 150px;
  	position: fixed;
  	right: 0;
  	top: 42%;
  	z-index: 99;
}
#sideFixBnr img {
	margin-bottom: 10px;
}

/*TOPへボタン*/
a.topBtn {
    display: inline-block;
    padding: 4px;
    text-align: center;
    text-decoration: none;
    background: #999;
    border-radius: 2px;
    color: #fff;
    position: fixed;
    bottom: 12px;
    right: 12px;
    z-index: 1000;
    width: 2em;
    height: 2em;
    line-height: 2em;
    font-size: 12px;
}
a.topBtn:hover {
	background: #181818;
	color: #edc000;
}

/* 固定ヘッダーのアンカー対策 */
#contents [id*="Anc_"] {
  margin-top : -60px;
  padding-top : 60px;
}
.ams-build #contents [id*="Anc_"] {
  margin : 0;
  padding : 0;
}

/* 字体 */
.article, #mainTopics #mainTopics_body, .gallery .article_body  {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
 } 

#sideMobile {
    background-color: #bde0cc;
}

#sideMobile p {
    color: #037d44;
}