@charset "UTF-8";

.page-header {
  background-color: #fdfaf1;
}

.category-wrap {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}

.category-wrap>a {
  position: relative;
  display: flex;
  width: auto;
  padding: 0.75em 2.5em;
  align-items: center;
  gap: 25px;

  background-color: #fff;
  color: #f46529;
  border: 1px solid;
  border-radius: 100px;
  transition: .2s all;
}

.category-wrap>a:hover {
  color: #fff;
  background-color: #f46529;
}

#school h3 {
  font-size: 2.8rem;
  margin-bottom: 1.3em;
  line-height: 1.2;
  letter-spacing: 0.08em;
}

#school h4 {
  font-size: 2.0rem;
  font-weight: 700;
  margin-bottom: 0.05em;
}

#school .section-subtitle {
  display: block;
  text-align: center;
  font-size: 0.9em;
}

#school .flex-container.headquarters h4 {
  font-size: 2.2rem;
  margin-bottom: 0.5em;
}

#school .flex-container.headquarters a {
  color: #f46529;
}


#school .flex-container.headquarters>div {
  width: 48.5%;
}

#school .flex-container.headquarters>div iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
}

#school .flex-container.headquarters table {
  width: 100%;
  border-collapse: collapse;
}

#school .flex-container.headquarters table tr>* {
  padding: 0.5em 0.0em;
  vertical-align: top;
  line-height: 1.75;
  font-size: 0.95em;
}

#school .flex-container.headquarters table tr th {
  width: 7em;
  letter-spacing: 0.1em;
}


#school .area-wrap:not(:first-of-type) {
  margin-top: 12rem;
  padding-top: 12rem;
  border-top: 1px solid #d2d2d2;
}

#school .area-wrap .flex-container.list {
  justify-content: flex-start;
  gap: 4rem calc((100% - 96%) / 2);
}

#school .area-wrap .flex-container.list .school-wrap {
  width: 32%;
}

#school .area-wrap .flex-container.list .school-wrap .info {
  flex-direction: column;
  gap: 20px;
}

#school .area-wrap .flex-container.list .school-wrap .info .img img {
  aspect-ratio: 16 / 10;
  border-radius: 5px;
}

#school .area-wrap .flex-container.list .school-wrap .info .address {
  font-size: 1.5rem;
  opacity: 0.7;
  letter-spacing: 0.05em;
}

/** -------- スマホ -------- **/
@media screen and (max-width: 960px) {
  #school .area-wrap .flex-container.list .school-wrap {
    width: 49%;
  }

  #school .flex-container.headquarters {
    gap: 20px;
  }

  #school .flex-container.headquarters>div {
    width: 100%;
  }

  #school .flex-container.headquarters h4 {
    text-align: center;
  }

  #school .flex-container.headquarters table {
    max-width: 350px;
    margin: 0 auto;
  }

  #school .flex-container.headquarters table tr th {
    width: 6em;
  }
}

@media screen and (max-width: 768px) {
  #school .area-wrap:not(:first-of-type) {
    margin-top: 8rem;
    padding-top: 8rem;
  }
}

@media screen and (max-width: 570px) {
  .category-wrap {
    gap: 10px 7px;
  }

  .category-wrap>a {
    padding: 0.45em 1.5em;
  }

  #school h3 {
    font-size: 2.0rem;
  }

  #school h4 {
    font-size: 1.5rem;
  }

  #school .area-wrap .flex-container.list {
    gap: 20px;
  }

  #school .area-wrap .flex-container.list .school-wrap .info {
    flex-direction: row;
    gap: 10px;
    align-items: flex-start;
  }

  #school .area-wrap .flex-container.list .school-wrap .info .img {
    flex: 2.5;
  }

  #school .area-wrap .flex-container.list .school-wrap .info .text {
    flex: 7.5;
  }

  #school .area-wrap .flex-container.list .school-wrap .info .text .address {
    font-size: 1.2rem;
  }

  #school .area-wrap:not(:first-of-type) {
    margin-top: 14vw;
    padding-top: 14vw;
  }

  #school .area-wrap .flex-container.list .school-wrap {
    width: 100%;
  }

  #school .flex-container.headquarters h4 {
    font-size: 1.8rem;
  }
}