@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(3) a {
  color: #ffffff;
  background: #65A923; }
  #global-header .inner #global-navi ul li:nth-child(3) a span {
    color: #ffffff; }

#key-visual {
  background: url("../works/images/top.jpg") center;
  background-size: cover;
  height: 100%;
  height: 400px;
  width: auto;
  display: flex;
  align-items: center;
  justify-content: center; }
  @media screen and (max-width: 1024px) {
    #key-visual {
      height: 300px;
      position: relative; } }
  @media screen and (max-width: 415px) {
    #key-visual {
      height: 250px;
      position: relative; } }

.midashi {
  width: 100%;
  height: 150px;
  display: flex;
  justify-content: center;
  align-items: center; }
  @media screen and (max-width: 1024px) {
    .midashi {
      width: 100%;
      height: 130px; } }
  @media screen and (max-width: 415px) {
    .midashi {
      margin: 40px auto 0px auto; } }
  .midashi h2 {
    color: #ffffff;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
    font-size: 4.8em;
    letter-spacing: .5em;
    font-weight: bold;
    text-align: center; }
    .midashi h2 span {
      font-size: 0.5em;
      font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
      color: #ffffff;
      font-weight: normal;
      letter-spacing: .5em; }

.work-tab {
  padding: 100px 0; }
  .work-tab .tab-group {
    display: flex;
    justify-content: flex-start;
    width: 1280px;
    margin: 0 auto; }
    @media screen and (max-width: 1520px) {
      .work-tab .tab-group {
        width: 95%; } }
    @media screen and (max-width: 1280px) {
      .work-tab .tab-group {
        flex-wrap: wrap; } }
  .work-tab .tab {
    flex-grow: 1;
    padding: 5px;
    background: #fff;
    border: solid 1px #65A923;
    text-align: center;
    cursor: pointer;
    color: #65A923;
    font-size: 1.4em; }
    @media screen and (max-width: 1280px) {
      .work-tab .tab {
        width: 20%;
        display: grid;
        place-items: center; } }
  .work-tab .tab.is-active {
    color: #FFF;
    background: #65A923;
    transition: all 0.2s ease-out; }
  .work-tab .panel.is-show {
    display: block; }
  .work-tab .panel-group {
    min-height: 100px;
    background: #E7F5D8;
    padding-top: 80px;
    padding-bottom: 80px; }
  .work-tab .panel {
    display: none;
    min-height: 200px; }
    .work-tab .panel .panel-inner {
      padding: 40px 0 64px; }
      .work-tab .panel .panel-inner:nth-child(even) {
        background: #fff; }
      .work-tab .panel .panel-inner .panel-body {
        width: 1260px;
        margin: 0 auto; }
        @media screen and (max-width: 1520px) {
          .work-tab .panel .panel-inner .panel-body {
            width: 95%; } }
        .work-tab .panel .panel-inner .panel-body h3 {
          margin-bottom: 24px; }
          @media screen and (max-width: 415px) {
            .work-tab .panel .panel-inner .panel-body h3 span {
              display: block; } }
          .work-tab .panel .panel-inner .panel-body h3 span.num {
            color: #65A923;
            font-size: 5.4em;
            font-weight: bold;
            margin-right: 24px; }
            @media screen and (max-width: 415px) {
              .work-tab .panel .panel-inner .panel-body h3 span.num {
                font-size: 3.2em; } }
          .work-tab .panel .panel-inner .panel-body h3 span.text {
            color: #333333;
            font-size: 3.4em;
            font-weight: bold; }
            @media screen and (max-width: 415px) {
              .work-tab .panel .panel-inner .panel-body h3 span.text {
                font-size: 2em; } }
        .work-tab .panel .panel-inner .panel-body .pic-box {
          display: grid;
          grid-template-columns: 1fr 1fr;
          gap: 2.5%;
          margin-bottom: 40px; }
          .work-tab .panel .panel-inner .panel-body .pic-box li img {
            width: 100%;
            height: auto;
            vertical-align: bottom; }
        .work-tab .panel .panel-inner .panel-body .descbox {
          outline: 10px solid #65A923;
          outline-offset: -10px;
          padding: 40px;
          background: #fff; }
          .work-tab .panel .panel-inner .panel-body .descbox p {
            font-size: 1.6em; }

.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; }
