/*
Theme Name: Sportowe Wiadomości
Theme URI: https://sportowewiadomosci.pl
Description: Child theme portalu sportowego SportoweWiadomosci.pl. Parent: GeneratePress.
Author: SportoweWiadomosci.pl
Author URI: https://sportowewiadomosci.pl
Template: generatepress
Version: 1.0.0
Text Domain: sportowe-wiadomosci
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */

:root {
  /* Kolory */
  --sw-primary: #DC2626;
  --sw-primary-hover: #B91C1C;
  --sw-secondary: #0F172A;
  --sw-secondary-light: #334155;
  --sw-accent: #EA580C;
  --sw-accent-hover: #C2410C;
  --sw-surface: #FFFFFF;
  --sw-background: #F8FAFC;
  --sw-text: #0F172A;
  --sw-text-secondary: #64748B;
  --sw-text-muted: #94A3B8;
  --sw-border: #E2E8F0;

  /* Kategorie */
  --cat-mma: #DC2626;
  --cat-futbol: #059669;
  --cat-boks: #7C3AED;
  --cat-tenis: #D97706;
  --cat-f1: #E11D48;
  --cat-zaklady: #EA580C;

  /* Dark mode */
  --sw-dm-surface: #1E293B;
  --sw-dm-background: #0F172A;
  --sw-dm-text: #F1F5F9;
  --sw-dm-text-secondary: #94A3B8;
  --sw-dm-border: #334155;

  /* Typografia */
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body: 'Source Sans 3', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  /* Rozmiary tekstu */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1.0625rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-12: 3rem;
  --space-16: 4rem;

  /* Layout */
  --container: 1200px;
  --content-width: 720px;
  --sidebar-width: 320px;
  --gap: 1.5rem;

  /* Efekty */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.07);
  --shadow-lg: 0 10px 25px rgba(0,0,0,0.1);
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --transition: 150ms ease;

  /* Bento 2026 — spójne design tokens */
  --radius-card: 16px;
  --radius-card-mobile: 12px;
  --radius-badge: 6px;
  --radius-button: 8px;
  --radius-full: 50%;
  --color-primary: #DC2626;
  --color-text-desktop: #222222;
  --color-text-mobile: #E0E0E0;
  --color-bg-desktop: #FFFFFF;
  --color-bg-mobile: #0F172A;
  --color-border: #E8E8E8;
  --color-border-mobile: rgba(255,255,255,0.1);
  --space-card-gap: 16px;
  --space-section: 32px;
  --space-section-mobile: 24px;
  --space-content-padding: 16px;
}

/* ==========================================================================
   RESET I GLOBALNE
   ========================================================================== */

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--sw-text);
  background-color: var(--sw-background);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--sw-primary);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--sw-primary-hover);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 var(--space-4);
  color: var(--sw-text);
}

h1 { font-size: var(--text-5xl); }
h2 { font-size: var(--text-4xl); }
h3 { font-size: var(--text-3xl); }
h4 { font-size: var(--text-2xl); }

p {
  margin: 0 0 var(--space-4);
}

/* Kontener */
.sw-container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

/* ==========================================================================
   SCREEN READER TEXT + SKIP TO CONTENT
   ========================================================================== */

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.sw-skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  z-index: 10000;
  padding: var(--space-2) var(--space-4);
  background: var(--sw-primary);
  color: #fff;
  font-weight: 700;
  border-radius: var(--radius-sm);
  transition: top var(--transition);
}

.sw-skip-link:focus {
  top: var(--space-2);
  color: #fff;
  outline: 3px solid var(--sw-accent);
  outline-offset: 2px;
}

/* ==========================================================================
   HEADER / NAWIGACJA
   ========================================================================== */

.sw-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--sw-secondary);
  box-shadow: var(--shadow-md);
}

.sw-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

/* Logo */
.sw-logo {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-2xl);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1;
  color: #fff;
  text-decoration: none;
  display: flex;
  gap: var(--space-1);
  flex-shrink: 0;
}

.sw-logo:hover {
  color: #fff;
}

.sw-logo .logo-accent {
  color: var(--sw-primary);
}

/* Nawigacja główna */
.sw-main-nav {
  display: none;
}

.sw-main-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--space-6);
}

.sw-main-nav a {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #fff;
  padding: var(--space-2) 0;
  position: relative;
  transition: color var(--transition);
}

.sw-main-nav a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: var(--sw-primary);
  transition: width var(--transition);
  border-radius: 2px;
}

.sw-main-nav a:hover::after,
.sw-main-nav .current-menu-item a::after {
  width: 100%;
}

/* Kolorowe underline per kategoria */
.sw-main-nav .cat-mma a::after { background: var(--cat-mma); }
.sw-main-nav .cat-futbol a::after { background: var(--cat-futbol); }
.sw-main-nav .cat-boks a::after { background: var(--cat-boks); }
.sw-main-nav .cat-tenis a::after { background: var(--cat-tenis); }
.sw-main-nav .cat-f1 a::after { background: var(--cat-f1); }
.sw-main-nav .cat-zaklady a::after { background: var(--cat-zaklady); }

/* Kategorie — horizontal scroll na mobile */
.sw-categories-bar {
  background: var(--sw-secondary);
  border-top: 1px solid var(--sw-dm-border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.sw-categories-bar::-webkit-scrollbar {
  display: none;
}

.sw-categories-bar ul {
  list-style: none;
  margin: 0;
  padding: 0 var(--space-4);
  display: flex;
  gap: var(--space-4);
  white-space: nowrap;
}

.sw-categories-bar a {
  display: block;
  padding: var(--space-2) 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--sw-dm-text-secondary);
  border-bottom: 3px solid transparent;
  transition: color var(--transition), border-color var(--transition);
}

.sw-categories-bar a:hover {
  color: #fff;
}

.sw-categories-bar .cat-mma a { border-bottom-color: var(--cat-mma); }
.sw-categories-bar .cat-futbol a { border-bottom-color: var(--cat-futbol); }
.sw-categories-bar .cat-boks a { border-bottom-color: var(--cat-boks); }
.sw-categories-bar .cat-tenis a { border-bottom-color: var(--cat-tenis); }
.sw-categories-bar .cat-f1 a { border-bottom-color: var(--cat-f1); }
.sw-categories-bar .cat-zaklady a { border-bottom-color: var(--cat-zaklady); }

/* Hamburger */
.sw-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.sw-hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}

.sw-hamburger.is-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.sw-hamburger.is-active span:nth-child(2) {
  opacity: 0;
}

.sw-hamburger.is-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile menu overlay */
.sw-mobile-menu {
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--sw-secondary);
  z-index: 999;
  padding: var(--space-6);
  transform: translateX(100%);
  transition: transform 300ms ease;
  overflow-y: auto;
}

.sw-mobile-menu.is-open {
  transform: translateX(0);
}

.sw-mobile-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sw-mobile-menu a {
  display: block;
  padding: var(--space-3) 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xl);
  text-transform: uppercase;
  color: #fff;
  border-bottom: 1px solid var(--sw-dm-border);
}

body.menu-open {
  overflow: hidden;
}

/* Search expand */
.sw-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sw-search-toggle {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: var(--space-1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.sw-search-toggle svg {
  width: 20px;
  height: 20px;
}

.sw-search-expand {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--sw-secondary);
  padding: var(--space-4);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 200ms ease;
  z-index: 998;
}

.sw-search-expand.is-open {
  transform: scaleY(1);
}

.sw-search-expand .search-field {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  display: block;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-lg);
  font-family: var(--font-body);
  background: var(--sw-dm-surface);
  border: 2px solid var(--sw-dm-border);
  border-radius: var(--radius-md);
  color: #fff;
  outline: none;
}

.sw-search-expand .search-field:focus {
  border-color: var(--sw-primary);
}

/* ==========================================================================
   PASEK "POPULARNE" (trending bar)
   ========================================================================== */

.sw-trending-bar {
  background: #111111;
  border-bottom: 2px solid #DC2626;
  height: 36px;
}

.sw-trending-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--space-4);
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  overflow: hidden;
}

.sw-trending-track {
  display: flex;
  align-items: center;
  white-space: nowrap;
  gap: var(--space-3);
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  flex: 1;
  min-width: 0;
}

.sw-trending-track::-webkit-scrollbar {
  display: none;
}

.sw-trending-badge {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff;
  background: var(--sw-primary);
  padding: 2px 8px;
  border-radius: 3px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 5px;
  line-height: 1;
}

.sw-trending-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
  flex-shrink: 0;
}

.sw-trending-link {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.6);
  transition: color var(--transition);
  flex-shrink: 0;
}

.sw-trending-link:hover {
  color: #fff;
}

.sw-trending-dot {
  color: rgba(255,255,255,0.3);
  font-size: 12px;
  flex-shrink: 0;
  line-height: 1;
}

/* ==========================================================================
   BREAKING NEWS TICKER
   ========================================================================== */

.sw-ticker {
  background: #000;
  color: #fff;
  overflow: hidden;
  position: relative;
  height: 36px;
  display: flex;
  align-items: center;
}

.sw-ticker-label {
  flex-shrink: 0;
  background: var(--sw-primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: var(--space-1) var(--space-3);
  z-index: 2;
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.sw-ticker-label .pulse-dot {
  width: 8px;
  height: 8px;
  background: #fff;
  border-radius: 50%;
  animation: pulse 1.5s ease-in-out infinite;
}

.sw-ticker-track {
  display: flex;
  animation: ticker-scroll 30s linear infinite;
  white-space: nowrap;
}

.sw-ticker-track:hover {
  animation-play-state: paused;
}

.sw-ticker-item {
  flex-shrink: 0;
  padding: 0 var(--space-8);
  font-size: var(--text-sm);
  font-weight: 600;
}

.sw-ticker-item a {
  color: #fff;
}

.sw-ticker-item a:hover {
  color: var(--sw-primary);
}

.sw-ticker-separator {
  color: var(--sw-primary);
  flex-shrink: 0;
}

/* ==========================================================================
   HERO
   ========================================================================== */

.sw-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-card);
  margin-bottom: var(--gap);
}

.sw-hero-link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  color: #fff;
}

.sw-hero-link:hover {
  color: #fff;
}

.sw-hero-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.sw-hero-link:hover .sw-hero-image {
  transform: scale(1.05);
}

.sw-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.85) 0%,
    rgba(0,0,0,0.4) 40%,
    rgba(0,0,0,0.1) 100%
  );
  z-index: 1;
}

.sw-hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-8) var(--space-6);
  z-index: 2;
}

.sw-hero-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-4xl);
  text-transform: uppercase;
  line-height: 1.1;
  margin: 0 0 var(--space-3);
  color: #fff;
}

.sw-hero-meta {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.8);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* ==========================================================================
   CATEGORY BADGE
   ========================================================================== */

.sw-cat-badge {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  color: #fff;
  line-height: 1;
  margin-bottom: var(--space-2);
}

/* ==========================================================================
   HERO ROW — hero + ad placeholder
   ========================================================================== */

.sw-hero-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-card-gap);
  margin-top: 20px;
  margin-bottom: var(--space-section-mobile);
}

.sw-hero-main .sw-hero {
  height: 100%;
  width: 100%;
  margin-bottom: 0;
  max-height: 320px;
}

.sw-hero-ad {
  display: none;
  background: #1E293B;
  border-radius: var(--radius-card);
  align-items: center;
  justify-content: center;
  min-height: 320px;
}

.sw-hero-ad-label {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.3);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ==========================================================================
   MOBILE FEED CARDS (widoczne tylko na mobile)
   ========================================================================== */

.sw-mobile-only {
  display: block;
}

.sw-desktop-only {
  display: none;
}

.sw-feed-card {
  margin-bottom: var(--space-card-gap);
  border-radius: var(--radius-card-mobile);
  overflow: hidden;
}

.sw-feed-card-link {
  display: block;
  color: #fff;
  text-decoration: none;
}

.sw-feed-card-image {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.sw-feed-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sw-feed-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 60%);
  z-index: 1;
}

.sw-feed-card-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px;
  z-index: 2;
}

.sw-feed-card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  text-transform: uppercase;
  line-height: 1.2;
  color: #fff;
  margin: 6px 0 4px;
}

.sw-feed-card-date {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
}

/* Load more button */
.sw-load-more-wrap {
  padding: 0 0 var(--space-8);
}

.sw-load-more-btn {
  display: block;
  width: 100%;
  padding: 16px;
  background: transparent;
  border: 1px solid var(--sw-border);
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--sw-text-secondary);
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}

.sw-load-more-btn:hover {
  background: var(--sw-background);
  color: var(--sw-text);
}

/* ==========================================================================
   BENTO GRID — strona główna
   ========================================================================== */

.sw-home-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-card-gap);
  margin-bottom: var(--space-section);
}

.sw-home-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-card-gap);
}

/* ==========================================================================
   POST CARDS
   ========================================================================== */

.sw-card {
  background: var(--color-bg-desktop);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  overflow: hidden;
  transition: border-color var(--transition);
  display: flex;
  flex-direction: column;
}

.sw-card:hover {
  border-color: #D0D0D0;
}

.sw-card-image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-card) var(--radius-card) 0 0;
}

.sw-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 400ms ease;
}

.sw-card:hover .sw-card-image img {
  transform: scale(1.08);
}

.sw-card-image .sw-cat-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 2;
}

.sw-card-body {
  padding: 16px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.sw-card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xl);
  text-transform: uppercase;
  line-height: 1.2;
  margin: 0 0 var(--space-2);
}

.sw-card-title a {
  color: var(--sw-text);
}

.sw-card-title a:hover {
  color: var(--sw-primary);
}

.sw-card-excerpt {
  font-size: var(--text-sm);
  color: var(--sw-text-secondary);
  line-height: 1.5;
  margin: 0 0 var(--space-3);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.sw-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--sw-text-muted);
  margin-top: auto;
}

.sw-card-meta img {
  border-radius: 50%;
  width: 24px;
  height: 24px;
}

.sw-card-meta span {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* Mała karta */
.sw-card-small {
  display: flex;
  gap: var(--space-3);
  background: var(--sw-surface);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: box-shadow var(--transition);
}

.sw-card-small:hover {
  box-shadow: var(--shadow-md);
}

.sw-card-small .sw-card-image {
  width: 120px;
  flex-shrink: 0;
  aspect-ratio: 16 / 9;
}

.sw-card-small .sw-card-body {
  padding: var(--space-2) var(--space-3) var(--space-2) 0;
}

.sw-card-small .sw-card-title {
  font-size: var(--text-sm);
  margin: 0 0 var(--space-1);
}

.sw-card-small .sw-card-meta {
  font-size: var(--text-xs);
}

/* ==========================================================================
   ARTICLE SINGLE
   ========================================================================== */

.sw-article-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-4);
}

.sw-article-content {
  min-width: 0;
  background: #fff;
  color: #222;
}

.sw-article-body {
  background: #fff;
  color: #222;
  font-family: 'Roboto', Arial, Helvetica, sans-serif;
  font-size: 17px;
  line-height: 1.7;
  letter-spacing: -0.01em;
}

.sw-article-body p {
  margin-bottom: 1.5em;
  color: #222;
}

.sw-article-body a {
  color: #DC2626;
  text-decoration: none;
}

.sw-article-body a:hover {
  text-decoration: underline;
}

.sw-article-header {
  margin-bottom: var(--space-6);
}

.sw-article-header .sw-cat-badge {
  margin-bottom: var(--space-3);
}

.sw-article-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-4xl);
  text-transform: uppercase;
  line-height: 1.1;
  margin: 0 0 var(--space-4);
}

.sw-article-meta {
  font-size: 14px;
  color: #888;
  line-height: 1.4;
}

.sw-article-meta .meta-dot {
  margin: 0 6px;
  color: #bbb;
}

/* Share bar na końcu artykułu */
.sw-share-bar-bottom {
  padding-top: var(--space-section-mobile);
  margin-top: var(--space-section-mobile);
  border-top: 1px solid var(--color-border);
  align-items: center;
}

.sw-share-label {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #888;
  margin-right: 4px;
}

.sw-article-featured-image {
  margin-bottom: var(--space-6);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.sw-article-featured-image img {
  width: 100%;
  height: auto;
}

/* Treść artykułu — nagłówki */
.sw-article-body h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px;
  color: #111;
  margin-top: 2.2em;
  margin-bottom: 0.8em;
  padding-bottom: var(--space-2);
  border-bottom: 3px solid var(--sw-primary);
}

.sw-article-body h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px;
  color: #111;
  margin-top: 1.8em;
  margin-bottom: 0.6em;
  margin: var(--space-6) 0 var(--space-3);
}

.sw-article-body p {
  margin-bottom: var(--space-4);
}

.sw-article-body blockquote {
  border-left: 4px solid var(--sw-primary);
  margin: var(--space-6) 0;
  padding: var(--space-4) var(--space-6);
  background: var(--sw-background);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-style: italic;
  color: var(--sw-text-secondary);
}

.sw-article-body blockquote p:last-child {
  margin-bottom: 0;
}

.sw-article-body table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-6) 0;
  font-size: var(--text-sm);
}

.sw-article-body th,
.sw-article-body td {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--sw-border);
  text-align: left;
}

.sw-article-body th {
  background: var(--sw-secondary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: var(--text-xs);
  letter-spacing: 0.05em;
}

.sw-article-body tr:nth-child(even) td {
  background: var(--sw-background);
}

.sw-article-body ul,
.sw-article-body ol {
  margin: 0 0 var(--space-4);
  padding-left: var(--space-6);
}

.sw-article-body ul {
  list-style: none;
}

.sw-article-body ul li {
  position: relative;
  padding-left: var(--space-4);
  margin-bottom: var(--space-2);
}

.sw-article-body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 8px;
  height: 8px;
  background: var(--sw-primary);
  border-radius: 2px;
}

.sw-article-body code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--sw-background);
  padding: 0.15em 0.4em;
  border-radius: var(--radius-sm);
  border: 1px solid var(--sw-border);
}

.sw-article-body pre {
  background: var(--sw-secondary);
  color: var(--sw-dm-text);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin: var(--space-6) 0;
}

.sw-article-body pre code {
  background: none;
  border: none;
  padding: 0;
  color: inherit;
}

/* ==========================================================================
   TL;DR BOX
   ========================================================================== */

.sw-tldr {
  background: #F0F4FF;
  border: 1px solid #E2E8F0;
  border-radius: 16px;
  padding: 24px;
  margin: var(--space-6) 0;
}

.sw-tldr-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #457B9D;
  margin-bottom: var(--space-2);
}

.sw-tldr p {
  font-size: 17px;
  line-height: 1.7;
  color: #333;
}

.sw-tldr p:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   ATHLETE PROFILE CARD
   ========================================================================== */

.sw-athlete-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  background: var(--sw-surface);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  margin: var(--space-6) 0;
}

.sw-athlete-photo {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto;
}

.sw-athlete-info h3 {
  margin-bottom: var(--space-1);
}

.sw-athlete-nickname {
  font-size: var(--text-sm);
  color: var(--sw-text-secondary);
  font-style: italic;
  margin-bottom: var(--space-3);
}

.sw-athlete-details {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
}

.sw-athlete-details li {
  display: flex;
  justify-content: space-between;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--sw-border);
}

.sw-athlete-details .detail-label {
  color: var(--sw-text-secondary);
}

.sw-athlete-details .detail-value {
  font-weight: 600;
}

.sw-athlete-stats {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
}

.sw-athlete-stat {
  text-align: center;
}

.sw-athlete-stat-value {
  display: block;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-3xl);
  color: var(--sw-primary);
  line-height: 1;
}

.sw-athlete-stat-label {
  font-size: var(--text-xs);
  color: var(--sw-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ==========================================================================
   AFFILIATE TABLE
   ========================================================================== */

.sw-affiliate-table {
  width: 100%;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  margin: var(--space-6) 0;
}

.sw-affiliate-table table {
  width: 100%;
  border-collapse: collapse;
}

.sw-affiliate-table th {
  background: var(--sw-secondary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: var(--text-xs);
  letter-spacing: 0.05em;
  padding: var(--space-3) var(--space-4);
  text-align: left;
}

.sw-affiliate-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--sw-border);
  font-size: var(--text-sm);
  vertical-align: middle;
}

.sw-affiliate-table tr:hover td {
  background: var(--sw-background);
}

.sw-affiliate-rank {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--text-sm);
  color: #fff;
}

.sw-affiliate-rank.rank-1 { background: #F59E0B; }
.sw-affiliate-rank.rank-2 { background: #9CA3AF; }
.sw-affiliate-rank.rank-3 { background: #B45309; }
.sw-affiliate-rank.rank-default { background: var(--sw-text-muted); }

.sw-affiliate-cta {
  display: inline-block;
  background: var(--sw-accent);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  transition: background var(--transition);
  white-space: nowrap;
}

.sw-affiliate-cta:hover {
  background: var(--sw-accent-hover);
  color: #fff;
}

/* ==========================================================================
   BONUS BOX
   ========================================================================== */

.sw-bonus-box {
  border: 2px solid var(--sw-accent);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin: var(--space-6) 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  background: var(--sw-surface);
}

.sw-bonus-icon {
  width: 56px;
  height: 56px;
  background: var(--sw-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  flex-shrink: 0;
}

.sw-bonus-info {
  flex: 1;
  min-width: 200px;
}

.sw-bonus-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  text-transform: uppercase;
}

.sw-bonus-value {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-2xl);
  color: var(--sw-primary);
}

.sw-bonus-rating {
  font-size: var(--text-sm);
  color: var(--sw-text-secondary);
}

.sw-bonus-cta {
  display: inline-block;
  background: var(--sw-accent);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  text-transform: uppercase;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}

.sw-bonus-cta:hover {
  background: var(--sw-accent-hover);
  color: #fff;
}

/* ==========================================================================
   FAQ ACCORDION
   ========================================================================== */

.sw-faq {
  margin: var(--space-6) 0;
}

.sw-faq-item {
  border: 1px solid var(--sw-border);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-2);
  overflow: hidden;
}

.sw-faq-question {
  width: 100%;
  background: var(--sw-surface);
  border: none;
  padding: var(--space-4);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  color: var(--sw-text);
  transition: background var(--transition);
}

.sw-faq-question:hover {
  background: var(--sw-background);
}

.sw-faq-toggle {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  position: relative;
}

.sw-faq-toggle::before,
.sw-faq-toggle::after {
  content: '';
  position: absolute;
  background: var(--sw-text);
  border-radius: 2px;
  transition: transform 300ms ease;
}

.sw-faq-toggle::before {
  width: 16px;
  height: 2px;
  top: 11px;
  left: 4px;
}

.sw-faq-toggle::after {
  width: 2px;
  height: 16px;
  top: 4px;
  left: 11px;
}

.sw-faq-item.open .sw-faq-toggle::after {
  transform: rotate(90deg);
}

.sw-faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 400ms ease;
}

.sw-faq-item.open .sw-faq-answer {
  max-height: 500px;
}

.sw-faq-answer-inner {
  padding: 0 var(--space-4) var(--space-4);
  color: var(--sw-text-secondary);
  line-height: 1.7;
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */

.sw-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
}

.sw-widget {
  background: var(--color-bg-desktop);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  padding: var(--space-6);
}

.sw-widget-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 3px solid var(--sw-primary);
}

/* Newsletter CTA */
.sw-newsletter {
  background: var(--sw-secondary);
  color: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-6);
}

.sw-newsletter-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

.sw-newsletter-desc {
  font-size: var(--text-sm);
  color: var(--sw-dm-text-secondary);
  margin-bottom: var(--space-4);
}

.sw-newsletter-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.sw-newsletter-input {
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--sw-dm-border);
  border-radius: var(--radius-sm);
  background: var(--sw-dm-surface);
  color: #fff;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  outline: none;
}

.sw-newsletter-input:focus {
  border-color: var(--sw-primary);
}

.sw-newsletter-submit {
  padding: var(--space-3) var(--space-4);
  background: var(--sw-primary);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background var(--transition);
}

.sw-newsletter-submit:hover {
  background: var(--sw-primary-hover);
}

/* ==========================================================================
   SOCIAL MEDIA FOLLOW BOX
   ========================================================================== */

.sw-social-follow {
  background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
  border-radius: var(--radius-card);
  padding: 20px;
  color: #fff;
}

.sw-social-follow-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 var(--space-1);
}

.sw-social-follow-desc {
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  margin: 0 0 var(--space-4);
  line-height: 1.4;
}

.sw-social-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.sw-social-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  padding: 12px;
  color: #fff;
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition);
}

.sw-social-btn:hover {
  background: rgba(255,255,255,0.15);
  color: #fff;
}

.sw-social-facebook:hover { border-color: #1877F2; }
.sw-social-twitter:hover  { border-color: #fff; }
.sw-social-youtube:hover   { border-color: #FF0000; }
.sw-social-instagram:hover { border-color: #E4405F; }

.sw-social-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.sw-social-name {
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
}

/* Popular posts lista */
.sw-popular-posts {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sw-popular-posts li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--sw-border);
}

.sw-popular-posts li:last-child {
  border-bottom: none;
}

.sw-popular-posts a {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  color: var(--sw-text);
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}

.sw-popular-posts a:hover {
  color: var(--sw-primary);
}

.sw-popular-posts .post-number {
  font-weight: 800;
  font-size: var(--text-lg);
  color: var(--sw-primary);
  line-height: 1;
  flex-shrink: 0;
  width: 24px;
}

.sw-popular-posts .post-title {
  flex: 1;
  line-height: 1.3;
}

/* TOC — spis treści */
.sw-toc {
  position: sticky;
  top: 80px;
}

.sw-toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
}

.sw-toc-list li {
  counter-increment: toc;
}

.sw-toc-list a {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  color: var(--sw-text-secondary);
  border-left: 3px solid transparent;
  padding-left: var(--space-3);
  transition: color var(--transition), border-color var(--transition);
}

.sw-toc-list a::before {
  content: counter(toc) ".";
  font-weight: 700;
  color: var(--sw-text-muted);
  flex-shrink: 0;
}

.sw-toc-list a:hover,
.sw-toc-list a.is-active {
  color: var(--sw-text);
  border-left-color: var(--sw-primary);
}

.sw-toc-list a.is-active::before {
  color: var(--sw-primary);
}

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */

.sw-breadcrumbs {
  font-size: var(--text-sm);
  color: var(--sw-text-muted);
  padding: var(--space-4) 0;
}

.sw-breadcrumbs a {
  color: var(--sw-text-secondary);
}

.sw-breadcrumbs a:hover {
  color: var(--sw-primary);
}

.sw-breadcrumbs .separator {
  margin: 0 var(--space-2);
  color: var(--sw-border);
}

/* ==========================================================================
   LIVE BADGE
   ========================================================================== */

.sw-live-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  background: var(--sw-primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.sw-live-badge .live-dot {
  width: 8px;
  height: 8px;
  background: #fff;
  border-radius: 50%;
  animation: pulse 1.5s ease-in-out infinite;
}

/* ==========================================================================
   RELATED POSTS
   ========================================================================== */

.sw-related-posts {
  margin-top: var(--space-section);
  padding-top: var(--space-section);
  border-top: 1px solid var(--color-border);
}

.sw-related-posts-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-2xl);
  text-transform: uppercase;
  margin-bottom: var(--space-6);
}

.sw-related-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap);
}

/* ==========================================================================
   AFFILIATE DISCLAIMER
   ========================================================================== */

.sw-affiliate-disclaimer {
  margin-top: var(--space-8);
  padding: var(--space-4);
  background: var(--sw-background);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--sw-text-muted);
  border: 1px solid var(--sw-border);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.sw-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-8) 0;
  font-family: var(--font-display);
}

.sw-pagination a,
.sw-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: var(--text-sm);
  transition: background var(--transition), color var(--transition);
}

.sw-pagination a {
  color: var(--sw-text);
  background: var(--sw-surface);
  border: 1px solid var(--sw-border);
}

.sw-pagination a:hover {
  background: var(--sw-primary);
  color: #fff;
  border-color: var(--sw-primary);
}

.sw-pagination .current {
  background: var(--sw-primary);
  color: #fff;
  border: 1px solid var(--sw-primary);
}

/* ==========================================================================
   SEARCH FORM
   ========================================================================== */

.sw-search-form {
  display: flex;
  gap: var(--space-2);
}

.sw-search-form .search-field {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--sw-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-base);
  background: var(--sw-surface);
  color: var(--sw-text);
  outline: none;
  transition: border-color var(--transition);
}

.sw-search-form .search-field:focus {
  border-color: var(--sw-primary);
}

.sw-search-form .search-submit {
  padding: var(--space-3) var(--space-6);
  background: var(--sw-primary);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--transition);
}

.sw-search-form .search-submit:hover {
  background: var(--sw-primary-hover);
}

/* ==========================================================================
   404
   ========================================================================== */

.sw-404 {
  text-align: center;
  padding: var(--space-16) var(--space-4);
  max-width: 600px;
  margin: 0 auto;
}

.sw-404-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 8rem;
  color: var(--sw-primary);
  line-height: 1;
  margin-bottom: var(--space-4);
}

.sw-404-text {
  font-size: var(--text-xl);
  color: var(--sw-text-secondary);
  margin-bottom: var(--space-8);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.sw-footer {
  background: var(--sw-secondary);
  color: var(--sw-dm-text-secondary);
  padding: var(--space-12) 0 0;
  margin-top: var(--space-12);
}

.sw-footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap);
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--space-4) var(--space-8);
}

.sw-footer-heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  text-transform: uppercase;
  color: #fff;
  margin-bottom: var(--space-4);
}

.sw-footer a {
  color: var(--sw-dm-text-secondary);
  font-size: var(--text-sm);
}

.sw-footer a:hover {
  color: #fff;
}

.sw-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sw-footer li {
  margin-bottom: var(--space-2);
}

.sw-footer-separator {
  border: none;
  border-top: 1px solid var(--sw-dm-border);
  margin: 0;
}

.sw-footer-bottom {
  max-width: var(--container);
  margin: 0 auto;
  padding: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--text-xs);
}

.sw-footer-copyright {
  color: var(--sw-text-muted);
}

/* ==========================================================================
   SCROLL FADE IN
   ========================================================================== */

.sw-fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 500ms ease, transform 500ms ease;
}

.sw-fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ==========================================================================
   KEYFRAMES
   ========================================================================== */

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes fade-in {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   DARK MODE
   ========================================================================== */

@media (prefers-color-scheme: dark) {
  :root {
    --sw-surface: #1E293B;
    --sw-background: #0F172A;
    --sw-text: #F1F5F9;
    --sw-text-secondary: #94A3B8;
    --sw-border: #334155;
  }

  body {
    color: #F1F5F9;
    background-color: #0F172A;
  }

  /* Karty */
  .sw-card {
    background: #1E293B;
    border: 1px solid #334155;
  }

  .sw-card-title a {
    color: #F1F5F9;
  }

  .sw-card-excerpt {
    color: #94A3B8;
  }

  /* Widgety */
  .sw-widget {
    background: #1E293B;
    border: 1px solid #334155;
  }

  /* Artykuł: ZAWSZE jasne tło i ciemny tekst */
  .sw-article-content {
    background: #fff;
    color: #222;
  }

  .sw-article-body {
    background: #fff;
    color: #222;
  }

  .sw-article-body p,
  .sw-article-body li,
  .sw-article-body td {
    color: #222;
  }

  .sw-article-body h2,
  .sw-article-body h3,
  .sw-article-body h4 {
    color: #111;
  }

  .sw-article-body a {
    color: #DC2626;
  }

  .sw-article-body blockquote {
    background: #F8FAFC;
    color: #555;
  }

  .sw-article-body code {
    background: #F8FAFC;
    border-color: #E2E8F0;
    color: #222;
  }

  .sw-article-header,
  .sw-article-meta {
    color: #94A3B8;
  }

  /* Elementy treści */
  .sw-tldr {
    background: #1E293B;
    color: #F1F5F9;
  }

  .sw-faq-question {
    background: #1E293B;
    color: #F1F5F9;
  }

  .sw-faq-question:hover {
    background: #0F172A;
    color: #F1F5F9;
  }

  .sw-faq-toggle::before,
  .sw-faq-toggle::after {
    background: #F1F5F9;
  }

  .sw-faq-item {
    border-color: #334155;
  }

  .sw-faq-answer-inner {
    color: #94A3B8;
  }

  .sw-athlete-card {
    background: #1E293B;
    color: #F1F5F9;
  }

  .sw-bonus-box {
    background: #1E293B;
    color: #F1F5F9;
  }

  .sw-affiliate-table tr:hover td {
    background: rgba(255,255,255,0.03);
  }

  .sw-search-form .search-field {
    background: #1E293B;
    border-color: #334155;
    color: #F1F5F9;
  }

  .sw-affiliate-disclaimer {
    background: #1E293B;
    border-color: #334155;
    color: #94A3B8;
  }

  .sw-popular-posts a {
    color: #F1F5F9;
  }

  /* Feed cards dark */
  .sw-feed-card {
    background: #1E293B;
  }

  /* Load more dark */
  .sw-load-more-btn {
    border-color: #334155;
    color: #94A3B8;
  }

  .sw-load-more-btn:hover {
    background: #1E293B;
    color: #F1F5F9;
  }

  /* Paginacja dark */
  .sw-pagination a {
    background: #1E293B;
    border-color: #334155;
    color: #F1F5F9;
  }

  .sw-article-body tr:nth-child(even) td {
    background: rgba(255,255,255,0.03);
  }
}

/* ==========================================================================
   RESPONSIVE — MOBILE FIRST
   ========================================================================== */

/* Tablet — 640px */
@media (min-width: 640px) {
  .sw-home-content {
    grid-template-columns: repeat(2, 1fr);
  }

  .sw-related-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sw-footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sw-athlete-card {
    grid-template-columns: 200px 1fr;
  }

  .sw-athlete-photo {
    margin: 0;
  }

  .sw-newsletter-form {
    flex-direction: row;
  }

  .sw-newsletter-input {
    flex: 1;
  }
}

/* Desktop — 768px+ (D1: light theme) */
@media (min-width: 769px) {
  /* D1: Białe tło na desktop */
  body {
    background: #FFFFFF;
    color: #222;
  }

  h1, h2, h3, h4, h5, h6 {
    color: var(--sw-text);
  }

  /* Karty light */
  .sw-card {
    background: #FFFFFF;
    border: 1px solid #E2E8F0;
  }

  .sw-card-title a { color: #222; }
  .sw-card-excerpt { color: #64748B; }

  /* Widget light */
  .sw-widget {
    background: #FFFFFF;
    border: 1px solid #E2E8F0;
  }

  .sw-widget-title { color: var(--sw-text); }
  .sw-popular-posts a { color: var(--sw-text); }

  /* D5: Artykuł desktop: białe tło, ciemny tekst, max-width 700px */
  .sw-article-content {
    background: #FFFFFF;
    color: #222;
    padding: 0;
  }

  .sw-article-body {
    font-family: 'Roboto', Arial, Helvetica, sans-serif;
    font-size: 17px;
    line-height: 1.7;
    letter-spacing: -0.01em;
    color: #222;
    max-width: 700px;
    text-align: left;
  }

  .sw-article-body p {
    color: #222;
    margin-bottom: 1.5em;
  }

  .sw-article-body h2 { font-size: 26px; color: #111; }
  .sw-article-body h3 { font-size: 20px; color: #111; }

  .sw-article-body blockquote {
    background: #F8FAFC;
    color: #555;
  }

  .sw-article-body code {
    background: #F8FAFC;
    color: #222;
    border-color: #E2E8F0;
  }

  .sw-article-meta { color: #64748B; }
  .sw-article-meta .meta-author { color: #222; }

  /* TL;DR desktop */
  .sw-tldr {
    background: #F0F4FF;
    border: 1px solid #E2E8F0;
    border-radius: 16px;
    padding: 24px;
  }

  .sw-tldr-label { color: #457B9D; }
  .sw-tldr p { color: #333; }

  /* FAQ light */
  .sw-faq-question { background: #FFFFFF; color: var(--sw-text); }
  .sw-faq-question:hover { background: #F8FAFC; color: var(--sw-text); }
  .sw-faq-item { border-color: #E2E8F0; }
  .sw-faq-toggle::before, .sw-faq-toggle::after { background: var(--sw-text); }
  .sw-faq-answer-inner { color: #64748B; }

  /* Related posts */
  .sw-related-posts-title { color: var(--sw-text); }
  .sw-related-posts { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }

  /* 404 light */
  .sw-404-text { color: #64748B; }
  .sw-404-list a { color: #222; }

  /* WhatsApp: ukryj na desktop */
  .sw-share-whatsapp { display: none; }

  /* Load more light */
  .sw-load-more-btn { border-color: #E2E8F0; color: #64748B; }

  /* Pagination light */
  .sw-pagination a { background: #FFFFFF; border-color: #E2E8F0; color: #222; }

  /* Search form light */
  .sw-search-form .search-field { background: #FFFFFF; border-color: #E2E8F0; color: #222; }

  /* Trending bar: no animation on desktop */
  .sw-trending-track { animation: none; overflow-x: auto; }

  /* Breadcrumbs visible */
  .sw-breadcrumbs { display: block; }
}

/* Desktop layout — 1024px */
@media (min-width: 1024px) {
  .sw-main-nav {
    display: block;
  }

  .sw-hamburger {
    display: none;
  }

  .sw-categories-bar {
    display: none;
  }

  .sw-mobile-only {
    display: none;
  }

  .sw-desktop-only {
    display: grid;
  }

  .sw-hero-row {
    grid-template-columns: 1fr 300px;
  }

  .sw-hero-ad {
    display: flex;
  }

  .sw-home-grid {
    grid-template-columns: 1fr var(--sidebar-width);
  }

  .sw-article-layout {
    grid-template-columns: 1fr 300px;
    gap: 32px;
  }

  .sw-article-layout .sw-sidebar,
  .sw-article-layout .sw-article-sidebar {
    position: sticky;
    top: 80px;
    align-self: start;
  }

  .sw-related-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .sw-hero-title {
    font-size: var(--text-4xl);
  }

  .sw-footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Duży desktop — 1400px */
@media (min-width: 1400px) {
  .sw-container {
    max-width: 1400px;
  }
}

/* ==========================================================================
   MOBILE — poniżej 768px
   ========================================================================== */

@media (max-width: 768px) {
  /* Overflow safety */
  * { max-width: 100%; }
  .sw-header,
  .sw-trending-bar,
  .sw-trending-inner,
  .sw-trending-badge,
  .sw-cat-badge { max-width: none; }

  /* M1: Ciemne tło na mobile */
  body {
    background: #0F172A;
    color: #F1F5F9;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
  }

  h1, h2, h3, h4, h5, h6 {
    color: #FFFFFF;
  }

  /* Sticky header: kompaktowy 48px */
  .sw-header-inner {
    height: 48px;
  }

  .sw-logo {
    font-size: var(--text-lg);
  }

  /* M2: Kontenery 16px padding */
  .sw-container {
    padding: 0 16px;
  }

  /* Typografia */
  h1 { font-size: var(--text-2xl); }
  h2 { font-size: var(--text-xl); }

  .sw-article-title {
    font-size: var(--text-2xl);
    color: #FFFFFF;
  }

  /* M1: Treść artykułu na mobile: JASNA czcionka na ciemnym tle */
  .sw-article-content {
    background: #0F172A;
    color: #E0E0E0;
    padding: 0 16px;
  }

  .sw-article-body {
    font-size: 16px;
    line-height: 1.7;
    color: #E0E0E0;
    padding: 0;
    text-align: left;
  }

  .sw-article-body p {
    color: #E0E0E0;
    margin-bottom: 1.5em;
  }

  .sw-article-body h2 {
    font-size: 22px;
    color: #FFFFFF;
  }

  .sw-article-body h3 {
    font-size: 18px;
    color: #FFFFFF;
  }

  .sw-article-body a {
    color: #DC2626;
  }

  .sw-article-body blockquote {
    background: #1E293B;
    color: #94A3B8;
    border-left-color: #DC2626;
  }

  .sw-article-body code {
    background: #1E293B;
    color: #E0E0E0;
    border-color: #334155;
  }

  .sw-article-body pre {
    background: #111;
  }

  .sw-article-meta {
    color: #94A3B8;
  }

  .sw-article-meta .meta-dot {
    color: #64748B;
  }

  .sw-share-bar-bottom {
    border-top-color: var(--color-border-mobile);
  }

  .sw-share-label {
    color: #94A3B8;
  }

  /* M1: Karty dark mobile + Bento mobile radius */
  .sw-card {
    background: #1E293B;
    border: 1px solid #334155;
    border-radius: var(--radius-card-mobile);
  }

  .sw-card-image {
    border-radius: var(--radius-card-mobile) var(--radius-card-mobile) 0 0;
  }

  .sw-card-title a { color: #F1F5F9; }
  .sw-card-excerpt { color: #94A3B8; }
  .sw-card-meta { color: #64748B; }

  /* M1: Widget dark mobile */
  .sw-widget {
    background: #1E293B;
    border: 1px solid #334155;
  }

  .sw-widget-title { color: #FFFFFF; }
  .sw-popular-posts a { color: #F1F5F9; }

  /* M5: Powiązane artykuły widoczne na mobile */
  .sw-related-posts {
    margin-bottom: 32px;
    padding-bottom: 32px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }

  .sw-related-posts-title {
    color: #FFFFFF;
  }

  /* M6: Ukryj breadcrumbs na mobile */
  .sw-breadcrumbs {
    display: none;
  }

  /* TL;DR na mobile */
  .sw-tldr {
    border-radius: 12px;
    padding: 16px;
    background: #1E293B;
    border-color: #334155;
  }

  .sw-tldr-label { color: #6BA3BE; }
  .sw-tldr p { color: #E0E0E0; }

  /* FAQ dark mobile */
  .sw-faq-question {
    background: #1E293B;
    color: #F1F5F9;
  }

  .sw-faq-question:hover {
    background: #0F172A;
    color: #F1F5F9;
  }

  .sw-faq-item {
    border-color: #334155;
  }

  .sw-faq-answer-inner {
    color: #94A3B8;
  }

  .sw-faq-toggle::before,
  .sw-faq-toggle::after {
    background: #F1F5F9;
  }

  /* Athlete card dark */
  .sw-athlete-card { background: #1E293B; color: #F1F5F9; }
  .sw-bonus-box { background: #1E293B; color: #F1F5F9; }
  .sw-affiliate-disclaimer { background: #1E293B; border-color: #334155; color: #94A3B8; }

  /* Load more dark */
  .sw-load-more-btn { border-color: #334155; color: #94A3B8; }
  .sw-load-more-btn:hover { background: #1E293B; color: #F1F5F9; }

  /* Pagination dark */
  .sw-pagination a { background: #1E293B; border-color: #334155; color: #F1F5F9; }

  /* Search form dark */
  .sw-search-form .search-field { background: #1E293B; border-color: #334155; color: #F1F5F9; }

  /* Share buttons mobile: pokaż WhatsApp */
  .sw-share-whatsapp { display: flex; }

  /* 404 dark mobile */
  .sw-404-code { color: #DC2626; }
  .sw-404-heading { color: #FFFFFF; }
  .sw-404-text { color: #94A3B8; }
  .sw-404-home-link { color: #DC2626; }
  .sw-404-section-title { color: #FFFFFF; }
  .sw-404-list a { color: #F1F5F9; }

  /* Hero */
  .sw-hero {
    border-radius: var(--radius-sm);
    max-height: 250px;
  }

  .sw-hero-title {
    font-size: var(--text-xl);
  }

  .sw-hero-content {
    padding: 12px;
  }

  .sw-hero-row {
    grid-template-columns: 1fr;
    margin-top: 12px;
  }

  .sw-hero-ad {
    display: none;
  }

  /* Gridy: jedna kolumna */
  .sw-home-grid,
  .sw-home-content,
  .sw-article-layout,
  .sw-related-grid {
    grid-template-columns: 1fr;
  }

  .sw-article-layout {
    gap: var(--space-4);
    padding: var(--space-4) 16px;
  }

  /* Sidebar pod treścią */
  .sw-sidebar {
    position: static;
  }

  /* Footer: 2 kolumny */
  .sw-footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Obrazki */
  img {
    max-width: 100%;
    height: auto;
  }

  /* Touch targets: minimum 44px */
  .sw-hamburger,
  .sw-search-toggle {
    min-width: 44px;
    min-height: 44px;
  }

  .sw-main-nav a,
  .sw-mobile-menu a,
  .sw-categories-bar a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  /* Kategorie pills */
  .sw-categories-bar {
    display: flex;
    background: var(--sw-secondary);
    border-top: 1px solid var(--sw-dm-border);
    padding: 8px 0;
  }

  .sw-categories-bar ul {
    padding: 0 16px;
    gap: 8px;
  }

  .sw-categories-bar a {
    background: #333;
    color: rgba(255,255,255,0.7);
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    font-family: var(--font-display);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: none;
    white-space: nowrap;
    min-height: auto;
  }

  .sw-categories-bar a:hover,
  .sw-categories-bar .current-cat a {
    background: var(--sw-primary);
    color: #fff;
  }

  /* Tabele afiliacyjne */
  .sw-affiliate-table table,
  .sw-affiliate-table thead,
  .sw-affiliate-table tbody,
  .sw-affiliate-table th,
  .sw-affiliate-table td,
  .sw-affiliate-table tr {
    display: block;
  }

  .sw-affiliate-table thead {
    position: absolute;
    left: -9999px;
  }

  .sw-affiliate-table tr {
    margin-bottom: var(--space-4);
    background: var(--sw-surface);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    padding: var(--space-4);
  }

  .sw-affiliate-table td {
    border: none;
    padding: var(--space-1) 0;
    text-align: left;
  }

  .sw-affiliate-table td::before {
    content: attr(data-label) ": ";
    font-weight: 700;
    font-family: var(--font-display);
    text-transform: uppercase;
    font-size: var(--text-xs);
    color: var(--sw-text-muted);
  }

  /* Tabele w artykule: scroll */
  .sw-article-body table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Trending bar: ticker auto-scroll */
  .sw-trending-track {
    overflow: hidden;
    animation: trending-scroll 25s linear infinite;
    width: max-content;
  }

  .sw-trending-track:active {
    animation-play-state: paused;
  }

  /* Athlete card */
  .sw-athlete-card {
    grid-template-columns: 1fr;
  }

  .sw-athlete-photo {
    margin: 0 auto;
  }

  /* Karty: bez hover animacji na mobile */
  .sw-card:hover {
    transform: none;
    box-shadow: var(--shadow-sm);
  }

  /* Social grid na mobile: 2x2 */
  .sw-social-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Ticker animation */
@keyframes trending-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ==========================================================================
   PRINT
   ========================================================================== */

/* ==========================================================================
   PRINT
   ========================================================================== */

@media print {
  .sw-header,
  .sw-ticker,
  .sw-trending-bar,
  .sw-sidebar,
  .sw-article-sidebar,
  .sw-categories-bar,
  .sw-newsletter,
  .sw-social-follow,
  .sw-mobile-menu,
  .sw-search-expand,
  .sw-related-posts,
  .sw-footer,
  .sw-pagination,
  .sw-load-more-wrap,
  .sw-hero-ad,
  .sw-share-bar,
  .sw-back-to-top,
  #sw-progress-bar,
  .sw-bonus-cta,
  .sw-affiliate-cta,
  .sw-skip-link {
    display: none !important;
  }

  body {
    color: #000;
    background: #fff;
    font-size: 12pt;
  }

  a { color: #000; text-decoration: underline; }
  .sw-article-layout { grid-template-columns: 1fr; }
  .sw-article-content { max-width: 100%; background: #fff; color: #000; }
  img { max-width: 100%; }
}

/* ==========================================================================
   UX1: PROGRESS BAR
   ========================================================================== */

#sw-progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: #DC2626;
  z-index: 9999;
  transition: width 100ms linear;
  pointer-events: none;
}

/* ==========================================================================
   UX4: SHARE BUTTONS
   ========================================================================== */

.sw-share-bar {
  display: flex;
  gap: 8px;
  margin: 16px 0;
  flex-wrap: wrap;
}

.sw-share-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border: none;
  cursor: pointer;
  transition: opacity var(--transition);
  text-decoration: none;
}

.sw-share-btn:hover {
  opacity: 0.8;
  color: #fff;
}

.sw-share-facebook { background: #1877F2; }
.sw-share-twitter { background: #000; }
.sw-share-whatsapp { background: #25D366; display: none; }
.sw-share-copy { background: #6B7280; }
.sw-share-copy.copied { background: #059669; }

/* ==========================================================================
   UX5: BACK TO TOP
   ========================================================================== */

.sw-back-to-top {
  position: fixed;
  bottom: 24px;
  right: 16px;
  width: 44px;
  height: 44px;
  background: #DC2626;
  color: #fff;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 999;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 200ms ease, transform 200ms ease;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.sw-back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

@media (max-width: 768px) {
  .sw-back-to-top {
    width: 40px;
    height: 40px;
    bottom: 24px;
  }
}

/* ==========================================================================
   UX6: SKELETON LOADING
   ========================================================================== */

.sw-skeleton {
  background: #E2E8F0;
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
}

.sw-skeleton::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.4) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* ==========================================================================
   UX8: 404 PAGE
   ========================================================================== */

.sw-404 {
  text-align: center;
  padding: var(--space-16) var(--space-4);
  max-width: 600px;
  margin: 0 auto;
}

.sw-404-code {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 8rem;
  color: #DC2626;
  line-height: 1;
  margin-bottom: var(--space-4);
}

.sw-404-heading {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
}

.sw-404-text {
  font-size: var(--text-lg);
  color: var(--sw-text-secondary);
  margin-bottom: var(--space-6);
}

.sw-404-home-link {
  display: inline-block;
  margin: var(--space-6) 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  color: #DC2626;
}

.sw-404-home-link:hover {
  color: var(--sw-primary-hover);
}

.sw-404-recent {
  text-align: left;
  margin-top: var(--space-12);
}

.sw-404-section-title {
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}

.sw-404-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sw-404-list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--sw-border);
}

.sw-404-list a {
  font-weight: 500;
  color: var(--sw-text);
}

.sw-404-list a:hover {
  color: #DC2626;
}

/* ==========================================================================
   UX2: TOC WIDGET
   ========================================================================== */

.sw-toc-widget {
  font-size: var(--text-sm);
}

.sw-toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
}

.sw-toc-list li {
  counter-increment: toc;
}

.sw-toc-list a {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  color: var(--sw-text-secondary);
  border-left: 3px solid transparent;
  padding-left: var(--space-3);
  transition: color var(--transition), border-color var(--transition);
  text-decoration: none;
}

.sw-toc-list a::before {
  content: counter(toc) ".";
  font-weight: 700;
  color: var(--sw-text-muted);
  flex-shrink: 0;
}

.sw-toc-list a:hover,
.sw-toc-list a.is-active {
  color: var(--sw-text);
  border-left-color: #DC2626;
}

.sw-toc-list a.is-active::before {
  color: #DC2626;
}

@media (max-width: 768px) {
  .sw-toc-widget {
    display: none;
  }
}

/* ==========================================================================
   FOCUS STYLES — accessibility
   ========================================================================== */

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid #DC2626;
  outline-offset: 2px;
}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ==========================================================================
   CARD HOVER (desktop only)
   ========================================================================== */

@media (min-width: 769px) {
  .sw-card {
    transition: border-color var(--transition);
  }

  .sw-card:hover {
    border-color: #D0D0D0;
    transform: none;
  }
}

/* ==========================================================================
   MOBILE DARK THEME — OSTATECZNY OVERRIDE
   Umieszczony na samym końcu pliku żeby nadpisać WSZYSTKO.
   Używa !important żeby pokonać parent theme i Customizer.
   ========================================================================== */

@media (max-width: 767px) {

  /* --- Globalne tło i tekst --- */
  html { background-color: #0F172A !important; }
  body { background-color: #0F172A !important; color: #E0E0E0 !important; }

  /* --- Nagłówki — białe --- */
  h1, h2, h3, h4, h5, h6 { color: #FFFFFF !important; }
  .sw-article-title { color: #FFFFFF !important; }
  .sw-widget-title { color: #FFFFFF !important; }
  .sw-related-posts-title { color: #FFFFFF !important; }
  .sw-hero-latest-title { color: #FFFFFF !important; }

  /* --- Treść artykułu — jasna --- */
  .sw-article-content { background-color: #0F172A !important; color: #E0E0E0 !important; }
  .sw-article-body { background-color: #0F172A !important; color: #E0E0E0 !important; }
  .sw-article-body p { color: #E0E0E0 !important; }
  .sw-article-body li { color: #E0E0E0 !important; }
  .sw-article-body td { color: #E0E0E0 !important; }
  .sw-article-body th { color: #FFFFFF !important; }
  .sw-article-body h2 { color: #FFFFFF !important; }
  .sw-article-body h3 { color: #FFFFFF !important; }
  .sw-article-body h4 { color: #FFFFFF !important; }
  .sw-article-body a { color: #DC2626 !important; }
  .sw-article-body strong { color: #F1F5F9 !important; }
  .sw-article-body em { color: #E0E0E0 !important; }

  /* Entry content (GeneratePress) */
  .entry-content { color: #E0E0E0 !important; background-color: #0F172A !important; }
  .entry-content p { color: #E0E0E0 !important; }
  .entry-content li { color: #E0E0E0 !important; }
  .entry-content h2 { color: #FFFFFF !important; }
  .entry-content h3 { color: #FFFFFF !important; }
  .entry-content a { color: #DC2626 !important; }

  /* --- Blockquote, code, pre --- */
  .sw-article-body blockquote { background: #1E293B !important; color: #94A3B8 !important; border-left-color: #DC2626 !important; }
  .sw-article-body code { background: #1E293B !important; color: #E0E0E0 !important; border-color: #334155 !important; }
  .sw-article-body pre { background: #111111 !important; color: #E0E0E0 !important; }
  .sw-article-body pre code { background: transparent !important; }

  /* --- Tabele --- */
  .sw-article-body table { border-color: #334155 !important; }
  .sw-article-body th { background: #1E293B !important; }
  .sw-article-body td { border-color: #334155 !important; }
  .sw-article-body tr:nth-child(even) td { background: rgba(255,255,255,0.03) !important; }

  /* --- TL;DR / W skrócie --- */
  .sw-tldr { background: rgba(255,255,255,0.05) !important; border-color: rgba(255,255,255,0.1) !important; }
  .sw-tldr-label { color: #6BA3BE !important; }
  .sw-tldr p { color: #E0E0E0 !important; }

  /* --- FAQ --- */
  .sw-faq-question { background: #1E293B !important; color: #F1F5F9 !important; }
  .sw-faq-question:hover { background: #0F172A !important; color: #F1F5F9 !important; }
  .sw-faq-item { border-color: #334155 !important; }
  .sw-faq-answer-inner { color: #94A3B8 !important; }
  .sw-faq-toggle::before,
  .sw-faq-toggle::after { background: #F1F5F9 !important; }

  /* --- Meta artykułu --- */
  .sw-article-meta { color: #94A3B8 !important; }
  .sw-article-meta .meta-dot { color: #64748B !important; }
  .sw-article-header { color: #F1F5F9 !important; }

  /* --- Karty artykułów --- */
  .sw-card { background: #1E293B !important; border-color: #334155 !important; }
  .sw-card-title a { color: #F1F5F9 !important; }
  .sw-card-excerpt { color: #94A3B8 !important; }
  .sw-card-meta { color: #64748B !important; }
  .sw-card-body { background: #1E293B !important; }

  /* --- Mała karta --- */
  .sw-card-small { background: #1E293B !important; }
  .sw-card-small .sw-card-title a { color: #F1F5F9 !important; }

  /* --- Sidebar --- */
  .sw-sidebar { background: transparent !important; }
  .sw-widget { background: #1E293B !important; border-color: #334155 !important; }
  .sw-popular-posts a { color: #F1F5F9 !important; }
  .sw-popular-posts .post-number { color: #DC2626 !important; }

  /* --- Social follow box --- */
  .sw-social-follow { background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%) !important; }

  /* --- Athlete card, bonus box, affiliate --- */
  .sw-athlete-card { background: #1E293B !important; color: #F1F5F9 !important; }
  .sw-athlete-nickname { color: #94A3B8 !important; }
  .sw-athlete-details .detail-label { color: #94A3B8 !important; }
  .sw-athlete-details .detail-value { color: #F1F5F9 !important; }
  .sw-athlete-details li { border-bottom-color: #334155 !important; }
  .sw-bonus-box { background: #1E293B !important; color: #F1F5F9 !important; border-color: var(--sw-accent) !important; }
  .sw-affiliate-disclaimer { background: #1E293B !important; border-color: #334155 !important; color: #94A3B8 !important; }

  /* --- Powiązane artykuły --- */
  .sw-related-posts { border-top-color: rgba(255,255,255,0.1) !important; border-bottom-color: rgba(255,255,255,0.1) !important; }

  /* --- Share bar --- */
  .sw-share-bar-bottom { border-top-color: rgba(255,255,255,0.1) !important; }
  .sw-share-label { color: #94A3B8 !important; }

  /* --- Paginacja --- */
  .sw-pagination a { background: #1E293B !important; border-color: #334155 !important; color: #F1F5F9 !important; }
  .sw-pagination .current { background: #DC2626 !important; border-color: #DC2626 !important; color: #FFFFFF !important; }

  /* --- Load more --- */
  .sw-load-more-btn { border-color: #334155 !important; color: #94A3B8 !important; background: transparent !important; }

  /* --- Search form --- */
  .sw-search-form .search-field { background: #1E293B !important; border-color: #334155 !important; color: #F1F5F9 !important; }
  .sw-search-form .search-submit { background: #DC2626 !important; color: #FFFFFF !important; }

  /* --- Breadcrumbs — ukryte na mobile --- */
  .sw-breadcrumbs { display: none !important; }

  /* --- Kontener — jasne tło wyłączone --- */
  .sw-container { background: transparent !important; }
  main { background: transparent !important; }
  #main { background: transparent !important; }
  .site-content { background-color: #0F172A !important; }
  .site { background-color: #0F172A !important; }
  #page { background-color: #0F172A !important; }

  /* --- 404 --- */
  .sw-404-code { color: #DC2626 !important; }
  .sw-404-heading { color: #FFFFFF !important; }
  .sw-404-text { color: #94A3B8 !important; }
  .sw-404-home-link { color: #DC2626 !important; }
  .sw-404-section-title { color: #FFFFFF !important; }
  .sw-404-list a { color: #F1F5F9 !important; }
  .sw-404-list li { border-bottom-color: #334155 !important; }

  /* --- TOC widget --- */
  .sw-toc-list a { color: #94A3B8 !important; }
  .sw-toc-list a.is-active { color: #F1F5F9 !important; }

  /* --- Newsletter (jeśli wróci) --- */
  .sw-newsletter { background: #1E293B !important; }
  .sw-newsletter-input { background: #0F172A !important; border-color: #334155 !important; color: #F1F5F9 !important; }

  /* --- Back to top --- */
  .sw-back-to-top { background: #DC2626 !important; color: #FFFFFF !important; }

  /* --- Affiliate table mobile stacked --- */
  .sw-affiliate-table tr { background: #1E293B !important; border-color: #334155 !important; }
  .sw-affiliate-table td { color: #E0E0E0 !important; }
  .sw-affiliate-table td::before { color: #64748B !important; }

  /* --- Live badge --- */
  .sw-live-badge { background: #DC2626 !important; color: #FFFFFF !important; }

  /* --- Bonus CTA --- */
  .sw-bonus-cta { background: var(--sw-accent) !important; color: #FFFFFF !important; }
  .sw-affiliate-cta { background: var(--sw-accent) !important; color: #FFFFFF !important; }

  /* --- C: Catch-all text override --- */
  p, li, td, th, label, figcaption, cite, small, address, dd, dt {
    color: #E0E0E0 !important;
  }
  /* span z wyjątkiem logo i badge */
  span:not(.logo-accent):not(.sw-cat-badge):not(.sw-trending-badge) {
    color: #E0E0E0 !important;
  }
  strong, b { color: #F1F5F9 !important; }
  a { color: #DC2626 !important; }
  a:visited { color: #DC2626 !important; }
  .sw-card-title a { color: #FFFFFF !important; }
  .sw-widget-title { color: #FFFFFF !important; }

  /* --- D: Breadcrumbs ukryte na mobile --- */
  .sw-breadcrumbs { display: none !important; }

  /* --- I: Ukryj zbędne meta na kartach --- */
  .sw-card-meta-hide-mobile { display: none !important; }
  .sw-card-meta img { display: none !important; }

  /* --- I: Meta artykułu na mobile: mniejszy font, dwie linie --- */
  .sw-article-meta {
    font-size: 12px !important;
    color: #94A3B8 !important;
    line-height: 1.5 !important;
  }

  /* --- H: Ticker mask — tekst zanika przy badge --- */
  .sw-trending-track {
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 30px, black calc(100% - 30px), transparent 100%) !important;
    mask-image: linear-gradient(to right, transparent 0%, black 30px, black calc(100% - 30px), transparent 100%) !important;
  }

  .sw-trending-badge {
    position: relative !important;
    z-index: 2 !important;
  }

  /* --- BUG 1: Logo kolor czerwony na "Wiadomości" --- */
  .sw-logo .logo-accent {
    color: #DC2626 !important;
  }
  .sw-logo span {
    color: #FFFFFF !important;
  }
  .sw-logo .logo-accent {
    color: #DC2626 !important;
  }

  /* --- BUG 2: Ticker linki — białe, nie czerwone --- */
  .sw-trending-link {
    color: rgba(255,255,255,0.85) !important;
  }
  .sw-trending-link:hover {
    color: #FFFFFF !important;
  }
  .sw-trending-dot {
    color: rgba(255,255,255,0.3) !important;
  }

  /* --- BUG 3: Ticker overflow — kontener musi obcinać --- */
  .sw-trending-inner {
    overflow: hidden !important;
  }
  .sw-trending-track {
    overflow: hidden !important;
    -webkit-mask-image: linear-gradient(to right, transparent 0px, black 30px, black calc(100% - 30px), transparent 100%) !important;
    mask-image: linear-gradient(to right, transparent 0px, black 30px, black calc(100% - 30px), transparent 100%) !important;
  }
  .sw-trending-bar {
    overflow: hidden !important;
  }

  /* --- BUG 4: Ukryj breadcrumbs i duplikat kategorii --- */
  .sw-breadcrumbs,
  .cat-links,
  .entry-category,
  .taxonomy-description,
  nav.sw-breadcrumbs {
    display: none !important;
  }

  /* --- BUG 6: Share buttons — małe, dyskretne --- */
  .sw-share-btn {
    width: 36px !important;
    height: 36px !important;
    background: transparent !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
  }
  .sw-share-facebook svg { fill: #1877F2 !important; }
  .sw-share-twitter svg { fill: #FFFFFF !important; }
  .sw-share-label {
    color: #94A3B8 !important;
    font-size: 12px !important;
  }

  /* --- GeneratePress parent theme overrides --- */
  .inside-article,
  .site-content,
  .content-area,
  .site-main,
  .inside-page-header,
  .page-header,
  .entry-header,
  .entry-summary,
  .comment-body {
    background-color: #0F172A !important;
    color: #E0E0E0 !important;
  }
}

/* ==========================================================================
   F: CENTROWANIE NA DUŻYCH MONITORACH (27"+)
   ========================================================================== */

.site-content,
.sw-container,
main,
.entry-content-wrapper {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.sw-header {
  width: 100%;
}

.sw-header-inner {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.sw-footer {
  width: 100%;
}

.sw-footer-grid,
.sw-footer-bottom {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 1400px) {
  .sw-container {
    padding: 0 40px;
  }
}

/* ==========================================================================
   B: ARTICLE LAYOUT — 1fr 300px, max-width 1100px, gap 32px
   ========================================================================== */

@media (min-width: 769px) {
  .sw-article-layout {
    display: grid !important;
    grid-template-columns: 1fr 300px !important;
    gap: 32px !important;
    max-width: 1100px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sw-article-body {
    max-width: 700px !important;
  }

  /* G: Sticky sidebar */
  .sw-article-sidebar {
    position: sticky !important;
    top: 80px !important;
    align-self: start !important;
  }
}

/* ==========================================================================
   H: TICKER — badge z-index + mask na track
   ========================================================================== */

.sw-trending-badge {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
}

.sw-trending-inner {
  overflow: hidden;
}

@media (min-width: 769px) {
  .sw-trending-track {
    -webkit-mask-image: none;
    mask-image: none;
  }
}
