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

#key-visual {
  background: url("../contact/images/top.jpg") center;
  background-size: cover;
  height: 283px;
  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; }

.page-contents {
  width: 1366px;
  margin: 0 auto 80px; }
  @media screen and (max-width: 1366px) {
    .page-contents {
      width: 100%; } }

.content-inner {
  width: 70%;
  margin: 0 auto 64px auto;
  background: #fff; }
  @media screen and (max-width: 1280px) {
    .content-inner {
      width: 85%; } }
  @media screen and (max-width: 1024px) {
    .content-inner {
      width: 100%; } }
  @media screen and (max-width: 415px) {
    .content-inner {
      width: 100%; } }

div.page-desc {
  width: 780px;
  margin: 0 auto 80px; }
  div.page-desc p {
    font-size: 1.5em;
    letter-spacing: .05em;
    line-height: 2; }
  @media screen and (max-width: 1024px) {
    div.page-desc {
      width: 90%; } }

form {
  background: #F7F7F7;
  padding: 80px 40px 40px 40px;
  width: 800px;
  margin: 0 auto; }
  @media screen and (max-width: 1280px) {
    form {
      padding: 40px 20px; } }
  form dl div {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 16px 0; }
    @media screen and (max-width: 768px) {
      form dl div {
        padding: 8px 0; } }
    form dl div dt {
      width: 30%;
      font-size: 1.5em;
      font-weight: bold;
      margin-bottom: 3px; }
      form dl div dt span.hissu {
        color: #e0222b; }
    form dl div dd {
      width: 70%; }
      form dl div dd input, form dl div dd textarea {
        display: inline-block;
        font-size: 1.6em;
        background: #fff;
        padding: 8px;
        box-sizing: border-box;
        width: 100%;
        border: none; }
    form dl div dd.radio__wrap {
      font-size: 1.5em; }
      form dl div dd.radio__wrap label {
        display: inline-block;
        margin-bottom: 6px; }
        form dl div dd.radio__wrap label input {
          display: inline;
          width: auto;
          position: relative;
          top: -4px; }
  form dl span.radio-wrap {
    display: inline-block; }
    form dl span.radio-wrap .radio-input {
      display: none; }
    form dl span.radio-wrap .radio-input + label {
      padding-left: 20px;
      position: relative;
      margin-right: 40px;
      font-size: 1.5em; }
      @media screen and (max-width: 415px) {
        form dl span.radio-wrap .radio-input + label {
          line-height: 2.5em; } }
    form dl span.radio-wrap .radio-input + label::before {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      width: 15px;
      height: 15px;
      border: 1px solid #999;
      border-radius: 50%; }
    form dl span.radio-wrap .radio-input:checked + label {
      color: #d01137; }
    form dl span.radio-wrap .radio-input:checked + label::after {
      content: "";
      display: block;
      position: absolute;
      top: 3px;
      left: 3px;
      width: 11px;
      height: 11px;
      background: #d01137;
      border-radius: 50%; }
    form dl span.radio-wrap .radio {
      flex-direction: column;
      align-items: flex-start; }
    form dl span.radio-wrap .radio2 {
      flex-direction: column;
      align-items: flex-start; }
  form .btn-group {
    text-align: center;
    padding: 20px 0; }
    form .btn-group input[type="reset"],
    form .btn-group input[type="submit"] {
      border: none;
      font-size: 1.6em; }
    form .btn-group input[type="reset"] {
      padding: 2% 7%;
      margin-right: 5%;
      background: #cccccc; }
    form .btn-group input[type="submit"] {
      padding: 2% 7%;
      background: #333;
      color: #ffffff;
      font-weight: bold; }
    @media screen and (max-width: 415px) {
      form .btn-group input[type="reset"],
      form .btn-group input[type="submit"] {
        padding: 12px 18px; } }
  @media screen and (max-width: 1024px) {
    form {
      width: 90%; } }
  @media screen and (max-width: 415px) {
    form {
      padding: 24px; }
      form dl div {
        display: block; }
        form dl div dt {
          width: 100%;
          margin-bottom: 12px; }
          form dl div dt br {
            display: none; }
          form dl div dt span.hissu {
            padding-left: 8px; }
        form dl div dd {
          width: 100%; } }
  form .submit_area {
    text-align: center; }

#pp .pp-header {
  margin-bottom: 40px;
  text-align: center; }
  #pp .pp-header h3 {
    font-size: 3.2em;
    color: #65A923;
    margin-bottom: 10px; }
  #pp .pp-header .pp-title-line {
    display: inline-block;
    background: #65A923;
    width: 65px;
    height: 9px; }
#pp .pp-inner {
  width: 780px;
  margin: 0 auto; }
  #pp .pp-inner .pp-body {
    width: 95%;
    margin: 0 auto; }
    #pp .pp-inner .pp-body p {
      margin-bottom: 12px;
      font-size: 1.4em;
      line-height: 1.8;
      letter-spacing: .15em; }
  @media screen and (max-width: 415px) {
    #pp .pp-inner {
      width: 100%; } }

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