/* =========================
   WIR PRACA – LAYOUT (ładny)
   ========================= */

.wir-wrap{
  max-width:980px;
  margin:0 auto;
  padding:0 12px;
}

.wir-wrap,
.wir-wrap *{
  box-sizing:border-box;
}

/* ===== Wyszukiwarka ===== */

.wir-searchbar{
  display:grid;
  grid-template-columns:1.4fr 1fr auto;
  gap:10px;
  background:rgba(0,0,0,.03);
  border:1px solid rgba(0,0,0,.10);
  padding:12px;
  border-radius:14px;
  width:100%;
  max-width:100%;
}

.wir-searchbar input{
  width:100%;
  max-width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
}

.wir-searchbar button{
  padding:12px 16px;
  border-radius:12px;
  border:0;
  background:#fb0606;
  color:#fff;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}

/* ===== Meta (Wyników: X) ===== */

.wir-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin:12px 2px;
  color:#666;
  font-size:14px;
}

/* ===== Lista / karty ===== */

.wir-list{
  display:grid;
  gap:10px;
  width:100%;
  max-width:100%;
}

.wir-card{
  border:1px solid rgba(0,0,0,.12);
  border-radius:16px;
  padding:14px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  width:100%;
  max-width:100%;
  overflow:hidden; /* zabezpiecza przed “uciekaniem” */
}

.wir-title{
  margin:0 0 4px;
  font-size:16px;
  font-weight:800;
  line-height:1.25;
  word-break:break-word;
}

.wir-company{
  margin:0 0 10px;
  color:#666;
  word-break:break-word;
}

.wir-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px 10px;
  align-items:center;
}

.wir-muted{
  color:#666;
  word-break:break-word;
}

.wir-pill{
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  font-size:12px;
}

/* ===== Akcje / przyciski ===== */

.wir-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:140px;
  align-items:flex-end;
}

.wir-btn{
  display:inline-block;
  text-align:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  text-decoration:none;
  color:#111;
  line-height:1;
}

/* Aplikuj (czerwony + biały napis) */
.wir-btn-primary,
a.wir-btn-primary{
  background:#fb0606 !important;
  color:#fff !important;
  border-color:#fb0606 !important;
  font-weight:800;
}

/* Puste / błędy */
.wir-empty,
.wir-error{
  border:1px dashed rgba(0,0,0,.20);
  border-radius:16px;
  padding:18px;
  color:#666;
}

/* =========================
   PAGINACJA – 2 LINIE (Twoje preferencje)
   Linia 1: Poprzednia / Następna
   Linia 2: numery + info
   ========================= */

.wir-pager{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  margin:22px 0 10px;
  text-align:center;
  width:100%;
  max-width:100%;
}

/* Linia 1 */
.wir-pager-nav{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:26px;
  width:100%;
}

/* Przyciski w linii 1 */
.wir-pager-nav button{
  background:none !important;
  border:0 !important;
  padding:6px 10px;
  font-size:16px;
  font-weight:700;
  color:#000;
  cursor:pointer;
}

.wir-pager-nav button:hover{ color:#fb0606; }
.wir-pager-nav button:disabled{ opacity:.4; cursor:not-allowed; }

/* Linia 2: numery + info */
.wir-pager-bottom{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
  width:100%;
}

/* =========================
   PAGINACJA – NUMERY STRON
   Domyślnie: czarne numery, białe tło
   Aktywna: czerwony numer + czerwona ramka
   ========================= */

.wir-pager-pages{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}

/* NUMERY */
.wir-pager-pages button{
  min-width:34px;
  height:34px;
  line-height:34px;
  padding:0 8px;
  text-align:center;

  background:#ffffff;
  color:#000000;

  border:1px solid #e0e0e0;
  border-radius:10px;

  font-size:15px;
  font-weight:700;
  cursor:pointer;

  box-shadow:none;
  text-decoration:none;

  transition:color .15s ease, border-color .15s ease, background .15s ease;
}

.wir-pager-pages button:hover{
  border-color:#fb0606;
  color:#fb0606;
  background:#ffffff;
}

/* AKTYWNA */
.wir-pager-pages button.is-active,
.wir-pager-pages .is-active{
  background:#ffffff !important;
  color:#fb0606 !important;
  border:2px solid #fb0606 !important;
  cursor:default !important;
  pointer-events:none !important;
}

/* TRZY KROPKI ... */
.wir-pager-pages span{
  min-width:30px;
  height:34px;
  line-height:34px;
  text-align:center;
  color:#999999;
  font-weight:700;
}

/* Info: Strona X z Y */
.wir-pager-info{
  font-size:14px;
  color:#666;
  white-space:nowrap;
}

/* =========================
   MOBILE – bez rozlewania + ładny układ
   ========================= */

@media (max-width:720px){
  .wir-searchbar{
    grid-template-columns:1fr;
  }

  .wir-card{
    grid-template-columns:1fr;
  }

  .wir-actions{
    min-width:auto;
    align-items:stretch;
  }

  .wir-actions .wir-btn,
  .wir-actions .wir-btn-primary{
    width:100%;
  }
}

@media (max-width:480px){
  .wir-wrap{
    padding:0 12px;
    overflow-x:hidden;
  }

  /* Na mobile bez “pudełka” wokół (ale równo) */
  .wir-searchbar{
    background:transparent;
    border:0;
    padding:0;
    gap:10px;
  }

  .wir-searchbar input{
    font-size:16px;
  }

  .wir-searchbar button{
    width:100%;
    padding:14px 12px;
    font-size:16px;
    border-radius:12px;
  }

  .wir-pager { flex-direction: column; }
  .wir-pager-nav{ width: 100%; }
    gap:18px;
  }

  .wir-pager-pages button{
    min-width:32px;
    height:32px;
    line-height:32px;
    font-size:14px;
  }

  .wir-pager-pages span{
    height:32px;
    line-height:32px;
  }
}
