.pc {
  display: none; }

.sp {
  display: block; }

.menu_btn {
  width: 30px;
  height: 30px;
  cursor: pointer;
  margin: auto;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  right: 15px;
  top: 18px; }
  .menu_btn span {
    border-top: 3px solid #256ab3;
    display: block;
    margin-bottom: 10px;
    -webkit-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s; }
  .menu_btn.on {
    margin-right: 10px; }
    .menu_btn.on span {
      border-color: #fff; }
      .menu_btn.on span.top {
        -webkit-transform: rotate(45deg) translate(60%);
        -ms-transform: rotate(45deg) translate(60%);
        transform: rotate(45deg) translate(60%); }
      .menu_btn.on span.middle {
        -webkit-transform: translateX(100vw);
        -ms-transform: translateX(100vw);
        transform: translateX(100vw); }
      .menu_btn.on span.bottom {
        -webkit-transform: rotate(-45deg) translate(60%);
        -ms-transform: rotate(-45deg) translate(60%);
        transform: rotate(-45deg) translate(60%); }

header div.wrap div.flex {
  padding: 0;
  height: 70px;
  margin: auto; }
  header div.wrap div.flex h1 {
    width: 160px; }

header nav {
  margin-top: -100px;
  margin-left: 100vw;
  opacity: 0;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
  width: 0; }
  header nav ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 70px 0 20px;
    opacity: 0; }
    header nav ul li {
      border-left: none;
      text-align: right; }
      header nav ul li a {
        color: #fff;
        height: auto;
        line-height: 0;
        font-size: 16px; }
      header nav ul li:last-child {
        border-right: none; }
  header nav.on {
    margin-top: -70px;
    opacity: 1;
    width: 100%;
    margin-left: 0; }
    header nav.on ul {
      opacity: 1; }
      header nav.on ul li a {
        padding: 30px 50px; }

main section h2 {
  font-size: 6vw;
  margin-bottom: 30px; }
  main section h2::first-letter {
    font-size: 8vw; }

main section#hero {
  max-height: 750px; }
  main section#hero p.copy {
    width: 90%; }
    main section#hero p.copy img {
      margin-top: 20%; }

main section#service {
  padding: 50px 20px; }
  main section#service h2 {
    margin-bottom: 30px;
    width: 40%; }
  main section#service ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column; }
    main section#service ul li {
      padding: 0 20px; }
      main section#service ul li.workstylereform {
        -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
        order: -1; }

main section#workstylereform {
  padding: 10% 2%; }
  main section#workstylereform div.wrap {
    padding: 0;
    padding-top: 10%; }
    main section#workstylereform div.wrap div.cloud-left,
    main section#workstylereform div.wrap div.cloud-right {
      width: 40%;
      height: 30%; }
    main section#workstylereform div.wrap div.cloud-right {
      top: 1%; }
    main section#workstylereform div.wrap h2 {
      font-size: 6vw;
      margin-bottom: 20px;
      letter-spacing: 1vw; }
      main section#workstylereform div.wrap h2::first-letter {
        font-size: 8vw; }
    main section#workstylereform div.wrap p {
      margin-bottom: 30px;
      font-size: 14px; }
    main section#workstylereform div.wrap div.frame {
      padding-bottom: 60%;
      width: 100%; }

main section#agent {
  padding: 10% 2%; }
  main section#agent div.wrap {
    padding: 10% 2%; }
    main section#agent div.wrap h2 {
      font-size: 5vw;
      margin-bottom: 50px; }
      main section#agent div.wrap h2::first-letter {
        font-size: 7vw; }
    main section#agent div.wrap div.box {
      margin-top: 50px;
      padding: 20px; }
      main section#agent div.wrap div.box ul li {
        margin-left: 20px;
        margin-bottom: 30px; }
        main section#agent div.wrap div.box ul li h3 {
          font-size: 18px;
          margin-bottom: 10px; }
        main section#agent div.wrap div.box ul li p {
          margin-bottom: 20px; }

main section#consulting {
  padding: 10% 2%; }
  main section#consulting div.wrap {
    padding: 10% 2%; }
    main section#consulting div.wrap h2 {
      font-size: 5vw;
      margin-bottom: 50px;
      letter-spacing: 2px; }
      main section#consulting div.wrap h2::first-letter {
        font-size: 7vw; }
    main section#consulting div.wrap div.slogan {
      margin-bottom: 30px; }
      main section#consulting div.wrap div.slogan p {
        font-size: 4vw;
        padding: 20px; }
        main section#consulting div.wrap div.slogan p span {
          font-size: 6vw;
          padding-bottom: 0px;
          display: inline-block;
          margin-bottom: 10px; }
    main section#consulting div.wrap div.description {
      padding: 5%; }
      main section#consulting div.wrap div.description p {
        font-size: 3.5vw; }
        main section#consulting div.wrap div.description p span.fz24 {
          font-size: 5.5vw; }
        main section#consulting div.wrap div.description p span.fz22 {
          font-size: 5vw; }
        main section#consulting div.wrap div.description p span.fz20 {
          font-size: 4.5vw; }
        main section#consulting div.wrap div.description p span.fz18 {
          font-size: 4vw; }

main section#philosophy div.wrap {
  padding: 50px 0 0; }
  main section#philosophy div.wrap p.top {
    font-size: 5vw; }
  main section#philosophy div.wrap p.bottom {
    font-size: 4vw;
    margin-top: 30px; }

main section#pointer div.wrap {
  padding: 50px; }
  main section#pointer div.wrap ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column; }
    main section#pointer div.wrap ul li {
      padding: 15px 30px;
      font-size: 18px;
      margin: auto;
      margin-bottom: 30px; }

main section#greetings div.wrap {
  padding: 0; }
  main section#greetings div.wrap h2::after {
    bottom: 0px; }
  main section#greetings div.wrap p.sub {
    font-size: 5vw;
    margin-top: -20px; }
  main section#greetings div.wrap div.flex {
    padding: 0 20px;
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse; }
    main section#greetings div.wrap div.flex div {
      width: 100%; }
      main section#greetings div.wrap div.flex div.txt p {
        margin-bottom: 10px; }
      main section#greetings div.wrap div.flex div.photo {
        margin-bottom: 10px; }

main section#profile div.wrap {
  width: 100%;
  padding: 50px 20px; }
  main section#profile div.wrap p {
    margin: 0;
    margin-bottom: 10px; }

main section#about {
  margin-bottom: 50px; }
  main section#about div.wrap {
    padding: 20px; }
    main section#about div.wrap > div.flex {
      padding: 20px 0;
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
      flex-direction: column-reverse; }
      main section#about div.wrap > div.flex > div {
        width: 100%; }
        main section#about div.wrap > div.flex > div.info dl div.flex dt {
          color: #256ab3;
          width: 4em;
          margin-right: 20px; }

main section#form div.wrap {
  padding: 50px 20px; }
  main section#form div.wrap h2 {
    font-size: 5vw; }
    main section#form div.wrap h2::first-letter {
      font-size: 7vw; }
  main section#form div.wrap p {
    font-size: 12px; }
  main section#form div.wrap form dl {
    margin-bottom: 10px; }
    main section#form div.wrap form dl div.flex {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column; }
      main section#form div.wrap form dl div.flex:last-child dt {
        border-bottom: 1px solid #aaa; }
      main section#form div.wrap form dl div.flex dt {
        border-right: none; }
      main section#form div.wrap form dl div.flex dt,
      main section#form div.wrap form dl div.flex dd {
        width: 100%; }

main section#policy, main section#thanks {
  padding-top: 100px; }
  main section#policy h2, main section#thanks h2 {
    font-size: 4vw; }
    main section#policy h2::first-letter, main section#thanks h2::first-letter {
      font-size: 5vw; }
  main section#policy div.wrap, main section#thanks div.wrap {
    padding: 0 20px; }

main section#contact {
  padding: 10% 0px; }
  main section#contact div.wrap {
    padding: 0; }
    main section#contact div.wrap p.head {
      margin-bottom: 30px;
      font-size: 16px; }
    main section#contact div.wrap div.flex {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column; }
      main section#contact div.wrap div.flex > * {
        width: 100%; }
      main section#contact div.wrap div.flex div dl dt {
        font-size: 18px;
        margin-bottom: 0; }
      main section#contact div.wrap div.flex div dl dd {
        font-size: 9vw; }
      main section#contact div.wrap div.flex div#mail {
        margin-top: 40px; }
        main section#contact div.wrap div.flex div#mail dl dt {
          margin-bottom: 20px; }

main h2.sub {
  margin-top: 70px;
  padding: 20px; }
  main h2.sub img {
    width: 30%; }

footer div.wrap {
  padding: 10% 5%; }
  footer div.wrap div.container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse; }
    footer div.wrap div.container > * {
      width: 100%; }
    footer div.wrap div.container div.box {
      padding-left: 0;
      max-width: 90%;
      margin: auto; }
      footer div.wrap div.container div.box p {
        font-size: 14px; }
        footer div.wrap div.container div.box p.footer_ttl {
          font-size: 5vw; }
        footer div.wrap div.container div.box p.footer_tel {
          font-size: 5vw; }
          footer div.wrap div.container div.box p.footer_tel a {
            color: #fff; }
    footer div.wrap div.container div.frame {
      padding-bottom: 80%;
      width: 100%;
      margin-top: 30px; }
