@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   page
         - index
         - service
									- company
									- works
									- recruit
									- news
									- blog
									- contact

--------------------------------------------------------------------------------------------------*/


/*--------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------*/
#banner {
  position: relative;
  overflow-y: hidden;
}

#banner h2 {
  padding-bottom: 38px;
}

#banner .photo {
  width: 100%;
}

#banner .text {
  position: absolute;
  height: 100%;
  width: 100%;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  text-align: center;
}

#banner h2 {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  padding-top: 23px;
}

#banner .text img {
  position: absolute;
		cursor: pointer;
}

#banner .text .photo1 {
  right: 39%;
  top: 5.6%;
}

#banner .text .photo2 {
  left: 33.3%;
  bottom: 18.5%;
}

#banner .text .photo3 {
  right: 30.8%;
  bottom: 1%;
}

#morning-afternoon-time .photo1 {
  width: 5.55%;
}

#morning-afternoon-time .photo1:hover {
  width: 7.4%;
}


#morning-afternoon-time .photo2 {
  width: 7.2%;
}

#morning-afternoon-time .photo2:hover {
  width: 8%;
}

#morning-afternoon-time .photo3 {
  width: 8.75%;
}

#morning-afternoon-time .photo3:hover {
  width: 10.4%;
}


#evening-night-time .photo1 {
  width: 5.95%;
}

#evening-night-time .photo1:hover {
  width: 7.45%;
}

#evening-night-time .photo2 {
  width: 6.15%;
}

#evening-night-time .photo2:hover {
  width: 6%;
}

#evening-night-time .photo3 {
  width: 7%;
}

#evening-night-time .photo3:hover {
  width: 7%;
}


#night-time .photo1 {
  width: 6.65%;
}

#night-time .photo1:hover {
  width: 6.65%;
}

#night-time .photo2 {
  width: 6.95%;
}

#night-time .photo2:hover {
  width: 6.94%;
}

#night-time .photo3 {
  width: 7.25%;
}

#night-time .photo3:hover {
  width: 7.25%;
}



#evening-night-time .text .photo3 {
  bottom: 7.9%;
}

#evening-night-time .text .photo1 {
  left: 55.1%;
  bottom: 75.8%;
  right: unset;
  top: unset;
}

#night-time .text .photo1 {
  left: 54.8%;
  bottom: 76.4%;
  right: unset;
  top: unset;
}

#night-time .text .photo3 {
  bottom: 8.8%;
}


#night-time h2 {
  color: #fff;
}

#night-time h2::after {
  background-color: #fff;
}

#banner .indexscroll {
margin: -40px auto 0;
left: 0;
right: 0;
position: absolute;
bottom: 10px;
z-index: 100;
}

#banner .indexscroll a {
width: 200px;
height: 60px;
margin: 0 auto;
display: block;
}

#new-blog {
  padding: 80px 0 90px 0;
}

#new-blog .container {
  justify-content: space-between;
}

#new-blog .new-box,
#new-blog .blog-box {
  width: 46%;
  letter-spacing: 0.5px;
}

#new-blog .new-box h2,
#new-blog .blog-box h2 {
  margin-bottom: 38px;
}

#new-blog span {
  display: inline-block;
}

#new-blog .new-box .list-new {
  margin-bottom: 45px;
}

#new-blog .new-box li {
  width: 100%;
  border-top: 1px solid #b9b9b9;
  line-height: 19px;
}

#new-blog .new-box li a {
  padding: 17px 0 17px;
}

#new-blog .new-box li:last-child {
  border-bottom: 1px solid #b9b9b9;
}

#new-blog .new-box li .date {
  width: 150px;
  color: #acacaf;
}

#new-blog .icon-new {
  padding: 0px 10px;
  display: inline-block;
  border: 1px solid #4e9041;
  color: #4e9041;
  font-size: 11px;
  border-radius: 15px;
  margin-left: 5px;
  letter-spacing: 2px;
}

#new-blog .blog-box li {
  width: 208px;
}

#new-blog .blog-box li img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	border: 1px solid #CCC;
}

#new-blog .blog-box li .date {
  margin: 15px 0 7px 0;
  line-height: 19px;
  color: #acacaf;
  justify-content: space-between;
}

#new-blog .blog-box li .title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#new-blog .blog-box .list-blog {
  margin-bottom: 25px;
  justify-content: space-between;
}

#service-box,
#work-box {
  width: 98%;
  margin: 0 auto;
  padding: 70px 0 80px 0;
  border-radius: 20px;
}

#service-box {
  background: url(../image/bg1-service.png) no-repeat left calc(50% - 545px) top 60px,url(../image/bg2-service.png) no-repeat right calc(50% - 545px) bottom 75px #b9dc99;
  margin-bottom: 20px;
}

#work-box {
  background: url(../image/bg1-service.png) no-repeat left calc(50% - 545px) top 60px,url(../image/bg2-service.png) no-repeat right calc(50% - 545px) bottom 75px #c5e7f8;
}

#service-box .list-info {
  justify-content: space-between;
  margin: 53px 0 50px 0;
}

#service-box .list-info li {
  width: 290px;
  height: 290px;
  background-color: #fff;
  position: relative;
  border-radius: 50%;
  text-align: center;
}

#service-box .list-info li:hover {
	background-color: #FFFEE3;
}

#service-box .list-info li .number {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  color: #fff;
  font-weight: 700;
  font-size: 27px;
  line-height: 60px;
  text-align: center;
  display: block;
  background-color: #1c2e43;
  position: absolute;
  left: 10px;
  top: 22px;
}

#service-box .list-info li .number::after {
  content: "";
  position: absolute;
  right: 4px;
  bottom: 2px;
  height: 65px;
  width: 0;
  height: 0;
  border-top: 12px solid transparent;
  border-right: 20px solid #1c2e43;
  border-bottom: 12px solid transparent;
  transform: rotate(-30deg);
}

#service-box .list-info li .photo {
  margin: 65px 0 15px 0;
  height: 120px;
}

#service-box .list-info li .photo {
  align-items: flex-end;
  justify-content: center;
}


#service-box .list-info li h3 {
  font-size: 18px;
  padding: 0 60px;
  letter-spacing: 2px;
}

#work-box .list-info {
  justify-content: space-between;
  margin-top: 50px;
  margin-bottom: 42px;
  letter-spacing: 0.5px;
}

#work-box .list-info li {
  width: 31.3%;
}

#work-box .list-info li .photo {
  position: relative;
}

#work-box .list-info li .photo img {
  max-width: 100%;
  height: auto;
}

#work-box .list-info li .photo .text {
  min-width: 146px;
  display: inline-block;
  position: absolute;
  left: 0;
  bottom: 0;
  border-bottom-left-radius: 8px;
  border-top-right-radius: 8px;
  background-color: #1c2e43;
  color: #fff;
  padding: 6px 10px;
  font-size: 12px;
  text-align: center;
}

#work-box .list-info li h3 {
  font-size: 15px;
  padding-top: 14px;
}

#work-box .list-info li:hover img {
	opacity: 0.8;
}

#link-box {
  padding: 84px 0;
}

#link-box ul {
  justify-content: space-between;
}

#link-box li {
  width: 47%;
}

#link-box li a {
  width: 100%;
  padding: 42px 0 45px 0;
  text-align: center;
  border-radius: 15px;
  color: #3e404a;
  font-size: 20px;
  letter-spacing: 2px;
}

#link-box li:first-child {
  background: url(../image/icon1-link.png) no-repeat 88px center;
}

#link-box li:first-child a:hover {
  background: url(../image/icon1-link.png) #E5F6F5 no-repeat 86px center;
}

#link-box li:last-child {
  background: url(../image/icon2-link.png) no-repeat 78px center;
}

#link-box li:last-child a:hover {
  background: url(../image/icon2-link.png) #E5F6F5 no-repeat 76px center;
}

#link-box li .btn::before {
  right: 65px;
}

#link-box li .btn::after {
  width: 65px;
}

#link-box li .btn:hover::before {
	right: 0;
}


/*--------------------------------------------------------------------------------------------
  service
--------------------------------------------------------------------------------------------*/
#second.service {
	background-color: #b9dc99;
}

#second .inner .serviceBox {
	padding-top: 50px;
	margin-top: -50px;
}

#second .inner .serviceBox h2 {
	margin: 0 0 32px;
	font-size: 20px;
	padding: 10px 10px 10px 60px;
	text-align: left;
	background-color: #CCECEB;
	position: relative;
}

#second .inner .serviceBox h2:after {
	top: -24px;
	left: -16px;
	right: auto;
	width: 60px;
	height: 60px;
	line-height: 60px;
	margin: 0;
	border-radius: 50%;
	background-color: #1c2e43;
	color: #FFF;
}

#second .inner .serviceBox:nth-of-type(1) h2:after {
	content: "01";
}

#second .inner .serviceBox:nth-of-type(2) h2:after {
	content: "02";
}

#second .inner .serviceBox:nth-of-type(3) h2:after {
	content: "03";
}

#second .inner .serviceBox h2:before {
  content: "";
  position: absolute;
  left: 28px;
  top: 8px;
  height: 65px;
  width: 0;
  height: 0;
  border-top: 12px solid transparent;
  border-right: 20px solid #1c2e43;
  border-bottom: 12px solid transparent;
  transform: rotate(220deg);
		background-color: #CCECEB;
}

#second .inner .serviceBox .text {
	margin: 0 5%;
	font-size: 16px;
}

#second .inner .serviceBox .al-center .btn {
	margin: 0 0 60px;
}

#second .inner .serviceBox .tool {
	margin: 0 0 40px;
	border: 4px solid #E7F3FA;
	padding: 24px 16px 0;
	border-image: url(../image/gd_line-01.png);
 border-image-slice: 1;
 border-image-repeat: stretch;
	display: flex;
	justify-content: center;
}

#second .inner .serviceBox dl {
	width: 48%;
	margin: 0 1%;
}

#second .inner .serviceBox dl dt {
	background-color: #F1F8EB;
	padding: 6px;
	font-weight: 700;
}

#second .inner .serviceBox dl dd {
	margin: 0 0 10px;
	padding: 6px;
}

#second .inner .serviceBox dl dd ul li {
	position: relative;
	padding: 0 0 0 22px;
}

#second .inner .serviceBox dl dd ul li:before {
	content: "";
	background-color: #1c2e43;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	position: absolute;
	top: 8px;
	left: 8px;
}


/*--------------------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------------------*/
#second.company {
	background-color: #E6E7BC;
}

.gaiyou {
	width: 80%;
	margin: 0 auto 40px;
	display: flex;
	flex-wrap: wrap;
}

.gaiyou dt {
	width: 20%;
	margin-right: 2%;
	padding: 24px 16px;
	border-top: 2px solid #00A29C;
}

.gaiyou dd {
	width: 78%;
	padding: 24px 16px;
	border-top: 2px solid #CCC;
}

.gmap iframe{
	margin: 0 0 40px;
	width: 100%;
}

/*.gmap {
 height: 0;
 overflow: hidden;
 padding-bottom: 56.25%;
 position: relative;
}

.gmap iframe {
 position: absolute;
 left: 0;
 top: 0;
 height: 100%;
 width: 100%;
}*/



/*--------------------------------------------------------------------------------------------
  works
--------------------------------------------------------------------------------------------*/
#second.works {
	background-color: #c5e7f8;
}

#second.works .list-info {
 	justify-content: space-around;
  margin: 0 20px;
  letter-spacing: 0.5px;
		flex-wrap: wrap;
}

#second.works .list-info li {
  width: 30%;
		margin: 0 0 80px;
}

#second.works .list-info li .photo {
  position: relative;
}

#second.works .list-info li .photo img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

#second.works .list-info li .photo .text {
  min-width: 146px;
  display: inline-block;
  position: absolute;
  left: 0;
  bottom: 0;
  border-bottom-left-radius: 8px;
  border-top-right-radius: 8px;
  background-color: #1c2e43;
  color: #fff;
  padding: 6px 10px;
  font-size: 12px;
  text-align: center;
}

#second.works .list-info li h3 {
  font-size: 15px;
  padding-top: 14px;
}

#second.works .list-info li:hover img {
	opacity: 0.8;
}

#second.works .catMenu {
	margin: 0 0 50px;
	display: flex;
	justify-content: center;
}

#second.works .catMenu li {
	width: 20%;
	margin: 0 2%;
	text-align: center;
}

#second.works .catMenu li a {
	display: block;
	padding: 12px;
	border: 2px solid #1c2e43;
	border-radius: 20px;
	position: relative;
}

#second.works .catMenu li a:hover {
	background-color: #1c2e43;
	color: #FFF;
}

#second.works .catMenu li a:hover::before {
	position: absolute;
	width: 63px;
	height: 30px;
	top: -31px;
	left: 10%;
	background: url(../image/second_frog.png) no-repeat;
	background-size: 63px;
	content: "";
}


/*--------------------------------------------------------------------------------------------
  works-detail
--------------------------------------------------------------------------------------------*/
.worksDetail {
	margin: 40px 24px 0;
	display: flex;
	justify-content: space-between;
}

.worksDetail .text {
	width: 64%;
}

.worksDetail .image {
	width: 32%;
}

.worksDetail .image ul li {
	margin-bottom: 24px;
}

.worksDetail .image ul li img {
	max-width: 100%;
	border: 1px solid #CCC;
}

.worksDetail .spec {
	width: 100%;
	margin: 0 0 32px;
}

.worksDetail .spec th {
	text-align: left;
	width: 20%;
	white-space: nowrap;
	padding: 8px;
	border-bottom: 1px dotted #CCC;
	background-color: #E2F3FB;
}

.worksDetail .spec td {
	padding: 8px 8px 8px 16px;
	border-bottom: 1px dotted #CCC;
}

#second.works .inner .al-center .btn {
	margin-bottom: 60px;
}

.worksCat {
	margin: -32px auto 0 0 !important;
	padding: 6px;
	color: #FFF;
	position: relative;
	width: 200px;
	text-align: right;
	background-color: #1c2e43;
	text-align: center;
}

.worksCat::before {
	position: absolute;
	bottom: 2px;
	right: 2px;
	background-color: rgba(255, 255, 255, .7);
	content: "";
	width: 8px;
	height: 1px;
}

.worksCat::after {
	position: absolute;
	bottom: 2px;
	right: 2px;
	background-color: rgba(255, 255, 255, .7);
	content: "";
	width: 1px;
	height: 8px;
}


/*--------------------------------------------------------------------------------------------
  recruit
--------------------------------------------------------------------------------------------*/
#second.recruit {
	background-color: #E6E7BC;
}



/*--------------------------------------------------------------------------------------------
  news
--------------------------------------------------------------------------------------------*/
#second.news {
	background-color: #E6E7BC;
}

#second.news .list-new {
  margin-bottom: 45px;
}

#second.news .list-new li {
  width: 100%;
  border-top: 1px solid #b9b9b9;
  line-height: 19px;
}

#second.news .list-new li:last-child {
  border-bottom: 1px solid #b9b9b9;
}

#second.news .list-new li .date {
  width: 150px;
  color: #acacaf;
}

#second.news .list-new li a {
	padding: 17px 10px;
}

#second.news .list-new li a:hover {
	background-color: #F9F9F0;
}

#second.news .icon-new {
  padding: 0px 10px;
  display: inline-block;
  border: 1px solid #4e9041;
  color: #4e9041;
  font-size: 11px;
  border-radius: 15px;
  margin-left: 5px;
  letter-spacing: 2px;
}

.newsDate i {
	margin-right: 4px;
}

.newsDetail {
	margin: 0 0 60px;
	font-size: 16px;
}

#second.news .inner .al-center .btn {
	margin-bottom: 60px;
}


/*--------------------------------------------------------------------------------------------
  blog
--------------------------------------------------------------------------------------------*/
#second.blog {
	background-color: #A8DFDE;
}

.listblog {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}

.listblog li {
	width: 30%;
	margin: 0 0 60px;
}

.listblog li img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	border: 1px solid #CCC;
}

.listblog li .title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.listblog li .date {
  margin: 15px 0 7px 0;
  line-height: 19px;
  color: #acacaf;
  justify-content: space-between;
}

.listblog li .icon-new {
  padding: 0px 10px;
  display: inline-block;
  border: 1px solid #4e9041;
  color: #4e9041;
  font-size: 11px;
  border-radius: 15px;
  margin-left: 5px;
  letter-spacing: 2px;
}

.blogDetail {
	position: relative;
	padding: 20px;
	background-color: #FFF;
}

.blogDetail::before {
	content: "";
	width: 108px;
	height: 94px;
	position: absolute;
	top: -24px;
	right: -10px;
	background: url(../image/flog_back.png) no-repeat 0 0;
}

.blogDate i {
	margin-right: 4px;
}

.blogDetail div {
	font-size: 16px;
}

#second.blog .inner .al-center .btn {
	margin-bottom: 60px;
}

/*--------------------------------------------------------------------------------------------
  contact
--------------------------------------------------------------------------------------------*/
#second.contact {
	background-color: #A8DFDE;
}

#second.contact .inner {
	font-size: 16px;
}

.hs {
	color: #F00;
}

.contactTb {
	width: 90%;
	margin: 0 auto 30px;
}

.contactTb th {
	width: 24%;
	white-space: nowrap;
	padding: 16px;
	text-align: left;
	font-weight: normal;
	border-bottom: 1px solid #CCC;
}

.contactTb td {
	padding: 16px;
	border-bottom: 1px solid #CCC;
}

.contactTb td input[type="text"] {
	padding: 8px;
	width: 80%;
 font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
}

.contactTb td input#zip {
	padding: 8px;
	width: 80%;
 font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
}

.contactTb td label {
	margin-right: 20px;
}

.contactTb td textarea {
	display: block;
	padding: 8px;
	width: 80%;
 font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
}

.contactBtn {
	margin: 0 0 60px;
	text-align: center;
}

.contactBtn input {
	margin: 0 10px;
	padding: 8px 20px;
}

.error {
    color: #F00 !important;
    background-color: #FEFCEB;
    padding: 4px;
}

.privacy {
	background-color:#FFFFFF;
	width: 98%;
	margin: 0 auto 20px;
	height: 150px;
	padding: 20px;
	overflow:auto;
	overflow-y:scroll;
	overflow-x:hidden;
	border: 1px solid #CCC;
	font-size: 14px;
}

.privacy ol {
	margin: 0 0 0 20px;
	padding: 0;
}

.privacy ol li {
	margin: 0 0 10px;
	padding: 0;
	list-style: decimal;
}
