/* ================================================================
   RETROTARG – GŁÓWNY CSS v3
   Czcionka: Roboto
   Przyciski: Granatowy #1a1a2e
   Tło: Jasna szarość #F2F3F5
   Blog/Mapa/O nas: Popiel #E8E9EC
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;1,400&display=swap');

/* ── Zmienne ─────────────────────────────────────────────── */
:root {
  --white:       #FFFFFF;
  --gray-light:  #F2F3F5;   /* tło główne */
  --gray-mid:    #E8E9EC;   /* blog, mapa, o nas */
  --gray-card:   #FFFFFF;   /* karty */
  --border:      #DDE0E6;
  --shadow:      rgba(0,0,0,.07);
  --shadow-lg:   rgba(0,0,0,.14);

  --navy:        #1a1a2e;   /* główny kolor przycisków */
  --navy-hover:  #0f0f22;
  --gold:        #8B6914;   /* akcent cenowy */
  --gold-lt:     #C49A28;
  --dark:        #1a1a2e;
  --text:        #1f2937;
  --text-mid:    #4b5563;
  --text-muted:  #9ca3af;

  --ff-body:     'Roboto', sans-serif;
  --ff-head:     'Roboto', sans-serif;

  --r-sm:   6px;
  --r-md:   12px;
  --r-lg:   18px;
  --r-pill: 50px;

  /* Aliasy dla nowego kodu sklepu */
  --bg-light:  #F2F3F5;
  --bg-mid:    #E8E9EC;
  --green:     #16a34a;
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  background: var(--gray-light) !important;
  font-family: var(--ff-body) !important;
  color: var(--text) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  margin: 0 !important;
}

h1,h2,h3,h4,h5 {
  font-family: var(--ff-head) !important;
  color: var(--dark) !important;
  line-height: 1.2 !important;
}

/* ── Astra full-width overrides ──────────────────────────── */
.home #secondary,
.home .ast-right-sidebar,
.home .ast-left-sidebar { display: none !important; }

.home #primary,
.home .content-area,
.front-page #primary {
  width: 100% !important; max-width: 100% !important;
  float: none !important; padding: 0 !important; margin: 0 !important;
}

.home .ast-container,
.home #content,
.home .site-content,
.home .ast-article-post,
.home .entry-content,
.home .post-content {
  padding: 0 !important; margin: 0 !important; max-width: 100% !important;
}

.home .ast-row,
.home #content .ast-container { max-width: 100% !important; padding: 0 !important; }

.home article.page,
.home .entry-header,
.home .entry-title { display: none !important; }

#rt-home { width: 100%; max-width: 100%; padding: 0; margin: 0; overflow-x: hidden; }

/* ── Formularz zapytania o produkt ─────────────────────────── */
.rt-product-inquiry {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 24px;
  margin-top: 32px;
  box-shadow: 0 2px 8px var(--shadow);
}

.rt-inquiry-header {
  margin-bottom: 20px;
  text-align: center;
}

.rt-inquiry-header h3 {
  margin: 0 0 8px 0;
  font-size: 20px;
  font-weight: 600;
  color: var(--dark);
}

.rt-inquiry-header p {
  margin: 0;
  font-size: 14px;
  color: var(--text-mid);
}

.rt-inquiry-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.rt-inquiry-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.rt-inquiry-field label {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}

.rt-inquiry-field input,
.rt-inquiry-field textarea {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  font-size: 14px;
  font-family: var(--ff-body);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  background: var(--white);
}

.rt-inquiry-field input:focus,
.rt-inquiry-field textarea:focus {
  outline: none;
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(26, 26, 46, 0.1);
}

.rt-inquiry-field input::placeholder,
.rt-inquiry-field textarea::placeholder {
  color: var(--text-muted);
}

.rt-inquiry-submit {
  background: var(--navy);
  color: var(--white);
  border: none;
  border-radius: var(--r-sm);
  padding: 14px 24px;
  font-size: 15px;
  font-weight: 500;
  font-family: var(--ff-body);
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.1s ease;
  margin-top: 8px;
}

.rt-inquiry-submit:hover:not(:disabled) {
  background: var(--navy-hover);
}

.rt-inquiry-submit:active:not(:disabled) {
  transform: translateY(1px);
}

.rt-inquiry-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.rt-inquiry-message {
  padding: 12px 16px;
  border-radius: var(--r-sm);
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  margin-top: 16px;
}

.rt-inquiry-message[style*="color: #28a745"] {
  background: rgba(22, 163, 74, 0.1);
  border: 1px solid rgba(22, 163, 74, 0.2);
}

.rt-inquiry-message[style*="color: #dc3545"] {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid rgba(220, 53, 69, 0.2);
}

/* ── WYSZUKIWARKA SKLEPU ───────────────────────────────────── */
#rts-szukaj {
    background: transparent !important;
    background-image: none !important;
    padding-left: 14px !important;
}
#rts-szukaj::before,
#rts-szukaj::after {
    display: none !important;
}

/* ── Przycisk części pasujące do modelu w modalu ogłoszeń ─────────────────────────── */
.rtads-modal-section {
    margin: 16px 0;
    text-align: center;
}

.rtads-modal-section .rtads-btn--primary {
    background: var(--gold) !important;
    color: var(--white) !important;
    border: none !important;
    padding: 12px 20px !important;
    border-radius: var(--r-md) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    box-shadow: 0 2px 8px var(--shadow) !important;
}

.rtads-modal-section .rtads-btn--primary:hover {
    background: var(--gold-lt) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px var(--shadow-lg) !important;
}

.rtads-modal-section .rtads-btn--primary:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px var(--shadow) !important;
}

/* ── Przycisk telefonu w modalu ogłoszeń (zmiana koloru na navy) ───────────────── */
.rtads-btn--call {
    background: var(--navy) !important;
    color: var(--white) !important;
}

.rtads-btn--call:hover {
    background: var(--navy-hover) !important;
}

/* ── Chmurka logowania dla ulubionych ───────────────────────── */
.rts-login-tooltip {
  position: fixed !important;
  z-index: 100001 !important;
  background: var(--dark);
  border-radius: var(--r-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  padding: 0;
  font-family: var(--ff-body);
  pointer-events: auto;
  min-width: 280px;
  max-width: 320px;
}

.rts-login-tooltip__content {
  padding: 16px 20px;
  text-align: center;
}

.rts-login-tooltip__icon {
  font-size: 24px;
  margin-bottom: 8px;
}

.rts-login-tooltip__text {
  color: var(--white);
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 16px;
  line-height: 1.4;
}

.rts-login-tooltip__actions {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.rts-login-tooltip__login,
.rts-login-tooltip__close {
  padding: 8px 16px;
  border-radius: var(--r-sm);
  font-family: var(--ff-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
}

.rts-login-tooltip__login {
  background: var(--gold);
  color: var(--white);
}

.rts-login-tooltip__login:hover {
  background: var(--gold-lt);
  transform: translateY(-1px);
}

.rts-login-tooltip__close {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.8);
}

.rts-login-tooltip__close:hover {
  background: rgba(255, 255, 255, 0.2);
  color: var(--white);
}

.rts-login-tooltip__arrow {
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid var(--dark);
}

/* Responsive dla chmurki */
@media (max-width: 768px) {
  .rts-login-tooltip {
    min-width: 240px;
    max-width: calc(100vw - 32px);
    left: 16px !important;
    right: 16px !important;
  }
  
  .rts-login-tooltip__content {
    padding: 14px 16px;
  }
  
  .rts-login-tooltip__text {
    font-size: 13px;
  }
  
  .rts-login-tooltip__login,
  .rts-login-tooltip__close {
    padding: 7px 14px;
    font-size: 12px;
    min-width: auto;
  }
}

/* Bardzo male ekrany */
@media (max-width: 380px) {
  .rts-login-tooltip {
    min-width: auto !important;
    max-width: calc(100vw - 16px) !important;
    width: calc(100vw - 16px) !important;
    left: 8px !important;
    right: 8px !important;
  }
  
  .rts-login-tooltip__actions {
    flex-direction: column;
    gap: 8px;
  }
  
  .rts-login-tooltip__login,
  .rts-login-tooltip__close {
    width: 100%;
  }
}

/* ── Przycisk "Przeglądaj ogłoszenia" gdy brak ulubionych w panelu użytkownika ───────── */
.woocommerce-MyAccount-content .rtads-empty a.rtads-btn,
.woocommerce-MyAccount-content .rtads-empty .rtads-btn--primary,
.woocommerce-MyAccount-content .rtads-empty .button {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: #fff !important;
  border-radius: var(--r-pill) !important;
  padding: 12px 28px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: background .2s, transform .15s !important;
  display: inline-block !important;
}

.woocommerce-MyAccount-content .rtads-empty a.rtads-btn:hover,
.woocommerce-MyAccount-content .rtads-empty .rtads-btn--primary:hover,
.woocommerce-MyAccount-content .rtads-empty .button:hover {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* ── Formularz zapytania o produkt w modalu ─────────────────── */
.rts-modal-inquiry {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.rts-modal-section-lbl {
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  margin: 0 0 12px 0;
}

.rts-inquiry-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rts-inquiry-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.rts-inquiry-field label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}

.rts-inquiry-field input,
.rts-inquiry-field textarea {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: 13px;
  font-family: var(--ff-body);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  background: var(--white);
}

.rts-inquiry-field input:focus,
.rts-inquiry-field textarea:focus {
  outline: none;
  border-color: var(--navy);
  box-shadow: 0 0 0 2px rgba(26, 26, 46, 0.1);
}

.rts-inquiry-field input::placeholder,
.rts-inquiry-field textarea::placeholder {
  color: var(--text-muted);
}

.rts-inquiry-submit {
  background: var(--navy);
  color: var(--white);
  border: none;
  border-radius: var(--r-sm);
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 500;
  font-family: var(--ff-body);
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.1s ease;
  margin-top: 8px;
}

.rts-inquiry-submit:hover:not(:disabled) {
  background: var(--navy-hover);
}

.rts-inquiry-submit:active:not(:disabled) {
  transform: translateY(1px);
}

.rts-inquiry-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.rts-inquiry-message {
  padding: 10px 12px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  margin-top: 12px;
}

.rts-inquiry-message[style*="color: #28a745"] {
  background: rgba(22, 163, 74, 0.1);
  border: 1px solid rgba(22, 163, 74, 0.2);
}

.rts-inquiry-message[style*="color: #dc3545"] {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid rgba(220, 53, 69, 0.2);
}

/* Responsive dla formularza w modalu */
@media (max-width: 768px) {
  .rts-modal-inquiry {
    margin-top: 16px;
    padding-top: 16px;
  }
  
  .rts-inquiry-field input,
  .rts-inquiry-field textarea {
    padding: 8px 10px;
    font-size: 12px;
  }
  
  .rts-inquiry-submit {
    padding: 10px 16px;
    font-size: 13px;
  }
}

/* ================================================================
   HEADER
   ================================================================ */
#masthead, .site-header, .ast-header-wrap {
  background: var(--white) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 1px 8px rgba(0,0,0,.05) !important;
  position: sticky !important; top: 0 !important; z-index: 999 !important;
}

.ast-site-identity .site-title a,
.ast-site-identity .site-title {
  font-family: var(--ff-head) !important;
  font-size: 20px !important; font-weight: 700 !important;
  color: var(--dark) !important;
}

.main-navigation .menu-item > a,
.ast-builder-menu-1 .menu-item > a,
#site-navigation .menu-item > a {
  font-family: var(--ff-body) !important;
  font-size: 13px !important; font-weight: 500 !important;
  letter-spacing: .3px !important;
  color: var(--text) !important; padding: 8px 14px !important;
  transition: color .2s !important;
}
.main-navigation .menu-item > a:hover,
.ast-builder-menu-1 .menu-item > a:hover { color: var(--navy) !important; }

/* ================================================================
   HERO
   ================================================================ */
.rth-hero {
  position: relative;
  min-height: 500px;
  display: flex; align-items: center;
  overflow: hidden;
}

.rth-hero__bg {
  position: absolute; inset: 0;
  background: var(--navy) center/cover no-repeat;
  transform: scale(1.04);
  transition: transform 8s ease;
}
.rth-hero:hover .rth-hero__bg { transform: scale(1); }

.rth-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    110deg,
    rgba(26,26,46,.92) 0%,
    rgba(26,26,46,.70) 50%,
    rgba(26,26,46,.35) 100%
  );
}

.rth-hero__inner {
  position: relative; z-index: 2;
  width: 100%; max-width: 1200px;
  margin: 0 auto; padding: 80px 40px;
}

.rth-hero__content { max-width: 560px; }

.rth-eyebrow {
  display: block;
  font-family: var(--ff-body);
  font-size: 11px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  color: var(--gold-lt); margin-bottom: 16px;
}

.rth-hero__title {
  font-size: clamp(34px, 4.5vw, 54px) !important;
  font-weight: 700 !important;
  color: #fff !important;
  line-height: 1.1 !important;
  margin: 0 0 18px !important;
}

.rth-hero__sub {
  font-size: 16px; line-height: 1.65;
  color: rgba(255,255,255,.78); margin-bottom: 32px;
}

.rth-hero__btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* ================================================================
   PRZYCISKI – granatowy #1a1a2e
   ================================================================ */
.rth-btn,
.ast-button,
button[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.single_add_to_cart_button,
.woocommerce .checkout-button {
  display: inline-block !important;
  background: var(--gold) !important;
  color: #fff !important;
  font-family: var(--ff-body) !important;
  font-size: 12px !important; font-weight: 700 !important;
  letter-spacing: 1px !important; text-transform: uppercase !important;
  padding: 12px 28px !important;
  border-radius: var(--r-pill) !important;
  border: 2px solid var(--gold) !important;
  text-decoration: none !important;
  transition: background .2s, transform .15s, box-shadow .2s !important;
  cursor: pointer !important; white-space: nowrap !important;
}

.rth-btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.single_add_to_cart_button:hover {
  background: var(--navy-hover) !important;
  border-color: var(--navy-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(26,26,46,.35) !important;
  color: #fff !important;
}

.rth-btn--outline {
  background: transparent !important;
  border-color: rgba(255,255,255,.5) !important;
  color: #fff !important;
}
.rth-btn--outline:hover {
  background: rgba(255,255,255,.12) !important;
  border-color: #fff !important;
}

.rth-btn--sm {
  font-size: 11px !important;
  padding: 7px 16px !important;
}

/* ================================================================
   LAYOUT HELPERS
   ================================================================ */
.rth-container { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

/* Sekcje – tła */
.rth-section          { padding: 52px 0; background: var(--white); }
.rth-section--gray    { padding: 52px 0; background: var(--gray-mid); }
.rth-section--white   { padding: 52px 0; background: var(--white); }
/* Portal – pełna szerokość */
.rth-section--portal  {
  padding: 52px 0;
  background: var(--navy);
  width: 100%;
}
.rth-section--portal .rth-container {
  max-width: 1400px;
  padding: 0 48px;
}
/* Nagłówek i "rth-more" w trybie portal – białe */
.rth-section--portal .rth-label  { color: var(--gold-lt); }
.rth-section--portal h2          { color: #fff !important; }
.rth-section--portal .rth-more   { color: rgba(255,255,255,.7); border-bottom-color: rgba(255,255,255,.4); }
.rth-section--portal .rth-more:hover { opacity: .9; color: #fff; }
/* Przycisk "Dodaj ogłoszenie" w nagłówku portalu */
.rth-section--portal .rth-section-head .rth-btn {
  background: var(--gold-lt) !important;
  border-color: var(--gold-lt) !important;
  color: var(--dark) !important;
}
/* Karty ogłoszeń na ciemnym tle */
.rth-section--portal .rth-card {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}
.rth-section--portal .rth-card:hover {
  background: rgba(255,255,255,.09);
}
.rth-section--portal .rth-card__title { color: #e8e0cc !important; }
.rth-section--portal .rth-card__title:hover { color: var(--gold-lt) !important; }
.rth-section--portal .rth-card__no-img { background: rgba(255,255,255,.06); }
.rth-section--portal .rth-chip {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: rgba(232,224,204,.7);
}

.rth-section-head {
  display: flex; justify-content: space-between;
  align-items: flex-end; margin-bottom: 28px;
}
.rth-section-head h2 {
  font-size: 24px !important; margin: 4px 0 0 !important;
}

.rth-label {
  display: block;
  font-family: var(--ff-body);
  font-size: 11px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--navy); margin-bottom: 3px;
}

a.rth-more {
  font-family: var(--ff-body);
  font-size: 12px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--gold-lt) !important; text-decoration: none;
  border-bottom: 1px solid var(--gold-lt) !important;
  padding-bottom: 2px; white-space: nowrap;
  transition: opacity .2s;
}
a.rth-more:hover { opacity: .65; color: var(--gold) !important; }

/* ================================================================
   KARTY PRODUKTÓW / OGŁOSZEŃ
   ================================================================ */
.rth-grid4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.rth-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s;
}
.rth-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 28px var(--shadow-lg);
}

.rth-card__img-wrap {
  display: block; overflow: hidden;
  aspect-ratio: 4/3; position: relative;
  background: var(--gray-mid);
}
.rth-card__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .4s ease;
}
.rth-card:hover .rth-card__img-wrap img { transform: scale(1.05); }

.rth-card__no-img {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; color: var(--text-muted);
}

.rth-card__body {
  padding: 13px 14px 14px;
  display: flex; flex-direction: column; flex: 1;
}

.rth-card__title {
  font-family: var(--ff-body);
  font-size: 14px; font-weight: 500;
  color: var(--text) !important;
  text-decoration: none !important;
  line-height: 1.4;
  /* Stała wysokość 2 linii = wyrównane przyciski */
  min-height: 2.8em;
  max-height: 2.8em;
  margin-bottom: 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.rth-card__title:hover { color: var(--navy) !important; }

.rth-card__chips-row {
  display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px;
}

.rth-card__footer {
  display: flex; align-items: center;
  justify-content: space-between; gap: 8px; margin-top: auto;
}

/* Prices */
.rth-price,
.rth-price .woocommerce-Price-amount,
.rth-price .price {
  font-family: var(--ff-head) !important;
  font-size: 18px !important; font-weight: 700 !important;
  color: var(--gold) !important;
}

/* Chips */
.rth-chip {
  display: inline-block;
  background: var(--gray-mid);
  color: var(--text-mid);
  font-size: 10px; font-weight: 500;
  padding: 2px 8px; border-radius: var(--r-pill);
  border: 1px solid var(--border);
}
.rth-chip--loc { background: transparent; border-color: transparent; color: var(--text-muted); padding-left: 0; }

/* Badges */
.rth-badge {
  display: inline-block;
  background: var(--navy);
  color: #fff;
  font-family: var(--ff-body);
  font-size: 10px; font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase;
  padding: 3px 10px; border-radius: var(--r-pill);
}
.rth-badge--corner {
  position: absolute; top: 10px; right: 10px; z-index: 3;
}
.rth-badge--stan {
  position: absolute; top: 10px; left: 10px; z-index: 3;
  background: var(--gold);
}

.rth-tag {
  display: inline-block;
  background: var(--gray-mid); color: var(--text-mid);
  font-size: 10px; font-weight: 600;
  letter-spacing: .5px; text-transform: uppercase;
  padding: 2px 9px; border-radius: var(--r-pill);
  border: 1px solid var(--border);
}

/* ================================================================
   BLOG GRID
   ================================================================ */
.rth-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.rth-blog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
}
.rth-blog-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px var(--shadow-lg);
}

.rth-blog-card__img { display: block; overflow: hidden; }
.rth-blog-card__img img {
  width: 100%; height: 190px; object-fit: cover; display: block;
  transition: transform .4s;
}
.rth-blog-card:hover .rth-blog-card__img img { transform: scale(1.04); }

.rth-blog-card__body { padding: 18px; }

.rth-blog-card__meta {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 8px; font-size: 11px; color: var(--text-muted);
}

.rth-blog-card__body h3 {
  font-size: 16px !important; font-weight: 700 !important;
  line-height: 1.3 !important; margin: 0 0 8px !important;
}
.rth-blog-card__body h3 a {
  color: var(--dark) !important; text-decoration: none !important;
}
.rth-blog-card__body h3 a:hover { color: var(--navy) !important; }

.rth-blog-card__body p {
  font-size: 13px; color: var(--text-mid);
  line-height: 1.6; margin-bottom: 12px;
}

.rth-read-more {
  font-family: var(--ff-body);
  font-size: 12px; font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase;
  color: var(--navy) !important; text-decoration: none !important;
}
.rth-read-more:hover { opacity: .7; }

/* ================================================================
   FEATURES BAR
   ================================================================ */
.rth-features-bar {
  background: var(--navy);
  padding: 24px 0;
}

.rth-features-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.rth-feat-item {
  display: flex; align-items: center; gap: 12px;
}
.rth-feat-item__icon {
  width: 40px; height: 40px;
  background: rgba(255,255,255,.1);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.rth-feat-item > div { display: flex; flex-direction: column; gap: 1px; }
.rth-feat-item strong {
  font-family: var(--ff-body);
  font-size: 13px; font-weight: 700; color: #fff;
}
.rth-feat-item span { font-size: 11px; color: rgba(255,255,255,.6); }

/* ================================================================
   FOOTER – zwarta wersja (połowa wysokości)
   ================================================================ */
#colophon, footer.site-footer, .site-footer {
  background: var(--navy) !important;
  color: rgba(255,255,255,.75) !important;
  padding-top: 20px !important;
  padding-bottom: 0 !important;
}

.site-footer .widget-area,
.ast-footer-widget-area {
  padding: 0 0 16px !important;
}

/* Zmniejsz rozmiar widgetów w stopce */
.ast-footer-widget-area .ast-footer-widget {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.site-footer h4,
.widget-title,
#colophon .widget-title {
  font-family: var(--ff-body) !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  color: rgba(255,255,255,.9) !important;
  margin-bottom: 8px !important;
  margin-top: 0 !important;
}

.site-footer a, #colophon a {
  color: rgba(255,255,255,.65) !important;
  text-decoration: none !important;
  font-size: 12px !important;
  transition: color .2s !important;
}
.site-footer a:hover, #colophon a:hover {
  color: var(--gold-lt) !important;
}

.site-footer ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.site-footer ul li { margin-bottom: 4px !important; }

.site-footer p, #colophon p {
  font-size: 12px !important;
  color: rgba(255,255,255,.6) !important;
  margin-bottom: 4px !important;
  line-height: 1.5 !important;
}

/* Logo w stopce – zmniejsz */
.site-footer img { max-height: 36px !important; width: auto !important; }

.ast-footer-copyright,
.site-info {
  background: rgba(0,0,0,.25) !important;
  color: rgba(255,255,255,.4) !important;
  font-size: 11px !important;
  padding: 8px 0 !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
  text-align: center !important;
}

/* --- POPRAWKA WIDOCZNOŚCI STOPKI RETROTARG --- */

/* Cała stopka i teksty akapitów */
#rth-footer {
    background-color: #1a1a2e !important; /* Spójny granat */
    color: #ffffff !important;
    padding: 10px 0 30px 0;
}

/* Nagłówki kolumn (Sklep, Informacje, Newsletter) */
#rth-footer h4 {
    color: #C49A28 !important; /* Złoty kolor z Twojej palety dla wyróżnienia */
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    margin-bottom: 20px !important;
}

/* Linki w listach - teraz będą białe i widoczne */
#rth-footer ul li a {
    color: rgba(255, 255, 255, 0.8) !important;
    text-decoration: none !important;
    font-size: 14px !important;
    transition: color 0.3s ease !important;
}

#rth-footer ul li a:hover {
    color: #ffffff !important;
    padding-left: 5px; /* Delikatny efekt po najechaniu */
}

/* Motto pod logo */
.rth-footer-motto {
    color: rgba(255, 255, 255, 0.6) !important;
    font-style: italic !important;
}

/* Ikony Social Media */
.rth-footer-social a {
    color: #ffffff !important;
    border: 1px solid rgba(255,255,255,0.2);
    padding: 8px;
    border-radius: 50%;
    display: inline-flex;
    margin-right: 10px;
}

/* Dolny pasek (Copyright) */
.rth-footer-bottom {
    color: rgba(255, 255, 255, 0.4) !important;
    font-size: 12px !important;
}

.rth-footer-bottom a {
    color: rgba(255, 255, 255, 0.4) !important;
}



/* ================================================================
   WOOCOMMERCE – NOWOCZESNY SKLEP RETROTARG
   Dotyczy: archive-product.php, single-product.php, content-product.php
   ================================================================ */

/* --- BREADCRUMBS --- */
.woocommerce-breadcrumb, .ast-breadcrumbs,
.rt-breadcrumb { font-family: var(--ff-body) !important; font-size: 12px; color: var(--text-muted); }
.rt-breadcrumb { background: var(--white); border-bottom: 1px solid var(--border); padding: 12px 0; }
.rt-breadcrumb__inner { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.woocommerce-breadcrumb a, .ast-breadcrumbs a,
.rt-breadcrumb a { color: var(--navy) !important; transition: opacity .2s; }
.woocommerce-breadcrumb a:hover { opacity: .65; }

/* Zwiększ padding nagłówka kategorii Astry - styl jak portal */
.tax-product_cat .ast-container h1,
.tax-product_cat .ast-container .page-title,
.tax-product_cat .woocommerce-products-header__title {
    padding: 10px 0 !important;
    margin-bottom: 10px !important;
    text-align: center !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    color: #333333 !important;
    background: #f0f0f0 !important;
    display: block !important;
}

/* Nagłówek kategorii sklepu responsywny */
.rt-shop-category-header {
    width: 100% !important;
    background: #f0f0f0 !important;
    padding: 10px 0 !important;
    margin-bottom: 10px !important;
    text-align: center !important;
    display: block !important;
    clear: both !important;
    position: relative !important;
    z-index: 10 !important;
}

.rt-shop-category-header > div {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    color: #333333 !important;
    text-align: center !important;
}

/* Responsywność mobilna */
@media (max-width: 768px) {
    .rt-shop-category-header {
        padding: 8px 0 !important;
        margin-bottom: 8px !important;
    }
    
    .rt-shop-category-header > div {
        font-size: 16px !important;
        padding: 0 16px !important;
        letter-spacing: 0.5px !important;
    }
}

@media (max-width: 480px) {
    .rt-shop-category-header {
        padding: 6px 0 !important;
        margin-bottom: 6px !important;
    }
    
    .rt-shop-category-header > div {
        font-size: 14px !important;
        padding: 0 12px !important;
        letter-spacing: 0.2px !important;
    }
}

/* ===================== SHOP WRAP ===================== */
.rt-shop-wrap { background: var(--bg-light); }

/* --- NAGŁÓWEK SKLEPU --- */
.rt-shop-header { background: var(--white); border-bottom: 1px solid var(--border); padding: 22px 0 20px; }
.rt-shop-header__inner { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.rt-shop-header__title { font-size: 24px; margin: 4px 0 0; }
.rt-shop-header__desc { font-size: 13px; color: var(--text-muted); margin-top: 6px; }

/* --- NAGŁÓWEK SKLEP UŻYWANE --- */
body .rt-shop-header-wrapper {
    width: 100% !important;
    background: #f0f0f0 !important;
    margin-bottom: 10px !important;
    display: block !important;
}

body .rt-shop-portal-header {
    text-align: center !important;
    padding: 10px 20px !important;
    margin: 0 auto !important;
    background: #f0f0f0 !important;
    color: #333333 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    max-width: 1200px !important;
    display: block !important;
}

body .rt-shop-portal-header div {
    text-align: center !important;
    display: block !important;
    color: #333333 !important;
}

/* --- MOBILNY PASEK FILTRÓW --- */
.rt-filter-mob-bar {
  display: none;
  position: sticky; top: 64px; z-index: 80;
  background: var(--white); border-bottom: 1px solid var(--border);
  padding: 10px 16px; gap: 10px; align-items: center;
}
.rt-fmob-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg-mid); border: 1px solid var(--border);
  padding: 7px 14px; border-radius: var(--r-pill);
  font-family: var(--ff-body); font-size: 12px; font-weight: 600;
  color: var(--text); cursor: pointer; transition: all .18s;
}
.rt-fmob-btn:hover { background: var(--border); }

/* --- CATALOG LAYOUT: SIDEBAR + MAIN --- */
.rt-catalog-layout {
  max-width: 1200px; margin: 0 auto; padding: 0 40px 60px;
  display: grid; grid-template-columns: 264px 1fr; gap: 0; align-items: start;
}

/* ══════════════════════════════════════════════
   SIDEBAR SKLEPU – ciemny, spójny z wyszukiwarką portalu
   ══════════════════════════════════════════════ */
.rt-sidebar {
  position: sticky; top: 64px;
  height: calc(100vh - 64px); overflow-y: auto;
}
.rt-sidebar::-webkit-scrollbar { width: 3px; }
.rt-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 2px; }

/* Główny kontener formularza w sidebarze – taki sam styl jak .rth-search-form */
.rt-shop-sf {
  background: #1a1a2e;
  padding: 20px 18px 22px;
  min-height: 100%;
}

/* Nagłówek sidebara */
.rt-shop-sf__head {
  display: flex; align-items: center; gap: 9px;
  color: rgba(255,255,255,.92);
  font-family: var(--ff-body); font-size: 14px; font-weight: 700; letter-spacing: .03em;
  margin-bottom: 18px; padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.rt-shop-sf__close {
  display: none; margin-left: auto; background: none; border: none;
  color: rgba(255,255,255,.5); font-size: 16px; cursor: pointer; padding: 2px 4px;
  transition: color .18s;
}
.rt-shop-sf__close:hover { color: #fff; }

/* Grupy sekcji */
.rt-shop-sf__group {
  margin-bottom: 18px; padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.rt-shop-sf__group:last-of-type { border: none; margin-bottom: 0; padding-bottom: 0; }

/* Label sekcji – identyczny z .rth-sf-label */
.rt-shop-sf__label {
  display: block;
  font-family: var(--ff-body); font-size: 9px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: 10px;
}

/* ── Lista kategorii ─────────────────────────── */
.rt-shop-sf__catlist { list-style: none; padding: 0; margin: 0; }
.rt-shop-sf__catlist > li { margin-bottom: 2px; }

.rt-shop-sf__cat {
  display: flex; align-items: center; gap: 9px;
  padding: 9px 10px; border-radius: var(--r-sm);
  font-family: var(--ff-body); font-size: 13px; font-weight: 500;
  color: rgba(255,255,255,.72); text-decoration: none;
  transition: background .18s, color .18s;
  cursor: pointer;
}
.rt-shop-sf__cat:hover { background: rgba(255,255,255,.08); color: #fff; }
.rt-shop-sf__cat--on   { background: rgba(196,154,40,.18) !important; color: var(--gold-lt) !important; font-weight: 700; }

.rt-shop-sf__cat-icon { font-size: 16px; flex-shrink: 0; }
.rt-shop-sf__cat-name { flex: 1; }
.rt-shop-sf__cat-cnt {
  font-size: 10px; font-weight: 600;
  background: rgba(255,255,255,.1); color: rgba(255,255,255,.55);
  padding: 1px 7px; border-radius: 10px; flex-shrink: 0;
}
.rt-shop-sf__cat--on .rt-shop-sf__cat-cnt {
  background: rgba(196,154,40,.25); color: var(--gold-lt);
}

/* Podkategorie – wewnątrz listy */
.rt-shop-sf__subcatlist { list-style: none; padding: 0 0 0 28px; margin: 4px 0 6px; }
.rt-shop-sf__subcatlist li { margin-bottom: 2px; }
.rt-shop-sf__subcat {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 10px; border-radius: var(--r-sm);
  font-family: var(--ff-body); font-size: 12px;
  color: rgba(255,255,255,.6); text-decoration: none;
  transition: background .18s, color .18s;
}
.rt-shop-sf__subcat:hover { background: rgba(255,255,255,.07); color: #fff; }
.rt-shop-sf__subcat--on { color: var(--gold-lt) !important; font-weight: 600; }

/* ── Checkboxy (marka, stan) ─────────────────── */
.rt-shop-sf__checklist { list-style: none; padding: 0; margin: 0; }
.rt-shop-sf__checklist li { margin-bottom: 8px; }
.rt-shop-sf__check {
  display: flex; align-items: center; gap: 9px; cursor: pointer;
}
.rt-shop-sf__check input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--gold-lt);
  cursor: pointer; flex-shrink: 0;
}
.rt-shop-sf__check-label {
  font-family: var(--ff-body); font-size: 13px; color: rgba(255,255,255,.75);
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; transition: color .18s;
}
.rt-shop-sf__check:hover .rt-shop-sf__check-label { color: #fff; }
.rt-shop-sf__cnt {
  font-size: 10px; font-weight: 600;
  background: rgba(255,255,255,.1); color: rgba(255,255,255,.5);
  padding: 1px 6px; border-radius: 10px;
}

/* ── Pola ceny ──────────────────────────────── */
.rt-shop-sf__range { display: flex; gap: 8px; align-items: center; }
.rt-shop-sf__rsep { color: rgba(255,255,255,.4); font-size: 13px; flex-shrink: 0; }
.rt-shop-sf__rinput {
  flex: 1; min-width: 0;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-sm); padding: 11px 10px;
  font-family: var(--ff-body); font-size: 13px; color: rgba(255,255,255,.88);
  outline: none; transition: border-color .2s;
}
.rt-shop-sf__rinput::placeholder { color: rgba(255,255,255,.35); }
.rt-shop-sf__rinput:focus { border-color: var(--gold-lt); }

/* ── Przyciski ─────────────────────────────── */
.rt-shop-sf__submit {
  width: 100%; margin-top: 18px;
  background: var(--gold-lt); color: var(--dark);
  border: none; border-radius: var(--r-sm);
  font-family: var(--ff-body); font-size: 12px; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 13px; cursor: pointer;
  transition: background .18s, transform .15s;
}
.rt-shop-sf__submit:hover { background: #a07818; color: #fff; transform: translateY(-1px); }

.rt-shop-sf__clear {
  display: block; text-align: center; margin-top: 8px;
  font-family: var(--ff-body); font-size: 11px; font-weight: 600;
  color: rgba(255,255,255,.4); text-decoration: none;
  letter-spacing: .05em; transition: color .18s;
}
.rt-shop-sf__clear:hover { color: rgba(255,255,255,.75); }

/* ===================== SHOP MAIN ===================== */
.rt-shop-main { padding: 22px 22px 0; min-width: 0; }

/* Toolbar */
.rt-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; flex-wrap: wrap; gap: 10px;
}
.rt-results-count { font-family: var(--ff-body); font-size: 13px; color: var(--text-muted); }
.rt-results-count strong { color: var(--text); font-weight: 700; }
.rt-toolbar__right { display: flex; align-items: center; gap: 10px; }
.rt-view-toggle {
  display: flex; border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
}
.rt-vtbtn {
  width: 34px; height: 34px; background: none; border: none;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); cursor: pointer; transition: all .18s;
}
.rt-vtbtn--on, .rt-vtbtn:hover { background: var(--navy); color: #fff; }
/* WooCommerce native ordering dropdown */
.woocommerce-ordering select,
.woocommerce-ordering .orderby {
  border: 1.5px solid var(--border) !important;
  background: var(--white) !important;
  padding: 6px 11px !important;
  font-family: var(--ff-body) !important; font-size: 12px !important;
  font-weight: 500; color: var(--text-mid) !important;
  border-radius: var(--r-sm) !important; outline: none !important; cursor: pointer;
  transition: border-color .2s;
}
.woocommerce-ordering select:focus { border-color: var(--navy) !important; }

/* ===================== KARTA PRODUKTU (rt-pcard) ===================== */
/* Grid domyślny: 3 kolumny w rt-shop-main */
.rt-products-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2px !important;
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}

/* Widok lista */
.rt-products-grid.rt-products-grid--list {
  grid-template-columns: 1fr !important;
}
.rt-products-grid.rt-products-grid--list .rt-pcard {
  flex-direction: row !important;
}
.rt-products-grid.rt-products-grid--list .rt-pcard__img-wrap {
  width: 200px !important; height: 200px !important; flex-shrink: 0;
}
.rt-products-grid.rt-products-grid--list .rt-pcard__body {
  padding: 16px 20px !important; flex: 1;
}
.rt-products-grid.rt-products-grid--list .rt-pcard__title {
  -webkit-line-clamp: 1 !important;
}

/* Karta */
.rt-pcard {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  overflow: hidden !important; padding: 0 !important;
  display: flex !important; flex-direction: column !important;
  transition: transform .25s, box-shadow .25s !important;
  position: relative !important;
}
.rt-pcard:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 28px var(--shadow-lg) !important;
  z-index: 2;
}

/* Zdjęcie */
.rt-pcard__img-wrap {
  display: block; position: relative;
  height: 200px; overflow: hidden; background: var(--bg-mid);
  text-decoration: none !important;
}
.rt-pcard__img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; display: block !important;
  transition: transform .4s !important;
}
.rt-pcard:hover .rt-pcard__img { transform: scale(1.04) !important; }
.rt-pcard__img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 52px; color: rgba(26,26,46,.2);
  background: linear-gradient(135deg, var(--bg-mid) 0%, var(--bg-light) 100%);
}

/* Odznaki */
.rt-pcard__badges { position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 4px; }
.rt-badge {
  display: inline-block; font-family: var(--ff-body);
  font-size: 9px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--r-pill);
}
.rt-badge--sale { background: var(--gold); color: #fff; }
.rt-badge--new  { background: var(--green); color: #fff; }

.rt-cond-badge {
  position: absolute; top: 10px; right: 36px;
  font-family: var(--ff-body); font-size: 9px; font-weight: 700;
  letter-spacing: .15em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--r-pill);
}
.rt-cond--new  { background: rgba(22,163,74,.12); color: var(--green); border: 1px solid rgba(22,163,74,.25); }
.rt-cond--regen{ background: #ede8f8; color: #4a30a0; border: 1px solid rgba(74,48,160,.18); }
.rt-cond--used { background: rgba(139,105,20,.1); color: var(--gold); border: 1px solid rgba(139,105,20,.25); }

/* Przycisk Ulubione */
.rt-pcard__wish {
  position: absolute; top: 10px; right: 10px;
  width: 30px; height: 30px;
  background: rgba(255,255,255,.9); border: 1px solid var(--border);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 13px; cursor: pointer; opacity: 0;
  transition: opacity .2s, background .18s; padding: 0;
}
.rt-pcard:hover .rt-pcard__wish,
.rt-pcard__wish--active { opacity: 1 !important; }
.rt-pcard__wish--active { color: #e11d48; border-color: #e11d48; }
.rt-pcard__wish:hover { background: #fff; }

/* Body karty */
.rt-pcard__body {
  padding: 12px 13px 13px;
  display: flex; flex-direction: column; flex: 1;
}
.rt-pcard__brand {
  font-family: var(--ff-body); font-size: 9px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 3px;
}
.rt-pcard__title {
  font-family: var(--ff-body) !important; font-size: 14px !important;
  font-weight: 500 !important; color: var(--text) !important;
  line-height: 1.4 !important; flex: 1;
  margin-bottom: 4px !important; padding: 0 !important;
  display: -webkit-box !important; -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important; overflow: hidden !important;
}
.rt-pcard__title a { color: inherit !important; text-decoration: none !important; transition: color .2s; }
.rt-pcard:hover .rt-pcard__title a { color: var(--navy) !important; }
.rt-pcard__sku {
  font-family: var(--ff-body); font-size: 10px; color: var(--text-muted);
  letter-spacing: .05em; margin-bottom: 10px;
}
.rt-pcard__foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-top: auto; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.rt-pcard__prices { display: flex; flex-direction: column; gap: 1px; }
.rt-pcard__price-now {
  font-family: var(--ff-head) !important; font-size: 18px !important;
  font-weight: 700 !important; color: var(--gold) !important; line-height: 1.1;
}
.rt-pcard__price-now .woocommerce-Price-amount { color: var(--gold) !important; font-size: inherit !important; }
.rt-pcard__price-was {
  font-family: var(--ff-body); font-size: 11px; color: var(--text-muted);
  text-decoration: line-through;
}
.rt-pcard__price-was .woocommerce-Price-amount { color: var(--text-muted) !important; }
.rt-pcard__btn,
.rt-pcard .button {
  background: var(--navy) !important; color: #fff !important;
  border: none !important; border-radius: var(--r-pill) !important;
  font-family: var(--ff-body) !important; font-size: 10px !important;
  font-weight: 700 !important; letter-spacing: .08em !important; text-transform: uppercase !important;
  padding: 8px 13px !important; cursor: pointer !important;
  transition: background .18s, transform .15s !important;
  white-space: nowrap; flex-shrink: 0; text-decoration: none !important;
}
.rt-pcard__btn:hover, .rt-pcard .button:hover {
  background: var(--navy-hover) !important; color: #fff !important;
  transform: translateY(-1px) !important;
}

/* Brak produktów */
.rt-no-products {
  grid-column: 1 / -1; text-align: center; padding: 72px 40px;
}
.rt-no-products__icon { font-size: 56px; margin-bottom: 16px; opacity: .5; }
.rt-no-products h3 { font-size: 20px; color: var(--navy); margin-bottom: 8px; }
.rt-no-products p { font-size: 14px; color: var(--text-muted); margin-bottom: 24px; }

/* Paginacja */
.rt-pager { margin-top: 32px; padding-top: 26px; border-top: 1px solid var(--border); }
.woocommerce-pagination ul {
  display: flex !important; gap: 4px !important;
  justify-content: center !important; flex-wrap: wrap !important;
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 36px !important; height: 36px !important;
  border: 1px solid var(--border) !important; background: var(--white) !important;
  font-family: var(--ff-body) !important; font-size: 13px !important; font-weight: 500;
  color: var(--text-mid) !important; border-radius: var(--r-sm) !important;
  text-decoration: none !important; transition: all .18s;
}
.woocommerce-pagination ul li a:hover,
.woocommerce-pagination ul li span.current {
  background: var(--navy) !important; color: #fff !important;
  border-color: var(--navy) !important;
}

/* ===================== SINGLE PRODUCT ===================== */
.rt-single-wrap { background: var(--bg-light); }

.rt-single-layout {
  max-width: 1200px; margin: 0 auto; padding: 36px 40px 0;
  display: grid; grid-template-columns: 1fr 420px; gap: 48px; align-items: start;
}

/* Galeria */
.rt-single-gallery { position: sticky; top: 80px; }
.rt-gal-main {
  background: var(--bg-mid); border: 1px solid var(--border);
  border-radius: var(--r-md); overflow: hidden;
  height: 400px; display: flex; align-items: center; justify-content: center;
  margin-bottom: 10px; position: relative; cursor: zoom-in;
}
.rt-gal-main--placeholder { font-size: 80px; color: rgba(26,26,46,.15); cursor: default; }
.rt-gal-main__link { display: block; width: 100%; height: 100%; }
.rt-gal-main__img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; display: block !important;
  transition: opacity .18s;
}
.rt-sale-badge {
  position: absolute; top: 14px; left: 14px;
  background: var(--gold); color: #fff;
  font-family: var(--ff-body); font-size: 10px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; padding: 4px 10px; border-radius: var(--r-pill);
}
.rt-outofstock-badge {
  position: absolute; top: 14px; right: 14px;
  background: #ef4444; color: #fff;
  font-family: var(--ff-body); font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; padding: 4px 10px; border-radius: var(--r-pill);
}
.rt-gal-thumbs { display: flex; gap: 8px; flex-wrap: wrap; }
.rt-gth {
  width: 72px; height: 60px;
  border: 2px solid var(--border); border-radius: var(--r-sm);
  overflow: hidden; cursor: pointer; transition: border-color .18s;
  background: var(--bg-mid);
}
.rt-gth img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rt-gth--on { border-color: var(--navy) !important; }
.rt-gth:hover { border-color: var(--gold); }

/* Info produktu */
.rt-single-info {}
.rt-single-brand {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 5px; flex-wrap: wrap; gap: 6px;
}
.rt-single-brand__name {
  font-family: var(--ff-body); font-size: 10px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
}
.rt-stars { display: inline-flex; align-items: center; gap: 4px; }
.rt-stars .star-rating { font-size: 12px; }
.rt-stars__count { font-family: var(--ff-body); font-size: 11px; color: var(--text-muted); }
.rt-single-title {
  font-family: var(--ff-head) !important; font-size: 26px !important;
  font-weight: 700 !important; color: var(--navy) !important;
  line-height: 1.2; margin-bottom: 6px !important;
}
.rt-single-sku {
  font-family: var(--ff-body); font-size: 11px; color: var(--text-muted);
  letter-spacing: .06em; margin-bottom: 16px;
}
.rt-single-sku strong { color: var(--text); }

/* Cena pojedyncza */
.rt-single-price-box {
  background: rgba(139,105,20,.07); border: 1px solid rgba(139,105,20,.22);
  border-radius: var(--r-sm); padding: 16px 18px; margin-bottom: 16px;
}
.rt-single-price-main .woocommerce-Price-amount {
  font-family: var(--ff-head) !important; font-size: 34px !important;
  font-weight: 700 !important; color: var(--gold) !important;
}
.rt-single-price-main ins { text-decoration: none; }
.rt-single-price-main del { font-size: 14px !important; color: var(--text-muted) !important; }
.rt-single-price-main del .woocommerce-Price-amount {
  font-size: 14px !important; color: var(--text-muted) !important;
}
.rt-single-price-tax { font-family: var(--ff-body); font-size: 11px; color: var(--text-muted); margin-top: 4px; }

/* Watching badge */
.rt-watching {
  display: inline-flex !important; align-items: center; gap: 7px;
  background: var(--bg-mid); border: 1px solid var(--border);
  padding: 5px 12px; border-radius: var(--r-pill); margin-bottom: 14px;
  font-family: var(--ff-body); font-size: 11px; color: var(--text-muted);
}
.rt-watching__dot {
  width: 7px; height: 7px; background: var(--green);
  border-radius: 50%; flex-shrink: 0;
  animation: rtPulse 2s infinite;
}
@keyframes rtPulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* Formularz koszyka – nadpisanie WooCommerce */
.rt-single-add-to-cart .quantity { display: inline-flex !important; }
.rt-single-add-to-cart .qty {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-sm) !important; padding: 10px 12px !important;
  font-family: var(--ff-body) !important; font-size: 15px !important;
  font-weight: 700 !important; color: var(--text) !important;
  width: 72px !important; text-align: center !important;
  background: var(--white) !important;
}
.rt-single-add-to-cart .qty:focus { border-color: var(--navy) !important; outline: none !important; }
.rt-single-add-to-cart .cart { display: flex !important; gap: 10px !important; align-items: center !important; margin-bottom: 10px !important; }
.rt-single-add-to-cart .single_add_to_cart_button,
.single_add_to_cart_button {
  background: var(--green) !important; border-color: var(--green) !important;
  color: #fff !important; border-radius: var(--r-sm) !important;
  font-family: var(--ff-body) !important; font-size: 15px !important;
  font-weight: 700 !important; letter-spacing: .04em !important;
  padding: 13px 28px !important; cursor: pointer !important;
  transition: background .2s, transform .15s, box-shadow .2s !important;
  flex: 1 !important;
}
.rt-single-add-to-cart .single_add_to_cart_button:hover,
.single_add_to_cart_button:hover {
  background: #15803d !important; border-color: #15803d !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 18px rgba(22,163,74,.35) !important;
}

/* Info boxy */
.rt-info-boxes {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-top: 14px;
}
.rt-ibox {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 12px 10px;
  display: flex; align-items: flex-start; gap: 9px;
}
.rt-ibox__icon { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.rt-ibox__title { font-family: var(--ff-body); font-size: 11px; font-weight: 700; color: var(--navy); margin-bottom: 2px; }
.rt-ibox__sub   { font-family: var(--ff-body); font-size: 10px; color: var(--text-muted); line-height: 1.4; }

/* Zakładki */
.rt-product-tabs {
  max-width: 1200px; margin: 28px auto 0; padding: 0 40px;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden;
}
.rt-tabs-nav {
  display: flex; border-bottom: 1px solid var(--border);
  overflow-x: auto; scrollbar-width: none;
}
.rt-tabs-nav::-webkit-scrollbar { display: none; }
.rt-tnav {
  padding: 14px 22px; white-space: nowrap;
  font-family: var(--ff-body); font-size: 12px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted);
  background: none; border: none; border-bottom: 2px solid transparent;
  margin-bottom: -1px; cursor: pointer; transition: color .18s, border-color .18s;
}
.rt-tnav--on { color: var(--navy) !important; border-bottom-color: var(--navy) !important; }
.rt-tnav:hover { color: var(--navy); }
.rt-tpanel { display: none; padding: 22px; }
.rt-tpanel--on { display: block; }
.rt-product-desc { font-family: var(--ff-body); font-size: 14px; color: var(--text-mid); line-height: 1.75; }
.rt-product-desc p { margin-bottom: 12px; }

/* Tabela specyfikacji */
.rt-specs-table { width: 100%; border-collapse: collapse; }
.rt-specs-table tr { border-bottom: 1px solid var(--border); }
.rt-specs-table tr:last-child { border: none; }
.rt-specs-table td { padding: 9px 12px; font-family: var(--ff-body); font-size: 13px; vertical-align: top; }
.rt-specs-table__key { font-weight: 600; color: var(--navy); width: 40%; background: var(--bg-light); }
.rt-specs-table__val { color: var(--text-mid); }

/* Kompatybilność */
.rt-compat-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.rt-compat-chip {
  background: var(--bg-mid); border: 1px solid var(--border);
  padding: 5px 13px; border-radius: var(--r-pill);
  font-family: var(--ff-body); font-size: 12px; font-weight: 600; color: var(--text);
}

/* Powiązane produkty */
.rt-related-wrap { max-width: 1200px; margin: 28px auto 0; padding: 0 40px 60px; }
.rt-related-head { margin-bottom: 20px; }
.rt-related-head h2 { font-size: 22px; margin: 4px 0 0; }
.rt-related-grid {
  display: grid !important; grid-template-columns: repeat(4,1fr) !important;
  gap: 18px !important; list-style: none !important; padding: 0 !important; margin: 0 !important;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 1100px) {
  .rt-shop-header__inner { padding: 0 20px; }
  .rt-catalog-layout { grid-template-columns: 1fr; padding: 0 20px 40px; overflow-x: hidden !important; }
  .rt-filter-mob-bar { display: flex; }
  .rt-sidebar {
    position: fixed; top: 0; left: -300px; width: 280px; height: 100vh;
    z-index: 200; box-shadow: 4px 0 24px rgba(0,0,0,.4);
    transition: left .3s; overflow-y: auto;
  }
  .rt-sidebar--open { left: 0 !important; }
  .rt-shop-sf__close { display: flex !important; }
  .rt-shop-main { padding: 14px 0 0; overflow-x: hidden !important; }
  .rt-products-grid { 
    grid-template-columns: repeat(2, 1fr) !important; 
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .rt-pcard { min-width: 0 !important; }
  .rt-single-layout { grid-template-columns: 1fr; padding: 20px 20px 0; gap: 24px; }
  .rt-single-gallery { position: static; }
  .rt-product-tabs { margin: 20px 20px 0; padding: 0; }
  .rt-related-wrap { padding: 0 20px 40px; }
  .rt-related-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 640px) {
  .rt-shop-header__inner { padding: 0 16px; }
  .rt-catalog-layout { padding: 0 12px 32px; }
  .rt-shop-main { padding: 12px 0 0; }
  .rt-products-grid { grid-template-columns: 1fr !important; gap: 1px !important; }
  .rt-single-layout { padding: 16px 16px 0; gap: 18px; }
  .rt-single-title { font-size: 22px !important; }
  .rt-info-boxes { grid-template-columns: 1fr; }
  .rt-product-tabs { margin: 16px 12px 0; }
  .rt-related-wrap { padding: 0 12px 32px; }
  .rt-related-grid { grid-template-columns: 1fr !important; }
  .rt-tabs-nav .rt-tnav { padding: 12px 14px; font-size: 11px; }
  .woocommerce-breadcrumb, .rt-breadcrumb { padding: 9px 0; }
  .rt-breadcrumb__inner { padding: 0 16px; }
}

/* Body overlay gdy sidebar otwarty (mobile) */
body.rt-sidebar-open::after {
  content: ''; position: fixed; inset: 0; background: rgba(0,0,0,.55);
  z-index: 199;
}

/* ================================================================
   WYSZUKIWARKA PORTALU – ciemna (jak na screenie)
   ================================================================ */
/* ================================================================
   PORTAL – NOWY LAYOUT: sidebar wyszukiwarki + siatka kart
   ================================================================ */

/* Layout wrapper: sidebar lewo + main prawo */
.rth-portal-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  align-items: start;
}

/* ── SIDEBAR wyszukiwarki (styl jak zdjęcie 1 – ciemny) ───── */
.rth-portal-sidebar {
  position: sticky;
  top: 80px;
}

.rth-search-form {
  background: #1a1a2e;
  border-radius: var(--r-md);
  padding: 20px 18px 18px;
  box-shadow: 0 4px 24px rgba(0,0,0,.28);
}

.rth-search-head {
  display: flex; align-items: center; gap: 9px;
  color: rgba(255,255,255,.92);
  font-family: var(--ff-body);
  font-size: 14px; font-weight: 700; letter-spacing: .03em;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

/* Główne pole tekstowe */
.rth-sf-input {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-sm);
  padding: 11px 14px;
  font-family: var(--ff-body);
  font-size: 13px; color: #fff;
  outline: none; margin-bottom: 14px;
  transition: border-color .2s, background .2s;
}
.rth-sf-input::placeholder { color: rgba(255,255,255,.35); }
.rth-sf-input:focus { border-color: var(--gold-lt); background: rgba(255,255,255,.12); }

/* Grupy pól z labelem */
.rth-sf-group { margin-bottom: 14px; }

.rth-sf-label {
  display: block;
  font-family: var(--ff-body);
  font-size: 9px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: 7px;
}

/* Select */
.rth-sf-select {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-sm);
  padding: 11px 32px 11px 14px;
  font-family: var(--ff-body);
  font-size: 13px; color: rgba(255,255,255,.88);
  outline: none; appearance: none; cursor: pointer;
  transition: border-color .2s, background .2s;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath fill='%23C49A28' d='M1 1l4.5 4.5L10 1'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.rth-sf-select:focus { border-color: var(--gold-lt); background-color: rgba(255,255,255,.12); }
.rth-sf-select option { background: #1a1a2e; color: #fff; }

/* Pola range (cena, rok) */
.rth-sf-range { display: flex; gap: 8px; align-items: center; }
.rth-sf-range-sep { color: rgba(255,255,255,.4); font-size: 13px; flex-shrink: 0; }
.rth-sf-range-input {
  flex: 1; min-width: 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-sm);
  padding: 11px 12px;
  font-family: var(--ff-body);
  font-size: 13px; color: rgba(255,255,255,.88);
  outline: none; transition: border-color .2s;
}
.rth-sf-range-input::placeholder { color: rgba(255,255,255,.35); }
.rth-sf-range-input:focus { border-color: var(--gold-lt); }

/* Checkboxy */
.rth-sf-checkboxes { display: flex; flex-direction: column; gap: 8px; }
.rth-sf-check {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--ff-body);
  font-size: 13px; color: rgba(255,255,255,.75);
  cursor: pointer;
}
.rth-sf-check input[type="checkbox"] {
  width: 15px; height: 15px;
  accent-color: var(--gold-lt); cursor: pointer; flex-shrink: 0;
}
.rth-sf-check:hover { color: #fff; }

/* Przyciski formularza */
.rth-sf-submit {
  width: 100%; margin-top: 16px;
  background: var(--gold-lt); color: var(--dark);
  border: none; border-radius: var(--r-sm);
  font-family: var(--ff-body); font-size: 12px; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 13px; cursor: pointer;
  transition: background .18s, transform .15s;
}
.rth-sf-submit:hover { background: #a07818; color: #fff; transform: translateY(-1px); }

.rth-sf-clear {
  display: block; text-align: center; margin-top: 8px;
  font-family: var(--ff-body); font-size: 11px; font-weight: 600;
  color: rgba(255,255,255,.4); text-decoration: none;
  letter-spacing: .05em; transition: color .18s;
}
.rth-sf-clear:hover { color: rgba(255,255,255,.75); }

/* ── PRAWA CZĘŚĆ: pasek + siatka ─────────────────────────── */
.rth-portal-main { min-width: 0; }

.rth-portal-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; flex-wrap: wrap; gap: 10px;
}
.rth-portal-count {
  font-family: var(--ff-body); font-size: 13px; color: var(--text-muted);
}
.rth-portal-bar-right { display: flex; align-items: center; gap: 10px; }
.rth-portal-sort {
  border: 1.5px solid var(--border); background: var(--white);
  padding: 6px 11px; font-family: var(--ff-body); font-size: 12px;
  color: var(--text-mid); border-radius: var(--r-sm); outline: none; cursor: pointer;
}
.rth-btn--gold {
  background: var(--gold-lt) !important;
  border-color: var(--gold-lt) !important;
  color: var(--dark) !important;
  font-weight: 800 !important;
}
.rth-btn--gold:hover {
  background: #a07818 !important; border-color: #a07818 !important; color: #fff !important;
}

/* Responsive portal */
@media (max-width: 960px) {
  .rth-portal-layout { grid-template-columns: 1fr; }
  .rth-portal-sidebar { position: static; }
  .rth-search-form { padding: 16px; }
  .rth-sf-range { }
}
@media (max-width: 600px) {
  .rth-sf-range { flex-wrap: wrap; }
  .rth-sf-range-input { flex: 1 1 calc(50% - 16px); }
}

/* Grid natywnych kart portalu na stronie głównej */
.rtads-grid--home {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 18px !important;
}

@media (max-width: 1100px) { .rtads-grid--home { grid-template-columns: repeat(3,1fr) !important; } }
@media (max-width: 760px)  { .rtads-grid--home { grid-template-columns: repeat(2,1fr) !important; } }
@media (max-width: 480px)  { .rtads-grid--home { grid-template-columns: 1fr !important; } }

@media (max-width: 960px) {
  .rth-portal-search { padding: 14px 16px; }
  .rth-portal-search__form { flex-wrap: wrap; }
  .rth-portal-search__field--sm   { width: calc(50% - 4px); }
  .rth-portal-search__field--grow { width: 100%; flex: none; }
  .rth-portal-search__form .rth-btn { width: 100% !important; text-align: center !important; }
}

/* ================================================================
   POPRAWKI: WYSZUKIWARKA ASTRY + MAPA USŁUG
   ================================================================ */

/* Napraw ciemny element przy lupce Astry */
.ast-search-menu-icon .ast-search-icon,
.ast-header-search .ast-search-icon {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

/* Ukryj ciemne tło które pojawia się przy kliknięciu */
.ast-search-menu-icon.ast-dropdown-active .ast-search-icon,
.ast-search-menu-icon .ast-search-icon svg,
.ast-search-menu-icon .ast-search-icon:before,
.ast-search-menu-icon .ast-search-icon:after {
  background: transparent !important;
  box-shadow: none !important;
}

/* Formularz wyszukiwania Astry – styl spójny z motywem */
.ast-search-menu-icon .search-form,
.ast-header-search .search-form {
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-pill) !important;
  box-shadow: 0 4px 20px var(--shadow-lg) !important;
  overflow: hidden !important;
  padding: 0 !important;
}

.ast-search-menu-icon .search-field,
.ast-header-search .search-field {
  background: transparent !important;
  border: none !important;
  padding: 10px 16px !important;
  font-family: var(--ff-body) !important;
  font-size: 14px !important;
  color: var(--text) !important;
  outline: none !important;
  box-shadow: none !important;
}

.ast-search-menu-icon .search-submit,
.ast-header-search .search-submit {
  background: var(--navy) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 var(--r-pill) var(--r-pill) 0 !important;
  padding: 10px 18px !important;
  cursor: pointer !important;
  font-size: 13px !important;
}

/* Ciemny overlay/backdrop przy otwartej wyszukiwarce */
.ast-search-menu-icon-layout--slide-in::before,
.ast-search-menu-icon-layout--full-screen::before {
  background: rgba(26,26,46,.6) !important;
}

/* Ikonka lupy – przywrócenie bez tła wewnątrz */
.ast-search-menu-icon svg,
.ast-search-menu-icon .ast-search-icon {
    display: block !important;
}

/* Usuń tło/złoty kolor wewnątrz okienka wyszukiwania */
.ast-search-menu-icon .search-field,
.ast-header-search .search-field {
    background: transparent !important;
    background-image: none !important;
}

/* Ikonka lupy – poprawny kolor */
.ast-search-menu-icon svg path,
.ast-search-menu-icon svg {
  fill: var(--text) !important;
  stroke: var(--text) !important;
}

/* Mapa usług – kontener szerszy o 50% */
.page-id-* .ast-container,
body.page .ast-container {
  max-width: 100% !important;
}

/* Konkretna strona mapy */
.page-template-default .entry-content,
.page .entry-content {
  max-width: 100% !important;
}

/* Kontener mapy – poszerzony */
.wpgmza_map,
.wpgmza-map,
#wpgmza_map,
[id^="wpgmza_map"],
.wpgmaps_marker,
iframe[src*="google.com/maps"],
.mapa-uslug-container,
.wp-block-group {
  width: 100% !important;
  max-width: 100% !important;
}

/* Jeśli mapa jest w iframe */
.entry-content iframe {
  width: 100% !important;
  max-width: 100% !important;
}

/* Astra content area na stronach z mapą – full width */
.ast-page-builder-template #content,
body.page #primary {
  max-width: 100% !important;
  padding-left: 3% !important;
  padding-right: 3% !important;
}
.blog body,
.single-post body,
.page-template-default body,
body.page {
  background: var(--gray-mid) !important;
}

/* Karty postów na blogu */
article.post {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  transition: transform .25s, box-shadow .25s !important;
  margin-bottom: 20px !important;
}
article.post:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px var(--shadow-lg) !important;
}

.entry-thumbnail img {
  border-radius: 0 !important;
  height: 220px !important; object-fit: cover !important; width: 100% !important;
}

.entry-header .entry-title a {
  font-family: var(--ff-head) !important; color: var(--dark) !important;
}
.entry-header .entry-title a:hover { color: var(--navy) !important; }

/* ================================================================
   PORTAL – integracja kolorów pluginu
   ================================================================ */
.rtads-btn--primary,
.rtads-btn--gold {
  background: var(--navy) !important;
  color: #fff !important;
  border-radius: var(--r-pill) !important;
  font-family: var(--ff-body) !important;
  font-weight: 700 !important; letter-spacing: .8px !important;
}
.rtads-btn--primary:hover,
.rtads-btn--gold:hover {
  background: var(--navy-hover) !important; color: #fff !important;
}

.rtads-card {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  transition: transform .25s, box-shadow .25s !important;
}
.rtads-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 28px var(--shadow-lg) !important;
}
.rtads-card__name {
  font-family: var(--ff-body) !important;
  font-weight: 500 !important; color: var(--text) !important;
}
.rtads-card__price {
  font-family: var(--ff-head) !important;
  font-size: 18px !important; font-weight: 700 !important;
  color: var(--gold) !important;
}
.rtads-filter { background: var(--navy) !important; border-radius: var(--r-md) !important; }
.rtads-filter .rtads-btn--primary { background: var(--gold) !important; color: #fff !important; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1100px) {
  .rth-container { padding: 0 28px; }
  .rth-grid4 { grid-template-columns: repeat(3, 1fr); }
  .woocommerce ul.products { grid-template-columns: repeat(3,1fr) !important; }
}

@media (max-width: 960px) {
  .rth-hero { min-height: 380px; }
  .rth-hero__inner { padding: 52px 24px; }
  .rth-hero__title { font-size: 36px !important; }
  .rth-grid4 { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .rth-blog-grid { grid-template-columns: repeat(2, 1fr); }
  .rth-features-row { grid-template-columns: repeat(2, 1fr); }
  .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .rth-section, .rth-section--gray, .rth-section--white, .rth-section--portal { padding: 40px 0; }
  .rth-container { padding: 0 20px; }
}

@media (max-width: 640px) {
  .rth-hero { min-height: 320px; }
  .rth-hero__inner { padding: 40px 16px; }
  .rth-hero__title { font-size: 28px !important; }
  .rth-hero__sub { font-size: 14px; margin-bottom: 24px; }
  .rth-hero__btns { flex-direction: column; gap: 10px; }
  .rth-hero__btns .rth-btn { text-align: center; }
  .rth-section-head { flex-direction: column; align-items: flex-start; gap: 6px; }
  .rth-section-head h2 { font-size: 20px !important; }
  .rth-grid4 { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .rth-blog-grid { grid-template-columns: 1fr; }
  .rth-features-row { grid-template-columns: 1fr; gap: 10px; }
  .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
  .rth-container { padding: 0 14px; }
  .rth-section, .rth-section--gray, .rth-section--white, .rth-section--portal { padding: 28px 0; }
}

@media (max-width: 420px) {
  .rth-grid4 { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
  .rth-hero__title { font-size: 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   RetroTarg Sklep – styl portalu ogłoszeń
   Używa klas rtads-* z pluginu + własne rts-*
   ═══════════════════════════════════════════════════════════ */

/* ── Nagłówek strony ─────────────────────────────────────── */
.rtads-listing-page-header { display:none !important; } .rtads-listing-page-header-DISABLED {
    background: var(--navy, #1a1a2e);
    padding: 32px 0 24px;
}
.rtads-listing-page-header__inner {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 24px;
}
.rtads-listing-page-header h1 {
    font-family: 'Roboto', sans-serif;
    font-size: 1.8rem;
    color: #fff;
    margin: 6px 0 0;
}

/* ── Wrap (pełna szerokość jak portal) ───────────────────── */
.rt-sklep-archive-wrap {
    display: flex;
    gap: 24px;
    max-width: 100%;
    margin: 0 auto;
    padding: 28px 32px;
    font-family: 'Roboto', sans-serif;
    align-items: flex-start;
    /* overflow musi być visible żeby sticky działało */
    overflow: visible !important;
}

/* Kontener siatki musi rosnąć */
#rts-grid-wrap {
    flex: 1;
    min-width: 0;
    overflow: visible !important;
}

/* ── Siatka kart (identyczna jak rtads-grid) ─────────────── */
.rts-archive-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}
@media (max-width: 1400px) { .rts-archive-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 1100px) { .rts-archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .rts-archive-grid { grid-template-columns: repeat(2, 1fr); } }

/* Karta produktu jako karta portalu */
.rts-prod-card {
    cursor: pointer;
    user-select: none;
    transition: transform .18s, box-shadow .18s;
}
.rts-prod-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,.13);
}
.rts-card__brand {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--gold-lt, #C49A28);
    font-weight: 700;
    margin-bottom: 3px;
}

/* Ceny WooCommerce wewnątrz karty */
.rts-prod-card .rtads-card__price .woocommerce-Price-amount { color: var(--gold, #8B6914); }
.rts-prod-card .rtads-card__price del { opacity: .5; font-size: .85em; }
.rts-prod-card .rtads-card__price ins { text-decoration: none; }

/* Badge'e na karcie */
.rts-badge-sale { background: #dc2626 !important; color: #fff !important; left: 10px !important; right: auto !important; }
.rts-stan--nowy        { background: #16a34a !important; color: #fff !important; }
.rts-stan--regenerowany{ background: #2563eb !important; color: #fff !important; }
.rts-stan--uzywany     { background: #6b7280 !important; color: #fff !important; }

/* ── Pasek wyników ───────────────────────────────────────── */
.rtads-results__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 10px;
}
.rtads-results__count { font-size: .88rem; color: #6b7280; font-weight: 600; }
.rtads-results__bar-right { display: flex; gap: 10px; align-items: center; }

/* ── Paginacja WooCommerce w stylu portalu ───────────────── */
.rts-wc-pager { margin-top: 28px; display: flex; justify-content: center; gap: 6px; flex-wrap: wrap; }
.rts-wc-pager .page-numbers {
    min-width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px;
    border: 1.5px solid #e5e7eb;
    background: #fff;
    color: #374151;
    font-size: .88rem;
    font-weight: 600;
    text-decoration: none;
    transition: all .15s;
    padding: 0 10px;
}
.rts-wc-pager .page-numbers:hover { border-color: #1a1a2e; color: #1a1a2e; }
.rts-wc-pager .page-numbers.current { background: #1a1a2e; border-color: #1a1a2e; color: #fff; }

/* ── Modal ───────────────────────────────────────────────── */
.rts-modal-bg {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.82);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    backdrop-filter: blur(4px);
}
.rts-modal {
    background: #fff;
    border-radius: 14px;
    width: 100%;
    max-width: 960px;
    max-height: 92vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 80px rgba(0,0,0,.55);
    animation: rtsModalIn .22s ease;
}
@keyframes rtsModalIn {
    from { opacity: 0; transform: translateY(16px) scale(.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Layout modala (galeria | info) */
.rts-modal-inner-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 480px;
}
@media (max-width: 680px) {
    .rts-modal-inner-wrap { grid-template-columns: 1fr; }
    .rts-modal-gallery    { border-radius: 14px 14px 0 0 !important; }
}

/* Bardzo male ekrany - modal nie wychodzi poza ekran */
@media (max-width: 480px) {
    .rts-modal-bg {
       padding: 60px 8px 8px !important;
    align-items: flex-start !important;
      
    }
    .rts-modal {
        max-width: 100% !important;
        width: 100% !important;
        max-height: 85vh !important;
        border-radius: 12px !important;
      
    }
    .rts-modal-inner-wrap {
        min-height: auto !important;
    }
    .rts-modal-gallery .rtads-modal-main-img {
        max-height: 180px !important;
    }
    .rts-modal-info {
        padding: 18px 16px !important;
        max-height: 55vh !important;
    }
}

/* Galeria modala */
.rts-modal-gallery {
    background: #f4f4f5;
    border-radius: 14px 0 0 14px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.rts-gal-empty { align-items: center; justify-content: center; font-size: 3rem; }
.rts-modal-gallery .rtads-modal-main-img {
    width: 100%; flex: 1; object-fit: cover; max-height: 380px;
}

/* Lightbox zdjęcia (w modalu sklepu) */
#rts-lightbox{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.86);
    z-index: 100000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
#rts-lightbox .rts-lightbox__img{
    max-width: 92vw;
    max-height: 92vh;
    width: auto;
    height: auto;
    border-radius: 10px;
    box-shadow: 0 18px 60px rgba(0,0,0,.55);
    cursor: zoom-out;
}
.rts-modal-gallery .rtads-modal-thumbs {
    display: flex; gap: 6px; padding: 10px 12px;
    background: #e9e9eb; flex-wrap: wrap;
}
.rts-modal-gallery .rtads-modal-thumb {
    width: 58px; height: 46px; object-fit: cover;
    border-radius: 6px; cursor: pointer;
    border: 2px solid transparent; transition: border-color .15s;
}
.rts-modal-gallery .rtads-modal-thumb.is-active,
.rts-modal-gallery .rtads-modal-thumb:hover { border-color: #C49A28; }

/* Panel info modala */
.rts-modal-info {
    padding: 28px 28px 24px;
    display: flex; flex-direction: column; gap: 14px;
    overflow-y: auto; max-height: 92vh;
}
.rts-modal-info .rtads-modal-header {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
}
.rts-modal-info .rtads-modal-title { font-size: 1.2rem; font-weight: 700; color: #1a1a2e; margin: 0; line-height: 1.35; }

/* Cena w modalu */
.rts-price-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.rts-modal-price-val .woocommerce-Price-amount { font-size: 1.55rem; font-weight: 800; color: #8B6914; }
.rts-modal-price-val del .woocommerce-Price-amount { font-size: .95rem; color: #9ca3af; font-weight: 400; }
.rts-modal-price-val ins { text-decoration: none; }
.rts-stock { font-size: .78rem; font-weight: 700; padding: 4px 10px; border-radius: 20px; }
.rts-stock--in  { background: #dcfce7; color: #16a34a; }
.rts-stock--out { background: #fee2e2; color: #dc2626; }

/* "X osób przegląda" */
.rts-watching {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: .82rem; color: #f97316; font-weight: 600;
    background: rgba(249,115,22,.09); padding: 5px 12px;
    border-radius: 20px; width: fit-content;
}
.rts-watching__dot {
    width: 8px; height: 8px; background: #f97316; border-radius: 50%;
    animation: rtsWatchPulse 1.4s infinite; flex-shrink: 0;
}
@keyframes rtsWatchPulse {
    0%,100% { opacity:1; transform:scale(1); } 50% { opacity:.4; transform:scale(.65); }
}

/* Przyciski modala */
.rts-modal-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.rts-cart-btn {
    flex: 1; display: flex !important; align-items: center; justify-content: center;
    font-weight: 700; font-size: .93rem; padding: 13px 18px;
    text-decoration: none;
}
.rts-fullpage-btn { padding: 13px 16px !important; white-space: nowrap; font-size: .87rem; }

/* Info boxy w modalu */
.rts-info-boxes .rt-ibox { background: #f8f9fa; border: 1px solid #e5e7eb; }
.rts-info-boxes .rt-ibox__title { color: #1a1a2e; }
.rts-info-boxes .rt-ibox__sub   { color: #6b7280; }

/* Specs */
.rts-specs-block {
    background: #f8f9fa; border-radius: 10px; padding: 12px 16px;
}
.rts-specs-block .rtads-modal-spec {
    display: flex; justify-content: space-between; padding: 7px 0;
    border-bottom: 1px solid #e5e7eb; font-size: .86rem;
}
.rts-specs-block .rtads-modal-spec:last-child { border-bottom: none; }
.rts-specs-block .rtads-modal-spec__lbl { color: #6b7280; font-weight: 600; }
.rts-specs-block .rtads-modal-spec__val { color: #1a1a2e; font-weight: 500; text-align: right; }

/* Kompatybilność */
.rts-modal-compat { display: flex; flex-direction: column; gap: 8px; }
.rts-modal-section-lbl { font-size: .75rem; text-transform: uppercase; letter-spacing: .07em; font-weight: 700; color: #6b7280; margin: 0; }
.rts-compat-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.rt-compat-chip { background: #1a1a2e; color: #fff; font-size: .74rem; font-weight: 600; padding: 4px 10px; border-radius: 20px; }

/* Opis */
.rts-modal-desc { display: flex; flex-direction: column; gap: 6px; }
.rts-modal-desc-txt { font-size: 1rem; color: #374151; line-height: 1.65; max-height: 150px; overflow-y: auto; }

/* Mapa */
.rts-map-link {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .82rem; color: #2563eb; text-decoration: none; font-weight: 600;
    padding: 6px 0; border-bottom: 1px dashed #bfdbfe; width: fit-content;
    transition: color .15s;
}
.rts-map-link:hover { color: #1d4ed8; }

/* Serduszko modalu */
.rts-modal-fav-btn {
    width: 38px; height: 38px; flex-shrink: 0;
    border-radius: 50%; border: 1.5px solid #e5e7eb;
    background: #fff; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    color: #9ca3af; transition: all .15s;
}
.rts-modal-fav-btn:hover,
.rts-modal-fav-btn.is-active { border-color: #f97316; color: #f97316; }
.rts-modal-fav-btn.is-active { background: rgba(249,115,22,.07); }

/* Serduszko na karcie */
.rts-fav-btn.is-active svg { fill: #f97316 !important; stroke: #f97316 !important; }

/* Brak wyników */
.rtads-empty { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: #9ca3af; }
.rtads-empty span { font-size: 3rem; display: block; margin-bottom: 12px; }
.rtads-empty p { font-size: 1rem; }

/* ── Kafelki Kategoria + SKU (single product) ────────────── */
.rt-meta-tiles {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 4px;
}
.rt-meta-tile {
    background: #f8f9fa;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 12px 16px;
}
.rt-meta-tile__label {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: #9ca3af;
    font-weight: 700;
    margin-bottom: 5px;
}
.rt-meta-tile__value {
    font-size: .93rem;
    color: #1a1a2e;
    font-weight: 600;
}

/* ── Kafelek mapa serwisów – link bez niebieskiego koloru ── */
.rt-ibox__map-link {
    text-decoration: none;
    color: inherit;
    display: block;
}
.rt-ibox__map-link:hover .rt-ibox__title { color: #C49A28; }

/* ── Modal – usuń niebieski link do mapy (jest w kafelkach) ─ */
.rts-map-link { display: none !important; }

/* ── Kafelki SKU + Kategoria w modalu ────────────────────── */
.rts-modal-tiles {
    grid-template-columns: 1fr 1fr;
    margin-top: 0;
}
/* Na wąskim panelu modala jeden kafelek może być pełnej szer. jeśli jest tylko jeden */
.rts-modal-tiles .rt-meta-tile:only-child {
    grid-column: 1 / -1;
}

/* ── Paginacja WooCommerce – usuń kropki, napraw wygląd ──── */
.rts-wc-pager .page-numbers,
.rtads-pagination .page-numbers {
    min-width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px;
    border: 1.5px solid #e5e7eb;
    background: #fff;
    color: #374151;
    font-size: .88rem;
    font-weight: 600;
    text-decoration: none;
    transition: all .15s;
    padding: 0 10px;
    /* Usuń kropki które WooCommerce/WP dodaje po linkach */
    list-style: none !important;
}
/* WooCommerce opakowuje w <ul> – musimy usunąć style listy */
.rts-wc-pager ul.page-numbers,
.rtads-pagination ul.page-numbers,
#rts-pagination ul.page-numbers {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    list-style: none !important;
    padding: 0; margin: 0;
}
.rts-wc-pager ul.page-numbers li,
.rtads-pagination ul.page-numbers li {
    list-style: none !important;
    display: flex;
}
/* Wyjdź z WC - page-numbers generowane jako <a> i <span> */
.rts-wc-pager .page-numbers:hover,
.rtads-pagination .page-numbers:hover { border-color: #1a1a2e; color: #1a1a2e; }
.rts-wc-pager .page-numbers.current,
.rtads-pagination .page-numbers.current { background: #1a1a2e; border-color: #1a1a2e; color: #fff; }
.rts-wc-pager .page-numbers.dots,
.rtads-pagination .page-numbers.dots { border-color: transparent; background: transparent; cursor: default; }

/* ── Filtr sticky – idzie razem ze scrollem ─────────────── */
/* Astra ustawia overflow:hidden na .site-content i podobnych - musimy to nadpisać */
.woocommerce-page .site-content,
.woocommerce-page .content-area,
.woocommerce-page .ast-container,
.woocommerce-page #content,
.woocommerce-page .entry-content {
    overflow: visible !important;
}
.rt-sklep-archive-wrap .rtads-filter {
     position: static !important;
    top: auto !important;
    max-height: none !important;
    overflow: visible !important;
    align-self: flex-start;
    flex-shrink: 0;
    width: 240px !important;
    min-width: 240px !important;
    
}
/* Scrollbar w filtrze – subtelny */
.rt-sklep-archive-wrap .rtads-filter::-webkit-scrollbar { width: 4px; }
.rt-sklep-archive-wrap .rtads-filter::-webkit-scrollbar-track { background: transparent; }
.rt-sklep-archive-wrap .rtads-filter::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 4px; }

/* ── Link w kafelku Kategoria ───────────────────────────── */
.rt-meta-tile__link {
    color: #1a1a2e;
    text-decoration: none;
    font-weight: 600;
    border-bottom: 1.5px dashed #C49A28;
    transition: color .15s, border-color .15s;
}
.rt-meta-tile__link:hover { color: #C49A28; border-bottom-style: solid; }

/* ═══════════════════════════════════════════════════════
   ARTYKUŁY – naprawa siatki
   ═══════════════════════════════════════════════════════ */
.rth-grid3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px)  { .rth-grid3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .rth-grid3 { grid-template-columns: 1fr; } }

.rth-article-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    display: flex;
    flex-direction: column;
    transition: transform .18s, box-shadow .18s;
}
.rth-article-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,.12); }
.rth-article-card__img-wrap { display: block; aspect-ratio: 16/9; overflow: hidden; }
.rth-article-card__img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.rth-article-card:hover .rth-article-card__img-wrap img { transform: scale(1.04); }
.rth-article-card__body { padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.rth-article-card__date { font-size: .75rem; color: #9ca3af; font-weight: 500; }
.rth-article-card__title {
    font-family: 'Roboto', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: #1a1a2e;
    text-decoration: none;
    line-height: 1.4;
}
.rth-article-card__title:hover { color: #C49A28; }
.rth-article-card__excerpt { font-size: .85rem; color: #6b7280; line-height: 1.6; flex: 1; }

/* ── Features bar ─────────────────────────────────────── */
.rth-features {
    background: #1a1a2e;
    padding: 28px 0;
}
.rth-features__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 32px;
}
.rth-feature {
    display: flex;
    align-items: center;
    gap: 14px;
    color: #fff;
}
.rth-feature__icon { font-size: 1.8rem; flex-shrink: 0; }
.rth-feature strong { display: block; font-size: .9rem; font-weight: 700; font-family: 'Roboto', sans-serif; }
.rth-feature p { margin: 0; font-size: .78rem; color: rgba(255,255,255,.6); font-family: 'Roboto', sans-serif; }
@media (max-width: 900px)  { .rth-features__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px)  { 
    .rth-features__grid { grid-template-columns: 1fr; }
    .rth-feature {
        flex-direction: column !important;
        text-align: center !important;
        gap: 10px !important;
    }
}

/* ═══════════════════════════════════════════════════════
   ROBOTO WSZĘDZIE – nadpisanie Playfair
   ═══════════════════════════════════════════════════════ */
* { font-family: 'Roboto', sans-serif !important; }

/* ═══════════════════════════════════════════════════════
   STOPKA – nowy layout
   ═══════════════════════════════════════════════════════ */
/* Ukryj oryginalną stopkę Astry i zastąp naszą */
.site-footer,
.ast-footer-overlay { display: none !important; }

#rth-footer {
    background: #0f0f1a;
    color: rgba(255,255,255,.75);
    font-family: 'Roboto', sans-serif;
    font-size: .88rem;
}
/* Usuń newsletter row nad stopką jeśli istnieje */
.ast-above-footer { display: none !important; }

/* Główna część stopki */
.rth-footer-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 56px 32px 40px;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.4fr;
    gap: 40px;
}

/* Kolumna 1 – logo + motto + social */
.rth-footer-brand {}
.rth-footer-logo {
    display: block;
    max-height: 35px;
    width: auto;
    margin-bottom: 14px;
    filter: brightness(0) invert(1);
}
.rth-footer-motto {
    font-size: .85rem;
    color: rgba(255,255,255,.5);
    font-style: italic;
    margin-bottom: 20px;
    line-height: 1.5;
}
.rth-footer-social { display: flex; gap: 14px; }
.rth-footer-social a {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.2);
    color: rgba(255,255,255,.7);
    text-decoration: none;
    transition: border-color .2s, color .2s, background .2s;
}
.rth-footer-social a:hover { border-color: #C49A28; color: #C49A28; background: rgba(196,154,40,.08); }
.rth-footer-social svg { display: block; }

/* Kolumny 2 & 3 – linki */
.rth-footer-col h4 {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin: 0 0 16px;
    font-family: 'Roboto', sans-serif;
}
.rth-footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.rth-footer-col ul a {
    color: rgba(255,255,255,.7);
    text-decoration: none;
    font-size: .88rem;
    transition: color .18s;
}
.rth-footer-col ul a:hover { color: #C49A28; }

/* Kolumna 4 – newsletter */
.rth-footer-newsletter h4 {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin: 0 0 10px;
    font-family: 'Roboto', sans-serif;
}
.rth-footer-newsletter p {
    font-size: .82rem;
    color: rgba(255,255,255,.5);
    margin: 0 0 16px;
    line-height: 1.5;
}
/* Styl formularza newslettera na ciemnym tle */
#rth-footer .tnp-widget input[type="email"],
#rth-footer .tnp input[type="email"] {
    width: 100%; padding: 10px 14px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 8px; color: #fff; font-size: .88rem;
    outline: none; box-sizing: border-box;
    font-family: 'Roboto', sans-serif;
}
#rth-footer .tnp-widget input[type="email"]:focus,
#rth-footer .tnp input[type="email"]:focus { border-color: #C49A28; }
#rth-footer .tnp-widget input[type="submit"],
#rth-footer .tnp input[type="submit"] {
    width: 100%; margin-top: 8px; padding: 10px;
    background: #C49A28; border: none; border-radius: 8px;
    color: #fff; font-weight: 700; font-size: .88rem;
    cursor: pointer; transition: background .18s;
    font-family: 'Roboto', sans-serif;
}
#rth-footer .tnp-widget input[type="submit"]:hover,
#rth-footer .tnp input[type="submit"]:hover { background: #a8831f; }
#rth-footer .tnp-widget label,
#rth-footer .tnp label { display: none; }

/* Linia oddzielająca */
.rth-footer-divider {
    border: none;
    border-top: 1px solid rgba(255,255,255,.08);
    margin: 0 32px;
}

/* Bottom bar */
.rth-footer-bottom {
    max-width: 1200px;
    margin: 0 auto;
    padding: 18px 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: .78rem;
    color: rgba(255,255,255,.3);
}
.rth-footer-bottom a { color: rgba(255,255,255,.3); text-decoration: none; }
.rth-footer-bottom a:hover { color: rgba(255,255,255,.6); }

@media (max-width: 1024px) {
    .rth-footer-main { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 600px) {
    .rth-footer-main { grid-template-columns: 1fr; padding: 40px 20px 28px; }
    .rth-footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
    .rth-footer-divider { margin: 0 20px; }
    
    /* Footer na środku mobilny */
    .rth-footer-brand,
    .rth-footer-col,
    .rth-footer-newsletter {
        text-align: center !important;
        align-items: center !important;
        display: flex !important;
        flex-direction: column !important;
    }
    
    .rth-footer-logo {
        margin: 0 auto 14px !important;
    }
    
    .rth-footer-social {
        justify-content: center !important;
    }
    
    .rth-footer-col ul {
        align-items: center !important;
    }
    
    #rth-footer .tnp-widget,
    #rth-footer .tnp {
        margin: 0 auto !important;
        max-width: 300px !important;
    }
}

/* ═══════════════════════════════════════════════════════
   KOLOR LINKÓW – granatowy zamiast brązowego Astry
   ═══════════════════════════════════════════════════════ */
a,
.ast-builder-menu-1 .menu-item > a,
.ast-builder-menu-2 .menu-item > a,
.entry-content a,
.woocommerce-MyAccount-navigation a,
.woocommerce-MyAccount-navigation ul li a,
.woocommerce-account .woocommerce a,
.woocommerce-account p a,
.rtads-panel a,
.rtads-tab-btn,
.rtads-kpi--tab {
    color: #1a1a2e !important;
}
a:hover,
.woocommerce-MyAccount-navigation a:hover,
.woocommerce-account .woocommerce a:hover {
    color: #C49A28 !important;
}

/* Aktywna zakładka w panelu – granatowe tło */
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--orders.is-active a {
    color: #fff !important;
    background: #1a1a2e !important;
}

/* Liczniki KPI w panelu portalu */
.rtads-kpi__val { color: #1a1a2e !important; }

/* Usun brązowy Astry globalnie */
:root {
    --ast-global-color-0: #1a1a2e !important;
    --ast-global-color-1: #1a1a2e !important;
    --ast-link-color: #1a1a2e !important;
    --ast-link-hover-color: #C49A28 !important;
}

/* ═══════════════════════════════════════════════════════
   WYRÓŻNIONE OGŁOSZENIA – układ duży + 4 małe
   ═══════════════════════════════════════════════════════ */
.rth-featured-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    align-items: start;
}

/* Duży kafelek – zajmuje pełną wysokość prawej kolumny */
.rth-featured-big .rtads-card {
    height: 100%;
}
.rth-featured-big .rtads-card .rtads-card__img-wrap {
    aspect-ratio: unset;
    height: 340px;
}
.rth-featured-big .rtads-card .rtads-card__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 4 małe kafelki – grid 2x2 */
.rth-featured-small-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}

/* Puste miejsca */
.rth-featured-empty {
    background: #f3f4f6;
    border: 2px dashed #d1d5db;
    border-radius: 12px;
    padding: 40px 20px;
    text-align: center;
    color: #9ca3af;
    font-size: .85rem;
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 900px) {
    .rth-featured-layout { grid-template-columns: 1fr; }
    .rth-featured-big .rtads-card .rtads-card__img-wrap { height: 220px; }
}
@media (max-width: 500px) {
    .rth-featured-small-grid { grid-template-columns: 1fr; }
}


  /* ================================================================
     PANEL KONTA – ULUBIONE: siatka 3-kolumny (v3)
     Klasa rt-fav-3col dodawana przez JS do ISTNIEJĄCEGO kontenera RTADS.
     Karty zachowują swój naturalny rozmiar – zmienia się tylko liczba kolumn.
     ================================================================ */

  /* Siatka 3 kolumny na stronie ulubionych */
  .rt-ulubione-page .woocommerce-MyAccount-content .rt-fav-3col {
      display: grid !important;
      grid-template-columns: repeat(3, 1fr) !important;
      gap: 18px !important;
      width: 100% !important;
  }
  @media (max-width: 900px) {
      .rt-ulubione-page .woocommerce-MyAccount-content .rt-fav-3col {
          grid-template-columns: repeat(2, 1fr) !important;
      }
  }
  @media (max-width: 560px) {
      .rt-ulubione-page .woocommerce-MyAccount-content .rt-fav-3col {
          grid-template-columns: 1fr !important;
      }
  }

  /* Paginacja – wyśrodkowana */
  nav#rt-ulpag-bar {
      display: flex !important;
      justify-content: center !important;
      align-items: center !important;
      width: 100% !important;
      margin-top: 16px !important;
      text-align: center !important;
  }
  nav#rt-ulpag-bar .rt-ulpag {
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      gap: 4px !important;
      list-style: none !important;
      padding: 0 !important; margin: 0 !important;
      flex-wrap: wrap !important;
  }
  nav#rt-ulpag-bar li { margin: 0 !important; }

  .rt-ulpag__btn {
      display: inline-flex;
      align-items: center; justify-content: center;
      min-width: 36px; height: 36px; padding: 0 10px;
      border: 1.5px solid var(--border, #e0e0e0);
      border-radius: 6px;
      background: #fff;
      font-family: var(--ff-body, 'Roboto', sans-serif);
      font-size: 13px; font-weight: 500;
      color: #555;
      cursor: pointer;
      transition: background .18s, border-color .18s, color .18s;
      line-height: 1;
  }
  .rt-ulpag__btn:hover:not(.rt-ulpag__btn--disabled):not(.rt-ulpag__num--active) {
      background: #f4f4f4;
      color: #111;
  }
  .rt-ulpag__num--active {
      background: #1a1a2e !important;
      border-color: #1a1a2e !important;
      color: #fff !important;
      font-weight: 700;
      cursor: default;
  }
  .rt-ulpag__btn--disabled { opacity: 0.35; cursor: not-allowed; }
  .rt-ulpag__ellipsis {
      display: inline-flex;
      align-items: center; justify-content: center;
      width: 36px; height: 36px;
      font-size: 14px; color: #aaa;
  }

  /* ================================================================
     SKLEP / KATEGORIA – spójny szeroki układ na wszystkich stronach
     Gwarantuje że .rtads-listing-wrap zajmuje pełną szerokość
     niezależnie od tego czy strona jest załadowana świeżo czy przez AJAX
     ================================================================ */

  /* Wrapper listingu sklepu zawsze full-width */
  body .rt-sklep-archive-wrap {
      width: 100% !important;
      max-width: 100% !important;
      display: flex !important;
      gap: 24px !important;
      align-items: flex-start !important;
      box-sizing: border-box !important;
  }

  /* Sidebar filtra – stała szerokość */
  body .rt-sklep-archive-wrap > .rtads-filter {
      flex: 0 0 230px !important;
      width: 230px !important;
      min-width: 0 !important;
  }

  /* Sekcja wyników – wypełnia resztę */
  body .rt-sklep-archive-wrap > .rtads-results {
      flex: 1 1 0 !important;
      min-width: 0 !important;
      width: 0 !important; /* wymusza flex-grow */
  }

  /* Siatka kart – zawsze 4 kolumny (responsive niżej) */
  body .rt-sklep-archive-wrap .rts-archive-grid {
      width: 100% !important;
      box-sizing: border-box !important;
  }

  @media (max-width: 600px) {
      body .rt-sklep-archive-wrap { flex-direction: column !important; }
      body .rt-sklep-archive-wrap > .rtads-filter { flex: none !important; width: 100% !important; }
      body .rt-sklep-archive-wrap > .rtads-results { width: 100% !important; }
  }
  
  /* ================================================================
     LOGIN TOOLTIP - identyczny jak w portalu
     ================================================================ */
  .rtads-login-tooltip {
      position: fixed !important;
      background: #ffffff;
      border: 1px solid #e5e7eb;
      border-radius: 12px;
      box-shadow: 0 4px 20px rgba(0,0,0,.15);
      z-index: 100001 !important;
      min-width: 320px;
      animation: rtTooltipFadeIn 0.2s ease-out;
      font-family: 'Roboto', sans-serif;
  }

  @keyframes rtTooltipFadeIn {
      from { opacity: 0; transform: translateY(-5px); }
      to { opacity: 1; transform: translateY(0); }
  }

  .rtads-login-tooltip__content {
      padding: 24px 20px;
      text-align: center;
  }

  .rtads-login-tooltip__icon {
      font-size: 2.5rem;
      margin-bottom: 16px;
      color: #C49A28;
  }

  .rtads-login-tooltip__text {
      font-size: 14px;
      color: #374151;
      margin-bottom: 24px;
      line-height: 1.4;
      font-weight: 400;
  }

  .rtads-login-tooltip__actions {
      display: flex;
      gap: 12px;
      justify-content: center;
  }

  .rtads-login-tooltip__login,
  .rtads-login-tooltip__close {
      padding: 12px 24px;
      font-size: 12px;
      font-weight: 600;
      border-radius: 8px;
      border: none;
      cursor: pointer;
      transition: all 0.2s;
      font-family: 'Roboto', sans-serif;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      min-width: 100px;
  }

  .rtads-login-tooltip__login {
      background: #1f2937;
      color: #ffffff;
  }

  .rtads-login-tooltip__login:hover {
      background: #111827;
      color: #ffffff;
  }

  .rtads-login-tooltip__close {
      background: #ffffff;
      border: 1px solid #d1d5db;
      color: #374151;
  }

  .rtads-login-tooltip__close:hover {
      background: #f9fafb;
      border-color: #9ca3af;
      color: #1f2937;
  }

  .rtads-login-tooltip__arrow {
      position: absolute;
      top: -8px;
      left: 50%;
      transform: translateX(-50%);
      width: 0;
      height: 0;
      border-left: 8px solid transparent;
      border-right: 8px solid transparent;
      border-bottom: 8px solid #ffffff;
  }

  .rtads-login-tooltip::before {
      content: '';
      position: absolute;
      top: -9px;
      left: 50%;
      transform: translateX(-50%);
      width: 0;
      height: 0;
      border-left: 8px solid transparent;
      border-right: 8px solid transparent;
      border-bottom: 8px solid #e5e7eb;
      z-index: -1;
  }

/* =====================================================
   Aktualizacja koszyka - efekt wizualny
   ===================================================== */
.cart-updated {
    animation: cartPulse 1s ease-in-out;
    color: #16a34a !important;
}

@keyframes cartPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); color: #16a34a; }
    100% { transform: scale(1); }
}

/* =====================================================
   PODOBNE PRODUKTY w modalu – karuzela Swiper
   ===================================================== */
.rts-sim-wrapper { margin: 20px 0 4px; }
.rts-sim-title { font-size: .9rem; font-weight: 600; margin-bottom: 10px; color: inherit; }
.rts-sim-swiper { position: relative; padding-bottom: 2px; }
.rts-sim-card {
    display: flex; flex-direction: column;
    background: #fff; border: 1px solid #e8e8e8;
    border-radius: 8px; overflow: hidden;
    text-decoration: none; color: inherit;
    transition: box-shadow .2s ease, transform .2s ease;
    cursor: pointer;
    padding: 0;
    border: none;
    background: #fff;
    border: 1px solid #e8e8e8;
    text-align: left;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}
.rts-sim-card:hover {
    box-shadow: 0 4px 14px rgba(0,0,0,.10);
    transform: translateY(-2px);
    text-decoration: none; color: #c9a84c;
}
.rts-sim-img {
    width: 100%; padding-top: 100%;
    background-size: cover; background-position: center;
    background-repeat: no-repeat; background-color: #f5f5f5;
}
.rts-sim-info { display: flex; flex-direction: column; gap: 3px; padding: 6px 8px 8px; }
.rts-sim-name {
    font-size: .72rem; line-height: 1.3; text-align: center; color: #333;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.rts-sim-card:hover .rts-sim-name {
    color: #c9a84c;
}

.rts-sim-price { text-align: center; font-size: .78rem; font-weight: 700; }
.rts-sim-swiper .swiper-button-next,
.rts-sim-swiper .swiper-button-prev {
    width: 28px; height: 28px;
    background: #fff; border: 1px solid #ddd;
    border-radius: 50%; box-shadow: 0 2px 6px rgba(0,0,0,.12);
    top: 36%;
}
.rts-sim-swiper .swiper-button-next::after,
.rts-sim-swiper .swiper-button-prev::after { font-size: 10px; color: #555; font-weight: 700; }
/* Agresywne naprawy mobilne dla sklepu */
@media (max-width: 768px) {
  body.woocommerce-page {
    overflow-x: hidden !important;
  }
  
  .rt-products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    padding: 0 10px !important;
  }
  
  .rt-pcard {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  
  .woocommerce-pagination {
    padding: 0 10px !important;
  }
  
  .woocommerce-pagination ul {
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
  
  /* Paginacja - pokazuj tylko 1, 2, ..., przedostatni, ostatni */
  .woocommerce-pagination ul.page-numbers li a.page-numbers:not(.prev):not(.next),
  .woocommerce-pagination ul.page-numbers li span.page-numbers:not(.current):not(.dots) {
    display: none !important;
  }
  
  /* Zawsze pokazuj: prev, next, 1, 2, dots, przedostatni, ostatni */
  .woocommerce-pagination ul.page-numbers li a.prev,
  .woocommerce-pagination ul.page-numbers li a.next,
  .woocommerce-pagination ul.page-numbers li:first-child a.page-numbers,
  .woocommerce-pagination ul.page-numbers li:first-child span.page-numbers,
  .woocommerce-pagination ul.page-numbers li:nth-child(2) a.page-numbers,
  .woocommerce-pagination ul.page-numbers li:nth-child(2) span.page-numbers,
  .woocommerce-pagination ul.page-numbers li:last-child a.page-numbers,
  .woocommerce-pagination ul.page-numbers li:last-child span.page-numbers,
  .woocommerce-pagination ul.page-numbers li:nth-last-child(2) a.page-numbers,
  .woocommerce-pagination ul.page-numbers li:nth-last-child(2) span.page-numbers,
  .woocommerce-pagination ul.page-numbers li span.dots {
    display: inline-flex !important;
  }
}
/* ================================================================
   NAPRAWA KOSZYKA ASTRY NA MOBILE
   ================================================================ */

/* Wymuś aby koszyk na mobile otwierał się jako link (nie dropdown) */
@media (max-width: 768px) {
  .ast-site-header-cart .cart-container {
    pointer-events: auto !important;
    cursor: pointer !important;
  }
  
  /* Jeśli Astra blokuje kliknięcia - odblokuj */
  .ast-site-header-cart-li {
    pointer-events: auto !important;
  }
  
  /* Ukryj pusty dropdown który może blokować */
  .ast-site-header-cart-data:empty {
    display: none !important;
  }
  
  /* Wymuś z-index dla ikony koszyka */
  .ast-addon-cart-wrap {
    position: relative !important;
    z-index: 1000000 !important;
  }
}
/* ================================================================
   PRZYCISK KUPONU NA MOBILE - wyrównanie tekstu do lewej
   ================================================================ */
@media (max-width: 768px) {
    .woocommerce-cart-form .coupon .button,
    .cart .coupon .button,
    .woocommerce .coupon button[type="submit"],
    button[name="apply_coupon"] {
        padding-left: 8px !important;
        padding-right: 8px !important;
        text-align: center !important;
        font-size: 12px !important;
        letter-spacing: 0.5px !important;
    }
}
/* Górna część nagłówka (logo) na mobile - białe tło */
@media (max-width: 768px) {
  .ast-above-header-wrap,
  .ast-above-header-bar,
  .site-above-header-wrap {
    background: #ffffff !important;
    background-color: #ffffff !important;
  }
    /* Wymuś białe tło na wszystkich elementach w headerze */
  .ast-above-header-wrap *,
  .ast-above-header-bar *,
  .site-above-header-wrap * {
    background: transparent !important;
  }
  .ast-above-header-wrap .ast-container,
  .ast-above-header-bar .ast-container,
  .site-above-header-wrap .ast-container {
    background: #ffffff !important;
  }
}
}