/* Theme Name: * Theme Name: HTMLレイアウト標準テンプレート用CSS
* Theme URI:
* Description: 共通で使うスタイル
* Created Date: 2018.02.28
* Update Date: 2018.04.27
*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@400;500;600;700;900&display=swap')
main{
  width: 1000px;
  margin: 0 auto;
}


body {
  margin: 0 auto;
  font-family: '小塚ゴシック Pro', 'イワタ中太丸ゴシック', 'イワタミンゴ', 'イワタ新ゴシックＬ';
}

h2 {
  color: #002C72;
  text-align: center;
  font-size: 40px;
  margin: 50px 0 0 0;
}

p {
  font-size: 18px;
  margin: 0;
}

ul {
  margin: 0;
  padding: 0px;
  list-style: none;
}

li {
  font-size: 18px;
}

a img:hover {
  opacity: .8;
  transition: .5s
}

/*------------------------------------
  common
------------------------------------*/
section {
  width: 1000px;
  margin: 0 auto;
}
.section-primary .section-content {
  margin: 10px auto;
}

/*------------------------------------
  Toitsu
------------------------------------*/
#toitsu {
  width: 1000px;
  margin: 0 auto;
  border: 2px solid #002C72;
}

.toitsu_target {
  border: 5px solid #002C72;
  font-weight: bold;
  font-size: 30px;
  border-radius: 15px;
  text-align: center;
  padding: 3px;
  background-color: #fff;
  margin: 20px 20px 0 20px;

}

.toitsu_target span {
  color: #002C72;
}

.toitsu_ttl {
  font-weight: bold;
  font-size: 32px;
  text-align: center;
}

.toitsu_ttl_margin {
  margin-top: 20px;
  margin-bottom: 0;
}

.toitsu_ttl span {
  color: #dd0f17;
}

.toitsu_detail {
  text-align: center;
  font-size: 30px;
}

.toitsu_detail a {
  color: #000;
  font-weight: bold;
  text-decoration: underline;
}

.senbatsu {
  font-weight: bold;
  font-size: 26px;
  margin: 0;
}

.fly_to_toitsu {
  font-weight: bold;
  font-size: 22px;
  margin-top: 10px;
}

.fly_to_toitsu a {
  color: #000;
  text-decoration: underline;
}

#toitsu_content {
  border: 5px dotted #002c72;
}

.top-text {
  margin-top: 40px;
}
.bannerBox {
    width: 900px;
    margin: 10px auto;
    text-align: center;
}

.application-period{
  border: 2px solid #009380;
  margin: 2em auto;
  padding: 1.5em;
  width: 70%;
}


.application-period.closed,
.application-period.with-information{
  border: none;
  width: fit-content;
  padding: auto; 
}


.application-period.closed::after{
  border: 2px solid #f33;
  color: #f33;
  content: "本年の選抜試験申し込み受付は終了いたしました";
  display: block;
  font-size: 1.3em;
  font-weight: 900;
  margin-top: 1em;
  padding: 2em 0;
  text-align: center;
  width: 100%;
}

.application-period.closed .schedule-list{
  display: none;
}

.application-period-title{
  color: #333;
  font-size: 22px;
  margin: 0 auto;
  text-decoration: underline;
}

.schedule-list{
  font-weight: bold;
  margin: 1em auto 0;
  padding: 0;
  position: relative;
}

.schedule-detail{
  display: flex;
  margin: .5em 0;
  position: relative;
}

.schedule-list.closed .schedule-detail{
  filter: blur(.1em);
}

.schedule-detail.closed::before{
  align-items: center;
  background: rgba(255,255,255,.8);
  border: 2px solid #f33;
  color: #f33;
  content: "申し込み受付は終了いたしました";
  display: flex;
  height: 100%;
  justify-content: center;
  position: absolute;
  width: 100%;
}

.schedule-detail-list{
  margin-left: 1em;
}

.detail-period{
  font-weight: normal;
}

.information-text{
  border: 2px solid #f33;
  color: #f33;
  font-size: 1.3em;
  font-weight: 900;
  margin-top: 1em;
  padding: 1em 3em;
  text-align: center;
  width: 100%;
  font-size: larger;
}
.information-text span{
  display: inline-block;
}

/*------------------------------------
  Button
------------------------------------*/
.apply {
  text-align: center;
}

.apply a {
  width: 780px;
  display: inline-block;
  background-color: #79be6d;
  font-size: 40px;
  font-weight: 600;
  color: #fff;
  border-radius: 20px;
  line-height: 90px;
  box-shadow: 0px 7px 0px 0px #4a883d;
  position: relative;
  overflow: hidden;
}

.apply a::before {
  position: absolute;
  content: '';
  width: 860px;
  height: 120px;
  opacity: .2;
  background-color: #fff;
  border-radius: 50%;
  top: -65px;
  left: -50px;
}

.apply a:hover {
  top: 7px;
  box-shadow: none;
}

.apply a span {
  font-size: 0.8em;
}

.apply-text{
  font-size: 30px;
}

.btn-area{
  align-items: flex-start;
  display: flex;
  font-family: 'Noto Sans JP', sans-serif;
  justify-content: space-around;
  width: 1000px;
  margin: 0 auto;
}

.btn-area-inner{
  width: 50%;
}

.btn-pr-text{
  font-weight: bold;
  text-align: center;
}

.btn-pr-text::before{
  content: "＼";
}

.btn-pr-text::after{
  content: "／";
}

.text-red{
  color: #f00;
}

.btn{
  color: #fff;
  display: block;
  font-size: 32px;
  font-weight: normal;
  letter-spacing: 2px;
  margin: 0 auto;
  padding: .2em 0;
  position: relative;
  text-align: center;
  width: 90%;
}

.btn::after{
  background: #fff;
  content: "";
  height: 100%;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  width: 100%;
  transition: all .3s;
}

.btn:hover::after{
  content: "";
  display: block;
  filter: blur(20px);
  opacity: .3;
}

.btn-document-request{
  background: #06c;
  box-shadow: 0 0 0 2px #06c inset, 0 0 0 4px #fff inset;
}

.btn-entry{
  background: #f30;
  box-shadow: 0 0 0 2px #f30 inset, 0 0 0 4px #fff inset;
}

.fas.fa-file-alt{
  margin: 0 .1em;
}

.btn-text-small{
  font-size: .6em;
}

.btn-note{
  font-size: .9em;
  text-align: center;
}

.btn-note::before{
  content: "※";
}

/*------------------------------------
  Box
------------------------------------*/

.section-secondary.col-6,
.section-secondary.col-4 {
  margin-bottom: 0;
}


/*------------------------------------
  To top
------------------------------------*/
.global-page-top-button .page-top {
  margin: 0;
  padding: 0;
  position: fixed;
  right: 16px;
  bottom: 90px;
  z-index: 9999;
}

.global-page-top-button .page-top {
  display: block;
  background: #009380;
  width: 50px;
  height: 50px;
  cursor: pointer;
  border-radius: 50px;

  color: #fff;
  line-height: 50px;
  text-decoration: none;
  text-align: center;

  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
}

/* clearfix */
.cf:after {
  content: '.';
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.cf {
  display: inline-block;
}

.mini {
  width: 90%;
  display: block;
  margin: 0 auto 20px;
}

.mini2 {
  width: 600px;
  display: block;
  margin: 0 auto 20px;
}

.bottom {
  margin-bottom: 15px;
}

/* top */
#content {
  width: 960px;
  margin: 40px auto;
}

.mainvisual {
  margin: .5% auto 20px;
  width: 100%;
  background-image: url('../img/bg.jpg');
  background-repeat: repeat;
}

.mv-inner {
  width: 1000px;
  margin: 0 auto;
  text-align: center;
  padding: 30px 0 0;
}

.mv-img {
  width: 900px;
}

.page_ttl {
  text-align: center;
  font-size: 31px;
  width: 100%;
  background-color: #002C72;
  padding: 15px 0 20px;
  color: #fff;
}

.page_ttl span {
  border-bottom: 2px dashed #fff;
  padding-bottom: 5px;
  text-align: center;
  font-size: 30px;
}

.get{
  margin: 2em auto;
}

.nobel_content {
  width: 1000px;
  margin: 0 auto;
}
.nobel-title {
  margin: 30px 0;
  border-bottom: solid 2px black;
}
.nobel-subtitle {
  margin: 30px 0 10px;
  font-size: 20px;
  width: 100px;
  text-align: center;
  border-bottom: solid 2px orange;
}
.nobel-text {
 margin: 50px 0 70px;
 font-size: 22px;
}

.banners-container {
  width: fit-content;
  margin: 0 auto;
}

.banner-item {
  width: 100%;
  margin: 5px 0;
}

.link-text {
  text-decoration: underline;
}