@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 10px;
  font-weight: 400;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
  font-size: 10px;
}
@media screen and (max-width: 350px) {
  body {
    /*　画面サイズが1024pxからはここを読み込む　*/
    font-size: 8rem;
  }
}

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

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
  appearance: none;
}

a:hover {
  color: #555555 !important;
}

@font-face {
  font-family: "Marion";
  src: url(../../fonts/marion-regular.ttf);
}
html {
  font-size: 0.859231vw;
}
@media screen and (min-width: 1200px) {
  html {
    font-size: 10px;
  }
}
@media screen and (max-width: 756px) {
  html {
    font-size: 2.6666666667vw;
  }
}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media screen and (max-width: 756px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}
body {
  min-width: auto;
  margin: 0 auto;
  font-size: 1.6rem;
  color: rgb(0, 0, 0);
  background-color: white;
}
@media screen and (max-width: 756px) {
  body {
    overflow-x: hidden;
  }
}

.Inner {
  max-width: 1200px;
  min-width: auto;
  margin: 0 auto;
}
@media screen and (max-width: 756px) {
  .Inner {
    padding: 0 1.5rem;
  }
}
.Inner--min {
  max-width: 980px;
}
@media screen and (max-width: 756px) {
  .Inner--min {
    max-width: 100%;
    padding: 0;
  }
}

.PageUp {
  padding-top: 15rem;
}
@media screen and (max-width: 756px) {
  .PageUp {
    padding-top: 11rem;
  }
}

/* ====== Zen / Poppins のショートネーム ====== */
/* 1行指定用 mixin */
/* すぐ使えるユーティリティ */
/*（任意）Poppinsの全ウェイトを自動生成したい場合 */
.pop-100 {
  font-family: "Poppins", sans-serif;
  font-weight: 100;
  font-style: normal;
}

.pop-100-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 100;
  font-style: italic;
}

.pop-200 {
  font-family: "Poppins", sans-serif;
  font-weight: 200;
  font-style: normal;
}

.pop-200-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 200;
  font-style: italic;
}

.pop-300 {
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.pop-300-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-style: italic;
}

.pop-400 {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.pop-400-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: italic;
}

.pop-500 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.pop-500-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: italic;
}

.pop-600 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
}

.pop-600-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: italic;
}

.pop-700 {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.pop-700-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.pop-800 {
  font-family: "Poppins", sans-serif;
  font-weight: 800;
  font-style: normal;
}

.pop-800-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 800;
  font-style: italic;
}

.pop-900 {
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  font-style: normal;
}

.pop-900-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  font-style: italic;
}

/* 例 */
e body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-family: "Zen Kaku Gothic New", sans-serif !important;
}

a {
  text-decoration: none;
}

.single-page {
  margin-top: 16rem;
}
.single-page .Inner {
  max-width: 96rem;
}
@media screen and (max-width: 756px) {
  .single-page {
    margin-top: 8rem;
  }
}
.single-page .News__container__right {
  width: calc(100% - 1rem);
}

.Archive__title {
  font-size: 4rem;
  font-weight: 400;
}

.Footer__dis {
  text-align: center;
}

.Pager {
  margin: 5rem auto;
  width: fit-content;
  height: fit-content;
}
.Pager .pagination .prev {
  color: white;
  background-color: #080808;
  line-height: 1rem;
  text-align: center;
  padding: 2rem;
  font-size: 1.8rem;
  margin-right: 0.5rem;
  margin-left: 0.5rem;
  border-radius: 100%;
  display: inline-flex;
}
@media screen and (max-width: 756px) {
  .Pager .pagination .prev {
    padding: 1.2rem;
    font-size: 1.5rem;
    margin-left: 0.1rem;
    margin-right: 0.1rem;
  }
}
.Pager .pagination .next {
  color: white;
  background-color: #080808;
  line-height: 1rem;
  text-align: center;
  padding: 2rem;
  margin-right: 0.5rem;
  margin-left: 0.5rem;
  font-size: 1.8rem;
  border-radius: 100%;
  display: inline-flex;
}
@media screen and (max-width: 756px) {
  .Pager .pagination .next {
    padding: 1.2rem;
    font-size: 1.5rem;
    margin-left: 0.1rem;
    margin-right: 0.1rem;
  }
}
.Pager .pagination .pager {
  color: white;
  background-color: #080808;
  line-height: 1rem;
  text-align: center;
  padding: 2rem;
  margin-right: 0.5rem;
  font-size: 1.8rem;
  margin-left: 0.5rem;
  border-radius: 100%;
  display: inline-flex;
}
@media screen and (max-width: 756px) {
  .Pager .pagination .pager {
    padding: 1.2rem;
    font-size: 1.5rem;
    margin-left: 0.1rem;
    margin-right: 0.1rem;
  }
}

.tag {
  font-size: 1.6rem;
  color: #5A5A5A;
}
@media screen and (max-width: 756px) {
  .tag {
    font-size: 1.8rem;
  }
}

.Spage {
  margin-top: 16rem;
}

.wp-block-embed :where(figcaption) {
  margin-bottom: 1em;
  font-size: 1.6rem;
  margin-top: 0.5em;
}

/*========= ナビゲーションのためのCSS ===============*/
#g-nav {
  /*position:fixed;にし、z-indexの数値を小さくして最背面へ*/
  position: fixed;
  z-index: -1;
  opacity: 0; /*はじめは透過0*/
  /*ナビの位置と形状*/
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh; /*ナビの高さ*/
  background: #000; /* 背景色 */
  /*動き*/
  transition: all 0.2s;
}
@media screen and (max-width: 756px) {
  #g-nav {
    background-color: rgba(47, 47, 47, 0.6);
  }
}

/*アクティブクラスがついたら透過なしにして最前面へ*/
#g-nav.panelactive {
  opacity: 1;
  z-index: 999;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list {
  /*ナビの数が増えた場合縦スクロール*/
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100vh; /*表示する高さ*/
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
  position: relative;
  /*ナビゲーション天地中央揃え*/
  z-index: 999;
  top: 0rem;
  background-color: #fff;
  height: 100%;
  width: 100%;
  box-sizing: border-box;
}
#g-nav ul .page-link_cv {
  display: flex;
  justify-content: space-between;
  max-width: 97rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 756px) {
  #g-nav ul .page-link_cv {
    flex-direction: column;
    margin-top: 2rem;
  }
}
#g-nav ul .page-link_cv__item {
  background: #fff;
  display: block;
  text-decoration: none;
  text-align: center;
  transition: all 300ms;
}
@media screen and (max-width: 756px) {
  #g-nav ul .page-link_cv__item {
    margin-bottom: 1rem;
    height: fit-content;
    padding: 2rem 0;
    width: 100%;
  }
}
#g-nav ul .page-link_cv__item:hover {
  opacity: 0.6;
  transition: all 300ms;
}
#g-nav ul .page-link_cv__item span {
  letter-spacing: 0.04rem;
}
#g-nav ul .page-link_cv__item--tel {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background-color: #0A345D;
}
#g-nav ul .page-link_cv__item--tel .num {
  font-family: "Oswald", "Arial", "Helvetica", sans-serif;
  font-size: 3.1rem;
  line-height: 3.1rem;
  line-height: 4rem;
  letter-spacing: 0.04rem;
  color: #fff;
  border-bottom: 1px solid #fff;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 3rem;
  text-align: center;
  position: relative;
}
#g-nav ul .page-link_cv__item--tel .num::before {
  content: "";
  display: block;
  position: absolute;
  top: 40%;
  left: 0px;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 4.6rem;
  background: url(../img/common/phone_icon.png) no-repeat center/contain;
}
#g-nav ul .page-link_cv__item--tel .time {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
  text-align: center;
  letter-spacing: 0.04rem;
}
#g-nav ul .page-link_cv__item--contact {
  background-color: #BAAA6D;
}
#g-nav ul .page-link_cv__item--contact span {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.04rem;
  color: #fff;
  line-height: 10rem;
  text-align: center;
}
@media screen and (max-width: 756px) {
  #g-nav ul .page-link_cv__item--contact span {
    line-height: 3rem;
  }
}
#g-nav ul .page-link_cv__item--line {
  background-color: #02C755;
}
#g-nav ul .page-link_cv__item--line span {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.04rem;
  color: #fff;
  line-height: 10rem;
  position: relative;
  padding-left: 4rem;
  text-align: center;
}
@media screen and (max-width: 756px) {
  #g-nav ul .page-link_cv__item--line span {
    line-height: 3rem;
  }
}
#g-nav ul .page-link_cv__item--line span::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  width: 2.8rem;
  height: 2.8rem;
  background: url(../img/common/line_icon_white.png) no-repeat center/contain;
}

/*リストのレイアウト設定*/
#g-nav li {
  list-style: none;
  text-align: center;
}

#g-nav li a {
  color: #2f2f2f;
  text-decoration: none;
  display: block;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 1.6rem;
  font-weight: 500;
  padding: 1.5rem 0;
  text-align: left;
}

/*========= ボタンのためのCSS ===============*/
.openbtn1 {
  position: fixed;
  z-index: 9999; /*ボタンを最前面に*/
  top: 1rem;
  right: 2rem;
  cursor: pointer;
  background-color: #0a345d;
  width: 3rem;
  height: 3rem;
}

/*×に変化*/
.openbtn1 span {
  display: inline-block;
  transition: all 0.4s;
  position: absolute;
  left: 0.8rem; /*  線の位置*/
  height: 1px; /*  線の太さ*/
  background-color: #fff; /* ボタンの色*/
  width: 1.4rem;
}

.openbtn1 span:nth-of-type(1) {
  top: 1.3rem;
}

.openbtn1 span:nth-of-type(2) {
  top: 1.8rem;
}

.openbtn1.active span:nth-of-type(1) {
  top: 0.9rem;
  left: 0.9rem;
  transform: translateY(6px) rotate(-45deg);
  width: 40%;
}

.openbtn1.active span:nth-of-type(2) {
  top: 2rem;
  left: 0.9rem;
  transform: translateY(-6px) rotate(45deg);
  width: 40%;
}

.Pager .Inner .pagination {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem 0;
}
.Pager .Inner .pagination a,
.Pager .Inner .pagination span {
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  font-family: "Shippori Mincho", "shippori-mincho", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 400;
  font-style: normal;
  height: 4rem;
  margin: 0 0.5rem;
  font-size: 2rem;
}
.Pager .Inner .pagination a.prev,
.Pager .Inner .pagination a.next {
  background: linear-gradient(to right, #728C96, #A1BAC4);
  color: #fff;
  font-size: 1.6rem;
  width: 6rem;
  font-family: "Shippori Mincho", "shippori-mincho", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 400;
  font-style: normal;
  text-decoration: none;
}
.Pager .Inner .pagination a.pager {
  background: #fff;
  box-shadow: 0px 3px 20px 0px rgba(0, 0, 0, 0.15);
  font-family: "Shippori Mincho", "shippori-mincho", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 400;
  font-style: normal;
  color: #333;
  text-decoration: none;
}
.Pager .Inner .pagination span.current.pager {
  background: #003A5B;
  color: #fff;
  font-family: "Shippori Mincho", "shippori-mincho", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 400;
  font-style: normal;
  border: none;
}

.Contact__btn {
  background: #C00000;
  border-radius: 3rem;
  padding: 0rem 2rem;
  cursor: pointer;
}
.Contact__btn a {
  font-size: 1.5rem;
  color: white !important;
}

.Contact__btn:hover {
  background: rgba(192, 0, 0, 0.7333333333);
}

.Btn {
  background-color: #2A2A30;
  position: relative;
  padding: 1.8rem 5rem;
  padding-right: 7rem;
  border-radius: 3rem;
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
}
@media screen and (max-width: 756px) {
  .Btn {
    padding: 1rem 5rem;
  }
}
.Btn:hover {
  background-color: rgba(42, 42, 48, 0.7803921569);
}
.Btn__txt span {
  font-size: 2rem;
  text-align: center;
  color: white;
}
@media screen and (max-width: 756px) {
  .Btn__txt span {
    font-size: 1.6rem;
    line-height: 2rem;
  }
}
.Btn::after {
  content: "";
  position: absolute;
  background: url(../img/btn-arrow.png) no-repeat center center/cover;
  top: 0.5rem;
  right: 0.4rem;
  width: 4.5rem;
  height: 4.5rem;
}
@media screen and (max-width: 756px) {
  .Btn::after {
    width: 3.1rem;
    height: 3.1rem;
  }
}

.Btn-blog {
  background-color: rgba(255, 255, 255, 0);
  border: solid 0.2rem #080808;
  position: relative;
  padding: 1.8rem 5rem;
  border-radius: 3rem;
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
}
.Btn-blog .text {
  color: #080808;
}

.Btn-category-active {
  background-color: #2A2A30;
}
.Btn-category-active .text {
  color: white;
}

.Professor__main__swipe {
  overflow: visible !important;
  margin-bottom: 7rem;
}
.Professor__main__swipe a {
  color: #080808;
}
.Professor__main__swipe .swiper-slide {
  object-fit: cover;
  border-radius: 4rem;
  overflow: visible !important;
}
.Professor__main__swipe .swiper-slide__profile {
  position: relative;
  aspect-ratio: 4/5;
  display: flex;
  align-items: center; /* 中央寄せ */
  justify-content: center;
}
.Professor__main__swipe .swiper-slide__profile .slide__profile__txt {
  position: absolute;
  bottom: 0;
  right: 0;
  color: white;
  background-color: rgba(255, 0, 0, 0.8352941176);
  padding: 1.3rem 3.8rem;
  font-size: 2.4rem;
  bottom: 0rem;
  border-radius: 0 0rem 2rem 0;
}
.Professor__main__swipe .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* トリミングしても枠いっぱいに収める */
  border-radius: 2rem;
}
@media (max-width: 480px) {
  .Professor__main__swipe .swiper-slide {
    aspect-ratio: 4/3;
  }
}

.swiper-button-next, .swiper-button-prev {
  color: rgba(255, 0, 0, 0.8352941176) !important;
}

.swiper-slide {
  object-fit: cover;
  border-radius: 4rem;
  overflow: visible !important;
}
.swiper-slide__profile {
  position: relative;
  aspect-ratio: 4/5;
  display: flex;
  align-items: center; /* 中央寄せ */
  justify-content: center;
}
.swiper-slide__profile .slide__profile__txt {
  position: absolute;
  bottom: 0;
  right: 0;
  color: white;
  background-color: rgba(255, 0, 0, 0.8352941176);
  padding: 1.3rem 3.8rem;
  font-size: 2.4rem;
  bottom: 0rem;
  border-radius: 0 0rem 2rem 0;
}
.swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* トリミングしても枠いっぱいに収める */
  border-radius: 2rem;
}

@media (max-width: 480px) {
  .swiper-slide {
    aspect-ratio: 4/3;
  }
}
.swiper-button-next, .swiper-button-prev {
  color: rgba(255, 0, 0, 0.8352941176) !important;
}

.Blog__main__swipe {
  overflow: visible !important;
  margin-bottom: 7rem;
}
.Blog__main__swipe .swiper-slide {
  object-fit: cover;
  border-radius: 4rem;
  overflow: visible !important;
}
.Blog__main__swipe .swiper-slide__profile {
  position: relative;
}
.Blog__main__swipe .swiper-slide__profile .slide__profile__txt {
  position: absolute;
  bottom: 0;
  right: 0;
  color: white;
  background-color: rgba(255, 0, 0, 0.8352941176);
  padding: 1.3rem 3.8rem;
  font-size: 2.4rem;
  bottom: 0.2rem;
  border-radius: 0 0rem 2rem 0;
}
.Blog__main__swipe .swiper-slide img {
  width: 100%;
  height: 100%;
  border-radius: 2rem;
}
@media (max-width: 480px) {
  .Blog__main__swipe .swiper-slide {
    aspect-ratio: 4/3;
  }
}

.swiper-button-next, .swiper-button-prev {
  color: rgba(255, 0, 0, 0.8352941176) !important;
}

.Title .Title__en {
  font-size: 7rem;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 756px) {
  .Title .Title__en {
    font-size: 5rem;
  }
}
.Title .Title__jp {
  font-size: 1.9rem;
  font-weight: 400;
  letter-spacing: 0.1rem;
}
@media screen and (max-width: 756px) {
  .Title .Title__jp {
    font-size: 1.4rem;
  }
}

.ttl {
  font-size: 4rem;
  font-weight: 550;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
@media screen and (max-width: 756px) {
  .ttl {
    font-size: 2.2rem;
    margin-bottom: 0.5rem;
  }
}

.txt {
  font-weight: 400;
  line-height: 1.7;
  font-size: 1.8rem;
}
@media screen and (max-width: 756px) {
  .txt {
    line-height: 1.5;
    font-size: 1.6rem;
  }
}

.TitleWrap {
  display: flex;
  align-items: center;
  gap: 5rem;
}
@media screen and (max-width: 756px) {
  .TitleWrap {
    display: block;
  }
}
@media screen and (max-width: 756px) {
  .TitleWrap .TitleWrap__left {
    margin-bottom: 1.5rem;
  }
}
.TitleWrap .TitleWrap__right span {
  font-size: 1.8rem;
  line-height: 1.5;
}
@media screen and (max-width: 756px) {
  .TitleWrap .TitleWrap__right span {
    font-size: 1.4rem;
    line-height: 1.3;
  }
}

.Page__ttl {
  padding-bottom: 4rem;
}
@media screen and (max-width: 756px) {
  .Page__ttl {
    padding-bottom: 0rem;
  }
}
.Page__ttl__ja {
  font-size: 5rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
@media screen and (max-width: 756px) {
  .Page__ttl__ja {
    font-size: 3rem;
    margin-bottom: 0.5rem;
  }
}
.Page__ttl__en {
  font-size: 1.9rem;
}
@media screen and (max-width: 756px) {
  .Page__ttl__en {
    font-size: 1.9rem;
  }
}

.Header {
  position: fixed;
  top: 0.5rem;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
  z-index: 100;
  width: 100%;
  margin: 1rem;
}
.Header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.Header__inner__nav {
  background: rgba(255, 255, 255, 0.4941176471);
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(4px);
  border: solid rgba(255, 255, 255, 0.5490196078) 0.1rem;
  border-radius: 10rem;
  align-items: center;
  justify-content: space-between;
  display: flex;
  padding-left: 2rem;
  padding-right: 2rem;
  margin-right: 3rem;
  height: 5rem;
}
@media screen and (max-width: 756px) {
  .Header__inner__nav {
    display: none;
  }
}
.Header__inner__nav a {
  gap: 0.5rem;
  text-decoration: none;
  color: #130000;
  font-size: 1.5rem;
  line-height: 3.4rem;
  display: flex;
  padding: 0 1.5rem;
  border-radius: 0.8rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.Header__inner__nav a svg {
  width: 2rem;
  height: 3.3rem;
}
.Header__logo {
  width: 4.9rem;
  height: 4.9rem;
  margin-left: 1.5rem;
}
@media screen and (max-width: 756px) {
  .Header__logo {
    width: 4rem;
    height: 4rem;
    margin-left: 0rem;
  }
}
.Header__logo a img {
  width: 100%;
  height: 100%;
}

#wpadminbar {
  display: none;
}

.Hum {
  display: flex;
  visibility: visible;
  cursor: pointer;
  position: fixed;
  width: fit-content;
  left: 27rem;
  width: 8.3rem;
  top: 2rem;
  justify-content: space-evenly;
  gap: 0.2rem;
  padding: 0.5rem;
  color: rgb(199, 41, 30);
  font-weight: 500;
  backdrop-filter: blur(12px);
  z-index: 100;
  background: rgb(255, 255, 255);
  border: solid 0.18rem rgb(199, 41, 30);
  border-radius: 2rem;
  filter: drop-shadow(0px 10px 20px rgba(0, 0, 0, 0.178));
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 1200px) {
  .Hum {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .Hum {
    display: none;
  }
}
.Hum span {
  font-size: 1.6rem;
  text-align: center;
  line-height: 2rem;
}
.Hum svg {
  width: 2rem;
  height: 2rem;
  fill: #be1106;
}

.hidden {
  opacity: 0;
  pointer-events: none; /* 非表示状態でクリックできないようにする */
}

.bar {
  position: fixed;
  width: 20rem;
  height: 16rem;
  text-align: left;
  border-radius: 2rem;
  z-index: 200;
  background: white;
  left: 15rem;
  top: 1rem;
  padding-left: 1rem;
  padding: 1rem;
  scroll-behavior: auto;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.15);
}
@media screen and (min-width: 1200px) {
  .bar {
    display: none;
  }
}
.bar__nav {
  position: relative;
  top: -2.5rem;
}
.bar__nav__item {
  padding-left: 2rem;
  margin-bottom: 1rem;
}
.bar__nav__item a {
  color: rgb(199, 41, 30);
  font-size: 2rem;
  font-weight: 590;
}
.bar__nav .Contact__btn a {
  display: inline-flex;
}
.bar__nav .Contact__btn a svg {
  width: 2rem;
  margin-right: 0.5rem;
}
.bar__nav .Contact__btn a span {
  font-size: 1.5rem;
  line-height: 3rem;
  margin-right: 0rem;
}

.close {
  display: none !important;
}
@media screen and (min-width: 1200px) {
  .close {
    display: none;
  }
}

.exit {
  text-align: center;
  color: #868686;
  font-weight: 500;
  backdrop-filter: blur(12px);
  z-index: 100;
  background: rgba(255, 255, 255, 0.691);
  border: solid 0.18rem #868686;
  font-size: 2rem;
  border-radius: 2rem;
  filter: drop-shadow(0px 10px 20px rgba(0, 0, 0, 0.178));
  width: 7rem;
  margin-left: 12rem;
  padding: 0.5rem;
}
.exit span {
  font-size: 1.6rem;
  text-align: center;
  line-height: 2rem;
}
@media screen and (min-width: 1200px) {
  .exit {
    display: none;
  }
}

.close {
  display: none;
}

.Header__inner__sp {
  display: none;
}
@media screen and (max-width: 756px) {
  .Header__inner__sp {
    display: block;
  }
}

.FV {
  position: relative;
  height: 100vh;
  background: url(../img/fv-bg.png) no-repeat center center/cover;
  object-fit: cover;
}
.FV::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  pointer-events: none;
}
.FV::after {
  content: "";
  position: absolute;
  background: url(../img/arrow.png) no-repeat center center/cover;
  height: 2.8rem;
  width: 2.9rem;
  left: 50%;
  bottom: 4rem;
  animation: bounce 1.5s infinite ease-in-out;
}
@media screen and (max-width: 756px) {
  .FV::after {
    left: 47%;
    bottom: 3rem;
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}
.FV__bg {
  height: 100%;
  object-fit: cover;
}
.FV__bottom {
  position: absolute;
  left: 5rem;
  bottom: 20%;
}
@media screen and (max-width: 756px) {
  .FV__bottom {
    left: 1rem;
    bottom: 15%;
  }
}
.FV__bottom__catch {
  font-size: 5.4rem;
  color: white;
  line-height: 1.3;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media screen and (max-width: 756px) {
  .FV__bottom__catch {
    font-size: 2.6rem;
  }
}
.FV__bottom__dis {
  font-size: 2rem;
  color: white;
  line-height: 1.5;
  margin-top: 1rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media screen and (max-width: 756px) {
  .FV__bottom__dis {
    font-size: 1.6rem;
    margin-top: 1.5rem;
  }
}

.About {
  background: #F7F7F7;
  padding: 8rem;
}
@media screen and (max-width: 756px) {
  .About {
    padding: 2.5rem;
  }
}
.About__inner {
  background-color: white;
  border-radius: 3rem;
  padding: 8rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 756px) {
  .About__inner {
    border-radius: 2rem;
    padding: 3rem 2rem;
    display: block;
  }
}
.About__right {
  position: relative;
  width: calc(55% - 1rem);
}
@media screen and (max-width: 756px) {
  .About__right {
    width: calc(100% - 1rem);
  }
}
.About__right img {
  position: absolute;
  width: 52rem;
  top: -3rem;
  transform: rotate(-4deg);
  left: -2rem;
}
@media screen and (max-width: 756px) {
  .About__right img {
    position: absolute;
    width: 18rem;
    top: -10.5rem;
    transform: rotate(3deg);
    left: 10rem;
  }
}
.About__right .ttl {
  padding-top: 30rem;
  line-height: 1.4;
}
@media screen and (max-width: 756px) {
  .About__right .ttl {
    padding-top: 2rem;
    line-height: 1.4;
  }
}
.About__right .Btn {
  margin-top: 3rem;
}
.About__left {
  width: calc(45% - 1rem);
}
@media screen and (max-width: 756px) {
  .About__left {
    width: calc(100% - 1rem);
  }
}
.About__left img {
  margin-top: 9rem;
  height: 36rem;
}
@media screen and (max-width: 756px) {
  .About__left img {
    margin-top: 2.5rem;
    height: 9rem;
  }
}

.Professor {
  padding: 10rem 0;
}
@media screen and (max-width: 756px) {
  .Professor {
    padding: 4.5rem 0;
  }
}
@media screen and (max-width: 756px) {
  .Professor .Btn-wrap {
    padding-top: 7rem;
  }
}
.Professor__profile {
  position: relative;
  padding-top: 1.5rem;
}
.Professor__profile__name {
  font-size: 4rem;
  font-weight: 400;
}
.Professor__profile__grade {
  font-size: 2.4rem;
  padding-left: 1rem;
}
.Professor__profile__en {
  position: absolute;
  bottom: -2.3rem;
  left: 0rem;
  font-size: 2.4rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
}
@media screen and (max-width: 756px) {
  .Professor__main__swipe {
    height: 41rem;
  }
}
.Professor .Title {
  padding-bottom: 8rem;
}
@media screen and (max-width: 756px) {
  .Professor .Title {
    padding-bottom: 4rem;
  }
}
.Professor .Btn-wrap {
  display: flex;
  justify-content: flex-end;
}
.Professor .Btn {
  width: fit-content;
  display: inline-flex;
}

.ProfessorIndex a {
  color: #080808;
}
.ProfessorIndex .ProfessorGrid {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 1rem;
}
.ProfessorIndex .ProfessorGrid .ProfCard {
  width: calc(25% - 1.5rem);
  padding-bottom: 4rem;
}
@media screen and (max-width: 756px) {
  .ProfessorIndex .ProfessorGrid .ProfCard {
    width: calc(50% - 1rem);
    padding-bottom: 4rem;
  }
}
@media screen and (max-width: 756px) {
  .ProfessorIndex .ProfessorGrid .ProfCard .slide__profile__txt {
    padding: 0.5rem 2rem;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 756px) {
  .ProfessorIndex .ProfessorGrid .ProfCard .Professor__profile__name {
    font-size: 2rem;
    /* font-weight: 400; */
  }
}
@media screen and (max-width: 756px) {
  .ProfessorIndex .ProfessorGrid .ProfCard .Professor__profile__en {
    bottom: -2.9rem;
    font-size: 1.9rem;
  }
}
.ProfessorIndex .ProfessorGrid .Professor__profile__en {
  bottom: -3.5rem;
}
.ProfessorIndex .ProfessorGrid .ProfCard__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2rem;
}

.Skill {
  padding: 8rem 0;
  padding-top: 0rem;
}
@media screen and (max-width: 756px) {
  .Skill {
    padding-top: 5rem;
  }
}
@media screen and (max-width: 756px) {
  .Skill .Title {
    margin-bottom: 4rem;
  }
}
.Skill__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 756px) {
  .Skill__container {
    display: block;
  }
}
.Skill__container__left {
  width: calc(50% - 4rem);
}
@media screen and (max-width: 756px) {
  .Skill__container__left {
    width: calc(100% - 1rem);
    margin-bottom: 3rem;
  }
}
.Skill__container__left img {
  width: 100%;
}
.Skill__container__right {
  width: calc(50% - 0rem);
}
.Skill__container__right .ttl {
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 756px) {
  .Skill__container__right {
    width: calc(100% - 1rem);
  }
}

.Blog a {
  color: #080808;
}
.Blog .Blog__main__swipe {
  margin-top: 5rem;
}
@media screen and (max-width: 756px) {
  .Blog .Blog__main__swipe {
    margin-top: 2rem;
  }
}
.Blog .Blog__article .wp-element-caption {
  font-size: 1.5rem;
  margin: 1rem 0;
}
.Blog .Blog__article .Blog__article__img {
  height: 28rem;
  object-fit: cover;
}
@media screen and (max-width: 756px) {
  .Blog .Blog__article .Blog__article__img {
    height: auto;
    min-height: 20rem;
  }
}
.Blog .Blog__article .Blog__article__img img {
  width: 100%;
  border-radius: 1.5rem;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.15);
  object-fit: cover;
}
@media screen and (max-width: 756px) {
  .Blog .Blog__article .Blog__article__img img {
    max-height: 20rem;
  }
}
.Blog .Blog__article .Blog__article__title {
  font-size: 2.3rem;
  margin-top: 1.5rem;
  line-height: 1.3;
  font-weight: 450;
}
@media screen and (max-width: 756px) {
  .Blog .Blog__article .Blog__article__title {
    font-size: 2rem;
  }
}
.Blog .Blog__article .Blog__article__title__tags {
  margin-top: 1rem;
  display: flex;
  gap: 1.5rem;
  list-style-type: none;
}
.Blog .Blog__article .Blog__article__title__tags .tag {
  font-size: 1.6rem;
  color: #5A5A5A;
}
@media screen and (max-width: 756px) {
  .Blog .Blog__article .Blog__article__title__tags .tag {
    font-size: 1.8rem;
  }
}
.Blog .Btn-wrap {
  margin-top: 8rem;
}
@media screen and (max-width: 756px) {
  .Blog .Btn-wrap {
    margin-top: 6rem;
  }
}

.Blog__article__img {
  object-fit: cover;
  margin-top: 2rem;
}
.Blog__article__img img {
  width: 100%;
  object-fit: cover;
}
.Blog__article__img__el {
  width: 100%;
  border-radius: 3rem;
}

.Blog__article__title {
  font-size: 2rem;
  margin-top: 1.5rem;
  line-height: 1.3;
  font-weight: 450;
}

.Blog__article__title__tags {
  margin-top: 1rem;
  display: flex;
  gap: 1.5rem;
  list-style-type: none;
}
.Blog__article__title__tags .tag {
  font-size: 2.4rem;
  color: #5A5A5A;
}

.single__head {
  margin-top: 1rem;
}
.single__head figure {
  margin-top: 5rem;
}
.single__head .Blog__article__img__el {
  border-radius: 3rem;
}
@media screen and (max-width: 756px) {
  .single__head .Blog__article__img__el {
    height: auto;
  }
}
.single__date {
  font-size: 1.5rem;
}
.single__cat {
  font-size: 1.5rem;
}
.single__title {
  margin-bottom: 1rem;
  font-size: 3.5rem;
}
@media screen and (max-width: 756px) {
  .single__title {
    margin-bottom: 2rem;
    font-size: 2rem;
    line-height: 2.5rem;
  }
}
.single__date {
  font-size: 2rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #8a8a8a;
}
.single__meta {
  margin-bottom: 1rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.single__content {
  margin-bottom: 5rem;
  margin-top: 5rem;
}
@media screen and (max-width: 756px) {
  .single__content {
    margin-bottom: 3rem;
    margin-top: 3rem;
  }
}
.single__content p {
  margin: 0.2rem 0;
  font-size: 1.5rem;
  line-height: 1.5;
  padding-bottom: 1.5rem 24px;
}
@media screen and (max-width: 756px) {
  .single__content p {
    font-size: 1.6rem;
  }
}
.single__content ul {
  margin-left: 2em;
}
.single__content li {
  margin: 1rem 0;
  font-size: 1.8rem;
  line-height: 1.3;
}
.single__content strong {
  margin: 0.8rem 0;
  font-size: 1.5rem;
  line-height: 1.3;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 600;
  font-style: normal;
}
@media screen and (max-width: 756px) {
  .single__content strong {
    font-size: 1.6rem;
  }
}
.single__content h4 strong span {
  text-decoration: underline;
  font-size: 1.8rem;
}
.single__content h2 {
  font-size: 2.2rem;
  margin: 1.5rem 0;
  margin-top: 10rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media screen and (max-width: 756px) {
  .single__content h2 {
    font-size: 2rem;
    margin: 1rem 0;
    margin-top: 4rem;
  }
}
.single__content h2 strong {
  font-size: 2.2rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.single__footer {
  text-align: center;
}
.single__footer .Btn {
  margin: 3rem auto;
}
.single__pager {
  display: flex;
  justify-content: space-between;
}
.single__pager .prev a, .single__pager .next a {
  color: #080808;
  font-size: 1.5rem;
}
.single__tags {
  list-style-type: none;
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
}

article p {
  margin: 0.2rem 0;
  font-size: 1.8rem;
  line-height: 1.3;
}
article h2 {
  font-size: 2.5rem;
  margin: 2rem 0;
  margin-top: 4rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
article iframe {
  max-width: 100%;
  width: 100%;
  height: 50rem;
}
@media screen and (max-width: 756px) {
  article iframe {
    height: revert-layer;
  }
}
article h4 {
  font-size: 2rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  margin-bottom: 3rem;
  margin-top: 3rem;
}
@media screen and (max-width: 756px) {
  article h4 {
    margin-top: 3rem;
    margin-bottom: 1rem;
  }
}

.Page__works .Btn-wrap a {
  margin-right: 1rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 756px) {
  .Page__works .Btn-wrap a {
    padding: 0.8rem 3rem;
  }
}
.Page__works a {
  color: #080808;
}
.Page__works .Blog__article__img {
  object-fit: cover;
  border-radius: 2rem;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.15);
  height: 28rem;
  max-height: 22rem;
  overflow: hidden;
}
.Page__works__body__wrap {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 2.5rem;
}
.Page__works__body__wrap .Blog__article {
  width: calc(33.33% - 2.5rem);
}
@media screen and (max-width: 756px) {
  .Page__works__body__wrap .Blog__article {
    width: calc(100% - 0rem);
    height: fit-content;
  }
}
@media screen and (max-width: 756px) {
  .Page__works__body__wrap .Blog__article__title {
    font-size: 2rem;
  }
}
.Page__works__body__wrap .Blog__article__title__tags .tag {
  font-size: 1.6rem;
}
@media screen and (max-width: 756px) {
  .Page__works__body__wrap .Blog__article__title__tags .tag {
    font-size: 1.8rem;
  }
}

.wp-block-embed {
  font-size: 1.5rem;
}

cite > a {
  font-size: 1.6rem;
}

em {
  font-size: 1.6rem;
  margin: 2rem 0;
}

blockquote {
  border-left: solid 0.3rem;
  margin: 2rem 0;
  padding-left: 0.5rem;
}

.News__container {
  display: flex;
}
@media screen and (max-width: 756px) {
  .News__container {
    display: block;
  }
}
.News__container__left {
  width: calc(30% - 1rem);
}
@media screen and (max-width: 756px) {
  .News__container__left {
    width: calc(100% - 1rem);
  }
}
.News__container__left .Btn-wrap {
  margin-top: 4rem;
}
.News__container__right {
  width: calc(70% - 1rem);
  margin-top: 5rem;
}
.News__container__right a {
  text-decoration: none;
  color: black;
}
@media screen and (max-width: 756px) {
  .News__container__right {
    margin-top: 3rem;
    width: calc(100% - 1rem);
  }
}
.News__container__right .News__card {
  margin-bottom: 3rem;
  display: block;
  width: 100%;
  background-color: #ECFDFF;
  border: #91E7FF solid 0.1rem;
  padding: 0.3rem;
  border-radius: 0.6rem;
  min-height: 9rem;
}
@media screen and (max-width: 756px) {
  .News__container__right .News__card {
    margin-bottom: 2rem;
  }
}
.News__container__right .News__card__categori {
  color: #F2F2F2;
  background-color: rgba(42, 42, 48, 0.2745098039);
  border-radius: 0.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 2rem;
  padding: 0.25rem 1.5rem;
  font-size: 1.5rem;
  min-width: 7rem;
  width: fit-content;
}
.News__container__right .News__card__data {
  padding: 1.4rem;
}
.News__container__right .News__card__data .date {
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  margin-right: 2rem;
}
@media screen and (max-width: 756px) {
  .News__container__right .News__card__data .date {
    font-size: 1.4rem;
    margin-right: 0.5rem;
  }
}
.News__container__right .News__card__data .news__title {
  font-size: 1.6rem;
}
@media screen and (max-width: 756px) {
  .News__container__right .News__card__data .news__title {
    font-size: 1.4rem;
    line-height: 1.3;
  }
}