/* =============================================================
   pw-design.css — polakw.nl design system v2
   Kolorystyka: fioletowo-różowa (spójna z całą stroną)
   ============================================================= */

/* ── Design tokens ── */
:root {
  --pw-font: 'Inter', 'Poppins', system-ui, sans-serif;
  --pw-dark:    #0f172a;
  --pw-dark2:   #1a1a2e;
  --pw-gray:    #64748b;
  --pw-border:  #ede8f7;
  --pw-light:   #f8f7fc;
  --pw-white:   #ffffff;
  --pw-primary: #a855f7;
  --pw-primary-dark: #9333ea;
  --pw-accent:  #ec4899;
  --pw-green:   #10b981;
  --pw-amber:   #f59e0b;
  --pw-red:     #ef4444;
  --pw-blue:    #2563eb;
  --pw-grad:    linear-gradient(135deg, #a855f7 0%, #ec4899 100%);
  --pw-grad-warm: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);
  --pw-shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --pw-shadow:    0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
  --pw-shadow-lg: 0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);
  --pw-radius:  12px;
  --pw-radius-sm: 8px;
  --pw-radius-lg: 20px;
  --pw-transition: .2s cubic-bezier(.4,0,.2,1);
}

/* ── Base typography ── */
html { scroll-behavior: smooth; }

body,
body p, body span, body a, body li, body td, body th,
body input, body textarea, body select, body button {
  font-family: var(--pw-font) !important;
  -webkit-font-smoothing: antialiased;
}

body {
  color: var(--pw-dark2);
  background: #f8f7fc;
  font-size: 15px;
  line-height: 1.65;
}

a { color: var(--pw-primary); transition: color var(--pw-transition); }
a:hover { color: var(--pw-primary-dark); }
a:focus-visible { outline: 2px solid var(--pw-primary); outline-offset: 3px; }

h1,h2,h3,h4,h5,h6 {
  font-family: var(--pw-font) !important;
  color: var(--pw-dark2);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -.02em;
}

/* ── Header ── */
.site-header,
#masthead {
  background: var(--pw-white) !important;
  border-bottom: 1px solid var(--pw-border) !important;
  box-shadow: 0 2px 12px rgba(168,85,247,.06) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
}

.header-navbar {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
  height: 68px !important;
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
}

/* Logo */
.header-logo,
.header-logo a {
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -.04em !important;
  color: var(--pw-dark2) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.header-logo img {
  height: 36px !important;
  width: auto !important;
}

/* Nav menu */
.header-navbar__menu .menu,
.header-navbar__menu ul {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.header-navbar__menu .menu a,
.header-navbar__menu ul a {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--pw-gray) !important;
  text-decoration: none !important;
  padding: 8px 12px !important;
  border-radius: var(--pw-radius-sm) !important;
  transition: color var(--pw-transition), background var(--pw-transition) !important;
  white-space: nowrap !important;
}

.header-navbar__menu .menu a:hover,
.header-navbar__menu ul a:hover,
.header-navbar__menu .current-menu-item > a,
.header-navbar__menu .current_page_item > a {
  color: var(--pw-primary) !important;
  background: #faf5ff !important;
}

/* "Dodaj ogłoszenie" button in header */
.header-navbar__actions .hp-menu__item--listing-submit > a,
.hp-menu__item--listing-submit > a {
  background: var(--pw-grad) !important;
  color: var(--pw-white) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 9px 20px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  transition: opacity var(--pw-transition), transform var(--pw-transition) !important;
  white-space: nowrap !important;
  box-shadow: 0 4px 14px rgba(168,85,247,.35) !important;
}

.hp-menu__item--listing-submit > a:hover {
  opacity: .9 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(168,85,247,.45) !important;
  color: var(--pw-white) !important;
}

/* ── Main content wrapper ── */
.site-content,
#content,
.hp-page {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 28px 24px !important;
}

/* ── Forms & inputs ── */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="url"],
input[type="tel"],
input[type="search"],
textarea,
select,
.hp-field input,
.hp-field textarea,
.hp-field select,
.woocommerce-input-wrapper input,
.woocommerce-input-wrapper select {
  font-family: var(--pw-font) !important;
  font-size: 15px !important;
  color: var(--pw-dark2) !important;
  background: var(--pw-white) !important;
  border: 2px solid var(--pw-border) !important;
  border-radius: var(--pw-radius-sm) !important;
  padding: 11px 14px !important;
  transition: border-color var(--pw-transition), box-shadow var(--pw-transition) !important;
  width: 100% !important;
  outline: none !important;
  box-shadow: none !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="url"]:focus,
input[type="tel"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus,
.hp-field input:focus,
.hp-field textarea:focus,
.hp-field select:focus {
  border-color: var(--pw-primary) !important;
  box-shadow: 0 0 0 3px rgba(168,85,247,.15) !important;
}

input::placeholder,
textarea::placeholder { color: #94a3b8 !important; }

label,
.hp-field__label {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--pw-dark2) !important;
  margin-bottom: 5px !important;
  display: block !important;
}

/* ── Buttons ── */
.button, button,
input[type="submit"],
.wp-block-button__link,
.hp-button,
.hp-button--primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button {
  font-family: var(--pw-font) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 10px 22px !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: all var(--pw-transition) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
  border: none !important;
  outline: none !important;
}

/* Primary button — gradient fiolet/różowy */
.hp-button--primary,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
form[class*="hp-form"] [type="submit"],
.hp-form__actions [type="submit"],
.pw-buy-btn {
  background: var(--pw-grad) !important;
  color: var(--pw-white) !important;
  box-shadow: 0 4px 14px rgba(168,85,247,.3) !important;
}

.hp-button--primary:hover,
.woocommerce a.button.alt:hover,
form[class*="hp-form"] [type="submit"]:hover,
.hp-form__actions [type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(168,85,247,.4) !important;
  color: var(--pw-white) !important;
}

/* Secondary button */
.hp-button--secondary,
.woocommerce a.button:not(.alt),
.woocommerce button.button:not(.alt) {
  background: transparent !important;
  color: var(--pw-primary) !important;
  border: 2px solid var(--pw-primary) !important;
  box-shadow: none !important;
}

.hp-button--secondary:hover,
.woocommerce a.button:not(.alt):hover {
  background: #faf5ff !important;
  transform: translateY(-1px) !important;
}

/* ── Listing cards (block view) ── */
.hp-listing--view-block,
article.hp-listing {
  background: var(--pw-white) !important;
  border: 1px solid var(--pw-border) !important;
  border-radius: var(--pw-radius) !important;
  overflow: hidden !important;
  transition: transform var(--pw-transition), box-shadow var(--pw-transition), border-color var(--pw-transition) !important;
  box-shadow: var(--pw-shadow-sm) !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

.hp-listing--view-block:hover,
article.hp-listing:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--pw-shadow-lg) !important;
  border-color: #d8b4fe !important;
}

/* Card image */
.hp-listing__image,
.hp-listing--view-block .hp-listing__image {
  position: relative !important;
  overflow: hidden !important;
  background: #f3f0fb !important;
  aspect-ratio: 16/10 !important;
}

.hp-listing__image img,
.hp-listing--view-block .hp-listing__image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform .4s ease !important;
}

.hp-listing--view-block:hover .hp-listing__image img {
  transform: scale(1.06) !important;
}

/* Card content */
.hp-listing__content,
.hp-listing--view-block .hp-listing__content {
  padding: 14px 16px 10px !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

/* Category label */
.hp-listing__categories,
.hp-listing__category,
.hp-listing--view-block .hp-listing__categories {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--pw-primary) !important;
}

.hp-listing__categories a {
  color: var(--pw-primary) !important;
  text-decoration: none !important;
}

/* Card title */
.hp-listing__title,
.hp-listing--view-block .hp-listing__title,
.hp-listing--view-block h2,
.hp-listing--view-block h3 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--pw-dark2) !important;
  line-height: 1.35 !important;
  letter-spacing: -.01em !important;
  margin: 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.hp-listing__title a,
.hp-listing--view-block h2 a,
.hp-listing--view-block h3 a {
  color: var(--pw-dark2) !important;
  text-decoration: none !important;
  transition: color var(--pw-transition) !important;
}

.hp-listing--view-block:hover .hp-listing__title a,
.hp-listing--view-block:hover h2 a {
  color: var(--pw-primary) !important;
}

/* Price — gradient text */
.hp-listing__price,
.hp-listing--view-block .hp-listing__price {
  font-size: 18px !important;
  font-weight: 800 !important;
  background: var(--pw-grad) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  letter-spacing: -.02em !important;
}

/* Price "Za darmo" */
.pw-price-free,
.pw-free-label {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--pw-green) !important;
  -webkit-text-fill-color: var(--pw-green) !important;
}

/* Card details row */
.hp-listing__details,
.hp-listing--view-block .hp-listing__details {
  display: flex !important;
  gap: 12px !important;
  font-size: 12px !important;
  color: var(--pw-gray) !important;
  flex-wrap: wrap !important;
}

/* Card footer */
.hp-listing__footer,
.hp-listing--view-block .hp-listing__footer {
  padding: 10px 16px 12px !important;
  border-top: 1px solid var(--pw-border) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}

.hp-listing__actions a,
.hp-listing__actions button {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--pw-primary) !important;
  background: #faf5ff !important;
  border: none !important;
  padding: 6px 14px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  transition: background var(--pw-transition), transform var(--pw-transition) !important;
  cursor: pointer !important;
}

.hp-listing__actions a:hover,
.hp-listing__actions button:hover {
  background: #f3e8ff !important;
  transform: scale(1.03) !important;
}

/* Featured / promoted badge */
.hp-listing--featured {
  border-color: var(--pw-amber) !important;
  box-shadow: 0 4px 20px rgba(245,158,11,.18) !important;
}

.hp-listing__header { position: relative !important; }

/* ── Listing grid ── */
.hp-listings,
.hp-listings--view-block,
.listings-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 20px !important;
}

/* ── Single listing page ── */
.hp-listing--view-page .hp-listing__title,
.hp-row .hp-listing--view-page h1 {
  font-size: clamp(22px, 3vw, 32px) !important;
  font-weight: 800 !important;
  color: var(--pw-dark2) !important;
  margin-bottom: 12px !important;
}

.hp-listing--view-page .hp-listing__price {
  font-size: 28px !important;
  font-weight: 900 !important;
}

.hp-listing--view-page .hp-listing__description,
.hp-listing--view-page .hp-field--type-textarea .hp-field__value {
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: var(--pw-dark2) !important;
  white-space: pre-wrap !important;
}

.hp-listing__gallery,
.hp-listing--view-page .hp-listing__image {
  border-radius: var(--pw-radius) !important;
  overflow: hidden !important;
  box-shadow: var(--pw-shadow) !important;
  margin-bottom: 20px !important;
}

/* Sidebar contact box */
.hp-page__sidebar .hp-vendor,
.hp-page__sidebar .hp-page__widget,
.hp-page__sidebar > div {
  background: var(--pw-white) !important;
  border: 1px solid var(--pw-border) !important;
  border-radius: var(--pw-radius) !important;
  padding: 20px !important;
  box-shadow: var(--pw-shadow-sm) !important;
  margin-bottom: 20px !important;
}

/* ── Categories grid ── */
.hp-category--view-grid,
.polakw-cat-btn {
  background: var(--pw-white) !important;
  border: 2px solid var(--pw-border) !important;
  border-radius: var(--pw-radius) !important;
  padding: 18px 12px !important;
  text-align: center !important;
  transition: all var(--pw-transition) !important;
  cursor: pointer !important;
  text-decoration: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: var(--pw-shadow-sm) !important;
}

.hp-category--view-grid:hover,
.polakw-cat-btn:hover {
  border-color: var(--pw-primary) !important;
  background: #faf5ff !important;
  transform: translateY(-3px) !important;
  box-shadow: var(--pw-shadow) !important;
}

/* ── Tabs (pw_section_nav) ── */
.pw-tabs-bar {
  background: var(--pw-white) !important;
  border: 1px solid var(--pw-border) !important;
  border-radius: 50px !important;
  padding: 4px !important;
  display: inline-flex !important;
  gap: 2px !important;
  box-shadow: var(--pw-shadow-sm) !important;
  margin-bottom: 24px !important;
}

.pw-tab {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--pw-gray) !important;
  padding: 8px 18px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  transition: all var(--pw-transition) !important;
}

.pw-tab:hover { color: var(--pw-primary) !important; background: #faf5ff !important; }

.pw-tab--active,
.pw-tab.active {
  background: var(--pw-grad) !important;
  color: var(--pw-white) !important;
  box-shadow: 0 2px 8px rgba(168,85,247,.3) !important;
}

/* ── Package cards / cennik ── */
.hp-card,
.hp-cards .hp-card,
.pw-package-card {
  background: var(--pw-white) !important;
  border: 2px solid var(--pw-border) !important;
  border-radius: var(--pw-radius-lg) !important;
  padding: 28px 24px !important;
  transition: all var(--pw-transition) !important;
  box-shadow: var(--pw-shadow-sm) !important;
}

.hp-card:hover,
.pw-package-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--pw-shadow-lg) !important;
  border-color: #d8b4fe !important;
}

.hp-card--highlighted,
.hp-card.popular {
  border-color: var(--pw-primary) !important;
  box-shadow: 0 0 0 4px rgba(168,85,247,.12), var(--pw-shadow) !important;
}

.hp-card__price {
  font-size: 32px !important;
  font-weight: 900 !important;
  background: var(--pw-grad) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* Cennik "Najpopularniejszy" badge */
.hp-card.popular::before {
  background: var(--pw-grad) !important;
}

/* ── WooCommerce ── */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--pw-white) !important;
  border: 1px solid var(--pw-border) !important;
  border-radius: var(--pw-radius) !important;
  overflow: hidden !important;
  transition: all var(--pw-transition) !important;
  box-shadow: var(--pw-shadow-sm) !important;
  padding: 0 !important;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--pw-shadow-lg) !important;
  border-color: #d8b4fe !important;
}

.woocommerce ul.products li.product a img {
  transition: transform .4s ease !important;
}

.woocommerce ul.products li.product:hover a img {
  transform: scale(1.06) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 12px 16px 4px !important;
  color: var(--pw-dark2) !important;
}

.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .woocommerce-Price-amount {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--pw-primary) !important;
  padding: 0 16px !important;
}

.woocommerce ul.products li.product .button {
  margin: 10px 16px 16px !important;
  width: calc(100% - 32px) !important;
}

.woocommerce-message,
.woocommerce-info {
  border-left: 4px solid var(--pw-primary) !important;
  background: #faf5ff !important;
  color: var(--pw-dark2) !important;
  border-radius: var(--pw-radius-sm) !important;
  padding: 14px 18px !important;
}

.woocommerce-error {
  border-left: 4px solid var(--pw-red) !important;
  background: #fef2f2 !important;
  border-radius: var(--pw-radius-sm) !important;
}

/* ── Pagination ── */
.hp-pagination,
.woocommerce-pagination,
.page-numbers {
  display: flex !important;
  gap: 6px !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 32px !important;
  flex-wrap: wrap !important;
}

.page-numbers li a,
.page-numbers li span,
.hp-pagination a,
.hp-pagination span {
  width: 38px !important;
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--pw-radius-sm) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--pw-gray) !important;
  background: var(--pw-white) !important;
  border: 1px solid var(--pw-border) !important;
  text-decoration: none !important;
  transition: all var(--pw-transition) !important;
}

.page-numbers li a:hover,
.hp-pagination a:hover {
  border-color: var(--pw-primary) !important;
  color: var(--pw-primary) !important;
}

.page-numbers li .current,
.hp-pagination .current {
  background: var(--pw-grad) !important;
  color: var(--pw-white) !important;
  border-color: transparent !important;
}

/* ── Footer ── */
.pw-footer,
.site-footer,
#colophon {
  background: #0f0a1e !important;
  color: #94a3b8 !important;
  padding: 52px 24px 28px !important;
  margin-top: 60px !important;
}

.pw-footer__inner,
.site-footer .site-info,
#colophon .container {
  max-width: 1280px !important;
  margin: 0 auto !important;
}

.pw-footer__logo {
  font-size: 22px !important;
  font-weight: 800 !important;
  background: var(--pw-grad) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  margin-bottom: 8px !important;
  display: block !important;
}

.pw-footer__grid {
  display: grid !important;
  grid-template-columns: 2fr repeat(3, 1fr) !important;
  gap: 32px !important;
  padding-bottom: 36px !important;
  border-bottom: 1px solid #1e0a3c !important;
  margin-bottom: 24px !important;
}

.pw-footer h4 {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: #e9d5ff !important;
  margin-bottom: 14px !important;
}

.pw-footer ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.pw-footer ul li { margin-bottom: 8px !important; }
.pw-footer ul a {
  color: #64748b !important;
  text-decoration: none !important;
  font-size: 14px !important;
  transition: color var(--pw-transition) !important;
}
.pw-footer ul a:hover { color: #d8b4fe !important; }

.pw-footer__bottom {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  font-size: 13px !important;
  color: #475569 !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

/* ── Breadcrumbs ── */
.breadcrumbs,
.hp-breadcrumbs,
.woocommerce-breadcrumb {
  font-size: 13px !important;
  color: var(--pw-gray) !important;
  margin-bottom: 18px !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
}

.breadcrumbs a, .hp-breadcrumbs a, .woocommerce-breadcrumb a {
  color: var(--pw-gray) !important;
  text-decoration: none !important;
}

.breadcrumbs a:hover, .hp-breadcrumbs a:hover { color: var(--pw-primary) !important; }

/* ── Info banner ── */
.hp-info-banner {
  background: #faf5ff !important;
  border: 1px solid #d8b4fe !important;
  border-radius: var(--pw-radius) !important;
  padding: 18px 22px !important;
  margin-bottom: 24px !important;
  font-size: 14px !important;
  color: var(--pw-dark2) !important;
}

/* ── Badges ── */
.pw-verified-badge {
  background: #d1fae5 !important;
  color: #065f46 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 10px !important;
  border-radius: 50px !important;
}

/* Wyróżnione badge */
span[style*="Wyróżnione"],
span[style*="Promowane"],
.pw-em {
  background: var(--pw-grad) !important;
  color: var(--pw-white) !important;
}

/* ── Alerts / form messages ── */
.hp-alert,
.hp-message {
  border-radius: var(--pw-radius-sm) !important;
  padding: 12px 18px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .hp-listings,
  .hp-listings--view-block {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  }
  .pw-footer__grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 768px) {
  .header-navbar {
    padding: 0 16px !important;
    height: 60px !important;
    gap: 12px !important;
  }
  .header-navbar__menu { display: none !important; }

  .site-content, #content, .hp-page {
    padding: 16px !important;
  }

  .hp-listings,
  .hp-listings--view-block {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  .pw-footer__grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
}

@media (max-width: 480px) {
  .hp-listings,
  .hp-listings--view-block {
    grid-template-columns: 1fr !important;
  }

  .hp-listing__price { font-size: 15px !important; }
}

@media print {
  .site-header, .site-footer, .pw-tabs-bar, .pw-intent-bar { display: none !important; }
  body { background: white !important; color: black !important; }
}

/* ══════════════════════════════════════════════════
   pw-card — Homepage recent listings cards
   ══════════════════════════════════════════════════ */

/* Grid */
.pw-cards-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 18px !important;
}
@media (max-width: 1024px) { .pw-cards-grid { grid-template-columns: repeat(3,1fr) !important; } }
@media (max-width: 768px)  { .pw-cards-grid { grid-template-columns: repeat(2,1fr) !important; gap:12px !important; } }
@media (max-width: 480px)  { .pw-cards-grid { grid-template-columns: 1fr 1fr !important; gap:10px !important; } }

/* Card image */
.pw-card-img {
  width: 100% !important;
  aspect-ratio: 4/3 !important;
  min-height: 150px !important;
  background: linear-gradient(135deg,#f3f0fb 0%,#ede8f7 100%) !important;
  border-radius: 12px 12px 0 0 !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 52px !important;
  border: 1.5px solid #ede8f7 !important;
  border-bottom: none !important;
  position: relative !important;
}
.pw-card-img img:not(.emoji) {
  width:100% !important; height:100% !important;
  object-fit:cover !important; display:block !important;
}

/* Card body */
.pw-card-body {
  background: #ffffff !important;
  border: 1.5px solid #ede8f7 !important;
  border-top: none !important;
  border-radius: 0 0 12px 12px !important;
  padding: 12px 14px 10px !important;
}
.pw-card-body > a.pw-card {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  text-decoration: none !important;
}

/* Category */
.pw-card-cat {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .07em !important;
  color: #a855f7 !important;
  display: block !important;
  min-height: 14px !important;
}

/* TITLE — główny problem */
.pw-card-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  line-height: 1.35 !important;
  letter-spacing: -.01em !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 40px !important;
}

/* PRICE */
.pw-price {
  font-size: 17px !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg,#a855f7,#ec4899) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  letter-spacing: -.02em !important;
  display: block !important;
  padding: 4px 0 0 !important;
}

/* Bezpłatne */
.pw-noprice {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #10b981 !important;
  -webkit-text-fill-color: #10b981 !important;
  display: block !important;
  padding: 4px 0 0 !important;
}

/* Buttons row */
.pw-card-btns {
  display: flex !important;
  gap: 7px !important;
  margin-top: 10px !important;
  padding-top: 9px !important;
  border-top: 1px solid #f0ebfc !important;
}
.pw-card-btns a {
  flex: 1 !important;
  padding: 7px 4px !important;
  border-radius: 50px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-align: center !important;
  text-decoration: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  transition: all .18s !important;
  white-space: nowrap !important;
}
.pw-card-btns a:first-child {
  background: #faf5ff !important;
  color: #a855f7 !important;
  border: 1.5px solid #e9d5ff !important;
  -webkit-text-fill-color: #a855f7 !important;
}
.pw-card-btns a:first-child:hover { background: #f3e8ff !important; }

.pw-btn-wa {
  background: #1a8a3e !important;
  color: #fff !important;
  border: none !important;
  -webkit-text-fill-color: #fff !important;
}
.pw-btn-wa:hover { opacity: .88 !important; }

.pw-btn-em {
  background: linear-gradient(135deg,#a855f7,#ec4899) !important;
  color: #fff !important;
  border: none !important;
  -webkit-text-fill-color: #fff !important;
}
.pw-btn-em:hover { opacity: .88 !important; }

/* Section headers */
.pw-section-title {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: #0f172a !important;
  letter-spacing: -.03em !important;
  margin: 0 0 4px !important;
}
.pw-section-sub {
  font-size: 13px !important;
  color: #64748b !important;
  margin: 0 0 20px !important;
}
