html {
  scroll-behavior: smooth;
  height: 100%; }

body {
  display: flex;
  flex-flow: column;
  min-height: 100vh;
  font-family: 'Noto Sans JP', sans-serif; }

#container {
  width: 100vw;
  margin: 0 auto;
  padding: 0;
  color: #333333; }

header {
  height: auto;
  padding: 1em 0;
  margin-bottom: 1em;
  border-bottom: 1px solid #e6e6e6; }
  header .header__inner {
    position: relative;
    display: grid;
    justify-content: center;
    align-items: center;
    grid-template-columns: 40% 60%;
    width: 970px;
    margin: 0 auto; }
    header .header__inner p {
      color: #a0a0a0;
      font-size: .7em;
      font-weight: bold;
      text-align: right; }
  header img.logo {
    width: 80%;
    height: auto; }
    header img.logo:hover {
      opacity: .5; }
  header .tel {
    color: #a0a0a0;
    font-size: .7em;
    font-weight: bold;
    text-align: right; }
    header .tel img {
      position: absolute;
      top: 2em;
      bottom: 0;
      right: 0;
      display: block; }
  header .menu-bt {
    display: none;
    position: absolute;
    top: .5em;
    right: .5em;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 90;
    border-radius: .2em;
    border: 1px solid #cccccc;
    background-color: #fff; }
  header .menu-bt span,
  header .menu-bt span:before,
  header .menu-bt span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #565656;
    position: absolute; }
  header .menu-bt span:before {
    bottom: 8px; }
  header .menu-bt span:after {
    top: 8px; }
  header #menu-bt-check {
    display: none; }
  header #menu-bt-check:checked ~ .menu-bt span {
    background-color: rgba(255, 255, 255, 0); }
  header #menu-bt-check:checked ~ .menu-bt span::before {
    bottom: 0;
    transform: rotate(45deg); }
  header #menu-bt-check:checked ~ .menu-bt span::after {
    top: 0;
    transform: rotate(-45deg); }
  header .menu-content {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%;
    z-index: 80;
    background-color: #cccccc;
    transition: all 0.5s; }
    header .menu-content ul {
      padding: 70px 10px 0; }
    header .menu-content ul li {
      border-bottom: solid 1px #a0a0a0;
      list-style: none; }
    header .menu-content ul li a {
      display: block;
      width: 100%;
      font-size: 15px;
      box-sizing: border-box;
      color: #333333;
      text-decoration: none;
      padding: 1em;
      position: relative;
      font-weight: bold;
      text-align: right; }
    header .menu-content #m_current:before {
      font-family: "Font Awesome 5 Free";
      margin-right: .4em;
      font-weight: 900;
      content: "\f105";
      color: #333333;
      text-decoration: none; }
  header #menu-bt-check:checked ~ .menu-content {
    left: 0; }

.contents {
  width: 970px;
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  margin: 1em auto;
  display: grid;
  grid-template-columns: 1fr 4fr;
  grid-gap: 1em; }
  .contents a {
    color: #000; }
    .contents a:hover {
      color: #2115b7;
      text-decoration: none; }
  .contents h3 {
    border-bottom: 1px solid #000;
    margin-bottom: 1em; }
  .contents h4 {
    border: 1px solid #000;
    background: #e0dfdf;
    color: #565656;
    font-size: 1em;
    padding: .5em; }
  .contents h5 {
    font-size: 1em;
    margin: 1em 0;
    padding: 0em; }
  .contents .maincontact {
    display: none;
    border-top: 1px solid #cccccc;
    text-align: center;
    padding-top: 1em;
    margin-bottom: 2em; }
    .contents .maincontact p {
      font-weight: bold; }
    .contents .maincontact .m_mailbt a {
      display: flex;
      list-style: none;
      flex-flow: row;
      justify-content: center;
      margin: .5em auto;
      padding: 1em 2em;
      width: 70%;
      font-size: 18px;
      font-weight: 700;
      text-decoration: none;
      border-radius: .2em;
      background: #2115b7;
      color: #fff;
      text-decoration: none; }
      .contents .maincontact .m_mailbt a:hover {
        text-decoration: none;
        color: #fff;
        opacity: .8; }
      .contents .maincontact .m_mailbt a .fas {
        margin: .35em .2em 0 0; }

.side {
  font-size: .8em; }
  .side nav.menu {
    border: 1px solid #cccccc; }
    .side nav.menu ul {
      list-style: none;
      margin: 0;
      padding: 0; }
      .side nav.menu ul li {
        border-bottom: 1px solid #cccccc;
        padding: .4em 1em;
        background: #fafafa;
        background: -moz-linear-gradient(top, #fafafa 0%, #f2f2f2 100%);
        background: -webkit-linear-gradient(top, #fafafa 0%, #f2f2f2 100%);
        background: linear-gradient(to bottom, #fafafa 0%, #f2f2f2 100%);
        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fafafa', endColorstr='#f2f2f2', GradientType=0); }
        .side nav.menu ul li a {
          display: block; }
        .side nav.menu ul li:last-child {
          border-bottom: none; }
        .side nav.menu ul li #current:before {
          display: inline-block;
          font-family: "Font Awesome 5 Free";
          font-weight: 900;
          content: "\f105";
          color: #333333;
          margin-right: .5em;
          text-decoration: none; }
  .side .s_box {
    border: 1px solid #cccccc;
    margin: 1em 0; }
    .side .s_box .title {
      font-size: 1.1em;
      padding: .5em .8em;
      font-weight: bold;
      color: #575757;
      background: #f4f4f4;
      border-bottom: 1px solid #cccccc; }
      .side .s_box .title .fas {
        color: #919191;
        font-size: .4em;
        vertical-align: middle; }
    .side .s_box p {
      padding: .5em;
      margin: 0;
      border-bottom: 1px solid #cccccc; }
      .side .s_box p:last-child {
        border-bottom: none; }
  .side .top-bn img {
    display: block;
    margin: 1em auto; }
    .side .top-bn img:hover {
      opacity: .8; }

#pagetop {
  width: 970px;
  margin: 0 auto;
  text-align: right;
  font-size: 0.8em;
  text-decoration: underline; }
  #pagetop .pagetop {
    display: inline; }
    #pagetop .pagetop:hover {
      color: #2115b7;
      text-decoration: none;
      cursor: pointer; }

footer {
  width: 100%;
  border-top: 1px solid #eaeaea;
  margin: 1em 0;
  color: #565656; }
  footer a {
    color: #565656; }
    footer a:hover {
      color: #2115b7;
      text-decoration: none; }
  footer .inner {
    padding: 1em 0;
    text-align: center;
    font-size: .8em; }
    footer .inner .f_nav {
      display: flex;
      list-style: none;
      flex-flow: row;
      justify-content: center; }
      footer .inner .f_nav li {
        margin: 0; }
        footer .inner .f_nav li + li {
          position: relative; }
        footer .inner .f_nav li + li::before {
          content: "";
          display: block;
          height: 1em;
          border-left: 1px solid #cccccc;
          position: absolute;
          top: 0;
          bottom: 0;
          margin: auto; }
      footer .inner .f_nav a {
        padding: 0 .8em; }

@media (max-width: 768px) {
  #container {
    width: 100%; }

  header .header__inner {
    width: 98%;
    grid-template-columns: none; }
    header .header__inner p {
      display: none; }
  header img.logo {
    width: 80%; }

  .contents {
    width: 96%; }

  #pagetop {
    width: 100%;
    font-size: 0.8em;
    padding-right: 1em; }

  footer .inner {
    font-size: .7em;
    padding: 2em 0; }
    footer .inner .f_nav {
      display: none; } }
@media (max-width: 767px) {
  #container {
    width: 100%;
    padding: 0; }

  header {
    width: 100%;
    grid-template-columns: 75% 25%;
    padding: 0;
    border-bottom: 1px solid #e6e6e6; }
    header .header__inner {
      display: block;
      width: 100%; }
    header img.logo {
      padding: 1em .5em;
      width: 80%; }
    header .tel {
      display: none; }
    header .menu-bt {
      display: flex; }

  .contents {
    width: 96%;
    margin: .6em auto;
    grid-template-columns: 1fr; }
    .contents h4 {
      font-size: 1em; }
    .contents .side {
      display: none; }
    .contents .mail_bt {
      display: none; }
    .contents .maincontact {
      display: block; }

  #pagetop {
    width: 100%;
    font-size: 0.8em;
    padding-right: 1em; }

  footer .inner {
    font-size: .7em;
    padding: 2em 0; }
    footer .inner .f_nav {
      display: none; } }

/*# sourceMappingURL=style.css.map */
