/* paynplaylista.com — unique theme: Finnish blue (#1d4ed8) + white, cyan accent.
   Font pairing: Fraunces (display serif) + Inter (body). Clean, editorial, card-driven. */

:root{
  --blue:#1d4ed8;
  --blue-700:#1e40af;
  --blue-900:#172554;
  --cyan:#22d3ee;
  --cyan-600:#0891b2;
  --ink:#0f172a;
  --slate:#475569;
  --mut:#64748b;
  --line:#e2e8f0;
  --bg:#f6f8fc;
  --card:#ffffff;
  --good:#16a34a;
  --bad:#dc2626;
  --warn:#b45309;
  --warnbg:#fef3c7;
  --goodbg:#dcfce7;
  --badbg:#fee2e2;
  --radius:16px;
  --shadow:0 1px 2px rgba(15,23,42,.06), 0 8px 24px rgba(29,78,216,.06);
  --maxw:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto}
a{color:var(--blue-700);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:Fraunces,Georgia,"Times New Roman",serif;line-height:1.18;color:var(--blue-900);letter-spacing:-.01em}
h1{font-size:2.45rem;margin:.2em 0 .35em;font-weight:600}
h2{font-size:1.75rem;margin:1.8em 0 .5em;font-weight:600}
h3{font-size:1.28rem;margin:1.5em 0 .35em;font-weight:600}
p{margin:.7em 0}
small{color:var(--mut)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.narrow{max-width:760px}

/* ---------- Header ---------- */
.site-head{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-head .bar{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.12rem;color:var(--blue-900)}
.brand:hover{text-decoration:none}
.brand .logo{width:30px;height:30px;flex:none}
.brand b{color:var(--blue)}
.nav{display:flex;gap:18px;margin-left:auto;flex-wrap:wrap}
.nav a{color:var(--slate);font-weight:600;font-size:.95rem}
.nav a:hover{color:var(--blue)}
.nav-toggle{display:none}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(1100px 380px at 82% -8%, rgba(34,211,238,.20), transparent 60%),
    linear-gradient(180deg,#eef3ff 0%, var(--bg) 100%);
  border-bottom:1px solid var(--line);
  padding:54px 0 40px;
}
.hero .kicker{display:inline-block;background:#fff;border:1px solid var(--line);color:var(--blue-700);
  font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.hero h1{font-size:2.9rem;max-width:18ch}
.hero p.lead{font-size:1.18rem;color:var(--slate);max-width:62ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-weight:700;
  padding:12px 20px;border-radius:12px;border:1px solid var(--blue);cursor:pointer;font-size:1rem}
.btn:hover{background:var(--blue-700);text-decoration:none}
.btn.ghost{background:#fff;color:var(--blue-700)}
.btn.ghost:hover{background:#eff4ff}
.btn.cyan{background:var(--cyan-600);border-color:var(--cyan-600)}
.btn.cyan:hover{background:#0e7490}

/* ---------- Generic sections ---------- */
main section{padding:8px 0}
.lede{font-size:1.12rem;color:var(--slate)}
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.card h3{margin-top:0}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.78rem;padding:4px 10px;border-radius:999px;white-space:nowrap}
.badge.tax-free{background:var(--goodbg);color:#166534}
.badge.tax{background:var(--badbg);color:#991b1b}
.badge.eea{background:#dbeafe;color:#1e40af}
.badge.pnp{background:#cffafe;color:#155e75}
.badge.hybrid{background:#f1f5f9;color:#475569}
.badge.fast{background:var(--goodbg);color:#166534}
.badge.mid{background:var(--warnbg);color:#92400e}
.badge.slow{background:var(--badbg);color:#991b1b}

/* ---------- Comparison cards (home) ---------- */
.op-list{display:grid;gap:16px;counter-reset:rank}
.op{display:grid;grid-template-columns:54px 1fr auto;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);position:relative}
.op .rank{counter-increment:rank;font-family:Fraunces,serif;font-weight:600;font-size:1.5rem;color:#fff;
  background:var(--blue);width:46px;height:46px;border-radius:12px;display:grid;place-items:center}
.op:nth-child(1) .rank{background:linear-gradient(135deg,#1d4ed8,#22d3ee)}
.op .meta h3{margin:0 0 4px;font-size:1.2rem}
.op .meta .tags{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0}
.op .meta .line{color:var(--mut);font-size:.92rem}
.op .score{text-align:right;display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.op .score .num{font-family:Fraunces,serif;font-size:1.7rem;font-weight:600;color:var(--blue-900);line-height:1}
.op .score .num span{font-size:.95rem;color:var(--mut)}

/* ---------- Tables ---------- */
.table-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}
table{border-collapse:collapse;width:100%;font-size:.95rem;min-width:560px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
thead th{background:#f1f5ff;color:var(--blue-900);font-weight:700;font-size:.86rem;letter-spacing:.02em;position:sticky;top:0}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#f8faff}
caption{caption-side:bottom;color:var(--mut);font-size:.82rem;padding-top:8px;text-align:left}

/* ---------- Pros / cons ---------- */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pc ul{list-style:none;padding:0;margin:0}
.pc li{padding:6px 0 6px 26px;position:relative}
.pc .pros li:before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:800}
.pc .cons li:before{content:"✕";position:absolute;left:0;color:var(--bad);font-weight:800}

/* ---------- Rating block ---------- */
.rating{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow)}
.rating .big{font-family:Fraunces,serif;font-size:2.6rem;font-weight:600;color:var(--blue);line-height:1}
.stars{color:#f59e0b;font-size:1.1rem;letter-spacing:2px}

/* ---------- Tool ---------- */
.tool{background:linear-gradient(180deg,#fff, #fbfdff);border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:var(--shadow)}
.tool h2{margin-top:0}
.tool .row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px;color:var(--blue-900)}
.field select,.field input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:#fff;color:var(--ink)}
.field select:focus,.field input:focus{outline:2px solid var(--blue);border-color:var(--blue)}
.tool-actions{margin-top:16px;display:flex;gap:12px;flex-wrap:wrap}
.tool-out{margin-top:22px}
.notice{padding:14px 16px;border-radius:12px;font-size:.95rem}
.notice.err{background:var(--badbg);color:#991b1b}
.notice.ok{background:var(--goodbg);color:#166534}
.notice.info{background:#e0f2fe;color:#075985}
.result-card{border:1px solid var(--line);border-radius:14px;padding:16px 18px;background:#fff;margin-bottom:12px}
.result-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.result-card h4{margin:0;font-size:1.12rem;font-family:Fraunces,serif}
.result-card .tags{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.result-card dl{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;margin:10px 0 0;font-size:.92rem}
.result-card dt{color:var(--mut);font-weight:600}
.result-card dd{margin:0}
.payout-pill{font-weight:800;padding:6px 12px;border-radius:999px;font-size:.85rem}

/* ---------- Callouts ---------- */
.callout{border-left:4px solid var(--blue);background:#eef3ff;padding:14px 18px;border-radius:0 12px 12px 0;margin:18px 0}
.callout.warn{border-color:var(--warn);background:var(--warnbg)}
.callout.tax{border-color:var(--bad);background:var(--badbg)}
.callout h3{margin-top:0}

/* ---------- Breadcrumb ---------- */
.crumbs{font-size:.85rem;color:var(--mut);padding:14px 0 0}
.crumbs a{color:var(--mut)}
.crumbs a:hover{color:var(--blue)}

/* ---------- TOC ---------- */
.toc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin:18px 0}
.toc strong{display:block;margin-bottom:6px;color:var(--blue-900);font-family:Fraunces,serif}
.toc ol{margin:0;padding-left:18px;columns:2;column-gap:28px}
.toc a{color:var(--slate)}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 18px;margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:700;padding:12px 0;color:var(--blue-900);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary:before{content:"+";color:var(--blue);font-weight:800;margin-right:10px}
.faq details[open] summary:before{content:"–"}
.faq details p{margin-top:0}

/* ---------- Author / meta ---------- */
.byline{display:flex;align-items:center;gap:12px;color:var(--mut);font-size:.92rem;margin:6px 0 18px}
.byline .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#22d3ee);color:#fff;display:grid;place-items:center;font-weight:800;font-family:Fraunces,serif}
.updated{font-size:.85rem;color:var(--mut)}

/* ---------- Footer ---------- */
.site-foot{background:var(--blue-900);color:#cbd5e1;margin-top:48px;padding:40px 0 28px;font-size:.92rem}
.site-foot a{color:#bfdbfe}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.site-foot h4{color:#fff;font-family:Inter,sans-serif;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin:0 0 10px}
.site-foot ul{list-style:none;padding:0;margin:0}
.site-foot li{margin:6px 0}
.foot-bottom{border-top:1px solid #1e3a8a;margin-top:26px;padding-top:18px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#94a3b8;font-size:.85rem}
.k18{display:inline-grid;place-items:center;width:34px;height:34px;border:2px solid #ef4444;color:#fecaca;border-radius:8px;font-weight:800;font-size:.8rem}

/* ---------- Utilities ---------- */
.muted{color:var(--mut)}
.center{text-align:center}
.mt0{margin-top:0}
.sponsored{font-size:.78rem;color:var(--mut)}
.pill-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
hr.sep{border:0;border-top:1px solid var(--line);margin:30px 0}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  body{font-size:16px}
  .hero h1{font-size:2.2rem}
  h1{font-size:2rem}
  .cols-2,.cols-3{grid-template-columns:1fr}
  .tool .row{grid-template-columns:1fr}
  .pc{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .toc ol{columns:1}
  .op{grid-template-columns:42px 1fr;}
  .op .score{grid-column:2;flex-direction:row;align-items:center;justify-content:space-between;margin-top:6px}
  .nav{display:none;position:absolute;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;padding:12px 20px;gap:4px}
  .nav.open{display:flex}
  .nav a{padding:8px 0}
  .nav-toggle{display:inline-grid;place-items:center;margin-left:auto;width:42px;height:42px;border:1px solid var(--line);
    border-radius:10px;background:#fff;cursor:pointer;font-size:1.3rem;color:var(--blue)}
}

/* ---------- Mobile-only additions (≤ 480px) ---------- */
/* Prevent horizontal overflow on small viewports */
body{overflow-x:hidden;overflow-wrap:anywhere}

@media (max-width:480px){
  /* Hero heading floor */
  .hero h1{font-size:1.7rem}
  h1{font-size:1.7rem}
  h2{font-size:1.3rem}

  /* Operator card: stack CTA below meta */
  .op{grid-template-columns:38px 1fr;gap:10px;padding:14px}
  .op .score{grid-column:1/-1;margin-top:4px}
  .op .score .btn{width:100%;justify-content:center}

  /* Rating block: stack on tiny screens */
  .rating{flex-direction:column;align-items:flex-start;gap:8px}

  /* Tool grid: already collapses at 880px via .tool .row */

  /* Result card: don't let flex items overflow */
  .result-card .top{flex-direction:column}

  /* TOC: single column (already set at 880px via columns:1) */
}
