/**
 * File: /wp-content/plugins/partmost-cookie-consent/assets/css/frontend.css
 * Module: PCC Frontend CSS
 * Version: 1.0.0-alpha4
 *
 * Purpose:
 * - Стили баннера cookie consent
 * - Стили FAB-кнопки повторного открытия
 *
 * Changes in 1.0.0-alpha4:
 * - Сохранена серверная основа alpha3 без потерь
 * - FAB-кнопка визуально усилена, чтобы не сливаться с темным футером
 * - Добавлены border, более заметная тень, hover и focus-visible состояния
 */

#pcc-root {
	--pcc-font: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
	--pcc-font-size: 14px;
	--pcc-bg: #111111;
	--pcc-text: #ffffff;
	--pcc-link: #61dafb;
	--pcc-radius: 12px;
	--pcc-pad-y: 16px;
	--pcc-pad-x: 16px;
	--pcc-btn1-bg: #28a745;
	--pcc-btn1-text: #ffffff;
	--pcc-btn2-bg: #333333;
	--pcc-btn2-text: #ffffff;
	--pcc-fab-bg: #111111;
	--pcc-fab-text: #ffffff;
	--pcc-fab-offset-bottom: 24px;
	--pcc-fab-offset-side: 24px;
}

.pcc-banner {
	position: fixed;
	z-index: 999999;
	font-family: var(--pcc-font);
	font-size: var(--pcc-font-size);
	color: var(--pcc-text);
}

.pcc-banner-inner {
	background: var(--pcc-bg);
	color: var(--pcc-text);
	border-radius: var(--pcc-radius);
	padding: var(--pcc-pad-y) var(--pcc-pad-x);
	box-shadow: 0 12px 34px rgba(0, 0, 0, 0.24);
}

.pcc-layout-bar-bottom {
	left: 12px;
	right: 12px;
	bottom: 12px;
}

.pcc-layout-bar-top {
	left: 12px;
	right: 12px;
	top: 12px;
}

.pcc-layout-box-left {
	left: 16px;
	bottom: 16px;
	max-width: 420px;
}

.pcc-layout-box-right {
	right: 16px;
	bottom: 16px;
	max-width: 420px;
}

.pcc-title {
	margin: 0 0 10px;
	font-size: 18px;
	line-height: 1.3;
	color: var(--pcc-text);
}

.pcc-text {
	line-height: 1.55;
	margin-bottom: 14px;
}

.pcc-link {
	color: var(--pcc-link);
}

.pcc-switches {
	display: grid;
	gap: 10px;
	margin-bottom: 14px;
}

.pcc-switch-row {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 10px;
	align-items: start;
	line-height: 1.45;
}

.pcc-switch-row input {
	margin-top: 3px;
}

.pcc-locked {
	opacity: 0.95;
}

.pcc-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.pcc-btn {
	border: 0;
	border-radius: 10px;
	padding: 10px 14px;
	cursor: pointer;
	font: inherit;
}

.pcc-btn-primary {
	background: var(--pcc-btn1-bg);
	color: var(--pcc-btn1-text);
}

.pcc-btn-secondary {
	background: var(--pcc-btn2-bg);
	color: var(--pcc-btn2-text);
}

.pcc-fab {
	position: fixed;
	bottom: var(--pcc-fab-offset-bottom);
	z-index: 999999;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	padding: 10px 14px;
	cursor: pointer;
	font: inherit;
	background: var(--pcc-fab-bg);
	color: var(--pcc-fab-text);
	box-shadow:
		0 10px 28px rgba(0, 0, 0, 0.28),
		0 0 0 1px rgba(255, 255, 255, 0.04) inset;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	line-height: 1;
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease,
		background-color 0.18s ease;
}

.pcc-fab:hover {
	transform: translateY(-1px);
	border-color: rgba(255, 255, 255, 0.28);
	box-shadow:
		0 14px 32px rgba(0, 0, 0, 0.34),
		0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}

.pcc-fab:focus-visible {
	outline: none;
	border-color: rgba(97, 218, 251, 0.7);
	box-shadow:
		0 0 0 3px rgba(97, 218, 251, 0.2),
		0 14px 32px rgba(0, 0, 0, 0.34);
}

.pcc-fab-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
}

.pcc-fab-label {
	display: inline-block;
	white-space: nowrap;
}

.pcc-fab-left {
	left: var(--pcc-fab-offset-side);
}

.pcc-fab-right {
	right: var(--pcc-fab-offset-side);
}

@media (max-width: 680px) {
	.pcc-layout-bar-bottom,
	.pcc-layout-bar-top,
	.pcc-layout-box-left,
	.pcc-layout-box-right {
		left: 10px;
		right: 10px;
		bottom: 10px;
		top: auto;
		max-width: none;
	}

	.pcc-layout-bar-top {
		top: 10px;
		bottom: auto;
	}

	.pcc-fab {
		bottom: var(--pcc-fab-offset-bottom);
		padding: 10px;
		width: 42px;
		height: 42px;
		min-width: 42px;
		justify-content: center;
		gap: 0;
		border-color: rgba(255, 255, 255, 0.24);
		box-shadow:
			0 10px 24px rgba(0, 0, 0, 0.3),
			0 0 0 1px rgba(255, 255, 255, 0.05) inset;
	}

	.pcc-fab-left {
		left: var(--pcc-fab-offset-side);
	}

	.pcc-fab-right {
		right: var(--pcc-fab-offset-side);
	}

	.pcc-fab-label {
		display: none;
	}
}