/* ============================================================
   Mowgli Blog — дизайн-система
   ============================================================ */

:root {
	/* джунглі: зелень + небо/річка, тепло — лише акцентами */
	--bg-dark:        #143D26;   /* глибокий джунглевий зелений (hero/footer) */
	--bg-dark-2:      #1C4E32;
	--bg-dark-3:      #0E2E1C;
	--bg-paper:       #F4EEDD;   /* папір/пісок */
	--bg-paper-2:     #E7DEC3;
	--bg-paper-3:     #DDEBE0;   /* ледь зеленавий папір */
	--ink:            #1B2A1B;   /* майже-чорний з зеленим підтоном */
	--ink-2:          #2E4B30;
	--ink-muted:      #5C6E55;
	--line:           #C8D2BC;
	--line-soft:      rgba(27, 42, 27, 0.12);

	--green:          #2F8F45;   /* листя — головний акцент */
	--green-deep:     #1F6B33;
	--green-soft:     #CDE7CF;
	--sky:            #2E86AB;   /* небо/річка — другий акцент */
	--sky-deep:       #1F6481;
	--sky-soft:       #CFE6EE;
	--sun:            #E0A93D;   /* сонячні плями — третій, тепло, дозовано */
	--sun-soft:       #F6E3B6;
	--clay:           #C2603F;   /* леопард/глина — четвертий */

	/* загальні акцентні аліаси */
	--accent:         var(--green);
	--accent-deep:    var(--green-deep);
	--accent-soft:    var(--green-soft);

	--cat-novyny:     var(--sky);
	--cat-anonsy:     var(--sun);
	--cat-turniry:    var(--green);
	--cat-statti:     var(--clay);

	--maxw:           1240px;
	--gutter:         clamp(20px, 4vw, 56px);
	--radius:         2px;

	--fs-display:     clamp(2.1rem, 5.4vw, 4.5rem);
	--fs-h1:          clamp(2rem, 4.5vw, 3.5rem);
	--fs-h2:          clamp(1.625rem, 3vw, 2.5rem);
	--fs-h3:          1.375rem;
	--fs-base:        1rem;
	--fs-sm:          0.875rem;
	--fs-xs:          0.75rem;

	--shadow-press:   0 2px 0 0 var(--ink);
	--shadow-press-2: 0 4px 0 0 var(--ink);

	--ease:           cubic-bezier(.2,.7,.2,1);
}

/* --- reset --- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
body {
	margin: 0;
	font-family: 'Manrope', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	font-size: var(--fs-base);
	line-height: 1.55;
	color: var(--ink);
	background: var(--bg-paper);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
ul, ol { padding: 0; margin: 0; list-style: none; }
h1, h2, h3, h4 { margin: 0; font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; }
p { margin: 0 0 1em; }

/* --- утиліти --- */
.m-container { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
.m-section   { padding-block: clamp(56px, 8vw, 112px); position: relative; }
.m-section--paper { background: var(--bg-paper); }
.m-section--paper-2 { background: var(--bg-paper-2); }
.m-section--dark { background: var(--bg-dark); color: var(--bg-paper); }

.m-eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-size: var(--fs-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ink-muted);
}
.m-eyebrow::before {
	content: ""; width: 28px; height: 2px; background: currentColor; opacity: .7;
}
.m-section--dark .m-eyebrow { color: var(--sun); }

.m-title-xl { font-size: var(--fs-display); }
.m-title-l  { font-size: var(--fs-h1); }
.m-title-m  { font-size: var(--fs-h2); }

.m-mark {
	display: inline-block;
	background: var(--sun);
	color: var(--ink);
	padding: 0 .15em;
	box-shadow: 6px 6px 0 0 rgba(0,0,0,.35);
	transform: rotate(-1.5deg);
}
.m-mark--sky  { background: var(--sky); color: #fff; }
.m-mark--leaf { background: var(--green); color: #fff; }
@media (max-width: 600px) {
	.m-mark { transform: none; box-shadow: 4px 4px 0 0 rgba(0,0,0,.3); }
}

/* --- pattern background --- */
.m-pattern {
	position: absolute; inset: 0;
	background-image: radial-gradient(circle at 1px 1px, rgba(47,143,69,.12) 1px, transparent 0);
	background-size: 22px 22px;
	pointer-events: none;
	z-index: 0;
}
.m-section--dark .m-pattern,
.m-hero .m-pattern, .m-cta .m-pattern, .m-post-hero .m-pattern {
	background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.10) 1px, transparent 0);
}
.m-section > .m-container { position: relative; z-index: 1; }

/* ============================================================
   Header / Navbar
   ============================================================ */
.m-header {
	background: var(--bg-dark);
	color: var(--bg-paper);
	border-bottom: 1px solid rgba(255,255,255,.06);
	position: sticky; top: 0; z-index: 50;
}
.m-nav {
	display: flex; align-items: center; gap: 32px;
	padding-block: 18px;
}
.m-logo {
	display: inline-flex; align-items: center; gap: 12px;
	font-weight: 800; font-size: 1.2rem; letter-spacing: -0.02em;
	color: var(--bg-paper);
}
.m-logo__img, .m-logo .custom-logo {
	width: 52px; height: 52px;
	object-fit: contain;
	flex-shrink: 0;
	filter: drop-shadow(2px 2px 0 rgba(0,0,0,.25));
}
.m-logo__text { display: flex; flex-direction: column; line-height: 1.1; }
.m-logo__txt { font-size: 1.05rem; }
.m-logo__sub { font-size: var(--fs-xs); color: var(--sun); letter-spacing: 0.2em; text-transform: uppercase; font-weight: 700; }
@media (max-width: 520px) {
	.m-logo__txt { font-size: .95rem; }
	.m-logo__img, .m-logo .custom-logo { width: 44px; height: 44px; }
}

.m-nav__links { display: flex; gap: 28px; align-items: center; flex: 1; }
.m-nav__links a {
	font-size: var(--fs-sm); font-weight: 600;
	color: rgba(246, 239, 226, 0.8);
	padding: 8px 0;
	position: relative;
	transition: color .2s var(--ease);
}
.m-nav__links a::after {
	content: ""; position: absolute; left: 0; right: 100%; bottom: 4px;
	height: 2px; background: var(--sun);
	transition: right .25s var(--ease);
}
.m-nav__links a:hover, .m-nav__links a.is-active { color: var(--bg-paper); }
.m-nav__links a:hover::after, .m-nav__links a.is-active::after { right: 0; }

.m-nav__cta {
	margin-left: auto;
	display: inline-flex; align-items: center; gap: 8px;
	padding: 11px 20px;
	background: var(--accent); color: var(--ink);
	font-weight: 700; font-size: var(--fs-sm);
	border: 2px solid var(--ink);
	box-shadow: var(--shadow-press);
	transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.m-nav__cta:hover { transform: translateY(-1px); box-shadow: 0 3px 0 0 var(--ink); }
.m-nav__cta:active { transform: translateY(2px); box-shadow: 0 0 0 0 var(--ink); }

.m-nav__toggle { display: none; background: none; border: 0; color: inherit; }

@media (max-width: 880px) {
	.m-nav__links, .m-nav__cta { display: none; }
	.m-nav__toggle { display: inline-grid; place-items: center; width: 40px; height: 40px; margin-left: auto; }
	.m-nav.is-open { flex-wrap: wrap; }
	.m-nav.is-open .m-nav__links {
		display: flex; flex-direction: column; align-items: stretch;
		flex-basis: 100%; gap: 0; border-top: 1px solid rgba(255,255,255,.08);
		padding-block: 16px;
	}
	.m-nav.is-open .m-nav__links a { padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.04); }
	.m-nav.is-open .m-nav__cta { display: inline-flex; flex-basis: 100%; justify-content: center; margin: 0 0 12px; }
}

/* ============================================================
   Hero (Blog index)
   ============================================================ */
.m-hero {
	background: var(--bg-dark);
	color: var(--bg-paper);
	padding-top: clamp(56px, 8vw, 96px);
	padding-bottom: clamp(80px, 10vw, 128px);
	overflow: hidden;
	position: relative;
}
.m-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, .9fr);
	gap: clamp(32px, 5vw, 72px);
	align-items: center;
	position: relative; z-index: 1;
}
.m-hero__title {
	font-size: var(--fs-display);
	line-height: .95;
	margin-bottom: 24px;
	overflow-wrap: break-word;
}
.m-hero__lede {
	font-size: 1.125rem; line-height: 1.55;
	color: rgba(246, 239, 226, 0.78);
	max-width: 56ch;
	margin-bottom: 32px;
}
.m-hero__meta {
	display: flex; flex-wrap: wrap; gap: 24px 40px;
	border-top: 1px solid rgba(255, 255, 255, .18);
	padding-top: 24px;
}
.m-hero__meta-item .num {
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	display: block; line-height: 1;
}
.m-hero__meta-item:nth-child(1) .num { color: var(--sun); }
.m-hero__meta-item:nth-child(2) .num { color: var(--sky-soft); }
.m-hero__meta-item:nth-child(3) .num { color: var(--green-soft); }
.m-hero__meta-item .lbl {
	font-size: var(--fs-xs);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(244, 238, 221, 0.6);
	margin-top: 6px; display: block;
}

/* hero featured card (right side) */
.m-hero__featured {
	position: relative;
	border: 2px solid var(--sky);
	background: var(--bg-dark-2);
	transform: rotate(-1.2deg);
	box-shadow: 8px 8px 0 0 var(--sky);
	transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.m-hero__featured:hover { transform: rotate(0); box-shadow: 12px 12px 0 0 var(--sky); }
.m-hero__featured-stripe {
	background: var(--sky); color: #fff;
	font-size: var(--fs-xs); font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase;
	padding: 8px 14px;
	display: flex; justify-content: space-between;
}
.m-hero__featured-img { aspect-ratio: 16/9; overflow: hidden; }
.m-hero__featured-img img { width: 100%; height: 100%; object-fit: cover; }
.m-hero__featured-img--empty {
	background:
		linear-gradient(135deg, transparent 0 49%, rgba(255,255,255,.12) 49% 51%, transparent 51%) 0 0 / 28px 28px,
		var(--bg-dark-3);
	display: grid; place-items: center;
	color: var(--sky-soft); font-weight: 800; font-size: 4rem;
}
.m-hero__featured-body { padding: 20px 22px; }
.m-hero__featured-body h2 {
	font-size: 1.5rem; line-height: 1.15; margin-bottom: 10px; color: var(--bg-paper);
}
.m-hero__featured-body p { color: rgba(246, 239, 226, 0.7); margin: 0; font-size: var(--fs-sm); }

@media (max-width: 880px) {
	.m-hero__inner { grid-template-columns: 1fr; }
	.m-hero__featured { transform: rotate(0); box-shadow: 6px 6px 0 0 var(--accent); }
}

/* ============================================================
   Filter / tabs
   ============================================================ */
.m-filter {
	background: var(--bg-paper-2);
	border-block: 2px solid var(--ink);
	position: sticky; top: 76px; z-index: 30;
}
.m-filter__inner {
	display: flex; align-items: center;
	gap: 8px;
	overflow-x: auto;
	scrollbar-width: none;
	padding-block: 14px;
}
.m-filter__inner::-webkit-scrollbar { display: none; }
.m-filter__label {
	font-size: var(--fs-xs); letter-spacing: 0.16em; text-transform: uppercase;
	font-weight: 700; color: var(--ink-muted); margin-right: 12px; flex-shrink: 0;
}
.m-filter a {
	flex-shrink: 0;
	display: inline-flex; align-items: center; gap: 8px;
	padding: 10px 18px;
	font-size: var(--fs-sm); font-weight: 700;
	background: var(--bg-paper); color: var(--ink);
	border: 2px solid var(--ink);
	transition: transform .15s var(--ease), background .15s var(--ease), color .15s var(--ease);
}
.m-filter a:hover { transform: translateY(-1px); }
.m-filter a.is-active {
	background: var(--ink); color: var(--bg-paper);
	box-shadow: var(--shadow-press);
	transform: translateY(-2px);
}
.m-filter a .dot {
	width: 8px; height: 8px; background: var(--cat); border: 1.5px solid currentColor;
}
.m-filter a[data-cat="novyny"]  { --cat: var(--cat-novyny); }
.m-filter a[data-cat="anonsy"]  { --cat: var(--cat-anonsy); }
.m-filter a[data-cat="turniry"] { --cat: var(--cat-turniry); }
.m-filter a[data-cat="statti"]  { --cat: var(--cat-statti); }
.m-filter a[data-cat="all"]     { --cat: var(--ink); }

/* ============================================================
   Card grid
   ============================================================ */
.m-feed { padding-block: clamp(48px, 6vw, 80px); }
.m-feed__head {
	display: flex; align-items: end; justify-content: space-between; gap: 24px;
	margin-bottom: 40px; flex-wrap: wrap;
}
/* Кладка «плиткою»: картки різної висоти пакуються в колонки (masonry) */
.m-grid {
	column-width: 320px;
	column-gap: 28px;
}
.m-grid > * {
	break-inside: avoid;
	margin-bottom: 28px;
}

.m-card {
	background: var(--bg-paper);
	border: 2px solid var(--ink);
	box-shadow: 6px 6px 0 0 var(--ink);
	transition: transform .2s var(--ease), box-shadow .2s var(--ease);
	display: flex; flex-direction: column;
	position: relative;
}
.m-card::before {
	content: ""; position: absolute; left: -2px; right: -2px; top: -2px;
	height: 8px; background: var(--cat, var(--ink));
}
.m-card--novyny  { --cat: var(--cat-novyny); }
.m-card--anonsy  { --cat: var(--cat-anonsy); }
.m-card--turniry { --cat: var(--cat-turniry); }
.m-card--statti  { --cat: var(--cat-statti); }

.m-card:hover {
	transform: translate(-2px, -2px);
	box-shadow: 10px 10px 0 0 var(--ink);
}
.m-card__link { display: contents; color: inherit; }

.m-card__media {
	overflow: hidden;
	border-bottom: 2px solid var(--ink);
	background: var(--bg-paper-2);
}
.m-card__media img {
	display: block; width: 100%; height: auto;
	transition: transform .5s var(--ease);
}
.m-card:hover .m-card__media img { transform: scale(1.03); }

.m-card__placeholder {
	width: 100%; aspect-ratio: 16/10; position: relative;
	display: grid; place-items: center;
	background: linear-gradient(135deg, var(--bg-paper-2), var(--bg-paper));
}
.m-card__placeholder svg.mowgli-pattern { position: absolute; inset: 0; }
.m-card__mark {
	position: relative; z-index: 1;
	font-size: clamp(4rem, 10vw, 6rem); font-weight: 900;
	color: var(--cat); opacity: .35;
	letter-spacing: -0.06em;
}

.m-card__body {
	padding: 22px 22px 24px;
	display: flex; flex-direction: column; gap: 12px; flex: 1;
}
.m-badge {
	align-self: flex-start;
	background: var(--ink); color: var(--bg-paper);
	font-size: var(--fs-xs); font-weight: 800;
	letter-spacing: 0.14em; text-transform: uppercase;
	padding: 5px 12px;
	transform: rotate(-1deg);
}
.m-card__title {
	font-size: 1.25rem; font-weight: 800; line-height: 1.2;
	color: var(--ink);
}
.m-card__excerpt {
	color: var(--ink-muted); font-size: var(--fs-sm); margin: 0;
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
	overflow: hidden;
}
.m-card__meta {
	display: flex; gap: 8px; align-items: center;
	color: var(--ink-muted);
	font-size: var(--fs-xs); letter-spacing: 0.04em;
	margin-top: auto; padding-top: 8px;
	border-top: 1px dashed var(--line);
}
.m-dot { opacity: .5; }

/* Виділена велика картка для першого посту в стрічці */
.m-card--featured {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: 1.2fr 1fr;
}
.m-card--featured::before { left: -2px; right: -2px; height: 10px; }
.m-card--featured .m-card__media { border-bottom: 0; border-right: 2px solid var(--ink); aspect-ratio: auto; }
.m-card--featured .m-card__title { font-size: clamp(1.5rem, 2.5vw, 2.25rem); }
.m-card--featured .m-card__body { padding: clamp(24px, 3vw, 40px); gap: 16px; }
.m-card--featured .m-card__excerpt {
	font-size: var(--fs-base); -webkit-line-clamp: 5;
}
@media (max-width: 720px) {
	.m-card--featured { grid-template-columns: 1fr; }
	.m-card--featured .m-card__media { border-right: 0; border-bottom: 2px solid var(--ink); aspect-ratio: 16/10; }
}

/* ============================================================
   Pagination
   ============================================================ */
.m-pager {
	margin-top: 56px;
	display: flex; justify-content: center; gap: 8px;
}
.m-pager .page-numbers {
	min-width: 44px; height: 44px;
	display: inline-grid; place-items: center;
	font-weight: 700; font-size: var(--fs-sm);
	background: var(--bg-paper); color: var(--ink);
	border: 2px solid var(--ink);
	transition: transform .15s var(--ease);
	padding: 0 14px;
}
.m-pager .page-numbers:hover { transform: translateY(-2px); box-shadow: var(--shadow-press); }
.m-pager .page-numbers.current {
	background: var(--ink); color: var(--accent);
}

/* ============================================================
   Single post
   ============================================================ */
.m-post-hero {
	background: var(--bg-dark);
	color: var(--bg-paper);
	padding-block: clamp(56px, 7vw, 96px);
	position: relative; overflow: hidden;
}
.m-post-hero__inner { max-width: 880px; margin: 0 auto; position: relative; z-index: 1; }
.m-post-hero .m-badge { background: var(--accent); color: var(--ink); margin-bottom: 24px; }
.m-post-hero__title {
	font-size: clamp(2rem, 5vw, 4rem);
	line-height: 1.05;
	margin-bottom: 24px;
}
.m-post-hero__meta {
	display: flex; flex-wrap: wrap; gap: 16px 28px;
	color: rgba(246, 239, 226, 0.65);
	font-size: var(--fs-sm);
	letter-spacing: 0.04em;
}
.m-post-hero__meta strong { color: var(--bg-paper); font-weight: 600; }

.m-post-body {
	max-width: 720px;
	margin: 0 auto;
	padding-block: clamp(48px, 6vw, 88px);
	font-size: 1.0625rem; line-height: 1.7;
}
.m-post-body > * + * { margin-top: 1.2em; }
.m-post-body h2 { font-size: clamp(1.5rem, 2.5vw, 2rem); margin-top: 2em; }
.m-post-body h3 { font-size: 1.25rem; margin-top: 1.6em; }
.m-post-body a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--accent); text-decoration-thickness: 3px; text-underline-offset: 3px; }
.m-post-body a:hover { background: var(--accent-soft); }
.m-post-body blockquote {
	border-left: 6px solid var(--accent);
	padding: 12px 0 12px 24px;
	font-size: 1.25rem; font-weight: 600;
	font-style: italic;
	color: var(--ink-2);
	margin-block: 1.6em;
}
.m-post-body img { border: 2px solid var(--ink); margin-block: 0; display: block; }
.m-post-body figure { margin-block: 1.8em; }
.m-post-body figure img { width: 100%; }
.m-post-body figcaption {
	margin-top: 10px; font-size: var(--fs-sm); color: var(--ink-muted);
	border-left: 3px solid var(--green); padding-left: 12px;
}
.m-post-body ul, .m-post-body ol { padding-left: 1.4em; }
.m-post-body ul li, .m-post-body ol li { margin-bottom: .4em; list-style: revert; }
.m-post-body ul li::marker { color: var(--green); }
.m-post-body ol li::marker { color: var(--green); font-weight: 700; }
.m-post-body code { background: var(--bg-paper-2); padding: 1px 6px; font-size: .9em; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.m-post-body pre, .m-post-body .wp-block-code {
	background: var(--bg-dark-3); color: var(--green-soft);
	padding: 16px 18px; overflow-x: auto; border: 2px solid var(--ink);
	font-size: var(--fs-sm); line-height: 1.5; margin-block: 1.6em;
}
.m-post-body pre code, .m-post-body .wp-block-code code { background: none; padding: 0; color: inherit; }

/* таблиці */
.m-post-body table, .m-post-body .wp-block-table table {
	width: 100%; border-collapse: collapse;
	border: 2px solid var(--ink);
	font-size: var(--fs-sm); margin-block: 0;
}
.m-post-body .wp-block-table { margin-block: 1.8em; overflow-x: auto; }
.m-post-body th, .m-post-body td {
	padding: 10px 14px; text-align: left;
	border: 1px solid var(--line);
}
.m-post-body thead th {
	background: var(--ink); color: var(--bg-paper);
	font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.1em;
	border-color: var(--ink);
}
.m-post-body tbody tr:nth-child(even) { background: var(--bg-paper-2); }
.m-post-body table figcaption, .m-post-body .wp-block-table figcaption { border: 0; padding-left: 0; }

.m-post-thumbnail {
	max-width: 1000px; margin: 0 auto;
	border: 2px solid var(--ink);
	box-shadow: 12px 12px 0 0 var(--sky);
}
.m-post-thumbnail img { display: block; width: 100%; height: auto; }

/* ============================================================
   Tournament detail
   ============================================================ */
/* основний текст перед таблицею — менший відступ знизу */
.m-post-body--top { padding-bottom: clamp(16px, 2.5vw, 28px); }

.m-tournament {
	max-width: 960px; margin: 0 auto;
	padding-block: clamp(28px, 4vw, 56px);
}

/* медальний залік клубу — зведена плашка */
.m-medaltally {
	display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px;
	border: 2px solid var(--ink); background: var(--bg-paper);
	padding: 14px 18px; margin-bottom: 30px;
}
.m-medaltally__lbl {
	font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.14em;
	font-weight: 700; color: var(--ink-muted); margin-right: 4px;
}
.m-medal {
	display: inline-flex; align-items: baseline; gap: 7px;
	padding: 6px 14px 6px 11px; line-height: 1;
	border: 2px solid var(--ink); border-left-width: 7px;
	background: var(--bg-paper-2);
	font-size: var(--fs-sm); font-weight: 700;
}
.m-medal b { font-size: 1.375rem; font-weight: 900; }
.m-medal--g   { border-left-color: #C9A227; }
.m-medal--s   { border-left-color: #B8B8B8; }
.m-medal--b   { border-left-color: #A0522D; }
.m-medal--all { border-left-color: var(--green); background: var(--green-soft); }

/* група = вікова / вагова категорія */
.m-t-group + .m-t-group { margin-top: 38px; }
.m-t-group__head {
	display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between;
	gap: 6px 22px; margin-bottom: 14px; padding-bottom: 10px;
	border-bottom: 3px solid var(--ink);
}
.m-t-group__title { font-size: clamp(1.2rem, 1.9vw, 1.55rem); line-height: 1.15; margin: 0; }
.m-t-group__sum {
	display: flex; flex-wrap: wrap; gap: 14px;
	font-size: var(--fs-sm); color: var(--ink-muted); white-space: nowrap;
}
.m-t-group__sum span { font-weight: 600; }
.m-t-group__sum b { font-weight: 900; font-size: 1.05rem; }
.m-t-group__sum .g  b { color: #9A7B12; }
.m-t-group__sum .s  b { color: #6F7479; }
.m-t-group__sum .b2 b { color: #7A3E20; }

/* таблиця спортсменів усередині групи */
.m-t-table {
	border: 2px solid var(--ink);
	background: var(--bg-paper);
}
.m-t-table__head, .m-t-table__row {
	display: grid;
	grid-template-columns: 84px 1fr;
	gap: 16px;
	padding: 12px 20px;
	border-bottom: 1px dashed var(--line);
	align-items: center;
}
.m-t-table__head {
	background: var(--ink); color: var(--bg-paper);
	font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 700;
	border-bottom: 0;
}
.m-t-table__row:last-child { border-bottom: 0; }
.m-t-table__row:nth-child(even) { background: var(--bg-paper-2); }
.m-t-place {
	display: inline-grid; place-items: center;
	width: 44px; height: 44px;
	background: var(--cat-turniry); color: var(--bg-paper);
	font-weight: 900; font-size: 1.125rem;
	transform: rotate(-3deg);
}
.m-t-place--1 { background: #C9A227; color: var(--ink); }
.m-t-place--2 { background: #B8B8B8; color: var(--ink); }
.m-t-place--3 { background: #A0522D; color: var(--bg-paper); }
.m-t-row__name { font-weight: 700; }
@media (max-width: 600px) {
	.m-t-table__head, .m-t-table__row { grid-template-columns: 60px 1fr; padding-inline: 14px; }
	.m-t-place { width: 38px; height: 38px; font-size: 1rem; }
	.m-t-group__head { gap: 4px 14px; }
}

/* блок пов'язаної статті (фотозвіт, репортаж) */
.m-related {
	max-width: 960px; margin: 0 auto;
	padding-bottom: clamp(48px, 6vw, 88px);
}
.m-related__link {
	display: grid; grid-template-columns: 260px 1fr;
	border: 2px solid var(--ink); background: var(--bg-paper);
	text-decoration: none; color: var(--ink);
	box-shadow: var(--shadow-press-2);
	transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.m-related__link--plain { grid-template-columns: 1fr; }
.m-related__link:hover,
.m-related__link:focus-visible {
	transform: translate(-3px, -3px);
	box-shadow: 7px 7px 0 0 var(--ink);
}
.m-related__media { overflow: hidden; border-right: 2px solid var(--ink); }
.m-related__media img { width: 100%; height: 100%; min-height: 180px; object-fit: cover; display: block; }
.m-related__body { padding: clamp(20px, 3vw, 34px); display: flex; flex-direction: column; gap: 10px; }
.m-related__kicker {
	display: inline-flex; align-items: center; gap: 9px;
	font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 700;
	color: var(--cat, var(--green));
}
.m-related__kicker::before { content: ""; width: 24px; height: 3px; background: currentColor; }
.m-related__title { font-size: clamp(1.3rem, 2.4vw, 1.8rem); line-height: 1.2; font-weight: 800; }
.m-related__excerpt { color: var(--ink-muted); font-size: var(--fs-sm); line-height: 1.6; }
.m-related__cta {
	margin-top: auto; align-self: flex-start; font-weight: 800;
	border-bottom: 4px solid var(--cat, var(--green)); padding-bottom: 2px;
}
@media (max-width: 640px) {
	.m-related__link { grid-template-columns: 1fr; }
	.m-related__media { border-right: 0; border-bottom: 2px solid var(--ink); }
	.m-related__media img { aspect-ratio: 16 / 9; min-height: 0; }
}

/* ============================================================
   CTA
   ============================================================ */
.m-cta {
	background: var(--bg-dark); color: var(--bg-paper);
	padding-block: clamp(64px, 8vw, 120px);
	position: relative; overflow: hidden;
	text-align: center;
}
.m-cta__inner { max-width: 720px; margin: 0 auto; position: relative; z-index: 1; }
.m-cta__title { font-size: var(--fs-h1); margin-bottom: 20px; }
.m-cta__title em { font-style: normal; color: var(--sun); }
.m-cta__lede { color: rgba(246, 239, 226, 0.75); font-size: 1.0625rem; margin-bottom: 32px; }
.m-btn {
	display: inline-flex; align-items: center; gap: 12px;
	padding: 16px 32px;
	background: var(--accent); color: var(--ink);
	border: 2px solid var(--ink);
	box-shadow: var(--shadow-press-2);
	font-weight: 800; font-size: 1rem; letter-spacing: 0.04em;
	text-transform: uppercase;
	transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.m-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 0 var(--ink); }
.m-btn:active { transform: translateY(4px); box-shadow: 0 0 0 0 var(--ink); }
.m-btn--ghost {
	background: transparent; color: var(--bg-paper); border-color: var(--bg-paper);
	box-shadow: 0 4px 0 0 var(--accent);
}
.m-btn--ghost:hover { box-shadow: 0 6px 0 0 var(--accent); }

/* ============================================================
   Footer
   ============================================================ */
.m-footer {
	background: var(--bg-dark); color: rgba(244, 238, 221, 0.78);
	padding-top: 64px; padding-bottom: 28px;
	position: relative;
}
.m-footer::before {
	content: ""; position: absolute; left: 0; right: 0; top: 0; height: 7px;
	background: linear-gradient(90deg, var(--green) 0 33.33%, var(--sky) 33.33% 66.66%, var(--sun) 66.66% 100%);
}
.m-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: 40px;
	padding-bottom: 56px;
}
.m-footer h4 {
	color: var(--bg-paper); font-size: var(--fs-sm);
	letter-spacing: 0.16em; text-transform: uppercase;
	margin-bottom: 16px;
}
.m-footer__brand p { font-size: var(--fs-sm); max-width: 36ch; }
.m-footer__list li { margin-bottom: 8px; }
.m-footer__list a { font-size: var(--fs-sm); transition: color .2s var(--ease); }
.m-footer__list a:hover { color: var(--accent); }
.m-footer__bottom {
	border-top: 1px solid rgba(246, 239, 226, 0.1);
	padding-top: 24px;
	display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
	font-size: var(--fs-xs); color: rgba(246, 239, 226, 0.5);
}
@media (max-width: 720px) { .m-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .m-footer__grid { grid-template-columns: 1fr; } }

/* ============================================================
   Search / 404 / empty
   ============================================================ */
.m-empty {
	text-align: center;
	padding-block: clamp(80px, 12vw, 160px);
}
.m-empty__num {
	font-size: clamp(6rem, 18vw, 14rem);
	font-weight: 900; line-height: .9;
	color: var(--cat-novyny);
	letter-spacing: -0.06em;
	transform: rotate(-2deg);
	display: inline-block;
	margin-bottom: 24px;
}
.m-empty__title { font-size: var(--fs-h1); margin-bottom: 16px; }
.m-empty__lede { color: var(--ink-muted); max-width: 48ch; margin: 0 auto 28px; }

.m-search-form {
	display: flex; gap: 0;
	max-width: 480px; margin: 0 auto;
	border: 2px solid var(--ink);
	background: var(--bg-paper);
}
.m-search-form input[type="search"] {
	flex: 1; padding: 14px 18px;
	border: 0; background: transparent;
	font: inherit; color: var(--ink);
	outline: none;
}
.m-search-form button {
	background: var(--ink); color: var(--accent);
	border: 0; padding: 0 22px;
	font-weight: 800; letter-spacing: 0.04em;
}
.m-search-form button:hover { background: var(--accent); color: var(--ink); }

/* ============================================================
   Misc
   ============================================================ */
::selection { background: var(--accent); color: var(--ink); }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) {
	* { transition: none !important; animation: none !important; }
}

/* ============================================================
   Lightbox (фото та галереї у статтях)
   ============================================================ */
.m-post-body img { cursor: zoom-in; }
.m-post-body a > img { cursor: pointer; }
body.m-lightbox-open { overflow: hidden; }

.m-lightbox {
	position: fixed; inset: 0; z-index: 9999;
	display: flex; align-items: center; justify-content: center;
	padding: clamp(14px, 4vw, 56px);
	background: rgba(14, 46, 28, 0.94);
	opacity: 0; visibility: hidden;
	transition: opacity .25s var(--ease), visibility .25s var(--ease);
}
.m-lightbox.is-open { opacity: 1; visibility: visible; }
.m-lightbox__stage {
	position: relative;
	display: flex; flex-direction: column; align-items: center; gap: 14px;
	max-width: 100%; max-height: 100%;
}
.m-lightbox__img {
	max-width: 100%;
	max-height: calc(100vh - clamp(110px, 18vh, 200px));
	width: auto; height: auto;
	border: 3px solid var(--bg-paper);
	background: var(--bg-paper);
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
	object-fit: contain;
}
.m-lightbox__caption {
	margin: 0;
	color: var(--bg-paper);
	font-size: var(--fs-sm); line-height: 1.55; text-align: center;
	max-width: 64ch;
}
.m-lightbox__btn,
.m-lightbox__close {
	position: absolute;
	display: flex; align-items: center; justify-content: center;
	border: 2px solid var(--bg-paper);
	background: rgba(20, 61, 38, 0.6);
	color: var(--bg-paper);
	line-height: 1; font-weight: 700;
	cursor: pointer; user-select: none;
	transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.m-lightbox__btn {
	top: 50%; transform: translateY(-50%);
	width: 52px; height: 52px; font-size: 28px;
}
.m-lightbox__btn:hover { background: var(--accent); color: var(--ink); border-color: var(--accent); }
.m-lightbox__btn--prev { left: clamp(8px, 2.5vw, 28px); }
.m-lightbox__btn--next { right: clamp(8px, 2.5vw, 28px); }
.m-lightbox__close {
	top: clamp(10px, 2.5vw, 24px); right: clamp(10px, 2.5vw, 24px);
	width: 46px; height: 46px; font-size: 22px;
}
.m-lightbox__close:hover { background: var(--clay); color: var(--bg-paper); border-color: var(--clay); }
.m-lightbox__count {
	position: absolute; top: clamp(12px, 2.5vw, 26px); left: clamp(12px, 2.5vw, 26px);
	color: rgba(246, 239, 226, 0.7);
	font-size: var(--fs-xs); letter-spacing: 0.05em;
}
@media (max-width: 600px) {
	.m-lightbox__btn { width: 40px; height: 40px; font-size: 22px; }
	.m-lightbox__btn--prev { left: 6px; }
	.m-lightbox__btn--next { right: 6px; }
}
