@charset "UTF-8";
/* ===========================================================

	body

=========================================================== */
html,
body {
  background: url("../img/bg_top.gif") 0 0 repeat-x;
  font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Arial, Helvetica, sans-serif, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
 /*font-family: 'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;*/
  color: #111;
  text-align: center;
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
	
/* text
----------------------------------------------------------- */
p {
	font-size: 16px;
	line-height: 1.7;
}
p,ul,ol,dl {
	margin: 0 0 20px;
}
ul li,ol li {
	margin: 0 0 2px;
	list-style-type:none;
}
ul {
	padding-inline-start: 0;
}
ol ol {
	padding: 5px 0 0;
}

/* link
----------------------------------------------------------- */
a:link,
a:visited {
	text-decoration: none;
	color: #74a92d;
}
a:hover {
	text-decoration: underline;
	color: #111;
}
.link-reverse a:link,
.link-reverse a:visited,
a.link-reverse:link,
a.link-reverse:visited {
	color: #111;
	text-decoration: underline;
}
.link-reverse a:hover,
a.link-reverse:hover {
	color: #74a92d;
	text-decoration: none;
}
/* box-sizing
----------------------------------------------------------- */
* {
	box-sizing: border-box;
}

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

	header

=========================================================== */
header {
  width:100%;
}
header .header-inner {
  position: relative;
  width: 980px;
  height: 140px;
  z-index: 100;
  margin:0 auto;
}

  /* logo
----------------------------------------------------------- */
header h1 {
  position: absolute;
  top: 65px;
  left: 0px;
  font-size: 11px;
  line-height: 1;
}

  /* hed-link
----------------------------------------------------------- */
header ul.hed-link {
  position: absolute;
  top: 8px;
  right: 0;
  margin: 0;
  display:flex;
}

header ul.hed-link li {
  margin: 0 0 0 15px;
  line-height: 24px;
  height: 24px;
  font-size: 11px;
  list-style-type: none;
}
header ul.hed-link li a {
  background: url("../img/ic_arrow_1.png") 0 50% no-repeat;
  background-size: 5px 8px;
  padding: 0 0 0 10px;
  color: #fff;
  text-decoration: none;
}
header ul.hed-link li a:hover {
  text-decoration: underline;
}

  /* global-navigation
----------------------------------------------------------- */
header .gn {
  position: absolute;
  top: 60px;
  right: 150px;
  /* right: 0px; */
  height: 60px;
  margin: 0;
  padding: 0;
  z-index: 90;
  user-select: none;
  list-style-type: none;
}
header .gn ul.toggle_wrap {
  display:flex;
}
/* TOPなし電話番号入れる版 */
header .gn ul.toggle_wrap li.gn__primary {
  position: relative;
  width: 120px;
  margin: 0;
  padding: 0;
  text-align: center;
  list-style-type: none;
  font-size:14px;
}
header .gn ul.toggle_wrap li#gn-blog {
  width: 80px;
}
header .gn ul.toggle_wrap li#gn-about {
  width: 100px;
}

header .gn ul.toggle_wrap li.gn__primary>a {
  display: block;
  color: #111;
  font-weight: bold;
  text-decoration: none;
  padding: 20px 10px 54px;
}

/* current */
#service header  .gn ul.toggle_wrap li#gn-service>a,
#blog header .gn ul.toggle_wrap li#gn-blog>a,
#about header  .gn ul.toggle_wrap li#gn-about>a,
#contact header .gn ul.toggle_wrap li#gn-contact>a{
  color: #74a92d;
}
#service header .gn ul.toggle_wrap li#gn-service>a:after,
#blog header .gn ul.toggle_wrap li#gn-blog>a:after,
#blog2 header .gn ul.toggle_wrap li#gn-blog>a:after,
#about header .gn ul.toggle_wrap li#gn-about>a:after,
#contact header .gn ul.toggle_wrap li#gn-contact>a:after,
#contact_check header .gn ul.toggle_wrap li#gn-contact>a:after,
#contact_comp header .gn ul.toggle_wrap li#gn-contact>a:after {
  content: " ";
  position: absolute;
  top: 35px;
  left: 50%;
  width: 70%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  height: 16px;
  border-bottom: 2px solid #87a066;
  z-index: 90;
}

/* hover */
header .gn ul.toggle_wrap li.gn__primary:hover>a {
  color: #74a92d;
}

header .gn ul.gn__secondary {
  list-style: none;
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 200px;
  z-index: 100;
  text-align: left;
	opacity:0;
}
header .gn ul.gn__secondary:last-of-type {
  width: 168px;
}
header .gn ul.gn__secondary:before {
  content: "";
  position: absolute;
  top: -15px;
  left: 0;
  background: url("../img/gn_arrow_a.png") 50% 0 no-repeat;
  width: 100%;
  height: 15px;
  opacity: 0;
}
header .gn ul.gn__secondary li {
	display:none;
	margin-bottom:0;
}

header .gn ul.gn__secondary li a {
	display:block;
  padding: 14px 16px 14px 26px;
	height:46px;
	line-height:18px;
  color: #fff;
  text-align: left;
  font-size: 12px;
  text-decoration: none;
  background: #74a92d url(../img/ic_arrow_2.png) 16px 50% no-repeat;
  background-size: 4px 6px;
}
header .gn ul.gn__secondary li:first-of-type a {
  border-radius: 5px 5px 0 0;
}
header .gn ul.gn__secondary li:last-of-type a {
  border-radius: 0 0 5px 5px;
}
header .gn ul.gn__secondary li:not(:first-of-type) a {
	height:32px;
	padding-top:0;
	background-position:16px 6px;
}

/* hover */
header .gn ul.toggle_wrap li.gn__primary:hover ul.gn__secondary {
  opacity: 1;
  transition: .4s ease-out;
}
header .gn ul.toggle_wrap li.gn__primary:hover ul.gn__secondary:before {
  opacity: 1;
  transition: .2s ease-out;
}
header .gn ul.toggle_wrap li.gn__primary:hover ul.gn__secondary li {
  display:block;
}

header .gn ul.toggle_wrap li.gn__primary:hover ul.gn__secondary li:hover a {
  color: #aacd06;
}
header .nav-tel {
    width: 140px;
    height: 60px;
    position: absolute;
    top: 60px;
    right: 0;
    background: #FF9826;
    border-radius: 6px;
    padding: 12px 0;
}
header .nav-tel a {
    color: #fff;
    word-break: normal;
    font-size: 11px;
    font-weight: 800;
    transform: scale(1, 1.2);
    display: inline-block;
}
header .nav-tel a span.text {
    text-shadow: 1px 1px 2px #6e4110;
}
header .nav-tel a span.tel {
    text-shadow: 1px 0.5px 2px #6e4110;
    font-size: 16px;
    transform: scale(1, 1.1);
    display: inline-block;
    line-height: 1.4;
}

  /* navibtn
----------------------------------------------------------- */
#navbtn {
  transition:all 1s;
  width:40px;
  height:40px;
  background:transparent;
  position:fixed;
  right:0px;
  top:0px;
  cursor:pointer;
  z-index:1000;
}
#navbtn span {
  width:30px;
  height:2px;
  background:#fff;
  position:absolute;
}
#navbtn span:nth-child(1) {
  transition:all 0.2s;
  left:5px;
  top:11px;
}
#navbtn span:nth-child(2) {
  left:5px;
  top:19px;
}
#navbtn span:nth-child(3) {
  transition:all 0.2s;
  left:5px;
  top:27px;
}
.open span:nth-child(1) {
  transform:translateY(8px) rotate(45deg);
}
.open span:nth-child(3) {
  transform:translateY(-8px) rotate(-45deg);
}
.open span:nth-child(2) {
  top:17px; opacity:0;
}
.opennav {
  transform:translateY(351px);
}


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

	bt-pagetop

=========================================================== */
.bt-pagetop {
	width: 980px;
	height: 90px;
	margin: 0 auto;
	background: url(../img/fot_image.png) 0 bottom no-repeat;
	position: relative;
}
.bt-pagetop a {
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	width: 90px;
	height: 70px;
	padding-top:50px;
	background: url(../img/bt_pagetop.png) 50% 0 no-repeat;
	background-size:40px 40px;
	font-size:12px;
	color: #333;
	transition: ease .2s
}
.bt-pagetop a:hover {
  color: #74a92d;
  text-decoration: none;
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
  transition: ease.2s
}

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

	footer-navi

=========================================================== */
footer #footer-navi {
	width: 100%;
	padding: 40px 0;
	border-top: solid 1px #eeeeee;
	border-bottom: solid 1px #eeeeee;
	background: #f6f6f6;
}
footer #footer-navi-inner {
	width: 980px;
	margin: 0 auto;
	text-align: left;
	display: flex;
}
footer #footer-navi .box {
	width: 200px;
}
footer #footer-navi #fot-navi-top {
	width: 210px;
}
footer #footer-navi #fot-navi-blog {
	width: 160px;
}
footer #footer-navi #fot-navi-contact {
	width: 210px;
}
footer #footer-navi h3 {
	padding: 0;
	margin: 0 0 10px;
	border: none;
	background: none;
}
footer #footer-navi h3>a {
	line-height: 1.4;
	font-size: 16px;
	font-weight:normal;
	padding: 0 0 0 22px;
	background: url(../img/ic_arrow_3.png) 0 3px no-repeat;
	background-size: 14px 14px;
}
footer #footer-navi ul {
	font-size: 14px;
	line-height: 1.3;
	margin: 0 20px 0 0;
	padding: 0;
}
footer #footer-navi ul li {
	margin: 0 0 2px;
}
footer #footer-navi ul li a {
	background: url(../img/ic_arrow_4.png) 4px 50% no-repeat;
	background-size: 4px 4px;
	padding: 2px 0 2px 22px;
	display: block;
}
footer #footer-navi a:link, #footer-navi a:visited {
	text-decoration: none;
	color: #111;
}
footer #footer-navi a:hover {
	text-decoration: none;
	color: #74a92d;
}
footer #footer-navi a.current {
	color: #111;
	font-weight: bold;
}
/* ===========================================================

	footer-btm

=========================================================== */
footer #footer-btm {
	width: 100%;
	padding: 25px 0;
}
footer #footer-inner {
	width: 980px;
	margin: 0 auto;
	display: flex;
}
footer #footer-btm ul {
	width: 550px;
	text-align: left;
	padding: 0;
	font-size: 11px;
	line-height: 1;
	margin-bottom:0;
}
footer #footer-btm ul li {
	display: inline;
	margin: 0;
	padding: 0 10px;
	border-left: solid 1px #ddd;
}
footer #footer-btm ul li:first-child {
	padding: 0 10px 0 0;
	border-left: none;
}
footer #footer-btm ul li a:link, #footer-btm ul li a:visited {
	text-decoration: none;
}
footer #footer-btm ul li a.current {
	color: #74a92d;
	font-weight: bold;
}
footer #footer-btm p {
	width: 430px;
	text-align: right;
	margin: 0;
	padding: 0;
	font-size: 10px;
	line-height: 1;
}

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

	top
	
=========================================================== */
#top header .gn ul.gn__secondary:before {
  background: url("../img/gn_arrow.png") 50% 0 no-repeat;
}

/* main-visual
----------------------------------------------------------- */
#top #main-visual {
  background: url("../img/main-visual.jpg") right 10% no-repeat;
  background-size: cover;
  position: relative;
  min-width: 980px;
  min-height: 600px;
  height: 600px;
}
#top .main-visual-inner{/*追加*/
	width:980px;
	margin:0 auto;
	height:100%;
	position:relative;
}
#top .main-visual-msg {
	position:relative;
	width:440px;
	height:100%;
	background-color: rgba(255,255,255,0.5);
}
#top .main-visual-msg img.msg {
  display:block;
	margin:0 auto;
	position:absolute;
	top:8%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
}
#top .main-visual-msg a.service-link {
  display:block;
  background: url("../img/top_button_tete.png") 0 0 no-repeat;
  width: 425px;
  height: 60px;
  text-indent:100%;
  white-space: nowrap;
  overflow:hidden;
  position: absolute;
  top: 35%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
}
#top .main-visual-msg img.top-pic {
	width:410px;
  display:block;
	margin:0 auto;
	position:absolute;
	bottom:6%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
	border:2px solid #fff;
}
#top .main-visual-msg a:hover {
  background-position: 0 bottom;
}

/* top-menu
----------------------------------------------------------- */
#top .top-menu {
	background: url(../img/bg_gray.gif) 0 0 repeat;
	padding: 20px 0;
}
#top .top-menu ul {
	display:flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 980px;
	margin: 0 auto;
}
#top .top-menu ul li {
	margin: 0 10px 0 0;
	list-style-type: none;
}
#top .top-menu ul li.menu3 {
	margin-right: 0;
}
#top .top-menu ul li a {
	width: 320px;
	height: 100px;
	background: url(../img/top_menu.png) 0 0 no-repeat;
	display:block;
	text-indent:100%;
	white-space: nowrap;
	overflow:hidden;
}
#top .top-menu ul li.menu1 a {
	background-position: 0 0;
}
#top .top-menu ul li.menu1 a:hover {
	background-position: 0 -110px;
}
#top .top-menu ul li.menu2 a {
	background-position: -330px 0;
}
#top .top-menu ul li.menu2 a:hover {
	background-position: -330px -110px;
}
#top .top-menu ul li.menu3 a {
	background-position: -660px 0;
}
#top .top-menu ul li.menu3 a:hover {
	background-position: -660px -110px;
}

/* top-news
----------------------------------------------------------- */
#top .top-news {
	width: 980px;
	padding: 40px 0 40px;
	margin: 0 auto;
	text-align: left;
	display:flex;
}
#top .top-news-tit {
	width: 250px;
}
#top .top-news h2 {
	padding: 0;
	margin: 0 0 20px;
	background: url(../img/ic_news.png) 0 50% no-repeat;
	background-size: 24px 24px;
	padding: 10px 0 8px 34px;
	font-size:16px;
}
#top .top-news dl {
	width: 725px;
	border-left: dotted 1px #acacac;
	margin: 0;
	display: inline-flexbox;
}
#top .top-news dt {
	position: absolute;
	margin: 0 0 0 50px;
	padding: 5px 0;
	width: 14em;
	display: inline-block;
}
#top .top-news dt span {
	position: absolute;
	top: 7px;
	right: 0;
	width: 7em;
	height:21px;
	text-align:center;
	font-size:13px;
	background-color: #2D96A9;
	color:#fff;
	display: inline-block;
}
#top .top-news dt img {
	position: absolute;
	top: 7px;
	right: 0;
	vertical-align: text-bottom;
}
#top .top-news dd {
	margin: 0 0 5px;
	padding: 5px 0 5px 18em;
}
#top .top-news dd img {
	margin: 0 2px 0 4px;
	vertical-align: middle;
}

/* top-info
----------------------------------------------------------- */
#top .top-info {
	padding: 40px 0;
	background: #fafafa url(../img/bg_info.gif) 50% 50% repeat-y;
	border-top: solid 1px #eeeeee;
	border-bottom: solid 1px #eeeeee;
	margin-bottom:74px;
}
#top .top-info-container {
	display:flex;
	justify-content: space-between;
	max-width: 980px;
	margin: 0 auto;
	text-align: left;
	height:auto;
}
#top .top-info h2 {
	position: relative;
	margin: 0 0 15px;
	width: 290px;
	padding: 8px 0 10px 48px;
	display: block;
	border-bottom: 1px solid #dddddd;
	font-size:16px;
}
#top .top-info h2:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 40px;
  height: inherit;
  border-bottom: 1px solid #74a92d;
}
#top .top-info ul {
	height:174px;
}
#top .top-info img {
	width:100%;
}

/* top-trouble
----------------------------------------------------------- */
#top .top-trouble {
	width: 290px;
}
#top .top-trouble h2 {
	background: url(../img/ic_trouble.png) no-repeat;
	background-size: 40px 40px;
}

/* top-service
----------------------------------------------------------- */
#top .top-service {
	width: 290px;
}
#top .top-service h2 {
	background: url(../img/ic_service.png) no-repeat;
	background-size: 40px 40px;
}

/* top-area
----------------------------------------------------------- */
#top .top-area {
	width: 290px;
}
#top .top-area h2 {
	background: url(../img/ic_area.png) no-repeat;
	background-size: 40px 40px;
}
#top .top-area ul li span {
	padding-left: 5em;
}


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

 about

===========================================================  */
.main {
	width: 720px;
	margin: 30px auto 40px;
	padding: 0;
	text-align: left;
	display: block;
}
#about .cont-margin {
	margin-bottom: 50px !important;
}
#about .flexbox {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 20px;
}
/* tit
----------------------------------------------------------- */
.title h2 {
	line-height: 70px;
	min-height: 70px;
	margin: 0 0 30px;
	padding: 0;
}
.title h2 span {
	color: #000;
	font-size: 30px;
	font-weight: bold;
	border-bottom: solid 2px #74a92d;
	padding: 0 0 15px;
	letter-spacing: 1px;
}
#about h3 {
	border-bottom: solid 3px #f0f0f0;
	padding: 0;
	margin: 0 0 15px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 6px;
}
#about h3 span {
	font-weight: bold;
	border-left: solid 5px #74a92d;
	padding: 1px 10px 0;
	display: block;
	line-height: 1.2em;
}
/* text
----------------------------------------------------------- */
#about .read {
	font-weight: normal;
	color: #000;
	margin: 0 0 15px;
	font-size: 28px;
	line-height: 1.6;
	font-family: 'Crimson Text', "Times New Roman", Times, "Sawarabi Mincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}
#about .read span{
	color: #74a92d;
	font-weight: bold;
}
#about p.p-1 {
	margin: 0;
	padding: 0;
}
#about p.p-2{
	padding: 0 0 10px 24px;
	margin-bottom: 10px;
}
#about p.p-margin {
	margin-bottom: 20px;
}
#about .p-weight {
	font-weight: bold;
}
#about .p-border{
	border-bottom: dotted 1px #ccc;
}
#about .side ul li {
	text-align: left;
}
/* side
----------------------------------------------------------- */
#about .side {
	width: 220px;
	margin: 140px 5px 20px 50px;
}
#about .side h3 {
	background: url(../img/right-title.png) 0 0 no-repeat;
	width: 220px;
	height: 70px;
	line-height: 70px;
	text-align: center;
	font-size: 15px;
	padding: 0;
	margin: 0 0 2px;
	color: #fff;
	font-weight: normal;
	border: none;
}
/* side-navi
----------------------------------------------------------- */
#about .side .side-navi {
	margin: 0 0 20px;
}
#about .side .side-navi ul {
	margin: 0;
	padding: 15px 0;
	font-size: 13px;
	line-height: 1.5;
	color: #000;
	background: #fff;
	border: solid 1px #ddd;
}
#about .side .side-navi ul li {
	line-height: 0;
	vertical-align: bottom;
	margin: 0 15px;
	padding: 0;
}
#about .side .side-navi ul li a {
	display: block;
	background: url(../img/ic_arrow_e.png) 0 10px no-repeat;
	background-size: 14px 14px;
	padding: 8px 0 8px 20px;
	line-height: normal;
	zoom: 1;
}
#about .side .side-navi ul li a:link, .side .side-navi ul li a:visited {
	text-decoration: none;
	color: #333;
}
#about .side .side-navi ul li a:hover {
	color: #74a92d !important;
}
#about .side .side-navi ul li a.current {
	color: #74a92d !important;
	font-weight: bold;
}
/* side-ad
----------------------------------------------------------- */
#about .side-ad {
	position: -webkit-sticky;
	position: sticky;
	top: 10px;
}

/* table
----------------------------------------------------------- */
#about table {
	width: 720px;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: inherit;
}
#about table.th-top th {
	border-left: solid 1px #fff;
	/* border-bottom: none; */
	width: auto;
	text-align: center;
	background: #717171;
	color: #fff;
}
#about table th {
	width: 25%;
	padding: 10px 10px;
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	background: #f9f9f9;
}
#about table td {
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	padding: 10px 10px;
	vertical-align: middle;
}
#about tbody {
	display: table-row-group;
	vertical-align: middle;
	border-color: inherit;
}
/* @media
----------------------------------------------------------- */
@media screen and (max-width: 1024px) {
#about body {
	background: none;
}
.title h2 {
	min-height: inherit;
	line-height: 1.4;
	border-bottom: solid 2px #74a92d;
	padding: 30px 0 10px;
}
.title h2 span {
	font-size: 24px;
	border: none;
	padding: 0;
}
#about .main {
	width: auto;
	margin: 0 auto 40px;
	padding: 0 20px;
}
#about .responsive-img img{
	width: 65%;
	min-width: 380px;
	height: auto;
}
#about .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#about p.p-1, p.p-2 {
	width: 100%;
}
#about .side {
	display: none;
}
#about .flexbox {
	display: block;
	width: 100%;
}
#about .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#about table {
	width: 100%;
	}
}
@media screen and (max-width: 767px){
#about #main .read {
	font-size: 20px;
	line-height: 1.5;
	}
}

@media screen and (max-width: 764px) {
	#about .responsive-table {
		width: 100%;
		border-left: none;
		border-top: solid 1px #ccc;
	}
	#about table.responsive-table tr th {
		display: block;
		width: auto !important;
		border-top: none;
		background-color: #f0f0f0;
	}
	#about .responsive-table td {
		display: block;
		width: auto !important;
		border-top: none;
	}
}

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

 service

===========================================================  */
#service .imgcenter {
	text-align: center;
}
#service .cont-margin {
	margin-bottom: 50px !important;
}
#service .flexbox {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 20px;
}

/* tit
----------------------------------------------------------- */
#service h3 {
	border-bottom: solid 3px #f0f0f0;
	padding: 0;
	margin: 0 0 15px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 6px;
}
#service h3 span {
	font-weight: bold;
	border-left: solid 5px #74a92d;
	padding: 1px 10px 0;
	display: block;
	line-height: 1.2em;
}
/* text
----------------------------------------------------------- */
#service .read {
	font-weight: normal;
	color: #000;
	margin: 0 0 15px;
	font-size: 28px;
	line-height: 1.6;
	font-family: 'Crimson Text', "Times New Roman", Times, "Sawarabi Mincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}
#service .read span{
	color: #74a92d;
	font-weight: bold;
}
#service p.p-1 {
	margin: 0;
	padding: 0;
}
#service p.p-2{
	padding: 0 0 10px 24px;
	margin-bottom: 10px;
}
#service p.p-margin {
	margin-bottom: 20px;
}
#service .p-weight {
	font-weight: bold;
}
#service .p-border{
	border-bottom: dotted 1px #ccc;
}
#service .side ul li {
	text-align: left;
}
/* side
----------------------------------------------------------- */
#service .side {
	width: 220px;
	margin: 140px 5px 20px 50px;
}
#service .side h3 {
	background: url(../img/right-title.png) 0 0 no-repeat;
	width: 220px;
	height: 70px;
	line-height: 70px;
	text-align: center;
	font-size: 15px;
	padding: 0;
	margin: 0 0 2px;
	color: #fff;
	font-weight: normal;
	border: none;
}
/* side-navi
----------------------------------------------------------- */
#service .side .side-navi {
	margin: 0 0 20px;
}
#service .side .side-navi ul {
	margin: 0;
	padding: 15px 0;
	font-size: 13px;
	line-height: 1.5;
	color: #000;
	background: #fff;
	border: solid 1px #ddd;
}
#service .side .side-navi ul li {
	line-height: 0;
	vertical-align: bottom;
	margin: 0 15px;
	padding: 0;
}
#service .side .side-navi ul li a {
	display: block;
	background: url(../img/ic_arrow_e.png) 0 10px no-repeat;
	background-size: 14px 14px;
	padding: 8px 0 8px 20px;
	line-height: normal;
	zoom: 1;
}
#service .side .side-navi ul li a:link, .side .side-navi ul li a:visited {
	text-decoration: none;
	color: #333;
}
#service .side .side-navi ul li a:hover {
	color: #74a92d !important;
}
#service .side .side-navi ul li a.current {
	color: #74a92d !important;
	font-weight: bold;
}
/* side-ad
----------------------------------------------------------- */
#service .side-ad {
	position: -webkit-sticky;
	position: sticky;
	top: 10px;
}
/* table
----------------------------------------------------------- */
#service table {
	width: 720px;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: inherit;
}
#service table.th-top th {
	border-left: solid 1px #fff;
	/* border-bottom: none; */
	width: auto;
	text-align: center;
	background: #717171;
	color: #fff;
}
#service table th {
	width: 25%;
	padding: 10px 10px;
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	background: #f9f9f9;
}
#service table td {
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	padding: 10px 10px;
	vertical-align: middle;
}
#service tbody {
	display: table-row-group;
	vertical-align: middle;
	border-color: inherit;
}
#service .bg-color-1 {
	background: #ceddb9;
}
#service .bg-color-2 {
	background: #cde5c3;
}
#service .bg-color-3 {
	background: #dbebc4;
}
#service .bg-color-4 {
	background: #e9e4d9;
}
#service .bg-color-5 {
	background: #d4e1f1;
}
#service .bg-color-6 {
	background: #dae3e8;
}
#service .t-font{
	font-size: 12px;
}

/* @media
----------------------------------------------------------- */
@media screen and (max-width: 1024px) {
#service body {
	background: none;
}

#service .main {
	width: auto;
	margin: 0 auto 40px;
	padding: 0 20px;
}
#service .responsive-img img{
	width: 65%;
	min-width: 280px;
	height: auto;
}
#service .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#service p.p-1, p.p-2 {
	width: 100%;
}
#service .side {
	display: none;
}
#service .flexbox {
	display: block;
	width: 100%;
}
#service .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#service table {
	width: 100%;
	}
}
@media screen and (max-width: 767px){
#service #main .read {
	font-size: 20px;
	line-height: 1.5;
	}
#service .br-1 {
	display: block;
	}
}
/* ===========================================================

 blog

===========================================================  */
/* ブログ一覧
-------------------------------------------------------------*/
#blog .img-flex {
	min-height: 500px;
}
#blog #blog-contents {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 20px;
}
/* メイン部分 */

#blog article.main {
	width: 720px;
	margin-left: 0;
	padding: 0;
	text-align: left;
}
#blog #blog-contents #img-flex {
	display: flex;
	justify-content: flex-start;
	flex-direction: row;
	flex-wrap: wrap;
	margin-left: 0;
	padding-left: 0;
	margin-bottom: 20px;
}
#blog .items {
	margin-right: 20px;
	margin-bottom: 15px;
}
#blog .items dl {
	width: 220px;
	height: 230px;
	margin-bottom: 0;
}
#blog .items dt,
#blog .items dd {
	border: 2px solid #ddd;
	padding: 3px;
	overflow: hidden;
}
#blog .items dt {
	height: 150px;
}
#blog .items dd {
	border-top: none;
	height: 80px;
	overflow: hidden;
}
#blog .items p {
	padding: 10px 5px;
	color: #000;
}
/* サムネ内３点リーダー用クラス
=================================*/ 
#blog p.video-title {
	width: 220px;
	height: 100px;
	overflow: hidden;
	display: block;
}
#blog .items img {
	width: 100%;
	height: 150px;
	box-sizing: border-box;
	display: block;
	transition: 0.5s;
	/* IE対策 */
	object-fit: cover;
	font-family: 'object-fit: cover;';
}
#blog .items a {
	text-decoration: none;
}
#blog .items a:hover p {
	color: #74a92d;
}
#blog .items img:hover {
	transform: scale(1.1, 1.1);
}

/* サムネ下ナビボタン */
#blog #btn-wrap {
	margin: 0 auto;
	width: 100%;
}
#blog #btn-flex {
	display: flex;
	margin-top: 50px;
}
#blog #btn-flex li {
	border: 1px solid #ddd;
	margin-right: -1px;
	margin-bottom: 0;
	width: 38px;
	height: 38px;
}
#blog #btn-flex li a {
	color: #000;
	text-decoration: none;
	display: block;
	line-height: 38px;
	text-align: center;
	height: 100%;
}
#blog #btn-flex li.current {    /* 変更点 */
	background: #74a92d;
}
#blog #btn-flex li.current a {
	color: #fff;
}
#blog #btn-flex li:hover {
	background: #74a92d;
}
#blog #btn-flex li:hover a {
	color: #fff;
}
#blog #btn-flex li.current {
	background: #74a92d;
	color: #fff;
}
#blog #btn-flex li.iro {
	background: #74a92d;
}
#blog #btn-flex li.iro a {
	color: #fff;
}
/* =============================================================================

	サイドバー・アーカイブ

============================================================================= */
#blog aside {
	width: 200px;
	margin-top: 100px;
	margin-right: 0;
}
#blog .side-ad ul.sub-menu li.catselect a {		/* 変更点 */
	color: #74a92d;
}
#blog .sub-title {
	font-size: 1rem;
	padding: 0 8px 8px;
	border-bottom: 2px #ddd solid;
	font-weight: bold;
	text-align: left;
}
#blog .sub-menu {
	margin-bottom: 60px;
	list-style: none;
}
#blog .sub-menu li {
	border-bottom: 1px #ddd solid;
	text-align: left;
}
#blog .sub-menu a {
	text-decoration: none;
	color: #000;
	padding: 10px;
	display: block;
}
#blog .sub-menu a:hover {
	color: #74a92d;
}

/* blog ここまで↑↑↑↑
============================================================ */

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

 blog2

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

#blog2 #blog-contents {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 50px;
}
/* メインブログエリア 
------------------------------------------------------------ */

#blog2 .title h2 {
	margin-bottom: 0;
}
#blog2 p.date {
	margin-top: 10px;
}
#blog2 article.main {
	width: 720px;
	margin-left: 0;
	padding: 0;
	text-align: left;
}
#blog2 p.date {
	font-size: 14px;
	margin-bottom: 0;
}
#blog2 img#eyecatch-img {
	margin-top: 50px;
	margin-bottom: 0;
	text-align: center;
	vertical-align: center;
	font-size: 20px;
	max-width: 300px;
}
#blog2 #text-box {
	margin-top: 50px;
}
#blog2 dl dt {
	border: 2px solid #ddd;
	padding: 3px;
}

/* サイドバー・アーカイブ =======================================================
============================================================================== */
#blog2 aside {
	width: 200px;
	margin-top: 100px;
	margin-right: 0;
	position: -webkit-sticky;
	position: sticky;
	top: 10px;
}
#blog2 .sub-title {
	font-size: 1rem;
	padding: 0 8px 8px;
	border-bottom: 2px /* #74a92d */ #ddd solid;
	font-weight: bold;
	text-align: left;
}
#blog2 .sub-menu {
	margin-bottom: 60px;
	list-style: none;
}
#blog2 .sub-menu li {
	border-bottom: 1px /* #74a92d */ #ddd solid;
	text-align: left;
}
#blog2 .sub-menu a {
	text-decoration: none;
	color: #000;
	padding: 10px;
	display: block;
}
#blog2 .sub-menu a:hover {
	color: #74a92d;
}
#blog2 ul.sub-menu li.catselect a {
	color: #74a92d;
}
/* ブログ切替ボタン ============================================================
============================================================================= */
#blog2 #btn-wrap {
	width: 980px;
	margin: 0 auto;
}
#blog2 #btn-flex {
	display: flex;
	margin-top: 50px;
	margin-bottom: 50px;
}
#blog2 #btn-flex li {
	padding: 10px 32px;
	border: 1px solid #ddd;
	display: block;
	margin-right: -1px;
	width: 260px;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}
#blog2 #btn-flex li a {
	text-decoration: none;
	font-size: 16px;
}

/* ブログ切替ボタン　戻る */

#blog2 #btn-flex li#back a {
	color: #000;
}
#blog2 #btn-flex li#back:hover {
	background: #74a92d;
}
#blog2 #btn-flex li#back:hover a {
	color: #fff;
}

/* ブログ切替ボタン　進む */

#blog2 #btn-flex li#next a {
	color: #000;
}
#blog2 #btn-flex li#next:hover {
	background: #74a92d;
}
#blog2 #btn-flex li#next:hover a {
	color: #fff;
}
/* blog2 ここまで↑↑↑↑
============================================================ */

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

 contact

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

#contact .wrap {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 20px;
}
/* メイン部分
------------------------------------------------------------ */
#contact .main {
	width: 720px;
    margin: 30px auto 40px;
    padding: 0;
    text-align: left;
    display: block;
}
#contact h3.caption {
	border-bottom: 3px solid #f0f0f0; 
	margin: 0 0 25px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 6px;
}

#contact h3.caption span {
	border-left: 5px solid #74a92d;
	padding: 1px 10px 0;
	display: block;
	line-height: 1.2em;
}*/

/* FAQ
----------------------------------------------------------------------------- */
#contact #faq_wrap {
	margin-top: 30px;
	margin-bottom: 60px;
}
#contact .rows_wrap {
	border-bottom: 1px solid grey;
	margin-bottom: 25px;
}
#contact #faq_wrap p.q_text span {
	background: #74a92d;
	border-radius: 5px;
	color: #fff;
	width: 30px;
	height: 30px;
	text-align: center;
	padding: 0 6px;
	margin-right: 5px;
}
#contact #faq_wrap .rows_wrap p.q_text {
	margin-bottom: 10px;
}
#contact #faq_wrap .rows_wrap p.a_text {
	margin-bottom: 25px;
}
#contact #faq_wrap p.a_text span {
	background: #e83928;
	border-radius: 5px;
	color: #fff;
	width: 30px;
	height: 30px;
	text-align: center;
	padding: 0 6px;
	margin-right: 5px;
}
/* フォームテーブル 
----------------------------------------------------------------------------- */
#contact section#form {
	width: 100%;
	margin: 100px auto;
}
#contact p.index {
	position: relative;
	padding-right: 40px;
	margin-bottom: 5px;
	font-size: 16px;
	font-weight: bold;
}
#contact span.required {
	display: block;
	position: absolute;
	top: 2px;
	right: 0;
	background: #e83928;
	color: #fff;
	line-height: 1.2;
	font-size: 14px;
	padding: 3px 7px 2px;
	border-radius: 3px;
}
#contact span.radioBtn {
	padding: 2px 0 2px 10px;
	display: inline-block;
	cursor: pointer;
}
#contact .name-box {
	margin-bottom: 20px;
}
#contact span.note {
	text-indent: -1rem;
	padding-left: 1rem;
	font-weight: normal;
}
#contact .nameWrap {
	display: inline-block;
}
#contact .nameWrap .name{
	text-align: right;
	display: inline-block;
	width: 2rem;
	margin-right: 10px;
}
#contact table.q-content {
	width: 100%;
	margin-bottom: 50px;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: inherit;
}
#contact table.q-content input[type="email"].long,
#contact table.q-content input[type="text"].long {
	width: 100%;
}
#contact table.q-content ul {
	margin-bottom: 0;
}
#contact table.q-content th,
#contact table.q-content td {
	border: 1px solid #ddd;
}
#contact table.q-content th {
	width: 33%;
	vertical-align: top;
	text-align: left;
	padding: 20px 20px;
	background: #f7f7f7;
}
#contact table.q-content td {
	padding: 20px 20px;
}
#contact input[type="text"],
#contact input[type="email"],
#contact input[type="tel"],
#contact textarea {
	box-sizing: border-box;
	min-width: 100px;
	border: 1px solid #ddd;
	border-radius: 3px;
	font-size: 16px;
	padding: 10px 6px;
}
#contact textarea {
	width: 100%;
}
#contact .drop {
	box-sizing: border-box;
	min-width: 200px;
	padding: 10px 10px 10px 10px;
	line-height: 1.2;
	border: 1px solid #ccc;
	border-radius: 3px;
	position: relative;
	cursor: pointer;
}
#contact #confirm-submit {
	margin: 40px 0 100px;
	text-align: center;
}
#contact p.text-confirm {
	font-weight: bold;
	color: #e83928;
	text-align: center;
	font-size: 18px;
}
#contact #submitBtn .checkBtn input[type="submit"] {
	display: block;
	margin: auto;
	width: 400px;
	background: #e83928;
	text-align: center;
	color: #fff;
	line-height: 60px;
	font-size: 20px;
	border-radius: 30px;
	cursor: pointer;
	outline: none;
	color: #fff;
	letter-spacing: 1px;
	text-shadow: 0;
	font-weight: bold;
	transition: all 0.25s ease;
}
#contact #submitBtn .checkBtn input[type="submit"]:hover {
	color: white;
	opacity: 0.8;
}
#contact #submitBtn .checkBtn input[type="submit"]:active {
	letter-spacing: 2px;
}
#contact #submitBtn .checkBtn input[type="submit"]:after {
	content: "SUBMIT";
}
/* 郵便番号検索ボタン */
#contact .zipBtn {
	display: inline-block;
	margin-left: 10px;
}
#contact .zipSearch {
	display: inline-block;
    padding: 8px 12px;
    background-color: #eee;
    border: 1px solid #aaa;
    font-size: 14px;
    border-radius: 5px;
    cursor: pointer;
}
/* プライバシーポリシー
----------------------------------------------------------------------------- */
#contact section#privacy-policy {
	margin: 0 auto 50px;
	width: 100%;
}
#contact #privacy-box {
	background: #f9f9f9;
	border: 1px solid #e5e5e5;
	margin: 20px 0 0;
}
#contact #privacyIn {
	padding: 30px;
	font-size: 14px;
}

/* サイドバー
---------------------------------------------------------- */
#contact .side {
	width: 220px;
	margin: 140px 5px 20px 50px;
}
#contact .side h3 {
	background: url(../img/right-title.png) 0 0 no-repeat; 
	width: 220px;
	height: 70px;
	line-height: 70px;
	text-align: center;
	font-size: 15px;
	padding: 0;
	margin: 0 0 2px;
	color: #fff;
	font-weight: normal;
	border: none;
}
/* side-navi
----------------------------------------------------------- */
#contact .side .side-navi {
	margin: 0 0 20px;
}
#contact .side .side-navi ul {
	margin: 0;
	padding: 15px 0;
	font-size: 13px;
	line-height: 1.5;
	color: #000;
	background: #fff;
	border: solid 1px #ddd;
}
#contact .side .side-navi ul li {
	line-height: 0;
	vertical-align: bottom;
	text-align: left;
	margin: 0 15px;
	padding: 0;
}
#contact .side .side-navi ul li a {
	display: block;
	background: url(../img/ic_arrow_e.png) 0 10px no-repeat;	
	background-size: 14px 14px;
	padding: 8px 0 8px 20px;
	line-height: normal;
	zoom: 1;
}
#contact .side .side-navi ul li a:link, 
#contact .side .side-navi ul li a:visited {
	text-decoration: none;
	color: #333;
}
#contact .side .side-navi ul li a:hover {
	color: #74a92d !important;
}
#contact .side .side-navi ul li a.current {
	color: #74a92d !important;
	font-weight: bold;
}
/* side-ad
----------------------------------------------------------- */
#contact .side-ad {
	position: -webkit-sticky;
	position: sticky;
	top: 10px;
}
/* contact ここまで↑↑↑↑
=========================================================== */

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

 contact_check

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

#contact_check #warningBox {
	border: 2px solid #e83928;
    text-align: center;
    width: 480px;
    margin: 50px auto 0;
    padding: 20px 10px;
    font-weight: bold;
    color: #e83928;
    box-sizing: border-box;
}
#contact_check .main {
	width: 980px;
}
#contact_check section.form_wrap {
	margin: 50px auto 100px;
	max-width: 720px;
}
#contact_check h3.caption {
	border-left: 5px solid #74a92d;
	margin-bottom: 20px;
	text-align: left;
}
#contact_check h3.caption span {
	margin-left: 10px;
}
#contact_check p.index {
	position: relative;
	padding-right: 40px;
	margin-bottom: 5px;
	font-size: 16px;
	font-weight: bold;
}
#contact_check table.q-content {
	width: 100%;
	margin-bottom: 50px;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: inherit;
	text-align: left;
}
#contact_check table.q-content th,
#contact_check table.q-content td {
	border: 1px solid #ddd;
}
#contact_check table.q-content th {
	width: 33%;
	vertical-align: top;
	text-align: left;
	padding: 20px 20px;
	background: #f7f7f7;
}
#contact_check table.q-content td {
	padding: 20px 20px;
}
#contact_check .text_confirm {
	text-align: center;
	font-size: 18px;
	margin-bottom: 40px;
}
/* ボタン
---------------------------------------------------------- */
#contact_check #buttonWrap {
	display: flex;
	justify-content: center;
}
#contact_check input[type="submit"],
#contact_check button[type="button"] {
	display: inline-block;
	margin: auto;
	width: 350px;
	text-align: center;
	transition: 0.3s ease-in-out;
	color: #fff;
	line-height: 60px;
	font-size: 20px;
	border-radius: 30px;
	cursor: pointer;
	outline: 0;
}
#contact_check input[type="submit"] {
	margin-left: 10px;
	background: #e83928;
}
#contact_check button[type="button"] {
	margin-right: 10px;
	background: #aaa;
	color: #fff;
	display: block;
}
/* contact_check ここまで↑↑↑↑
=========================================================== */

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

 contact_comp ここから↓↓↓↓

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

#contact_comp .main {
	marin: 30px auto 100px;
	width: 90vw;
}
#contact_comp .main dl dd,
#contact_comp .main dl dt {
	padding: 10px;
}
#contact_comp p#send_comp {
	font-size: 16px;
	font-weight: bold;
	color: #e83928;
	margin-top: 20px;
	margin-bottom: 20px;
}
#contact_comp #btn_wrap {
	margin: 0 auto 40px;
	width: 90vw;
}
#contact_comp #btn_wrap button[type="button"] {
	width: auto;
	min-width: 300px;
	margin: auto;
	background: #74a92d;
	text-align: center;
	transition: all 0.25s ease;
	line-height: 60px;
	font-size: 20px;
	border-radius: 30px;
	cursor: pointer;
	outline: 0;
}
#contact_comp #btn_wrap button[type="button"]:hover {
	opacity: 0.8;
}
#contact_comp #btn_wrap button[type="button"] a {
	color: #fff;
	display: block;
	font-weight: bold;
}
/* contact_comp ここまで↑↑↑↑
=========================================================== */

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

 sitemap

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

#sitemap .cont-margin {
	margin-bottom: 50px !important;
}
#sitemap .flexbox {
	display: flex;
	justify-content: space-between;
	width: 980px;
	margin: 0 auto 20px;
}

/* tit
----------------------------------------------------------- */
#sitemap h3 {
	border-bottom: solid 3px #f0f0f0;
	padding: 0;
	margin: 0 0 15px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 6px;
}
#sitemap h3 span {
	font-weight: bold;
	border-left: solid 5px #74a92d;
	padding: 1px 10px 0;
	display: block;
	line-height: 1.2em;
}

/* text
----------------------------------------------------------- */
#sitemap .read {
	font-weight: normal;
	color: #000;
	margin: 0 0 15px;
	font-size: 28px;
	line-height: 1.6;
	font-family: 'Crimson Text', "Times New Roman", Times, "Sawarabi Mincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}
#sitemap .read span{
	color: #74a92d;
	font-weight: bold;
}
#sitemap p.p-1 {
	margin: 0;
	padding: 0;
}
#sitemap p.p-2{
	padding: 0 0 10px 24px;
	margin-bottom: 10px;
}
#sitemap p.p-margin {
	margin-bottom: 20px;
}
#sitemap .p-weight {
	font-weight: bold;
}
#sitemap .p-border{
	border-bottom: dotted 1px #ccc;
}
#sitemap .side ul li {
	text-align: left;
}
/* side
----------------------------------------------------------- */
#sitemap .side {
	width: 220px;
	margin: 140px 5px 20px 50px;
}
#sitemap .side h3 {
	background: url(../img/right-title.png) 0 0 no-repeat;
	width: 220px;
	height: 70px;
	line-height: 70px;
	text-align: center;
	font-size: 15px;
	padding: 0;
	margin: 0 0 2px;
	color: #fff;
	font-weight: normal;
	border: none;
}
/* side-navi
----------------------------------------------------------- */
#sitemap .side .side-navi {
	margin: 0 0 20px;
}
#sitemap .side .side-navi ul {
	margin: 0;
	padding: 15px 0;
	font-size: 13px;
	line-height: 1.5;
	color: #000;
	background: #fff;
	border: solid 1px #ddd;
}
#sitemap .side .side-navi ul li {
	line-height: 0;
	vertical-align: bottom;
	margin: 0 15px;
	padding: 0;
}
#sitemap .side .side-navi ul li a {
	display: block;
	background: url(../img/ic_arrow_e.png) 0 10px no-repeat;
	background-size: 14px 14px;
	padding: 8px 0 8px 20px;
	line-height: normal;
	zoom: 1;
}
#sitemap .side .side-navi ul li a:link, .side .side-navi ul li a:visited {
	text-decoration: none;
	color: #333;
}
#sitemap .side .side-navi ul li a:hover {
	color: #74a92d !important;
}
#sitemap .side .side-navi ul li a.current {
	color: #74a92d !important;
	font-weight: bold;
}
/* side-ad
----------------------------------------------------------- */
#sitemap .side-ad {
	position: -webkit-sticky;
	position: sticky;
	top: 10px;
}
/* table
----------------------------------------------------------- */
#sitemap table {
	width: 720px;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: inherit;
}
#sitemap table.th-top th {
	border-left: solid 1px #fff;
	width: auto;
	text-align: center;
	background: #717171;
	color: #fff;
}
#sitemap table th {
	width: 25%;
	padding: 10px 10px;
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	background: #f9f9f9;
}
#sitemap table td {
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	padding: 10px 10px;
	vertical-align: middle;
}
#sitemap tbody {
	display: table-row-group;
	vertical-align: middle;
	border-color: inherit;
}
/* link
----------------------------------------------------------- */
#sitemap .sitemap-link h3 span {
	border: none;
	padding: 0;
}
#sitemap .sitemap-link h3 a {
	display: block;
	padding: 5px 0;
}
#sitemap .sitemap-link h3 a:link,
#sitemap .sitemap-link h3 a:visited {
	font-weight: bold;
}
#sitemap .sitemap-link ul {
	margin: 0 0 35px 10px;
}
#sitemap .sitemap-link li {
	margin: 0 0 5px;
}
#sitemap .sitemap-link li a {
	background: url(../img/ic_arrow_5.png) 0 50% no-repeat;
	background-size: 4px auto;
	padding: 0 12px;
	display: block;
}
#sitemap .sitemap-link a:link, 
#sitemap .sitemap-link a:visited {
	text-decoration: none;
	color: #111;
}
#sitemap .sitemap-link a:hover {
	text-decoration: underline;
	color: #74a92d;
}

/* @media
----------------------------------------------------------- */
@media screen and (max-width: 1024px) {
#sitemap body {
	background: none;
}

#sitemap .main {
	width: auto;
	margin: 0 auto 40px;
	padding: 0 20px;
}
#sitemap .responsive-img img{
	width: 65%;
	min-width: 380px;
	height: auto;
}
#sitemap .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#sitemap p.p-1, p.p-2 {
	width: 100%;
}
#sitemap .side {
	display: none;
}
#sitemap .flexbox {
	display: block;
	width: 100%;
}
#sitemap .read {
	font-size: 26px;
	line-height: 1.3;
	margin: 0 0 20px;
}
#sitemap table {
	width: 100%;
	}
}
@media screen and (max-width: 767px){
#sitemap #main .read {
	font-size: 20px;
	line-height: 1.5;
	}
}
  /* ===========================================================
  /* ===========================================================
レスポンシブ max-width: 1024px
===========================================================
=========================================================== */

@media screen and (max-width: 1024px) {
	html,
	body {
		background:none;
	}
  header .header-inner {
    width: 100%;
    /*height: 110px;*/
    height: 160px;
    z-index: 100;
    border-bottom: solid 1px #ddd;
  }
  header:before {
    content: " ";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 40px;
    background-color: #74a92d;
    z-index: 200;
  }
  header h1 {
    top: 40px;
    padding-top:10px;
    width: 100%;
    text-align: center;
    height: 60px;
  }
  header h1 img {
 	 width: 90%;
	  max-width: 360px;
	  height: auto;
  }
  header ul.hed-link {
    display: none;
  }
  header .gn {
    position: absolute;
    top: 0;
    right: 0;
    height: auto;
    width:100%;
  }
  header .gn ul.gn__secondary {
    display: none !important;
  }
	header .gn ul.toggle_wrap {
    flex-direction:column;
    transition:all 0.5s;
    width:100%;
    /*height:351px;*/
    position:fixed;
    left:0;
    top:-351px;
    background:#74a92d;
    padding-top:40px;
    z-index:200;
	}
  header .gn ul.toggle_wrap li.gn__primary {
    position: relative;
    width: 100% !important;
    margin: 0 auto;
    padding: 0;
    text-align: center;
    list-style-type: none;
    font-size:14px;
  }
  header .gn ul.toggle_wrap li.gn__primary>a {
    display: block;
		width:100%;
    color: #fff !important;
    font-weight: bold;
    text-decoration: none;
    padding: 20px 0;
		text-align:center;
		border-bottom:1px solid #8fb957;
  }
  header .gn ul.toggle_wrap li.gn__primary:first-of-type>a {
		border-top:1px solid #fff;
  }
  /* #top header .gn ul.toggle_wrap li#gn-top>a:after, */
  #service header .gn ul.toggle_wrap li#gn-service>a:after,
  #blog header .gn ul.toggle_wrap li#gn-blog>a:after,
  #about header .gn ul.toggle_wrap li#gn-about>a:after,
  #contact header .gn ul.toggle_wrap li#gn-contact>a:after {
		display:none;
  }
  header .gn ul.toggle_wrap li.gn__primary:hover>a {
    color: #74a92d !important;
		background-color:#fff;
  }
	header .nav-tel {
	  position:absolute;
	  top: 100px;
	  right: 50%;
 	 -webkit-transform: translateX(50%);
 	 transform: translateX(50%);
		height: 43px;
		width: 310px;
		height: 43px;
    padding: 10px 38px 10px 15px;
	}
	header .nav-tel a {
    font-weight: 800;
    text-shadow: 1px 1px 2px #6e4110;
    transform: scale(1, 1.2);
    display: flex;
    justify-content: space-between;
	}
	header .nav-tel a:hover {
		text-decoration:none;
	}
	header .nav-tel a span.text {
    font-size: 11px;
    line-height: 1.2;
    width: 80px;
    word-break: break-all;
	}
	header .nav-tel a span.tel {
    font-size: 16px;
    transform: scale(1.3, 1.6);
    line-height: 1.7;
    background: url(../img/juwa.png);
    padding-left: 26px;
    background-size: 21px 15px;
    background-repeat: no-repeat;
    background-position-y: 5px;
	}

	.bt-pagetop {
		width: 100%;
		background: url(../img/fot_image.png) center bottom no-repeat;
	}
	.bt-pagetop a {
		display: none !important;
	}
	footer #footer-navi {
		display: none;
	}
	footer #footer-btm {
		padding: 0;
	}
	footer #footer-inner {
		width: 100%;
		flex-direction: column;
	}
	footer #footer-btm ul {
		width: 100%;
		font-size: 14px;
	}
	footer #footer-btm ul li,
	footer #footer-btm ul li:first-child {
		display: block;
		padding: 0;
		border: none;
	}
	footer #footer-btm ul li a {
		position: relative;
		display: block;
		margin: 0;
		padding: 15px 25px 15px 10px;
		border: none;
		border-top: solid 1px #ccc;
		height: auto;
		line-height: 1.4;
		text-decoration: none;
	}
	footer #footer-btm ul li a:before {
		position: absolute;
		content: " ";
		vertical-align: middle;
		top: 50%;
		right: 15px;
		width: 6px;
		height: 6px;
		margin: -4px 0 0;
		border-top: 1px solid #74a92d;
		border-right: 1px solid #74a92d;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	footer #footer-btm p {
		width:  auto;
		text-align: center;
		padding: 25px 10px;
		font-size: 13px;
		line-height: 1.5;
		color: #fff;
		background-color: #74a92d;
	}
	#top #main-visual {
    background: url("../img/main-visual.jpg") 80% 10% no-repeat;
		background-size: cover;
		position: relative;
		min-width: 320px;
		min-height: 400px;
  }
	#top .main-visual-inner{/*追加*/
		width:100%;
		height:100%;
	}
	#top .main-visual-msg {
    position: absolute;
    top: 50%;
    width:100%;
    height: 180px;
  }
  #top .main-visual-msg img.msg {
    width: 300px;
    height: auto;
    margin:0 auto;
    position:absolute;
    top: 3%;
  }
  #top .main-visual-msg a.service-link {
    background-size: 300px auto;
    width:300px;
    height: calc(60px*300/425);
    margin:0 auto;
    position:absolute;
    top: 63%;
  }
	#top .main-visual-msg img.top-pic {
		display:none;
	}
	#top .top-menu ul li {
		margin: 0 5px;
	}
	#top .top-menu ul li.menu3 {
		margin-right: 5px;
	}
	#top .top-menu ul li a {
		width: 300px;
		height: 100px;
		border-radius: 5px;
	}
	#top .top-news {
		width: auto;
		padding: 40px 20px;
		display:block;
	}
	#top .top-news-tit {
		width: 100%;
		text-align: center;
	}
	#top .top-news h2 {
		padding: 55px 0 0;
		margin: 0 0 20px;
		background: url(../img/ic_news.png) 50% 0 no-repeat;
		background-size: 43px auto;
		font-size: 18px;
		text-indent: 0;
		white-space: inherit;
	}
	#top .top-news dl {
		display:block;
		width: auto;
		border: none;
		border-top: dotted 1px #ccc;
		padding: 10px 0 0;
	}
	#top .top-news dt {
		margin: 0;
		padding: 5px 0;
		position: relative;
	}
	#top .top-news dd {
		margin: 0 0 10px;
		padding: 0 0 10px;
		border-bottom: dotted 1px #ccc;
	}
	#top .top-info {
		width: 100%;
		padding-bottom: 0;
		background: none;
		background-color: #fafafa;
		min-width: 320px;
	}
	#top .top-info-container {
		flex-direction: column;
	}
	#top .top-info h2 {
		padding: 55px 0 0;
		margin: 0 0 20px;
		width: 100%;
		height: auto;
		font-size: 18px;
		text-align: center;
		border-bottom: none;
	}
	#top .top-info h2:before {
		border-bottom: none;
	}
	#top .top-trouble {
		width: 300px;
		margin: 0 auto;
		padding: 0 0 50px;
	}
	#top .top-trouble h2 {
		background: url(../img/ic_trouble.png) 50% 0 no-repeat;
		background-size: 46px auto;
	}
	#top .top-trouble ul {
		height:150px;
	}
	#top .top-service {
		width: 300px;
		margin: 0 auto;
		padding: 0 0 50px;
	}
	#top .top-service h2 {
		background: url(../img/ic_service.png) 50% 0 no-repeat;
		background-size: 47px auto;
	}
	#top .top-area {
		width: 300px;
		margin: 0 auto;
		padding: 0 0 30px;
	}
	#top .top-area h2 {
		background: url(../img/ic_area.png) 50% 0 no-repeat;
		background-size: 38px auto;
	}
/* blog↓↓↓↓ ================================================
============================================================= */
	#blog #blog-contents {
		text-align: center;
		display: flex;
		flex-direction: column;
		width: 100%;
	}
	/* ページ見出し */
	#blog .title h2 {
		min-height: inherit;
		line-height: 1.4;
		border-bottom: solid 2px #74a92d;
		padding: 10px 0 10px;
	}
	#blog .title h2 span {
		font-size: 24px;
		border: none;
		padding: 0;
	}
	#blog article.main {
		max-width: 320px;
		margin: 0 auto;
		padding: 0 30px;
	}
	#blog #blog-contents #img-flex {
		display: flex;
		justify-content: space-around;
		flex-direction: row;
		flex-wrap: wrap; 
	}
	#blog .items {
		margin-right: 0px;
		margin-left: 0px;
		margin-bottom: 15px;
	}
	#blog .items dl {
		width: 300px;
		height: 340px;
	}
	#blog .items dl dt {
		width: 300px;
		height: 260px;
	}
	#blog .items dl dd {
		width: 300px;
		height: 80px;
	}
	#blog .items dl dt img {
		width: 100%;
		height: 100%;
		box-sizing: border-box;
		display: block;
		object-fit: cover;
		transition: 0.5s;
	}
	/* ナビボタン */
	#blog #btn-flex {
		justify-content: center;
		margin-bottom: 50px;
	}
	/* サイドバー */
	#blog .side-ad {
		order: 3;
	}
	#blog aside {
		width: auto;
		margin: 30px 30px 0px;
		padding: 0 30px;
	}
	#blog .sub-title {
		text-align: center;
		font-size: 1.375rem;
	}
	#blog .sub-menu li {
		text-align: center;	
	}
/* blog2 ここから
-------------------------------------------------------------- */
	#blog2 #blog-contents {
		text-align: center;
		display: flex;
		justify-content: center;
		flex-direction: column;
		width: 100%;
		margin-bottom: 0;
	}
	/* ページ見出し */
	#blog2 .title {
		word-wrap: break-word;
	}
	#blog2 .title h3 {
		min-height: inherit;
		line-height: 1.4;
		border-bottom: solid 2px #74a92d;
		padding: 10px 0 10px;
	}
	#blog2 .title h3 span {
		font-size: 24px;
		border: none;
		padding: 0;
	}
	/* メインエリア */
	#blog2 article.main {
		order: 1;
		/*width: auto;*/
		width: 100%;
		margin: 0 auto;
		padding: 0 30px;
	}	
	#blog2 .title h2 span {
		width: 280px;
		display: block;
	}
	#blog2 #photo-box {
		text-align: center;
	}
	#blog2 img#eyecatch-img {
		max-width: 260px;
	}
	#blog2 #text-box img {
		width: 90vw;
	}
	/* サイドバー */
	#blog2 aside {
		order: 3;
		width: auto;
		margin: 30px 30px 0px;
		padding: 0 30px;
	}
	#blog2 .sub-title {
		text-align: center;
		font-size: 1.375rem;
	}
	#blog2 .sub-menu li {
		text-align: center;	
	}
/* contact↓↓↓↓ ================================================
============================================================= */

	#contact .wrap {
		display: block;
		margin: 0;
		padding: 0;
		width: 100%;
	}
	#contact .main {
		margin: 0 auto;
		width: auto;
		padding: 0 20px;
	}
	#contact .zipBtn {
		margin-top: 10px;
	}
	#contact h4.caption {
		margin-top: 30px;
	}
	#contact table.q-content {
		width: 100%;
		margin: 0 auto;
		box-sizing: border-box;
		border-collapse: collapse;
	}
	#contact table.q-content th,
	#contact table.q-content td 	{
		width: 100%;
		display: block;
		border-top: none;
	}
	#contact table.q-content tr:first-child th:first-child {
		border-top: 1px solid #ddd;
	}
	#contact .nameWrap {
		display: block;
		margin-bottom: 5px;
	}
	#contact .name-box {
		width: 100%;
	}
	#contact #submitBtn .checkBtn input[type="submit"] {
		width: 100%;
		min-width: 300px;
	}
/* サイドバー消去
----------------------------------------------------------------------------- */
	#contact .side {
		display: none;
	}

/* contact_check↓↓↓↓ ======================================
============================================================= */

	#contact_check #warningBox {
		text-align: left;
		max-width: 720px;
		width: 90vw;
		padding: 10px;
		margin-left: auto;
		margin-right: auto;
	}
	#contact_check #main {
		width: 90vw;
		margin-left: auto;
		margin-right: auto;
	}
	#contact_check section.form_wrap {
		margin: 50px auto 100px;
	}
	
	#contact_check table.q-content {
		width: 100%;
	}
	#contact_check table.q-content th,
	#contact_check table.q-content td {
		width: 100%;
		display: block;
	}
	#contact_check #buttonWrap {
		display: block;
	}
	#contact_check input[type="submit"],
	#contact_check button[type="button"] {
		display: block;
		margin-bottom: 10px;
		width: 100%;
		margin-right: 0;
		margin-left: 0;
	}
}

  /* ===========================================================
  /* ===========================================================
レスポンシブ max-width: 946px
===========================================================
=========================================================== */
@media screen and (max-width: 946px) {
	#top .top-menu ul li:not(:last-of-type) {
		margin-bottom: 10px;
	}
}

  /* ===========================================================
  /* ===========================================================
レスポンシブ min-width: 1024px
===========================================================
=========================================================== */
@media screen and (min-width: 1024px) {

	#navbtn{
    display:none;
	}
}
  /* ===========================================================
  /* ===========================================================
レスポンシブ min-width: 768px
===========================================================
=========================================================== */
@media(min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
  }
}

