/* ==========================================================================
   marketplace.css — Clean Marketplace V1 (Vinted-style) for KSZ
   Renderuje się NA istniejącym style.css/sklep.css.
   Header (.topbar, .nav-main) i Footer (#footer-main) — nieruszone.
   ========================================================================== */

:root{
  --mk-brand:#F59E0B;
  --mk-brand-600:#D97706;
  --mk-brand-ink:#7a4300;
  --mk-brand-soft:#FEF3C7;
  --mk-brand-softer:#FFFBEB;

  --mk-ink-900:#0F1012;
  --mk-ink-800:#1c1d20;
  --mk-ink-700:#3a3d42;
  --mk-ink-500:#6b7075;
  --mk-ink-400:#9aa0a6;
  --mk-ink-300:#c7cacf;
  --mk-ink-200:#dde0e3;
  --mk-ink-100:#eef0f3;
  --mk-ink-50:#f6f7f9;

  --mk-surface:#ffffff;
  --mk-surface-alt:#faf9f6;
  --mk-border:#e8eaec;

  --mk-radius-sm:8px;
  --mk-radius:14px;
  --mk-radius-lg:22px;
  --mk-radius-pill:999px;

  --mk-shadow-sm:0 1px 2px rgba(15,16,18,.04);
  --mk-shadow:0 6px 24px -12px rgba(15,16,18,.14),0 2px 6px -2px rgba(15,16,18,.06);
  --mk-shadow-lg:0 24px 60px -20px rgba(15,16,18,.25);

  --mk-font-sans:"Inter","Plus Jakarta Sans",system-ui,sans-serif;
  --mk-font-display:"Plus Jakarta Sans","Inter",system-ui,sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap');

/* ============ Main content background ============ */
.main-content-wrap{background:var(--mk-surface-alt);position:relative;z-index:1}
.main-content-wrap{font-family:var(--mk-font-sans);color:var(--mk-ink-900)}

/* Utility shell */
.mk-shell{max-width:1440px;margin:0 auto;padding:20px 28px 0}
.mk-section{max-width:1440px;margin:0 auto;padding:28px 28px 0}

/* ============ Buttons ============ */
.mk-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;border-radius:var(--mk-radius-pill);
  font-weight:600;font-size:13.5px;font-family:var(--mk-font-sans);
  transition:all .15s;cursor:pointer;border:0;text-decoration:none;line-height:1;
}
.mk-btn-lg{padding:14px 28px;font-size:14.5px}
.mk-btn-primary{background:var(--mk-brand);color:#fff}
.mk-btn-primary:hover{background:var(--mk-brand-600);color:#fff}
.mk-btn-dark{background:var(--mk-ink-900);color:#fff}
.mk-btn-dark:hover{background:#000;color:#fff}
.mk-btn-ghost{background:var(--mk-ink-50);color:var(--mk-ink-900)}
.mk-btn-ghost:hover{background:var(--mk-ink-100)}
.mk-btn-outline{background:transparent;color:var(--mk-ink-900);border:1px solid var(--mk-border)}
.mk-btn-outline:hover{border-color:var(--mk-ink-900)}
.mk-btn-outline-ink{background:transparent;color:var(--mk-brand-ink);border:1px solid rgba(122,67,0,.25)}
.mk-btn-outline-ink:hover{border-color:var(--mk-brand-ink);color:var(--mk-brand-ink)}
.mk-btn-white{background:#fff;color:var(--mk-ink-900)}
.mk-btn-white:hover{background:#f2f2f2}

/* ============ HERO 2fr/1fr ============ */
.mk-hero{
  display:grid;grid-template-columns:2fr 1fr;gap:14px;
  min-height:260px;
}
.mk-hero-main{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#FEF3C7 0%,#FDE68A 100%);
  border-radius:var(--mk-radius-lg);
  padding:34px 36px;
  display:flex;align-items:flex-end;
}
.mk-hero-main-inner{position:relative;z-index:2}
.mk-hero-bubble{
  position:absolute;right:-40px;bottom:-40px;width:280px;height:280px;
  border-radius:50%;background:rgba(255,255,255,.35);
}
.mk-hero-main::before{
  content:'';position:absolute;right:56px;top:40px;width:110px;height:110px;
  border-radius:50%;background:rgba(255,255,255,.55);
}
.mk-eyebrow{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--mk-brand-ink);margin-bottom:14px;
}
.mk-hero-main h2{
  font-family:var(--mk-font-display);font-weight:800;font-size:38px;line-height:1.05;
  color:#1a1300;margin:0 0 12px;max-width:460px;
}
.mk-hero-main p{font-size:14px;color:#4b3a00;max-width:460px;margin:0 0 22px}
.mk-hero-ctas{display:flex;gap:10px;flex-wrap:wrap}

.mk-hero-side{display:grid;grid-template-rows:1fr 1fr;gap:14px}
.mk-hero-tile{
  display:flex;align-items:center;gap:14px;
  padding:22px 24px;border-radius:var(--mk-radius-lg);
  text-decoration:none;cursor:pointer;text-align:left;transition:transform .18s;
}
.mk-hero-tile:hover{transform:translateY(-2px)}
.mk-hero-tile-dark{background:var(--mk-ink-900);color:#fff}
.mk-hero-tile-soft{background:var(--mk-brand-soft);color:var(--mk-brand-ink)}
.mk-hero-tile-icon{
  width:56px;height:56px;border-radius:14px;flex-shrink:0;
  display:grid;place-items:center;font-size:26px;
  background:rgba(255,255,255,.12);color:#fff;
}
.mk-hero-tile-icon-brand{background:var(--mk-brand);color:#fff}
.mk-hero-tile-title{font-family:var(--mk-font-display);font-weight:700;font-size:16px;line-height:1.2}
.mk-hero-tile-sub{font-size:12px;opacity:.72;margin-top:4px}

/* ============ CAT PILLS ============ */
.mk-catpills{
  max-width:1440px;margin:18px auto 0;padding:0 28px;
  display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;
}
.mk-catpills::-webkit-scrollbar{display:none}
.mk-chip{
  padding:8px 14px;border-radius:var(--mk-radius-pill);
  border:1px solid var(--mk-border);background:var(--mk-surface);
  color:var(--mk-ink-700);font-size:12.5px;font-weight:500;white-space:nowrap;
  text-decoration:none;transition:all .15s;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;line-height:1;
}
.mk-chip i{font-size:13px}
.mk-chip:hover{border-color:var(--mk-ink-400);color:var(--mk-ink-900)}
.mk-chip.active{background:var(--mk-ink-900);color:#fff;border-color:var(--mk-ink-900)}
.mk-chip.active i{color:#fff !important}

/* ============ SORT TABS ============ */
.mk-sort-tabs{
  display:flex;gap:8px;flex-wrap:wrap;
}
.mk-sort-tabs a{
  padding:8px 18px;border-radius:var(--mk-radius-pill);
  border:1px solid var(--mk-border);background:var(--mk-surface);
  color:var(--mk-ink-700);font-size:13px;font-weight:500;
  text-decoration:none;transition:all .15s;
}
.mk-sort-tabs a:hover{border-color:var(--mk-ink-400);color:var(--mk-ink-900)}
.mk-sort-tabs a.active{background:var(--mk-ink-900);color:#fff;border-color:var(--mk-ink-900)}

/* ============ SECTION HEAD ============ */
.mk-section-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
  padding:0 0 18px;
}
.mk-section-head h2{
  font-family:var(--mk-font-display);font-weight:700;font-size:22px;
  color:var(--mk-ink-900);margin:0;letter-spacing:-.01em;
}
.mk-section-sub{font-size:13.5px;color:var(--mk-ink-500);margin-top:4px}
.mk-more{
  font-size:13px;font-weight:600;color:var(--mk-brand-ink);
  text-decoration:none;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;
}
.mk-more:hover{color:var(--mk-brand-600)}

/* ============ PRODUCT CARD GRID (sklep) ============ */
.mk-grid-products{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mk-pcard{
  display:flex;flex-direction:column;
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius-lg);overflow:hidden;
  text-decoration:none;color:inherit;
  transition:transform .18s,box-shadow .18s,border-color .18s;
}
.mk-pcard:hover{
  transform:translateY(-2px);box-shadow:var(--mk-shadow);
  border-color:var(--mk-ink-200);color:inherit;
}
.mk-pcard-img{
  position:relative;aspect-ratio:1/1;overflow:hidden;
  background:var(--mk-ink-50);display:flex;align-items:center;justify-content:center;padding:18px;
}
.mk-pcard-img img{max-width:100%;max-height:100%;object-fit:contain}
.mk-pcard-placeholder{font-size:44px;color:var(--mk-ink-400)}
.mk-pcard-badge{
  position:absolute;top:10px;left:10px;
  background:var(--mk-ink-900);color:#fff;font-size:10px;font-weight:700;
  padding:4px 9px;border-radius:var(--mk-radius-pill);letter-spacing:.04em;
}
.mk-pcard-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:4px;flex:1}
.mk-pcard-brand{
  font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--mk-brand-ink);
}
.mk-pcard-title{
  font-size:13px;font-weight:500;color:var(--mk-ink-900);line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:36px;
}
.mk-pcard-price{
  font-family:var(--mk-font-display);font-size:17px;font-weight:700;
  color:var(--mk-ink-900);margin-top:auto;
}

/* ============ LISTING CARD (ogłoszenia, 2-kol poziome) ============ */
.mk-grid-listings{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.mk-lcard{
  display:flex;gap:14px;align-items:stretch;
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius-lg);padding:14px;
  text-decoration:none;color:inherit;
  transition:transform .18s,box-shadow .18s,border-color .18s;
}
.mk-lcard:hover{transform:translateY(-2px);box-shadow:var(--mk-shadow);border-color:var(--mk-ink-200);color:inherit}
.mk-lcard-img{
  flex:none;width:140px;height:140px;border-radius:var(--mk-radius);
  background:var(--mk-ink-50);display:grid;place-items:center;font-size:52px;
}
.mk-lcard-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;justify-content:space-between}
.mk-lcard-tag{
  display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;
  padding:3px 9px;border-radius:var(--mk-radius-pill);color:#fff;
}
.mk-tag-sell{background:#10b981}
.mk-tag-buy{background:#3b82f6}
.mk-tag-swap{background:#F59E0B}
.mk-tag-free{background:#8b5cf6}
.mk-lcard-time{font-size:11px;color:var(--mk-ink-500);margin-left:6px}
.mk-lcard-title{
  font-size:14.5px;font-weight:600;line-height:1.3;color:var(--mk-ink-900);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.mk-lcard-meta{font-size:12px;color:var(--mk-ink-500);display:flex;align-items:center;gap:4px}
.mk-lcard-price{
  font-family:var(--mk-font-display);font-size:18px;font-weight:700;color:var(--mk-ink-900);
}

/* ============ STATS STRIP (biała karta) ============ */
.mk-stats-card{
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius-lg);padding:28px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.mk-stat{display:flex;align-items:center;gap:14px}
.mk-stat-icon{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  background:var(--mk-brand-soft);color:var(--mk-brand-ink);
  display:grid;place-items:center;font-size:22px;
}
.mk-stat-n{font-family:var(--mk-font-display);font-size:22px;font-weight:800;color:var(--mk-ink-900);line-height:1}
.mk-stat-l{font-size:12px;color:var(--mk-ink-500);margin-top:4px}

/* ============ FREE CARD (oddam) ============ */
.mk-grid-free{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.mk-freecard{
  display:flex;flex-direction:column;
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius-lg);overflow:hidden;
  text-decoration:none;color:inherit;
  transition:transform .18s,box-shadow .18s,border-color .18s;
}
.mk-freecard:hover{transform:translateY(-2px);box-shadow:var(--mk-shadow);border-color:var(--mk-ink-200);color:inherit}
.mk-freecard-img{
  aspect-ratio:4/3;background:linear-gradient(135deg,#ecfdf5,#d1fae5);
  display:grid;place-items:center;font-size:48px;
}
.mk-freecard-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}
.mk-freecard-title{
  font-size:13.5px;font-weight:600;line-height:1.35;color:var(--mk-ink-900);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.mk-freecard-meta{font-size:11.5px;color:var(--mk-ink-500);display:flex;gap:8px;flex-wrap:wrap}

/* ============ KATEGORIE grid (6-kol) ============ */
.mk-cats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.mk-cat-tile{
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius);
  padding:14px 12px;text-decoration:none;
  transition:all .18s;
  display:flex;flex-direction:column;align-items:flex-start;gap:8px;
}
.mk-cat-tile:hover{transform:translateY(-2px);box-shadow:var(--mk-shadow);border-color:var(--mk-ink-200)}
.mk-cat-icon{
  width:36px;height:36px;border-radius:10px;
  display:inline-grid;place-items:center;font-size:18px;
}
.mk-cat-name{font-size:13px;font-weight:600;color:var(--mk-ink-900);line-height:1.25}

/* ============ FB CARD (3-kol) ============ */
.mk-grid-fb{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.mk-fbcard{
  display:flex;flex-direction:column;
  background:var(--mk-surface);border:1px solid var(--mk-border);
  border-radius:var(--mk-radius-lg);overflow:hidden;
  text-decoration:none;color:inherit;
  transition:transform .18s,box-shadow .18s,border-color .18s;
}
.mk-fbcard:hover{transform:translateY(-2px);box-shadow:var(--mk-shadow);border-color:var(--mk-ink-200);color:inherit}
.mk-fbcard-cover{
  position:relative;aspect-ratio:16/9;overflow:hidden;
  background:linear-gradient(135deg,#1877f2,#0b5cbf);
  display:grid;place-items:center;
}
.mk-fbcard-cover img{width:100%;height:100%;object-fit:cover}
.mk-fbcard-icon{position:absolute;font-size:60px;opacity:.2;color:#fff}
.mk-fbcard-cover img + .mk-fbcard-icon{display:none}
.mk-fbcard-members{
  position:absolute;left:10px;bottom:10px;
  background:rgba(15,16,18,.8);color:#fff;font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:var(--mk-radius-pill);
}
.mk-fbcard-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}
.mk-fbcard-type{
  font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--mk-ink-500);
}
.mk-fbcard-title{font-size:15px;font-weight:700;color:var(--mk-ink-900);line-height:1.3;font-family:var(--mk-font-display)}
.mk-fbcard-join{font-size:12.5px;font-weight:600;color:#1877f2;display:flex;align-items:center;gap:6px;margin-top:4px}

/* ============ CTA BANNER ============ */
.mk-cta-banner{
  background:linear-gradient(135deg,var(--mk-ink-900) 0%,#1c1d20 100%);
  color:#fff;border-radius:var(--mk-radius-lg);
  padding:36px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.mk-cta-banner h3{font-family:var(--mk-font-display);font-size:26px;font-weight:800;margin:0 0 6px}
.mk-cta-banner p{font-size:14px;color:rgba(255,255,255,.7);margin:0;max-width:560px}

/* ==========================================================================
   Ukrywamy stare karuzele/legacy z index.php (nie są już potrzebne)
   ========================================================================== */
.hero-banner,.hex-tabs,
#sekcja-sklep,#sekcja-ogl,#sekcja-free,
#mapa-wrapper,#box_miasta,.gl-stats,
.gl-section:has(.cr-item-fb){
  display:none !important;
}

/* Nie schowaj gdy zostały edytowane przez user po pominięciu: bezpieczniej */

/* ==========================================================================
   Responsywność
   ========================================================================== */
@media (max-width:1100px){
  .mk-grid-products{grid-template-columns:repeat(3,1fr)}
  .mk-grid-free{grid-template-columns:repeat(3,1fr)}
  .mk-grid-fb{grid-template-columns:repeat(2,1fr)}
  .mk-cats-grid{grid-template-columns:repeat(4,1fr)}
  .mk-stats-card{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .mk-hero{grid-template-columns:1fr;min-height:auto}
  .mk-hero-main{padding:28px 26px}
  .mk-hero-main h2{font-size:28px}
  .mk-hero-side{grid-template-rows:auto auto}
}
@media (max-width:768px){
  .mk-shell,.mk-section{padding-left:14px;padding-right:14px}
  .mk-section{padding-top:24px}
  .mk-section-head h2{font-size:19px}
  .mk-hero-main{padding:22px 20px}
  .mk-hero-main h2{font-size:24px}
  .mk-hero-main p{font-size:13px}
  .mk-grid-products{grid-template-columns:repeat(2,1fr);gap:12px}
  .mk-grid-listings{grid-template-columns:1fr}
  .mk-grid-free{grid-template-columns:repeat(2,1fr);gap:10px}
  .mk-grid-fb{grid-template-columns:1fr}
  .mk-cats-grid{grid-template-columns:repeat(3,1fr)}
  .mk-stats-card{grid-template-columns:1fr 1fr;padding:20px}
  .mk-cta-banner{padding:26px 24px;flex-direction:column;align-items:flex-start}
  .mk-cta-banner h3{font-size:22px}
  .mk-catpills{padding:0 14px}
}
