:root {
--accent-color: #0D9488; /* Основной бирюзовый /
--accent-hover: #0F766E; / Темнее для наведения /
--text-primary: #1F2937; / Насыщенный темный для текста /
--text-secondary: #4B5563; / Мягкий серый для второстепенного текста /
--bg-main: #F9FAFB; / Очень светлый серый фон /
--bg-surface: #FFFFFF; / Чистый белый для поверхностей /
--border-color: #E5E7EB; / Светлая рамка */
--shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
--shadow-md: 0 6px 12px -3px rgba(0, 0, 0, 0.1);
}
body {
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
line-height: 1.8;
margin: 0;
background-color: var(--bg-main);
color: var(--text-primary);
}
.container {
max-width: 800px;
margin: 0 auto;
padding: 24px;
}
a {
color: var(--accent-color);
text-decoration: none;
transition: color .2s ease;
}
a:hover {
color: var(--accent-hover);
}
header {
background: var(--bg-surface);
padding: 24px 0;
border-bottom: 1px solid var(--border-color);
box-shadow: var(--shadow-sm);
margin-bottom: 56px; /* Увеличен отступ */
}
header .container {
display: flex;
justify-content: center;
align-items: center;
}
nav ul {
margin: 0;
padding: 0;
list-style: none;
}
nav ul li {
display: inline-block;
margin: 0 24px;
}
nav a {
font-weight: 600;
font-size: 1rem;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 1.2px;
}
article {
background: var(--bg-surface);
padding: 56px; /* Больше "воздуха" /
border-radius: 16px; / Более мягкие скругления */
box-shadow: var(--shadow-md);
}
article h1 {
font-size: 3rem; /* Крупный и заметный заголовок */
margin-top: 0;
line-height: 1.2;
margin-bottom: 2rem;
color: var(--text-primary);
}
article h2 {
font-size: 2rem;
margin-top: 3rem;
padding-bottom: .75rem;
border-bottom: 3px solid var(--accent-color); /* Более жирное подчеркивание */
color: var(--text-primary);
}
article h3 {
font-size: 1.6rem;
margin-top: 2.5rem;
color: var(--text-primary);
}
article p,
article li {
font-size: 1.15rem; /* Чуть крупнее для читаемости */
color: var(--text-secondary);
}
article strong {
color: var(--accent-color);
}
.post-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 32px;
}
.post-card-link {
text-decoration: none;
color: var(--text-primary);
}
.post-card {
background: var(--bg-surface);
border-radius: 16px;
box-shadow: var(--shadow-sm);
overflow: hidden;
transition: transform .2s ease, box-shadow .2s ease;
border: 1px solid transparent; /* Рамка по умолчанию прозрачная */
}
.post-card:hover {
transform: translateY(-8px); /* Более заметный эффект */
box-shadow: var(--shadow-md);
border-color: var(--accent-color);
}
.post-card-content {
padding: 28px;
}
.post-card h2 {
margin: 0;
font-size: 1.4rem;
line-height: 1.4;
}
.related-posts {
margin-top: 5rem;
padding-top: 3rem;
border-top: 1px solid var(--border-color);
}
.related-posts h3 {
font-size: 2rem;
margin-bottom: 3rem;
text-align: center;
color: var(--text-primary);
}
.related-grid {
display: grid;
grid-template-columns: repeat(auto-fit, 250px);
justify-content: center;
gap: 24px;
}
/* Ключевое исправление: делаем карточку flex-контейнером */
.related-card {
/* Эти 3 свойства - ключ к центрированию /
display: flex;
align-items: center;     / ВЫРАВНИВАНИЕ ПО ВЕРТИКАЛИ /
justify-content: center; / Выравнивание по горизонтали */
/* Это свойство заставляет ссылку занять всю высоту родителя */
height: 100%;
/* ВОТ ИСПРАВЛЕНИЕ: Это свойство говорит браузеру включать padding
в расчет высоты (100%), а не добавлять его сверх этого. */
box-sizing: border-box;
/* Все остальные ваши стили остаются без изменений */
padding: 20px;
background: var(--bg-surface);
border-radius: 12px;
box-shadow: var(--shadow-sm);
border: 1px solid var(--border-color);
text-align: center;
font-weight: 600;
transition: all .2s ease;
}
.related-card a {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
box-sizing: border-box;
text-align: center;
font-weight: 600;
transition: all .2s ease;
}
.related-card a:hover {
transform: translateY(-8px);
box-shadow: var(--shadow-md);
border-color: var(--accent-color);
color: var(--accent-color);
}
.discussion-comments-container {
margin-top: 5rem;
padding-top: 3rem;
border-top: 1px solid var(--border-color);
}
.comments-title {
font-size: 2rem;
margin-bottom: 3rem;
text-align: center;
color: var(--text-primary);
}
.comment-node {
margin-top: 1.5rem;
}
.comment-main {
display: flex;
align-items: flex-start;
}
.comment-avatar img {
width: 44px;
height: 44px;
border-radius: 50%;
margin-right: 16px;
flex-shrink: 0;
}
.comment-body {
flex-grow: 1;
}
.comment-author {
font-weight: 600;
color: var(--text-primary);
font-size: 1rem;
}
.comment-text {
margin: 0.25rem 0 0 0;
color: var(--text-secondary);
}
.comment-replies {
margin-left: 28px;
padding-left: 28px;
border-left: 2px solid var(--border-color);
margin-top: 1rem;
}
.pagination-container {
margin-top: 56px;
text-align: center;
}
.pagination a,
.pagination span {
display: inline-block;
margin: 0 5px;
padding: 10px 18px;
border-radius: 50px;
font-weight: 600;
border: 1px solid var(--border-color);
transition: all .2s ease;
}
.pagination a:hover {
background: var(--accent-color);
color: #fff;
border-color: var(--accent-color);
}
.pagination span {
background: var(--accent-color);
color: #fff;
border: 1px solid var(--accent-color);
}
footer {
text-align: center;
padding: 56px 0;
margin-top: 56px;
background: var(--bg-surface);
color: var(--text-secondary);
border-top: 1px solid var(--border-color);
}
@media (max-width: 768px) {
.post-grid,
.related-grid {
grid-template-columns: 1fr;
}
.comment-replies {
padding-left: 16px;
margin-left: 12px;
}
article {
padding: 24px;
}
}