.wpins-cookie-root,
.wpins-cookie-modal-wrap,
.wpins-cookie-footer-link,
.wpins-cookie-iframe-placeholder {
  /* Fonty marki (fallback = działa samodzielnie bez motywu). */
  font-family: var(--font-wpins-ui, system-ui, -apple-system, "Segoe UI", sans-serif);
  /* Wiązanie z tokenami design systemu — gdy motyw aktywny dziedziczy markę,
     bez motywu używa fallbacku. Zmiana brandu w tokens.json → cookie też się zmienia. */
  --wpins-cookie-accent: var(--color-wpins-accent, #e52528);
  --wpins-cookie-bg: var(--color-wpins-ink-100, #000);
  --wpins-cookie-text: var(--color-wpins-white, #fff);
}
.wpins-cookie-root[hidden], .wpins-cookie-modal-wrap[hidden] { display: none !important; }
.wpins-cookie-root { position: fixed; z-index: 999998; left: 0; right: 0; padding: 16px; }
.wpins-cookie-bottom { bottom: 0; }
.wpins-cookie-top { top: 0; }
.wpins-cookie-banner {
  width: min(1180px, calc(100% - 24px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: var(--wpins-cookie-bg, #000);
  color: var(--wpins-cookie-text, #fff);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 18px;
  padding: 20px 24px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.wpins-cookie-layout-full .wpins-cookie-banner { width: calc(100% - 24px); border-radius: 14px; }

/* Header: ikona + tytuł — zawsze w jednym wierszu */
.wpins-cookie-header {
  display: flex;
  align-items: center;
  gap: 14px;
}
.wpins-cookie-icon { width: 46px; height: 46px; border: 2px solid currentColor; border-radius: 999px; display: grid; place-items: center; font-size: 24px; flex-shrink: 0; }
.wpins-cookie-header h2 { margin: 0; color: inherit; font-family: var(--font-wpins-heading, inherit); font-size: 20px; font-weight: 800; line-height: 1.2; }

/* Opis */
.wpins-cookie-desc {
  margin: 0;
  color: inherit;
  font-size: 14px;
  line-height: 1.55;
  opacity: .88;
}

/* Przyciski — zawsze pod spodem, poziomo */
.wpins-cookie-actions {
  display: flex;
  flex-direction: row;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.wpins-cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.wpins-cookie-btn,
.wpins-cookie-iframe-placeholder button,
.wpins-cookie-footer-link {
  min-height: 44px;
  border-radius: 8px;
  border: 2px solid transparent;
  padding: 11px 16px;
  font-weight: 800;
  cursor: pointer;
  font-size: 15px;
  line-height: 1.2;
}
.wpins-cookie-btn-primary { background: var(--wpins-cookie-accent, #e52528); color: #fff; }
.wpins-cookie-btn-outline { background: transparent; color: var(--wpins-cookie-text, #fff); border-color: rgba(255,255,255,.75); }
.wpins-cookie-btn-light { background: #fff; color: #000; border-color: #aaa; }
.wpins-cookie-btn:focus-visible,
.wpins-cookie-close:focus-visible,
.wpins-cookie-toggle input:focus-visible + span,
.wpins-cookie-footer-link:focus-visible,
.wpins-cookie-iframe-placeholder button:focus-visible {
  outline: 4px solid var(--wpins-cookie-accent, #e52528);
  outline-offset: 3px;
}
.wpins-cookie-modal-wrap { position: fixed; inset: 0; z-index: 999999; display: grid; place-items: center; padding: 20px; }
.wpins-cookie-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.62); }
.wpins-cookie-modal {
  position: relative;
  z-index: 1;
  width: min(720px, 100%);
  max-height: calc(100dvh - 40px);
  overflow: auto;
  background: #fff;
  color: #000;
  border-radius: 18px;
  padding: 28px;
  box-shadow: 0 18px 70px rgba(0,0,0,.35);
}
.wpins-cookie-close { position: absolute; right: 18px; top: 14px; background: transparent; border: 0; font-size: 34px; line-height: 1; cursor: pointer; color: #000; }
.wpins-cookie-modal h2 { margin: 0 40px 8px 0; color: #000; font-family: var(--font-wpins-heading, inherit); font-weight: 800; font-size: 28px; }
.wpins-cookie-modal > p { margin: 0 0 18px; color: #222; }
.wpins-cookie-categories { border: 1px solid #d8d8d8; border-radius: 10px; overflow: hidden; }

/* Grupa */
.wpins-cookie-group { border-bottom: 1px solid #e3e3e3; }
.wpins-cookie-group:last-child { border-bottom: 0; }
.wpins-cookie-group__header { display: grid; grid-template-columns: 32px auto 1fr auto; gap: 14px; align-items: center; padding: 16px; }
.wpins-cookie-group__expand { width: 32px; height: 32px; background: #f4f4f4; border: 1px solid #ddd; border-radius: 6px; display: grid; place-items: center; cursor: pointer; color: #444; transition: background .15s; flex-shrink: 0; }
.wpins-cookie-group__expand:hover { background: #e8e8e8; }
.wpins-cookie-group__expand--placeholder { background: transparent; border-color: transparent; cursor: default; }
.wpins-cookie-group__expand svg { transition: transform .2s ease; }
.wpins-cookie-group__expand--open svg { transform: rotate(180deg); }

/* Usługi wewnątrz grupy */
.wpins-cookie-group__services { background: #fafafa; border-top: 1px solid #ececec; }
.wpins-cookie-service { display: grid; grid-template-columns: 1fr auto; gap: 14px; align-items: center; padding: 14px 16px 14px 62px; border-bottom: 1px solid #ececec; }
.wpins-cookie-service:last-child { border-bottom: 0; }
.wpins-cookie-service .wpins-cookie-cat-text h4 { margin: 0 0 3px; font-size: 14px; font-weight: 700; color: #000; }
.wpins-cookie-service .wpins-cookie-cat-text p { margin: 0; font-size: 13px; color: #555; line-height: 1.45; }

.wpins-cookie-cat-icon { width: 40px; height: 40px; background: #000; color: #fff; border-radius: 999px; display: grid; place-items: center; flex-shrink: 0; }
.wpins-cookie-cat-text h3 { margin: 0 0 2px; font-size: 16px; color: #000; }
.wpins-cookie-cat-text h3 span { margin-left: 8px; font-size: 11px; padding: 2px 7px; border-radius: 999px; background: #eee; font-weight: 700; }
.wpins-cookie-cat-text h3 small.wpins-cookie-group__count { margin-left: 8px; font-size: 11px; color: #888; font-weight: 400; }
.wpins-cookie-cat-text p { margin: 0; font-size: 14px; color: #444; line-height: 1.45; }
.wpins-cookie-toggle { position: relative; display: inline-flex; align-items: center; }
.wpins-cookie-toggle input { position: absolute; opacity: 0; width: 1px; height: 1px; }
.wpins-cookie-toggle span[aria-hidden="true"] { width: 58px; height: 32px; display: block; border-radius: 999px; background: #111; border: 2px solid #111; position: relative; }
.wpins-cookie-toggle span[aria-hidden="true"]::after { content: ""; position: absolute; top: 4px; left: 4px; width: 20px; height: 20px; border-radius: 999px; background: #fff; transition: transform .16s ease; box-shadow: 0 1px 4px rgba(0,0,0,.35); }
.wpins-cookie-toggle input:checked + span { background: var(--wpins-cookie-accent, #e52528); border-color: var(--wpins-cookie-accent, #e52528); }
.wpins-cookie-toggle input:checked + span::after { transform: translateX(26px); }
.wpins-cookie-toggle input:disabled + span { background: #777; border-color: #777; cursor: not-allowed; }
.wpins-cookie-modal-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; }
.wpins-cookie-modal-footer { display: flex; flex-wrap: wrap; gap: 22px; border-top: 1px solid #eee; margin-top: 18px; padding-top: 14px; }
.wpins-cookie-modal-footer a { color: #000; text-decoration: underline; text-underline-offset: 3px; }
.wpins-cookie-footer-link { position: fixed; right: 16px; bottom: 16px; z-index: 999990; background: #fff; color: #000; border-color: #000; box-shadow: 0 8px 24px rgba(0,0,0,.18); }
.wpins-cookie-root:not([hidden]) + .wpins-cookie-modal-wrap + .wpins-cookie-footer-link { display: none; }
/* Zasłona zgody dla wklejonych iframe — POKRYWA cały element + centruje (V+H), radius 0 (marka). */
.wpins-cookie-embed-gate { position: relative; }
.wpins-cookie-iframe-placeholder {
  position: absolute; inset: 0; margin: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 20px; border: 1px solid var(--wpins-cookie-accent, #e52528); border-radius: 0;
  background: #111; color: #fff; text-align: center;
}
.wpins-cookie-iframe-placeholder strong { display: block; font-size: 18px; margin-bottom: 6px; }
.wpins-cookie-iframe-placeholder p { margin: 0 0 14px; }
.wpins-cookie-iframe-placeholder button { background: var(--wpins-cookie-accent, #e52528); color: #fff; }
html.wpins-cookie-modal-open { overflow: hidden; }
/* Tablet: przyciski pod tekstem */
@media (max-width: 900px) {
  .wpins-cookie-banner {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    width: calc(100% - 20px);
  }
  .wpins-cookie-header { grid-column: 1; grid-row: 1; }
  .wpins-cookie-desc   { grid-column: 1; grid-row: 2; }
  .wpins-cookie-actions {
    grid-column: 1;
    grid-row: 3;
    justify-content: flex-start;
  }
}

/* Mobile: przyciski pionowo */
@media (max-width: 560px) {
  .wpins-cookie-root { padding: 10px; }
  .wpins-cookie-banner { width: 100%; padding: 16px; }
  .wpins-cookie-actions, .wpins-cookie-modal-actions { flex-direction: column; }
  .wpins-cookie-btn { width: 100%; }
  .wpins-cookie-modal { padding: 22px 16px; }
  .wpins-cookie-category { grid-template-columns: auto 1fr; }
  .wpins-cookie-toggle { grid-column: 1 / -1; justify-self: end; }
  .wpins-cookie-footer-link { left: 12px; right: 12px; bottom: 12px; width: auto; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto !important; }
}

/* ── Brand WPiNS: radius 0 (ostry, instytucjonalny) — nadpisanie zaokrągleń wtyczki.
   Wyjątek: ikony (kółka) i przełączniki (pill) zostają — rozpoznawalne kontrolki. ── */
.wpins-cookie-banner,
.wpins-cookie-layout-full .wpins-cookie-banner,
.wpins-cookie-btn,
.wpins-cookie-iframe-placeholder button,
.wpins-cookie-footer-link,
.wpins-cookie-modal,
.wpins-cookie-categories,
.wpins-cookie-group__expand,
.wpins-cookie-cat-text h3 span,
.wpins-cookie-iframe-placeholder {
  border-radius: 0;
}
