@charset "UTF-8";
/*
---------------------------------------------------------------------------------------------------------------------
ヘッダー
---------------------------------------------------------------------------------------------------------------------
*/
#header .header-logo {
  position: fixed;
  top: 10px;
  left: 10px;
  z-index: 100; }
  @media (min-width: 1024px) {
    #header .header-logo {
      top: 20px;
      left: 20px; } }
  #header .header-logo a img {
    width: 150px; }
    @media (min-width: 1024px) {
      #header .header-logo a img {
        width: 230px; } }
#header .document-btn {
  position: absolute;
  top: 10px;
  right: 80px;
  z-index: 20; }
  @media (min-width: 768px) {
    #header .document-btn {
      top: 20px;
      right: 100px; } }
  #header .document-btn a:hover .document-btn-in > svg {
    right: 10px; }
  #header .document-btn a .document-btn-in {
    position: relative;
    width: 110px;
    height: 60px;
    padding: 10px 0 10px 10px;
    border-radius: 10px;
    background-color: #fff; }
    @media (min-width: 768px) {
      #header .document-btn a .document-btn-in {
        padding: 15px 0 15px 15px;
        width: 160px;
        height: 70px; } }
    #header .document-btn a .document-btn-in p {
      font-size: 0.8em;
      line-height: 1.4em;
      display: flex;
      align-items: center;
      height: 100%; }
      @media (min-width: 768px) {
        #header .document-btn a .document-btn-in p {
          font-size: 1.0em; } }
    #header .document-btn a .document-btn-in svg {
      position: absolute;
      top: 0;
      bottom: 0;
      right: 10px;
      display: flex;
      align-items: center;
      height: 100%;
      width: 8px;
      fill: #000;
      transition: .5s; }
      @media (min-width: 768px) {
        #header .document-btn a .document-btn-in svg {
          right: 15px; } }

/*
---------------------------------------------------------------------------------------------------------------------
ページヘッダー
---------------------------------------------------------------------------------------------------------------------
*/
#mv {
  position: relative; }
  @media (min-width: 768px) {
    #mv {
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover;
      height: 100vh; } }
  #mv .main-title {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10; }
    #mv .main-title .main-title-in {
      text-align: left;
      margin: -10% 0 0 0; }
      @media (min-width: 768px) {
        #mv .main-title .main-title-in {
          margin: -20% 0 0 0; } }
      @media (min-width: 1024px) {
        #mv .main-title .main-title-in {
          margin: -20% 0 0 -20%; } }
      @media (min-width: 1250px) {
        #mv .main-title .main-title-in {
          margin: -25% 0 0 -25%; } }
      #mv .main-title .main-title-in h1 {
        font-family: 'Montserrat', sans-serif;
        font-size: 9vw;
        font-weight: 900;
        line-height: 1.0em; }
        @media (min-width: 768px) {
          #mv .main-title .main-title-in h1 {
            font-size: 7vw; } }
        @media (min-width: 1250px) {
          #mv .main-title .main-title-in h1 {
            font-size: 5.0em; } }
      #mv .main-title .main-title-in h2 {
        font-family: 'Montserrat', sans-serif;
        font-size: 4.5vw;
        font-weight: 700;
        line-height: 1.4em;
        margin-top: 20px; }
        @media (min-width: 768px) {
          #mv .main-title .main-title-in h2 {
            font-size: 4.0vw; } }
        @media (min-width: 1024px) {
          #mv .main-title .main-title-in h2 {
            font-size: 2.25em; } }

/*
---------------------------------------------------------------------------------------------------------------------
フッター
---------------------------------------------------------------------------------------------------------------------
*/
#footer {
  background-color: #6CAE38;
  color: #fff;
  padding: 60px 0 20px;
  margin-bottom: -25px; }
  #footer .footer-in {
    max-width: 1600px;
    width: 90%;
    margin: auto; }
  @media (min-width: 768px) {
    #footer .footer-menu {
      display: flex;
      justify-content: center; } }
  #footer .footer-menu .first {
    display: flex; }
    @media (min-width: 768px) {
      #footer .footer-menu .first {
        margin-right: 40px; } }
    #footer .footer-menu .first ul:first-child {
      margin-right: 60px; }
    @media (min-width: 1024px) {
      #footer .footer-menu .first ul {
        margin-right: 40px; }
        #footer .footer-menu .first ul:last-child {
          margin-right: 0; } }
    #footer .footer-menu .first ul li {
      margin-bottom: 25px;
      line-height: 1.2em; }
      #footer .footer-menu .first ul li a {
        font-size: 1.125em;
        color: #fff;
        position: relative; }
        @media (min-width: 1024px) {
          #footer .footer-menu .first ul li a {
            font-size: 1.25em; } }
        #footer .footer-menu .first ul li a::after {
          position: absolute;
          bottom: 0;
          left: 0;
          content: '';
          width: 100%;
          height: 1px;
          background: #fff;
          transform: scale(0, 1);
          transform-origin: right top;
          transition: transform .3s; }
        #footer .footer-menu .first ul li a:hover::after {
          transform-origin: left top;
          transform: scale(1, 1); }
  #footer .footer-menu ul.second h3 {
    font-size: 1.125em;
    font-weight: 400; }
    @media (min-width: 1024px) {
      #footer .footer-menu ul.second h3 {
        font-size: 1.25em; } }
  #footer .footer-menu ul.second .second-in {
    display: flex;
    border-left: 1px solid #fff;
    margin: 10px 0 0 5px;
    padding-left: 10px; }
    @media (min-width: 1024px) {
      #footer .footer-menu ul.second .second-in {
        margin: 10px 0 0 10px;
        padding-left: 20px; } }
    #footer .footer-menu ul.second .second-in ul {
      margin-right: 20px; }
      #footer .footer-menu ul.second .second-in ul:last-child {
        margin-right: 0; }
      #footer .footer-menu ul.second .second-in ul li {
        margin: 16px 0 0 0;
        line-height: 1.2em; }
        #footer .footer-menu ul.second .second-in ul li a {
          font-size: 0.8em;
          color: #fff;
          position: relative; }
          @media (min-width: 1024px) {
            #footer .footer-menu ul.second .second-in ul li a {
              font-size: 1.0em; } }
          #footer .footer-menu ul.second .second-in ul li a::after {
            position: absolute;
            bottom: 0;
            left: 0;
            content: '';
            width: 100%;
            height: 1px;
            background: #fff;
            transform: scale(0, 1);
            transform-origin: right top;
            transition: transform .3s; }
          #footer .footer-menu ul.second .second-in ul li a:hover::after {
            transform-origin: left top;
            transform: scale(1, 1); }
  #footer .company {
    text-align: center;
    margin: 60px auto 0; }
    @media (min-width: 768px) {
      #footer .company .company-in {
        display: flex;
        align-items: center;
        justify-content: center; } }
    #footer .company .company-in .logo {
      margin-bottom: 10px; }
      @media (min-width: 768px) {
        #footer .company .company-in .logo {
          margin: 0 20px 0 0; } }
      #footer .company .company-in .logo img {
        width: 240px; }
        @media (min-width: 1024px) {
          #footer .company .company-in .logo img {
            width: 280px; } }
    #footer .company .company-in .txt {
      text-align: center; }
      @media (min-width: 1024px) {
        #footer .company .company-in .txt {
          text-align: left; } }
      #footer .company .company-in .txt h2 {
        font-family: "kinuta-reiwa-kana", sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 1.75em; }
        @media (min-width: 1024px) {
          #footer .company .company-in .txt h2 {
            font-size: 3em; } }
      #footer .company .company-in .txt h3 {
        font-size: 1.125em;
        margin-top: 5px; }
        @media (min-width: 1024px) {
          #footer .company .company-in .txt h3 {
            font-size: 1.5em; } }
    #footer .company h4 {
      font-size: 0.8em;
      font-weight: 500;
      margin-top: 20px; }
      @media (min-width: 1024px) {
        #footer .company h4 {
          font-size: 1.0em; } }
  #footer ul.service {
    margin-top: 100px;
    max-width: 900px;
    margin: 0px auto 0; }
    #footer ul.service li {
      margin-bottom: 20px; }
      #footer ul.service li:last-child {
        margin-bottom: 0; }
      #footer ul.service li h4 {
        font-size: 1.10em;
        margin-bottom: 5px; }
        @media (min-width: 1024px) {
          #footer ul.service li h4 {
            font-size: 1.125em; } }
      #footer ul.service li p {
        font-size: 0.8em;
        line-height: 1.6em; }
        @media (min-width: 1024px) {
          #footer ul.service li p {
            font-size: 0.9em; } }
  #footer .copy {
    text-align: center;
    margin-top: 30px; }
    @media (min-width: 1024px) {
      #footer .copy {
        margin-top: 40px; } }
    #footer .copy p {
      font-size: 0.7em;
      line-height: 1.4em; }
      @media (min-width: 1024px) {
        #footer .copy p {
          font-size: 0.8em; } }
.flexbox{
    display: flex;
    justify-content: center;
    padding-top: 2rem;
    align-items: center;
  a{
    width: 150px;
  }
}