@charset "UTF-8";

/* 共通 */
body {
  animation-name: fuwa;
  animation-duration: 0.5s;
}

@keyframes fuwa {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.custom-p {
  margin-top: 0;
}
.bread ol {
  display: flex;
  width: 1025px;
  margin: auto;
  padding-inline-start: 7px;
  flex-wrap: wrap;

  & a {
    color: #4089b4;
    padding-right: 1vw;
  }
  & span {
    color: #4089b4;
  }
}
.bread p {
  margin: 0;
}
.custom-ttl {
  padding: 1vh 5vw;
  margin-top: 10vh;
  text-align: center;
  position: relative;
  background-size: cover;
  height: 10vh;
  display: block grid;
  place-items: center;

  & h1 {
    color: #4089b4;
    margin: 0 auto;
    font-size: 1.6rem;
  }
}
.bread-container {
  border-bottom: 1px solid #4089b4;
  padding: 1vw 5vw;
}

/*news*/
#news-all .custom-ttl {
  background-image: url("../img/other/news-img.jpg");
  margin: 10vh auto 0;
  height: 16vh;
}
#news-cate .custom-ttl {
  background-image: url("../img/other/news-img.jpg");
  margin: 10vh auto 0;
  height: 16vh;
}
.categories {
  border-top: 1px solid #4089b4;
  padding-top: 2vw;
}
.categories_list {
  display: flex;
  flex-wrap: wrap;
  gap: 2vw;
  padding: 0;
  max-width: 900px;
  margin: 1vw auto;
}
.categories_list li a {
  display: block;
  margin: 0 2px;
  padding: 10px 20px;
  color: #4089b4;
}
.categories_content {
  padding: 50px 20px;
}
.pagination {
  margin: 2vw auto;
}
.pagination ul {
  display: flex;
  justify-content: center;
  gap: 8px;
  list-style: none;
  padding: 0;
}

.pagination li a,
.pagination li span {
  display: flex;
  padding: 8px;
  border: 1px solid #ccc;
  text-decoration: none;
  font-size: 0.8rem;
  color: #333;
  border-radius: 25px;
  justify-content: center;
  align-items: center;
  width: 2vw;
  aspect-ratio: 1;
  white-space: nowrap;
}

.pagination li .current {
  background-color: #4089b4;
  color: #fff;
  border-color: #4089b4;
}

.pagination li a:hover {
  background-color: #f0f0f0;
}

.pagination li .dots,
.pagination li .prev,
.pagination li .next {
  border: none;
  background: none;
}

/*
.area {
	display: none;
	opacity: 0;
	background: #fff;
	padding:50px 20px;
}

.area.is-catopen {
    display: block;
    animation-name: displayAnime;
    animation-duration: 2s;
    animation-fill-mode: forwards;
}

@keyframes displayAnime{
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
*/

/* single */
#news-single .custom-ttl {
  background-image: url("../img/other/news-img.jpg");
  margin: 12vh auto 0;
  height: 16vh;
}
.single-container {
  padding: 2vw 5vw;
  margin: 0 auto;
  max-width: 1000px;
  border-top: 1px solid #4089b4;
}
.single-group {
  margin: 0 auto;
  max-width: 900px;
  border-bottom: 1px solid #4089b4;
  padding: 4vw;
}
.single-img {
  width: 100%;
  text-align: center;
}
.single-ttl {
  color: #244e7d;
  font-size: 1.6rem;
  margin: 1vw 0 1vw;
}
.current-category a {
  color: #5b31b6 !important;
  border-bottom: 1px solid #5b31b6;
}
.single-date {
  color: #6baed1;
}
.single-text {
  color: #244e7d;
  margin: 3vw 0;
  line-height: 1.9rem;

  & p {
    text-align: justify;
  }
}

.news-back {
  margin: 0 auto;
  max-width: 1000px;
  display: flex;
  justify-content: end;
}
.news-backbtn {
  font-size: 1.3rem;
  color: #244e7d;
}
.news-backbtn_text {
  display: flex;
  align-items: center;
  margin: 0;
  gap: 1vw;
}
.news-backbtn_text::before {
  content: "";
  display: block;
  background-image: url(../img/arrow-l.svg);
  background-repeat: no-repeat;
  width: 0.7vw;
  height: 0.7vw;
}

#webShareApi {
  cursor: pointer;
  background-color: #fff;
  border: none;
  width: 7%;

  & img {
    width: 50%;
  }
}

/* 将来ビジョン */
.orange-line .line-text {
  position: relative;
}
.line-marker.is-animated .line-text::before {
  animation: orange-line 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  background-color: #e8ffcc;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
}
.orange-line .line-text .line {
  display: inline-block;
  position: relative;
  z-index: 1;
}
.line-box {
  display: flex;
  margin: 0 auto;
  width: fit-content;
  align-items: center;
}

@keyframes orange-line {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%,
  100% {
    opacity: 1;
  }
}
.vision-ttl {
  position: relative;
  margin: 2vw auto;
  text-align: center;

  & h2 {
    color: #244e7d;
    z-index: 1;
    position: relative;
    font-size: 2rem;
  }
}
.vision-ttl img {
  width: 23%;
  position: absolute;
  transform: translate(-24vw, -12vw);
}
.grade-back {
  background-size: cover;
  color: #4089b4;
  text-align: center;
}
#vision-top {
  margin-bottom: 26vh;
}
.vision-top_catch {
  background-image: url("../img/vision/vision-top_catch.jpg");
  background-size: cover;
  width: 100%;
  height: 148vh;
  position: relative;
  writing-mode: vertical-rl;
}
.vision-top_text {
  position: absolute;
  top: 17%;
  left: 10%;

  & h1 {
    margin: 0;
    font-size: 6rem;
    line-height: 1.4;
    color: #7382e5;
    font-family: "TazuganeGothicStdN-Light";
  }
  & span.hensin_color {
    color: #7382e5;
    margin-top: -46px;
  }
  & p {
    color: #5d87b0;
    font-size: 1.5rem;
    margin-top: 8px;
  }
}
.vision-top_svg {
  width: 30%;
  position: absolute;
  bottom: 18%;
  right: 4%;
}
.vision-top-copy {
  color: #244e7d;
  width: fit-content;
  margin: 3vw auto;

  & p {
    font-size: 3rem;
    margin-bottom: 25px;
    text-align: center;
  }
  & h2 {
    font-size: 4rem;
    margin: 0;
    line-height: 5rem;
    text-align: center;
  }
}
.vision-top-copy2 {
  color: #4089b4;
  text-align: center;
  font-size: 2rem;
  margin: 7vw auto;
  width: fit-content;

  & p {
    margin: 0 0 1vw;
  }
}
#seiryo-vision {
  margin: 38vh 0;
}

.grade-back01 {
  background: linear-gradient(70deg, #ccebff 0%, #edd9ff 100%);
  background-repeat: no-repeat;
  font-size: 2rem;
  padding: 7vw 0 0;

  .container {
    padding: 5vw 0;
  }
  .grade-p1 {
    color: #fff;
  }
  & p {
    margin: 0;
  }
}
.vis-img {
  display: block;
  margin: 0 auto;
}
.vision-img {
  position: relative;
  width: fit-content;
  margin: 0 auto;
}
.img-on01 {
  position: absolute;
  width: 28%;
  bottom: 0;
  left: 0;
}
.img-on02 {
  position: absolute;
  width: 28%;
  bottom: 0;
  right: 0;
}
.vision-sis {
  margin: 5vw auto;
  text-align: center;

  & img {
    width: 70%;
  }
  .vision-sis_text {
    color: #244e7d;
    margin: 5vw auto;
    font-size: 2rem;

    & p {
      margin: 1vw;
    }
    .line-text {
      width: fit-content;
      margin: 1vw auto;
    }
  }
}
.vision-sis_btn {
  text-align: center;
  margin: 5vw auto;
}
.vision-sis_btn a {
  width: 30%;
  border: 1px solid #244e7d;
  padding: 1.2vw 1vw;
  display: flex;
  align-items: center;
  margin: 1vw auto;
  overflow-wrap: anywhere;
  justify-content: center;
  color: #244e7d;

  & span {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2vw;
    aspect-ratio: 1;
    overflow: hidden;
  }
  & p {
    margin: 0;
    padding-left: 1vw;
  }
}
#vision-todo {
  margin: 30vh 0;

  .vision-ttl img {
    width: 15%;
    transform: translate(-15vw, -7vw);
  }
}
.grade-back02 {
  background: linear-gradient(30deg, #ccebff 0%, #edd9ff 100%);
  background-repeat: no-repeat;
  font-size: 1.5rem;
  padding: 7vw 0;

  & p {
    margin: 3vw 0;
  }
}
.grade-back03 {
  background: linear-gradient(90deg, #edffff 0%, #efe3f2 100%);
  background-repeat: no-repeat;
  padding: 5vw 0 4vw;
}
.todoplan {
  margin: 5vw auto;
  position: relative;
  width: 55%;

  & img {
    width: 55%;
  }
  .todo-no {
    position: absolute;
    top: 0;
    left: 20%;
    font-size: 3.5rem;
  }
  .orange-line {
    font-size: 1.6rem;
    margin: 0.5vw auto;
    width: fit-content;
    transform: translateY(-1vw);
  }
}
.todo-text {
  color: #244e7d;
  transform: translateY(-2vw);

  & h3 {
    font-size: 2.5rem;
    color: #244e7d;
    margin: 0;
  }
  & p {
    font-size: 2rem;
    margin: 0;
    font-weight: bold;
    line-height: 2.4rem;
  }
}
.todo-text02 {
  width: fit-content;
  margin: 1vw auto;
}
#vision-promise {
  margin-bottom: 25vh;

  .vision-ttl {
    text-align: left;
    max-width: 1000px;
    padding: 0 10vw;

    & img {
      transform: translate(-8vw, -12vw);
      width: 28%;
    }
  }
}
.grade-back04 {
  background: linear-gradient(30deg, #ffffde 30%, #deffcc 100%);
  background-repeat: no-repeat;
  padding: 5vw 0 4vw;
  text-align: left;
  font-size: 1.7rem;

  .promise-text {
    color: #244e7d;
    font-size: 2rem;
  }
  .container {
    width: fit-content;
  }
}
.promise-group {
  margin: 4vw 0;
  color: #244e7d;

  & h3 {
    margin: 0;
    font-size: 1.9rem;
    transform: translateY(-2vw);
  }
  .promise-ttl {
    background: linear-gradient(30deg, #ffffde 30%, #deffcc 100%);
    background-repeat: no-repeat;
    height: 1vw;
    width: 100%;
    background-size: cover;
    background-position: center bottom;
  }

  .container {
    max-width: 900px;
    padding: 2vw 10vw;
  }
  & p {
    font-size: 1.3rem;
    margin-top: 1vw;
  }
}
#vision-universal {
  margin: 5vw 0;

  .grade-back01 {
    font-size: 1.5rem;
    padding-bottom: 7vw;
    letter-spacing: 0.07em;
    line-height: 1.8;

    & p {
      margin: 2vw 0;
    }
  }
  .vision-ttl img {
    width: 23%;
    position: absolute;
    transform: translate(-20vw, -10vw);
  }
}
.univ-mission {
  margin: 5vw auto;
  text-align: center;
  color: #244e7d;

  & img {
    width: 50%;
    margin: 5vw auto;
  }
  & h2 {
    font-size: 3rem;
    color: #374f7b;
    font-style: italic;
  }
  .green-line {
    background: linear-gradient(transparent 50%, rgba(232, 255, 204, 0.5) 50%);
    width: fit-content;
    margin: 0.5vw auto;
    font-size: 1.5rem;
    padding: 0 0.5vw;
  }
}
.univ-img {
  position: relative;

  .univ-img_text {
    position: absolute;
    width: 37%;
    z-index: 2;
    top: 31%;
  }
  .univ-img1 {
    transform: translate(25%, 0%);
    width: 70%;
  }
  .univ-img2 {
    transform: translate(0%, 25%);
    width: 70%;
  }
}

/* 公開情報 */
#koukai .custom-ttl {
  background-image: url("../img/other/discloser-img_pc.jpg");
  height: 15vh;
}
.koukai-container {
  background-color: #f1eef2;
  border-top: 1px solid #4089b4;
  padding-bottom: 5vw;
}
.koukai-group {
  background-color: #fff;
  border: 1px solid #4089b4;
  width: 90%;
  margin: 3vw auto;
  color: #244e7d;
  padding: 2vw;

  & ul {
    padding: 0;
    color: #244e7d;
    border-top: 3px solid #4089b4;
  }
  & a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 93%;
    padding: 0.5vw 0vw 0.5vw 3vw;
    margin: 1vw 0;
    color: #244e7d !important;
  }
  & h2 {
    font-size: 1.4rem;
  }
  summary {
    display: block;
    list-style: none;
    padding: 3vw 1vw;
  }
  summary::-webkit-details-marker {
    display: none;
  }
  summary:hover {
    color: #bdd2e4;
    opacity: 0.5;
  }
}

.koukai-file_container {
  background-color: #fff;
  margin: 5vw auto;
  width: 70%;
  color: #244e7d;
  padding: 5vw;

  & h2 {
    font-size: 1.4rem;
  }
}
.file-dl {
  border-bottom: 1px solid #4089b4;
  padding: 1vw 0;
  margin: 2vw auto;
  font-size: 1.2rem;

  & a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #244e7d;
  }
  & span {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2vw;
    overflow: hidden;
    padding-left: 3vw;
  }
}
.koukai-file-group {
  border-bottom: 1px solid #4089b4;
  padding: 1vw 0;
  margin: 2vw auto;
  font-size: 1rem;

  & a {
    color: #244e7d;
  }
  & span {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2vw;
    overflow: hidden;
    padding-left: 3vw;
  }
  .koukai-dl {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .koukai-text a {
    color: #4089b4;
    display: contents;
  }
  .koukai-text a:hover {
    color: #bdd2e4;
    opacity: 0.5;
  }
  .koukai-text p {
    margin: 0;
  }
}
.buttonIconText02 {
  width: 8%;
  min-width: 8%;
  padding: 0.5vw 2.5vw 0.5vw 2vw;
  font-size: 1.3rem;
  flex-direction: row;
}
.buttonIconText02_text {
  padding-top: 0.5vw;
}
.koukai-taxo {
  margin-top: 150px;
}

/*お問合せ*/
#contact {
  color: #4089b4;
  letter-spacing: 0.08rem;
}
.contact-top_catch {
  background-image: url("../img/other/contact-img.jpg");
  background-size: cover;
  width: 100%;
  height: 50vh;
  position: relative;
  margin-top: 100px;

  .contact-top_text {
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
  }
  & h1 {
    font-size: 2rem;
    margin: 0;
  }
  & p {
    color: #244e7d;
    font-size: 1.2rem;
    margin: 0;
  }
}
.contact-p {
  width: 75%;
  margin: 4vw auto 7vw;

  & span {
    font-size: 0.9rem;
  }
}
.contact-point {
  color: #244e7d;
  font-size: 1.1rem;
  margin: 0;
}
.contact-container {
  margin: 5vw auto;
  width: 75%;
  color: #244e7d;

  & table {
    width: 100%;
    border: 1px solid #244e7d;
    border-collapse: collapse;
  }
  & td {
    border: 1px solid #244e7d;
  }
  & th {
    background-color: #7bbecc;
    color: #fff;
    border: 1px solid #244e7d;
    padding: 1vw;
  }
  & td {
    padding: 2vw;
  }
  .contact-name {
    width: 45%;
    text-align: center;
  }
  .contact-date {
    margin: 0 auto;
    color: #4089b4;
    width: fit-content;

    & span {
      font-size: 1rem;
      color: #244e7d;
      padding-right: 1vw;
    }
  }
  & span {
    font-size: 0.9rem;
  }
  .contact-text {
    color: #4089b4;
  }
}

/*教育事業*/
.education {
  margin: 10vh 0 20vh;
}
.edu-top_catch {
  background-image: url(../img/other/edu-top-img.jpg);
  background-size: cover;
  width: 100%;
  height: 50vh;
  position: relative;
  margin-top: 100px;

  .edu-top_text {
    margin: 0;
    position: absolute;
    top: 56%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
  }
  & h1 {
    font-size: 2rem;
    margin: 0;
    color: #244e7d;
  }
}
.edu-container {
  margin: 5vw auto;
  width: 75%;
  max-width: 1000px;
  color: #244e7d;

  & h2 {
    text-align: center;
    margin: 2vw auto;
  }
  & img {
    margin: 1vw auto;
    display: block;
  }
  .more-btn {
    background: linear-gradient(90deg, #a8ccff 0%, #edb9ff 100%);
    background-repeat: no-repeat;
    background-size: 100% 0.5vw;
    background-position: bottom;
    width: fit-content;
    padding: 0.5vw 0;
    margin: 3vw auto;
  }
  .more-btn:hover {
    opacity: 0.5;
  }
  .more-list ul {
    padding: 0;
  }
  .more-list p {
    color: #4089b4;
  }
  .more-list a:hover {
    opacity: 0.5;
  }
}
.edu-text {
  padding: 3vw;
  border-bottom: 1px solid #244e7d;
  text-align: justify;
  line-height: 1.9rem;

  & a {
    text-align: right;
    color: #4089b4;
    display: flex;
    align-items: center;
    gap: 1vw;
    justify-content: right;
    font-size: 1rem;
  }
  & a::after {
    content: "";
    display: block;
    background-image: url(../img/arrow-r.svg);
    background-repeat: no-repeat;
    width: 0.7vw;
    height: 0.7vw;
  }
  .align-r {
    text-align: right;
  }
}
.edu-add {
  padding: 2vw 3vw;
  font-size: 1rem;

  & a {
    color: #4089b4;
  }
}

/*学園概要*/
.font-mincho {
  font-family: serif;
}
.overview {
  padding-top: 10vw;

  & h2 {
    text-align: center;
    color: #4089b4;
  }
}
.overview-top {
  margin: 11vh auto 0;
  max-width: 1200px;
  padding: 2vw 5vw;

  & h1 {
    color: #244e7d;
    margin: 0;
    font-size: 1.5rem;
    margin-block-start: 0;
   margin-block-end: 0;
  }
  .bread-container {
    border-bottom: none;
    padding: 1vw 0;
  }
}
#overview-kengaku {
  background: linear-gradient(90deg, #daf2cc 0%, #edd9ff 100%);
  background-repeat: no-repeat;
  background-size: 100%;
  padding: 4vw 2vw;

  & h1 {
    text-align: center;
    letter-spacing: 0.3rem;
  }
}
.kengaku-container {
  position: relative;
  padding: 3vw 5vw;
  margin: 2vw auto;
  width: 60%;
  z-index: 0;

  .kengaku-img {
    width: 25%;
    margin: 1vw auto;

    & p {
      text-align: left;
      margin: 0;
      font-size: 0.9rem;
    }
    & img {
      width: 100%;
      margin: 1vw auto;
    }
  }
  .kengaku-text {
    width: 70%;
    margin: 2vw auto;
    letter-spacing: 0.1rem;
    text-align: justify;
  }
}
.kengaku-container::before {
  content: "";
  position: absolute;
  background-color: #fff;
  border-radius: 1vw;
  opacity: 0.5;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.over-more {
  background: linear-gradient(90deg, #a8ccff 0%, #edb9ff 100%);
  background-repeat: no-repeat;
  background-size: 100% 0.5vw;
  background-position: bottom;
  width: fit-content;
  padding: 0.5vw 0;
  list-style: none;
  color: #4089b4;
  margin: 3vw auto;
}
.over-more:hover {
  opacity: 0.5;
}
details[open] .over-more {
  display: none;
}
#overview-logo {
  border-bottom: 1px solid #4089b4;
}
.over-logo_container {
  margin: 5vh auto;
  padding: 5vw;

  & h4 {
    color: #244e7d;
  }
}
.over-logo_group {
  margin: 1vw auto;
  width: 70%;
  color: #244e7d;
  text-align: justify;

  & img {
    width: 25%;
    margin: 5vw auto;
    display: block;
  }
}
#overview-message {
  color: #244e7d;
  text-align: justify;
}
.over-message {
  display: flex;
  justify-content: space-around;
  margin: 7vw auto 5vw;

  .over-message_img {
    width: 40%;
    background: linear-gradient(90deg, #daf2cc 0%, #edd9ff 100%);
    background-repeat: no-repeat;
    background-size: 100% 11vw;
    background-position: bottom;
    padding-bottom: 1vw;

    & img {
      width: 50%;
      margin: 0 auto;
      display: block;
    }
    & p {
      font-size: 1rem;
      margin: 1vw 4vw;
    }
    & span {
      font-size: 1.4rem;
      padding-left: 1vw;
    }
  }
  & p {
    font-size: 2rem;
  }
}
#overview-history {
  background: linear-gradient(90deg, #daf2cc 0%, #edd9ff 100%);
  background-repeat: no-repeat;
  background-size: 100% 0.5vw;
  background-position: bottom;
}
.enkaku-container {
  border-top: 1px solid #4089b4;
  border-bottom: 1px solid #4089b4;
  padding: 5vw 0;
}
.enkaku-group {
  display: flex;
  gap: 4vw;
  margin: 5vw auto;

  .enkaku-img {
    width: 35%;
  }
  & table {
    color: #244e7d;

    & tr {
      vertical-align: top;
    }
    & td:nth-child(1) {
      width: 19%;
      font-family: "TazuganeGothicStdN-Bold";
    }
  }
}
#overview-kyotei {
  padding-top: 7vw;
}
.kyotei-group {
  color: #244e7d;
  margin: 5vw auto 15vw;

  & table {
    width: 80%;
    margin: 0 auto;
  }
  & tr {
    vertical-align: top;
  }
  & td:nth-child(1) {
    width: 18%;
    font-family: "TazuganeGothicStdN-Bold";
  }
  & a {
    color: #4089b4;
  }
}
.overview-bottom_file {
  margin: 5vw auto;
  width: 70%;
  padding: 0;

  & p {
    color: #244e7d;
    margin: 0.5vw 0;
  }
  & h3 {
    color: #4089b4;
    font-size: 1.2rem;
  }
  & h4 {
    color: #4089b4;
    margin: 1vw 0;
  }
  .file-dl {
    margin: 1vw 0;
  }
  .over-more {
    margin: 1vw auto;
  }
}
#overview-access {
  margin: 5vw auto;
  color: #244e7d;

  & h4 {
    background: linear-gradient(90deg, #daf2cc 0%, #edd9ff 100%);
    background-repeat: no-repeat;
    background-size: 100%;
    width: fit-content;
    padding: 0.5vw 1vw;
  }
  & a {
    color: #4089b4;
  }
}
.map {
  width: 60%;
  margin: 5vw auto;
}
.over-access_group {
  margin: 5vw auto;
  width: 80%;

  & table {
    width: 80%;
    margin: 3vw auto;
    border-collapse: collapse;

    & th {
      background-color: #dae4e4;
      padding: 1vw;
    }
    & td {
      border-bottom: 1px solid #666699;
      width: 50%;
      padding: 2vw 1vw;
      vertical-align: top;

      & a {
        margin-bottom: 1vw;
        display: block;
      }
    }
    & td:nth-child(1),
    th:nth-child(1) {
      border-right: 1px solid #666699;
    }
  }
}
.overview-video {
  margin: 5vw auto;
  width: 100%;
  height: 100%;
  overflow: hidden;
  text-align: center;
}
.overview-video video {
  height: auto;
}

/*理事長ブログ*/
.blog-top img {
  width: 100%;
}
.blog-nav {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #4089b4;

  & a {
    width: 20%;
  }
}

.blog-item {
  max-width: 900px;
  margin: 3vw auto;
  border-bottom: 0.1vw solid #5b31b6;
  padding: 1vw 0;
  font-size: 1rem;

  .blog-text {
    display: flex;
    justify-content: space-between;
  }
  & h3 {
    color: #244e7d;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 1vw;
    font-size: 1.3rem;

    .new_mark {
      font-size: 0.7rem;
    }
  }
  .date {
    color: #4089b4;
  }
  & p {
    color: #244e7d;
  }
}
.blog-more {
  display: flex;
  justify-content: right;
  align-items: center;
  gap: 1vw;
}
.blog-more::after {
  content: "";
  display: block;
  background-image: url(../img/arrow-r.svg);
  background-repeat: no-repeat;
  width: 0.7vw;
  height: 0.7vw;
}
.new_mark {
  color: #dc7799;
  font-size: 1rem;
  display: block;
}
.blog-p-top {
  & img {
    width: 100%;
  }
  & h1 {
    margin: 0;
  }
}
.blog-container {
  padding: 2vw 5vw;
  margin: 0 auto;
  max-width: 1000px;
  border-bottom: 1px solid #5b31b6;
  font-feature-settings: normal;

  & h3 {
    color: #4089b4;
  }
}
.blog-ttl {
  display: flex;
  align-items: center;
  gap: 1vw;
}
.blog-p-ttl {
  display: flex;
  align-items: center;
  gap: 1vw;

  & h2 {
    font-size: 2rem;
    color: #244e7d;
    margin: 0;
  }
}
.blog-vol {
  font-size: 1.2rem;
  color: #244e7d;
  margin: 0;
}
.blog-date {
  color: #6baed1;
  text-align: right;
  font-size: 0.8rem;
}
.pagination-single {
  margin: 1vw auto;
  padding: 2vw 0vw;
  max-width: 1000px;
  display: flex;
  justify-content: right;
  gap: 2vw;

  & p {
    margin: 0;
  }
  & a {
    color: #244e7d;
    display: flex;
    align-items: center;
    gap: 1vw;
    margin: 0;
  }
  .page-next a::after {
    content: "";
    display: block;
    background-image: url(../img/arrow-r.svg);
    background-repeat: no-repeat;
    width: 0.7vw;
    height: 0.7vw;
  }
  .page-prev a::before {
    content: "";
    display: block;
    background-image: url(../img/arrow-l.svg);
    background-repeat: no-repeat;
    width: 0.7vw;
    height: 0.7vw;
  }
}
.blog-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #244e7d;

  & a {
    color: #244e7d;
    display: flex;
    align-items: center;
    gap: 1vw;
    font-size: 1rem;
    padding: 1vw;
    overflow-wrap: anywhere;
    justify-content: center;
  }
  & p {
    margin: 0;
    width: 10vw;
  }
  .blog-pagination-prev a::before {
    content: "";
    display: block;
    background-image: url(../img/arrow-l.svg);
    background-repeat: no-repeat;
    width: 0.7vw;
    height: 0.7vw;
  }
  .blog-pagination-next a::after {
    content: "";
    display: block;
    background-image: url(../img/arrow-r.svg);
    background-repeat: no-repeat;
    width: 0.7vw;
    height: 0.7vw;
  }
}

nav.bread {
  margin: 1vh auto 0;
  font-size: 14px;
}

/*SPサイズ*/
@media screen and (max-width: 767px) {
  .page-up {
    padding: 2vw;
  }
  #news-cate .custom-ttl,
  #news-all .custom-ttl {
    margin-top: 64px;
    padding: 0;
    height: 72px;
  }

  #news-cate .custom-ttl h1,
  #news-all .custom-ttl h1 {
    font-size: 1.3rem;
  }

  .custom-p {
    /*margin-top: 8vh;*/
  }
  .bread ol {
    font-size: 0.8rem;
    margin: 1vw auto;
    padding-inline-start: 6px;
    max-width: 95vw;
    padding-right: 3vw;
    flex-wrap: wrap;
  }
  .categories_content {
    padding: 1vh 2vw;
  }
  .categories_list li a {
    padding: 1vw;
    font-size: 0.9rem;
  }
  .categories_list {
    justify-content: space-around;
  }
  .pagination {
    margin: 5vw auto;
  }
  .pagination ul {
    gap: 6px;
  }

  .pagination li a,
  .pagination li span {
    padding: 4px;
    width: 6vw;
  }
  .single-group {
    padding: 4vw 2vw 10vw;
  }
  .single-ttl {
    font-size: 1.2rem;
    margin: 4vw 0;
    /*		padding: 0 2vw;*/
  }
  .single-date {
    font-size: 0.7rem;
    /*		padding: 0 2vw;*/
  }
  .single-text {
    margin: 5vw 0;
    line-height: 1.5rem;
    font-size: 0.9rem;
    padding: 0 2vw;
  }
  #webShareApi {
    width: 15%;
  }
  .news-backbtn {
    padding: 1.5vw 2.5vw 1.5vw 2vw;
    margin: 0 5vw;
    font-size: 1.1rem;
  }
  .news-backbtn_text::before {
    width: 3vw;
    height: 3vw;
  }

  .vision-top_catch {
    background-image: url("../img/vision/vision-top_catchsp.jpg");
    width: 100%;
    height: 105vh;
  }
  .vision-top_text {
    top: 12%;
    left: 6%;

    & h1 {
      font-size: 4rem;
      line-height: 6rem;
      letter-spacing: 0.1rem;
    }
    & p {
      font-size: 1.2rem;
      margin-right: -4px;
      margin-left: -8px;
    }
  }
  .vision-top_svg {
    width: 36%;
    bottom: 2%;
    right: 2%;
  }
  .bread-container {
    padding: 2vw 5vw 1vw;
  }
  .vision-top-copy {
    & h2 {
      font-size: 2rem;
      line-height: 3rem;
    }
    & p {
      font-size: 1.5rem;
      margin-bottom: 1vw;
    }
  }
  .vision-top-copy2 {
    font-size: 1.3rem;
    margin: 0 auto;

    & p {
      margin: 5vw auto;
      width: fit-content;
    }
  }
  #vision-top {
    margin-bottom: 25vh;
  }
  #seiryo-vision {
    margin: 30vh 0;
  }
  .vision-ttl img {
    width: 59%;
    transform: translate(-47vw, -31vw);
  }
  .vision-ttl h2 {
    margin: 0;
    font-size: 1.8rem;
  }
  .grade-back01 {
    font-size: 1.3rem;

    .grade-p1 {
      color: #fff;
      font-size: 1.6rem;
      margin: 3vw 0;
    }
    .container {
      padding: 2vw 0 9vw;
    }
  }
  .grade-back03 {
    background-size: contain;
  }
  .img-on01 {
    width: 38%;
  }
  .img-on02 {
    width: 38%;
  }
  .vision-sis {
    margin: 15vw auto;

    & img {
      width: 100%;
    }
    .vision-sis_text {
      margin: 10vw auto;
      font-size: 1.5rem;
    }
  }
  .vision-sis_btn {
    margin: 8vw auto;
  }
  .vision-sis_btn a {
    width: 73%;
    padding: 3vw;

    & span {
      width: 5vw;
    }
    & p {
      padding-left: 3vw;
      font-size: 0.8rem;
    }
  }
  #vision-todo {
    margin: 25vh 0;

    .vision-ttl img {
      width: 42%;
      transform: translate(-47vw, -20vw);
    }
  }
  .grade-back02 {
    font-size: 1.1rem;
    padding: 7vw 5vw;

    & p {
      margin: 6vw 0;
    }
  }
  .todoplan {
    margin: 7vh auto;
    width: 90%;

    .todo-no {
      top: -4%;
      left: 12%;
    }
    & img {
      width: 84%;
    }
    .orange-line {
      font-size: 1.1rem;
      margin: 3vw auto;
      line-height: 1.2rem;
    }
  }
  .todo-text {
    transform: translateY(-7vw);

    & h3 {
      font-size: 2rem;
    }
    & p {
      font-size: 1.7rem;
      line-height: 2rem;
    }
  }
  .todo-text02 {
    transform: translateY(-5vw);
    margin: 2vw auto;
  }
  #vision-promise {
    margin-bottom: 20vh;

    .vision-ttl {
      padding: 0 6vw;

      & h2 {
        font-size: 1.4rem;
      }
      & img {
        width: 46%;
        transform: translate(-1vw, -26vw);
      }
    }
  }
  .grade-back04 {
    padding: 4vw 0 4vw;

    .promise-text {
      color: #244e7d;
      font-size: 1.2rem;
      letter-spacing: 0.1rem;
      line-height: 2rem;
      text-align: justify;
    }
  }
  .promise-text span {
    color: #4089b4;
  }
  .promise-group {
    margin: 8vw 0;

    & h3 {
      font-size: 1rem;
      transform: translateY(-4vw);
    }
    .promise-ttl {
      height: 2vw;
    }
    .container {
      padding: 4vw 10vw;
    }
    & p {
      font-size: 1.1rem;
      margin-top: 4vw;
      text-align: justify;
    }
  }
  .promise-ttl::after {
    height: 2vw;
  }
  #vision-universal {
    margin: 6vw 0 11vh;

    .vision-ttl img {
      transform: translate(-47vw, -20vw);
      width: 60%;
    }
    .grade-back01 {
      font-size: 1.2rem;
      padding: 7vw;

      & p {
        margin: 5vw 0;
      }
    }
  }
  .univ-mission {
    margin: 11vw auto;

    & h2 {
      font-size: 2.2rem;
      margin: 2vw;
      font-style: italic;
    }
    & img {
      width: 90%;
      margin: 4vw auto;
    }
    & p {
      margin: 7vw 0;
    }
  }
  .univ-img {
    .univ-img_text {
      width: 57%;
      top: 27%;
    }
    .univ-img1 {
      transform: translate(32%, 0%);
      width: 80%;
    }
    .univ-img2 {
      transform: translate(-7%, 25%);
      width: 80%;
    }
  }

  .koukai-taxo {
    margin-top: 10vh;
  }
  .koukai-container {
    padding: 5vw 0;
  }
  .koukai-group {
    margin: 7vw auto;
    width: 90%;

    & h2 {
      font-size: 1rem;
    }
    & a {
      padding: 0.5vw 0vw 0.5vw 4vw;
      margin: 8vw 0;
    }
    summary:hover {
      color: #244e7d;
      opacity: 1;
    }
  }
  .koukai-file_container {
    margin: 7vw auto;
    width: 80%;
    padding-bottom: 8vw;

    & h2 {
      font-size: 1rem;
      margin: 0 0;
    }
  }
  .file-dl {
    margin: 7vw auto;

    & h3 {
      font-size: 0.9rem;
      margin: 0.5vw;
    }
    & span {
      width: 4vw;
      padding-left: 2vw;
    }
    & img {
      width: 4vw;
    }
  }
  .koukai-file-group {
    margin: 7vw auto;

    & h3 {
      font-size: 0.9rem;
      margin: 0.5vw;
    }
    & span {
      width: 4vw;
      padding-left: 2vw;
    }
    & img {
      width: 4vw;
    }

    .koukai-text p {
      font-size: 0.9rem;
      margin: 0.5vw;
      letter-spacing: 0.1rem;
    }
  }
  .go-more-btn {
    margin: 8vw auto 10vw;
  }
  .buttonIconText02 {
    width: 25%;
    min-width: 20%;
    padding: 1.5vw 2.5vw 1.5vw 2vw;
    font-size: 1.1rem;
    justify-content: center;
  }
  .buttonIconText02_text {
    width: 55%;
    padding-top: 1vw;
  }
  .buttonIconText02_icon {
    width: 4vw;
  }

  .contact-top_catch {
    height: 40vh;
    margin-top: 10vh;

    & h1 {
      font-size: 1.5rem;
    }
  }
  .contact-p {
    width: 90%;
    margin: 7vw auto;
    font-size: 1rem;

    & span {
      font-size: 0.8rem;
    }
  }
  .contact-point {
    font-size: 1rem;
  }
  .contact-container {
    width: 90%;
    margin: 6vh auto 8vh;

    & table {
      font-size: 0.9rem;
    }
    & span {
      font-size: 0.8rem;
    }
    & td {
      padding: 4vw 2vw;
    }
    .contact-date {
      & span {
        font-size: 0.9rem;
      }
    }
  }
  .contact-date p {
    margin: 1vw auto;
  }

  .edu-top_catch {
    height: 11vh;
    margin-top: 8vh;

    .edu-top_text {
      top: 47%;
    }
    & h1 {
      font-size: 1.5rem;
    }
  }
  .edu-container {
    width: 100%;

    & h2 {
      margin: 4vw auto;
      font-size: 1.5rem;
    }
  }
  .edu-text {
    padding: 5vw;
    line-height: 1.7rem;

    & a {
      gap: 3vw;
    }
    & a::after {
      width: 3vw;
      height: 3vw;
    }
  }
  .edu-add {
    padding: 4vh 0 0 5vw;
  }
  .more-list {
    padding: 0 5vw;

    .file-dl {
      width: 90%;
    }
  }

  .overview {
    padding-top: 15vw;
  }
  #overview-kengaku {
    padding: 5vw 2vw 8vw;
  }
  .kengaku-container {
    padding: 6vw 5vw;
    width: 85%;

    .kengaku-img {
      width: 60%;
    }
    .kengaku-text {
      width: 90%;
    }
  }
  .over-more {
    margin: 4vh auto;
  }
  .over-logo_container {
    margin: 3vw auto;
  }
  .over-logo_group {
    margin: 10vw auto;
    width: 100%;

    & img {
      width: 40%;
      margin: 10vw auto;
    }
  }
  .over-message {
    display: block;

    .over-message_img {
      width: 100%;
      background-size: 100% 31vw;
      padding-bottom: 2vw;

      & img {
        width: 55%;
        margin: 4vw;
        margin-left: auto;
      }
    }
    & p {
      font-size: 1.5rem;
    }
  }
  .enkaku-group {
    display: block;

    & table {
      margin: 7vw auto;

      & td:nth-child(1) {
        width: 34%;
        text-align: justify;
      }
    }
    .enkaku-img {
      width: 100%;
    }
  }
  .enkaku-container {
    padding: 9vw 0;
    margin-bottom: 14vw;
  }
  .kyotei-group {
    display: block;
    font-size: 1.1rem;

    & table {
      width: 100%;
    }
    & td:nth-child(1) {
      width: 33%;
      text-align: justify;
    }
    & td:nth-child(2) {
      overflow-wrap: anywhere;
    }
  }
  .overview-bottom_file {
    margin: 5vw auto;
    width: 90%;

    & p {
      margin: 0;
    }
    .file-dl {
      margin: 0 auto 7vw;
    }
    & h4 {
      font-size: 0.9rem;
    }
    & h3 {
      font-size: 1rem;
    }
  }
  .map {
    width: 100%;
    margin: 10vw auto;

    & iframe {
      height: 33vh;
    }
  }
  .over-access_group {
    margin: 10vw auto;
    width: 100%;

    & table {
      width: 100%;
      margin: 9vw auto;

      & th {
        padding: 2vw 1vw 0.5vw;
      }
      & td {
        font-size: 1rem;
        padding-left: 3vw;
      }
    }
    & p {
      margin: 1vw 0;
    }
  }
  #overview-access {
    letter-spacing: 0.05rem;

    & h4 {
      padding: 1.5vw 2vw 0.5vw;
      margin-bottom: 3vw;
    }
  }
  .hosoku {
    padding-top: 3vw;
  }
  .overview-video {
    margin: 10vh auto;
  }
  .overview-video video {
    width: 100%;
  }

  .blog-top h1 {
    margin: 0;
  }
  .blog-item {
    padding: 5vw 5vw;

    .date {
      font-size: 0.8rem;
    }
    & h3 {
      align-items: flex-start;
      font-size: 1.1rem;
    }
  }
  .blog-container {
    padding: 5vw 2vw;
    margin: 0 4vw;

    & h3 {
      font-size: 1.1rem;
    }
  }
  .blog-ttl {
    display: block;
  }
  .blog-p-ttl {
    & h2 {
      font-size: 1.3rem;
    }
  }
  .blog-vol {
    font-size: 1rem;
  }
  .blog-more {
    gap: 2vw;
    margin: 0;
  }
  .blog-more::after {
    width: 3vw;
    height: 3vw;
  }
  .blog-pagination {
    margin: 5vw auto;

    & p {
      width: 23vw;
    }
    .blog-pagination-prev a::before {
      width: 3vw;
      height: 3vw;
    }
    .blog-pagination-next a::after {
      width: 3vw;
      height: 3vw;
    }
  }
  .blog-btn {
    margin: 8vw auto;
    text-align: center;

    & img {
      width: 60%;
    }
  }
  .pagination-single {
    margin: 4vw auto;
    justify-content: center;
    gap: 10vh;

    .page-next a::after {
      width: 3vw;
      height: 3vw;
    }
    .page-prev a::before {
      width: 3vw;
      height: 3vw;
    }
  }

  nav.bread {
    margin: 0vh auto 0;
  }
  #news-single .custom-ttl {
  margin: 66px auto 0;
  height: 70px;
  }
  .education {
    margin: 2vh 0 15vh;
  }
}
/* タブレット */
@media screen and (min-width: 767px) and (max-width: 1280px) {
  .vision-sis_btn a {
    width: 45%;

    & span {
      width: 3vw;
    }
  }
}
