@charset "UTF-8";

/* 要素リセット */
body{
   margin: 0;
    padding: 0;
    text-align: center;
    font-size: 16px;
    color: #333; /* 標準文字色 */
    font-family: "Noto Sans JP", sans-serif,'メイリオ' ,Meiryo, 'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'ＭＳ Ｐゴシック' , 'Osaka';
    font-optical-sizing: auto;
    font-weight: weight;
    font-style: normal;
}

/* Safari用ハック 文字サイズ調整 */
/*\*/
html:first-child body{
    font-size: 70%;
}
/* end */

img{
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
}



/*--------------------------------------------------------
  レイアウト設定
--------------------------------------------------------*/
#hpb-container
{
}

#hpb-header{
    width: 80%;
    padding-right: 10%;
    padding-left: 10%;
    height: 150px;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    padding-top: 0;
    text-align: left;
    position: fixed;
    z-index: 99;
    background-color: #fff;
}

#hpb-header::after{
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

*:first-child + html #hpb-header{
    /*for IE7*/
    padding-bottom: 15px;
}

#hpb-headerMain{
    width: 100%;
    height: 4px;
    background-color: #314b06;
    position: fixed;
    z-index: 100;
    top: 0;
}

#hpb-headerLogo{
    width: 470px;
    float: left;
    padding-left: 10px;
    margin-bottom: 5px;
}

*:first-child + html #hpb-headerLogo{
    /*for IE7*/
    margin-bottom: 4px;
}

#hpb-headerExtra1{
    width: auto;
    float: right;
    text-align: right;
    margin-top: 40px;
}

#hpb-inner{
    clear: both;
    width: 100%;
    position: relative;
}

#hpb-inner::after{
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

#hpb-wrapper{
    width: 100%;
    padding-top: 50px;
}

*:first-child + html #hpb-wrapper{
    /*for IE7*/
    margin-top: 20px;
}

#hpb-title{
    margin-top: 15px;
    background-color: #fff;
}

#hpb-main{
    width: 100%;
    padding-top: 10px;
    float: left;
    text-align: left;
    background-color: #fff;
    position: relative;
    top: 100px;
}


#hpb-nav {
    width: 660px;
    height: 46px;
    overflow: hidden;
    position: absolute;
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
    position: fixed;
    z-index: 99;
}

/*--------------------------------------------------------
  デザイン設定
--------------------------------------------------------*/

/* ヘッダー領域 */

#hpb-headerLogo{
    width: 299px;
    float: left;
}

* html #hpb-headerLogo{
    /* for IE6 */
    padding-bottom: 0;
}

#hpb-headerLogo a{
    display: block;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: 0;
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 0;
    padding-left: 0;
    text-indent: -9999px;
    overflow: hidden;
    height: 80px;
    background-image : url(logo_1K.png);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: contain;
}

* html #hpb-headerLogo a{
    /* for IE6 */
    margin-top: 0;
}

.hpb-layoutset-01 #hpb-title{
    width: 66%;
    margin: 0;
    padding: 2% 17% 0;
    background-size: cover;
    height: 660px;
    text-indent: -9999px;
    overflow: hidden;
    position: relative;
    top: 100px;
}

.bg-slider {
  width: 100%;
  margin: 0;
  height: 660px;
  position: relative;
  overflow: hidden;
}

.bg-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: opacity 1s ease-in-out;
  z-index: 1;
}

/* コンテンツ配置領域 */

/* ナビゲーション */
#hpb-nav ul{
    width: 959px;
    margin-top: 0;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: 0;
    padding-top: 0;
    padding-right: 0;
    padding-left: 1px;
    padding-bottom: 0;
    list-style-type: none;
    text-align: center;
    height: 39px;
}

#hpb-nav ul::after{
    content: ".";
    display: block;
    height: 0;
    clear: both;
    height: 39px;
    visibility: hidden;
}

#hpb-nav li{
    float: left;
    font-size: 14px;
    line-height: 39px;
    margin-top: 0;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: 0;
    padding-right: 1px;
    padding-left: 0;
    padding-bottom: 0;
    text-align: center;
}

#hpb-nav li a{
    width: 110px;
    display: block;
    height: 39px;
    overflow: hidden;
}

* html #hpb-nav li a{
    /* ie6用ハック */
    font-size: 12px;
}
/*--------------------------------------------------------
  ナビゲーションデザイン設定
--------------------------------------------------------*/

#hpb-nav li a{
    /* ナビゲーション文字設定 */
    font-weight: normal;
}

#hpb-nav li a:link{
    color: #333;
    text-decoration: none;
}
/* ナビゲーション文字色設定 */
#hpb-nav li a:visited{
    color: #333;
    text-decoration: underline;
}
#hpb-nav li a:hover{
    color: #006400;
    text-decoration: none;
}
#hpb-nav li a:active{
    color: #333;
    text-decoration: underline;
}

#hpb-nav li span.en{
    display: none;
}
#hpb-nav li span.en{
    display: none;
}

#hpb-nav a:link{
    
}
#hpb-nav a:visited{
    
}
#hpb-nav a:hover{
   
}
#hpb-nav a:active{
   
}

h3{
    font-family: "Noto Serif", serif, 'メイリオ' ,Meiryo, 'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'ＭＳ Ｐゴシック' , 'Osaka' ,sans-serif;
    font-size: 30px;
    font-weight: 500;
}

.telbutton {
    display: none;
}

/*hover*/
.hover-zoom{
	width:100%; 
	margin:0 auto; 
	overflow:hidden;
}
.hover-zoom img:hover{
	 transform:scale(1.2,1.2);
	 transition:1s all;
}
.hover-zoom img{
	transition:1s all;
   }

/******************************
 * フェードイン設定
 ******************************/

 .effect {
    opacity: 0;
    visibility: hidden;
    transform: translateY(30px);
    transition: opacity 1s, visibility 1s, transform 1s;
}

.is-fadein {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
}

.effect-right{
	opacity: 0;
    visibility: hidden;
    transform: translateX(30px);
    transition: opacity 1s, visibility 1s, transform 1s;
} 

.is-fadein-right {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.effect-left{
	opacity: 0;
    visibility: hidden;
    transform: translateX(-30px);
    transition: opacity 1s, visibility 1s, transform 1s;
} 


.is-fadein-left {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/*dog*/
 .tera {
      width: 100%;
      height: 250px;
      display: flex;
      overflow: hidden;
      position: relative;
      align-items: center;
      justify-content: flex-end;
      background: url(top/bg_chiheisen_brown.png) no-repeat;
      background-size: cover;
      background-position: top;
      margin-top: 20px;
    }

    .tera-box {
      width: 200px;
      max-width: 350px;
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
    }

    .ball {
      width: 30px;
      height: auto;
      position: absolute;
      left: -70px;
      bottom: 0;
      user-select: none;
    }

    .target {
      width: 100%;
      height: auto;
      user-select: none;
    }
    .target {
    animation: floating-y 1.8s ease-in-out infinite alternate-reverse;
  }
  @keyframes floating-x {
    0% {
      transform: translateX(-10%);
    }
    100% {
      transform: translateX(10%);
    }
  }
  @keyframes floating-y {
    0% {
      transform: translateY(-15%);
    }
    100% {
      transform: translateY(15%);
    }
  }

/*top*/
.top-menu-j{
    font-size: 16px;
    font-weight: 600;
    padding-left: 1em;
}

.top-about{
    margin:auto;
    width: 70%;
    padding: 5% 15%;
    background-image: url(top/about.jpg);
    background-size: cover;
}
.top-about-p{
    width: 60%;
    padding-right: 40%;
}

.btn-ab {
  width: 200px;
  height: 50px;
  font-size: 16px;
  background-color: #314b06;
  font-weight: 100;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 10% 0 10% auto;
  position: relative;
  padding-left: 10px;
  bottom: 0;
}
.btn {
  width: 200px;
  height: 50px;
  font-size: 16px;
  background-color: #314b06;
  font-weight: 100;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 15% auto 10%;
  position: relative;
  padding-left: 10px;
  bottom: 0;
}
.btn a,.btn-ab a{
    letter-spacing: 3px;
}

.top-service{
    max-width:1280px;
    margin:auto;
    width: 90%;
    padding: 15% 5% 0;
}

/*hover*/
.hover-zoom{
	width:100%; 
	margin:0 auto; 
	overflow:hidden;
}
.hover-zoom img:hover{
	transform:scale(1.2,1.2);
	transition:1s all;
}
.hover-zoom img{
	transition:1s all;
}

.top-service-box{
    display:flex;
    flex-wrap:wrap;
    max-width:1280px;
    margin:auto;
    padding: 0;
}
.top-service-box-mini {
  width: 24%;
  margin: 0.5%;
  flex-grow: 1;
  position: relative; 
}
.top-service-box-mini-2 {
  width: 44%;
  margin: 0.5% 1%;
  flex-grow: 1;
  position: relative; 
  overflow: hidden; 
}

.top-service-box2{
    display:flex;
    flex-wrap:wrap;
    max-width:1280px;
    margin:auto;
    padding: 10% 0 0;
}
.top-service-box2-mini-2 {
  width: 44%;
  margin: 0.5% 1%;
  flex-grow: 1;
  position: relative;
}


.top-service-box-mini p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  color: white;
  font-size: 1.2rem;
  font-weight: bold;
  pointer-events: none;
  z-index: 2;
  text-align: center;
  line-height: 1.4;
  white-space: normal;
  word-break: break-word;
  background-color: rgba(24, 23, 23, 0.5);
  padding: 0.5em;
}

.top-service-box-mini-2 img{
    width: 100%;
    position: absolute;
    bottom: 0;  
    left: 0;
}
.top-service-box-mini img{
  width: 100%;
}
.top-service-box2-mini-2 img{
    width: 100px;
    padding-left: 10%;
}

.top-recruit{
    padding-top: 5%;
    background-image: url(top/recruit.png);
    background-size: cover;
    background-position: center;
}
.top-recruit-box{
  display:flex;
  flex-wrap:wrap;
  max-width:1280px;
  margin:auto;
  padding: 5% 0;
}
.top-recruit-box-s{
  width: 25%;
  margin: 0;
  flex-grow: 1;
}
.top-recruit-box-c{
  width: 50%;
  margin: 0;
  flex-grow: 1;
}
.top-recruit-p{
  background-color: rgba(255, 255, 255, 0.7);
  padding: 5%;
}

.top-recruit h3{
    max-width:1280px;
    margin:auto;
    width: 70%;
    padding: 5% 15% ;
    text-align: center;
}

.fixed-background {
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}
 
.background-1 {
  background-image: url(top/top-haikei.jpg);
}


.top-works{
    margin:auto;
    width: 96%;
    padding: 12% 2% 1%;
    background-image: url(top/works.png);
    background-size: cover;
    background-position: right;
}
.top-works h3{
    max-width:1280px;
    margin:auto;
    width: 70%;
    padding: 0 15% 5%;
}

.slider-container {
    position: relative;
    margin: auto;
    overflow: hidden;
}

.slider-wrapper {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.slide {
    flex: 0 0 33.3333%;
    box-sizing: border-box;
}

.slide img {
    width: 86%;
    padding: 0 7%;
    display: block;
}

.slider-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 1;
}

.slider-button.prev {
    left: 10px;
}

.slider-button.next {
    right: 10px;
}

.top-info {
  display: flex;
  flex-direction: column;
  align-items: center; 
  justify-content: center;
  text-align: center; 
  padding: 10% 20px 2%;
}

.top-info img {
  width: 40%;
  padding: 0 0 30px;
  max-width: 300px;
  height: auto;
}

.top-info p {
  text-align: left; 
  max-width: 300px; 
}

#hpb-footer{
    position: relative;
    top: 100px;
}

/*company*/
#company,#contact,#privacy,#work{
    width: 66%; 
    padding: 5% 17% 0;
}

.company{
    padding: 30% 0 5%;
}
.sway-2-dog {
    width: 60%;
    height: auto;
    padding: 10px;
    display: flex;
    overflow: visible;
    position: relative;
    align-items: center;
    justify-content: flex-end;
}
.sway-dog {
    width: 180px;
    margin: 0;
    padding: 30px 30%;
    position: absolute;
    top: -40px;
}

.greeting{
    padding: 5% 0;
}

.contact-tel{
    padding: 5% 5% 10%;
    border: 1px solid #292929;
}
.contact-p{
    padding: 10px 0;
    font-size: 20px;
    text-align: center;
}

.contact-mall{
    padding-top: 15%;
}

.privacy-p{
    font-size: 18px;
    color: #314b06;
}
.privacy-3{
    padding-top: 30px;
    font-size: 25px;
     font-family: "Noto Serif", serif, 'Osaka' ,sans-serif;
     font-weight: 700;
}

/*service*/
#service{
    width: 70%; 
    padding: 5% 15% 0;
}
.service-box{
  display:flex;
  flex-wrap:wrap;
  width: 100%;
  margin: 0;
  padding: 5% 0 0 0;
}

.service-box-l{
  width: 40%;
  padding: 0 4%;
  flex-grow: 1;
}
.service-box-r{
  width: 40%;
  padding: 15% 4% 2%;
  flex-grow: 1;
}
.service-box-r-b{
  width: 40%;
  padding: 15% 4% 2%;
  flex-grow: 1;
  background-image: url(sub/dec.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top;
}
.service-box-l-b{
  width: 40%;
  padding: 0 4% 15%;
  flex-grow: 1;
  background-image: url(sub/dec2.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center calc(100% - 50px);
}
.service-number{
  font-style: italic;
  font-family: "Anton", sans-serif;
  font-weight: 400;
  font-size: 35px;
  color: #3FA32A;
  text-shadow: 2px 2px 4px #fff;
}
.service-menu{
  font-weight: 600;
  font-size: 18px;
  position: relative;
  top: -15px;
  margin: 0;
  text-shadow: 2px 2px 4px #fff;
}
.service-box-p{
  position: relative;
  top: -20px;
}



/*recruit*/
.recruit{
  width: 53%;
  padding: 5% 17% 5% 30%;
}


.recruit-p{
  font-size: 26px;
  font-weight: bold;
  color: #292929;
  padding-left: 10%;
}
.font-s{
  font-size: 20px;
  font-weight: 400;
  padding-left: 10px;
}

.recruit table{
  margin-top: 5px;
  border-collapse: collapse; 
  width: 100%;
  font-size: 15px;
}
.recruit table tr{
  line-height: 2.5;
}
.recruit table th {
  padding: 8px 2%;
  text-align: justify; 
  border-bottom: 2px solid #3FA32A; 
  width: 15%;
  min-width: 10em;
  font-weight: 400;
}
.recruit table th::after {
  content: ''; 
  display: inline-block;
  width: 100%;
}

.recruit table td{
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 5%;
  text-align: left;
  border-bottom-width: 2px;
  border-bottom: 2px solid #2a8fa3;
  letter-spacing: 0.06em;
  font-weight: 400;
}

.section-with-bg {
  position: relative; 
  overflow: hidden;   
  height: auto;     
  margin-bottom: 50px; 
  z-index: 1;
}
/* 背景スクロールエリア */
.scroll-bg {
  position: absolute; 
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1; 
}

/* スクロールアニメーション */
.bbs {
  width: 15%;
  padding-left: 5%;
  height: 100%;
}

.bbs ul {
  animation: flowing 20s linear infinite; 
  font-size: 200px;
  font-weight: 400;
  margin: 0;
  padding: 0 0 0 5%;
  transform: translateY(0);
  color: #dcdcdc; 
}

.bbs ul li {
  display: block; 
  padding: 10px 0; 
  text-align: center;
  line-height: 0.5!important;
  padding-top: 0;
  padding-right: 35px;
  padding-bottom: 0;
  padding-left: 5%;
  color: #ecebeb;
  transform: rotate(90deg);
  font-family: "Anton SC", sans-serif;
  font-style: normal;
  border-bottom-style: none !important;
}

/* 縦スクロールのアニメーション */
@keyframes flowing {
  0% { transform: translateY(0); }
  100% { transform: translateY(-100%); }
}
.character {
    width: 150px;
    padding: 0 10%;
}

.underline-title {
  border-bottom: 2px solid #3FA32A;
  display: inline-block;
  padding-bottom: 20px;
}

/*work*/
.work-box{
  display:flex;
  flex-wrap:wrap;
  width: 100%;
  margin: 0;
  padding: 2% 0;
}
.work-box-mini{
  width: 32%;
  margin: 0 0.5%;
  flex-grow: 1;
}
.work-box-mini p{
  font-size: 16px;
  font-weight: 500;
  padding-bottom: 30px;
}


/* =======================================================
  レスポンシブル設定
======================================================= */
@media screen and (max-width: 660px) {

	body{
		min-width: 100%;
		background-image : none;
	}

	/*--------------------------------------------------------
	  レイアウト設定
	--------------------------------------------------------*/
	#hpb-header{
		width: 50%;
		height: 65px;
		padding-bottom: 10px;
        margin: 0;
        padding-left: 0;
        padding-right: 0;
        z-index: 1000;
	}
	#hpb-headerMain{
		width: 100%;
		padding-left: 0;
		line-height: 1.4;
        z-index: 1001;
	}
	
	#hpb-headerExtra1{
		/*width: 98%;
		float: none;
		margin-left: auto;
		margin-right: auto;
		margin-top: 10px;*/
        display: none;
	}
	#hpb-inner{
		width: 100%;
	}
	#hpb-wrapper{
		width: 100%;
		padding-top: 0;
	}
	#hpb-title{
		margin-top: 0;
	}
	#hpb-main{
		width: 96%;
		padding-left: 0;
		padding-top: 0;
		float: none;
		margin-left: auto;
		margin-right: auto;
		padding-bottom: 20px;
        position: relative;
        top:0;
	}
	.hpb-layoutset-02 #hpb-main{
		padding-top: 0;
        top: 90px;
	}
	
	
	#hpb-nav{
		width: 100%;
		height: auto;
		position: fixed;
		top: 0;
        padding-top: 25px;
        padding-bottom: 15px;
		left: 0;
        transform: none;
        background-color: #fff;
	}

    #hpb-footer{
        position: relative;
        top: 90px;
}

	/*--------------------------------------------------------
	  デザイン設定
	--------------------------------------------------------*/
	/* ヘッダー領域 */
	#hpb-headerLogo{
		width: 98%;
		float: none;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 0;
		padding-left: 0;
	}
	#hpb-headerLogo a{
	  display: block;
		margin-top: 10px;
		margin-bottom: 10px;
		margin-left: auto;
		margin-right: auto;
		background-size: contain;
		background-position: top center;
	}
	.hpb-layoutset-01 #hpb-title{
        width: 100%;
        margin: 0;
        padding: 0;
		background-position: center;
		background-size: cover;
		height: 500px;
        position: relative;
        top: 0;
	}
    .bg-slider{
        height: 500px;
    }
    .bg-img {
        height: 500px;
    }
    #toppage{
        
    }
	

	/* ナビゲーション */
	#hpb-nav ul{
		display: none;
		width: 100%;
		padding-left: 0;
		text-align: left;
		background-image : none;
		height: auto;
        background-color: #fff;
        padding: 10% 0;
        position: relative;
        top: -8px;
	}
	#hpb-nav ul.toggled-on{
		display: block;
	}
	#hpb-nav ul::after{
		display: none;
	}
	#hpb-nav li{
		float: none;
		line-height: 1.4;
		padding-right: 0;
		text-align: left;
		border-top-width: 1px;
		border-top-color: #cccccc;
		border-top-style: solid;
	}
	#hpb-nav li a{
		width: 100%;
		display: block;
		height: auto;
		padding-left: 10px;
		padding-right: 10px;
		padding-top: 10px;
		padding-bottom: 10px;
		box-sizing: border-box;
	}
	#hpb-nav a:link,
	#hpb-nav a:visited,
	#hpb-nav a:hover,
	#hpb-nav a:active{
		background-image : none;
	}
	#hpb-nav li a:hover{
		background-color: #ebebeb;
	}

    .telbutton {
    display: block; 
    position: fixed;
    bottom: 40px;
    right: 10px;
    padding: 6px 12px;
    z-index: 999;
}

    /*top*/
    .top-about{
        margin: 0;
        width: 96%;
        padding: 5% 2%;
    }
    .top-about-p{
        width: 80%;
        padding: 5% 10%;
    }

    .top-service-box-mini,.top-service-box2-mini-2 {
        width: 96%;
        margin: 2%;
    }

    .top-service-box-mini-2 {
        height: auto; 
        position: relative;
        width: 96%;
        margin: 2%;
  }

    .top-service-box-mini-2 img{
        width: 100%;
        position: static;
}

    .top-recruit-box-s{
        width: 5%;
      }
    .top-recruit-box-c{
        width: 90%;
    }

    .top-service-box-mini p{
        font-size: 16px;
    }

    .slide {
        flex: 0 0 100%;
    }

    .bg-img {
        background-size: cover;
        background-position: center;
    }

    #company,#contact,#privacy,#recruit,#service,#work{
    width: 90%; 
    padding: 5% ;
    }

    .sway-dog {
    width: 100px;
    margin: 0;
    padding: 30px 30%;
    position: absolute;
    top: -40px;
}

.privacy-p{
    font-size: 14px;
}
.privacy-3{
    font-size: 18px;
}

.service-box-l,.service-box-r,.service-box-r-b,.service-box-l-b{
  margin: 0;
  width: 96%;
  padding: 5% 2%;
  background-image: none;
}

.service-number{
  font-size: 32px;
}
.service-menu{
  font-size: 17px;
  top: -30px;
}


.work img,.contact img{
  width: 100%;
  padding: 0;
}

.company, .privacy, .contact, .recruit {
  width: 92%;
  padding: 5% 4%;
}

.recruit table th{
  border-bottom: 2px solid #2a8fa3;
}
.recruit table th{
  width: 50%;
  border-bottom-style: dotted;
  border-bottom-color: #2a8fa3; 
  text-align: left;
}

.recruit table th,.recruit table td{
  display: block;
  width: 95%;
}

.underline-title{
  padding-left: 0;
}

.font-s {
  padding-left: 0;
}

.bbs {
  width: 30%;
  padding: 0 0 0 70%;
}

.work-box-mini{
  width: 49%;
  margin: 0 0.5%;
}



}

