.QUOTE-sidebar {
    position: fixed;
    left: 28px;
    top: auto;
    bottom: 28px;
    z-index: 900;
    width: min(260px, calc(100vw - 56px));
    transform: none;
    pointer-events: auto;
    cursor: grab;
    transition: transform 360ms ease, opacity 240ms ease;
    user-select: none;
    touch-action: none;
}

.QUOTE-sidebar.is-dragging {
    cursor: grabbing;
    transition: none;
}

.QUOTE-sidebar.is-positioned {
    transform: none;
}

.QUOTE-card {
    min-height: 124px;
    padding: 22px 22px 48px;
    border: 1px solid rgba(185, 177, 160, 0.28);
    border-radius: 20px;
    background:
        linear-gradient(145deg, rgba(255, 252, 245, 0.76), rgba(242, 238, 228, 0.62));
    color: #2f2a24;
    font-family: Georgia, "Times New Roman", "Noto Serif SC", serif;
    box-shadow:
        0 18px 46px rgba(44, 37, 28, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(16px) saturate(112%);
    -webkit-backdrop-filter: blur(16px) saturate(112%);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 900ms ease, transform 900ms ease;
}

.QUOTE-music-btn {
    position: absolute;
    left: 18px;
    bottom: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    padding: 0;
    border: 1px solid rgba(154, 129, 95, 0.32);
    border-radius: 999px;
    background: rgba(255, 250, 241, 0.74);
    color: #5f4632;
    box-shadow:
        0 8px 18px rgba(44, 37, 28, 0.1),
        inset 0 1px 1px rgba(255, 255, 255, 0.82);
    cursor: pointer;
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.QUOTE-music-btn:hover,
.QUOTE-music-btn:focus {
    transform: translateY(-1px);
    border-color: rgba(154, 129, 95, 0.52);
    box-shadow:
        0 10px 22px rgba(44, 37, 28, 0.14),
        inset 0 1px 1px rgba(255, 255, 255, 0.9);
    outline: none;
}

.QUOTE-music-icon {
    font-size: 13px;
    line-height: 1;
}

.QUOTE-card.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.QUOTE-text {
    margin: 0;
    font-size: 1rem;
    line-height: 1.85;
    letter-spacing: 0;
    overflow-wrap: anywhere;
}

.QUOTE-title {
    margin: 14px 0 0;
    color: #6a5543;
    font-size: 0.92rem;
    line-height: 1.5;
    text-align: right;
    overflow-wrap: anywhere;
}

.QUOTE-title::before {
    content: "\2014\2014";
    margin-right: 4px;
}

.QUOTE-sidebar:hover .QUOTE-card,
.QUOTE-sidebar:focus-within .QUOTE-card {
    border-color: rgba(154, 129, 95, 0.42);
    background: linear-gradient(145deg, rgba(255, 252, 245, 0.98), rgba(247, 241, 231, 0.96));
    box-shadow:
        0 20px 54px rgba(44, 37, 28, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(4px) saturate(108%);
    -webkit-backdrop-filter: blur(4px) saturate(108%);
}

.QUOTE-sidebar:hover .QUOTE-text,
.QUOTE-sidebar:focus-within .QUOTE-text {
    color: #211b15;
    font-weight: 700;
    text-shadow: 0 1px 0 rgba(255, 252, 245, 0.82);
}

.QUOTE-sidebar:hover .QUOTE-title,
.QUOTE-sidebar:focus-within .QUOTE-title {
    color: #7a4f2b;
    font-weight: 700;
}

.QUOTE-toggle {
    position: absolute;
    right: -16px;
    top: 16px;
    z-index: 2;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid rgba(185, 177, 160, 0.28);
    border-radius: 999px;
    background: rgba(255, 252, 245, 0.86);
    color: #5b493a;
    box-shadow: 0 10px 24px rgba(44, 37, 28, 0.16);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    transition: background 180ms ease, color 180ms ease, transform 360ms ease;
}

.QUOTE-toggle:hover,
.QUOTE-toggle:focus {
    background: rgba(255, 252, 245, 0.96);
    color: #8b5e34;
    outline: none;
}

.QUOTE-toggle-icon {
    display: block;
    transform: translateY(-1px);
}

.QUOTE-sidebar.is-collapsed {
    transform: translateX(calc(-100% + 18px));
}

.QUOTE-sidebar.is-positioned.is-collapsed {
    transform: translateX(calc(-100% + 18px));
}

.QUOTE-sidebar.is-collapsed .QUOTE-toggle {
    transform: rotate(180deg);
}

.QUOTE-dark-page .QUOTE-card {
    border-color: rgba(190, 181, 162, 0.22);
    background: linear-gradient(145deg, rgba(37, 33, 28, 0.76), rgba(18, 17, 16, 0.66));
    color: #f3ecdf;
    box-shadow: 0 20px 54px rgba(0, 0, 0, 0.36);
}

.QUOTE-dark-page .QUOTE-title {
    color: #d4c2aa;
}

.QUOTE-dark-page .QUOTE-sidebar:hover .QUOTE-card,
.QUOTE-dark-page .QUOTE-sidebar:focus-within .QUOTE-card,
body[data-mode] .QUOTE-sidebar:hover .QUOTE-card,
body[data-mode] .QUOTE-sidebar:focus-within .QUOTE-card {
    border-color: rgba(226, 205, 174, 0.34);
    background: linear-gradient(145deg, rgba(45, 39, 32, 0.98), rgba(22, 20, 17, 0.96));
    box-shadow: 0 22px 58px rgba(0, 0, 0, 0.42);
}

.QUOTE-dark-page .QUOTE-sidebar:hover .QUOTE-text,
.QUOTE-dark-page .QUOTE-sidebar:focus-within .QUOTE-text,
body[data-mode] .QUOTE-sidebar:hover .QUOTE-text,
body[data-mode] .QUOTE-sidebar:focus-within .QUOTE-text {
    color: #fff8ec;
    font-weight: 700;
    text-shadow: 0 1px 0 rgba(0, 0, 0, 0.32);
}

.QUOTE-dark-page .QUOTE-sidebar:hover .QUOTE-title,
.QUOTE-dark-page .QUOTE-sidebar:focus-within .QUOTE-title,
body[data-mode] .QUOTE-sidebar:hover .QUOTE-title,
body[data-mode] .QUOTE-sidebar:focus-within .QUOTE-title {
    color: #f0d8b8;
    font-weight: 700;
}

.QUOTE-dark-page .QUOTE-toggle {
    border-color: rgba(190, 181, 162, 0.22);
    background: rgba(37, 33, 28, 0.82);
    color: #f3ecdf;
}

.QUOTE-dark-page .QUOTE-music-btn {
    border-color: rgba(190, 181, 162, 0.24);
    background: rgba(48, 42, 35, 0.62);
    color: #f3ecdf;
}

body[data-mode] .QUOTE-sidebar {
    left: 40px;
    top: auto;
    bottom: 28px;
    z-index: 45;
    width: 210px;
    transform: none;
}

body[data-mode] .QUOTE-card {
    border-color: rgba(190, 181, 162, 0.22);
    background: linear-gradient(145deg, rgba(37, 33, 28, 0.76), rgba(18, 17, 16, 0.66));
    color: #f3ecdf;
    box-shadow: 0 20px 54px rgba(0, 0, 0, 0.3);
}

body[data-mode] .QUOTE-title {
    color: #d4c2aa;
}

body[data-mode] .QUOTE-toggle {
    border-color: rgba(190, 181, 162, 0.22);
    background: rgba(37, 33, 28, 0.82);
    color: #f3ecdf;
}

body[data-mode] .QUOTE-music-btn {
    border-color: rgba(190, 181, 162, 0.24);
    background: rgba(48, 42, 35, 0.62);
    color: #f3ecdf;
}

body[data-mode] .QUOTE-sidebar.is-collapsed {
    transform: translateX(calc(-100% + 18px));
}

@media screen and (max-width: 1199.98px) {
    .QUOTE-sidebar {
        left: 18px;
        top: auto;
        bottom: 18px;
        width: min(360px, calc(100vw - 32px));
        transform: none;
    }

    .QUOTE-card {
        padding: 14px 18px 44px;
        min-height: 0;
        border-radius: 16px;
        background: linear-gradient(145deg, rgba(255, 252, 245, 0.8), rgba(242, 238, 228, 0.68));
        box-shadow: 0 14px 36px rgba(18, 25, 38, 0.12);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
    }

    .QUOTE-text {
        font-size: 0.9rem;
        line-height: 1.55;
    }

    .QUOTE-title {
        margin-top: 8px;
        font-size: 0.82rem;
    }

    .QUOTE-toggle {
        right: -16px;
        top: 12px;
        width: 30px;
        height: 30px;
        border-radius: 999px;
        transform: none;
    }

    .QUOTE-sidebar.is-collapsed {
        transform: translateX(calc(-100% + 18px));
    }

    .QUOTE-sidebar.is-positioned.is-collapsed {
        transform: translateX(calc(-100% + 18px));
    }

    .QUOTE-sidebar.is-collapsed .QUOTE-toggle {
        transform: rotate(180deg);
    }

    body[data-mode] .QUOTE-sidebar {
        left: 18px;
        bottom: 18px;
        width: min(360px, calc(100vw - 32px));
        transform: none;
    }

    body[data-mode] .QUOTE-sidebar.is-collapsed {
        transform: translateX(calc(-100% + 18px));
    }
}

@media screen and (max-width: 575.98px) {
    .QUOTE-sidebar {
        bottom: 10px;
        width: calc(100vw - 40px);
        left: 12px;
    }

    .QUOTE-card {
        padding: 12px 14px 42px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .QUOTE-sidebar,
    .QUOTE-card,
    .QUOTE-toggle {
        transition: none;
    }
}
