:root {
    --bg: #FAFAF7;
    --surface: #FFFFFF;
    --ink: #14161A;
    --ink-soft: #3D424A;
    --muted: #6B7280;
    --line: #E6E4DE;
    --line-strong: #CFCBC1;
    --accent: #E94B6F;        /* roze-rood, past bij ShemaleFucks peach */
    --accent-dark: #C13458;
    --positive: #1F7A3A;
    --negative: #B8332A;
    --highlight: #FFF6E0;
    --score-bg: #14161A;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  html { scroll-behavior:smooth; }
  body {
    font-family:'Inter', system-ui, sans-serif;
    background:var(--bg); color:var(--ink);
    font-size:17px; line-height:1.65;
    -webkit-font-smoothing:antialiased;
  }
  a { color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
  a:hover { color:var(--accent-dark); }
  .serif { font-family:'Source Serif 4', Georgia, serif; }
  .container { max-width:1100px; margin:0 auto; padding:0 24px; }
  .narrow { max-width:720px; margin:0 auto; padding:0 24px; }

  /* MASTHEAD */
  .masthead { background:#fff; border-bottom:1px solid var(--line); padding:14px 0; }
  .masthead-inner { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
  .brand { font-family:'Source Serif 4',serif; font-weight:700; font-size:22px; letter-spacing:-0.01em; color:var(--ink); text-decoration:none; }
  .brand span { color:var(--accent); }
  .masthead-meta { display:flex; gap:18px; font-size:13px; color:var(--muted); align-items:center; flex-wrap:wrap; }
  .masthead-meta strong { color:var(--ink-soft); font-weight:600; }
  .nav-link { color:var(--muted); text-decoration:none; font-size:13px; }
  .nav-link:hover { color:var(--ink); }

  /* DISCLOSURE BAR */
  .disclosure { background:#F6F4EE; border-bottom:1px solid var(--line); font-size:12px; color:var(--muted); padding:6px 0; text-align:center; }
  .disclosure .container { display:flex; align-items:center; justify-content:center; gap:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .disclosure .disc-text { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; min-width:0; flex:0 1 auto; }
  .disclosure b { color:var(--ink-soft); font-weight:600; }
  .disclosure a { color:var(--muted); text-decoration:underline; flex-shrink:0; }
  @media(max-width:540px){
    .disclosure { font-size:11px; padding:5px 0; }
    .disclosure a { display:none; }
  }

  /* MOBILE NAV TOGGLE */
  .nav-toggle { display:none; background:none; border:1px solid var(--line-strong); border-radius:6px; padding:8px 10px; cursor:pointer; align-items:center; justify-content:center; }
  .nav-toggle span { display:block; width:20px; height:2px; background:var(--ink); position:relative; }
  .nav-toggle span::before, .nav-toggle span::after { content:""; position:absolute; left:0; width:20px; height:2px; background:var(--ink); }
  .nav-toggle span::before { top:-6px; }
  .nav-toggle span::after { top:6px; }
  @media(max-width:768px){
    .nav-toggle { display:inline-flex; }
    .masthead-meta { display:none; width:100%; flex-direction:column; align-items:flex-start; gap:0; padding-top:12px; margin-top:12px; border-top:1px solid var(--line); }
    .masthead-meta.open { display:flex; }
    .masthead-meta .nav-link { display:block; width:100%; padding:12px 4px; border-bottom:1px solid var(--line); font-size:15px; }
    .masthead-meta .nav-link:last-of-type { border-bottom:none; }
    .masthead-meta > span { padding:10px 4px; font-size:12px; }
  }

  /* ARTICLE HERO */
  .article-hero {
    position:relative;
    background:
      linear-gradient(180deg, rgba(31,18,28,0.82) 0%, rgba(58,22,40,0.9) 50%, rgba(86,28,56,0.95) 100%),
      url('img/header.jpg');
    background-size:cover; background-position:center;
    color:#fff;
    border-bottom:1px solid rgba(255,255,255,0.08);
    padding:48px 0 40px;
    overflow:hidden;
  }
  .article-hero::before {
    content:""; position:absolute; inset:0;
    background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 0);
    background-size:22px 22px; pointer-events:none;
  }
  .article-hero > .container { position:relative; z-index:1; }
  .article-hero .breadcrumb, .article-hero .breadcrumb a { color:rgba(255,255,255,0.55); }
  .article-hero .breadcrumb a:hover { color:#fff; }
  .article-hero h1.article-title { color:#fff; }
  .article-hero h1.article-title em { color:#FFB0C2; }
  .article-hero .article-lede { color:rgba(255,255,255,0.78); }
  .article-hero .category-tag { color:#FFB0C2; background:rgba(255,176,194,0.14); }
  .article-hero .category-tag::before { background:#FFB0C2; }
  .article-hero .byline { border-top:1px solid rgba(255,255,255,0.12); border-bottom:1px solid rgba(255,255,255,0.12); }
  .article-hero .byline-text strong { color:#fff; }
  .article-hero .byline-text span, .article-hero .byline-meta, .article-hero .byline-meta span { color:rgba(255,255,255,0.6); }
  .article-hero .byline-meta strong { color:rgba(255,255,255,0.85); }
  .breadcrumb { font-size:13px; color:var(--muted); margin-bottom:18px; letter-spacing:0.02em; }
  .breadcrumb a { color:var(--muted); text-decoration:none; }
  .breadcrumb a:hover { color:var(--ink); }
  .category-tag { display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); margin-bottom:18px; background:rgba(233,75,111,0.08); padding:6px 12px; border-radius:50px; }
  .category-tag::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); }
  h1.article-title { font-family:'Source Serif 4',serif; font-weight:700; font-size:clamp(30px, 5vw, 54px); line-height:1.08; letter-spacing:-0.02em; margin-bottom:18px; color:var(--ink); }
  h1.article-title em { font-style:italic; color:var(--accent); font-weight:700; }
  .article-lede { font-family:'Source Serif 4',serif; font-weight:400; font-size:clamp(17px, 2.2vw, 21px); line-height:1.55; color:var(--ink-soft); max-width:680px; margin-bottom:28px; }
  .byline { display:flex; align-items:center; gap:14px; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); flex-wrap:wrap; }
  .byline-avatar { width:44px; height:44px; border-radius:50%; flex-shrink:0; background:#D9D4C8 url('https://images.unsplash.com/photo-1438761681033-6461ffad8d80?w=120&h=120&fit=crop&q=80'); background-size:cover; background-position:center; }
  .byline-text { flex:1; font-size:14px; min-width:0; }
  .byline-text strong { display:block; color:var(--ink); font-weight:600; font-size:14px; }
  .byline-text span { color:var(--muted); font-size:13px; }
  .byline-meta { font-size:13px; color:var(--muted); text-align:right; }
  .byline-meta strong { display:block; color:var(--ink-soft); font-weight:600; }
  @media(max-width:540px){
    .byline-meta { text-align:left; width:100%; padding-top:8px; border-top:1px dashed var(--line); }
  }

  /* DEAL BAR */
  .deal-bar { margin-top:28px; background:#fff; border:1px solid var(--line-strong); border-radius:8px; box-shadow:0 8px 24px -12px rgba(20,22,26,0.18); display:grid; grid-template-columns:auto 1fr auto auto; align-items:center; gap:24px; padding:18px 24px; }
  .deal-logo { height:44px; width:auto; display:block; background:#fff; padding:6px 10px; border-radius:6px; border:1px solid var(--line); }
  .deal-info { min-width:0; }
  .deal-info strong { display:block; font-family:'Source Serif 4',serif; font-size:17px; color:var(--ink); margin-bottom:2px; }
  .deal-info span { font-size:13px; color:var(--muted); }
  .deal-score { display:flex; flex-direction:column; align-items:flex-end; line-height:1.1; }
  .deal-score-num { font-family:'Source Serif 4',serif; font-weight:700; font-size:32px; color:var(--ink); }
  .deal-score-num small { font-size:14px; color:var(--muted); font-weight:400; }
  .deal-stars { color:#F5A623; font-size:14px; letter-spacing:2px; }
  .deal-reviews { font-size:11.5px; color:var(--muted); margin-top:2px; }
  .deal-bar .btn { white-space:nowrap; }
  @media(max-width:760px){
    .deal-bar { grid-template-columns:auto 1fr; gap:14px 16px; padding:16px; }
    .deal-logo { height:36px; padding:4px 8px; }
    .deal-score { grid-column:2; align-items:flex-end; }
    .deal-bar .btn { grid-column:1 / -1; width:100%; justify-content:center; padding:14px; }
    .deal-info { grid-column:2; text-align:right; }
  }

  /* INLINE FIGURES */
  figure.inline-fig { margin:24px 0; border-radius:4px; overflow:hidden; }
  figure.inline-fig img { display:block; width:100%; height:auto; }
  figure.inline-fig figcaption { font-size:12.5px; color:var(--muted); font-style:italic; padding:8px 4px 0; }
  figure.inline-fig.float-right { float:right; width:42%; margin:6px 0 18px 22px; }
  @media(max-width:640px){
    figure.inline-fig.float-right { float:none; width:100%; margin:20px 0; }
  }

  /* VERDICT BOX */
  .verdict { background:#fff; border:1px solid var(--line-strong); border-radius:4px; padding:32px; display:grid; grid-template-columns:200px 1fr; gap:32px; margin-bottom:48px; box-shadow:0 1px 3px rgba(0,0,0,0.04); }
  @media(max-width:720px){ .verdict { grid-template-columns:1fr; padding:24px; gap:24px; } }
  .verdict-score { text-align:center; padding:20px; background:var(--score-bg); color:#fff; border-radius:4px; display:flex; flex-direction:column; justify-content:center; }
  .verdict-score-num { font-family:'Source Serif 4',serif; font-size:64px; font-weight:700; line-height:1; letter-spacing:-0.02em; }
  .verdict-score-num small { font-size:22px; opacity:0.5; font-weight:400; }
  .verdict-score-label { font-size:11px; letter-spacing:0.14em; text-transform:uppercase; opacity:0.7; margin-top:8px; }
  .verdict-stars { color:#F5A623; font-size:14px; margin-top:10px; letter-spacing:2px; }
  .verdict-content h2 { font-family:'Source Serif 4',serif; font-size:22px; font-weight:700; margin-bottom:6px; color:var(--ink); }
  .verdict-tagline { font-size:15px; color:var(--ink-soft); margin-bottom:18px; }
  .verdict-pros-cons { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:22px; }
  @media(max-width:540px){ .verdict-pros-cons { grid-template-columns:1fr; } }
  .pc-block h4 { font-size:11px; letter-spacing:0.12em; text-transform:uppercase; margin-bottom:8px; font-weight:700; }
  .pc-block.pros h4 { color:var(--positive); }
  .pc-block.cons h4 { color:var(--negative); }
  .pc-block ul { list-style:none; }
  .pc-block li { font-size:14px; line-height:1.5; color:var(--ink-soft); padding-left:18px; position:relative; margin-bottom:6px; }
  .pc-block.pros li::before { content:"+"; position:absolute; left:0; color:var(--positive); font-weight:700; }
  .pc-block.cons li::before { content:"−"; position:absolute; left:0; color:var(--negative); font-weight:700; }
  .verdict-cta-row { display:flex; align-items:center; gap:18px; flex-wrap:wrap; padding-top:18px; border-top:1px solid var(--line); }

  /* BUTTON */
  .btn { display:inline-flex; align-items:center; gap:8px; background:var(--accent); color:#fff; font-weight:600; padding:13px 24px; border-radius:3px; text-decoration:none; font-size:15px; transition:background .15s, transform .15s; border:none; cursor:pointer; }
  .btn:hover { background:var(--accent-dark); color:#fff; }
  .btn-large { padding:16px 32px; font-size:16px; }
  .btn-ghost { background:transparent; color:var(--ink); border:1px solid var(--line-strong); }
  .btn-ghost:hover { background:var(--ink); color:#fff; border-color:var(--ink); }
  .cta-note { font-size:12.5px; color:var(--muted); }
  .cta-note b { color:var(--ink-soft); font-weight:600; }

  /* TOC */
  .toc { background:#fff; border:1px solid var(--line); border-radius:4px; padding:20px 24px; margin-bottom:48px; }
  .toc-title { font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; font-weight:700; }
  .toc ol { list-style:none; counter-reset:toc; column-count:2; column-gap:32px; }
  @media(max-width:640px){ .toc ol { column-count:1; } }
  .toc li { counter-increment:toc; padding:5px 0; font-size:14.5px; break-inside:avoid; }
  .toc li::before { content:counter(toc) ". "; color:var(--muted); margin-right:6px; }
  .toc a { color:var(--ink-soft); text-decoration:none; }
  .toc a:hover { color:var(--accent); }

  /* SECTIONS */
  section.body-section { padding:24px 0 40px; }
  h2.section-h { font-family:'Source Serif 4',serif; font-weight:700; font-size:clamp(26px, 3vw, 34px); letter-spacing:-0.01em; margin:32px 0 16px; color:var(--ink); line-height:1.2; }
  h3.sub-h { font-family:'Source Serif 4',serif; font-weight:600; font-size:21px; margin:24px 0 10px; color:var(--ink); }
  p.body-p { margin-bottom:16px; color:var(--ink-soft); }
  p.body-p:first-of-type::first-letter, .lede-letter::first-letter {
    font-family:'Source Serif 4',serif; font-weight:700;
    float:left; font-size:58px; line-height:0.9;
    padding:6px 10px 0 0; color:var(--accent);
  }

  /* METHODOLOGY */
  .method { background:#fff; border-left:3px solid var(--accent); padding:24px 28px; margin:24px 0; border-radius:0 4px 4px 0; }
  .method-label { font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); font-weight:700; margin-bottom:10px; }
  .method h3 { font-family:'Source Serif 4',serif; font-size:20px; margin-bottom:10px; font-weight:700; }
  .method-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:18px; }
  @media(max-width:680px){ .method-grid { grid-template-columns:repeat(2,1fr); } }
  .method-stat { border-top:1px solid var(--line); padding-top:10px; }
  .method-stat b { font-family:'Source Serif 4',serif; font-size:24px; color:var(--ink); display:block; }
  .method-stat span { font-size:12.5px; color:var(--muted); }

  /* SCORE CARD */
  .scorecard { background:#fff; border:1px solid var(--line); border-radius:4px; overflow:hidden; margin:24px 0; }
  .sc-row { display:grid; grid-template-columns:180px 1fr 60px; align-items:center; padding:16px 22px; border-bottom:1px solid var(--line); gap:16px; }
  .sc-row:last-child { border-bottom:none; }
  .sc-row.sc-total { background:var(--ink); color:#fff; }
  .sc-row.sc-total .sc-bar { background:rgba(255,255,255,0.15); }
  .sc-row.sc-total .sc-bar-fill { background:#F5A623; }
  .sc-label { font-weight:600; font-size:15px; }
  .sc-label small { display:block; font-weight:400; font-size:12.5px; color:var(--muted); margin-top:2px; }
  .sc-row.sc-total .sc-label small { color:rgba(255,255,255,0.6); }
  .sc-bar { height:8px; background:var(--line); border-radius:4px; overflow:hidden; }
  .sc-bar-fill { height:100%; background:var(--accent); border-radius:4px; }
  .sc-num { font-family:'Source Serif 4',serif; font-weight:700; font-size:20px; text-align:right; }
  @media(max-width:600px){
    .sc-row { grid-template-columns:1fr 50px; }
    .sc-bar { grid-column:1/-1; order:3; }
  }

  /* INLINE CTA */
  .inline-cta { background:#fff; border:1px solid var(--line-strong); border-radius:4px; padding:24px 28px; display:flex; align-items:center; justify-content:space-between; gap:24px; margin:32px 0; flex-wrap:wrap; }
  .inline-cta-text { flex:1; min-width:240px; }
  .inline-cta-text strong { font-family:'Source Serif 4',serif; font-size:18px; display:block; margin-bottom:4px; color:var(--ink); }
  .inline-cta-text span { font-size:14px; color:var(--muted); }

  /* FOR WHOM */
  .for-whom { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:24px 0; }
  @media(max-width:640px){ .for-whom { grid-template-columns:1fr; } }
  .fw-card { background:#fff; border:1px solid var(--line); border-radius:4px; padding:22px; }
  .fw-card.fw-yes { border-top:3px solid var(--positive); }
  .fw-card.fw-no { border-top:3px solid var(--negative); }
  .fw-card h4 { font-size:11px; letter-spacing:0.14em; text-transform:uppercase; font-weight:700; margin-bottom:14px; }
  .fw-yes h4 { color:var(--positive); }
  .fw-no h4 { color:var(--negative); }
  .fw-card ul { list-style:none; }
  .fw-card li { font-size:14.5px; padding:7px 0 7px 22px; position:relative; color:var(--ink-soft); border-bottom:1px solid var(--line); }
  .fw-card li:last-child { border-bottom:none; }
  .fw-yes li::before { content:"✓"; color:var(--positive); position:absolute; left:0; font-weight:700; }
  .fw-no li::before { content:"✕"; color:var(--negative); position:absolute; left:0; font-weight:700; }

  /* QUOTES */
  .user-reviews { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin:24px 0; }
  @media(max-width:680px){ .user-reviews { grid-template-columns:1fr; } }
  .ur-card { background:#fff; border:1px solid var(--line); border-radius:4px; padding:22px; }
  .ur-stars { color:#F5A623; font-size:14px; letter-spacing:2px; margin-bottom:8px; }
  .ur-text { font-family:'Source Serif 4',serif; font-size:16px; line-height:1.55; color:var(--ink); margin-bottom:14px; }
  .ur-author { display:flex; align-items:center; gap:10px; font-size:13px; padding-top:12px; border-top:1px solid var(--line); }
  .ur-av { width:34px; height:34px; border-radius:50%; object-fit:cover; }
  .ur-name { font-weight:600; color:var(--ink); }
  .ur-meta { color:var(--muted); font-size:12.5px; }
  .ur-source { margin-left:auto; font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:0.08em; }

  /* FAQ */
  .faq { margin:24px 0; }
  .faq details { background:#fff; border:1px solid var(--line); border-radius:4px; margin-bottom:10px; }
  .faq summary { cursor:pointer; padding:16px 22px; font-weight:600; font-size:15.5px; list-style:none; display:flex; justify-content:space-between; align-items:center; color:var(--ink); }
  .faq summary::-webkit-details-marker { display:none; }
  .faq summary::after { content:"+"; font-size:22px; color:var(--accent); font-weight:300; transition:transform .15s; }
  .faq details[open] summary::after { content:"−"; }
  .faq details > div { padding:0 22px 18px; color:var(--ink-soft); font-size:15px; line-height:1.6; }

  /* FINAL VERDICT */
  .final-verdict { background:var(--ink); color:#fff; border-radius:4px; padding:40px; margin:40px 0; text-align:center; }
  .final-verdict .verdict-score-num { font-size:80px; }
  .final-verdict h2 { font-family:'Source Serif 4',serif; font-size:32px; margin:14px 0 10px; font-weight:700; }
  .final-verdict p { color:rgba(255,255,255,0.75); font-size:16px; max-width:560px; margin:0 auto 24px; }

  /* AUTHOR BIO */
  .author-bio { background:#fff; border:1px solid var(--line); border-radius:4px; padding:24px; display:flex; gap:20px; align-items:center; margin:24px 0 40px; }
  .author-bio img { width:72px; height:72px; border-radius:50%; object-fit:cover; flex-shrink:0; }
  .author-bio h4 { font-family:'Source Serif 4',serif; font-size:18px; margin-bottom:4px; }
  .author-bio p { font-size:14px; color:var(--muted); margin-bottom:6px; }
  .author-bio a { font-size:13px; }

  /* FOOTER */
  footer { background:#fff; border-top:1px solid var(--line); padding:40px 0 80px; margin-top:60px; text-align:center; font-size:13px; color:var(--muted); }
  footer .brand { font-size:18px; }
  footer p { margin:10px 0; }
  footer a { color:var(--muted); margin:0 8px; }

  /* STICKY CTA */
  .sticky-cta { position:fixed; bottom:0; left:0; right:0; background:#fff; border-top:1px solid var(--line-strong); padding:12px 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; z-index:100; box-shadow:0 -4px 16px rgba(0,0,0,0.08); }
  .sticky-cta-text { font-size:13.5px; line-height:1.3; }
  .sticky-cta-text strong { font-family:'Source Serif 4',serif; font-size:16px; color:var(--ink); }
  .sticky-cta-text small { display:block; color:var(--muted); font-size:11.5px; }
  .sticky-cta .btn { padding:10px 16px; font-size:13.5px; flex-shrink:0; }
  body { padding-bottom:78px; }
  .article-hero .deal-bar { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.14); backdrop-filter:blur(8px); box-shadow:0 12px 32px -16px rgba(0,0,0,0.5); }
  .article-hero .deal-info strong { color:#fff; }
  .article-hero .deal-info span { color:rgba(255,255,255,0.65); }
  .article-hero .deal-score-num { color:#fff; }
  .article-hero .deal-score-num small { color:rgba(255,255,255,0.55); }
  .article-hero .deal-reviews { color:rgba(255,255,255,0.6); }

  /* Global mobile safety */
  html, body { overflow-x:hidden; }
  img { max-width:100%; height:auto; }

  @media(max-width:540px){
    body { font-size:16px; }
    .container, .narrow { padding:0 16px; }
    .article-hero { padding:32px 0 28px; }
    .verdict { padding:20px; }
    .verdict-score { padding:16px; }
    .verdict-score-num { font-size:48px; }
    .masthead { padding:10px 0; }
    .masthead-inner { gap:8px; }
    .brand img { height:32px !important; }
    .sticky-cta { padding:10px 12px; gap:8px; }
    .sticky-cta-logo { height:26px !important; padding:4px 6px !important; }
    .sticky-cta-text strong { font-size:13.5px; }
    .sticky-cta-text small { font-size:10.5px; }
    .sticky-cta .btn { padding:9px 12px; font-size:12.5px; }
    body { padding-bottom:72px; }
    .inline-cta { padding:18px; gap:14px; }
    .inline-cta .btn { width:100%; justify-content:center; }
    h1.article-title { font-size:28px; }
    .article-lede { font-size:16px; }
  }