/* ===========================================================
   PREVENTIVE FIXES — gebaseerd op lessen van home/pos/pricing/webshop
   =========================================================== */

/* 1. Witruimte boven hero fix */
html body main#payli-main,
body main#payli-main {
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
}

body.page .ct-elementor-default-template,
body.page .entry-header,
body.page .page-header,
body.page .ct-hero-section,
body.page h1.entry-title {
    display: none !important;
}

.payli-page-hardware {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* 2. Page wrapper full-width met witte achtergrond */
html body.page-template-template-payli-hardware {
    background: #FAFBFD !important;
    background-color: #FAFBFD !important;
}

html body .payli-page-hardware,
.payli-page-hardware {
    background: #FAFBFD !important;
    background-color: #FAFBFD !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
    height: auto !important;
}

/* 3. Bg-orbs fixed positioning */
html body .payli-page-hardware .bg-orb,
.payli-page-hardware .bg-orb {
    position: fixed !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

/* 4. Hero ruime padding */
html body .payli-page-hardware .hero,
.payli-page-hardware .hero {
    overflow: visible !important;
    position: relative !important;
    padding-top: 80px !important;
    padding-bottom: 100px !important;
}

html body .payli-page-hardware .hero-visual,
.payli-page-hardware .hero-visual {
    position: relative !important;
    overflow: visible !important;
}

/* 5. Hero eyebrow lichtblauwe pil */
html body .payli-page-hardware .hero .eyebrow,
.payli-page-hardware .hero .eyebrow {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: #E8EEFB !important;
    color: #2952C5 !important;
    padding: 8px 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    border-radius: 100px !important;
    margin-bottom: 24px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    width: auto !important;
    max-width: max-content !important;
}

html body .payli-page-hardware .eyebrow .dot,
.payli-page-hardware .eyebrow .dot {
    width: 6px !important;
    height: 6px !important;
    background: #2952C5 !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

/* 6. USP strip donkere achtergrond */
html body .payli-page-hardware .usp-strip,
.payli-page-hardware .usp-strip {
    background: #0B1530 !important;
    background-color: #0B1530 !important;
    color: white !important;
    padding: 22px 0 !important;
    overflow: hidden !important;
    position: relative !important;
    width: 100% !important;
}

html body .payli-page-hardware .usp-strip::before,
.payli-page-hardware .usp-strip::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: 80px !important;
    z-index: 3 !important;
    pointer-events: none !important;
    background: linear-gradient(90deg, #0B1530, transparent) !important;
}

html body .payli-page-hardware .usp-strip::after,
.payli-page-hardware .usp-strip::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 80px !important;
    z-index: 3 !important;
    pointer-events: none !important;
    background: linear-gradient(-90deg, #0B1530, transparent) !important;
}

html body .payli-page-hardware .usp-item,
.payli-page-hardware .usp-item {
    color: white !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
}

html body .payli-page-hardware .usp-item svg,
html body .payli-page-hardware .usp-item .icon,
.payli-page-hardware .usp-item svg,
.payli-page-hardware .usp-item .icon {
    color: #6B8DEF !important;
    stroke: #6B8DEF !important;
    flex-shrink: 0 !important;
}

/* 7. Floating CTA */
html body .payli-page-hardware .floating-cta,
.payli-page-hardware .floating-cta {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    background: #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;
    transform: translateY(80px) !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: all .3s ease !important;
}

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

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

html body .payli-page-hardware .floating-cta img,
.payli-page-hardware .floating-cta img {
    width: 22px !important;
    height: auto !important;
}

html body .payli-page-hardware .floating-cta * {
    color: white !important;
}

/* 8. Dark CTA correct stylen */
html body .payli-page-hardware .cta-dark,
.payli-page-hardware .cta-dark {
    background: #FAFBFD !important;
    padding: 100px 24px !important;
    overflow: visible !important;
    width: 100% !important;
}

html body .payli-page-hardware .cta-dark .container,
.payli-page-hardware .cta-dark .container {
    background: #0B1530 !important;
    color: white !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;
}

html body .payli-page-hardware .cta-dark .container *,
.payli-page-hardware .cta-dark .container * {
    color: white !important;
}

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

/* Dark CTA eyebrow doorzichtig wit */
html body .payli-page-hardware .cta-dark .eyebrow,
.payli-page-hardware .cta-dark .eyebrow {
    background: rgba(255,255,255,.08) !important;
    color: white !important;
    border: 1px solid rgba(255,255,255,.15) !important;
}

html body .payli-page-hardware .cta-dark .eyebrow .dot,
.payli-page-hardware .cta-dark .eyebrow .dot {
    background: #6B8DEF !important;
}

html body .payli-page-hardware .cta-dark h2 .em,
html body .payli-page-hardware .cta-dark h2 em,
.payli-page-hardware .cta-dark h2 .em,
.payli-page-hardware .cta-dark h2 em {
    color: #6B8DEF !important;
}

/* 9. Section spacing */
html body .payli-page-hardware .stats-bar,
.payli-page-hardware .stats-bar {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
}

html body .payli-page-hardware .hero-product,
html body .payli-page-hardware .categories-bento,
html body .payli-page-hardware .quote-breaker,
html body .payli-page-hardware .all-products,
html body .payli-page-hardware .how-it-works,
html body .payli-page-hardware .tarieven,
html body .payli-page-hardware .faq-section,
.payli-page-hardware .hero-product,
.payli-page-hardware .categories-bento,
.payli-page-hardware .quote-breaker,
.payli-page-hardware .all-products,
.payli-page-hardware .how-it-works,
.payli-page-hardware .tarieven,
.payli-page-hardware .faq-section {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
}

/* 10. Bento cards: tekst boven decoratie */
html body .payli-page-hardware .bento-card,
.payli-page-hardware .bento-card {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate !important;
}

html body .payli-page-hardware .bento-card .bento-cat,
html body .payli-page-hardware .bento-card h3,
html body .payli-page-hardware .bento-card > p,
.payli-page-hardware .bento-card .bento-cat,
.payli-page-hardware .bento-card h3,
.payli-page-hardware .bento-card > p {
    position: relative !important;
    z-index: 10 !important;
}

html body .payli-page-hardware .bento-illu,
.payli-page-hardware .bento-illu {
    z-index: 1 !important;
    pointer-events: none !important;
}

/* 11. Bento eyebrow plain text styling (geen pil) */
html body .payli-page-hardware .bento-card .bento-cat,
.payli-page-hardware .bento-card .bento-cat {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    text-transform: uppercase !important;
    letter-spacing: .12em !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    margin-bottom: 12px !important;
    display: block !important;
    width: auto !important;
    max-width: none !important;
    color: #2952C5 !important;
}

/* === EINDE PREVENTIVE FIXES === */

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

comment
.payli-page-hardware::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-hardware img { max-width: 100%; display: block; }
.payli-page-hardware button { font-family: inherit; cursor: pointer; border: none; background: none; }
.payli-page-hardware a { color: inherit; text-decoration: none; }
.payli-page-hardware h1, .payli-page-hardware h2, .payli-page-hardware h3, .payli-page-hardware h4 {
    font-family: 'Bricolage Grotesque', 'Plus Jakarta Sans', sans-serif;
    letter-spacing: -.03em;
    line-height: 1.05;
    font-weight: 700;
  }
.payli-page-hardware .container { max-width: 1280px; margin: 0 auto; padding: 0 32px; position: relative; z-index: 2; }
.payli-page-hardware .section { padding: 120px 0; position: relative; }
comment
.payli-page-hardware .btn-ghost {
    padding: 10px 18px; font-size: 14px; font-weight: 500;
    color: var(--ink); border-radius: 100px;
    transition: background .2s;
  }
.payli-page-hardware .btn-ghost:hover { background: var(--line-soft); }
.payli-page-hardware .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-hardware .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-hardware .hero {
    padding: 80px 0 100px;
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .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-hardware .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-hardware .hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 64px;
    align-items: center;
  }
.payli-page-hardware .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-hardware .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-hardware .hero h1 {
    font-size: clamp(48px, 7.5vw, 108px);
    letter-spacing: -.045em;
    margin-bottom: 24px;
    line-height: .98;
  }
.payli-page-hardware .hero h1 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
    letter-spacing: -.02em;
  }
.payli-page-hardware .hero p {
    font-size: 19px; color: var(--ink-soft);
    max-width: 520px;
    margin-bottom: 32px;
  }
.payli-page-hardware .hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.payli-page-hardware .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-hardware .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-hardware .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;
  }
.payli-page-hardware .btn-large-ghost:hover { background: var(--bg); border-color: var(--muted-light); }
.payli-page-hardware .hero-meta {
    margin-top: 32px;
    display: flex; gap: 24px; align-items: center;
    font-size: 13px; color: var(--muted);
  }
.payli-page-hardware .hero-meta-item {
    display: flex; align-items: center; gap: 8px;
  }
.payli-page-hardware .hero-meta svg { width: 16px; height: 16px; color: var(--brand); }
comment
.payli-page-hardware .hero-visual {
    position: relative;
    height: 660px;
    display: flex; align-items: center; justify-content: center;
  }
.payli-page-hardware .terminal-main {
    position: relative;
    width: 280px; height: 540px;
    background: linear-gradient(155deg, #1a2440 0%, #0B1530 100%);
    border-radius: 36px;
    box-shadow: var(--shadow-xl), inset 0 0 0 2px rgba(255,255,255,.04);
    padding: 16px;
    z-index: 3;
    animation: float 6s ease-in-out infinite;
    transform: rotate(-4deg);
  }
@keyframes float {
    0%,100% { transform: rotate(-4deg) translateY(0); }
    50% { transform: rotate(-4deg) translateY(-12px); }
  }
.payli-page-hardware .terminal-screen {
    background: #fff;
    border-radius: 22px;
    height: 300px;
    padding: 24px 20px;
    display: flex; flex-direction: column;
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .terminal-screen::before {
    content: '';
    position: absolute; top: 12px; left: 50%;
    width: 8px; height: 8px;
    background: #1a2440; border-radius: 50%;
    transform: translateX(-50%);
  }
.payli-page-hardware .terminal-merchant {
    margin-top: 18px;
    font-size: 11px; font-weight: 600;
    color: var(--muted-light);
    text-transform: uppercase; letter-spacing: .12em;
    text-align: center;
  }
.payli-page-hardware .terminal-amount {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 56px; font-weight: 700;
    text-align: center;
    margin-top: 24px;
    letter-spacing: -.04em;
    color: var(--ink);
  }
.payli-page-hardware .terminal-amount .currency {
    font-size: 32px;
    color: var(--muted);
    margin-right: 4px;
    vertical-align: top;
    line-height: 1.4;
  }
.payli-page-hardware .terminal-prompt {
    margin-top: 20px;
    text-align: center;
    font-size: 13px;
    color: var(--ink-soft);
    font-weight: 500;
  }
.payli-page-hardware .terminal-card {
    margin-top: auto;
    margin-left: auto; margin-right: auto;
    width: 80px; height: 50px;
    background: linear-gradient(135deg, var(--brand), var(--brand-light));
    border-radius: 6px;
    position: relative;
    animation: tap 3s ease-in-out infinite;
  }
.payli-page-hardware .terminal-card::before {
    content: '';
    position: absolute;
    top: 12px; left: 8px;
    width: 16px; height: 12px;
    background: linear-gradient(135deg, #FFD580, #E5A93C);
    border-radius: 2px;
  }
.payli-page-hardware .terminal-card::after {
    content: '';
    position: absolute;
    top: 32px; right: 8px;
    width: 18px; height: 14px;
    border: 2px solid rgba(255,255,255,.6);
    border-radius: 50%;
    border-left-color: transparent;
    border-right-color: transparent;
    transform: rotate(0deg);
  }
@keyframes tap {
    0%,90%,100% { transform: translateY(0) scale(1); }
    45% { transform: translateY(-12px) scale(1.04); }
  }
.payli-page-hardware .terminal-keypad {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 6px;
    padding: 0 6px;
  }
.payli-page-hardware .terminal-key {
    aspect-ratio: 2.2 / 1;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: white;
    font-size: 18px; font-weight: 600;
    font-family: 'Bricolage Grotesque', sans-serif;
    letter-spacing: -.02em;
    border: 1px solid rgba(255,255,255,.08);
  }
comment
.payli-page-hardware .receipt-printer {
    position: absolute;
    right: -20px;
    bottom: 40px;
    width: 220px;
    background: linear-gradient(160deg, #2C3654, #0B1530);
    border-radius: 18px;
    padding: 12px;
    z-index: 2;
    box-shadow: var(--shadow-lg);
    transform: rotate(7deg);
    animation: float-printer 7s ease-in-out infinite;
  }
@keyframes float-printer {
    0%,100% { transform: rotate(7deg) translateY(0); }
    50% { transform: rotate(7deg) translateY(-10px); }
  }
.payli-page-hardware .receipt-printer-top {
    height: 30px;
    border-radius: 12px 12px 0 0;
    background: rgba(255,255,255,.05);
    display: flex; align-items: center; padding-left: 12px;
    font-size: 10px; color: rgba(255,255,255,.6);
    font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  }
.payli-page-hardware .receipt-paper {
    background: white;
    padding: 14px 12px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 9px;
    color: var(--ink);
    line-height: 1.6;
    margin: 0 -2px;
    box-shadow: inset 0 -8px 12px rgba(0,0,0,.04);
  }
.payli-page-hardware .receipt-paper .r-store {
    text-align: center; font-weight: 700;
    text-transform: uppercase; letter-spacing: .15em;
    margin-bottom: 8px;
    font-size: 10px;
  }
.payli-page-hardware .receipt-paper .r-line {
    display: flex; justify-content: space-between;
    padding: 2px 0;
  }
.payli-page-hardware .receipt-paper .r-divider {
    border-top: 1px dashed var(--ink);
    margin: 4px 0;
  }
.payli-page-hardware .receipt-paper .r-total {
    display: flex; justify-content: space-between;
    font-weight: 700;
    margin-top: 4px;
  }
.payli-page-hardware .receipt-tear {
    height: 8px;
    background: white;
    margin: 0 -2px;
    -webkit-mask-image: radial-gradient(circle at 4px 0, transparent 4px, black 5px);
    -webkit-mask-size: 8px 8px;
    -webkit-mask-position: 0 100%;
    -webkit-mask-repeat: repeat-x;
    mask-image: radial-gradient(circle at 4px 0, transparent 4px, black 5px);
    mask-size: 8px 8px;
    mask-position: 0 100%;
    mask-repeat: repeat-x;
  }
comment
.payli-page-hardware .cashdrawer-float {
    position: absolute;
    left: -20px;
    top: 50px;
    width: 200px;
    height: 50px;
    background: linear-gradient(180deg, #2C3654, #0B1530);
    border-radius: 8px;
    z-index: 1;
    box-shadow: var(--shadow-md);
    transform: rotate(-12deg);
    animation: float-cd 8s ease-in-out infinite;
  }
@keyframes float-cd {
    0%,100% { transform: rotate(-12deg) translateY(0); }
    50% { transform: rotate(-12deg) translateY(-8px); }
  }
.payli-page-hardware .cashdrawer-float::before {
    content: '';
    position: absolute;
    top: 14px; left: 14px; right: 14px; bottom: 12px;
    background: linear-gradient(90deg, #1a2440 0%, #2C3654 50%, #1a2440 100%);
    border-radius: 4px;
    box-shadow: inset 0 2px 4px rgba(0,0,0,.6);
  }
.payli-page-hardware .cashdrawer-float::after {
    content: '';
    position: absolute;
    bottom: 4px; left: 50%;
    width: 30px; height: 4px;
    background: rgba(255,255,255,.2);
    border-radius: 2px;
    transform: translateX(-50%);
  }
comment
.payli-page-hardware .usp-strip {
    background: var(--ink);
    padding: 18px 0;
    overflow: hidden;
    position: relative;
  }
.payli-page-hardware .usp-strip::before, .payli-page-hardware .usp-strip::after {
    content: '';
    position: absolute; top: 0; bottom: 0;
    width: 80px; z-index: 2;
    pointer-events: none;
  }
.payli-page-hardware .usp-strip::before {
    left: 0;
    background: linear-gradient(90deg, var(--ink), transparent);
  }
.payli-page-hardware .usp-strip::after {
    right: 0;
    background: linear-gradient(-90deg, var(--ink), transparent);
  }
.payli-page-hardware .usp-track {
    display: flex; gap: 56px;
    animation: marquee-rev 32s linear infinite;
    width: max-content;
  }
@keyframes marquee-rev {
    0% { transform: translateX(-50%); }
    100% { transform: translateX(0); }
  }
.payli-page-hardware .usp-item {
    display: flex; align-items: center; gap: 12px;
    color: white;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 18px; font-weight: 600;
    letter-spacing: -.02em;
    white-space: nowrap;
  }
.payli-page-hardware .usp-item .icon {
    width: 18px; height: 18px;
    color: var(--brand-light);
    flex-shrink: 0;
  }
comment
.payli-page-hardware .stats-bar {
    padding: 80px 0;
    background: var(--paper);
    border-bottom: 1px solid var(--line-soft);
  }
.payli-page-hardware .stats-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 24px;
  }
.payli-page-hardware .stat-hero {
    background: linear-gradient(155deg, var(--brand), var(--brand-darker));
    padding: 40px;
    border-radius: 24px;
    color: white;
    box-shadow: var(--shadow-brand);
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .stat-hero::before {
    content: '';
    position: absolute;
    top: -40%; right: -40%;
    width: 80%; height: 80%;
    background: radial-gradient(circle, rgba(255,255,255,.1), transparent 70%);
    border-radius: 50%;
  }
.payli-page-hardware .stat-hero .num {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 88px; font-weight: 700;
    letter-spacing: -.05em;
    line-height: .95;
  }
.payli-page-hardware .stat-hero .num .small { font-size: 50px; }
.payli-page-hardware .stat-hero .label {
    margin-top: 12px;
    font-size: 16px;
    opacity: .9;
  }
.payli-page-hardware .stat-hero .badge {
    position: absolute;
    top: 24px; right: 24px;
    background: rgba(255,255,255,.15);
    padding: 6px 12px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    backdrop-filter: blur(10px);
  }
.payli-page-hardware .stat-card {
    background: var(--paper);
    border: 1px solid var(--line);
    padding: 32px 24px;
    border-radius: 20px;
    display: flex; flex-direction: column;
    justify-content: center;
  }
.payli-page-hardware .stat-card .num {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 48px; font-weight: 700;
    color: var(--ink);
    letter-spacing: -.04em;
    line-height: 1;
  }
.payli-page-hardware .stat-card .num .small { font-size: 28px; color: var(--brand); }
.payli-page-hardware .stat-card .label {
    margin-top: 10px;
    font-size: 14px;
    color: var(--ink-soft);
  }
comment
.payli-page-hardware .hero-product {
    padding: 120px 0;
    background: var(--bg);
  }
.payli-page-hardware .hero-product-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 32px;
    padding: 64px;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .hero-product-grid::before {
    content: '';
    position: absolute;
    bottom: -200px; left: -200px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, var(--brand-soft), transparent 70%);
    border-radius: 50%;
    z-index: 0;
  }
.payli-page-hardware .hero-product-content { position: relative; z-index: 1; }
.payli-page-hardware .hero-product .featured {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--ink); color: white;
    padding: 6px 12px;
    border-radius: 100px;
    font-size: 11px; font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 20px;
  }
.payli-page-hardware .hero-product h2 {
    font-size: 56px;
    margin-bottom: 16px;
  }
.payli-page-hardware .hero-product .tagline {
    font-size: 18px;
    color: var(--ink-soft);
    margin-bottom: 28px;
  }
.payli-page-hardware .spec-list {
    list-style: none;
    margin-bottom: 32px;
  }
.payli-page-hardware .spec-list li {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 12px 0;
    border-top: 1px solid var(--line-soft);
    font-size: 15px;
    color: var(--ink-soft);
  }
.payli-page-hardware .spec-list li:last-child { border-bottom: 1px solid var(--line-soft); }
.payli-page-hardware .spec-list li svg {
    width: 18px; height: 18px;
    color: var(--brand);
    margin-top: 2px;
    flex-shrink: 0;
  }
.payli-page-hardware .spec-list strong { color: var(--ink); font-weight: 600; }
.payli-page-hardware .price-row {
    display: flex; align-items: baseline; gap: 16px;
    margin-bottom: 24px;
  }
.payli-page-hardware .price-row .price {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 48px; font-weight: 700;
    letter-spacing: -.04em;
    color: var(--ink);
  }
.payli-page-hardware .price-row .vat {
    font-size: 13px; color: var(--muted);
  }
.payli-page-hardware .price-row .strike {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px;
    color: var(--muted-light);
    text-decoration: line-through;
  }
comment
.payli-page-hardware .product-stage {
    position: relative;
    height: 620px;
    display: flex; align-items: center; justify-content: center;
    z-index: 1;
  }
.payli-page-hardware .wisepos {
    width: 270px; height: 540px;
    background: linear-gradient(160deg, #2a3450 0%, #0B1530 100%);
    border-radius: 28px;
    padding: 16px;
    box-shadow: var(--shadow-xl), inset 0 0 0 1px rgba(255,255,255,.04);
    position: relative;
  }
.payli-page-hardware .wisepos::after {
    content: 'PAYLI';
    position: absolute;
    bottom: 18px; left: 50%;
    transform: translateX(-50%);
    color: rgba(255,255,255,.3);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .15em;
  }
.payli-page-hardware .wisepos-screen {
    background: white;
    border-radius: 18px;
    height: 300px;
    padding: 24px 20px;
    display: flex; flex-direction: column;
    position: relative;
  }
.payli-page-hardware .wisepos-camera {
    position: absolute; top: 12px; left: 50%;
    width: 6px; height: 6px;
    background: #2a3450; border-radius: 50%;
    transform: translateX(-50%);
  }
.payli-page-hardware .wisepos-status {
    margin-top: 14px;
    display: flex; justify-content: space-between;
    font-size: 10px; color: var(--muted);
    font-weight: 600;
  }
.payli-page-hardware .wisepos-status .battery {
    display: flex; align-items: center; gap: 4px;
  }
.payli-page-hardware .wisepos-merchant {
    margin-top: 18px;
    font-size: 10px;
    color: var(--muted-light);
    text-align: center;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
  }
.payli-page-hardware .wisepos-amount {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 60px;
    font-weight: 700;
    text-align: center;
    margin-top: 16px;
    letter-spacing: -.04em;
    color: var(--ink);
  }
.payli-page-hardware .wisepos-amount .c { font-size: 32px; color: var(--muted); vertical-align: top; line-height: 1.6; }
.payli-page-hardware .wisepos-prompt {
    margin-top: 12px;
    text-align: center;
    font-size: 12px;
    color: var(--brand);
    font-weight: 600;
  }
.payli-page-hardware .wisepos-icons {
    margin-top: auto;
    display: flex; justify-content: center; gap: 12px;
  }
.payli-page-hardware .wisepos-icons .icon {
    width: 36px; height: 24px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 4px;
    display: flex; align-items: center; justify-content: center;
    font-size: 8px;
    font-weight: 700;
    color: var(--muted);
    letter-spacing: .06em;
  }
.payli-page-hardware .wisepos-keypad {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 6px;
    padding: 0 10px 8px;
  }
.payli-page-hardware .wisepos-key {
    aspect-ratio: 2.2 / 1;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: white;
    font-size: 16px;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 600;
    border: 1px solid rgba(255,255,255,.08);
  }
.payli-page-hardware .wisepos-key.green { background: linear-gradient(180deg, #2ECC71, #27AE60); border-color: rgba(255,255,255,.15); }
.payli-page-hardware .wisepos-key.red { background: linear-gradient(180deg, #E74C3C, #C0392B); border-color: rgba(255,255,255,.15); }
.payli-page-hardware .wisepos-key.yellow { background: linear-gradient(180deg, #F39C12, #D68910); border-color: rgba(255,255,255,.15); }
comment
.payli-page-hardware .float-badge {
    position: absolute;
    background: white;
    border: 1px solid var(--line);
    box-shadow: var(--shadow-md);
    padding: 14px 18px;
    border-radius: 18px;
    display: flex; align-items: center; gap: 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    z-index: 4;
  }
.payli-page-hardware .float-badge svg { width: 18px; height: 18px; color: var(--brand); }
.payli-page-hardware .float-badge.bg1 {
    top: 30px; right: 20px;
    animation: float-b 5s ease-in-out infinite;
  }
.payli-page-hardware .float-badge.bg2 {
    bottom: 60px; left: 0;
    animation: float-b 5s ease-in-out infinite -2s;
  }
.payli-page-hardware .float-badge.bg3 {
    bottom: 200px; right: -10px;
    animation: float-b 5s ease-in-out infinite -3s;
  }
@keyframes float-b {
    0%,100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
comment
.payli-page-hardware .categories {
    padding: 100px 0 120px;
  }
.payli-page-hardware .section-title-row {
    display: flex; justify-content: space-between; align-items: flex-end;
    margin-bottom: 60px;
    gap: 32px;
  }
.payli-page-hardware .section-eyebrow {
    color: var(--brand);
    font-size: 13px; font-weight: 600;
    text-transform: uppercase; letter-spacing: .12em;
    margin-bottom: 12px;
  }
.payli-page-hardware .section-title-row h2 {
    font-size: clamp(40px, 5vw, 64px);
    max-width: 700px;
    letter-spacing: -.04em;
  }
.payli-page-hardware .section-title-row h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-hardware .section-title-row p {
    color: var(--ink-soft);
    font-size: 17px;
    max-width: 360px;
    flex-shrink: 0;
  }
.payli-page-hardware .bento {
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr;
    grid-template-rows: 320px 320px;
    gap: 20px;
  }
.payli-page-hardware .bento-card {
    border-radius: 24px;
    padding: 32px;
    position: relative;
    overflow: hidden;
    transition: transform .3s, box-shadow .3s;
  }
.payli-page-hardware .bento-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
  }
.payli-page-hardware .bento-card.b1 {
    grid-column: 1 / 2;
    grid-row: 1 / 3;
    background: linear-gradient(155deg, var(--brand), var(--brand-darker));
    color: white;
  }
.payli-page-hardware .bento-card.b2 {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    background: var(--paper);
    border: 1px solid var(--line);
  }
.payli-page-hardware .bento-card.b3 {
    grid-column: 3 / 4;
    grid-row: 1 / 2;
    background: var(--cream);
    border: 1px solid var(--cream-line);
  }
.payli-page-hardware .bento-card.b4 {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    background: var(--ink);
    color: white;
  }
.payli-page-hardware .bento-card.b5 {
    grid-column: 3 / 4;
    grid-row: 2 / 3;
    background: var(--paper);
    border: 1px solid var(--line);
  }
.payli-page-hardware .bento-cat {
    font-size: 11px; font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 14px;
    opacity: .7;
  }
.payli-page-hardware .bento-card h3 {
    font-size: 28px;
    margin-bottom: 12px;
    line-height: 1.05;
  }
.payli-page-hardware .bento-card.b1 h3 {
    font-size: 44px;
  }
.payli-page-hardware .bento-card p {
    font-size: 14px;
    opacity: .82;
    line-height: 1.5;
  }
.payli-page-hardware .bento-card .from-price {
    margin-top: auto;
    padding-top: 16px;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 14px; font-weight: 600;
    display: flex; align-items: center; gap: 6px;
  }
.payli-page-hardware .bento-card .from-price strong {
    font-size: 22px; font-weight: 700;
    letter-spacing: -.02em;
  }
.payli-page-hardware .bento-card.b1 { display: flex; flex-direction: column; }
.payli-page-hardware .bento-card.b2, .payli-page-hardware .bento-card.b3, .payli-page-hardware .bento-card.b4, .payli-page-hardware .bento-card.b5 {
    display: flex; flex-direction: column;
  }
comment
.payli-page-hardware .bento-illu {
    position: absolute;
    pointer-events: none;
  }
.payli-page-hardware .bento-illu.terminal-big {
    bottom: -60px; right: -40px;
    width: 280px; height: 380px;
    background: linear-gradient(155deg, rgba(255,255,255,.18), rgba(255,255,255,.08));
    border-radius: 32px;
    transform: rotate(-12deg);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(10px);
  }
.payli-page-hardware .bento-illu.terminal-big::before {
    content: '';
    position: absolute;
    inset: 16px 16px auto 16px;
    height: 60%;
    background: rgba(255,255,255,.95);
    border-radius: 22px;
  }
.payli-page-hardware .bento-illu.terminal-big::after {
    content: '€ 24,90';
    position: absolute;
    top: 60px; left: 50%;
    transform: translateX(-50%);
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 32px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.03em;
  }
.payli-page-hardware .bento-illu.printer {
    bottom: -20px; right: -10px;
    width: 200px; height: 130px;
    background: linear-gradient(160deg, #3a4670, #1a2440);
    border-radius: 14px;
    transform: rotate(-6deg);
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .bento-illu.printer::before {
    content: '';
    position: absolute;
    top: 18px; left: 16px; right: 16px;
    height: 6px;
    background: rgba(255,255,255,.1);
    border-radius: 3px;
  }
.payli-page-hardware .bento-illu.printer::after {
    content: '';
    position: absolute;
    top: 32px; left: 12px; right: 12px;
    height: 50px;
    background: white;
    border-radius: 2px;
    box-shadow: inset 0 -10px 14px rgba(0,0,0,.04);
  }
.payli-page-hardware .bento-illu.tablet {
    bottom: 0; right: -10px;
    width: 200px; height: 150px;
    background: linear-gradient(155deg, #1a2440, #0B1530);
    border-radius: 14px;
    transform: rotate(-3deg);
    border: 6px solid #5a3920;
    border-bottom: 14px solid #5a3920;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .bento-illu.tablet::before {
    content: '';
    position: absolute;
    inset: 4px;
    background: var(--brand);
    border-radius: 6px;
    background: linear-gradient(135deg, var(--brand), var(--brand-light));
  }
.payli-page-hardware .bento-illu.tablet::after {
    content: '';
    position: absolute;
    bottom: -36px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px; height: 16px;
    background: linear-gradient(180deg, #3a4670, #1a2440);
    border-radius: 2px;
  }
.payli-page-hardware .bento-illu.cashdrawer {
    bottom: 20px; right: -20px;
    width: 220px; height: 90px;
    background: linear-gradient(180deg, #3a4670, #1a2440);
    border-radius: 8px;
    transform: rotate(-4deg);
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .bento-illu.cashdrawer::before {
    content: '';
    position: absolute;
    top: 16px; left: 16px; right: 16px; bottom: 14px;
    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-hardware .bento-illu.cashdrawer::after {
    content: '';
    position: absolute;
    bottom: 4px; left: 50%;
    width: 36px; height: 4px;
    background: rgba(255,255,255,.15);
    border-radius: 2px;
    transform: translateX(-50%);
  }
.payli-page-hardware .bento-illu.scanner {
    bottom: 0; right: 10px;
    width: 130px; height: 160px;
    background: linear-gradient(155deg, var(--ink), #1a2440);
    border-radius: 18px 18px 30px 30px;
    transform: rotate(8deg);
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .bento-illu.scanner::before {
    content: '';
    position: absolute;
    top: 14px; left: 12px; right: 12px;
    height: 50px;
    background: linear-gradient(135deg, #1a2440, #0B1530);
    border-radius: 8px;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  }
.payli-page-hardware .bento-illu.scanner::after {
    content: '';
    position: absolute;
    top: 28px; left: 24px; right: 24px;
    height: 16px;
    background: linear-gradient(90deg, #FF3030, #FF6060);
    border-radius: 2px;
    box-shadow: 0 0 8px rgba(255,48,48,.6);
  }
comment
.payli-page-hardware .quote-breaker {
    background: var(--cream);
    padding: 100px 0;
    border-top: 1px solid var(--cream-line);
    border-bottom: 1px solid var(--cream-line);
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .quote-breaker .container { text-align: center; }
.payli-page-hardware .quote-breaker .quote-mark {
    font-family: 'Instrument Serif', serif;
    font-size: 200px;
    color: var(--brand);
    line-height: 1;
    margin-bottom: -40px;
    opacity: .25;
  }
.payli-page-hardware .quote-breaker blockquote {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-size: clamp(36px, 5vw, 64px);
    line-height: 1.15;
    color: var(--ink);
    max-width: 900px;
    margin: 0 auto 32px;
    letter-spacing: -.02em;
  }
.payli-page-hardware .quote-attr {
    display: inline-flex; align-items: center; gap: 12px;
    background: var(--paper);
    padding: 10px 18px;
    border-radius: 100px;
    border: 1px solid var(--cream-line);
    font-size: 14px;
    color: var(--ink-soft);
  }
.payli-page-hardware .quote-attr .avatar {
    width: 32px; height: 32px;
    background: linear-gradient(135deg, var(--brand), var(--brand-light));
    border-radius: 50%;
    color: white;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 700;
    font-size: 12px;
  }
comment
.payli-page-hardware .all-products {
    padding: 120px 0;
  }
.payli-page-hardware .filter-row {
    display: flex; gap: 8px;
    margin-bottom: 48px;
    flex-wrap: wrap;
  }
.payli-page-hardware .filter-chip {
    padding: 10px 18px;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    color: var(--ink-soft);
    cursor: pointer;
    transition: all .2s;
  }
.payli-page-hardware .filter-chip:hover { border-color: var(--brand); color: var(--brand); }
.payli-page-hardware .filter-chip.active {
    background: var(--ink);
    color: white;
    border-color: var(--ink);
  }
.payli-page-hardware .product-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
.payli-page-hardware .product-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 22px;
    overflow: hidden;
    transition: all .3s;
    position: relative;
    display: flex; flex-direction: column;
  }
.payli-page-hardware .product-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--brand-soft);
  }
.payli-page-hardware .product-card .badge {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--brand);
    color: white;
    padding: 4px 10px;
    border-radius: 100px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    z-index: 2;
  }
.payli-page-hardware .product-card .badge.dark { background: var(--ink); }
.payli-page-hardware .product-card .badge.cream { background: var(--cream); color: var(--ink); border: 1px solid var(--cream-line); }
.payli-page-hardware .product-image {
    aspect-ratio: 4 / 3;
    background: linear-gradient(155deg, var(--brand-softer), var(--brand-soft));
    display: flex; align-items: center; justify-content: center;
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .product-image.var-1 { background: linear-gradient(155deg, var(--brand-softer), var(--brand-soft)); }
.payli-page-hardware .product-image.var-2 { background: linear-gradient(155deg, var(--brand-soft), #C9D5F4); }
.payli-page-hardware .product-image.var-3 { background: linear-gradient(155deg, #C9D5F4, var(--brand-light)); }
.payli-page-hardware .product-image.var-4 { background: linear-gradient(155deg, var(--brand-soft), var(--cream-soft)); }
.payli-page-hardware .product-image.var-cream { background: linear-gradient(155deg, var(--cream-soft), var(--cream)); }
comment
.payli-page-hardware .pi-terminal {
    width: 140px; height: 200px;
    background: linear-gradient(160deg, #2a3450 0%, #0B1530 100%);
    border-radius: 18px;
    padding: 8px;
    box-shadow: var(--shadow-md);
    transform: rotate(-3deg);
  }
.payli-page-hardware .pi-terminal .scr {
    background: white;
    border-radius: 12px;
    height: 110px;
    padding: 10px 8px;
    display: flex; flex-direction: column; justify-content: center;
    align-items: center;
  }
.payli-page-hardware .pi-terminal .scr .amt {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 20px; font-weight: 700;
    color: var(--ink);
    letter-spacing: -.02em;
  }
.payli-page-hardware .pi-terminal .scr .lbl {
    font-size: 7px; color: var(--brand);
    margin-top: 4px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .1em;
  }
.payli-page-hardware .pi-terminal .keys {
    margin-top: 6px;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 3px;
  }
.payli-page-hardware .pi-terminal .key {
    aspect-ratio: 1.6 / 1;
    background: rgba(255,255,255,.05);
    border-radius: 4px;
    border: 1px solid rgba(255,255,255,.06);
  }
.payli-page-hardware .pi-printer {
    width: 200px; height: 130px;
    background: linear-gradient(160deg, #3a4670, #1a2440);
    border-radius: 14px;
    padding: 10px;
    transform: rotate(-2deg);
    position: relative;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .pi-printer .top {
    height: 16px;
    background: rgba(255,255,255,.1);
    border-radius: 4px;
    margin-bottom: 6px;
    display: flex; align-items: center; padding: 0 8px;
    gap: 4px;
  }
.payli-page-hardware .pi-printer .top span {
    width: 4px; height: 4px;
    background: rgba(255,255,255,.3);
    border-radius: 50%;
  }
.payli-page-hardware .pi-printer .top span.on { background: #2ECC71; box-shadow: 0 0 4px rgba(46,204,113,.6); }
.payli-page-hardware .pi-printer .pap {
    background: white;
    height: 70px;
    border-radius: 2px;
    padding: 6px 8px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 5px;
    color: var(--ink);
    line-height: 1.4;
  }
.payli-page-hardware .pi-tablet {
    width: 220px; height: 150px;
    background: linear-gradient(155deg, #1a2440, #0B1530);
    border-radius: 12px;
    border: 5px solid #5a3920;
    transform: rotate(-2deg);
    position: relative;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .pi-tablet::before {
    content: '';
    position: absolute;
    inset: 2px;
    background: linear-gradient(135deg, var(--brand), var(--brand-light));
    border-radius: 6px;
  }
.payli-page-hardware .pi-tablet::after {
    content: '';
    position: absolute;
    bottom: -28px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px; height: 16px;
    background: linear-gradient(180deg, #3a4670, #1a2440);
    border-radius: 2px;
    box-shadow: 0 4px 8px rgba(0,0,0,.15);
  }
.payli-page-hardware .pi-cashdrawer {
    width: 230px; height: 90px;
    background: linear-gradient(180deg, #3a4670, #1a2440);
    border-radius: 8px;
    transform: rotate(-2deg);
    position: relative;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .pi-cashdrawer::before {
    content: '';
    position: absolute;
    top: 16px; left: 14px; right: 14px; bottom: 14px;
    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-hardware .pi-cashdrawer::after {
    content: '';
    position: absolute;
    bottom: 4px; left: 50%;
    width: 36px; height: 4px;
    background: rgba(255,255,255,.15);
    border-radius: 2px;
    transform: translateX(-50%);
  }
.payli-page-hardware .pi-scanner {
    width: 110px; height: 180px;
    background: linear-gradient(155deg, var(--ink), #1a2440);
    border-radius: 18px 18px 30px 30px;
    transform: rotate(6deg);
    position: relative;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .pi-scanner::before {
    content: '';
    position: absolute;
    top: 14px; left: 12px; right: 12px;
    height: 50px;
    background: linear-gradient(135deg, #1a2440, #0B1530);
    border-radius: 8px;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  }
.payli-page-hardware .pi-scanner::after {
    content: '';
    position: absolute;
    top: 28px; left: 24px; right: 24px;
    height: 16px;
    background: linear-gradient(90deg, #FF3030, #FF6060);
    border-radius: 2px;
    box-shadow: 0 0 8px rgba(255,48,48,.6);
    animation: scanner-line 2s ease-in-out infinite;
  }
@keyframes scanner-line {
    0%,100% { opacity: 1; }
    50% { opacity: .5; }
  }
.payli-page-hardware .pi-paper {
    width: 160px; height: 160px;
    background: linear-gradient(155deg, white, #f5f5f0);
    border-radius: 50%;
    box-shadow: var(--shadow-md), inset -8px 0 0 #e8e8e0, inset 0 0 0 28px white;
    transform: rotate(-4deg);
    position: relative;
  }
.payli-page-hardware .pi-paper::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    width: 50px; height: 50px;
    background: var(--cream);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    box-shadow: inset 0 0 0 4px var(--cream-line);
  }
.payli-page-hardware .pi-dock {
    width: 200px; height: 130px;
    background: linear-gradient(155deg, #3a4670, #1a2440);
    border-radius: 14px;
    transform: rotate(-3deg);
    position: relative;
    box-shadow: var(--shadow-md);
  }
.payli-page-hardware .pi-dock::before {
    content: '';
    position: absolute;
    top: 18px; left: 30px;
    width: 90px; height: 90px;
    background: rgba(0,0,0,.3);
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.05);
  }
.payli-page-hardware .pi-dock::after {
    content: '';
    position: absolute;
    top: 50%; right: 20px;
    transform: translateY(-50%);
    width: 30px; height: 30px;
    background: linear-gradient(135deg, var(--brand), var(--brand-light));
    border-radius: 6px;
    box-shadow: 0 0 12px rgba(41,82,197,.4);
  }
.payli-page-hardware .product-info {
    padding: 24px;
    flex: 1;
    display: flex; flex-direction: column;
  }
.payli-page-hardware .product-cat {
    font-size: 11px;
    font-weight: 700;
    color: var(--brand);
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
.payli-page-hardware .product-name {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 22px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.02em;
    margin-bottom: 8px;
    line-height: 1.15;
  }
.payli-page-hardware .product-desc {
    font-size: 13px;
    color: var(--ink-soft);
    margin-bottom: 16px;
    line-height: 1.5;
  }
.payli-page-hardware .product-features {
    display: flex; gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 16px;
  }
.payli-page-hardware .product-feature {
    font-size: 11px;
    background: var(--bg);
    color: var(--ink-soft);
    padding: 4px 10px;
    border-radius: 100px;
    border: 1px solid var(--line-soft);
    font-weight: 500;
  }
.payli-page-hardware .product-bottom {
    margin-top: auto;
    display: flex; justify-content: space-between;
    align-items: center;
    padding-top: 16px;
    border-top: 1px solid var(--line-soft);
  }
.payli-page-hardware .product-price {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px; font-weight: 700;
    letter-spacing: -.02em;
    color: var(--ink);
  }
.payli-page-hardware .product-price .vat {
    font-size: 11px;
    color: var(--muted);
    font-weight: 400;
    margin-left: 4px;
  }
.payli-page-hardware .product-cta {
    background: var(--ink);
    color: white;
    padding: 8px 16px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 600;
    transition: all .2s;
    display: inline-flex; align-items: center; gap: 4px;
  }
.payli-page-hardware .product-cta:hover {
    background: var(--brand);
    transform: translateX(2px);
  }
comment
.payli-page-hardware .how-it-works {
    background: var(--cream-soft);
    border-top: 1px solid var(--cream-line);
    border-bottom: 1px solid var(--cream-line);
    padding: 120px 0;
    position: relative;
  }
.payli-page-hardware .hiw-header { text-align: center; margin-bottom: 80px; }
.payli-page-hardware .hiw-header h2 {
    font-size: clamp(40px, 5vw, 64px);
    margin-bottom: 16px;
  }
.payli-page-hardware .hiw-header h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-hardware .hiw-header p {
    font-size: 18px;
    color: var(--ink-soft);
    max-width: 600px;
    margin: 0 auto;
  }
.payli-page-hardware .hiw-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    position: relative;
    margin-top: 40px;
  }
.payli-page-hardware .hiw-line {
    position: absolute;
    top: 80px; left: 16%; right: 16%;
    height: 1px;
    pointer-events: none;
    z-index: 0;
  }
.payli-page-hardware .hiw-line svg {
    width: 100%; height: 100px;
    overflow: visible;
  }
.payli-page-hardware .hiw-line path {
    stroke: var(--brand);
    stroke-width: 2;
    stroke-dasharray: 4 6;
    fill: none;
    opacity: .4;
  }
.payli-page-hardware .step {
    background: var(--paper);
    border: 1px solid var(--cream-line);
    border-radius: 24px;
    padding: 36px 32px;
    position: relative;
    z-index: 1;
    box-shadow: var(--shadow-sm);
  }
.payli-page-hardware .step-num {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-size: 124px;
    line-height: 1;
    color: var(--brand);
    letter-spacing: -.04em;
    margin-bottom: 8px;
  }
.payli-page-hardware .step h4 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: -.03em;
  }
.payli-page-hardware .step p {
    color: var(--ink-soft);
    font-size: 15px;
    margin-bottom: 16px;
  }
.payli-page-hardware .step-meta {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 12px;
    background: var(--cream);
    padding: 6px 12px;
    border-radius: 100px;
    color: var(--ink-soft);
    font-weight: 500;
  }
.payli-page-hardware .step-meta svg { width: 14px; height: 14px; color: var(--brand); }
comment
.payli-page-hardware .tarif-section {
    padding: 120px 0;
    background: var(--bg);
  }
.payli-page-hardware .tarif-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 32px;
    padding: 64px 64px 48px;
    text-align: center;
    box-shadow: var(--shadow-md);
    max-width: 800px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .tarif-card::before {
    content: '';
    position: absolute;
    top: -200px; left: 50%;
    transform: translateX(-50%);
    width: 600px; height: 400px;
    background: radial-gradient(ellipse, var(--brand-soft), transparent 60%);
    pointer-events: none;
  }
.payli-page-hardware .tarif-card .eyebrow { margin-bottom: 16px; }
.payli-page-hardware .tarif-headline {
    font-size: clamp(40px, 5vw, 64px);
    margin-bottom: 24px;
  }
.payli-page-hardware .tarif-headline .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-hardware .tarif-big-number {
    position: relative; z-index: 1;
    display: flex; align-items: baseline; justify-content: center;
    gap: 16px;
    margin: 40px 0 32px;
  }
.payli-page-hardware .tarif-big-number .pct {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(96px, 14vw, 200px);
    font-weight: 700;
    color: var(--brand);
    letter-spacing: -.06em;
    line-height: 1;
  }
.payli-page-hardware .tarif-big-number .plus {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-size: clamp(48px, 7vw, 88px);
    color: var(--ink-soft);
    line-height: 1;
  }
.payli-page-hardware .tarif-big-number .euro {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(56px, 9vw, 112px);
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.04em;
    line-height: 1;
  }
.payli-page-hardware .tarif-sub {
    font-size: 16px;
    color: var(--ink-soft);
    max-width: 520px;
    margin: 0 auto 32px;
    position: relative; z-index: 1;
  }
.payli-page-hardware .tarif-bullets {
    display: flex; gap: 24px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 32px;
    position: relative; z-index: 1;
  }
.payli-page-hardware .tarif-bullet {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px;
    color: var(--ink-soft);
  }
.payli-page-hardware .tarif-bullet svg { width: 18px; height: 18px; color: var(--brand); }
comment
.payli-page-hardware .faq-section {
    padding: 120px 0;
  }
.payli-page-hardware .faq-grid {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 80px;
  }
.payli-page-hardware .faq-grid h2 {
    font-size: clamp(36px, 4.5vw, 56px);
    margin-bottom: 16px;
  }
.payli-page-hardware .faq-grid h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand);
  }
.payli-page-hardware .faq-grid > div:first-child p {
    color: var(--ink-soft);
    font-size: 16px;
    margin-bottom: 24px;
  }
.payli-page-hardware .faq-help {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 24px;
    display: flex; flex-direction: column; gap: 12px;
  }
.payli-page-hardware .faq-help h4 {
    font-size: 16px;
    margin: 0;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 600;
  }
.payli-page-hardware .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-hardware .faq-help-link:hover { color: var(--brand); }
.payli-page-hardware .faq-help-link svg { width: 14px; height: 14px; }
.payli-page-hardware .faq-list {
    border-top: 1px solid var(--line);
  }
.payli-page-hardware .faq-item {
    border-bottom: 1px solid var(--line);
  }
.payli-page-hardware .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-hardware .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-hardware .faq-item.open .faq-q .plus {
    background: var(--brand);
    color: white;
    transform: rotate(45deg);
  }
.payli-page-hardware .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-hardware .faq-item.open .faq-a {
    max-height: 400px;
    padding: 0 0 24px;
  }
comment
.payli-page-hardware .cta-dark {
    padding: 100px 0;
    background: var(--ink);
    color: white;
    position: relative;
    overflow: hidden;
  }
.payli-page-hardware .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-hardware .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-hardware .cta-dark .container {
    text-align: center;
    position: relative; z-index: 1;
  }
.payli-page-hardware .cta-dark .eyebrow {
    background: rgba(255,255,255,.1);
    color: white;
  }
.payli-page-hardware .cta-dark h2 {
    font-size: clamp(48px, 6vw, 88px);
    margin-bottom: 24px;
    color: white;
  }
.payli-page-hardware .cta-dark h2 .em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    color: var(--brand-light);
  }
.payli-page-hardware .cta-dark p {
    font-size: 18px;
    color: rgba(255,255,255,.7);
    max-width: 540px;
    margin: 0 auto 36px;
  }
.payli-page-hardware .cta-dark-btns {
    display: flex; gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }
comment
.payli-page-hardware .payment-icons {
    display: flex; gap: 12px;
    align-items: center;
  }
.payli-page-hardware .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-hardware .pay-icon.bc { color: #005498; }
comment
.payli-page-hardware .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-hardware .floating-cta.show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
  }
.payli-page-hardware .floating-cta:hover {
    transform: translateY(-2px) scale(1.02);
  }
.payli-page-hardware .floating-cta img {
    height: 16px;
    filter: brightness(0) invert(1);
  }
comment
@media (max-width: 1280px) {
  .payli-page-hardware .hero h1 { font-size: clamp(40px, 6.5vw, 88px); }
}
@media (max-width: 1024px) {
  .payli-page-hardware .container { padding: 0 24px; }
  .payli-page-hardware .section { padding: 90px 0; }
  .payli-page-hardware .hero { padding: 60px 0 80px; }
  .payli-page-hardware .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .payli-page-hardware .hero-grid > div:first-child { text-align: center; }
  .payli-page-hardware .hero-grid > div:first-child .eyebrow, .payli-page-hardware .hero-grid > div:first-child .hero-ctas, .payli-page-hardware .hero-grid > div:first-child .hero-meta { justify-content: center; }
  .payli-page-hardware .hero p { margin-left: auto; margin-right: auto; }
  .payli-page-hardware .hero-meta { justify-content: center; }
  .payli-page-hardware .hero-product-grid { grid-template-columns: 1fr; gap: 48px; padding: 40px; text-align: center; }
  .payli-page-hardware .hero-product-content .featured { margin-left: auto; margin-right: auto; }
  .payli-page-hardware .spec-list li { text-align: left; }
  .payli-page-hardware .price-row { justify-content: center; }
  .payli-page-hardware .stats-grid { grid-template-columns: 1fr 1fr; }
  .payli-page-hardware .stat-hero { grid-column: 1 / -1; }
  .payli-page-hardware .bento { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .payli-page-hardware .bento-card.b1 { grid-column: 1 / -1; grid-row: auto; height: 360px; }
  .payli-page-hardware .bento-card.b2, .payli-page-hardware .bento-card.b3, .payli-page-hardware .bento-card.b4, .payli-page-hardware .bento-card.b5 { grid-column: auto; grid-row: auto; height: 280px; }
  .payli-page-hardware .product-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
  .payli-page-hardware .hiw-steps { grid-template-columns: 1fr; gap: 32px; }
  .payli-page-hardware .hiw-line { display: none; }
  .payli-page-hardware .step { padding: 28px 24px; }
  .payli-page-hardware .step-num { font-size: 88px; }
  .payli-page-hardware .faq-grid { grid-template-columns: 1fr; gap: 40px; }
  .payli-page-hardware .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .payli-page-hardware .section-title-row { flex-direction: column; align-items: flex-start; gap: 16px; margin-bottom: 40px; }
  .payli-page-hardware .tarif-bullets { gap: 16px; }
  .payli-page-hardware .nav-links { display: none; }
  .payli-page-hardware .nav-toggle { display: flex; }
}
@media (max-width: 768px) {
  .payli-page-hardware .container { padding: 0 18px; }
  .payli-page-hardware .section { padding: 70px 0; }
  .payli-page-hardware .hero { padding: 32px 0 60px; }
  .payli-page-hardware .hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .payli-page-hardware .hero p { font-size: 16px; }
  .payli-page-hardware .hero-visual { height: 460px; transform: scale(0.85); transform-origin: center; }
  .payli-page-hardware .stats-grid { grid-template-columns: 1fr; gap: 16px; }
  .payli-page-hardware .stat-hero { padding: 32px 24px; }
  .payli-page-hardware .stat-hero .num { font-size: 64px; }
  .payli-page-hardware .stat-card { padding: 24px 20px; }
  .payli-page-hardware .stat-card .num { font-size: 36px; }
  .payli-page-hardware .bento { grid-template-columns: 1fr; }
  .payli-page-hardware .bento-card { height: auto; min-height: 240px; padding: 28px 24px; }
  .payli-page-hardware .bento-card.b1 { height: auto; min-height: 320px; }
  .payli-page-hardware .bento-card h3 { font-size: 24px; }
  .payli-page-hardware .bento-card.b1 h3 { font-size: 32px; }
  .payli-page-hardware .bento-illu { transform: scale(0.78); transform-origin: bottom right; }
  .payli-page-hardware .product-grid { grid-template-columns: 1fr; }
  .payli-page-hardware .quote-breaker { padding: 60px 0; }
  .payli-page-hardware .quote-breaker blockquote { font-size: clamp(26px, 7vw, 38px); }
  .payli-page-hardware .quote-breaker .quote-mark { font-size: 140px; margin-bottom: -28px; }
  .payli-page-hardware .how-it-works { padding: 70px 0; }
  .payli-page-hardware .step-num { font-size: 72px; }
  .payli-page-hardware .step h4 { font-size: 22px; }
  .payli-page-hardware .hero-product-grid { padding: 32px 24px; gap: 32px; border-radius: 24px; }
  .payli-page-hardware .hero-product h2 { font-size: 36px; }
  .payli-page-hardware .product-stage { height: 480px; transform: scale(0.82); }
  .payli-page-hardware .float-badge { font-size: 11px; padding: 10px 12px; }
  .payli-page-hardware .float-badge.bg1 { right: 0; top: 10px; }
  .payli-page-hardware .float-badge.bg2 { left: -10px; }
  .payli-page-hardware .float-badge.bg3 { right: -10px; bottom: 100px; }
  .payli-page-hardware .tarif-card { padding: 48px 24px; border-radius: 24px; }
  .payli-page-hardware .tarif-big-number { gap: 8px; }
  .payli-page-hardware .tarif-big-number .pct { font-size: clamp(72px, 18vw, 120px); }
  .payli-page-hardware .tarif-big-number .euro { font-size: clamp(48px, 14vw, 80px); }
  .payli-page-hardware .tarif-big-number .plus { font-size: clamp(36px, 9vw, 64px); }
  .payli-page-hardware .cta-dark h2 { font-size: clamp(36px, 8vw, 56px); }
  .payli-page-hardware .cta-dark { padding: 70px 0; }
  .payli-page-hardware .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .payli-page-hardware .footer-brand { grid-column: 1 / -1; }
  .payli-page-hardware .footer-bottom { flex-direction: column; align-items: flex-start; }
  .payli-page-hardware .filter-row { gap: 6px; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
  .payli-page-hardware .filter-row::-webkit-scrollbar { display: none; }
  .payli-page-hardware .filter-chip { font-size: 12px; padding: 8px 14px; white-space: nowrap; flex-shrink: 0; }
  .payli-page-hardware .nav-cta .btn-ghost { display: none; }
  .payli-page-hardware .nav-cta .btn-primary { padding: 10px 16px; font-size: 13px; }
  .payli-page-hardware .nav-logo { height: 26px; }
  .payli-page-hardware .floating-cta { padding: 12px 18px; font-size: 13px; bottom: 16px; right: 16px; }
  .payli-page-hardware .usp-item { font-size: 15px; }
  .payli-page-hardware .usp-track { gap: 36px; }
}
@media (max-width: 480px) {
  .payli-page-hardware .container { padding: 0 16px; }
  .payli-page-hardware .section { padding: 56px 0; }
  .payli-page-hardware .hero h1 { font-size: clamp(32px, 10vw, 44px); letter-spacing: -.03em; }
  .payli-page-hardware .btn-large-primary, .payli-page-hardware .btn-large-ghost { padding: 14px 22px; font-size: 14px; width: 100%; justify-content: center; }
  .payli-page-hardware .hero-ctas { width: 100%; flex-direction: column; }
  .payli-page-hardware .hero-meta { gap: 12px; font-size: 12px; flex-direction: column; align-items: center; }
  .payli-page-hardware .hero-visual { height: 380px; transform: scale(0.65); }
  .payli-page-hardware .stat-hero .num { font-size: 56px; }
  .payli-page-hardware .stat-hero .num.smaller { font-size: 40px; }
  .payli-page-hardware .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .payli-page-hardware .footer-brand { grid-column: auto; }
  .payli-page-hardware .cta-dark-btns { flex-direction: column; width: 100%; }
  .payli-page-hardware .cta-dark-btns a { width: 100%; justify-content: center; }
  .payli-page-hardware .nav-inner { padding: 14px 18px; }
}


/* ===========================================================
   FIX: Product stage badges drijvend op terminal mockup
   =========================================================== */

/* Product-stage moet relative zijn voor absolute children */
html body .payli-page-hardware .product-stage,
.payli-page-hardware .product-stage {
    position: relative !important;
    overflow: visible !important;
}

/* Float-badges - alle gemeenschappelijke styling */
html body .payli-page-hardware .float-badge,
.payli-page-hardware .float-badge {
    position: absolute !important;
    background: white !important;
    background-color: white !important;
    border: 1px solid #E2E6F0 !important;
    box-shadow: 0 8px 24px rgba(11,21,48,.10), 0 4px 8px rgba(11,21,48,.06) !important;
    padding: 12px 16px !important;
    border-radius: 100px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #0B1530 !important;
    z-index: 10 !important;
    width: auto !important;
    max-width: max-content !important;
    white-space: nowrap !important;
}

html body .payli-page-hardware .float-badge svg,
.payli-page-hardware .float-badge svg {
    width: 16px !important;
    height: 16px !important;
    color: #2952C5 !important;
    stroke: #2952C5 !important;
    flex-shrink: 0 !important;
}

/* "Contactloos · NFC" rechtsboven */
html body .payli-page-hardware .float-badge.bg1,
.payli-page-hardware .float-badge.bg1 {
    top: 30px !important;
    right: 20px !important;
    bottom: auto !important;
    left: auto !important;
}

/* "Wi-Fi & Ethernet" linkmidden */
html body .payli-page-hardware .float-badge.bg2,
.payli-page-hardware .float-badge.bg2 {
    bottom: 200px !important;
    left: -20px !important;
    top: auto !important;
    right: auto !important;
}

/* "11u accuduur" rechtsonder */
html body .payli-page-hardware .float-badge.bg3,
.payli-page-hardware .float-badge.bg3 {
    bottom: 60px !important;
    right: -10px !important;
    top: auto !important;
    left: auto !important;
}

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


/* ===========================================================
   FIX: Bento donkere kaarten — witte tekst (Betaalterminals + Cashdrawers)
   =========================================================== */

/* b1 (blauwe Betaalterminals kaart) — alle tekst wit */
html body .payli-page-hardware .bento-card.b1,
.payli-page-hardware .bento-card.b1 {
    background: linear-gradient(155deg, #2952C5 0%, #15307E 100%) !important;
}

html body .payli-page-hardware .bento-card.b1,
html body .payli-page-hardware .bento-card.b1 *,
.payli-page-hardware .bento-card.b1,
.payli-page-hardware .bento-card.b1 * {
    color: white !important;
}

html body .payli-page-hardware .bento-card.b1 h3,
.payli-page-hardware .bento-card.b1 h3 {
    color: white !important;
}

html body .payli-page-hardware .bento-card.b1 .bento-cat,
.payli-page-hardware .bento-card.b1 .bento-cat {
    color: rgba(255,255,255,.8) !important;
}

html body .payli-page-hardware .bento-card.b1 > p,
.payli-page-hardware .bento-card.b1 > p {
    color: rgba(255,255,255,.85) !important;
}

html body .payli-page-hardware .bento-card.b1 .from-price,
html body .payli-page-hardware .bento-card.b1 .from-price strong,
.payli-page-hardware .bento-card.b1 .from-price,
.payli-page-hardware .bento-card.b1 .from-price strong {
    color: white !important;
}

/* b4 (donkere Cashdrawers kaart) — alle tekst wit */
html body .payli-page-hardware .bento-card.b4,
.payli-page-hardware .bento-card.b4 {
    background: #0B1530 !important;
}

html body .payli-page-hardware .bento-card.b4,
html body .payli-page-hardware .bento-card.b4 *,
.payli-page-hardware .bento-card.b4,
.payli-page-hardware .bento-card.b4 * {
    color: white !important;
    text-decoration: none !important;
}

html body .payli-page-hardware .bento-card.b4 h3,
.payli-page-hardware .bento-card.b4 h3 {
    color: white !important;
    text-decoration: none !important;
}

html body .payli-page-hardware .bento-card.b4 .bento-cat,
.payli-page-hardware .bento-card.b4 .bento-cat {
    color: #6B8DEF !important;
}

html body .payli-page-hardware .bento-card.b4 > p,
.payli-page-hardware .bento-card.b4 > p {
    color: rgba(255,255,255,.75) !important;
}

html body .payli-page-hardware .bento-card.b4 .from-price,
html body .payli-page-hardware .bento-card.b4 .from-price strong,
.payli-page-hardware .bento-card.b4 .from-price,
.payli-page-hardware .bento-card.b4 .from-price strong {
    color: white !important;
}

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


/* ===========================================================
   FIX: Cashdrawer-float klein houden + niet uitstrekken
   =========================================================== */

/* Hero-visual moet relative zijn met overflow visible */
html body .payli-page-hardware .hero-visual,
.payli-page-hardware .hero-visual {
    position: relative !important;
    overflow: visible !important;
}

/* Cashdrawer-float: klein liggend blok linksonder de terminal */
html body .payli-page-hardware .cashdrawer-float,
.payli-page-hardware .cashdrawer-float {
    position: absolute !important;
    left: -20px !important;
    top: 50px !important;
    right: auto !important;
    bottom: auto !important;
    width: 200px !important;
    height: 50px !important;
    max-width: 200px !important;
    max-height: 50px !important;
    background: linear-gradient(180deg, #2C3654, #0B1530) !important;
    border-radius: 8px !important;
    z-index: 1 !important;
    box-shadow: 0 16px 32px rgba(11,21,48,.20), 0 4px 8px rgba(11,21,48,.10) !important;
    transform: rotate(-12deg) !important;
    overflow: hidden !important;
    flex: none !important;
    display: block !important;
}

/* Pseudo-elementen - zwarte streep in het midden */
html body .payli-page-hardware .cashdrawer-float::before,
.payli-page-hardware .cashdrawer-float::before {
    content: '' !important;
    position: absolute !important;
    top: 14px !important;
    left: 14px !important;
    right: 14px !important;
    bottom: 12px !important;
    background: linear-gradient(90deg, #1a2440 0%, #2C3654 50%, #1a2440 100%) !important;
    border-radius: 4px !important;
    box-shadow: inset 0 2px 4px rgba(0,0,0,.6) !important;
}

html body .payli-page-hardware .cashdrawer-float::after,
.payli-page-hardware .cashdrawer-float::after {
    content: '' !important;
    position: absolute !important;
    bottom: 4px !important;
    left: 50% !important;
    width: 30px !important;
    height: 4px !important;
    background: rgba(255,255,255,.2) !important;
    border-radius: 2px !important;
    transform: translateX(-50%) !important;
}

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


/* ===========================================================
   FIX: Receipt-printer drijvend rechtsonder de terminal
   =========================================================== */

/* Receipt printer ABSOLUUT gepositioneerd, klein en geroteerd */
html body .payli-page-hardware .receipt-printer,
.payli-page-hardware .receipt-printer {
    position: absolute !important;
    right: -20px !important;
    bottom: 40px !important;
    top: auto !important;
    left: auto !important;
    width: 220px !important;
    max-width: 220px !important;
    background: linear-gradient(160deg, #2C3654, #0B1530) !important;
    border-radius: 18px !important;
    padding: 12px !important;
    z-index: 2 !important;
    box-shadow: 0 24px 48px rgba(11,21,48,.20), 0 8px 16px rgba(11,21,48,.12) !important;
    transform: rotate(7deg) !important;
    overflow: visible !important;
    margin: 0 !important;
    flex: none !important;
    display: block !important;
}

/* Top deel met "PRINTER · ONLINE" */
html body .payli-page-hardware .receipt-printer-top,
.payli-page-hardware .receipt-printer-top {
    height: 30px !important;
    border-radius: 12px 12px 0 0 !important;
    background: rgba(255,255,255,.05) !important;
    display: flex !important;
    align-items: center !important;
    padding-left: 12px !important;
    font-size: 10px !important;
    color: rgba(255,255,255,.6) !important;
    font-weight: 600 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
}

/* Receipt papier (wit met monospace tekst) */
html body .payli-page-hardware .receipt-paper,
.payli-page-hardware .receipt-paper {
    background: white !important;
    padding: 14px 12px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 9px !important;
    color: #0B1530 !important;
    line-height: 1.6 !important;
    margin: 0 -2px !important;
    box-shadow: inset 0 -8px 12px rgba(0,0,0,.04) !important;
}

html body .payli-page-hardware .receipt-paper .r-store,
.payli-page-hardware .receipt-paper .r-store {
    text-align: center !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .15em !important;
    margin-bottom: 8px !important;
    font-size: 10px !important;
    color: #0B1530 !important;
}

html body .payli-page-hardware .receipt-paper .r-line,
.payli-page-hardware .receipt-paper .r-line {
    display: flex !important;
    justify-content: space-between !important;
    padding: 2px 0 !important;
    color: #0B1530 !important;
}

html body .payli-page-hardware .receipt-paper .r-divider,
.payli-page-hardware .receipt-paper .r-divider {
    border-top: 1px dashed #0B1530 !important;
    margin: 4px 0 !important;
}

html body .payli-page-hardware .receipt-paper .r-total,
.payli-page-hardware .receipt-paper .r-total {
    display: flex !important;
    justify-content: space-between !important;
    font-weight: 700 !important;
    margin-top: 4px !important;
    color: #0B1530 !important;
}

/* Bonpapier afscheur-rand onderaan */
html body .payli-page-hardware .receipt-tear,
.payli-page-hardware .receipt-tear {
    height: 8px !important;
    background: white !important;
    margin: 0 -2px !important;
    -webkit-mask-image: radial-gradient(circle at 4px 0, transparent 4px, black 5px) !important;
    -webkit-mask-size: 8px 8px !important;
    -webkit-mask-position: 0 100% !important;
    -webkit-mask-repeat: repeat-x !important;
    mask-image: radial-gradient(circle at 4px 0, transparent 4px, black 5px) !important;
    mask-size: 8px 8px !important;
    mask-position: 0 100% !important;
    mask-repeat: repeat-x !important;
}

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


/* ===========================================================
   FIX: Payli Terminal product mockup goed zichtbaar
   =========================================================== */

/* Terminal lichaam — donker zwart met goede contrast */
html body .payli-page-hardware .pi-terminal,
.payli-page-hardware .pi-terminal {
    width: 160px !important;
    height: 220px !important;
    background: linear-gradient(160deg, #2a3450 0%, #0B1530 100%) !important;
    background-color: #0B1530 !important;
    border-radius: 18px !important;
    padding: 10px !important;
    box-shadow: 0 16px 40px rgba(11,21,48,.25), 0 4px 12px rgba(11,21,48,.15) !important;
    transform: rotate(-3deg) !important;
    position: relative !important;
    overflow: hidden !important;
}

/* Wit scherm bovenaan */
html body .payli-page-hardware .pi-terminal .scr,
.payli-page-hardware .pi-terminal .scr {
    background: white !important;
    background-color: white !important;
    border-radius: 10px !important;
    height: 110px !important;
    padding: 10px 8px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.15) !important;
}

html body .payli-page-hardware .pi-terminal .scr .amt,
.payli-page-hardware .pi-terminal .scr .amt {
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #0B1530 !important;
    letter-spacing: -.02em !important;
}

html body .payli-page-hardware .pi-terminal .scr .lbl,
.payli-page-hardware .pi-terminal .scr .lbl {
    font-size: 7px !important;
    color: #2952C5 !important;
    margin-top: 4px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .1em !important;
}

/* Toetsenbord grid 3x4 — duidelijk zichtbare toetsen */
html body .payli-page-hardware .pi-terminal .keys,
.payli-page-hardware .pi-terminal .keys {
    margin-top: 8px !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 4px !important;
}

html body .payli-page-hardware .pi-terminal .key,
.payli-page-hardware .pi-terminal .key {
    aspect-ratio: 1.6 / 1 !important;
    background: rgba(255,255,255,.12) !important;
    background-color: rgba(255,255,255,.12) !important;
    border-radius: 5px !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 0 1px 2px rgba(0,0,0,.2) !important;
}

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


/* ===========================================================
   FIX: Product-bottom zonder prijs — Bekijk knop full-width
   =========================================================== */
html body .payli-page-hardware .product-bottom,
.payli-page-hardware .product-bottom {
    justify-content: stretch !important;
}

/* "Bekijk" knop neemt de volledige breedte */
html body .payli-page-hardware .product-bottom .product-cta,
.payli-page-hardware .product-bottom .product-cta {
    width: 100% !important;
    justify-content: center !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
}

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