/*
 * Cookie Consent Shim — базовые стили.
 * Все цвета/радиусы/шрифты заданы через CSS-переменные с fallback на токены
 * темы (--wp--preset--*) либо нейтральные значения. Per-site override живёт
 * в child-theme: assets/css/cookie-consent-override.css.
 */
:root {
	--ccs-color-bg: var(--wp--preset--color--background, #ffffff);
	--ccs-color-fg: var(--wp--preset--color--foreground, #1a1a1a);
	--ccs-color-muted: var(--wp--preset--color--tertiary, #555555);
	--ccs-color-primary: var(--wp--preset--color--primary, #1a73e8);
	--ccs-color-primary-fg: var(--wp--preset--color--background, #ffffff);
	--ccs-color-border: rgba(0, 0, 0, 0.12);
	--ccs-color-overlay: rgba(0, 0, 0, 0.45);
	--ccs-radius: 12px;
	--ccs-radius-btn: 8px;
	--ccs-font-family: var(--wp--preset--font-family--body, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif);
	--ccs-font-size: 15px;
	--ccs-line-height: 1.5;
	--ccs-shadow: 0 -8px 32px rgba(0, 0, 0, 0.12);
	--ccs-spacing: 16px;
	--ccs-z-banner: 9000;
	--ccs-z-modal: 9100;
}

.cc-banner {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: var(--ccs-z-banner);
	font-family: var(--ccs-font-family);
	font-size: var(--ccs-font-size);
	line-height: var(--ccs-line-height);
	color: var(--ccs-color-fg);
	background: var(--ccs-color-bg);
	border-top: 1px solid var(--ccs-color-border);
	box-shadow: var(--ccs-shadow);
	border-radius: var(--ccs-radius) var(--ccs-radius) 0 0;
	padding-bottom: env(safe-area-inset-bottom, 0);
}

.cc-banner__inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--ccs-spacing) calc(var(--ccs-spacing) * 1.25);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 12px;
}

.cc-banner__title {
	margin: 0;
	font-size: 1.1em;
	font-weight: 700;
	color: var(--ccs-color-fg);
}

.cc-banner__desc {
	margin: 0;
	color: var(--ccs-color-muted);
}

.cc-banner__desc a {
	color: var(--ccs-color-primary);
	text-decoration: underline;
	transition: opacity 0.15s, text-decoration-color 0.15s;
}

.cc-banner__desc a:hover,
.cc-banner__desc a:focus-visible {
	opacity: 0.8;
	text-decoration: none;
}

.cc-banner__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}

.cc-banner__btn {
	font: inherit;
	cursor: pointer;
	min-height: 44px;
	padding: 10px 18px;
	border-radius: var(--ccs-radius-btn);
	border: 1.5px solid transparent;
	background: transparent;
	color: inherit;
	font-weight: 600;
	transition: background-color 0.15s, color 0.15s, transform 0.05s;
}

.cc-banner__btn:focus-visible {
	outline: 3px solid var(--ccs-color-primary);
	outline-offset: 2px;
}

.cc-banner__btn--primary {
	background: var(--ccs-color-primary);
	color: var(--ccs-color-primary-fg);
	border-color: var(--ccs-color-primary);
}

.cc-banner__btn--primary:hover {
	filter: brightness(0.95);
}

.cc-banner__btn--secondary {
	background: transparent;
	color: var(--ccs-color-primary);
	border-color: var(--ccs-color-primary);
}

.cc-banner__btn--secondary:hover {
	background: color-mix(in srgb, var(--ccs-color-primary) 10%, transparent);
}

.cc-banner__btn--text {
	background: transparent;
	color: inherit;
	text-decoration: underline;
	min-height: 44px;
	padding: 10px 12px;
}

.cc-banner__btn--text:hover {
	background: color-mix(in srgb, currentColor 8%, transparent);
	text-decoration: none;
}

.cc-modal {
	position: fixed;
	inset: 0;
	z-index: var(--ccs-z-modal);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	font-family: var(--ccs-font-family);
}

@media (min-width: 768px) {
	.cc-modal {
		align-items: center;
	}
}

.cc-modal__backdrop {
	position: absolute;
	inset: 0;
	background: var(--ccs-color-overlay);
	cursor: pointer;
}

.cc-modal__inner {
	position: relative;
	width: 100%;
	max-width: 560px;
	max-height: 92vh;
	overflow-y: auto;
	background: var(--ccs-color-bg);
	color: var(--ccs-color-fg);
	border-radius: var(--ccs-radius) var(--ccs-radius) 0 0;
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.24);
	padding: 24px;
}

@media (min-width: 768px) {
	.cc-modal__inner {
		border-radius: var(--ccs-radius);
	}
}

.cc-modal__inner:focus-visible {
	outline: 3px solid var(--ccs-color-primary);
	outline-offset: -3px;
}

.cc-modal__title {
	margin: 0 0 8px;
	font-size: 1.25em;
	font-weight: 700;
}

.cc-modal__desc {
	margin: 0 0 16px;
	color: var(--ccs-color-muted);
}

.cc-categories {
	list-style: none;
	margin: 0 0 16px;
	padding: 0;
	display: grid;
	gap: 12px;
}

.cc-category {
	border: 1px solid var(--ccs-color-border);
	border-radius: var(--ccs-radius-btn);
	padding: 12px 14px;
}

.cc-category__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.cc-category__title {
	font-weight: 600;
}

.cc-category__desc {
	margin: 6px 0 0;
	font-size: 0.92em;
	color: var(--ccs-color-muted);
}

.cc-switch {
	position: relative;
	display: inline-block;
	width: 44px;
	height: 24px;
	flex-shrink: 0;
}

.cc-switch input {
	position: absolute;
	width: 100%;
	height: 100%;
	margin: 0;
	opacity: 0;
	cursor: pointer;
}

.cc-switch input:disabled {
	cursor: not-allowed;
}

.cc-switch__track {
	position: absolute;
	inset: 0;
	border-radius: 999px;
	background: #ccd0d5;
	transition: background-color 0.15s;
	box-shadow: inset 0 0 0 1px var(--ccs-color-border);
}

.cc-switch__track::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
	transition: transform 0.15s;
}

.cc-switch input:checked + .cc-switch__track {
	background: var(--ccs-color-primary);
}

.cc-switch input:checked + .cc-switch__track::after {
	transform: translateX(20px);
}

.cc-switch input:focus-visible + .cc-switch__track {
	outline: 3px solid var(--ccs-color-primary);
	outline-offset: 2px;
}

.cc-switch input:disabled + .cc-switch__track {
	opacity: 0.6;
}

.cc-modal__buttons {
	display: flex;
	gap: 8px;
	justify-content: center;
	flex-wrap: wrap;
}

@media (prefers-reduced-motion: reduce) {
	.cc-banner,
	.cc-banner__btn,
	.cc-switch__track,
	.cc-switch__track::after {
		transition: none !important;
		animation: none !important;
	}
}

/*
 * Contact Form 7 — поле [acceptance].
 * 1. Чекбокс и текст в одну строку (чекбокс слева, текст справа с отступом).
 * 2. Ссылка в тексте — currentColor + underline, чтобы оставалась читаемой
 *    на любом фоне темы.
 */
.wpcf7-acceptance .wpcf7-list-item {
	display: block;
	margin: 0;
}

.wpcf7-acceptance .wpcf7-list-item label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	line-height: 1.5;
}

/*
 * Темы часто задают width: 100% для всех input внутри
 * .wpcf7-form-control-wrap. Для checkbox/radio это раздувает контрол на
 * всю ширину родителя — возвращаем нативный размер. !important здесь
 * оправдан: Popup Maker рендерит формы внутри #popmake-XXX, и темы с
 * правилом `#popmake-X input { width: 100% }` побеждают по специфичности
 * ID-селектора. Селектор без требования <p>, чтобы покрывать и темы с
 * `add_filter('wpcf7_autop_or_not', '__return_false')`.
 */
.wpcf7-form .wpcf7-form-control-wrap input[type="checkbox"],
.wpcf7-form .wpcf7-form-control-wrap input[type="radio"],
.wpcf7-acceptance input[type="checkbox"] {
	width: auto !important;
	max-width: none !important;
}

/*
 * Acceptance-обёртка (внешний <label class="cf7-consent">) и внутренний
 * <label> CF7 в .wpcf7-acceptance — оба попадают под правило Popup Maker
 * `.pum-container.popmake .pum-content.popmake-content .wpcf7 label
 *  { width: calc(50% - 0.75rem) }` (поля попапа в две колонки), что
 * обрезает текст согласия. Возвращаем на всю ширину. Специфичность
 * Popup Maker 0,0,5,1 — без !important не побить.
 *
 * display не задаём здесь, чтобы сохранить flex-row у внутреннего label
 * (определён выше в `.wpcf7-acceptance .wpcf7-list-item label`).
 */
.wpcf7-form label.cf7-consent,
.wpcf7-form .wpcf7-acceptance label,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item label {
	width: 100% !important;
	max-width: none !important;
}

.wpcf7-form label.cf7-consent {
	display: block;
	margin-top: 8px;
}

.wpcf7-acceptance input[type="checkbox"] {
	flex-shrink: 0;
	margin-top: 3px;
	cursor: pointer;
}

.wpcf7-acceptance .wpcf7-list-item-label {
	flex: 1;
}

.wpcf7-acceptance a {
	color: currentColor;
	text-decoration: underline;
	text-underline-offset: 2px;
	font-weight: 600;
	transition: opacity 0.15s;
}

.wpcf7-acceptance a:hover,
.wpcf7-acceptance a:focus-visible {
	opacity: 0.75;
}
