@charset "UTF-8";
/*reset*/
* {
  margin: 0;
  padding: 0; }

html, body {
  -webkit-text-size-adjust: 100%; }

body {
  color: #484848;
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 14px; }

h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, caption, th, td, img, form,
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  margin: 0;
  padding: 0;
  border: none;
  font-feature-settings: "palt";
  list-style-type: none; }

input, select, textarea {
  font-size: 100%; }

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  outline: none; }

*:focus {
  outline: none; }

hr {
  display: none; }

a {
  color: #484848;
  text-decoration: none;
  outline: none;
  -webkit-transition: opacity 0.5s;
  -moz-transition: opacity 0.5s;
  -ms-transition: opacity 0.5s;
  -o-transition: opacity 0.5s;
  transition: opacity 0.5s; }

a:hover {
  opacity: .7; }

/* set html5 elements to block */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none; }

.column-row-reverse {
  flex-direction: row-reverse; }

.inner {
  margin: 0 auto;
  width: 86%;
  max-width: 920px;
  /*page*/
  /*graduate-message & efforts*/
  /*contact & request*/ }
  .idea #school-badge .inner {
    max-width: 690px; }
  .idea #school-song .inner {
    max-width: 550px; }
  .history .inner {
    /*max-width: 550px;*/
    /*2個の場合*/
    max-width: 838px;
    /*3個の場合*/ }
  .introduction .inner {
    max-width: 830px; }
  .policy .inner {
    max-width: 820px; }
  .consistency #learning .tab-desc:last-child .inner {
    width: 93%; }
  .english .back-beige .inner {
    max-width: 850px; }
  .subject1 .inner {
    max-width: 800px; }
  .theday #schedule .inner {
    background: url(../images/school-life/theday/back_cloth.jpg);
    border-radius: 15px;
    padding: 4% 4% 0 4%;
    width: 93%; }
  .uniform-event #event .inner:first-child {
    max-width: 810px; }
  .mv-box .inner {
    width: 90%; }
  @media screen and (min-width: 769px) {
    .graduate-message .mv-box .inner {
      width: 50%; }
    .efforts .mv-box .inner {
      width: 66.66667%; } }
  .inner.form-box {
    max-width: 700px; }

p {
  /*line-height: 1.6;*/
  line-height: 1.8; }

.text {
  /*margin-bottom: 1.7em;*/
  margin-bottom: 2em;
  /*page*/ }
  @media screen and (min-width: 769px) {
    .policy .policy-list .text {
      margin-bottom: 0; } }
  @media screen and (min-width: 769px) {
    .program h4 + .text {
      text-align: center; } }
  .english #flow .text {
    margin-bottom: 2.7em; }
  @media screen and (min-width: 769px) {
    .facility h5 + .text {
      margin-bottom: 3%; } }
  .performance .text {
    text-align: center; }
    @media screen and (min-width: 769px) {
      .performance .text {
        margin-bottom: 3%; } }
  @media screen and (min-width: 769px) {
    .en .text {
      margin-bottom: 2%; } }

.text-link {
  color: #009fe8;
  text-decoration: underline; }

.pc,
.br-pc {
  display: none; }

@media screen and (min-width: 769px) {
  .pc,
  .br-pc {
    display: block; }

  .sp,
  .br-sp {
    display: none !important; } }
.border-box {
  background: #efedde;
  border: 1px solid #752586;
  border-radius: 5px;
  color: #752586;
  display: inline-block;
  font-size: 0.9em !important;
  padding: 3px 12px;
  margin-bottom: .5rem; }

/***********************************************************************
loading
**********************************************************************/
.start {
  /*background:url(../img/loading/loading.jpg) no-repeat 0 0;
  background-size: cover;
  background-position: top left;*/
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  z-index: 999999;
  opacity: 0; }

.start .video-wrapper {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1; }

.start .video-wrapper video {
  position: absolute;
  display: block;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  transform: translateX(-50%) translateY(-50%); }

/*.animsition {
  display: none; }*/
@media (max-width: 560px) {
  .start {
    /*background-image: url(../img/loading/loading-sp.jpg);*/
    /*height: calc(100vh - 123px);*/
    height: calc(45vh); }

  .start .video-wrapper {
    top: 50%; }

  .start video {
    transform: translate(-50%, -50%); } }
/***********************************************************************
common
**********************************************************************/
.mincho {
  font-family: "Sawarabi Mincho", serif;
  font-weight: 400;
  letter-spacing: 2px; }

.midashigo {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 1.15em;
  letter-spacing: 1px; }
  @media screen and (min-width: 769px) {
    .midashigo {
      font-size: 1.3em; } }

.futogo {
  font-family: '太ゴB101','Futo Go B101'; }

.copperplate {
  font-family: Copperplate Gothic;
  font-weight: bold; }

.marugo {
  font-family: 'ヒラギノ丸ゴ W6 JIS2004','Hiragino Maru Gothic W6 JIS2004'; }

.border {
  height: 5px;
  background: linear-gradient(127deg, #6bd7cd, #804793, #804793, #6bd7cd, #ff00ff);
  background-size: 800% 800%;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999;
  -webkit-animation: AnimationName 15s ease infinite;
  -moz-animation: AnimationName 15s ease infinite;
  animation: AnimationName 15s ease infinite; }
@-webkit-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@-moz-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@media screen and (min-width: 769px) {
  .border {
    height: 15px;
    position: inherit; } }
.brackets-box {
  border: 2px solid #752586;
  position: relative; }
  @media screen and (max-width: 769px) {
    .brackets-box {
      margin: 0.5em auto !important; } }
  .brackets-box.pink {
    border-color: #E95464; }
  .brackets-box::before {
    content: "";
    background: #fff;
    height: 5px;
    width: 95%;
    position: absolute;
    top: -3px;
    left: 50%;
    transform: translate(-50%, 0%); }
  .brackets-box::after {
    content: "";
    background: #fff;
    height: 5px;
    width: 90%;
    position: absolute;
    bottom: -3px;
    left: 50%;
    transform: translate(-50%, 0%); }
  .brackets-box .column {
    padding: 1em 2em; }
    @media screen and (min-width: 769px) {
      .brackets-box .column + .column {
        border-left: 1px solid #ccc; } }

.brackets-box-2column {
  justify-content: space-between; }
  @media screen and (max-width: 769px) {
    .brackets-box-2column {
      margin: 0.5em auto !important; } }
  .brackets-box-2column.pink {
    border-color: #E95464; }
  .brackets-box-2column .column {
    border: 2px solid #752586;
    position: relative;
    padding: 1em 2em;
    width: 48%; }
    @media screen and (max-width: 769px) {
      .brackets-box-2column .column {
        padding: .5em 1em;
        width: 100%; } }
    .brackets-box-2column .column::before {
      content: "";
      background: #fff;
      height: 5px;
      width: 95%;
      position: absolute;
      top: -3px;
      left: 50%;
      transform: translate(-50%, 0%); }
    .brackets-box-2column .column::after {
      content: "";
      background: #fff;
      height: 5px;
      width: 95%;
      position: absolute;
      bottom: -3px;
      left: 50%;
      transform: translate(-50%, 0%); }
    @media screen and (max-width: 769px) {
      .brackets-box-2column .column + .column {
        margin-top: 1rem; } }

#header-logo {
  height: 45px;
  margin-top: 5px;
  padding: 1%;
  position: relative;
  z-index: 9;
  /*page*/ }
  #header-logo img {
    width: 196px; }
  @media screen and (min-width: 769px) {
    #header-logo {
      height: 80px; }
      #header-logo img {
        width: 325px; } }
  @media screen and (min-width: 769px) {
    .top #header-logo {
      position: absolute; } }

#main {
  background: url(../images/common/back.jpg) no-repeat top center/cover;
  margin-top: 35px;
  padding: 5% 0 6%;
  /*page*/
  /*subject1 & subject2*/
  /*uniform-event & club & facility*/
  /*efforts */
  /*exam & openschool*/
  /*news & update*/
  /*candidate & student & private-news & graduate*/ }
  #main h2 {
    color: #fff;
    font-size: 1.4em;
    padding-top: 23px; }
    #main h2:before {
      content: "";
      background: url(../images/common/h2_white.svg);
      display: inline-block;
      height: 22px;
      width: 73px; }
  @media screen and (min-width: 769px) {
    #main {
      margin-top: 0;
      padding: 0 0 15%; }
      #main h2 {
        background: #fff;
        color: #222222;
        font-size: 2.2em;
        padding-bottom: 1%;
        padding-top: 40px; }
        #main h2::before {
          content: "";
          background: url(../images/common/h2_brown.svg);
          display: inline-block;
          height: 36px;
          width: 122px; } }
  #main.large-main, .performance #main {
    padding: 29% 0; }
    #main.large-main h2, .performance #main h2 {
      background: rgba(255, 255, 255, 0.85);
      color: #222222;
      padding-top: 26px;
      padding-bottom: 1%; }
      #main.large-main h2::before, .performance #main h2::before {
        content: "";
        background: url(../images/common/h2_brown.svg);
        display: inline-block;
        top: 3px; }
    @media screen and (min-width: 769px) {
      #main.large-main, .performance #main {
        padding: 0 0 42%; }
        #main.large-main h2, .performance #main h2 {
          background: #fff;
          font-size: 2.2em;
          padding-top: 40px; }
          #main.large-main h2::before, .performance #main h2::before {
            width: 122px; } }
  .performance #main {
    padding: 21% 0 17%; }
    @media screen and (min-width: 769px) {
      .performance #main {
        padding: 0 0 24%; } }
  @media screen and (min-width: 769px) {
    .idea #main h2 {
      font-size: 2.23em; } }
  .policy #main {
    background: url(../images/learning/policy/back-sp.jpg) no-repeat center center/cover; }
    @media screen and (min-width: 769px) {
      .policy #main {
        background: url(../images/learning/policy/back.jpg) no-repeat top center/cover; } }
  .feature #main {
    background: url(../images/learning/feature/back-sp.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .feature #main {
        background: url(../images/learning/feature/back.jpg) no-repeat center -90px/cover; } }
  .program #main {
    background: url(../images/learning/program/back-sp.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .program #main {
        background: url(../images/learning/program/back.jpg) no-repeat center 97px/cover; } }
  .peace-studies #main, .global #main {
    background: url(../images/learning/peace-studies/back-sp.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .peace-studies #main, .global #main {
        background: url(../images/learning/peace-studies/back.jpg) no-repeat center 78%/cover; } }
  .global-issues #main {
    background: url(../images/learning/global-issues/back.jpg) no-repeat top center/cover; }
  .training #main {
    background: url(../images/learning/training/back.jpg) no-repeat center top/cover; }
  .consistency #main {
    background: url(../images/subject-education/consistency/back.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .consistency #main {
        background: url(../images/subject-education/consistency/back.jpg) no-repeat center 90px/cover; } }
  .english #main {
    background: url(../images/subject-education/english/back-sp.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .english #main {
        background: url(../images/subject-education/english/back.jpg) no-repeat top center/cover; } }
  .theday.school-life #main {
    background: url(../images/school-life/theday/back.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .theday.school-life #main {
        background: url(../images/school-life/theday/back.jpg) no-repeat center 97px/cover; } }
  .subject #main {
    background: url(../images/subject-education/subject/back.jpg) no-repeat top center/cover; }
  .school-life #main {
    background: url(../images/school-life/back.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .school-life #main {
        background: url(../images/school-life/back.jpg) no-repeat center 97px/cover; } }
  .course #main {
    background: url(../images/course/back.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .course #main {
        background: url(../images/course/back.jpg) no-repeat center 75px/cover; } }
  .graduate-message #main, .current-message #main {
    background: url(../images/course/graduate-message/back.jpg) no-repeat top center/cover; }
    @media screen and (min-width: 769px) {
      .graduate-message #main, .current-message #main {
        background: url(../images/course/graduate-message/back.jpg) no-repeat center 75px/cover; } }
  .performance #main {
    background: url(../images/course/performance/back-sp.jpg) no-repeat -227px 0/cover; }
    @media screen and (min-width: 769px) {
      .performance #main {
        background: url(../images/course/performance/back.jpg) no-repeat right 75px/cover; } }
  .information #main {
    background: url(../images/information/back.jpg) no-repeat top center/cover; }
  .blog #main {
    background: url(../images/blog/back.jpg) no-repeat top center/cover; }
  .todays-jogakuin #main {
    background: url(../images/blog/todays-jogakuin/back.jpg) no-repeat top center/cover; }
  .user #main {
    background: url(../images/user/back.jpg) no-repeat top center/cover; }

.top-animsition {
  margin-top: 35px; }
  @media screen and (min-width: 769px) {
    .top-animsition {
      margin-top: 0; } }

/*nav*/
#btn-pc {
  position: fixed;
  top: 150px;
  right: 0;
  transition: 0.5s ease;
  width: 230px;
  z-index: 99999; }
  #btn-pc.move {
    right: 375px; }
  #btn-pc button {
    background: rgba(128, 71, 150, 0.8);
    border-radius: 10px 0 0 10px / 10px 0 0 10px;
    -webkit-border-radius: 10px 0 0 10px / 10px 0 0 10px;
    -moz-border-radius: 10px 0 0 10px / 10px 0 0 10px;
    color: #fff;
    display: block;
    height: 60px;
    line-height: 1.7;
    margin-bottom: 9px;
    padding-left: 20px;
    text-align: left;
    width: 230px;
    -moz-transition: all 0.3s linear;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    -ms-transition: all 0.3s linear;
    transition: all 0.3s linear; }
  #btn-pc button:hover {
    background: #804796;
    border-radius: 15px 0 0 15px / 15px 0 0 15px;
    -webkit-border-radius: 15px 0 0 15px / 15px 0 0 15px;
    -moz-border-radius: 15px 0 0 15px / 15px 0 0 15px;
    color: #fff;
    display: block;
    height: 60px;
    line-height: 1.7;
    margin-bottom: 9px;
    padding-left: 28px;
    text-align: left;
    width: 230px; }

#btn-branch {
  position: fixed;
  top: 287px;
  right: 0;
  transition: 0.5s ease;
  width: 205px;
  z-index: 99999; }
  #btn-branch.move {
    right: 375px; }
  #btn-branch li a {
    background: rgba(85, 72, 101, 0.8);
    color: #fff;
    display: block;
    font-size: 14px;
    height: 46px;
    letter-spacing: 0.1em;
    line-height: 46px;
    margin-bottom: 8px;
    padding-left: 10px;
    position: relative;
    width: 205px; }
    #btn-branch li a::after {
      background: url(../images/common/arrowwh.png) no-repeat;
      background-size: contain;
      content: "";
      height: 10px;
      position: absolute;
      top: 18px;
      right: 8px;
      width: 6px; }

.close {
  position: absolute;
  top: 15px;
  right: 15px; }

.nav li {
  position: relative; }

.hide {
  display: none; }

.nav1 {
  margin: 60px 37.5px 0; }

.branch ul {
  margin-bottom: 10%; }
  .branch ul li a {
    background: #fff;
    border: 3.73px solid #804796;
    border-radius: 26px;
    color: #804796;
    display: block;
    margin-bottom: 4%;
    padding: 2% 0;
    text-align: center; }

.contact.columns {
  margin-bottom: 10%; }
  .contact.columns .column {
    padding: 2%; }
    .contact.columns .column a {
      background: #a080af;
      color: #fff;
      display: block;
      line-height: 1.4;
      padding: 52% 0 9%;
      position: relative;
      text-align: center; }
      .contact.columns .column a::before {
        background: url(../images/common/access.png) no-repeat;
        background-size: contain;
        content: "";
        height: 22px;
        margin: auto;
        position: absolute;
        top: 22%;
        left: 0;
        right: 0;
        width: 15px; }
    .contact.columns .column:nth-child(2) a::before {
      background: url(../images/common/data.png) no-repeat;
      background-size: contain;
      height: 25px;
      width: 22px; }
    .contact.columns .column:last-child a::before {
      background: url(../images/common/contact.png) no-repeat;
      background-size: contain;
      height: 17px;
      width: 27px; }

.menu {
  margin-bottom: 8%; }
  .menu li {
    border-bottom: 1px solid #222; }
    .menu li:first-child {
      border-top: 1px solid #222; }
    .menu li a, .menu li p {
      display: block;
      font-size: 14px;
      padding: 2%; }

.nav .inner {
  background: #fff;
  margin-bottom: 10px;
  padding: 4% 6% 6%;
  width: 100%; }
  .nav .inner li:first-child {
    border-top: 0; }
  .nav .inner li a:before {
    content: "-";
    padding-right: 5px; }

.child {
  display: none; }

.english-btn a {
  background: #554865;
  color: #fff;
  display: block;
  font-size: 12px;
  height: 32px;
  line-height: 32px;
  margin-bottom: 15px;
  position: relative;
  text-align: center; }
  .english-btn a:after {
    background: url(../images/common/arrowwh.png) no-repeat;
    background-size: contain;
    content: "";
    height: 9px;
    position: absolute;
    top: 12px;
    right: 8px;
    width: 5px; }

.sns {
  text-align: center;
  width: 100%; }
  .sns li {
    display: inline-block;
    width: 25px; }

.nav2 {
  margin: 60px 37.5px 0; }
  .nav2 h4 {
    color: #752586;
    font-family: "Shippori Mincho", serif;
    font-size: 20px;
    margin-bottom: 6%; }
  .nav2 .tab-news-btn {
    border-bottom: 1px solid #000;
    cursor: pointer;
    font-size: 1em;
    padding: 0 0 8% 0; }
    .nav2 .tab-news-btn li {
      background: #fff;
      border-radius: 0;
      border: 1px solid #752586;
      color: #000;
      font-size: 0.8em;
      display: inline-block;
      margin-right: 0;
      padding: 3% 0;
      text-align: center;
      width: 32%; }
      .nav2 .tab-news-btn li.active {
        background: #DDE6EB;
        color: #000; }
  .nav2 .newslist ul li {
    border-bottom: 1px solid #752586; }

#btn-sp {
  display: none; }

.gnav-sp .sns li {
  width: 40px; }
.gnav-sp .contact a {
  background: #752586 !important; }

@media screen and (max-width: 768px) {
  .nav {
    margin: 0;
    width: 85%; }

  .nav1 {
    margin: 60px auto 0; }

  .nav2 {
    margin: 0 auto 18px; }

  .nav3 {
    margin: 0 auto; }

  .nav4 {
    background: #fff;
    padding: 13px 0 90px;
    text-align: center;
    width: 100%; }
    .nav4 li {
      display: inline-block;
      width: 25px; }

  #btn-pc,
  .close {
    display: none; }

  #btn-sp,
  #btn-sp span {
    display: inline-block;
    transition: all .5s;
    box-sizing: border-box; }

  #btn-sp {
    background: #804797;
    cursor: pointer;
    position: fixed;
    right: 0;
    /*top:5px;*/
    top: 0px;
    width: 94px;
    height: 45px;
    z-index: 1000; }

  #btn-sp .btn-title {
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    position: absolute;
    top: 29%;
    left: 12%; }

  #btn-sp span {
    background-color: #fff;
    position: absolute;
    left: 63%;
    width: 26%;
    height: 1.725px; }

  #btn-sp span:nth-of-type(1) {
    top: 12px; }

  #btn-sp span:nth-of-type(2) {
    top: 21px; }

  #btn-sp span:nth-of-type(3) {
    top: 30px; }

  /* 開いたとき　*/
  #btn-sp.active {
    background: rgba(0, 0, 0, 0); }

  #btn-sp.active .btn-title {
    display: none; }

  #btn-sp.active span {
    background-color: #804796;
    left: 58%; }

  #btn-sp.active span:nth-of-type(1) {
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(9px) rotate(-45deg); }

  #btn-sp.active span:nth-of-type(2) {
    opacity: 0; }

  #btn-sp.active span:nth-of-type(3) {
    -webkit-transform: translateY(-20px) rotate(45deg);
    transform: translateY(-9px) rotate(45deg); }

  #btn-en a {
    background: #554865;
    color: #fff;
    display: block;
    font-size: 12px;
    height: 45px;
    line-height: 45px;
    position: absolute;
    /*top: 5px;*/
    top: 0px;
    right: 94px;
    text-align: center;
    width: 45px;
    z-index: 100; }

  .btn-branch {
    background: #fff;
    display: flex;
    justify-content: center;
    height: 35px;
    position: absolute;
    top: 45px;
    left: 0;
    width: 100%;
    z-index: 100; }
    .btn-branch li {
      display: inline-block;
      font-size: 0.8em;
      position: relative;
      text-align: center; }
      .btn-branch li:nth-child(2) {
        padding: 0 .5rem; }
        .btn-branch li:nth-child(2)::before, .btn-branch li:nth-child(2)::after {
          content: "";
          height: 50%;
          margin: auto;
          position: absolute;
          bottom: 0;
          top: 0; }
        .btn-branch li:nth-child(2)::before {
          border-left: 1px dashed #554865;
          left: 0; }
        .btn-branch li:nth-child(2)::after {
          border-right: 1px dashed #554865;
          right: 0; }
      .btn-branch li:first-child {
        padding: 0 .5rem 0 0; }
      .btn-branch li:last-child {
        padding: 0 0 0 .5rem;
        /*width: 25%;*/ }
      .btn-branch li a {
        color: #554865;
        display: inline-block;
        height: 35px;
        line-height: 35px; }

  .contact-scroll {
    background: #554865;
    height: 45px;
    padding-right: 94px;
    position: fixed;
    /*top: 5px;*/
    top: 0px;
    width: 100%;
    z-index: 100; }
    .contact-scroll li {
      display: inline-block;
      font-size: 0.9em;
      position: relative;
      text-align: center;
      /*width: 28%;*/
      width: 58%; }
      .contact-scroll li:nth-child(2) {
        width: 40%; }
        .contact-scroll li:nth-child(2)::before, .contact-scroll li:nth-child(2)::after {
          content: "";
          height: 50%;
          margin: auto;
          position: absolute;
          bottom: 0;
          top: 0; }
        .contact-scroll li:nth-child(2)::before {
          border-left: 1px dashed #fff;
          left: 0; }
        .contact-scroll li:nth-child(2)::after {
          border-right: 1px dashed #fff;
          right: 0; }
      .contact-scroll li a {
        color: #fff;
        display: inline-block;
        height: 45px;
        line-height: 45px; }

  div.gnav-sp.active {
    transform: translateY(0%);
    width: 100%; } }
.breadcrumb {
  display: flex;
  margin: 1% 0 5% 2%; }
  .breadcrumb li {
    color: #7c7c7c;
    font-size: 0.6em; }
    .breadcrumb li + li {
      padding: 0 4%;
      position: relative; }
      .breadcrumb li + li::before {
        content: "\0003E";
        color: #7c7c7c;
        position: absolute;
        left: 0; }
    .breadcrumb li a {
      color: #7c7c7c;
      text-decoration: underline; }
  @media screen and (min-width: 769px) {
    .breadcrumb {
      margin: 1% 0 5% 11%; }
      .breadcrumb li {
        font-size: 0.9em; }
        .breadcrumb li + li {
          padding: 0 1% 0 2%; } }

footer {
  background: #80478c;
  color: #fff;
  margin-top: 6%;
  padding: 3em 0 0;
  text-align: center;
  /*related-schools*/
  /*page*/ }
  footer .inner {
    max-width: 1248px; }
  @media screen and (min-width: 769px) {
    footer .address-wrapper {
      display: flex;
      justify-content: space-between;
      align-items: baseline; } }
  footer .footer-logo {
    margin: auto;
    width: 80%; }
    @media screen and (min-width: 769px) {
      footer .footer-logo {
        margin: 0;
        width: auto; } }
    footer .footer-logo img {
      width: 430px; }
  footer .address {
    font-size: clamp(0.813rem, 0.727rem + 0.36vw, 1rem);
    margin-top: 1.5em; }
    footer .address .tel {
      font-size: clamp(1rem, 0.886rem + 0.48vw, 1.25rem);
      color: #fff; }
      footer .address .tel a {
        color: #fff; }
  footer .footer-nav .contact {
    margin-bottom: 0;
    margin-left: auto;
    max-width: 300px; }
  footer .footer-nav ul {
    display: flex;
    flex-wrap: wrap;
    margin: 1.5em auto 0;
    text-align: left;
    width: 90%; }
    @media screen and (min-width: 769px) {
      footer .footer-nav ul {
        gap: 0 2.5em;
        text-align: right;
        width: auto; } }
    footer .footer-nav ul li {
      width: 50%;
      font-size: clamp(0.875rem, 0.847rem + 0.12vw, 0.938rem); }
      @media screen and (min-width: 769px) {
        footer .footer-nav ul li {
          width: inherit; } }
      footer .footer-nav ul li::before {
        content: "\025cf";
        margin-right: .25em; }
      footer .footer-nav ul li a {
        color: #fff; }
  footer .sns-school-box {
    margin-top: 2.5em; }
    @media screen and (min-width: 769px) {
      footer .sns-school-box {
        display: flex; } }
    footer .sns-school-box .sns {
      width: auto; }
      footer .sns-school-box .sns li {
        width: 46px; }
        footer .sns-school-box .sns li:nth-child(2) {
          margin: 0 .5em; }
  footer .related-schools {
    display: flex;
    align-items: center;
    gap: 0 3em;
    flex-wrap: wrap;
    margin-top: 2em;
    /*li*/ }
    @media screen and (min-width: 769px) {
      footer .related-schools {
        margin-left: auto;
        margin-top: 0; } }
    footer .related-schools li {
      margin: auto;
      width: 85%; }
      @media screen and (min-width: 769px) {
        footer .related-schools li {
          width: auto; } }
      footer .related-schools li a {
        border-bottom: 1px solid #fff;
        color: #fff;
        font-size: clamp(0.875rem, 0.761rem + 0.48vw, 1.125rem);
        display: block;
        padding: .5em 0; }
        @media screen and (min-width: 769px) {
          footer .related-schools li a {
            padding: 0 0 3px; } }
        footer .related-schools li a:hover {
          text-decoration: underline; }
      footer .related-schools li:last-child a {
        border-bottom: none; }
        @media screen and (min-width: 769px) {
          footer .related-schools li:last-child a {
            border-bottom: 1px solid #fff; } }
  footer .copyright {
    font-size: 0.9em;
    padding: 3em 0 2em;
    text-align: center; }
    @media screen and (min-width: 769px) {
      footer .copyright {
        padding: 5em 0 2em; } }
  @media screen and (min-width: 769px) {
    footer {
      padding: 5em 0 0; }
      footer .address {
        position: relative;
        text-align: left; }
      footer .sns {
        text-align: left; }
      footer .footer-nav {
        padding-left: 1.5rem;
        padding-right: 0; }
      footer .contact.columns .column {
        padding: 1%; } }
  @media screen and (min-width: 1020px) {
    footer .footer-nav {
      padding-left: 3.5rem;
      padding-right: 1.5rem; } }
  .top footer {
    height: inherit;
    margin-top: 0; }
  .english footer {
    margin-top: 0; }
  .subject2 footer {
    margin-top: 0; }
  .theday footer {
    margin-top: 0; }
  .efforts footer {
    margin-top: 0; }

h2 {
  color: #222222;
  font-size: 1.8em;
  text-align: center;
  padding-top: 28px;
  position: relative;
  /*page*/ }
  h2:before {
    content: "";
    background: url(../images/common/h2_brown.svg);
    display: inline-block;
    height: auto;
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 22px;
    width: 73px; }
  .top h2 {
    margin: 6% 0 8%; }
    @media screen and (min-width: 769px) {
      .top h2 {
        margin: 5% 0 2%; } }
  .top #learning h2 {
    margin: 1% 0 6%; }
    @media screen and (min-width: 769px) {
      .top #learning h2 {
        margin: 0 0 2%; } }
  @media screen and (min-width: 769px) {
    .subject1 #main h2 {
      font-size: 2.23em; } }

h3 {
  color: #916134;
  font-size: 1.8em;
  line-height: 1.2;
  margin-bottom: 1em;
  text-align: center;
  /*page*/ }
  h3 span {
    display: inline-block;
    padding: 0 65px;
    position: relative; }
    h3 span::before {
      content: url(../images/common/h3_left.svg);
      height: auto;
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 57px; }
    h3 span::after {
      content: url(../images/common/h3_right.svg);
      height: auto;
      position: absolute;
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 57px; }
    h3 span small {
      display: block;
      font-size: 0.65em; }
  @media screen and (min-width: 769px) {
    h3 {
      font-size: 3em; }
      h3 span {
        padding: 0 130px;
        position: relative; }
        h3 span::before {
          width: 110px; }
        h3 span::after {
          width: 110px; } }
  @media screen and (min-width: 769px) {
    .idea #idea h3 {
      font-size: 3.01em; } }
  .english #flow h3 span {
    padding: 0 50px; }
    .english #flow h3 span::before {
      content: url(../images/subject-education/english/h3_left.svg);
      top: 57%;
      width: 10px; }
    .english #flow h3 span::after {
      content: url(../images/subject-education/english/h3_right.svg);
      top: 57%;
      width: 10px; }
  @media screen and (min-width: 769px) {
    .english #flow h3 span::before, .english #flow h3 span::after {
      top: 65%; } }
  .subject1 h3 {
    font-size: 1.81em; }
    @media screen and (min-width: 769px) {
      .subject1 h3 {
        font-size: 3.05em; } }

.newslist ul {
  margin: 0 0 4%; }
  .newslist ul li {
    border-bottom: 1px dashed #CFCFD0;
    padding: 4% 0; }
    .newslist ul li .columns {
      margin-bottom: 0; }
.newslist.noimage h5 {
  margin-bottom: 2.5%;
  text-decoration: underline; }
.newslist.image li {
  padding: 4% 0 3%;
  position: relative; }
  .newslist.image li::after {
    background: url(../images/common/arrow_p.png) no-repeat;
    background-size: contain;
    content: "";
    height: 6px;
    margin: auto;
    position: absolute;
    bottom: 0;
    top: 0;
    right: .75rem;
    width: 30px; }
.newslist.notype .border-gradation {
  margin-bottom: 6%; }
.newslist.notype li {
  border: none;
  padding: 1% 0; }

.new {
  background: #c00051;
  color: #fff;
  display: inline-block;
  margin-left: 3%;
  padding: 0 2%; }

.type {
  background: #fff;
  border: 1px solid #7D7D7D;
  color: #7D7D7D;
  display: inline-block;
  font-size: 0.9em;
  margin-bottom: 1%;
  margin-right: 2%;
  padding: 0 3%; }
  .type.hjs_blog, .type.guardian, .type.guardian-info, .type.general {
    background: #554865;
    border: #554865;
    color: #fff; }
  .type.entrance_examination, .type.prospectus {
    background: #F76073;
    border: #F76073;
    color: #fff; }
  .type.emergency {
    background: #C10051;
    border: #C10051;
    color: #fff; }
  .type.saiyo {
    background: #80ac1f;
    border: #80ac1f;
    color: #fff; }
  .type.irisletter {
    background: #d970b8;
    border: #d970b8;
    color: #fff; }

.list-btn {
  text-align: right; }
  .list-btn a {
    background: #fff;
    border: 1px solid;
    padding: 0 2%; }

.page-btn {
  margin: 11% auto 0;
  max-width: 165px; }
  .page-btn li {
    display: inline-block;
    width: 17%; }
    .page-btn li.active a {
      background: #804780;
      color: #fff; }
  .page-btn a {
    border: 1px solid #804780;
    color: #804780;
    display: inline-block;
    padding: 6% 0;
    text-align: center;
    width: 100%; }

.border-left {
  padding-left: 2em;
  position: relative; }
  .border-left:before {
    border-bottom: 1px solid;
    content: "";
    top: 10px;
    left: 0;
    position: absolute;
    width: 1.5em; }

.date {
  color: #8C8C8D;
  font-size: 0.6em;
  margin-bottom: 0; }

.note {
  color: #231815;
  font-size: 0.9em;
  margin-bottom: 1.4em;
  margin-top: 1%; }

@media screen and (min-width: 769px) {
  .newslist.image li {
    border: none;
    margin-right: 3%;
    padding: 2% 0 2% 2%;
    width: 31.33333%; }
    .newslist.image li:nth-child(3n) {
      margin-right: 0; }
    .newslist.image li .columns {
      margin: 0; }
      .newslist.image li .columns .column.is-4 {
        padding: 0 0 .75rem 0; }
        .newslist.image li .columns .column.is-4 img {
          height: 68px;
          object-fit: cover; }
    .newslist.image li::before {
      background: #d3dee5;
      content: "";
      position: absolute;
      bottom: 0;
      left: 0;
      height: 82%;
      width: 100%;
      z-index: -1; }
    .newslist.image li::after {
      bottom: 15%;
      top: inherit; }
  .newslist.noimage h5 {
    margin-bottom: 1%; }
  .newslist.notype .border-gradation {
    margin-bottom: 1%; }

  .page-btn {
    margin: 0 auto; }

  .archive-box {
    border: 1px solid;
    height: 100%; } }
.border-gradation {
  padding-bottom: 3%;
  position: relative;
  /*page*/ }
  .border-gradation::after {
    content: "";
    height: 5px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(127deg, #6bd7cd, #804793, #804793, #6bd7cd, #ff00ff);
    background-size: 800% 800%;
    -webkit-animation: AnimationName 15s ease infinite;
    -moz-animation: AnimationName 15s ease infinite;
    animation: AnimationName 15s ease infinite; }
@-webkit-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@-moz-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
  @media screen and (min-width: 769px) {
    .border-gradation {
      font-size: 1.15em;
      padding-bottom: 10px; } }
  .top #learning .border-gradation {
    padding-bottom: 0; }
    .top #learning .border-gradation::after {
      height: 3px; }
    @media screen and (min-width: 769px) {
      .top #learning .border-gradation::after {
        height: 5px; } }
  @media screen and (min-width: 769px) {
    .qa .border-gradation {
      font-size: 1.2em; } }

.link-list {
  margin: 5% 0 10%; }
  .link-list li {
    margin-bottom: 1%; }
    .link-list li a {
      display: inline-block;
      padding: 0 15px;
      position: relative;
      text-decoration: underline; }
      .link-list li a::before {
        background: url(../images/common/link_arrow.jpg) no-repeat;
        background-size: contain;
        content: "";
        height: 13px;
        position: absolute;
        top: 5px;
        left: 0;
        width: 13px; }
      .link-list li a.documents-link::after {
        background: url(../images/common/documents_icon.jpg) no-repeat;
        background-size: contain;
        content: "";
        height: 13px;
        margin: auto 0;
        position: absolute;
        bottom: 0;
        top: 0;
        right: 0;
        width: 11px; }
      .link-list li a.other-link::after {
        background: url(../images/common/other_icon.jpg) no-repeat;
        background-size: contain;
        content: "";
        height: 12px;
        margin: auto 0;
        position: absolute;
        bottom: 0;
        top: 0;
        right: 0;
        width: 12px; }
  @media screen and (min-width: 769px) {
    .link-list {
      margin: 2% 0 7%; }
      .link-list li {
        display: inline-block;
        width: 24%; } }

@media screen and (min-width: 769px) {
  .student .link-list li {
    display: block;
    width: inherit; } }

.image-desc {
  /*page*/ }
  .image-desc.columns {
    margin-left: 0;
    margin-right: 0;
    padding: 0; }
    .image-desc.columns:not(:last-child) {
      margin-bottom: 5%; }
    .image-desc.columns .image {
      padding: 0; }
  @media screen and (min-width: 769px) {
    .image-desc.columns .column {
      padding: 1rem; } }
  .subject1 #science .image-desc {
    background: #fff; }
    .subject1 #science .image-desc h6 {
      border-bottom: 1px solid;
      color: #804f21;
      margin-bottom: 1%; }
      .subject1 #science .image-desc h6 + p {
        margin-bottom: 3%; }

.back-border {
  background: repeating-linear-gradient(90deg, #f0eaf4 0, #f0eaf4 10px, #e9dfee 10px, #e9dfee 20px);
  padding: 6%;
  /*page*/ }
  @media screen and (min-width: 769px) {
    .training .back-border.box {
      padding: 1rem; } }
  .club .back-border {
    background: #e9dfee;
    padding: 7% 6% 6%; }
    @media screen and (min-width: 769px) {
      .club .back-border {
        padding: 3% 6% 6%; } }

.back-beige {
  background: #efedde;
  padding-top: 6%;
  /*page*/ }
  @media screen and (min-width: 769px) {
    .back-beige {
      padding-top: 3%; } }
  .top #learning .back-beige {
    margin: -7% auto 12%;
    padding-top: 5%;
    position: relative;
    width: 87%; }
    .top #learning .back-beige p {
      text-align: center; }
    @media screen and (min-width: 769px) {
      .top #learning .back-beige {
        margin: -4% auto 6%;
        padding-top: 3%;
        width: 65%; }
        .top #learning .back-beige p {
          font-size: 1.3em; } }
  .top #learning + .back-beige {
    margin: 7% auto 0;
    max-width: 920px;
    padding: 1%; }
    @media screen and (min-width: 769px) {
      .top #learning + .back-beige {
        margin: 4% auto 0;
        padding: .5%; } }
  .english .back-beige {
    padding-top: 10%; }
    @media screen and (min-width: 769px) {
      .english .back-beige {
        padding-top: 4%; } }

.back-beige-gradient {
  background-image: linear-gradient(#ffffff, #efedde 4%); }

.image-box {
  margin: 0 auto 1.3em;
  max-width: 920px;
  text-align: center;
  /*page*/
  /*graduate-message & efforts*/ }
  @media screen and (min-width: 769px) {
    .facility .image-box {
      margin: 0 auto 1%; } }
  .efforts #support .image-box {
    margin: 3% 0; }
  .mv-box .image-box {
    margin: .75rem auto 0;
    padding: 0; }
    @media screen and (min-width: 769px) {
      .mv-box .image-box {
        padding-right: .75rem; } }
  @media screen and (min-width: 769px) {
    .en .image-box {
      margin-bottom: 2%; } }

.beige-box {
  background: #f3f0e6;
  padding: 6% 7% 3%;
  /*page*/ }
  .beige-box h5 {
    color: #804f21;
    border-bottom: 1px solid;
    margin-bottom: 3%; }
  .uniform-event #christianity-event .beige-box {
    padding: 6% 7%; }

.gradation-btn {
  margin: 0 auto;
  max-width: 150px;
  /*page*/
  /*student & graduate*/
  /*en & qa*/ }
  .gradation-btn a, .gradation-btn input, .gradation-btn p {
    border-radius: 35px;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    padding: 9% 0 10%;
    position: relative;
    width: 100%;
    text-align: center;
    background: linear-gradient(127deg, #6bd7cd, #804793, #804793, #6bd7cd);
    background-size: 800% 800%;
    -webkit-animation: AnimationName 12s ease infinite;
    -moz-animation: AnimationName 12s ease infinite;
    animation: AnimationName 12s ease infinite; }
@-webkit-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@-moz-keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
@keyframes AnimationName {
  0% {
    background-position: 5% 0%; }
  50% {
    background-position: 96% 100%; }
  100% {
    background-position: 5% 0%; } }
    .gradation-btn a::after, .gradation-btn input::after, .gradation-btn p::after {
      background: url(../images/common/arrowwh.png) no-repeat;
      background-size: contain;
      content: "";
      height: 8px;
      margin: auto;
      position: absolute;
      right: 8%;
      bottom: 0;
      top: 3px;
      width: 5px; }
  .gradation-btn.large {
    max-width: 280px; }
    .gradation-btn.large a, .gradation-btn.large input, .gradation-btn.large p {
      padding: 5% 0; }
  .gradation-btn.yellow a {
    background: linear-gradient(127deg, #ffff82, #b2c37a, #b2c37a);
    background-size: 600% 600%;
    color: #222;
    -webkit-animation: AnimationName 16s ease infinite;
    -moz-animation: AnimationName 16s ease infinite;
    animation: AnimationName 16s ease infinite; }
@-webkit-keyframes AnimationName {
  0% {
    background-position: 0% 13%; }
  50% {
    background-position: 100% 88%; }
  100% {
    background-position: 0% 13%; } }
@-moz-keyframes AnimationName {
  0% {
    background-position: 0% 13%; }
  50% {
    background-position: 100% 88%; }
  100% {
    background-position: 0% 13%; } }
@keyframes AnimationName {
  0% {
    background-position: 0% 13%; }
  50% {
    background-position: 100% 88%; }
  100% {
    background-position: 0% 13%; } }
    .gradation-btn.yellow a::after {
      background: url(../images/common/arrow.png) no-repeat;
      background-size: contain;
      height: 5px;
      -moz-transform: rotate(-90deg);
      -ms-transform: rotate(-90deg);
      -webkit-transform: rotate(-90deg);
      transform: rotate(-90deg);
      width: 8px; }
  @media screen and (min-width: 769px) {
    .gradation-btn {
      max-width: 263px; }
      .gradation-btn.large {
        max-width: 350px; }
      .gradation-btn a {
        padding: 7% 0 8%; } }
  .top .gradation-btn.yellow {
    margin: 10% auto; }
    @media screen and (min-width: 769px) {
      .top .gradation-btn.yellow {
        margin: 3% auto 6%; } }
  .top #learning .gradation-btn {
    max-width: 170px; }
    .top #learning .gradation-btn a {
      padding: 2% 0 3%; }
    @media screen and (min-width: 769px) {
      .top #learning .gradation-btn {
        max-width: 220px; }
        .top #learning .gradation-btn a {
          padding: 5% 0 6%; } }
  .top #learning li .gradation-btn {
    margin: 0;
    max-width: 150px; }
    .top #learning li .gradation-btn a {
      padding: 2% 0 4%; }
  .policy .gradation-btn {
    max-width: 200px; }
  .openschool .gradation-btn {
    max-width: 300px; }
    .openschool .gradation-btn p {
      border-radius: 20px;
      cursor: text; }
      .openschool .gradation-btn p strong {
        color: #fff;
        font-size: 2.3em; }
      .openschool .gradation-btn p span {
        background: #fff;
        border-radius: 5px;
        color: #000;
        margin-right: 3%;
        padding: 0 2%;
        vertical-align: super; }
      .openschool .gradation-btn p a {
        background: none;
        border-radius: 0;
        display: inherit;
        padding: 0;
        text-align: inherit;
        width: inherit; }
        .openschool .gradation-btn p a::after {
          content: none; }
      .openschool .gradation-btn p::after {
        content: none; }
  .user .gradation-btn {
    margin-bottom: 10%; }
    @media screen and (min-width: 769px) {
      .user .gradation-btn {
        margin-bottom: 5%; } }
  .student .gradation-btn a::before {
    background: url(../images/user/student/lock_icon.png) no-repeat;
    background-size: contain;
    content: "";
    padding-right: 9%; }
  .student .gradation-btn a::after {
    content: none; }
  .graduate .gradation-btn a::after {
    background: url(../images/user/graduate/other_icon.png) no-repeat right;
    background-size: contain;
    content: "";
    padding-left: 10%; }
  .page-navlist .gradation-btn {
    max-width: inherit;
    padding-bottom: 0; }
    .page-navlist .gradation-btn.large {
      padding-bottom: .75rem; }
    @media screen and (min-width: 769px) {
      .page-navlist .gradation-btn.large a {
        padding: 7% 0 8%; } }
    .page-navlist .gradation-btn a::after {
      content: none; }
    .page-navlist .gradation-btn a::before {
      background: url(../images/common/arrowwh.png) no-repeat;
      background-size: contain;
      content: "";
      height: 10px;
      margin: auto;
      position: absolute;
      left: 10%;
      top: 0;
      bottom: 0;
      -moz-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      -webkit-transform: rotate(90deg);
      transform: rotate(90deg);
      width: 5px; }
  .form-box .gradation-btn {
    margin-top: 5%; }

.head-purple {
  background: #752686;
  border-radius: 25px;
  color: #fff;
  display: block;
  margin-bottom: 2%;
  padding: 1% 0 1.5%;
  text-align: center; }

.head-mincho {
  color: #000;
  font-size: 1.4em !important;
  margin-bottom: 10%;
  text-align: center;
  /*page*/
  /*graduate-message & efforts*/ }
  @media screen and (min-width: 769px) {
    .head-mincho {
      font-size: 2em !important;
      margin-bottom: 3%; } }
  .top #learning .head-mincho {
    font-size: 2.5em;
    margin-bottom: 3%; }
  .program .head-mincho {
    margin-bottom: 5%; }
    @media screen and (min-width: 769px) {
      .program .head-mincho {
        margin-bottom: 3%; } }
  @media screen and (min-width: 769px) {
    .subject2 #lhr .head-mincho {
      text-align: left; } }
  .efforts #voice .head-mincho {
    color: #752485; }
  .mv-box .head-mincho {
    text-align: left; }

.head-border {
  text-align: center;
  margin-bottom: 4%; }
  .head-border span {
    border-bottom: 4.5px solid #752586;
    color: #231815;
    font-size: 0.9em;
    padding-bottom: 1%; }

.head-sub {
  font-size: 1.1em;
  margin-bottom: 1em;
  /*page*/ }
  .head-sub span {
    background: #752586;
    border-radius: 5px;
    color: #fff;
    margin-right: 3%;
    padding: 0 3% 1px; }
  @media screen and (min-width: 769px) {
    .training .head-sub {
      font-size: 1.15em; } }
  .global-issues .head-sub {
    /*color: #866134;
    margin-bottom: 0;*/ }
    .global-issues .head-sub span {
      /*background: #866134;*/
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 400;
      /*font-size: 0.8em;*/ }

.head-td {
  color: #484848;
  font-size: 1.3em;
  margin-bottom: 3%;
  text-align: center;
  padding-top: 23px;
  position: relative; }
  .head-td span {
    padding: 0 1%; }
  .head-td:before {
    content: url(../images/common/deco1.svg);
    height: auto;
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 97px; }
  .head-td.midashigo {
    font-size: 1em; }
    .head-td.midashigo:before {
      content: url(../images/common/deco2.svg); }
  @media screen and (min-width: 769px) {
    .head-td {
      font-size: 1.7em;
      padding-top: 30px; }
      .head-td.midashigo {
        font-size: 1.2em; } }

.head-circle {
  margin-bottom: 5%;
  position: relative;
  /*page*/ }
  .head-circle:before {
    border-top: 1px solid #866134;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%; }
  .head-circle:after {
    color: #866134;
    content: "●";
    position: absolute;
    top: 50%;
    right: 0;
    text-shadow: 0 0 0 #fff, -6px 0 0 #fff, 3px 0 0 #fff, 0 0 0 #fff;
    transform: translateY(-50%); }
  .head-circle span {
    background-color: #fff;
    color: #866134;
    display: inline-block;
    padding-right: 2%;
    position: relative; }
  .peace-studies .purple .head-circle:before, .global .purple .head-circle:before {
    border-top: 1px solid #752586; }
  .peace-studies .purple .head-circle:after, .global .purple .head-circle:after {
    color: #752586; }
  .peace-studies .purple .head-circle span, .global .purple .head-circle span {
    color: #752586; }
  .english .head-circle {
    margin-bottom: 0.7em; }
  .subject1 .head-circle:before {
    border-top: 1px solid #752586; }
  .subject1 .head-circle:after {
    color: #752586;
    text-shadow: 0 0 0 #f2ecf5, -6px 0 0 #f2ecf5, 3px 0 0 #f2ecf5, 0 0 0 #f2ecf5;
    transform: translateY(-50%); }
  .subject1 .head-circle span {
    background-color: #f2ecf5;
    color: #752586; }

.head-box {
  background: #fff;
  border: 2px solid #752585;
  color: #752585;
  margin-bottom: 3%;
  padding: .2em 0;
  text-align: center; }

.head-black {
  border-bottom: 1px solid;
  color: #231815;
  font-size: 1.15em;
  margin-bottom: 5%;
  padding-bottom: 2%; }
  @media screen and (min-width: 769px) {
    .head-black {
      margin-bottom: 4%;
      padding-bottom: 1%; } }

.head-bkcircle {
  background: #efedde;
  border-radius: 50% 50% 0 0/100% 100% 0 0;
  margin: 0 auto -14px;
  padding-top: 35px;
  text-align: center;
  width: 68%;
  /*page*/ }
  .english .head-bkcircle {
    max-width: 450px; }
  .efforts .head-bkcircle {
    max-width: 500px; }

.ribbon {
  background: url(../images/school-life/ribbon.png) no-repeat center;
  background-size: contain;
  color: #fff;
  margin-bottom: 3%;
  padding: 1.5% 0 4%;
  text-align: center; }
  @media screen and (min-width: 769px) {
    .ribbon {
      padding: 1% 0 2%; } }

.border-circle {
  border-bottom: 1px solid #752586;
  margin-bottom: 2%;
  padding-bottom: 2%;
  position: relative;
  /*page*/ }
  .border-circle::before, .border-circle::after {
    content: "・";
    color: #752586;
    position: absolute;
    bottom: -14px; }
  .border-circle::before {
    left: -16px; }
  .border-circle::after {
    right: -16px; }
  .performance .border-circle {
    margin-bottom: 8%; }
    .performance .border-circle::before, .performance .border-circle::after {
      bottom: -8px; }
    .performance .border-circle::before {
      left: -11px; }
    .performance .border-circle::after {
      right: -11px; }
  .efforts .border-circle {
    color: #752586;
    font-size: 1.6em;
    text-align: center; }

.head-square {
  color: #752580;
  font-size: 1.1em;
  margin-bottom: 1%;
  padding-left: 1em;
  position: relative;
  /*page*/ }
  .head-square::before {
    background: url(../images/common/square.jpg) no-repeat;
    background-size: contain;
    content: "";
    height: 12px;
    position: absolute;
    top: 28%;
    left: 0;
    width: 12px; }
  .performance .head-square span {
    color: #484848;
    font-size: 0.9em;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    /*position: absolute;
    right: 0;
    top: 8%;*/ }
  .efforts .head-square {
    margin-top: 5%; }
  .exam .head-square {
    margin-top: 14%; }
    @media screen and (min-width: 769px) {
      .exam .head-square {
        margin-top: 5%; } }
  .en .head-square {
    border-bottom: 1px solid #484848;
    margin-bottom: 5%;
    padding-bottom: 2%; }
    @media screen and (min-width: 769px) {
      .en .head-square {
        font-size: 1.5em;
        margin-bottom: 2%;
        margin-top: 5%;
        padding-bottom: 1%; } }

.name {
  text-align: right; }

.accordion p {
  cursor: pointer;
  position: relative;
  width: 100%; }
  .accordion p:after {
    background: url(../images/common/arrow.png) no-repeat;
    background-size: contain;
    height: 5px;
    margin: auto;
    position: absolute;
    right: 10px;
    bottom: 0;
    top: 0;
    content: "";
    -moz-transition: all, 0.25s, linear;
    -o-transition: all, 0.25s, linear;
    -webkit-transition: all, 0.25s, linear;
    transition: all, 0.25s, linear;
    width: 9px; }
  .accordion p.active:after {
    -moz-transform: translate(0, 50%);
    -ms-transform: translate(0, 50%);
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    -moz-transform: rotate(-180deg);
    -ms-transform: rotate(-180deg);
    -webkit-transform: rotate(-180deg);
    transform: rotate(-180deg); }

.table {
  border-collapse: collapse;
  margin-bottom: 0;
  width: 100%; }
  .table th, .table td {
    border: 1px solid #796a56;
    vertical-align: middle;
    padding: 4% 3%; }
  .table th {
    text-align: center;
    line-height: 1.1;
    white-space: nowrap; }
  .table td {
    background: #e8e8e8; }
  .table tr:first-child th:nth-child(even) {
    background: #c4a7cc; }
  .table tr:first-child th:nth-child(odd) {
    background: #d2bdda; }
  .table + p {
    padding-bottom: 7%; }
  @media screen and (min-width: 769px) {
    .table.pc {
      display: table; }
    .table th, .table td {
      padding: 1% 3%; } }

.history-table {
  margin-bottom: 9%;
  /*page*/ }
  .history-table th {
    border-right: 1px solid;
    color: #752586;
    font-size: 0.8em;
    padding-top: 3px;
    padding-right: 14px;
    position: relative;
    text-align: right;
    white-space: nowrap; }
    .history-table th::after {
      background: url(../images/about/history/circle.png) no-repeat;
      background-size: contain;
      content: "";
      height: 8px;
      position: absolute;
      top: 7px;
      right: -5px;
      width: 8px; }
  .history-table tr:first-child th::before,
  .history-table tr:last-child th::before {
    background: #fff;
    content: "";
    position: absolute;
    right: -5px;
    width: 8px; }
  .history-table tr:first-child th::before {
    top: 0;
    height: 8px; }
  .history-table tr:last-child th::before {
    bottom: 0;
    height: 70%; }
  .history-table td {
    padding: 0 0 5% 14px; }
  .history-table tr:last-child th::after {
    bottom: 0; }
  .history-table tr:last-child td {
    padding: 0 0 0 14px; }
  @media screen and (min-width: 769px) {
    .history-table th::after {
      height: 10px;
      top: 6px;
      right: -6px;
      width: 10px; } }
  .history .history-table tr:last-child th::before {
    height: 84%; }

.dashed-table dl {
  align-items: center; }
  .dashed-table dl dd {
    border-left: 1px dashed #231815;
    margin: .75rem 0;
    padding: 0 .75rem; }

.tab-btn {
  color: #fff;
  font-size: 1.2em;
  margin: 0 auto !important;
  max-width: 920px;
  padding: 0 7%;
  /*page*/ }
  .tab-btn span {
    font-size: 0.8em; }
  .tab-btn li {
    background: #bababa;
    border-radius: 10px 10px 0 0;
    cursor: pointer;
    padding: 1%;
    margin-right: 2%;
    text-align: center; }
    .tab-btn li:last-child {
      margin-bottom: 0; }
    .tab-btn li.active {
      background: #efedde;
      color: #8a6134; }
  .graduate-message #graduate .tab-btn {
    color: #484848;
    font-size: 0.9em;
    padding: 0; }
    .graduate-message #graduate .tab-btn li {
      background: transparent;
      border-radius: 0;
      cursor: pointer;
      padding: .75rem;
      margin-right: 0; }
      .graduate-message #graduate .tab-btn li:first-child, .graduate-message #graduate .tab-btn li:nth-child(2), .graduate-message #graduate .tab-btn li:nth-child(3) {
        padding-bottom: 0; }
      .graduate-message #graduate .tab-btn li .is-5 {
        padding-bottom: 0; }
      .graduate-message #graduate .tab-btn li .image {
        margin: auto;
        position: relative;
        width: 80%; }
        .graduate-message #graduate .tab-btn li .image img {
          border-radius: 50%; }
        .graduate-message #graduate .tab-btn li .image::after {
          background: rgba(0, 0, 0, 0.4);
          border-radius: 50%;
          content: "";
          height: 100%;
          position: absolute;
          top: 0;
          right: 0;
          width: 100%; }
      .graduate-message #graduate .tab-btn li .desc {
        padding-top: 2%; }
        .graduate-message #graduate .tab-btn li .desc p {
          line-height: 1.3; }
      .graduate-message #graduate .tab-btn li.active {
        color: #484848; }
        .graduate-message #graduate .tab-btn li.active .image {
          border: 3px solid #752586;
          border-radius: 50%; }
          .graduate-message #graduate .tab-btn li.active .image::after {
            content: none; }
    @media screen and (min-width: 769px) {
      .graduate-message #graduate .tab-btn li .columns {
        align-items: center; }
      .graduate-message #graduate .tab-btn li .is-5 {
        padding-bottom: .75rem; }
      .graduate-message #graduate .tab-btn li .desc {
        font-size: 1.1em;
        padding-top: .75rem;
        text-align: left; } }

.tab-desc {
  margin-bottom: 7%;
  /*page*/ }
  @media screen and (min-width: 769px) {
    .tab-desc {
      margin-bottom: 4%; } }
  .consistency #learning .tab-desc:first-child {
    position: relative;
    margin-bottom: 11%;
    margin-top: -18px;
    top: 18px; }
  @media screen and (min-width: 769px) {
    .consistency #learning .tab-desc:first-child {
      margin-bottom: 5%;
      margin-top: -47px;
      top: 27px; } }
  .graduate-message #graduate .tab-desc {
    border-top: 3px solid #752586;
    max-width: 920px; }
    @media screen and (min-width: 769px) {
      .graduate-message #graduate .tab-desc {
        padding-top: 2%; } }

/*graduate-message & efforts*/
.mv-box {
  margin: auto;
  max-width: 920px;
  /*page*/ }
  .mv-box .columns {
    margin: -.75rem 0; }
  .mv-box .profile {
    margin-bottom: 8%;
    position: relative; }
    .mv-box .profile p {
      padding-left: 2em; }
    .mv-box .profile strong {
      font-size: 1.4em; }
      .mv-box .profile strong span {
        font-size: 0.65em;
        padding-left: 1%; }
    .mv-box .profile .award {
      background: #956134;
      color: #fff;
      display: inline-block;
      padding: 2px 12px;
      margin-top: 8px;
      margin-left: 2em; }
      @media screen and (min-width: 769px) {
        .mv-box .profile .award {
          margin-left: 0em;
          position: absolute;
          bottom: 0;
          left: 230px; } }
      @media screen and (min-width: 769px) {
        .mv-box .profile .award.arima {
          bottom: 3px;
          left: 152px; } }
  .efforts .mv-box {
    padding: 2em 0; }
    .efforts .mv-box .profile {
      margin-bottom: 3%; }
    .efforts .mv-box:first-child {
      border-bottom: 1px dashed #752485; }

/*style*/
/***********************************************************************
top
**********************************************************************/
.top {
  /*wrapper*/
  /*newslist*/
  /*new-policy*/
  /*new-policy-sp-text*/
  /*#learning*/ }
  .top .wrapper {
    overflow: inherit;
    position: relative; }
    @media screen and (min-width: 769px) {
      .top .wrapper::before {
        content: "";
        background: #f3f1e2;
        height: 170px;
        position: absolute;
        bottom: -150px;
        width: 100%;
        z-index: 0; } }
  .top .scroll_down {
    position: relative;
    margin: 32px auto 0;
    width: 62px; }
  .top .scroll_down a img {
    display: block;
    margin: auto;
    width: 62px;
    position: absolute;
    top: -117px;
    left: 0; }
  .top .scroll_down a:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 1px;
    height: 100px;
    background: #ddd; }
  .top .scroll_down a:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 1px;
    height: 100px;
    background: #752586; }
  .top .scroll_down a:hover {
    opacity: .5; }
  .top #type01 a:after {
    animation: sdl01 2.5s infinite; }
@keyframes sdl01 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0; }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0; }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%; }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%; } }
  .top .link-badge {
    position: relative;
    margin: -24px auto 0;
    width: 80%; }
    @media screen and (min-width: 769px) {
      .top .link-badge {
        position: absolute;
        bottom: 10%;
        left: 0;
        z-index: 9; } }
    @media screen and (min-width: 769px) {
      .top .link-badge img {
        width: clamp(12.5rem, 8.75rem + 16vw, 20.75rem); } }
  .top .banner-slider {
    margin-top: 6%;
    overflow: hidden; }
    .top .banner-slider .slick-list {
      margin: 0 -12px; }
    .top .banner-slider .slick-slide {
      margin: 0 12px; }
  .top .news-wrapper {
    max-width: 1080px; }
    @media screen and (min-width: 769px) {
      .top .news-wrapper {
        margin-top: 5.5em; } }
  .top .news-head {
    border-bottom: 1px solid #752586;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 1.5em;
    margin-top: 2em; }
    @media screen and (min-width: 769px) {
      .top .news-head {
        margin-bottom: 3em; } }
    .top .news-head h2 {
      margin: 0;
      text-align: inherit; }
      .top .news-head h2::before {
        content: none; }
    .top .news-head .title img {
      width: clamp(9.375rem, 6.705rem + 11.39vw, 15.25rem); }
    .top .news-head .gradation-btn {
      margin: 2em 0 0;
      width: clamp(12.5rem, 8.523rem + 16.97vw, 21.25rem);
      max-width: 150px; }
      @media screen and (min-width: 769px) {
        .top .news-head .gradation-btn {
          max-width: inherit; } }
  @media screen and (min-width: 769px) {
    .top .news-list-wrapper {
      display: flex;
      gap: 0 5%;
      justify-content: space-between; } }
  .top .newslist:not(.tab-news-desc) {
    /*jogakuin-blog*/ }
    @media screen and (min-width: 769px) {
      .top .newslist:not(.tab-news-desc) {
        width: 47.5%; } }
    .top .newslist:not(.tab-news-desc) .flex-box {
      display: inherit;
      margin-top: 2em; }
      @media screen and (min-width: 769px) {
        .top .newslist:not(.tab-news-desc) .flex-box {
          display: flex;
          justify-content: space-between;
          align-items: center; } }
      .top .newslist:not(.tab-news-desc) .flex-box .gradation-btn {
        font-size: clamp(0.813rem, 0.727rem + 0.36vw, 1rem);
        margin-left: auto;
        margin-right: inherit;
        margin-top: .5em;
        width: 115px; }
        @media screen and (min-width: 769px) {
          .top .newslist:not(.tab-news-desc) .flex-box .gradation-btn {
            width: 155px; } }
        .top .newslist:not(.tab-news-desc) .flex-box .gradation-btn a {
          padding: 1% 0 2%; }
          @media screen and (min-width: 769px) {
            .top .newslist:not(.tab-news-desc) .flex-box .gradation-btn a {
              padding: 3% 0 4%; } }
    .top .newslist:not(.tab-news-desc) .title {
      margin: 0; }
      .top .newslist:not(.tab-news-desc) .title img {
        height: 25px; }
        @media screen and (min-width: 769px) {
          .top .newslist:not(.tab-news-desc) .title img {
            height: 30px; } }
    .top .newslist:not(.tab-news-desc) ul {
      margin-top: 1em; }
      @media screen and (min-width: 769px) {
        .top .newslist:not(.tab-news-desc) ul {
          margin-top: 2em; } }
      .top .newslist:not(.tab-news-desc) ul li {
        border: none;
        padding: 0; }
        .top .newslist:not(.tab-news-desc) ul li a {
          background: #ebe3ed;
          border-radius: 10px;
          display: block;
          padding: .5em 1.5em;
          position: relative; }
          .top .newslist:not(.tab-news-desc) ul li a::after {
            background: url(../images/top/arrow-purple.svg) no-repeat;
            background-size: contain;
            content: "";
            height: 19px;
            position: absolute;
            right: 4%;
            top: 50%;
            transform: translateY(-50%);
            width: 10px;
            transition: .2s; }
          .top .newslist:not(.tab-news-desc) ul li a:hover::after {
            right: 3%; }
        .top .newslist:not(.tab-news-desc) ul li + li {
          margin-top: 8px; }
        .top .newslist:not(.tab-news-desc) ul li .date {
          color: #752586;
          font-size: clamp(0.75rem, 0.693rem + 0.24vw, 0.875rem);
          font-weight: bold; }
        .top .newslist:not(.tab-news-desc) ul li h5 {
          font-size: clamp(0.875rem, 0.818rem + 0.24vw, 1rem);
          text-decoration: none;
          width: 90%;
          white-space: nowrap;
          overflow: hidden;
          text-overflow: ellipsis; }
        .top .newslist:not(.tab-news-desc) ul li .type {
          margin-right: .25em; }
    .top .newslist:not(.tab-news-desc).entrance-exam ul li a {
      background: #f1efe0;
      padding: .62em 1.5em; }
    .top .newslist:not(.tab-news-desc).jogakuin-blog {
      margin: 4em auto 0;
      width: 90%;
      /*ul*/ }
      @media screen and (min-width: 769px) {
        .top .newslist:not(.tab-news-desc).jogakuin-blog {
          margin-left: auto;
          padding-left: calc((100% - 1080px) / 2);
          width: 100%; } }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .flex-box {
        max-width: 420px; }
      .top .newslist:not(.tab-news-desc).jogakuin-blog ul {
        margin-bottom: 1em; }
        .top .newslist:not(.tab-news-desc).jogakuin-blog ul li {
          border: 1px solid #752586;
          background-image: linear-gradient(90deg, #ffffff, #ebe3ed);
          border-radius: 10px;
          position: relative;
          transition: .2s; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li::after {
            background: url(../images/top/arrow-purple.svg) no-repeat;
            background-size: contain;
            content: "";
            height: 19px;
            position: absolute;
            right: 4%;
            bottom: 2em;
            width: 10px;
            transition: .2s; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li:hover::after {
            right: 3%; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li a {
            background: none;
            padding: 1em; }
            @media screen and (min-width: 1080px) {
              .top .newslist:not(.tab-news-desc).jogakuin-blog ul li a {
                padding: 2em; } }
            .top .newslist:not(.tab-news-desc).jogakuin-blog ul li a::after {
              content: none; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .date {
            text-align: right; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li h5 {
            font-size: clamp(0.875rem, 0.818rem + 0.24vw, 1rem);
            width: inherit;
            white-space: inherit;
            overflow: hidden;
            text-overflow: inherit;
            line-height: 1.6; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image {
            padding-bottom: 0;
            position: relative;
            text-align: center; }
            @media screen and (min-width: 1080px) {
              .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image {
                padding-bottom: .75rem;
                text-align: inherit; } }
            .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image .shape {
              padding: 1PX;
              position: relative;
              min-width: 137px;
              display: inline-block; }
              @media screen and (min-width: 1080px) {
                .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image .shape {
                  display: inherit; } }
              .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image .shape::before {
                content: "";
                background: #752586;
                position: absolute;
                /*top: calc(0.75rem - 1px);
                left: calc(0.75rem - 1px);*/
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                clip-path: polygon(10% 0, 90% 0, 100% 10%, 100% 90%, 90% 100%, 10% 100%, 0 90%, 0 10%);
                z-index: 0;
                height: 137px;
                width: 137px;
                /*@media screen and (min-width:1080px) {
                    height: 137px;
                    width: 137px;
                }*/ }
            .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .image img {
              clip-path: polygon(10% 0, 90% 0, 100% 10%, 100% 90%, 90% 100%, 10% 100%, 0 90%, 0 10%);
              object-fit: cover;
              height: 135px;
              width: 135px;
              position: relative; }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .text-box {
            padding-left: 1em; }
            @media screen and (min-width: 1080px) {
              .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .text-box {
                padding-left: 0; } }
          .top .newslist:not(.tab-news-desc).jogakuin-blog ul li .type-list {
            display: flex;
            flex-wrap: wrap; }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .slick-list {
        margin: 0 -10px;
        padding: 0 10px !important; }
        @media screen and (min-width: 1080px) {
          .top .newslist:not(.tab-news-desc).jogakuin-blog .slick-list {
            padding: 0 !important; } }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .slick-slide {
        margin: 0 10px;
        height: auto !important; }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .slick-track {
        display: flex;
        align-items: stretch; }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .arrow_box {
        display: flex;
        gap: 0 1%;
        margin-left: 1em; }
        @media screen and (min-width: 769px) {
          .top .newslist:not(.tab-news-desc).jogakuin-blog .arrow_box {
            margin-left: 0; } }
      .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow {
        background: #752586;
        border-radius: 50%;
        color: #fff;
        position: relative;
        height: 28px;
        width: 28px;
        transition: .2s; }
        @media screen and (min-width: 769px) {
          .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow {
            height: 48px;
            width: 48px; } }
        .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow span {
          font-size: 14px;
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }
          @media screen and (min-width: 769px) {
            .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow span {
              font-size: 18px; } }
        .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow:hover {
          cursor: pointer;
          opacity: .8; }
        .top .newslist:not(.tab-news-desc).jogakuin-blog .slide-arrow.slick-disabled {
          background: #b2c1c9; }
  .top #new-policy,
  .top .new-policy-sp-text {
    background-image: url("../images/top/new-policy-back-sp.jpg");
    background-size: cover;
    margin-top: 3em;
    /*padding: 23em 0 0;*/
    padding: 0em 0 0;
    position: relative;
    /*scripture-wrapper*/ }
    @media screen and (min-width: 769px) {
      .top #new-policy,
      .top .new-policy-sp-text {
        background: url("../images/top/new-policy-back.jpg") no-repeat center;
        margin-top: 6em;
        padding: 0; } }
    .top #new-policy .inner,
    .top .new-policy-sp-text .inner {
      position: relative;
      padding: 3em 0 3em;
      margin: auto;
      max-width: 1080px; }
      @media screen and (min-width: 769px) {
        .top #new-policy .inner,
        .top .new-policy-sp-text .inner {
          padding: 7em 0 7em; } }
    .top #new-policy .badge,
    .top .new-policy-sp-text .badge {
      background-image: linear-gradient(90deg, #ffe7bd, #d1b0cf);
      color: #752586;
      display: inline-block;
      font-size: clamp(0.938rem, 0.852rem + 0.36vw, 1.125rem);
      padding: .25em 1em;
      margin-bottom: 1em; }
      @media screen and (min-width: 769px) {
        .top #new-policy .badge,
        .top .new-policy-sp-text .badge {
          padding: .5em 1.5em; } }
    .top #new-policy .title,
    .top .new-policy-sp-text .title {
      /*color: #d970b8;*/
      color: #ffcbff;
      font-family: "Shippori Mincho", serif;
      font-size: clamp(1.25rem, 0.369rem + 3.76vw, 3.188rem);
      line-height: 1.8;
      letter-spacing: 1px;
      text-align: left; }
      @media screen and (min-width: 769px) {
        .top #new-policy .title,
        .top .new-policy-sp-text .title {
          color: #ffcbff; } }
      .top #new-policy .title span,
      .top .new-policy-sp-text .title span {
        padding: 0;
        position: relative; }
        .top #new-policy .title span::before, .top #new-policy .title span::after,
        .top .new-policy-sp-text .title span::before,
        .top .new-policy-sp-text .title span::after {
          content: none;
          top: inherit;
          transform: none; }
        .top #new-policy .title span::before, .top #new-policy .title span::after,
        .top .new-policy-sp-text .title span::before,
        .top .new-policy-sp-text .title span::after {
          content: "";
          height: 1px;
          width: 100%;
          background: #ffcbff;
          position: absolute;
          bottom: 0;
          left: 0; }
    .top #new-policy .desc,
    .top .new-policy-sp-text .desc {
      /*color: #000;*/
      color: #fff;
      margin-top: 1em; }
      @media screen and (min-width: 769px) {
        .top #new-policy .desc,
        .top .new-policy-sp-text .desc {
          color: #fff; } }
    .top #new-policy .gradation-btn,
    .top .new-policy-sp-text .gradation-btn {
      font-size: clamp(0.938rem, 0.824rem + 0.48vw, 1.188rem);
      margin: 5% 0 8%; }
    .top #new-policy .scripture-wrapper,
    .top .new-policy-sp-text .scripture-wrapper {
      background: #fff5d9;
      clip-path: polygon(8% 0, 92% 0, 100% 8%, 100% 92%, 94% 100%, 8% 100%, 0 92%, 0 8%);
      padding: 2em 1em;
      max-width: 100%;
      width: 100%; }
      @media screen and (min-width: 769px) {
        .top #new-policy .scripture-wrapper,
        .top .new-policy-sp-text .scripture-wrapper {
          clip-path: polygon(4% 0, 96% 0, 100% 16%, 100% 84%, 96% 100%, 4% 100%, 0 84%, 0 16%);
          padding: 2em 0;
          width: 90%; } }
      .top #new-policy .scripture-wrapper .border-head,
      .top .new-policy-sp-text .scripture-wrapper .border-head {
        text-align: center; }
        .top #new-policy .scripture-wrapper .border-head span,
        .top .new-policy-sp-text .scripture-wrapper .border-head span {
          border: 1px solid #752586;
          border-right: none;
          border-left: none;
          font-size: clamp(0.875rem, 0.761rem + 0.48vw, 1.125rem);
          font-weight: bold;
          padding: .25em 1em .5em; }
      .top #new-policy .scripture-wrapper .head img,
      .top .new-policy-sp-text .scripture-wrapper .head img {
        display: block;
        margin: 2em auto 0;
        max-width: 665px;
        width: 96%; }
      .top #new-policy .scripture-wrapper ul,
      .top .new-policy-sp-text .scripture-wrapper ul {
        margin-top: 2em;
        padding: 0 0em;
        text-align: center; }
        @media screen and (min-width: 769px) {
          .top #new-policy .scripture-wrapper ul,
          .top .new-policy-sp-text .scripture-wrapper ul {
            padding: 0 2em; } }
        .top #new-policy .scripture-wrapper ul li,
        .top .new-policy-sp-text .scripture-wrapper ul li {
          font-weight: bold;
          display: block;
          position: relative; }
          @media screen and (min-width: 769px) {
            .top #new-policy .scripture-wrapper ul li,
            .top .new-policy-sp-text .scripture-wrapper ul li {
              display: inline; } }
          @media screen and (max-width: 769px) {
            .top #new-policy .scripture-wrapper ul li,
            .top .new-policy-sp-text .scripture-wrapper ul li {
              font-size: 13px; } }
          .top #new-policy .scripture-wrapper ul li:nth-child(2),
          .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2) {
            padding: 0;
            margin: .5em 0; }
            @media screen and (min-width: 769px) {
              .top #new-policy .scripture-wrapper ul li:nth-child(2),
              .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2) {
                padding: 0 2.5em;
                margin: 0 1.5em; } }
            .top #new-policy .scripture-wrapper ul li:nth-child(2)::before, .top #new-policy .scripture-wrapper ul li:nth-child(2)::after,
            .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::before,
            .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::after {
              content: none;
              position: absolute;
              top: 0; }
              @media screen and (min-width: 769px) {
                .top #new-policy .scripture-wrapper ul li:nth-child(2)::before, .top #new-policy .scripture-wrapper ul li:nth-child(2)::after,
                .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::before,
                .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::after {
                  content: "／"; } }
            .top #new-policy .scripture-wrapper ul li:nth-child(2)::before,
            .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::before {
              left: 0; }
            .top #new-policy .scripture-wrapper ul li:nth-child(2)::after,
            .top .new-policy-sp-text .scripture-wrapper ul li:nth-child(2)::after {
              right: 0; }
  .top .new-policy-sp-text {
    background: none;
    margin-top: 0;
    padding: 0; }
    .top .new-policy-sp-text .inner {
      background: #fff;
      position: relative;
      padding: 1.5em 1.5em 2em;
      margin: -3em auto 0;
      width: 85%; }
  .top #learning {
    margin-top: 0em;
    padding-top: 2em;
    /*christian-education*/
    /*li*/ }
    @media screen and (min-width: 769px) {
      .top #learning {
        margin-top: 5em;
        padding-top: 4em; } }
    .top #learning h2 {
      margin: auto;
      max-width: 1080px;
      padding-top: 0;
      width: 80%; }
      @media screen and (min-width: 769px) {
        .top #learning h2 {
          padding-top: 28px; } }
      .top #learning h2::before {
        content: none; }
      .top #learning h2 img {
        width: 100%; }
    .top #learning .christian-education {
      background: url("../images/top/christian-education-back.jpg") no-repeat center;
      background-size: cover;
      margin: 2em 0 3em; }
      @media screen and (min-width: 769px) {
        .top #learning .christian-education {
          margin: 4em 0 6em; } }
      .top #learning .christian-education .inner {
        padding: 2.5em 0;
        margin: auto;
        max-width: 1080px; }
        @media screen and (min-width: 769px) {
          .top #learning .christian-education .inner {
            padding: 5em 0; } }
      .top #learning .christian-education .head-wrapper {
        color: #fff;
        padding-bottom: clamp(9rem, -1.727rem + 32.97vw, 23rem); }
        .top #learning .christian-education .head-wrapper .text {
          font-size: clamp(0.875rem, 0.705rem + 0.73vw, 1.25rem);
          line-height: 1.6;
          margin: 0; }
        .top #learning .christian-education .head-wrapper h4 {
          font-family: "Shippori Mincho", serif;
          font-size: clamp(1.5rem, 0.085rem + 4.97vw, 3.813rem);
          line-height: 1;
          margin-top: .1em; }
        .top #learning .christian-education .head-wrapper .en {
          line-height: 1;
          margin-top: .5em; }
          @media screen and (min-width: 769px) {
            .top #learning .christian-education .head-wrapper .en {
              margin-top: 1.5em; } }
          .top #learning .christian-education .head-wrapper .en img {
            height: 10px; }
            @media screen and (min-width: 769px) {
              .top #learning .christian-education .head-wrapper .en img {
                height: 16px; } }
      .top #learning .christian-education .gradation-btn {
        font-size: clamp(0.938rem, 0.824rem + 0.48vw, 1.188rem);
        margin: 0;
        margin-left: auto;
        max-width: 384px; }
    .top #learning li {
      margin-bottom: 5%;
      padding: 0;
      /*li*/ }
      .top #learning li div {
        background: #fff;
        position: relative; }
        @media screen and (max-width: 769px) {
          .top #learning li div {
            margin-left: auto !important;
            margin-top: -1.5em !important;
            width: 85%; } }
        .top #learning li div .wrap-link {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          text-indent: -999px; }
      .top #learning li .columns {
        margin: 0; }
      .top #learning li .desc {
        padding-right: .75rem;
        position: relative;
        width: 100%; }
        @media screen and (min-width: 769px) {
          .top #learning li .desc {
            padding-right: 14%;
            width: 66.66667%; } }
        .top #learning li .desc::after {
          /*background: url(../images/common/link_arrow.jpg) no-repeat;*/
          background: url(../images/top/arrow-black.svg) no-repeat;
          background-size: contain;
          content: "";
          height: 14px;
          margin: auto 0;
          position: absolute;
          bottom: 0;
          top: 0;
          right: 8%;
          width: 10px; }
        .top #learning li .desc h4 {
          color: #752586;
          font-size: 22px;
          margin-bottom: 0%; }
          @media screen and (min-width: 769px) {
            .top #learning li .desc h4 {
              color: #222;
              margin-bottom: 4%; } }
        @media screen and (max-width: 769px) {
          .top #learning li .desc .text {
            margin-bottom: .5em; } }
      @media screen and (max-width: 769px) {
        .top #learning li .image {
          width: 90%; } }
      @media screen and (max-width: 769px) {
        .top #learning li .en {
          line-height: 1; } }
      @media screen and (max-width: 769px) {
        .top #learning li .en img {
          height: 8px; } }
      .top #learning li li div {
        background: #fff; }
        @media screen and (max-width: 769px) {
          .top #learning li li div {
            margin-left: 0 !important;
            margin-top: 0 !important; } }
        .top #learning li li div .image {
          max-width: 300px; }
        .top #learning li li div .text-box {
          padding: 1em;
          position: relative; }
          .top #learning li li div .text-box::after {
            background: url(../images/top/arrow-black.svg) no-repeat;
            background-size: contain;
            content: "";
            height: 19px;
            position: absolute;
            right: 6%;
            top: 50%;
            transform: translateY(-50%);
            width: 10px; }
        .top #learning li li div h4 {
          font-family: "Shippori Mincho", serif;
          font-size: clamp(1rem, 0.83rem + 0.73vw, 1.375rem); }
        .top #learning li li div .en {
          line-height: 1; }
          .top #learning li li div .en img {
            height: 5px; }
            @media screen and (min-width: 769px) {
              .top #learning li li div .en img {
                height: 10px; } }
      .top #learning li li:nth-child(odd) {
        /*padding: 0 .75rem 0 0;*/ }
      .top #learning li li:nth-child(even) {
        /*padding: 0 0 0 .75rem;*/ }
    .top #learning .learning-content {
      width: 78%; }
      @media screen and (min-width: 769px) {
        .top #learning .learning-content {
          width: 90%; } }
    @media screen and (max-width: 769px) {
      .top #learning .last-column ul {
        flex-wrap: wrap;
        justify-content: space-between; } }
    @media screen and (max-width: 769px) {
      .top #learning .last-column ul li {
        width: 50%; } }
    @media screen and (max-width: 769px) {
      .top #learning .last-column ul li div {
        width: 99%; } }
    @media screen and (max-width: 769px) {
      .top #learning .last-column ul li:last-child {
        margin-left: auto;
        margin-right: auto; } }
  .top .bible {
    background: url(../images/top/border.png);
    outline: .5px solid #ae8046;
    outline-offset: -5px;
    padding: 7px;
    text-align: center; }
    .top .bible .box {
      background: url(../images/learning/policy/frame_left.png), url(../images/learning/policy/frame_right.png), url(../images/learning/policy/frame_left2.png), url(../images/learning/policy/frame_right2.png);
      background-repeat: no-repeat;
      background-position: left top,right top,left bottom,right bottom;
      background-size: 35px;
      padding: 3%; }
    .top .bible h5 {
      color: #6a3906;
      font-size: 2.1em;
      line-height: 1.3; }
      .top .bible h5 span {
        display: block;
        color: #000;
        font-size: 0.5em; }
    .top .bible p {
      font-size: 0.8em; }
      .top .bible p span {
        color: #000;
        display: block;
        font-size: 1.3em;
        margin-bottom: 1%; }
  @media screen and (min-width: 769px) {
    .top .banner-slider {
      margin-top: 5%; }
    .top #learning .inner {
      max-width: 1080px; }
    .top #learning li {
      padding: 0 .75rem; }
      .top #learning li div {
        background: transparent; }
      .top #learning li .image {
        max-width: 486px; }
      .top #learning li .desc {
        background: #fff;
        padding: 1.5em 2em;
        margin-top: -3.5em;
        margin-left: auto;
        width: clamp(14rem, 8.347rem + 24.12vw, 26.438rem); }
        .top #learning li .desc::after {
          content: none; }
        .top #learning li .desc h4 {
          color: #752586;
          font-size: 32px;
          margin-bottom: 0; }
        .top #learning li .desc .text {
          margin: 0; }
        .top #learning li .desc .en {
          line-height: 1; }
          .top #learning li .desc .en img {
            height: 10px; }
      .top #learning li .gradation-btn {
        margin-top: 1em;
        margin-left: auto;
        max-width: 225px; }
        .top #learning li .gradation-btn a {
          padding: .75em 0 .75em; }
    .top .bible .box {
      padding: 1%; }
    .top .bible h5 {
      font-size: 2.5em; } }

/***********************************************************************
message
**********************************************************************/
.message .img-box {
  margin: 0 auto;
  width: 50%; }
.message .name {
  font-size: 1.2em;
  text-align: right; }
  .message .name small {
    margin-right: 1em; }
@media screen and (min-width: 769px) {
  .message h3 + p {
    line-height: 2; }
  .message .img-box {
    width: 33.33333%; } }

/***********************************************************************
idea
**********************************************************************/
.idea #idea {
  margin-bottom: 6%; }
  .idea #idea .idea-list {
    margin: 4em auto 0;
    max-width: 820px;
    			/*li{
    				margin: 0 0 3%;
    
    				.column:first-child{
    					padding-left: 0;
    				}
    				.column:last-child{
    					padding-right: 0;
    				}
    
    				&:nth-child(odd){
    					.column.is-10 p{
    						margin-right: 5%;
    					}
    				}
    				&:nth-child(even){
    					.column.is-10 p{
    						margin-left: 5%;
    					}
    				}
    
    				.column.is-2{
    					text-align: center;
    					padding: .6rem;
    				}
    			}
    			p{
    				margin-top: 2em;
    			}*/ }
    @media screen and (max-width: 769px) {
      .idea #idea .idea-list {
        margin-top: 2em;
        width: 90%; } }
    .idea #idea .idea-list h4 {
      color: #752586;
      font-size: clamp(1.25rem, 0.909rem + 1.45vw, 2rem);
      border-bottom: 1px solid #c08fbe;
      padding-bottom: .25em; }
    .idea #idea .idea-list p {
      font-size: clamp(0.875rem, 0.79rem + 0.36vw, 1.063rem);
      margin-top: .5em; }
    .idea #idea .idea-list img {
      margin-top: 1.25em;
      width: 100%; }
    .idea #idea .idea-list li + li {
      margin-top: 2em; }
      @media screen and (max-width: 769px) {
        .idea #idea .idea-list li + li {
          margin-top: 1em; } }
.idea #school-badge {
  border-radius: 50% 50% 0 0 / 8% 8% 0 0; }
  .idea #school-badge h4 {
    border-bottom: 1px solid;
    border-top: 1px solid;
    color: #752586;
    font-size: clamp(1.063rem, 0.693rem + 1.58vw, 1.875rem);
    margin-bottom: 7%;
    padding: 2% 0 2%;
    text-align: center; }
  .idea #school-badge .image {
    padding-bottom: 7%;
    text-align: center; }
.idea #school-song {
  margin-top: 10%; }
  .idea #school-song ul {
    text-align: center; }
  .idea #school-song li {
    display: inline-block;
    line-height: 1.8;
    margin-bottom: 7%;
    margin-left: 5%;
    text-align: left; }
  .idea #school-song .column.is-7 {
    text-align: center; }
    .idea #school-song .column.is-7 img {
      max-width: 200px; }
  .idea #school-song .audio-box {
    text-align: center; }
    .idea #school-song .audio-box p {
      margin-bottom: 1%; }
@media screen and (min-width: 769px) {
  .idea {
    /*#idea .idea-list p{
    	margin-left: 5%;
    	margin-right: 5%;
    }*/ }
    .idea #school-song {
      margin-top: 5%; }
      .idea #school-song ul {
        text-align: left; }
      .idea #school-song .column.is-7 img {
        max-width: 300px; } }

/***********************************************************************
history
**********************************************************************/
.history #history {
  margin-bottom: 8%; }
  .history #history .img-box {
    margin: 0 auto;
    width: 80%; }

@media screen and (max-width: 769px) {
  .history .img-logo {
    margin: 0 auto;
    width: 60%; } }
/***********************************************************************
introduction
**********************************************************************/
.introduction #guide, .introduction #publicity {
  margin-bottom: 5%; }
.introduction #guide, .introduction #publicity, .introduction #media {
  text-align: center; }
  .introduction #guide .column, .introduction #publicity .column, .introduction #media .column {
    max-width: 287px; }
  .introduction #guide img, .introduction #publicity img, .introduction #media img {
    margin-bottom: 4%;
    width: 77%; }
  .introduction #guide p, .introduction #publicity p, .introduction #media p {
    color: #231815;
    margin-bottom: 7%; }

/***********************************************************************
access
**********************************************************************/
.access #access h4 {
  font-size: 1.15em;
  margin-bottom: 2%; }
.access #access .address {
  border-left: 7px solid #804793;
  padding-left: 3%; }
.access #access iframe {
  margin-bottom: 5%; }
.access #access .traffic {
  text-align: center; }
@media screen and (min-width: 769px) {
  .access #access iframe {
    height: 400px; }
  .access #access .traffic {
    margin: 0 auto;
    width: 60%; } }

/***********************************************************************
policy
**********************************************************************/
.policy #christianity {
  margin-bottom: 9%; }
.policy .policy-list {
  background: #dfdfd8;
  margin: 0 auto 10%;
  max-width: 920px;
  outline: 1px solid #9a8046;
  outline-offset: -6px;
  padding-top: 6%;
  position: relative; }
  .policy .policy-list::before {
    background: url(../images/learning/policy/frame_left.png) no-repeat;
    background-size: contain;
    content: "";
    height: 8%;
    position: absolute;
    left: 10px;
    top: 10px;
    width: 19%; }
  .policy .policy-list::after {
    background: url(../images/learning/policy/frame_right.png) no-repeat right;
    background-size: contain;
    content: "";
    height: 8%;
    position: absolute;
    right: 10px;
    top: 10px;
    width: 19%; }
  .policy .policy-list .head {
    background: url(../images/learning/policy/border.png);
    margin-bottom: 3%;
    padding: 3% 0 5%;
    text-align: center; }
    .policy .policy-list .head h5 {
      color: #6a3906;
      font-size: 2.1em;
      text-shadow: 0 0 0px #a47a19, 0 0 1px #a47a19, 0 0 0.40px #a47a19; }
      .policy .policy-list .head h5 span {
        display: block;
        color: #000;
        font-size: 0.6em;
        margin-bottom: 2%;
        text-shadow: none; }
    .policy .policy-list .head p span {
      color: #000;
      display: block;
      font-size: 1.1em;
      margin-bottom: 1%; }
  .policy .policy-list li {
    padding: 12% 0 4%; }
    .policy .policy-list li h6 {
      color: #231815;
      font-size: 1.7em;
      line-height: 1.2;
      padding-left: 65px;
      position: relative; }
      .policy .policy-list li h6 small {
        font-size: 0.6em; }
      .policy .policy-list li h6::before {
        background: url(../images/learning/policy/one.png) no-repeat;
        background-size: contain;
        content: "";
        height: 87px;
        position: absolute;
        left: 0;
        width: 45px; }
    .policy .policy-list li:nth-child(2) {
      border-bottom: 1px solid #806134;
      border-top: 1px solid #806134; }
      .policy .policy-list li:nth-child(2) h6::before {
        background: url(../images/learning/policy/two.png) no-repeat;
        background-size: contain; }
    .policy .policy-list li:last-child h6::before {
      background: url(../images/learning/policy/three.png) no-repeat;
      background-size: contain; }
.policy #learning li {
  margin-bottom: 8%; }
.policy #learning h5 {
  border-bottom: 5px double #af8762;
  border-top: 5px double #af8762;
  color: #6a3906;
  margin-bottom: 6%;
  padding: 1.5% 0;
  font-size: 1.1em;
  text-shadow: 0 0 0px #a47a19, 0 0 1px #a47a19, 0 0 0px #a47a19;
  text-align: center; }
.policy #learning .columns:not(:last-child) {
  margin: 0; }
  .policy #learning .columns:not(:last-child) .column:first-child {
    padding-bottom: 0; }
.policy #learning p {
  /*text-align: center;*/ }
@media screen and (min-width: 769px) {
  .policy #christianity {
    margin-bottom: 5%; }
  .policy .policy-list {
    margin-bottom: 5%;
    padding-top: 3%; }
    .policy .policy-list .head {
      margin-bottom: 0;
      padding: 2% 0 3%; }
      .policy .policy-list .head h5 {
        font-size: 3em; }
        .policy .policy-list .head h5 span {
          margin-bottom: 0; }
    .policy .policy-list li {
      padding: 6% 0 5%; }
      .policy .policy-list li:last-child {
        padding: 6% 0 8%; } }

/***********************************************************************
learning
**********************************************************************/
.learning {
  /*learning-overview*/ }
  .learning .inner {
    max-width: 1030px;
    width: 100%; }
  .learning .text {
    margin: auto;
    max-width: 920px;
    width: 86%; }
  .learning #learning-overview {
    /*inner*/ }
    .learning #learning-overview .inner {
      position: relative; }
      .learning #learning-overview .inner .image {
        position: relative;
        z-index: 0; }
      .learning #learning-overview .inner .float-btn {
        position: absolute; }
        .learning #learning-overview .inner .float-btn.item1 {
          max-width: 240px;
          width: 24%;
          top: 28%;
          left: 11%; }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item1 {
              width: 31%;
              top: 26%;
              left: 6%; } }
        .learning #learning-overview .inner .float-btn.item2 {
          max-width: 260px;
          width: 26%;
          top: 15%;
          left: 26%; }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item2 {
              width: 31%;
              top: 13%;
              left: 22%; } }
        .learning #learning-overview .inner .float-btn.item3 {
          max-width: 210px;
          width: 21%;
          top: 16%;
          left: 50%; }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item3 {
              width: 27%;
              top: 14%;
              left: 46%; } }
        .learning #learning-overview .inner .float-btn.item4 {
          max-width: 190px;
          width: 19%;
          top: 28%;
          left: 66%; }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item4 {
              width: 26%;
              top: 25%;
              left: 62%; } }
        .learning #learning-overview .inner .float-btn.item5 {
          max-width: 260px;
          width: 26%;
          top: 45%;
          left: 50%;
          transform: translate(-50%, 0); }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item5 {
              width: 32%; } }
        .learning #learning-overview .inner .float-btn.item6 {
          max-width: 190px;
          width: 19%;
          top: 60.5%;
          left: 50%;
          transform: translate(-50%, 0); }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item6 {
              width: 23%;
              top: 59.5%; } }
        .learning #learning-overview .inner .float-btn.item7 {
          max-width: 340px;
          width: 34%;
          top: 65.5%;
          left: 50%;
          transform: translate(-50%, 0); }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item7 {
              width: 36%; } }
        .learning #learning-overview .inner .float-btn.item8 {
          max-width: 275px;
          width: 27.5%;
          top: 71.25%;
          left: 50%;
          transform: translate(-50%, 0); }
          @media screen and (max-width: 769px) {
            .learning #learning-overview .inner .float-btn.item8 {
              width: 29.5%; } }
        .learning #learning-overview .inner .float-btn.item9 {
          max-width: 400px;
          width: 40%;
          bottom: 11.5%;
          left: 50%;
          transform: translate(-50%, 0); }

/*learning*/
/***********************************************************************
feature
**********************************************************************/
.feature #point {
  /*li*/ }
  .feature #point .head-mincho {
    max-width: 330px;
    margin: 0 auto 1.8em;
    position: relative; }
    .feature #point .head-mincho::before {
      background: url(../images/learning/feature/h5_left.png) no-repeat left;
      background-size: contain;
      content: "";
      height: 100%;
      position: absolute;
      left: 0;
      width: 19%; }
    .feature #point .head-mincho::after {
      background: url(../images/learning/feature/h5_right.png) no-repeat right;
      background-size: contain;
      content: "";
      height: 100%;
      position: absolute;
      right: 0;
      width: 19%; }
  .feature #point li {
    margin-bottom: 7%;
    padding: 0 1.5%; }
    .feature #point li .columns {
      align-items: center;
      background-image: radial-gradient(circle at 0% 0%, transparent 5px, #ede5f1 0), radial-gradient(circle at 100% 0%, transparent 5px, #ede5f1 0), radial-gradient(circle at 0% 100%, transparent 5px, #ede5f1 0), radial-gradient(circle at 100% 100%, transparent 5px, #ede5f1 0);
      background-position: 0% 0%, 100% 0%, 0% 100%, 100% 100%;
      background-repeat: no-repeat;
      background-size: 55% 55%;
      position: relative; }
      .feature #point li .columns::before {
        border-top: 1px solid #fff;
        content: "";
        height: 1px;
        margin: 0 auto;
        position: absolute;
        top: 3px;
        left: 0;
        right: 0;
        width: 94%; }
      .feature #point li .columns::after {
        border-top: 1px solid #fff;
        content: "";
        height: 1px;
        margin: 0 auto;
        position: absolute;
        bottom: 3px;
        left: 0;
        right: 0;
        width: 94%; }
      .feature #point li .columns a {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        text-indent: -999px; }
    .feature #point li p {
      font-size: 1em; }
    .feature #point li h6 {
      color: #752586;
      font-size: 1.5em; }
      @media screen and (max-width: 769px) {
        .feature #point li h6 {
          font-size: 1.2em; } }
    .feature #point li.christianity .columns {
      background-image: radial-gradient(circle at 0% 0%, transparent 5px, #dcdacc 0), radial-gradient(circle at 100% 0%, transparent 5px, #dcdacc 0), radial-gradient(circle at 0% 100%, transparent 5px, #dcdacc 0), radial-gradient(circle at 100% 100%, transparent 5px, #dcdacc 0); }
    .feature #point li.christianity h6 {
      color: #804f21; }
    .feature #point li:first-child {
      display: block;
      margin-left: auto;
      margin-right: auto; }
@media screen and (min-width: 769px) {
  .feature #point .head-mincho {
    max-width: 700px; }
    .feature #point .head-mincho::before {
      left: 20%; }
    .feature #point .head-mincho::after {
      right: 20%; }
  .feature #point li {
    display: inline-block;
    margin-bottom: 4%;
    width: 49%; }
    .feature #point li .column.is-7 {
      zoom: 1.15; } }

/***********************************************************************
program
**********************************************************************/
.program .purple-box {
  background-image: radial-gradient(circle at 0% 0%, transparent 5px, #e9dfee 0), radial-gradient(circle at 100% 0%, transparent 5px, #e9dfee 0), radial-gradient(circle at 0% 100%, transparent 5px, #e9dfee 0), radial-gradient(circle at 100% 100%, transparent 5px, #e9dfee 0);
  background-position: 0% 0%, 100% 0%, 0% 100%, 100% 100%;
  background-repeat: no-repeat;
  background-size: 55% 55%;
  outline: 1px solid #752586;
  outline-offset: -4px;
  max-width: 550px;
  margin: 0 auto 2.2em;
  padding: 5%; }
.program .grade {
  margin-bottom: 2%;
  text-align: center; }
.program .table, .program .table + p {
  max-width: 670px;
  margin: 0 auto; }
.program .table th {
  width: 20%; }
  @media screen and (max-width: 769px) {
    .program .table th {
      width: 20%; } }
.program .table td {
  width: 80%; }
  @media screen and (max-width: 769px) {
    .program .table td {
      width: 80%; } }
.program .table th, .program .table td {
  padding: 1% 3%; }
.program #start {
  margin-bottom: 8%; }
.program #themed-research {
  margin-top: -200px;
  padding-top: 200px; }
  @media screen and (max-width: 769px) {
    .program #themed-research {
      margin-top: -100px;
      padding-top: 100px; } }
  .program #themed-research .table tr:first-child th:first-child {
    background: #d6d6d0; }
  .program #themed-research .table tr:first-child th:last-child {
    background: #cdccbf; }
  .program #themed-research .head-td span {
    background: linear-gradient(transparent 0%, transparent 70%, #d6d6d0 70%, #d6d6d0 100%); }
.program #extensive-program {
  margin-top: -200px;
  padding-top: 200px; }
  @media screen and (max-width: 769px) {
    .program #extensive-program {
      margin-top: -100px;
      padding-top: 100px; } }
  .program #extensive-program .table tr:first-child th:first-child {
    background: #ffecb8; }
  .program #extensive-program .table tr:first-child th:last-child {
    background: #ece285; }
  .program #extensive-program .head-td span {
    background: linear-gradient(transparent 0%, transparent 70%, #ffeaa2 70%, #ffeaa2 100%); }

/***********************************************************************
peace-studie
**********************************************************************/
.peace-studies .table + p,
.global .table + p {
  text-align: right; }
.peace-studies strong,
.global strong {
  font-size: 1.3em; }
.peace-studies #thinking,
.global #thinking {
  margin-bottom: 7%; }
  .peace-studies #thinking .image,
  .global #thinking .image {
    margin: 0 auto 5%;
    max-width: 550px; }
.peace-studies #efforts img,
.global #efforts img {
  margin-bottom: 5%; }
.peace-studies #efforts h4,
.global #efforts h4 {
  color: #752586;
  font-size: 1.3em;
  margin-bottom: 0.7em; }
@media screen and (min-width: 769px) {
  .peace-studies #efforts h4,
  .global #efforts h4 {
    font-size: 1.5em; } }

/***********************************************************************
global-issues
**********************************************************************/
.global-issues #global-issues {
  margin-bottom: 8%; }
  .global-issues #global-issues h5 {
    font-size: 1.1em;
    margin-bottom: 2%; }
  .global-issues #global-issues .back-beige {
    padding: 6%; }
    .global-issues #global-issues .back-beige h5 {
      color: #866134;
      font-size: 1.3em;
      margin: 0 auto 2%;
      max-width: 465px;
      position: relative;
      text-align: center; }
      .global-issues #global-issues .back-beige h5::after, .global-issues #global-issues .back-beige h5::before {
        color: #866134;
        content: "・";
        line-height: 1;
        position: absolute;
        top: 50%;
        transform: translateY(-50%); }
      .global-issues #global-issues .back-beige h5::after {
        right: 0; }
      .global-issues #global-issues .back-beige h5::before {
        left: 0; }
      .global-issues #global-issues .back-beige h5 span {
        display: inline-block;
        margin: auto;
        position: relative;
        width: 90%; }
        .global-issues #global-issues .back-beige h5 span::after, .global-issues #global-issues .back-beige h5 span::before {
          content: "";
          height: 1px;
          position: absolute;
          top: 50%;
          transform: translateY(-50%);
          width: 50%; }
        .global-issues #global-issues .back-beige h5 span::after {
          background: linear-gradient(90deg, transparent 0%, transparent 33%, #866134 33%, #866134 100%);
          right: 0; }
        .global-issues #global-issues .back-beige h5 span::before {
          background: linear-gradient(270deg, transparent 0%, transparent 33%, #866134 33%, #866134 100%);
          left: 0; }
  .global-issues #global-issues li div {
    background: #fff;
    border-radius: 7px;
    padding: 5%; }
.global-issues #training h4 {
  color: #752586;
  font-size: 1.3em;
  margin-bottom: 3%; }
.global-issues #training h6 {
  font-size: 1.1em;
  margin: 0% 0 3%; }
  @media screen and (min-width: 769px) {
    .global-issues #training h6 {
      margin: 4% 0 3%; } }
  .global-issues #training h6 + p {
    margin-bottom: 4%; }
@media screen and (min-width: 769px) {
  .global-issues #global-issues {
    margin-bottom: 5%; }
    .global-issues #global-issues h5 {
      font-size: 1.15em;
      margin-bottom: 1%; }
    .global-issues #global-issues .back-beige {
      padding: 3%; }
  .global-issues #training h4 {
    font-size: 1.7em; } }

/***********************************************************************
training
**********************************************************************/
.training #activity,
.global #activity {
  margin-bottom: 12%;
    	/*margin-top: -200px;
		padding-top: 200px;*/
  padding-top: 5%; }
  .training #activity h5,
  .global #activity h5 {
    background: url(../images/learning/training/border.png) repeat-x center;
    margin-bottom: 1em;
    margin-top: 3em;
    text-align: center; }
    .training #activity h5 span,
    .global #activity h5 span {
      background: #fff;
      color: #752586;
      font-size: 1.1em;
      padding: 0 5%; }
.training #training,
.global #training {
    	/*margin-top: -200px;
		padding-top: 200px;*/
  margin-top: 11%; }
  @media screen and (min-width: 769px) {
    .training #training,
    .global #training {
      margin-top: 8%; } }
  .training #training h6,
  .global #training h6 {
    font-size: 1.1em;
    margin: 0% 0 3%; }
    @media screen and (min-width: 769px) {
      .training #training h6,
      .global #training h6 {
        margin: 4% 0 3%; } }
    .training #training h6 + p,
    .global #training h6 + p {
      margin-bottom: 4%; }
  .training #training .back-beige,
  .global #training .back-beige {
    margin-bottom: 6%; }
  .training #training .table tr:not(:first-child) th,
  .global #training .table tr:not(:first-child) th {
    background: #e8e8e8; }
  .training #training .table td,
  .global #training .table td {
    background: #fff; }
  .training #training .table + p,
  .global #training .table + p {
    text-align: right; }
@media screen and (min-width: 769px) {
  .training #activity,
  .global #activity {
    margin-bottom: 7%; }
  .training #training .back-beige,
  .global #training .back-beige {
    margin-bottom: 3%; }
  .training #training h6,
  .global #training h6 {
    font-size: 1.2em;
    margin: 4% 0 1%; }
  .training #training .box h6,
  .global #training .box h6 {
    margin: 0 0 1%; } }

/***********************************************************************
consistency
**********************************************************************/
.consistency {
  /*learning-flow-wrapper*/
  /*===========
  scrollbar
  ===========*/
  /*スクロールバー全体の高さ*/
  /*スクロールバー全体の背景*/
  /*スクロールバーの動く部分*/
  /*スクロールバーの動く部分のホバー（マウスオーバー）*/ }
  .consistency #learning .tab-desc {
    padding: 5% 0 0; }
    .consistency #learning .tab-desc:last-child {
      padding: 5% 0; }
  .consistency .head-td {
    font-size: 1.5em; }
    @media screen and (max-width: 769px) {
      .consistency .head-td {
        font-size: 1.2em; } }
  .consistency .learning-flow-wrapper {
    padding: 3% 0 4%;
    margin: 0 0 4%; }
    .consistency .learning-flow-wrapper .all-flow {
      margin: 5% 0 7%; }
      @media screen and (max-width: 769px) {
        .consistency .learning-flow-wrapper .all-flow .scroll-box {
          overflow-x: auto;
          padding-bottom: 10px;
          -webkit-overflow-scrolling: touch; } }
      @media screen and (max-width: 769px) {
        .consistency .learning-flow-wrapper .all-flow .scroll-box img {
          max-width: 100%;
          min-width: 1000px;
          vertical-align: top; } }
      .consistency .learning-flow-wrapper .all-flow .gradation-btn {
        margin: 2% auto 0; }
  .consistency .scroll-box::-webkit-scrollbar {
    height: 4px; }
  .consistency .scroll-box::-webkit-scrollbar-track {
    background: #eee; }
  .consistency .scroll-box::-webkit-scrollbar-thumb {
    background: #aaa;
    border: none; }
  .consistency .scroll-box::-webkit-scrollbar-thumb:hover {
    background: #999; }
  .consistency .teacher-wrapper {
    margin: 7% 0 5%; }
    @media screen and (max-width: 769px) {
      .consistency .teacher-wrapper {
        margin: 12% 0 5%; } }
  .consistency .teacher-box {
    margin: 0; }
    .consistency .teacher-box .image {
      margin: 0 10%;
      padding: 5%; }
      @media screen and (max-width: 769px) {
        .consistency .teacher-box .image {
          padding: 0; } }
    .consistency .teacher-box .text {
      padding: 0 5% 3%; }
      @media screen and (max-width: 769px) {
        .consistency .teacher-box .text {
          padding: auto; } }
    .consistency .teacher-box h5 {
      font-size: 1.3em;
      margin-bottom: 5%;
      padding-left: 85px;
      position: relative;
      letter-spacing: 0; }
      .consistency .teacher-box h5 span {
        color: #fff;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
        font-size: 0.8em;
        line-height: 47px;
        letter-spacing: 0;
        position: absolute;
        bottom: 0;
        left: 0;
        text-align: center;
        width: 75px; }
        .consistency .teacher-box h5 span::before, .consistency .teacher-box h5 span::after {
          border-top: 1px solid #fff;
          content: "";
          position: absolute;
          left: 0;
          width: 100%; }
        .consistency .teacher-box h5 span::before {
          top: 4px; }
        .consistency .teacher-box h5 span::after {
          bottom: 4px; }
    .consistency .teacher-box.teacher1 {
      background: #ffd8d5; }
      .consistency .teacher-box.teacher1 h5 {
        color: #fe5c64; }
        .consistency .teacher-box.teacher1 h5 span {
          background: #fe5c64; }
    .consistency .teacher-box.teacher2 {
      background: #c8eaf2; }
      .consistency .teacher-box.teacher2 h5 {
        color: #00adce; }
        .consistency .teacher-box.teacher2 h5 span {
          background: #00adce; }
  @media screen and (min-width: 769px) {
    .consistency #learning .tab-btn {
      font-size: 1.5em; }
    .consistency #learning .tab-desc {
      padding: 1% 0 0; }
      .consistency #learning .tab-desc:last-child {
        padding: 0 0 3%; }
    .consistency .teacher-box .image {
      margin: 0; }
    .consistency .teacher-box h5 {
      font-size: 1.67em;
      margin-bottom: 3%;
      padding-left: 95px; }
      .consistency .teacher-box h5 span {
        line-height: 62px;
        width: 80px; } }
  .consistency .ict-box {
    border: 1px solid #752586;
    margin: 5% 0 0;
    padding: 3%; }
    @media screen and (max-width: 769px) {
      .consistency .ict-box {
        margin: 12% 0 0; } }
    .consistency .ict-box h6 {
      font-size: 1em;
      position: relative;
      text-align: center;
      /*&:before{
          content: "";
          background: url(../images/subject-education/consistency/ribon.svg) no-repeat;
          display: inline-block;
          margin: auto;
          position: absolute;
          left: 0;
          right: 0;
          top: 0;
          height: 22px;
          width: 74px;
      }*/ }
      @media screen and (min-width: 769px) {
        .consistency .ict-box h6 {
          font-size: 1.5em; } }
      .consistency .ict-box h6 span {
        background: #752586;
        color: #fff;
        display: block;
        padding: 3px 0 5px; }
    .consistency .ict-box .copperplate {
      color: #752586; }
    .consistency .ict-box .head {
      color: #752586;
      font-size: 1.7em;
      margin: 4% 0 4%;
      text-align: center; }
      @media screen and (min-width: 769px) {
        .consistency .ict-box .head {
          font-size: 2.5em; } }
    .consistency .ict-box ul li {
      line-height: 200%; }
      .consistency .ict-box ul li a {
        color: #752586;
        text-decoration: underline; }

/***********************************************************************
current message
**********************************************************************/
.current-message .text {
  margin: 0 auto 7%; }
  @media screen and (min-width: 769px) {
    .current-message .text {
      max-width: 720px;
      margin: 0 auto 5%; } }
.current-message .box {
  padding: 2%;
  max-width: 870px;
  margin: 0 auto 2%; }
  .current-message .box + .box {
    margin: 8% auto 0; }
    @media screen and (min-width: 769px) {
      .current-message .box + .box {
        margin: 2% auto 0; } }
  .current-message .box .text {
    margin: 0 auto 0%; }
.current-message .flex-reverse {
  flex-direction: row-reverse; }
.current-message .flex-box {
  display: flex;
  gap: 0 5%; }
  @media screen and (max-width: 769px) {
    .current-message .flex-box {
      display: inherit; } }
.current-message .interview-box {
  width: 47.5%; }
  @media screen and (max-width: 769px) {
    .current-message .interview-box {
      width: 100%; } }
  @media screen and (max-width: 769px) {
    .current-message .interview-box + .interview-box {
      margin-top: 2em; } }
.current-message .column-single .image {
  margin-bottom: 1em; }
.current-message .column-single .text {
  max-width: inherit; }
.current-message .column-single .head-sub {
  margin-top: .5rem; }
  .current-message .column-single .head-sub span {
    padding: 0 2% 0.5%; }
@media screen and (max-width: 769px) {
  .current-message .column-single .awards-table {
    margin-top: 1rem; } }
.current-message .column-single .awards-table th {
  border: 2px solid #752586;
  border-left: none;
  border-right: none;
  color: #752586;
  vertical-align: middle;
  padding: 0 1rem; }
  @media screen and (max-width: 769px) {
    .current-message .column-single .awards-table th {
      padding: 0 .5rem; } }
.current-message .column-single .awards-table td {
  color: #752586;
  padding-left: 1rem; }

/*current-message*/
/***********************************************************************
english
**********************************************************************/
.english {
  /*small-class*/ }
  .english #about {
    margin-bottom: 5%; }
    .english #about .gradation-btn {
      margin-top: -0.5em;
      margin-bottom: 3em;
      max-width: 244px; }
      .english #about .gradation-btn a {
        padding: 6% 0 7%; }
  .english #flow {
    margin-bottom: 3em;
    /*.text{
    	padding-top: 30px;
    	position: relative;
    	
    	&::before{
    		border-right: 3px dotted #9f8677;
    		content: "";
    		height: 21px;
    		margin: auto;
    		position: absolute;
    		top: -5px;
    		left: 0;
    		right: 0;
    		width: 3px;
    	}
    }*/ }
    .english #flow ul.columns {
      overflow-x: scroll;
      margin-left: 0;
      margin-top: 3em;
      padding-bottom: 2%; }
      .english #flow ul.columns::-webkit-scrollbar {
        height: 6px; }
      .english #flow ul.columns::-webkit-scrollbar-track {
        border-radius: 5px;
        background: #eee; }
      .english #flow ul.columns::-webkit-scrollbar-thumb {
        border-radius: 5px;
        background: #666; }
    .english #flow li.column {
      list-style: none;
      position: relative;
      width: 310px;
      z-index: 10; }
      .english #flow li.column::after {
        background: url(../images/subject-education/english/arrow.png);
        background-size: contain;
        content: "";
        height: 32px;
        margin: auto;
        position: absolute;
        bottom: 0;
        top: 0;
        right: 20px;
        width: 20px;
        z-index: 5; }
        @media screen and (max-width: 769px) {
          .english #flow li.column::after {
            /*background-repeat: no-repeat;
            height: 22px;
            width: 10px;
            right: 9px;*/ } }
      .english #flow li.column:last-child::after {
        content: none; }
    .english #flow dl {
      /*align-items: center;*/
      align-items: stretch;
      position: relative;
      z-index: 20; }
    .english #flow dt {
      border: 1px solid #752586;
      color: #752586;
      /*height: 74px;*/
      height: auto;
      /*line-height: 49px;*/
      line-height: 122px;
      padding: 2.5% 0;
      text-align: center; }
    .english #flow dd {
      padding-left: 4%; }
      .english #flow dd h4 {
        color: #752586; }
      .english #flow dd li {
        font-size: 0.9em;
        padding-left: 0.5em;
        text-indent: -0.3em; }
  .english #math,
  .english #science {
    margin-top: 4em !important; }
    @media screen and (min-width: 769px) {
      .english #math,
      .english #science {
        margin: 5% auto !important; } }
  @media screen and (max-width: 769px) {
    .english .speach {
      margin: 12% 0 0;
      width: 100%; } }
  .english .speach h6 {
    font-size: 1.15em; }
    @media screen and (min-width: 769px) {
      .english .speach h6 {
        font-size: 1.3em !important; } }
  .english .small-class {
    /*border-left: 2px solid #752586;
    border-right: 2px solid #752586;
    margin: 2% auto 0;
    padding: 0 2%;
    max-width: 460px;*/
    text-align: center;
    padding: 0 8px;
    background-color: #752586;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 2% auto 0;
    max-width: 460px; }
    .english .small-class .inner {
      padding: 25px;
      background-color: #fff;
      border-radius: 10px;
      margin-bottom: 0;
      width: 100%; }
    .english .small-class .head {
      color: #752586;
      text-align: center; }
      .english .small-class .head span {
        position: relative; }
        .english .small-class .head span::before {
          content: "";
          background: #752586;
          height: 2px;
          width: 100%;
          position: absolute;
          bottom: 0;
          left: 0; }
    .english .small-class .desc-text {
      margin: 1em 0 0;
      text-align: left; }
  .english .head-feature {
    color: #752586;
    font-size: 1.7em; }
    .english .head-feature span {
      background: linear-gradient(transparent 0%, transparent 85%, #d2bdda 85%, #d2bdda 100%);
      padding: 26px 1% 0;
      position: relative;
      z-index: 1; }
      .english .head-feature span:before {
        content: url(../images/subject-education/english/deco1.svg);
        height: auto;
        margin: auto;
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        width: 65px; }
  .english #feature {
    padding-bottom: 4%;
    position: relative; }
    .english #feature .head-circle::before {
      border-top: 1px dashed #752586; }
    .english #feature .head-circle::after {
      color: #752586;
      font-size: 0.3em;
      text-shadow: 0 0 0 #efedde, -3px 0 0 #efedde, 3px 0 0 #efedde, 0 0 0 #efedde; }
    .english #feature .head-circle span {
      background: #efedde;
      color: #752586;
      font-size: 1.1em;
      padding: 0 2% 0 0; }
    .english #feature li {
      padding-bottom: 5%; }
      .english #feature li:first-child .columns {
        margin-bottom: 0; }
      .english #feature li:first-child .column {
        padding-bottom: 0; }
      .english #feature li:first-child .head-triangle {
        margin-bottom: 0; }
      .english #feature li:first-child p {
        margin-bottom: 1em; }
    .english #feature .contents {
      align-items: center;
      background: #fff;
      border: 1px dashed #604c3f;
      border-radius: 10px;
      margin-bottom: 1%; }
      .english #feature .contents dt {
        text-align: center; }
      .english #feature .contents dd {
        border-left: 1px dashed #604c3f; }
        .english #feature .contents dd .columns {
          margin: 0; }
        .english #feature .contents dd .column {
          padding: 0; }
      .english #feature .contents dt, .english #feature .contents dd {
        color: #604c3f; }
      .english #feature .contents li {
        margin-bottom: 1%;
        padding-bottom: 0; }
        .english #feature .contents li ul {
          margin-left: 1em;
          margin-top: 0; }
          .english #feature .contents li ul li {
            font-family: "Noto Sans JP", sans-serif;
            font-weight: 400;
            margin-bottom: 0; }
    .english #feature .head-triangle {
      color: #752586;
      margin-bottom: 0.7em;
      position: relative;
      text-indent: 1em; }
      .english #feature .head-triangle::before {
        background: url(../images/subject-education/english/triangle.png) no-repeat;
        background-size: contain;
        content: "";
        height: 13px;
        position: absolute;
        top: 4px;
        left: 0;
        width: 10px; }
    .english #feature h6 {
      margin-bottom: 4%;
      text-align: center; }
      .english #feature h6 span {
        border-bottom: 3px solid #d2bdda; }
      .english #feature h6 strong {
        font-size: 1.15em; }
    .english #feature .result-box {
      margin: auto;
      margin-top: 7%; }
    .english #feature .table tr:first-child th {
      background: #d2bdda; }
    .english #feature .table th, .english #feature .table td {
      background: #fff;
      padding: 1% 3%;
      text-align: center; }
  .english .dashed-table {
    margin-bottom: 5%; }
  @media screen and (min-width: 1010px) {
    .english #flow ul.columns {
      overflow: inherit; } }
  @media screen and (min-width: 769px) {
    .english #flow .text {
      /*text-align: center;*/ }
    .english #flow li.column {
      margin-right: 25px; }
      .english #flow li.column::after {
        right: 0; }
    .english .head-feature {
      font-size: 2em;
      padding-top: 45px;
      width: 45%; }
      .english .head-feature span {
        padding: 38px 1% 0; }
        .english .head-feature span:before {
          width: 100px; }
    .english #feature h6 {
      font-size: 1.1em; }
    .english #feature .result-box .image-box {
      margin-top: 3em;
      margin-bottom: 7%;
      width: 95%; } }

/***********************************************************************
subject1
**********************************************************************/
.subject-wrapper {
  margin-bottom: 7%; }
  .subject-wrapper .gradation-btn {
    max-width: 320px; }
    @media screen and (min-width: 769px) {
      .subject-wrapper .gradation-btn {
        max-width: 500px; } }
    @media screen and (min-width: 769px) {
      .subject-wrapper .gradation-btn a {
        padding: 5% 0 6%; } }

.subject1 section:not(#main),
.english section:not(#main) {
  margin: 5% auto; }
  .subject1 section:not(#main) img + p,
  .english section:not(#main) img + p {
    font-size: 0.9em; }
.subject1 .sb-image,
.english .sb-image {
  /*float: left;*/
  margin-bottom: 3%;
  width: 100%; }
.subject1 .desc,
.english .desc {
  /*float: right;*/
  margin-bottom: 4%;
  /*width: 61%;*/
  float: none;
  width: 100%; }
.subject1 .point,
.english .point {
  /*clear: both;*/
  float: none;
  width: 100%; }
.subject1 .exercise-box,
.english .exercise-box {
  float: none;
  margin-bottom: 4%;
  width: 100%; }
.subject1 .purple-box,
.english .purple-box {
  background-image: radial-gradient(circle at 0% 0%, transparent 25px, #f2ecf5 0), radial-gradient(circle at 100% 0%, transparent 25px, #f2ecf5 0), radial-gradient(circle at 0% 100%, transparent 25px, #f2ecf5 0), radial-gradient(circle at 100% 100%, transparent 25px, #f2ecf5 0);
  background-position: 0% 0%, 100% 0%, 0% 100%, 100% 100%;
  background-repeat: no-repeat;
  background-size: 55% 55%;
  max-width: 930px;
  margin: 0 auto 8%;
  padding: 5% 0; }
  .subject1 .purple-box .point-list,
  .english .purple-box .point-list {
    background: #fff; }
.subject1 h5.copperplate,
.english h5.copperplate {
  color: #752586; }
.subject1 .point-list,
.english .point-list {
  background: #f2ecf5;
  color: #752586;
  outline: 1px solid #752586;
  outline-offset: -6px;
  padding: 4%; }
  .subject1 .point-list li,
  .english .point-list li {
    margin-bottom: 1%;
    padding-left: 1em;
    position: relative; }
    .subject1 .point-list li::before,
    .english .point-list li::before {
      color: #a87bb1;
      content: "●";
      position: absolute;
      left: 0; }
.subject1 .head-marker,
.english .head-marker {
  background: linear-gradient(transparent 0%, transparent 70%, #d2bdda 70%, #d2bdda 100%);
  color: #752586;
  display: inline; }
.subject1 #science table:not(.stylenone-table),
.english #science table:not(.stylenone-table) {
  border-collapse: collapse;
  margin-bottom: 0;
  width: 100%; }
  .subject1 #science table:not(.stylenone-table) th, .subject1 #science table:not(.stylenone-table) td,
  .english #science table:not(.stylenone-table) th,
  .english #science table:not(.stylenone-table) td {
    vertical-align: middle;
    text-align: center; }
  .subject1 #science table:not(.stylenone-table) th,
  .english #science table:not(.stylenone-table) th {
    background: #752586;
    color: #fff;
    padding: 1%; }
  .subject1 #science table:not(.stylenone-table) td,
  .english #science table:not(.stylenone-table) td {
    background: #fff;
    padding: 2%; }
  .subject1 #science table:not(.stylenone-table) tr td:first-child,
  .english #science table:not(.stylenone-table) tr td:first-child {
    text-align: left; }
  .subject1 #science table:not(.stylenone-table) tr th:nth-child(2),
  .english #science table:not(.stylenone-table) tr th:nth-child(2) {
    border-left: 1px solid #fff;
    border-right: 1px solid #fff; }
  .subject1 #science table:not(.stylenone-table) tr td:nth-child(2),
  .english #science table:not(.stylenone-table) tr td:nth-child(2) {
    border-left: 1px solid #231815;
    border-right: 1px solid #231815; }
  .subject1 #science table:not(.stylenone-table) tr:not(:first-child):not(:last-child),
  .english #science table:not(.stylenone-table) tr:not(:first-child):not(:last-child) {
    border-bottom: 1px solid #231815; }
.subject1 #science .stylenone-table th,
.english #science .stylenone-table th {
  padding-right: 1em;
  white-space: nowrap; }
.subject1 #social-studies,
.subject1 #bible,
.subject1 #information,
.subject1 #art,
.subject1 #pe,
.subject1 #th,
.english #social-studies,
.english #bible,
.english #information,
.english #art,
.english #pe,
.english #th {
  margin-top: 3.5em !important; }
  @media screen and (min-width: 769px) {
    .subject1 #social-studies,
    .subject1 #bible,
    .subject1 #information,
    .subject1 #art,
    .subject1 #pe,
    .subject1 #th,
    .english #social-studies,
    .english #bible,
    .english #information,
    .english #art,
    .english #pe,
    .english #th {
      margin: 5% auto; } }
.subject1 #pe .text,
.english #pe .text {
  margin-bottom: 0; }
@media screen and (min-width: 769px) {
  .subject1 .sb-image,
  .english .sb-image {
    float: left;
    margin-right: 3%;
    width: 48%; }
  .subject1 h5.copperplate,
  .english h5.copperplate {
    font-size: 1.15em; }
  .subject1 .desc-box,
  .english .desc-box {
    /*float: right;
    width: 48%;*/
    clear: both; }
  .subject1 .desc,
  .english .desc {
    /*float: inherit;
    width: 100%;*/
    float: left;
    width: 48%; }
  .subject1 .point,
  .english .point {
    /*float: right;
    width: 48%;*/ }
  .subject1 .exercise-box,
  .english .exercise-box {
    float: right;
    margin-bottom: 2%;
    width: 48%; }
  .subject1 #social-studies .sb-image,
  .english #social-studies .sb-image {
    float: left;
    width: 24%; }
  .subject1 #social-studies .desc-box,
  .english #social-studies .desc-box {
    clear: none;
    float: right;
    width: 72%; }
  .subject1 #social-studies .desc,
  .english #social-studies .desc {
    float: inherit;
    width: 100%; }
  .subject1 #social-studies .point,
  .english #social-studies .point {
    float: inherit;
    width: 100%; }
  .subject1 .purple-box,
  .english .purple-box {
    padding: 2% 0 3%; }
  .subject1 .point-list,
  .english .point-list {
    padding: 3%; } }

/***********************************************************************
subject2
**********************************************************************/
.subject2 #bible {
  margin-bottom: 9%;
  margin-top: -150px;
  padding-top: 150px; }
.subject2 #art {
  margin-bottom: 13%; }
.subject2 #pe {
  margin-bottom: 5%; }
.subject2 #th {
  margin-bottom: 6%; }
.subject2 #lhr h5 {
  color: #804f21;
  font-size: 1.2em;
  margin-bottom: 2%;
  text-align: center; }
.subject2 #lhr .table th, .subject2 #lhr .table td {
  background: #fff !important;
  border: 1px solid #000;
  padding: 1.7% 3%; }
@media screen and (min-width: 769px) {
  .subject2 #bible, .subject2 #art {
    margin-bottom: 6%; }
  .subject2 #lhr .back-beige {
    margin-top: 2%; }
    .subject2 #lhr .back-beige .inner {
      max-width: 750px; }
  .subject2 #lhr .table th, .subject2 #lhr td {
    padding: 1% 3%; } }

/***********************************************************************
theday
**********************************************************************/
.theday #schedule {
  background: url(../images/school-life/theday/back_purple.jpg);
  padding: 3.5% 0; }
  .theday #schedule .inner {
    position: relative; }
  .theday #schedule h4 {
    color: #804f21;
    font-size: 1.1em; }
    .theday #schedule h4 .time {
      color: #752586;
      font-size: 1.2em;
      padding-right: 3%; }
    .theday #schedule h4 small {
      padding-right: 3%; }
  .theday #schedule p {
    letter-spacing: .076em; }
  .theday #schedule .title h3 {
    position: relative;
    z-index: 1; }
  .theday #schedule .title-desc {
    margin-top: 5%;
    padding-left: 0;
    padding-right: 2rem; }
  .theday #schedule .box-8-00 {
    margin-bottom: 8%;
    margin-top: -50%;
    position: relative; }
    .theday #schedule .box-8-00 .desc-box {
      background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.85) 0, rgba(255, 255, 255, 0.85) 6px, rgba(255, 255, 255, 0.9) 6px, rgba(255, 255, 255, 0.9) 16px);
      border-radius: 10px;
      margin: -5% 5% 0;
      padding: 5%;
      position: relative;
      z-index: 1; }
      .theday #schedule .box-8-00 .desc-box h4 {
        font-size: 1.3em; }
      .theday #schedule .box-8-00 .desc-box::before {
        border-radius: 10px;
        border: 1px solid #752586;
        content: "";
        height: 93%;
        margin: auto;
        position: absolute;
        bottom: 0;
        top: 0;
        left: 0;
        right: 0;
        width: 98%; }
      .theday #schedule .box-8-00 .desc-box .start {
        height: 82px;
        width: 82px;
        position: absolute;
        top: -30%;
        right: 10%; }
    .theday #schedule .box-8-00::after {
      background: url(../images/school-life/theday/arrow1.png) no-repeat;
      background-size: contain;
      content: "";
      height: 61px;
      position: absolute;
      bottom: -21%;
      right: 28%;
      width: 76px; }
  .theday #schedule .box-8-30 {
    padding-right: 1.45rem;
    position: relative; }
    .theday #schedule .box-8-30 p {
      max-width: 272px; }
    .theday #schedule .box-8-30::after {
      background: url(../images/school-life/theday/arrow2.png) no-repeat;
      background-size: contain;
      content: "";
      height: 60px;
      position: absolute;
      bottom: 62%;
      right: -23%;
      width: 44px; }
  .theday #schedule .box-8-40 {
    margin-top: 12%;
    padding: 0 .75rem 0 0;
    position: relative; }
    .theday #schedule .box-8-40 .columns {
      flex-direction: row-reverse; }
    .theday #schedule .box-8-40::after {
      background: url(../images/school-life/theday/arrow3.png) no-repeat;
      background-size: contain;
      content: "";
      height: 60px;
      position: absolute;
      bottom: 30%;
      left: -35%;
      width: 44px; }
    .theday #schedule .box-8-40 .desc {
      margin-right: 2%;
      margin-bottom: 7%;
      text-align: right; }
  .theday #schedule .box-bible {
    margin-top: -108px;
    padding-right: 1.45rem;
    position: relative; }
    .theday #schedule .box-bible::after {
      background: url(../images/school-life/theday/arrow4.png) no-repeat;
      background-size: contain;
      content: "";
      height: 46px;
      position: absolute;
      bottom: 25%;
      right: 5%;
      width: 60px; }
  .theday #schedule .box-art {
    margin-top: 14%;
    position: relative; }
    .theday #schedule .box-art::after {
      background: url(../images/school-life/theday/arrow5.png) no-repeat;
      background-size: contain;
      content: "";
      height: 43px;
      position: absolute;
      bottom: -12%;
      right: 50%;
      width: 60px; }
  .theday #schedule .box-lunch {
    margin-bottom: 21%;
    position: relative; }
    .theday #schedule .box-lunch .desc {
      position: absolute;
      bottom: -70px;
      right: 0;
      width: 43%; }
    .theday #schedule .box-lunch:before {
      background: url(../images/school-life/theday/lunch_iris.png) no-repeat;
      background-size: contain;
      content: "";
      height: 68%;
      position: absolute;
      top: -37%;
      left: 3%;
      width: 37%; }
    .theday #schedule .box-lunch::after {
      background: url(../images/school-life/theday/arrow6.png) no-repeat;
      background-size: contain;
      content: "";
      height: 54px;
      position: absolute;
      bottom: -30%;
      right: 50%;
      width: 22px; }
  .theday #schedule .box-th {
    position: relative; }
    .theday #schedule .box-th h4 {
      position: absolute;
      right: 16%;
      top: 2%;
      white-space: nowrap;
      z-index: 1; }
    .theday #schedule .box-th .image {
      margin-bottom: 3%;
      margin-left: 2%;
      width: 90%; }
    .theday #schedule .box-th::after {
      background: url(../images/school-life/theday/arrow8.png) no-repeat;
      background-size: contain;
      content: "";
      height: 44px;
      position: absolute;
      bottom: -26%;
      right: 48%;
      width: 23px; }
  .theday #schedule .box-lhr {
    align-items: center;
    flex-direction: row-reverse;
    position: relative; }
    .theday #schedule .box-lhr .image {
      margin-bottom: -7%;
      text-align: right; }
    .theday #schedule .box-lhr .column:last-child {
      margin-top: 11%; }
    .theday #schedule .box-lhr::after {
      background: url(../images/school-life/theday/arrow9.png) no-repeat;
      background-size: contain;
      content: "";
      height: 292px;
      position: absolute;
      bottom: -129%;
      right: 1%;
      width: 92px; }
  .theday #schedule .box-activity {
    margin-bottom: 8%;
    max-width: 435px;
    width: 68%; }
    .theday #schedule .box-activity .desc {
      margin-bottom: 2%; }
  .theday #schedule .box-club {
    align-items: flex-end;
    flex-direction: row-reverse;
    margin: 0 0 15% auto;
    max-width: 410px;
    position: relative; }
    .theday #schedule .box-club .column {
      padding: 0; }
    .theday #schedule .box-club .image {
      margin: 0 5% 5% 0;
      text-align: right; }
    .theday #schedule .box-club::after {
      background: url(../images/school-life/theday/arrow8.png) no-repeat;
      background-size: contain;
      content: "";
      height: 44px;
      position: absolute;
      bottom: -30%;
      right: 48%;
      width: 23px; }
  .theday #schedule .box-18-00 {
    margin: auto;
    max-width: 310px;
    width: 70%; }
  .theday #schedule .annotation {
    position: absolute;
    bottom: 8px;
    right: 14px; }
    @media screen and (max-width: 769px) {
      .theday #schedule .annotation {
        position: relative;
        text-align: center;
        bottom: auto;
        right: auto; } }
@media screen and (min-width: 500px) {
  .theday #schedule .box-8-00 {
    margin-top: -44%; } }
@media screen and (min-width: 769px) {
  .theday #schedule .box-8-00 {
    margin-bottom: 1%;
    margin-top: 0; }
    .theday #schedule .box-8-00 .desc-box {
      max-width: 272px;
      margin-left: 56%;
      margin-top: -7%;
      padding: 2%; }
      .theday #schedule .box-8-00 .desc-box .start {
        height: 117px;
        width: 117px;
        top: -52%;
        right: 5%; }
      .theday #schedule .box-8-00 .desc-box::before {
        height: 97%; }
    .theday #schedule .box-8-00::after {
      bottom: 7%;
      right: 52%; }
  .theday #schedule .box-8-30 {
    margin-top: -10%; }
    .theday #schedule .box-8-30::after {
      background: url(../images/school-life/theday/arrow4.png) no-repeat;
      background-size: contain;
      height: 46px;
      bottom: 25%;
      right: 5%;
      width: 60px; }
  .theday #schedule .box-8-40 {
    margin-top: 5%;
    max-width: 457px; }
    .theday #schedule .box-8-40::after {
      background: url(../images/school-life/theday/arrow1.png) no-repeat;
      background-size: contain;
      height: 61px;
      bottom: -25%;
      left: -4%;
      width: 76px; }
  .theday #schedule .box-bible {
    margin-top: -45px; }
    .theday #schedule .box-bible::after {
      background: url(../images/school-life/theday/arrow7.png) no-repeat;
      background-size: contain;
      height: 22px;
      bottom: 48%;
      right: -34%;
      width: 140px; }
  .theday #schedule .box-art {
    margin-top: 4%; }
    .theday #schedule .box-art::after {
      background: url(../images/school-life/theday/arrow3.png) no-repeat;
      background-size: contain;
      content: "";
      height: 60px;
      position: absolute;
      bottom: 0;
      right: 106%;
      width: 44px; }
  .theday #schedule .box-lunch {
    max-width: 657px;
    margin: 0 auto 5%; }
    .theday #schedule .box-lunch .desc {
      bottom: 3%;
      width: 34%; }
    .theday #schedule .box-lunch::before {
      height: 35%;
      top: -3%;
      width: 19%; }
    .theday #schedule .box-lunch::after {
      bottom: -12%; }
  .theday #schedule .box-th .image {
    margin-bottom: 0;
    width: 69%; }
  .theday #schedule .box-th .desc {
    margin-left: 12%;
    width: 12em; }
  .theday #schedule .box-th h4 {
    right: 47%;
    top: 8%; }
  .theday #schedule .box-th::after {
    background: url(../images/school-life/theday/arrow2.png) no-repeat;
    background-size: contain;
    content: "";
    height: 60px;
    position: absolute;
    bottom: 49%;
    right: 21%;
    width: 44px; }
  .theday #schedule .box-lhr {
    margin-left: auto;
    margin-top: -35%;
    max-width: 285px; }
    .theday #schedule .box-lhr .desc-box {
      margin-right: 5%;
      width: 13em; }
    .theday #schedule .box-lhr .column:last-child {
      margin-top: 0;
      padding-top: 0; }
    .theday #schedule .box-lhr::before {
      background: url(../images/school-life/theday/arrow10.png) no-repeat;
      background-size: contain;
      content: "";
      height: 61px;
      position: absolute;
      bottom: 25%;
      right: 109%;
      width: 45px; }
    .theday #schedule .box-lhr::after {
      background: url(../images/school-life/theday/arrow11.png) no-repeat;
      background-size: contain;
      content: "";
      height: 155px;
      position: absolute;
      bottom: -36%;
      right: 27%;
      width: 83px; }
  .theday #schedule .box-activity {
    margin-top: -15%; }
  .theday #schedule .box-club {
    max-width: 340px;
    margin-top: -16%; }
    .theday #schedule .box-club .image {
      position: absolute;
      top: -30%;
      left: 5%; }
    .theday #schedule .box-club::after {
      background: url(../images/school-life/theday/arrow3.png) no-repeat;
      background-size: contain;
      content: "";
      height: 60px;
      position: absolute;
      bottom: 46%;
      right: 110%;
      width: 44px; }
  .theday #schedule .box-18-00 {
    margin: -40% 0 0 5%; } }
@media screen and (min-width: 769px) and (max-width: 940px) {
  .theday #schedule .inner {
    width: 860px;
    zoom: 0.85; } }

/***********************************************************************
uniform-event
**********************************************************************/
.uniform-event #uniform {
  margin-bottom: 11%;
  padding-bottom: 4%; }
  .uniform-event #uniform .uniform-inner {
    margin: 0 auto;
    max-width: 1200px;
    outline: 1px solid #9a8046;
    outline-offset: -6px;
    padding: 4% 0;
    position: relative; }
    .uniform-event #uniform .uniform-inner::before {
      background: url(../images/learning/policy/frame_left.png) no-repeat;
      background-size: contain;
      content: "";
      height: 8%;
      position: absolute;
      left: 10px;
      top: 10px;
      width: 8%; }
    .uniform-event #uniform .uniform-inner::after {
      background: url(../images/learning/policy/frame_right.png) no-repeat;
      background-size: contain;
      content: "";
      height: 8%;
      position: absolute;
      right: 10px;
      top: 10px;
      width: 8%; }
    .uniform-event #uniform .uniform-inner .inner {
      max-width: 1090px; }
  .uniform-event #uniform .arch {
    color: #752586;
    font-family: Copperplate;
    font-size: 1.1em;
    text-align: center; }
    .uniform-event #uniform .arch span:first-child, .uniform-event #uniform .arch span:last-child {
      font-size: 0.6em; }
  .uniform-event #uniform .head-mincho {
    text-align: center;
    color: #752586;
    font-size: 2.2em; }
    @media screen and (max-width: 769px) {
      .uniform-event #uniform .head-mincho {
        font-size: 1.4em; } }
    .uniform-event #uniform .head-mincho span {
      background: linear-gradient(transparent 0%, transparent 75%, #fff 75%, #fff 100%);
      color: #752586;
      display: inline-block;
      padding: 0 2%; }
      .uniform-event #uniform .head-mincho span strong {
        color: #752586;
        font-size: 1.7em; }
  .uniform-event #uniform .uniform-tab-btn {
    margin: 0 auto !important;
    max-width: 920px;
    padding: 0 7%;
    width: 73%; }
    .uniform-event #uniform .uniform-tab-btn li {
      background: none;
      background-position: 0% 0%, 100% 0%, 0% 100%, 100% 100%;
      background-repeat: no-repeat;
      background-size: 55% 55%;
      cursor: pointer;
      color: #fff;
      outline: 1px solid #fff;
      outline-offset: -2.5px;
      margin-right: 7%;
      margin-left: -2%;
      padding: 1% 0 2.2%;
      position: relative;
      text-align: center; }
      .uniform-event #uniform .uniform-tab-btn li.active:after {
        border: 12px solid transparent;
        content: "";
        margin-left: -12px;
        position: absolute;
        top: 100%;
        left: 50%; }
      .uniform-event #uniform .uniform-tab-btn li.middle {
        background-image: radial-gradient(circle at 0% 0%, transparent 5px, #bc4b57 0), radial-gradient(circle at 100% 0%, transparent 5px, #bc4b57 0), radial-gradient(circle at 0% 100%, transparent 5px, #bc4b57 0), radial-gradient(circle at 100% 100%, transparent 5px, #bc4b57 0); }
        .uniform-event #uniform .uniform-tab-btn li.middle.active {
          background-image: radial-gradient(circle at 0% 0%, transparent 5px, #ff6474 0), radial-gradient(circle at 100% 0%, transparent 5px, #ff6474 0), radial-gradient(circle at 0% 100%, transparent 5px, #ff6474 0), radial-gradient(circle at 100% 100%, transparent 5px, #ff6474 0); }
          .uniform-event #uniform .uniform-tab-btn li.middle.active::after {
            border-top: 15px solid #ff6474; }
      .uniform-event #uniform .uniform-tab-btn li.high {
        background-image: radial-gradient(circle at 0% 0%, transparent 5px, #457485 0), radial-gradient(circle at 100% 0%, transparent 5px, #457485 0), radial-gradient(circle at 0% 100%, transparent 5px, #457485 0), radial-gradient(circle at 100% 100%, transparent 5px, #457485 0); }
        .uniform-event #uniform .uniform-tab-btn li.high.active {
          background-image: radial-gradient(circle at 0% 0%, transparent 5px, #239ec9 0), radial-gradient(circle at 100% 0%, transparent 5px, #239ec9 0), radial-gradient(circle at 0% 100%, transparent 5px, #239ec9 0), radial-gradient(circle at 100% 100%, transparent 5px, #239ec9 0); }
          .uniform-event #uniform .uniform-tab-btn li.high.active::after {
            border-top: 15px solid #239ec9; }
  .uniform-event #uniform .image-list {
    margin: 5% auto 0;
    max-width: 450px;
    width: 83%; }
    .uniform-event #uniform .image-list.three-persons {
      width: 100%; }
      @media screen and (max-width: 769px) {
        .uniform-event #uniform .image-list.three-persons .column {
          padding: 0.75rem 0; } }
    .uniform-event #uniform .image-list .column {
      padding: .5rem; }
    .uniform-event #uniform .image-list p {
      font-size: clamp(0.813rem, 0.784rem + 0.12vw, 0.875rem);
      margin-bottom: 3%;
      text-align: center;
      white-space: nowrap; }
    .uniform-event #uniform .image-list img {
      display: block;
      /*height: 330px;*/
      margin: 0 auto; }
  .uniform-event #uniform .uniform-tab-desc {
    padding: 0; }
  .uniform-event #uniform .desc {
    background: rgba(243, 206, 201, 0.6);
    border-radius: 10px;
    margin-bottom: 4%;
    padding: 2%; }
    .uniform-event #uniform .desc.common {
      background: rgba(255, 255, 255, 0.6); }
    .uniform-event #uniform .desc .point-list li {
      margin-bottom: 5%; }
    .uniform-event #uniform .desc .point-list h5, .uniform-event #uniform .desc .point-list p {
      padding-left: 1em; }
    .uniform-event #uniform .desc .point-list .purple h5 {
      color: #752586;
      font-size: 1.1em;
      position: relative;
      margin: 2% 0 0; }
      .uniform-event #uniform .desc .point-list .purple h5::before {
        color: #c7b9c3;
        content: "●";
        position: absolute;
        left: 0; }
  .uniform-event #uniform .high .desc {
    background: rgba(199, 224, 238, 0.6); }
  .uniform-event #uniform .middle .image-list p {
    color: #ff6474; }
  .uniform-event #uniform .middle .point-list h5 {
    color: #ff6474;
    font-size: 1.1em;
    position: relative; }
    .uniform-event #uniform .middle .point-list h5::before {
      color: #f3cec9;
      content: "●";
      position: absolute;
      left: 0; }
  .uniform-event #uniform .high .image-list p {
    color: #239ec9; }
  .uniform-event #uniform .high .point-list h5 {
    color: #239ec9;
    font-size: 1.1em;
    position: relative; }
    .uniform-event #uniform .high .point-list h5::before {
      color: #c7e0ee;
      content: "●";
      position: absolute;
      left: 0; }
  .uniform-event #uniform .designer {
    align-items: center;
    background: #fff9d8;
    border: 1px solid #babbbb;
    margin: 0 auto; }
    .uniform-event #uniform .designer dt {
      color: #752586; }
    .uniform-event #uniform .designer dd {
      border-left: 1px dashed #babbbb; }
      .uniform-event #uniform .designer dd span {
        font-size: 1.2em; }
.uniform-event #event {
  margin-bottom: 12%; }
  @media screen and (max-width: 769px) {
    .uniform-event #event {
      margin-top: -100px;
      padding-top: 100px; } }
  .uniform-event #event .event-slider {
    margin-bottom: 4%; }
    .uniform-event #event .event-slider .columns {
      align-items: center;
      margin-left: 0;
      margin-right: 0;
      padding: 2% 0; }
    .uniform-event #event .event-slider .month {
      border-radius: 50%;
      font-size: 2em;
      height: 60px;
      line-height: 60px;
      margin: 0 auto;
      position: relative;
      text-align: center;
      width: 60px; }
      .uniform-event #event .event-slider .month::after {
        border-radius: 50%;
        content: "";
        height: 54px;
        margin: auto;
        width: 54px;
        position: absolute;
        bottom: 0;
        top: 0;
        left: 0;
        right: 0; }
    .uniform-event #event .event-slider h5 {
      font-size: 1.2em; }
    .uniform-event #event .event-slider .odd {
      background: #efedde; }
      .uniform-event #event .event-slider .odd .month {
        background: #e6e3c5;
        border: 1.5px solid #804f21;
        color: #804f21; }
        .uniform-event #event .event-slider .odd .month::after {
          border: 1.5px dotted #804f21; }
      .uniform-event #event .event-slider .odd h5 {
        color: #804f21; }
    .uniform-event #event .event-slider .even {
      background: #f2ecf5; }
      .uniform-event #event .event-slider .even .month {
        background: #d2bdda;
        border: 1.5px solid #752586;
        color: #752586; }
        .uniform-event #event .event-slider .even .month::after {
          border: 1.5px dotted #752586; }
      .uniform-event #event .event-slider .even h5 {
        color: #752586; }
  .uniform-event #event .event-list h5 {
    color: #231815;
    font-size: 1.2em;
    margin-bottom: 5%;
    text-align: center; }
  .uniform-event #event .event-accordion .column {
    padding: .75rem .75rem 0; }
  .uniform-event #event .event-accordion p {
    border-radius: 5px;
    cursor: pointer;
    font-size: 2em;
    padding: 0 4%;
    position: relative;
    line-height: 1.4; }
    .uniform-event #event .event-accordion p span {
      font-size: 0.3em;
      margin-left: 3%;
      padding-bottom: 1%;
      position: absolute;
      top: 29%; }
      .uniform-event #event .event-accordion p span::after {
        border-radius: 15%;
        content: "";
        height: 4px;
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%; }
  .uniform-event #event .event-accordion .child {
    padding: 3% 5% 0; }
    .uniform-event #event .event-accordion .child li::before {
      content: "●";
      font-size: 0.8em;
      padding-right: 1%; }
  .uniform-event #event .event-accordion li.odd p {
    background: #d2bdda;
    border: 2px solid #752586;
    color: #752586; }
    .uniform-event #event .event-accordion li.odd p span::after {
      background: #752586; }
  .uniform-event #event .event-accordion li.odd .child li::before {
    color: #d2bdda; }
  .uniform-event #event .event-accordion li.even p {
    background: #e6e3c5;
    border: 2px solid #804f21;
    color: #804f21; }
    .uniform-event #event .event-accordion li.even p span::after {
      background: #804f21; }
  .uniform-event #event .event-accordion li.even .child li::before {
    color: #e6e3c5; }
  .uniform-event #event .back-label {
    background: #E7DCEB;
    padding: 0 2px;
    border-radius: 5px; }
    .uniform-event #event .back-label::before {
      color: #fff !important; }
.uniform-event #christianity-event {
  margin-top: -200px;
  padding-top: 200px; }
@media screen and (min-width: 769px) {
  .uniform-event #uniform {
    margin-bottom: 5%; }
    .uniform-event #uniform .uniform-tab-btn li {
      cursor: text;
      margin-right: 14%;
      margin-left: -4%;
      padding: 1.2% 0 1.8%; }
      .uniform-event #uniform .uniform-tab-btn li.high {
        background-image: radial-gradient(circle at 0% 0%, transparent 5px, #239ec9 0), radial-gradient(circle at 100% 0%, transparent 5px, #239ec9 0), radial-gradient(circle at 0% 100%, transparent 5px, #239ec9 0), radial-gradient(circle at 100% 100%, transparent 5px, #239ec9 0); }
        .uniform-event #uniform .uniform-tab-btn li.high::after {
          border: 12px solid transparent;
          border-top: 15px solid #239ec9;
          content: "";
          margin-left: -12px;
          position: absolute;
          top: 100%;
          left: 50%; }
    .uniform-event #uniform .hide {
      display: block; }
    .uniform-event #uniform .uniform-tab-desc {
      padding: .75rem; }
    .uniform-event #uniform .middle .desc,
    .uniform-event #uniform .high .desc {
      padding-bottom: 5%; }
    .uniform-event #uniform .desc {
      margin-bottom: 2%; }
      .uniform-event #uniform .desc .point-list li {
        margin-bottom: 0; }
    .uniform-event #uniform .common {
      padding: 1% 2% 2%; }
      .uniform-event #uniform .common h4 {
        color: #752586;
        font-size: 1.5em;
        margin-bottom: 4%;
        text-align: center; }
      .uniform-event #uniform .common .point-list li {
        margin-bottom: 0; }
        .uniform-event #uniform .common .point-list li:first-child img {
          display: block;
          margin: auto;
          /*max-width: 267px;*/ }
  .uniform-event #event {
    margin-bottom: 6%; }
    .uniform-event #event .event-slider .columns {
      align-items: stretch; }
      .uniform-event #event .event-slider .columns .column:last-child {
        padding-left: 0; }
    .uniform-event #event .event-slider .month {
      font-size: 2.5em;
      height: 80px;
      line-height: 80px;
      width: 80px; }
      .uniform-event #event .event-slider .month::after {
        height: 70px;
        width: 70px; }
    .uniform-event #event .event-accordion .column {
      padding: .75rem; }
    .uniform-event #event .event-accordion .child {
      display: block; }
    .uniform-event #event .event-accordion p {
      cursor: text; } }

@media screen and (max-width: 769px) {
  .uniform-event #uniform .desc .point-list li {
    margin-bottom: 0%; } }
/***********************************************************************
club
**********************************************************************/
.club {
  /*club-slider*/
  /*club-list*/
  /*club-list-wrapper*/ }
  .club .circle {
    background: url(../images/school-life/club/circle.png) no-repeat center/contain;
    color: #752586;
    margin-top: 5%;
    padding: 4em 0;
    text-align: center; }
    .club .circle span {
      font-size: 1.2em; }
  .club .club-slider {
    max-width: 980px; }
    .club .club-slider .slick-prev, .club .club-slider .slick-next {
      bottom: inherit;
      top: 50%;
      transform: translate(-50%, -50%);
      width: 12px; }
    @media screen and (max-width: 769px) {
      .club .club-slider .slick-slide img.pc {
        display: none !important; } }
    .club .club-slider .slide-dots {
      text-align: center;
      position: absolute;
      bottom: 25px;
      left: 50%;
      margin-left: -25px; }
      .club .club-slider .slide-dots li {
        display: inline-block;
        margin: 0 9px; }
        .club .club-slider .slide-dots li button {
          position: relative;
          text-indent: -9999px; }
          .club .club-slider .slide-dots li button:before {
            content: '\025cf';
            color: #752586;
            opacity: .5;
            font-size: 20px;
            text-indent: 0px;
            position: absolute;
            top: 0;
            left: 0; }
        .club .club-slider .slide-dots li.slick-active button:before {
          opacity: 1; }
  .club .club-list {
    margin: 3% auto 0;
    max-width: 980px; }
    .club .club-list .copperplate {
      background: #d2bdda;
      border: 2px solid #752586;
      color: #752586;
      padding: 6px 12px; }
    .club .club-list .copperplate2 {
      background: #e6e3c5;
      border: 2px solid #804f21;
      color: #804f21;
      padding: 6px 12px; }
    .club .club-list ul {
      margin: 2% 0 0; }
      .club .club-list ul li::before {
        color: #d2bdda;
        content: "\025cf";
        font-size: 0.8em;
        padding-right: 1%; }
    @media screen and (max-width: 768px) {
      .club .club-list .culture ul {
        padding-bottom: 0; } }
    @media screen and (max-width: 768px) {
      .club .club-list .culture ul + ul {
        padding-top: 0;
        margin-top: 0; } }
  .club .tab-btn li {
    padding: 4%; }
    .club .tab-btn li.active {
      background: #e9dfee; }
  .club .tab-desc {
    margin: 0 auto;
    max-width: 920px; }
  .club .ribbon {
    margin-top: -16%;
    margin-bottom: 8%;
    padding: 1% 0 6%;
    position: relative;
    letter-spacing: 0.1em;
    z-index: 1; }
    .club .ribbon.spacing {
      letter-spacing: 0; }
  .club .club-list-wrapper {
    margin: 0 auto 0;
    max-width: 1200px;
    width: 90%;
    /*ul*/ }
    .club .club-list-wrapper ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-around; }
      .club .club-list-wrapper ul li {
        padding: .75em 0;
        width: 15%; }
        @media screen and (max-width: 768px) {
          .club .club-list-wrapper ul li {
            width: 25%; } }
        .club .club-list-wrapper ul li:nth-child(even) {
          margin-top: 2em; }
        .club .club-list-wrapper ul li .image {
          position: relative; }
        .club .club-list-wrapper ul li .back {
          display: block;
          margin: auto;
          width: 80%; }
        .club .club-list-wrapper ul li .float {
          object-fit: cover;
          height: 100%;
          max-width: inherit;
          position: absolute;
          bottom: 0;
          left: 50%;
          transform: translate(-50%, 0); }
        .club .club-list-wrapper ul li.on_layer {
          position: relative;
          z-index: 1; }
      .club .club-list-wrapper ul h5 {
        font-size: clamp(0.875rem, 0.818rem + 0.24vw, 1rem);
        margin-top: .25em;
        text-align: center; }
      .club .club-list-wrapper ul.last {
        margin: auto;
        max-width: 360px; }
        @media screen and (max-width: 768px) {
          .club .club-list-wrapper ul.last {
            display: none; } }
        .club .club-list-wrapper ul.last li {
          width: 50%; }
  .club #qa h4 {
    margin: 5% 0;
    text-align: center; }
  .club #qa h5 {
    border-bottom: 1px dashed #231815;
    font-size: 1.3em;
    line-height: 1.3;
    margin-bottom: 3%;
    padding-bottom: 3%;
    padding-left: 80px;
    position: relative; }
    .club #qa h5 span {
      color: #752586;
      font-size: 1.3em;
      font-weight: normal;
      line-height: 0.5;
      padding-bottom: 4%;
      position: absolute;
      bottom: 0;
      left: 0; }
      .club #qa h5 span strong {
        color: #752586;
        font-size: 2.2em;
        font-weight: normal; }
  .club #qa p {
    padding-left: 45px;
    position: relative; }
    .club #qa p span {
      color: #b18046;
      font-size: 1.7em;
      font-weight: normal;
      line-height: 1.2;
      position: absolute;
      top: 0;
      left: 0; }
  @media screen and (min-width: 769px) {
    .club .circle {
      font-size: 1.2em;
      padding: 3em 0;
      text-align: center; }
      .club .circle span {
        font-size: 1.2em; }
    .club #qa h4 img {
      width: 200px; } }

/***********************************************************************
facility
**********************************************************************/
.facility #facility ul {
  margin-bottom: 7%; }
.facility #facility li h5 {
  margin: 7% 0 4%; }
.facility #facility li:first-child h5, .facility #facility li:nth-child(2) h5 {
  margin: 3% 0 1%; }
.facility #facility .learning-commons {
  background-image: radial-gradient(circle at 0% 0%, transparent 10px, #efedde 0), radial-gradient(circle at 100% 0%, transparent 10px, #efedde 0), radial-gradient(circle at 0% 100%, transparent 10px, #efedde 0), radial-gradient(circle at 100% 100%, transparent 10px, #efedde 0);
  background-position: 0% 0%, 100% 0%, 0% 100%, 100% 100%;
  background-repeat: no-repeat;
  background-size: 55% 55%;
  outline: 1px solid #752586;
  outline-offset: -5px;
  padding: 3%; }
  .facility #facility .learning-commons .mincho {
    color: #752586; }
  .facility #facility .learning-commons p.mincho {
    font-size: 1.2em;
    line-height: 1; }
  .facility #facility .learning-commons h5.mincho {
    font-size: 2em;
    margin-bottom: 0.2em; }
.facility #facility .back-border {
  margin-top: 7%;
  padding-bottom: 1%; }
  .facility #facility .back-border h5 {
    color: #752586; }
@media screen and (min-width: 769px) {
  .facility #facility ul {
    margin-bottom: 4%; }
  .facility #facility li h5 {
    margin: 5% 0 1%; }
  .facility #facility .back-border {
    margin-top: 5%;
    padding: 2% 6%; }
    .facility #facility .back-border ul {
      margin-bottom: 0; } }

/***********************************************************************
performance
**********************************************************************/
.performance .box {
  background: url(../images/course/performance/box_back.png) no-repeat;
  background-size: 100% 100%;
  margin-bottom: 3%;
  padding: 3% 4%;
  text-align: center; }
  .performance .box.is-6-mobile {
    width: 48.5%; }
    .performance .box.is-6-mobile:nth-child(odd) {
      margin-right: 3%; }
  .performance .box p {
    color: #752586;
    font-size: 1.3em;
    line-height: 1;
    text-shadow: 0 0 0 #a67faa, 0 0 0 #a67faa, 0 0 8px #a67faa, 0 0 0 #a67faa; }
  .performance .box strong {
    color: #752586;
    font-size: 2.3em;
    font-weight: normal; }
.performance .table {
  margin-bottom: 5%; }
  .performance .table th, .performance .table td {
    padding: 0.5em 1em; }
  .performance .table td {
    text-align: center; }
  .performance .table td:last-child {
    background: #fff;
    text-align: left; }
  .performance .table.foreign p {
    padding-left: 1em; }
  .performance .table.foreign .country {
    font-weight: bold;
    padding: 0;
    text-decoration: underline; }
.performance .table4 tr:first-child th {
  white-space: nowrap; }
.performance .table4 th {
  white-space: inherit; }
.performance .table4 th, .performance .table4 td {
  padding: 0.5em 0; }
.performance .table4 td:last-child {
  text-align: center; }
@media screen and (max-width: 769px) {
  .performance .change {
    margin: 14% 0 0; } }
.performance #performance {
  margin-bottom: 8%; }
  @media screen and (max-width: 769px) {
    .performance #performance {
      margin-bottom: 11%; } }
  .performance #performance .text img {
    width: 100%; }
  .performance #performance .graph-wrapper {
    margin-bottom: 5%; }
    .performance #performance .graph-wrapper .column.is-7 {
      padding: 0.75rem; }
      @media screen and (min-width: 769px) {
        .performance #performance .graph-wrapper .column.is-7 {
          padding: 1.75rem; } }
    .performance #performance .graph-wrapper .text {
      text-align: left; }
.performance #recommendation {
  margin-top: -200px;
  padding-top: 200px; }
  @media screen and (max-width: 769px) {
    .performance #recommendation {
      padding-bottom: 3em; } }
  .performance #recommendation li {
    position: relative; }
  .performance #recommendation li::before {
    content: "●";
    color: #d2bdda;
    font-size: 1.1em;
    position: absolute;
    left: 0; }
  .performance #recommendation li a {
    color: #752586;
    font-size: 1.1em;
    padding-left: .5em;
    position: relative;
    text-decoration: underline; }
    .performance #recommendation li a::before {
      color: #d2bdda; }
    .performance #recommendation li a::after {
      background: url(../images/common/arrow_p.png) no-repeat;
      background-size: contain;
      content: "";
      height: 6px;
      margin: auto;
      position: absolute;
      bottom: 0;
      top: 0;
      right: -32px;
      width: 30px; }
.performance .record-wrapper {
  margin: 0 0 8%; }
  @media screen and (max-width: 769px) {
    .performance .record-wrapper {
      margin: 9% 0 9%; } }
  .performance .record-wrapper .inner {
    max-width: 720px; }
  .performance .record-wrapper .gradation-btn {
    max-width: 320px; }
@media screen and (min-width: 769px) {
  .performance .performance-box {
    margin: 0 auto;
    width: 60%; }
  .performance .box {
    padding: 3% 2%; }
    .performance .box p {
      font-size: 1.8em; }
    .performance .box .border-circle {
      font-size: 1.2em; }
      .performance .box .border-circle::after {
        bottom: -11px;
        right: -14px; }
      .performance .box .border-circle::before {
        bottom: -11px;
        left: -14px; }
    .performance .box.is-3-tablet {
      margin-right: 1%;
      width: 24%; }
      .performance .box.is-3-tablet:nth-child(odd) {
        margin-right: 1%; }
      .performance .box.is-3-tablet:first-child {
        margin-left: 0.5%; }
      .performance .box.is-3-tablet:last-child {
        margin-right: 0.5%; }
  .performance #recommendation {
    margin-top: 0;
    padding-top: 0; } }

/***********************************************************************
efforts
**********************************************************************/
.efforts .table td {
  background: #fff; }
.efforts .table tr:last-child th {
  background: #c4a7cc; }
.efforts .purple-box {
  background: #e9dfee;
  margin: 7% 0;
  padding: 9% 0; }
.efforts #support {
  margin-bottom: 3em;
  margin-top: -200px;
  padding-top: 200px; }
  .efforts #support .inner {
    max-width: 702px; }
@media screen and (min-width: 769px) {
  .efforts .purple-box {
    margin: 4% 0;
    padding: 3% 0; } }

.information .inner {
  max-width: 820px; }

/***********************************************************************
exam
**********************************************************************/
.exam section:not(#main) {
  margin-top: 15%; }
.exam .table + p {
  text-align: right; }
.exam #requirements {
  text-align: center; }
.exam #tuition h3 {
  margin-bottom: 2%; }
.exam #tuition h3 + p {
  text-align: center; }
.exam #tuition .table th, .exam #tuition .table td {
  font-size: 0.65em;
  padding: 1%;
  text-align: center; }
.exam #tuition .table td {
  /*text-align: right;*/ }
.exam #tuition .table tr:nth-child(6) th {
  background: #c4a7cc; }
.exam #tuition .table tr:nth-child(6) td {
  background: #d2bdda; }
.exam #birthplace .table th, .exam #birthplace .table td {
  font-size: 0.5em;
  padding: 1%;
  text-align: center; }
.exam #birthplace .table th {
  background: #d2bdda; }
.exam #birthplace .table td {
  background: #fff; }
.exam #birthplace .table tr:first-child th:not(:first-child),
.exam #birthplace .table tr:nth-child(2) th,
.exam #birthplace .table tr:last-child td {
  background: #c4a7cc; }
@media screen and (min-width: 769px) {
  .exam section:not(#main) {
    margin-top: 7%; }
  .exam #tuition .table th, .exam #tuition .table td,
  .exam #birthplace .table th, .exam #birthplace .table td {
    font-size: 1em; } }

/***********************************************************************
openschool
**********************************************************************/
.openschool .eventlist-text {
  font-size: 15px;
  text-align: center;
  margin: 10% 0 0; }
.openschool .eventlist {
  border-top: 1px solid #752586;
  margin-bottom: 11%;
  margin-top: 3%;
  position: relative; }
  .openschool .eventlist::before, .openschool .eventlist::after {
    content: "・";
    color: #752586;
    position: absolute;
    top: -12px; }
  .openschool .eventlist::before {
    left: -5px;
    text-shadow: -2px 0 0 #fff, -6px 0 0 #fff, 3px 0 0 #fff, 0 0 0 #fff; }
  .openschool .eventlist::after {
    right: -5px;
    text-shadow: -3px 0 0 #fff, -3px 0 0 #fff,3px 0 0 #fff, 0 0 0 #fff; }
  .openschool .eventlist li {
    border-bottom: 1px solid #752586;
    padding: 5%;
    position: relative; }
    .openschool .eventlist li::before, .openschool .eventlist li::after {
      content: "・";
      color: #752586;
      position: absolute;
      bottom: -10px; }
    .openschool .eventlist li::before {
      left: 0;
      text-shadow: -2px 0 0 #fff, -6px 0 0 #fff, 3px 0 0 #fff,0 0 0 #fff; }
    .openschool .eventlist li::after {
      right: 0;
      text-shadow: -3px 0 0 #fff, -3px 0 0 #fff, 3px 0 0 #fff, 0 0 0 #fff; }
    .openschool .eventlist li.yellow {
      background: #f7e082; }
    .openschool .eventlist li .columns {
      margin-bottom: 0; }
    .openschool .eventlist li h4 {
      color: #752586;
      font-size: 1.25em;
      margin-bottom: 5%;
      text-shadow: 0 0 0px #b17a19, 0 0 1px #b17a19, 0 0 0.85px rgba(177, 122, 25, 0.5); }
    .openschool .eventlist li .head-purple {
      border-radius: 5px;
      display: inline-block;
      padding: 0 5%; }
@media screen and (min-width: 769px) {
  .openschool .eventlist {
    margin-bottom: 5%;
    margin-top: 2%; }
    .openschool .eventlist li {
      padding: 3%; }
      .openschool .eventlist li h4 {
        font-size: 1.5em; } }

/*blog*/
.blog .inner {
  max-width: 820px; }

/***********************************************************************
todays-jogakuin
**********************************************************************/
.todays-jogakuin {
  /*jogakuin-blog*/ }
  @media screen and (min-width: 769px) {
    .todays-jogakuin .newslist + .columns {
      margin-top: 4%; } }
  .todays-jogakuin .jogakuin-blog {
    margin: 4em auto 3em;
    width: 90%;
    /*ul*/ }
    @media screen and (min-width: 769px) {
      .todays-jogakuin .jogakuin-blog {
        max-width: 1080px; } }
    .todays-jogakuin .jogakuin-blog .flex-box {
      max-width: 420px; }
    .todays-jogakuin .jogakuin-blog ul {
      flex-wrap: wrap;
      gap: 0 2%;
      margin-bottom: 1em; }
      .todays-jogakuin .jogakuin-blog ul li {
        border: 1px solid #752586;
        background-image: linear-gradient(90deg, #ffffff, #ebe3ed);
        border-radius: 10px;
        padding: 1em 1em 0;
        position: relative;
        margin: .5em 0 0;
        transition: .2s;
        width: 100%; }
        @media screen and (min-width: 769px) {
          .todays-jogakuin .jogakuin-blog ul li {
            margin: 2% 0 0;
            padding: 0;
            width: 32%; } }
        .todays-jogakuin .jogakuin-blog ul li::after {
          background: url(../images/top/arrow-purple.svg) no-repeat;
          background-size: contain;
          content: "";
          height: 19px;
          position: absolute;
          right: 4%;
          bottom: 0em;
          width: 10px;
          transition: .2s; }
          @media screen and (min-width: 769px) {
            .todays-jogakuin .jogakuin-blog ul li::after {
              bottom: 2em; } }
        .todays-jogakuin .jogakuin-blog ul li:hover::after {
          right: 3%; }
        .todays-jogakuin .jogakuin-blog ul li .column {
          flex-grow: 0; }
          @media screen and (max-width: 1080px) {
            .todays-jogakuin .jogakuin-blog ul li .column {
              flex-grow: 0; } }
        .todays-jogakuin .jogakuin-blog ul li a {
          background: none;
          padding: 0em !important; }
          @media screen and (min-width: 1080px) {
            .todays-jogakuin .jogakuin-blog ul li a {
              padding: 2em; } }
          .todays-jogakuin .jogakuin-blog ul li a::after {
            content: none; }
        .todays-jogakuin .jogakuin-blog ul li .date {
          padding-right: 1em;
          text-align: right; }
          @media screen and (min-width: 1080px) {
            .todays-jogakuin .jogakuin-blog ul li .date {
              padding-right: 0; } }
        .todays-jogakuin .jogakuin-blog ul li h5 {
          font-size: clamp(0.875rem, 0.818rem + 0.24vw, 1rem);
          width: inherit;
          white-space: inherit;
          overflow: hidden;
          text-overflow: inherit;
          line-height: 1.6; }
        .todays-jogakuin .jogakuin-blog ul li .image {
          padding-bottom: 0;
          /*padding-right: 0;
          padding-left: 0;*/
          position: relative;
          text-align: center; }
          @media screen and (min-width: 1080px) {
            .todays-jogakuin .jogakuin-blog ul li .image {
              padding-bottom: .75rem;
              padding-right: .75rem;
              padding-left: .75rem;
              text-align: inherit;
              width: calc(110px + 0.75rem + 0.75rem); } }
          .todays-jogakuin .jogakuin-blog ul li .image .shape {
            padding: 1PX;
            position: relative;
            min-width: 102px;
            display: inline-block; }
            @media screen and (min-width: 1080px) {
              .todays-jogakuin .jogakuin-blog ul li .image .shape {
                display: inherit; } }
            .todays-jogakuin .jogakuin-blog ul li .image .shape::before {
              content: "";
              background: #752586;
              position: absolute;
              /*top: calc(0.75rem - 1px);
              left: calc(0.75rem - 1px);*/
              top: 0;
              left: 0;
              width: 100%;
              height: 100%;
              clip-path: polygon(10% 0, 90% 0, 100% 10%, 100% 90%, 90% 100%, 10% 100%, 0 90%, 0 10%);
              z-index: 0;
              height: 102px;
              width: 102px;
              /*@media screen and (min-width:1080px) {
                  height: 137px;
                  width: 137px;
              }*/ }
          .todays-jogakuin .jogakuin-blog ul li .image img {
            clip-path: polygon(10% 0, 90% 0, 100% 10%, 100% 90%, 90% 100%, 10% 100%, 0 90%, 0 10%);
            object-fit: cover;
            height: 100px;
            width: 100px;
            position: relative; }
        .todays-jogakuin .jogakuin-blog ul li .text-box {
          flex-basis: auto; }
        .todays-jogakuin .jogakuin-blog ul li .type-list {
          display: flex;
          flex-wrap: wrap;
          padding: 1em .5em .5em; }
          @media screen and (min-width: 1080px) {
            .todays-jogakuin .jogakuin-blog ul li .type-list {
              padding: 0 1em .5em; } }

/*todays-jogakuin*/
/*user*/
.user .inner {
  max-width: 860px; }

/***********************************************************************
student
**********************************************************************/
@media screen and (min-width: 769px) {
  .student .newslist ul li {
    padding: 2% 0; } }

/***********************************************************************
private-news
**********************************************************************/
.private-news .contact-title {
  color: #80478c;
  margin-bottom: 1%; }
.private-news .contact-box {
  border: 2px solid #80478c;
  margin-bottom: 11%;
  padding: 4%; }
.private-news .newslist .border-gradation {
  margin-bottom: 0; }
.private-news .newslist .tab-btn {
  padding: 0; }
  .private-news .newslist .tab-btn li {
    background: #484848;
    border-top: 1px solid #484848;
    border-right: 1px solid #fff;
    border-radius: 0;
    margin-right: 0;
    padding: 2% 0; }
    .private-news .newslist .tab-btn li.active {
      background: #fff;
      color: #484848; }
    .private-news .newslist .tab-btn li:first-child.active {
      border-left: 1px solid #484848; }
    .private-news .newslist .tab-btn li:last-child.active {
      border-right: 1px solid #484848; }
.private-news .newslist .tab-desc {
  margin-top: 8%; }
@media screen and (min-width: 769px) {
  .private-news .contact-box {
    margin-bottom: 5%;
    padding: 2%; }
  .private-news .newslist .tab-btn li {
    padding: 1% 0; }
  .private-news .newslist .tab-desc {
    margin-top: 4%; } }

/***********************************************************************
privacy & sitepolicy
**********************************************************************/
#privacy li, #sitepolicy li {
  margin-bottom: 7%; }
  #privacy li p, #privacy li ul, #sitepolicy li p, #sitepolicy li ul {
    padding-left: 1em; }
#privacy h5, #sitepolicy h5 {
  font-size: 1.1em;
  margin-bottom: .3%; }
#privacy .contact div, #sitepolicy .contact div {
  float: right; }
  #privacy .contact div h5 + p, #sitepolicy .contact div h5 + p {
    padding-left: 0; }
@media screen and (min-width: 769px) {
  #privacy li,
  #privacy .text, #sitepolicy li,
  #sitepolicy .text {
    margin-bottom: 3%; } }

#sitepolicy li ul {
  margin-top: 1%; }
#sitepolicy li li {
  margin-bottom: 0; }

/***********************************************************************
qa
**********************************************************************/
.qa .page-navlist + p {
  color: #80478c; }
.qa section:not(#main) {
  margin-top: -85px;
  padding-top: 85px; }
.qa .qa-list li {
  margin: 4% 0; }
.qa .qa-list p {
  padding-left: 2em; }
  .qa .qa-list p span {
    border-radius: 50%;
    color: #fff;
    display: inline-block;
    height: 23px;
    line-height: 23px;
    position: absolute;
    left: 0;
    text-align: center;
    width: 23px; }
  .qa .qa-list p::after {
    content: none; }
.qa .qa-list .question {
  color: #80478c; }
  .qa .qa-list .question span {
    background: #80478c; }
.qa .qa-list .answer {
  cursor: unset;
  margin-top: 3%; }
  .qa .qa-list .answer span {
    background: #6d6c6c; }
@media screen and (min-width: 769px) {
  .qa section:not(#main) {
    margin-top: 0;
    padding-top: 0; } }

/***********************************************************************
en
**********************************************************************/
.en section:not(#main) {
  margin-bottom: 6%;
  margin-top: -85px;
  padding-top: 85px; }
.en .note {
  margin: 0 auto 2%;
  width: 70%; }
.en .image-box.message {
  width: 50%; }
.en .image-box.school-badge {
  width: 33%; }
.en .image-box.history {
  width: 80%; }
  .en .image-box.history .note {
    width: 100%; }
@media screen and (min-width: 769px) {
  .en section:not(#main) {
    margin-top: 0;
    padding-top: 0; }
  .en .image-box.message {
    width: 80%; }
  .en .image-box.school-badge {
    width: 50%; }
  .en .image-box.history {
    width: 45%; }
  .en .note {
    width: 45%; } }

/***********************************************************************
form --contact & request--
**********************************************************************/
.form-box p.text.midashigo {
  color: #80478c; }
.form-box .notes {
  border: 1px solid;
  padding: 3%; }
.form-box dl {
  margin-bottom: 0 !important; }
.form-box dt {
  color: #231815;
  padding-bottom: .2rem; }
  .form-box dt span {
    background: #e34335;
    border-radius: 5px;
    color: #fff;
    margin-left: 2%;
    padding: 0 1.5%; }
.form-box dd {
  padding: .2rem .75rem .3rem; }
  .form-box dd p {
    padding-left: 1.6em; }
  .form-box dd span {
    margin-bottom: 2%; }
.form-box input[type="text"], .form-box textarea {
  background: #dedbda;
  border-radius: 0;
  font-size: 16px;
  padding: 3%;
  width: 100%; }
.form-box input[type="tel"] {
  background: #dedbda;
  border-radius: 0;
  font-size: 16px;
  padding: 3%;
  width: 50%; }
.form-box input, .form-box textarea {
  border: none; }
.form-box .agree-box {
  border: 1px solid;
  margin: 0 auto;
  max-width: 470px;
  padding: 2% 0 3%;
  text-align: center; }
  .form-box .agree-box a {
    color: #80478c;
    text-decoration: underline; }
.form-box .confirm {
  display: none; }
.form-box .agree-box .mwform-checkbox-field-text {
  display: none; }
.form-box .request-check .mwform-checkbox-field {
  display: block;
  margin-left: 0 !important; }
@media screen and (min-width: 769px) {
  .form-box dt, .form-box dd {
    padding: .75rem; }
  .form-box .agree-box {
    padding: 1.5% 0 2%; } }

.contact-confirm .agree-box, .contact-confirm dt span, .request-confirm .agree-box, .request-confirm dt span {
  display: none; }

#irisletter .newslist h4 {
  margin-top: 1.5em;
  padding-bottom: 8px; }
#irisletter .newslist h5 a {
  padding-right: 15px;
  position: relative; }
  #irisletter .newslist h5 a::after {
    background: url(../images/common/documents_icon.jpg) no-repeat;
    background-size: contain;
    content: "";
    height: 13px;
    margin: auto 0;
    position: absolute;
    bottom: 0;
    top: 0;
    right: 0;
    width: 11px; }
@media screen and (min-width: 769px) {
  #irisletter .newslist li {
    padding: 2% 0; } }

/***/
.svg {
  max-width: 520px;
  width: 50%;
  height: auto;
  display: block;
  margin: 0px auto 100px;
  padding: 20px;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto; }

.st0 {
  fill: none;
  stroke: #fff;
  stroke-miterlimit: 5;
  animation: anim 5s ease-in 0s forwards; }

@keyframes anim {
  30% {
    fill: transparent; }
  60% {
    stroke-dashoffset: 0; }
  100% {
    stroke-dashoffset: 0;
    fill: #fff; } }
.wrapper {
  width: 100%;
  overflow: hidden;
  /*position: -webkit-sticky;
  position: sticky;*/
  top: 0;
  z-index: -1; }

#video {
  height: 100%;
  min-width: 100%;
  min-width: 100vw; }
  @media screen and (min-width: 768px) {
    #video {
      height: 100vh; } }

video {
  width: 100%;
  object-fit: cover; }

@media screen and (min-width: 768px) {
  .movie-bg {
    background: url(../images/top/yokojima.png);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    overflow: hidden;
    width: 100%;
    height: calc(100vh - 15px);
    opacity: .2; }

  video {
    width: 100%;
    object-fit: cover; } }
@media screen and (max-width: 950px) {
  .svg {
    margin: 2% auto 0;
    width: 70%; } }
@media screen and (max-width: 560px) {
  .wrapper {
    margin: 34px 0 0; } }
