/* ============================================================
   OTMS — _premium.css · Elegant Premium 2026 design layer
   Prefiks .pr-* = zero kolizji z istniejącym CSS.
   Używa zmiennych z _vars.css → działa w light i dark.
   Dodawane PO _components; nic nie nadpisuje istniejących klas.
   ============================================================ */

/* ---------- Page head ---------- */
.pr-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.pr-head-l{display:flex;align-items:center;gap:14px}
.pr-ic{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;flex:none;color:#fff;
  background:linear-gradient(135deg,var(--brand-blue-light,#3b82f6),var(--brand-blue-dark,#1d4ed8));
  box-shadow:0 8px 18px rgba(37,99,235,.32)}
.pr-h1{font-size:24px;font-weight:800;letter-spacing:-.01em;color:var(--text);line-height:1.1}
.pr-sub{font-size:13px;color:var(--text-muted);margin-top:3px}
.pr-head-actions{display:flex;gap:9px;align-items:center}

/* ---------- Buttons (premium) ---------- */
.pr-btn{display:inline-flex;align-items:center;gap:7px;border:none;cursor:pointer;font-family:inherit;
  font-size:13.5px;font-weight:700;padding:11px 17px;border-radius:12px;transition:transform .15s,box-shadow .15s,background .15s;text-decoration:none}
.pr-btn-primary{color:#fff;background:linear-gradient(135deg,var(--brand-blue-light,#3b82f6),var(--brand-blue-dark,#1d4ed8));
  box-shadow:0 8px 18px rgba(37,99,235,.30)}
.pr-btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(37,99,235,.40)}
.pr-btn-ghost{background:var(--card);border:1px solid var(--border);color:var(--text-soft,#334155)}
.pr-btn-ghost:hover{border-color:var(--border-strong,#cbd5e1)}
.pr-btn-sm{padding:8px 13px;font-size:12.5px;border-radius:10px}

/* ---------- Stat strip ---------- */
.pr-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.pr-stat{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);
  padding:15px 17px;display:flex;align-items:center;gap:13px;transition:transform .15s,box-shadow .15s}
.pr-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.pr-stat-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none}
.pr-stat-num{font-size:24px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--text)}
.pr-stat-lbl{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:600}
@media(max-width:820px){.pr-stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Toolbar + premium search ---------- */
.pr-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.pr-search{flex:1;min-width:240px;display:flex;align-items:center;gap:11px;background:var(--card);
  border:1px solid var(--border);border-radius:14px;padding:0 15px;height:50px;box-shadow:var(--shadow);
  transition:border-color .15s,box-shadow .15s}
.pr-search:focus-within{border-color:var(--brand-blue,#2563eb);box-shadow:0 0 0 4px rgba(37,99,235,.12),var(--shadow)}
.pr-search-ic{width:32px;height:32px;border-radius:10px;flex:none;display:grid;place-items:center;
  color:var(--brand-blue,#2563eb);background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(37,99,235,.14))}
.pr-search input{border:none;outline:none;background:transparent;flex:1;font-family:inherit;font-size:14.5px;
  font-weight:500;color:var(--text)}
.pr-search input::placeholder{color:var(--text-dim,#94a3b8);font-weight:500}
.pr-kbd{font-family:var(--font-mono,monospace);font-size:11px;color:var(--text-muted);background:var(--bg);
  border:1px solid var(--border);border-radius:7px;padding:4px 8px}
.pr-count{font-size:13px;font-weight:700;color:var(--text-muted);white-space:nowrap;padding:0 4px}

/* ---------- Card grid ---------- */
.pr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.pr-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--border);
  border-radius:18px;box-shadow:var(--shadow);padding:18px;transition:transform .18s,box-shadow .18s,border-color .18s}
.pr-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ac,var(--brand-blue,#2563eb))}
.pr-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-pop);border-color:var(--brand-blue,#2563eb)}
.pr-card.is-inactive{opacity:.62}
.pr-card-top{display:flex;align-items:flex-start;gap:12px}
.pr-av{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;flex:none;
  font-size:15px;font-weight:800;letter-spacing:.02em;color:var(--av-c,#0369a1);background:var(--av-bg,#e0f2fe)}
.pr-id{min-width:0;flex:1}
.pr-name{font-size:15.5px;font-weight:700;letter-spacing:-.01em;line-height:1.2;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;display:block}
a.pr-name:hover{color:var(--brand-blue,#2563eb)}
.pr-name-sub{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-actions{display:flex;gap:6px;flex:none}
.pr-ibtn{width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:var(--card);
  display:grid;place-items:center;color:var(--text-muted);cursor:pointer;transition:.15s;text-decoration:none}
.pr-ibtn:hover{color:var(--brand-blue,#2563eb);border-color:var(--brand-blue,#2563eb);background:var(--st-info-bg,#e0f2fe)}
.pr-ibtn.danger:hover{color:var(--st-danger,#dc2626);border-color:var(--st-danger,#dc2626);background:var(--st-danger-bg,#fee2e2)}

/* chips */
.pr-chips{display:flex;flex-wrap:wrap;gap:6px;margin:13px 0 11px}
.pr-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px;
  border-radius:999px;color:var(--c,var(--st-neutral,#64748b));
  background:color-mix(in srgb,var(--c,#64748b) 14%,transparent)}
.pr-chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
/* fallback dla starszych przeglądarek bez color-mix → status klasy */
.pr-chip.s-green{color:var(--st-success,#16a34a);background:var(--st-success-bg,#dcfce7)}
.pr-chip.s-blue{color:var(--st-info,#0ea5e9);background:var(--st-info-bg,#e0f2fe)}
.pr-chip.s-amber{color:var(--st-warning,#b45309);background:var(--st-warning-bg,#fef3c7)}
.pr-chip.s-purple{color:var(--st-customs,#7c3aed);background:var(--st-customs-bg,#ede9fe)}
.pr-chip.s-red{color:var(--st-danger,#dc2626);background:var(--st-danger-bg,#fee2e2)}
.pr-chip.s-neutral{color:var(--st-neutral,#64748b);background:var(--st-neutral-bg,#f1f5f9)}

/* meta rows */
.pr-meta{display:flex;gap:18px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--line,#eef2f7);margin-top:2px}
.pr-meta+.pr-meta{border-top:none;padding-top:8px;margin-top:0}
.pr-mi{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--text-muted)}
.pr-mi svg{color:var(--text-muted);flex:none}
.pr-mi b{font-size:13.5px;font-weight:800;color:var(--text)}
.pr-mi .mono{font-family:var(--font-mono,monospace);color:var(--text-soft,#334155)}
.pr-dash{color:var(--text-dim,#94a3b8)}
.pr-foot{display:flex;gap:8px;margin-top:14px}
.pr-act{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--border);
  background:var(--card);border-radius:10px;padding:9px;font-family:inherit;font-size:12.5px;font-weight:600;
  color:var(--text-soft,#334155);cursor:pointer;text-decoration:none;transition:.15s}
.pr-act:hover{background:var(--bg);border-color:var(--brand-blue,#2563eb);color:var(--brand-blue,#2563eb)}

/* country flag (mini) */
.pr-flag{display:inline-flex;align-items:center;font-weight:700;font-size:11.5px;color:var(--text-soft,#334155);gap:4px}

/* ---------- FIRM block (global) ---------- */
.pr-firm-name{font-size:16px;font-weight:800;letter-spacing:-.01em;color:var(--text);line-height:1.2}
.pr-line{font-size:13px;color:var(--text-soft,#334155);margin-top:5px;display:flex;align-items:center;gap:7px}
.pr-kv{font-size:13px;display:flex;gap:7px;margin-top:5px}
.pr-kv .k{color:var(--text-muted);font-weight:700;min-width:44px}
.pr-kv .v{color:var(--text)}
.pr-kv .v.mono{font-family:var(--font-mono,monospace);font-size:12.5px}

/* ---------- PERSON block (global) ---------- */
.pr-person{background:var(--bg);border:1px solid var(--line,#eef2f7);border-radius:14px;padding:12px 13px}
.pr-person+.pr-person{margin-top:10px}
.pr-person-top{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.pr-person-name{font-size:14px;font-weight:700;color:var(--text)}
.pr-role{font-size:11px;color:var(--text-muted);font-weight:600;background:var(--card);
  border:1px solid var(--border);padding:1px 8px;border-radius:999px}
.pr-plinks{margin-top:8px;display:flex;flex-direction:column;gap:7px}
.pr-plink{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--text);text-decoration:none;width:fit-content;transition:.12s}
.pr-plink .pic{width:25px;height:25px;border-radius:8px;display:grid;place-items:center;flex:none}
.pr-plink .pic.wa{color:#1faa5a;background:var(--st-success-bg,#dcfce7)}
.pr-plink .pic.ml{color:var(--st-info,#0ea5e9);background:var(--st-info-bg,#e0f2fe)}
.pr-plink .k{color:var(--text-muted);font-weight:700}
.pr-plink:hover{color:var(--brand-blue,#2563eb)}
.pr-plink:hover .val{text-decoration:underline}
.pr-person-note{font-size:12px;color:var(--text-muted);margin-top:7px;display:flex;gap:6px}
.pr-person-note .k{font-weight:700}

/* ---------- Collapsible contacts + multi-select ---------- */
.pr-contacts{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;margin-top:12px}
.pr-ct-head{display:flex;align-items:center;gap:11px;padding:13px 16px;cursor:pointer;user-select:none}
.pr-ct-ic{width:32px;height:32px;border-radius:10px;flex:none;display:grid;place-items:center;color:var(--st-info,#0ea5e9);background:var(--st-info-bg,#e0f2fe)}
.pr-ct-title{font-size:14px;font-weight:700;color:var(--text)}
.pr-count-pill{background:var(--brand-blue,#2563eb);color:#fff;font-size:11.5px;font-weight:800;border-radius:999px;min-width:22px;height:22px;padding:0 7px;display:grid;place-items:center}
.pr-ct-avs{margin-left:auto;display:flex;align-items:center}
.pr-ct-avs .a{width:27px;height:27px;border-radius:50%;border:2px solid var(--card);display:grid;place-items:center;font-size:10.5px;font-weight:800;margin-left:-8px}
.pr-ct-chev{margin-left:12px;color:var(--text-muted);transition:transform .2s}
.pr-contacts.open .pr-ct-chev{transform:rotate(180deg)}
.pr-contacts.open .pr-ct-avs{display:none}
.pr-ct-body{display:none;border-top:1px solid var(--line,#eef2f7)}
.pr-contacts.open .pr-ct-body{display:block}
.pr-crow{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line,#eef2f7)}
.pr-crow:last-child{border-bottom:none}
.pr-crow:hover{background:var(--card-hover,#fafbfc)}

/* ---------- Atoms (identical everywhere) ---------- */
.pr-check{position:relative;display:inline-grid;place-items:center;width:21px;height:21px;flex:none}
.pr-check input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0}
.pr-check b{width:21px;height:21px;border:2px solid var(--border-strong,#cbd5e1);border-radius:7px;background:var(--card);display:grid;place-items:center;transition:.15s}
.pr-check input:checked+b{background:var(--brand-blue,#2563eb);border-color:var(--brand-blue,#2563eb)}
.pr-check input:checked+b::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2.4px 2.4px 0;transform:rotate(45deg);margin-top:-2px}
.pr-check.ind b{background:var(--brand-blue,#2563eb);border-color:var(--brand-blue,#2563eb)}
.pr-check.ind b::after{content:"";width:9px;height:0;border-top:2.4px solid #fff;border-radius:2px}
.pr-radio{position:relative;display:inline-grid;place-items:center;width:21px;height:21px;flex:none}
.pr-radio input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0}
.pr-radio b{width:21px;height:21px;border:2px solid var(--border-strong,#cbd5e1);border-radius:50%;background:var(--card);display:grid;place-items:center;transition:.15s}
.pr-radio input:checked+b{border-color:var(--brand-blue,#2563eb)}
.pr-radio input:checked+b::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--brand-blue,#2563eb)}
.pr-switch{position:relative;width:44px;height:25px;display:inline-block;flex:none}
.pr-switch input{opacity:0;width:0;height:0}
.pr-switch .tr{position:absolute;inset:0;background:var(--border-strong,#cbd5e1);border-radius:999px;transition:.18s;cursor:pointer}
.pr-switch .tr::before{content:"";position:absolute;width:19px;height:19px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.pr-switch input:checked+.tr{background:var(--brand-blue,#2563eb)}
.pr-switch input:checked+.tr::before{transform:translateX(19px)}
.pr-token{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--text-soft,#334155);background:var(--card);border:1px solid var(--border);border-radius:999px;padding:5px 6px 5px 12px}
.pr-token-x{width:20px;height:20px;border:none;border-radius:50%;background:var(--st-neutral-bg,#f1f5f9);color:var(--text-muted);display:grid;place-items:center;cursor:pointer;transition:.15s}
.pr-token-x:hover{background:var(--st-danger-bg,#fee2e2);color:var(--st-danger,#dc2626)}

/* ---------- Empty / no-results ---------- */
.pr-empty{grid-column:1/-1;text-align:center;padding:48px 20px;color:var(--text-muted)}
.pr-empty .ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin:0 auto 14px;color:var(--brand-blue,#2563eb);background:var(--st-info-bg,#e0f2fe)}
.pr-empty h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.pr-empty p{font-size:13px;margin-bottom:16px}

/* ---------- Premium rich TABLE (zachowuje table[data-bulk-url] → bulk działa) ---------- */
.pr-panel{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-md);overflow:hidden}
.pr-panel-h{display:flex;align-items:center;gap:9px;padding:13px 17px;border-bottom:1px solid var(--line,#eef2f7);font-size:13.5px;font-weight:700;color:var(--text);background:linear-gradient(180deg,var(--bg,#f8fafc),transparent)}
.pr-panel-h svg{color:var(--brand-blue,#2563eb)}
.pr-tablewrap{overflow-x:auto}
table.pr-table{width:100%;border-collapse:collapse}
table.pr-table thead th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--text-muted);padding:13px 16px;background:var(--card-hover,#fafbfc);border-bottom:1px solid var(--border);white-space:nowrap}
table.pr-table thead th.pr-r{text-align:right}
table.pr-table thead th.pr-c{text-align:center}
table.pr-table tbody td{padding:12px 16px;border-bottom:1px solid var(--line,#eef2f7);font-size:13.5px;vertical-align:middle;color:var(--text)}
table.pr-table tbody tr:last-child td{border-bottom:none}
table.pr-table tbody tr{transition:background .12s}
table.pr-table tbody tr:hover{background:var(--card-hover,#f8fbff)}
table.pr-table tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--brand-blue,#2563eb)}
table.pr-table tbody tr.is-inactive{opacity:.6}
.pr-tname{display:flex;align-items:center;gap:11px}
.pr-tav{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;font-size:13px;font-weight:800;flex:none;color:var(--av-c,#0369a1);background:var(--av-bg,#e0f2fe)}
.pr-tnm{font-weight:700;font-size:14px;color:var(--text);text-decoration:none}
.pr-tnm:hover{color:var(--brand-blue,#2563eb)}
.pr-tsub{font-size:11.5px;color:var(--text-muted)}
.pr-r{text-align:right}.pr-c{text-align:center}
.pr-kpi{font-weight:800;font-family:var(--font-mono,monospace);color:var(--text)}
.pr-bulkcol{width:40px}
.pr-driveravatar{width:24px;height:24px;border-radius:7px;display:inline-grid;place-items:center;font-size:10px;
  font-weight:800;color:#fff;background:var(--dc,#64748b);margin-right:7px;vertical-align:-6px}
/* mini link wa/mail w wierszu tabeli */
.pr-tlink{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:var(--text-soft,#334155);font-size:12.5px}
.pr-tlink:hover{color:var(--brand-blue,#2563eb);text-decoration:underline}
