/* /css/global.css */

/* Zmienne globalne i reset */
:root{
  --orange-1:#FFA500;
  --orange-2:#FF8C00;
  --cream:#DEB887;
  --text:#1f2937;
  --muted:#636b74;
  --border:#e9e9e9;
  --shadow:0 8px 24px rgba(0,0,0,.08);

  /* NAWIGACJA — rozmiar tekstu bez zmian */
  --nav-fs: .9rem;
  --nav-pad-y: 5px;
  --nav-pad-x: 7px;
  --nav-gap: 8px;

  /* LOGO — bazowe wartości + aktualnie używane */
  --logo-slot-base: 250px;
  --logo-w-base:    250px;
  --logo-h-base:     81px;

  --logo-slot: var(--logo-slot-base);
  --logo-w:    var(--logo-w-base);
  --logo-h:    var(--logo-h-base);

  --intro-1: .5s;
  --intro-2: .6s;
  --intro-3: .7s;

  --reveal-duration: .5s;
  --reveal-stagger: 60ms;

  --avatar-size-auth: 22px;

  --cream-rgb: 222, 184, 135;

  /* NOWE (dla kafelków) */
  --card-radius: 18px;
  --card-bg: #ffffff;
  --card-line: #f3f4f6;
  --dot:#d1d5db;
  --dot-active:#ff9800;

  /* DODANE: pomocnicza linia (używana w toast) */
  --line: #e9e9e9;
  
  --paw-angle: 0deg;
  --paw-size: 25px;
  --paw-color-unliked:#000000;
  --paw-color-liked:#ff9100;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Inter var", Inter, ui-sans-serif, system-ui, -apple-system,
               "Segoe UI", Roboto, Ubuntu, Cantarell, "Noto Sans",
               "Helvetica Neue", Arial, "Apple Color Emoji",
               "Segoe UI Emoji","Segoe UI Symbol", sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.6;
  font-weight:400;
}
@media (prefers-reduced-motion: reduce){
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* Przyciski globalne */
.btn-primary,
.btn-ghost{
  display:inline-block;
  text-decoration:none;
  cursor:pointer;
  padding:var(--nav-pad-y) var(--nav-pad-x);
  border-radius:10px;
  transition:background-color .2s ease, box-shadow .2s ease, filter .2s ease, color .2s ease;
  position:relative;
  font-size:var(--nav-fs);
  line-height:1.2;
}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg,var(--orange-1),var(--orange-2));
  box-shadow:var(--shadow);
  border:0;
  font-weight:600;
}
.btn-primary:hover{
  filter:brightness(1.03);
  box-shadow:0 10px 26px rgba(255,165,0,.22);
}
.btn-ghost{
  color:var(--orange-2);
  border:2px solid var(--orange-2);
  background:#fff;
  font-weight:600;
}
.btn-ghost:hover{
  opacity:.90;
}

/* Layout główny */
main{
  max-width:1200px;
  margin:18px auto;
  padding:0 16px;
}
.section{
  margin:15px 0;
}
.section > h2{
  margin:0 0 8px;
  font-size:1.4rem;
  font-weight:600;
  color:var(--orange-2);
  padding-bottom:8px;
  border-bottom:3px solid var(--orange-1);
  position:relative;
}
.section > h2::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-3px;
  width:54px;
  height:3px;
  background:linear-gradient(90deg,var(--orange-1),var(--orange-2));
  border-radius:2px;
}

/* Wyszukiwarka i lista ogłoszeń (sekcja "lista") */
#search{
  width:100%;
  max-width:520px;
  background:#fff;
  border:2px solid var(--cream);
  border-radius:12px;
  padding:12px 14px;
  font-size:1rem;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease;
  color:var(--text);
}
#search:focus{
  outline:none;
  border-color:var(--orange-2);
  box-shadow:0 0 0 4px rgba(255,140,0,.12);
}

/* Ulepszony kontener searchForm (global) */
.search-form{
  background:linear-gradient(135deg,#fff7ed,#fffbeb);
  border-radius:16px;
  padding:10px 12px;
  border:1px solid rgba(248,181,92,.4);
  box-shadow:0 10px 24px rgba(0,0,0,.04);
}
.search-form-grid{
  display:grid;
  grid-template-columns:1fr 220px 160px;
  gap:8px;
  align-items:center;
}
@media (max-width: 720px){
  .search-form-grid{
    grid-template-columns:1fr;
  }
}

/* Layout kafelków */
#dogs-list{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:14px;
  margin-bottom:26px;
  align-items:start;
}
@media (max-width: 1200px){
  #dogs-list{ grid-template-columns:repeat(4, minmax(0,1fr)); }
}
@media (max-width: 980px){
  #dogs-list{ grid-template-columns:repeat(3, minmax(0,1fr)); }
}
@media (max-width: 720px){
  #dogs-list{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 460px){
  #dogs-list{ grid-template-columns:repeat(1, minmax(0,1fr)); }
}

/* Karta ogłoszenia */
.pet-card{
  background: var(--card-bg);
  border:1px solid var(--card-line);
  border-radius: var(--card-radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease;
  display:flex;
  flex-direction:column;
  min-width:0;
}
.pet-card:hover{
  transform: translateY(-2px);
  box-shadow:0 14px 36px rgba(0,0,0,.12);
}

/* Media (galeria) */
.pet-media{
  position: relative;
  aspect-ratio: 5 / 8;
  background: #f5f5f5;
  overflow: hidden;
}

/* Główna ramka: obraz + stały pasek informacyjny */
.pet-frame{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
}

/* Obraz – elastyczna wysokość, domyślnie ok. 60% */
.pet-image-wrap{
  flex:1 1 60%;
  position:relative;
}
.pet-image-wrap img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transition: transform .25s ease, opacity .15s ease;
}
.pet-card:hover .pet-image-wrap img{
  transform: scale(1.02);
}

/* Lokalizacja na zdjęciu */
.pet-location{
  position:absolute;
  top:5px;
  left:5px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 5px;
  color:#fff;
  font-weight:500;
  font-size:.8rem;
  background: rgba(var(--cream-rgb), .70);
  border:1px solid rgba(var(--cream-rgb), .85);
  border-radius:12px;
  backdrop-filter: saturate(1.2) blur(1.5px);
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
  z-index:3;
}
.pet-location svg{ opacity:.95; }
.pet-location span{
  white-space:nowrap;
  max-width:140px;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Badge płci */
.pet-sex-badge{
  position:absolute;
  left:10px;
  bottom:10px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.96);
  box-shadow:0 6px 18px rgba(0,0,0,.16);
  font-size:.74rem;
  font-weight:700;
  color:#111827;
  z-index:4;
  transform:translateY(0);
  transition:transform .22s ease;
  white-space:nowrap;
}
.pet-sex-icon{
  font-size:.9rem;
  line-height:1;
}
.pet-sex-label{
  font-size:.74rem;
}
.pet-sex-badge--male{
  border:1px solid rgba(37,99,235,.28);
}
.pet-sex-badge--female{
  border:1px solid rgba(236,72,153,.28);
}
.pet-sex-badge--male .pet-sex-icon{
  color:#2563eb;
}
.pet-sex-badge--female .pet-sex-icon{
  color:#ec4899;
}

/* Nawigacja zdjęć */
.pet-nav{
  position:absolute;
  top:35%;
  transform:translateY(-50%);
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  color:#111;
  font-weight:700;
  display:inline-grid;
  place-items:center;
  box-shadow: var(--shadow);
  cursor:pointer;
  opacity: .9;
  transition: background .18s ease, transform .12s ease, opacity .12s ease;
  z-index:4;
}
.pet-nav:hover{
  background:#fafafa;
}
.pet-nav:active{
  transform: translateY(-50%) scale(.98);
}
.pet-nav.prev{ left:10px; }
.pet-nav.next{ right:10px; }
.pet-nav.disabled{
  opacity:.3;
  cursor:default;
  pointer-events:none;
}

/* Kropki */
.pet-dots{
  position:absolute;
  left:0;
  right:0;
  bottom:10px;
  display:flex;
  gap:6px;
  justify-content:center;
  pointer-events:none;
  z-index:4;
  transform:translateY(0);
  transition:transform .22s ease;
}
.pet-dots i{
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--dot);
  opacity:.9;
}
.pet-dots i.active{
  background:var(--dot-active);
  transform:scale(1.15);
}

/* Pasek informacyjny – kremowy gradient + obramowanie */
.pet-info-bar{
  flex:0 0 auto;
  padding:7px 9px 8px;
  background: linear-gradient(180deg, rgba(255,249,235,.98) 0%, rgba(255,237,213,.98) 100%);
  color:#7b3413;
  display:grid;
  grid-template-rows:auto auto auto;
  align-content:start;
  row-gap:2px;
  border-radius:0 0 var(--card-radius) var(--card-radius);
  border-top:1px solid rgba(248,181,92,.45);
  box-shadow:0 -1px 0 rgba(255,255,255,.7) inset;
  transform:translateY(0);
  transition:transform .22s ease, background-color .18s ease, box-shadow .18s ease;
}
.pet-header-row{
  display:flex;
  align-items:center;
  gap:4px;
}
.pet-header-row .pet-title{
  flex:1 1 auto;
  min-width:0;
}
.pet-header-row .pet-cta{
  flex:0 0 auto;
  margin-top:0;
}
.pet-title.on-media{
  margin:0;
  font-size:.93rem;
  font-weight:800;
  letter-spacing:.2px;
  color:#7c2d12;
  text-shadow:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.pet-meta.on-media{
  margin:0;
  font-size:.78rem;
  color:#b45309;
  opacity:.95;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Właściciel */
.pet-owner{
  margin-top:1px;
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}

/* Wrapper + fallback avatar */
.owner-avatar-wrap{
  position:relative;
  width:24px;
  height:24px;
  flex:0 0 auto;
}
.owner-avatar{
  width:100%;
  height:100%;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.75);
  object-fit:cover;
  background:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,.12);
  display:block;
}
.owner-avatar-fallback{
  position:absolute;
  inset:0;
  border-radius:50%;
  display:flex;               /* <-- ZMIANA: fallback domyślnie WIDOCZNY */
  align-items:center;
  justify-content:center;
  font-size:.75rem;
  font-weight:700;
  color:#fff;
  background:radial-gradient(circle at 30% 30%, #fed7aa, #ea580c);
  border:1px solid #fff;
  text-transform:uppercase;
}

/* Ten selektor może zostać - nie przeszkadza, nawet jeśli JS kiedyś doda klasę */
.owner-avatar-wrap.owner-avatar--fallback-visible .owner-avatar-fallback{
  display:flex;
}

.owner-name{
  font-size:.8rem;
  font-weight:700;
  color:#7b3413;
  text-shadow:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* CTA w pasku */
.pet-cta{ margin-top:2px; }
.btn-outline-light{
  display:inline-block;
  text-decoration:none;
  cursor:pointer;
  padding:3px 6px;
  font-size:.78rem;
  border-radius:999px;
  border:2px solid #f97316;
  color:#7c2d12;
  background:#fff7ed;
  font-weight:700;
  line-height:1.1;
  box-shadow:0 2px 8px rgba(248,181,92,.4);
  transition: background .18s ease, color .18s ease, transform .12s ease, box-shadow .18s ease, border-color .18s ease;
}
.btn-outline-light:hover{
  background:#f97316;
  color:#fff;
  border-color:#ea580c;
  box-shadow:0 4px 12px rgba(248,181,92,.8);
  transform: translateY(-1px);
}

/* Część tekstowa (re-use) */
.pet-body{
  padding:12px 12px 14px;
  display:flex;
  flex-direction:column;
  gap:6px;
  border-top:1px dashed var(--card-line);
}
.pet-title{
  margin:0;
  font-size:1.02rem;
  font-weight:700;
  letter-spacing:.2px;
  color:#0f172a;
}
.pet-meta{
  margin:0;
  font-size:.9rem;
  color:#6b7280;
}
.pet-desc{
  margin:2px 0 4px;
  font-size:.95rem;
  color:#374151;
  line-height:1.55;
}
.pet-actions{
  margin-top:auto;
  display:flex;
  gap:8px;
}
.btn-primary.small{
  padding:8px 10px;
  font-size:.85rem;
  border-radius:10px;
}

/* Plakietki kontekstowe */
.pet-context{
  margin-top:3px;
  min-width:0;
}
.card-pill{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:2px 7px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#f9fafb;
  color:#374151;
  font-size:.72rem;
  font-weight:600;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.card-pill--volunteer-self{
  background:#eff6ff;
  border-color:#dbeafe;
  color:#1d4ed8;
}
.card-pill--org-owner{
  background:#fef3c7;
  border-color:#fed7aa;
  color:#92400e;
}
.card-pill--volunteer-org{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#047857;
}

/* Paginacja */
.pagination{
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
  margin:18px 0 0;
}
.pagination a{
  text-decoration:none;
  padding:9px 12px;
  border-radius:10px;
  color:#fff;
  background:linear-gradient(135deg,var(--orange-1),var(--orange-2));
  font-weight:600;
  transition:box-shadow .18s ease, filter .18s ease;
  box-shadow:0 6px 18px rgba(255,165,0,.2);
}
.pagination a:hover{
  box-shadow:0 8px 22px rgba(255,165,0,.25);
  filter:brightness(1.03);
}

/* Formularze */
form h3{
  margin:0 0 6px;
  font-weight:600;
  color:var(--text);
}
label{
  display:block;
  margin:14px 0 6px;
  font-weight:500;
  color:var(--orange-2);
}
input,
textarea,
select{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:2px solid #d4af37;
  background:#fff;
  font-size:1rem;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease;
  color:var(--text);
}
input:focus,
textarea:focus,
select:focus{
  outline:none;
  border-color:var(--orange-2);
  box-shadow:0 0 0 4px rgba(255,140,0,.12);
}

/* Ładniejsze dropdowny filtrów (global) */
.filter-select{
  border-color:#fed7aa;
  background:#fffdf7;
  padding-right:30px;
  box-shadow:0 4px 10px rgba(0,0,0,.03);
}
.filter-select:focus{
  border-color:var(--orange-2);
  box-shadow:0 0 0 3px rgba(248,181,92,.45);
}

/* Komunikaty */
.error{
  color:#b42318;
  background:rgba(180,35,24,.08);
  border-left:5px solid #b42318;
  padding:12px;
  border-radius:10px;
}
.success{
  color:#1f7a34;
  background:rgba(31,122,52,.08);
  border-left:5px solid #1f7a34;
  padding:12px;
  border-radius:10px;
}

/* Animacje ogólne */
@keyframes fadeUp {
  from {opacity:0; transform:translateY(12px)}
  to {opacity:1; transform:translateY(0)}
}
@keyframes fadeIn {
  from {opacity:0}
  to {opacity:1}
}
@keyframes revealUp {
  from {opacity:0; transform:translateY(10px)}
  to {opacity:1; transform:none}
}
html.anim-load .reveal{
  opacity:0;
  transform:translateY(8px);
  will-change: opacity, transform;
}
html.anim-load .reveal.in{
  animation: revealUp var(--reveal-duration) ease-out both;
  animation-delay: var(--reveal-delay, 0s);
}
html.anim-load main .section{
  animation: fadeUp var(--intro-3) ease-out both;
}

/* Ukrycie wizualne */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

/* duży avatar (np. profile.php) */
.avatar-fallback2.big{
  width:88px;
  height:88px;
  font-size:2rem;
  box-shadow:var(--shadow);
}

/* Toasty */
.toast-wrap{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
  z-index: 9999;
}
.toast{
  min-width: 280px;
  max-width: 90vw;
  background: #fff;
  color: #1f2937;
  border: 1px solid var(--line);
  border-left: 6px solid var(--orange-1);
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 700;
  text-align: center;
  animation: toast-in .2s ease, toast-out .2s ease 2.8s forwards;
}
.toast.success { border-left-color: #10b981; }
.toast.error   { border-left-color: #ef4444; }
@keyframes toast-in {
  from { transform: translateY(10px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
@keyframes toast-out {
  to { transform: translateY(-10px); opacity: 0; }
}

/* Łapka (like) */
.like-paw{
  position:absolute;
  bottom:5px;
  right:5px;
  z-index:5;
  display:inline-grid;
  place-items:center;
  width:30px;
  height:30px;
  padding:1px;
  box-sizing: border-box;
  background-color: rgba(245, 234, 214, 0.8);
  border: 1px solid rgba(245, 234, 214, 1);
  border-radius: 12px;
  cursor:pointer;
  user-select:none;
  transform: rotate(var(--paw-angle));
  transform-origin: 50% 50%;
  color:var(--paw-color-unliked);
  transition:
    transform .12s ease,
    filter .15s ease,
    opacity .15s ease;
  will-change: transform;
}
.like-paw:focus-visible{
  outline: 2px solid #f59e0b55;
  outline-offset: 2px;
  border-radius:12px;
}
.like-paw:hover{
  transform: rotate(var(--paw-angle)) translateY(-1px) scale(1.02);
}
.like-paw:active{
  transform: rotate(var(--paw-angle)) translateY(0) scale(0.98);
}
.like-paw .paw-svg{
  width:var(--paw-size);
  height:var(--paw-size);
  display:block;
  fill:currentColor;
  transition:
    transform .12s ease,
    color .18s ease,
    filter .18s ease,
    opacity .15s ease;
}
.like-paw.liked{
  color:var(--paw-color-liked);
}
.like-paw.liked .paw-svg{
  transform:scale(1.06);
}
@keyframes paw-pop {
  0% { transform: scale(1); }
  55% { transform: scale(1.18); }
  100% { transform: scale(1.06); }
}
.like-paw.bump .paw-svg{
  animation: paw-pop .18s ease;
}
.like-paw .like-count{
  position:absolute;
  right:-4px;
  top:-4px;
  min-width:16px;
  height:16px;
  padding:0 4px;
  border-radius:999px;
  font-weight:700;
  font-size:10px;
  color:#0b0b0b;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #eaeaea;
}
@media (prefers-reduced-motion: reduce){
  .like-paw,
  .like-paw .paw-svg{
    transition: none !important;
    animation: none !important;
  }
}

/* Baner cookies */
.cookie-banner{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  padding:10px 16px 18px;
  z-index:11000;
  font-size:.9rem;
  transform:translateY(100%);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:
    transform .35s ease-out,
    opacity .35s ease-out,
    visibility 0s linear .35s;
}
.cookie-banner.is-visible{
  transform:translateY(0);
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transition:
    transform .35s ease-out,
    opacity .35s ease-out;
}
.cookie-inner{
  max-width:1100px;
  margin:0 auto;
  background:#020617;
  color:#f9fafb;
  border-radius:18px;
  padding:14px 18px;
  display:flex;
  align-items:flex-start;
  gap:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.4);
  border:1px solid rgba(148,163,184,.65);
}
.cookie-icon{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #fed7aa, #f97316);
  box-shadow:0 8px 18px rgba(248,181,92,.5);
  font-size:1.4rem;
}
.cookie-text{
  flex:1 1 auto;
  min-width:0;
}
.cookie-text h3{
  margin:0 0 4px;
  font-size:1rem;
  font-weight:700;
  color:#fefce8;
}
.cookie-text p{
  margin:0 0 4px;
  color:#e5e7eb;
}
.cookie-link-wrap{
  margin-top:4px;
  font-size:.85rem;
  color:#cbd5f5;
}
.cookie-link-wrap a{
  color:#facc15;
  font-weight:600;
  text-decoration:none;
}
.cookie-link-wrap a:hover{
  text-decoration:underline;
}
.cookie-actions{
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-left:8px;
}
.btn-cookie-primary,
.btn-cookie-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 14px;
  border-radius:999px;
  border:0;
  cursor:pointer;
  font-weight:600;
  font-size:.9rem;
  white-space:nowrap;
  transition:
    transform .12s ease,
    box-shadow .18s ease,
    filter .18s ease,
    background-color .18s ease,
    color .18s ease;
}
.btn-cookie-primary{
  background:linear-gradient(135deg,var(--orange-1),var(--orange-2));
  color:#111827;
  box-shadow:0 10px 26px rgba(248,181,92,.5);
}
.btn-cookie-primary:hover{
  filter:brightness(1.03);
  box-shadow:0 14px 34px rgba(248,181,92,.7);
  transform:translateY(-1px);
}
.btn-cookie-primary:active{
  transform:translateY(0);
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.btn-cookie-secondary{
  background:transparent;
  color:#e5e7eb;
  border:1px solid rgba(148,163,184,.9);
}
.btn-cookie-secondary:hover{
  background:rgba(15,23,42,.9);
  transform:translateY(-1px);
}
.btn-cookie-secondary:active{
  transform:translateY(0);
}
@media (max-width: 768px){
  .cookie-inner{
    flex-direction:column;
    align-items:flex-start;
    padding:12px 12px 12px;
  }
  .cookie-actions{
    flex-direction:row-reverse;
    width:100%;
    justify-content:flex-end;
    margin-left:0;
    margin-top:8px;
  }
  .cookie-actions button{
    flex:0 0 auto;
  }
}
@media (max-width: 480px){
  .cookie-banner{
    padding-inline:10px;
  }
  .cookie-inner{
    border-radius:16px;
  }
  .cookie-actions{
    flex-wrap:wrap;
    gap:6px;
  }
  .cookie-actions button{
    flex:1 1 48%;
  }
}

/* Przełącznik tożsamości (konto prywatne / organizacja) */
.messages-identity{
  margin-bottom:10px;
}
.messages-identity-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(135deg,#fff7ed,#fef9c3);
  box-shadow:var(--shadow);
}
.messages-identity-label{
  font-size:.9rem;
  color:var(--muted);
  white-space:nowrap;
}
.messages-identity-list{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.identity-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.04);
  background:#fff;
  text-decoration:none;
  color:var(--text);
  box-shadow:0 4px 10px rgba(0,0,0,.04);
  font-size:.88rem;
  transition:background .12s ease, border-color .12s ease, transform .08s ease, box-shadow .12s ease;
}
.identity-chip:hover{
  background:#fef3c7;
  border-color:#fed7aa;
  transform:translateY(-1px);
}
.identity-chip--active{
  border-color:#f97316;
  background:#fff7ed;
  box-shadow:0 6px 16px rgba(248,163,73,.35);
}
.identity-avatar{
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:.9rem;
  background:linear-gradient(135deg,#f97316,#ea580c);
  color:#fff;
}
.identity-chip-text{
  display:flex;
  flex-direction:column;
  gap:1px;
}
.identity-chip-label-main{
  font-weight:600;
}
.identity-chip-label-sub{
  font-size:.75rem;
  color:var(--muted);
}
.identity-chip--org .identity-avatar{
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
}
@media (max-width: 680px){
  .messages-identity-inner{
    flex-direction:column;
    align-items:flex-start;
  }
}
/* =========================
   FUNDRAISER (Zbiórka) — badge + overlay na pet-card
   ========================= */

/* klik w całą ramkę (szczegóły) */
.pet-frame.js-open-detail{
  cursor: pointer;
}

/* Badge "Zbiórka" — MAŁY, pod lokalizacją */
.pet-fundraiser-pill{
  position: absolute;
  top: 36px;              /* pod .pet-location (top:5px) */
  left: 6px;
  transform: none;
  z-index: 6;

  display: inline-flex;
  align-items: center;
  gap: 6px;

  padding: 4px 8px;
  border-radius: 999px;

  border: 1px solid rgba(255,255,255,.70);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(6px) saturate(1.1);
  box-shadow: 0 8px 18px rgba(0,0,0,.14);

  cursor: pointer;
  user-select: none;
}

.pet-fundraiser-pill:focus-visible{
  outline: 2px solid rgba(34,197,94,.45);
  outline-offset: 2px;
}

.pet-fundraiser-label{
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .2px;
  color: #14532d;
  line-height: 1;
}

.pet-fundraiser-status{
  background: #16a34a;
  color: #fff;

  border-radius: 999px;
  padding: 2px 7px;

  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .45px;
  text-transform: uppercase;
  line-height: 1;

  /* lekkie pulsowanie */
  animation: fr-pulse 1.6s ease-in-out infinite;
  transform-origin: 50% 50%;
}

@keyframes fr-pulse{
  0%   { transform: scale(1);    filter: brightness(1);    opacity: .92; }
  55%  { transform: scale(1.06); filter: brightness(1.06); opacity: 1; }
  100% { transform: scale(1);    filter: brightness(1);    opacity: .92; }
}

/* Overlay (domyślnie ukryty) */
.pet-fundraiser-overlay{
  position: absolute;
  inset: 0;
  z-index: 9;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  opacity: 0;
  pointer-events: none;
  text-decoration: none;
  transition: opacity .18s ease;
}

.pet-fundraiser-overlay::before{
  content:"";
  position: absolute;
  inset: 0;
  background: rgba(2,6,23,.46);
  backdrop-filter: blur(2px);
}

/* Widoczność overlay sterowana klasą na .pet-frame */
.pet-frame.fundraiser-open .pet-fundraiser-overlay{
  opacity: 1;
  pointer-events: auto;
}

.pet-fundraiser-card{
  position: relative;
  width: min(320px, 100%);
  border-radius: 16px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow: 0 18px 46px rgba(0,0,0,.28);
  padding: 12px 12px 11px;
  color: #0f172a;
  transform: translateY(6px);
  transition: transform .18s ease;
}

/* delikatne "wejście" */
.pet-frame.fundraiser-open .pet-fundraiser-card{
  transform: translateY(0);
}

.pet-fundraiser-top{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.pet-fundraiser-title{
  font-weight: 900;
  font-size: .92rem;
  line-height: 1.2;
  color: #0f172a;
  max-width: 220px;
}

.pet-fundraiser-badge{
  flex: 0 0 auto;
  padding: 3px 9px;
  border-radius: 999px;
  background: #16a34a;
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .4px;
  text-transform: uppercase;
}

/* Pasek postępu: szerokość z CSS var(--p) */
.pet-fundraiser-bar{
  height: 10px;
  border-radius: 999px;
  background: rgba(2,6,23,.08);
  overflow: hidden;
  border: 1px solid rgba(2,6,23,.06);
  margin-bottom: 8px;
}
.pet-fundraiser-bar > span{
  display: block;
  height: 100%;
  width: var(--p, 0%);
  background: linear-gradient(90deg, #22c55e, #16a34a);
  border-radius: 999px;
}

.pet-fundraiser-stats{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: .68rem;
  color: rgba(15,23,42,.78);
  margin-bottom: 8px;
}
.pet-fundraiser-stats strong{
  color: #0f172a;
  font-weight: 700;
}

.pet-fundraiser-desc{
  margin: 0 0 10px;
  font-size: .78rem;
  color: rgba(15,23,42,.72);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.pet-fundraiser-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 8px 10px;
  border-radius: 12px;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  color: #fff;
  font-weight: 900;
  font-size: .8rem;
  letter-spacing: .2px;
  box-shadow: 0 10px 22px rgba(34,197,94,.22);
}

@media (prefers-reduced-motion: reduce){
  .pet-fundraiser-status{ animation: none !important; }
  .pet-fundraiser-overlay,
  .pet-fundraiser-card{
    transition: none !important;
  }
}
