/* ============================================================
   CzymPryskac.pl — Design System
   Typografia: DM Sans (body) + DM Serif Display (akcenty)
   Paleta: głęboka zieleń leśna + biel + akcent limonka
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=DM+Serif+Display:ital@0;1&display=swap');

:root {
  --green-950: #0d2409;
  --green-900: #163a0f;
  --green-800: #1a4812;
  --green-700: #2a5f1a;
  --green-600: #3b7325;
  --green-500: #4d8c30;
  --green-200: #b8dfa0;
  --green-100: #dff0d0;
  --green-50:  #f0f9e8;
  --lime:      #7dd44a;
  --lime-dark: #6bc33a;

  --white:     #ffffff;
  --gray-50:   #f8f9f7;
  --gray-100:  #f0f2ee;
  --gray-200:  #e2e6df;
  --gray-300:  #c8cfc4;
  --gray-400:  #9aa394;
  --gray-500:  #6b7568;
  --gray-700:  #3a3f38;
  --gray-900:  #1c1f1b;

  --red:       #b83a00;
  --red-light: #fcebeb;
  --blue:      #185fa5;
  --blue-light:#e6f1fb;
  --amber:     #c87f00;
  --amber-light:#faeeda;

  --font-body:    'DM Sans', sans-serif;
  --font-display: 'DM Serif Display', serif;

  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  14px;
  --radius-xl:  18px;
  --radius-2xl: 24px;

  --shadow-sm:  0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:  0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:  0 12px 32px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--gray-900);
  background: var(--gray-50);
  -webkit-font-smoothing: antialiased;
}

/* ── TOPBAR ── */
.topbar {
  background: var(--green-950);
  padding: 6px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.topbar a {
  font-size: 12px;
  color: var(--green-200);
  text-decoration: none;
  opacity: .8;
  transition: opacity .15s;
}
.topbar a:hover { opacity: 1; }
.topbar-links { display: flex; gap: 20px; }

/* ── NAVBAR ── */
.navbar {
  background: var(--green-800);
  padding: 0 28px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 12px rgba(0,0,0,.2);
  min-height: 56px;
}
.nav-logo img { height: 36px; width: auto; }
.nav-logo {
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--white);
  padding: 14px 0;
  cursor: pointer;
  flex-shrink: 0;
  text-decoration: none;
  letter-spacing: -.3px;
}
.nav-logo span { color: var(--lime); }
.nav-logo small {
  font-family: var(--font-body);
  font-size: 10px;
  color: var(--green-200);
  display: block;
  font-weight: 400;
  letter-spacing: .2px;
  margin-top: -2px;
}
.nav-links { display: flex; gap: 0; flex: 1; overflow-x: auto; }
.nav-link {
  background: none;
  border: none;
  color: var(--green-200);
  font-family: var(--font-body);
  font-size: 13px;
  padding: 14px 12px;
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.nav-link:hover { color: var(--white); }
.nav-link.active { color: var(--lime); border-bottom-color: var(--lime); font-weight: 500; }
.nav-actions { display: flex; gap: 8px; flex-shrink: 0; }
.btn-login {
  background: transparent;
  border: 1px solid rgba(255,255,255,.25);
  color: var(--white);
  font-family: var(--font-body);
  font-size: 13px;
  padding: 6px 16px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background .15s;
}
.btn-login:hover { background: rgba(255,255,255,.1); }
.btn-register {
  background: var(--lime);
  border: none;
  color: var(--green-800);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  padding: 6px 16px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background .15s;
}
.btn-register:hover { background: var(--lime-dark); }

/* ── SEARCH BAR (navbar) ── */
.nav-search { display: flex; max-width: 340px; flex: 1; }
.nav-search input {
  flex: 1;
  padding: 7px 12px;
  font-family: var(--font-body);
  font-size: 13px;
  border: none;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  outline: none;
  background: var(--white);
  color: var(--gray-900);
}
.nav-search button {
  background: var(--lime);
  border: none;
  padding: 0 14px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--green-800);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
}
.nav-search button:hover { background: var(--lime-dark); }

/* ── LAYOUT ── */
.container { max-width: 1060px; margin: 0 auto; padding: 0 24px; }
.page { padding: 24px 0 48px; }
.page-with-sidebar { display: flex; gap: 20px; align-items: flex-start; }
.sidebar { width: 200px; flex-shrink: 0; }
.main-area { flex: 1; min-width: 0; }

/* ── BREADCRUMB ── */
.breadcrumb {
  font-size: 12px;
  color: var(--gray-400);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.breadcrumb a { color: var(--gray-400); text-decoration: none; cursor: pointer; }
.breadcrumb a:hover { color: var(--gray-500); }
.breadcrumb .sep { color: var(--gray-300); }
.breadcrumb .current { color: var(--gray-600); }

/* ── CARDS ── */
.card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}
.card-sm { border-radius: var(--radius-lg); }
.card-p { padding: 16px 20px; }
.card-p-lg { padding: 24px 28px; }

/* ── SIDEBAR FILTER BOX ── */
.filter-box {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 14px;
  margin-bottom: 10px;
  box-shadow: var(--shadow-sm);
}
.filter-title {
  font-size: 10px;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 9px;
  padding-bottom: 7px;
  border-bottom: 1px solid var(--gray-100);
}
.filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 13px;
  color: var(--gray-600);
  cursor: pointer;
}
.filter-row input[type=checkbox] { accent-color: var(--green-700); flex-shrink: 0; }
.filter-count { font-size: 11px; color: var(--gray-300); margin-left: auto; }
.price-range { display: flex; gap: 5px; margin-top: 8px; }
.price-range input {
  flex: 1; border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  padding: 5px 7px; font-size: 12px; width: 0;
  background: var(--white); color: var(--gray-900); font-family: var(--font-body);
}
.price-range button {
  background: var(--green-700); color: var(--white); border: none;
  border-radius: var(--radius-sm); padding: 5px 10px; font-size: 12px; cursor: pointer;
}

/* ── BADGES ── */
.badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 20px;
}
.badge-green  { background: var(--green-50);    color: var(--green-700); }
.badge-amber  { background: var(--amber-light); color: var(--amber); }
.badge-blue   { background: var(--blue-light);  color: var(--blue); }
.badge-red    { background: var(--red-light);   color: var(--red); }
.badge-promo  { background: var(--green-800);   color: var(--white); font-size: 10px; }
.badge-ad     { background: var(--gray-100);    color: var(--gray-400); font-size: 9px; letter-spacing: .3px; text-transform: uppercase; }

/* ── PRODUCT CARD ── */
.product-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  padding: 16px 18px;
  margin-bottom: 10px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  transition: border-color .2s, box-shadow .2s;
  box-shadow: var(--shadow-sm);
}
.product-card:hover { border-color: var(--gray-300); box-shadow: var(--shadow-md); }
.product-card.sponsored { border-left: 3px solid var(--green-600); }
.product-icon {
  width: 64px; height: 64px; flex-shrink: 0;
  background: var(--green-50);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
}
.product-info { flex: 1; min-width: 0; }
.product-name {
  font-size: 15px; font-weight: 600; color: var(--gray-900);
  margin-bottom: 2px; line-height: 1.3; cursor: pointer;
  text-decoration: none; display: block;
}
.product-name:hover { color: var(--green-700); }
.product-meta { font-size: 12px; color: var(--gray-400); margin-bottom: 7px; }
.product-badges { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 6px; }
.product-rating { font-size: 12px; color: var(--gray-500); display: flex; align-items: center; gap: 4px; }
.stars { color: var(--amber); font-size: 11px; }
.product-reg { font-size: 11px; color: var(--gray-300); margin-top: 4px; font-family: monospace; }
.product-detail {
  font-size: 12px; color: var(--gray-600);
  margin-top: 6px; padding: 8px 12px;
  background: var(--gray-50); border-radius: var(--radius-md); line-height: 1.6;
}
.product-detail strong { color: var(--gray-800); font-weight: 500; }
.product-price-col {
  display: flex; flex-direction: column;
  align-items: flex-end; gap: 7px;
  min-width: 148px; flex-shrink: 0;
}
.price-from { font-size: 11px; color: var(--gray-400); }
.price-main { font-size: 22px; font-weight: 600; color: var(--red); line-height: 1; }
.price-pak { font-size: 11px; color: var(--gray-400); }
.price-shops { font-size: 12px; color: var(--gray-500); cursor: pointer; text-align: right; }
.price-shops span { color: var(--green-700); text-decoration: underline; }
.btn-primary {
  background: var(--green-700); color: var(--white); border: none;
  border-radius: var(--radius-md); padding: 8px 14px;
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  cursor: pointer; width: 100%; transition: background .15s;
}
.btn-primary:hover { background: var(--green-800); }
.btn-secondary {
  background: transparent; color: var(--green-700);
  border: 1px solid var(--green-700);
  border-radius: var(--radius-md); padding: 6px 14px;
  font-family: var(--font-body); font-size: 12px;
  cursor: pointer; width: 100%; transition: all .15s;
}
.btn-secondary:hover { background: var(--green-50); }

/* ── SHOPS DROPDOWN ── */
.shops-dropdown {
  background: var(--gray-50); border-radius: var(--radius-md);
  padding: 8px; margin-top: 10px;
  border: 1px solid var(--gray-200);
}
.shop-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 0; border-bottom: 1px solid var(--gray-100);
  font-size: 13px; gap: 8px;
}
.shop-row:last-child { border-bottom: none; }
.shop-name { font-weight: 500; color: var(--gray-800); }
.shop-ship { font-size: 11px; color: var(--gray-400); }
.shop-price { font-weight: 600; color: var(--red); white-space: nowrap; }
.shop-diff { font-size: 10px; padding: 1px 6px; border-radius: 5px; }
.diff-best { background: var(--green-50); color: var(--green-700); }
.diff-more { background: var(--red-light); color: var(--red); }
.btn-shop {
  background: var(--green-700); color: var(--white); border: none;
  border-radius: var(--radius-sm); padding: 4px 10px; font-size: 12px; cursor: pointer;
  white-space: nowrap; transition: background .15s;
}
.btn-shop:hover { background: var(--green-800); }

/* ── COMPARE CHECKBOX ── */
.compare-check {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--gray-500); margin-top: 6px; cursor: pointer;
}
.compare-check input { accent-color: var(--green-700); }

/* ── COMPARE FLOAT BAR ── */
.compare-bar {
  display: none; background: var(--white);
  border: 2px solid var(--green-700);
  border-radius: var(--radius-lg);
  padding: 12px 16px; margin-bottom: 14px;
  align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
  box-shadow: var(--shadow-md);
}
.compare-bar.visible { display: flex; }
.compare-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.compare-pill {
  background: var(--green-50); color: var(--green-700);
  font-size: 12px; padding: 3px 10px; border-radius: 8px;
  display: flex; align-items: center; gap: 5px;
}
.compare-pill button {
  background: none; border: none; cursor: pointer;
  color: var(--green-700); font-size: 14px; line-height: 1; padding: 0;
}

/* ── QUICK COMPARE ── */
.quick-compare {
  background: var(--white); border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl); padding: 16px 18px;
  margin-bottom: 14px; box-shadow: var(--shadow-sm);
}
.quick-title {
  font-size: 11px; font-weight: 600; color: var(--gray-400);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 12px;
}
.quick-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.quick-card {
  border: 1px solid var(--gray-200); border-radius: var(--radius-lg);
  padding: 12px; cursor: pointer; position: relative;
  transition: border-color .15s, box-shadow .15s;
}
.quick-card:hover { border-color: var(--green-600); box-shadow: var(--shadow-sm); }
.quick-card.recommended { border: 2px solid var(--green-700); }
.rec-label {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  background: var(--green-700); color: var(--white);
  font-size: 10px; font-weight: 600; padding: 2px 10px; border-radius: 20px; white-space: nowrap;
}
.ad-label-sm { position: absolute; top: 7px; right: 8px; font-size: 9px; color: var(--gray-300); text-transform: uppercase; }
.quick-name { font-size: 13px; font-weight: 600; color: var(--gray-900); margin-bottom: 2px; line-height: 1.3; }
.quick-sc { font-size: 11px; color: var(--gray-400); margin-bottom: 8px; }
.quick-price { font-size: 18px; font-weight: 600; color: var(--red); }
.quick-pak { font-size: 11px; color: var(--gray-400); }
.quick-shops { font-size: 11px; color: var(--gray-500); margin-top: 2px; }

/* ── RESULTS BAR ── */
.results-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; flex-wrap: wrap; gap: 8px;
}
.results-count { font-size: 13px; color: var(--gray-500); }
.results-count strong { color: var(--gray-900); }
.sort-select {
  border: 1px solid var(--gray-200); border-radius: var(--radius-md);
  padding: 5px 10px; font-size: 13px; font-family: var(--font-body);
  background: var(--white); color: var(--gray-700); cursor: pointer;
}

/* ── INFO BAR ── */
.info-bar {
  background: var(--green-50); border-radius: var(--radius-md);
  padding: 8px 13px; font-size: 12px; color: var(--green-700);
  margin-bottom: 12px; display: flex; align-items: center; gap: 6px;
}
.warn-bar {
  background: var(--amber-light); border: 1px solid #e8cfa0;
  border-radius: var(--radius-md); padding: 9px 14px;
  font-size: 12px; color: #7a5000; margin-bottom: 14px;
  display: flex; gap: 8px; align-items: flex-start;
}

/* ── AD STRIP ── */
.ad-strip {
  background: var(--gray-50); border: 1px solid var(--gray-200);
  border-radius: var(--radius-md); padding: 9px 14px;
  margin-bottom: 12px; display: flex; align-items: center; gap: 12px;
  font-size: 13px;
}
.ad-strip .ad-lbl { font-size: 10px; color: var(--gray-300); text-transform: uppercase; letter-spacing: .4px; flex-shrink: 0; }
.ad-strip a { color: var(--green-700); font-size: 12px; }

/* ── COMPARISON TABLE (Apple style) ── */
.cmp-outer {
  background: var(--white); border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl); overflow: hidden;
  box-shadow: var(--shadow-sm); margin-bottom: 16px;
}
.cmp-scroll { overflow-x: auto; }
table.cmp-table {
  width: 100%; border-collapse: collapse; min-width: 680px;
}
.cmp-table thead { position: sticky; top: 57px; z-index: 2; }
.cmp-table thead tr { background: var(--white); border-bottom: 2px solid var(--gray-200); }
.cmp-table thead th { padding: 0; vertical-align: bottom; }
.cmp-table thead th:first-child { background: var(--gray-50); width: 200px; min-width: 160px; }
.prod-col-head { padding: 16px 16px 14px; text-align: center; }
.prod-col-head.rec-bg { background: var(--green-50); }
.prod-head-badge { display: inline-block; font-size: 10px; font-weight: 600; padding: 2px 10px; border-radius: 20px; margin-bottom: 8px; }
.phb-rec { background: var(--green-700); color: var(--white); }
.phb-gen { background: var(--green-50); color: var(--green-700); }
.phb-gen2 { background: var(--blue-light); color: var(--blue); }
.prod-col-name { font-size: 15px; font-weight: 600; color: var(--gray-900); margin-bottom: 2px; line-height: 1.3; }
.prod-col-maker { font-size: 12px; color: var(--gray-400); }
.prod-col-reg { font-size: 11px; color: var(--gray-300); font-family: monospace; margin-top: 3px; }
.prod-col-price { font-size: 21px; font-weight: 600; color: var(--red); margin-top: 9px; line-height: 1; }
.prod-col-price.price-best { color: var(--green-700); }
.prod-col-pak { font-size: 11px; color: var(--gray-400); }
.prod-col-save { font-size: 11px; background: var(--green-50); color: var(--green-700); padding: 2px 8px; border-radius: 8px; display: inline-block; margin-top: 4px; }
.prod-col-btn {
  display: block; background: var(--green-700); color: var(--white); border: none;
  border-radius: var(--radius-md); padding: 7px 0; font-family: var(--font-body);
  font-size: 12px; font-weight: 500; cursor: pointer;
  width: calc(100% - 32px); margin: 8px 16px 14px;
  transition: background .15s;
}
.prod-col-btn:hover { background: var(--green-800); }
.cmp-table td {
  padding: 10px 16px; border-bottom: 1px solid var(--gray-100);
  font-size: 13px; color: var(--gray-900); text-align: center; vertical-align: middle;
}
.cmp-table td:first-child {
  text-align: left; font-size: 12px; color: var(--gray-500);
  background: var(--gray-50); font-weight: 500; white-space: nowrap; padding: 10px 14px;
}
.cmp-table tr.sec-head td {
  background: var(--gray-100) !important; font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .6px; color: var(--gray-400);
  padding: 7px 16px;
}
.cmp-table tbody tr:not(.sec-head):hover td { background: var(--gray-50); }
.cmp-table tbody tr:not(.sec-head):hover td:first-child { background: var(--gray-100); }
.cmp-table tr:last-child td { border-bottom: none; }
.val-eq   { color: var(--blue); font-weight: 500; }
.val-best { color: var(--green-700); font-weight: 600; }
.val-bad  { color: var(--red); }
.val-na   { color: var(--gray-300); font-size: 12px; }
.val-wide { color: var(--green-600); }
.tag-ok   { display:inline-block; font-size:11px; padding:2px 7px; border-radius:8px; background:var(--green-50); color:var(--green-700); }
.tag-no   { display:inline-block; font-size:11px; padding:2px 7px; border-radius:8px; background:var(--red-light); color:var(--red); }
.tag-part { display:inline-block; font-size:11px; padding:2px 7px; border-radius:8px; background:var(--amber-light); color:var(--amber); }
.sp-price-best { font-size:17px; font-weight:600; color:var(--green-700); }
.sp-price { font-size:15px; font-weight:500; color:var(--red); }
.sp-diff-best { display:block; font-size:11px; padding:1px 6px; border-radius:6px; margin-top:2px; background:var(--green-50); color:var(--green-700); }
.sp-diff-exp  { display:block; font-size:11px; padding:1px 6px; border-radius:6px; margin-top:2px; background:var(--red-light); color:var(--red); }
.cmp-footer { font-size:11px; color:var(--gray-300); text-align:right; padding:8px 16px; }

/* ── SUMMARY CARDS ── */
.summary-row { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:16px; }
.summary-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-lg); padding:14px 16px; box-shadow:var(--shadow-sm); }
.sc-label { font-size:10px; font-weight:600; color:var(--gray-400); text-transform:uppercase; letter-spacing:.5px; margin-bottom:5px; }
.sc-value { font-size:18px; font-weight:600; color:var(--gray-900); line-height:1; }
.sc-value.cv-red   { color:var(--red); }
.sc-value.cv-green { color:var(--green-700); }
.sc-value.cv-blue  { color:var(--blue); }
.sc-sub { font-size:12px; color:var(--gray-500); margin-top:3px; }

/* ── HOMEPAGE HERO ── */
.hero { padding:64px 0 48px; text-align:center; }
.hero-eyebrow {
  font-size:12px; color:var(--green-700); background:var(--green-50);
  padding:4px 14px; border-radius:20px; display:inline-block;
  margin-bottom:20px; letter-spacing:.3px; font-weight:500;
}
.hero-title {
  font-family:var(--font-display);
  font-size:42px; line-height:1.2; color:var(--gray-900);
  margin-bottom:16px; letter-spacing:-.5px;
  max-width:700px; margin-left:auto; margin-right:auto;
}
.hero-title em { font-style:italic; color:var(--green-700); }
.hero-sub {
  font-size:17px; color:var(--gray-500); line-height:1.7;
  max-width:580px; margin:0 auto 36px;
}
.search-card {
  background:var(--white); border:1px solid var(--gray-200);
  border-radius:var(--radius-2xl); padding:20px;
  max-width:660px; margin:0 auto 48px; box-shadow:var(--shadow-md);
}
.search-main { display:flex; gap:0; margin-bottom:14px; }
.search-main input {
  flex:1; padding:12px 16px; font-size:15px; font-family:var(--font-body);
  border:1px solid var(--gray-200); border-radius:var(--radius-md) 0 0 var(--radius-md);
  outline:none; background:var(--white); color:var(--gray-900);
  transition:border-color .15s;
}
.search-main input:focus { border-color:var(--green-600); }
.search-main button {
  background:var(--green-700); color:var(--white); border:none;
  padding:0 22px; font-family:var(--font-body); font-size:14px; font-weight:600;
  border-radius:0 var(--radius-md) var(--radius-md) 0; cursor:pointer; transition:background .15s;
}
.search-main button:hover { background:var(--green-800); }
.search-tags { display:flex; gap:6px; flex-wrap:wrap; align-items:center; }
.search-tag-label { font-size:12px; color:var(--gray-400); flex-shrink:0; }
.search-tag {
  background:var(--gray-50); border:1px solid var(--gray-200);
  border-radius:20px; padding:4px 13px; font-size:12px; font-family:var(--font-body);
  color:var(--gray-600); cursor:pointer; transition:all .15s; white-space:nowrap;
}
.search-tag:hover { border-color:var(--green-600); color:var(--green-700); background:var(--green-50); }

/* ── STATS ROW ── */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; max-width:780px; margin:0 auto 64px; }
.stat-card {
  background:var(--white); border:1px solid var(--gray-200);
  border-radius:var(--radius-lg); padding:16px 20px; text-align:center; box-shadow:var(--shadow-sm);
}
.stat-number { font-family:var(--font-display); font-size:28px; color:var(--green-700); line-height:1; }
.stat-label  { font-size:12px; color:var(--gray-500); margin-top:4px; }

/* ── CATEGORIES ── */
.cat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.cat-card {
  background:var(--white); border:1px solid var(--gray-200);
  border-radius:var(--radius-xl); padding:20px 16px;
  cursor:pointer; transition:border-color .2s, box-shadow .2s, transform .15s;
  box-shadow:var(--shadow-sm);
}
.cat-card:hover {
  border-color:var(--green-400); box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.cat-icon {
  width:42px; height:42px; border-radius:var(--radius-md);
  background:var(--green-50); display:flex; align-items:center; justify-content:center;
  margin-bottom:12px; font-size:20px;
}
.cat-name { font-size:14px; font-weight:600; color:var(--gray-900); margin-bottom:3px; }
.cat-count { font-size:12px; color:var(--gray-400); }
.cat-arrow { font-size:16px; color:var(--gray-300); float:right; margin-top:-32px; transition:color .15s; }
.cat-card:hover .cat-arrow { color:var(--green-600); }

/* ── FEATURES ── */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.feature-card {
  transition: box-shadow .2s, transform .15s;
  background:var(--white); border:1px solid var(--gray-200);
  border-radius:var(--radius-xl); padding:22px; box-shadow:var(--shadow-sm);
}
.feature-num { font-size:11px; font-weight:600; color:var(--green-600); letter-spacing:.4px; margin-bottom:12px; }
.feature-title { font-size:15px; font-weight:600; color:var(--gray-900); margin-bottom:7px; line-height:1.35; }
.feature-desc { font-size:13px; color:var(--gray-500); line-height:1.65; }

/* ── MANIFESTO ── */
.manifesto {
  background:var(--white); border:1px solid var(--gray-200);
  border-radius:var(--radius-2xl); padding:40px 44px;
  position:relative; overflow:hidden; box-shadow:var(--shadow-sm);
  margin-bottom:56px;
}
.manifesto::before {
  content:''; position:absolute; top:0; left:0;
  width:4px; height:100%;
  background:linear-gradient(180deg, var(--green-700), var(--lime));
  border-radius:4px 0 0 4px;
}
.manifesto-label { font-size:11px; font-weight:600; color:var(--green-600); letter-spacing:.6px; text-transform:uppercase; margin-bottom:16px; }
.manifesto-text { font-size:16px; line-height:1.8; color:var(--gray-700); max-width:100%; }
.manifesto-text em { font-style:normal; color:var(--green-700); font-weight:600; }
.manifesto-sign { font-size:13px; color:var(--gray-400); margin-top:20px; }

/* ── SECTION HEADINGS ── */
.section-label { font-size:11px; font-weight:600; color:var(--gray-400); text-transform:uppercase; letter-spacing:.6px; margin-bottom:8px; }
.section-title { font-size:22px; font-weight:600; color:var(--gray-900); margin-bottom:6px; }
.section-sub   { font-size:14px; color:var(--gray-500); margin-bottom:24px; }

/* ── FOOTER ── */
.footer {
  background:var(--white); border-top:1px solid var(--gray-200);
  padding:28px 28px; text-align:center;
}
.footer-text { font-size:12px; color:var(--gray-400); }
.footer-links { display:flex; gap:24px; justify-content:center; margin-top:10px; flex-wrap:wrap; }
.footer-links a { font-size:12px; color:var(--gray-400); text-decoration:none; }
.footer-links a:hover { color:var(--gray-600); }

/* ── UTILS ── */
.section-divider { height:1px; background:var(--gray-200); margin:0 0 48px; }
.mt-4  { margin-top:4px; }
.mt-8  { margin-top:8px; }
.mt-12 { margin-top:12px; }
.mb-12 { margin-bottom:12px; }
.mb-16 { margin-bottom:16px; }
.text-right { text-align:right; }
.update-note { font-size:11px; color:var(--gray-300); }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .topbar { display:none; }
  .navbar { padding:0 16px; }
  .container { padding:0 16px; }
  .cat-grid { grid-template-columns:repeat(2,1fr); }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .features-grid { grid-template-columns:1fr; }
  .quick-grid { grid-template-columns:1fr; }
  .page-with-sidebar { flex-direction:column; }
  .sidebar { width:100%; }
  .hero-title { font-size:28px; }
  .manifesto { padding:24px 20px; }
  .summary-row { grid-template-columns:1fr; }
}

/* ── POPRAWKI WIZUALNE 30.04.2026 ── */
.feature-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.10);
  transform: translateY(-2px);
}
.feature-num {
  font-size: 11px;
  font-weight: 600;
  color: var(--green-600);
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.feature-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--gray-900);
  margin-bottom: 8px;
}
.feature-desc {
  font-size: 14px;
  color: var(--gray-500);
  line-height: 1.7;
}
.cat-card {
  cursor: pointer;
  transition: box-shadow .2s, transform .15s, border-color .2s;
}
.cat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.09);
}
.manifesto {
  border-left: 3px solid var(--green-500);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}
.hstat-n {
  font-family: var(--font-display);
  font-size: 28px;
  color: #c8d44a;
  line-height: 1;
}
.hstat-l {
  font-size: 11px;
  color: rgba(255,255,255,.6);
  margin-top: 4px;
}
/* Topbar sticky fix */
.topbar {
  position: sticky;
  top: 0;
  z-index: 101;
}
