@charset "utf-8";
/* CSS Document */
.calender {
  position: relative;
  overflow: hidden;
  height: 100%;
  padding: 30px 0;
}
.calender .title {
    text-align: center;
}
.calender .title .title_ch span {
    font-size: 165%;
    font-weight: bold;
    padding: 0 10px;
    border-right: 1px #b0b0b0 solid;
    color: #35073e;
}

.calender .title .title_ch span:nth-child(2n+2) {
    color: #773683;
}
.calender .title .title_en{
    color: #187096;
    position: relative;
    padding: 10px 0;
    text-transform: uppercase;
}
.calender .title p {
  margin: 0;
}

.calender .more {
    display: block;
    padding: 10px 0 0 0;
    text-align: center;
}

.calender .more a::before {content: "";width: 0;height: 0;border-style: solid;border-width: 5px 0 5px 9px;border-color: transparent transparent transparent #6b6b6b;position: absolute;right: 15px;top: 50%;}

.calender .more a {
    color: #6c6c6c;
    padding: 20px 40px 10px 40px;
    display: inline-block;
    border-bottom: 1px #b9b9b9 solid;
    position: relative;
    letter-spacing: 2px;
    text-decoration: none;
}

.calender .more a:hover {
    color: #773683;
}

.calender .more a:hover::after {content: "";width: 100%;}

.calender .more a::after {
    content: "";
    position: absolute;
    height: 1px;
    background-color: #773683;
    display: block;
    right: 0;
    bottom: -1px;
    width: 0;
    transition: all 200ms ease-out;
}
.calender .more a:hover::before {border-color: transparent transparent transparent #773683;}

.calender .detail .infobox {
  position: relative;
  z-index: 1;
}
.calender .detail::after {
  content: "";
  display: block;
  background-color: #d7d7d7;
  position: absolute;
  z-index: 0;
}
.calender .detail .date {
  color: #773683;
  font-weight: bold;
}
.calender .detail .date::after {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  background-color: #187096;
  border-radius: 100%;
  border: 3px #fff solid;
}
.calender .detail .part, .calender .detail .con {
  letter-spacing: 1px;
  padding: 2px 0;
}
.calender .detail .part {
  color: #565656;
  font-size: 95%;
}
.calender .detail .con,.calender .detail .con a {
  font-weight: bold;
  font-size: 110%;
  color: #000;
}

.calender .detail .con a:hover {
    color: #3153ba;
}


    .calender .detail {
  position: relative;
}
/*調整比例*/
.col-lg-7 .calender .detail, .col-lg-6 .calender .detail, .col-lg-5 .calender .detail, .col-lg-4 .calender .detail, .col-lg-3 .calender .detail,.col-md-11 .calender .detail, .col-md-10 .calender .detail, .col-md-9 .calender .detail, .col-md-8 .calender .detail, .col-md-7 .calender .detail, .col-md-6 .calender .detail{
  padding: 85px 25px 40px 155px !important;
}
.col-lg-7 .calender .detail::after, .col-lg-6 .calender .detail::after, .col-lg-5 .calender .detail::after, .col-lg-4 .calender .detail::after, .col-lg-3 .calender .detail::after,.col-md-11 .calender .detail::after, .col-md-10 .calender .detail::after, .col-md-9 .calender .detail::after, .col-md-8 .calender .detail::after, .col-md-7 .calender .detail::after, .col-md-6 .calender .detail::after{
  width: 2px;
  top: 50px;
  left: 154px;
  bottom: 30px;
  height: inherit;
}
.col-lg-7 .calender .detail .infobox, .col-lg-6 .calender .detail .infobox, .col-lg-5 .calender .detail .infobox, .col-lg-4 .calender .detail .infobox, .col-lg-3 .calender .detail .infobox,.col-md-11 .calender .detail .infobox, .col-md-10 .calender .detail .infobox, .col-md-9 .calender .detail .infobox, .col-md-8 .calender .detail .infobox, .col-md-7 .calender .detail .infobox, .col-md-6 .calender .detail .infobox{
  padding: 15px 0 0px 20px !important;
  width: 100%;
}
.col-lg-7 .calender .detail .date, .col-lg-6 .calender .detail .date, .col-lg-5 .calender .detail .date, .col-lg-4 .calender .detail .date, .col-lg-3 .calender .detail .date,.col-md-11 .calender .detail .date, .col-md-10 .calender .detail .date, .col-md-9 .calender .detail .date, .col-md-8 .calender .detail .date, .col-md-7 .calender .detail .date, .col-md-6 .calender .detail .date{
  display: inline-flex;
  position: absolute;
  left: -90px;
}
.col-lg-7 .calender .detail .date::after, .col-lg-6 .calender .detail .date::after, .col-lg-5 .calender .detail .date::after, .col-lg-4 .calender .detail .date::after, .col-lg-3 .calender .detail .date::after,.col-md-11 .calender .detail .date::after, .col-md-10 .calender .detail .date::after, .col-md-9 .calender .detail .date::after, .col-md-8 .calender .detail .date::after, .col-md-7 .calender .detail .date::after, .col-md-6 .calender .detail .date::after{
  margin: 5px 0 0 10px;
}
@media screen and (max-width: 992px) and (min-width: 767px) {
    .col-sm-12 .calender .detail,.col-md-12 .calender .detail {
    padding: 40px 90px 40px 160px !important;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-around;
    justify-content: space-around;
}
    .col-sm-12 .calender .detail .infobox,.col-md-12 .calender .detail .infobox {
    padding: 0 20px !important;
    width: 25%;
}
.col-sm-12 .calender .detail::after,.col-md-12 .calender .detail::after {
    height: 2px;
    top: 74px;
    left: 150px;
    right: 90px;
    width: auto;
}
.col-sm-12 .calender .detail .date,.col-md-12 .calender .detail .date{
        text-align: center;
        position: relative;
        left: inherit;
        display: block;
    }
    .col-sm-12 .calender .detail .date::after,.col-md-12 .calender .detail .date::after{
    margin: 5px auto 0 auto;
}
}
@media screen and (min-width: 767px) {
    .calender .detail {
  padding: 40px;
  display: -webkit-flex;
  display:flex;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  -webkit-justify-content:space-around;
  justify-content:space-around;
}
    .calender .detail::after {
  height: 2px;
  top: 74px;
  left: 0;
  right: 0;
}    
    .calender .detail .infobox {
  padding: 0 20px;
  width: 25%;
}
    .calender .detail .date {
  text-align: center;
}
    .calender .detail .date::after {
  margin: 5px auto 0 auto;
}
}
@media screen and (max-width: 767px) {
    .calender .detail {
  padding: 20px 20px 20px 105px;
}
    .calender .detail::after {
  width: 2px;
  top: 20px;
  left: 106px;
  bottom: 0;
}
    .calender .detail .infobox {
  padding: 15px 0 0 20px;
}
    .calender .detail .date {
  display: inline-flex;
  position: absolute;
  left: -90px;
}
    .calender .detail .date::after {
  margin: 5px 0 0 10px;
}
}