:root{
  --brand:#FF8C00;
  --ink:#0f172a; /* slate-900 */
  --ink-2:#334155; /* slate-700 */
  --muted:#64748b; /* slate-500 */
  --line:#e5e7eb; /* gray-200 */
  --bg:#f8fafc; /* slate-50 */
  --card:#ffffff;
  --chip-bg:#f1f5f9; /* slate-100 */
  --chip-ink:#0f172a;
  --radius:16px;
  --shadow:0 12px 32px rgba(2, 6, 23, .10);
  /* Łapka / dekoracje tła (może być nadpisane z PHP przez --paw-color) */
  --paw-color:#8a4c00;
  /* Akcje */
  --success:#16a34a; /* green-600 */
  --success-border:#15803d;/* green-700 */
  --neutral:#ffffff;
  --neutral-border:#e5e7eb;
  /* Opis */
  --desc-bg:#eef2f7; /* lekko ciemniejszy od card */
}

html,
body{
  margin:0;
  padding:0;
  background:var(--bg);
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
}

.view-wrap{
  padding:24px 16px 40px;
}

/* GRID LAYOUT */
.view-grid{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:20px;
}
@media (max-width:980px){
  .view-grid{ grid-template-columns:1fr; }
}

/* CARD */
.card{
  position:relative; /* pod SVG */
  z-index:0; /* stacking context dla dekoracji */
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
  overflow:hidden; /* SVG nie wychodzi poza kartę */
}

.head-card{
  position:relative;
  padding:22px 20px;
}

.title-line{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.title{
  margin:0;
  font-size:24px;
  line-height:1.2;
}

/* ===== Pasek akcji nad galerią ===== */
.action-bar{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 8px; /* kompaktowy */
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  margin-bottom:10px;
  overflow:auto hidden;
  white-space:nowrap;
}

/* ===== Kompaktowe przyciski ===== */
.btn-primary,
.btn-secondary,
.btn-warning,
.btn-success,
.btn-neutral,
.btn-plain{
  appearance:none;
  text-decoration:none;
  border-radius:10px;
  font-weight:700;
  transition:filter .2s ease, transform .02s, background .2s;
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid transparent;
  cursor:pointer;
}

.btn-compact{
  padding:6px 10px;
  font-size:13.5px;
}

.btn-primary{
  background:var(--brand);
  color:#fff;
  border-color:#ff9a1f;
}
.btn-primary:hover{ filter:brightness(1.03); }
.btn-primary:active{ transform:translateY(1px); }

.btn-secondary{
  background:#fff;
  color:var(--ink);
  border-color:var(--line);
}
.btn-secondary:hover{ filter:brightness(0.98); }

.btn-warning{
  color:#111;
  background:linear-gradient(135deg,#ffd54f,#ffb300);
  border:0;
  cursor:pointer;
  box-shadow:var(--shadow);
}

.btn-success{
  background:var(--success);
  color:#fff;
  border-color:var(--success-border);
}
.btn-success:hover{ filter:brightness(1.05); }

.btn-neutral{
  background:var(--neutral);
  color:var(--ink);
  border-color:var(--neutral-border);
}
.btn-neutral:hover{ filter:brightness(0.98); }

.btn-plain{
  background:#fff;
  color:var(--ink);
  border-color:var(--line);
}

.actions{
  margin-top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ===== GALERIA ===== */
.gallery-col{
  position:sticky;
  top:18px;
  height:fit-content;
}
.gallery-col > .card + .card{
  margin-top: 14px; /* możesz zmienić np. na 12px / 16px */
}
.gallery .carousel{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:#0b0b0b;
  width:100%;
  height:auto;
  aspect-ratio:4 / 3;
  display:block;
}

/* Obraz zawsze w środku */
.gallery .carousel > img.main-photo{
  position:absolute;
  inset:0;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#0b0b0b;
  display:block;
}

/* ===== Miniatury ===== */
.thumbs{
  margin-top:10px;
  display:flex;
  gap:8px;
  overflow:auto hidden;
  padding-bottom:2px;
}

.thumbs .thumb{
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
  padding:0;
  cursor:pointer;
  overflow:hidden;
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  transition:border-color .2s ease, transform .02s;
}

.thumbs .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.thumbs .thumb.active{ border-color:var(--brand); }
.thumbs .thumb:active{ transform:translateY(1px); }

/* ===== Lightbox ===== */
.lightbox[hidden]{ display:none !important; }
.lightbox{
  position:fixed;
  inset:0;
  z-index:1000;
}
.lb-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.7);
  backdrop-filter:saturate(120%) blur(2px);
}
.lb-inner{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  padding:24px;
}
.lb-photo{
  width:auto !important;
  height:auto !important;
  max-width:96vw !important;
  max-height:90vh !important;
  object-fit:contain !important;
  object-position:center center !important;
  border-radius:14px;
  box-shadow:0 30px 70px rgba(0,0,0,.45);
  background:#000;
}
.lb-close{
  position:absolute;
  top:18px;
  right:18px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:none;
  background:rgba(255,255,255,.92);
  font-size:18px;
  font-weight:800;
  color:#111;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
}

/* ===== Siatka metadanych ===== */
.meta-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}
@media (max-width:900px){
  .meta-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width:600px){
  .meta-grid{ grid-template-columns: 1fr; }
}

.meta-item{
  position:relative; /* też kotwica dla SVG */
  z-index:0; /* stacking context pod dekoracje */
  background:linear-gradient(180deg, var(--chip-bg), #eef2f6);
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 12px;
  min-height:56px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  overflow:hidden; /* łapki nie wychodzą poza kafelek */
}

.meta-label{
  font-size:11.5px;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--muted);
  line-height:1;
}

.meta-value{
  font-size:15.5px;
  font-weight:800;
  color:var(--ink);
  line-height:1.35;
  word-break:break-word;
}

/* ===== Sekcje danych ===== */
.section-title{
  margin:0 0 10px;
  font-size:18px;
  font-weight:800;
  color:#1f2937;
}

.kv{
  margin:0;
  display:grid;
  gap:8px;
}

.kv-row{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:14px;
  align-items:start;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
}

.kv-row:last-child{ border-bottom:none; }

.kv dt{
  margin:0;
  font-weight:700;
  color:var(--ink);
  font-size:14.5px;
}

.kv dd{
  margin:0;
  color:var(--ink-2);
  font-size:14.5px;
  min-height:22px;
}

.kv-row-empty dt,
.kv-row-empty dd{
  opacity:.6;
}

@media (max-width:700px){
  .kv-row{
    grid-template-columns:1fr;
    gap:6px;
  }
}

/* ===== Opis ===== */
.desc-box{
  width:100%;
  background:var(--desc-bg);
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 16px;
}
.desc-content{
  color:var(--ink-2);
  line-height:1.75;
  font-size:15.5px;
  white-space:pre-wrap; /* zachowuje nowe linie z bazy */
}

/* ===== Chip płci ===== */
.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:#fff;
  color:var(--ink);
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  font-size:13.5px;
}

/* ===== Kolumna szczegółów ===== */
.details-col{
  display:grid;
  gap:14px;
}

/* ===== Przycisk łapki (like) ===== */
.like-paw{
  position:absolute;
  top:16px;
  right:18px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.7);
  background:#fff;
  cursor:pointer;
  font-size:13px;
  line-height:1;
  color:var(--muted);
  box-shadow:0 8px 18px rgba(15,23,42,.12);
  transition:
    background-color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .04s ease,
    color .18s ease;
}

.like-paw:hover{
  box-shadow:0 12px 26px rgba(15,23,42,.18);
  transform:translateY(-1px);
}

.like-paw:active{
  transform:translateY(0);
  box-shadow:0 6px 14px rgba(15,23,42,.24);
}

.like-paw .paw-svg{
  width:18px;
  height:18px;
  display:block;
}

.like-count{
  font-weight:700;
  min-width:1.5em;
  text-align:right;
}

/* stan polubiony */
.like-paw.liked{
  background:rgba(248,250,252,1);
  border-color:rgba(251,146,60,1);
  color:#b45309;
  box-shadow:0 10px 30px rgba(248,113,113,.25);
}
.like-paw.liked .paw-svg{
  color:var(--paw-color,#8a4c00);
}

/* ===== Ramka edycji ===== */
.edit-frame.editing{
  border: 2px solid transparent;
  border-image: repeating-linear-gradient(45deg, #e11d48 0 10px, #ffffff 10px 20px) 1;
  border-image-slice: 1;
  border-image-repeat: round;
  margin: -2px;
  padding: calc(1px + 1px);
}

/* ===== Pływające akcje ===== */
.floating-actions[hidden]{ display:none !important; }

.floating-actions{
  position:fixed;
  z-index:1100;
  right:16px;
  top:90px;
  display:flex;
  gap:8px;
  background:rgba(255,255,255,.95);
  border:1px solid var(--line);
  padding:8px 10px;
  border-radius:12px;
  box-shadow:0 12px 30px rgba(15,23,42,.18);
  backdrop-filter:saturate(120%) blur(2px);
}

/* ===== KOMPAKTOWE EDYTORY ===== */
.edit-inline-wrap{
  display:inline-flex;
  align-items:center;
  max-width:100%;
}

.edit-input,
.edit-select{
  font-size:14px;
  line-height:1.2;
  padding:6px 8px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  width:auto;
  max-width:clamp(140px, 40vw, 260px);
  box-shadow:0 1px 1px rgba(0,0,0,.02) inset;
}

.edit-select{
  padding-right:28px;
}

.edit-textarea{
  font-size:14px;
  line-height:1.5;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  width:100%;
  min-height:96px;
  max-height:180px;
  resize:vertical;
  box-shadow:0 1px 1px rgba(0,0,0,.02) inset;
}

/* Drobna korekta w siatce metadanych, żeby inputy nie „skakały” */
.meta-item .edit-inline-wrap{ width:100%; }

.meta-item .edit-input,
.meta-item .edit-select{
  width:100%;
  max-width:100%;
}

/* Edytory w sekcjach Zdrowie/Zachowanie/Adopcja */
.kv dd .edit-inline-wrap{
  width:100%;
}

.kv dd .edit-input,
.kv dd .edit-select{
  width:100%;
  max-width:100%;
}

/* ===== Podpowiedzi miejscowości (pole "Miejsce") ===== */
.edit-inline-wrap-location{
  display:block;
  width:100%;
}

.edit-input-location{
  width:100%;
  max-width:100%;
}

.location-suggest[hidden]{
  display:none !important;
}

.location-suggest{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:0 18px 40px rgba(15,23,42,.16);
  z-index:2000;
}

.location-suggest-portal{
  position:fixed;
  left:0;
  top:0;
}

.location-suggest-list{
  list-style:none;
  margin:4px 0;
  padding:2px 0;
  max-height:180px;
  overflow-y:auto;
}

.location-suggest-item{
  padding:6px 10px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap:2px;
  font-size:13px;
  color:var(--ink-2);
}

.location-suggest-item:hover,
.location-suggest-item.is-highlighted{
  background:rgba(248,250,252,1);
}

.location-suggest-label{
  font-weight:600;
  color:var(--ink);
}

.location-suggest-secondary{
  font-size:12px;
  color:var(--muted);
}

/* ===== Karta publikującego (org / prywatny / wolontariusz) ===== */
.publisher-card{
  padding:16px 18px;
  display:flex;
  align-items:center;

  /* delikatne "upiększenie" tylko dla tej karty */
  background:
    radial-gradient(140px 90px at 12% 18%, rgba(255,140,0,.10), transparent 60%),
    linear-gradient(180deg, #ffffff, #fffaf3);
  border-color:rgba(148,163,184,.35);
}

.publisher-inner{
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
}

/* linki w publisherze - bez domyślnego niebieskiego/fioletowego */
.publisher-card a{
  text-decoration:none;
}

/* focus widoczny i spójny */
.publisher-card a:focus-visible{
  outline:2px solid rgba(255,140,0,.55);
  outline-offset:3px;
  border-radius:10px;
}

.publisher-avatars{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
}

.avatar-circle{
  width:44px;
  height:44px;
  border-radius:999px;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--chip-bg);
  color:#fff;
  font-weight:800;
  font-size:18px;
  flex-shrink:0;
}

/* wymuszamy kolor także dla visited (żeby inicjał nie robił się fioletowy) */
.publisher-card a.avatar-circle:link,
.publisher-card a.avatar-circle:visited{
  color:#fff;
}

.avatar-circle img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.avatar-main{
  box-shadow:0 4px 12px rgba(15,23,42,.18);
}

.avatar-secondary{
  width:30px;
  height:30px;
  border-radius:999px;
  position:relative;
  margin-left:-14px;
  border:2px solid #fff;
  box-shadow:0 4px 12px rgba(15,23,42,.18);
  background:var(--chip-bg);
}

.avatar-fallback{
  background:var(--brand);
}

.publisher-text{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}

.publisher-label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
}

.publisher-name{
  font-size:15px;
  font-weight:900;
  color:var(--ink);
  overflow-wrap:anywhere;
}

.publisher-sub{
  display:flex;
  gap:6px;
  align-items:center;
  font-size:13px;
  color:var(--ink-2);
  margin-top:2px;
  min-width:0;
}

.publisher-tag{
  padding:2px 7px;
  border-radius:999px;
  background:rgba(255,140,0,.12);
  color:#b45309;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  border:1px solid rgba(255,140,0,.25);
  flex:0 0 auto;
}

/* ===== KLUCZOWA POPRAWKA: linki NIE zmieniają koloru po odwiedzeniu ===== */
.publisher-name-link:link,
.publisher-name-link:visited{
  color:var(--ink);
  font-weight:900;
  text-decoration:none;
  transition:color .15s ease, text-decoration-color .15s ease;
}

.publisher-name-link:hover,
.publisher-name-link:focus-visible{
  color:var(--brand);
  text-decoration-thickness:2px;
  text-decoration-color:rgba(255,140,0,.65);
}

/* link do wolontariusza (podtytuł) */
.publisher-sub-name:link,
.publisher-sub-name:visited{
  color:var(--ink-2);
  font-weight:700;
  overflow-wrap:anywhere;
  transition:color .15s ease, text-decoration-color .15s ease;
}

.publisher-sub-name:hover,
.publisher-sub-name:focus-visible{
  color:var(--brand);
  text-decoration-thickness:2px;
  text-decoration-color:rgba(255,140,0,.55);
}

@media (max-width:600px){
  .publisher-card{ padding:14px; }
}

/* ===== Dekoracyjne łapki na kartach (z animals_ad_settings) ===== */
.ad-svg-decor{
  position:absolute;
  opacity:0.06;
  pointer-events:none;
  transform-origin:center;
  z-index:-1; /* dzięki stacking context na .card / .meta-item łapki są pod treścią */
}

/* delikatnie mocniejsze, żeby wzór był widoczny */
.ad-svg-decor--card,
.ad-svg-decor--meta{
  opacity:0.2;
}

/* Kolor łapek z CSS zmiennej (nadpisywanej z PHP na <main>) */
.ad-svg-decor path,
.ad-svg-decor g{
  fill:var(--paw-color,#8a4c00);
}

/* =========================================================
   TOOLBAR EDYCJI STYLU – panel + uchwyt jako JEDEN blok
   ========================================================= */
.edit-style-toolbar[hidden]{ display:none !important; }

/* Kontener: fixed, przesuwamy go cały (panel + uchwyt razem) */
.edit-style-toolbar{
  position:fixed;
  top:140px;              /* poniżej Anuluj/Zapisz */
  right:-260px;           /* stan ZAMKNIĘTY: panel poza ekranem, wystaje tylko uchwyt */
  width:306px;            /* 260 (panel) + 46 (uchwyt) */
  z-index:1200;
  transition:right .25s ease-out;
}

/* Stan OTWARTY – całość dosuwa się tak, że panel jest widoczny */
.edit-style-toolbar.is-open{
  right:0;
}

/* Uchwyt "WYGLĄD" – bardziej profesjonalny wygląd */
.style-toolbar-tab{
  position:absolute;
  top:20px;
  left:0;
  width:46px;
  padding:10px 6px;
  border-radius:12px 0 0 12px;
  border:1px solid rgba(15,23,42,.12);          /* cienka ramka */
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  background:
    linear-gradient(180deg,#f97316,#ea580c);     /* cieplejszy, bardziej spójny pomarańcz */
  box-shadow:
    0 10px 24px rgba(15,23,42,.35),
    inset 0 0 0 1px rgba(255,255,255,.35);       /* lekka poświata wewnątrz */
  color:#f9fafb;
  font-weight:600;
  text-shadow:0 1px 1px rgba(15,23,42,.4);
  transition:
    background .18s ease,
    box-shadow .18s ease,
    transform .08s ease,
    border-color .18s ease;
}

.style-toolbar-tab:hover{
  background:linear-gradient(180deg,#fb923c,#f97316);
  box-shadow:
    0 12px 30px rgba(15,23,42,.45),
    inset 0 0 0 1px rgba(255,255,255,.45);
  transform:translateX(1px);
  border-color:rgba(248,250,252,.7);
}

.style-toolbar-tab:active{
  transform:translateX(0) translateY(1px);
  box-shadow:
    0 6px 16px rgba(15,23,42,.4),
    inset 0 0 0 1px rgba(255,255,255,.3);
}

.style-toolbar-tab-icon{
  font-size:19px;
  line-height:1;
  margin-bottom:2px;
}

.style-toolbar-tab-text{
  font-size:10.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  line-height:1.08;
  text-align:center;
}

/* Panel wysuwany – dosunięty do prawej, uchwyt wystaje z LEWEJ */
.style-toolbar-inner{
  position:absolute;
  top:0;
  left:46px;                     /* zaraz za uchwytem */
  width:260px;
  max-height:calc(100vh - 200px);
  overflow-y:auto;
  background:linear-gradient(135deg,#ffffff,#fff7eb);
  border-radius:16px 0 0 16px;
  border:1px solid rgba(148,163,184,.35);
  border-right:none;
  padding:10px 14px 12px;
  display:flex;
  flex-direction:column;
  gap:8px;
  box-shadow:0 18px 40px rgba(15,23,42,.25);
}

.style-toolbar-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:4px;
}

.style-toolbar-title{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
}

.style-toolbar-close{
  border:none;
  background:transparent;
  cursor:pointer;
  width:24px;
  height:24px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
  color:var(--muted);
}
.style-toolbar-close:hover{
  background:rgba(255,255,255,.85);
}

.style-toolbar-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.style-toolbar-section{
  padding:8px 8px 10px;
  border-radius:12px;
  background:rgba(255,255,255,.96);
  box-shadow:0 0 0 1px rgba(148,163,184,.18);
}

.style-toolbar-section-label{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
  margin-bottom:6px;
}

/* Bazowy kontener na kropki */
.preview-toolbar-dots{
  display:grid;
  align-content:flex-start;
  justify-content:flex-start;
  row-gap:6px;
  column-gap:6px;
  min-height:34px;
}

/* Siatka: kolory kart (dużo kropek, kompaktowo) */
.preview-toolbar-dots--cards{
  grid-template-columns: repeat(10, minmax(0,18px));
}

/* Siatka: style SVG */
.preview-toolbar-dots--styles{
  grid-template-columns: repeat(7, minmax(0,32px));
}

/* Siatka: kolory łapek */
.preview-toolbar-dots--paw{
  grid-template-columns: repeat(6, minmax(0,18px));
}

/* =========================
   Kropki: styl dekoracji SVG
   ========================= */
.preview-style-dot{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#ffffff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
  margin:0;
  position:relative;
  overflow:hidden;
  transition:
    transform .12s ease,
    box-shadow .12s ease,
    border-color .12s ease,
    background-color .12s ease;
}

.preview-style-dot:hover{
  transform:scale(1.04);
  box-shadow:0 0 0 2px rgba(15,23,42,.04);
}

.preview-style-dot--active{
  border-color:var(--brand);
  box-shadow:0 0 0 2px rgba(255,140,0,.35);
}

/* Pierwsza kropka: brak wzoru ("X") */
.preview-style-dot--none{
  background:#e5e7eb;
  border-style:solid;
}

.preview-style-dot--none::before,
.preview-style-dot--none::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:70%;
  height:1px;
  background:#111827;
  transform-origin:center;
}

.preview-style-dot--none::before{
  transform:translate(-50%,-50%) rotate(45deg);
}
.preview-style-dot--none::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}

.preview-style-dot-icon{
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.preview-style-dot-svg{
  width:100%;
  height:100%;
  opacity:0.9;
}

/* =========================
   Kropki: kolory tła kart
   ========================= */
.preview-color-dot{
  flex:0 0 auto;
  width:18px;
  height:18px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#f3f4f6;
  padding:0;
  margin:0;
  cursor:pointer;
  outline:none;
  position:relative;
  transition:
    transform .12s ease,
    box-shadow .12s ease,
    border-color .12s ease,
    background-color .12s ease;
}

.preview-color-dot:hover{
  transform:scale(1.05);
  box-shadow:0 0 0 2px rgba(15,23,42,.04);
}

/* Aktywna kropka – podkreślona kolorem brand */
.preview-color-dot--active{
  box-shadow:0 0 0 2px rgba(255,140,0,.35);
  border-color:var(--brand);
  transform:scale(1.08);
}

/* 1: DOMYŚLNE BIAŁE TŁO + „X” */
.preview-color-dot--1{
  background:#ffffff;
}
.preview-color-dot--1::before,
.preview-color-dot--1::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:70%;
  height:1px;
  background:#111827;
  transform-origin:center;
}
.preview-color-dot--1::before{
  transform:translate(-50%,-50%) rotate(45deg);
}
.preview-color-dot--1::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}

/* 2–9: ciepłe kremowo-pomarańczowe */
.preview-color-dot--2{ background:#fff1e6; }
.preview-color-dot--3{ background:#ffe4cc; }
.preview-color-dot--4{ background:#ffd7b5; }
.preview-color-dot--5{ background:#f6c8a8; }
.preview-color-dot--6{ background:#f3ddc0; }
.preview-color-dot--7{ background:#ead2b5; }
.preview-color-dot--8{ background:#f0c7b0; }
.preview-color-dot--9{ background:#e4bca3; }

/* 10: krem */
.preview-color-dot--10{ background:#fffaf3; }

/* Pastelowe róże */
.preview-color-dot--11{ background:#ffeaf0; }
.preview-color-dot--12{ background:#ffd6e3; }
.preview-color-dot--13{ background:#f9c2d0; }

/* 14–16: pastelowe żółte */
.preview-color-dot--14{ background:#fffbea; }
.preview-color-dot--15{ background:#fef9c3; }
.preview-color-dot--16{ background:#fef3c7; }

/* 17–20: beże / brązy */
.preview-color-dot--17{ background:#f2e8da; }
.preview-color-dot--18{ background:#f7f1e8; }
.preview-color-dot--19{ background:#e9c5ae; }
.preview-color-dot--20{ background:#d8b59c; }

/* =========================
   Paleta kolorów łapki
   ========================= */
.preview-paw-dot{
  width:18px;
  height:18px;
  border-radius:999px;
  border:1px solid var(--line);
  padding:0;
  margin:0;
  cursor:pointer;
  background:#fff;
  transition:
    transform .12s ease,
    box-shadow .12s ease,
    border-color .12s ease,
    background-color .12s ease;
}

.preview-paw-dot:hover{
  transform:scale(1.08);
  box-shadow:0 0 0 2px rgba(15,23,42,.04);
}

.preview-paw-dot--active{
  border-color:var(--brand);
  box-shadow:0 0 0 2px rgba(255,140,0,.35);
  transform:scale(1.1);
}

/* Domyślny kolor motywu – szarawa kropka z X */
.preview-paw-dot--default{
  background:#d1d5db;
  position:relative;
}
.preview-paw-dot--default::before,
.preview-paw-dot--default::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:70%;
  height:1px;
  background:#111827;
  transform-origin:center;
}
.preview-paw-dot--default::before{
  transform:translate(-50%,-50%) rotate(45deg);
}
.preview-paw-dot--default::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}

/* Kolory łapek – ciemniejsze, nie gryzą się z pastelowym tłem kart */
.preview-paw-dot--1{ background:#8a4c00; } /* ciemny brąz */
.preview-paw-dot--2{ background:#b45309; } /* karmel */
.preview-paw-dot--3{ background:#92400e; } /* głęboki bursztyn */
.preview-paw-dot--4{ background:#4b5563; } /* chłodny grafit */
.preview-paw-dot--5{ background:#1f2937; } /* ciemny antracyt */

/* ===== Responsywność toolbara ===== */
@media (max-width:900px){
  .edit-style-toolbar{
    top:120px;
  }
}

/* ===== ZBIÓRKA (fundraiser) pod galerią ===== */
.fund-card{
  padding:16px 18px;
}

.fund-head{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-bottom:10px;
}

.fund-kicker{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:800;
}

.fund-title{
  font-size:16px;
  font-weight:900;
  color:var(--ink);
  line-height:1.25;
}

.fund-desc{
  font-size:13.5px;
  line-height:1.5;
  color:var(--ink-2);
}

.fund-progress{
  width:100%;
  height:12px;
  border-radius:999px;
  background:rgba(15,23,42,.08);
  border:1px solid rgba(15,23,42,.10);
  overflow:hidden;
}

.fund-bar{
  height:100%;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(251,146,60,.95), rgba(249,115,22,.95));
  box-shadow:0 6px 14px rgba(249,115,22,.25);
}

.fund-meta{
  margin-top:10px;
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:12px;
}

.fund-amounts{
  font-size:13.5px;
  color:var(--ink-2);
}

.fund-percent{
  font-size:13px;
  font-weight:900;
  color:var(--ink);
  background:rgba(248,250,252,1);
  border:1px solid var(--line);
  border-radius:999px;
  padding:4px 8px;
}

.fund-actions{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.fund-note{
  font-size:12.5px;
  color:var(--muted);
}
