/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --red:    #e8000d;
  --dark:   #111827;
  --mid:    #374151;
  --muted:  #6b7280;
  --border: #e5e7eb;
  --bg:     #eef0f3;
  --white:  #fff;
  --radius: 10px;
  --shadow: 0 2px 12px rgba(0,0,0,.10);
  --shadow-hover: 0 6px 24px rgba(0,0,0,.18);
}
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif; font-size: 14px; line-height: 1.5; color: var(--dark); background: var(--bg); }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { max-width: 1280px; margin: 0 auto; padding: 0 16px; }

/* === TOP BAR === */
.top-bar { background: #0d1117; color: #6b7280; font-size: .72rem; padding: 5px 0; }
.top-bar-inner { display: flex; justify-content: space-between; }

/* === HEADER === */
.site-header { background: var(--white); border-bottom: 3px solid var(--red); padding: 14px 0; box-shadow: 0 1px 6px rgba(0,0,0,.06); }
.header-inner { display: flex; align-items: center; justify-content: center; }
.logo { font-size: 2.4rem; font-weight: 900; color: var(--red); letter-spacing: -1.5px; text-transform: uppercase; }

/* === LEADERBOARD === */
.reklama-leaderboard { background: var(--white); border-bottom: 1px solid var(--border); padding: 8px 0; text-align: center; }

/* === NAV === */
.glowne-menu { background: var(--dark); position: sticky; top: 0; z-index: 200; box-shadow: 0 2px 8px rgba(0,0,0,.3); }
.menu-inner { display: flex; overflow-x: auto; scrollbar-width: none; }
.menu-inner::-webkit-scrollbar { display: none; }
.menu-link { display: block; padding: 12px 16px; color: #d1d5db; font-size: .83rem; font-weight: 500; white-space: nowrap; border-bottom: 3px solid transparent; transition: color .15s, border-color .15s; }
.menu-link:hover { color: #fff; border-bottom-color: var(--red); }

/* === MAIN WRAP === */
.main-wrap { padding: 18px 16px 0; }

/* === KARTA Z OVERLAYEM (wspólna) === */
.karta-overlay-wrap {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: #1f2937;
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease;
}
.karta-overlay-wrap:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}
.karta-overlay-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s ease, opacity .35s ease;
}
.karta-overlay-wrap:hover img { transform: scale(1.07); opacity: .82; }
.img-ph { width: 100%; height: 100%; background: linear-gradient(135deg, #374151, #1f2937); }

.karta-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.6) 50%, transparent 100%);
  padding: 48px 14px 14px;
  color: #fff;
}
.karta-overlay h2, .karta-overlay h3 {
  font-size: .92rem;
  font-weight: 700;
  line-height: 1.28;
  margin-top: 5px;
  text-shadow: 0 1px 4px rgba(0,0,0,.6);
}
.karta-overlay-wrap:hover .karta-overlay h2,
.karta-overlay-wrap:hover .karta-overlay h3 { color: #ffe; }
.karta-sponsor { outline: 3px solid #f0a500; }

/* === HERO NAGŁÓWEK === */
.hero-naglowek {
  margin-bottom: 12px;
}
.hero-data {
  font-size: .75rem;
  color: var(--muted);
  font-weight: 500;
}

/* === HERO SECTION === */
.hero-section {
  display: grid;
  grid-template-columns: 58% 1fr;
  gap: 10px;
  margin-bottom: 10px;
  align-items: stretch;
}
@media (max-width: 860px) { .hero-section { grid-template-columns: 1fr; } }

.hero-big {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: #1f2937;
  box-shadow: var(--shadow);
  transition: transform .25s, box-shadow .25s;
  min-height: 360px;
}
.hero-big:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.hero-big img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s, opacity .4s; }
.hero-big:hover img { transform: scale(1.05); opacity: .88; }
.hero-big .karta-overlay { padding: 60px 18px 18px; }
.hero-big .karta-overlay h2 { font-size: 1.5rem; font-weight: 800; line-height: 1.2; }
.hero-big .karta-overlay .art-meta { font-size: .75rem; margin-top: 6px; }

.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
}
.hero-grid .karta-overlay-wrap {
  min-height: 0;
}
.hero-grid .karta-overlay h3 { font-size: .85rem; line-height: 1.25; }
.hero-grid .karta-overlay { padding: 36px 12px 12px; }

/* === REKLAMA PAS === */
.reklama-pas {
  text-align: center;
  padding: 10px 0;
  margin: 20px 0;
}
.reklama-pas.ad-ph { height: 80px; border-radius: var(--radius); }

/* === AD PLACEHOLDER === */
.ad-ph {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f3f4f6;
  border: 2px dashed #d1d5db;
  color: #9ca3af;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .6px;
  border-radius: var(--radius);
}
.reklama-sidebar.ad-ph { min-height: 250px; }

/* === PORTAL BODY === */
.portal-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 20px;
  align-items: start;
  padding-top: 20px;
}
@media (max-width: 960px) { .portal-body { grid-template-columns: 1fr; } }

/* === SEKCJA KATEGORII === */
.sekcja-kat {
  margin-bottom: 32px;
}

.sekcja-naglowek {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 10px;
  border-bottom: 3px solid var(--red);
  margin-bottom: 12px;
}
.sekcja-naglowek h2 {
  font-size: .95rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .7px;
  color: var(--dark);
}
.sekcja-naglowek h2 a:hover { color: var(--red); }
.wiecej-link { font-size: .75rem; color: var(--muted); font-weight: 600; padding: 3px 10px; border: 1px solid var(--border); border-radius: 20px; transition: all .15s; }
.wiecej-link:hover { color: var(--red); border-color: var(--red); }

/* === SIATKA 3 KOLUMNY === */
.sekcja-siatka {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.sekcja-siatka .karta-overlay-wrap { aspect-ratio: 4/3; }
@media (max-width: 700px) { .sekcja-siatka { grid-template-columns: 1fr 1fr; } }
@media (max-width: 420px) { .sekcja-siatka { grid-template-columns: 1fr; } }

/* === BADGE SPONSOR === */
.badge-sponsor {
  position: absolute;
  top: 10px; left: 10px; z-index: 2;
  background: #f0a500;
  color: #fff;
  font-size: .62rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .4px;
}

/* === TAGI / META === */
.tag-kat { display: inline-block; font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--red); border-left: 3px solid var(--red); padding-left: 6px; }
.tag-kat-sm { font-size: .65rem; font-weight: 700; text-transform: uppercase; color: var(--red); }
.art-meta { font-size: .68rem; color: rgba(255,255,255,.65); margin-top: 4px; }
.zrodlo { font-weight: 600; }
.zrodlo-male { font-size: .62rem; color: rgba(255,255,255,.45); font-style: italic; }
.czas-sm { font-size: .65rem; color: var(--muted); }

/* === SIDEBAR === */
.col-sidebar { position: sticky; top: 56px; align-self: start; }
.reklama-sidebar { margin-bottom: 18px; text-align: center; }
.sticky-ad { position: sticky; top: 66px; }

.sidebar-box {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 18px;
  box-shadow: var(--shadow);
}
.sidebar-tytul { font-size: .7rem; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--white); background: var(--dark); padding: 10px 14px; }
.sidebar-item { display: flex; flex-direction: column; gap: 3px; padding: 9px 14px; border-bottom: 1px solid var(--border); transition: background .12s; }
.sidebar-item:last-child { border-bottom: none; }
.sidebar-item:hover { background: #f9fafb; }
.sidebar-item-tytul { font-size: .81rem; font-weight: 600; line-height: 1.35; color: var(--dark); }
.sidebar-item:hover .sidebar-item-tytul { color: var(--red); }
.kat-link { display: flex; justify-content: space-between; align-items: center; padding: 9px 14px; border-bottom: 1px solid var(--border); font-size: .85rem; color: var(--mid); transition: background .12s; }
.kat-link:last-child { border-bottom: none; }
.kat-link:hover { background: #f9fafb; color: var(--red); }
.kat-aktywna { color: var(--red); font-weight: 700; }
.kat-ile { background: var(--bg); color: var(--muted); font-size: .7rem; padding: 2px 8px; border-radius: 12px; font-weight: 600; }

/* === KAT HEADER === */
.kat-header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 16px;
  padding: 12px 16px;
  background: var(--white);
  border-radius: var(--radius);
  border-left: 5px solid var(--red);
  box-shadow: var(--shadow);
}
.kat-header h1 { font-size: 1.35rem; font-weight: 900; }
.kat-liczba { color: var(--muted); font-size: .8rem; }

/* === ARTYKUŁ PEŁNY === */
.portal-layout { display: grid; grid-template-columns: 1fr 300px; gap: 20px; align-items: start; }
@media (max-width: 960px) { .portal-layout { grid-template-columns: 1fr; } }

.artykul-pelny {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  margin-bottom: 18px;
}
.art-pelny-hero { width: 100%; max-height: 480px; object-fit: cover; }
.artykul-pelny-body { padding: 22px 28px 32px; }
.art-pelny-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.art-pelny-meta .art-meta { color: var(--muted); font-size: .78rem; }
.art-pelny-meta .zrodlo { color: var(--mid); }
.artykul-pelny h1 { font-size: 1.8rem; font-weight: 900; line-height: 1.2; margin-bottom: 20px; }
.art-tresc { color: var(--mid); line-height: 1.85; font-size: .97rem; }
.art-tresc p { margin-bottom: 1em; }
.art-tresc img { max-width: 100%; border-radius: 8px; margin: 14px 0; }
.art-tresc h2, .art-tresc h3 { color: var(--dark); margin: 1.2em 0 .4em; font-size: 1.1rem; }
.sponsor-info { background: #fff8e6; border-left: 4px solid #f0a500; padding: 10px 14px; font-size: .83rem; color: #7a5000; margin-bottom: 18px; border-radius: 0 6px 6px 0; }
.czytaj-wiecej { margin-top: 22px; padding-top: 16px; border-top: 1px solid var(--border); font-size: .86rem; }
.czytaj-wiecej a { color: var(--red); font-weight: 700; }

.reklama-art { text-align: center; margin: 18px 0; }
.reklama-art.ad-ph { height: 90px; border-radius: var(--radius); }

.podobne { background: var(--white); border-radius: var(--radius); overflow: hidden; margin-bottom: 18px; box-shadow: var(--shadow); }
.podobne-header { font-size: .7rem; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; background: var(--dark); color: var(--white); padding: 10px 16px; }
.podobne-siatka { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; padding: 12px; }
.podobny-art { display: block; position: relative; overflow: hidden; border-radius: 8px; aspect-ratio: 4/3; background: #1f2937; box-shadow: 0 1px 4px rgba(0,0,0,.1); transition: transform .2s, box-shadow .2s; }
.podobny-art:hover { transform: translateY(-3px); box-shadow: 0 4px 14px rgba(0,0,0,.16); }
.podobny-art img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.podobny-art:hover img { transform: scale(1.06); opacity: .85; }
.podobny-art .karta-overlay h3 { font-size: .75rem; }
@media (max-width: 600px) { .podobne-siatka { grid-template-columns: 1fr 1fr; } }

/* === PAGINACJA === */
.paginacja { display: flex; justify-content: center; align-items: center; gap: 16px; padding: 24px 0; font-size: .83rem; color: var(--muted); }
.paginacja a { background: var(--dark); color: var(--white); padding: 8px 20px; border-radius: 6px; font-weight: 600; transition: background .15s; }
.paginacja a:hover { background: var(--red); }

/* === INFO BOX === */
.info-box { background: #eff6ff; border: 1px solid #bfdbfe; padding: 14px 18px; border-radius: var(--radius); margin-bottom: 16px; }
.info-box a { color: var(--red); font-weight: 600; }

/* === FOOTER === */
.site-footer { background: var(--dark); color: #6b7280; text-align: center; padding: 24px; margin-top: 32px; font-size: .78rem; }
