.treasure-chamber-button {
    position: fixed;
    bottom: -0.9rem;
    left: 7rem;
    font-family: "input-mono-condensed", monospace;
    font-size: 1.30rem;
    line-height: 1.2;
    padding: 0.2rem;
    background: none;
    border: none;
    z-index: 1001;
    opacity: 0;
    visibility: hidden;
    text-align: center;
    transition: all 0.3s ease;
    font-weight: bold;
    color: #63480D;
    letter-spacing: -0.05em;
    mix-blend-mode: normal;
    font-style: normal;
    cursor: url('../img/cursor.svg'), pointer !important;
}

/* Dot separator */
.button-separator {
    position: fixed;
    bottom: -1.25rem;
    left: 4.5rem;
    font-family: "input-mono-condensed", monospace;
    font-size: 2rem;
    line-height: 1.2;
    padding: 0.2rem;
    color: #63480D;
    z-index: 1001;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

/* When buttons are visible, transform the separator too */
.button-separator.visible,
.button-separator.main-page {
    opacity: 1;
    visibility: visible;
    transform: translateY(-25px);
}

.treasure-chamber-button:hover:not(.main-page),
.treasure-chamber-button.at-top {
    transform: translateY(-25px);
    font-style: italic;
    cursor: url('../img/cursor.svg'), pointer !important;
}

.treasure-chamber-button.visible {
    opacity: 1;
    visibility: visible;
}

/* Special styling for main page */
.treasure-chamber-button.main-page {
    transform: translateY(-25px);
    font-style: normal;
    opacity: 1 !important;
    visibility: visible !important;
    cursor: url('../img/cursor.svg'), pointer !important;
}

.treasure-chamber-button.main-page:hover {
    color: rgb(30,170,255);
    font-style: italic;
    /* cursor: none; */
}

.treasure-chamber-button span {
    white-space: nowrap;
}

@media (max-width: 768px) {
    .treasure-chamber-button {
        left: 8rem;
        bottom: 1rem;
        font-size: 1.20rem;
    }
    
    .button-separator {
        left: 4.5rem;
        bottom: 1rem;
        font-size: 1.20rem;
    }
} 