/**
 * Winzardy — фронтовый CSS.
 *
 * Только то, что нельзя выразить в theme.json: оформление кастомных
 * стилей блоков (block styles) и мелкие штрихи. Палитра/типографика —
 * в theme.json (CSS-переменные --wp--preset--*).
 *
 * @package Winzardy
 */

/* Контурная кнопка */
.wp-block-button.is-style-winzardy-ghost .wp-block-button__link {
	background-color: transparent;
	color: var(--wp--preset--color--contrast);
	border: 1px solid var(--wp--preset--color--accent);
}

.wp-block-button.is-style-winzardy-ghost .wp-block-button__link:hover,
.wp-block-button.is-style-winzardy-ghost .wp-block-button__link:focus {
	background-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--contrast);
}

/* Карточка */
.is-style-winzardy-card {
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.is-style-winzardy-card:hover {
	transform: translateY(-2px);
	border-color: var(--wp--preset--color--accent) !important;
}

/* Свечение */
.is-style-winzardy-glow {
	box-shadow: var(--wp--preset--shadow--glow);
}

/* Градиентный текст заголовка */
.is-style-winzardy-gradient {
	background-image: var(--wp--preset--gradient--accent-gold);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

/* Руна — декоративный разделитель */
.wp-block-separator.is-style-winzardy-rune {
	border: 0;
	height: 1px;
	max-width: 120px;
	background: var(--wp--preset--gradient--accent-gold);
	opacity: 0.8;
}

/* Доступность: видимый фокус */
:where(a, button, input, select, textarea, .wp-block-button__link):focus-visible {
	outline: 2px solid var(--wp--preset--color--gold);
	outline-offset: 2px;
}

/* Чуть мягче рендер шрифтов на тёмном фоне */
body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

@media (prefers-reduced-motion: reduce) {
	.is-style-winzardy-card {
		transition: none;
	}
}

/* ---------------------------------------------------------------------------
 * Карусель скриншотов
 * ------------------------------------------------------------------------- */
.winzardy-carousel {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid var(--wp--preset--color--border);
	background: var(--wp--preset--color--surface-2);
	box-shadow: var(--wp--preset--shadow--soft);
}

.wz-carousel__viewport {
	overflow: hidden;
}

.wz-carousel__track {
	display: flex;
	transition: transform 0.5s cubic-bezier( 0.22, 1, 0.36, 1 );
	will-change: transform;
}

.wz-carousel__slide {
	position: relative;
	flex: 0 0 100%;
	min-width: 100%;
	aspect-ratio: 16 / 9;
	background: var(--wp--preset--color--base);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

/* Размытый фон-заливка (тот же кадр), чтобы вертикальные скрины смотрелись premium */
.wz-carousel__bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale( 1.15 );
	filter: blur( 30px ) brightness( 0.45 ) saturate( 1.15 );
	z-index: 0;
}

/* Резкий кадр по центру */
.wz-carousel__media {
	position: relative;
	z-index: 1;
	max-width: 100%;
	max-height: 100%;
	height: 100%;
	width: auto;
	object-fit: contain;
	display: block;
	border-radius: 12px;
	box-shadow: 0 10px 40px rgba( 0, 0, 0, 0.5 );
}

/* Широкие кадры (16:9) заполняют слайд целиком */
.wz-carousel__media.is-wide {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 0;
	box-shadow: none;
}

/* Подпись слайда */
.wz-carousel__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	margin: 0;
	padding: 2.5rem 1.25rem 1rem;
	font-size: 0.9rem;
	color: var(--wp--preset--color--contrast);
	background: linear-gradient( 0deg, rgba( 14, 11, 26, 0.85 ) 0%, rgba( 14, 11, 26, 0 ) 100% );
}

/* Видео-слайд */
.wz-carousel__video-mount {
	position: absolute;
	inset: 0;
	z-index: 2;
}

.wz-carousel__video,
.wz-carousel__iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
	object-fit: cover;
}

.wz-carousel__play {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	width: 100%;
	border: 0;
	cursor: pointer;
	color: var(--wp--preset--color--contrast);
	background: transparent;
	font-family: inherit;
	font-size: 1rem;
}

.wz-carousel__slide.is-playing .wz-carousel__play {
	display: none;
}

.wz-carousel__play-icon {
	display: grid;
	place-items: center;
	width: 76px;
	height: 76px;
	border-radius: 50%;
	background: var(--wp--preset--gradient--accent-gold);
	box-shadow: var(--wp--preset--shadow--glow);
	transition: transform 0.2s ease;
}

.wz-carousel__play:hover .wz-carousel__play-icon {
	transform: scale( 1.06 );
}

.wz-carousel__play-icon svg {
	width: 30px;
	height: 30px;
	margin-left: 4px;
	fill: var(--wp--preset--color--base);
}

/* Стрелки */
.wz-carousel__nav {
	position: absolute;
	top: 50%;
	transform: translateY( -50% );
	z-index: 4;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid var(--wp--preset--color--border);
	background: rgba( 14, 11, 26, 0.6 );
	color: var(--wp--preset--color--contrast);
	cursor: pointer;
	display: grid;
	place-items: center;
	backdrop-filter: blur( 6px );
	transition: background 0.2s ease;
}

.wz-carousel__nav:hover {
	background: var(--wp--preset--color--accent);
}

.wz-carousel__nav--prev { left: 0.75rem; }
.wz-carousel__nav--next { right: 0.75rem; }

.wz-carousel__nav svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

/* Точки */
.wz-carousel__dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0.85rem;
	z-index: 4;
	display: flex;
	gap: 0.5rem;
	justify-content: center;
}

.wz-carousel__dot {
	width: 9px;
	height: 9px;
	padding: 0;
	border-radius: 50%;
	border: 0;
	cursor: pointer;
	background: rgba( 236, 234, 245, 0.4 );
	transition: background 0.2s ease, transform 0.2s ease;
}

.wz-carousel__dot[aria-current="true"] {
	background: var(--wp--preset--color--gold);
	transform: scale( 1.25 );
}

@media ( prefers-reduced-motion: reduce ) {
	.wz-carousel__track { transition: none; }
}

/* ---------------------------------------------------------------------------
 * Кнопка Google Play (иконка + текст)
 * ------------------------------------------------------------------------- */
.wz-gplay__link {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
}

.wz-gplay__link svg {
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
}

.wz-gplay__sub {
	display: block;
	font-size: 0.7rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	opacity: 0.85;
	line-height: 1;
}

.wz-gplay__title {
	display: block;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.1;
}

/* Цветная иконка Google Play в кнопке */
.wz-gp-ico {
	width: 20px;
	height: 22px;
	flex: 0 0 auto;
	transition: transform 0.25s var( --wz-ease );
}
.wz-btn:hover .wz-gp-ico { transform: scale( 1.12 ); }

/* Посадочная страница проекта (page-legacy-wizard) */
.wz-home .wz-page-hero.wz-hero { min-height: auto; padding: 112px 0 56px; display: block; }
/* На внутренних страницах длинные заголовки переносятся (не режутся в одну строку) */
.wz-home .wz-page-hero h1 { max-width: none; }
.wz-home .wz-page-hero h1 .wz-magic { white-space: normal; }
.wz-back {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 0.85rem; font-weight: 600; text-decoration: none;
	color: var( --wp--preset--color--contrast-muted );
	margin-bottom: 18px; transition: color 0.25s var( --wz-ease );
}
.wz-back:hover { color: var( --wp--preset--color--gold ); }
.wz-page-note {
	margin-top: 26px; font-size: 0.92rem;
	color: var( --wp--preset--color--contrast-muted );
	border: 1px solid var( --wz-glass-brd ); border-radius: 14px;
	background: var( --wz-glass ); backdrop-filter: blur( 8px );
	padding: 14px 18px; max-width: 52ch;
}

/* ===========================================================================
 * Бестиарий: хлебные крошки, сетка разделов, мозаика волшебников, карточка героя
 * ========================================================================= */
.wz-page-body{ padding:0 0 90px; }
.wz-crumbs{ display:flex; flex-wrap:wrap; gap:8px; align-items:center; font-size:.82rem; margin-bottom:20px; color:var(--wp--preset--color--contrast-muted); }
.wz-crumbs a{ color:var(--wp--preset--color--contrast-muted); text-decoration:none; transition:color .25s; }
.wz-crumbs a:hover{ color:var(--wp--preset--color--gold); }
.wz-crumbs > span:not([aria-current]){ opacity:.4; }
.wz-crumbs span[aria-current]{ color:var(--wp--preset--color--contrast); }

/* разделы бестиария */
.wz-bgrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; }
.wz-bsec{ position:relative; display:flex; flex-direction:column; gap:10px; padding:28px; border-radius:20px;
	background:var(--wz-glass); border:1px solid var(--wz-glass-brd); backdrop-filter:blur(14px);
	text-decoration:none; color:inherit; transition:transform .3s var(--wz-ease), box-shadow .3s, border-color .3s; }
.wz-bsec__ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center;
	background:rgba(124,92,255,.16); border:1px solid var(--wz-glass-brd); color:var(--wp--preset--color--accent-soft); transition:background .3s; }
.wz-bsec__ic svg{ width:24px; height:24px; }
.wz-bsec h3{ font-family:var(--wp--preset--font-family--heading); font-size:1.3rem; margin:0; color:var(--wp--preset--color--contrast); }
.wz-bsec p{ margin:0; color:var(--wp--preset--color--contrast-muted); font-size:.93rem; line-height:1.5; }
.wz-bsec__go{ margin-top:auto; color:var(--wp--preset--color--gold); font-weight:600; font-size:.9rem; }
a.wz-bsec:hover{ transform:translateY(-4px); border-color:var(--wp--preset--color--accent-soft); box-shadow:0 18px 50px -20px rgba(124,92,255,.6); }
a.wz-bsec:hover .wz-bsec__ic{ background:rgba(124,92,255,.3); }
.wz-bsec.is-soon{ opacity:.55; }
.wz-bsec__soon{ margin-top:auto; align-self:flex-start; font-size:.76rem; font-weight:600; color:var(--wp--preset--color--contrast-muted);
	border:1px solid var(--wz-glass-brd); border-radius:30px; padding:4px 12px; }

/* мозаика волшебников */
.wz-wgrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:22px; }
.wz-wcard{ position:relative; display:flex; flex-direction:column; border-radius:22px; overflow:hidden;
	background:var(--wz-glass); border:1px solid var(--wz-glass-brd); text-decoration:none; color:inherit;
	transition:transform .3s var(--wz-ease), box-shadow .3s, border-color .3s; }
.wz-wcard__art{ position:relative; aspect-ratio:4/5; overflow:hidden; background:linear-gradient(160deg,#1c1640,#0f0b22); }
.wz-wcard__art img{ width:100%; height:100%; object-fit:cover; object-position:top center; transition:transform .5s var(--wz-ease); }
.wz-wcard__art--cut{ background:radial-gradient(circle at 50% 34%, rgba(176,76,196,.5), transparent 62%), linear-gradient(160deg,#241640,#120c26); }
.wz-wcard__art--cut img{ object-fit:contain; object-position:bottom center; }
.wz-wcard__info{ padding:18px 20px 22px; display:flex; flex-direction:column; gap:6px; }
.wz-wcard__el{ font-size:.74rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--wp--preset--color--accent-soft); }
.wz-wcard h3{ font-family:var(--wp--preset--font-family--heading); font-size:1.35rem; margin:0; color:var(--wp--preset--color--contrast); }
.wz-wcard p{ margin:0; color:var(--wp--preset--color--contrast-muted); font-size:.9rem; line-height:1.5; }
.wz-wcard__go{ margin-top:6px; color:var(--wp--preset--color--gold); font-weight:600; font-size:.88rem; }
.wz-wcard__soon{ margin-top:6px; font-size:.78rem; font-weight:600; color:var(--wp--preset--color--contrast-muted); }
a.wz-wcard:hover{ transform:translateY(-6px); border-color:var(--wp--preset--color--accent-soft); box-shadow:0 26px 60px -24px rgba(124,92,255,.7); }
a.wz-wcard:hover .wz-wcard__art img{ transform:scale(1.06); }
.wz-wcard--water:hover{ border-color:rgba(106,240,231,.6); box-shadow:0 26px 60px -22px rgba(106,240,231,.55); }
.wz-wcard.is-soon .wz-wcard__art img{ filter:saturate(.92); }

/* карточка героя */
.wz-cstack{ display:flex; flex-direction:column; gap:22px; }
.wz-chero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:34px; align-items:center; }
.wz-chero__lat{ font-family:var(--wp--preset--font-family--heading); letter-spacing:.42em; font-size:.8rem; color:var(--wp--preset--color--accent-soft); margin:-4px 0 14px; }
.wz-quote{ font-family:var(--wp--preset--font-family--heading); font-style:italic; font-size:1.25rem; line-height:1.45; color:var(--wp--preset--color--contrast); border-left:3px solid var(--wp--preset--color--gold); padding-left:16px; margin:6px 0 18px; }
.wz-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.wz-chero__art{ border-radius:24px; overflow:hidden; border:1px solid var(--wz-glass-brd); box-shadow:var(--wz-shadow);
	background:radial-gradient(circle at 60% 40%, rgba(106,240,231,.22), transparent 60%), linear-gradient(160deg,#10243a,#0c1326); }
.wz-chero__art img{ width:100%; display:block; }

.wz-csec{ padding:30px 34px; }
.wz-csec__k{ font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--wp--preset--color--gold); margin-bottom:6px; }
.wz-csec__k--sub{ margin-top:26px; }
.wz-csec__h{ font-family:var(--wp--preset--font-family--heading); font-size:clamp(1.5rem,2.6vw,2.1rem); margin:0 0 14px; color:var(--wp--preset--color--contrast); line-height:1.1; }
.wz-prose{ color:var(--wp--preset--color--contrast-muted); line-height:1.7; margin:0 0 12px; max-width:70ch; }
.wz-note{ font-size:.85rem; color:var(--wp--preset--color--contrast-muted); opacity:.85; margin-top:14px; max-width:78ch; line-height:1.55; }
.wz-cgrid2{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.wz-cgrid2--tight{ gap:16px; margin-top:18px; }

.wz-dossier{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--wz-glass-brd); border:1px solid var(--wz-glass-brd); border-radius:14px; overflow:hidden; margin:0; }
.wz-dossier > div{ background:rgba(14,11,26,.6); padding:16px 18px; }
.wz-dossier dt{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--wp--preset--color--accent-soft); margin-bottom:6px; }
.wz-dossier dd{ margin:0; color:var(--wp--preset--color--contrast); font-size:.95rem; line-height:1.4; }

.wz-shadowcall{ margin-top:18px; padding:18px 20px; border-radius:16px; color:var(--wp--preset--color--contrast-muted); line-height:1.6;
	background:rgba(124,92,255,.1); border:1px solid rgba(124,92,255,.3); border-left:3px solid var(--wp--preset--color--accent); }
.wz-shadowcall__t{ display:block; font-family:var(--wp--preset--font-family--heading); font-weight:700; color:var(--wp--preset--color--accent-soft); margin-bottom:6px; }

.wz-spell__head{ display:flex; justify-content:space-between; gap:24px; align-items:flex-start; flex-wrap:wrap; }
.wz-spell__lat{ font-family:var(--wp--preset--font-family--body); font-weight:500; font-size:1rem; color:var(--wp--preset--color--accent-soft); margin-left:8px; }
.wz-spell__stats{ display:flex; gap:10px; flex:0 0 auto; }
.wz-stat-pill{ display:flex; flex-direction:column; align-items:center; min-width:86px; padding:10px 14px; border-radius:14px;
	background:rgba(124,92,255,.12); border:1px solid var(--wz-glass-brd); font-size:.7rem; color:var(--wp--preset--color--contrast-muted); letter-spacing:.04em; text-align:center; }
.wz-stat-pill b{ font-family:var(--wp--preset--font-family--heading); font-size:1.5rem; color:var(--wp--preset--color--contrast); line-height:1; margin-bottom:3px; }
.wz-stat-pill--ice{ background:rgba(106,240,231,.12); border-color:rgba(106,240,231,.35); }
.wz-stat-pill--ice b{ color:#9af3ec; }

.wz-props{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; margin-top:6px; }
.wz-prop{ padding:16px 18px; border-radius:14px; background:rgba(14,11,26,.5); border:1px solid var(--wz-glass-brd); }
.wz-prop h4{ font-family:var(--wp--preset--font-family--heading); font-size:1rem; margin:0 0 6px; color:var(--wp--preset--color--contrast); }
.wz-prop p{ margin:0; font-size:.88rem; color:var(--wp--preset--color--contrast-muted); line-height:1.5; }
.wz-req{ display:inline-block; margin-top:8px; font-size:.73rem; color:var(--wp--preset--color--accent-soft); border:1px solid var(--wz-glass-brd); border-radius:30px; padding:3px 10px; }

.wz-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:6px; }
.wz-step{ padding:20px 18px 18px; border-radius:16px; background:rgba(106,240,231,.07); border:1px solid rgba(106,240,231,.25); }
.wz-step__n{ display:grid; place-items:center; width:34px; height:34px; border-radius:50%; background:var(--wz-grad-magic); color:#fff; font-family:var(--wp--preset--font-family--heading); font-weight:700; margin-bottom:12px; }
.wz-step h4{ font-family:var(--wp--preset--font-family--heading); margin:0 0 6px; color:var(--wp--preset--color--contrast); font-size:1.05rem; }
.wz-step p{ margin:0; font-size:.88rem; color:var(--wp--preset--color--contrast-muted); line-height:1.5; }

.wz-subcard{ padding:16px 18px; border-radius:14px; background:rgba(14,11,26,.5); border:1px solid var(--wz-glass-brd); }
.wz-subcard__k{ display:block; font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:.82rem; letter-spacing:.05em; color:var(--wp--preset--color--accent-soft); margin-bottom:6px; }
.wz-subcard p{ margin:0; color:var(--wp--preset--color--contrast-muted); font-size:.9rem; line-height:1.5; }

.wz-firesyn{ margin-top:18px; padding:18px 20px; border-radius:16px; color:var(--wp--preset--color--contrast-muted); line-height:1.6;
	background:linear-gradient(120deg, rgba(255,120,40,.12), rgba(232,80,40,.05)); border:1px solid rgba(255,120,40,.35); border-left:3px solid #ff7a2a; }
.wz-firesyn__t{ display:block; font-family:var(--wp--preset--font-family--heading); font-weight:700; color:#ffb178; margin-bottom:6px; }

.wz-swatches{ display:flex; flex-wrap:wrap; gap:16px; }
.wz-swatch{ display:flex; align-items:center; gap:10px; font-size:.85rem; color:var(--wp--preset--color--contrast-muted); }
.wz-swatch span{ width:26px; height:26px; border-radius:8px; border:1px solid rgba(255,255,255,.18); flex:0 0 auto; }
.wz-swatch b{ font-family:var(--wp--preset--font-family--mono, ui-monospace, monospace); color:var(--wp--preset--color--contrast); font-weight:600; }

.wz-emos{ display:flex; flex-wrap:wrap; gap:8px; }
.wz-emos span{ font-size:.82rem; color:var(--wp--preset--color--contrast); border:1px solid var(--wz-glass-brd); background:var(--wz-glass); border-radius:30px; padding:6px 14px; }

.wz-cback{ display:flex; justify-content:center; gap:12px; flex-wrap:wrap; margin-top:8px; }

/* Страница «Культура компании» */
.wz-culture-lead{ font-family:var(--wp--preset--font-family--heading); font-size:clamp(1.15rem,2.2vw,1.6rem); line-height:1.5;
	color:var(--wp--preset--color--contrast); max-width:62ch; border-left:3px solid var(--wp--preset--color--gold); padding-left:18px; margin-top:8px; }
.wz-culture-lead strong{ color:var(--wp--preset--color--gold); }
.wz-callout{ background:rgba(124,92,255,.08); border:1px solid var(--wz-glass-brd); border-radius:14px; padding:18px 20px; margin:0 0 18px; }
.wz-callout .wz-prose:last-child{ margin-bottom:0; }
.wz-clist{ margin:6px 0 14px; padding-left:0; list-style:none; max-width:76ch; }
.wz-clist li{ position:relative; padding-left:22px; margin:8px 0; color:var(--wp--preset--color--contrast-muted); line-height:1.6; }
.wz-clist > li::before{ content:""; position:absolute; left:3px; top:11px; width:7px; height:7px; border-radius:50%; background:var(--wp--preset--color--gold); }
.wz-clist ul{ list-style:none; padding-left:0; margin:6px 0; }
.wz-clist ul li::before{ content:""; position:absolute; left:4px; top:11px; width:7px; height:7px; border-radius:50%; background:transparent; border:1px solid var(--wp--preset--color--accent-soft); }
.wz-culture-final{ text-align:center; padding:30px 26px; border-radius:18px; border:1px dashed var(--wz-glass-brd); background:rgba(14,11,26,.4); }
.wz-culture-final p{ color:var(--wp--preset--color--contrast-muted); line-height:1.7; margin:0 0 10px; }
.wz-culture-final p:last-child{ margin:0; }
.wz-culture-final p:first-child{ font-family:var(--wp--preset--font-family--heading); font-size:1.15rem; color:var(--wp--preset--color--contrast); }

/* Хаб «Стратегия»: группа документов */
.wz-docgroup{ margin-top:36px; }
.wz-docgroup__title{ display:flex; align-items:baseline; gap:12px; font-family:var(--wp--preset--font-family--heading); font-size:1.5rem; color:var(--wp--preset--color--contrast); margin:0 0 18px; }
.wz-docgroup__title .wz-csec__k{ margin:0; }
.wz-bsec.is-archived{ opacity:.7; }

/* Документы стратегии: именованные блоки */
.wz-blocks{ display:flex; flex-direction:column; gap:14px; margin:6px 0 8px; }
.wz-block{ padding:18px 20px; border-radius:14px; background:rgba(14,11,26,.5); border:1px solid var(--wz-glass-brd); }
.wz-block__k{ display:block; font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:1.02rem; color:var(--wp--preset--color--contrast); margin-bottom:8px; }
.wz-block__k em{ font-style:normal; font-weight:600; font-size:.76rem; color:var(--wp--preset--color--accent-soft); border:1px solid var(--wz-glass-brd); border-radius:30px; padding:2px 10px; margin-left:8px; vertical-align:middle; white-space:nowrap; }
.wz-block .wz-clist{ margin-bottom:0; }
.wz-prose--sm{ font-size:.9rem; margin-bottom:8px; }
.wz-important{ margin-top:18px; padding:18px 20px; border-radius:16px; color:var(--wp--preset--color--contrast-muted); line-height:1.6;
	background:linear-gradient(120deg, rgba(232,184,75,.14), rgba(232,184,75,.05)); border:1px solid rgba(232,184,75,.4); border-left:3px solid var(--wp--preset--color--gold); }
.wz-important__t{ display:block; font-family:var(--wp--preset--font-family--heading); font-weight:700; color:var(--wp--preset--color--gold); margin-bottom:6px; }
.wz-prose a, .wz-clist a{ color:var(--wp--preset--color--accent-soft); text-decoration:underline; text-underline-offset:2px; transition:color .2s; }
.wz-prose a:hover, .wz-clist a:hover{ color:var(--wp--preset--color--gold); }
/* Этапы (статус + дата) */
.wz-stage-head{ display:flex; align-items:center; gap:12px; margin-bottom:8px; flex-wrap:wrap; }
.wz-stage-date{ font-size:.82rem; color:var(--wp--preset--color--contrast-muted); }
.wz-chip--done{ color:#7ee0a8; border-color:rgba(110,224,140,.45); background:rgba(110,224,140,.1); }
.wz-chip--current{ color:var(--wp--preset--color--gold); border-color:rgba(232,184,75,.5); background:rgba(232,184,75,.12); }
.wz-chip--next{ color:var(--wp--preset--color--accent-soft); }
.wz-statline{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin:18px 0; padding:16px 20px; border-radius:14px; background:rgba(232,184,75,.08); border:1px solid rgba(232,184,75,.35); }
.wz-statline__k{ font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--wp--preset--color--gold); }
.wz-statline__v{ color:var(--wp--preset--color--contrast-muted); }
.wz-statline__v b{ font-family:var(--wp--preset--font-family--heading); color:var(--wp--preset--color--contrast); font-size:1.2rem; }
.wz-statline__v small{ display:block; font-size:.82rem; opacity:.8; margin-top:2px; }

@media (max-width:900px){
	.wz-chero__grid{ grid-template-columns:1fr; }
	.wz-cgrid2, .wz-steps, .wz-dossier{ grid-template-columns:1fr; }
	.wz-csec{ padding:24px 20px; }
	.wz-spell__stats{ width:100%; }
}

/* ===========================================================================
 * Космический визуал v0.2 — живой фон-созвездия, курсор-огонёк,
 * стеклянные блоки с наклоном, матовая шапка, секции главной.
 * Классы с префиксом wz- чтобы не конфликтовать с ядром Gutenberg.
 * ========================================================================= */
:root{
	--wz-glass: rgba(34,26,61,.45);
	--wz-glass-brd: rgba(157,133,255,.18);
	--wz-shadow: 0 30px 80px -30px rgba(0,0,0,.8);
	--wz-glow: 0 0 50px -6px rgba(124,92,255,.55);
	--wz-grad-accent: linear-gradient(105deg, var(--wp--preset--color--accent-soft), var(--wp--preset--color--accent));
	--wz-grad-gold: linear-gradient(105deg, #F4D27A, var(--wp--preset--color--gold));
	--wz-grad-magic: linear-gradient(105deg, #9D85FF 0%, #7C5CFF 45%, #E8B84B 110%);
	--wz-ease: cubic-bezier(.22,1,.36,1);
}

/* фон/курсор-слои поверх страницы */
#wz-sky{ position:fixed; inset:0; z-index:0; display:block; pointer-events:none; }
.wz-veil{ position:fixed; inset:0; z-index:0; pointer-events:none;
	background:
		radial-gradient(1100px 700px at 78% -8%, rgba(124,92,255,.20), transparent 60%),
		radial-gradient(900px 600px at 12% 12%, rgba(232,184,75,.07), transparent 60%),
		radial-gradient(1200px 900px at 50% 120%, rgba(124,92,255,.14), transparent 60%); }
/* контент сайта поднимаем над фоном */
.wp-site-blocks{ position:relative; z-index:1; }

#wz-spark,#wz-aura{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none; will-change:transform; opacity:0; transition:opacity .4s; }
#wz-aura{ width:420px; height:420px; margin:-210px 0 0 -210px; border-radius:50%;
	background:radial-gradient(circle, rgba(124,92,255,.18) 0%, rgba(124,92,255,.07) 35%, transparent 70%); }
#wz-spark{ width:14px; height:14px; margin:-7px 0 0 -7px; border-radius:50%;
	background:radial-gradient(circle, #FFF3CF 0%, #FFE19A 30%, #E8B84B 55%, rgba(124,92,255,0) 72%);
	box-shadow:0 0 14px 4px rgba(232,184,75,.7), 0 0 40px 10px rgba(124,92,255,.45);
	transition:width .25s var(--wz-ease), height .25s var(--wz-ease), margin .25s var(--wz-ease), opacity .4s; }
#wz-spark.wz-big{ width:30px; height:30px; margin:-15px 0 0 -15px; }
.wz-fine, .wz-fine body{ cursor:none; }
.wz-fine a, .wz-fine button, .wz-fine .wz-tilt, .wz-fine .wp-block-button__link{ cursor:none; }

/* обнуляем корневые боковые отступы на главной — секции верстаются своим .wz-wrap */
.home .wp-site-blocks{ --wp--style--root--padding-left:0; --wp--style--root--padding-right:0; }
.wz-wrap{ max-width:1180px; margin:0 auto; padding:0 28px; position:relative; z-index:2; }
/* фикс-шапка глобальная: на внутренних страницах даём контенту отступ сверху */
.wp-site-blocks{ padding-top:92px; }
/* сдвиг шапки под админ-бар у залогиненного пользователя */
body.admin-bar .wz-site-header{ top:32px; }
@media (max-width:782px){ body.admin-bar .wz-site-header{ top:46px; } }

/* -------- матовая липкая шапка -------- */
.wz-site-header{ position:fixed; top:0; left:0; right:0; z-index:100; padding:0!important;
	transition:background .4s var(--wz-ease), backdrop-filter .4s var(--wz-ease), border-color .4s var(--wz-ease); }
.wz-site-header > .wp-block-group{ max-width:1180px; margin:0 auto; padding:20px 28px; transition:padding .4s var(--wz-ease); }
.wz-site-header.is-scrolled{ background:rgba(14,11,26,.66); border-bottom:1px solid var(--wp--preset--color--border);
	backdrop-filter:blur(16px) saturate(140%); -webkit-backdrop-filter:blur(16px) saturate(140%); }
.wz-site-header.is-scrolled > .wp-block-group{ padding-top:11px; padding-bottom:11px; }
/* прозрачный логотип-W (без чёрного фона) = заглавная буква слова */
.wz-brand{ flex-wrap:nowrap; align-items:center; }
.wz-logo{ display:inline-flex; line-height:0; }
.wz-logo img{ height:42px; width:auto; display:block; transition:transform .5s var(--wz-ease); }
.wz-logo:hover img{ transform:rotate(-6deg) scale(1.06); }
/* воркмарк «inzardy» — градиент с перетеканием на ховере */
.wz-brandmark{ display:inline-block; font-family:var(--wp--preset--font-family--heading); font-weight:600; font-size:1.7rem;
	letter-spacing:-.03em; line-height:1.25; padding:0 1px 4px; margin-left:4px; transform:translateY(12px);
	text-decoration:none; white-space:nowrap; overflow:visible;
	background:linear-gradient(100deg,#9D85FF 0%,#7C5CFF 30%,#E8B84B 55%,#9D85FF 80%,#7C5CFF 100%);
	background-size:300% 100%; background-position:0% 50%;
	-webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
	transition:background-position .6s var(--wz-ease); }
.wz-brandmark:hover,.wz-brandmark:focus-visible{ animation:wz-brandshift 2.6s linear infinite; }
@keyframes wz-brandshift{ from{ background-position:0% 50%; } to{ background-position:300% 50%; } }
@media (prefers-reduced-motion:reduce){ .wz-brandmark:hover,.wz-brandmark:focus-visible{ animation:none; background-position:100% 50%; } }
.wz-site-header .wp-block-navigation{ font-size:.95rem; }
/* пункты меню: цвет + растущее по центру подчёркивание, плавно */
.wz-site-header .wp-block-navigation-item__content{
	position:relative; color:var(--wp--preset--color--contrast-muted); font-weight:500; text-decoration:none;
	padding-bottom:4px; transition:color .3s var(--wz-ease); }
.wz-site-header .wp-block-navigation-item__content::after{
	content:""; position:absolute; left:0; right:0; bottom:0; margin:0 auto; width:0; height:2px;
	border-radius:2px; background:var(--wz-grad-gold); transition:width .3s var(--wz-ease); }
.wz-site-header .wp-block-navigation-item__content:hover,
.wz-site-header .wp-block-navigation-item__content:focus-visible{ color:var(--wp--preset--color--contrast); }
.wz-site-header .wp-block-navigation-item__content.is-active{ color:var(--wp--preset--color--gold); }
.wz-site-header .wp-block-navigation-item__content:hover::after,
.wz-site-header .wp-block-navigation-item__content:focus-visible::after,
.wz-site-header .wp-block-navigation-item__content.is-active::after{ width:100%; }
.wz-lang{ width:42px; height:42px; border-radius:50%; border:1px solid var(--wp--preset--color--border);
	display:grid; place-items:center; font-size:.78rem; color:var(--wp--preset--color--contrast-muted); font-weight:600; transition:.3s; }
.wz-lang:hover{ border-color:var(--wp--preset--color--accent-soft); color:var(--wp--preset--color--contrast); }

/* -------- кнопки -------- */
.wz-btn{ font-family:var(--wp--preset--font-family--heading); font-weight:600; border:0; border-radius:40px;
	padding:13px 24px; font-size:.92rem; display:inline-flex; align-items:center; gap:9px; text-decoration:none;
	transition:transform .25s var(--wz-ease), box-shadow .3s, filter .3s; }
.wz-bico{ width:27px; height:27px; flex:0 0 auto; transition:transform .25s var(--wz-ease); }
.wz-btn:hover{ transform:scale(1.045); }
.wz-btn:hover .wz-bico{ transform:scale(1.12); }
.wz-btn:active{ transform:scale(.985); }
.wz-btn-primary{ background:var(--wz-grad-accent); color:#fff; box-shadow:var(--wz-glow); }
.wz-btn-primary:hover{ filter:brightness(1.08); color:#fff; box-shadow:0 0 60px -4px rgba(124,92,255,.8); }
.wz-btn-gold{ background:var(--wz-grad-gold); color:#251a05; }
.wz-btn-gold:hover{ filter:brightness(1.06); color:#251a05; box-shadow:0 0 48px -6px rgba(232,184,75,.7); }
.wz-btn-ghost{ background:transparent; color:var(--wp--preset--color--contrast); border:1px solid var(--wp--preset--color--accent-soft); }
.wz-btn-ghost:hover{ background:rgba(157,133,255,.12); color:var(--wp--preset--color--contrast); }

/* -------- стекло + наклон -------- */
.wz-glass{ background:var(--wz-glass); border:1px solid var(--wz-glass-brd); border-radius:20px;
	backdrop-filter:blur(14px) saturate(130%); -webkit-backdrop-filter:blur(14px) saturate(130%);
	box-shadow:var(--wz-shadow); position:relative; overflow:hidden; }
.wz-glass::after{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
	background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), rgba(157,133,255,.16), transparent 45%);
	opacity:0; transition:opacity .4s; }
.wz-glass:hover::after{ opacity:1; }
.wz-tilt{ transform-style:preserve-3d; transition:transform .5s var(--wz-ease); }
.wz-tilt-inner{ transform:translateZ(40px); transform-style:preserve-3d; }

/* -------- секции главной -------- */
.wz-home section{ position:relative; padding:100px 0; }
.wz-home .wz-hero{ position:relative; padding:112px 0 90px; min-height:auto; display:flex; align-items:center; }
.wz-eyebrow{ font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--wp--preset--color--gold); font-weight:600; margin-bottom:14px; }
.wz-h2{ font-family:var(--wp--preset--font-family--heading); font-size:clamp(2rem,4vw,3.2rem); font-weight:700; line-height:1.05; letter-spacing:-.02em; }
.wz-g{ background:var(--wz-grad-magic); -webkit-background-clip:text; background-clip:text; color:transparent; }
/* «магию» — тот же градиент + золотая подсветка, следящая за курсором (реакция градиента на свет мыши, а не всего слова) */
.wz-magic{ position:relative; white-space:nowrap;
	background-image:
		radial-gradient(circle at var(--gx,50%) var(--gy,160%), rgba(255,243,207,.98) 0%, #F4D27A 14%, rgba(232,184,75,0) 42%),
		linear-gradient(105deg,#9D85FF 0%,#7C5CFF 45%,#E8B84B 115%);
	background-repeat:no-repeat; background-size:100% 100%, 100% 100%;
	-webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.wz-sub{ color:var(--wp--preset--color--contrast-muted); max-width:54ch; margin-top:16px; font-size:1.05rem; }
.wz-badge{ display:inline-flex; align-items:center; gap:8px; font-size:.82rem; color:var(--wp--preset--color--accent-soft); font-weight:600;
	border:1px solid var(--wz-glass-brd); background:var(--wz-glass); backdrop-filter:blur(8px); border-radius:40px; padding:8px 16px; margin-bottom:28px; }
.wz-badge .wz-dot{ width:7px; height:7px; border-radius:50%; background:var(--wp--preset--color--gold); box-shadow:0 0 10px var(--wp--preset--color--gold); animation:wz-pulse 2.4s infinite; }
@keyframes wz-pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }
.wz-hero h1{ font-family:var(--wp--preset--font-family--heading); font-size:clamp(2.6rem,6vw,5rem); font-weight:700; line-height:1.04; letter-spacing:-.02em; max-width:15ch; margin:0; color:var(--wp--preset--color--contrast); }
.wz-lead{ color:var(--wp--preset--color--contrast-muted); font-size:1.15rem; max-width:46ch; margin:26px 0 36px; }
.wz-cta{ display:flex; gap:16px; flex-wrap:wrap; }
.wz-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:66px; max-width:760px; }
.wz-stat{ padding:22px; }
.wz-stat .wz-num{ font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:1.7rem; line-height:1.1;
	background:var(--wz-grad-magic); -webkit-background-clip:text; background-clip:text; color:transparent; }
.wz-stat .wz-lbl{ font-size:.74rem; color:var(--wp--preset--color--contrast-muted); text-transform:uppercase; letter-spacing:.08em; margin-top:6px; }

/* парящие руны */
.wz-rune{ position:absolute; z-index:1; opacity:.5; will-change:transform; color:var(--wp--preset--color--accent-soft); }
.wz-rune svg{ filter:drop-shadow(0 0 14px rgba(124,92,255,.6)); }
.wz-rune.r1{ top:16%; right:7%; animation:wz-float1 9s ease-in-out infinite; }
.wz-rune.r2{ top:60%; right:16%; color:var(--wp--preset--color--gold); animation:wz-float2 11s ease-in-out infinite; }
.wz-rune.r3{ top:42%; left:3%; animation:wz-float2 13s ease-in-out infinite; }
@keyframes wz-float1{ 0%,100%{transform:translateY(0) rotate(0)} 50%{transform:translateY(-22px) rotate(8deg)} }
@keyframes wz-float2{ 0%,100%{transform:translateY(0) rotate(0)} 50%{transform:translateY(18px) rotate(-7deg)} }

/* Legacy Wizard featured */
.wz-lw{ display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center; padding:40px; isolation:isolate; }
/* Фоновое изображение «портал» — еле видно сквозь цвет блока, как во мгле */
.wz-lw::before{
	content:""; position:absolute; inset:-10px; z-index:0; pointer-events:none;
	background:
		linear-gradient(155deg, rgba(26,19,48,.80), rgba(15,11,30,.88) 72%),
		url(../img/lw-portal-bg.webp) center/cover no-repeat;
	filter:blur(2px) saturate(.95);
}
.wz-lw > *{ position:relative; z-index:1; }
.wz-phone{ aspect-ratio:9/16; max-height:520px; margin:0 auto; border-radius:26px; overflow:hidden; position:relative;
	border:1px solid var(--wz-glass-brd); background:linear-gradient(160deg,#1c1640,#0f0b22 70%); box-shadow:var(--wz-shadow); }
.wz-phone img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.wz-phone .wz-tag{ position:absolute; left:14px; bottom:14px; z-index:2; font-size:.72rem; color:var(--wp--preset--color--contrast);
	background:rgba(14,11,26,.6); padding:6px 12px; border-radius:30px; backdrop-filter:blur(6px); }

/* Карусель скриншотов в «телефоне» (вертикальный вариант) */
.wz-pcar{ position:relative; border:0; background:none; box-shadow:none; border-radius:0; overflow:visible; }
.wz-pcar__stage{ display:flex; align-items:center; justify-content:center; gap:clamp(8px,2.2vw,18px); }
.wz-pcar__frame{ position:relative; flex:0 1 300px; width:100%; max-width:300px; aspect-ratio:9/16; max-height:560px;
	border-radius:26px; overflow:hidden; border:1px solid var(--wz-glass-brd);
	background:linear-gradient(160deg,#1c1640,#0f0b22 70%); box-shadow:var(--wz-shadow); }
.wz-pcar .wz-carousel__viewport{ position:absolute; inset:0; height:100%; overflow:hidden; }
.wz-pcar .wz-carousel__track{ height:100%; display:flex; transition:none; will-change:auto; }
/* плавная смена кадра — лёгкое проявление активного слайда (перелистывание мгновенное и надёжное) */
.wz-pcar .wz-carousel__slide{ animation:wz-pcar-fade .35s var(--wz-ease); }
@keyframes wz-pcar-fade{ from{ opacity:.55; } to{ opacity:1; } }
@media (prefers-reduced-motion:reduce){ .wz-pcar .wz-carousel__slide{ animation:none; } }
.wz-pcar .wz-carousel__slide{ flex:0 0 100%; min-width:100%; height:100%; aspect-ratio:auto;
	position:relative; overflow:hidden; background:#0f0b22; }
.wz-pcar__media{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.wz-pcar .wz-tag{ z-index:3; }

/* Стрелки — по бокам от телефона */
.wz-pcar .wz-carousel__nav{ position:static; transform:none; flex:0 0 auto; left:auto; right:auto; }

/* Пузырьки — под телефоном, активный оранжево-золотой */
.wz-pcar .wz-carousel__dots{ position:static; margin-top:20px; }
.wz-pcar .wz-carousel__dot{ width:9px; height:9px; transition:width .2s ease, background .2s ease; }
.wz-pcar .wz-carousel__dot[aria-current="true"]{ width:24px; border-radius:5px; background:var(--wp--preset--color--gold); transform:none; }

/* Слайд-трейлер: вертикальное видео вписывается в окно */
.wz-pcar__play-label{ font-size:.82rem; font-weight:600; letter-spacing:.01em;
	padding:6px 14px; border-radius:30px; background:rgba(14,11,26,.62); backdrop-filter:blur(6px);
	border:1px solid rgba(255,255,255,.12); transition:transform .2s ease; }
.wz-pcar .wz-carousel__play-icon{ transition:transform .2s ease; }
.wz-pcar .wz-carousel__play:hover .wz-carousel__play-icon,
.wz-pcar .wz-carousel__play:focus-visible .wz-carousel__play-icon{ transform:scale(1.14); }
.wz-pcar .wz-carousel__play:hover .wz-pcar__play-label,
.wz-pcar .wz-carousel__play:focus-visible .wz-pcar__play-label{ transform:scale(1.1); }
.wz-pcar .wz-carousel__video,
.wz-pcar .wz-carousel__iframe{ object-fit:contain; background:#000; }

@media (max-width:900px){
	.wz-pcar__frame{ flex-basis:260px; max-width:260px; }
	.wz-pcar .wz-carousel__nav{ width:38px; height:38px; }
}
.wz-chip{ display:inline-block; font-size:.74rem; font-weight:600; color:var(--wp--preset--color--accent-soft);
	border:1px solid var(--wz-glass-brd); border-radius:30px; padding:6px 13px; margin-bottom:16px; }
.wz-lw h3{ font-family:var(--wp--preset--font-family--heading); font-size:2.2rem; font-weight:700; margin:0; line-height:1.1; color:var(--wp--preset--color--contrast); }
.wz-lw p{ color:var(--wp--preset--color--contrast-muted); margin:14px 0 24px; max-width:42ch; }

/* bento ценностей */
.wz-bento{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:48px; }
.wz-bento .wz-glass{ padding:26px; }
.wz-bento .wz-glass:nth-child(1){ grid-column:span 2; }
.wz-ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center;
	background:rgba(124,92,255,.14); border:1px solid var(--wz-glass-brd); margin-bottom:16px; color:var(--wp--preset--color--accent-soft); }
.wz-bento h3{ font-family:var(--wp--preset--font-family--heading); font-size:1.18rem; font-weight:600; margin:0 0 8px; color:var(--wp--preset--color--contrast); }
.wz-bento p{ color:var(--wp--preset--color--contrast-muted); font-size:.93rem; margin:0; }
/* Золотая CTA-карточка «Подробнее о нашей культуре» (увеличивается на ховере) */
.wz-bento-cta{ grid-column:span 3; display:flex; align-items:center; gap:20px; text-decoration:none;
	background:linear-gradient(120deg, rgba(232,184,75,.16), rgba(232,184,75,.05));
	border:1px solid rgba(232,184,75,.42);
	transition:transform .3s var(--wz-ease), box-shadow .3s, border-color .3s, background .3s; }
.wz-bento-cta .wz-ic{ margin-bottom:0; transition:transform .3s var(--wz-ease); }
.wz-ic--gold{ background:var(--wz-grad-gold); color:#251a05; border-color:transparent; }
.wz-bento-cta__text strong{ font-family:var(--wp--preset--font-family--heading);
	font-size:clamp(1.05rem,1.6vw,1.3rem); font-weight:700; color:var(--wp--preset--color--contrast); }
.wz-bento-cta__arrow{ margin-left:auto; font-size:1.7rem; line-height:1; color:var(--wp--preset--color--gold);
	transition:transform .3s var(--wz-ease); }
.wz-bento-cta:hover{ transform:scale(1.03); border-color:rgba(232,184,75,.8);
	box-shadow:0 0 50px -8px rgba(232,184,75,.55);
	background:linear-gradient(120deg, rgba(232,184,75,.26), rgba(232,184,75,.09)); }
.wz-bento-cta:hover .wz-ic--gold{ transform:scale(1.08); }
.wz-bento-cta:hover .wz-bento-cta__arrow{ transform:translateX(7px); }
@media (max-width:900px){ .wz-bento-cta{ grid-column:1 / -1; } }

/* секция-разрыв (комикс/персонаж) */
.wz-home .wz-rupture{ padding:40px 0; }
.wz-comic{ position:relative; border-radius:28px; overflow:hidden; border:1px solid rgba(232,184,75,.25);
	background:
		radial-gradient(700px 500px at 18% 30%, rgba(124,92,255,.55), transparent 60%),
		radial-gradient(700px 600px at 88% 80%, rgba(232,184,75,.4), transparent 60%),
		linear-gradient(135deg,#2a1d52,#140f2c);
	min-height:460px; display:flex; align-items:center; padding:56px; }
.wz-comic::before{ content:""; position:absolute; inset:0; opacity:.5;
	background:repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 9px); }
.wz-panel{ position:relative; z-index:2; max-width:520px; background:rgba(14,11,26,.55);
	border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:34px; backdrop-filter:blur(8px); }
.wz-panel .wz-kicker{ font-family:var(--wp--preset--font-family--heading); font-weight:700; font-size:.85rem; letter-spacing:.14em; color:var(--wp--preset--color--gold); text-transform:uppercase; }
.wz-panel h2{ font-family:var(--wp--preset--font-family--heading); font-size:clamp(1.8rem,3.4vw,2.7rem); margin:10px 0 14px; line-height:1.08; color:var(--wp--preset--color--contrast); }
.wz-panel p{ color:#d9d3f2; margin-bottom:22px; }
.wz-char{ position:absolute; right:6%; bottom:0; z-index:1; width:320px; height:400px;
	background:radial-gradient(circle at 50% 38%, rgba(232,184,75,.9), rgba(124,92,255,.5) 55%, transparent 72%);
	filter:blur(2px); border-radius:50% 50% 46% 46%/60% 60% 40% 40%; opacity:.8; }
/* Свечения-заглушки под разных героев (заменим на реальный арт) */
.wz-char--vamp{ background:radial-gradient(circle at 50% 40%, rgba(232,184,75,.85), rgba(176,76,196,.5) 55%, transparent 72%); }
.wz-char--lord{ background:radial-gradient(circle at 50% 40%, rgba(120,200,255,.85), rgba(124,92,255,.5) 55%, transparent 72%); }
.wz-char--gnome{ background:radial-gradient(circle at 50% 40%, rgba(232,184,75,.9), rgba(96,140,255,.5) 55%, transparent 72%); }
.wz-char--qufli{ background:radial-gradient(circle at 50% 40%, rgba(106,240,231,.85), rgba(70,150,255,.5) 55%, transparent 72%); }
.wz-char--gloss{ background:radial-gradient(circle at 50% 40%, rgba(255,170,70,.9), rgba(220,60,40,.5) 55%, transparent 72%); }
/* Слот под реальный арт персонажа (когда добавишь <img class="wz-char__img">) */
.wz-char:has(.wz-char__img){ background:none; filter:none; border-radius:0; opacity:1; width:auto; height:100%; }
.wz-char__img{ position:absolute; right:0; bottom:0; height:100%; width:auto; max-width:60vw;
	object-fit:contain; object-position:bottom right; filter:drop-shadow(0 24px 50px rgba(0,0,0,.5)); }
/* Вариант «с фоном»: полный кадр героя как правая панель с растушёвкой слева */
.wz-char:has(.wz-char__img--bg){ right:0; top:0; bottom:0; width:50%; height:auto; max-width:none; }
.wz-char__img--bg{ inset:0; width:100%; height:100%; max-width:none; object-fit:cover; object-position:center right; filter:none;
	-webkit-mask-image:linear-gradient(90deg, transparent 0, #000 34%); mask-image:linear-gradient(90deg, transparent 0, #000 34%); }

/* Баннеры-герои: карусель целых баннеров (стрелки + пузырьки; анимация — WAA в carousel.js) */
.wz-banners.winzardy-carousel{ border:0; background:none; box-shadow:none; border-radius:0; overflow:visible; }
.wz-banners .wz-carousel__viewport{ position:relative; overflow:hidden; border-radius:28px; }
.wz-banners .wz-carousel__track{ display:block; transition:none; }
.wz-banners .wz-carousel__slide{ aspect-ratio:auto; background:none; overflow:visible; }
.wz-banners .wz-comic{ width:100%; }
/* Ряд управления под баннером: ‹ • • • › */
.wz-banners__controls{ display:flex; align-items:center; justify-content:center; gap:clamp(12px,2vw,20px); margin-top:22px; }
.wz-banners .wz-carousel__nav{ position:static; transform:none; left:auto; right:auto; flex:0 0 auto; }
.wz-banners .wz-carousel__dots{ position:static; margin:0; }
.wz-banners .wz-carousel__dot{ width:9px; height:9px; transition:width .2s ease, background .2s ease; }
.wz-banners .wz-carousel__dot[aria-current="true"]{ width:24px; border-radius:5px; background:var(--wp--preset--color--gold); transform:none; }

/* footer */
.wz-footer{ position:relative; z-index:2; }
.wz-foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.wz-foot-brand .wz-wordmark{ font-family:var(--wp--preset--font-family--heading); font-size:2.6rem; font-weight:700; line-height:1;
	background:var(--wz-grad-magic); -webkit-background-clip:text; background-clip:text; color:transparent; }
.wz-foot-brand p{ color:var(--wp--preset--color--contrast-muted); margin-top:10px; max-width:30ch; font-size:.92rem; }
.wz-foot-col h4{ font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--wp--preset--color--gold); margin:0 0 16px; }
.wz-foot-col a{ display:block; color:var(--wp--preset--color--contrast-muted); font-size:.92rem; padding:6px 0; text-decoration:none; transition:color .25s; }
.wz-foot-col a:hover{ color:var(--wp--preset--color--contrast); }
.wz-foot-bottom{ display:flex; justify-content:space-between; align-items:center; margin-top:50px; padding-top:24px;
	border-top:1px solid var(--wp--preset--color--border); color:var(--wp--preset--color--contrast-muted); font-size:.84rem; flex-wrap:wrap; gap:14px; }
.wz-socials{ display:flex; gap:12px; }
.wz-socials a{ width:38px; height:38px; border-radius:50%; border:1px solid var(--wp--preset--color--border);
	display:grid; place-items:center; transition:.3s; color:var(--wp--preset--color--contrast-muted); }
.wz-socials a:hover{ border-color:var(--wp--preset--color--accent-soft); color:var(--wp--preset--color--contrast); transform:translateY(-3px); }

/* соц-чипы (страница проекта) */
.wz-soc-block{ margin-top:34px; }
.wz-soc-title{ font-size:1.35rem; margin:0 0 4px; }
.wz-soc-sub{ color:var(--wp--preset--color--contrast-muted); margin:0 0 16px; }
.wz-soclist{ display:flex; flex-wrap:wrap; gap:12px; margin-top:8px; }
.wz-soc{ display:inline-flex; align-items:center; gap:10px; padding:11px 16px 11px 13px; border-radius:14px;
	border:1px solid var(--wp--preset--color--border); background:rgba(255,255,255,.02);
	color:var(--wp--preset--color--contrast-muted); text-decoration:none; font-weight:600; font-size:.95rem;
	transition:transform .25s var(--wz-ease), border-color .25s, color .25s, background .25s; }
.wz-soc svg{ width:20px; height:20px; flex:0 0 auto; }
.wz-soc:hover{ transform:translateY(-3px); color:var(--wp--preset--color--contrast);
	border-color:var(--wp--preset--color--accent-soft); background:rgba(255,255,255,.05); }

/* scroll-reveal */
.wz-reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--wz-ease), transform .8s var(--wz-ease); }
.wz-reveal.is-in{ opacity:1; transform:none; }

@media (max-width:900px){
	.wz-stats{ grid-template-columns:repeat(2,1fr); }
	.wz-lw,.wz-foot-grid{ grid-template-columns:1fr; }
	.wz-bento{ grid-template-columns:1fr 1fr; }
	.wz-bento .wz-glass:nth-child(1){ grid-column:span 2; }
	.wz-char{ display:none; }
}
@media (prefers-reduced-motion:reduce){
	.wz-rune,.wz-badge .wz-dot{ animation:none!important; }
	.wz-reveal{ opacity:1; transform:none; transition:none; }
	.wz-tilt{ transition:none; }
	#wz-spark,#wz-aura{ display:none!important; }
	.wz-fine, .wz-fine body{ cursor:auto; }
}

/* ===========================================================================
 * АДАПТИВ — телефоны и планшеты (v0.6.0)
 * Desktop-first: блоки ниже доуточняют базовые правила на узких экранах.
 * Брейкпоинты: 960 (планшет) · 720 (планшет→телефон) · 520 (телефон) · 380 (узкий).
 * Существующие @media(max-width:900px) выше остаются; эти идут позже и при
 * совпадении селекторов перекрывают их по порядку источника.
 * ========================================================================= */

/* --- Глобальные страховки от горизонтального переполнения и сирот --- */
img, video, canvas, svg, iframe { max-width: 100%; }
.wz-hero h1, .wz-h2, .wz-panel h2, .wz-lw h3, .wz-csec__h, .wz-culture-final p:first-child { text-wrap: balance; }
.wz-prose, .wz-lead, .wz-sub, .wz-bento p, .wz-bsec p, .wz-wcard p { text-wrap: pretty; }

/* --- Планшет ≤960 --- */
@media (max-width:960px){
	.wz-home section{ padding:74px 0; }
	.wz-home .wz-hero{ padding:100px 0 64px; }
	.wz-home .wz-rupture{ padding:32px 0; }
	.wz-lw{ padding:30px; gap:30px; }
	.wz-comic{ padding:44px; min-height:auto; }
	.wz-panel{ max-width:none; }
	.wz-foot-grid{ gap:28px; }
}

/* --- Планшет→телефон ≤720: ключевой мобильный брейкпоинт --- */
@media (max-width:720px){
	/* гуттеры и вертикальный ритм */
	.wz-wrap{ padding:0 clamp(16px,4.5vw,24px); }
	.wp-site-blocks{ padding-top:72px; }
	.wz-home section{ padding:60px 0; }
	.wz-home .wz-hero{ padding:88px 0 48px; }

	/* ШАПКА: убираем тесноту — декоративный воркмарк и языковой стаб прячем,
	   оставляем логотип + CTA + бургер, чтобы строка влезала на 360px */
	.wz-site-header > .wp-block-group{ padding:13px 16px; }
	.wz-brandmark{ display:none; }
	.wz-lang{ display:none; }
	.wz-logo img{ height:36px; }
	.wz-site-header .wz-btn-primary{ padding:11px 16px; font-size:.85rem; }

	/* Оверлей-меню (бургер) под тему */
	.wz-site-header .wp-block-navigation__responsive-container.is-menu-open{
		background:rgba(12,9,22,.97); backdrop-filter:blur(20px) saturate(140%);
		-webkit-backdrop-filter:blur(20px) saturate(140%); padding:28px 24px; }
	.wz-site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content{ margin-top:40px; }
	.wz-site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container{ gap:6px; }
	.wz-site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content{
		color:var(--wp--preset--color--contrast); font-size:1.25rem; font-family:var(--wp--preset--font-family--heading);
		padding:12px 2px; display:inline-block; }
	.wz-site-header .wp-block-navigation__responsive-container-open,
	.wz-site-header .wp-block-navigation__responsive-container-close{
		color:var(--wp--preset--color--contrast); padding:8px; min-width:44px; min-height:44px; }

	/* Legacy Wizard featured */
	.wz-lw{ padding:24px; border-radius:18px; gap:24px; }
	.wz-phone{ max-height:none; width:100%; max-width:300px; }
	.wz-lw h3{ font-size:1.9rem; }

	/* Бенто ценностей — одна колонка, спец-карточки на всю ширину */
	.wz-bento{ grid-template-columns:1fr; gap:14px; margin-top:36px; }
	.wz-bento .wz-glass:nth-child(1){ grid-column:auto; }
	.wz-bento-cta{ grid-column:auto; }

	/* Секция-разрыв / комикс / баннеры */
	.wz-comic{ padding:30px 22px; border-radius:22px; }
	.wz-panel{ padding:24px 22px; }
	.wz-panel h2{ font-size:clamp(1.6rem,6vw,2.1rem); }

	/* Бестиарий / карточка героя — плотнее */
	.wz-csec{ padding:22px 18px; }
	.wz-page-body{ padding-bottom:60px; }
	.wz-chero__art{ max-width:420px; margin-inline:auto; }

	/* Футер: низ в столбик */
	.wz-foot-brand .wz-wordmark{ font-size:2.1rem; }
	.wz-foot-bottom{ flex-direction:column; align-items:flex-start; gap:16px; margin-top:36px; }

	/* ОБЛЕГЧАЕМ ЭФФЕКТЫ на мобильных: декоративные руны прочь (плюс защита от
	   переполнения), плотность звёзд режется в cosmic.js, наклон 3D уже off на тач */
	.wz-rune{ display:none; }
}

/* --- Телефон ≤520 --- */
@media (max-width:520px){
	.wz-wrap{ padding:0 16px; }
	.wz-home section{ padding:52px 0; }
	.wz-home .wz-hero{ padding:84px 0 44px; }

	/* CTA-кнопки героя — в столбик, во всю ширину (удобный тап-таргет) */
	.wz-cta{ flex-direction:column; align-items:stretch; gap:12px; }
	.wz-cta .wz-btn{ width:100%; justify-content:center; }

	/* Статы героя — компактнее, 2 колонки сохраняем */
	.wz-stats{ gap:12px; margin-top:40px; }
	.wz-stat{ padding:16px; }
	.wz-stat .wz-num{ font-size:1.45rem; }
	.wz-lead{ font-size:1.05rem; margin:22px 0 30px; }

	/* Карточка героя: статы заклинаний без минимальной ширины (не переполняют) */
	.wz-spell__head{ gap:14px; }
	.wz-spell__stats{ width:100%; }
	.wz-stat-pill{ min-width:0; flex:1 1 0; }

	/* Комикс/панель ещё компактнее */
	.wz-comic{ padding:24px 18px; }
	.wz-panel{ padding:20px 16px; }

	/* Соц-чипы и кнопки «назад» — на всю ширину строки */
	.wz-soc{ flex:1 1 100%; justify-content:center; }
	.wz-cback{ flex-direction:column; }
	.wz-cback .wz-btn{ width:100%; justify-content:center; }
}

/* --- Узкий телефон ≤380 --- */
@media (max-width:380px){
	.wz-site-header .wz-btn-primary{ padding:10px 13px; font-size:.8rem; }
	.wz-logo img{ height:32px; }
	.wz-h2{ font-size:1.7rem; }
	.wz-lw h3{ font-size:1.7rem; }
	.wz-foot-brand .wz-wordmark{ font-size:1.85rem; }
}

/* --- Тач-устройства: крупнее тап-таргеты, спокойнее моторика --- */
@media (pointer:coarse){
	/* точки каруселей — расширяем зону нажатия до ~40px без изменения вида */
	.wz-carousel__dot{ position:relative; }
	.wz-carousel__dot::after{ content:""; position:absolute; inset:-15px; }
	/* соц-иконки футера — минимум 40px */
	.wz-socials a{ width:40px; height:40px; }
	/* плавный скролл-якорь без дёрганья на тач */
	html{ scroll-padding-top:84px; }
}

/* Бургер-оверлей: ядро задаёт белый фон правилом
   `.wp-block-navigation:not(.has-background) … .is-menu-open` (специфичность 0,5,0).
   Перебиваем тем же весом + !important, чтобы оверлей был в тёмной теме. */
.wz-site-header .wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open{
	background-color:rgba(12,9,22,.97)!important;
}

/* Полноширинные на мобильных кнопки/чипы: border-box, иначе width:100% + паддинги
   вылезают за контейнер и дают горизонтальный скролл на телефоне. */
.wz-btn, .wz-soc, .wz-gplay__link { box-sizing:border-box; }
