/* ==========
   Prosty DARK MODE (bez gradientów/blurów/cieni)
   Montserrat 700 Italic globalnie
   ========== */

:root{
  --bg:#0b0b10;        /* główne tło */
  --bg-soft:#13131a;   /* delikatny panel */
  --ink:#f2f2f5;       /* główny tekst */
  --muted:#a2a2b0;     /* tekst pomocniczy */
  --line:#242432;      /* linie/obramowania */
  --accent:#7d7dff;    /* kolor akcentu */
  --card:#101017;      /* tło kart/sekcji */
}

/* RESET */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
img{max-width:100%;display:block}

/* BAZA */
body{
  font-family:'Montserrat', sans-serif;
  font-weight:700;
  font-style:italic;
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
a:focus{outline:2px solid var(--accent);outline-offset:2px}

/* NAV */
.nav{
  position:sticky;top:0;z-index:10;
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 22px;
  background:var(--bg-soft);
  border-bottom:1px solid var(--line);
}

/* klikalne logo + nazwa */
.nav__left{display:flex;align-items:center}
.nav__brand-link{
  display:flex;align-items:center;gap:8px;
  text-decoration:none;white-space:nowrap;
}
.logo{height:36px;width:auto;border-radius:6px;flex:0 0 auto}
.brand{margin:0;line-height:1}

.nav__right{display:flex;align-items:center;gap:16px}
.nav__link{font-weight:600;color:var(--ink)}
.nav__link:hover{color:var(--accent)}
.btn.btn--ghost{border:1px solid var(--line);padding:8px 14px;border-radius:999px;background:transparent;color:var(--ink)}

/* HERO */
.hero{
  text-align:center;padding:80px 20px 56px;
  background:var(--bg);border-bottom:1px solid var(--line);
}
.hero__logo{width:160px;height:auto;margin:0 auto 18px;border-radius:8px}
.hero h1{font-size:clamp(32px,5vw,56px);margin-bottom:10px;color:var(--ink)}
.hero p{font-size:18px;color:var(--muted);margin-bottom:24px}

/* SEKCJE */
.section{
  max-width:1100px;margin:22px auto;background:var(--card);
  border:1px solid var(--line);border-radius:16px;padding:22px;
}
.section__head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:10px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:16px;
}

.section__head h2 {
  text-align: center;
  width: 100%;
}
.section h2{font-size:24px;color:var(--ink)}

/* GRID */
.grid{display:grid;gap:16px}
.grid--cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.grid--mini{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* KARTY */
.card{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:12px;padding:16px;text-align:center;color:var(--ink);
}
.card h3{margin:10px 0 4px;font-size:18px}
.pill{
  display:inline-block;margin-top:8px;padding:6px 10px;
  background:#15151d;border:1px solid var(--line);
  border-radius:999px;font-size:13px;color:var(--muted);
}

/* AVATAR (inicjały) */
.avatar{
  width:96px;height:96px;border-radius:50%;
  margin:0 auto 10px;display:grid;place-items:center;
  color:#0b0b10;background:#9aa0ff;font-weight:900;letter-spacing:.5px;
}
.avatar::after{content:attr(data-initials)}
.avatar--sm{width:52px;height:52px;font-size:14px}

/* LISTA MINI */
.mini{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:#15151d;border:1px solid var(--line);
  border-radius:10px;color:var(--ink);
}

/* SPONSORZY */
.sponsors{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.sponsor{
  background:#15151d;border:1px solid var(--line);
  border-radius:10px;padding:18px;text-align:center;font-weight:900;color:var(--ink);
}

/* CTA */
.cta{
  max-width:900px;margin:28px auto;text-align:center;color:var(--ink);
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:16px;padding:28px 20px;
}
.cta h2{margin-bottom:6px}
.cta p{margin:0 0 16px;color:var(--muted)}

/* PRZYCISKI */
.btn{
  display:inline-block;border-radius:999px;padding:10px 18px;
  font-weight:900;border:1px solid var(--line);background:#1a1a24;color:var(--ink);
}
.btn--primary{background:var(--accent);border-color:var(--accent);color:#0b0b10}
.btn--lg{padding:12px 22px;font-size:18px}
.btn--xl{padding:14px 26px;font-size:20px}
.btn:hover{opacity:.9}

/* UTIL */
.muted{color:var(--muted)}
.footer{
  text-align:center;padding:24px 0;color:var(--muted);
  border-top:1px solid var(--line);margin-top:24px;
}

/* DOSTĘPNOŚĆ */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* --- HAMBURGER --- */
.nav__toggle{
  display:none;background:transparent;border:none;cursor:pointer;color:var(--ink);padding:8px;
}
.nav__toggle .nav__bar{
  display:block;width:22px;height:2px;background:var(--ink);margin:4px 0;transition:.3s;
}
.nav__toggle.is-open .nav__bar:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav__toggle.is-open .nav__bar:nth-child(2){opacity:0}
.nav__toggle.is-open .nav__bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* --- MOBILE MENU --- */
@media (max-width:768px){
  .nav{background:var(--bg);padding:14px 18px}
  .nav__toggle{display:block}
  .nav__right{
    position:absolute;top:56px;left:0;right:0;background:var(--bg-soft);
    border-bottom:1px solid var(--line);display:none;flex-direction:column;
    padding:10px 0;animation:menuSlide .25s ease;
  }
  .nav__right.is-open{display:flex}
  .nav__link,.btn.btn--ghost{
    width:100%;text-align:center;font-weight:800;padding:14px;color:var(--ink);
    border:none;border-radius:0;background:transparent;transition:.2s;
  }
  .nav__link:hover,.btn.btn--ghost:hover{background:rgba(255,255,255,.05);color:var(--accent)}
  .nav__left .brand{font-size:18px}
}
@keyframes menuSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* RESPONSYWNOŚĆ drobna */
@media (max-width:480px){
  .btn--xl{font-size:18px;padding:12px 22px}
  .hero__logo{width:140px}
}


/* --- klikane karty --- */
.card--link {
  display: block;
  color: inherit;
  text-decoration: none;
  transition: transform 0.2s ease, background 0.2s ease;
}

.card--link:hover {
  background: #1a1a24;
  transform: translateY(-3px);
  border-color: var(--accent);
  color: var(--ink);
  cursor: pointer;
}

/* klikane "mini" karty w Najnowszych */
.mini--link {
  display:flex;                 /* zachowujemy układ jak w .mini */
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}

.mini--link:hover {
  background:#1a1a24;
  border-color:var(--accent);
  transform:translateY(-2px);
  cursor:pointer;
}

/* ===== REJESTRACJA ===== */
.form-register {
  display: grid;
  gap: 18px;
  padding: 20px;
  max-width: 480px;
  margin: 0 auto;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}

.form-register label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 700;
  color: var(--ink);
}

.form-register .note {
  font-size: 13px;
  color: var(--muted);
  font-weight: 400;
}

.form-register input {
  background: #15151d;
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  font: inherit;
  font-size: 16px;
  transition: border .2s, background .2s;
  text-transform: none;
}

.form-register input:focus {
  border-color: var(--accent);
  background: #1b1b25;
  outline: none;
}

.form-register button {
  width: 100%;
  padding: 14px 18px;
  border: none;
  border-radius: 999px;
  background: var(--accent);
  color: #0b0b10;
  font-size: 18px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.2s;
}

.form-register button:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.form-register h2 {
  text-align: center;
  margin-bottom: 10px;
  font-size: 28px;
}

.form-register .errors {
  color: #ff6688;
  background: rgba(255,102,136,0.08);
  border: 1px solid rgba(255,102,136,0.25);
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 14px;
  line-height: 1.4;
}

/* === GALERIA PROFILU — pionowo i wyśrodkowana === */
.profile-gallery {
  display: flex;
  flex-direction: column; /* jeden pod drugim */
  align-items: center;    /* wyśrodkuj w poziomie */
  gap: 20px;              /* odstępy między zdjęciami */
}

.profile-gallery .profile-photo-wrapper {
  width: 100%;
  max-width: 420px; /* ogranicz szerokość, żeby nie rozciągało */
  text-align: center;
}

.profile-gallery img.profile-photo {
  width: 100%;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
  display: block;
  margin: 0 auto;
}

/* === Mini-galeria w edycji profilu — wyśrodkowana === */
.account-photos{
  display:flex;
  flex-wrap:wrap;         /* zawijaj wiersze */
  justify-content:center; /* wyśrodkuj w poziomie */
  gap:14px;               /* odstępy między kafelkami */
  margin-top:16px;
}

.account-photo-card{
  width:170px;            /* stała szerokość kafelka (zmień wg uznania) */
  padding:10px;
  text-align:center;
}

.account-photo-img{
  width:100%;
  height:170px;           /* kwadratowe kafelki */
  object-fit:cover;       /* wypełnij bez zniekształceń */
  border-radius:8px;
  display:block;
}

/* na wąskich ekranach — trochę większe odstępy/miękko */
@media (max-width:480px){
  .account-photo-card{ width:160px; }
  .account-photo-img{ height:160px; }
}
/* Kursory dla przycisków/linków akcji */
.btn,
button,
input[type="submit"],
input[type="button"]{
  cursor: pointer;
}

/* Gdy przycisk wyłączony */
.btn:disabled,
button:disabled,
input[type="submit"]:disabled,
input[type="button"]:disabled{
  cursor: not-allowed;
  opacity: .6;
}

/* ===== RANKING ===== */

/* --- linia z pozycją, nazwą i punktami --- */
.rank-line {
  font-size: 1.5rem;         /* ~24px */
  font-weight: 700;          /* pogrubienie jak nagłówki */
  text-align: center;        /* wyśrodkowanie */
  margin-bottom: 10px;
  color: var(--ink);         /* zachowaj kolor tekstu strony */
}

.rank-line .rank-pos {
  color: var(--accent);
}

.rank-line .rank-dash {
  margin: 0 6px;
}

.rank-line .rank-points {
  color: var(--accent);
}


/* lista kart jednego pod drugim */
.rank-list { display: grid; gap: 16px; }

/* linia: "1. nazwa — 123 punkty" już masz w HTML,
   tu nic nie trzeba */

/* obrazek w karcie rankingu */
.rank-item .rank-media img{
  display:block;
  margin:12px auto 0;
  max-height:550px;      /* maksymalna wysokość na desktopie */
  width:auto;            /* szerokość skaluje się proporcjonalnie */
  height:auto;           /* zachowaj proporcje */
  max-width:100%;        /* ale nie wyjdzie poza kartę */
  object-fit:contain;    /* nie przytnie zdjęcia */
  border-radius:12px;
}

/* mniejsze limit na mobile, żeby nie było za wysokie */
@media (max-width: 768px){
  .rank-item .rank-media img{ max-height:360px; }
}

/* --- Paginacja wyśrodkowana i w jednej linii --- */
.pager-center{
  display:flex;
  justify-content:center;
  margin:18px 0 8px;
}

.pager-center ul{
  display:flex;
  gap:10px;
  list-style:none; /* usuń kropki */
  padding:0;
  margin:0;
}

.pager-center li{ display:block; }

.pager-center a.btn{
  display:inline-block;
  padding:10px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#1a1a24;
  color:var(--ink);
  text-decoration:none;
  font-weight:800;
  cursor:pointer;          /* łapka na linkach */
}

.pager-center a.btn.is-current{
  background:var(--accent);
  border-color:var(--accent);
  color:#0b0b10;
}

.pager-center a.btn.is-disabled{
  pointer-events:none;
  opacity:.5;
}

.flash{
  max-width: 900px;
  margin: 14px auto;
  padding: 12px 14px;
  border-radius: 10px;
  font-weight: 700;
  border:1px solid transparent;
}
.flash--ok{
  background: rgba(60,180,120,.12);
  border-color: rgba(60,180,120,.35);
  color:#eafff3;
}
.flash--err{
  background: rgba(255,102,136,.10);
  border-color: rgba(255,102,136,.35);
  color:#ffd6e0;
}

.alert-waiting {
  background: #ffefef;
  color: #a00;
  border: 1px solid #e55;
  padding: 12px 16px;
  border-radius: 8px;
  font-weight: 700;
  text-align: center;
  margin: 18px;
  font-size: 15px;
  box-shadow: 0 1px 4px rgba(255, 0, 0, 0.1);
}
