:root{
  --bg:#f4f6fb; --panel:#ffffff; --ink:#0f172a; --muted:#5a6783;
  --line:#e3e8f2; --input:#ffffff; --radius:18px;
}
*{box-sizing:border-box}
body{
  margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:
    radial-gradient(900px 500px at 80% -10%, #ede9ff 0%, transparent 60%),
    radial-gradient(700px 500px at -10% 10%, #e6f0ff 0%, transparent 55%),
    var(--bg);
  min-height:100vh;
}
a{color:inherit;text-decoration:none}

/* pasek afiliacji */
.aff-bar{background:linear-gradient(90deg,#4e9a06,#7cb518);padding:10px 16px;text-align:center;font-size:14px}

/* nagłówek */
.top{display:flex;align-items:center;gap:18px;padding:16px 24px;border-bottom:1px solid var(--line);
  position:sticky;top:0;backdrop-filter:blur(10px);background:rgba(255,255,255,.85);z-index:5}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.5px}
.brand-mark{color:#4e9a06;font-size:20px}
.tabs{display:flex;gap:6px;flex:1;flex-wrap:wrap}
.tabs a{padding:8px 14px;border-radius:999px;font-size:14px;font-weight:600;border:1px solid var(--line);
  background:var(--panel);transition:.15s}
.tabs a:hover{transform:translateY(-1px)}
.top-actions{display:flex;gap:8px}
.btn{padding:9px 16px;border-radius:999px;font-weight:700;font-size:14px;cursor:pointer;border:1px solid var(--line)}
.btn.ghost{background:transparent}
.btn.ghost:hover{background:var(--panel)}

/* hero */
.hero{text-align:center;padding:54px 20px 26px}
.hero h1{font-size:clamp(28px,5vw,48px);margin:0 0 10px;line-height:1.1}
.hero-sub{color:var(--muted);margin:0 0 24px}
.personas{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.personas button{padding:10px 18px;border-radius:999px;border:1px solid var(--line);background:var(--panel);
  color:var(--ink);font-weight:700;cursor:pointer;transition:.15s}
.personas button:hover{transform:translateY(-2px)}
.personas button.active{background:linear-gradient(90deg,#4e9a06,#7cb518);border-color:transparent}

/* kafelki światów */
.worlds{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;
  max-width:1100px;margin:14px auto;padding:0 20px}
.world{position:relative;border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  background:linear-gradient(180deg,#ffffff,#f4f6fb);overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.world:hover{transform:translateY(-4px);border-color:var(--accent)}
.world::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--accent)}
.world .tag{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--accent);font-weight:800}
.world h3{margin:8px 0 6px;font-size:22px}
.world p{color:var(--muted);font-size:14px;flex:1;margin:0 0 16px}
.world .row{display:flex;gap:8px;align-items:center}
.world .go{padding:10px 16px;border-radius:12px;font-weight:800;background:var(--accent);color:#08111f}
.world .owntag{font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.world.rank-0{grid-column:span 1;outline:2px solid var(--accent);outline-offset:-1px}

/* pasek korzyści */
.strip{max-width:1100px;margin:40px auto;padding:0 20px}
.strip h2{text-align:center}
.strip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:16px}
.strip-grid>div,.strip-grid>a{border:1px solid var(--line);border-radius:14px;padding:16px;background:var(--panel);display:block;transition:.15s}
.strip-grid>a:hover{transform:translateY(-2px);border-color:#4e9a06}
.strip-grid b{display:block;margin-bottom:6px}
.strip-grid span{color:var(--muted);font-size:14px}

.foot{text-align:center;color:var(--muted);padding:30px;border-top:1px solid var(--line);margin-top:30px;font-size:13px}
.foot a{color:#4e9a06}

/* panel */
.panel-wrap{max-width:760px;margin:40px auto;padding:0 20px}
.kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:20px 0}
.kpi>div{border:1px solid var(--line);border-radius:14px;padding:18px;background:var(--panel)}
.kpi .big{font-size:28px;font-weight:800}
.kpi small{color:var(--muted)}
.linkbox{display:flex;gap:8px;margin-top:10px}
.linkbox input{flex:1;padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--input);color:var(--ink)}

/* ── KALENDARZ WYDARZEŃ ─────────────────────────────────────────── */
.cal-wrap{max-width:1100px;margin:24px auto;padding:0 20px}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.cal-head h2{margin:0;font-size:clamp(20px,3vw,28px)}
.cal-nav{display:flex;align-items:center;gap:8px}
.cal-nav button{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:18px;cursor:pointer}
.cal-nav button:hover{border-color:#4e9a06}
.cal-nav .cal-month{min-width:170px;text-align:center;font-weight:800;text-transform:capitalize}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{font-size:12px;color:var(--muted);text-align:center;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 0}
.cal-cell{min-height:96px;border:1px solid var(--line);border-radius:12px;background:var(--panel);padding:6px;display:flex;flex-direction:column;gap:4px;overflow:hidden}
/* domyślnie pokazujemy max 3 wydarzenia w dniu; „+N więcej" rozwija komórkę */
.cal-cell:not(.expanded) button.cal-ev:nth-of-type(n+4){display:none}
.cal-cell.expanded{overflow:visible;min-height:auto}
.cal-more{font-size:11px;color:#4e9a06;font-weight:700;cursor:pointer}
.cal-cell.out{opacity:.35}
.cal-cell.today{outline:2px solid #4e9a06;outline-offset:-2px}
.cal-cell .dn{font-size:12px;color:var(--muted);font-weight:700}
.cal-ev{font-size:12px;font-weight:700;padding:3px 6px;border-radius:7px;cursor:pointer;
  background:linear-gradient(90deg,#4e9a06,#7cb518);color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:none;text-align:left;width:100%}
.cal-ev.mid{border-radius:0}.cal-ev.start{border-top-right-radius:0;border-bottom-right-radius:0}
.cal-ev.end{border-top-left-radius:0;border-bottom-left-radius:0}
/* info / szukaj ekipy (nie sprzedajemy) — wygląd odróżniony od sprzedawanych */
.cal-ev.crew{background:#eef1f8;color:#475569;border:1px dashed #b9c4da}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin:10px 0 0;font-size:13px;color:var(--muted)}
.cal-legend span{display:inline-flex;align-items:center;gap:6px}
.cal-legend i{width:14px;height:14px;border-radius:4px;display:inline-block}
.cal-legend i.sold{background:linear-gradient(90deg,#4e9a06,#7cb518)}
.cal-legend i.crew{background:transparent;border:1px dashed var(--line)}
/* agenda (mobile) */
.agenda{display:none;flex-direction:column;gap:10px}
.agenda .ag-day{font-weight:800;color:var(--muted);margin-top:8px}
.agenda .ag-ev{display:flex;gap:10px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--panel);cursor:pointer}
.agenda .ag-ev b{display:block}.agenda .ag-ev span{color:var(--muted);font-size:13px}
@media(max-width:640px){.cal-grid{display:none}.agenda{display:flex}}

/* ── KARTA / SZCZEGÓŁY WYDARZENIA ───────────────────────────────── */
.ev-page{max-width:900px;margin:24px auto;padding:0 20px}
.ev-cover{width:100%;aspect-ratio:16/7;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line);background:var(--input)}
.ev-meta{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0;color:var(--muted);font-size:14px}
.ev-meta .pill{border:1px solid var(--line);border-radius:999px;padding:6px 12px;background:var(--panel)}
.ev-links{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}
.ev-links a{padding:10px 16px;border-radius:12px;font-weight:700;border:1px solid var(--line);background:var(--panel)}
.ev-links a:hover{border-color:#4e9a06}
.ev-links a.wa{background:#25d366;color:#062b14;border-color:transparent}

/* ── CZAT ───────────────────────────────────────────────────────── */
.chat{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);margin-top:18px;overflow:hidden}
.chat h3{margin:0;padding:14px 16px;border-bottom:1px solid var(--line);font-size:16px}
.chat-msgs{height:340px;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.msg{max-width:80%}
.msg .who{font-size:12px;color:var(--muted);margin-bottom:2px}
.msg .bub{padding:8px 12px;border-radius:12px;background:var(--input);border:1px solid var(--line);white-space:pre-wrap;word-wrap:break-word}
.msg.mine{align-self:flex-end}.msg.mine .bub{background:linear-gradient(90deg,#4e9a06,#7cb518);border-color:transparent}
.chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.chat-form input{flex:1;padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--input);color:var(--ink)}
.chat-locked{padding:18px 16px;color:var(--muted);text-align:center}

/* ── FORMULARZ / MODAL ──────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:13px;font-weight:700;color:var(--muted)}
.field input,.field textarea{padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--input);color:var(--ink);font:inherit}
.field textarea{min-height:90px;resize:vertical}
.field .hint{font-size:12px;color:var(--muted)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.row2{grid-template-columns:1fr}}
.btn.primary{background:#111827;border-color:#111827;color:#fff}
.btn.primary:hover{background:#000}
.btn{color:var(--ink)}
.btn.ghost{border-color:var(--line);color:var(--ink)}
.modal{position:fixed;inset:0;background:rgba(4,7,16,.7);display:none;align-items:flex-start;justify-content:center;z-index:50;overflow-y:auto;padding:30px 16px}
.modal.open{display:flex}
.modal-card{width:100%;max-width:560px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.modal-card h2{margin:0 0 16px}
.modal-x{float:right;cursor:pointer;color:var(--muted);font-size:22px;line-height:1;border:none;background:none}
.note{padding:10px 12px;border-radius:10px;font-size:14px;margin:10px 0}
.note.ok{background:rgba(37,211,102,.12);border:1px solid #1f7a45;color:#9be8bd}
.note.err{background:rgba(255,80,80,.12);border:1px solid #7a1f1f;color:#ffb3b3}

/* ── rozwijane menu (grupy w nawigacji) ───────────────────────────── */
.navgrp{position:relative;display:inline-block}
.navgrp>.navbtn{padding:8px 13px;border-radius:999px;font-size:13px;font-weight:700;color:var(--muted);
  background:none;border:0;cursor:pointer;font-family:inherit}
.navgrp>.navbtn:hover,.navgrp.open>.navbtn{color:var(--ink);background:var(--panel)}
.navgrp .drop{display:none;position:absolute;top:calc(100% + 4px);left:0;background:var(--panel);
  border:1px solid var(--line);border-radius:12px;padding:6px;min-width:190px;z-index:60;
  box-shadow:0 10px 30px rgba(0,0,0,.14)}
.navgrp:hover .drop,.navgrp.open .drop{display:block}
.navgrp .drop a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap}
.navgrp .drop a:hover{background:var(--input)}
@media(max-width:640px){.navgrp .drop{position:static;box-shadow:none;border:0;padding:0 0 0 12px;min-width:0}}

/* ── globalny pasek festiwalowy (festmenu.js) ─────────────────────── */
.ftbar{display:flex;align-items:center;gap:14px;padding:12px 22px;position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);flex-wrap:wrap}
.ftbar .ftlogo img{height:40px;border-radius:8px;vertical-align:middle;display:block}
.ftbar nav{display:flex;gap:4px;flex:1;flex-wrap:wrap;align-items:center}
.ftbar nav>a{padding:8px 13px;border-radius:999px;font-size:13px;font-weight:700;color:var(--muted);text-decoration:none}
.ftbar nav>a:hover,.ftbar nav>a.active{color:var(--ink);background:var(--panel)}
.ftbar .ftright{display:flex;gap:8px;align-items:center}

/* ═══════════════════════════════════════════════════════════════════
   REDESIGN 2026 — spójny system graficzny (nadpisuje powyższe)
   Font: Plus Jakarta Sans · czyste karty · subtelne cienie · ikony Lucide
   ═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
:root{
  --bg:#f6f7f9; --panel:#ffffff; --ink:#101828; --muted:#667085;
  --line:#eaecf0; --input:#ffffff; --radius:16px;
  --brand:#4e9a06; --brand2:#7cb518;
  --sh-sm:0 1px 2px rgba(16,24,40,.06); --sh:0 4px 16px rgba(16,24,40,.08);
  --sh-lg:0 12px 32px rgba(16,24,40,.12);
}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg); -webkit-font-smoothing:antialiased; letter-spacing:-0.01em;
}
h1,h2,h3{letter-spacing:-0.025em;font-weight:800}
h1{font-weight:800}
/* ikony Lucide — spójny rozmiar, dziedziczą kolor tekstu */
.ti,svg.lucide,[data-lucide]{vertical-align:-0.18em}
svg.lucide{width:1.05em;height:1.05em;stroke-width:2}
.ico{display:inline-flex;align-items:center;gap:7px}
/* przyciski */
.btn{padding:10px 18px;border-radius:12px;font-weight:700;font-size:14px;cursor:pointer;
  border:1px solid var(--line);background:var(--panel);color:var(--ink);transition:.16s;display:inline-flex;align-items:center;gap:7px}
.btn:hover{box-shadow:var(--sh);transform:translateY(-1px)}
.btn.primary{background:#101828;border-color:#101828;color:#fff}
.btn.primary:hover{background:#000}
.btn.ghost{background:var(--panel)}
.btn.brand{background:linear-gradient(180deg,var(--brand2),var(--brand));border-color:transparent;color:#fff}
/* karty (świat / sekcje) */
.world,.kpi>div,.strip-grid>div,.strip-grid>a{box-shadow:var(--sh-sm);transition:.18s}
.world{background:var(--panel)}
.world:hover{box-shadow:var(--sh-lg);transform:translateY(-4px)}
.strip-grid>a:hover{box-shadow:var(--sh)}
/* nagłówek / paski */
.top,.ftbar{box-shadow:var(--sh-sm);border-bottom:1px solid var(--line)}
.ftbar{padding:14px 26px;gap:16px}
.ftbar nav>a{font-weight:600;color:var(--muted);transition:.14s}
.ftbar nav>a:hover,.ftbar nav>a.active{color:var(--ink);background:#f2f4f7}
.navgrp>.navbtn{font-weight:600}
.navgrp .drop{border-radius:14px;box-shadow:var(--sh-lg);padding:8px;border-color:var(--line)}
.navgrp .drop a{display:flex;align-items:center;gap:9px;border-radius:9px;font-weight:600}
/* inputy */
input,textarea,select{font-family:inherit}
.field input,.field textarea,.linkbox input{border-radius:12px;transition:.14s;border-color:var(--line)}
.field input:focus,.field textarea:focus,.linkbox input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(78,154,6,.12)}
/* drobne */
.tabs a{box-shadow:var(--sh-sm);font-weight:600}
.tabs a:hover{box-shadow:var(--sh)}

/* nagłówki sekcji z ikoną — wyśrodkowane i spójne (fix .ico inline-flex) */
h2.ico,h3.ico{display:flex;justify-content:center;align-items:center;gap:10px}
.sec h2.ico{text-align:center}

/* logo marki na kaflu portalu */
.world .wlogo{height:64px;width:auto;border-radius:10px;margin-bottom:10px;display:block}

/* ═══════════════════════════════════════════════════════════════════
   STRONA GŁÓWNA 2026 — porządek menu + kwadratowe loga + równa siatka.
   WSZYSTKO zawężone do .home (body strony głównej), żeby NIE ruszać
   pozostałych stron portalu, które współdzielą .top / .world / .top-actions.
   ═══════════════════════════════════════════════════════════════════ */

/* — nagłówek: jedno, pogrupowane menu (rozwijanki .navgrp) — */
.home .mainnav{display:flex;align-items:center;gap:2px;flex:1;flex-wrap:wrap}
.home .mainnav .navgrp>.navbtn{display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:12px;font-size:14px;font-weight:600;
  color:var(--ink);background:none;border:1px solid transparent;cursor:pointer;font-family:inherit}
.home .mainnav .navgrp>.navbtn:hover,.home .mainnav .navgrp.open>.navbtn{background:var(--panel);border-color:var(--line)}
.home .mainnav .navgrp .chev{width:.8em;height:.8em;opacity:.55}
/* mini-logo marki w rozwijanej liście „Światy" — też kwadrat */
.home .navgrp .drop .wmini{width:24px;height:24px;object-fit:cover;border-radius:7px;
  border:1px solid var(--line);flex:0 0 auto}

/* — prawa strona nagłówka: spójne selecty waluty/języka — */
.home .top-actions{display:flex;align-items:center;gap:8px}
.home .top-actions select{padding:9px 12px;border-radius:12px;background:var(--panel);
  color:var(--ink);border:1px solid var(--line);font:inherit;font-weight:600;cursor:pointer}

/* — KAFELKI ŚWIATÓW: równa siatka, bez osieroconego prostokąta przy 5 — */
.home .worlds{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;
  gap:18px;max-width:1180px;margin:18px auto;padding:0 20px}
.home .world{flex:1 1 190px;max-width:340px}

/* — LOGO MARKI: zawsze kwadrat (jednolite miniaturki) — */
.home .world .wlogo{width:76px;height:76px;object-fit:cover;border-radius:16px;
  border:1px solid var(--line);margin-bottom:14px;display:block}

/* — nagłówek responsywny: na wąskim ekranie menu schodzi do osobnego rzędu — */
@media(max-width:860px){
  .home .top{flex-wrap:wrap;gap:10px 12px;padding:12px 16px}
  .home .brand{order:1}
  .home .top-actions{order:2;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
  .home .mainnav{order:3;flex-basis:100%;justify-content:flex-start;gap:4px}
}
/* bardzo wąsko: waluta/język/konto dostają własny rząd (nic się nie przycina) */
@media(max-width:460px){
  .home .top-actions{flex-basis:100%;margin-left:0;justify-content:flex-start}
}
@media(max-width:560px){
  .home .world{flex:1 1 100%;max-width:none}
  .home .top-actions .btn{padding:9px 12px}
}
