/* =========================================================================
   Jackery Product Compare — styling.
   Wykorzystuje tokeny child theme przez fallback var().
   ========================================================================= */
:root {
	--jpc-accent: var(--jp-accent, #f2581c);
	--jpc-ink: var(--jp-ink, #111114);
	--jpc-ink-mid: var(--jp-ink-mid, #5e5e66);
	--jpc-ink-soft: var(--jp-ink-soft, #93939b);
	--jpc-bg: var(--jp-bg, #f6f4ef);
	--jpc-surface: var(--jp-surface, #ffffff);
	--jpc-line: var(--jp-line, #e5e2da);
	--jpc-line-strong: var(--jp-line-strong, #d4d0c5);
	--jpc-display: var(--jp-display, "Space Grotesk", ui-sans-serif, system-ui, sans-serif);
	--jpc-mono: var(--jp-mono, "JetBrains Mono", ui-monospace, monospace);
}

/* -------------------------------------------------------------------------
   Toggle button ⇄ na karcie loop / single
   ------------------------------------------------------------------------- */
.jpc-toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 36px;
	padding: 0 14px;
	border: 1px solid var(--jpc-line);
	background: #fff;
	color: var(--jpc-ink);
	font-family: var(--jpc-display);
	font-size: 13px;
	cursor: pointer;
	border-radius: 0;
	transition: border-color 200ms, background 200ms, color 200ms;
}

.jpc-toggle:hover {
	border-color: var(--jpc-ink);
}

.jpc-toggle.is-on {
	background: var(--jpc-accent);
	border-color: var(--jpc-accent);
	color: #fff;
}

.jp-card__actions .jpc-toggle.is-on,
.jp-card__actions .jpc-toggle.is-on:hover {
	background: var(--jpc-accent) !important;
	border-color: var(--jpc-accent) !important;
	color: #fff !important;
}

.jp-card__actions .jpc-toggle.is-on svg {
	stroke: #fff;
}

/* Kompaktowa wersja tylko z ikoną — w karcie produktu w loop */
ul.products .jpc-toggle:not(:has(span)) {
	width: 36px;
	padding: 0;
	border-radius: 18px;
	justify-content: center;
}

/* -------------------------------------------------------------------------
   Floating bar
   ------------------------------------------------------------------------- */
.jpc-bar {
	position: fixed;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	z-index: 100015;
	background: var(--jpc-surface);
	color: var(--jpc-ink);
	font-family: var(--jpc-display);
	padding: 14px 20px;
	display: flex;
	align-items: center;
	gap: 24px;
	border: 1px solid var(--jpc-line);
	box-shadow: 0 12px 40px rgba(17, 17, 20, 0.12);
	max-width: calc(100vw - 32px);
}

.jpc-bar[hidden] {
	display: none;
}

.jpc-bar__icon {
	color: var(--jpc-accent);
	font-size: 18px;
}

.jpc-bar__count {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13.5px;
}

.jpc-bar__thumbs {
	display: flex;
	gap: 8px;
}

.jpc-bar__thumb {
	width: 40px;
	height: 40px;
	background: var(--jpc-bg);
	border: 1px solid var(--jpc-line);
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

.jpc-bar__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.jpc-bar__thumb:hover::after {
	content: "×";
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	background: rgba(0, 0, 0, 0.7);
	color: #fff;
	font-size: 20px;
}

.jpc-bar__actions {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-left: auto;
}

.jpc-bar__clear {
	background: transparent;
	border: none;
	color: var(--jpc-ink-mid);
	font-family: var(--jpc-display);
	font-size: 13px;
	cursor: pointer;
	text-decoration: underline;
}

.jpc-bar__clear:hover {
	color: var(--jpc-ink);
}

@media (max-width: 720px) {
	.jpc-bar {
		left: 16px;
		right: 16px;
		transform: none;
		flex-direction: column;
		align-items: flex-start;
	}

	.jpc-bar__actions {
		margin-left: 0;
		width: 100%;
		justify-content: space-between;
	}

	.jpc-bar__thumbs {
		flex-wrap: wrap;
	}
}

/* -------------------------------------------------------------------------
   Strona porównywarki — jasny układ (jak PLP / kalkulator)
   ------------------------------------------------------------------------- */
.jpc-compare-page {
	background: transparent;
	color: var(--jpc-ink);
	padding: 0 0 clamp(48px, 8vw, 80px);
	font-family: var(--jpc-display);
	min-height: 40vh;
}

body.jp-jackery-stack .jpc-compare-page {
	padding-top: 0;
}

.jpc-compare-page__label {
	display: inline-flex;
	gap: 10px;
	font-family: var(--jpc-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--jpc-ink-mid);
}

.jpc-compare-page__title {
	font-size: clamp(32px, 5vw, 56px);
	font-weight: 500;
	letter-spacing: -0.03em;
	line-height: 1;
	margin: 16px 0 32px;
	color: var(--jpc-ink);
	max-width: 880px;
}

.jpc-compare-page__actions {
	margin-bottom: 24px;
}

.jpc-clear {
	background: transparent;
	border: 1px solid var(--jpc-line-strong);
	color: var(--jpc-ink-mid);
	font-family: var(--jpc-display);
	font-size: 13px;
	padding: 8px 14px;
	cursor: pointer;
}

.jpc-clear:hover {
	border-color: var(--jpc-ink);
	color: var(--jpc-ink);
}

.jpc-compare-page__empty {
	padding: 48px;
	background: var(--jpc-surface);
	border: 1px solid var(--jpc-line);
	text-align: center;
	color: var(--jpc-ink-mid);
}

.jpc-arrow {
	display: inline-grid;
	place-items: center;
	width: 28px;
	height: 28px;
	margin: 0 6px;
	border-radius: 14px;
	background: var(--jpc-accent);
	color: #fff;
}

.jpc-table {
	background: var(--jpc-surface);
	border: 1px solid var(--jpc-line);
}

.jpc-table__row {
	display: grid;
	grid-template-columns: 1.3fr repeat(var(--cols, 4), 1fr);
	border-bottom: 1px solid var(--jpc-line);
}

.jpc-table__row:last-child {
	border-bottom: none;
}

.jpc-table__cell {
	padding: 16px 24px;
	border-left: 1px solid var(--jpc-line);
	font-family: var(--jpc-mono);
	font-size: 13px;
	color: var(--jpc-ink);
	display: flex;
	align-items: center;
	gap: 8px;
}

.jpc-table__cell:first-child {
	border-left: none;
}

.jpc-table__cell--label {
	color: var(--jpc-ink-soft);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	background: var(--jpc-bg);
}

.jpc-table__cell--best {
	color: var(--jpc-accent);
	font-weight: 600;
}

.jpc-table__star {
	color: var(--jpc-accent);
	font-size: 11px;
}

.jpc-table__row--head .jpc-table__cell {
	padding: 24px;
	display: block;
	position: relative;
}

.jpc-table__remove {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 24px;
	height: 24px;
	border-radius: 12px;
	background: var(--jpc-bg);
	color: var(--jpc-ink-mid);
	border: 1px solid var(--jpc-line);
	cursor: pointer;
	font-size: 14px;
	line-height: 1;
}

.jpc-table__remove:hover {
	background: var(--jpc-accent);
	border-color: var(--jpc-accent);
	color: #fff;
}

.jpc-table__media {
	aspect-ratio: 1/1;
	background: var(--jpc-bg);
	border: 1px solid var(--jpc-line);
	margin-bottom: 14px;
	overflow: hidden;
}

.jpc-table__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.jpc-compare-page .jpc-img-slot {
	display: grid;
	place-items: center;
	width: 100%;
	height: 100%;
	color: var(--jpc-ink-soft);
	font-family: var(--jpc-mono);
	font-size: 10.5px;
	letter-spacing: 0.06em;
	background-image: repeating-linear-gradient(135deg, var(--jpc-line) 0 1px, transparent 1px 14px);
}

.jpc-table__sku {
	font-family: var(--jpc-mono);
	font-size: 10.5px;
	color: var(--jpc-ink-soft);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.jpc-table__name {
	font-family: var(--jpc-display);
	font-size: 18px;
	font-weight: 500;
	letter-spacing: -0.02em;
	margin: 4px 0 12px;
}

.jpc-table__name a {
	color: var(--jpc-ink);
	text-decoration: none;
}

.jpc-table__name a:hover {
	color: var(--jpc-accent);
}

.jpc-table__price {
	font-family: var(--jpc-display);
	font-size: 20px;
	font-weight: 500;
	margin-bottom: 12px;
	color: var(--jpc-ink);
}

.jpc-table__price .price del {
	color: var(--jpc-ink-soft);
	font-size: 12px;
	text-decoration: line-through;
	margin-right: 8px;
}

.jpc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 18px;
	height: 42px;
	font-family: var(--jpc-display);
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	border: 1px solid transparent;
}

.jpc-btn--solid {
	background: var(--jpc-accent);
	border-color: var(--jpc-accent);
	color: #fff;
	font-weight: 600;
	white-space: nowrap;
}

.jp-has-compare-bar .jpc-notice {
	bottom: 120px;
}

.jpc-btn--solid:hover {
	background: #d94613;
	border-color: #d94613;
}

.jpc-btn--sm {
	height: 36px;
	padding: 0 14px;
	font-size: 13px;
}

.jpc-compare-page__foot {
	margin-top: 32px;
	font-family: var(--jpc-mono);
	font-size: 11px;
	color: var(--jpc-ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

@media (max-width: 999px) {
	.jpc-compare-page {
		padding: 0 0 48px;
	}

	.jpc-table__row {
		grid-template-columns: 1fr;
	}

	.jpc-table__cell {
		border-left: none;
		border-top: 1px solid var(--jpc-line);
	}

	.jpc-table__cell:first-child {
		font-weight: 600;
		color: var(--jpc-accent);
	}

	.jpc-table__row--head .jpc-table__cell {
		padding: 24px;
	}
}

/* -------------------------------------------------------------------------
   Notice (toast)
   ------------------------------------------------------------------------- */
.jpc-notice {
	position: fixed;
	bottom: 100px;
	right: 24px;
	z-index: 200;
	background: var(--jpc-ink);
	color: #fff;
	padding: 12px 18px;
	font-family: var(--jpc-display);
	font-size: 13px;
	opacity: 0;
	transition: opacity 200ms, transform 200ms;
	transform: translateY(8px);
}

.jpc-notice.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.jpc-notice[data-type="error"] {
	background: #4a1f1a;
	color: #ffb39d;
	border: 1px solid #c14d3a;
}

.jpc-notice[data-type="success"] {
	background: #14302a;
	color: #5dd2a3;
	border: 1px solid #1f8a5b;
}
