/* Универсальный стиль кнопки-лайка и блока комментариев.
 * Подключается из layouts/app.blade.php. Используется и в публичной части
 * (страница работы, модалка работы), и в кабинете, и в админ-модалках.
 */

/* === Like button === */
.like-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    /* background: transparent; */
    /* border: 1px solid rgba(118, 154, 201, 0.4); */
    /* border-radius: 999px; */
    color: var(--darkBlue, --textPrimary);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    transition: background-color 0.15s, color 0.15s, border-color 0.15s;
    user-select: none;
}
.like-btn:hover:not(:disabled) {
    /* background: rgba(118, 154, 201, 0.1); */
    border-color: rgba(118, 154, 201, 0.8);
}
.like-btn.is-liked {
    color: #A6312E;
}
.like-btn.is-busy,
.like-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.like-btn__count {
    font-weight: 500;
    min-width: 1ch;
}

/* === Comments block === */
.comments-block {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(118, 154, 201, 0.25);
}
.comments-block__head {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: 0 0 16px;
}
.comments-block__title {
    margin: 0;
    font-size: 22px;
    font-weight: 600;
}
.comments-block__count {
    color: rgba(33, 33, 45, 0.55);
    font-weight: 400;
    margin-left: 4px;
}
.comments-block__container {
    padding: clamp(16px, 2vw, 24px);
    border-radius: 24px;
    background-color: var(--white);
}
.comments-block__form {
    margin-bottom: 24px;
}
.comments-block__input-wrap {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: flex-start;
    gap: 8px;
}
.comments-block__textarea {
    width: 100%;
    /* min-height: 90px; */
    resize: vertical;
}
.comments-block__form-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
}
.comments-block__counter {
    font-size: 12px;
    color: rgba(33, 33, 45, 0.6);
}
.comments-block__submit {
    padding: 8px;
    background: #769AC9;
    color: #fff;
    border: 0;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: background 0.15s;
}
.comments-block__submit:hover:not(:disabled) {
    background: #5A7FAF;
}
.comments-block__submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.comments-block__loader {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;

    div {
        width: 4px;
        height: 4px;
        background-color: var(--white);
        border-radius: 100%;
        animation: blink 1.4s infinite both;
    }

    div:nth-child(1) { animation-delay: -0.32s; }

    div:nth-child(2) { animation-delay: -0.16s; }
}

@keyframes blink {
  0%, 80%, 100% { opacity: 0; }
  40% { opacity: 1; }
}

.comments-block__error {
    color: #c75454;
    font-size: 13px;
    margin: 8px 0 0;
}
.comments-block__flash {
    color: #2a8a3e;
    font-size: 13px;
    margin: 8px 0 0;
}
.comments-block__guest {
    padding: 16px;
    background: rgba(118, 154, 201, 0.1);
    border-radius: 8px;
    margin: 0 0 24px;
    font-size: 14px;
}
.comments-block__guest-link {
    color: #5A7FAF;
    background: none;
    border: 0;
    cursor: pointer;
    padding: 0;
    font: inherit;
    text-decoration: underline;
}
.comments-block__loading,
.comments-block__empty {
    color: rgba(33, 33, 45, 0.5);
    font-size: 14px;
    padding: 12px 0;
}
.comments-block__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.comments-block__item {
    padding: 16px;
    background: rgba(118, 154, 201, 0.05);
    border-radius: 8px;
}
.comments-block__item[data-status="pending"] {
    background: rgba(255, 200, 100, 0.08);
}
.comments-block__item[data-status="rejected"] {
    background: rgba(199, 84, 84, 0.06);
    opacity: 0.85;
}
.comments-block__item-head {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 8px;
    font-size: 13px;
}
.comments-block__author {
    font-weight: 600;
    color: var(--textPrimary, #21212d);
}
.comments-block__date {
    color: rgba(33, 33, 45, 0.55);
}
.comments-block__badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
}
.comments-block__badge--pending {
    background: rgba(255, 165, 0, 0.15);
    color: #b87b00;
}
.comments-block__badge--rejected {
    background: rgba(199, 84, 84, 0.15);
    color: #a04545;
}
.comments-block__body {
    margin: 0;
    white-space: pre-wrap;
    word-wrap: break-word;
}
.comments-block__rejection {
    margin: 8px 0 0;
    font-size: 12px;
    color: #a04545;
    font-style: italic;
}

/* === Карта конкурса: лайк в правом нижнем углу карточки работы === */
.contest-map__work-card {
    position: relative;
}
.contest-map__work-like {
    /* position: absolute;
    right: 12px;
    bottom: 12px; */
}

/* === Modal: социальный блок (лайк + переход к комментариям) === */
.contest-work-modal__social {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid rgba(118, 154, 201, 0.2);
}
.contest-work-modal__comments-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    color: var(--darkBlue, --textPrimary);
    text-decoration: none;
    font-size: 14px;
}
.contest-work-modal__comments-link:hover {
    text-decoration: underline;
}

/* === Детальная страница работы === */
.contest-entry-page {
    /* padding: 24px 0 60px; */
}
.contest-entry-page__head {
    margin-top: 16px;
}
.contest-entry-page__category {
    font-size: 14px;
    color: rgba(33, 33, 45, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.contest-entry-page__title {
    font-size: clamp(24px, 4vw, 36px);
    margin: 8px 0 4px;
    font-weight: 700;
}
.contest-entry-page__nomination {
    color: rgba(33, 33, 45, 0.7);
    font-size: 15px;
    margin-bottom: 16px;
}
.contest-entry-page__meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 14px;
    color: rgba(33, 33, 45, 0.8);
    margin-bottom: 24px;
}
.contest-entry-page__meta-row {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 4px;
    color: var(--brown);
    font-size: 16px;
    line-height: 150%;
}
.contest-entry-page__annotation {
    margin: 0 0 24px;
}
.contest-entry-page__annotation h2 {
    font-size: 20px;
    margin: 0 0 8px;
}
.contest-entry-page__annotation p {
    white-space: pre-wrap;
}
.contest-entry-page__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.contest-entry-page__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 22px;
    background: #769AC9;
    color: #fff;
    border-radius: 6px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
}
.contest-entry-page__btn:hover {
    background: #5A7FAF;
}
.contest-entry-page__btn--secondary {
    background: transparent;
    color: #5A7FAF;
    border: 1px solid #769AC9;
}
.contest-entry-page__btn--secondary:hover {
    background: rgba(118, 154, 201, 0.1);
}
/* .contest-entry-page__social {
    margin-bottom: 24px;
} */
