/*
 * Payli Pricing Page Styles
 * Wordt alleen geladen op pagina's met template-payli-pricing.php
 * Alle selectors zijn gescoped onder .payli-page-pricing om Blocksy conflicten te vermijden.
 */

.payli-page-pricing::before {
    content: '';
    position: fixed; inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: 0.035;
    mix-blend-mode: multiply;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
.payli-page-pricing img { max-width: 100%; display: block; }
.payli-page-pricing button { font-family: inherit; cursor: pointer; border: none; background: none; }
.payli-page-pricing a { color: inherit; text-decoration: none; }
.payli-page-pricing h1, .payli-page-pricing h2, .payli-page-pricing h3, .payli-page-pricing h4 {
    font-family: 'Bricolage Grotesque', 'Plus Jakarta Sans', sans-serif;
    letter-spacing: -.03em;
    line-height: 1.05;
    font-weight: 700;
  }
.payli-page-pricing .container { max-width: 1280px; margin: 0 auto; padding: 0 32px; position: relative; z-index: 2; }
.payli-page-pricing .section { padding: 120px 0; position: relative; }
comment
.payli-page-pricing .btn-ghost {
    padding: 10px 18px; font-size: 14px; font-weight: 500;
    color: var(--ink); border-radius: 100px;
    transition: background .2s;
  }
.payli-page-pricing .btn-ghost:hover { background: var(--line-soft); }
.payli-page-pricing .btn-primary {
    padding: 11px 22px; font-size: 14px; font-weight: 600;
    color: white; background: var(--brand); border-radius: 100px;
    box-shadow: var(--shadow-brand);
    transition: transform .2s, box-shadow .2s;
  }
.payli-page-pricing .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 24px 56px rgba(41,82,197,.32), 0 10px 20px rgba(41,82,197,.20);
  }
comment
.payli-page-pricing .hero {
    padding: 100px 0 80px;
    position: relative;
    overflow: hidden;
    text-align: center;
  }
.payli-page-pricing .hero::before {
    content: '';
    position: absolute;
    top: -200px; right: -200px;
    width: 700px; height: 700px;
    background: radial-gradient(circle, rgba(41,82,197,.10), transparent 70%);
    border-radius: 50%;
    z-index: 0;
    animation: orb 20s ease-in-out infinite alternate;
  }
.payli-page-pricing .hero::after {
    content: '';
    position: absolute;
    bottom: -300px; left: -200px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(255,232,199,.5), transparent 70%);
    border-radius: 50%;
    z-index: 0;
    animation: orb 25s ease-in-out infinite alternate-reverse;
  }
@keyframes orb {
    0% { transform: translate(0,0) scale(1); }
    100% { transform: translate(30px,40px) scale(1.1); }
  }
.payli-page-pricing .eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--brand-soft);
    color: var(--brand);
    padding: 8px 14px;
    font-size: 12px; font-weight: 600;
    border-radius: 100px;
    margin-bottom: 24px;
    text-transform: uppercase; letter-spacing: .08em;
  }
.payli-page-pricing .eyebrow .dot {
    width: 6px; height: 6px;
    background: var(--brand);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
  }
@keyframes pulse {
    0%,100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.4); opacity: .5; }
  }
.payli-page-pricing .hero h1 {
    font-size: clamp(48px, 7.5vw, 108px);
    letter-spacing: -.045em;
    margin-bottom: 24px;
    line-height: .98;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
  }
.payli-page-pricing .hero h1 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
    letter-spacing: -.02em;
  }
.payli-page-pricing .hero p {
    font-size: 19px; color: var(--ink-soft);
    max-width: 600px;
    margin: 0 auto 24px;
  }
comment
.payli-page-pricing .pricing-toggle-row {
    display: flex; justify-content: center; align-items: center;
    gap: 12px;
    margin-top: 8px;
    margin-bottom: 60px;
  }
.payli-page-pricing .toggle-pill {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 100px;
    padding: 6px;
    display: flex;
    box-shadow: var(--shadow-sm);
  }
.payli-page-pricing .toggle-btn {
    padding: 10px 22px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink-soft);
    border-radius: 100px;
    transition: all .2s;
  }
.payli-page-pricing .toggle-btn.active {
    background: var(--ink);
    color: white;
  }
.payli-page-pricing .toggle-badge {
    background: var(--cream);
    color: var(--ink);
    border: 1px solid var(--cream-line);
    padding: 4px 10px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
  }
comment
.payli-page-pricing .pricing-section {
    padding: 24px 0 120px;
    position: relative;
  }
.payli-page-pricing .pricing-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: stretch;
    padding-top: 24px;
  }
.payli-page-pricing .price-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 24px;
    padding: 32px 26px;
    display: flex; flex-direction: column;
    position: relative;
    transition: transform .3s, box-shadow .3s;
  }
.payli-page-pricing .price-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
  }
.payli-page-pricing .price-card.featured {
    background: linear-gradient(155deg, var(--ink), #1a2440);
    color: white;
    border: 1px solid var(--ink);
    box-shadow: var(--shadow-xl);
    transform: translateY(-12px);
  }
.payli-page-pricing .price-card.featured::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 100%; height: 100%;
    background: radial-gradient(circle at top right, rgba(41,82,197,.4), transparent 60%);
    border-radius: inherit;
    pointer-events: none;
    z-index: 0;
  }
.payli-page-pricing .price-card.featured > * {
    position: relative;
    z-index: 1;
  }
.payli-page-pricing .price-card.featured:hover {
    transform: translateY(-16px);
  }
.payli-page-pricing .price-popular {
    position: absolute;
    top: -14px; left: 50%;
    transform: translateX(-50%);
    background: var(--brand);
    color: white;
    padding: 7px 16px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    box-shadow: var(--shadow-brand);
    z-index: 10;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
  }
.payli-page-pricing .price-popular svg {
    width: 12px; height: 12px;
  }
.payli-page-pricing .price-card .pkg-name {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -.02em;
    margin-bottom: 6px;
    position: relative; z-index: 1;
  }
.payli-page-pricing .price-card .pkg-tagline {
    font-size: 14px;
    color: var(--ink-soft);
    margin-bottom: 28px;
    line-height: 1.45;
    position: relative; z-index: 1;
  }
.payli-page-pricing .price-card.featured .pkg-tagline {
    color: rgba(255,255,255,.7);
  }
.payli-page-pricing .price-card .price-display {
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--line-soft);
    position: relative; z-index: 1;
  }
.payli-page-pricing .price-card.featured .price-display {
    border-bottom-color: rgba(255,255,255,.1);
  }
.payli-page-pricing .price-card .price-amount {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 56px;
    font-weight: 700;
    letter-spacing: -.05em;
    line-height: 1;
    color: var(--ink);
  }
.payli-page-pricing .price-card.featured .price-amount {
    color: white;
  }
.payli-page-pricing .price-card .price-amount .currency {
    font-size: 30px;
    color: var(--muted);
    margin-right: 4px;
    vertical-align: top;
    line-height: 1.4;
  }
.payli-page-pricing .price-card.featured .price-amount .currency {
    color: rgba(255,255,255,.6);
  }
.payli-page-pricing .price-card .price-period {
    margin-top: 8px;
    font-size: 13px;
    color: var(--muted);
  }
.payli-page-pricing .price-card.featured .price-period {
    color: rgba(255,255,255,.5);
  }
.payli-page-pricing .price-card .pkg-features {
    list-style: none;
    margin-bottom: 32px;
    flex: 1;
    position: relative; z-index: 1;
  }
.payli-page-pricing .price-card .pkg-features li {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 8px 0;
    font-size: 14px;
    color: var(--ink-soft);
    line-height: 1.4;
  }
.payli-page-pricing .price-card.featured .pkg-features li {
    color: rgba(255,255,255,.85);
  }
.payli-page-pricing .price-card .pkg-features li svg {
    width: 16px; height: 16px;
    color: var(--brand);
    margin-top: 2px;
    flex-shrink: 0;
  }
.payli-page-pricing .price-card.featured .pkg-features li svg {
    color: var(--brand-light);
  }
.payli-page-pricing .price-card .pkg-features li.muted {
    color: var(--muted-light);
    text-decoration: line-through;
  }
.payli-page-pricing .price-card .pkg-features li.muted svg {
    color: var(--muted-light);
  }
.payli-page-pricing .price-card .pkg-cta {
    width: 100%;
    padding: 14px 24px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    display: flex; align-items: center; justify-content: center; gap: 6px;
    transition: all .2s;
    position: relative; z-index: 1;
  }
.payli-page-pricing .price-card .pkg-cta.outline {
    background: var(--paper);
    border: 1px solid var(--line);
    color: var(--ink);
  }
.payli-page-pricing .price-card .pkg-cta.outline:hover {
    border-color: var(--brand);
    color: var(--brand);
  }
.payli-page-pricing .price-card .pkg-cta.solid {
    background: var(--brand);
    color: white;
    box-shadow: var(--shadow-brand);
  }
.payli-page-pricing .price-card .pkg-cta.solid:hover {
    transform: translateY(-1px);
    box-shadow: 0 24px 56px rgba(41,82,197,.32), 0 10px 20px rgba(41,82,197,.20);
  }
comment
.payli-page-pricing .fee-callout {
    padding: 80px 0 120px;
    background: var(--bg);
  }
.payli-page-pricing .fee-card {
    background: linear-gradient(155deg, var(--brand), var(--brand-darker));
    border-radius: 32px;
    padding: 80px 64px;
    color: white;
    box-shadow: var(--shadow-brand);
    position: relative;
    overflow: hidden;
    text-align: center;
  }
.payli-page-pricing .fee-card::before {
    content: '';
    position: absolute;
    top: -100px; right: -100px;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(255,255,255,.12), transparent 70%);
    border-radius: 50%;
    pointer-events: none;
  }
.payli-page-pricing .fee-card::after {
    content: '';
    position: absolute;
    bottom: -200px; left: -100px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
    border-radius: 50%;
    pointer-events: none;
  }
.payli-page-pricing .fee-card .container-inner {
    position: relative;
    z-index: 1;
  }
.payli-page-pricing .fee-card .eyebrow {
    background: rgba(255,255,255,.15);
    color: white;
    backdrop-filter: blur(10px);
  }
.payli-page-pricing .fee-card h2 {
    font-size: clamp(40px, 5vw, 64px);
    margin-bottom: 16px;
    color: white;
    letter-spacing: -.04em;
  }
.payli-page-pricing .fee-card h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: rgba(255,255,255,.7);
  }
.payli-page-pricing .fee-card p {
    font-size: 18px;
    color: rgba(255,255,255,.85);
    max-width: 600px;
    margin: 0 auto 40px;
  }
.payli-page-pricing .fee-amount {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(120px, 18vw, 240px);
    font-weight: 700;
    line-height: .9;
    letter-spacing: -.07em;
    color: white;
    margin-bottom: 16px;
  }
.payli-page-pricing .fee-amount .pct-sign {
    font-size: 0.5em;
    color: rgba(255,255,255,.6);
    margin-left: 4px;
    vertical-align: top;
    line-height: 1.7;
  }
.payli-page-pricing .fee-sub {
    display: inline-flex; align-items: center; gap: 14px;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(10px);
    padding: 14px 24px;
    border-radius: 100px;
    border: 1px solid rgba(255,255,255,.15);
    margin-bottom: 36px;
  }
.payli-page-pricing .fee-sub-item {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px;
    color: white;
    font-weight: 500;
  }
.payli-page-pricing .fee-sub-item svg {
    width: 16px; height: 16px;
    color: white;
    opacity: .7;
  }
.payli-page-pricing .fee-sub-divider {
    width: 1px;
    height: 16px;
    background: rgba(255,255,255,.2);
  }
.payli-page-pricing .fee-methods {
    display: flex; flex-wrap: wrap; gap: 8px;
    justify-content: center;
    margin-top: 16px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
  }
.payli-page-pricing .fee-method {
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.15);
    backdrop-filter: blur(10px);
    color: white;
    padding: 8px 16px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 600;
  }
comment
.payli-page-pricing .compare-section {
    padding: 120px 0;
  }
.payli-page-pricing .section-title-row {
    text-align: center;
    margin-bottom: 60px;
  }
.payli-page-pricing .section-eyebrow {
    color: var(--brand);
    font-size: 13px; font-weight: 600;
    text-transform: uppercase; letter-spacing: .12em;
    margin-bottom: 12px;
  }
.payli-page-pricing .section-title-row h2 {
    font-size: clamp(40px, 5vw, 64px);
    letter-spacing: -.04em;
    max-width: 700px;
    margin: 0 auto 16px;
  }
.payli-page-pricing .section-title-row h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-pricing .section-title-row p {
    color: var(--ink-soft);
    font-size: 17px;
    max-width: 580px;
    margin: 0 auto;
  }
.payli-page-pricing .compare-table-wrap {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--shadow-md);
  }
.payli-page-pricing .compare-table {
    width: 100%;
    border-collapse: collapse;
  }
.payli-page-pricing .compare-table thead {
    background: var(--bg);
  }
.payli-page-pricing .compare-table th {
    padding: 24px 24px;
    text-align: center;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--ink);
    border-bottom: 1px solid var(--line);
    position: relative;
  }
.payli-page-pricing .compare-table th:first-child {
    text-align: left;
    background: var(--paper);
    width: 35%;
  }
.payli-page-pricing .compare-table th .pkg-sub {
    display: block;
    margin-top: 4px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: var(--muted);
    letter-spacing: 0;
  }
.payli-page-pricing .compare-table th.featured-col {
    background: linear-gradient(180deg, var(--ink), #1a2440);
    color: white;
    position: relative;
  }
.payli-page-pricing .compare-table th.featured-col .pkg-sub {
    color: rgba(255,255,255,.6);
  }
.payli-page-pricing .compare-table th.featured-col::before {
    content: 'Populair';
    position: absolute;
    top: 8px; right: 8px;
    background: var(--brand);
    color: white;
    padding: 3px 8px;
    border-radius: 100px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
  }
.payli-page-pricing .compare-table td {
    padding: 16px 24px;
    border-bottom: 1px solid var(--line-soft);
    font-size: 14px;
    color: var(--ink-soft);
    text-align: center;
  }
.payli-page-pricing .compare-table td:first-child {
    text-align: left;
    color: var(--ink);
    font-weight: 500;
  }
.payli-page-pricing .compare-table td.featured-col {
    background: var(--bg);
    color: var(--ink);
    font-weight: 600;
  }
.payli-page-pricing .compare-table tr:last-child td {
    border-bottom: none;
  }
.payli-page-pricing .compare-table .check {
    color: var(--brand);
    font-size: 18px;
  }
.payli-page-pricing .compare-table .x {
    color: var(--muted-light);
  }
.payli-page-pricing .compare-table .section-row td {
    background: var(--bg);
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 700;
    color: var(--ink);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 14px 24px;
    text-align: left !important;
  }
.payli-page-pricing .compare-table .section-row td.featured-col {
    background: var(--bg);
  }
comment
.payli-page-pricing .hw-section {
    padding: 120px 0;
    background: var(--bg);
  }
.payli-page-pricing .hw-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 32px;
    padding: 64px;
    box-shadow: var(--shadow-md);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
    position: relative;
    overflow: hidden;
  }
.payli-page-pricing .hw-card::before {
    content: '';
    position: absolute;
    bottom: -150px; right: -150px;
    width: 400px; height: 400px;
    background: radial-gradient(circle, var(--brand-soft), transparent 70%);
    border-radius: 50%;
  }
.payli-page-pricing .hw-content { position: relative; z-index: 1; }
.payli-page-pricing .hw-content h2 {
    font-size: clamp(36px, 4.5vw, 56px);
    margin-bottom: 16px;
  }
.payli-page-pricing .hw-content h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-pricing .hw-content > p {
    font-size: 17px;
    color: var(--ink-soft);
    margin-bottom: 24px;
    max-width: 480px;
  }
.payli-page-pricing .hw-list {
    display: flex; flex-direction: column;
    gap: 8px;
    margin-bottom: 28px;
  }
.payli-page-pricing .hw-item {
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 18px;
    background: var(--bg);
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    transition: all .2s;
  }
.payli-page-pricing .hw-item:hover {
    border-color: var(--brand);
    background: var(--brand-softer);
  }
.payli-page-pricing .hw-item-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
  }
.payli-page-pricing .hw-item-name .sub {
    display: block;
    font-size: 12px;
    color: var(--muted);
    font-weight: 400;
    margin-top: 2px;
  }
.payli-page-pricing .hw-item-price {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.02em;
  }
.payli-page-pricing .hw-item-price .vat {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 11px;
    color: var(--muted);
    font-weight: 400;
    margin-left: 4px;
  }
comment
.payli-page-pricing .hw-visual {
    position: relative;
    height: 360px;
    z-index: 1;
    min-width: 0;
  }
.payli-page-pricing .hw-terminal {
    position: absolute;
    top: 30px; left: 60px;
    width: 160px; height: 280px;
    background: linear-gradient(155deg, #2a3450, #0B1530);
    border-radius: 22px;
    padding: 8px;
    transform: rotate(-6deg);
    box-shadow: var(--shadow-xl), inset 0 0 0 1px rgba(255,255,255,.04);
    z-index: 3;
    animation: float-hw 6s ease-in-out infinite;
  }
@keyframes float-hw {
    0%,100% { transform: rotate(-6deg) translateY(0); }
    50% { transform: rotate(-6deg) translateY(-6px); }
  }
.payli-page-pricing .hw-terminal-screen {
    background: white;
    border-radius: 14px;
    height: 180px;
    padding: 14px;
    display: flex; flex-direction: column;
    align-items: center;
    justify-content: center;
  }
.payli-page-pricing .hw-terminal-screen .lbl {
    font-size: 8px;
    color: var(--muted-light);
    text-transform: uppercase;
    letter-spacing: .15em;
    font-weight: 700;
  }
.payli-page-pricing .hw-terminal-screen .amt {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 32px;
    font-weight: 700;
    letter-spacing: -.04em;
    color: var(--ink);
    margin-top: 6px;
  }
.payli-page-pricing .hw-terminal-screen .amt .c {
    font-size: 18px; color: var(--muted); vertical-align: top; line-height: 1.4;
  }
.payli-page-pricing .hw-terminal-screen .prm {
    font-size: 8px;
    color: var(--brand);
    margin-top: 8px;
    font-weight: 600;
  }
.payli-page-pricing .hw-terminal-keys {
    margin-top: 8px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    padding: 0 6px;
  }
.payli-page-pricing .hw-terminal-key {
    aspect-ratio: 2.2 / 1;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
    border-radius: 4px;
    border: 1px solid rgba(255,255,255,.08);
  }
.payli-page-pricing .hw-printer-mini {
    position: absolute;
    right: 30px; top: 50px;
    width: 130px; height: 90px;
    background: linear-gradient(160deg, #3a4670, #1a2440);
    border-radius: 12px;
    padding: 8px;
    transform: rotate(8deg);
    box-shadow: var(--shadow-lg);
    z-index: 2;
    animation: float-hw 7s ease-in-out infinite;
  }
.payli-page-pricing .hw-printer-mini::before {
    content: '';
    position: absolute;
    top: 18px; left: 8px; right: 8px;
    height: 50px;
    background: white;
    border-radius: 2px;
  }
.payli-page-pricing .hw-cashdrawer-mini {
    position: absolute;
    right: 0; bottom: 30px;
    width: 200px; height: 60px;
    background: linear-gradient(180deg, #3a4670, #1a2440);
    border-radius: 8px;
    transform: rotate(-3deg);
    box-shadow: var(--shadow-md);
    z-index: 1;
  }
.payli-page-pricing .hw-cashdrawer-mini::before {
    content: '';
    position: absolute;
    top: 12px; left: 14px; right: 14px; bottom: 10px;
    background: linear-gradient(90deg, #0B1530 0%, #1a2440 50%, #0B1530 100%);
    border-radius: 4px;
    box-shadow: inset 0 2px 4px rgba(0,0,0,.6);
  }
.payli-page-pricing .hw-badge {
    position: absolute;
    background: white;
    border: 1px solid var(--line);
    box-shadow: var(--shadow-md);
    padding: 10px 14px;
    border-radius: 14px;
    font-size: 12px;
    font-weight: 600;
    color: var(--ink);
    z-index: 4;
    display: flex; align-items: center; gap: 8px;
  }
.payli-page-pricing .hw-badge svg { width: 14px; height: 14px; color: var(--brand); }
.payli-page-pricing .hw-badge.b1 {
    top: 0; right: 80px;
    animation: float-badge 5s ease-in-out infinite;
  }
.payli-page-pricing .hw-badge.b2 {
    bottom: 10px; left: 0;
    animation: float-badge 5s ease-in-out infinite -2.5s;
  }
@keyframes float-badge {
    0%,100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
comment
.payli-page-pricing .vs-section {
    padding: 120px 0;
    background: var(--cream-soft);
    border-top: 1px solid var(--cream-line);
    border-bottom: 1px solid var(--cream-line);
    position: relative;
  }
.payli-page-pricing .vs-section .section-title-row h2 .em {
    color: var(--brand);
  }
.payli-page-pricing .vs-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
.payli-page-pricing .vs-card {
    background: var(--paper);
    border: 1px solid var(--cream-line);
    border-radius: 22px;
    padding: 32px;
    text-align: center;
  }
.payli-page-pricing .vs-card.payli {
    background: linear-gradient(155deg, var(--ink), #1a2440);
    color: white;
    border: 1px solid var(--ink);
    transform: scale(1.05);
    box-shadow: var(--shadow-xl);
    position: relative;
    overflow: hidden;
  }
.payli-page-pricing .vs-card.payli::before {
    content: '';
    position: absolute;
    top: -50%; right: -50%;
    width: 100%; height: 100%;
    background: radial-gradient(circle, rgba(41,82,197,.3), transparent 70%);
    border-radius: 50%;
  }
.payli-page-pricing .vs-card .vs-name {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -.02em;
    margin-bottom: 8px;
    position: relative;
  }
.payli-page-pricing .vs-card .vs-monthly {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 56px;
    font-weight: 700;
    letter-spacing: -.05em;
    line-height: 1;
    margin: 24px 0 4px;
    color: var(--ink);
    position: relative;
  }
.payli-page-pricing .vs-card.payli .vs-monthly {
    color: white;
  }
.payli-page-pricing .vs-card .vs-monthly .currency {
    font-size: 32px;
    color: var(--muted);
    vertical-align: top;
    line-height: 1.4;
  }
.payli-page-pricing .vs-card.payli .vs-monthly .currency {
    color: rgba(255,255,255,.5);
  }
.payli-page-pricing .vs-card .vs-period {
    font-size: 12px;
    color: var(--muted);
    margin-bottom: 24px;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 600;
    position: relative;
  }
.payli-page-pricing .vs-card.payli .vs-period {
    color: rgba(255,255,255,.5);
  }
.payli-page-pricing .vs-card .vs-fee {
    background: var(--bg);
    padding: 14px;
    border-radius: 12px;
    margin-bottom: 16px;
    border: 1px solid var(--line-soft);
    position: relative;
  }
.payli-page-pricing .vs-card.payli .vs-fee {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.1);
  }
.payli-page-pricing .vs-card .vs-fee-label {
    font-size: 11px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 600;
    margin-bottom: 4px;
  }
.payli-page-pricing .vs-card.payli .vs-fee-label {
    color: rgba(255,255,255,.5);
  }
.payli-page-pricing .vs-card .vs-fee-val {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.03em;
  }
.payli-page-pricing .vs-card.payli .vs-fee-val {
    color: white;
  }
.payli-page-pricing .vs-card .vs-features {
    list-style: none;
    text-align: left;
    position: relative;
  }
.payli-page-pricing .vs-card .vs-features li {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 6px 0;
    font-size: 13px;
    color: var(--ink-soft);
  }
.payli-page-pricing .vs-card.payli .vs-features li {
    color: rgba(255,255,255,.85);
  }
.payli-page-pricing .vs-card .vs-features li svg {
    width: 14px; height: 14px;
    color: var(--brand);
    margin-top: 3px;
    flex-shrink: 0;
  }
.payli-page-pricing .vs-card.payli .vs-features li svg {
    color: var(--brand-light);
  }
.payli-page-pricing .vs-card .vs-features li.x svg {
    color: var(--muted-light);
  }
.payli-page-pricing .vs-card .vs-features li.x {
    color: var(--muted-light);
  }
.payli-page-pricing .vs-card.payli .vs-features li.x {
    color: rgba(255,255,255,.4);
  }
comment
.payli-page-pricing .faq-section {
    padding: 120px 0;
  }
.payli-page-pricing .faq-grid {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 80px;
  }
.payli-page-pricing .faq-grid h2 {
    font-size: clamp(36px, 4.5vw, 56px);
    margin-bottom: 16px;
  }
.payli-page-pricing .faq-grid h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-pricing .faq-grid > div:first-child p {
    color: var(--ink-soft);
    font-size: 16px;
    margin-bottom: 24px;
  }
.payli-page-pricing .faq-help {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 24px;
    display: flex; flex-direction: column; gap: 12px;
  }
.payli-page-pricing .faq-help h4 {
    font-size: 16px;
    margin: 0;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 600;
  }
.payli-page-pricing .faq-help-link {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0;
    font-size: 14px;
    border-top: 1px solid var(--line-soft);
    color: var(--ink-soft);
    transition: color .2s;
  }
.payli-page-pricing .faq-help-link:hover { color: var(--brand); }
.payli-page-pricing .faq-help-link svg { width: 14px; height: 14px; }
.payli-page-pricing .faq-list { border-top: 1px solid var(--line); }
.payli-page-pricing .faq-item { border-bottom: 1px solid var(--line); }
.payli-page-pricing .faq-q {
    width: 100%;
    padding: 24px 0;
    display: flex; justify-content: space-between; align-items: center;
    font-size: 17px;
    font-weight: 600;
    color: var(--ink);
    text-align: left;
    font-family: 'Plus Jakarta Sans', sans-serif;
  }
.payli-page-pricing .faq-q .plus {
    width: 28px; height: 28px;
    background: var(--bg);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--ink);
    font-size: 18px;
    font-weight: 400;
    flex-shrink: 0;
    transition: all .3s;
  }
.payli-page-pricing .faq-item.open .faq-q .plus {
    background: var(--brand);
    color: white;
    transform: rotate(45deg);
  }
.payli-page-pricing .faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease, padding .3s ease;
    color: var(--ink-soft);
    font-size: 15px;
    line-height: 1.65;
  }
.payli-page-pricing .faq-item.open .faq-a {
    max-height: 400px;
    padding: 0 0 24px;
  }
comment
.payli-page-pricing .cta-dark {
    padding: 100px 0 !important;
    background: var(--ink) !important;
    color: white !important;
    position: relative !important;
    overflow: hidden !important;
  }
.payli-page-pricing section.cta-dark {
    background: var(--ink) !important;
    color: white !important;
  }
.payli-page-pricing .cta-dark * {
    color: inherit;
  }
.payli-page-pricing .cta-dark::before {
    content: '';
    position: absolute;
    top: -100px; right: -100px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(41,82,197,.4), transparent 70%);
    border-radius: 50%;
  }
.payli-page-pricing .cta-dark::after {
    content: '';
    position: absolute;
    bottom: -200px; left: -100px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(85,119,217,.2), transparent 70%);
    border-radius: 50%;
  }
.payli-page-pricing .cta-dark .container {
    text-align: center;
    position: relative; z-index: 1;
  }
.payli-page-pricing .cta-dark .eyebrow {
    background: rgba(255,255,255,.1);
    color: white;
  }
.payli-page-pricing .cta-dark h2 {
    font-size: clamp(48px, 6vw, 88px) !important;
    margin-bottom: 24px !important;
    color: white !important;
  }
.payli-page-pricing .cta-dark h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand-light);
  }
.payli-page-pricing .cta-dark p {
    font-size: 18px !important;
    color: rgba(255,255,255,.7) !important;
    max-width: 540px;
    margin: 0 auto 36px;
  }
.payli-page-pricing .cta-dark-btns {
    display: flex; gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }
.payli-page-pricing .btn-large-primary {
    padding: 16px 28px; font-size: 15px; font-weight: 600;
    color: white; background: var(--brand); border-radius: 100px;
    box-shadow: var(--shadow-brand);
    display: inline-flex; align-items: center; gap: 8px;
    transition: transform .2s, box-shadow .2s;
  }
.payli-page-pricing .btn-large-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 28px 64px rgba(41,82,197,.34), 0 12px 24px rgba(41,82,197,.22);
  }
.payli-page-pricing .btn-large-ghost {
    padding: 16px 28px; font-size: 15px; font-weight: 600;
    color: var(--ink); border-radius: 100px;
    background: var(--paper);
    border: 1px solid var(--line);
    display: inline-flex; align-items: center; gap: 8px;
    transition: background .2s, border-color .2s;
  }
comment
.payli-page-pricing .payment-icons { display: flex; gap: 12px; align-items: center; }
.payli-page-pricing .pay-icon {
    height: 28px;
    padding: 4px 10px;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
    color: var(--ink);
    display: flex; align-items: center;
    letter-spacing: -.02em;
  }
.payli-page-pricing .pay-icon.bc { color: #005498; }
comment
.payli-page-pricing .floating-cta {
    position: fixed;
    bottom: 24px; right: 24px;
    background: var(--brand);
    color: white;
    padding: 14px 22px;
    border-radius: 100px;
    box-shadow: var(--shadow-brand);
    display: flex; align-items: center; gap: 10px;
    font-weight: 600;
    font-size: 14px;
    transition: all .3s;
    opacity: 0;
    transform: translateY(20px);
    pointer-events: none;
    z-index: 50;
  }
.payli-page-pricing .floating-cta.show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
  }
.payli-page-pricing .floating-cta:hover { transform: translateY(-2px) scale(1.02); }
.payli-page-pricing .floating-cta img { height: 16px; filter: brightness(0) invert(1); }
comment
/* Laptop schermen — kleinere desktops (1280-1440px) */
@media (max-width: 1440px) {
  .payli-page-pricing .container { padding: 0 28px; }
  .payli-page-pricing .section { padding: 100px 0; }
  .payli-page-pricing .hero { padding: 80px 0 60px; }
  .payli-page-pricing .hero h1 { font-size: clamp(42px, 6.5vw, 88px); }
  .payli-page-pricing .pricing-grid { gap: 16px; }
  .payli-page-pricing .price-card { padding: 28px 22px; }
  .payli-page-pricing .price-card .price-amount { font-size: 48px; }
  .payli-page-pricing .price-card .pkg-features li { font-size: 13px; padding: 7px 0; }
  .payli-page-pricing .fee-card { padding: 64px 48px; }
  .payli-page-pricing .fee-amount { font-size: clamp(120px, 16vw, 200px); }
  .payli-page-pricing .compare-table th,
  .payli-page-pricing .compare-table td { padding: 14px 18px; font-size: 13.5px; }
  .payli-page-pricing .compare-table th { font-size: 16px; }
  .payli-page-pricing .hw-card { padding: 56px; gap: 56px; }
  .payli-page-pricing .vs-card { padding: 28px 24px; }
  .payli-page-pricing .footer-grid { gap: 48px; }
}

/* Smallere laptop / groot tablet (1100-1280px) */
@media (max-width: 1280px) {
  .payli-page-pricing .hero h1 { font-size: clamp(40px, 6.5vw, 76px); }
  .payli-page-pricing .section { padding: 100px 0; }
  .payli-page-pricing .pricing-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .payli-page-pricing .price-card.featured { transform: none; }
  .payli-page-pricing .price-card { padding: 32px 28px; }
  .payli-page-pricing .price-card .price-amount { font-size: 56px; }
  .payli-page-pricing .vs-cards { grid-template-columns: 1fr 1fr 1fr; }
  .payli-page-pricing .vs-card.payli { transform: scale(1.03); }
  .payli-page-pricing .hw-card { padding: 48px; gap: 48px; }
}
/* Hardware-card op kleinere laptops naar 1-koloms (mockup onder tekst) */
@media (max-width: 1400px) {
  .payli-page-pricing .hw-card { grid-template-columns: 1fr !important; gap: 48px; padding: 48px; text-align: center; }
  .payli-page-pricing .hw-content { max-width: 600px; margin: 0 auto; }
  .payli-page-pricing .hw-content > p { margin-left: auto; margin-right: auto; }
  .payli-page-pricing .hw-list { text-align: left; max-width: 520px; margin-left: auto; margin-right: auto; }
  .payli-page-pricing .hw-visual { margin: 24px auto 0; max-width: 520px; width: 100%; height: 380px; }
}

@media (max-width: 1024px) {
  .payli-page-pricing .container { padding: 0 24px; }
  .payli-page-pricing .section { padding: 100px 0; }
  .payli-page-pricing .hero { padding: 80px 0 60px; }
  .payli-page-pricing .fee-card { padding: 60px 32px; }
  .payli-page-pricing .compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .payli-page-pricing .compare-table { min-width: 720px; }
  .payli-page-pricing .hw-card { grid-template-columns: 1fr; gap: 48px; padding: 40px; text-align: center; }
  .payli-page-pricing .hw-list { text-align: left; }
  .payli-page-pricing .vs-cards { grid-template-columns: 1fr; gap: 16px; }
  .payli-page-pricing .vs-card.payli { transform: none; }
  .payli-page-pricing .faq-grid { grid-template-columns: 1fr; gap: 40px; }
  .payli-page-pricing .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .payli-page-pricing .nav-links { display: none; }
  .payli-page-pricing .nav-toggle { display: flex; }
}
@media (max-width: 768px) {
  .payli-page-pricing .container { padding: 0 18px; }
  .payli-page-pricing .section { padding: 70px 0; }
  .payli-page-pricing .hero { padding: 60px 0 40px; }
  .payli-page-pricing .hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .payli-page-pricing .hero p { font-size: 16px; }
  .payli-page-pricing .pricing-grid { grid-template-columns: 1fr; }
  .payli-page-pricing .price-card { padding: 28px 24px; }
  .payli-page-pricing .price-card.featured { transform: none; margin-top: 16px; }
  .payli-page-pricing .price-card .price-amount { font-size: 48px; }
  .payli-page-pricing .fee-card { padding: 48px 24px; border-radius: 24px; }
  .payli-page-pricing .fee-card h2 { font-size: clamp(32px, 7vw, 48px); }
  .payli-page-pricing .fee-amount { font-size: clamp(80px, 22vw, 140px); }
  .payli-page-pricing .fee-sub { flex-direction: column; gap: 8px; padding: 16px 20px; }
  .payli-page-pricing .fee-sub-divider { display: none; }
  .payli-page-pricing .compare-table th, .payli-page-pricing .compare-table td { padding: 12px 14px; font-size: 13px; }
  .payli-page-pricing .compare-table th { font-size: 14px; }
  .payli-page-pricing .hw-card { padding: 32px 24px; border-radius: 24px; }
  .payli-page-pricing .hw-content h2 { font-size: 32px; }
  .payli-page-pricing .hw-visual { height: 280px; transform: scale(0.85); }
  .payli-page-pricing .hw-badge { font-size: 11px; padding: 8px 12px; }
  .payli-page-pricing .hw-item { padding: 12px 14px; }
  .payli-page-pricing .hw-item-price { font-size: 16px; }
  .payli-page-pricing .vs-card { padding: 24px 20px; }
  .payli-page-pricing .vs-card .vs-monthly { font-size: 44px; margin: 16px 0 4px; }
  .payli-page-pricing .vs-card .vs-fee-val { font-size: 20px; }
  .payli-page-pricing .cta-dark h2 { font-size: clamp(36px, 8vw, 56px); }
  .payli-page-pricing .cta-dark { padding: 70px 0; }
  .payli-page-pricing .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .payli-page-pricing .footer-brand { grid-column: 1 / -1; }
  .payli-page-pricing .footer-bottom { flex-direction: column; align-items: flex-start; }
  .payli-page-pricing .nav-cta .btn-ghost { display: none; }
  .payli-page-pricing .nav-cta .btn-primary { padding: 10px 16px; font-size: 13px; }
  .payli-page-pricing .nav-logo { height: 26px; }
  .payli-page-pricing .floating-cta { padding: 12px 18px; font-size: 13px; bottom: 16px; right: 16px; }
  .payli-page-pricing .section-title-row h2 { font-size: clamp(32px, 7vw, 48px); }
  .payli-page-pricing .faq-q { font-size: 15px; padding: 20px 0; }
}
@media (max-width: 480px) {
  .payli-page-pricing .container { padding: 0 16px; }
  .payli-page-pricing .section { padding: 56px 0; }
  .payli-page-pricing .hero h1 { font-size: clamp(32px, 10vw, 44px); letter-spacing: -.03em; }
  .payli-page-pricing .btn-large-primary, .payli-page-pricing .btn-large-ghost { padding: 14px 22px; font-size: 14px; width: 100%; justify-content: center; }
  .payli-page-pricing .price-card .price-amount { font-size: 44px; }
  .payli-page-pricing .fee-amount { font-size: clamp(72px, 22vw, 110px); }
  .payli-page-pricing .vs-card .vs-monthly { font-size: 40px; }
  .payli-page-pricing .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .payli-page-pricing .footer-brand { grid-column: auto; }
  .payli-page-pricing .cta-dark-btns { flex-direction: column; width: 100%; }
  .payli-page-pricing .cta-dark-btns a { width: 100%; justify-content: center; }
  .payli-page-pricing .nav-inner { padding: 14px 18px; }
  .payli-page-pricing .price-popular { font-size: 10px; padding: 6px 12px; }
}

/* ========================================
   Laptop/desktop fine-tuning
   ======================================== */

/* Op echt grote schermen: zorg dat content niet te wijd uitspreidt */
@media (min-width: 1600px) {
  .payli-page-pricing .container { max-width: 1320px; }
  .payli-page-pricing .pricing-grid { gap: 24px; }
}

/* Laptop sweet spot (1280-1500px) — meest voorkomende laptop-resoluties */
@media (min-width: 1281px) and (max-width: 1500px) {
  .payli-page-pricing .section { padding: 110px 0; }
  .payli-page-pricing .hero { padding: 80px 0 70px; }
  .payli-page-pricing .hero h1 { font-size: clamp(48px, 6vw, 80px); }
  .payli-page-pricing .hero p { font-size: 17px; }
  .payli-page-pricing .pricing-grid { gap: 18px; }
  .payli-page-pricing .price-card { padding: 28px 22px; }
  .payli-page-pricing .price-card .pkg-tagline { font-size: 13px; }
  .payli-page-pricing .price-card .price-amount { font-size: 52px; }
  .payli-page-pricing .price-card .pkg-features li { font-size: 13px; padding: 6px 0; gap: 8px; }
  /* MEER ruimte onder pricing kaarten */
  .payli-page-pricing .pricing-section { padding: 24px 0 130px; }

  /* Fee callout — kleiner cijfer + meer ruimte boven */
  .payli-page-pricing .fee-card { padding: 80px 56px; }
  .payli-page-pricing .fee-amount { font-size: clamp(140px, 14vw, 180px); }
  .payli-page-pricing .fee-callout { padding: 40px 0 130px; }

  /* Compare table — iets compacter, meer adem voor en na */
  .payli-page-pricing .compare-table th,
  .payli-page-pricing .compare-table td { padding: 14px 18px; font-size: 13.5px; }
  .payli-page-pricing .compare-table th { font-size: 16px; }
  .payli-page-pricing .compare-table th .pkg-sub { font-size: 11.5px; }
  .payli-page-pricing .compare-section { padding: 110px 0; }

  /* Hardware card op laptop sweet-spot: 1-koloms */
  .payli-page-pricing .hw-card { padding: 64px 48px; gap: 48px; }
  .payli-page-pricing .hw-section { padding: 110px 0; }
  .payli-page-pricing .hw-content h2 { font-size: clamp(32px, 4vw, 48px); }
  .payli-page-pricing .hw-visual { transform: scale(0.95); }

  /* VS cards — compacter */
  .payli-page-pricing .vs-section { padding: 110px 0; }
  .payli-page-pricing .vs-card { padding: 28px 24px; }
  .payli-page-pricing .vs-card .vs-monthly { font-size: 48px; }

  /* FAQ section */
  .payli-page-pricing .faq-section { padding: 110px 0; }
  .payli-page-pricing .faq-grid { gap: 60px; }

  /* Dark CTA */
  .payli-page-pricing .cta-dark { padding: 100px 0 !important; }
  .payli-page-pricing .cta-dark h2 { font-size: clamp(48px, 5.5vw, 72px) !important; }

  /* Footer — wat meer ademruimte */
  .payli-page-pricing .footer { padding: 80px 0 40px; }
  .payli-page-pricing .footer-grid { gap: 48px; margin-bottom: 56px; }

  /* Section titles — meer ademruimte voor titels */
  .payli-page-pricing .section-title-row { margin-bottom: 60px; }
  .payli-page-pricing .section-title-row h2 { font-size: clamp(36px, 4vw, 56px); }
}


/* ===========================================================
   FIX: Hardware-card altijd 1-koloms tot 1500px (laptop)
   =========================================================== */

/* Op alle schermen onder 1500px: hardware sectie 1-koloms */
@media (max-width: 1500px) {
    html body .payli-page-pricing .hw-card,
    .payli-page-pricing .hw-card {
        grid-template-columns: 1fr !important;
        gap: 48px !important;
        padding: 56px 48px !important;
        text-align: center !important;
    }

    html body .payli-page-pricing .hw-content,
    .payli-page-pricing .hw-content {
        max-width: 640px !important;
        margin: 0 auto !important;
    }

    html body .payli-page-pricing .hw-content > p,
    .payli-page-pricing .hw-content > p {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    html body .payli-page-pricing .hw-list,
    .payli-page-pricing .hw-list {
        text-align: left !important;
        max-width: 560px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    html body .payli-page-pricing .hw-visual,
    .payli-page-pricing .hw-visual {
        margin: 24px auto 0 !important;
        max-width: 520px !important;
        width: 100% !important;
        height: 400px !important;
        position: relative !important;
    }

    /* Terminal mockup gecentreerd in zijn visual container */
    html body .payli-page-pricing .hw-terminal,
    .payli-page-pricing .hw-terminal {
        left: 50% !important;
        top: 30px !important;
        transform: translateX(-180px) rotate(-6deg) !important;
    }

    /* Animation aanpassen voor nieuwe transform */
    @keyframes float-hw {
        0%, 100% { transform: translateX(-180px) rotate(-6deg) translateY(0); }
        50% { transform: translateX(-180px) rotate(-6deg) translateY(-6px); }
    }
}

/* === EINDE FIX === */


/* ===========================================================
   ULTRA-AGGRESSIVE FIX: Hardware ALTIJD 1-koloms behalve op zeer brede schermen
   =========================================================== */

/* Default: ALTIJD 1-koloms — geen overlap mogelijk */
html body .payli-page-pricing .hw-card,
.payli-page-pricing .hw-card {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 48px !important;
    padding: 56px 48px !important;
    text-align: center !important;
    align-items: center !important;
}

/* Hw content gecentreerd */
html body .payli-page-pricing .hw-content,
.payli-page-pricing .hw-content {
    max-width: 640px !important;
    margin: 0 auto !important;
    text-align: center !important;
}

html body .payli-page-pricing .hw-content > p,
.payli-page-pricing .hw-content > p {
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Hw lijst: tekst link uitgelijnd, maar gecentreerd binnen container */
html body .payli-page-pricing .hw-list,
.payli-page-pricing .hw-list {
    text-align: left !important;
    max-width: 560px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Hw visual: gecentreerd onder de tekst */
html body .payli-page-pricing .hw-visual,
.payli-page-pricing .hw-visual {
    margin: 24px auto 0 !important;
    max-width: 520px !important;
    width: 100% !important;
    height: 400px !important;
    position: relative !important;
}

/* Terminal mockup gecentreerd binnen visual container */
html body .payli-page-pricing .hw-terminal,
.payli-page-pricing .hw-terminal {
    left: 50% !important;
    top: 30px !important;
    margin-left: -80px !important;
    transform: rotate(-6deg) !important;
    animation: float-hw-centered 6s ease-in-out infinite !important;
}

@keyframes float-hw-centered {
    0%, 100% { transform: rotate(-6deg) translateY(0); }
    50% { transform: rotate(-6deg) translateY(-6px); }
}

/* === Op ZEER brede schermen (>1700px): 2-koloms layout activeren === */
@media (min-width: 1700px) {
    html body .payli-page-pricing .hw-card,
    .payli-page-pricing .hw-card {
        grid-template-columns: 1.1fr 1fr !important;
        gap: 64px !important;
        padding: 64px !important;
        text-align: left !important;
    }

    html body .payli-page-pricing .hw-content,
    .payli-page-pricing .hw-content {
        text-align: left !important;
        max-width: none !important;
    }

    html body .payli-page-pricing .hw-content > p,
    .payli-page-pricing .hw-content > p {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    html body .payli-page-pricing .hw-list,
    .payli-page-pricing .hw-list {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    html body .payli-page-pricing .hw-visual,
    .payli-page-pricing .hw-visual {
        margin: 0 !important;
    }

    /* Terminal in 2-col mode: weer aan de linkerkant van zijn visual */
    html body .payli-page-pricing .hw-terminal,
    .payli-page-pricing .hw-terminal {
        left: 60px !important;
        margin-left: 0 !important;
        top: 30px !important;
    }
}

/* === EINDE FIX === */


/* ===========================================================
   FIX: Floating CTA op prijspagina — keiharde override
   =========================================================== */

html body .payli-page-pricing .floating-cta,
html body .floating-cta,
.payli-page-pricing .floating-cta {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    left: auto !important;
    background: #2952C5 !important;
    background-color: #2952C5 !important;
    color: white !important;
    padding: 14px 22px !important;
    border-radius: 999px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 14.5px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    box-shadow: 0 12px 32px rgba(41,82,197,.35) !important;
    z-index: 99 !important;
    cursor: pointer !important;
    transition: all .3s ease !important;
    border: none !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    transform: translateY(80px) !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

html body .payli-page-pricing .floating-cta.show,
html body .floating-cta.show,
.payli-page-pricing .floating-cta.show {
    transform: translateY(0) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

html body .payli-page-pricing .floating-cta:hover,
.payli-page-pricing .floating-cta:hover {
    background: #1E40AF !important;
    transform: translateY(-4px) scale(1.02) !important;
    color: white !important;
}

html body .payli-page-pricing .floating-cta img,
.payli-page-pricing .floating-cta img {
    width: 22px !important;
    height: auto !important;
    display: inline-block !important;
    margin: 0 !important;
    filter: none !important;
}

/* Tekst en alle children wit */
html body .payli-page-pricing .floating-cta,
html body .payli-page-pricing .floating-cta * {
    color: white !important;
}

/* === EINDE FIX === */


/* ===========================================================
   FIX: Extra ruimte tussen pricing-kaarten en "Eerlijk & transparant"
   =========================================================== */

/* Pricing-section onderaan: meer ruimte */
html body .payli-page-pricing .pricing-section,
.payli-page-pricing .pricing-section {
    padding-bottom: 160px !important;
}

/* Fee callout (Eerlijk & transparant blauw blok) — meer ruimte boven */
html body .payli-page-pricing .fee-callout,
.payli-page-pricing .fee-callout {
    padding-top: 80px !important;
    padding-bottom: 120px !important;
    margin-top: 0 !important;
}

/* Op laptop schermen ook genoeg ruimte */
@media (max-width: 1500px) {
    html body .payli-page-pricing .pricing-section {
        padding-bottom: 140px !important;
    }
    html body .payli-page-pricing .fee-callout {
        padding-top: 60px !important;
    }
}

/* === EINDE FIX === */


/* ===========================================================
   FIX: Meer ruimte tussen vergelijkingstabel en Hardware sectie
   =========================================================== */

/* Compare-section meer padding-bottom */
html body .payli-page-pricing .compare-section,
.payli-page-pricing .compare-section {
    padding-top: 120px !important;
    padding-bottom: 160px !important;
}

/* Hardware sectie meer padding-top */
html body .payli-page-pricing .hw-section,
.payli-page-pricing .hw-section {
    padding-top: 120px !important;
    padding-bottom: 120px !important;
}

/* Op laptop schermen ook genoeg ruimte */
@media (max-width: 1500px) {
    html body .payli-page-pricing .compare-section {
        padding-bottom: 140px !important;
    }
    html body .payli-page-pricing .hw-section {
        padding-top: 100px !important;
    }
}

/* === EINDE FIX === */


/* ===========================================================
   FIX: CTA dark blok met afgeronde hoeken in container
   =========================================================== */

/* Wikkel het cta-dark blok in een buitencontainer met witte achtergrond */
html body .payli-page-pricing .cta-dark,
.payli-page-pricing .cta-dark {
    background: transparent !important;
    background-color: transparent !important;
    padding: 80px 24px !important;
    overflow: visible !important;
    position: relative !important;
}

/* De inner container krijgt de donkere achtergrond + afgeronde hoeken */
html body .payli-page-pricing .cta-dark .container,
.payli-page-pricing .cta-dark .container {
    background: #0B1530 !important;
    background-color: #0B1530 !important;
    border-radius: 32px !important;
    padding: 80px 64px !important;
    max-width: 1184px !important;
    margin: 0 auto !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden !important;
}

/* De radial gradients VERBERGEN (zaten op cta-dark zelf) en in container plaatsen */
html body .payli-page-pricing .cta-dark::before,
html body .payli-page-pricing .cta-dark::after,
.payli-page-pricing .cta-dark::before,
.payli-page-pricing .cta-dark::after {
    display: none !important;
}

/* Nieuwe radial gradients in de container */
html body .payli-page-pricing .cta-dark .container::before,
.payli-page-pricing .cta-dark .container::before {
    content: '' !important;
    position: absolute !important;
    top: -100px !important;
    right: -100px !important;
    width: 500px !important;
    height: 500px !important;
    background: radial-gradient(circle, rgba(41,82,197,.4), transparent 70%) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}

html body .payli-page-pricing .cta-dark .container::after,
.payli-page-pricing .cta-dark .container::after {
    content: '' !important;
    position: absolute !important;
    bottom: -200px !important;
    left: -100px !important;
    width: 600px !important;
    height: 600px !important;
    background: radial-gradient(circle, rgba(85,119,217,.2), transparent 70%) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}

/* Inhoud van container — boven de gradients */
html body .payli-page-pricing .cta-dark .container > *,
.payli-page-pricing .cta-dark .container > * {
    position: relative !important;
    z-index: 2 !important;
}

/* Zorg dat alle tekst nog steeds wit is */
html body .payli-page-pricing .cta-dark .container,
html body .payli-page-pricing .cta-dark .container * {
    color: white !important;
}

html body .payli-page-pricing .cta-dark .container .eyebrow,
.payli-page-pricing .cta-dark .container .eyebrow {
    color: rgba(255,255,255,.7) !important;
}

html body .payli-page-pricing .cta-dark .container p,
.payli-page-pricing .cta-dark .container p {
    color: rgba(255,255,255,.7) !important;
}

/* Op kleinere schermen: minder padding */
@media (max-width: 768px) {
    html body .payli-page-pricing .cta-dark .container,
    .payli-page-pricing .cta-dark .container {
        padding: 56px 32px !important;
        border-radius: 24px !important;
    }
}

/* === EINDE FIX === */


/* ===========================================================
   FIX: Pricing hero gecentreerd (eyebrow, h1, beschrijving)
   =========================================================== */

/* Hero sectie zelf gecentreerd */
html body .payli-page-pricing .hero,
.payli-page-pricing .hero {
    text-align: center !important;
}

/* Hero container: gecentreerd */
html body .payli-page-pricing .hero .container,
.payli-page-pricing .hero .container {
    text-align: center !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
}

/* Eyebrow ("Eerlijke tarieven · Geen verrassingen") gecentreerd */
html body .payli-page-pricing .hero .eyebrow,
.payli-page-pricing .hero .eyebrow {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: 24px !important;
}

/* H1 gecentreerd */
html body .payli-page-pricing .hero h1,
.payli-page-pricing .hero h1 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 960px !important;
}

/* Beschrijving gecentreerd */
html body .payli-page-pricing .hero p,
.payli-page-pricing .hero p {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 600px !important;
}

/* === EINDE FIX === */


/* ===========================================================
   COMING SOON badge + disabled CTA voor Free plan
   =========================================================== */

html body .payli-page-pricing .price-card.price-card-coming-soon,
.payli-page-pricing .price-card.price-card-coming-soon {
    position: relative !important;
}

html body .payli-page-pricing .price-card .badge-coming-soon,
.payli-page-pricing .price-card .badge-coming-soon {
    position: absolute !important;
    top: -12px !important;
    left: 24px !important;
    background: linear-gradient(135deg, #FFA726 0%, #FB8C00 100%) !important;
    color: white !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 6px 14px !important;
    border-radius: 100px !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    box-shadow: 0 4px 12px rgba(251,140,0,.30) !important;
    z-index: 5 !important;
    white-space: nowrap !important;
    line-height: 1 !important;
}

/* Disabled CTA — niet klikbaar */
html body .payli-page-pricing .pkg-cta.pkg-cta-disabled,
.payli-page-pricing .pkg-cta.pkg-cta-disabled {
    background: #F1F4F9 !important;
    color: #6E7B96 !important;
    border: 1px solid #E2E6F0 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    text-decoration: none !important;
    user-select: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}

html body .payli-page-pricing .pkg-cta.pkg-cta-disabled:hover,
.payli-page-pricing .pkg-cta.pkg-cta-disabled:hover {
    background: #F1F4F9 !important;
    transform: none !important;
}
