/* SAMOSEO Consent Mode v2 — redesign banera (motyw) */
#cookie-banner{
  --brand:#479A36;
  --brand-strong:#3a7d2c;
  --brand-soft:#eef6ec;
  --brand-tint:#f4f9f2;
  --ink:#15201a;
  --muted:#5f6b64;
  --faint:#8a948e;
  --line:#e6ece8;
  --line-soft:#eef2ef;
  --surface:#ffffff;
  --surface-2:#f6f8f6;
  --scrim:rgba(15,24,19,.52);
  --shadow:0 24px 70px -24px rgba(15,40,25,.45), 0 6px 18px -8px rgba(15,40,25,.18);
  --radius:20px;
  --radius-sm:13px;
  --sans:"Montserrat",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}

body.cb-open{overflow:hidden}

#cookie-banner, #cookie-banner *{box-sizing:border-box;font-family:var(--sans)}

#cookie-banner.is-open{
  display:flex;
}

#cookie-banner{
  position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;
  padding:22px;background:var(--scrim);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  animation:scrimIn .4s ease both;overscroll-behavior:contain;
}
@keyframes scrimIn{from{opacity:0}to{opacity:1}}

body.cb-open *:not(#cookie-banner):not(#cookie-banner *):not(#cookie-reopen){pointer-events:none !important}

/* ---- karta ---- */
.cb-card{
  position:relative;width:min(94vw,640px);max-height:min(90vh,760px);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;
  animation:cardIn .46s cubic-bezier(.2,.8,.2,1) both;
}
#cookie-banner.wide .cb-card{width:min(94vw,720px)}
@keyframes cardIn{from{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:none}}

/* sygnaturowy zielony „grzbiet" po lewej */
.cb-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(180deg,var(--brand),color-mix(in srgb,var(--brand) 55%, transparent));
}

/* ---- nagłówek ---- */
.cb-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 24px 14px}
.cb-head-left{display:flex;align-items:center;gap:13px;min-width:0}
.cb-mark{
  flex:0 0 auto;width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:var(--brand-soft);color:var(--brand);
}
.cb-mark svg{width:23px;height:23px}
.cb-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);line-height:1}
.cb-head h2{margin:5px 0 0;font-size:1.22rem;font-weight:700;letter-spacing:-.01em;line-height:1.15}
.cb-brand{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex:0 0 auto}
.cb-brand span{font-size:.62rem;letter-spacing:.08em;color:var(--faint);text-transform:uppercase}
.cb-brand a{display:block;line-height:0}
.cb-brand svg{height:17px;width:auto;display:block}
.cb-logo-text{fill:var(--ink)}
.cb-logo-icon{fill:var(--brand)}

/* ---- nawigacja zakładek (segmented) ---- */
.cb-tabs{display:flex;gap:4px;margin:6px 18px 0;padding:4px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:14px}
.cb-tab{
  flex:1;appearance:none;border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:.86rem;color:var(--muted);
  padding:9px 8px;border-radius:10px;background:transparent;transition:color .18s, background .18s, box-shadow .18s;
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
}
.cb-tab svg{width:16px;height:16px;fill:currentColor}
.cb-tab:hover{color:var(--ink)}
.cb-tab[aria-selected="true"]{background:var(--surface);color:var(--brand);box-shadow:0 1px 4px rgba(15,40,25,.10)}

/* ---- ciało / przewijanie ---- */
.cb-body{flex:1 1 auto;overflow-y:auto;padding:18px 24px 8px;min-height:0;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.cb-body::-webkit-scrollbar{width:9px}
.cb-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px;border:3px solid var(--surface)}

.cb-pane{display:none;animation:paneIn .28s ease both}
.cb-pane.active{display:block}
@keyframes paneIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}

.cb-pane p.intro{margin:0 0 6px;color:var(--muted);line-height:1.62;font-size:.94rem}
.cb-pane h3{margin:0 0 9px;font-size:1.05rem;font-weight:700}
.cb-link{color:var(--brand);text-decoration:none;font-weight:600}
.cb-link:hover{text-decoration:underline}

/* ---- kategorie (akordeon) ---- */
.cat-list{margin:14px 0 4px;display:flex;flex-direction:column;gap:10px}
.cat{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);overflow:hidden;transition:border-color .2s, box-shadow .2s}
.cat[data-open="true"]{border-color:color-mix(in srgb,var(--brand) 40%, var(--line));box-shadow:0 6px 18px -12px rgba(71,154,54,.5)}
.cat-head{display:flex;align-items:center;gap:13px;padding:13px 15px;cursor:pointer;user-select:none}
.cat-ico{flex:0 0 auto;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--brand-soft);color:var(--brand)}
.cat-ico svg{width:19px;height:19px;fill:currentColor}
.cat-meta{flex:1 1 auto;min-width:0}
.cat-name{font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:8px}
.cat-count{font-family:var(--mono);font-size:.66rem;font-weight:600;padding:2px 7px;border-radius:6px;background:var(--surface-2);color:var(--muted);border:1px solid var(--line-soft)}
.cat-sub{font-size:.8rem;color:var(--faint);margin-top:2px}
.cat-chev{flex:0 0 auto;color:var(--faint);transition:transform .3s ease;display:flex}
.cat[data-open="true"] .cat-chev{transform:rotate(180deg)}

/* przełącznik */
.sw{position:relative;flex:0 0 auto;width:46px;height:26px;display:inline-block}
.sw input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer}
.sw .track{position:absolute;inset:0;border-radius:999px;background:var(--line);transition:background .25s}
.sw .track::before{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .25s}
.sw input:checked + .track{background:var(--brand)}
.sw input:checked + .track::before{transform:translateX(20px)}
.sw input:focus-visible + .track{outline:2px solid var(--brand);outline-offset:2px}
.sw input:disabled{cursor:not-allowed}
.cat.locked .sw{opacity:.5}
.cat.locked .sw input{cursor:not-allowed}

.cat-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .34s ease}
.cat[data-open="true"] .cat-body{grid-template-rows:1fr}
.cat-body > div{overflow:hidden}
.cat-body .desc{padding:0 15px 8px 64px;color:var(--muted);font-size:.88rem;line-height:1.55}
.cat-body .desc strong{color:var(--ink);font-weight:600}

/* tabela cookies */
.ck-wrap{margin:4px 15px 14px 64px;overflow-x:auto}
.ck-table{width:100%;border-collapse:collapse;font-size:.78rem;min-width:340px}
.ck-table th{text-align:left;font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:7px 10px;border-bottom:1px solid var(--line)}
.ck-table td{padding:8px 10px;border-bottom:1px solid var(--line-soft);color:var(--muted);vertical-align:top;line-height:1.45}
.ck-table tr:last-child td{border-bottom:none}
.ck-name{font-family:var(--mono);font-size:.74rem;color:var(--ink);font-weight:500;white-space:nowrap}
.ck-dur{font-family:var(--mono);font-size:.72rem;color:var(--faint);white-space:nowrap}

/* ---- zakładka informacje ---- */
.cid{margin-top:18px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px}
.cid-label{font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.cid-value{font-family:var(--mono);font-size:.82rem;font-weight:500;color:var(--brand);background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:9px 11px;margin:8px 0;word-break:break-all}
.cid-desc{font-size:.8rem;color:var(--faint);line-height:1.5}

/* ---- stopka / przyciski ---- */
.cb-foot{
  flex:0 0 auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  padding:14px 24px 18px;border-top:1px solid var(--line-soft);
  background:linear-gradient(to top, var(--surface), color-mix(in srgb,var(--surface) 70%, transparent));
}
.cb-foot[data-view="settings"]{justify-content:space-between}
#cookie-banner .btn{
  appearance:none;font-family:inherit;font-weight:600;font-size:.9rem;cursor:pointer;
  padding:11px 18px;border-radius:12px;border:1px solid transparent;transition:transform .14s, background-color .16s, color .16s, border-color .16s;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
  background-color:transparent;background-image:none;
}
#cookie-banner .btn:hover{transform:translateY(-2px)}
#cookie-banner .btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
#cookie-banner .btn-ghost{background-color:transparent;color:var(--muted);border-color:var(--line)}
#cookie-banner .btn-ghost:hover{color:var(--ink);background-color:var(--surface-2);border-color:var(--line)}
#cookie-banner .btn-outline{background-color:var(--surface);color:var(--brand);border-color:color-mix(in srgb,var(--brand) 45%, transparent)}
#cookie-banner .btn-outline:hover{background-color:var(--brand-soft);color:var(--brand)}
#cookie-banner .btn-solid{
  background-color:#479A36;
  color:#fff;
  border-color:#479A36;
  box-shadow:0 10px 22px -12px rgba(71,154,54,.8);
  -webkit-text-fill-color:#fff;
}
#cookie-banner .btn-solid:hover{
  background-color:#3a7d2c;
  color:#fff;
  border-color:#3a7d2c;
  -webkit-text-fill-color:#fff;
}
.cb-foot .grow{flex:1}
.foot-group{display:flex;gap:10px}

/* ---- przycisk ponownego otwarcia ---- */
#cookie-reopen{
  position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:9998;
  display:none;align-items:center;gap:8px;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:.8rem;
  appearance:none;background-color:#479A36;background-image:none;color:#fff;border:none;
  padding:11px 14px 11px 12px;border-radius:0 13px 13px 0;
  box-shadow:0 10px 24px -10px rgba(71,154,54,.8);
  transition:transform .25s, padding .2s, color .2s;
}
#cookie-reopen svg{
  width:19px;height:19px;flex:0 0 auto;
  color:#ffe41a;fill:#ffe41a;
  -webkit-text-fill-color:#ffe41a;
}
#cookie-reopen .lbl{
  max-width:0;overflow:hidden;white-space:nowrap;opacity:0;
  transition:max-width .28s, opacity .2s, color .2s;
}
#cookie-reopen:hover{
  transform:translateY(-50%) translateX(2px);
  color:#000;
}
#cookie-reopen:hover svg{
  color:#ffe41a;fill:#ffe41a;
  -webkit-text-fill-color:#ffe41a;
}
#cookie-reopen:hover .lbl{
  max-width:140px;opacity:1;
  color:#000;
  -webkit-text-fill-color:#000;
}

/* ---- mobile ---- */
@media (max-width:560px){
  #cookie-banner{padding:0;align-items:flex-end}
  .cb-card,#cookie-banner.wide .cb-card{width:100%;max-height:92vh;border-radius:22px 22px 0 0;border-bottom:none}
  .cb-card::before{border-radius:22px 0 0 0}
  .cb-head{padding:18px 18px 12px}
  .cb-tabs{margin:6px 14px 0}
  .cb-tab .tab-txt{display:none}
  .cb-tab{padding:10px}
  .cb-body{padding:16px 18px 6px}
  .cat-body .desc,.ck-wrap{padding-left:18px;margin-left:18px}
  .cb-foot{padding:12px 16px calc(14px + env(safe-area-inset-bottom));flex-direction:column}
  #cookie-banner .cb-foot[data-view="consent"] .btn,#cookie-banner .cb-foot[data-view="settings"] .btn{width:100%}
  .cb-foot[data-view="settings"]{align-items:stretch}
  .foot-group{flex-direction:column;width:100%}
  #cookie-reopen .lbl{display:none}
  #cookie-reopen{padding:12px}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}