@charset "UTF-8";

.site_logo .logo_img {
  width: 5.0625em;
  height: 2em;
}
.title em {
  font-style: normal;
}

.title [lang="en"], 
.wp-block-button .wp-block-button__link {
  font-family: 'Raleway', sans-serif;
  letter-spacing: 0.1em;
}

#header, 
#footer {
  background-color: rgba(111, 186, 44, 0.7);
}
#header a, 
#head_menu a, 
#footer a {
  color: inherit;
  fill: inherit;
  text-decoration: none;
}


#header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  padding: 1rem 0;
  color: #FFF;
  fill: #FFF;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
#header .site_logo {
  font-size: 1.5em;
}
@media only screen and (max-width:600px) {
  #header.-fix {
    padding: 0.5rem 0;
  }
  #header.-fix .site_logo {
    font-size: 1em;
  }
}
@media print, (min-width:601px) {
  #header {
    padding-top: 1.5rem;
    height: 6rem;
  }
  #header.-fix {
    padding-top: 1rem;
    font-size: 0.75em;
    height: 4.3rem;
  }
  #header > .inner {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    max-width: none;
  }
  #header > .inner::after {
    display: none;
  }
}

#header .info_menu {
  font-size: 0.8125em;
  line-height: 1;
  white-space: nowrap;
  -ms-word-break: keep-all;
  word-break: keep-all;
}
.info_menu .menu_title {
  margin-bottom: 0.5em;
  font-weight: normal;
}
.info_menu a svg {
  vertical-align: middle;
}
.info_menu a.info_tel .menu_txt {
  width: 9.625em; 
  height: 1em;
}
.info_menu a.info_contact .menu_txt {
  width: 9.8125em; 
  height: 1em;
}
.info_menu a.info_contact .menu_icn {
  width: 1em;
  height: 1em;
  font-size: 1.25em;
}
@media only screen and (max-width:600px) {
  #header .info_menu {
    margin-top: 1rem;
  }
  .info_menu a {
    display: block;
  }
  .info_menu a.info_tel {
    float: left;
  }
  .info_menu a.info_contact {
    float: right;
  }
}
@media print, (min-width:601px) {
  .info_menu .menu_title {
    margin-bottom: 1em;
  }
  .info_menu a {
    display: inline-block;
  }
  .info_menu a + a {
    margin-left: 1em;
  }
  .info_menu a.info_tel .menu_txt {
    font-size: 1.25em;
  }
  .info_menu a.info_contact .menu_icn {
    font-size: 1.75em;
  }
}


#head_menu {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
}
.site_menu .sub-menu {
  list-style: none;
}
@media only screen and (max-width:600px) {
  #head_menu {
    font-size: 0.875em;
  }
  #head_menu_btn {
    position: fixed;
    background-color: rgba(255,255,255,0.7);
    color: #6fba2c;
  }
  .site_menu a {
    padding-left: 2em;
    line-height: 1.25;
  }
  .site_menu li a::before {
    content: '';
    display: inline-block;
    margin-bottom: 0.2em;
    margin-left: -1.2em;
    margin-right: 0.7em;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.3em 0 0.3em 0.5em;
    border-top-color: transparent;
    border-bottom-color: transparent;
    vertical-align: middle;
  }
  .site_menu .sub-menu {
    display: none;
  }
}
@media print, (min-width:601px) {
  #head_menu {
    padding-top: 6rem;
    background-color: rgba(255,255,255,0.7);
    font-size: 0.75em;
    -webkit-box-shadow: 0 1px 2px 0 rgba(0,0,0,0.2);
    box-shadow: 0 1px 2px 0 rgba(0,0,0,0.2);
    z-index: 1900;
  }
  #header.-fix ~ #head_menu {
    padding-top: 4.3rem;
  }
  #head_menu > .menu_inner {
    margin-right: auto;
    margin-left: auto;
    width: 90%;
  }
  .site_menu a {
    padding: 0 0.5em;
    line-height: 1.25;
    -ms-word-break: keep-all;
    word-break: keep-all;
  }
  #head_menu .site_menu a:hover {
    color: #6fba2c;
  }
  .site_menu a > span {
    display: inline-block;
  }
  .site_menu .menu_list {
    display: table;
    border-collapse: separate;
    border-spacing: 0 0.75rem;
    width: 100%;
  }
  .site_menu .menu_list > li {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
  }
  .site_menu .menu_list > li + li {
    border-left: solid 1px rgba(0,0,0,0.5);
  }
  .site_menu .sub-menu, 
  .site_menu .sub-menu > li {
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;    
  }
  .site_menu .sub-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    margin-top: 0.5rem;
    border-style: solid;
    border-width: 2px;
    border-color: #6fba2c;
    background-color: rgba(255,255,255,0.7);
    opacity: 0;
    -webkit-box-shadow: 0 1px 1px 0 rgba(0,0,0,0.2);
    box-shadow: 0 1px 1px 0 rgba(0,0,0,0.2);
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  .site_menu .sub-menu::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 100%;
    right: 0;
    left: 0;
    margin: auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0.4em 0.75em;
    border-color: #6fba2c transparent;
  }
  .site_menu .sub-menu > li {
    max-height: 0;
    overflow: hidden;
  }
  .site_menu .sub-menu > li + li {
    border-top: solid 1px rgba(0,0,0,0.5);
  }
  .site_menu .sub-menu a {
    padding: 0.5em 1em;
    white-space: nowrap;
  }
  .site_menu .menu_list > li:hover .sub-menu {
    opacity: 1;
  }
  .site_menu .menu_list > li:hover .sub-menu > li {
    max-height: 5em;
  }
}

#footer > .inner {
  padding: 1.5rem 0;
}
@media only screen and (max-width:600px) {
  #footer {
    text-align: center;
  }
}
@media print, (min-width:601px) {
  #footer > .inner {
    padding: 3rem 0;
  }
}

#footer .foot_menu {
  font-size: 0.9375em;
  line-height: 1;
}
.foot_menu .menu_list > li {
  display: inline-block;
  margin: 0.5em 0;
}
@media only screen and (max-width:600px) {
  .foot_menu .menu_list > li {
    width: 48%;
  }
}
@media print, (min-width:601px) {
  .foot_menu .menu_list > li + li {
    margin-left: 0.5em;
    padding-left: 0.5em;
    border-style: solid;
    border-width: 0 0 0 1px;
  }
}


#footer .copyright {
  margin-top: 1rem;
  font-size: 0.75em;
  line-height: 1;
  letter-spacing: 0.1em;
}



.cont_block .cont_visual {
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover;
}
.cont_visual > .inner::before {
  content: '';
  display: block;
}
.cont_block .cont_head {
  margin: auto;
  text-align: center;
}
.cont_visual .cont_head {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  -o-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.cont_head .cont_title, 
.cont_block .sect_title {
  margin-bottom: 1.5rem;
  font-size: 1em;
  font-weight: normal;
  line-height: 1.5;
  text-align: center;
}
.cont_head .cont_copy {
  font-weight: bold;
  font-size: 0.875em;
}
.cont_block .cont_body > .inner {
  padding: 1.5rem 0 3rem;
}
@media only screen and (max-width:600px) {
  .cont_visual > .inner::before {
    padding-top: 100%;
    padding-top: 100vmin;
  }
  .cont_head > .inner {
    padding-top: 8.25rem;
  }
  .cont_visual .cont_head {
    top: -webkit-calc( ( 100% - 8.25rem ) / 2 );
    top: calc( ( 100% - 8.25rem ) / 2 );
    margin-top: 8.25rem;
  }
  .cont_head .cont_title [lang="en"], 
  .cont_block .sect_title [lang="en"] {
    font-size: 1.5em;
  }
  .cont_visual .cont_head .cont_title {
    font-size: 1.625em;
  }
  .cont_head > .inner .cont_title {
    margin-top: 1.5rem;
  }
}
@media print, (min-width:601px) {
  .cont_visual > .inner::before {
    padding-top: 56.25%;
  }
  .cont_head > .inner {
    padding-top: 8.4rem;
  }
  .cont_visual .cont_head {
    top: -webkit-calc( ( 100% - 8.4rem ) / 2 );
    top: calc( ( 100% - 8.4rem ) / 2 );
    margin-top: 8.4rem;
  }
  .cont_block .cont_title [lang="en"], 
  .cont_block .sect_title [lang="en"] {
    font-size: 2.5em;
  }
  .cont_visual .cont_head .cont_title {
    font-size: 3em;
  }
  .cont_head > .inner .cont_title {
    margin-top: 3rem;
  }
}




/* cont_menu */
.cont_menu {
  text-align: center;
}
.cont_menu .menu_title {
  margin-bottom: 1.5rem;
  font-size: 1em;
  font-weight: normal;
  line-height: 1.5;
}
.cont_menu a {
  display: block;
  text-decoration: none;
  color: inherit;
  line-height: 1.25;
}
.cont_menu .menu_list {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  text-align: center;
}
.cont_menu .menu_list > li {
  margin: 1rem 0 0;
}
.cont_menu .menu .menu_thumb, 
.cont_menu .menu .menu_txt {
  display: block;
}
@media only screen and (max-width:600px) {
  .cont_menu > .inner {
    padding: 3rem 0;
  }
  .cont_menu .menu_title [lang="en"] {
    font-size: 1.5em;
  }
}
@media print, (min-width:601px) {
  .cont_menu > .inner {
    padding: 4.5rem 0;
  }
  .cont_menu .menu_title [lang="en"] {
    font-size: 2.5em;
  }
}


/* post_block */
.cont_block .post_block .post_head, 
.cont_block .content .post_title {
  background-color: rgba(111, 186, 44, 0.7);
  color: #FFF;
  fill: #FFF;
  text-align: center;
}
.cont_block .post_block .post_head > .inner, 
.cont_block .content .post_title {
  padding: 1rem 0;
}
.cont_block .post_title {
  line-height: 1.25;
}
.cont_block .content .post_title {
  margin-bottom: 3rem;
  position: relative;
  left: 50%;
  width: 100%;
  width: 100vw;
  font-size: 1em;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  -o-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}
.cont_block .post_title em {
  font-family: serif;
  font-weight: 400;
  letter-spacing: 0.1em;
  font-size: 1.25em;
}
.cont_block .post_block .post_body > .inner {
  padding: 1.5rem 0;
}
@media print, (min-width:601px) {
  .cont_block .post_block .post_body > .inner {
    padding: 4.5rem 0;
  }
  .cont_block .post_title em {
    font-size: 2em;
  }
}


.sect_block.anti_inner {
  margin-top: 3rem;
  padding: 3rem 0;
  background-color: #eae5e3;
}
.sect_block.anti_inner .sect_title {
  margin-top: auto;
}


.service_menu {
  background-color: #eae5e3;
  text-align: center;
}
.service_menu > .inner {
  padding: 3rem 0;
}
.service_menu .menu_title {
  font-size: 1.5em;
  line-height: 1.5;
}
.service_menu .menu_list {
  text-align: left;
}
.service_menu .menu_list > li {
  margin-top: 1.5rem;
}
.service_menu .menu .menu_name {
  line-height: 1.25;
}
.service_menu .menu .menu_name > em {
  font-size: 0.875em;
}
.service_menu .menu .menu_text {
  margin-top: 0.5em;
  font-size: 0.75em;
  line-height: 1.5;
}
@media only screen and (max-width:600px) {
  .service_menu .menu {
    padding-left: 6em;
    min-height: 5em;
  }
  .service_menu .menu .menu_name > [lang="en"] {
    display: none;
  }
  .service_menu .menu .menu_thumb {
    position: absolute;
    top: 0;
    left: 0;
    margin-top: 0.25em;
    width: 5em;
  }
}
@media print, (min-width:601px) {
  .service_menu > .inner {
    padding: 4.5rem 0;
  }
  .service_menu .menu_title {
    font-size: 2.5em;
  }
  .service_menu .menu_list {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .service_menu .menu_list > li {
    margin-top: 3rem;
    width: 32%;
  }
  .service_menu .menu {
    padding-top: 2em;
    padding-bottom: 1.5em;
  }
/*
  .service_menu .menu.menu_l {
    padding-top: 2em;
  }
*/
  .service_menu .menu .menu_name {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    line-height: 1;
  }
  .service_menu .menu .menu_name > em {
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    font-size: 1.125em;
  }
  .service_menu .menu .menu_name > [lang="en"] {
    font-size: 1.5em;
  }
  .service_menu .menu_l .trim_img::before {
    padding-top: 82%;
  }
  .service_menu .menu_m .trim_img::before {
    padding-top: 47.5%;
  }
}

.pager .page-numbers > li + li {
  margin-top: auto;
}
.pager .page-numbers a, 
.pager .page-numbers span {
  padding: 1em 0;
  width: 3em;
  height: 3em;
  line-height: 1;
}
.pager .page-numbers.current {
  background-color: #eceee4;
  color: inherit;
}

#company_info {
  padding: 3rem 0;
  background-color: #231815;
  color: #FFF;
  fill: #FFF;
}
#company_info a {
  color: inherit;
}
#company_info .company_logo {
  font-size: 1.75em;
}
#company_info .info {
  margin-top: 1rem;
  line-height: 1.5;
}
#company_info .info > span {
  display: inline-block;
  margin-right: 0.5em;
}
#company_info #business_area {
  font-size: 1.5em;
}
#company_info .area_list {
  list-style: none;
  margin-top: 1rem;
}
#company_info .area_list > li {
  display: inline-block;
}
#company_info .area_list > li:not(:last-child)::after {
  content: '、';
  display: inline-block;
  margin-right: -0.3em;
}
#company_info .info02 .link {
  margin-top: 1rem;
}
#company_info .info02 .link a {
  display: inline-block;
  font-size: 1.375em;
  text-decoration: none;
}
#company_info .info02 .link a:hover {
  text-decoration: underline;
}
@media only screen and (max-width:600px) {
  #company_info .info {
    font-size: 0.875em;
  }
  #company_info #business_area {
    margin-top: 1.5rem;
  }
  #company_info .area_list {
    font-size: 0.875em;
  }
  #company_info .info02 .link a::before {
    content: '＞';
    display: inline-block;
  }
}
@media print, (min-width:601px) {
  #company_info {
    padding: 4.5rem 0;
  }
  #company_info .info_block::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 24%;
    left: 64%;
    margin: 0 auto;
    width: 0;
    height: auto;
    border-style: solid;
    border-width: 0 0 0 1px;
  }
  #company_info .info_block .info01 {
    flex-basis: 64%;
  }
  #company_info .info_block .info02 {
    flex-basis: 24%;
    margin-left: auto;
  }
  #company_info .info {
    margin-top: 1.5rem;
  }
  #company_info .area_list {
    margin-top: 1.5rem;
  }
  #company_info .info02 .link {
    margin-top: 1.5rem;
  }

}

.banner_area {
  margin: 3rem auto;
}

.map_block {
  margin-top: 1.5rem;
  width: 100%;
  max-width: 100%;
}
.map_block::before {
  content: '';
  display: block;
  padding-top: 75%;
}
.map_block > iframe {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media print, (min-width:601px) {
  .map_block::before {
    padding-top: 54%;
  }
}

.grecaptcha-badge {
  bottom: 5rem !important; 
  z-index: 1100;
}