:root {
	--psap-ink: #172033;
	--psap-font: #172033;
	--psap-primary: #0f766e;
	--psap-secondary: #e85d75;
	--psap-width: 390px;
	--psap-mobile-width: 360px;
	--psap-radius: 22px;
	--psap-muted: #667085;
	--psap-surface: rgba(255, 255, 255, 0.82);
	--psap-border: rgba(23, 32, 51, 0.12);
	--psap-accent: #0f766e;
	--psap-coral: #e85d75;
	--psap-gold: #f6c85f;
}

.psap-root {
	position: fixed;
	z-index: 99999;
	right: max(20px, env(safe-area-inset-right));
	bottom: max(20px, env(safe-area-inset-bottom));
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	color: var(--psap-font);
}

.psap-root--bottom-left {
	right: auto;
	left: max(20px, env(safe-area-inset-left));
}

.psap-root--top-right {
	top: max(20px, env(safe-area-inset-top));
	bottom: auto;
}

.psap-root--top-left {
	top: max(20px, env(safe-area-inset-top));
	right: auto;
	bottom: auto;
	left: max(20px, env(safe-area-inset-left));
}

.psap-fab,
.psap-icon-button,
.psap-actions button,
.psap-product button,
.psap-cart-item button {
	border: 0;
	cursor: pointer;
	font: inherit;
}

.psap-fab {
	position: relative;
	display: grid;
	place-items: center;
	width: 64px;
	height: 64px;
	border-radius: var(--psap-radius);
	color: #fff;
	background: linear-gradient(135deg, var(--psap-primary), #243b53 58%, var(--psap-secondary));
	box-shadow: 0 18px 48px rgba(15, 118, 110, 0.32);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.psap-root--button-small .psap-fab {
	width: 54px;
	height: 54px;
}

.psap-root--button-large .psap-fab {
	width: 74px;
	height: 74px;
}

.psap-root.no-shadows .psap-fab,
.psap-root.no-shadows .psap-panel {
	box-shadow: none;
}

.psap-fab:hover,
.psap-root.is-open .psap-fab {
	transform: translateY(-2px) scale(1.02);
	box-shadow: 0 22px 56px rgba(23, 32, 51, 0.34);
}

.psap-fab__glow {
	position: absolute;
	inset: -8px;
	border-radius: 28px;
	background: rgba(246, 200, 95, 0.16);
	opacity: 0;
	transition: opacity 180ms ease;
}

.psap-root.is-listening .psap-fab__glow {
	animation: psap-pulse 1.35s ease infinite;
	opacity: 1;
}

.psap-root.is-listening
[data-psap-command="voice"]{

	box-shadow:
		0 0 0 2px #14b8a6,
		0 0 12px #14b8a6,
		0 0 24px #14b8a6;

	transition:
		box-shadow .25s ease;

}

.psap-icon {
	width: 26px;
	height: 26px;
	fill: currentColor;
}

.psap-fab__text {
	position: absolute;
	right: 76px;
	max-width: 150px;
	overflow: hidden;
	padding: 8px 10px;
	border-radius: 8px;
	background: rgba(23, 32, 51, 0.86);
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.psap-root--bottom-left .psap-fab__text,
.psap-root--top-left .psap-fab__text {
	right: auto;
	left: 76px;
}

.psap-cart-count {
	position: absolute;
	top: -7px;
	right: -7px;
	display: grid;
	min-width: 24px;
	height: 24px;
	padding: 0 7px;
	place-items: center;
	border-radius: 999px;
	color: #172033;
	background: var(--psap-gold);
	font-size: 12px;
	font-weight: 800;
}

.psap-panel {
	position: absolute;
	right: 0;
	bottom: 78px;
	width: min(var(--psap-width), calc(100vw - 32px));
	max-height: min(680px, calc(100vh - 118px));
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.46);
	border-radius: 8px;
	background: var(--psap-surface);
	box-shadow: 0 28px 80px rgba(23, 32, 51, 0.28);
	backdrop-filter: blur(22px) saturate(150%);
	opacity: 0;
	pointer-events: none;
	transform: translateY(16px) scale(0.98);
	transform-origin: bottom right;
	transition: opacity 180ms ease, transform 180ms ease;
}

.psap-root.no-glass .psap-panel {
	background: #fff;
	backdrop-filter: none;
}

.psap-root--mode-dark .psap-panel {
	--psap-surface: rgba(20, 28, 42, 0.9);
	--psap-border: rgba(255, 255, 255, 0.13);
	--psap-muted: #b8c0cc;
	color: #f8fafc;
}

.psap-root--mode-dark .psap-search input,
.psap-root--mode-dark .psap-status-line,
.psap-root--mode-dark .psap-product,
.psap-root--mode-dark .psap-cart-item {
	background: rgba(255, 255, 255, 0.08);
	color: #f8fafc;
}

.psap-root--bottom-left .psap-panel {
	right: auto;
	left: 0;
	transform-origin: bottom left;
}

.psap-root--top-right .psap-panel,
.psap-root--top-left .psap-panel {
	top: 78px;
	bottom: auto;
	transform-origin: top right;
}

.psap-root--top-left .psap-panel {
	right: auto;
	left: 0;
	transform-origin: top left;
}

.psap-root.is-open .psap-panel {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}

.psap-panel__header {
	display: flex;
	align-items: start;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 18px 14px;
	border-bottom: 1px solid var(--psap-border);
	background: linear-gradient(135deg, rgba(15, 118, 110, 0.12), rgba(232, 93, 117, 0.1));
}

.psap-kicker,
.psap-panel h2,
.psap-empty {
	margin: 0;
}

.psap-kicker {
	color: var(--psap-primary);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
}

.psap-panel h2 {
	margin-top: 4px;
	font-size: 20px;
	line-height: 1.2;
}

.psap-icon-button {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	padding: 0;
	line-height: 1;
	position: relative;
	border-radius: 18px;
	color: var(--psap-ink);
	background: rgba(255,255,255,.75);
	backdrop-filter: blur(14px);
	overflow: hidden;
}

.psap-icon-button--accent {
	color: #fff;
	background: var(--psap-primary);
}

.psap-panel__body {
	display: grid;
	gap: 14px;
	max-height: calc(min(680px, 100vh - 118px) - 84px);
	overflow: auto;
	padding: 16px;
}

.psap-status-line {
	padding: 10px 12px;
	border: 1px solid var(--psap-border);
	border-radius: 8px;
	color: var(--psap-muted);
	background: rgba(255, 255, 255, 0.58);
	font-size: 13px;
}

.psap-search {
	display: grid;

	grid-template-columns:
		minmax(0, 1fr)
		42px
		46px;

	gap: 8px;

	align-items: center;
}

.psap-search-clear {

	display: flex;
	align-items: center;
	justify-content: center;

	width: 42px;
	height: 42px;

	border: 1px solid rgba(255,255,255,.4);

	border-radius: 12px;

	background: rgba(255,255,255,.7);

	color: var(--psap-muted);

	font-size: 20px;
	font-weight: 700;

	cursor: pointer;

	transition:
		transform .2s ease,
		background .2s ease,
		color .2s ease;
}

.psap-search-clear:hover {

	transform: scale(1.05);

	background: rgba(255,255,255,.9);

	color: #ef4444;
}

.psap-search input {
	width: 100%;
	min-width: 0;
	border: 1px solid var(--psap-border);
	border-radius: 8px;
	padding: 11px 12px;
	background: rgba(255, 255, 255, 0.86);
	color: var(--psap-ink);
	font: inherit;
}

.psap-actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

.psap-actions button,
.psap-product button,
.psap-cart-item button {
	border-radius: 8px;
	background: rgba(15, 118, 110, 0.1);
	color: var(--psap-primary);
	font-size: 13px;
	font-weight: 800;
}

.psap-actions button {
	min-height: 42px;
	padding: 8px 10px;
	position:relative;
	overflow:hidden;
}

.psap-results,
.psap-cart {
	display: grid;
	gap: 10px;
}

.psap-product,
.psap-cart-item {
	display: grid;
	grid-template-columns: 54px minmax(0, 1fr) auto;
	gap: 10px;
	align-items: center;
	padding: 10px;
	border: 1px solid var(--psap-border);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.64);
}

.psap-product img,
.psap-cart-item img,
.psap-product__placeholder {
	display: block;
	width: 54px;
	height: 54px;
	border-radius: 8px;
	object-fit: cover;
	background: linear-gradient(135deg, rgba(15, 118, 110, 0.18), rgba(246, 200, 95, 0.24));
}

.psap-product__name {
	display: block;
	overflow: hidden;
	color: var(--psap-ink);
	font-weight: 800;
	text-decoration: none;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.psap-product__price,
.psap-cart-item span,
.psap-empty {
	color: var(--psap-muted);
	font-size: 13px;
}

.psap-product button {
	min-height: 34px;
	padding: 8px 12px;
}

.psap-cart__top {
	display: flex;
	justify-content: space-between;
	gap: 12px;
}

.psap-cart-item {
	grid-template-columns: 44px minmax(0, 1fr) 32px 32px auto;
}

.psap-cart-item img,
.psap-cart-item .psap-product__placeholder {
	width: 44px;
	height: 44px;
}

.psap-cart-item strong {
	display: block;
	overflow: hidden;
	font-size: 13px;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.psap-cart-item button {
	min-height: 30px;
	padding: 6px 8px;
}

@keyframes psap-pulse {
	0% {
		transform: scale(0.92);
		opacity: 0.4;
	}

	70% {
		transform: scale(1.16);
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

@keyframes psap-float {
	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-6px);
	}
}

.psap-root--animation-float .psap-fab {
	animation: psap-float 3s ease-in-out infinite;
}

.psap-root--animation-glow .psap-fab__glow,
.psap-root--animation-pulse .psap-fab__glow {
	animation: psap-pulse 1.8s ease infinite;
	opacity: 1;
}

.psap-root--animation-none .psap-fab,
.psap-root--animation-none .psap-fab__glow {
	animation: none;
}

@media (max-width: 480px) {
	.psap-root {
		right: 16px;
		bottom: 16px;
		left: 16px;
	}

	.psap-root--bottom-left {
		left: 16px;
	}

	.psap-fab {
		margin-left: auto;
	}

	.psap-root--bottom-left .psap-fab {
		margin-right: auto;
		margin-left: 0;
	}

	.psap-panel,
	.psap-root--bottom-left .psap-panel {
		right: 0;
		left: 0;
		width: min(var(--psap-mobile-width), 100%);
	}

	.psap-actions {
		grid-template-columns: 1fr;
	}
}

/* Premium AI UI upgrade layer. Kept at the end so theme CSS loses politely. */
.psap-root {
	--psap-cart-hover-color: #f6c85f;
	--psap-glass-bg: linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(244, 250, 255, 0.68));
	--psap-glass-edge: rgba(255, 255, 255, 0.72);
	--psap-neon-primary: color-mix(in srgb, var(--psap-primary) 74%, #7dd3fc);
	--psap-neon-secondary: color-mix(in srgb, var(--psap-secondary) 76%, #fef08a);
	--psap-control-shadow: 0 12px 34px rgba(15, 23, 42, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.74);
	isolation: isolate;
	font-size: 14px;
	line-height: 1.4;
	text-rendering: geometricPrecision;
}

.psap-root *,
.psap-root *::before,
.psap-root *::after {
	box-sizing: border-box;
}

.psap-root button,
.psap-root input {
	appearance: none;
	box-shadow: none;
	letter-spacing: 0;
}

.psap-panel {
	border-color: rgba(255, 255, 255, 0.58);
	background:
		radial-gradient(circle at 16% 0%, color-mix(in srgb, var(--psap-primary) 24%, transparent), transparent 36%),
		radial-gradient(circle at 100% 18%, color-mix(in srgb, var(--psap-secondary) 18%, transparent), transparent 34%),
		var(--psap-glass-bg);
	box-shadow: 0 34px 98px rgba(2, 6, 23, 0.34), 0 14px 44px rgba(15, 118, 110, 0.18);
	backdrop-filter: blur(26px) saturate(180%);
	-webkit-backdrop-filter: blur(26px) saturate(180%);
}

.psap-panel::before {
	position: absolute;
	inset: 0;
	z-index: -1;
	border-radius: inherit;
	background: linear-gradient(115deg, rgba(255, 255, 255, 0.42), transparent 31%, rgba(255, 255, 255, 0.22) 57%, transparent 76%);
	content: "";
	pointer-events: none;
}

.psap-panel__header {
	position: relative;
	overflow: hidden;
	border-bottom-color: rgba(255, 255, 255, 0.38);
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--psap-primary) 20%, transparent), transparent 48%),
		linear-gradient(230deg, color-mix(in srgb, var(--psap-secondary) 18%, transparent), transparent 54%);
}

.psap-panel__header::after {
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 0%, rgba(255, 255, 255, 0.36) 42%, transparent 62%);
	content: "";
	opacity: 0.52;
	transform: translateX(-72%);
	animation: psap-shine 5.8s ease-in-out infinite;
	pointer-events: none;
}

.psap-kicker {
	color: var(--psap-neon-primary);
	letter-spacing: 0.08em;
}

.psap-panel h2 {
	color: var(--psap-font);
	font-weight: 850;
}

.psap-root--mode-dark .psap-panel {
	--psap-glass-bg: linear-gradient(145deg, rgba(15, 23, 42, 0.91), rgba(17, 24, 39, 0.78));
	--psap-glass-edge: rgba(255, 255, 255, 0.18);
	box-shadow: 0 34px 98px rgba(0, 0, 0, 0.48), 0 18px 48px color-mix(in srgb, var(--psap-primary) 24%, transparent);
}

.psap-icon-button {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.54);
	color: var(--psap-font);
	background: rgba(255, 255, 255, 0.64);
	box-shadow: var(--psap-control-shadow);
	backdrop-filter: blur(14px) saturate(160%);
	-webkit-backdrop-filter: blur(14px) saturate(160%);
	transition: transform 160ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

.psap-icon-button::before {
	position: absolute;
	inset: -45%;
	background: conic-gradient(from 140deg, transparent, rgba(255, 255, 255, 0.55), transparent, color-mix(in srgb, var(--psap-primary) 30%, transparent), transparent);
	content: "";
	opacity: 0;
	transform: rotate(0deg) scale(0.74);
	transition: opacity 180ms ease, transform 260ms ease;
}

.psap-icon-button svg {
	position: relative;
	z-index: 1;
	transition: transform 170ms ease;
	width:22px;
	height:22px;
	display:block;
	flex-shrink:0;
}

.psap-icon-button:hover,
.psap-icon-button:focus-visible {
	border-color: color-mix(in srgb, var(--psap-primary) 58%, rgba(255, 255, 255, 0.55));
	background: rgba(255, 255, 255, 0.82);
	box-shadow: 0 18px 44px rgba(15, 23, 42, 0.18), 0 0 0 4px color-mix(in srgb, var(--psap-primary) 14%, transparent), 0 0 34px color-mix(in srgb, var(--psap-primary) 28%, transparent);
	transform: translateY(-1px) scale(1.03);
}

.psap-icon-button:hover::before,
.psap-icon-button:focus-visible::before {
	opacity: 1;
	transform: rotate(50deg) scale(1);
}

.psap-icon-button:hover svg,
.psap-icon-button:focus-visible svg {
	transform: scale(1.12) rotate(-4deg);
}

.psap-icon-button:active {
	box-shadow: 0 9px 22px rgba(15, 23, 42, 0.16), inset 0 2px 8px rgba(15, 23, 42, 0.13);
	transform: translateY(1px) scale(0.96);
	transition-duration: 90ms;
}

.psap-icon-button:active svg {
	transform: scale(0.92) rotate(4deg);
}

.psap-panel [data-psap-close] {
	border-radius: 12px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.44)),
		color-mix(in srgb, var(--psap-secondary) 10%, transparent);
	box-shadow: 0 16px 38px rgba(15, 23, 42, 0.18), 0 0 22px color-mix(in srgb, var(--psap-secondary) 16%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.psap-panel [data-psap-close]:hover,
.psap-panel [data-psap-close]:focus-visible {
	color: #fff;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--psap-secondary) 84%, #fff), color-mix(in srgb, var(--psap-primary) 54%, var(--psap-secondary))),
		var(--psap-secondary);
	box-shadow: 0 20px 48px color-mix(in srgb, var(--psap-secondary) 36%, transparent), 0 0 0 4px color-mix(in srgb, var(--psap-secondary) 16%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.psap-status-line {
	position: relative;
	overflow: hidden;
	padding: 13px 15px;
	border-color: color-mix(in srgb, var(--psap-primary) 18%, rgba(255, 255, 255, 0.58));
	border-radius: 14px;
	color: color-mix(in srgb, var(--psap-font) 78%, var(--psap-primary));
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.44)),
		linear-gradient(90deg, color-mix(in srgb, var(--psap-primary) 10%, transparent), color-mix(in srgb, var(--psap-secondary) 10%, transparent));
	box-shadow: 0 14px 38px rgba(15, 23, 42, 0.11), inset 0 1px 0 rgba(255, 255, 255, 0.78);
	backdrop-filter: blur(16px) saturate(165%);
	-webkit-backdrop-filter: blur(16px) saturate(165%);
	animation: psap-breathe 4.4s ease-in-out infinite;
}

.psap-status-line::after {
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 8%, rgba(255, 255, 255, 0.72) 44%, transparent 68%);
	content: "";
	transform: translateX(-110%);
	animation: psap-status-shine 4.8s ease-in-out infinite;
	pointer-events: none;
}

.psap-root.is-listening .psap-status-line,
.psap-status-line:focus-within {
	box-shadow: 0 16px 42px rgba(15, 23, 42, 0.14), 0 0 0 4px color-mix(in srgb, var(--psap-primary) 15%, transparent), 0 0 34px color-mix(in srgb, var(--psap-primary) 22%, transparent);
}

.psap-search {
	grid-template-columns: minmax(0, 1fr) 46px;
	gap: 10px;
	align-items: center;
}

.psap-search input {
	min-height: 46px;
	border-color: color-mix(in srgb, var(--psap-primary) 16%, rgba(255, 255, 255, 0.62));
	border-radius: 14px;
	padding: 12px 14px;
	background: rgba(255, 255, 255, 0.78);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72), 0 12px 28px rgba(15, 23, 42, 0.09);
	outline: 0;
	transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease, transform 180ms ease;
}

.psap-search input:hover {
	border-color: color-mix(in srgb, var(--psap-primary) 32%, rgba(255, 255, 255, 0.56));
	background: rgba(255, 255, 255, 0.88);
}

.psap-search input:focus {
	border-color: color-mix(in srgb, var(--psap-primary) 72%, #fff);
	background: rgba(255, 255, 255, 0.94);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--psap-primary) 16%, transparent), 0 18px 40px rgba(15, 23, 42, 0.13);
	transform: translateY(-1px);
}

.psap-icon-button--accent {
	width: 46px;
	height: 46px;
	border-color: color-mix(in srgb, var(--psap-primary) 54%, rgba(255, 255, 255, 0.48));
	color: #fff;
	background: linear-gradient(145deg, var(--psap-neon-primary), color-mix(in srgb, var(--psap-secondary) 42%, var(--psap-primary)));
	box-shadow: 0 18px 42px color-mix(in srgb, var(--psap-primary) 30%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.psap-actions button,
.psap-product button,
.psap-cart-item button {
	border: 1px solid color-mix(in srgb, var(--psap-primary) 15%, rgba(255, 255, 255, 0.5));
	background: linear-gradient(145deg, color-mix(in srgb, var(--psap-primary) 12%, rgba(255, 255, 255, 0.74)), rgba(255, 255, 255, 0.48));
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.09), inset 0 1px 0 rgba(255, 255, 255, 0.7);
	transition: transform 160ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

.psap-actions button:hover,
.psap-product button:hover,
.psap-cart-item button:hover,
.psap-actions button:focus-visible,
.psap-product button:focus-visible,
.psap-cart-item button:focus-visible {
	border-color: color-mix(in srgb, var(--psap-primary) 44%, rgba(255, 255, 255, 0.5));
	background: linear-gradient(145deg, color-mix(in srgb, var(--psap-primary) 18%, rgba(255, 255, 255, 0.82)), color-mix(in srgb, var(--psap-secondary) 10%, rgba(255, 255, 255, 0.6)));
	box-shadow: 0 16px 34px rgba(15, 23, 42, 0.13), 0 0 26px color-mix(in srgb, var(--psap-primary) 18%, transparent);
	transform: translateY(-1px);
}

.psap-actions button:active,
.psap-product button:active,
.psap-cart-item button:active {
	transform: translateY(1px) scale(0.98);
}

.psap-product,
.psap-cart-item {
	border-color: rgba(255, 255, 255, 0.5);
	border-radius: 14px;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.48));
	box-shadow: 0 14px 34px rgba(15, 23, 42, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.74);
	backdrop-filter: blur(14px) saturate(155%);
	-webkit-backdrop-filter: blur(14px) saturate(155%);
	transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.psap-product:hover,
.psap-cart-item:hover,
.psap-product:focus-within,
.psap-cart-item:focus-within {
	border-color: color-mix(in srgb, var(--psap-primary) 28%, rgba(255, 255, 255, 0.58));
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(255, 255, 255, 0.55));
	box-shadow: 0 20px 44px rgba(15, 23, 42, 0.15), 0 0 28px color-mix(in srgb, var(--psap-primary) 12%, transparent);
	transform: translateY(-2px);
}

.psap-product__name,
.psap-cart-item__name {
	color: var(--psap-font);
	text-decoration: none;
	transition: color 160ms ease, text-shadow 180ms ease, transform 180ms ease;
}

.psap-product__name:hover,
.psap-cart-item__name:hover,
.psap-product__name:focus-visible,
.psap-cart-item__name:focus-visible {
	color: var(--psap-cart-hover-color);
	text-shadow: 0 0 18px color-mix(in srgb, var(--psap-cart-hover-color) 42%, transparent);
	transform: translateX(2px);
}

.psap-cart-item__name {
	display: block;
	overflow: hidden;
	font-size: 13px;
	font-weight: 850;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.psap-cart-item span {
	display: block;
	margin-top: 2px;
}

.psap-cart-item button[data-psap-increase],
.psap-cart-item button[data-psap-decrease] {
	width: 32px;
	height: 32px;
	min-height: 32px;
	padding: 0;
	border-radius: 10px;
	font-size: 16px;
	line-height: 1;
}

.psap-root--mode-dark .psap-status-line,
.psap-root--mode-dark .psap-search input,
.psap-root--mode-dark .psap-product,
.psap-root--mode-dark .psap-cart-item,
.psap-root--mode-dark .psap-icon-button {
	border-color: rgba(255, 255, 255, 0.16);
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.06));
	color: #f8fafc;
}

.psap-root--mode-dark .psap-product__name,
.psap-root--mode-dark .psap-cart-item__name,
.psap-root--mode-dark .psap-search input {
	color: #f8fafc;
}

.psap-root.no-glass .psap-panel,
.psap-root.no-glass .psap-status-line,
.psap-root.no-glass .psap-search input,
.psap-root.no-glass .psap-product,
.psap-root.no-glass .psap-cart-item,
.psap-root.no-glass .psap-icon-button {
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}

@keyframes psap-shine {
	0%,
	56% {
		transform: translateX(-72%);
	}

	78%,
	100% {
		transform: translateX(72%);
	}
}

@keyframes psap-status-shine {
	0%,
	48% {
		transform: translateX(-110%);
	}

	78%,
	100% {
		transform: translateX(110%);
	}
}

@keyframes psap-breathe {
	0%,
	100% {
		box-shadow: 0 14px 38px rgba(15, 23, 42, 0.11), inset 0 1px 0 rgba(255, 255, 255, 0.78);
	}

	50% {
		box-shadow: 0 16px 42px rgba(15, 23, 42, 0.14), 0 0 28px color-mix(in srgb, var(--psap-primary) 14%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.82);
	}
}

@media (prefers-reduced-motion: reduce) {
	.psap-panel__header::after,
	.psap-status-line,
	.psap-status-line::after {
		animation: none;
	}

	.psap-root *,
	.psap-root *::before,
	.psap-root *::after {
		transition-duration: 0.01ms !important;
	}
}

@media (max-width: 480px) {
	.psap-panel__body {
		gap: 12px;
		padding: 14px;
	}

	.psap-search {
		grid-template-columns: minmax(0, 1fr) 44px;
	}

	.psap-search input,
	.psap-icon-button--accent {
		min-height: 44px;
		height: 44px;
	}

	.psap-cart-item {
		grid-template-columns: 42px minmax(0, 1fr) 30px 30px;
	}

	.psap-cart-item button[data-psap-remove] {
		grid-column: 2 / -1;
		justify-self: start;
	}
}
.psap-transcript{
	margin:10px 0;
	padding:10px;
	border-radius:8px;
	font-size:13px;
	line-height:1.5;
	min-height:40px;
	background:#f8f8f8;
	word-break:break-word;
}
.psap-recommendations{
	margin-top:20px;
	padding-top:15px;
	border-top:1px solid #ddd;
}

.psap-recommendations h4{
	margin-bottom:10px;
	font-size:14px;
	font-weight:600;
}