@charset "UTF-8";
/*--- import -------------------------------------*/
* {
  margin: 0;
  padding: 0;
  outline: 0;
  font-size: 100%;
  word-break: break-word;
  box-sizing: border-box;
  vertical-align: baseline;
  background: transparent; }

html, body {
  overflow-x: hidden; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

li {
  list-style-type: none; }

blockquote, q {
  quotes: none; }
  blockquote::before, blockquote::after, q::before, q::after {
    content: '';
    content: none; }

a {
  text-decoration: none;
  color: inherit; }

img, picture {
  vertical-align: top;
  max-width: 100%; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

input, select {
  vertical-align: middle; }

/* safariでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box; }
  input[type="submit"]::-webkit-search-decoration,
  input[type="button"]::-webkit-search-decoration {
    display: none; }
  input[type="submit"]::focus,
  input[type="button"]::focus {
    outline-offset: -2px; }

/*------------------------------------- import ---*/
body {
  -webkit-text-size-adjust: 100%;
  font-family: 'Kosugi Maru', sans-serif;
  text-align: center;
  font-weight: normal;
  color: #333333;
  font-size: 18px;
  line-height: 1.5; }
  @media screen and (max-width: 750px) {
    body {
      font-size: 4.2666666667vw; } }

a {
  opacity: 1;
  transition: opacity .3s; }
  a:hover {
    opacity: 0.8; }

.pc {
  display: block !important; }
  @media screen and (max-width: 750px) {
    .pc {
      display: none !important; } }

.sp {
  display: none !important; }
  @media screen and (max-width: 750px) {
    .sp {
      display: block !important; } }

.sp_960 {
  display: none !important; }
  @media screen and (max-width: 960px) {
    .sp_960 {
      display: block !important; } }

.box_in1270 {
  width: 100%;
  max-width: 1270px;
  margin: 0 auto; }

.box_in {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto; }
  @media screen and (max-width: 1280px) {
    .box_in {
      padding: 0 40px; } }
  @media screen and (max-width: 750px) {
    .box_in {
      padding: 0 2.6666666667vw; } }

.box_in960 {
  width: 100%;
  max-width: 960px;
  margin: 0 auto; }
  @media screen and (max-width: 1040px) {
    .box_in960 {
      padding: 0 40px; } }
  @media screen and (max-width: 750px) {
    .box_in960 {
      padding: 0 5.3333333333vw; } }

.box_in800 {
  width: 100%;
  max-width: 800px;
  margin: 0 auto; }
  @media screen and (max-width: 880px) {
    .box_in800 {
      padding: 0 40px; } }
  @media screen and (max-width: 750px) {
    .box_in800 {
      padding: 0 5.3333333333vw; } }

.fixed {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important; }

.fade_off {
  opacity: 0;
  -webkit-transition: all 1s;
  -moz-transition: all 1s;
  -o-transition: all 1s;
  -ms-transition: all 1s;
  transition: all 1s; }

.fade_on {
  opacity: 1; }

.green {
  color: #009141; }

.markerGreen {
  background: linear-gradient(transparent 61%, rgba(68, 167, 53, 0.5) 0%);
  padding: 0 7px; }

#header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  background: rgba(0, 145, 65, 0.3);
  transition: 0.5s; }
  #header .header {
    display: flex;
    align-items: center; }
    #header .header .logo {
      padding: 10px 20px;
      background: #fff;
      width: 320px; }
      #header .header .logo h1 img {
        width: 265px; }
    #header .header .h_r {
      width: calc(100% - 320px);
      display: flex;
      justify-content: flex-end;
      align-items: center;
      padding: 0 20px; }
      @media screen and (max-width: 960px) {
        #header .header .h_r {
          display: none; } }
      #header .header .h_r ul {
        display: flex; }
        #header .header .h_r ul li {
          padding-right: 20px; }
          #header .header .h_r ul li a {
            font-size: 21px;
            /*ホバー時のアンダーライン-----start-----*/
            position: relative;
            display: inline-block;
            text-decoration: none;
            /*ホバー時のアンダーライン---end-----*/ }
            #header .header .h_r ul li a:after {
              position: absolute;
              bottom: 2px;
              left: 0;
              content: '';
              width: 100%;
              height: 3px;
              background: #009141;
              transform: scale(0, 1);
              transform-origin: left top;
              transition: transform .3s; }
            #header .header .h_r ul li a:hover::after {
              transform: scale(1, 1); }
            #header .header .h_r ul li a .sub {
              font-size: 12px;
              color: #fff; }
            #header .header .h_r ul li a img {
              width: 81px;
              margin-top: 5px; }
      #header .header .h_r .btn_area {
        width: 160px; }
        #header .header .h_r .btn_area .contact_btn {
          margin-top: 8px;
          font-size: 16px; }
          #header .header .h_r .btn_area .contact_btn a {
            background: #179c5c;
            padding: 5px 30px;
            color: #fff;
            border-radius: 30px; }
  @media screen and (max-width: 1040px) {
    #header .header .h_r .btn_area .contact_btn a {
      font-size: 14px; } }
  @media screen and (max-width: 960px) {
    #header {
      background: #fff !important;
      box-shadow: 0px 1px 8px #5454545e; }
      #header .header .logo {
        width: auto;
        padding: 5px 20px; }
        #header .header .logo h1 img {
          width: auto;
          height: 62px; } }
  @media screen and (max-width: 480px) {
    #header .header .logo {
      padding: 5px 10px; }
      #header .header .logo h1 img {
        width: auto;
        height: 48px; } }

.fixed {
  background: rgba(0, 145, 65, 0.9) !important; }
  .fixed .header .h_r ul li a {
    /*ホバー時のアンダーライン-----start-----*/
    /*ホバー時のアンダーライン---end-----*/ }
    .fixed .header .h_r ul li a:after {
      background: #fff !important; }
  .fixed .header .h_r .btn_area .contact_btn a {
    background: #fff !important;
    color: #179c5c !important;
    font-weight: bold !important; }

.other .fixed .header .h_r ul li a {
  /*ホバー時のアンダーライン-----start-----*/
  /*ホバー時のアンダーライン---end-----*/ }
  .other .fixed .header .h_r ul li a:after {
    background: #009141 !important; }

#navArea nav {
  background: rgba(0, 152, 65, 0.5);
  padding: 20px; }
  #navArea nav .inner {
    background: #fff; }
    #navArea nav .inner ul li:not(:first-child) {
      margin-top: 1.5vw; }
    #navArea nav .inner ul li a {
      font-size: 21px; }
      #navArea nav .inner ul li a .sub {
        font-size: 10px;
        color: #009841;
        font-weight: bold; }
      #navArea nav .inner ul li a img {
        width: 127px;
        margin-top: 5px; }
    #navArea nav .inner ul .close {
      background: #009841; }
      #navArea nav .inner ul .close p {
        color: #fff;
        display: block;
        padding: 0.5em;
        text-decoration: none;
        transition-duration: 0.2s;
        font-size: 21px;
        cursor: pointer; }
    #navArea nav .inner .btn_area {
      margin-top: 20px;
      padding: 20px;
      border: 2px solid #009841; }
      #navArea nav .inner .btn_area p {
        background: #009841;
        padding: 5px 10px;
        color: #fff;
        font-size: 3.7333333333vw;
        margin-bottom: 8px; }
      #navArea nav .inner .btn_area .contact_btn {
        margin-top: 8px; }
        #navArea nav .inner .btn_area .contact_btn a {
          background: #179c5c;
          padding: 10px 30px;
          color: #fff;
          border-radius: 30px;
          display: block;
          margin-top: 20px; }

.mv_b {
  color: #fff; }
  .mv_b .bg {
    background: url(../images/top/mv_bg.jpg) no-repeat;
    background-size: cover;
    background-position: bottom 25% center;
    position: relative;
    padding-top: 90px;
    padding-bottom: 110px;
    /*
    &:after{
    	content: '';
    	display: inline-block;
    	width: 100%;
    	height: 100%;
    	background: rgba(51, 51, 51, 0.5);
    	position: absolute;
    	top: 0;
    	left: 0;
    }	
    */ }
    .mv_b .bg .title {
      position: relative;
      z-index: 1;
      display: inline-block;
      width: 100%;
      text-align: left; }
      .mv_b .bg .title h2 .sub {
        font-size: 20px;
        color: #333333; }
      .mv_b .bg .title h2 img {
        max-width: 206px;
        width: 100%; }

@media screen and (max-width: 750px) {
  .mv_b .bg {
    padding-top: 10.666667vw;
    padding-bottom: 8.6666666667vw; }
    .mv_b .bg .title .icon {
      position: absolute;
      top: 50%;
      left: -12vw;
      transform: translateY(-50%); }
      .mv_b .bg .title .icon img {
        width: 20vw; }
    .mv_b .bg .title h2 .ttl {
      font-size: 6.6666666667vw; }
    .mv_b .bg .title h2 .sub {
      font-size: 4vw; } }
.contents_ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 35px; }
  .contents_ttl .images img {
    width: 74px; }
  .contents_ttl .txt_area {
    margin-left: 15px;
    color: #333333; }
    .contents_ttl .txt_area .p1 {
      font-size: 34px;
      white-space: nowrap; }
    .contents_ttl .txt_area .p2 {
      font-size: 19px;
      position: relative;
      display: inline-block;
      line-height: 14px; }
      .contents_ttl .txt_area .p2:before {
        content: '';
        background: #0274B5;
        width: 8px;
        height: 2px;
        display: inline-block;
        position: absolute;
        left: -15px;
        top: 50%;
        transform: translateY(-50%); }
      .contents_ttl .txt_area .p2:after {
        content: '';
        background: #0274B5;
        width: 8px;
        height: 2px;
        display: inline-block;
        position: absolute;
        right: -15px;
        top: 50%;
        transform: translateY(-50%); }
      .contents_ttl .txt_area .p2 img {
        width: 70px; }

@media screen and (max-width: 750px) {
  .contents_ttl {
    display: block;
    margin-bottom: 4.6666666667vw; }
    .contents_ttl .txt_area {
      margni-top: 10px;
      margin-left: 0; }
      .contents_ttl .txt_area .p1 {
        font-size: 6.4vw; }
      .contents_ttl .txt_area .p2 {
        font-size: 4.4vw;
        line-height: 0;
        top: -2vw; }
        .contents_ttl .txt_area .p2:before {
          content: '';
          width: 8px;
          height: 2px;
          display: inline-block;
          position: absolute;
          left: -15px;
          top: 50%;
          transform: translateY(-50%); }
        .contents_ttl .txt_area .p2:after {
          content: '';
          width: 8px;
          height: 2px;
          display: inline-block;
          position: absolute;
          right: -15px;
          top: 50%;
          transform: translateY(-50%); }
        .contents_ttl .txt_area .p2 img {
          width: 70px; } }
.thmnail .links_area {
  position: relative;
  z-index: 1;
  margin: 15px;
  display: flex;
  align-items: center;
  font-weight: bold;
  font-size: 14px; }
  .thmnail .links_area li {
    white-space: nowrap; }
    .thmnail .links_area li:not(:last-child) {
      margin-right: 15px;
      text-decoration: underline; }
    .thmnail .links_area li:not(:first-child) {
      border-left: 2px solid #333333;
      padding-left: 10px; }
@media screen and (max-width: 750px) {
  .thmnail .links_area {
    font-size: 3.7333333333vw;
    margin-top: 2.666667vw; }
    .thmnail .links_area li:not(:last-child) {
      margin-right: 15px; }
    .thmnail .links_area li a {
      display: block; } }

.txt {
  line-height: 1.8; }

section .ttl_h2 {
  position: relative; }
  section .ttl_h2 .bg_txt {
    position: absolute;
    top: -55px;
    left: 50%;
    transform: translateX(-50%); }
  section .ttl_h2 .ttl_area {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    left: -15px; }
    section .ttl_h2 .ttl_area .images img {
      width: 74px; }
    section .ttl_h2 .ttl_area .ttl {
      font-weight: bold;
      font-size: 28px;
      margin-left: 15px; }
      section .ttl_h2 .ttl_area .ttl .main_ttl {
        line-height: 0.5; }
      section .ttl_h2 .ttl_area .ttl .sub_ttl {
        font-size: 19px;
        color: #009141;
        display: inline-block; }
        section .ttl_h2 .ttl_area .ttl .sub_ttl:before {
          content: '';
          display: inline-block;
          background: #009141;
          width: 14px;
          height: 2px;
          position: relative;
          left: -10px;
          top: -2px; }
        section .ttl_h2 .ttl_area .ttl .sub_ttl:after {
          content: '';
          display: inline-block;
          background: #009141;
          width: 14px;
          height: 2px;
          position: relative;
          right: -10px;
          top: -2px; }
@media screen and (max-width: 750px) {
  section .ttl_h2 .bg_txt {
    display: none; }
  section .ttl_h2 .ttl_area {
    display: block;
    left: 0; }
    section .ttl_h2 .ttl_area .images img {
      width: 14.866667vw; }
    section .ttl_h2 .ttl_area .ttl {
      font-size: 7.4666666667vw;
      margin-left: 0;
      margin-top: 10px; }
      section .ttl_h2 .ttl_area .ttl .main_ttl {
        line-height: 0.5; }
      section .ttl_h2 .ttl_area .ttl .sub_ttl {
        font-size: 19px; }
        section .ttl_h2 .ttl_area .ttl .sub_ttl:before {
          content: '';
          display: inline-block;
          background: #009141;
          width: 14px;
          height: 2px;
          position: relative;
          left: -10px;
          top: -2px; }
        section .ttl_h2 .ttl_area .ttl .sub_ttl:after {
          content: '';
          display: inline-block;
          background: #009141;
          width: 14px;
          height: 2px;
          position: relative;
          right: -10px;
          top: -2px; } }

.more a {
  padding: 20px;
  color: #fff;
  background: #009141;
  border-radius: 8px;
  display: block;
  margin: 0 auto;
  max-width: 350px;
  width: 100%;
  font-size: 21px; }
@media screen and (max-width: 750px) {
  .more a {
    font-size: 4.2666666667vw; } }

.sankaku {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 50px 100px 0 100px;
  border-color: #ffffff transparent transparent transparent; }

footer {
  background: #009841;
  padding: 40px 20px;
  position: relative;
  color: #fff; }
  footer:before {
    content: '';
    background: url(../images/f_item01.png);
    width: 100%;
    height: 87px;
    position: absolute;
    top: -80px;
    left: 0;
    background-size: contain;
    background-repeat-y: no-repeat; }
  @media screen and (max-width: 960px) {
    footer:before {
      content: '';
      background: url(../images/f_item01.png);
      background-size: cover; } }
  footer .logo a {
    display: inline-block; }
    footer .logo a .inner {
      display: flex;
      align-items: center;
      justify-content: center; }
      footer .logo a .inner .images {
        background: #fff;
        padding: 15px;
        border-radius: 20px; }
        footer .logo a .inner .images img {
          width: 95px; }
      footer .logo a .inner .txt_area {
        margin-left: 20px; }
        footer .logo a .inner .txt_area .sub {
          font-size: 14px; }
        footer .logo a .inner .txt_area .company_name {
          margin-top: 10px;
          font-size: 32px;
          white-space: nowrap; }
  footer .adress_area {
    margin-top: 20px; }
  footer .btn_area {
    margin-top: 40px;
    display: flex;
    justify-content: center; }
    footer .btn_area .contact_btn {
      display: block; }
      footer .btn_area .contact_btn img {
        max-width: 315px;
        width: 100%; }
    footer .btn_area .tel_btn {
      display: block;
      margin-left: 40px; }
      footer .btn_area .tel_btn img {
        max-width: 303px;
        width: 100%; }

@media screen and (max-width: 750px) {
  footer {
    padding: 13.333333vw 2.6666666667vw; }
    footer:before {
      content: '';
      background: url(../images/f_item01.png);
      width: 100%;
      height: 87px;
      position: absolute;
      top: -80px;
      left: 0;
      background-size: cover;
      background-repeat-y: no-repeat; }
    footer .logo a {
      display: block;
      max-width: 68%;
      width: 100%;
      margin: 0 auto; }
      footer .logo a .inner {
        display: block; }
        footer .logo a .inner .images {
          max-width: 140px;
          width: 100%;
          margin: 0 auto;
          height: 140px;
          display: flex;
          align-items: center;
          justify-content: center; }
        footer .logo a .inner .txt_area {
          width: 100%;
          margin-left: 0px;
          margin-top: 20px; }
          footer .logo a .inner .txt_area .sub {
            font-size: 3.7333333333vw; }
          footer .logo a .inner .txt_area .company_name {
            margin-top: 0px;
            font-size: 6.1333333333vw; }
    footer .adress_area {
      margin-top: 20px; }
    footer .btn_area {
      margin-top: 5.3333333333vw;
      display: block; }
      footer .btn_area .tel_btn {
        margin-left: 0px;
        margin-top: 5.3333333333vw; }
        footer .btn_area .tel_btn img {
          max-width: 315px; } }
.footer_nav {
  font-size: 14px;
  background: #0273b5;
  padding: 15px;
  color: #fff; }
  .footer_nav ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    .footer_nav ul li {
      margin: 0 15px; }
      .footer_nav ul li a {
        display: block; }
  @media screen and (max-width: 750px) {
    .footer_nav {
      font-size: 3.7333333333vw;
      padding: 1.3333333333vw; }
      .footer_nav ul {
        display: block; }
        .footer_nav ul li {
          width: 100%;
          margin: 0; }
          .footer_nav ul li a {
            display: block;
            border-bottom: 1px solid rgba(255, 255, 255, 0.6);
            padding: 15px 10px;
            text-align: left;
            position: relative; }
            .footer_nav ul li a .fas {
              position: absolute;
              right: 20px;
              top: 50%;
              transform: translateY(-50%); }
              .footer_nav ul li a .fas:before {
                font-size: 28px; }
          .footer_nav ul li:last-child a {
            border-bottom: none; } }

.copy_right {
  font-weight: bold;
  padding: 10px;
  color: #009841;
  font-size: 14px; }
  @media screen and (max-width: 750px) {
    .copy_right {
      font-size: 3.7333333333vw; } }

#pagetop {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 0px;
  bottom: 0px;
  background: #ffffff;
  z-index: 1;
  border: 2px solid #009841; }

#pagetop a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
  text-align: center; }

#pagetop a::before {
  font-family: "Font Awesome 5 Free";
  content: '\f106';
  font-weight: 900;
  font-size: 25px;
  color: #009841;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 50%;
  left: 47%;
  margin: auto;
  transform: translate(-50%, -50%);
  line-height: 25px; }
