@font-face {
    font-family: Thin;
    src: url("./font/SF-Pro-Display-Thin.otf");
}
@font-face {
    font-family: Light;
    src: url("./font/SF-Pro-Display-Light.otf");
}
@font-face {
    font-family: LightItalic;
    src: url("./font/SF-Pro-Display-LightItalic.otf");
}
@font-face {
    font-family: Regular;
    src: url("./font/SF-Pro-Display-Regular.otf");
}
@font-face {
    font-family: Medium;
    src: url("./font/SF-Pro-Display-Medium.otf");
}
@font-face {
    font-family: Bold;
    src: url("./font/SF-Pro-Display-Bold.otf");
}


:root {
    --color-10: #090F17;
    --color-25: #8675CF;
    --color-26: #28ccae;
    --color-3: #585858;
    --color-20: #B3B3B3;
    --color-23: #26ac1f;
    --color-24: #F5A826;
    --color-1: #f5f5f5;
    --color-22: #5497E7;
    --color-7: #ffffff;

    font-size: calc(100vw / 192);
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: Thin;
}


body {
    margin: 0;
    background-color: var(--color-1);
    font-family: Thin;
}
.main {
    width: 100vw;
    overflow-x: hidden;
    position: relative;
}

p, a, label {
    margin: 0;
    color: var(--color-1);
    text-decoration: none;
    letter-spacing: .15rem;
    line-height: 1.5;
    font-family: Thin;
}
i {
    margin: 0;
    color: var(--color-1);
    text-decoration: none;
    letter-spacing: .15rem;
    line-height: 1.5;
    font-family: LightItalic;
}
b {
    margin: 0;
    color: var(--color-1);
    text-decoration: none;
    letter-spacing: .15rem;
    line-height: 1.5;
    font-family: Medium;
}


.color-10 {
    color: var(--color-10);
}
.color-25 {
    color: var(--color-25);
}
.color-26 {
    color: var(--color-26);
}
.color-3 {
    color: var(--color-3);
}
.color-20 {
    color: var(--color-20);
}
.color-23 {
    color: var(--color-23);
}
.color-24 {
    color: var(--color-24);
}
.color-1 {
    color: var(--color-1);
}
.color-22 {
    color: var(--color-22);
}
.color-7 {
    color: var(--color-7);
}


.fs-4 {
    font-size: 2.4rem !important;
}
.fs-10 {
    font-size: 1.8rem !important;
}
.fs-3 {
    font-size: 1.6rem !important;
}
.fs-5 {
    font-size: 1.4rem !important;
}
.fs-2 {
    font-size: 1.2rem !important;
}


.fw-700 {
    font-family: Bold !important;
}
.fw-600 {
    font-family: Medium !important;
}
.fw-500 {
    font-family: Regular !important;
}
.fw-400 {
    font-family: Light !important;
}
.fw-400-italic {
    font-family: LightItalic !important;
}
.fw-300 {
    font-family: Thin !important;
}


.rect-img {
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.circle-img {
    aspect-ratio: 1/1;
    border-radius: 50%;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.img-cover {
    object-fit: cover;
}


::-webkit-scrollbar {
    width: .5rem;
    height: 0;
}
::-webkit-scrollbar-thumb {
    background-color: var(--color-3);
    -webkit-border-radius: .5rem;
    border-radius: .5rem;
}
::-webkit-scrollbar-track {
    -webkit-border-radius: .5rem;
    border-radius: .5rem;
    background: transparent;
}


.calendar {
    width: 100vw;
    min-height: 100vh;
    height: 100vh;
    max-height: 100vh;
    background-color: var(--color-1);
    overflow: hidden;
}

.calendar .title {
    padding: 2rem 8rem;
    background-color: var(--color-22);
    display: flex;
    align-items: center;
}

.calendar .title .line {
    padding-right: 3rem;
    border-right: .1rem solid var(--color-1);
    line-height: 1;
    margin-right: 3rem;
}
.calendar .content {
    display: flex;
    gap: 4rem;
    padding: 1rem 6rem;
    height: calc(100% - 7.5rem);
    overflow-y: scroll;
    justify-content: space-between;
}
.calendar .content::-webkit-scrollbar {
    width: 0;
    height: 0;
}
.calendar .content .list {
    display: flex;
    flex-direction: column;
    align-items: start;
}
.calendar .content .list .item {
    margin-top: 1.5rem;
    background-color: var(--color-7);
    border-radius: .5rem;
    padding: 1.2rem 1.6rem;
    width: 41rem;
    height: max-content;
    box-shadow: 0 0.5rem 1rem rgba(110, 110, 110, 0.15);
}
.calendar .content .list .active-0 {
    background-color: #E3DFF5;
}
.calendar .content .list .active-1 {
    background-color: #C9F9EB;
}     
.calendar .content .dot {
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
}
.calendar .table-cus {
    width: 100%;
    height: calc(100% - 7rem);
    max-height: calc(100% - 7rem);
    overflow-y: scroll;
}
.calendar .table-cus::-webkit-scrollbar {
    width: 0;
    height: 0;
}
.calendar .table-cus th {
    background-color: #B4E9B1 !important;
    padding: 0 .5rem;
    vertical-align: middle;
    letter-spacing: .1rem;
    height: 5rem;
    border-color: inherit !important;
}
.calendar .table-cus tr {
    height: 5rem !important;
}
.calendar .table-cus td {
    vertical-align: middle;
    letter-spacing: .1rem;
}
.calendar .mySwiper {
    width: 100%;
    height: 100%;
    animation: slide 10s;
}
@keyframes slide {
    0% {
        transform: translateX(100%);
    }
    1% {
        transform: translateX(0);
    }
    99% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}
.calendar .mySwiper .slide {
    width: 100%;
    min-width: 100%;
    height: 100%;
    position: relative;
}
.calendar .mySwiper .slide .slide-title {
    width: 60rem;
    height: max-content;
    min-height: 10rem;
    position: absolute;
    z-index: 1;
    bottom: 2rem;
    left: 2rem;
    padding: 2rem;
    background-color: rgba(255, 255, 255, 0.9);
}
