@charset "UTF-8";
/* Scss Document */
html {
  scroll-behavior: smooth; }

body {
  display: flex; }

#wrap {
  width: calc(100% - 267px);
  position: absolute;
  margin: 0 0 0 267px;
  height: 100%; }
  @media screen and (max-width: 1024px) {
    #wrap {
      width: 100%;
      margin: 0; } }

#global-header {
  width: 267px;
  height: 100%;
  position: fixed;
  left: 0;
  z-index: 3;
  background: url(../images/bg_01.png), #ffffff;
  border-left: 13px solid #65A923;
  filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.2)); }
  @media screen and (max-width: 1024px) {
    #global-header {
      display: none; } }
  #global-header .inner {
    position: relative;
    height: 100%;
    margin: 0 auto;
    z-index: 1;
    justify-content: space-between; }
    #global-header .inner .logo {
      margin: 24px auto 0;
      z-index: 1;
      width: 100%;
      padding: 7%; }
      @media screen and (max-width: 1366px) {
        #global-header .inner .logo {
          margin: 20px auto 0; } }
      @media screen and (max-width: 1024px) {
        #global-header .inner .logo {
          margin: 1.5% auto 1% auto;
          width: 80%; } }
      @media screen and (max-width: 415px) {
        #global-header .inner .logo {
          margin: 1.5% auto 1.5% auto;
          width: 60%; } }
      #global-header .inner .logo a img {
        width: 95%;
        margin: 0 auto;
        display: block;
        height: auto;
        vertical-align: bottom; }
    #global-header .inner #global-navi {
      padding: 15% 0% 5%; }
      #global-header .inner #global-navi ul li {
        position: relative;
        width: 100%;
        z-index: 1; }
        #global-header .inner #global-navi ul li a {
          font-size: 1.5em;
          padding: 4% 2% 4% 4%;
          width: 94%;
          display: inline-block;
          text-align: left;
          transition: all .5s ease;
          color: #65A923;
          font-family: "筑紫A丸ゴシック レギュラー"; }
          @media screen and (max-width: 1366px) {
            #global-header .inner #global-navi ul li a {
              font-size: 1.3em; } }
          #global-header .inner #global-navi ul li a span {
            color: #65A923;
            font-size: 1.2em; }
          #global-header .inner #global-navi ul li a:hover {
            background: #4CA8C8;
            color: #ffffff; }
            #global-header .inner #global-navi ul li a:hover span {
              color: #ffffff; }
      #global-header .inner #global-navi ul ul {
        display: none;
        position: absolute;
        width: 100%; }
        #global-header .inner #global-navi ul ul a {
          color: #910000;
          width: 100%; }
          #global-header .inner #global-navi ul ul a:hover {
            width: 100%;
            text-align: center;
            background-color: #910000;
            color: #fff; }
      @media screen and (max-width: 1366px) {
        #global-header .inner #global-navi {
          padding: 5% 0; } }
    @media screen and (max-width: 1366px) {
      #global-header .inner {
        width: 100%; } }
    @media screen and (max-width: 1024px) {
      #global-header .inner .logo {
        display: flex;
        justify-content: center;
        align-items: center; }
        #global-header .inner .logo a {
          display: inline-block; }
          #global-header .inner .logo a img {
            width: 30%;
            height: 70%; }
      #global-header .inner #global-navi {
        display: none; } }
    @media screen and (max-width: 415px) {
      #global-header .inner .logo a img {
        width: 100%;
        height: auto; } }
    #global-header .inner div.sns__area {
      position: absolute;
      width: 100%;
      bottom: 120px;
      display: flex;
      justify-content: space-around;
      align-items: center;
      text-align: center; }
      @media screen and (max-width: 1366px) {
        #global-header .inner div.sns__area {
          bottom: 80px; } }
      #global-header .inner div.sns__area a {
        display: inline-block; }
      #global-header .inner div.sns__area a:nth-child(1) {
        margin-right: 32px; }
    #global-header .inner p.copy_small {
      position: absolute;
      bottom: 80px; }
      #global-header .inner p.copy_small small {
        width: 100%;
        color: #65A923;
        font-weight: bold;
        font-size: 1.2em; }
      @media screen and (max-width: 1366px) {
        #global-header .inner p.copy_small {
          bottom: 40px; } }

main#container {
  width: 100%; }
  main#container .logo h2:before {
    content: "";
    display: block;
    width: 36px;
    height: 45px;
    margin: 0 auto;
    background: url("../flow/images/logo.svg") no-repeat;
    background-size: 35px 35px; }
  main#container .page-header.contact-content {
    margin-bottom: 40px; }

.page-header {
  text-align: center;
  margin: 50px 0 40px 0;
  height: 110px;
  display: flex;
  justify-content: center;
  flex-direction: column; }
  @media screen and (max-width: 1360px) {
    .page-header {
      margin: 40px auto 20px auto; } }
  .page-header h2 {
    display: inline-block;
    text-align: center;
    font-size: 2.5em;
    letter-spacing: .15em;
    font-weight: bold;
    line-height: 1.3em; }
    @media screen and (max-width: 1366px) {
      .page-header h2 {
        line-height: 1.6em;
        font-size: 2em;
        width: 90%;
        margin: 0 auto; } }
    .page-header h2 span {
      font-size: .5em;
      line-height: 2.5em; }
      @media screen and (max-width: 415px) {
        .page-header h2 span {
          padding: 2.5% 0; } }
  .page-header p {
    width: 50%;
    text-align: left;
    margin: 20px auto 0 auto;
    font-size: 1.4em;
    line-height: 2em; }
    @media screen and (max-width: 415px) {
      .page-header p {
        width: 80%; } }

.sub-header {
  margin-bottom: 40px;
  text-align: center; }
  .sub-header h3 {
    font-size: 3.2em;
    color: #65A923;
    margin-bottom: 10px; }
  .sub-header .sub-title-line {
    display: inline-block;
    background: #65A923;
    width: 65px;
    height: 9px; }

/*---------------animation---------------*/
/*---スクロール時遅れて表示、順番に表示---*/
.fadein {
  opacity: 0;
  transition: all 1.3s; }

/*---TOP遅れて表示---*/
.post {
  opacity: 0; }

.common-content {
  padding: 100px 0; }
  @media screen and (max-width: 415px) {
    .common-content {
      padding: 0 0 32px; } }
  .common-content .common-cotnent-inner {
    width: 90%;
    margin: 0 auto; }
    @media screen and (max-width: 1280px) {
      .common-content .common-cotnent-inner {
        width: 90%; } }
    @media screen and (max-width: 415px) {
      .common-content .common-cotnent-inner {
        display: block; } }
    .common-content .common-cotnent-inner .common-header {
      margin-bottom: 40px; }
      .common-content .common-cotnent-inner .common-header h3 {
        font-size: 2.6em;
        font-weight: bold;
        color: #65A923;
        margin-bottom: 10px; }
      .common-content .common-cotnent-inner .common-header .common-title-line {
        display: inline-block;
        background: #65A923;
        width: 65px;
        height: 9px; }
      @media screen and (max-width: 415px) {
        .common-content .common-cotnent-inner .common-header {
          text-align: center; } }
    .common-content .common-cotnent-inner .common-left {
      width: 100%;
      margin-bottom: 64px; }
      @media screen and (max-width: 415px) {
        .common-content .common-cotnent-inner .common-left {
          width: 100%;
          margin-bottom: 24px; } }
      .common-content .common-cotnent-inner .common-left .common-left-inner {
        display: grid;
        grid-template-columns: 45% 50%;
        gap: 3%; }
        .common-content .common-cotnent-inner .common-left .common-left-inner .area-pic img {
          width: 100%;
          height: auto; }
        .common-content .common-cotnent-inner .common-left .common-left-inner ul li {
          margin-bottom: 12px;
          font-size: 2em; }
        @media screen and (max-width: 1440px) {
          .common-content .common-cotnent-inner .common-left .common-left-inner ul li {
            font-size: 1.6em; } }
        @media screen and (max-width: 415px) {
          .common-content .common-cotnent-inner .common-left .common-left-inner ul li {
            font-size: 1.2em;
            margin-bottom: 8px; } }
    .common-content .common-cotnent-inner .common-right {
      width: 100%; }
      .common-content .common-cotnent-inner .common-right .flow-image img {
        width: 100%;
        height: auto; }
      @media screen and (max-width: 415px) {
        .common-content .common-cotnent-inner .common-right {
          width: 100%; } }

#global-header .inner #global-navi ul li:nth-child(1) a {
  color: #ffffff;
  background: #65A923; }
  #global-header .inner #global-navi ul li:nth-child(1) a span {
    color: #ffffff; }

.main-img-wrapper {
  height: 85vh;
  overflow: hidden;
  position: relative; }
  @media screen and (max-width: 1024px) {
    .main-img-wrapper {
      height: 800px;
      object-fit: cover;
      width: 100%; } }
  @media screen and (max-width: 415px) {
    .main-img-wrapper {
      height: 600px;
      object-fit: cover;
      width: 100%; } }

div.main-img {
  width: 100%;
  height: 85vh;
  position: absolute;
  color: transparent;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: none;
  opacity: 0;
  z-index: 0;
  animation-name: ImgAnime;
  animation: ImgAnime 40s linear infinite; }
@keyframes ImgAnime {
  0% {
    opacity: 0;
    animation-timing-function: ease-in; }
  10% {
    opacity: 1;
    transform: scale(1.05);
    animation-timing-function: ease-out; }
  15% {
    opacity: 1;
    transform: scale(1.07); }
  20% {
    opacity: 1;
    transform: scale(1.1); }
  25% {
    opacity: 0;
    transform: scale(1.1); }
  100% {
    opacity: 0;
    animation-timing-function: ease-out; } }
.main-img-wrapper .main-img:nth-child(1) {
  background-image: url("../images/top.jpg"); }

.main-img-wrapper .main-img:nth-child(2) {
  background-image: url("../images/top2.jpg");
  animation-delay: 10s; }

.main-img-wrapper .main-img:nth-child(3) {
  background-image: url("../images/top3.jpg");
  animation-delay: 20s; }

.main-img-wrapper .main-img {
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover; }
  @media screen and (max-width: 415px) {
    .main-img-wrapper .main-img {
      height: 65vh; } }

.main-contents {
  position: absolute;
  width: 70%;
  left: 10%;
  top: 42%; }
  @media screen and (max-width: 768px) {
    .main-contents {
      width: 90%; } }
  @media screen and (max-width: 415px) {
    .main-contents {
      top: 140px; } }
  .main-contents h2 {
    color: #ffffff;
    font-size: 5em;
    margin-bottom: 40px;
    font-weight: bold;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; }
    @media screen and (max-width: 415px) {
      .main-contents h2 {
        font-size: 2em; } }
  .main-contents h3 {
    color: #ffffff;
    font-size: 2.1em;
    letter-spacing: .15em;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; }
    @media screen and (max-width: 415px) {
      .main-contents h3 {
        width: 90%;
        margin: 20% auto 0 0;
        font-size: 1.5em; } }
  .main-contents .main-inner {
    margin: 40px auto 0 auto;
    display: flex;
    justify-content: space-around;
    width: 80%; }
    @media screen and (max-width: 1240px) {
      .main-contents .main-inner {
        width: 100%; } }
    .main-contents .main-inner div {
      padding: 0 40px;
      background: rgba(255, 255, 255, 0.28);
      padding: 2%;
      border: solid 1px #ffffff;
      width: 180px;
      height: 180px;
      display: flex;
      justify-content: center;
      align-items: center; }
      @media screen and (max-width: 850px) {
        .main-contents .main-inner div {
          width: 150px;
          height: 150px; } }
      @media screen and (max-width: 560px) {
        .main-contents .main-inner div {
          width: 120px;
          height: 120px; } }
      @media screen and (max-width: 415px) {
        .main-contents .main-inner div {
          width: 100px;
          height: 100px; } }
      .main-contents .main-inner div p {
        color: #ffffff;
        font-family: "筑紫A丸ゴシック ボールド";
        font-size: 1.8em;
        letter-spacing: .5em;
        font-weight: bold;
        text-align: center; }
        @media screen and (max-width: 560px) {
          .main-contents .main-inner div p {
            font-size: 1.6em; } }

.greeting {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between; }
  .greeting .greet-inner {
    width: 70%;
    display: flex;
    justify-content: space-around;
    align-items: center; }
    @media screen and (max-width: 834px) {
      .greeting .greet-inner {
        width: 95%;
        display: block;
        padding: 24px 0 0 24px; } }
    .greeting .greet-inner .greet-box {
      width: 90%;
      margin-left: auto;
      margin-right: auto; }
      .greeting .greet-inner .greet-box .sub-header {
        text-align: left;
        margin-bottom: 64px; }
        @media screen and (max-width: 1440px) {
          .greeting .greet-inner .greet-box .sub-header {
            margin-bottom: 24px; } }
      .greeting .greet-inner .greet-box .desc {
        font-size: 3.2em;
        font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
        margin-bottom: 32px; }
        @media screen and (max-width: 415px) {
          .greeting .greet-inner .greet-box .desc {
            font-size: 2.1em; }
            .greeting .greet-inner .greet-box .desc br {
              display: none; } }
      .greeting .greet-inner .greet-box .greet-body {
        font-size: 1.8em;
        letter-spacing: .15em;
        line-height: 1.8; }
        .greeting .greet-inner .greet-box .greet-body .parag {
          margin-bottom: 24px; }
          @media screen and (max-width: 834px) {
            .greeting .greet-inner .greet-box .greet-body .parag br {
              display: none; } }
  @media screen and (max-width: 834px) {
    .greeting .floatpic {
      display: none; } }

.strongpoint {
  position: relative;
  z-index: 1;
  top: -90px;
  padding: 100px 0;
  background: #E7F5D8; }
  @media screen and (max-width: 834px) {
    .strongpoint {
      top: 0; } }
  .strongpoint p.desc {
    text-align: center;
    font-size: 2em;
    margin-bottom: 40px; }
  .strongpoint ul.picarea {
    width: 80%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px; }
    @media screen and (max-width: 415px) {
      .strongpoint ul.picarea {
        display: block;
        width: 60%; } }
    @media screen and (max-width: 415px) {
      .strongpoint ul.picarea li {
        margin-bottom: 24px; } }
    .strongpoint ul.picarea li img {
      width: 100%;
      height: auto; }

.cta {
  background: url(../images/contact-baner.jpg) no-repeat;
  background-size: cover; }
  .cta .inner {
    width: 80%;
    margin: 0 auto;
    padding: 40px;
    display: flex;
    justify-content: space-around;
    align-items: center; }
    @media screen and (max-width: 1280px) {
      .cta .inner {
        width: 90%; } }
    @media screen and (max-width: 415px) {
      .cta .inner {
        display: block; } }
    .cta .inner .text {
      color: #fff;
      font-size: 2.8em; }
      @media screen and (max-width: 1280px) {
        .cta .inner .text {
          font-size: 1.8em; } }
      @media screen and (max-width: 415px) {
        .cta .inner .text {
          margin-bottom: 12px; } }
    .cta .inner .cta-btn {
      display: inline-block;
      color: #fff;
      font-size: 2.4em;
      padding: 12px 28px;
      border: 1px solid #fff;
      border-radius: 2em; }
      @media screen and (max-width: 1280px) {
        .cta .inner .cta-btn {
          font-size: 1.6em; } }

.works-top {
  padding: 64px 0; }
  .works-top .inner {
    width: 85%;
    margin: 0 auto; }
    .works-top .inner .sub-header {
      text-align: left;
      margin-bottom: 40px; }
    .works-top .inner .works-pic {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 20px; }
      @media screen and (max-width: 415px) {
        .works-top .inner .works-pic {
          grid-template-columns: 1fr 1fr; } }
      .works-top .inner .works-pic .pic img {
        width: 100%; }
      .works-top .inner .works-pic .text {
        font-size: 1.6em;
        color: #65A923;
        padding: 12px 8px; }

.sponser {
  background: url("../images/sponser.svg") no-repeat;
  width: 100%;
  background-size: cover;
  background-position: center;
  height: 400px; }
  @media screen and (max-width: 1366px) {
    .sponser {
      height: 300px;
      background-position: center; } }
  @media screen and (max-width: 768px) {
    .sponser {
      background: url("../images/sponser_sp.svg") no-repeat;
      width: 100%;
      background-size: cover;
      background-position: center;
      height: 300px; } }
  @media screen and (max-width: 480px) {
    .sponser {
      height: 200px; } }
  @media screen and (max-width: 320px) {
    .sponser {
      height: 180px; } }

#global-footer {
  background: url(../images/footer-bg.png) no-repeat;
  background-size: cover;
  padding: 80px 0; }
  #global-footer .footer-inner {
    width: 1280px;
    margin: 0 auto;
    padding: 0 0 3px 0; }
    @media screen and (max-width: 1440px) {
      #global-footer .footer-inner {
        width: 95%; } }
    @media screen and (max-width: 1280px) {
      #global-footer .footer-inner {
        width: 100%; } }
    #global-footer .footer-inner .footer-head {
      text-align: center;
      margin-bottom: 80px; }
      #global-footer .footer-inner .footer-head h2 {
        font-size: 5em;
        font-weight: lighter;
        color: #C7FF1F;
        letter-spacing: .35em; }
      #global-footer .footer-inner .footer-head span.gline {
        display: inline-block;
        width: 65px;
        height: 6px;
        background: #C7FF1F; }
      @media screen and (max-width: 415px) {
        #global-footer .footer-inner .footer-head h2 {
          font-size: 3.5em; } }
    #global-footer .footer-inner .footer-body {
      display: flex;
      justify-content: space-between;
      width: 95%;
      margin: 0 auto; }
      @media screen and (max-width: 1440px) {
        #global-footer .footer-inner .footer-body {
          justify-content: space-around; } }
      @media screen and (max-width: 415px) {
        #global-footer .footer-inner .footer-body {
          flex-direction: column-reverse; } }
      #global-footer .footer-inner .footer-body .btn-wrap {
        width: 330px; }
        @media screen and (max-width: 1440px) {
          #global-footer .footer-inner .footer-body .btn-wrap {
            width: 400px; } }
        @media screen and (max-width: 1280px) {
          #global-footer .footer-inner .footer-body .btn-wrap {
            width: 35%; } }
        @media screen and (max-width: 415px) {
          #global-footer .footer-inner .footer-body .btn-wrap {
            width: 95%;
            margin: 0 auto; } }
        #global-footer .footer-inner .footer-body .btn-wrap dl {
          margin-bottom: 24px; }
          #global-footer .footer-inner .footer-body .btn-wrap dl div {
            border: 1px solid #fff;
            border-radius: 4em;
            padding: 14px 20px;
            display: flex;
            align-items: center;
            margin-bottom: 24px; }
            #global-footer .footer-inner .footer-body .btn-wrap dl div dt {
              border-right: 1px solid #fff;
              width: 72px;
              text-align: center; }
            #global-footer .footer-inner .footer-body .btn-wrap dl div dd {
              padding-left: 24px; }
              #global-footer .footer-inner .footer-body .btn-wrap dl div dd a {
                display: block;
                text-align: left;
                color: #fff;
                font-size: 1.9em;
                font-weight: bold; }
        #global-footer .footer-inner .footer-body .btn-wrap ul li {
          color: #C7FF1F;
          font-size: 1.4em;
          margin-bottom: 6px; }
          #global-footer .footer-inner .footer-body .btn-wrap ul li a {
            color: #C7FF1F; }
      #global-footer .footer-inner .footer-body .desc {
        width: 800px; }
        @media screen and (max-width: 1440px) {
          #global-footer .footer-inner .footer-body .desc {
            width: 600px; } }
        @media screen and (max-width: 1280px) {
          #global-footer .footer-inner .footer-body .desc {
            width: 50%; } }
        @media screen and (max-width: 415px) {
          #global-footer .footer-inner .footer-body .desc {
            width: 95%;
            margin: 0 auto 24px; } }
        #global-footer .footer-inner .footer-body .desc .fcatch {
          font-size: 2.7em;
          font-weight: bold;
          color: #fff;
          margin-bottom: 32px;
          line-height: 2.2; }
          @media screen and (max-width: 1440px) {
            #global-footer .footer-inner .footer-body .desc .fcatch {
              font-size: 1.8em; } }
          @media screen and (max-width: 415px) {
            #global-footer .footer-inner .footer-body .desc .fcatch {
              font-size: 2.4em; } }
        #global-footer .footer-inner .footer-body .desc .catch-desc {
          font-size: 1.4em;
          line-height: 1.8;
          letter-spacing: .05em;
          color: #fff; }
          @media screen and (max-width: 1366px) {
            #global-footer .footer-inner .footer-body .desc .catch-desc {
              font-size: 1.2em; } }
          @media screen and (max-width: 415px) {
            #global-footer .footer-inner .footer-body .desc .catch-desc {
              font-size: 1.4em; } }

.copy_small {
  width: 100%;
  text-align: center;
  color: #fff; }

div.backtop {
  width: 100%;
  background: #65A923; }
  div.backtop a {
    padding: 16px 0;
    display: block;
    text-align: center;
    color: #fff;
    font-size: 1.8em; }
    div.backtop a img {
      position: relative;
      left: 4px;
      bottom: 2px; }
