.pnw-widget {
  --pnw-bg: #ffffff;
  --pnw-bg2: #f7f7f5;
  --pnw-text: #1a1a18;
  --pnw-muted: #6b6b67;
  --pnw-border: rgba(0,0,0,0.1);
  --pnw-border-h: rgba(0,0,0,0.2);
  --pnw-blue: #185FA5;
  --pnw-blue-bg: #E6F1FB;
  --pnw-blue-text: #0C447C;
  --pnw-green: #1D9E75;
  --pnw-green-bg: #EAF3DE;
  --pnw-green-text: #27500A;
  --pnw-amber-bg: #FAEEDA;
  --pnw-amber-text: #633806;
  --pnw-purple-bg: #EEEDFE;
  --pnw-purple-text: #3C3489;
  --pnw-teal-bg: #E1F5EE;
  --pnw-teal-text: #085041;
  --pnw-r: 10px;
  --pnw-rs: 6px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  background: var(--pnw-bg);
  border: 1px solid var(--pnw-border);
  border-radius: var(--pnw-r);
  overflow: hidden;
  max-width: 480px;
  width: 100%;
  box-sizing: border-box;
}

@media (prefers-color-scheme: dark) {
  .pnw-widget {
    --pnw-bg: #1e1e1c;
    --pnw-bg2: #2a2a27;
    --pnw-text: #f0efe9;
    --pnw-muted: #999993;
    --pnw-border: rgba(255,255,255,0.1);
    --pnw-border-h: rgba(255,255,255,0.2);
    --pnw-blue-bg: #0c2d52;
    --pnw-blue-text: #85B7EB;
    --pnw-green-bg: #0a2d1a;
    --pnw-green-text: #97C459;
    --pnw-amber-bg: #2d1e07;
    --pnw-amber-text: #FAC775;
    --pnw-purple-bg: #1e1c40;
    --pnw-purple-text: #AFA9EC;
    --pnw-teal-bg: #042d20;
    --pnw-teal-text: #5DCAA5;
  }
}

.pnw-widget *, .pnw-widget *::before, .pnw-widget *::after { box-sizing: border-box; }

.pnw-header {
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--pnw-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--pnw-bg);
}
.pnw-header-left { display: flex; align-items: center; gap: 10px; }
.pnw-icon {
  width: 32px; height: 32px;
  background: var(--pnw-blue-bg);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pnw-icon svg { width: 16px; height: 16px; stroke: var(--pnw-blue-text); }
.pnw-title { font-size: 14px; font-weight: 600; color: var(--pnw-text); letter-spacing: -0.01em; }
.pnw-sub { font-size: 11px; color: var(--pnw-muted); margin-top: 1px; }

.pnw-refresh {
  display: flex; align-items: center; gap: 4px;
  font-size: 11px; color: var(--pnw-muted);
  background: var(--pnw-bg2);
  border: 1px solid var(--pnw-border);
  border-radius: 999px;
  padding: 4px 10px;
  cursor: pointer;
  transition: all 0.15s;
}
.pnw-refresh:hover { border-color: var(--pnw-border-h); color: var(--pnw-text); }
.pnw-refresh svg { width: 12px; height: 12px; }
.pnw-refresh.pnw-spinning svg { animation: pnw-spin 0.8s linear infinite; }
@keyframes pnw-spin { to { transform: rotate(360deg); } }

.pnw-filters {
  display: flex; gap: 5px; padding: 10px 16px;
  border-bottom: 1px solid var(--pnw-border);
  background: var(--pnw-bg2);
  overflow-x: auto; scrollbar-width: none;
}
.pnw-filters::-webkit-scrollbar { display: none; }

.pnw-chip {
  white-space: nowrap; font-size: 11px;
  padding: 3px 10px; border-radius: 999px;
  border: 1px solid var(--pnw-border);
  background: var(--pnw-bg);
  color: var(--pnw-muted);
  cursor: pointer; transition: all 0.12s;
}
.pnw-chip:hover { border-color: var(--pnw-border-h); }
.pnw-chip--active { background: var(--pnw-blue); border-color: var(--pnw-blue); color: #fff; }

.pnw-list { background: var(--pnw-bg); }

.pnw-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--pnw-border);
  cursor: pointer;
  transition: background 0.1s;
}
.pnw-item:last-child { border-bottom: none; }
.pnw-item:hover { background: var(--pnw-bg2); }

.pnw-item-top { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 5px; }

.pnw-tag {
  font-size: 10px; font-weight: 600;
  padding: 2px 7px; border-radius: 999px;
  flex-shrink: 0; margin-top: 1px;
  letter-spacing: 0.02em; text-transform: uppercase;
}
.pnw-tag--pensioen   { background: var(--pnw-blue-bg);   color: var(--pnw-blue-text); }
.pnw-tag--financieel { background: var(--pnw-green-bg);  color: var(--pnw-green-text); }
.pnw-tag--rente      { background: var(--pnw-amber-bg);  color: var(--pnw-amber-text); }
.pnw-tag--wetgeving  { background: var(--pnw-purple-bg); color: var(--pnw-purple-text); }
.pnw-tag--aow        { background: var(--pnw-teal-bg);   color: var(--pnw-teal-text); }

.pnw-item-title { font-size: 13px; font-weight: 500; color: var(--pnw-text); line-height: 1.4; flex: 1; }

.pnw-item-summary {
  font-size: 12px; color: var(--pnw-muted);
  line-height: 1.5; margin-bottom: 6px;
  display: none;
}
.pnw-item--open .pnw-item-summary { display: block; }

.pnw-item-meta { display: flex; align-items: center; justify-content: space-between; }
.pnw-source { font-size: 11px; color: var(--pnw-muted); display: flex; align-items: center; gap: 4px; }
.pnw-source svg { width: 10px; height: 10px; }
.pnw-toggle { font-size: 11px; color: var(--pnw-blue); display: flex; align-items: center; gap: 2px; }
.pnw-toggle svg { width: 10px; height: 10px; transition: transform 0.15s; }
.pnw-item--open .pnw-toggle svg { transform: rotate(180deg); }

.pnw-skel { background: var(--pnw-bg); }
.pnw-skel-item { padding: 12px 16px; border-bottom: 1px solid var(--pnw-border); }
.pnw-bone {
  background: var(--pnw-border);
  border-radius: 4px;
  animation: pnw-shimmer 1.2s ease-in-out infinite;
}
@keyframes pnw-shimmer { 0%,100%{opacity:.5} 50%{opacity:1} }

.pnw-footer {
  padding: 10px 16px;
  background: var(--pnw-bg2);
  border-top: 1px solid var(--pnw-border);
  display: flex; align-items: center; justify-content: space-between;
}
.pnw-live { font-size: 11px; color: var(--pnw-muted); display: flex; align-items: center; gap: 5px; }
.pnw-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--pnw-green);
  animation: pnw-pulse 2s ease-in-out infinite;
}
@keyframes pnw-pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.pnw-more { font-size: 11px; color: var(--pnw-blue); text-decoration: none; }
.pnw-more:hover { text-decoration: underline; }

.pnw-error { padding: 20px; text-align: center; font-size: 12px; color: var(--pnw-muted); }
.pnw-error button {
  display: block; margin: 8px auto 0;
  font-size: 12px; color: var(--pnw-blue);
  background: none; border: none; cursor: pointer; text-decoration: underline;
}
