﻿/* ============================================
   ROYAL JOKER POLSKA — STYLE CSS
   sokolsokolka.pl
   ============================================ */

/* === ZMIENNE === */
:root {
  --glowny: #dc2626;
  --glowny-ciemny: #b91c1c;
  --glowny-jasny: #ef4444;
  --zloty: #f59e0b;
  --zloty-ciemny: #d97706;
  --sukces: #10b981;
  --niebezp: #ef4444;
  --info: #3b82f6;

  --tlo: #ffffff;
  --tlo-2: #f8fafc;
  --tlo-3: #f1f5f9;
  --tekst: #1e293b;
  --tekst-2: #64748b;
  --tekst-3: #94a3b8;
  --obramowanie: #e2e8f0;

  --gradient-glowny: linear-gradient(135deg, #dc2626 0%, #991b1b 100%);
  --gradient-zloty: linear-gradient(135deg, #f59e0b 0%, #b45309 100%);
  --gradient-bohater: linear-gradient(160deg, #1e1b4b 0%, #312e81 30%, #4c1d95 60%, #7c3aed 100%);

  --cien-sm: 0 1px 3px rgba(0,0,0,0.08);
  --cien-md: 0 4px 12px rgba(0,0,0,0.1);
  --cien-lg: 0 8px 30px rgba(0,0,0,0.12);
  --cien-xl: 0 20px 40px rgba(0,0,0,0.15);

  --naglowek-h: 68px;
  --radius: 14px;
  --radius-sm: 8px;
  --radius-lg: 20px;
  --przeejscie: 0.25s ease;
}

[data-theme="dark"] {
  --tlo: #0f172a;
  --tlo-2: #1e293b;
  --tlo-3: #334155;
  --tekst: #f1f5f9;
  --tekst-2: #94a3b8;
  --tekst-3: #64748b;
  --obramowanie: #334155;
}

/* === RESET === */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:80px; }
body {
  font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, Roboto, 'Helvetica Neue', Arial, sans-serif;
  background: var(--tlo);
  color: var(--tekst);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
ul,ol { list-style:none; }
table { border-collapse:collapse; width:100%; }

/* === KONTENER === */
.kontener { max-width:1200px; margin:0 auto; padding:0 24px; }
.text-center { text-align:center; }

/* ============================================
   NAGŁÓWEK
   ============================================ */
.naglowek {
  position:fixed; top:0; left:0; right:0;
  background: var(--tlo);
  border-bottom: 1px solid var(--obramowanie);
  z-index:1000;
  height: var(--naglowek-h);
}
.naglowek.scrolled { box-shadow: var(--cien-md); }
.naglowek-pasek {
  display:flex; align-items:center; justify-content:space-between;
  height: var(--naglowek-h);
}
.logo {
  display:flex; align-items:center; gap:10px;
  font-size:20px; font-weight:700; color:var(--tekst);
  z-index:1001;
}
.logo:hover { color:var(--glowny); }
.logo-ikona {
  width:38px; height:38px; border-radius:10px;
  background:var(--gradient-glowny);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:16px; flex-shrink:0;
}
.logo-tekst strong { color:var(--glowny); }

/* Nawigacja */
.nawigacja {
  display:flex; gap:28px; align-items:center;
}
.nav-link {
  font-size:14px; font-weight:600; color:var(--tekst-2);
  padding:8px 0; position:relative; white-space:nowrap;
}
.nav-link::after {
  content:''; position:absolute; bottom:4px; left:0;
  width:0; height:2px; background:var(--glowny);
  transition: width var(--przeejscie);
}
.nav-link:hover { color:var(--glowny); }
.nav-link:hover::after { width:100%; }

/* Prawo nagłówka */
.naglowek-prawo {
  display:flex; align-items:center; gap:10px; z-index:1001;
}
.przelacznik-motyw {
  width:38px; height:38px; border-radius:10px;
  border:1px solid var(--obramowanie);
  background:var(--tlo-2);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--tekst);
}
.przelacznik-motyw:hover { background:var(--glowny); color:#fff; border-color:var(--glowny); }

.btn-bonus {
  display:flex; align-items:center; gap:8px;
  padding:9px 16px; background:var(--gradient-glowny);
  color:#fff; border-radius:10px; font-weight:600; font-size:13px;
}
.btn-bonus:hover { box-shadow:0 4px 16px rgba(220,38,38,0.4); }
.btn-bonus-odznaka {
  padding:2px 6px; background:rgba(255,255,255,0.2);
  border-radius:4px; font-size:10px; font-weight:700;
}

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  padding:8px; z-index:1002;
}
.hamburger span {
  width:24px; height:2.5px; background:var(--tekst);
  border-radius:2px; transition: all 0.3s ease; transform-origin:center;
}
.hamburger.active span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

/* Overlay menu */
.menu-overlay {
  display:none; position:fixed; top:var(--naglowek-h); left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.5); z-index:998;
}
.menu-overlay.active { display:block; }

/* ============================================
   BUTTONS
   ============================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 24px; border-radius:var(--radius-sm); font-weight:600;
  font-size:14px; border:none; cursor:pointer; transition:all var(--przeejscie);
}
.btn-primary {
  background:var(--gradient-glowny); color:#fff;
  box-shadow:0 2px 8px rgba(220,38,38,0.25);
}
.btn-primary:hover { box-shadow:0 6px 20px rgba(220,38,38,0.4); transform:translateY(-1px); }
.btn-secondary {
  background:var(--tlo); color:var(--tekst);
  border:2px solid var(--obramowanie);
}
.btn-secondary:hover { border-color:var(--glowny); color:var(--glowny); }
.btn-jasny {
  background:#fff; color:var(--glowny);
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
}
.btn-jasny:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(0,0,0,0.15); }
.btn-lg { padding:16px 36px; font-size:16px; }
.btn-pelny { width:100%; }

/* ============================================
   HERO / BOHATER
   ============================================ */
.bohater {
  margin-top:var(--naglowek-h);
  padding:60px 0 80px;
  background:var(--gradient-bohater);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.bohater::before {
  content:''; position:absolute; top:-50%; right:-30%;
  width:800px; height:800px; border-radius:50%;
  background:radial-gradient(circle, rgba(220,38,38,0.15) 0%, transparent 70%);
  pointer-events:none;
}
.bohater-siatka {
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:48px; align-items:center; position:relative; z-index:1;
}

/* Gra placeholder */
.gra-ramka { width:100%; }
.gra-placeholder {
  aspect-ratio:16/10; border-radius:var(--radius-lg);
  background:linear-gradient(145deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  border:2px solid rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.gra-overlay { text-align:center; }
.gra-korona { font-size:56px; color:var(--zloty); margin-bottom:12px; display:block; }
.gra-nazwa { font-size:28px; font-weight:900; margin-bottom:4px; }
.gra-producent { font-size:14px; opacity:0.7; margin-bottom:20px; }
.btn-graj {
  padding:14px 32px; background:var(--gradient-glowny);
  color:#fff; border:none; border-radius:var(--radius);
  font-size:16px; font-weight:700; cursor:pointer;
  display:inline-flex; align-items:center; gap:10px;
}
.btn-graj:hover { box-shadow:0 8px 24px rgba(220,38,38,0.5); }
.gra-cechy {
  display:flex; gap:12px; margin-top:16px;
}
.cecha {
  flex:1; display:flex; align-items:center; gap:8px;
  padding:10px 14px; background:rgba(255,255,255,0.08);
  border-radius:var(--radius-sm); font-size:13px; font-weight:600; color:rgba(255,255,255,0.9);
}
.cecha i { color:var(--zloty); font-size:14px; }

/* Tekst bohatera */
.bohater-tresc { color:#fff; }
.bohater-odznaka {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; background:rgba(220,38,38,0.2);
  border:1px solid rgba(220,38,38,0.3); border-radius:var(--radius-sm);
  font-size:12px; font-weight:600; color:#fca5a5;
  text-transform:uppercase; letter-spacing:0.5px; margin-bottom:16px;
}
.bohater-tytul {
  font-size:clamp(2rem,4.5vw,3.2rem); font-weight:900;
  line-height:1.15; margin-bottom:16px;
}
.bohater-podtytul { font-size:18px; opacity:0.9; margin-bottom:12px; font-weight:500; }
.bohater-opis { font-size:15px; opacity:0.8; line-height:1.7; margin-bottom:28px; }

.bohater-statystyki { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:28px; }
.stat-box {
  padding:14px; background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.1); border-radius:var(--radius);
  text-align:center;
}
.stat-wartosc { font-size:22px; font-weight:900; color:var(--zloty); }
.stat-etykieta { font-size:11px; text-transform:uppercase; letter-spacing:0.5px; opacity:0.7; }

.bohater-akcje { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:20px; }
.bohater-zaufanie { display:flex; gap:16px; flex-wrap:wrap; }
.zaufanie-el {
  display:flex; align-items:center; gap:6px;
  font-size:13px; opacity:0.8;
}
.zaufanie-el i { color:var(--sukces); }

/* ============================================
   SEKCJE WSPÓLNE
   ============================================ */
.sekcja { padding:80px 0; }
.sekcja-spec, .sekcja-poradnik, .sekcja-faq, .sekcja-recenzja { background:var(--tlo-2); }
.sekcja-kasyna, .sekcja-live, .sekcja-mobilna, .sekcja-porownanie, .sekcja-bonusy, .sekcja-miasta { background:var(--tlo); }

.sekcja-naglowek { margin-bottom:48px; }
.sekcja-odznaka {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; background:rgba(220,38,38,0.08);
  border:1px solid rgba(220,38,38,0.15); border-radius:var(--radius-sm);
  font-size:12px; font-weight:600; color:var(--glowny);
  text-transform:uppercase; letter-spacing:0.5px; margin-bottom:12px;
}
.sekcja-tytul {
  font-size:clamp(1.75rem,3.5vw,2.4rem); font-weight:900;
  line-height:1.2; margin-bottom:12px; color:var(--tekst);
}
.sekcja-podtytul {
  font-size:16px; color:var(--tekst-2); max-width:720px; line-height:1.7;
}
.text-center .sekcja-podtytul { margin:0 auto; }
.sekcja-podtytul-sm { font-size:14px; color:var(--tekst-2); margin-top:8px; }

/* ============================================
   SPECYFIKACJA
   ============================================ */
.spec-layout { display:grid; grid-template-columns:1fr 340px; gap:32px; }
.karta-info {
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:32px; margin-bottom:24px;
}
.karta-naglowek {
  display:flex; align-items:center; gap:14px; margin-bottom:24px;
}
.karta-naglowek i { font-size:24px; color:var(--glowny); }
.karta-naglowek h3 { font-size:22px; font-weight:800; }
.karta-opis { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:20px; }

/* Tabela spec */
.tabela-spec { width:100%; }
.tabela-spec tr { border-bottom:1px solid var(--obramowanie); }
.tabela-spec tr:last-child { border-bottom:none; }
.tabela-spec td { padding:12px 0; font-size:14px; }
.tabela-spec td:first-child { color:var(--tekst-2); width:50%; }
.tabela-spec td:last-child { font-weight:600; text-align:right; }

.znacznik {
  display:inline-block; padding:3px 10px; border-radius:6px;
  font-size:12px; font-weight:700; text-transform:uppercase;
}
.znacznik-zielony { background:rgba(16,185,129,0.1); color:var(--sukces); }
.znacznik-czerwony { background:rgba(220,38,38,0.1); color:var(--glowny); }

/* Symbole */
.symbole-lista { display:flex; flex-direction:column; gap:10px; }
.symbol-wiersz {
  display:flex; align-items:center; gap:14px;
  padding:10px 14px; background:var(--tlo-2); border-radius:var(--radius-sm);
}
.symbol-ikona { width:36px; text-align:center; font-size:20px; color:var(--zloty); }
.symbol-nazwa { flex:1; font-size:13px; color:var(--tekst-2); }
.symbol-mnoznik { font-size:15px; font-weight:800; color:var(--glowny); }

/* Mechanizmy */
.mechanizmy-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:20px; }
.mechanizm-karta {
  background:var(--tlo-2); border-radius:var(--radius);
  padding:24px; border:1px solid var(--obramowanie);
}
.mechanizm-ikona { font-size:32px; color:var(--glowny); margin-bottom:14px; display:block; }
.mechanizm-karta h4 { font-size:18px; font-weight:700; margin-bottom:10px; }
.mechanizm-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:14px; }
.mechanizm-meta { display:flex; gap:16px; flex-wrap:wrap; }
.mechanizm-meta span { font-size:12px; color:var(--tekst-3); display:flex; align-items:center; gap:4px; }
.mechanizm-meta i { color:var(--zloty); font-size:11px; }

/* Tabela wygranych */
.tabela-wygrane { font-size:14px; }
.tabela-wygrane thead { background:var(--tlo-2); }
.tabela-wygrane th { padding:12px 16px; text-align:left; font-weight:700; border-bottom:2px solid var(--obramowanie); }
.tabela-wygrane td { padding:12px 16px; border-bottom:1px solid var(--obramowanie); }
.tabela-wygrane tr:last-child td { border-bottom:none; }
.wygrana-zielona { font-weight:700; color:var(--sukces); }

/* Sidebar */
.spec-sidebar {}
.sidebar-karta {
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:24px; margin-bottom:24px;
}
.sidebar-sticky { position:sticky; top:90px; }
.sidebar-tytul { font-size:17px; font-weight:700; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.sidebar-tytul i { color:var(--glowny); }

/* Ocena */
.ocena-lista { display:flex; flex-direction:column; gap:14px; }
.ocena-element {}
.ocena-naglowek { display:flex; justify-content:space-between; margin-bottom:6px; }
.ocena-naglowek span { font-size:13px; color:var(--tekst-2); }
.ocena-procent { font-weight:700; color:var(--glowny); }
.pasek-bg { height:6px; background:var(--tlo-3); border-radius:3px; overflow:hidden; }
.pasek-fill { height:100%; background:var(--gradient-glowny); border-radius:3px; }

.ocena-podsumowanie {
  margin-top:20px; padding-top:20px; border-top:2px solid var(--obramowanie);
  text-align:center;
}
.ocena-duza { font-size:48px; font-weight:900; color:var(--glowny); }
.ocena-gwiazdki { color:var(--zloty); font-size:20px; margin:6px 0; }
.ocena-tekst { font-size:14px; font-weight:600; color:var(--sukces); }

/* Szybkie fakty */
.szybkie-fakty { display:flex; flex-direction:column; gap:8px; }
.fakt-wiersz {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px; background:var(--tlo-2); border-radius:var(--radius-sm);
  font-size:13px;
}
.fakt-wiersz span:first-child { color:var(--tekst-2); }
.fakt-wiersz span:last-child { font-weight:700; color:var(--tekst); }

/* Sidebar CTA */
.sidebar-cta { background:var(--gradient-glowny); color:#fff; text-align:center; border:none; }
.sidebar-cta-ikona { font-size:40px; margin-bottom:12px; display:block; }
.sidebar-cta h4 { font-size:18px; font-weight:800; margin-bottom:8px; }
.sidebar-cta p { font-size:14px; opacity:0.9; margin-bottom:16px; }
.sidebar-cta .btn { background:#fff; color:var(--glowny); }
.sidebar-cta .btn:hover { box-shadow:0 4px 16px rgba(0,0,0,0.2); }

/* ============================================
   PORÓWNANIE
   ============================================ */
.tabela-responsive { overflow-x:auto; margin-bottom:24px; }
.tabela-porownanie { min-width:700px; font-size:14px; }
.tabela-porownanie th, .tabela-porownanie td { padding:14px 18px; border-bottom:1px solid var(--obramowanie); text-align:center; }
.tabela-porownanie th { background:var(--tlo-2); font-weight:700; }
.tabela-porownanie td:first-child, .tabela-porownanie th:first-child { text-align:left; }
.kolumna-wyroznienie { background:rgba(220,38,38,0.04); }
.tabela-porownanie thead .kolumna-wyroznienie { background:rgba(220,38,38,0.1); color:var(--glowny); font-weight:800; }
.porownanie-wniosek { font-size:15px; color:var(--tekst-2); line-height:1.7; text-align:center; max-width:800px; margin:0 auto; }

/* ============================================
   KASYNA
   ============================================ */
.kasyna-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:24px;
}
.kasyno-karta {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:24px;
  transition:all var(--przeejscie);
}
.kasyno-karta:hover { border-color:var(--glowny); box-shadow:var(--cien-md); }
.kasyno-gora { display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.kasyno-logo {
  width:56px; height:56px; border-radius:12px; background:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:20px; color:var(--glowny); flex-shrink:0;
  border:1px solid var(--obramowanie);
}
.kasyno-nazwa { font-size:17px; font-weight:700; margin-bottom:2px; }
.kasyno-ocena { font-size:13px; color:var(--zloty); display:flex; align-items:center; gap:4px; }
.kasyno-bonus-box {
  background:var(--tlo); padding:14px; border-radius:var(--radius); margin-bottom:14px;
}
.kasyno-bonus-kwota { font-size:22px; font-weight:900; color:var(--glowny); margin-bottom:2px; }
.kasyno-bonus-opis { font-size:13px; color:var(--tekst-2); }
.kasyno-cechy { margin-bottom:16px; }
.kasyno-cechy li {
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--tekst-2); margin-bottom:7px;
}
.kasyno-cechy li i { color:var(--sukces); font-size:12px; }

/* ============================================
   PORADNIK
   ============================================ */
.kroki-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:24px;
  margin-bottom:48px;
}
.krok-karta {
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:28px; position:relative;
  transition:all var(--przeejscie);
}
.krok-karta:hover { border-color:var(--glowny); box-shadow:var(--cien-md); }
.krok-numer {
  position:absolute; top:-14px; left:24px;
  width:36px; height:36px; background:var(--gradient-glowny);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:900; font-size:15px;
}
.krok-ikona { font-size:36px; color:var(--glowny); margin:12px 0 14px; display:block; }
.krok-tytul { font-size:18px; font-weight:700; margin-bottom:10px; }
.krok-opis { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:14px; }
.krok-punkty { display:flex; flex-direction:column; gap:6px; }
.krok-punkty li { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--tekst-2); }
.punkt-ik { color:var(--sukces); font-size:12px; }

/* Strategie */
.strategie-sekcja, .wskazowki-sekcja { margin-top:48px; }
.strategie-naglowek {
  font-size:24px; font-weight:800; text-align:center;
  margin-bottom:28px; display:flex; align-items:center;
  justify-content:center; gap:10px;
}
.strategie-naglowek i { color:var(--glowny); }
.strategie-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:20px; }
.strategia-karta {
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius); padding:24px;
}
.strategia-ikona { font-size:28px; color:var(--glowny); margin-bottom:12px; display:block; }
.strategia-karta h4 { font-size:17px; font-weight:700; margin-bottom:10px; }
.strategia-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:14px; }
.strategia-meta { display:flex; gap:16px; padding-top:12px; border-top:1px solid var(--obramowanie); }
.strategia-meta span { font-size:12px; color:var(--tekst-3); display:flex; align-items:center; gap:4px; }

/* Wskazówki */
.wskazowki-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.wskazowka-karta {
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius); padding:24px;
  transition:all var(--przeejscie);
}
.wskazowka-karta:hover { border-color:var(--glowny); }
.wskazowka-ikona { font-size:28px; color:var(--zloty); margin-bottom:12px; display:block; }
.wskazowka-karta h4 { font-size:16px; font-weight:700; margin-bottom:8px; }
.wskazowka-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; }

/* Ostrzeżenie */
.ostrzezenie-blok {
  margin-top:48px; display:flex; gap:16px; align-items:flex-start;
  padding:28px; background:rgba(220,38,38,0.04);
  border-radius:var(--radius-lg); border-left:4px solid var(--glowny);
}
.ostrzezenie-blok > i { font-size:24px; color:var(--glowny); flex-shrink:0; margin-top:2px; }
.ostrzezenie-blok h4 { font-size:18px; font-weight:700; margin-bottom:8px; }
.ostrzezenie-blok p { font-size:14px; color:var(--tekst-2); line-height:1.7; }

/* ============================================
   BONUSY
   ============================================ */
.glowna-oferta {
  background:var(--gradient-glowny); border-radius:var(--radius-lg);
  padding:48px 40px; text-align:center; color:#fff;
  position:relative; margin-bottom:40px;
  box-shadow:0 8px 32px rgba(220,38,38,0.25);
}
.oferta-goraca-odznaka {
  position:absolute; top:-14px; right:24px;
  background:var(--gradient-zloty); color:#fff;
  padding:8px 20px; border-radius:20px; font-size:12px;
  font-weight:700; text-transform:uppercase;
  box-shadow:0 4px 12px rgba(245,158,11,0.4);
}
.oferta-napis { font-size:13px; text-transform:uppercase; letter-spacing:2px; opacity:0.9; margin-bottom:8px; }
.oferta-naglowek { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:900; margin-bottom:6px; }
.oferta-kwota { font-size:20px; font-weight:700; color:#fbbf24; margin-bottom:16px; }
.oferta-opis { font-size:15px; opacity:0.92; max-width:700px; margin:0 auto 28px; line-height:1.7; }
.oferta-statystyki { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:600px; margin:0 auto 28px; }
.oferta-stat {
  background:rgba(255,255,255,0.12); padding:16px; border-radius:var(--radius);
}
.oferta-stat:hover { background:rgba(255,255,255,0.2); }
.oferta-stat-wartosc { font-size:28px; font-weight:900; }
.oferta-stat-nazwa { font-size:13px; opacity:0.85; }

/* Karty ofert */
.oferty-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:24px; }
.oferta-karta {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:28px; position:relative;
  transition:all var(--przeejscie); overflow:hidden;
}
.oferta-karta::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--gradient-glowny); transform:scaleX(0);
  transition:transform var(--przeejscie);
}
.oferta-karta:hover { border-color:var(--glowny); box-shadow:var(--cien-md); }
.oferta-karta:hover::before { transform:scaleX(1); }
.oferta-karta-vip { border:2px solid var(--glowny); background:rgba(220,38,38,0.02); }
.oferta-karta-znacznik {
  position:absolute; top:0; right:0; padding:5px 14px;
  border-radius:0 0 0 12px; font-size:11px; font-weight:700;
  text-transform:uppercase; color:#fff;
}
.oferta-znacznik-nowa { background:var(--sukces); }
.oferta-znacznik-popularna { background:var(--zloty); }
.oferta-znacznik-ekskluzywna { background:var(--gradient-glowny); }
.oferta-karta-ikona { font-size:36px; color:var(--glowny); margin-bottom:14px; display:block; }
.oferta-karta h4 { font-size:20px; font-weight:800; margin-bottom:6px; }
.oferta-karta-wartosc { font-size:24px; font-weight:900; color:var(--glowny); margin-bottom:14px; }
.oferta-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:16px; }
.oferta-karta-lista { margin-bottom:20px; }
.oferta-karta-lista li {
  display:flex; align-items:center; gap:8px; margin-bottom:8px;
  font-size:13px; color:var(--tekst-2);
}
.oferta-karta-lista i { color:var(--sukces); font-size:12px; }

/* Regulamin */
.bonus-regulamin {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:32px; margin-top:40px;
}
.bonus-regulamin h4 { font-size:18px; font-weight:700; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.bonus-regulamin h4 i { color:var(--glowny); }
.regulamin-lista { display:grid; gap:10px; margin-bottom:20px; }
.regulamin-lista li { display:flex; align-items:flex-start; gap:8px; font-size:14px; color:var(--tekst-2); line-height:1.6; }
.regulamin-lista i { color:var(--sukces); margin-top:3px; flex-shrink:0; }
.regulamin-uwaga {
  padding:16px 20px; background:rgba(220,38,38,0.04);
  border-radius:var(--radius-sm); border-left:3px solid var(--glowny);
}
.regulamin-uwaga p { font-size:13px; color:var(--tekst-2); line-height:1.6; }

/* ============================================
   LIVE WYGRANE
   ============================================ */
.live-naglowek { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; margin-bottom:28px; }
.live-wskaznik {
  display:flex; align-items:center; gap:8px;
  padding:8px 16px; background:rgba(220,38,38,0.08); border-radius:20px;
}
.live-kropka {
  width:8px; height:8px; background:var(--glowny);
  border-radius:50%;
  animation: pulsuj 1.5s infinite;
}
@keyframes pulsuj { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.live-napis { font-size:12px; font-weight:700; color:var(--glowny); text-transform:uppercase; }
.live-feed { display:grid; gap:12px; max-height:560px; overflow-y:auto; padding-right:8px; }
.live-feed::-webkit-scrollbar { width:6px; }
.live-feed::-webkit-scrollbar-track { background:var(--tlo-2); border-radius:3px; }
.live-feed::-webkit-scrollbar-thumb { background:var(--glowny); border-radius:3px; }

.wygrana-el {
  display:flex; align-items:center; gap:14px;
  padding:14px; background:var(--tlo-2); border-radius:var(--radius);
  border:1px solid var(--obramowanie);
}
.wygrana-avatar {
  width:44px; height:44px; border-radius:50%;
  background:var(--gradient-glowny); display:flex;
  align-items:center; justify-content:center;
  color:#fff; font-weight:700; font-size:16px; flex-shrink:0;
}
.wygrana-info { flex:1; }
.wygrana-gracz { font-size:14px; font-weight:600; margin-bottom:2px; }
.wygrana-szczegoly { font-size:12px; color:var(--tekst-2); }
.wygrana-kwota { font-size:18px; font-weight:800; color:var(--sukces); flex-shrink:0; }

/* ============================================
   MOBILNE
   ============================================ */
.mobilne-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:24px; margin-bottom:48px; }
.mobilne-karta {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:28px;
  transition:all var(--przeejscie);
}
.mobilne-karta:hover { border-color:var(--glowny); box-shadow:var(--cien-md); }
.mobilne-ikona { font-size:40px; margin-bottom:14px; display:block; }
.mobilne-karta h3 { font-size:20px; font-weight:700; margin-bottom:10px; }
.mobilne-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; margin-bottom:16px; }
.mobilne-lista li { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--tekst-2); margin-bottom:8px; }
.mobilne-lista i { color:var(--sukces); font-size:12px; }

.mobilne-wydajnosc { margin-top:0; }
.wydajnosc-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:20px; }
.wydajnosc-karta {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius); padding:28px; text-align:center;
  transition:all var(--przeejscie);
}
.wydajnosc-karta:hover { border-color:var(--glowny); }
.wydajnosc-wartosc { font-size:32px; font-weight:900; color:var(--glowny); margin-bottom:6px; }
.wydajnosc-nazwa { font-size:13px; color:var(--tekst-2); }

/* ============================================
   RECENZJA
   ============================================ */
.recenzja-blok {
  max-width:900px; margin:0 auto;
  background:var(--tlo); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:40px; box-shadow:var(--cien-sm);
}
.recenzja-tresc { margin-bottom:24px; }
.recenzja-tresc p { font-size:15px; color:var(--tekst-2); line-height:1.8; margin-bottom:14px; }
.recenzja-autor {
  display:flex; align-items:center; gap:14px;
  padding:20px 0; border-top:1px solid var(--obramowanie);
  border-bottom:1px solid var(--obramowanie); margin-bottom:24px;
}
.autor-avatar {
  width:48px; height:48px; border-radius:50%;
  background:var(--gradient-glowny); display:flex;
  align-items:center; justify-content:center;
  color:#fff; font-size:20px;
}
.autor-info strong { display:block; font-size:15px; margin-bottom:2px; }
.autor-info span { font-size:13px; color:var(--tekst-2); }

.recenzja-plusy-minusy { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.plusy h4, .minusy h4 { font-size:16px; font-weight:700; margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.plusy h4 i { color:var(--sukces); }
.minusy h4 i { color:var(--glowny); }
.plusy li, .minusy li {
  display:flex; align-items:center; gap:8px; margin-bottom:8px;
  font-size:14px; color:var(--tekst-2);
}
.plusy li i { color:var(--sukces); }
.minusy li i { color:var(--glowny); }

/* ============================================
   MIASTA
   ============================================ */
.miasta-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.miasto-karta {
  background:var(--tlo-2); border:1px solid var(--obramowanie);
  border-radius:var(--radius-lg); padding:24px;
  transition:all var(--przeejscie);
}
.miasto-karta:hover { border-color:var(--glowny); box-shadow:var(--cien-md); }
.miasto-ikona { font-size:28px; color:var(--glowny); margin-bottom:12px; display:block; }
.miasto-karta h3 { font-size:17px; font-weight:600; margin-bottom:10px; }
.miasto-karta h3 strong { font-weight:800; }
.miasto-karta p { font-size:14px; color:var(--tekst-2); line-height:1.7; }

/* ============================================
   FAQ
   ============================================ */
.faq-lista { max-width:860px; margin:0 auto; }
.faq-element {
  border:1px solid var(--obramowanie); border-radius:var(--radius);
  margin-bottom:12px; overflow:hidden;
  background:var(--tlo);
}
.faq-pytanie {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px; background:transparent; border:none;
  font-size:15px; font-weight:600; color:var(--tekst); text-align:left;
  cursor:pointer; gap:12px;
}
.faq-pytanie span { flex:1; }
.faq-strzalka { font-size:14px; color:var(--tekst-2); transition:transform 0.3s ease; flex-shrink:0; }
.faq-element.active .faq-strzalka { transform:rotate(180deg); }
.faq-odpowiedz {
  max-height:0; overflow:hidden; transition:max-height 0.35s ease, padding 0.35s ease;
  padding:0 22px;
}
.faq-element.active .faq-odpowiedz { max-height:400px; padding:0 22px 20px; }
.faq-odpowiedz p { font-size:14px; color:var(--tekst-2); line-height:1.7; }

/* ============================================
   MODALS
   ============================================ */
.modal-demo {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.92); z-index:10000;
  display:none; align-items:center; justify-content:center; padding:20px;
}
.modal-demo.active { display:flex; }
.modal-zamknij {
  position:absolute; top:20px; right:20px;
  width:40px; height:40px; background:rgba(255,255,255,0.1);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:18px; z-index:10001;
}
.modal-zamknij:hover { background:rgba(255,255,255,0.2); }
.demo-iframe { width:100%; max-width:1200px; height:80vh; border-radius:var(--radius); border:none; }

.modal-bonus {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.75); display:none;
  align-items:center; justify-content:center; z-index:10000; padding:20px;
}
.modal-bonus.active { display:flex; }
.modal-bonus-zawartosc {
  background:var(--tlo); border-radius:var(--radius-lg);
  max-width:540px; width:100%; position:relative; overflow:hidden;
}
.modal-zamknij-bonus {
  position:absolute; top:14px; right:14px;
  width:34px; height:34px; background:var(--tlo-2);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--tekst); z-index:1;
}
.modal-zamknij-bonus:hover { background:var(--glowny); color:#fff; }
.modal-bonus-gora {
  background:var(--gradient-glowny); color:#fff;
  text-align:center; padding:36px 32px 24px;
}
.modal-bonus-ikona { font-size:52px; margin-bottom:12px; display:block; color:#fbbf24; }
.modal-bonus-gora h3 { font-size:24px; font-weight:900; margin-bottom:6px; }
.modal-bonus-gora p { font-size:14px; opacity:0.9; }
.modal-bonus-dol { padding:28px 32px 32px; text-align:center; }
.modal-bonus-kwota { font-size:36px; font-weight:900; color:var(--glowny); margin-bottom:6px; }
.modal-bonus-szczegoly { font-size:14px; color:var(--tekst-2); margin-bottom:20px; }
.modal-bonus-cechy { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.modal-cecha {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; background:var(--tlo-2); border-radius:var(--radius-sm);
  font-size:14px;
}
.modal-cecha i { color:var(--sukces); }
.modal-bonus-info { font-size:12px; color:var(--tekst-3); margin-top:16px; }

/* ============================================
   STOPKA
   ============================================ */
.stopka {
  background:var(--tlo-2); padding:56px 0 20px;
  border-top:1px solid var(--obramowanie);
}
.stopka-grid {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:40px; margin-bottom:36px;
}
.stopka-logo {
  display:flex; align-items:center; gap:10px;
  font-size:20px; font-weight:700; margin-bottom:14px;
}
.stopka-opis { font-size:13px; color:var(--tekst-2); line-height:1.7; margin-bottom:16px; }
.stopka-odznaki { display:flex; flex-wrap:wrap; gap:8px; }
.stopka-odznaki span {
  font-size:11px; padding:4px 10px; background:var(--tlo);
  border-radius:6px; color:var(--tekst-2); display:flex; align-items:center; gap:4px;
}
.stopka-naglowek { font-size:15px; font-weight:700; margin-bottom:14px; }
.stopka-link { display:block; font-size:13px; color:var(--tekst-2); margin-bottom:9px; }
.stopka-link:hover { color:var(--glowny); padding-left:3px; }
.stopka-dolna {
  padding-top:20px; border-top:1px solid var(--obramowanie); text-align:center;
}
.stopka-copyright, .stopka-disclaimer {
  font-size:11px; color:var(--tekst-3); line-height:1.6; margin-bottom:6px;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px) {
  .bohater-siatka { grid-template-columns:1fr; gap:36px; }
  .bohater-gra { order:-1; }
  .spec-layout { grid-template-columns:1fr; }
  .sidebar-sticky { position:static; }
  .nawigacja {
    position:fixed; top:var(--naglowek-h); left:0; right:0;
    background:var(--tlo); flex-direction:column; padding:0; gap:0;
    max-height:0; overflow:hidden; opacity:0; visibility:hidden;
    transition: max-height 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;
    border-bottom:1px solid var(--obramowanie); z-index:1000;
    box-shadow:0 8px 16px rgba(0,0,0,0.08);
  }
  .nawigacja.active { max-height:calc(100vh - var(--naglowek-h)); opacity:1; visibility:visible; padding:20px 24px; overflow-y:auto; }
  .nav-link { width:100%; padding:14px 16px; font-size:15px; border-bottom:1px solid var(--obramowanie); }
  .nav-link:last-child { border-bottom:none; }
  .nav-link::after { display:none; }
  .nav-link:hover { background:var(--tlo-2); }
  .hamburger { display:flex; }
  .btn-bonus-tekst { display:none; }
  .btn-bonus { padding:9px 12px; }
  .stopka-grid { grid-template-columns:1fr 1fr; }
  .recenzja-plusy-minusy { grid-template-columns:1fr; }
}

@media(max-width:768px) {
  :root { --naglowek-h:60px; }
  .kontener { padding:0 16px; }
  .sekcja { padding:60px 0; }
  .bohater { padding:40px 0 60px; }
  .bohater-statystyki { grid-template-columns:1fr; }
  .gra-cechy { flex-direction:column; }
  .kasyna-grid, .oferty-grid, .kroki-grid, .mobilne-grid, .miasta-grid { grid-template-columns:1fr; }
  .glowna-oferta { padding:32px 20px; }
  .oferta-statystyki { grid-template-columns:1fr; }
  .live-naglowek { flex-direction:column; }
  .stopka-grid { grid-template-columns:1fr; }
  .tabela-porownanie { font-size:13px; }
  .tabela-porownanie th, .tabela-porownanie td { padding:10px 12px; }
}

@media(max-width:480px) {
  .sekcja-tytul { font-size:1.5rem; }
  .wydajnosc-grid { grid-template-columns:repeat(2,1fr); }
  .recenzja-blok { padding:24px; }
  .strategia-karta, .wskazowka-karta { padding:18px; }
}