@charset "utf-8";
/* CSS Document */
.calender {
  position: relative;
  overflow: hidden;
  height: 100%;
}

.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: #0033a0;
  font-weight: bold;
}
.calender .detail .date::after {
  content: "";
  position: absolute;
  display: block;
}
.calender .detail .con {display: -webkit-box;-webkit-box-orient: vertical;-webkit-line-clamp: 3;overflow: hidden;}
.calender .detail .part {
  color: #565656;
  font-size: 95%;
}
.calender .detail .con,.calender .detail .con a {
  font-weight: bold;
  font-size: 110%;
  color: #000;
  text-decoration: none;
}

.calender .detail .con a:hover {
    color: #3153ba;
}
/*調整比例*/
.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: 0 0 40px 105px;
  display: inherit;
  position: relative;
}
.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: 1px;
  top: 0;
  left: 105px;
  bottom: 0;
  height: inherit;
}
.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%;
  margin: 0;
}
.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-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{
    background-color: #0033a0;
    height: 3px;
    width: 11px;
    left: 85px;
    top: 40%;
    transform: inherit;
}

@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 0;
  display: -webkit-flex;
  display:flex;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  -webkit-justify-content:space-around;
  justify-content:space-around;
  position: relative;
}
    .calender .detail::after {
  height: 1px;
  top: 49px;
  left: 0;
  right: 0;
}    
    .calender .detail .infobox {
  padding: 0 20px;
  width: 25%;
  margin: -30px 0 0 0;
}
    .calender .detail .date {
  text-align: center;
  margin: 0 0 30px 0;
}
    .calender .detail .date::after {
 width: 12px;
 height: 12px;
 -webkit-transform: rotate(135deg) translate(0, 0);
 transform: rotate(135deg) translate(0, 0);
 border-top: solid 3px #0033a0;
 left: 50%;
 border-left: solid 3px #0033a0;
 top: 34px;
}
}
@media screen and (max-width: 767px) {
    .calender .detail {
  padding: 0 0 40px 105px;
  position: relative;
}
    .calender .detail::after {
  width: 1px;
  top: 0;
  left: 105px;
  bottom: 0;
}
    .calender .detail .infobox {
  padding: 15px 0 0 20px;
}
    .calender .detail .date {
  display: inline-flex;
  position: absolute;
  left: -90px;
}
    .calender .detail .date::after {
  background-color: #0033a0;
  height: 3px;
  width: 11px;
  left: 85px;
  top: 40%;
}
}