/* ============================================================
 *  KodyPodarunkowe - main stylesheet (Cyber Neon)
 *  Palette is injected as inline CSS variables (see inc/enqueue.php).
 * ============================================================ */

/* ---------- RESET / BASE ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	font-size: 16px;
	line-height: 1.55;
	color: var(--kp-text);
	background: var(--kp-bg);
	background-image:
		radial-gradient(800px 400px at 90% -100px, rgba(176, 38, 255, 0.18), transparent 70%),
		radial-gradient(700px 400px at -10% 30%, rgba(0, 240, 255, 0.10), transparent 70%);
	background-attachment: fixed;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
svg { max-width: 100%; height: auto; display: inline-block; vertical-align: middle; }
a { color: var(--kp-accent-2); text-decoration: none; transition: color .15s; }
a:hover { color: var(--kp-accent-1); }
button { font-family: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--kp-accent-2); outline-offset: 2px; border-radius: 6px; }

h1, h2, h3, h4, .kp-h1, .kp-h2 {
	font-family: 'Rajdhani', 'Inter', sans-serif;
	font-weight: 700;
	letter-spacing: .01em;
	line-height: 1.15;
	margin: 0 0 .6em;
	color: var(--kp-text);
}
.kp-h1 { font-size: clamp(1.9rem, 4vw, 3rem); }
.kp-h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
h3 { font-size: 1.25rem; }

p { margin: 0 0 1em; }
.kp-lede { font-size: 1.1rem; color: var(--kp-text-mute); }

.screen-reader-text { position: absolute !important; left: -9999px; }
.kp-skip {
	position: absolute; left: -9999px; top: 0; z-index: 999;
	background: var(--kp-accent-1); color: #fff; padding: .5rem 1rem;
}
.kp-skip:focus { left: 1rem; top: 1rem; }

/* ---------- LAYOUT ---------- */
.kp-container { max-width: 1240px; margin: 0 auto; padding: 0 1.25rem; }
.kp-container--narrow { max-width: 880px; }
.kp-container--wide   { max-width: 1180px; }
.kp-section { padding: clamp(2.5rem, 7vw, 5rem) 0; }
.kp-section__head { text-align: center; margin-bottom: 2.5rem; }
.kp-section__head .kp-h2 { margin-bottom: .35em; }
.kp-section__sub { color: var(--kp-text-mute); max-width: 640px; margin: 0 auto; }
.kp-section__foot { text-align: center; margin-top: 2.25rem; }

/* ---------- HEADER ---------- */
.kp-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(10, 14, 39, .85);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid rgba(255, 255, 255, .07);
}
.kp-header__strip {
	background: linear-gradient(90deg, var(--kp-accent-1), var(--kp-accent-2));
	color: #fff; font-size: .82rem;
}
.kp-header__strip-inner {
	display: flex; justify-content: space-between; align-items: center;
	min-height: 32px; gap: 1rem;
}
.kp-header__strip-inner > span { display: inline-flex; align-items: center; gap: .4rem; }
.kp-header__strip svg { width: 16px; height: 16px; flex-shrink: 0; }

.kp-header__main {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1.5rem; padding: .85rem 1.25rem;
}
.kp-logo { display: inline-flex; align-items: center; gap: .55rem; color: var(--kp-text); }
.kp-logo:hover { color: var(--kp-text); }
.kp-logo img { max-height: 44px; width: auto; }
.kp-logo__mark {
	display: inline-grid; place-items: center;
	width: 38px; height: 38px; border-radius: 10px;
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	color: #fff; box-shadow: 0 4px 18px rgba(176, 38, 255, .35);
}
.kp-logo__mark svg { width: 22px; height: 22px; }
.kp-logo__text {
	font-family: 'Rajdhani', sans-serif; font-weight: 700; font-size: 1.2rem;
	text-transform: uppercase; letter-spacing: .05em;
	background: linear-gradient(90deg, var(--kp-accent-2), #fff);
	-webkit-background-clip: text; background-clip: text; color: transparent;
}

.kp-nav { flex: 1; display: flex; justify-content: center; }
.kp-nav__list {
	display: flex; gap: 1.5rem; list-style: none; margin: 0; padding: 0;
}
.kp-nav__list a {
	color: var(--kp-text); font-weight: 500; font-size: .95rem;
	padding: .5rem 0; position: relative;
}
.kp-nav__list a::after {
	content: ''; position: absolute; left: 0; bottom: 0; width: 0; height: 2px;
	background: linear-gradient(90deg, var(--kp-accent-1), var(--kp-accent-2));
	transition: width .25s;
}
.kp-nav__list a:hover { color: var(--kp-accent-2); }
.kp-nav__list a:hover::after { width: 100%; }

.kp-header__actions { display: flex; align-items: center; gap: .25rem; }
.kp-icon-btn {
	display: inline-grid; place-items: center;
	width: 40px; height: 40px;
	background: transparent; color: var(--kp-text); border: 0; border-radius: 10px;
	transition: background .2s, color .2s;
	position: relative;
	text-decoration: none;
}
.kp-icon-btn:hover { background: rgba(255, 255, 255, .07); color: var(--kp-accent-2); }
.kp-icon-btn svg { width: 22px; height: 22px; }
.kp-icon-btn--menu { display: none; }

.kp-cart-count {
	position: absolute; top: 4px; right: 4px;
	min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px;
	background: var(--kp-accent-1); color: #fff; font-size: .7rem; font-weight: 700;
	display: grid; place-items: center; line-height: 1;
}

.kp-search-bar { padding: .75rem 0; border-top: 1px solid rgba(255,255,255,.07); }
.kp-search { display: flex; align-items: center; gap: .5rem; max-width: 720px; margin: 0 auto;
	background: rgba(255,255,255,.05); border-radius: 12px; padding: .35rem .35rem .35rem 1rem;
	border: 1px solid rgba(255,255,255,.08); }
.kp-search input { flex: 1; background: transparent; border: 0; color: var(--kp-text); font-size: 1rem; padding: .5rem 0; outline: 0; }
.kp-search button { background: var(--kp-accent-1); border: 0; color: #fff; padding: .5rem .75rem; border-radius: 9px; }
.kp-search button:hover { background: var(--kp-accent-2); color: var(--kp-bg); }

/* ---------- BUTTONS / BADGES ---------- */
.kp-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
	padding: .85rem 1.5rem; border-radius: 12px; font-weight: 600; font-size: 1rem;
	text-decoration: none; border: 0; cursor: pointer; transition: transform .15s, box-shadow .2s, filter .2s;
}
.kp-btn--primary {
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	color: #fff; box-shadow: 0 6px 24px rgba(176, 38, 255, .35);
}
.kp-btn--primary:hover { transform: translateY(-1px); filter: brightness(1.1); color: #fff; }
.kp-btn--ghost { background: transparent; color: var(--kp-text); border: 1px solid rgba(255,255,255,.18); }
.kp-btn--ghost:hover { border-color: var(--kp-accent-2); color: var(--kp-accent-2); }

.kp-cta-row { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 1.5rem; }
.kp-link { color: var(--kp-accent-2); font-weight: 600; }
.kp-link:hover { color: var(--kp-accent-1); }

.kp-badge {
	display: inline-block; padding: .35rem .85rem; border-radius: 999px;
	font-size: .82rem; font-weight: 600; letter-spacing: .03em;
	background: rgba(176, 38, 255, .15); color: var(--kp-accent-1);
	border: 1px solid rgba(176, 38, 255, .35);
}
.kp-badge--alt { background: rgba(0, 240, 255, .12); color: var(--kp-accent-2); border-color: rgba(0, 240, 255, .35); }

/* ---------- HERO ---------- */
.kp-hero {
	position: relative; isolation: isolate;
	padding: clamp(3rem, 9vw, 7rem) 0;
	background-color: var(--kp-bg-alt);
	background-size: cover; background-position: center; background-repeat: no-repeat;
	overflow: hidden;
}
.kp-hero::before {
	content: ''; position: absolute; inset: 0;
	background:
		radial-gradient(700px 400px at 80% 20%, rgba(176, 38, 255, .35), transparent 60%),
		radial-gradient(500px 320px at 10% 80%, rgba(0, 240, 255, .25), transparent 60%);
	z-index: 0;
}
.kp-hero__overlay {
	position: absolute; inset: 0; z-index: 1;
	background: linear-gradient(90deg, var(--kp-bg) 0%, rgba(10,14,39,.72) 35%, rgba(10,14,39,.30) 100%);
}
.kp-hero__inner { position: relative; z-index: 2; }
.kp-hero__content { max-width: 640px; }
.kp-hero__title {
	font-family: 'Rajdhani', sans-serif; font-weight: 700;
	font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.1;
	margin: 1rem 0;
	background: linear-gradient(120deg, #fff 0%, var(--kp-accent-2) 60%, var(--kp-accent-1) 100%);
	-webkit-background-clip: text; background-clip: text; color: transparent;
}
.kp-hero__lead { font-size: 1.1rem; color: var(--kp-text-mute); max-width: 540px; }
.kp-hero__bullets {
	list-style: none; padding: 0; margin: 2rem 0 0;
	display: flex; flex-wrap: wrap; gap: 1.25rem; color: var(--kp-text-mute); font-size: .92rem;
}
.kp-hero__bullets li { display: inline-flex; align-items: center; gap: .4rem; }
.kp-hero__bullets svg { width: 18px; height: 18px; color: var(--kp-accent-2); }

/* ---------- TRUST BAR ---------- */
.kp-trust { padding: 1.75rem 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.kp-trust__grid {
	display: grid; gap: 1.25rem;
	grid-template-columns: repeat(4, 1fr);
}
.kp-trust__item {
	display: flex; align-items: center; gap: .75rem;
	padding: .75rem 1rem; background: rgba(255,255,255,.03);
	border: 1px solid rgba(255,255,255,.06); border-radius: 14px;
}
.kp-trust__icon {
	display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 10px;
	background: linear-gradient(135deg, rgba(176,38,255,.25), rgba(0,240,255,.25));
	color: var(--kp-accent-2); flex-shrink: 0;
}
.kp-trust__icon svg { width: 22px; height: 22px; }
.kp-trust__item strong { display: block; font-size: .98rem; }
.kp-trust__item span { color: var(--kp-text-mute); font-size: .85rem; }

/* ---------- CATEGORIES ---------- */
.kp-cats__grid {
	display: grid; gap: 1rem;
	grid-template-columns: repeat(4, 1fr);
}
.kp-cat {
	display: flex; flex-direction: column; align-items: center; text-align: center;
	gap: .35rem; padding: 1.5rem 1rem;
	background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
	border: 1px solid rgba(255,255,255,.07); border-radius: 18px;
	color: var(--kp-text); transition: transform .25s, border-color .25s, box-shadow .25s;
}
.kp-cat:hover { transform: translateY(-4px); border-color: rgba(0,240,255,.4); box-shadow: 0 12px 30px rgba(0,240,255,.12); color: var(--kp-text); }
.kp-cat__icon {
	display: inline-grid; place-items: center; width: 56px; height: 56px; border-radius: 14px;
	background: linear-gradient(135deg, rgba(176,38,255,.22), rgba(0,240,255,.22));
	color: var(--kp-accent-2); margin-bottom: .35rem;
}
.kp-cat__icon svg { width: 30px; height: 30px; }
.kp-cat__title { font-family: 'Rajdhani', sans-serif; font-size: 1.15rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.kp-cat__sub { font-size: .85rem; color: var(--kp-text-mute); }

/* ---------- PROMO BANNER ---------- */
.kp-promo {
	margin: clamp(2rem, 6vw, 4rem) 0;
}
.kp-promo__inner {
	display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; justify-content: space-between;
	padding: 2rem; border-radius: 22px;
	background: linear-gradient(135deg, rgba(176,38,255,.18), rgba(0,240,255,.10));
	border: 1px solid rgba(176,38,255,.30);
	position: relative; overflow: hidden;
}
.kp-promo__inner::before {
	content: ''; position: absolute; right: -80px; top: -80px; width: 280px; height: 280px;
	background: radial-gradient(circle, rgba(0,240,255,.4), transparent 60%);
	pointer-events: none;
}
.kp-promo__text { max-width: 720px; position: relative; }
.kp-promo h2 { margin-top: .5rem; }
.kp-promo p { color: var(--kp-text-mute); margin-bottom: 0; }

/* ---------- PRODUCT GRIDS ---------- */
.kp-grid { display: grid; gap: 1.25rem; }
.kp-grid--products { grid-template-columns: repeat(4, 1fr); }
.kp-grid--posts { grid-template-columns: repeat(3, 1fr); }

ul.products { list-style: none; padding: 0; margin: 0; }

.kp-product, li.kp-product {
	background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
	border: 1px solid rgba(255,255,255,.07); border-radius: 18px;
	overflow: hidden; transition: transform .25s, border-color .25s, box-shadow .25s;
	display: flex; flex-direction: column;
}
.kp-product:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(0,0,0,.35); }

/* Kontener miniaturki — zawsze kwadratowy, ale niezależnie od proporcji obrazu:
   1. blurred wariant w tle (wypełnia cały kwadrat)
   2. ostry obraz na wierzchu w pełnym widoku (object-fit: contain — nic nie ucinamy) */
.kp-product__media {
	position: relative;
	display: block;
	aspect-ratio: 1/1;
	overflow: hidden;
	background: linear-gradient(135deg, rgba(176,38,255,.10), rgba(0,240,255,.06));
}
.kp-product__media::before {
	content: '';
	position: absolute;
	inset: -8%;
	background-image: var(--kp-thumb, none);
	background-size: cover;
	background-position: center;
	filter: blur(22px) saturate(1.4) brightness(.55);
	transform: scale(1.1);
	z-index: 0;
	transition: transform .4s ease;
}
.kp-product__media img {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: .65rem;
	box-sizing: border-box;
	display: block;
	transition: transform .25s ease;
}
.kp-product:hover .kp-product__media img { transform: scale(1.03); }
.kp-product:hover .kp-product__media::before { transform: scale(1.15); }
/* Placeholder gdy brak obrazu */
.kp-product__media:not([style*="--kp-thumb"])::before {
	background-image: linear-gradient(135deg, rgba(176,38,255,.18), rgba(0,240,255,.12));
	filter: blur(0);
	opacity: .6;
}
.kp-product__badge {
	position: absolute; top: 12px; left: 12px;
	background: var(--kp-accent-1); color: #fff;
	font-size: .72rem; font-weight: 700; padding: .25rem .6rem; border-radius: 6px;
	letter-spacing: .05em; text-transform: uppercase;
	box-shadow: 0 4px 16px rgba(176,38,255,.4);
}
.kp-product__body { padding: 1rem 1rem .25rem; flex: 1; }
.kp-product__title { font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 600; margin: 0 0 .5rem; line-height: 1.35; }
.kp-product__title a { color: var(--kp-text); }
.kp-product__title a:hover { color: var(--kp-accent-2); }
.kp-product__price { font-family: 'Rajdhani', sans-serif; font-size: 1.4rem; font-weight: 700; color: var(--kp-accent-2); margin-bottom: .5rem; }
.kp-product__price del { color: var(--kp-text-mute); font-size: 1rem; opacity: .7; margin-right: .35rem; }
.kp-product__price ins { background: transparent; text-decoration: none; }
.kp-product__cart { padding: 0 1rem 1rem; }
.kp-product__cart .button, .kp-product__cart .added_to_cart {
	display: block; width: 100%; text-align: center;
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	color: #fff; padding: .7rem 1rem; border-radius: 10px; font-weight: 600; font-size: .92rem;
	border: 0; transition: filter .2s, transform .15s;
}
.kp-product__cart .button:hover { filter: brightness(1.15); transform: translateY(-1px); color: #fff; }

/* ---------- HOW IT WORKS ---------- */
.kp-howto { background: linear-gradient(180deg, transparent, rgba(176,38,255,.05) 50%, transparent); }
.kp-steps {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; counter-reset: kp-step;
}
.kp-step {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 18px; padding: 1.5rem; position: relative;
}
.kp-step__num {
	font-family: 'Rajdhani', sans-serif; font-weight: 700; font-size: 2.5rem;
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	-webkit-background-clip: text; background-clip: text; color: transparent;
	display: block; margin-bottom: .25rem; line-height: 1;
}
.kp-step__title { font-size: 1.1rem; margin-bottom: .35rem; }
.kp-step__desc { color: var(--kp-text-mute); font-size: .92rem; margin: 0; }

/* ---------- FAQ ---------- */
.kp-faq__list { display: flex; flex-direction: column; gap: .65rem; }
.kp-faq__item {
	background: rgba(255,255,255,.03);
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 14px; padding: 0;
	transition: border-color .2s;
}
.kp-faq__item[open] { border-color: rgba(0,240,255,.4); }
.kp-faq__item summary {
	cursor: pointer; padding: 1.1rem 1.4rem; font-weight: 600; font-size: 1.05rem;
	list-style: none; position: relative; padding-right: 3rem;
}
.kp-faq__item summary::after {
	content: '+'; position: absolute; right: 1.4rem; top: 50%; transform: translateY(-50%);
	font-size: 1.4rem; color: var(--kp-accent-2); transition: transform .25s;
}
.kp-faq__item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.kp-faq__item summary::-webkit-details-marker { display: none; }
.kp-faq__answer { padding: 0 1.4rem 1.2rem; color: var(--kp-text-mute); }
.kp-faq__answer p:last-child { margin-bottom: 0; }

/* ---------- FOOTER ---------- */
.kp-footer { margin-top: 4rem; background: #060819; border-top: 1px solid rgba(255,255,255,.06); }
.kp-footer__top {
	display: grid; grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: 2rem; padding: 3.5rem 1.25rem 2.5rem;
}
.kp-footer__brand .kp-logo { margin-bottom: 1rem; }
.kp-footer__about { color: var(--kp-text-mute); font-size: .92rem; max-width: 420px; }
.kp-footer__company { white-space: pre-line; color: var(--kp-text-mute); font-size: .85rem; }
.kp-footer__col h4 { font-family: 'Rajdhani', sans-serif; text-transform: uppercase; letter-spacing: .08em; font-size: .92rem; color: var(--kp-text); margin-bottom: 1rem; }
.kp-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.kp-footer__list a { color: var(--kp-text-mute); font-size: .92rem; }
.kp-footer__list a:hover { color: var(--kp-accent-2); }
.kp-footer__contact p { font-size: .92rem; margin-bottom: .5rem; color: var(--kp-text-mute); display: flex; align-items: center; gap: .4rem; }
.kp-footer__contact svg { width: 16px; height: 16px; color: var(--kp-accent-2); flex-shrink: 0; }
.kp-footer__contact .kp-footer__hours { display: block; }
.kp-footer__hours { font-size: .82rem; }
.kp-pay-icons { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.kp-pay-icons span {
	display: inline-block; padding: .25rem .65rem; font-size: .78rem; font-weight: 600;
	background: rgba(255,255,255,.07); border-radius: 6px; color: var(--kp-text);
}

.kp-footer__bottom { background: #03050f; padding: 1.25rem 0; }
.kp-footer__bottom-inner { display: flex; flex-direction: column; gap: .5rem; font-size: .82rem; color: var(--kp-text-mute); }
.kp-disclaimer { font-style: italic; }

/* ---------- 404 ---------- */
.kp-404 { text-align: center; padding-top: 5rem; padding-bottom: 6rem; }
.kp-404__code {
	font-family: 'Rajdhani', sans-serif; font-size: clamp(5rem, 18vw, 11rem); font-weight: 700;
	line-height: 1;
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	-webkit-background-clip: text; background-clip: text; color: transparent;
	margin-bottom: 1rem;
}
.kp-404__inner .kp-cta-row { justify-content: center; margin: 1.5rem 0 2.5rem; }

/* ---------- PROSE / PAGES ---------- */
.kp-prose { font-size: 1.02rem; }
.kp-prose h2 { margin-top: 2rem; }
.kp-prose ul, .kp-prose ol { padding-left: 1.5rem; }
.kp-prose li { margin-bottom: .35rem; }
.kp-prose a { text-decoration: underline; }

.kp-page-header { margin-bottom: 2rem; }
.kp-meta { color: var(--kp-text-mute); font-size: .9rem; }

/* ---------- SHOP — archive-product.php / taxonomy-product_cat ---------- */
.kp-shop__head { margin-bottom: 1.5rem; }
.kp-shop__title { margin-bottom: .5rem; }
.kp-shop .term-description, .kp-shop .woocommerce-archive-description {
	color: var(--kp-text-mute); max-width: 720px;
}

.kp-shop__toolbar {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; flex-wrap: wrap;
	margin-bottom: 1.5rem;
}
.kp-shop .woocommerce-result-count {
	margin: 0; color: var(--kp-text-mute); font-size: .92rem;
}
.kp-shop .woocommerce-ordering {
	margin: 0;
}
.kp-shop .woocommerce-ordering select {
	background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.12);
	color: var(--kp-text);
	border-radius: 10px;
	padding: .55rem .85rem;
	font-size: .92rem;
	min-width: 220px;
}
.kp-shop .woocommerce-ordering select:focus {
	border-color: var(--kp-accent-2);
	outline: 0;
	box-shadow: 0 0 0 3px rgba(0,240,255,.18);
}

.kp-shop .woocommerce-notices-wrapper:empty { display: none; }

.kp-shop nav.woocommerce-pagination ul { display: flex; gap: .35rem; padding: 0; margin: 2rem 0 0; justify-content: center; list-style: none; border: 0; }
.kp-shop nav.woocommerce-pagination ul li { margin: 0; }
.kp-shop nav.woocommerce-pagination ul li a, .kp-shop nav.woocommerce-pagination ul li span {
	display: inline-grid; place-items: center; min-width: 38px; height: 38px; padding: 0 .65rem;
	border-radius: 10px; background: rgba(255,255,255,.05); color: var(--kp-text); border: 0;
	text-decoration: none;
}
.kp-shop nav.woocommerce-pagination ul li a:hover { background: rgba(0,240,255,.15); color: var(--kp-accent-2); }
.kp-shop nav.woocommerce-pagination ul li .current { background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2)); color: #fff; }

/* ---------- SINGLE PRODUCT ----------
   Zostawiamy WC default float-layout (gallery left 48%, summary right 48%).
   Po `.product::after { clear: both }` kolejne sekcje (tabs, related) są pod. */
body.single-product div.product {
	clear: both;
}
body.single-product div.product::after {
	content: '';
	display: block;
	clear: both;
}
body.single-product .woocommerce-product-gallery {
	float: left;
	width: 48%;
	max-width: 48%;
	border-radius: 18px;
	overflow: hidden;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.07);
	padding: 1rem;
	box-sizing: border-box;
}
body.single-product .woocommerce-product-gallery__image img {
	border-radius: 12px;
	width: 100%;
	height: auto;
}
body.single-product .summary,
body.single-product .entry-summary {
	float: right;
	width: 48%;
	max-width: 48%;
	box-sizing: border-box;
}
body.single-product .product_title {
	font-family: 'Rajdhani', sans-serif;
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	margin: 0 0 1rem;
	line-height: 1.15;
	color: var(--kp-text);
}
body.single-product .price,
body.single-product .price .amount,
body.single-product .price .amount bdi,
body.single-product .price ins,
body.single-product .price ins .amount,
body.single-product .price ins .amount bdi,
body.single-product .price .woocommerce-Price-amount,
body.single-product .price .woocommerce-Price-currencySymbol {
	color: var(--kp-accent-2) !important;
}
body.single-product .price {
	font-family: 'Rajdhani', sans-serif;
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 1.5rem;
}
body.single-product .price del,
body.single-product .price del .amount,
body.single-product .price del .amount bdi {
	color: var(--kp-text-mute) !important;
	font-size: 1.1rem;
	opacity: .7;
	margin-right: .5rem;
}
body.single-product .price ins {
	background: transparent;
	text-decoration: none;
}
body.single-product .woocommerce-product-details__short-description {
	color: var(--kp-text-mute);
	margin-bottom: 1.5rem;
	line-height: 1.6;
}
body.single-product form.cart {
	display: flex;
	gap: .75rem;
	align-items: center;
	margin-bottom: 2rem;
}
body.single-product form.cart .quantity input.qty {
	background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.12);
	color: var(--kp-text);
	border-radius: 10px;
	padding: .65rem .85rem;
	width: 80px;
	text-align: center;
}
body.single-product form.cart button.single_add_to_cart_button,
body.single-product form.cart .button {
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2)) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 12px !important;
	padding: .85rem 1.75rem !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
	box-shadow: 0 6px 24px rgba(176,38,255,.35) !important;
	transition: transform .15s, filter .2s !important;
}
body.single-product form.cart button.single_add_to_cart_button:hover {
	transform: translateY(-1px);
	filter: brightness(1.1);
}
body.single-product .product_meta {
	color: var(--kp-text-mute);
	font-size: .9rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(255,255,255,.07);
}
body.single-product .product_meta a { color: var(--kp-accent-2); }
body.single-product .product_meta > span { display: block; margin-bottom: .25rem; }

body.single-product .woocommerce-tabs {
	margin-top: 3rem;
	grid-column: 1 / -1;
}
body.single-product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: .25rem;
	list-style: none;
	margin: 0 0 0 !important;
	padding: 0 !important;
	border-bottom: 1px solid rgba(255,255,255,.07);
}
body.single-product .woocommerce-tabs ul.tabs::before, body.single-product .woocommerce-tabs ul.tabs::after { display: none !important; }
body.single-product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}
body.single-product .woocommerce-tabs ul.tabs li a {
	display: inline-block;
	padding: .85rem 1.25rem !important;
	color: var(--kp-text-mute) !important;
	font-weight: 600;
	border-bottom: 2px solid transparent;
	transition: color .15s, border-color .15s;
}
body.single-product .woocommerce-tabs ul.tabs li.active a {
	color: var(--kp-accent-2) !important;
	border-color: var(--kp-accent-2);
}
body.single-product .woocommerce-tabs .panel {
	padding: 1.5rem 0;
	color: var(--kp-text-mute);
}

/* Sekcje related / upsells — full width pod single-product, bez ramki */
.kp-related,
.kp-upsells,
.kp-product-description {
	grid-column: 1 / -1;
	margin-top: 2rem;
	padding: 2.5rem 0 0 !important;
	background: transparent !important;
	border: 0 !important;
	clear: both;
}
.kp-product-description__content {
	color: var(--kp-text-mute);
	line-height: 1.7;
	max-width: 760px;
}
.kp-product-description__content p { margin-bottom: 1em; }
.kp-product-description__content h2,
.kp-product-description__content h3 {
	color: var(--kp-text);
	margin-top: 1.5em;
}
.kp-product-description__content ul,
.kp-product-description__content ol { padding-left: 1.5rem; }
.kp-related__title {
	font-family: 'Rajdhani', sans-serif;
	font-size: 1.6rem;
	font-weight: 700;
	margin: 0 0 1.5rem;
	color: var(--kp-text);
}
.kp-related ul.products,
.kp-upsells ul.products {
	background: transparent !important;
	border: 0 !important;
}
.kp-related .kp-grid--products,
.kp-upsells .kp-grid--products {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
}

/* Zabezpieczenie przed nested ramkami (block-template czasami dodaje wrapper) */
body.single-product .related,
body.single-product .upsells,
body.single-product .wp-block-woocommerce-related-products,
body.single-product .woocommerce-related-products,
body.single-product section.related {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	box-shadow: none !important;
}

@media (max-width: 768px) {
	body.single-product .woocommerce-product-gallery,
	body.single-product .summary,
	body.single-product .entry-summary {
		float: none;
		width: 100%;
		max-width: 100%;
	}
}

/* Badge "Promocja!" — przeciwko domyślnemu żółtemu */
body.single-product .onsale,
.woocommerce span.onsale {
	background: var(--kp-accent-1) !important;
	color: #fff !important;
	border-radius: 6px !important;
	font-size: .72rem !important;
	font-weight: 700 !important;
	letter-spacing: .05em !important;
	text-transform: uppercase !important;
	padding: .25rem .65rem !important;
	min-height: 0 !important;
	min-width: 0 !important;
	line-height: 1.3 !important;
	box-shadow: 0 4px 16px rgba(176,38,255,.4) !important;
	top: 12px !important;
	left: 12px !important;
	right: auto !important;
	margin: 0 !important;
}

/* Sekcja Opinie — pola formularza, gwiazdki, tekst */
body.single-product .woocommerce-Reviews,
body.single-product #reviews {
	color: var(--kp-text);
}
body.single-product #reviews input[type=text],
body.single-product #reviews input[type=email],
body.single-product #reviews input[type=url],
body.single-product #reviews textarea {
	background: rgba(255,255,255,.05) !important;
	border: 1px solid rgba(255,255,255,.12) !important;
	color: var(--kp-text) !important;
	border-radius: 10px !important;
	padding: .65rem .85rem !important;
	width: 100%;
	max-width: 540px;
}
body.single-product #reviews textarea {
	max-width: 100%;
	min-height: 120px;
	font-family: inherit;
}
body.single-product #reviews input:focus,
body.single-product #reviews textarea:focus {
	border-color: var(--kp-accent-2) !important;
	outline: 0 !important;
	box-shadow: 0 0 0 3px rgba(0,240,255,.18) !important;
}
body.single-product #reviews .stars a {
	color: var(--kp-text-mute);
}
body.single-product #reviews .stars a:hover,
body.single-product #reviews .stars a.active {
	color: var(--kp-accent-2);
}
body.single-product .star-rating::before,
body.single-product .star-rating span::before {
	color: var(--kp-accent-2);
}
body.single-product #reviews #submit,
body.single-product #reviews .submit {
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2)) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 10px !important;
	padding: .7rem 1.5rem !important;
	font-weight: 600 !important;
}
body.single-product #reviews .comment-form-cookies-consent {
	display: flex;
	gap: .5rem;
	align-items: flex-start;
	color: var(--kp-text-mute);
	font-size: .9rem;
}
body.single-product #reviews label {
	color: var(--kp-text-mute);
}

/* Etykieta promocyjnego cennika */
.kp-product__price ins,
.kp-product__price del {
	display: inline-block;
}

/* WooCommerce ogólne */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	background: rgba(0,240,255,.08); border-left: 4px solid var(--kp-accent-2);
	color: var(--kp-text); padding: 1rem 1.25rem; border-radius: 8px; margin-bottom: 1.5rem;
}
.woocommerce-error { background: rgba(255,80,80,.08); border-color: #ff5050; }

.kp-checkbox { display: flex; gap: .55rem; align-items: flex-start; font-size: .92rem; color: var(--kp-text-mute); }
.kp-checkbox input { margin-top: .25rem; }

/* Info-belka „Produkt wyślemy na Twój e-mail" — na górze checkoutu */
.kp-checkout-info {
	display: flex; align-items: center; gap: .65rem;
	padding: .9rem 1.1rem;
	background: linear-gradient(135deg, rgba(176,38,255,.10), rgba(0,240,255,.08));
	border: 1px solid rgba(0,240,255,.30);
	border-radius: 12px;
	color: var(--kp-text);
	font-size: .98rem;
	margin: 0 0 1.5rem;
}
.kp-checkout-info svg { width: 22px; height: 22px; color: var(--kp-accent-2); flex-shrink: 0; }

/* ---------- WOOCOMMERCE — checkout / cart / account ---------- */
.kp-section--wc { padding-top: clamp(2rem, 4vw, 3rem); }
.kp-section--wc .kp-page-header { margin-bottom: 1.5rem; }

/* Block-based checkout (WC 8+) — przedefiniowanie proporcji kolumn.
   Domyślnie WC robi sidebar ~30% i main ~70% — chcemy main ~58% / sidebar ~42% i większy gap. */
.kp-section--wc .wp-block-woocommerce-checkout,
.kp-section--wc .wp-block-woocommerce-cart {
	max-width: 100%;
}

.kp-section--wc .wc-block-components-sidebar-layout {
	gap: clamp(1.5rem, 3vw, 2.5rem) !important;
	align-items: flex-start;
}

.kp-section--wc .wc-block-components-main {
	flex: 1 1 58% !important;
	min-width: 0;
}

.kp-section--wc .wc-block-components-sidebar {
	flex: 0 1 420px !important;
	min-width: 360px !important;
	max-width: 460px !important;
	background: rgba(255,255,255,.03);
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 14px;
	padding: 1.5rem !important;
}

.kp-section--wc .wc-block-components-order-summary__content {
	min-width: 0;
}

/* Karta produktu w sidebarze — daj jej miejsce, żeby opis nie zwijał się po 1 słowie */
.kp-section--wc .wc-block-components-order-summary-item {
	display: grid !important;
	grid-template-columns: 56px 1fr auto;
	gap: 1rem;
	align-items: start;
}
.kp-section--wc .wc-block-components-order-summary-item__image {
	width: 56px; height: 56px; flex-shrink: 0;
}
.kp-section--wc .wc-block-components-order-summary-item__description p {
	margin: .25rem 0 0;
	font-size: .85rem;
	color: var(--kp-text-mute);
}

/* Inputy — ciemny styl pasujący do motywu */
.kp-section--wc input[type=text],
.kp-section--wc input[type=email],
.kp-section--wc input[type=tel],
.kp-section--wc input[type=number],
.kp-section--wc input[type=password],
.kp-section--wc select,
.kp-section--wc textarea,
.kp-section--wc .wc-block-components-text-input input {
	background: rgba(255,255,255,.04) !important;
	border: 1px solid rgba(255,255,255,.12) !important;
	color: var(--kp-text) !important;
	border-radius: 10px !important;
}
.kp-section--wc input:focus,
.kp-section--wc select:focus,
.kp-section--wc textarea:focus,
.kp-section--wc .wc-block-components-text-input input:focus {
	border-color: var(--kp-accent-2) !important;
	outline: 0 !important;
	box-shadow: 0 0 0 3px rgba(0,240,255,.18) !important;
}
.kp-section--wc .wc-block-components-text-input label {
	color: var(--kp-text-mute) !important;
}

/* Combobox (kraj, region/stan) — to jest custom select WC z własnymi sub-divami,
   trzeba twardego override żeby tło dopasować do inputów. */
.kp-section--wc .wc-block-components-combobox,
.kp-section--wc .wc-block-components-combobox > *,
.kp-section--wc .wc-block-components-combobox-control,
.kp-section--wc .wc-block-components-combobox-control > *,
.kp-section--wc .wc-block-components-form-control,
.kp-section--wc .wc-block-components-form-control > *,
.kp-section--wc .components-base-control,
.kp-section--wc .components-base-control > *,
.kp-section--wc .components-form-token-field,
.kp-section--wc .components-form-token-field > *,
.kp-section--wc .components-flex,
.kp-section--wc .components-input-control__container,
.kp-section--wc .components-input-control__backdrop {
	background: rgba(255,255,255,.04) !important;
	background-color: rgba(255,255,255,.04) !important;
	box-shadow: none !important;
}
.kp-section--wc .wc-block-components-combobox,
.kp-section--wc .wc-block-components-combobox-control,
.kp-section--wc .wc-block-components-form-control {
	border: 1px solid rgba(255,255,255,.12) !important;
	color: var(--kp-text) !important;
	border-radius: 10px !important;
	overflow: hidden;
}
.kp-section--wc .wc-block-components-combobox input,
.kp-section--wc .wc-block-components-combobox-control input,
.kp-section--wc .components-combobox-control__suggestions-container input,
.kp-section--wc .components-form-token-field__input-container input {
	background: transparent !important;
	color: var(--kp-text) !important;
	border: 0 !important;
	box-shadow: none !important;
}
.kp-section--wc .wc-block-components-combobox label,
.kp-section--wc .components-base-control__label,
.kp-section--wc .wc-block-components-form-control label {
	color: var(--kp-text-mute) !important;
	background: transparent !important;
}
.kp-section--wc .wc-block-components-combobox::after,
.kp-section--wc .wc-block-components-combobox-control::after {
	color: var(--kp-text-mute) !important;
}

/* Strzałka SVG po prawej */
.kp-section--wc .wc-block-components-combobox svg,
.kp-section--wc .components-form-token-field__suggestions-list + svg,
.kp-section--wc select + svg {
	color: var(--kp-text-mute) !important;
	fill: currentColor !important;
}

/* Wewnętrzny pseudo-input wc-block-components-combobox-control wraps an input.
   WP Combobox z @wordpress/components dostaje swoje style z .components-* klas. */
.kp-section--wc .components-combobox-control,
.kp-section--wc .components-base-control {
	background: transparent !important;
}
.kp-section--wc .components-form-token-field {
	background: rgba(255,255,255,.04) !important;
	border: 1px solid rgba(255,255,255,.12) !important;
	border-radius: 10px !important;
	color: var(--kp-text) !important;
	padding: .65rem .85rem !important;
}
.kp-section--wc .components-form-token-field__input-container {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
}

/* Lista sugestii dropdownu — ciemna */
.components-form-token-field__suggestions-list,
.wc-block-components-combobox-list,
.components-combobox-control__suggestions-container ul {
	background: var(--kp-bg-alt) !important;
	border: 1px solid rgba(255,255,255,.12) !important;
	border-radius: 10px !important;
	color: var(--kp-text) !important;
	max-height: 240px;
	overflow-y: auto;
}
.components-form-token-field__suggestion {
	padding: .5rem .85rem !important;
	color: var(--kp-text) !important;
}
.components-form-token-field__suggestion.is-selected,
.components-form-token-field__suggestion:hover {
	background: rgba(176,38,255,.18) !important;
	color: var(--kp-accent-2) !important;
}

/* Floating label trick używany przez WC — żeby tło etykiety nad polem nie było białe */
.kp-section--wc .wc-block-components-text-input label,
.kp-section--wc .wc-block-components-combobox label {
	background: var(--kp-bg) !important;
	padding: 0 .35rem !important;
}

/* Karta z tytułem sekcji */
.kp-section--wc .wc-block-components-checkout-step {
	background: transparent !important;
	padding-left: 0 !important;
}
.kp-section--wc .wc-block-components-title {
	color: var(--kp-text) !important;
	font-family: 'Rajdhani', sans-serif;
}

/* Główny przycisk „Zamawiam" */
.kp-section--wc .wc-block-components-checkout-place-order-button,
.kp-section--wc .wc-block-cart__submit-button {
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2)) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 12px !important;
	font-weight: 600 !important;
	box-shadow: 0 6px 24px rgba(176,38,255,.35) !important;
}

/* Mobile — sidebar ląduje pod */
@media (max-width: 900px) {
	.kp-section--wc .wc-block-components-sidebar-layout {
		flex-direction: column !important;
	}
	.kp-section--wc .wc-block-components-main,
	.kp-section--wc .wc-block-components-sidebar {
		flex: 1 1 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
	}
}

/* ---------- CLASSIC CHECKOUT (shortcode) ----------
   Lewa kolumna = Dane rozliczeniowe + Płatność + zgody + przycisk
   Prawa kolumna = Twoje zamówienie (heading + tabela)        */
.woocommerce-checkout form.checkout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
	grid-template-areas:
		"customer summary"
		"payment  summary";
	column-gap: clamp(1.5rem, 3vw, 2.5rem);
	row-gap: 1.5rem;
	align-items: start;
}
.woocommerce-checkout #customer_details {
	grid-area: customer;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.woocommerce-checkout .kp-payment-wrap {
	grid-area: payment;
}
.woocommerce-checkout .kp-summary-wrap {
	grid-area: summary;
	background: rgba(255,255,255,.03);
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 14px;
	padding: 1.4rem 1.5rem 1.5rem;
	align-self: start;
}
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	width: 100%;
	max-width: 100%;
	float: none;
	margin: 0;
	padding: 0;
}
/* Heading i review znajdują się wewnątrz .kp-summary-wrap (wrapper z PHP),
   więc same nie potrzebują tła ani ramek — zostają „nagie". */
.woocommerce-checkout #order_review_heading {
	margin: 0 0 .85rem;
	padding: 0;
	font-family: 'Rajdhani', sans-serif;
	font-size: 1.4rem;
	background: transparent;
	border: 0;
}
.woocommerce-checkout #order_review {
	background: transparent;
	border: 0;
	padding: 0;
}

.woocommerce-checkout h3 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 1.3rem;
	margin: 0 0 1rem;
	color: var(--kp-text);
}

/* Pola formularza */
.woocommerce-checkout .form-row {
	margin: 0 0 1rem;
	padding: 0;
}
.woocommerce-checkout .form-row label {
	display: block;
	margin-bottom: .35rem;
	color: var(--kp-text-mute);
	font-size: .9rem;
}
.woocommerce-checkout .form-row .required {
	color: var(--kp-accent-1);
	text-decoration: none;
	margin-left: .15rem;
}
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea {
	width: 100%;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	color: var(--kp-text);
	border-radius: 10px;
	padding: .85rem 1rem;
	font-family: inherit;
	font-size: 1rem;
	box-shadow: none;
}
.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus {
	border-color: var(--kp-accent-2);
	outline: 0;
	box-shadow: 0 0 0 3px rgba(0,240,255,.18);
}
.woocommerce-checkout .form-row-first { width: calc(50% - .5rem); float: left; margin-right: 1rem; }
.woocommerce-checkout .form-row-last  { width: calc(50% - .5rem); float: left; }
.woocommerce-checkout .form-row-wide  { clear: both; width: 100%; }

/* Tabela podsumowania */
.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1.25rem;
}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: .65rem 0;
	border-bottom: 1px solid rgba(255,255,255,.07);
	text-align: left;
	font-size: .95rem;
}
.woocommerce-checkout-review-order-table .product-total,
.woocommerce-checkout-review-order-table th:last-child,
.woocommerce-checkout-review-order-table td:last-child { text-align: right; }
.woocommerce-checkout-review-order-table .order-total td,
.woocommerce-checkout-review-order-table .order-total th {
	font-family: 'Rajdhani', sans-serif;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--kp-text);
	border-bottom: 0;
	padding-top: .85rem;
}
.woocommerce-checkout-review-order-table .order-total .amount { color: var(--kp-accent-2); }

/* Metody płatności */
.woocommerce-checkout #payment {
	background: transparent !important;
	border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods {
	padding: 0;
	margin: 0 0 1rem;
	list-style: none;
	border-bottom: 0;
}
.woocommerce-checkout #payment ul.payment_methods li {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 10px;
	padding: .85rem 1rem;
	margin-bottom: .5rem;
}
.woocommerce-checkout #payment ul.payment_methods li input[type=radio] {
	margin-right: .5rem;
}
.woocommerce-checkout #payment ul.payment_methods li label {
	color: var(--kp-text);
	font-weight: 600;
}
.woocommerce-checkout #payment .payment_box {
	background: rgba(0,240,255,.05) !important;
	border-radius: 8px;
	padding: .85rem 1rem;
	margin-top: .5rem;
	color: var(--kp-text-mute);
	font-size: .9rem;
}

/* Polityka + zgody */
.woocommerce-checkout .woocommerce-privacy-policy-text,
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
	color: var(--kp-text-mute);
	font-size: .88rem;
	margin: 1rem 0;
}
.woocommerce-checkout .woocommerce-form__label-for-checkbox {
	display: flex;
	gap: .55rem;
	align-items: flex-start;
	color: var(--kp-text-mute);
}

/* Główny przycisk "Złóż zamówienie" */
.woocommerce-checkout #place_order {
	display: block;
	width: 100%;
	background: linear-gradient(135deg, var(--kp-accent-1), var(--kp-accent-2));
	color: #fff;
	border: 0;
	border-radius: 12px;
	padding: 1rem 1.5rem;
	font-weight: 700;
	font-size: 1.05rem;
	letter-spacing: .02em;
	cursor: pointer;
	box-shadow: 0 6px 24px rgba(176,38,255,.35);
	transition: filter .2s, transform .15s;
}
.woocommerce-checkout #place_order:hover {
	filter: brightness(1.1);
	transform: translateY(-1px);
}

/* Komunikaty */
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
	background: rgba(0,240,255,.08);
	border-left: 4px solid var(--kp-accent-2);
	color: var(--kp-text);
	padding: .85rem 1rem;
	border-radius: 8px;
	margin-bottom: 1rem;
	list-style: none;
}
.woocommerce-checkout .woocommerce-error {
	background: rgba(255,80,80,.08);
	border-left: 4px solid #ff5050;
	color: var(--kp-text);
	padding: .85rem 1rem;
	border-radius: 8px;
	list-style: none;
	margin-bottom: 1rem;
}

/* Wyłączamy domyślną dashicon-ikonkę (niebieski kwadracik) z komunikatów WC */
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before,
.woocommerce-noreviews::before,
p.no-comments::before {
	display: none !important;
	content: none !important;
}

/* Mobile — kolumny pod sobą, sidebar ląduje na końcu */
@media (max-width: 900px) {
	.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr;
		grid-template-areas:
			"customer"
			"summary"
			"payment";
	}
	.woocommerce-checkout .form-row-first,
	.woocommerce-checkout .form-row-last {
		width: 100%;
		float: none;
		margin-right: 0;
	}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
	.kp-grid--products, .kp-cats__grid { grid-template-columns: repeat(3, 1fr); }
	.kp-trust__grid { grid-template-columns: repeat(2, 1fr); }
	.kp-steps { grid-template-columns: repeat(2, 1fr); }
	.kp-grid--posts { grid-template-columns: repeat(2, 1fr); }
	.kp-footer__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
	.kp-nav { display: none; }
	.kp-icon-btn--menu { display: inline-grid; }
	.kp-header__strip-inner { font-size: .75rem; flex-direction: column; min-height: auto; padding: .35rem 0; gap: .15rem; }
	.kp-grid--products, .kp-cats__grid { grid-template-columns: repeat(2, 1fr); }
	.kp-grid--posts { grid-template-columns: 1fr; }
	.kp-promo__inner { flex-direction: column; align-items: flex-start; }

	body.kp-menu-open .kp-nav {
		display: flex; position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; padding: 1rem 1.25rem;
		background: var(--kp-bg-alt); border-bottom: 1px solid rgba(255,255,255,.07);
	}
	body.kp-menu-open .kp-nav__list { flex-direction: column; gap: .25rem; }
	body.kp-menu-open .kp-nav__list a { padding: .65rem 0; border-bottom: 1px solid rgba(255,255,255,.05); }
}
@media (max-width: 480px) {
	.kp-grid--products, .kp-cats__grid { grid-template-columns: 1fr 1fr; }
	.kp-trust__grid, .kp-steps { grid-template-columns: 1fr; }
	.kp-footer__top { grid-template-columns: 1fr; }
	.kp-hero__bullets { flex-direction: column; gap: .5rem; }
}
