@charset "UTF-8";
/* CSS Document */
/* -------------------------------------------------

Reset.css

------------------------------------------------- */
@media print {
  html,
  body {
    zoom: 0.8;
  }
}
* {
  margin: 0;
  padding: 0;
  font-style: normal;
  font-weight: normal;
  line-height: 180%;
  box-sizing: border-box;
  list-style: none;
}

html {
  font-size: 62.5%;
}

body {
  color: #222;
}
body * {
  font-family: "Noto Serif JP", serif;
  font-size: 2rem;
  font-weight: 500;
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
}

a {
  color: #222;
  outline: none;
  text-decoration: none;
  transition: 0.3s;
}

a:hover img {
  transform: translateY(-5px);
}

a img {
  border-style: none;
  transition: 0.3s;
}

#wrapper img {
  width: 100%;
  vertical-align: middle;
}

/* media query */
@media screen {
  .fade__0 {
    opacity: 0;
    transition: 1s;
  }
  .fade__B {
    opacity: 0;
    transition: 1s;
    transform: translate(0, 30px);
  }
  .fade__L {
    opacity: 0;
    transition: 1s;
    transform: translate(-20px, 0);
  }
  .fadeReset {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@media all and (min-width: 669px) {
  .sp {
    display: none;
  }
}
@media all and (min-width: 801px) {
  .md {
    display: none;
  }
}
@media all and (min-width: 961px) {
  .tb {
    display: none;
  }
}
@media screen and (max-width: 960px) {
  .pc {
    display: none;
  }
}
@media screen and (max-width: 668px) {
  .ns {
    display: none;
  }
}
@media all and (max-width: 1200px) {
  .np {
    display: none;
  }
}
#wrapper {
  overflow: hidden;
}

header {
  background: url(../images/mainimg.jpg) no-repeat center/cover;
  height: 750px;
  padding: 100px 20px 0;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 960px) {
  header {
    display: block;
  }
}
@media screen and (max-width: 668px) {
  header {
    height: 600px;
  }
}
header > div {
  text-align: center;
  position: relative;
  padding: 0 100px;
}
@media all and (max-width: 1200px) {
  header > div {
    padding: 0;
  }
}
header > div p {
  color: #fff;
}
header > div p.year {
  font-size: 3rem;
  background-color: #222;
  display: inline-block;
  padding: 0 20px;
  margin-bottom: 10px;
}
@media screen and (max-width: 960px) {
  header > div p.year {
    font-size: 2rem;
  }
}
@media screen and (max-width: 668px) {
  header > div p.year {
    font-size: 1.7rem;
  }
}
header > div p.name {
  font-size: 3.5rem;
  margin-bottom: 20px;
}
@media screen and (max-width: 960px) {
  header > div p.name {
    font-size: 3rem;
  }
}
@media screen and (max-width: 668px) {
  header > div p.name {
    font-size: 2.3rem;
  }
}
header > div h1 {
  color: #fff;
  font-size: 8rem;
  line-height: 130%;
}
@media screen and (max-width: 960px) {
  header > div h1 {
    font-size: 6rem;
  }
}
@media screen and (max-width: 668px) {
  header > div h1 {
    font-size: 5rem;
  }
}
header > div > span {
  background-color: #F9FF56;
  position: absolute;
  top: 0;
  right: 0;
  border-radius: 50%;
  width: 122px;
  height: 122px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 960px) {
  header > div > span {
    width: 100px;
    height: 100px;
  }
}
@media screen and (max-width: 668px) {
  header > div > span {
    top: -70px;
  }
}
header > div > span > span {
  font-size: 2.7rem;
  line-height: 120%;
  transform: rotate(10deg);
}
@media screen and (max-width: 960px) {
  header > div > span > span {
    font-size: 2rem;
  }
}

main {
  padding: 80px 50px;
}
@media screen and (max-width: 960px) {
  main {
    padding: 70px 30px;
  }
}
@media screen and (max-width: 668px) {
  main {
    padding: 40px 20px;
  }
}
main .copyArea {
  border-bottom: 1px solid #222;
}
main .copyArea > p {
  font-size: 2.3rem;
  line-height: 250%;
  text-align: center;
  margin-bottom: 70px;
}
@media all and (max-width: 1200px) {
  main .copyArea > p {
    font-size: 2rem;
    line-height: 200%;
  }
}
@media screen and (max-width: 668px) {
  main .copyArea > p {
    font-size: 1.6rem;
    margin-bottom: 30px;
  }
}
main .titleArea {
  border-bottom: 1px solid #222;
  padding: 50px 0;
  text-align: center;
}
main .titleArea .about {
  font-size: 3rem;
}
@media screen and (max-width: 960px) {
  main .titleArea .about {
    font-size: 2.3rem;
  }
}
main .titleArea h2 {
  display: inline-block;
  font-size: 8.5rem;
  line-height: 120%;
  color: #fff;
  background-color: #222;
  padding: 20px 40px;
  margin: 30px 0;
}
@media all and (max-width: 1200px) {
  main .titleArea h2 {
    font-size: 6rem;
  }
}
@media screen and (max-width: 960px) {
  main .titleArea h2 {
    font-size: 4.5rem;
    padding: 20px;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  main .titleArea h2 {
    font-size: 4rem;
  }
}
main .titleArea ul {
  display: table;
  width: auto;
  margin: 0 auto 30px;
}
main .titleArea ul li {
  text-align: left;
  border-bottom: 1px solid #222;
  padding: 10px 0;
  font-size: 2.2rem;
}
@media screen and (max-width: 960px) {
  main .titleArea ul li {
    font-size: 1.7rem;
    line-height: 160%;
  }
}
main .titleArea ul li::before {
  content: "☑";
  margin-right: 8px;
}
main .titleArea .text {
  font-size: 2.5rem;
}
main .titleArea .text strong {
  font-size: 2.7rem;
  text-decoration: underline 2px wavy;
  text-underline-offset: 7px;
}
@media all and (max-width: 1200px) {
  main .titleArea .text strong {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 960px) {
  main .titleArea .text strong {
    font-size: 1.7rem;
    line-height: 220%;
  }
}
@media all and (max-width: 1200px) {
  main .titleArea .text {
    font-size: 2rem;
  }
}
@media screen and (max-width: 960px) {
  main .titleArea .text {
    font-size: 1.6rem;
  }
}
main .lecturerArea {
  padding: 50px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #222;
  flex-wrap: wrap;
}
@media all and (max-width: 1367px) {
  main .lecturerArea {
    padding: 50px 0;
  }
}
@media screen and (max-width: 960px) {
  main .lecturerArea {
    align-items: flex-start;
  }
}
main .lecturerArea > p {
  width: 23%;
}
@media all and (max-width: 1367px) {
  main .lecturerArea > p {
    width: 33%;
  }
}
@media screen and (max-width: 668px) {
  main .lecturerArea > p {
    width: 100%;
    margin-bottom: 20px;
  }
}
main .lecturerArea > div {
  width: calc(77% - 60px);
}
@media all and (max-width: 1367px) {
  main .lecturerArea > div {
    width: calc(67% - 40px);
  }
}
@media screen and (max-width: 668px) {
  main .lecturerArea > div {
    width: 100%;
  }
}
main .lecturerArea > div .tit {
  font-size: 2.2rem;
  letter-spacing: 15px;
  margin-bottom: 5px;
}
@media screen and (max-width: 668px) {
  main .lecturerArea > div .text {
    font-size: 1.6rem;
  }
}
main .lecturerArea > div > h4 {
  font-size: 5rem;
  line-height: 120%;
  margin-bottom: 10px;
}
@media all and (max-width: 1367px) {
  main .lecturerArea > div > h4 {
    font-size: 4.5rem;
  }
}
@media screen and (max-width: 960px) {
  main .lecturerArea > div > h4 {
    font-size: 4rem;
  }
}
@media screen and (max-width: 668px) {
  main .lecturerArea > div > h4 {
    font-size: 3.5rem;
  }
}
main .lecturerArea > div > dl {
  margin-top: 20px;
}
main .jizenArea {
  padding: 50px 40px;
  border-bottom: 1px solid #222;
}
@media all and (max-width: 1367px) {
  main .jizenArea {
    padding: 40px 0;
  }
}
main .jizenArea > h4 {
  letter-spacing: 15px;
  font-size: 2.5rem;
  margin-bottom: 20px;
}
main .jizenArea p.tit {
  font-size: 4rem;
  margin-bottom: 20px;
}
@media all and (max-width: 1367px) {
  main .jizenArea p.tit {
    font-size: 3.5rem;
  }
}
@media screen and (max-width: 960px) {
  main .jizenArea p.tit {
    font-size: 3rem;
  }
}
main .jizenArea p.tit small {
  font-size: 2rem;
}
main .jizenArea ol {
  margin-left: 20px;
  margin: 0 0 20px 30px;
}
main .jizenArea ol li {
  list-style: decimal;
}
main .jizenArea ol li {
  font-size: 2.6rem;
}
main .detailArea {
  display: flex;
  flex-wrap: wrap;
  padding: 40px 0;
  border-bottom: 1px solid #222;
}
@media screen and (max-width: 960px) {
  main .detailArea {
    padding: 0;
  }
}
main .detailArea > section {
  width: 50%;
  padding: 20px 40px;
}
@media screen and (max-width: 960px) {
  main .detailArea > section {
    width: 100%;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > section.subject {
    padding: 30px 0;
  }
}
main .detailArea > section.subject > section:not(:last-child) {
  margin-bottom: 30px;
}
main .detailArea > section.subject > section h5 {
  font-size: 4rem;
  line-height: 120%;
  margin-bottom: 10px;
}
@media all and (max-width: 1367px) {
  main .detailArea > section.subject > section h5 {
    font-size: 3.5rem;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > section.subject > section h5 {
    font-size: 3rem;
  }
}
main .detailArea > section.subject > section p {
  font-size: 1.8rem;
}
main .detailArea > section.subject > section p.notes {
  text-decoration: underline double;
  text-underline-offset: 5px;
}
main .detailArea > section > h4 {
  letter-spacing: 15px;
  font-size: 2.5rem;
  margin-bottom: 20px;
}
main .detailArea > div.schedule {
  width: 50%;
  padding: 20px 40px;
  border-right: 1px solid #222;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule {
    width: 100%;
  }
}
@media all and (max-width: 1367px) {
  main .detailArea > div.schedule {
    padding: 20px 20px 20px 0;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule {
    border-right: 0;
    border-bottom: 1px solid #222;
    padding: 30px 0;
  }
}
main .detailArea > div.schedule > section:first-child {
  width: 100% !important;
}
main .detailArea > div.schedule > section:not(:last-child) {
  margin-bottom: 30px;
  width: 50%;
}
main .detailArea > div.schedule > section > h4 {
  letter-spacing: 15px;
  font-size: 2.5rem;
  margin-bottom: 5px;
}
@media all and (max-width: 1200px) {
  main .detailArea > div.schedule > section table {
    display: block;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section table {
    display: table;
  }
}
@media screen and (max-width: 668px) {
  main .detailArea > div.schedule > section table {
    display: block;
  }
}
@media all and (max-width: 1200px) {
  main .detailArea > div.schedule > section table tr {
    display: flex;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section table tr {
    display: table-row-group;
  }
}
@media screen and (max-width: 668px) {
  main .detailArea > div.schedule > section table tr {
    display: block;
  }
}
main .detailArea > div.schedule > section table tr th,
main .detailArea > div.schedule > section table tr td {
  text-align: left;
  vertical-align: top;
  padding: 0 20px 20px 0;
  line-height: 150%;
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section table tr th,
  main .detailArea > div.schedule > section table tr td {
    font-size: 1.6rem;
  }
}
main .detailArea > div.schedule > section table tr th {
  white-space: nowrap;
}
@media all and (max-width: 1367px) {
  main .detailArea > div.schedule > section table tr th {
    padding-right: 0;
  }
}
@media all and (max-width: 1200px) {
  main .detailArea > div.schedule > section table tr th {
    display: block;
    width: 100%;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section table tr th {
    display: table-cell;
    width: auto;
  }
}
@media screen and (max-width: 668px) {
  main .detailArea > div.schedule > section table tr th {
    display: block;
    padding: 0 0 5px;
  }
}
main .detailArea > div.schedule > section table tr th strong {
  font-family: "EB Garamond", serif;
  font-size: 5rem;
  line-height: 100%;
}
@media all and (max-width: 1367px) {
  main .detailArea > div.schedule > section table tr th strong {
    font-size: 4rem;
  }
}
main .detailArea > div.schedule > section table tr td {
  padding-top: 15px;
}
@media all and (max-width: 1200px) {
  main .detailArea > div.schedule > section table tr td {
    padding-top: 5px;
    display: block;
  }
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section table tr td {
    padding-top: 15px;
    display: table-cell;
  }
}
@media screen and (max-width: 668px) {
  main .detailArea > div.schedule > section table tr td {
    display: block;
    padding: 0;
  }
}
main .detailArea > div.schedule > section ul li {
  font-size: 2rem;
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section ul li {
    font-size: 1.8rem;
  }
}
main .detailArea > div.schedule > section p {
  font-size: 2.5rem;
  line-height: 130%;
}
@media screen and (max-width: 960px) {
  main .detailArea > div.schedule > section p {
    font-size: 1.8rem;
  }
}
main .detailArea > div.schedule > section p small {
  font-size: 1.5rem;
}
main .contactArea {
  padding: 50px 0;
  display: flex;
  flex-wrap: wrap;
}
main .contactArea > section {
  width: calc(34% - 100px);
}
@media all and (max-width: 1367px) {
  main .contactArea > section {
    width: calc(34% - 60px);
  }
}
@media all and (max-width: 1200px) {
  main .contactArea > section {
    width: 100%;
    margin-bottom: 35px;
    text-align: center;
  }
}
main .contactArea > section > h3 {
  font-size: 4rem;
  margin-bottom: 50px;
}
@media all and (max-width: 1367px) {
  main .contactArea > section > h3 {
    margin-bottom: 30px;
  }
}
main .contactArea > section .name {
  margin-bottom: 25px;
}
main .contactArea > section .name small {
  font-size: 1.6rem;
  display: block;
}
main .contactArea > section address {
  margin-bottom: 30px;
}
main .contactArea > section address br {
  display: none;
}
@media all and (max-width: 1367px) {
  main .contactArea > section address br {
    display: block;
  }
}
@media all and (max-width: 1200px) {
  main .contactArea > section address br {
    display: none;
  }
}
main .contactArea > section .tel {
  font-family: "EB Garamond", serif;
  font-size: 3rem;
  line-height: 100%;
}
main .contactArea > section .tel a {
  font-size: 4.5rem;
  font-family: "EB Garamond", serif;
  line-height: 100%;
}
main .contactArea > a {
  width: 33%;
  display: flex;
  border-radius: 50px;
  align-items: center;
  justify-content: center;
  padding: 0 30px 0 50px;
  margin-left: 50px;
}
@media all and (max-width: 1367px) {
  main .contactArea > a {
    padding: 0 20px;
    margin-left: 30px;
  }
}
@media all and (max-width: 1200px) {
  main .contactArea > a {
    width: calc(50% - 15px);
    padding: 50px 20px;
  }
  main .contactArea > a:first-of-type {
    margin-left: 0;
  }
}
@media screen and (max-width: 668px) {
  main .contactArea > a {
    width: 100%;
    padding: 50px 20px;
    margin: 0;
  }
  main .contactArea > a:first-of-type {
    margin-bottom: 20px;
  }
}
main .contactArea > a p {
  font-size: 3.7rem;
  color: #fff;
  line-height: 120%;
  margin-left: 30px;
}
@media all and (max-width: 1367px) {
  main .contactArea > a p {
    font-size: 3rem;
  }
}
@media screen and (max-width: 960px) {
  main .contactArea > a p {
    font-size: 2rem;
    margin-left: 20px;
  }
}
main .contactArea > a p strong {
  font-size: 6.5rem;
  font-family: "EB Garamond", serif;
  line-height: 100%;
}
@media all and (max-width: 1367px) {
  main .contactArea > a p strong {
    font-size: 6rem;
  }
}
@media screen and (max-width: 960px) {
  main .contactArea > a p strong {
    font-size: 5rem;
  }
}
main .contactArea > a img {
  width: 30% !important;
}
main .contactArea > a.web {
  background-color: #2A4375;
}
main .contactArea > a.fax {
  background-color: #8D4C02;
}/*# sourceMappingURL=layout.css.map */