@charset "UTF-8";
/* 共通CSS */
html {
font-size: 62.5%;
}
body {
  color: #dac7a5;
  font-family: 'Noto Serif JP', serif;
  font-size: 1.2rem;
}
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
img {
  max-width: 100%;
  height: auto;
}
li {
  list-style: none;
}
a {
  color: #ccc;
}
a:link, a:visited, a:hover, a:active {
  text-decoration: none;
}

ul.slide_pc {
  display: none;
}
ul.slide_mb {
  position: relative;
}
ul.slide_mb li {
  position: fixed;
  z-index: -1;
}
ul.slide_mb img {
  width: 100vw;
  height: 100vh;
}

.mobile_nav {
  display: none;
  width: 100%;
  position: fixed;
  background-color: rgb(0, 0, 0, 0.7);
  padding: 2rem 0;
  z-index: 10;
}
.mobile_nav h2 {
  font-weight: normal;
  margin: 2rem 0 1rem;
  font-style: italic;
}
.mobile_nav h3 {
  width: 7rem;
  margin: 0 auto ;
}
.active {
  display: block;
}
.mobile_nav li {
  margin: 2rem 0;
  font-size: 1.6rem;
  font-style: italic;
  text-align: center;
}
.mobile_nav li a:hover {
  color: #dac7a5;
}
.pc_nav_logo {
  display: none;
}
.pc_nav {
  display: none;
}

.nav_button {
  width: 3rem;
  position: fixed;
  top: 1rem;
  right: 1rem;
  cursor: pointer;
  z-index: 100;
}

main {
  width: 100%;
}
.block {
  background-color: rgb(0, 0, 0, 0.4);
}
.text_content {
  width: 70%;
  margin: 0 auto;
}

h1, h2 {
  text-align: center;
}
h1 {
  height: 100vh;
}
h1 img {
  width: 30%;
  margin-top: 50%;
}

h2 {
  font-size: 1.6rem;
  margin: 15rem 0 3rem;
}
h2::before {
  font-family: 'Great Vibes', cursive, serif;
  margin-top: 5rem;
  padding-top: 4rem;
}
#concept h2::before {
  content: 'Concept';
  display: block;
  font-size: 2.1rem;
}
#system h2::before {
  content: 'System';
  display: block;
  font-size: 2.4rem;
}
#access h2::before {
  content: 'Access';
  display: block;
  font-size: 2.4rem;
}
#information h2::before {
  content: 'Information';
  display: block;
  font-size: 2.4rem;
}
#recruit h2::before {
  content: 'Recruit';
  display: block;
  font-size: 2.4rem;
}

main p {
  font-size: 1.3rem;
  overflow-wrap: break-word;
  word-wrap: break-word;
}
main p.text_end {
  padding-bottom: 5rem;
}
#concept p {
  letter-spacing: 0.3rem;
  line-height: 1.6;
  width: 75%;
  margin: 0 auto;
}
#concept p.text_end {
  margin-top: 2rem;
}
#system dl {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 0.5rem;
}
#system dl.text_end {
  padding-bottom: 5rem;
}
#system dt {
  width: 60%;
  padding-bottom: 1.2rem;
}
#system dd {
  width: 40%;
  text-align: left;
  padding-bottom: 1.2rem;
}
#system p {
  margin-bottom: 1.5rem;
}
#access p {
  text-align: center;
}
#access .address, #access .station {
  margin-bottom: 1rem;
}
#access .tel {
  margin-top: 2rem;
}
.google_map iframe {
  width: 100%;
  filter: grayscale(0.9);
  -webkit-filter: grayscale(0.9);
  margin-top: 3rem;
}
#information dl {
  margin: 0 auto;
  padding-bottom: 0.8rem;
  width: 80%;
}
#information dt {
  padding-bottom: 0.8rem;
}
#information dd {
  padding-bottom: 0.8rem;
  padding-left: 1.3rem;
}
.caution {
  text-indent: -1.3rem;
  padding-top: 1.6rem;
}
.admin {
  margin-top: 1.5rem;
  text-align: right;
}
#recruit {
  padding-bottom: 5rem;
}
#recruit h3 {
  text-align: center;
  margin-bottom: 2rem;
}
.text_end_recruit {
  padding-bottom: 2.5rem;
}
table {
  width: 100%;
  margin: 0 auto;
  border-collapse: collapse;
}
table tr th, table tr td {
  border: solid #dac7a5 1px;
  vertical-align: top;
}
table th {
  width: 25%;
  padding: 0.5rem 0;
}
table td {
  width: 75%;
  padding: 0.5rem 0 0.3rem 1rem;
}
.apeal, .application {
  margin: 2rem auto;
  width: 100%;
}
.apeal p, .application p {
  text-align: center;
  border: solid #dac7a5 1px;
  padding: 0.5rem 0;
}
.apeal ul, .application dl {
  border-left: solid #dac7a5 1px;
  border-right: solid #dac7a5 1px;
  border-bottom: solid #dac7a5 1px;
  padding: 1rem 0;
}
.apeal_01 li {
  width: 60%;
  margin: 0 auto;
  padding: 0.5rem 0
}
.apeal_02 li {
  text-indent: -1.5rem;
  width: 80%;
  margin: 0 auto;
  padding: 1rem 0.5rem 1rem 1.4rem;
}
.application dl {
  overflow: hidden;
}
.application dt {
  width: 30%;
  text-align: center;
  float: left;
}
.application dt::after {
  content: "：";
  display: inline;
}
.application dd {
  width: 70%;
  float: right;
  padding-right: 1.5rem;
}
.application dd a {
  text-decoration: underline;
}
.link {
  padding-bottom: 1rem;
}

.mobile {
  width: 4rem;
  position: fixed;
  bottom: 1rem;
  right: 1rem;
  text-align: center;
  display: none;
}
.tel_link_icon {
  margin-bottom: 1.5rem;
}
.tel_link_icon a::before {
  font-family: "Font Awesome 5 Free";
  content: "\f87b";
  font-weight: 900;
  color: #dac7a5;
  font-size: 3.5rem;
  font-style: normal;
}
.instagram a img {
  width: 3.5rem;
}

footer {
  width: 100%;
  background-color: rgb(0, 0, 0, 0.7);
  padding: 1.4rem 0 0.7rem;
  text-align: center;
  margin-top: 10rem;
}
.footer_logo img {
  width: 4.5rem;
  margin-bottom: 1rem;
}
.pc_tel {
  display: none;
}
small p {
  font-size: 0.7rem;
  font-style: italic;
  padding-top: 1.4rem;
}


@media only screen and (min-width: 640px){
  /* 640px以上 */
  ul.slide_mb {
    display: none;
  }
  ul.slide_pc {
    display: block;
    position: relative;
    
  }
  ul.slide_pc li {
    position: fixed;
    z-index: -1;
  }
  ul.slide_pc img {
    width: 100vw;
    height: 100vh;
  }
  .pc_nav {
    display: flex;
    justify-content: center;
    align-items: baseline;
    width: 100%;
    background-color: rgb(0, 0, 0, 0.7);
    padding: 1rem 0;
    z-index: 10;
    position: fixed;
    opacity: 0;
  }
  .pc_nav_logo {
    display: block;
    width: 30%;
    text-align: center;
    padding-top: 0.5rem;
  }
  .pc_nav_logo img {
    width: 6rem;
  }
  .pc_nav ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 70%;
  }
  .pc_nav li {
    font-size: 1.6rem;
    font-style: italic;
    text-align: center;
    padding: 0 2rem;
  }
  .pc_nav li a:hover {
    color: #dac7a5;
    border-bottom: none;
  }
  .nav_button {
    display: none;
  }
  main p {
    font-size: 1.4rem;
  }
  h1 img {
    width: 15%;
    margin-top: 20%;
  }
  .text_content {
    width: 60%;
  }
  #system .text_content {
    width: 60%;
    margin: 0 auto;
  }
  #system p {
    padding-left: 6rem;
  }
  #system dt {
    width: 50%;
    padding-left: 6rem;
  }
  #system dd {
    width: 50%;
    padding-left: 6rem;
  }
  #information dl {
    width: 70%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    padding-bottom: 1.2rem;
  }
  #information dt {
    width: 30%;
    padding-bottom: 1.2rem;
  }
  #information dd {
    width: 70%;
    text-align: left;
    padding-bottom: 1.2rem;
  }
  .caution, .admin {
    width: 70%;
    margin: 0 auto;
  }
  .apeal_01 li {
    width: 30%;
  }
  .apeal_02 li {
    width: 60%;
  }
  .application dt {
    width: 40%;
  }
  .application dd {
    width: 60%;
  }
  .link a {
    pointer-events: none;
    cursor: none;
    text-decoration: none;
  }
  .tel_link_icon {
    display: none;
  }
  .pc_tel {
    display: block;
    margin-top: 1rem;
  }
}

@media only screen and (min-width: 1020px){
  /* 1020px以上 */
  .text_content {
    width: 50%;
  }
  h1 img {
    width: 10%;
    margin-top: 15%;
  }
  #system .text_content {
    width: 40%;
  }
  .friends p {
    width: 80%;
    margin: 0 auto;
  }
  .apeal p, .application p {
    width: 100%;
  }
  .google_map {
    width: 60%;
    margin: 0 auto;
  }
}