/* カレンダー2列 */
.xo-months{
    display:flex;
}
.xo-month-wrap{
  width: 50%;
  margin: 0 5px;
}
@media (max-width: 768px) {
  .xo-months{
      display:block;
  }
  .xo-month-wrap{
    width: 100%;
    margin: 0;
  }
}

/* 背景囲み */
.bg {
  background: #e8f6fb;
  padding: 10px 15px;
  display: block;
  border: 1px solid #fff;
  box-shadow: 0 3px 3px #ebeae8;
  border-radius: 13px 0;
}

/* 文字囲み */
span.bg {
    background: #004BA0;
    color: #fff;
    padding: 5px;
    border-radius: 3px;
    display: block;
}

/* 行揃え */
.indent{
  margin-left:4em;
  text-indent:-4em;
}
.indent span.bg {
    display: inline;
}

/* 角丸枠線 */
.frame {
  border: 1px solid #004BA0;
  border-radius: 6px;
  padding: 1em;
  position: relative;
  display: flex;
}

.span_6 .frame,.span_4 .frame {
  margin-top: 30px;
}

@media (max-width: 767px){
  .span_6 .frame,.span_4 .frame {
    margin-top: 20px;
  }
  .frame {
    display: block;
  }
  .frame .span_2,
  .frame .span_3,
  .frame .span_4,
  .frame .span_5,
  .frame .span_6,
  .frame .span_7,
  .frame .span_8,
  .frame .span_9,
  .frame .span_10{
    width: 100%!important;
  }
}


/* オプション下矢印 */
.frame.arrow:after {
  border-color: transparent transparent transparent #004BA0;
  border-style: solid;
  border-width: 26px 0 26px 18px;
  content: '';
  margin-top: -11px;
  position: absolute;
  right: 50%;
  bottom: -36px;
  transform: rotate(90deg);
}
/* 最後の矢印消す */
.frame.arrow.end:after {
display: none;
}

/* 横並びのコンテンツ高さ合わせる */
.wrap{
  display: flex;
}



.dia-table td {
    text-align: left;
}

@media (max-width: 767px) {
    .top-medical__item--4 {
        flex-direction: column-reverse !important;
    }
}