.header__content {
    width: var(--content-width);
    margin-inline: auto;
    height: var(--header-height);
    background-color: var(--color-background-card);
    border-radius: var(--radius-m);
    border: 0.01rem solid rgba(94, 90, 90, 0.082);
    padding: var(--xl);
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.header__title {
    font-weight: var(--semi-bold);
}

.header__button {
    position: absolute;
    top: 50%;
    right: var(--xl);
    transform: translateY(-50%);
    transition: 0.3s ease-out all;
    font-size: var(--font-xl);
    display: none;
}

.header__button:hover {
    opacity: 0.4;
}

.wrapper {
    padding-block: var(--s);
}

.wrapper__content {
    width: var(--content-width);
    margin-inline: auto;
    display: flex;
    gap: var(--xl);
}

.aside {
    width: 22rem;
}

.aside__content {
    background-color: var(--color-background-card);
    border-radius: var(--radius-m);
    border: 0.01rem solid rgba(94, 90, 90, 0.082);
    padding: var(--xl);
    display: grid;
    gap: var(--xl);
    position: relative;
}

.aside__button {
    position: absolute;
    top: 0;
    right: 0;
    margin: var(--xl);
    transition: 0.3s ease-out all;
    font-size: var(--font-xl);
    display: none;
}

.aside__button:hover {
    opacity: 0.4;
}

.aside__list {
    display: grid;
    gap: var(--l);
    padding-inline: var(--xl) var(--xxs);
    overflow-y: auto;
    max-height: 28rem;
    list-style: decimal;
}

.aside__link {
    transition: 0.3s ease-out all;
}

.aside__link:hover {
    opacity: 0.4;
}

.main {
    flex: 1;
}

.main__content {
    background-color: var(--color-background-card);
    border-radius: var(--radius-m);
    border: 0.01rem solid rgba(94, 90, 90, 0.082);
    padding: var(--xl);
    display: flex;
    flex-direction: column;
    gap: var(--xxl);
    max-height: 40rem;
    overflow-y: auto;
}

.main__header-top {
    display: flex;
    gap: var(--xs);
    font-size: var(--font-xl);
    margin-bottom: var(--xl);
}

.main__header-top .icon {
    margin-top: var(--xxs);
}

.poem__introduction {
    opacity: 0.9;
    line-height: 1.7;
    margin-bottom: var(--xxl);
}

.author {
    display: flex;
    gap: var(--s);
}

.author__image {
    width: 3rem;
    aspect-ratio: 1;
    border-radius: 50%;
    object-fit: cover;
    object-position: center;
}

.author__name {
    font-weight: var(--bold);
}

.author__date {
    opacity: 0.6;
}

.main .line {
    width: 100%;
    height: 0.01rem;
    border: 0.01rem solid var(--color-text-body);
    opacity: 0.1;
}

.main__body {
    position: relative;
    margin-bottom: var(--xxl);
}

.main__body > .icon {
    position: absolute;
    bottom: 0;
    right: 0;
    transform: translate(0, 100%);
    font-size: var(--font-4xl);
    opacity: 0.06;
} 

.poem__main {
    display: grid;
    gap: var(--xxl);
}

.poem__main p {
    line-height: 1.7;
}

.contacts {
    display: grid;
    gap: var(--xxs);
}

.contact__link {
    display: flex;
    align-items: center;
    gap: var(--xxs);
    transition: 0.3s ease-out all;
}

.contact__link:hover {
    opacity: 0.4;
}


.footer {
    width: var(--content-width);
    margin-inline: auto;
    margin-top: auto;
}

.footer__content {   
    background-color: var(--color-background-card);
    border-radius: var(--radius-m);
    border: 0.01rem solid rgba(94, 90, 90, 0.082);
    padding: var(--xl);
    display: flex;
    justify-content: center;
    align-items: center;
}



/* media query */
@media (max-width: 1024px) {
    .aside {
        width: calc(var(--content-width) - var(--xl));
        position: fixed;
        top: var(--s);
        left: 50%;
        transform: translateX(-50%);
        z-index: 1;
        opacity: 0;
        pointer-events: none;
        transition: 0.3s ease-out all;
    }

    .aside::before {
        content: '';
        position: fixed;
        top: calc(var(--s) * -1);
        left: calc(var(--s) * -2);
        width: 100vw;
        height: 100vh;
        background-color: rgba(0, 0, 0, 0.404);
        backdrop-filter: blur(0.04rem);
        z-index: -1;
    }
    
    .aside.active {
        opacity: 1;
        pointer-events: all;
    }

    .header__button,
    .aside__button {
        display: block;
    }
}

@media (max-width: 480px) {
    .header__content {
        justify-content: flex-start;
    }
}