app-r3 {
    display: block;
    height: 100%;
    padding: 12px;
    background-color: #2b589b;
}

img {
    pointer-events: none;
}

#r3-bg {
    width: 1576px;
    height: 1056px;
    max-height: 1056px;
    transform-origin: top left;
    position: relative;
  }

  #r3-b1 {
    width: 782px;
    height: 660px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b1-title {
    width: 187px;
    height: 48px;
    display: flex;
  align-items: center;
  justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background-color: #0d1a2e;
  }
  #r3-b1-img {
    width: 790px;
    height: 620px;
    position: absolute;
    top: 48px;
    left: 0;
    padding: 15px;
  }

  #r3-b2 {
    width: 782px;
    height: 400px;
    position: absolute;
    top: 0;
    left: 794px;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b2-title {
    width: 170px;
    height: 48px;
    display: flex;
  align-items: center;
  justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background-color: #0d1a2e;
  }
  #r3-b2-bg1 {
    width: 750px;
    height: 328px;
    position: absolute;
    top: 56px;
    left: 20px;
    border-radius: 8px;
    border: solid 1px #809bc3;
    background-color: #809bc3;
  }
  #r3-b2-bg21 {
    width: 105px;
    height: 150px;
    position: absolute;
    top: 16px;
    left: 328px;
    border-radius: 8px;
    border: solid 1px #bfcde1;
    background-color: #bfcde1;
  }
  #r3-b2-bg22 {
    width: 164px;
    height: 150px;
    position: absolute;
    top: 16px;
    left: 449px;
    border-radius: 8px;
    border: solid 1px #bfcde1;
    background-color: #bfcde1;
  }
  #r3-b2-bg23 {
    width: 105px;
    height: 150px;
    position: absolute;
    top: 16px;
    left: 629px;
    border-radius: 8px;
    border: solid 1px #bfcde1;
    background-color: #bfcde1;
  }
  #r3-b2-bg24 {
    width: 195px;
    height: 130px;
    position: absolute;
    top: 182px;
    left: 328px;
    border-radius: 8px;
    border: solid 1px #bfcde1;
    background-color: #bfcde1;
  }
  #r3-b2-bg25 {
    width: 195px;
    height: 130px;
    position: absolute;
    top: 182px;
    left: 539px;
    border-radius: 8px;
    border: solid 1px #bfcde1;
    background-color: #bfcde1;
  }


  #r3-b3 {
    width: 360px;
    height: 248px;
    position: absolute;
    top: 412px;
    left: 794px;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b3-title {
    width: 187px;
    height: 48px;
    display: flex;
  align-items: center;
  justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background-color: #0d1a2e;
  }
  #r3-b3-bg {
    margin: 0 2% 2% 2%;
    width: 96%;
    height: 96%;
    border-radius: 8px;
    border: solid 1px #809bc3;
    background-color: #809bc3;
    position: relative;
  }

  .r3-b3-t {
    position: absolute;
    display: block;
    font-size: 14px;
  }

  #r3-b3-t2 {
    position: absolute;
    top: 60px;
    left: 34px;
    color: yellow;
    font-size: 23px;
  }

  #r3-b3-t3 {
    position: absolute;
    top: 90px;
    left: 74px;
    color: red;
    font-size: 23px;
  }

  #r3-b3-t4 {
    position: absolute;
    top: 80px;
    left: 204px;
    color: black;
    font-size: 18px;
  }

  #r3-b3-t5 {
    position: absolute;
    top: 40px;
    left: 284px;
    color: black;
    font-size: 18px;
  }
  #r3-b3-t6 {
    position: absolute;
    top: 20px;
    left: 204px;
    color: brown;
    font-size: 20px;
  }

  #r3-b3-t7 {
    position: absolute;
    top: 100px;
    left: 224px;
    color: black;
    font-size: 16px;
  }

  #r3-b3-t8 {
    position: absolute;
    top: 120px;
    left: 184px;
    color: black;
    font-size: 16px;
  }

  #r3-b3-t9 {
    position: absolute;
    top: 130px;
    left: 24px;
    color: blue;
    font-size: 16px;
  }

  #r3-b3-t10 {
    position: absolute;
    top: 30px;
    left: 124px;
    color: blue;
    font-size: 16px;
  }

  #r3-b4 {
    width: 560px;
    height: 384px;
    position: absolute;
    top: 672px;
    left: 0;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b4-title {
    width: 224px;
    height: 48px;
    display: flex;
  align-items: center;
  justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background-color: #0d1a2e;
  }


  #r3-b5 {
    width: 582px;
    height: 384px;
    position: absolute;
    top: 672px;
    left: 572px;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b5-title {
    width: 191px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background-color: #0d1a2e;
  }
  .r3-b5-t1 {
    font-size: 16px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    color: #ffffff;
  }
  .r3-b5-t2 {
    font-size: 11px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    color: #ffffff;
    padding: 0 2px;
  }
  .r3-b5-c {
    margin: 10px 0;
    display: flex;
    align-items: center;
  }


  #r3-b6 {
    width: 410px;
    height: 644px;
    position: absolute;
    top: 412px;
    left: 1166px;
    border-radius: 4px;
    border: solid 4px #0d1a2e;
    background-color: #1a355d;
  }
  #r3-b6-title {
    width: 187px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    background-color: #0d1a2e;
  }

  .realtime-mentoring-sub-title {
      font-size: 16px;
      font-weight: 900;
      text-align: center;
      color: black;
      margin: 10px;
  }

  .realtime-mentoring-content {
    font-size: 21px;
    text-align: center;
    color: black;
    margin: 10px;
}

.description {
    font-size: 16px;
    font-weight: 300;
    color: black;
    text-align: center;
}

.mentoring-condition {
    color: white;
    margin: 10px;
}

.mentoring-date {
    font-size: 13px;
    font-weight: 500;
    color: white;
    text-align: center;
}

.mentoring-count {
    border : 1px solid white;
    text-align: center;
    padding: 0 5px;
}


[class*=default-icon] {
    display: block;
    height: 16px;
    width: 16px;
    border: none!important;
    background-size: cover;
    background-color: transparent;
    opacity: 0.5;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    margin: auto;
  }
  [class*=default-icon]:hover {
    opacity: 1;
  }

.default-icon-chevron-left {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3C!--%20Generated%20by%20IcoMoon.io%20--%3E%0A%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22768%22%20height%3D%22768%22%20viewBox%3D%220%200%20768%20768%22%3E%0A%3Ctitle%3E%3C%2Ftitle%3E%0A%3Cg%20id%3D%22icomoon-ignore%22%3E%0A%3C%2Fg%3E%0A%3Cpath%20d%3D%22M493.28%20237.28l-45.28-45.28-192%20192%20192%20192%2045.28-45.28-146.72-146.72z%22%3E%3C%2Fpath%3E%0A%3C%2Fsvg%3E%0A");
  }
  .default-icon-chevron-right {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3C!--%20Generated%20by%20IcoMoon.io%20--%3E%0A%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22768%22%20height%3D%22768%22%20viewBox%3D%220%200%20768%20768%22%3E%0A%3Ctitle%3E%3C%2Ftitle%3E%0A%3Cg%20id%3D%22icomoon-ignore%22%3E%0A%3C%2Fg%3E%0A%3Cpath%20d%3D%22M320%20192l-45.28%2045.28%20146.72%20146.72-146.72%20146.72%2045.28%2045.28%20192-192z%22%3E%3C%2Fpath%3E%0A%3C%2Fsvg%3E%0A");
  }

.calendar {
    display: block;
    position: relative;
    width: 280px;
    border: 1px solid #dfdfdf;
    overflow: hidden;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    background-color: #ffffff;
  }
  .calendar-header,
  .calendar-content,
  .calendar-footer {
    position: relative;
    display: block;
    background-color: #ffffff;
    color: #1d1d1d;
  }
  .calendar-header {
    padding: 1rem;
    background-color: #004d6f;
    color: #ffffff;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
  }
  .calendar-header .header-year {
    font-size: 0.75rem;
    line-height: 1;
  }
  .calendar-header .header-day {
    font-size: 1.325rem;
  }
  .calendar-content {
    padding: 1px;
    width: 278px;
  }
  .calendar-content .calendar-toolbar,
  .calendar-content .days-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
  .calendar-content .calendar-toolbar {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row nowrap;
            flex-flow: row nowrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0.5rem 0;
    width: 100%;
  }
  .calendar-content .calendar-toolbar .prev-month,
  .calendar-content .calendar-toolbar .prev-year,
  .calendar-content .calendar-toolbar .next-month,
  .calendar-content .calendar-toolbar .next-year {
    padding: 0.5rem 0;
    cursor: pointer;
    text-align: center;
    width: 30px;
    display: block;
    position: relative;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .calendar-content .calendar-toolbar .curr-month,
  .calendar-content .calendar-toolbar .curr-year {
    padding: 0.5rem 0;
    width: 100%;
    text-align: center;
    cursor: pointer;
    font-size: 14px;
  }
  .calendar-content .week-days,
  .calendar-content .days {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row nowrap;
            flex-flow: row nowrap;
    border-top: 1px solid #dfdfdf;
    border-bottom: 1px solid #dfdfdf;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 0;
    font-size: 0.75rem;
  }
  .calendar-content .days {
    border: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column nowrap;
            flex-flow: column nowrap;
  }
  .calendar-content .days-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row nowrap;
            flex-flow: row nowrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .calendar-content .day,
  .calendar-content .week-number {
    width: calc(100%/7);
    text-align: center;
    cursor: pointer;
    font-size: 0.85rem;
    position: relative;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    margin: 0;
    height: 36px;
    line-height: 36px;
  }
  .calendar-content .day.and-week-number {
    width: calc(100% / 8);
  }

  .calendar-content .day.selected::after {
    border-top: 20px solid #5ebdec;
    border-left: 20px solid transparent;
    right: 0;
    top: 0;
  }
  .calendar-content .day.selected::before {
    right: 1px!important;
    top: 1px!important;
  }
  .calendar-content .day.showed {
    font-weight: bold;
  }
  .calendar-content .week-days .day {
    font-weight: 700;
  }
  .calendar-content .week-number {
    width: calc(100% / 8);
    background-color: #ffffff;
    font-weight: 700;
    font-size: 12px;
    border-right: 1px solid #dfdfdf;
  }
  .calendar-content .outside {
    color: #bebebe;
    font-size: 0.75rem;
  }
  .calendar-content .today {
    background-color: rgba(27, 161, 226, 0.5);
    color: #ffffff;
    font-weight: bold;
  }
  .calendar-content .excluded {
    background-color: #f8f8f8;
  }
  .calendar.day-border .days-row:not(:nth-child(1)) {
    border-top: 1px solid #dfdfdf;
  }
  .calendar.day-border .days-row .day:not(:nth-child(1)),
  .calendar.day-border .week-days .day:not(:nth-child(1)) {
    border-left: 1px solid #dfdfdf;
  }
  .calendar.day-border .days-row .week-number,
  .calendar.day-border .week-days .week-number {
    border-right: none;
  }
  .calendar-months,
  .calendar-years {
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    background-color: #f8f8f8;
    color: #1d1d1d;
    float: left;
    width: 120px;
    overflow: hidden;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    z-index: 500;
  }
  .calendar-years > .years-list,
  .calendar-months > .months-list {
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto!important;
  }
  .calendar-years > .years-list li.active,
  .calendar-months > .months-list li.active {
    background-color: #1ba1e2;
    color: #ffffff;
  }
  .calendar-months {
    left: 0;
    -webkit-transform: translateX(-100%);
        -ms-transform: translateX(-100%);
            transform: translateX(-100%);
    width: 160px;
  }
  .calendar-months.open {
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    -webkit-box-shadow: 5px 0 7px -6px rgba(0, 0, 0, 0.75);
            box-shadow: 5px 0 7px -6px rgba(0, 0, 0, 0.75);
  }
  .calendar-months .months-list {
    list-style: none inside;
    padding: 0;
    margin: 10px 0;
  }
  .calendar-months .months-list li {
    padding: 4px 16px;
    cursor: pointer;
  }
  .calendar-months .months-list li:hover {
    background-color: rgba(29, 29, 29, 0.1);
  }
  .calendar-years {
    left: 100%;
  }
  .calendar-years.open {
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    -webkit-transform: translateX(-100%);
        -ms-transform: translateX(-100%);
            transform: translateX(-100%);
    -webkit-box-shadow: -5px 0 7px -6px rgba(0, 0, 0, 0.75);
            box-shadow: -5px 0 7px -6px rgba(0, 0, 0, 0.75);
  }
  .calendar-years .years-list {
    list-style: none inside;
    padding: 0;
    margin: 10px 0;
    text-align: center;
  }
  .calendar-years .years-list li {
    padding: 4px 16px;
    cursor: pointer;
  }
  .calendar-years .years-list li:hover {
    background-color: rgba(29, 29, 29, 0.1);
  }
  .calendar-footer {
    padding: 0.5rem;
    border-top: 1px solid #dfdfdf;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row nowrap;
            flex-flow: row nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .calendar-footer > * {
    margin: 0 2px;
    font-size: 0.75rem;
  }
  .calendar.compact {
    width: 240px;
  }
  .calendar.compact .calendar-content {
    width: 100%;
  }
  .calendar.compact .calendar-header {
    padding: 0.5rem;
    line-height: 1.2;
  }
  .calendar.compact .calendar-header .header-year {
    font-size: 0.65rem;
  }
  .calendar.compact .calendar-header .header-day {
    font-size: 1rem;
  }
  .calendar.compact .calendar-toolbar > * {
    padding: 0!important;
    font-size: 14px;
  }
  .calendar.compact .calendar-footer .button {
    height: 24px;
    line-height: 24px;
    padding: 0 0.25rem;
  }
  .calendar.compact .day,
  .calendar.compact .week-number {
    height: 30px;
    line-height: 30px;
    width: 30px;
    margin: 0;
    font-size: 12px;
  }
  .calendar.compact .day + .day {
    margin-left: 1px;
  }
  .calendar.compact .months-list,
  .calendar.compact .years-list {
    font-size: 0.85rem;
  }
  .calendar-wide {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row nowrap;
            flex-flow: row nowrap;
    width: 560px;
  }
  .calendar-wide::after {
    display: block;
    clear: both;
    content: "";
  }
  .calendar-wide::after {
    display: block;
    clear: both;
    content: "";
  }
  .calendar-wide.calendar-picker {
    width: 460px;
  }
  .calendar-wide .calendar-header,
  .calendar-wide .calendar-footer {
    position: absolute;
    top: 0;
    height: 100%;
    min-height: 100%;
  }
  .calendar-wide .calendar-header {
    left: 0;
  }
  .calendar-wide .calendar-footer {
    right: 0;
  }
  .calendar-wide .calendar-header {
    width: 180px;
  }
  .calendar-wide .calendar-footer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column nowrap;
            flex-flow: column nowrap;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    border-top: none;
    border-left: 1px solid #dfdfdf;
    width: 100px;
  }
  .calendar-wide .calendar-footer * {
    width: 100%;
    margin: 2px 0;
  }
  .calendar-wide .calendar-content {
    margin: 0 96px 0 180px;
  }
  .calendar-wide.compact {
    width: 454px!important;
  }
  .calendar-wide.compact.calendar-picker {
    width: 354px!important;
  }
  .calendar-wide.compact .calendar-header {
    width: 120px;
  }
  .calendar-wide.compact .calendar-content {
    margin: 0 96px 0 120px;
    width: 234px;
  }
  .calendar-picker {
    position: relative;
  }
  .calendar-picker input {
    width: 100%;
  }
  .calendar-picker .calendar {
    position: absolute;
    top: 100%;
    left: 0;
    display: none;
    z-index: 500;
  }
  .calendar-picker .calendar.open {
    display: block!important;
  }
  .calendar-picker .calendar.open-up {
    top: auto;
    bottom: 100%;
  }
  .calendar-picker.dialog-mode .calendar {
    position: fixed;
    top: 50%!important;
    left: 50%!important;
    -webkit-transform: translate3d(-50%, -50%, 0);
            transform: translate3d(-50%, -50%, 0);
    z-index: 1050;
  }
  .calendar-picker.dialog-mode .calendar.open-up {
    top: auto;
    bottom: auto;
  }
  .calendar-picker .calendar-wide {
    width: 464px;
  }
  .calendar-picker .calendar-wide.compact {
    width: 364px;
  }

.calendar {
    background-color: transparent !important;
    border: 0 !important;
}

.calendar-header {
    visibility: hidden;
    background-color: transparent !important;
    border: 0 !important;
}

.calendar-content {
    background-color: transparent !important;
    border: 0 !important;
}

.calendar-footer {
    visibility: hidden;
    background-color: transparent !important;
    border: 0 !important;
}

.week-days {
    border: 0 !important;
}

.day.today {
    background-color: #1565b3 !important;
    border-radius: 30px !important;
    border: 0 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
}

.day.today::before {
    display: none !important;
}

.day.today::after {
    display: none !important;
}