@charset "UTF-8";
/*リセット
--------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none; }

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

/*変数
---------------------------------------------*/
/*全体
---------------------------------------------*/
body {
  font-feature-settings: "palt";
  letter-spacing: 1px;
  font-family: 'Roboto', sans-serif; }

body::before {
  background: url(../images/back_img.png) no-repeat left top;
  background-size: cover;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  z-index: -1; }

a {
  -webkit-transition: all 0.7s;
  -moz-transition: all 0.7s;
  -ms-transition: all 0.7s;
  -o-transition: all 0.7s;
  transition: all 0.7s;
  opacity: 1;
  text-decoration: none;
  color: black; }

a:hover {
  color: #fff; }

.fixedsticky {
  top: 0;
  z-index: 10; }

@-webkit-keyframes main_img {
  from {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes main_img {
  from {
    opacity: 0; }
  100% {
    opacity: 1; } }

.inviewfadeInUp {
  opacity: 0;
  transform: translate(0, 10px);
  -webkit-transform: translate(0, 10px);
  transition: 0.8s; }

.fadeInUp {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0); }

#pageTop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999; }

#pageTop a {
  display: block;
  padding: 8px 0 0 8px;
  border-radius: 30px;
  color: black;
  border: 1px solid black;
  text-decoration: none;
  text-align: center; }

#pageTop a:hover {
  text-decoration: none; }

/*head -------------------------*/
#head .logo_top {
  margin: 0 auto; }

#contents {
  margin: 0 auto;
  color: black; }

.box li span {
  border: 1px solid black;
  padding: 3px 30px; }

.box li span:hover {
  background-color: black; }

/*box1 -------------------------*/
#staff_info {
  text-align: center; }

/* footer -------------------------*/
#footer_box {
  margin: 0 auto; }

.footer_p {
  margin: 0 auto;
  text-align: center; }

#sns_flex {
  display: flex;
  justify-content: space-between;
  margin: 0 auto; }
#sns_flex a {
  text-decoration: none; }

#logo {
  margin: 0 auto; }

#copyright p {
  text-align: center;
  color: #000; }

/* PC
--------------------------------------*/
@media screen and (min-width: 668px) {
  body {
    font-feature-settings: "palt";
    letter-spacing: 1px;
    font-family: 'Roboto', sans-serif; }

  body::before {
    background: url(../images/back_img.png) no-repeat left top;
    background-size: cover;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    z-index: -1; }

  .pc_none {
    display: none; }

  .fixedsticky {
    top: 0;
    z-index: 10; }

  @-webkit-keyframes main_img {
    from {
      opacity: 0; }
    100% {
      opacity: 1; } }
  @keyframes main_img {
    from {
      opacity: 0; }
    100% {
      opacity: 1; } }

  .inviewfadeInUp {
    opacity: 0;
    transform: translate(0, 10px);
    -webkit-transform: translate(0, 10px);
    transition: 0.8s; }

  .fadeInUp {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  #pageTop a {
    width: 35px;
    height: 35px; }

  i {
    padding: 4px 5px 0px 0px; }

  /*head -------------------------*/
  #head {
    width: 100%;
    margin: 0 auto;
    -webkit-animation: main_img 1.0s linear 1 forwards;
    animation: main_img 1.0s linear 1 forwards; }

  #head h1 {
    width: 40%;
    margin: 50px auto;
  }

  #head .logo_top {
    width: 15%;
    margin: 0 auto;
  }

  #contents {
    max-width: 880px; }

  .box {
    margin: 100px auto 0 auto; }

  .box ul {
    text-align: left;
    padding-top: 15px; }

  .box li {
    line-height: 230%;
    font-size: 11px;
    text-align: right; }

  .box h2 {
    margin: 0 auto;
    width: 55%;
    padding-bottom: 20px;
  }

  .first_box {
    width: 100%; }

  .num_under {
    padding-bottom: 50px; }

  .flex {
    display: flex;
    justify-content: space-between; }

 /*box -------------------------*/
  .flex_left {
    width: 100%;
    margin-right: 10px;
  }

  .flex_right {
    width: 100%;
    margin: 0 auto; }

  #box_4 > .flex > .flex_right{
   position: relative;
   top: 200px;
  }

  #box_5 > .flex > .flex_left{
   position: relative;
   top: 200px;
  }

  #box_7 > .flex {
   margin-top: 100px;
  }

  #staff_info {
    font-size: 11px;
    line-height: 23px;
    padding-top: 100px; }

  /* footer -------------------------*/
  #footer_box {
    width: 40%;
    padding: 100px 0; }

  .footer_p {
    width: 35%;
    padding: 0 0 20px 0; }

  #sns_flex {
    width: 60%; }
  #sns_flex li {
    width: 12%; }
  #sns_flex a {
    text-decoration: none; }

  #logo {
    width: 10%; }

  #copyright p {
    padding: 20px 0 50px 0;
    font-size: 11px; } }

/* SP
--------------------------------------*/
@media screen and (max-width: 667px) {
  body {
    font-feature-settings: "palt";
    letter-spacing: 1px;
    font-family: 'Roboto', sans-serif; }

  body::before {
    background: url(../images/back_img.png) no-repeat left top;
    background-size: cover;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    z-index: -1; }

  .sp_none {
    display: none; }

  .fixedsticky {
    top: 0;
    z-index: 10; }

  @-webkit-keyframes main_img {
    from {
      opacity: 0; }
    100% {
      opacity: 1; } }
  @keyframes main_img {
    from {
      opacity: 0; }
    100% {
      opacity: 1; } }
  .inviewfadeInUp {
    opacity: 0;
    transform: translate(0, 10px);
    -webkit-transform: translate(0, 10px);
    transition: 0.8s; }

  .fadeInUp {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  #pageTop a {
    width: 30px;
    height: 30px; }

  i {
    padding: 2px 6px 0px 0px; }

  /*head -------------------------*/
  #head {
    width: 100%;
    margin: 0 auto; }

  #head h1 {
    width: 80%;
    margin: 20px auto;}

  #head .logo_top {
    width: 30%;
    margin: 0 auto 40px;}

  #contents {
    width: 90%; }

  .box {
    margin: 0px auto 0 auto; }

  .box ul {
    padding: 15px 0 50px 0; }

  .box li {
    line-height: 280%;
    font-size: 11px;
    text-align: left; }

  .box h2 {
    padding: 0 10px 30px;
  }

  .num_under {
    padding-bottom: 30px; }

  /*box -------------------------*/

  #box_1 {
    margin-top: 50px;
  }

  #box_6 > .flex > .flex_left {
   margin-bottom: 50px;
  }

  #staff_info {
    font-size: 10px;
    line-height: 18px;
    padding-top: 40px; }

  /* footer -------------------------*/
  #footer_box {
    width: 60%;
    padding: 80px 0; }

  .footer_p {
    width: 50%;
    padding: 0 0 15px 0; }

  #sns_flex {
    width: 100%; }
  #sns_flex li {
    width: 11%; }
  #sns_flex a {
    text-decoration: none; }

  #logo {
    width: 25%; }

  #copyright p {
    padding: 10px 0 30px 0;
    font-size: 10px; } }
