/* CSS Document */
a.support {
  color: #005cb8; }

p {
  line-height: 1.8; }

.m-lead {
  background: url(../img/support/main_bg.jpg) no-repeat center/cover; }

.m-lead .m-lead-txt br.spbr {
  display: none; }
@media only screen and (max-width: 768px) {
  .m-lead .m-lead-txt br.spbr {
    display: block; } }

.schedule {
  margin: 0 auto 100px; }
  @media only screen and (max-width: 768px) {
    .schedule {
      margin: 0 auto 40px; } }
  .schedule-month-wrap {
    text-align: center; }
  .schedule-month {
    text-align: left;
    width: 162px;
    display: inline-block;
    vertical-align: top;
    padding: 0 1em 60px 0;
    background: url(../img/support/line_blue.png) no-repeat 100px 25px; }
    .schedule-month.is-even {
      background: url(../img/support/line_yellow.png) no-repeat 100px 25px; }
      .schedule-month.is-even:last-of-type {
        background: none; }
    @media only screen and (max-width: 768px) {
      .schedule-month {
        width: 140px;
        background: none; }
        .schedule-month.is-even {
          background: none; } }
    .schedule-month dt {
      font-size: 12px;
      font-weight: 500;
      color: #fff;
      text-align: center;
      display: inline-block;
      padding: 10px;
      width: 82px;
      background: #005cb8;
      border-radius: 5px;
      position: relative;
      margin: 0 0 22px; }
      @media only screen and (max-width: 768px) {
        .schedule-month dt {
          font-size: 11px;
          padding: 7px;
          width: 72px; } }
      .schedule-month dt:before {
        content: '';
        display: block;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 10px 0 10px 12px;
        border-color: transparent transparent transparent #005cb8;
        position: absolute;
        bottom: -9px;
        left: 13px;
        transform: rotate(-40deg); }
      .schedule-month dt b {
        display: block;
        font-size: 28px; }
        @media only screen and (max-width: 768px) {
          .schedule-month dt b {
            font-size: 22px; } }
      .schedule-month dt img {
        position: absolute;
        top: -42px;
        left: 0;
        max-width: 82px; }
        @media only screen and (max-width: 768px) {
          .schedule-month dt img {
            display: none; } }
    .schedule-month dd {
      position: relative;
      padding: 0 0 0 12px;
      margin: 0 0 9px;
      font-size: 13px;
      line-height: 1.3em; }
      @media only screen and (max-width: 768px) {
        .schedule-month dd {
          font-size: 12px; } }
      .schedule-month dd:before {
        content: '';
        display: block;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #005cb8;
        position: absolute;
        top: 4px;
        left: 0; }
    .is-even dt {
      background: #e5bd00; }
      .is-even dt:before {
        border-color: transparent transparent transparent #e5bd00; }
    .is-even dd:before {
      background: #e5bd00; }
  .schedule-img {
    display: flex;
    justify-content: center; }
    @media only screen and (max-width: 768px) {
      .schedule-img {
        flex-wrap: wrap; } }
    .schedule-img li {
      text-align: center;
      margin: 0 10px 0 0;
      line-height: 1.5em; }
      @media only screen and (max-width: 768px) {
        .schedule-img li {
          font-size: 10px;
          letter-spacing: 0;
          width: 29%;
          margin-bottom: 15px; } }
      @media only screen and (min-width: 769px) {
        .schedule-img li {
          width: 192px; } }
      .schedule-img li:last-child {
        margin: 0; }
      .schedule-img li img {
        margin: 0 0 10px; }
        @media only screen and (max-width: 768px) {
          .schedule-img li img {
            margin: 0 0 6px; } }

.schedule-month.elem {
  opacity: 0; }
  @media only screen and (max-width: 768px) {
    .schedule-month.elem {
      opacity: 1; } }

.schedule-month:first-of-type.elem.isAnimate {
  animation: fadeInup 0.5s 0s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:first-of-type.elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(2).elem.isAnimate {
  animation: fadeInup 0.5s 0.2s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(2).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(3).elem.isAnimate {
  animation: fadeInup 0.5s 0.4s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(3).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(4).elem.isAnimate {
  animation: fadeInup 0.5s 0.6s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(4).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(5).elem.isAnimate {
  animation: fadeInup 0.5s 0.8s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(5).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(6).elem.isAnimate {
  animation: fadeInup 0.5s 1.0s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(6).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(7).elem.isAnimate {
  animation: fadeInup 0.5s 1.2s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(7).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(8).elem.isAnimate {
  animation: fadeInup 0.5s 1.4s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(8).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(9).elem.isAnimate {
  animation: fadeInup 0.5s 1.6s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(9).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(10).elem.isAnimate {
  animation: fadeInup 0.5s 1.8s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(10).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(11).elem.isAnimate {
  animation: fadeInup 0.5s 2.0s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(11).elem.isAnimate {
      animation: none; } }

.schedule-month:nth-of-type(12).elem.isAnimate {
  animation: fadeInup 0.5s 2.2s ease-in-out;
  animation-fill-mode: both; }
  @media only screen and (max-width: 768px) {
    .schedule-month:nth-of-type(12).elem.isAnimate {
      animation: none; } }

.support.is-bg {
  background: #005cb8;
  padding: 100px 0 50px; }
  @media only screen and (max-width: 768px) {
    .support.is-bg {
      padding: 50px 0 30px; } }
.support .m-ttl-02 span {
  color: #fff; }
  .support .m-ttl-02 span:after {
    background: #fff; }
.support-box {
  border: #5d9ad4 15px solid;
  background: #5d9ad4; }
  @media only screen and (max-width: 768px) {
    .support-box {
      border: #5d9ad4 8px solid; } }
.support-unit {
  background: #fff;
  margin: 0 0 10px; }
  .support-unit:last-of-type {
    margin-bottom: 0; }
  .support-unit-ttl {
    font-size: 20px;
    font-weight: 400;
    color: #fff;
    background: #002c64;
    border-bottom-right-radius: 6px;
    display: inline-block;
    padding: 8px 15px 10px 14px; }
    @media only screen and (max-width: 768px) {
      .support-unit-ttl {
        font-size: 18px;
        padding: 6px 10px; } }
  .support-unit-desc {
    padding: 20px 30px; }
    @media only screen and (max-width: 768px) {
      .support-unit-desc {
        padding: 20px 15px; } }
  .support-unit p {
    padding: 0 0 0 1em; }
  .support-unit-dl {
    margin: 0 0 12px; }
    .support-unit-dl dt {
      font-size: 16px;
      font-weight: 500;
      color: #005cb8;
      position: relative;
      margin: 0 0 10px 0; }
      .support-unit-dl dt:before, .support-unit-dl dt:after {
        content: '';
        display: block; }
      .support-unit-dl dt:before {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: #e5bd00;
        position: absolute;
        top: 4px;
        left: 0;
        z-index: 20; }
      .support-unit-dl dt:after {
        width: 100%;
        height: 1px;
        position: absolute;
        top: 8px;
        left: 0;
        border-top: dotted 2px #005cb8; }
      .support-unit-dl dt span {
        display: inline-block;
        background: #fff;
        position: relative;
        z-index: 10;
        padding: 0 8px 0 1em; }
    .support-unit-dl dd {
      line-height: 1.8;
      padding: 0 8px 10px 1em; }

.oneday {
  background: #e8f8fd;
  padding: 100px 0 50px;
  position: relative; }
  @media only screen and (max-width: 768px) {
    .oneday {
      padding: 40px 0 25px; } }
  .oneday .col-6 {
    width: 100%; }
    @media only screen and (min-width: 769px) {
      .oneday .col-6 {
        max-width: 480px; } }
    .oneday .col-6:last-of-type {
      margin-left: 40px; }
      @media only screen and (max-width: 768px) {
        .oneday .col-6:last-of-type {
          margin-left: 0; } }
  .oneday-unit {
    width: 100%;
    background: #fff;
    border: 1px solid #c9e9f3;
    position: relative;
    padding: 40px 40px 20px 30px;
    margin: 0 0 50px; }
    @media only screen and (max-width: 768px) {
      .oneday-unit {
        margin: 0 0 35px;
        padding: 35px 20px 14px 20px; } }
    .oneday-unit:after {
      content: '';
      display: block;
      width: 25px;
      height: 23px;
      background: url(../img/support/icon_arrow.png) no-repeat 0 0/contain;
      position: absolute;
      bottom: -37px;
      left: calc(50% - 11px); }
      @media only screen and (max-width: 768px) {
        .oneday-unit:after {
          width: 18px;
          height: 16px;
          bottom: -27px; } }
    .oneday-unit:last-of-type:after {
      display: none; }
    .oneday-unit-time {
      font-size: 18px;
      font-weight: 500;
      color: #fff;
      display: inline-flex;
      align-items: center;
      background: #002c64;
      padding: 10px 15px;
      border-radius: 8px;
      position: absolute;
      top: -20px;
      left: 10px; }
      @media only screen and (max-width: 768px) {
        .oneday-unit-time {
          font-size: 15px;
          padding: 6px 12px;
          top: -15px; } }
      .oneday-unit-time img {
        margin: 0 7px 0 0; }
      .oneday-unit-time:after {
        content: '';
        display: block;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 10px 0 10px 12px;
        border-color: transparent transparent transparent #002c64;
        position: absolute;
        bottom: -9px;
        left: 13px;
        transform: rotate(-40deg); }
  .oneday dt {
    display: inline-block;
    position: relative; }
    .oneday dt:after {
      content: '';
      display: block;
      width: calc(100% + 8px);
      height: 40%;
      background: #f6ed00;
      position: absolute;
      bottom: 8px;
      left: -4px;
      border-radius: 7px; }
    .oneday dt span {
      display: inline-block;
      font-size: 16px;
      font-weight: 500;
      color: #005cb8;
      margin: 0 0 16px;
      position: relative;
      z-index: 10; }
      @media only screen and (max-width: 768px) {
        .oneday dt span {
          font-size: 15px; } }
  .oneday dd {
    line-height: 1.6; }
  @media only screen and (min-width: 769px) {
    .oneday-img img {
      position: absolute; } }
  .oneday-img-01 {
    width: 65px;
    top: -30px;
    left: calc(50% + 160px); }
  .oneday-img-02 {
    width: 126px;
    top: 140px;
    left: calc(50% - 300px); }
  .oneday-img-03 {
    width: 151px;
    top: 310px;
    left: calc(50% - 120px); }
  .oneday-img-04 {
    width: 158px;
    top: 610px;
    left: calc(50% - 640px); }
  .oneday-img-05 {
    width: 189px;
    top: 70px;
    left: calc(50% + 400px); }
  .oneday-img-06 {
    width: 126px;
    top: 530px;
    left: calc(50% + 430px); }
  .oneday-img-07 {
    margin: -30px 0 0; }

.oneday-img-02.elem,
.oneday-img-03.elem,
.oneday-img-04.elem,
.oneday-img-05.elem,
.oneday-img-06.elem {
  opacity: 0; }

.oneday-img-02.elem.isAnimate {
  animation: fadeInup 1.0s 0s ease-in-out;
  animation-fill-mode: both; }

.oneday-img-05.elem.isAnimate {
  animation: fadeInup 1.0s 0.2s ease-in-out;
  animation-fill-mode: both; }

.oneday-img-03.elem.isAnimate {
  animation: fadeInup 1.0s 0.4s ease-in-out;
  animation-fill-mode: both; }

.oneday-img-06.elem.isAnimate {
  animation: fadeInup 1.0s 0.6s ease-in-out;
  animation-fill-mode: both; }

.oneday-img-04.elem.isAnimate {
  animation: fadeInup 1.0s 0.8s ease-in-out;
  animation-fill-mode: both; }

@keyframes fadeInup {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
.experience {
  text-align: center;
  padding: 70px 0 100px;
  position: relative;
  background: url(../img/support/bg_experience01.png) no-repeat 0 0/auto 100%, url(../img/support/bg_experience02.png) no-repeat right bottom/170px auto; }
  @media only screen and (max-width: 768px) {
    .experience {
      padding: 40px 0;
      background: none; } }
  @media only screen and (max-width: 768px) {
    .experience p {
      text-align: left; } }
  .experience p span {
    font-size: 12px; }
  .experience-img {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin: 30px auto 0; }
    @media only screen and (max-width: 768px) {
      .experience-img {
        flex-wrap: wrap; } }
    .experience-img li {
      text-align: center;
      margin: 0 15px 0 0;
      line-height: 1.3em; }
      @media only screen and (max-width: 768px) {
        .experience-img li {
          font-size: 12px;
          width: 43%;
          margin-bottom: 15px; } }
      @media only screen and (min-width: 769px) {
        .experience-img li {
          max-width: 150px; }
          .experience-img li:last-child {
            margin: 0; } }
      @media only screen and (max-width: 768px) {
        .experience-img li:nth-child(2n) {
          margin: 0 0 15px; } }
      .experience-img li img {
        margin: 0 0 10px; }
        @media only screen and (max-width: 768px) {
          .experience-img li img {
            margin: 0 0 5px; } }

.support-unit-dl dt {
  line-height: 1.3em; }

/*# sourceMappingURL=support.css.map */
