/* --- Типографика и иерархия --- */
body.single .wp-block-post-title,
body.single-post .wp-block-post-title {
	font-size: clamp(1.25rem, 1rem + 1vw, 1.6em);
	font-weight: 700;
	line-height: 1.35;
	white-space: normal;
}

.wp-block-post-content h2 {
	font-size: 1.15em;
	font-weight: 700;
	margin-top: 1.5em;
}

.wp-block-post-content h3 {
	font-size: 1.05em;
	font-weight: 700;
}

body.home .wp-block-query .wp-block-post-title a,
body.blog .wp-block-query .wp-block-post-title a,
body.home .wp-block-query .wp-block-post-title,
body.blog .wp-block-query .wp-block-post-title {
	white-space: normal;
	word-break: break-word;
}

body.home .wp-block-post-content,
body.single .wp-block-post-content {
	line-height: 1.75;
}

/* --- Шапка: поиск --- */
.itb-header-search .wp-block-search__inside-wrapper {
	border: 2px solid var(--wp--preset--color--midtone, #333366);
	max-width: 14rem;
}

.itb-header-search .wp-block-search__input {
	background: transparent;
	color: inherit;
	font-family: inherit;
	font-size: 0.875em;
	padding: 0.35em 0.6em;
}

.itb-header-search .wp-block-search__button {
	background: var(--wp--preset--color--contrast, #c7c7ff);
	color: var(--wp--preset--color--base, #0f0f23);
	border: 0;
	font-size: 0.875em;
	padding: 0.35em 0.75em;
}

/* --- Главная: рубрики, популярное, карточки записей --- */
.itb-home-categories,
.itb-home-popular {
	margin: 0 0 2em;
	padding: 1em 0;
	border-top: 1px solid var(--wp--preset--color--midtone, #333366);
	border-bottom: 1px solid var(--wp--preset--color--midtone, #333366);
}

.itb-home-categories__title,
.itb-home-popular__title {
	font-size: 0.9em;
	margin: 0 0 0.75em;
	opacity: 0.75;
}

.itb-home-categories__title::before {
	content: "$ ls categories/\A";
	white-space: pre;
	opacity: 0.55;
}

.itb-home-popular__title::before {
	content: "$ tail -n 5 popular.log\A";
	white-space: pre;
	opacity: 0.55;
}

.itb-home-categories ul,
.itb-home-popular ol {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em 1.25em;
}

.itb-home-categories a,
.itb-home-popular a {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.itb-home-categories .count {
	opacity: 0.65;
	font-size: 0.85em;
}

.itb-home-popular ol {
	flex-direction: column;
	gap: 0.35em;
}

.itb-home-popular li::before {
	content: "> ";
	opacity: 0.5;
}

body.home .wp-block-query .wp-block-post-template > li,
body.blog .wp-block-query .wp-block-post-template > li,
body.home .wp-block-query .wp-block-post-template > .wp-block-post,
body.blog .wp-block-query .wp-block-post-template > .wp-block-post {
	border-bottom: 1px solid var(--wp--preset--color--midtone, #333366);
	padding-bottom: 1.75em;
	margin-bottom: 1.75em;
}

body.home .wp-block-query .wp-block-post-template > *:last-child,
body.blog .wp-block-query .wp-block-post-template > *:last-child {
	border-bottom: 0;
	margin-bottom: 0;
	padding-bottom: 0;
}

.itb-post-card {
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 0.75em 1.25em;
	align-items: start;
}

.itb-post-card--no-thumb {
	grid-template-columns: 1fr;
}

.itb-post-thumb {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border: 2px solid var(--wp--preset--color--midtone, #333366);
}

.itb-post-card__body .wp-block-post-title {
	margin: 0 0 0.25em;
}

.itb-post-meta-line {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25em 0.5em;
	font-size: 0.85em;
	opacity: 0.8;
	margin-bottom: 0.35em;
}

.itb-post-excerpt {
	margin: 0.35em 0 0;
	font-size: 0.9em;
	line-height: 1.5;
	opacity: 0.82;
	max-width: 65ch;
}

/* --- Статья: мета, крошки, похожие --- */
.itb-breadcrumbs {
	margin: 0 0 1em;
	font-size: 0.875em;
	opacity: 0.85;
}

.itb-breadcrumbs::before {
	content: "pwd: ";
	opacity: 0.55;
}

.itb-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35em 0.5em;
	list-style: none;
	margin: 0;
	padding: 0;
}

.itb-breadcrumbs li:not(:last-child)::after {
	content: "›";
	margin: 0 0.5em;
	opacity: 0.6;
}

.itb-breadcrumbs a {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.itb-post-meta-line .itb-reading-time,
.itb-post-meta-line .itb-views {
	opacity: 0.85;
}

.itb-related-posts {
	margin-top: var(--wp--preset--spacing--60, 2em);
	padding-top: var(--wp--preset--spacing--50, 1.5em);
	border-top: 1px solid var(--wp--preset--color--midtone, #333366);
}

.itb-related-posts__title {
	font-size: 1em;
	margin: 0 0 0.75em;
}

.itb-related-posts__title::before {
	content: "> ls related/\A";
	white-space: pre;
	display: block;
	font-size: 0.85em;
	opacity: 0.55;
	margin-bottom: 0.35em;
}

.itb-related-posts ol {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: itb-related;
}

.itb-related-posts li {
	margin: 0.4em 0;
	counter-increment: itb-related;
}

.itb-related-posts li::before {
	content: counter( itb-related, decimal-leading-zero ) ". ";
	opacity: 0.55;
}

.itb-related-posts a {
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* --- Кнопка «Наверх» (h4x0r / theme.json) --- */
.itb-back-to-top {
	--itb-top-size: 2.75rem;
	position: fixed;
	left: 1ch;
	right: auto;
	bottom: 1.5em;
	z-index: 1000001;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--itb-top-size);
	height: var(--itb-top-size);
	padding: 0;
	border: 2px solid var(--wp--preset--color--primary, #ff3cff);
	background: var(--wp--preset--color--contrast, #161618);
	color: var(--wp--preset--color--accent, #00ffcc);
	font-family: inherit;
	line-height: 1;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translate( 0.5ch, 0.5ch );
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease, background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
	box-shadow: 0.5ch 0.5ch 0 var(--wp--preset--color--midtone, #333366);
}

.itb-back-to-top__icon {
	display: flex;
	align-items: center;
	justify-content: center;
}

.itb-back-to-top__icon svg {
	display: block;
}

.itb-back-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translate( 0, 0 );
}

.itb-back-to-top:hover,
.itb-back-to-top:focus-visible {
	background: var(--wp--preset--color--primary, #ff3cff);
	border-color: var(--wp--preset--color--accent, #00ffcc);
	color: var(--wp--preset--color--base, #0f0f23);
	outline: none;
	box-shadow: 0.5ch 0.5ch 0 var(--wp--preset--color--accent, #00ffcc);
}

.itb-back-to-top:active {
	transform: translate( 0.25ch, 0.25ch );
	box-shadow: 0.25ch 0.25ch 0 var(--wp--preset--color--midtone, #333366);
}

body:has( #itb-cn-banner.itb-cn-banner--bottom:not( .itb-cn-banner--hide ) ) .itb-back-to-top {
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none;
}

/* reCAPTCHA v3 (CF7) — правый нижний угол; кнопка «наверх» слева */
.grecaptcha-badge {
	z-index: 1000000 !important;
}

/* --- 404 --- */
body.error404 .wp-block-heading:first-of-type::before {
	content: "bash: page: command not found\A";
	white-space: pre;
	display: block;
	font-size: 0.75em;
	opacity: 0.55;
	margin-bottom: 0.5em;
}

/* --- Мобильная --- */
@media (max-width: 600px) {
	.itb-header-search .wp-block-search__inside-wrapper {
		max-width: 100%;
		width: 100%;
	}

	.itb-post-card {
		grid-template-columns: 56px 1fr;
	}

	.itb-post-thumb {
		width: 56px;
		height: 56px;
	}

	.itb-back-to-top {
		--itb-top-size: 2.5rem;
		left: 0.75em;
		bottom: 1.25em;
	}

	body:has( #itb-cn-banner.itb-cn-banner--bottom:not( .itb-cn-banner--hide ) ) .itb-back-to-top {
		opacity: 0 !important;
		visibility: hidden !important;
		pointer-events: none;
	}
}

body.home .wp-block-post-template .wp-block-group.is-horizontal,
body.blog .wp-block-post-template .wp-block-group.is-horizontal {
	flex-direction: column;
	align-items: stretch;
	flex-wrap: wrap;
}

body.home .wp-block-post-template .itb-post-card,
body.blog .wp-block-post-template .itb-post-card {
	width: 100%;
}

/* --- TOC, код, FAQ, навигация --- */
.itb-toc {
	margin: 0 0 1.5em;
	padding: 1em;
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	font-size: 0.9em;
}

.itb-toc__title::before {
	content: "# tree -L 2\A";
	white-space: pre;
	opacity: 0.55;
	display: block;
	margin-bottom: 0.35em;
}

.itb-toc ol {
	margin: 0.5em 0 0;
	padding-left: 1.25em;
}

.itb-toc__level-3 {
	margin-left: 0.75em;
}

/* --- Прогресс чтения --- */
.itb-read-progress {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	z-index: 1000002;
	pointer-events: none;
	background: transparent;
}

.itb-read-progress__bar {
	display: block;
	height: 100%;
	width: 0;
	background: var(--wp--preset--color--accent, #00ffcc);
	box-shadow: 0 0 10px var(--wp--preset--color--primary, #ff3cff);
	transition: width 0.1s linear;
}

/* --- Чипы рубрик / тегов --- */
.itb-chip,
.itb-home-categories a.itb-chip {
	display: inline-block;
	padding: 0.2em 0.65em;
	margin: 0.15em 0.35em 0.15em 0;
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	background: var(--wp--preset--color--contrast, #161618);
	color: var(--wp--preset--color--accent, #00ffcc);
	text-decoration: none;
	font-size: 0.85em;
	line-height: 1.4;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.itb-chip:hover,
.itb-chip:focus-visible {
	background: var(--wp--preset--color--primary, #ff3cff);
	border-color: var(--wp--preset--color--accent, #00ffcc);
	color: var(--wp--preset--color--base, #0f0f23);
	outline: none;
	text-decoration: none;
}

.itb-term-chips {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35em;
	margin: 0.5em 0;
}

.itb-term-chips .wp-block-post-terms__prefix {
	margin-right: 0.25em;
	opacity: 0.75;
	font-size: 0.9em;
}

.itb-home-categories ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35em;
	list-style: none;
	padding: 0;
	margin: 0;
}

.itb-home-categories li {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* --- Шапка: бренд (логотип + слоган) | RSS; на десктопе слоган по центру --- */
.itb-header-top,
header .itb-header-top {
	display: flex !important;
	flex-wrap: nowrap;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0.75rem 1.25rem;
	width: 100%;
	box-sizing: border-box;
}

.itb-header-top > *,
.itb-header-brand > *,
header .itb-header-top.is-layout-flow > *,
header .itb-header-brand.is-layout-flow > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

.itb-header-brand,
header .itb-header-brand {
	flex: 1 1 auto;
	min-width: 0;
	display: block;
}

.itb-header-top .wp-block-site-title {
	margin: 0;
	line-height: 1.2;
}

.itb-header-top .wp-block-site-title a {
	display: inline-block;
	line-height: 1.2;
	padding: 0.15em 0.3em;
	border: 1px solid transparent;
	box-sizing: border-box;
}

.itb-header-tagline,
header .itb-header-tagline.wp-block-site-tagline {
	margin: 0.2em 0 0;
	padding: 0;
	text-align: left;
	opacity: 0.85;
	white-space: normal;
	line-height: 1.35;
	font-size: clamp(0.75rem, 2.5vw, 0.875rem);
}

.itb-header-top .itb-header-top-actions,
.itb-header-top-actions {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	gap: 1em;
	padding-top: 0.2em;
}

.itb-header-nav {
	width: 100%;
	margin-top: 0.5rem !important;
}

/* Бургер — справа (удобнее правой рукой на телефоне) */
@media (max-width: 781px) {
	header .itb-header-nav,
	.itb-header-nav {
		display: flex !important;
		justify-content: flex-end !important;
		align-items: center;
	}

	header .itb-header-nav .wp-block-navigation,
	.itb-header-nav .wp-block-navigation {
		margin-inline-start: auto;
	}
}

.itb-header-top-actions .itb-theme-switcher,
header .itb-theme-switcher,
.wp-block-navigation .itb-theme-switcher {
	display: none !important;
}

header .wp-block-group.is-content-justification-space-between {
	align-items: center;
}

@media (min-width: 782px) {
	.itb-header-top,
	header .itb-header-top {
		display: grid !important;
		grid-template-columns: auto 1fr auto;
		align-items: center;
		gap: 0.75rem 1.5rem;
	}

	.itb-header-brand,
	header .itb-header-brand {
		display: contents;
	}

	.itb-header-top .wp-block-site-title {
		grid-column: 1;
		grid-row: 1;
	}

	.itb-header-tagline,
	header .itb-header-tagline.wp-block-site-tagline {
		grid-column: 2;
		grid-row: 1;
		margin: 0;
		text-align: center;
		white-space: nowrap;
	}

	.itb-header-top .itb-header-top-actions,
	.itb-header-top-actions {
		grid-column: 3;
		grid-row: 1;
		padding-top: 0;
	}
}

/* Главная: длинные заголовки в ленте не раздувают страницу по ширине (ломает fixed-баннер cookie) */
body.home,
body.home .wp-site-blocks {
	overflow-x: clip;
}

body.home .wp-block-post-title.nowrap,
body.home .nowrap.wp-block-post-title {
	white-space: normal !important;
	word-break: break-word;
}

@media (max-width: 781px) {
	body.home .wp-block-group.is-horizontal.is-nowrap {
		flex-wrap: wrap !important;
	}
}

/* Стрелки dropdown в меню не показываем */
header nav.wp-block-navigation .wp-block-navigation__submenu-icon,
header nav.wp-block-navigation button.wp-block-navigation-submenu__toggle.wp-block-navigation__submenu-icon {
	display: none !important;
}

/* --- Переключатель палитры (футер) --- */
.itb-footer-theme {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 100%;
	max-width: var(--wp--style--global--wide-size, 100%);
	margin: 0 auto;
	padding: 0.75em 0 0.25em;
	box-sizing: border-box;
}

.itb-theme-switcher {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	font-size: 0.8em;
}

.itb-theme-switcher-slot,
.wp-block-navigation .itb-theme-switcher-slot {
	display: none !important;
}

@media (max-width: 600px) {
	.itb-footer-theme {
		justify-content: flex-start;
	}

	.itb-theme-switcher {
		font-size: 0.75em;
		width: 100%;
	}

	.itb-theme-switcher__select {
		flex: 1;
		max-width: 100%;
	}
}

.itb-theme-switcher__prompt {
	opacity: 0.65;
	white-space: nowrap;
}

.itb-theme-switcher__select {
	max-width: 9rem;
	padding: 0.3em 0.5em;
	border: 2px solid var(--wp--preset--color--midtone, #333366);
	background: var(--wp--preset--color--base, #0f0f23);
	color: var(--wp--preset--color--contrast, #c7c7ff);
	font-family: inherit;
	font-size: 0.9em;
	cursor: pointer;
}

.itb-theme-switcher__select:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #00ffcc);
	outline-offset: 2px;
}

/* --- Плейсхолдер миниатюры --- */
.itb-post-thumb--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	border: 1px dashed var(--wp--preset--color--midtone, #333366);
	font-size: 0.55em;
	opacity: 0.55;
	text-align: center;
	line-height: 1.2;
}

/* --- Блоки кода (терминал) --- */
.itb-code-wrap {
	position: relative;
	margin: 1.25em 0;
	border: 2px solid var(--wp--preset--color--midtone, #333366);
	box-shadow: 0.5ch 0.5ch 0 var(--wp--preset--color--midtone, #333366);
}

.itb-code-titlebar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5em;
	padding: 0.35em 0.65em;
	border-bottom: 1px solid var(--wp--preset--color--midtone, #333366);
	background: var(--wp--preset--color--contrast, #161618);
	color: var(--wp--preset--color--accent, #00ffcc);
	font-size: 0.75em;
}

.itb-code-titlebar__path::before {
	content: "# ";
	opacity: 0.5;
}

.itb-code-wrap pre {
	overflow-x: auto;
	margin: 0;
	padding: 0.75em 1ch;
	border: 0;
	background: var(--wp--preset--color--base, #0f0f23);
}

.itb-code-copy {
	flex-shrink: 0;
	padding: 0.15em 0.55em;
	font-size: 0.95em;
	font-family: inherit;
	cursor: pointer;
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	background: var(--wp--preset--color--base, #0f0f23);
	color: var(--wp--preset--color--accent, #00ffcc);
}

.itb-code-copy:hover,
.itb-code-copy:focus-visible {
	background: var(--wp--preset--color--primary, #ff3cff);
	color: var(--wp--preset--color--base, #0f0f23);
	outline: none;
}

/* --- CRT слабее на мобиле --- */
@media (max-width: 600px) {
	.wp-site-blocks::before {
		opacity: 0.12 !important;
		background-size: 100% 3px, 2px 100% !important;
	}

	.wp-site-blocks::after {
		opacity: 0 !important;
	}
}

.itb-faq,
.itb-see-also,
.itb-post-nav,
.itb-stale-notice {
	margin-top: 2em;
	padding-top: 1.25em;
	border-top: 1px solid var(--wp--preset--color--midtone, #333366);
}

.itb-stale-notice {
	border: 1px solid var(--wp--preset--color--accent, #00ffcc);
	padding: 0.75em 1em;
	margin-top: 0;
	margin-bottom: 1.5em;
}

.itb-faq__item {
	margin: 0.5em 0;
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	padding: 0.35em 0.75em;
}

.itb-faq__item summary {
	cursor: pointer;
}

.itb-post-nav {
	display: grid;
	gap: 0.75em;
}

.itb-post-nav__label {
	opacity: 0.7;
	display: block;
	font-size: 0.85em;
}

.itb-archive-desc {
	margin: 0 0 1.5em;
	opacity: 0.9;
	max-width: 65ch;
}

.itb-rss-link {
	display: inline-block;
	font-size: 0.85em;
	line-height: 1.2;
	padding: 0.15em 0.3em;
	border: 1px solid transparent;
	box-sizing: border-box;
	opacity: 0.8;
}

/* Hover темы h4x0r (line-height: initial) дёргает высоту шапки */
.wp-site-blocks header.wp-block-template-part .itb-header-top a:hover,
.wp-site-blocks header.wp-block-template-part .itb-header-top a:focus-visible {
	line-height: 1.2 !important;
	outline: none !important;
	text-decoration: none !important;
}

/* Подвал: сайт — TG/MAX — WordPress */
.itb-footer-credits {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem 1.5rem;
	width: 100%;
	font-size: 1rem;
	line-height: 1.5;
}

.itb-footer-credits .has-small-font-size,
.itb-footer-credits .wp-block-site-title,
.itb-footer-credits .wp-block-site-title a {
	font-size: inherit !important;
	line-height: inherit;
}

.itb-footer-credits > .wp-block-group:first-child {
	flex: 0 1 auto;
}

.itb-footer-messengers,
.itb-footer-telegram {
	flex: 1 1 8rem;
	margin: 0;
	text-align: center;
	font-size: 1rem;
	font-weight: 500;
}

.itb-footer-messengers a + a {
	margin-left: 0.75em;
}

.itb-footer-credits > .itb-footer-messengers + p,
.itb-footer-credits > .itb-footer-telegram + p,
.itb-footer-credits > p.has-small-font-size:last-child {
	flex: 0 1 auto;
	margin: 0;
	text-align: right;
}

@media (max-width: 520px) {
	.itb-footer-credits {
		flex-direction: column;
		align-items: stretch;
	}

	.itb-footer-messengers,
	.itb-footer-telegram,
	.itb-footer-credits > p.has-small-font-size:last-child {
		text-align: center;
	}
}

.itb-updated {
	opacity: 0.75;
}

/* QR Telegram на /kontakty/ */
.itb-tg-qr {
	margin: 2em auto 0;
	max-width: 16rem;
	text-align: center;
}

.itb-tg-qr__img {
	margin: 0 auto;
}

.itb-tg-qr__img img {
	width: 100%;
	height: auto;
	border-radius: 4px;
}

.itb-tg-qr__caption {
	margin-top: 0.75em;
	font-size: 0.95em;
	opacity: 0.9;
}

/* --- Фокус для клавиатуры --- */
.wp-site-blocks a:focus-visible,
.wp-block-post-content a:focus-visible,
.itb-toc a:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent, #00ffcc);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.itb-back-to-top,
	.itb-read-progress__bar {
		transition: none;
	}
}

/* --- Лендинги услуг --- */
.itb-svc-hero {
	margin-bottom: var(--wp--preset--spacing--50, 1.5em);
	padding-bottom: var(--wp--preset--spacing--40, 1em);
	border-bottom: 1px solid var(--wp--preset--color--midtone, #333366);
}

/* Согласие на обработку ПД в форме заявки */
.itb-pd-consent {
	margin-top: 0.5em;
}

.itb-pd-consent .omniform-field-label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.itb-pd-consent legend {
	font-size: 0.9em;
	margin-bottom: 0.35em;
}

.itb-pd-consent__field.wp-block-omniform-field {
	align-items: flex-start;
	gap: 0.5em;
}

.itb-pd-consent__field .wp-block-omniform-label {
	font-size: 0.9em;
	line-height: 1.45;
	font-weight: 400;
}

.itb-pd-consent__field .wp-block-omniform-input[type="checkbox"] {
	flex-shrink: 0;
	margin-top: 0.2em;
}

.itb-svc-hero__lead {
	font-size: 1.05em;
	line-height: 1.65;
	max-width: 65ch;
}

.itb-svc-stack {
	margin-top: 0.75em;
	opacity: 0.85;
}

.itb-svc-stack code {
	font-size: 0.9em;
	word-break: break-word;
}

.itb-svc-cards .itb-svc-card {
	height: 100%;
}

.itb-svc-card h2 {
	font-size: 1.15em;
	margin-top: 0;
}

/* Хаб /uslugi/: строки направлений вместо узких колонок */
.itb-svc-hub-list {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--40, 1rem);
	margin-bottom: var(--wp--preset--spacing--50, 1.5em);
}

.itb-svc-hub-row {
	display: grid;
	grid-template-columns: minmax(10.5rem, max-content) minmax(0, 1fr) auto;
	align-items: center;
	column-gap: var(--wp--preset--spacing--50, 1.5rem);
	row-gap: 0.75rem;
}

.itb-svc-hub-row__title,
.itb-svc-hub-row > .wp-block-heading {
	margin: 0;
	font-size: 1.1em;
	line-height: 1.35;
	text-wrap: balance;
}

.itb-svc-hub-row__text,
.itb-svc-hub-row > p {
	margin: 0;
	max-width: none;
	line-height: 1.55;
}

.itb-svc-hub-row__action,
.itb-svc-hub-row > .wp-block-buttons {
	margin: 0;
}

.itb-svc-hub-row__action .wp-block-button__link,
.itb-svc-hub-row > .wp-block-buttons .wp-block-button__link {
	white-space: nowrap;
}

@media (max-width: 782px) {
	.itb-svc-hub-row {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.itb-svc-hub-row__action,
	.itb-svc-hub-row > .wp-block-buttons {
		justify-self: start;
	}
}

.itb-home-svc-actions {
	margin: 0 0 var(--wp--preset--spacing--50, 1.5em);
	gap: 0.5em;
}

.itb-svc-grid {
	margin: 1em 0 1.5em;
}

.itb-svc-steps {
	max-width: 55ch;
}

.wp-block-post-content .itb-svc-cta,
.itb-svc-cta {
	margin-top: var(--wp--preset--spacing--60, 2em);
	padding: var(--wp--preset--spacing--50, 1.5em) !important;
	border: 1px solid var(--wp--preset--color--midtone, #333366) !important;
	background-color: var(--wp--preset--color--base, #0f0f23) !important;
	color: var(--wp--preset--color--contrast, #c7c7ff) !important;
}

.wp-block-post-content .itb-svc-cta :is( h2, h3, p, .wp-block-heading, .wp-block-paragraph ),
.itb-svc-cta :is( h2, h3, p, .wp-block-heading, .wp-block-paragraph ) {
	color: var(--wp--preset--color--contrast, #c7c7ff) !important;
	opacity: 1 !important;
}

.itb-svc-cta h2,
.itb-svc-cta .wp-block-heading {
	margin-top: 0;
	font-size: 1.1em;
}

.itb-svc-cta p {
	margin-bottom: 1em;
}

.itb-svc-cta .wp-block-buttons {
	flex-wrap: wrap;
	gap: 0.5em;
}

.itb-service-page .wp-block-post-title {
	text-wrap: balance;
}

.itb-faq {
	margin-top: var(--wp--preset--spacing--60, 2em);
	padding-top: var(--wp--preset--spacing--50, 1.5em);
	border-top: 1px solid var(--wp--preset--color--midtone, #333366);
}

.itb-faq__title {
	font-size: 1.1em;
	margin: 0 0 1em;
}

.itb-faq__item {
	margin: 0.5em 0;
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	padding: 0.35em 0.75em;
}

.itb-faq__item summary {
	cursor: pointer;
	font-weight: 600;
}

.itb-faq__answer {
	margin: 0.5em 0 0.25em;
	opacity: 0.92;
}

/* --- CTA в конце записи --- */
.itb-post-cta {
	margin-top: var(--wp--preset--spacing--60, 2em);
	padding: var(--wp--preset--spacing--50, 1.5em);
	border: 1px solid var(--wp--preset--color--midtone, #333366);
	background-color: var(--wp--preset--color--base, #0f0f23) !important;
	color: var(--wp--preset--color--contrast, #c7c7ff) !important;
}

.itb-post-cta__title {
	margin: 0 0 0.5em;
	font-size: 1.1em;
	color: inherit;
}

.itb-post-cta__title::before {
	content: "> ./discuss-project\A";
	white-space: pre;
	display: block;
	font-size: 0.85em;
	opacity: 0.55;
	margin-bottom: 0.35em;
}

.itb-post-cta__text {
	margin: 0 0 1em;
	max-width: 60ch;
	color: inherit;
	opacity: 0.95;
}

.itb-post-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em 1em;
	align-items: center;
}

.itb-post-cta__actions .itb-cta-discuss {
	display: inline-block;
	padding: 0.35em 1em;
	border: 2px solid var(--wp--preset--color--contrast, #161618);
	background: var(--wp--preset--color--contrast, #161618);
	color: var(--wp--preset--color--base, #fff);
	text-decoration: none;
}

.itb-post-cta__link {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.itb-post-cta__link--tg {
	opacity: 0.9;
}

/* --- Кейсы (pattern case-study-row) --- */
.itb-case-row__title::before {
	content: "> cat cases/*.md\A";
	white-space: pre;
	display: block;
	font-size: 0.85em;
	opacity: 0.55;
	margin-bottom: 0.35em;
}

.itb-case-card .wp-block-post-title {
	font-size: 1.05em;
	margin: 0 0 0.35em;
}

.itb-case-card .wp-block-post-excerpt {
	margin: 0;
	opacity: 0.9;
}
