.sp {
  display: none;
}

.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
  .body-wrap {
    max-width: auto;
    margin: 0 10px;
  }
  /* common */
	main h1 {
		font-size:3.2rem;
	}
	main h1:first-letter {
		font-size:4rem;
	}

	main h2 {
	  font-size:2.4rem;
	}

	main h3 {
	  font-size:2rem;
	}
  table {
      width: 100%;
      table-layout: fixed;
      word-break: break-all;
      word-wrap: break-all;
  }
  table th,
  table td {
      display: block;
      width: 100%;
      word-break: break-all;
      word-wrap: break-all;
  }

  table.blog-calendar th,
  table.blog-calendar td {
      display: table-cell;
      width: auto;
  }

  .flex-box {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .float_box_left,
  .float_box_right{
    text-align:center;
    float:none;
  }
  .three-block > * {
    width:100%;
    padding:0!important;
  }

	main .bs-crumbs + .body-wrap{
		padding:0 8px;
	}


  header .header-inner {
    padding: 15px 20px;
  }
  header .sp_menu {
    display: block;
    height: 25px;
    position: fixed;
    right: 1rem;
    top: 2.0rem;
    width: 30px;
    z-index: 999999999;
  }
  header #menu-btn,
  header #menu-btn:before,
  header #menu-btn:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #fff;
    position: absolute;
    -webkit-transition: .2s;
    transition: .2s;
  }
  header #menu-btn:before {
    top: 8px;
  }
  header #menu-btn:after {
    top: 16px;
  }
  header #menu-btn.open-menu {
    background-color: rgba(255, 255, 255, 0);
  }
  header #menu-btn.open-menu::before {
    top: 8px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  header #menu-btn.open-menu::after {
    top: 8px;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  header nav {
    background: rgba(20, 20, 20, 0.9);
    position: absolute;
    z-index: 99999;
    right: 0;
    overflow-x: hidden;
    text-align: center;
    width: 0;
    -webkit-transition: .2s;
    transition: .2s;
  }
  header nav.open-menu {
    opacity: 1;
    width: 100%;
    height: 100vh;
    top: 0;
  }
  header nav.globalmenu ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    margin: 50px auto;
  }
  header nav.globalmenu li {
    width: 100%;
    text-align: center;
    padding: 20px 0;
    margin: 0;
    text-decoration: underline;
  }
  footer ul.footer-menu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer ul.footer-menu li {
    margin: 5px 0;
  }
  footer p#to_top a {
    right: 10px;
  }
  main {
    width: 100%;
  }
  #Home main .bx-wrapper img{
    height: 500px;
  }
  #Home main #main-img {
    height: 500px;
  }
  #Home main #main-img p.copy {
    font-size: 1.6rem;
    bottom: 120px;
    padding: 15px 25px;
  }
  #Home main #main-img .scrollBtn {
    right: 50%;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
  }
  #Home main #about .about-text {
    width: auto;
  }
  #Home main #about .about-text h2 {
    line-height: 1.4;
  }
  #Home main #about .about-image li {
    width: 50%;
    padding: 5px;
  }
  #Home main #flow ul {
    width: 315px;
    margin: 40px auto 25px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #Home main #flow ul li {
    margin-bottom: 15px;
  }
  #Home main #flow span.trust {
    width: auto;
  }
  #Home main #works {
    padding: 50px 0;
  }
  #Home main #works h2 {
    margin-bottom: 40px;
  }
  #Home main #works p {
    font-size: 1.4rem;
  }
  /* common */
  .more_btn {
    display: block;
  }

  #Mail th{
    width:100%;
  }
  #Mail .bs-mail-form-auth-captcha > div {
    flex-wrap:wrap;
  }
  #Mail .bs-mail-form-auth-captcha input[type="text"] {
      width: 100%;
  }
  #Blog .bs-blog-post .bs-blog-post__item{
  	width:100%;
  }
  #Blog .post .post__item .post__item-title {
      display:block;
  }
  #Blog .post .post__item .diary_block ._left{
  	width: 100%;
  	padding-right: 0;
  }
  #Blog .post .post__item .diary_block ._right{
  	width:100%;
    text-align:center;
    margin-top:2.4rem;
  }
  #Blog .post_detail ._meta_img {
	margin-left: 0;
	display: block;
	float: none;
	text-align: center;
  }
  #Blog .bs-widget-body tr th ,
  #Blog .bs-widget-body tr td {
	display:table-cell;
  }
  #Blog #gallery .img_list li{
  	width:48%;
  }

}
/*# sourceMappingURL=responsive.css.map */