/* Общие стили для контента TipTap редактора */
/* Используется везде: мероприятия, эпики, сообщества и т.д. */

.gc-text-content {
    white-space: normal !important;
}

.gc-text-content p {
    margin-bottom: 1em;
}

.gc-text-content p:last-child {
    margin-bottom: 0;
}

.gc-text-content h1,
.gc-text-content h2,
.gc-text-content h3 {
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    font-weight: 600;
}

.gc-text-content h1:first-child,
.gc-text-content h2:first-child,
.gc-text-content h3:first-child {
    margin-top: 0;
}

.gc-text-content ul,
.gc-text-content ol {
    margin-bottom: 1em;
    padding-left: 1.5em;
}

.gc-text-content a {
    color: var(--accent-link);
    text-decoration: none;
}

.gc-text-content a:hover {
    color: var(--accent-link-hover);
    text-decoration: underline;
}

.gc-text-content strong {
    font-weight: 600;
}

/* ===================================
   Stage: read-only briefing content
   =================================== */
.gc-stage-content-description {
    font-size: var(--font-size-md);
    line-height: 1.7;
    color: var(--font-primary);
}

/* Убираем лишний отступ сверху у первого элемента */
.gc-stage-content-description > *:first-child {
    margin-top: 0 !important;
}

.gc-stage-content-description h2 {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    color: var(--font-primary);
    line-height: 1.3;
}

.gc-stage-content-description h2:first-child {
    margin-top: 0;
}

.gc-stage-content-description h3 {
    font-size: var(--font-size-xl);
    font-weight: 600;
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    color: var(--font-primary);
    line-height: 1.4;
}

.gc-stage-content-description h3:first-child {
    margin-top: 0;
}

.gc-stage-content-description p {
    margin: 0 0 var(--spacing-md) 0;
    line-height: 1.7;
    color: var(--font-secondary);
}

.gc-stage-content-description p:last-child {
    margin-bottom: 0;
}

.gc-stage-content-description ul,
.gc-stage-content-description ol {
    margin: var(--spacing-md) 0;
    padding-left: 24px;
}

.gc-stage-content-description ul {
    list-style-type: disc;
}

.gc-stage-content-description ol {
    list-style-type: decimal;
}

.gc-stage-content-description li {
    margin-bottom: var(--spacing-xs);
    line-height: 1.7;
}

.gc-stage-content-description li p {
    margin-bottom: var(--spacing-xs);
}

.gc-stage-content-description blockquote {
    border-left: 3px solid var(--accent-primary);
    padding-left: var(--spacing-md);
    margin: var(--spacing-md) 0;
    color: var(--font-secondary);
    font-style: italic;
}

.gc-stage-content-description a,
.gc-stage-content-description .stage-editor-link {
    color: var(--accent-link);
    text-decoration: none;
    transition: opacity var(--transition-fast);
}

.gc-stage-content-description a:hover,
.gc-stage-content-description .stage-editor-link:hover {
    text-decoration: underline;
    text-decoration-color: var(--accent-link);
    text-underline-offset: 2px;
    opacity: 0.8;
}

.gc-stage-content-description strong {
    font-weight: 700;
}

.gc-stage-content-description em {
    font-style: italic;
}

.gc-stage-content-description s {
    text-decoration: line-through;
    color: var(--font-secondary);
}

.gc-stage-content-description code {
    background: var(--bg-content-secondary);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-family: 'Monaco', 'Menlo', 'Courier New', monospace;
    font-size: 0.9em;
    color: var(--font-primary);
}

@media (max-width: 767.98px) {
    .gc-stage-content-description {
        font-size: var(--font-size-mdl);
    }

    .gc-stage-content-description h2 {
        font-size: var(--font-size-xxl);
    }

    .gc-stage-content-description h3 {
        font-size: var(--font-size-lg);
    }
}

/* Show page main column: denser rhythm (stage, weapon, …) */
.gc-show-main-panel .gc-stage-content-description,
.gc-stage-show-main .gc-stage-content-description {
    font-size: var(--font-size-mdl);
    line-height: 1.5;
    color: var(--font-secondary);
}

.gc-show-main-panel .gc-stage-content-description p,
.gc-stage-show-main .gc-stage-content-description p {
    margin-bottom: var(--spacing-sm);
    line-height: 1.5;
}

.gc-show-main-panel .gc-stage-content-description p:last-child,
.gc-stage-show-main .gc-stage-content-description p:last-child {
    margin-bottom: 0;
}

.gc-show-main-panel .gc-stage-content-description h2,
.gc-show-main-panel .gc-stage-content-description h3,
.gc-stage-show-main .gc-stage-content-description h2,
.gc-stage-show-main .gc-stage-content-description h3 {
    color: var(--font-primary);
}

/* Упоминания — размер/вес как у окружающего текста, только фон и цвет */
:is(.gc-text-content, .event-description-text, .gc-stage-content-description) .mention {
    background: rgba(241, 90, 48, 0.08);
    color: var(--accent-link);
    border-radius: var(--radius-sm);
    padding: 0 var(--spacing-xs);
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    vertical-align: baseline;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
    text-decoration: none;
}

:is(.gc-text-content, .event-description-text, .gc-stage-content-description) .mention:hover {
    background: rgba(241, 90, 48, 0.15);
    color: var(--accent-link-hover);
}

/* Инлайн-виджеты TipTap (карта/погода/ивент/диск): одинаковый вид во всех местах */
:is(.gc-text-content, .event-description-text, .gc-stage-content-description) :is(.weather-widget, .yandex-map-inline, .event-widget, .yandex-disk-widget) {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-4xs);
    padding: 0 var(--spacing-xs);
    background: rgba(241, 90, 48, 0.08);
    color: var(--accent-link);
    border-radius: var(--radius-sm);
    font-size: inherit;
    font-weight: 500;
    white-space: nowrap;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
    text-decoration: none;
}

:is(.gc-text-content, .event-description-text, .gc-stage-content-description) :is(.weather-widget, .yandex-map-inline, .event-widget, .yandex-disk-widget):hover {
    background: rgba(241, 90, 48, 0.15);
    color: var(--accent-link-hover);
    text-decoration: none !important;
}

/* Ограничение ширины текстового контента для читабельности (опционально) */
.gc-text-content-constrained {
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 991px) {
    .gc-text-content-constrained {
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }
}
