#spinner-container {
    text-align: center;
}

#spinner {
    width: 80vw; /* Use viewport width for responsiveness */
    height: 80vw; /* Maintain aspect ratio */
    max-width: 300px; /* Limit maximum width for larger screens */
    max-height: 300px; /* Limit maximum height for larger screens */
    border-radius: 50%;
    position: relative;
    margin: 20px auto;
    overflow: hidden;
    background: radial-gradient(circle, #fff, #ddd);
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);
}

.option {
    position: absolute;
    width: 50%;
    height: 50%;
    clip-path: polygon(0% 0%, 500% 0%, 0% 100%);
    transform-origin: 100% 100%;
    text-align: right;
    line-height: 1.8;
    font-size: 3vw; /* Use viewport units for font size */
    font-weight: normal;
    color: #fff;
    background-color: #3498db;
    overflow: hidden;
}

.option-text {
    transform-origin: 0% 100%;
    transform: rotate(-90deg);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 80%;
    min-font-size: 1.5vw; /* Use viewport units for minimum font size */
    position: absolute;
    top: 50%; /* Center vertically */
    left: 50%; /* Center horizontally */
    transform: translate(-50%, -50%);
	font-size: 16px;
}

/* Media query for smaller screens */
@media (max-width: 768px) {
    .option-text {
        min-font-size: 2vw; /* Adjusted minimum font size for smaller screens */
    }
}

/* Media query for larger screens */
@media (min-width: 1200px) {
    .option-text {
        min-font-size: 1vw; /* Adjusted minimum font size for larger screens */
    }
}

#arrow {
    position: absolute;
    top: 100%;
    left: 50%;
    width: 0;
    height: 0;
    margin-left: -1vw; /* Use viewport units for margin */
    margin-top: -2.5vw; /* Use viewport units for margin */
    border-left: 2vw solid transparent; /* Use viewport units for border size */
    border-right: 2vw solid transparent; /* Use viewport units for border size */
    border-bottom: 2.5vw solid #e74c3c; /* Use viewport units for border size */
    transform-origin: 50% 0;
    transform: rotate(0deg);
    transition: transform 5s ease-out, box-shadow 0.5s ease-out;
}



#spinner-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    display: none;
}
