/* ==========================================================================
   VPNTotaal Plugin CSS: widget + resultaten
   ========================================================================== */

.vpnt-app {
  --vpnt-app-radius: var(--vpnt-radius, 18px);
  --vpnt-app-border: var(--vpnt-border, #E2E8F0);
  --vpnt-app-coral: var(--vpnt-coral, #FF6B47);
  --vpnt-app-navy: var(--vpnt-navy, #0F172A);
  --vpnt-app-teal: var(--vpnt-teal, #0EA5E9);
  --vpnt-app-ink: var(--vpnt-ink, #1B2332);
  --vpnt-app-muted: var(--vpnt-muted, #64748B);
  --vpnt-app-surface: var(--vpnt-surface, #F8FAFC);
  font-family: var(--vpnt-font, 'Plus Jakarta Sans', system-ui, sans-serif);
}

/* Widget */
.vpnt-widget {
  background: #fff;
  border-radius: var(--vpnt-app-radius);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.vpnt-widget__head { text-align: center; }
.vpnt-widget__title { font-size: 1.2rem; font-weight: 800; color: var(--vpnt-app-ink); }
.vpnt-widget__note { text-align: center; font-size: .82rem; color: var(--vpnt-app-muted); margin: 0; }

.vpnt-field { display: flex; flex-direction: column; gap: 6px; }
.vpnt-field__label { font-weight: 700; font-size: .92rem; color: var(--vpnt-app-ink); }
.vpnt-field label { font-weight: 700; font-size: .92rem; color: var(--vpnt-app-ink); }
.vpnt-field select {
  width: 100%; padding: 12px 14px; border: 1.5px solid var(--vpnt-app-border);
  border-radius: 10px; font-size: 1rem; background: #fff; color: var(--vpnt-app-ink);
  appearance: auto;
}
.vpnt-field select:focus { outline: 2px solid var(--vpnt-app-teal); border-color: transparent; }

/* Pills */
.vpnt-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.vpnt-pill-btn {
  padding: 8px 16px; border: 1.5px solid var(--vpnt-app-border); border-radius: 999px;
  background: #fff; color: var(--vpnt-app-ink); font-weight: 700; font-size: .88rem;
  cursor: pointer; transition: all .12s ease;
}
.vpnt-pill-btn:hover { border-color: var(--vpnt-app-teal); color: var(--vpnt-app-teal); }
.vpnt-pill-btn[aria-pressed="true"] {
  background: var(--vpnt-app-navy); border-color: var(--vpnt-app-navy); color: #fff;
}
.vpnt-pills--sm .vpnt-pill-btn { padding: 6px 12px; font-size: .82rem; }

/* Submit */
.vpnt-btn-submit {
  width: 100%; padding: 16px; border: none; border-radius: 999px;
  background: var(--vpnt-app-coral); color: #fff; font-weight: 800; font-size: 1.05rem;
  cursor: pointer; transition: background .12s, transform .08s;
  box-shadow: 0 8px 20px rgba(255,107,71,.32);
}
.vpnt-btn-submit:hover { background: #E5593A; transform: translateY(-1px); }

/* Range */
.vpnt-range { width: 100%; accent-color: var(--vpnt-app-teal); }
.vpnt-range__minmax { display: flex; justify-content: space-between; font-size: .78rem; color: var(--vpnt-app-muted); }

/* Checks list */
.vpnt-checks-list { display: flex; flex-direction: column; gap: 6px; }
.vpnt-checks-list label { display: flex; align-items: center; gap: 8px; font-size: .9rem; color: var(--vpnt-app-ink); cursor: pointer; }

/* Results layout: filter-sidebar + main */
.vpnt-results { display: grid; grid-template-columns: 280px 1fr; gap: 28px; align-items: start; }

/* ---- Filter sidebar ---- */
.vpnt-filters {
  background: #fff; border: 1px solid var(--vpnt-app-border); border-radius: var(--vpnt-app-radius);
  padding: 22px 20px;
  display: flex; flex-direction: column; gap: 22px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 8px 24px rgba(15,23,42,.05);
}
.vpnt-filters__head { display: flex; align-items: center; justify-content: space-between; }
.vpnt-filters__title { font-size: 1.05rem; font-weight: 800; color: var(--vpnt-app-ink); margin: 0; }
.vpnt-filters__reset { background: none; border: none; padding: 0; font-size: .82rem; font-weight: 700; color: var(--vpnt-app-teal); cursor: pointer; }
.vpnt-filters__reset:hover { text-decoration: underline; }

.vpnt-fgroup { display: flex; flex-direction: column; gap: 10px; padding-bottom: 20px; border-bottom: 1px solid var(--vpnt-app-border); }
.vpnt-fgroup:last-child { padding-bottom: 0; border-bottom: none; }
.vpnt-fgroup__label { font-size: .82rem; font-weight: 800; color: var(--vpnt-app-ink); text-transform: uppercase; letter-spacing: .04em; }

.vpnt-pills { display: flex; flex-wrap: wrap; gap: 7px; }
.vpnt-pill-btn {
  padding: 7px 13px; border: 1.5px solid var(--vpnt-app-border); border-radius: 999px;
  background: #fff; color: var(--vpnt-app-ink); font-weight: 700; font-size: .82rem;
  cursor: pointer; transition: all .12s ease;
}
.vpnt-pill-btn:hover { border-color: var(--vpnt-app-teal); color: var(--vpnt-app-teal); }
.vpnt-pill-btn[aria-pressed="true"] { background: var(--vpnt-app-navy); border-color: var(--vpnt-app-navy); color: #fff; }

/* Doel-lijst (Ik wil een VPN voor) */
.vpnt-doellist { display: flex; flex-direction: column; gap: 8px; }
.vpnt-doel {
  display: flex; align-items: center; gap: 12px; width: 100%;
  background: #fff; border: 1.5px solid var(--vpnt-app-border); border-radius: 12px;
  padding: 11px 13px; cursor: pointer; text-align: left;
  transition: border-color .12s, box-shadow .12s, background .12s;
}
.vpnt-doel:hover { border-color: var(--vpnt-app-teal); box-shadow: 0 2px 8px rgba(15,23,42,.06); }
.vpnt-doel__icon { flex-shrink: 0; width: 30px; height: 30px; display: grid; place-items: center; color: var(--vpnt-app-navy); }
.vpnt-doel__label { flex: 1; font-weight: 700; font-size: .95rem; color: var(--vpnt-app-ink); }
.vpnt-doel__check { flex-shrink: 0; color: #D5DBE3; display: grid; place-items: center; transition: color .12s, transform .12s; }
.vpnt-doel:hover .vpnt-doel__check { color: #B9C2CE; }
.vpnt-doel[aria-pressed="true"] { border-color: var(--vpnt-green, #22C55E); background: #F0FDF4; box-shadow: 0 2px 10px rgba(34,197,94,.14); }
.vpnt-doel[aria-pressed="true"] .vpnt-doel__check { color: var(--vpnt-green, #22C55E); transform: scale(1.05); }
.vpnt-doel[aria-pressed="true"] .vpnt-doel__icon { color: var(--vpnt-green-dark, #16A34A); }

.vpnt-range-val { font-size: 1.35rem; font-weight: 900; color: var(--vpnt-app-navy); }
.vpnt-range { width: 100%; accent-color: var(--vpnt-app-coral); }
.vpnt-range__minmax { display: flex; justify-content: space-between; font-size: .74rem; color: var(--vpnt-app-muted); }

.vpnt-checks-list { display: flex; flex-direction: column; gap: 4px; }
.vpnt-check { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--vpnt-app-ink); cursor: pointer; padding: 6px 8px; border-radius: 8px; transition: background .12s; }
.vpnt-check:hover { background: var(--vpnt-app-surface); }
.vpnt-check input { width: 17px; height: 17px; accent-color: var(--vpnt-app-teal); cursor: pointer; }

.vpnt-filters__mobtoggle { display: none; }

/* ---- Results header ---- */
.vpnt-results__bar { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.vpnt-results__heading { font-size: 1.5rem; margin: 0; }
.vpnt-results__count { font-size: .9rem; color: var(--vpnt-app-muted); margin: 4px 0 0; }
.vpnt-results__sort { display: flex; align-items: center; gap: 8px; }
.vpnt-results__sort label { font-size: .85rem; font-weight: 600; color: var(--vpnt-app-muted); }
.vpnt-results__sort select { padding: 9px 12px; border: 1.5px solid var(--vpnt-app-border); border-radius: 10px; font-size: .9rem; background: #fff; color: var(--vpnt-app-ink); font-weight: 600; }
.vpnt-results__disclaimer { font-size: .82rem; color: var(--vpnt-app-muted); margin-top: 20px; }

.vpnt-cards { display: flex; flex-direction: column; gap: 16px; }

/* ---- Ranking card (VPN.nl-stijl) ---- */
.vpnt-rcard {
  position: relative; background: #fff; border: 1px solid var(--vpnt-app-border); border-radius: var(--vpnt-app-radius);
  padding: 26px 28px 20px; display: grid; grid-template-columns: 150px 1fr 200px; gap: 28px; align-items: center;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 6px 18px rgba(15,23,42,.05);
  transition: box-shadow .15s, border-color .15s, transform .12s;
}
.vpnt-rcard:hover { box-shadow: 0 6px 28px rgba(15,23,42,.12); transform: translateY(-2px); }
.vpnt-rcard--top { border: 2px solid var(--vpnt-app-coral); box-shadow: 0 8px 30px rgba(255,107,71,.14); }

.vpnt-rcard__rank {
  position: absolute; top: -12px; left: -12px; z-index: 2;
  width: 34px; height: 34px; border-radius: 10px;
  background: var(--vpnt-app-navy); color: #fff; font-weight: 900; font-size: 1rem;
  display: grid; place-items: center; box-shadow: 0 4px 10px rgba(15,23,42,.25);
}
.vpnt-rcard--top .vpnt-rcard__rank { background: var(--vpnt-app-coral); }

.vpnt-rcard__brand { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.vpnt-rcard__logo { width: 108px; height: 84px; border: 1px solid var(--vpnt-app-border); border-radius: 14px; background: #fff; display: grid; place-items: center; overflow: hidden; padding: 10px; }
.vpnt-rcard__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.vpnt-rcard__initials { font-weight: 900; font-size: 2rem; color: var(--vpnt-app-teal); }
.vpnt-rcard__score { display: inline-flex; align-items: center; gap: 6px; }
.vpnt-rcard__score strong { font-size: 1.35rem; font-weight: 900; color: var(--vpnt-app-ink); }
.vpnt-rcard__scorelabel { font-size: .72rem; font-weight: 700; color: var(--vpnt-app-muted); text-transform: uppercase; letter-spacing: .05em; }

.vpnt-rcard__body { min-width: 0; }
.vpnt-rcard__titlerow { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.vpnt-rcard__name { margin: 0; font-size: 1.5rem; font-weight: 900; }
.vpnt-rcard__name a { color: var(--vpnt-app-ink); text-decoration: none; }
.vpnt-rcard__name a:hover { color: var(--vpnt-app-teal); }
.vpnt-rcard__pill { background: #EC4899; color: #fff; font-weight: 800; font-size: .78rem; padding: 5px 14px; border-radius: 999px; white-space: nowrap; }

.vpnt-rcard__benefits { list-style: none; margin: 0; padding: 0; display: grid; gap: 9px; }
.vpnt-rcard__benefits li { display: flex; align-items: center; gap: 11px; font-size: .98rem; color: var(--vpnt-app-ink); }
.vpnt-rcard__benefits li svg { flex-shrink: 0; }
.vpnt-rcard__benefits li:last-child { font-weight: 700; }

.vpnt-rcard__cta { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.vpnt-rcard__price { text-align: center; line-height: 1.1; }
.vpnt-rcard__price strong { font-size: 1.9rem; font-weight: 900; color: var(--vpnt-app-ink); }
.vpnt-rcard__price small { display: inline; font-size: .8rem; font-weight: 600; color: var(--vpnt-app-muted); margin-left: 3px; }
.vpnt-btn-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 30px; border-radius: 12px; width: 100%;
  background: var(--vpnt-app-coral); color: #fff; font-weight: 800; font-size: 1.02rem;
  text-decoration: none; white-space: nowrap;
  transition: background .12s, transform .08s; box-shadow: 0 8px 18px rgba(255,107,71,.3);
}
.vpnt-btn-cta:hover { background: #E5593A; transform: translateY(-1px); text-decoration: none; color: #fff; }

.vpnt-rcard__more {
  grid-column: 1 / -1; justify-self: center; margin-top: 4px;
  background: #fff; border: 1.5px solid var(--vpnt-app-border); border-radius: 999px;
  padding: 9px 26px; font-weight: 800; font-size: .9rem; color: var(--vpnt-app-navy); cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px; transition: border-color .12s, color .12s;
}
.vpnt-rcard__more:hover { border-color: var(--vpnt-app-navy); }
.vpnt-rcard__more-i { transition: transform .15s; }
.vpnt-rcard__more.is-open .vpnt-rcard__more-i { transform: rotate(180deg); }

/* ---- Details paneel ---- */
.vpnt-rcard__details { grid-column: 1 / -1; margin-top: 8px; padding-top: 20px; border-top: 1px solid var(--vpnt-app-border); }
.vpnt-detail-sam { font-style: italic; color: var(--vpnt-app-ink); margin: 0 0 18px; font-size: 1rem; }
.vpnt-detail-scores { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px 24px; margin-bottom: 18px; }
@media (max-width: 900px) { .vpnt-detail-scores { grid-template-columns: 1fr 1fr; } }
.vpnt-mini-bar { display: flex; align-items: center; gap: 8px; }
.vpnt-mini-bar__label { font-size: .78rem; color: var(--vpnt-app-muted); min-width: 54px; }
.vpnt-mini-bar__track { flex: 1; height: 6px; background: #F1F5F9; border-radius: 3px; overflow: hidden; }
.vpnt-mini-bar__fill { height: 100%; border-radius: 3px; transition: width .3s ease; }
.vpnt-mini-bar__val { font-size: .78rem; font-weight: 700; color: var(--vpnt-app-ink); min-width: 24px; text-align: right; }

.vpnt-werktmet { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.vpnt-werktmet__label { font-size: .74rem; font-weight: 700; color: var(--vpnt-app-muted); text-transform: uppercase; letter-spacing: .04em; margin-right: 4px; }
.vpnt-wm-chip { background: var(--vpnt-app-surface); border: 1px solid var(--vpnt-app-border); color: var(--vpnt-app-ink); font-size: .78rem; font-weight: 600; padding: 3px 10px; border-radius: 999px; }

.vpnt-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 700px) { .vpnt-detail-grid { grid-template-columns: 1fr; gap: 16px; } }
.vpnt-detail-h { display: block; font-size: .9rem; margin: 0 0 6px; }
.vpnt-detail-h--plus { color: var(--vpnt-green-dark, #16A34A); }
.vpnt-detail-h--min { color: #EF4444; margin-top: 14px; }
.vpnt-pc-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 5px; }
.vpnt-pc-list li { position: relative; padding-left: 22px; font-size: .9rem; color: var(--vpnt-app-ink); }
.vpnt-pc-plus::before { content: "\2713"; position: absolute; left: 0; color: var(--vpnt-green-dark, #16A34A); font-weight: 800; }
.vpnt-pc-min::before { content: "\2715"; position: absolute; left: 0; color: #EF4444; font-weight: 800; }
.vpnt-detail-row { display: flex; justify-content: space-between; gap: 12px; padding: 7px 0; border-bottom: 1px solid var(--vpnt-app-border); font-size: .9rem; }
.vpnt-detail-row span { color: var(--vpnt-app-muted); }
.vpnt-detail-row strong { color: var(--vpnt-app-ink); text-align: right; }
.vpnt-detail-chips { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.vpnt-detail-sub { display: block; width: 100%; font-size: .78rem; font-weight: 700; color: var(--vpnt-app-muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 2px; }
.vpnt-detail-review { display: inline-block; margin-top: 16px; font-weight: 700; color: var(--vpnt-app-teal); font-size: .9rem; }

.vpnt-no-results { text-align: center; padding: 40px 20px; color: var(--vpnt-app-muted); font-size: 1rem; }

/* Laad meer */
.vpnt-loadmore-wrap { display: flex; justify-content: center; margin-top: 22px; }
.vpnt-loadmore {
  background: #fff; border: 2px solid var(--vpnt-app-navy); border-radius: 999px;
  padding: 14px 34px; font-weight: 800; font-size: 1rem; color: var(--vpnt-app-navy); cursor: pointer;
  transition: background .12s, color .12s;
}
.vpnt-loadmore:hover { background: var(--vpnt-app-navy); color: #fff; }
.vpnt-loadmore span { opacity: .7; font-weight: 700; }

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .vpnt-results { grid-template-columns: 1fr; }
  .vpnt-filters { position: static; }
  .vpnt-filters { display: none; }
  .vpnt-filters.is-open { display: flex; }
  .vpnt-filters__mobtoggle {
    display: inline-flex; align-items: center; gap: 8px; margin-bottom: 16px;
    background: var(--vpnt-app-navy); color: #fff; border: none; border-radius: 10px;
    padding: 12px 20px; font-weight: 800; font-size: .95rem; cursor: pointer;
  }
}
@media (max-width: 720px) {
  .vpnt-rcard { grid-template-columns: 1fr; gap: 16px; text-align: center; padding: 24px 18px 18px; }
  .vpnt-rcard__brand { flex-direction: row; justify-content: center; gap: 14px; }
  .vpnt-rcard__logo { width: 80px; height: 64px; }
  .vpnt-rcard__titlerow { justify-content: center; }
  .vpnt-rcard__benefits li { justify-content: flex-start; text-align: left; }
  .vpnt-rcard__cta { max-width: 280px; margin: 0 auto; width: 100%; }
}

/* ==========================================================================
   Review page (single-vpnt_aanbieder)
   ========================================================================== */

.vpnt-review-hero {
  display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items: start;
  background: var(--vpnt-app-surface); border: 1px solid var(--vpnt-app-border);
  border-radius: var(--vpnt-app-radius, 18px); padding: 32px; margin-bottom: 32px;
}
.vpnt-review-hero__brand { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.vpnt-review-hero__logo { width: 64px; height: 64px; object-fit: contain; border-radius: 14px; background: #fff; padding: 6px; }
.vpnt-review-hero__right { display: flex; flex-direction: column; align-items: center; gap: 20px; }
.vpnt-review-hero__bars { width: 100%; max-width: 280px; display: flex; flex-direction: column; gap: 8px; }
@media (max-width: 760px) {
  .vpnt-review-hero { grid-template-columns: 1fr; gap: 24px; }
  .vpnt-review-hero__right { flex-direction: row; flex-wrap: wrap; justify-content: center; }
  .vpnt-review-hero__bars { max-width: none; }
}

.vpnt-review-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.vpnt-review-pros ul, .vpnt-review-cons ul { margin: 8px 0 0; padding-left: 18px; font-size: .92rem; }
.vpnt-review-pros li { color: var(--vpnt-green-dark, #16A34A); }
.vpnt-review-cons li { color: #EF4444; }
@media (max-width: 560px) { .vpnt-review-proscons { grid-template-columns: 1fr; } }

.vpnt-specs-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px;
  background: var(--vpnt-app-border); border: 1px solid var(--vpnt-app-border);
  border-radius: var(--vpnt-app-radius, 18px); overflow: hidden; margin-bottom: 32px;
}
.vpnt-spec { background: #fff; padding: 18px 14px; text-align: center; }
.vpnt-spec__label { display: block; font-size: .75rem; color: var(--vpnt-app-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.vpnt-spec__val { font-weight: 800; font-size: 1.05rem; color: var(--vpnt-app-ink); }
@media (max-width: 760px) { .vpnt-specs-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .vpnt-specs-grid { grid-template-columns: repeat(2, 1fr); } }

.vpnt-review-section { margin: 32px 0; }
.vpnt-review-section h2 { font-size: 1.3rem; margin: 0 0 16px; }

.vpnt-review-table { width: 100%; border-collapse: collapse; }
.vpnt-review-table th, .vpnt-review-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--vpnt-app-border); font-size: .95rem; }
.vpnt-review-table th { background: var(--vpnt-app-surface); font-weight: 700; }
.vpnt-review-table td:first-child { color: var(--vpnt-app-muted); min-width: 160px; }

.vpnt-expert-quote {
  border-left: 4px solid var(--vpnt-app-teal, #0EA5E9); background: var(--vpnt-app-surface);
  padding: 20px 24px; border-radius: 0 12px 12px 0; margin: 0;
  font-size: 1.05rem; font-style: italic; color: var(--vpnt-app-ink);
}
.vpnt-expert-quote p { margin: 0; }

/* ==========================================================================
   Review-pagina v2 (VPN.nl-stijl)
   ========================================================================== */
.vpnt-review-grid { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; margin-top: 8px; }
.vpnt-review-main { min-width: 0; }
@media (max-width: 980px) { .vpnt-review-grid { grid-template-columns: 1fr; } .vpnt-rev-aside { display: none; } }

/* Sticky CTA */
.vpnt-rev-aside { position: sticky; top: 90px; }
.vpnt-rev-cta { background: #fff; border: 1px solid var(--vpnt-app-border); border-radius: var(--vpnt-app-radius); padding: 24px; text-align: center; box-shadow: 0 8px 30px rgba(15,23,42,.08); display: flex; flex-direction: column; align-items: center; gap: 12px; }
.vpnt-rev-cta__logo { width: 100%; height: 64px; display: grid; place-items: center; overflow: hidden; }
.vpnt-rev-cta__logo img { max-width: 150px; max-height: 64px; width: auto; height: auto; object-fit: contain; }
.vpnt-rev-cta__score { width: 52px; height: 52px; border-radius: 50%; border: 3px solid; display: grid; place-items: center; font-weight: 900; font-size: 1.2rem; color: var(--vpnt-app-ink); }
.vpnt-rev-cta__price strong { font-size: 1.7rem; font-weight: 900; color: var(--vpnt-app-ink); }
.vpnt-rev-cta__price small { font-size: .8rem; color: var(--vpnt-app-muted); font-weight: 600; }
.vpnt-rev-cta__note { font-size: .8rem; color: var(--vpnt-app-muted); margin: 0; }
.vpnt-btn-cta--block { width: 100%; }

/* Header */
.vpnt-rev-header { display: flex; gap: 22px; align-items: center; margin: 12px 0 24px; }
.vpnt-rev-header__logo { width: 96px; height: 96px; flex-shrink: 0; border: 1px solid var(--vpnt-app-border); border-radius: 16px; background: #fff; display: grid; place-items: center; padding: 12px; }
.vpnt-rev-header__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.vpnt-rev-initials { font-weight: 900; font-size: 2.4rem; color: var(--vpnt-app-teal); }
.vpnt-rev-header__intro h1 { margin: 0 0 8px; }
.vpnt-rev-header__meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.vpnt-rev-score { width: 44px; height: 44px; border-radius: 50%; border: 3px solid; display: grid; place-items: center; font-weight: 900; color: var(--vpnt-app-ink); }
.vpnt-rev-score__label { font-size: .8rem; font-weight: 700; color: var(--vpnt-app-muted); text-transform: uppercase; letter-spacing: .04em; }
.vpnt-rev-header__reviews { display: inline-flex; align-items: center; gap: 8px; font-size: .9rem; }
.vpnt-rev-header__reviews a { color: var(--vpnt-app-teal); font-weight: 700; }
.vpnt-rev-header__sub { margin: 10px 0 0; color: var(--vpnt-app-muted); font-size: 1.02rem; }

/* Pros/cons */
.vpnt-rev-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 28px; }
.vpnt-rev-pros, .vpnt-rev-cons { background: var(--vpnt-app-surface); border-radius: 14px; padding: 18px 20px; }
.vpnt-rev-pros h2, .vpnt-rev-cons h2 { font-size: 1rem; margin: 0 0 10px; }
.vpnt-rev-pros h2 { color: var(--vpnt-green-dark, #16A34A); }
.vpnt-rev-cons h2 { color: #EF4444; }
.vpnt-rev-pros ul, .vpnt-rev-cons ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 7px; }
.vpnt-rev-pros li, .vpnt-rev-cons li { position: relative; padding-left: 24px; font-size: .92rem; }
.vpnt-rev-pros li::before { content: "\2713"; position: absolute; left: 0; color: var(--vpnt-green-dark, #16A34A); font-weight: 800; }
.vpnt-rev-cons li::before { content: "\2715"; position: absolute; left: 0; color: #EF4444; font-weight: 800; }
@media (max-width: 600px) { .vpnt-rev-proscons { grid-template-columns: 1fr; } .vpnt-rev-header { flex-direction: column; text-align: center; } }

/* TOC */
.vpnt-toc-box { background: var(--vpnt-navy-050, #F1F5F9); border: 1px solid var(--vpnt-app-border); border-radius: 14px; padding: 4px 22px; margin-bottom: 30px; }
.vpnt-toc-box summary { cursor: pointer; font-weight: 800; color: var(--vpnt-app-ink); padding: 16px 0; list-style: none; }
.vpnt-toc-box summary::-webkit-details-marker { display: none; }
.vpnt-toc-box summary::before { content: "\25B8"; display: inline-block; margin-right: 10px; transition: transform .15s; color: var(--vpnt-app-teal); }
.vpnt-toc-box[open] summary::before { transform: rotate(90deg); }
.vpnt-toc-list { margin: 0 0 16px; padding-left: 30px; display: grid; gap: 7px; }
.vpnt-toc-list a { color: var(--vpnt-app-ink); font-weight: 600; font-size: .95rem; }
.vpnt-toc-list a:hover { color: var(--vpnt-app-teal); }

/* Secties */
.vpnt-rev-section { margin: 36px 0; scroll-margin-top: 90px; }
.vpnt-rev-section > h2 { font-size: 1.45rem; margin: 0 0 16px; }
.vpnt-rev-scores { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 32px; }
@media (max-width: 600px) { .vpnt-rev-scores { grid-template-columns: 1fr; } }
.vpnt-rev-note { font-size: .88rem; color: var(--vpnt-app-muted); margin-top: 10px; }

/* Sterren */
.vpnt-stars { display: inline-flex; gap: 2px; }
.vpnt-star { width: var(--vpnt-star-size, 18px); height: var(--vpnt-star-size, 18px); fill: #D5DBE3; }
.vpnt-star.is-full { fill: #FBBF24; }
.vpnt-star.is-half { fill: url(#vpnt-half); }
.vpnt-star.is-half { fill: #FBBF24; clip-path: inset(0 50% 0 0); }

/* Reviews */
.vpnt-rev-agg { display: flex; align-items: center; gap: 20px; background: var(--vpnt-app-surface); border-radius: 14px; padding: 22px 24px; margin-bottom: 22px; }
.vpnt-rev-agg__num { font-size: 2.6rem; font-weight: 900; color: var(--vpnt-app-ink); line-height: 1; }
.vpnt-rev-agg p { margin: 4px 0 0; color: var(--vpnt-app-muted); font-size: .9rem; }
.vpnt-rev-list { display: flex; flex-direction: column; gap: 16px; }
.vpnt-rev-item { border: 1px solid var(--vpnt-app-border); border-radius: 14px; padding: 18px 20px; }
.vpnt-rev-item__head { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.vpnt-rev-item__avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--vpnt-app-navy); color: #fff; display: grid; place-items: center; font-weight: 800; flex-shrink: 0; }
.vpnt-rev-item__head strong { display: block; font-size: .92rem; color: var(--vpnt-app-ink); }
.vpnt-rev-item__head time { margin-left: auto; font-size: .8rem; color: var(--vpnt-app-muted); }
.vpnt-rev-item__title { font-size: 1rem; margin: 0 0 4px; }
.vpnt-rev-item__text { margin: 0; font-size: .93rem; color: var(--vpnt-app-text, #334155); }
.vpnt-rev-list + .vpnt-loadmore { margin: 20px auto 0; display: block; }

/* Expert */
.vpnt-expert { display: flex; gap: 18px; background: linear-gradient(135deg, var(--vpnt-app-navy), #0B1120); color: #fff; border-radius: 16px; padding: 24px; margin-bottom: 20px; }
.vpnt-expert__avatar { width: 54px; height: 54px; border-radius: 50%; background: var(--vpnt-app-coral); color: #fff; display: grid; place-items: center; font-weight: 900; flex-shrink: 0; overflow: hidden; }
.vpnt-expert__avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.vpnt-expert__label { font-size: .78rem; text-transform: uppercase; letter-spacing: .05em; color: rgba(255,255,255,.7); font-weight: 700; }
.vpnt-expert blockquote { margin: 6px 0 8px; font-size: 1.05rem; font-style: italic; line-height: 1.5; }
.vpnt-expert__name { display: inline-block; font-size: .9rem; color: #fff; font-weight: 800; }
.vpnt-expert__name:hover { color: #fff; text-decoration: underline; }
.vpnt-expert__title { display: block; font-size: .8rem; color: rgba(255,255,255,.6); }

/* Laatst bijgewerkt + categorie-beoordeling */
.vpnt-rev-updated { margin: 8px 0 0; font-size: .85rem; color: var(--vpnt-app-muted); }
.vpnt-cats { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 640px) { .vpnt-cats { grid-template-columns: 1fr; } }
.vpnt-cat { border: 1px solid var(--vpnt-app-border); border-radius: 14px; padding: 18px 20px; }
.vpnt-cat__head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vpnt-cat__num { width: 26px; height: 26px; border-radius: 8px; background: var(--vpnt-app-navy); color: #fff; font-weight: 800; font-size: .85rem; display: grid; place-items: center; flex-shrink: 0; }
.vpnt-cat__title { margin: 0; font-size: 1.05rem; flex: 1; }
.vpnt-cat__score { font-weight: 900; font-size: 1.25rem; }
.vpnt-cat__score small { font-size: .62em; font-weight: 700; color: var(--vpnt-app-muted); }
.vpnt-cat__track { height: 8px; background: #F1F5F9; border-radius: 4px; overflow: hidden; margin-bottom: 12px; }
.vpnt-cat__fill { display: block; height: 100%; border-radius: 4px; }
.vpnt-cat__text { margin: 0; font-size: .92rem; color: var(--vpnt-app-text, #334155); line-height: 1.55; }

/* Review v2: extra's (beste-voor, quotes, deal, trust, verdict, alternatieven) */
.vpnt-rev-bestevoor { display: inline-block; background: rgba(255,107,71,.12); color: var(--vpnt-app-coral); font-weight: 800; font-size: .78rem; padding: 4px 12px; border-radius: 999px; margin-bottom: 8px; text-transform: uppercase; letter-spacing: .03em; }
.vpnt-rev-quotes { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 4px 0 28px; }
@media (max-width: 600px) { .vpnt-rev-quotes { grid-template-columns: 1fr; } }
.vpnt-rev-quote { margin: 0; background: var(--vpnt-app-surface); border-radius: 14px; padding: 18px 20px; }
.vpnt-rev-quote blockquote { margin: 8px 0 8px; font-size: .95rem; color: var(--vpnt-app-ink); line-height: 1.5; }
.vpnt-rev-quote figcaption { font-size: .82rem; font-weight: 700; color: var(--vpnt-app-muted); }

.vpnt-rev-cta__deal { background: var(--vpnt-app-coral); color: #fff; font-weight: 800; font-size: .85rem; padding: 5px 14px; border-radius: 999px; }
.vpnt-rev-cta__trust { list-style: none; margin: 4px 0 0; padding: 0; display: flex; flex-direction: column; gap: 5px; }
.vpnt-rev-cta__trust li { font-size: .82rem; color: var(--vpnt-green-dark, #16A34A); font-weight: 600; }
.vpnt-rev-cta__pay { font-size: .74rem; color: var(--vpnt-app-muted); font-weight: 600; }

.vpnt-rev-verdict { background: var(--vpnt-navy-050, #F1F5F9); border-left: 4px solid var(--vpnt-app-coral); border-radius: 0 12px 12px 0; padding: 16px 20px; font-size: 1.05rem; line-height: 1.55; color: var(--vpnt-app-ink); margin-bottom: 20px; }

.vpnt-alts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 700px) { .vpnt-alts { grid-template-columns: 1fr; } }
.vpnt-alt { border: 1px solid var(--vpnt-app-border); border-radius: 14px; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.vpnt-alt__logo { height: 42px; display: flex; align-items: center; }
.vpnt-alt__logo img { max-height: 42px; max-width: 120px; width: auto; object-fit: contain; }
.vpnt-alt__body { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vpnt-alt__body strong { font-size: 1rem; color: var(--vpnt-app-ink); }
.vpnt-alt__score { font-weight: 900; }
.vpnt-alt__links { display: flex; gap: 14px; font-size: .85rem; font-weight: 700; }
.vpnt-alt__links a:first-child { color: var(--vpnt-app-teal); }
.vpnt-alt__links a:last-child { color: var(--vpnt-app-muted); }

/* Top 5 blok (voor in blogs) */
.vpnt-top5 { border: 1px solid var(--vpnt-app-border); border-radius: var(--vpnt-app-radius); overflow: hidden; margin: 28px 0; box-shadow: 0 6px 20px rgba(15,23,42,.06); }
.vpnt-top5__head { background: var(--vpnt-app-navy); color: #fff; padding: 16px 22px; font-weight: 900; font-size: 1.15rem; }
.vpnt-app .vpnt-top5__row, .vpnt-app .vpnt-top5__row:hover, .vpnt-prose .vpnt-top5__row, .vpnt-prose .vpnt-top5__row:hover { text-decoration: none; }
.vpnt-top5__row { display: grid; grid-template-columns: 40px 96px 1fr 52px auto; align-items: center; gap: 18px; padding: 14px 22px; border-bottom: 1px solid var(--vpnt-app-border); text-decoration: none; transition: background .12s; }
.vpnt-top5__row:last-child { border-bottom: none; }
.vpnt-top5__row:nth-child(even) { background: var(--vpnt-app-surface); }
.vpnt-top5__row:hover { background: #FFF3EF; }

.vpnt-top5__rank { width: 34px; height: 34px; border-radius: 10px; background: var(--vpnt-app-navy); color: #fff; font-weight: 900; display: grid; place-items: center; font-size: 1rem; box-shadow: 0 3px 8px rgba(15,23,42,.18); }
.vpnt-top5__rank[data-rank="1"] { background: linear-gradient(135deg, #FFB800, #FF8A00); box-shadow: 0 3px 10px rgba(255,138,0,.4); }
.vpnt-top5__rank[data-rank="2"] { background: linear-gradient(135deg, #B7C3D4, #8C9AAE); }
.vpnt-top5__rank[data-rank="3"] { background: linear-gradient(135deg, #E0A579, #C77B45); }

.vpnt-top5__logo { height: 36px; display: flex; align-items: center; }
.vpnt-top5__logo img { max-height: 36px; max-width: 96px; width: auto; object-fit: contain; }

.vpnt-top5__info { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.vpnt-top5__name { font-weight: 800; font-size: 1.05rem; color: var(--vpnt-app-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vpnt-top5__meta { font-size: .82rem; color: var(--vpnt-app-muted); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.vpnt-top5__score { width: 46px; height: 46px; border-radius: 50%; border: 3px solid var(--s, #0EA5E9); display: grid; place-items: center; font-weight: 900; font-size: 1.05rem; color: var(--vpnt-app-ink); justify-self: center; }

.vpnt-top5__cta { background: var(--vpnt-app-coral); color: #fff; font-weight: 800; font-size: .88rem; padding: 10px 20px; border-radius: 999px; white-space: nowrap; text-align: center; display: inline-flex; align-items: center; gap: 6px; box-shadow: 0 6px 14px rgba(255,107,71,.3); transition: transform .1s; }
.vpnt-top5__row:hover .vpnt-top5__cta { transform: translateY(-1px); }

@media (max-width: 620px) {
  .vpnt-top5__row { grid-template-columns: 34px 1fr 44px auto; gap: 12px; padding: 12px 16px; }
  .vpnt-top5__logo { display: none; }
  .vpnt-top5__score { width: 44px; height: 44px; font-size: 1rem; }
  .vpnt-top5__cta { padding: 9px 14px; font-size: .82rem; }
  .vpnt-top5__cta span { display: none; }
}

/* Vergelijkingstabel (X vs concurrentie) */
.vpnt-vs-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 8px -4px 0; padding: 4px; }
.vpnt-vs-table { width: 100%; min-width: 620px; border-collapse: separate; border-spacing: 0; }
.vpnt-vs-table th, .vpnt-vs-table td { padding: 12px 14px; text-align: center; border-bottom: 1px solid var(--vpnt-app-border); font-size: .92rem; }
.vpnt-vs-rowlabel { text-align: left !important; color: var(--vpnt-app-muted); font-weight: 600; white-space: nowrap; }
.vpnt-vs-table thead th { vertical-align: bottom; }
.vpnt-vs-logo { display: block; height: 34px; margin: 0 auto 6px; }
.vpnt-vs-logo img { max-height: 34px; max-width: 92px; width: auto; object-fit: contain; margin: 0 auto; }
.vpnt-vs-name { display: block; font-weight: 800; color: var(--vpnt-app-ink); font-size: .95rem; }
.vpnt-vs-tag { display: inline-block; margin-top: 4px; background: rgba(255,107,71,.12); color: var(--vpnt-app-coral); font-size: .68rem; font-weight: 800; padding: 2px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: .03em; }
.vpnt-vs-score { font-size: 1.1rem; font-weight: 900; }
.vpnt-vs-yes { color: var(--vpnt-green-dark, #16A34A); font-weight: 800; }
.vpnt-vs-no { color: #EF4444; font-weight: 800; }
.vpnt-vs-table td.is-current, .vpnt-vs-table th.is-current { background: #FFF6F3; }
.vpnt-vs-table th.is-current { border-top: 3px solid var(--vpnt-app-coral); border-radius: 10px 10px 0 0; }
.vpnt-vs-ctarow td { border-bottom: none; padding-top: 16px; }
.vpnt-vs-ctarow .vpnt-btn-cta { padding: 9px 18px; font-size: .85rem; box-shadow: none; }

/* Review byline (auteur) */
.vpnt-rev-updated { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.vpnt-rev-byline { display: inline-flex; align-items: center; gap: 7px; }
.vpnt-rev-byline img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.vpnt-rev-byline a { color: var(--vpnt-app-ink); font-weight: 700; }
.vpnt-rev-updated__sep { color: var(--vpnt-app-border); }

/* Widget: top 3 leaderboard */
.vpnt-widget-top3 { display: flex; flex-direction: column; gap: 8px; }
.vpnt-widget-top3__row {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px; border: 1px solid var(--vpnt-app-border);
    border-radius: 12px; text-decoration: none; background: var(--vpnt-app-surface, #F8FAFC);
    transition: border-color .15s, box-shadow .15s;
}
.vpnt-widget-top3__row:hover { border-color: var(--vpnt-app-teal); box-shadow: 0 2px 8px rgba(15,23,42,.08); }
.vpnt-widget-top3__rank {
    width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--vpnt-app-navy, #0F172A); color: #fff; font-size: .78rem; font-weight: 800;
}
.vpnt-widget-top3__row:first-child .vpnt-widget-top3__rank { background: var(--vpnt-app-coral, #FF6B47); }
.vpnt-widget-top3__logo { height: 22px; max-width: 110px; width: auto; object-fit: contain; }
.vpnt-widget-top3__name { font-weight: 700; color: var(--vpnt-app-ink); }
.vpnt-widget-top3__price { margin-left: auto; font-size: .82rem; color: var(--vpnt-app-muted); white-space: nowrap; }
.vpnt-widget-top3__score {
    min-width: 38px; text-align: center; padding: 4px 8px; border-radius: 8px;
    background: #DCFCE7; color: #16A34A; font-weight: 800; font-size: .9rem;
}

/* [vpnt_vs] vergelijkingstabel */
.vpnt-vs { margin: 24px 0; overflow-x: auto; }
.vpnt-vs__table { width: 100%; border-collapse: collapse; font-size: .95rem; }
.vpnt-vs__table th, .vpnt-vs__table td { padding: 10px 14px; border-bottom: 1px solid var(--vpnt-app-border); text-align: center; }
.vpnt-vs__table tbody th { text-align: left; color: var(--vpnt-app-muted); font-weight: 600; }
.vpnt-vs__table thead th { font-size: 1.05rem; }
.vpnt-vs__table thead a { color: var(--vpnt-app-ink); text-decoration: none; font-weight: 800; }
.vpnt-vs__yes { color: #16A34A; font-weight: 800; }
.vpnt-vs__no { color: #DC2626; font-weight: 800; }
.vpnt-vs__cta { display: inline-block; background: var(--vpnt-app-coral, #FF6B47); color: #fff; border-radius: 10px; padding: 10px 18px; font-weight: 700; text-decoration: none; }
.vpnt-vs__cta:hover { background: #E5593A; color: #fff; }

/* Reviews: samenvattingspaneel + subscores (Zonneplan-stijl) */
.vpnt-rev-grid { display: grid; grid-template-columns: 260px 1fr; gap: 24px; align-items: start; }
.vpnt-rev-panel {
    background: #fff; border: 1px solid var(--vpnt-app-border); border-radius: 16px;
    padding: 24px 22px; text-align: center; position: sticky; top: 90px;
}
.vpnt-rev-panel__label { font-weight: 700; color: var(--vpnt-app-ink); }
.vpnt-rev-panel__num { font-size: 2.6rem; font-weight: 900; color: var(--vpnt-app-ink); line-height: 1.15; }
.vpnt-rev-panel__count { color: var(--vpnt-app-muted); font-size: .9rem; margin: 8px 0 18px; }
.vpnt-rev-panel__bars { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; text-align: left; }
.vpnt-rev-panel__bar-head { display: flex; justify-content: space-between; font-size: .9rem; margin-bottom: 4px; }
.vpnt-rev-panel__bar-head span { color: var(--vpnt-app-ink); font-weight: 600; }
.vpnt-rev-panel__track { background: var(--vpnt-app-surface, #F1F5F9); border-radius: 99px; height: 8px; }
.vpnt-rev-panel__fill { background: #F59E0B; height: 8px; border-radius: 99px; }
.vpnt-btn--dark { background: var(--vpnt-app-navy, #0F172A); color: #fff; }
.vpnt-btn--dark:hover { background: #1E293B; color: #fff; }
.vpnt-rev-item__subs {
    background: #FFF7ED; border-radius: 12px; padding: 12px 16px; margin-top: 12px;
    display: flex; flex-direction: column; gap: 6px; max-width: 320px;
}
.vpnt-rev-item__subrow { display: flex; justify-content: space-between; align-items: center; font-size: .88rem; }
.vpnt-rev-item__subrow span { color: var(--vpnt-app-ink); font-weight: 600; }
@media (max-width: 860px) {
    .vpnt-rev-grid { grid-template-columns: 1fr; }
    .vpnt-rev-panel { position: static; }
}

/* Sidebar-alternatieven bij lage scores */
.vpnt-rev-cta--alts { text-align: left; }
.vpnt-rev-alts__label { display: inline-block; background: #FEF3C7; color: #92400E; font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; border-radius: 999px; padding: 4px 12px; margin-bottom: 10px; }
.vpnt-rev-alts__intro { font-size: .92rem; color: var(--vpnt-app-text, #334155); line-height: 1.5; margin: 0 0 14px; }
.vpnt-rev-alts__list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.vpnt-rev-alts__row { display: flex; align-items: center; gap: 10px; border: 1px solid var(--vpnt-app-border); border-radius: 12px; padding: 9px 12px; }
.vpnt-rev-alts__rank { width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; background: var(--vpnt-app-navy, #0F172A); color: #fff; font-size: .75rem; font-weight: 800; }
.vpnt-rev-alts__row:first-child .vpnt-rev-alts__rank { background: var(--vpnt-app-coral, #FF6B47); }
.vpnt-rev-alts__info { flex: 1; min-width: 0; display: flex; align-items: center; }
.vpnt-rev-alts__info img { height: 20px; max-width: 90px; width: auto; object-fit: contain; }
.vpnt-rev-alts__score { background: #DCFCE7; color: #16A34A; font-weight: 800; font-size: .85rem; border-radius: 7px; padding: 3px 8px; }
.vpnt-rev-alts__cta { background: var(--vpnt-app-coral, #FF6B47); color: #fff; font-size: .82rem; font-weight: 700; border-radius: 8px; padding: 6px 12px; text-decoration: none; white-space: nowrap; }
.vpnt-rev-alts__cta:hover { background: #E5593A; color: #fff; }
.vpnt-rev-alts__toch { display: block; text-align: center; font-size: .85rem; color: var(--vpnt-app-muted); text-decoration: underline; }
