:root {
		--color-primary: #2563eb;
		--color-primary-dark: #1d4ed8;
		--color-bg: #f8fafc;
		--color-surface: #ffffff;
		--color-text: #0f172a;
		--color-text-secondary: #334155;
		--color-border: #e2e8f0;
		--radius: 12px;
		--shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
		--max-width: 1280px;
		--header-height: 64px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: calc(var(--header-height) + 20px); }
body {
		font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
		background: var(--color-bg);
		color: var(--color-text);
		line-height: 1.6;
		font-size: 16px;
		min-height: 100vh;
		display: flex;
		flex-direction: column;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font: inherit; cursor: pointer; }

h1, h2, h3 { font-weight: 700; line-height: 1.2; }
h1 { font-size: clamp(1.8rem, 5vw, 2.5rem); margin-bottom: 16px; }
h2 { font-size: 1.5rem; margin: 32px 0 12px; }

.site-header {
		background: var(--color-surface);
		border-bottom: 1px solid var(--color-border);
		position: sticky;
		top: 0;
		z-index: 100;
		min-height: var(--header-height);
}
.header-container {
		max-width: var(--max-width);
		margin: 0 auto;
		padding: 12px 20px;
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		flex-wrap: wrap;
}
.logo {
		background: var(--color-primary);
		color: #fff;
		font-weight: 700;
		font-size: 1.5rem;
		padding: 8px 20px;
		border-radius: 8px;
		letter-spacing: -0.5px;
		white-space: nowrap;
		transition: background 0.2s;
		display: inline-flex;
		align-items: center;
		gap: 4px;
		min-height: 44px;
}
.logo:hover, .logo:focus { background: var(--color-primary-dark); outline: none; }
.logo-highlight { font-weight: 800; color: #fff;}
.age-restriction {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		background: var(--color-primary);
		color: #fff;
		font-weight: 700;
		font-size: 0.8rem;
		width: 44px;
		height: 44px;
		border-radius: 6px;
		margin-left: 8px;
}

.mega-menu { position: relative; }
.mega-menu-trigger {
		background: none;
		border: 2px solid var(--color-primary);
		font-weight: 600;
		font-size: 0.95rem;
		color: var(--color-primary);
		padding: 10px 16px;
		border-radius: 8px;
		cursor: pointer;
		transition: background 0.2s, color 0.2s;
		display: flex;
		align-items: center;
		gap: 6px;
		min-height: 44px;
}
.mega-menu-trigger:hover, .mega-menu-trigger:focus {
		background: var(--color-primary);
		color: #fff;
		outline: none;
}
.mega-menu-trigger::after {
		content: '';
		display: inline-block;
		width: 8px;
		height: 8px;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		transform: rotate(45deg);
		margin-left: 4px;
		transition: transform 0.3s;
}
.mega-menu.open .mega-menu-trigger {
		background: var(--color-primary);
		color: #fff;
}
.mega-menu.open .mega-menu-trigger::after {
		transform: rotate(-135deg);
}
.mega-menu-panel {
		position: absolute;
		top: 100%;
		left: 0;
		background: var(--color-surface);
		border: 1px solid var(--color-border);
		border-radius: 12px;
		box-shadow: 0 10px 25px rgba(0,0,0,0.08);
		padding: 24px;
		min-width: 520px;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 8px 20px;
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		transition: all 0.2s ease;
		z-index: 200;
}
.mega-menu.open .mega-menu-panel {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
}
.mega-menu-panel a {
		font-weight: 500;
		font-size: 0.9rem;
		color: var(--color-primary);
		padding: 8px 12px;
		border-radius: 6px;
		transition: background 0.15s, color 0.15s;
		white-space: nowrap;
}
.mega-menu-panel a:hover {
		background: #eff6ff;
		color: var(--color-primary-dark);
}

.hamburger {
		display: none;
		flex-direction: column;
		gap: 5px;
		background: none;
		border: none;
		padding: 12px;
		cursor: pointer;
		z-index: 110;
		width: 44px;
		height: 44px;
		align-items: center;
		justify-content: center;
}
.hamburger span { display: block; width: 24px; height: 2px; background: var(--color-text); transition: 0.3s; }
.hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }


.header-search { display: flex; align-items: center; flex-shrink: 0; }
.header-search .gsc-input {
  border:none;
}
.header-search .gsc-input .gsc-input-box {
border: 1px solid var(--color-border); 
border-radius: 16px;
}
.header-search .gsc-input .gsc-input-box:has(.gsc-input:focus) {
border: 1px solid var(--color-primary); 
}
.header-search .gsib_a {
padding: 0 10px 0 56px;
}
.header-search .gsib_b {
height: 40px;
padding: 0 4px 0 0;
}


.header-search input {
		padding: 0 16px; border: 1px solid var(--color-border);
		border-radius: 8px 0 0 8px; font-size: 0.95rem; width: 200px;
		outline: none; transition: border-color 0.2s; height: 44px;
}
.header-search input:focus { border-color: var(--color-primary); }
.header-search button {
		background: var(--color-primary); color: #fff; border: none;
		padding: 0 18px; border-radius: 0 8px 8px 0; cursor: pointer;
		font-weight: 500; transition: background 0.2s; height: 44px;
}
.header-search button:hover { background: var(--color-primary-dark); }




.mobile-nav { display: none; }
@media (max-width: 1024px) {
		.mega-menu { display: none; }
		.hamburger { display: flex; }
		.mobile-nav {
				display: block;
				position: fixed;
				top: var(--header-height);
				left: 0;
				width: 100%;
				background: var(--color-surface);
				border-bottom: none;
				max-height: 0;
				overflow: hidden;
				transition: max-height 0.3s ease;
				z-index: 90;
		}
		.mobile-nav.open { max-height: 80vh; overflow-y: auto; border-bottom: 1px solid var(--color-border);}
		.mobile-nav ul {
				display: grid;
				grid-template-columns: repeat(2, 1fr);
				gap: 4px;
				padding: 20px;
		}
		.mobile-nav a {
				font-weight: 500;
				font-size: 0.95rem;
				color: var(--color-primary);
				padding: 12px 8px;
				border-radius: 8px;
				text-align: center;
				background: #f8fafc;
				transition: background 0.15s;
		}
		.mobile-nav a:hover { background: #eff6ff; color: var(--color-primary-dark); }
		.header-container { gap: 12px; }
		.header-search { flex: 1; order: 2; width: 100%; }
		.header-search input { flex: 1; width: auto; }
		.logo { order: 0; }
		.hamburger { order: 1; }
}

.article-body {
    line-height: 1.75;
    font-size: 17px;
}
.main-container {
		max-width: var(--max-width);
		margin: 30px auto;
		padding: 0 20px;
		flex: 1;
}
.article-card {
		background: var(--color-surface);
		border-radius: var(--radius);
		padding: clamp(20px, 4vw, 32px);
		margin-bottom: 30px;
		box-shadow: var(--shadow-sm);
}
.breadcrumb { font-size: 0.9rem; color: var(--color-text-secondary); margin-bottom: 24px; }
.breadcrumb a { color: var(--color-primary); text-decoration: underline; }
.breadcrumb span[aria-current="page"] { color: var(--color-text); font-weight: 500; }

.article-meta {
		display: flex; align-items: center; gap: 12px; color: var(--color-text-secondary);
		font-size: 0.9rem; margin-bottom: 24px; padding-bottom: 24px;
		border-bottom: 1px solid var(--color-border); flex-wrap: wrap;
}
.author-avatar { border-radius: 50%; width: 44px; height: 44px; object-fit: cover; }
.article-body p { max-width: 100%; margin-bottom: 1.25em; font-size: 1.1rem; line-height: 1.65; color: var(--color-text-secondary); }
.article-contents {
		background: #f8fafc;
		border-radius: 8px;
		padding: 20px;
		margin-bottom: 24px;
}
.article-contents__title { font-weight: 600; margin-bottom: 12px; font-size: 1.1rem; color: var(--color-text); }
.article-contents__list { list-style: decimal inside; padding-left: 0; }
.article-contents__item { margin-bottom: 6px; color: var(--color-primary); cursor: pointer; }
.article-contents__item:hover { text-decoration: underline; }
.tags { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 8px; }
.tag, .tags a {
		background: #eff6ff; color: var(--color-primary); padding: 8px 18px;
		border-radius: 20px; font-size: 0.85rem; font-weight: 500;
		min-height: 44px; display: inline-flex; align-items: center;
}
.tags a:hover {
		background: var(--color-primary); color: #fff;
}
.social-block {
		margin: 24px 0;
		padding: 16px;
		background: #f8fafc;
		border-radius: 8px;
		display: flex;
		align-items: center;
		gap: 12px;
		flex-wrap: wrap;
}
.social-block strong { color: var(--color-primary); }
.social-block img { width: 32px; height: 32px; }
.related-news {
		background: var(--color-surface);
		border-radius: var(--radius);
		padding: clamp(20px, 4vw, 32px);
		box-shadow: var(--shadow-sm);
}
.related-news h2 { margin-top: 0; margin-bottom: 16px; }
.related-news ul { list-style: none; }
.related-news li { margin-bottom: 12px; }
.related-news a { font-weight: 500; color: var(--color-text); transition: color 0.2s; }
.related-news a:hover { color: var(--color-primary); }



        .category-header {
            background: var(--color-surface);
            border-radius: var(--radius);
            padding: clamp(20px, 4vw, 32px);
            margin-bottom: 30px;
            box-shadow: var(--shadow-sm);
            display: flex;
            gap: 24px;
            align-items: flex-start;
        }
        .category-header h1 {
            margin-bottom: 12px;
        }
        .category-header img {
            border-radius: 8px;
            max-width: 200px;
            height: auto;
        }
        @media (max-width: 600px) {
            .category-header {
                flex-direction: column;
            }
            .category-header img {
                max-width: 100%;
                margin-bottom: 16px;
            }
        }
        
        
        .articles-list {
            display: flex;
            flex-direction: column;
            gap: 20px;
        }
        .article-row {
            display: flex;
            gap: 20px;
            background: var(--color-surface);
            border-radius: var(--radius);
            padding: 20px;
            box-shadow: var(--shadow-sm);
            transition: box-shadow 0.2s;
        }
        .article-row:hover {
            box-shadow: 0 4px 12px rgba(0,0,0,0.08);
        }
        .article-row img {
            width: 240px;
            height: 160px;
            object-fit: cover;
            border-radius: 8px;
            flex-shrink: 0;
        }
        .article-row .content {
            flex: 1;
            display: flex;
            flex-direction: column;
        }
        .article-row .date {
            font-size: 0.8rem;
            color: var(--color-text-secondary);
            margin-bottom: 4px;
        }
        .article-row h2 {
            margin: 0;
            margin-bottom: 8px;
        }
        .article-row h2 a {
            color: var(--color-text);
            transition: color 0.2s;
        }
        .article-row h2 a:hover {
            color: var(--color-primary);
        }
        .article-row p {
            font-size: 0.95rem;
            color: var(--color-text-secondary);
            margin-bottom: 12px;
            flex: 1;
        }
        .article-row .meta {
            font-size: 0.8rem;
            color: var(--color-text-secondary);
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }
        .article-row .meta a {
            color: var(--color-primary);
            font-weight: 500;
        }
        .article-row .meta a.au {
            color: #000;
        }
        .article-row .meta a:hover {
            text-decoration: underline;
        }
        
        @media (max-width: 600px) {
            .article-row {
                flex-direction: column;
            }
            .article-row img {
                width: 100%;
                height: auto;
            }
        }
        
        
        
        .pagination {
/*             display: flex; */
/*             justify-content: center; */
/*             gap: 8px; */
            margin-top: 25px;
        }
        .pagination a, .pagination span {
            display: inline-block;
/*             align-items: center; */
/*             justify-content: center; */
/*             min-width: 44px; */
            height: 44px;
            line-height: 44px;
            border-radius: 8px;
            font-weight: 500;
            transition: background 0.2s, color 0.2s;
            padding: 0 15px;
            margin: 5px;
        }
        .pagination a {
            background: var(--color-surface);
            color: var(--color-primary);
            border: 1px solid var(--color-border);
        }
        .pagination a:hover {
            background: var(--color-primary);
            color: #fff;
            border-color: var(--color-primary);
        }
        .pagination span[aria-current="page"] {
            background: var(--color-primary);
            color: #fff;
            border: 1px solid var(--color-primary);
        }
        
      
        .section-title {
            display: flex;
            justify-content: space-between;
            align-items: baseline;
            margin-bottom: 20px;
            border-bottom: 1px solid var(--color-border);
            padding-bottom: 8px;
        }
        .section-title h2 {
            color: var(--color-primary);
            margin-bottom: 0;
        }
        .section-title a {
            color: var(--color-primary);
            font-weight: 500;
            font-size: 0.9rem;
            transition: color 0.2s;
        }
        .section-title a:hover {
            text-decoration: underline;
            color: var(--color-primary-dark);
        }
        .news-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 24px;
            margin-bottom: 30px;
        }
        @media (max-width: 900px) {
            .news-grid {
                grid-template-columns: repeat(2, 1fr);
            }
        }
        @media (max-width: 480px) {
            .news-grid {
                grid-template-columns: 1fr;
            }
        }
        .news-card {
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            transition: box-shadow 0.2s;
            display: flex;
            flex-direction: column;
            height: 100%;
        }
        .news-card:hover {
            box-shadow: 0 4px 12px rgba(0,0,0,0.08);
        }
        .news-card img {
            width: 100%;
            height: 150px;
            object-fit: cover;
            border-radius: var(--radius) var(--radius) 0 0;
        }
        .news-card .card-body {
            padding: 16px;
            flex: 1;
            display: flex;
            flex-direction: column;
        }
        .news-card .date {
            font-size: 0.75rem;
            color: var(--color-text-secondary);
            margin-bottom: 6px;
        }
        .news-card h3 {
            font-size: 1rem;
            font-weight: 600;
            line-height: 1.4;
            margin-bottom: 8px;
        }
        .news-card h3 a {
            color: var(--color-text);
            transition: color 0.2s;
        }
        .news-card h3 a:hover {
            color: var(--color-primary);
        }
        .featured-news {
            margin-bottom: 30px;
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            overflow: hidden;
            display: flex;
            flex-direction: row;
        }
        @media (max-width: 600px) {
            .featured-news {
                flex-direction: column;
            }
        }
        .featured-news img {
            width: 50%;
            object-fit: cover;
        }
        @media (max-width: 600px) {
            .featured-news img {
                width: 100%;
                height: auto;
            }
        }
        .featured-news .featured-body {
            padding: 24px;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }
        .featured-news .date {
            font-size: 0.8rem;
            color: var(--color-text-secondary);
            margin-bottom: 8px;
        }
        .featured-news h2 {
            font-size: 1.8rem;
            margin: 0;
            margin-bottom: 12px;
        }
        .featured-news h2 a {
            color: var(--color-text);
            transition: color 0.2s;
        }
        .featured-news h2 a:hover {
            color: var(--color-primary);
        }
        .featured-news p {
            font-size: 1rem;
            color: var(--color-text-secondary);
        }
               
 


        /* Заголовок и описание */
        .page-header {
            background: var(--color-surface);
            border-radius: var(--radius);
            padding: clamp(20px, 4vw, 32px);
            margin-bottom: 30px;
            box-shadow: var(--shadow-sm);
        }
        .page-header h1 {
            font-size: clamp(1.8rem, 5vw, 2.5rem);
            margin-bottom: 12px;
        }
        .page-header p {
            font-size: 1rem;
            color: var(--color-text-secondary);
        }

        /* Сетка авторов */
        .authors-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 30px;
            margin: 30px 0;
        }
        .author-card {
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            transition: box-shadow 0.2s, transform 0.2s;
            text-align: center;
            padding: 24px 16px;
            display: flex;
            flex-direction: column;
            height: 100%;
        }
        .author-card:hover {
            box-shadow: 0 8px 20px rgba(0,0,0,0.08);
            transform: translateY(-2px);
        }
        .author-card img {
            width: 120px;
            height: 120px;
            border-radius: 50%;
            object-fit: cover;
            margin: 0 auto 16px;
            border: 3px solid var(--color-primary);
        }
        .author-card h2 {
            font-size: 1.2rem;
            font-weight: 600;
            margin: 10px 0 5px;
        }
        .author-card h2 a {
            color: var(--color-text);
            transition: color 0.2s;
        }
        .author-card h2 a:hover {
            color: var(--color-primary);
        }
        .author-card .role {
            font-size: 0.85rem;
            color: var(--color-primary);
            margin-bottom: 12px;
        }
        .author-card .bio {
            font-size: 0.85rem;
            color: var(--color-text-secondary);
            margin-bottom: 20px;
            flex: 1;
        }
        .author-card .btn {
            background: var(--color-primary);
            color: #fff;
            border: none;
            padding: 8px 16px;
            border-radius: 30px;
            font-size: 0.8rem;
            transition: background 0.2s;
            display: inline-block;
            margin-top: auto;
        }
        .author-card .btn:hover {
            background: var(--color-primary-dark);
        }

        @media (max-width: 1024px) {
            .authors-grid { grid-template-columns: repeat(3, 1fr); gap: 25px; }
        }
        @media (max-width: 768px) {
            .authors-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
        }
        @media (max-width: 480px) {
            .authors-grid { grid-template-columns: 1fr; gap: 20px; }
        }




      /* Профиль автора */
        .author-hero {
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            padding: clamp(16px, 3vw, 32px);
            display: flex;
            gap: 24px;
            align-items: flex-start;
            margin-bottom: 32px;
            flex-wrap: wrap;
        }
        .author-hero-image {
            width: clamp(120px, 25vw, 200px);
            height: clamp(120px, 25vw, 200px);
            border-radius: 50%;
            object-fit: cover;
            border: 4px solid var(--color-primary);
            flex-shrink: 0;
            margin: 0 auto;
        }
        .author-hero-info {
            flex: 1 1 280px;
            min-width: 260px;
        }
        .author-hero-info h1 {
            margin-bottom: 4px;
            color: var(--color-text);
        }
        .author-role {
            font-size: clamp(0.95rem, 2vw, 1.1rem);
            color: var(--color-primary);
            font-weight: 600;
            margin-bottom: 8px;
        }
        .author-stats {
            font-size: 0.9rem;
            color: var(--color-text-secondary);
            margin-bottom: 16px;
        }
        .author-bio {
            font-size: 0.9rem;
            line-height: 1.5;
            color: var(--color-text-secondary);
            margin-bottom: 16px;
            word-break: break-word;
        }
        .author-bio p {
            margin-bottom: 10px;
        }
        .author-bio img {
            max-width: 100%;
            height: auto;
            border-radius: 8px;
            margin: 10px 0;
        }
        .author-social {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            align-items: center;
            margin-top: 12px;
        }
        .author-social a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 44px;
            min-height: 44px;
            transition: opacity 0.2s;
        }
        .author-social a:hover {
            opacity: 0.8;
        }
        .author-social img {
            width: 22px;
            height: 22px;
        }
        .contact-link {
            background: var(--color-primary);
            color: #fff;
            padding: 10px 18px;
            border-radius: 30px;
            font-weight: 500;
            font-size: 0.9rem;
            text-decoration: none;
            transition: background 0.2s;
            white-space: nowrap;
        }
        .contact-link:hover {
            background: var(--color-primary-dark);
        }

        @media (max-width: 600px) {
            .author-hero {
                flex-direction: column;
                text-align: center;
                gap: 16px;
            }
            .author-hero-image {
                width: 140px;
                height: 140px;
            }
            .author-social {
                justify-content: center;
            }
            .contact-link {
                width: 100%;
                text-align: center;
            }
        }

        
        .articles-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
            margin-bottom: 24px;
        }
        @media (max-width: 1024px) {
            .articles-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; }
        }
        @media (max-width: 768px) {
            .articles-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
        }
        @media (max-width: 480px) {
            .articles-grid { grid-template-columns: 1fr; gap: 12px; }
        }
        
               
        
        /* Фильтр букв */
        .letter-filter {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-bottom: 24px;
            align-items: center;
        }
        .letter-filter a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 44px;
            min-height: 44px;
            padding: 8px 14px;
            border: 1px solid var(--color-border);
            border-radius: 8px;
            font-weight: 500;
            font-size: 0.9rem;
            color: var(--color-primary);
            background: var(--color-surface);
            transition: all 0.15s;
        }
        .letter-filter a:hover {
            background: #eff6ff;
            border-color: var(--color-primary);
        }
        .letter-filter a.active {
            background: var(--color-primary);
            color: #fff;
            border-color: var(--color-primary);
        }

        /* Облако тегов */
        .tags-cloud {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-bottom: 30px;
        }
        .tags-cloud a {
            display: inline-block;
            padding: 8px 14px;
            border: 1px solid var(--color-border);
            border-radius: 8px;
            font-size: 0.9rem;
            color: var(--color-text-secondary);
            background: var(--color-surface);
            transition: all 0.15s;
        }
        .tags-cloud a:hover {
            border-color: var(--color-primary);
            color: var(--color-primary);
            background: #eff6ff;
        }


        /* Навигация карты сайта */
        .sitemap-nav {
            display: flex;
            flex-wrap: wrap;
            gap: 16px;
            margin-bottom: 30px;
        }
        .sitemap-nav a {
            color: var(--color-primary);
            font-weight: 500;
            font-size: 0.95rem;
            padding: 8px 16px;
            border-radius: 8px;
            background: var(--color-surface);
            border: 1px solid var(--color-border);
            transition: all 0.15s;
            display: inline-flex;
            align-items: center;
            min-height: 44px;
        }
        .sitemap-nav a:hover {
            background: #eff6ff;
            border-color: var(--color-primary);
        }

        /* Сетка годов */
        .sitemap-grid {
            display: grid;
            grid-template-columns: repeat(6, 1fr);
            gap: 24px;
        }
        @media (max-width: 1200px) {
            .sitemap-grid {
                grid-template-columns: repeat(5, 1fr);
            }
        }
        @media (max-width: 1000px) {
            .sitemap-grid {
                grid-template-columns: repeat(4, 1fr);
            }
        }
        @media (max-width: 950px) {
            .sitemap-grid {
                grid-template-columns: repeat(3, 1fr);
            }
        }
        @media (max-width: 900px) {
            .sitemap-grid {
                grid-template-columns: repeat(2, 1fr);
            }
        }
        @media (max-width: 480px) {
            .sitemap-grid {
                grid-template-columns: 1fr;
            }
        }
        .year-card {
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            padding: 20px;
            height: 100%;
        }
        .year-card h2 {
            font-size: 1.3rem;
            font-weight: 700;
            color: var(--color-text);
            margin:0;
            margin-bottom: 12px;
            border-bottom: 1px solid var(--color-border);
            padding-bottom: 8px;
        }
        .year-card ul {
            display: flex;
            flex-direction: column;
            gap: 4px;
        }
        .year-card li a {
            display: block;
            padding: 8px 12px;
            color: var(--color-primary);
            font-size: 0.95rem;
            font-weight: 500;
            border-radius: 6px;
            transition: background 0.15s;
            text-decoration: none;
        }
        .year-card li a:hover {
            background: #eff6ff;
        }        
        
        
        
                /* Архив навигация */
        .archive-months {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-bottom: 30px;
        }
        .archive-months a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 44px;
            min-height: 44px;
            padding: 10px 20px;
            border-radius: 8px;
            border: 1px solid var(--color-border);
            background: var(--color-surface);
            color: var(--color-primary);
            font-weight: 500;
            font-size: 0.95rem;
            transition: all 0.15s;
        }
        .archive-months a:hover {
            background: #eff6ff;
            border-color: var(--color-primary);
        }
        .archive-months a.active {
            background: var(--color-primary);
            color: #fff;
            border-color: var(--color-primary);
        }

        /* Сетка дней */
        .days-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 16px;
            margin-bottom: 30px;
        }
        @media (max-width: 1024px) {
            .days-grid { grid-template-columns: repeat(3, 1fr); }
        }
        @media (max-width: 768px) {
            .days-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (max-width: 480px) {
            .days-grid { grid-template-columns: 1fr; }
        }
        .day-card {
            background: var(--color-surface);
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            transition: box-shadow 0.2s;
            text-align: center;
        }
        .day-card:hover {
            box-shadow: 0 4px 12px rgba(0,0,0,0.08);
        }
        .day-card a {
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 16px;
            height: 100%;
            min-height: 60px;
            font-weight: 600;
            font-size: 1rem;
            color: var(--color-primary);
            transition: color 0.2s;
        }
        .day-card a:hover {
            color: var(--color-primary-dark);
        }
        
              /* Архив дней */
        .archive-nav {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-bottom: 30px;
            margin-top: 30px;
        }
        .archive-nav a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 44px;
            min-height: 44px;
            padding: 8px 16px;
            border-radius: 8px;
            border: 1px solid var(--color-border);
            background: var(--color-surface);
            color: var(--color-primary);
            font-weight: 500;
            font-size: 0.9rem;
            transition: all 0.15s;
        }
        .archive-nav a:hover {
            background: #eff6ff;
            border-color: var(--color-primary);
        }
        .archive-nav a.active {
            background: var(--color-primary);
            color: #fff;
            border-color: var(--color-primary);
        }
 
 
         /* Основной контейнер */
        .main-container-error {
            max-width: var(--max-width);
            margin: 0 auto;
            padding: 40px 16px;
            flex: 1;
            width: 100%;
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
        }
        .error-code {
            font-size: clamp(4rem, 15vw, 8rem);
            font-weight: 800;
            color: var(--color-primary);
            line-height: 1;
            margin-bottom: 16px;
        }
        .error-title {
            font-size: clamp(1.5rem, 5vw, 2.5rem);
            font-weight: 700;
            margin-bottom: 12px;
        }
        .error-message {
            font-size: 1rem;
            color: var(--color-text-secondary);
            max-width: 500px;
            margin: 0 auto 30px;
        }
        .error-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            justify-content: center;
        }
        .error-actions .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 12px 24px;
            border-radius: 8px;
            font-weight: 600;
            font-size: 1rem;
            min-height: 48px;
            transition: background 0.2s;
        }
        .error-actions .btn-primary {
            background: var(--color-primary);
            color: #fff;
        }
        .error-actions .btn-primary:hover { background: var(--color-primary-dark); }
        .error-actions .btn-outline {
            background: var(--color-surface);
            color: var(--color-primary);
            border: 2px solid var(--color-primary);
        }
        .error-actions .btn-outline:hover { background: #eff6ff; }      
  
  
         /* Форма */
        .contact-form {
            display: flex;
            flex-direction: column;
            gap: 20px;
        }
        .form-group {
            display: flex;
            flex-direction: column;
        }
        .form-group label {
            font-weight: 600;
            font-size: 0.95rem;
            margin-bottom: 6px;
            color: var(--color-text);
        }
        .form-group input,
        .form-group textarea {
            padding: 12px 16px;
            border: 1px solid var(--color-border);
            border-radius: 8px;
            font-size: 1rem;
            font-family: inherit;
            transition: border-color 0.2s;
            outline: none;
            background: var(--color-surface);
        }
        .form-group input:focus,
        .form-group textarea:focus {
            border-color: var(--color-primary);
        }
        .form-group textarea {
            min-height: 160px;
            resize: vertical;
        }
        .form-submit {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            margin-top: 8px;
        }
        
        .privacy-note {
            font-size: 0.85rem;
            color: var(--color-text-secondary);
            flex: 1;
            min-width: 200px;
        }
        .privacy-note a {
            color: var(--color-primary);
            text-decoration: underline;
        }
        .form-submit .btn-primary {
            background: var(--color-primary);
            color: #fff;
            border: none;
            padding: 12px 28px;
            border-radius: 40px;
            font-weight: 600;
            font-size: 1rem;
            cursor: pointer;
            transition: background 0.2s;
            white-space: nowrap;
            min-height: 44px;
        }
        . form-submit .btn-primary:hover {
            background: var(--color-primary-dark);
        }

        @media (max-width: 600px) {
            .form-submit {
                flex-direction: column;
                align-items: stretch;
            }
            .form-submit .btn-primary {
                width: 100%;
                text-align: center;
            }
        }
              
.site-footer { background: #1e293b; color: #cbd5e1; padding: 32px 0; margin-top: auto; }
.footer-container {
		max-width: var(--max-width); margin: 0 auto; padding: 0 20px;
		display: flex; flex-wrap: wrap; justify-content: space-between; gap: 24px;
}
.footer-links ul { display: flex; flex-wrap: wrap; gap: 12px 24px; }
.footer-links a { font-size: 0.9rem; color: #94a3b8; min-height: 44px; display: inline-flex; align-items: center; }
.footer-links a:hover { color: white; }
.footer-social { /* display: flex; */ gap: 16px; /* align-items: center; */ }
.footer-social a { display: inline-block; /* align-items: center; */ /* justify-content: center; */ width: 44px; height: 44px; }
.footer-social img { width: 24px; height: 24px; opacity: 0.7; transition: opacity 0.2s; }
.footer-social img:hover { opacity: 1; }
.copyright { text-align: center; width: 100%; margin-top: 20px; font-size: 0.8rem; color: #64748b; border-top: 1px solid #334155; padding-top: 16px; }

/* Cookie уведомление */
.cookie-notice {
		position: fixed;
		bottom: 20px;
		left: 20px;
		right: 20px;
		background: #1e293b;
		color: #e2e8f0;
		border-radius: 16px;
		padding: 16px 20px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		gap: 16px;
		z-index: 1000;
		box-shadow: 0 10px 25px rgba(0,0,0,0.2);
		font-size: 0.9rem;
		line-height: 1.4;
		backdrop-filter: blur(4px);
		background-color: rgba(30, 41, 59, 0.95);
}
.cookie-notice p { margin: 0; flex: 1; }
.cookie-notice a { color: #60a5fa; text-decoration: underline; }
.cookie-notice button {
		background: var(--color-primary);
		color: #fff;
		border: none;
		padding: 10px 24px;
		border-radius: 40px;
		font-weight: 600;
		cursor: pointer;
		transition: background 0.2s;
		font-size: 0.85rem;
		white-space: nowrap;
		min-height: 44px;
}
.cookie-notice button.cookie-decline { background: #334155; }
.cookie-notice button.cookie-decline:hover { background: #475569; }
.cookie-notice button:hover { background: var(--color-primary-dark); }
.cookie-buttons { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
@media (max-width: 600px) {
		.cookie-notice { flex-direction: column; text-align: center; bottom: 10px; left: 10px; right: 10px; padding: 16px; }
		.cookie-buttons { width: 100%; flex-direction: column; }
		.cookie-notice button { width: 100%; white-space: normal; }
}
  
  