/* ============================================================
   Zovepay — in-person & omnichannel payments
   Warm, tactile retail identity. Prefix: zp-
   Display: Sora · Body: Epilogue · Mono accent: Spline Sans Mono
   ============================================================ */

:root{
  /* warm retail palette */
  --ink:#22150e;            /* deep warm brown-black */
  --ink-2:#4a3a30;          /* muted brown text */
  --ink-3:#7a6a5e;          /* faint label brown */
  --cream:#fbf6ef;          /* warm off-white page */
  --cream-2:#f4ebdf;        /* slightly deeper cream */
  --paper:#ffffff;          /* card surface */
  --line:#ecdfce;           /* warm hairline */
  --line-2:#e0cfb8;

  --tang:#f0641e;           /* tangerine primary */
  --tang-deep:#d24e0c;      /* pressed tangerine */
  --tang-soft:#fde7d6;      /* tangerine wash */
  --berry:#7a2e16;          /* warm dark accent */
  --leaf:#1f7a52;           /* retail green secondary accent */
  --leaf-soft:#dcf0e6;
  --gold:#e7a334;           /* warm gold (tips / highlights) */

  --shadow-sm:0 1px 2px rgba(60,30,10,.06), 0 2px 6px rgba(60,30,10,.05);
  --shadow:0 6px 16px rgba(70,35,12,.08), 0 18px 40px rgba(70,35,12,.07);
  --shadow-lg:0 18px 50px rgba(70,35,12,.16), 0 4px 14px rgba(70,35,12,.08);
  --shadow-tang:0 12px 30px rgba(240,100,30,.30);

  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:34px;
  --shell:1200px;
  --font-disp:"Sora",system-ui,sans-serif;
  --font:"Epilogue",system-ui,-apple-system,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--cream);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-disp);font-weight:700;line-height:1.08;margin:0;letter-spacing:-.02em}
p{margin:0}
button{font-family:inherit}

.zp-shell{max-width:var(--shell);margin:0 auto;padding:0 28px;width:100%}

/* warm grain / dotted texture utility */
.zp-grain{
  background-image:radial-gradient(rgba(122,46,22,.05) 1px,transparent 1px);
  background-size:22px 22px;
}

/* ── eyebrow ─────────────────────────────────── */
.zp-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:12.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--tang-deep);
}
.zp-eyebrow::before{content:"";width:22px;height:2px;background:var(--tang);border-radius:2px}
.zp-eyebrow--leaf{color:var(--leaf)}
.zp-eyebrow--leaf::before{background:var(--leaf)}
.zp-eyebrow--center{justify-content:center}

/* ── buttons ─────────────────────────────────── */
.zp-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-disp);font-weight:600;font-size:15.5px;
  padding:14px 24px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;
  white-space:nowrap;
}
.zp-btn svg{width:18px;height:18px}
.zp-btn--solid{background:var(--tang);color:#fff;box-shadow:var(--shadow-tang)}
.zp-btn--solid:hover{background:var(--tang-deep);transform:translateY(-2px)}
.zp-btn--ink{background:var(--ink);color:var(--cream)}
.zp-btn--ink:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.zp-btn--ghost{background:var(--paper);color:var(--ink);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.zp-btn--ghost:hover{border-color:var(--tang);color:var(--tang-deep);transform:translateY(-2px)}
.zp-btn--sm{padding:10px 17px;font-size:14px}
.zp-btn--wide{width:100%}
.zp-btn--lg{padding:17px 30px;font-size:17px}

/* ============================================================
   HEADER
   ============================================================ */
.zp-head{position:sticky;top:0;z-index:60;transition:background .25s,box-shadow .25s,border-color .25s;
  border-bottom:1px solid transparent}
.zp-head.is-stuck{background:rgba(251,246,239,.86);backdrop-filter:saturate(1.4) blur(14px);
  border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(70,35,12,.06)}
.zp-head__bar{display:flex;align-items:center;gap:22px;height:74px}

.zp-logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-disp);
  font-weight:800;font-size:21px;letter-spacing:-.03em;color:var(--ink)}
.zp-logo__mark{width:30px;height:30px;border-radius:9px;position:relative;flex:0 0 auto;
  background:linear-gradient(145deg,var(--tang),var(--gold));box-shadow:var(--shadow-sm);
  display:grid;place-items:center}
.zp-logo__mark::after{content:"";width:13px;height:9px;border-radius:3px;
  background:#fff;opacity:.92;box-shadow:0 3px 0 rgba(255,255,255,.4)}
.zp-logo em{font-style:normal;color:var(--tang)}

.zp-nav{display:flex;align-items:center;gap:4px;margin-left:6px}
.zp-nav a{font-size:15px;font-weight:500;color:var(--ink-2);padding:9px 13px;border-radius:9px;
  transition:color .15s,background .15s}
.zp-nav a:hover{color:var(--ink);background:var(--cream-2)}

.zp-head__act{display:flex;align-items:center;gap:12px;margin-left:auto}
.zp-login{font-size:15px;font-weight:600;color:var(--ink);padding:8px 6px}
.zp-login:hover{color:var(--tang-deep)}

/* language selector */
.zp-lang{position:relative}
.zp-lang__btn{display:inline-flex;align-items:center;gap:6px;background:var(--paper);
  border:1.5px solid var(--line-2);color:var(--ink-2);font-weight:600;font-size:13.5px;
  padding:8px 11px;border-radius:999px;cursor:pointer;transition:border-color .15s,color .15s}
.zp-lang__btn:hover{border-color:var(--tang);color:var(--ink)}
.zp-lang__btn svg{width:15px;height:15px}
.zp-lang__chev{width:13px!important;height:13px!important;transition:transform .2s}
.zp-lang.open .zp-lang__chev{transform:rotate(180deg)}
.zp-lang__menu{position:absolute;top:calc(100% + 8px);right:0;min-width:148px;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-lg);padding:6px;display:none;flex-direction:column;z-index:80}
.zp-lang.open .zp-lang__menu{display:flex}
.zp-lang__menu button{text-align:left;background:none;border:0;font-family:var(--font);
  font-size:14.5px;font-weight:500;color:var(--ink-2);padding:9px 12px;border-radius:9px;cursor:pointer}
.zp-lang__menu button:hover{background:var(--cream-2);color:var(--ink)}
.zp-lang__menu button.is-on{color:var(--tang-deep);background:var(--tang-soft);font-weight:600}
.zp-lang--up .zp-lang__menu{top:auto;bottom:calc(100% + 8px)}

/* burger */
.zp-burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;
  border:1.5px solid var(--line-2);background:var(--paper);border-radius:12px;cursor:pointer;
  align-items:center;justify-content:center;margin-left:auto}
.zp-burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.zp-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.zp-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.zp-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.zp-mobile{display:none;flex-direction:column;gap:2px;padding:14px 0 22px}
.zp-mobile.is-open{display:flex}
.zp-mobile a{font-size:17px;font-weight:600;color:var(--ink);padding:13px 6px;border-bottom:1px solid var(--line)}
.zp-mobile .zp-btn{margin-top:14px}

/* ============================================================
   HERO — split product hero with terminal mockup
   ============================================================ */
.zp-hero{position:relative;padding:64px 0 84px;overflow:hidden}
.zp-hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(900px 480px at 88% -8%,var(--tang-soft),transparent 60%),
    radial-gradient(700px 420px at -6% 110%,var(--leaf-soft),transparent 55%);
}
.zp-hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.zp-hero__pill{display:inline-flex;align-items:center;gap:9px;background:var(--paper);
  border:1px solid var(--line);border-radius:999px;padding:7px 7px 7px 14px;font-size:13.5px;
  font-weight:600;color:var(--ink-2);box-shadow:var(--shadow-sm);margin-bottom:24px}
.zp-hero__pill b{background:var(--ink);color:var(--cream);font-size:11px;letter-spacing:.04em;
  padding:4px 9px;border-radius:999px;font-weight:700}
.zp-hero h1{font-size:clamp(40px,5.4vw,66px);letter-spacing:-.035em}
.zp-hero h1 em{font-style:normal;color:var(--tang);position:relative;white-space:nowrap}
.zp-hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;
  background:var(--gold);opacity:.45;border-radius:4px;z-index:-1}
.zp-hero__lede{font-size:19.5px;color:var(--ink-2);margin:22px 0 30px;max-width:35ch;line-height:1.55}
.zp-hero__cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:24px}
.zp-hero__meta{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:13.5px;color:var(--ink-3);
  font-family:var(--font-mono)}
.zp-hero__meta span{display:inline-flex;align-items:center;gap:7px}
.zp-hero__meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}

/* ── inline terminal + phone-tap mockup ───────── */
.zp-mock{position:relative;justify-self:center;width:100%;max-width:420px}
.zp-mock__counter{position:absolute;left:-4%;right:-4%;bottom:-26px;height:48px;border-radius:14px;
  background:linear-gradient(var(--cream-2),var(--cream));border:1px solid var(--line-2);z-index:0}
/* card terminal */
.zp-term{position:relative;z-index:2;width:230px;margin:0 auto;
  background:linear-gradient(160deg,#2b1c12,#1a1009);border-radius:30px;padding:16px 16px 22px;
  box-shadow:var(--shadow-lg);border:1px solid #3a281b}
.zp-term__screen{background:linear-gradient(160deg,#fff,#fff5ec);border-radius:16px;padding:16px 15px;
  min-height:172px;display:flex;flex-direction:column}
.zp-term__top{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);
  font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.zp-term__amt{font-family:var(--font-disp);font-weight:800;font-size:38px;letter-spacing:-.03em;
  color:var(--ink);margin:14px 0 4px}
.zp-term__lbl{font-size:12px;color:var(--ink-3);font-weight:600}
.zp-term__bar{margin-top:auto;display:flex;align-items:center;gap:8px;background:var(--leaf-soft);
  color:var(--leaf);border-radius:10px;padding:9px 12px;font-weight:700;font-size:12.5px}
.zp-term__bar svg{width:16px;height:16px}
.zp-term__pad{display:flex;justify-content:center;gap:5px;margin-top:14px}
.zp-term__pad i{width:7px;height:7px;border-radius:50%;background:#5a4434}
.zp-term__pad i:first-child{background:var(--tang)}
/* phone tapping the terminal */
.zp-phone{position:absolute;right:-6%;bottom:14%;z-index:3;width:108px;
  background:linear-gradient(160deg,#3a2618,#221408);border-radius:22px;padding:7px;
  box-shadow:var(--shadow-lg);transform:rotate(9deg);border:1px solid #4a3322}
.zp-phone__sc{background:linear-gradient(170deg,var(--tang),var(--tang-deep));border-radius:16px;
  height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:#fff;text-align:center;padding:10px}
.zp-phone__sc svg{width:34px;height:34px}
.zp-phone__sc b{font-family:var(--font-disp);font-size:13px}
.zp-phone__sc span{font-size:10px;opacity:.85;font-family:var(--font-mono)}
/* tap ripple */
.zp-tap{position:absolute;left:48%;top:34%;width:18px;height:18px;border-radius:50%;
  background:var(--gold);z-index:4;box-shadow:0 0 0 0 rgba(231,163,52,.6);animation:zptap 2.4s ease-out infinite}
@keyframes zptap{0%{box-shadow:0 0 0 0 rgba(231,163,52,.55)}70%{box-shadow:0 0 0 26px rgba(231,163,52,0)}100%{box-shadow:0 0 0 0 rgba(231,163,52,0)}}
@media (prefers-reduced-motion:reduce){.zp-tap{animation:none}}

/* floating chips on mock */
.zp-mock__chip{position:absolute;z-index:5;background:var(--paper);border:1px solid var(--line);
  border-radius:13px;box-shadow:var(--shadow);padding:9px 13px;display:flex;align-items:center;gap:9px;
  font-size:12.5px;font-weight:700;color:var(--ink)}
.zp-mock__chip small{display:block;font-size:10.5px;font-weight:500;color:var(--ink-3);font-family:var(--font-mono)}
.zp-mock__chip .dot{width:9px;height:9px;border-radius:50%}
.zp-mock__chip--a{top:-14px;left:-12px}
.zp-mock__chip--b{bottom:30px;left:-22px}

/* ── logo strip ──────────────────────────────── */
.zp-strip{padding:26px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--paper)}
.zp-strip__row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center}
.zp-strip__lbl{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-3)}
.zp-strip__logos{display:flex;gap:34px;flex-wrap:wrap;justify-content:center;align-items:center;
  font-family:var(--font-disp);font-weight:700;font-size:17px;color:var(--ink-3);opacity:.85}
.zp-strip__logos span{display:inline-flex;align-items:center;gap:7px}

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.zp-sec{padding:84px 0}
.zp-sec--cream{background:var(--cream-2)}
.zp-sec--ink{background:var(--ink);color:var(--cream)}
.zp-sec--paper{background:var(--paper)}
.zp-sechead{max-width:660px;margin-bottom:46px}
.zp-sechead--center{margin-left:auto;margin-right:auto;text-align:center}
.zp-sechead h2{font-size:clamp(30px,3.6vw,44px);margin:16px 0 14px}
.zp-sechead h2 em{font-style:normal;color:var(--tang)}
.zp-sec--ink .zp-sechead h2 em{color:var(--gold)}
.zp-sechead p{font-size:18px;color:var(--ink-2)}
.zp-sec--ink .zp-sechead p{color:#d9c8b6}

/* ============================================================
   "AT THE COUNTER" — horizontal step rail
   ============================================================ */
.zp-rail{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.zp-rail::before{content:"";position:absolute;top:34px;left:8%;right:8%;height:2px;
  background:repeating-linear-gradient(90deg,var(--line-2) 0 10px,transparent 10px 18px);z-index:0}
.zp-step{position:relative;z-index:1;padding:0 18px;text-align:center}
.zp-step__num{width:68px;height:68px;margin:0 auto 20px;border-radius:20px;background:var(--paper);
  border:1px solid var(--line);box-shadow:var(--shadow);display:grid;place-items:center;
  font-family:var(--font-disp);font-weight:800;font-size:24px;color:var(--tang);position:relative}
.zp-step__num::after{content:attr(data-step);position:absolute;top:-9px;right:-9px;width:24px;height:24px;
  border-radius:50%;background:var(--ink);color:var(--cream);font-size:11px;display:grid;place-items:center;
  font-weight:700}
.zp-step h3{font-size:19px;margin-bottom:8px}
.zp-step p{font-size:15px;color:var(--ink-2)}
.zp-step__tag{display:inline-block;margin-top:12px;font-family:var(--font-mono);font-size:11.5px;
  color:var(--leaf);background:var(--leaf-soft);padding:4px 10px;border-radius:999px;font-weight:600}

/* ============================================================
   FEATURE — tactile cards (asymmetric bento)
   ============================================================ */
.zp-bento{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.zp-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s;
  position:relative;overflow:hidden}
.zp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.zp-card--span3{grid-column:span 3}
.zp-card--span2{grid-column:span 2}
.zp-card--span6{grid-column:span 6}
.zp-card--feat{background:linear-gradient(160deg,var(--ink),#34211400);background-color:var(--ink);color:var(--cream)}
.zp-card--tang{background:linear-gradient(160deg,var(--tang),var(--tang-deep));color:#fff}
.zp-card__ic{width:50px;height:50px;border-radius:14px;background:var(--tang-soft);color:var(--tang-deep);
  display:grid;place-items:center;margin-bottom:18px}
.zp-card__ic svg{width:25px;height:25px}
.zp-card--feat .zp-card__ic{background:rgba(255,255,255,.12);color:var(--gold)}
.zp-card--tang .zp-card__ic{background:rgba(255,255,255,.2);color:#fff}
.zp-card h3{font-size:20px;margin-bottom:9px}
.zp-card--span6 h3,.zp-card--feat h3{font-size:25px}
.zp-card p{font-size:15.5px;color:var(--ink-2)}
.zp-card--feat p,.zp-card--tang p{color:rgba(255,255,255,.85)}
.zp-card__metric{margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);
  font-size:12.5px;font-weight:600;color:var(--tang-deep)}
.zp-card--feat .zp-card__metric,.zp-card--tang .zp-card__metric{color:var(--gold)}
.zp-card__metric svg{width:15px;height:15px}
.zp-card__chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.zp-chip{font-family:var(--font-mono);font-size:11.5px;font-weight:500;padding:5px 11px;border-radius:999px;
  background:var(--cream-2);color:var(--ink-2);border:1px solid var(--line)}
.zp-card--feat .zp-chip,.zp-card--tang .zp-chip{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}

/* big watermark inside feature card */
.zp-card__wm{position:absolute;right:-10px;bottom:-30px;font-family:var(--font-disp);font-weight:800;
  font-size:150px;line-height:1;color:rgba(255,255,255,.05);pointer-events:none}

/* ============================================================
   OMNICHANNEL DIAGRAM
   ============================================================ */
.zp-omni{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.zp-omni__copy h2{font-size:clamp(28px,3.4vw,40px);margin:14px 0 16px}
.zp-omni__copy h2 em{font-style:normal;color:var(--tang)}
.zp-omni__list{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:16px}
.zp-omni__list li{display:flex;gap:14px;align-items:flex-start}
.zp-omni__list b{display:block;font-family:var(--font-disp);font-size:16px;margin-bottom:2px}
.zp-omni__list span{font-size:15px;color:var(--ink-2)}
.zp-omni__ico{flex:0 0 auto;width:38px;height:38px;border-radius:11px;background:var(--leaf-soft);
  color:var(--leaf);display:grid;place-items:center}
.zp-omni__ico svg{width:20px;height:20px}

/* the diagram itself: two channels → one dashboard */
.zp-diagram{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:32px;box-shadow:var(--shadow);position:relative}
.zp-diagram__chs{display:flex;gap:16px;margin-bottom:22px}
.zp-node{flex:1;border-radius:var(--r);padding:18px;text-align:center;border:1px solid var(--line);
  background:var(--cream)}
.zp-node svg{width:30px;height:30px;margin:0 auto 10px}
.zp-node--store{color:var(--tang-deep)}
.zp-node--store svg{color:var(--tang)}
.zp-node--online{color:var(--leaf)}
.zp-node--online svg{color:var(--leaf)}
.zp-node b{font-family:var(--font-disp);font-size:15px;display:block}
.zp-node span{font-size:12px;color:var(--ink-3);font-family:var(--font-mono)}
.zp-diagram__merge{display:flex;align-items:center;justify-content:center;gap:10px;margin:0 0 22px;
  font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase}
.zp-diagram__merge::before,.zp-diagram__merge::after{content:"";flex:1;height:1px;
  background:linear-gradient(90deg,transparent,var(--line-2),transparent)}
.zp-dash{background:linear-gradient(160deg,var(--ink),#2c1b10);border-radius:var(--r);padding:20px;color:var(--cream)}
.zp-dash__hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.zp-dash__hd b{font-family:var(--font-disp);font-size:15px}
.zp-dash__hd span{font-family:var(--font-mono);font-size:11px;color:var(--gold)}
.zp-dash__rows{display:flex;flex-direction:column;gap:9px}
.zp-dash__row{display:flex;align-items:center;justify-content:space-between;font-size:13px;
  padding:9px 12px;background:rgba(255,255,255,.05);border-radius:9px}
.zp-dash__row span{color:#cdbba9;font-family:var(--font-mono);font-size:11.5px}
.zp-dash__row b{font-weight:700}
.zp-dash__row .src{display:inline-flex;align-items:center;gap:6px}
.zp-dash__row .src::before{content:"";width:7px;height:7px;border-radius:50%}
.zp-dash__row .store::before{background:var(--tang)}
.zp-dash__row .online::before{background:var(--leaf)}

/* ============================================================
   STATS BAND
   ============================================================ */
.zp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.zp-stat{text-align:left}
.zp-stat__n{font-family:var(--font-disp);font-weight:800;font-size:clamp(36px,4.4vw,54px);
  letter-spacing:-.03em;color:var(--ink);line-height:1}
.zp-sec--ink .zp-stat__n{color:var(--gold)}
.zp-stat__l{font-family:var(--font-disp);font-weight:600;font-size:15px;margin:12px 0 4px}
.zp-stat__d{font-size:13.5px;color:var(--ink-3)}
.zp-sec--ink .zp-stat__d{color:#bfae9c}

/* ============================================================
   INDUSTRIES SWITCHER
   ============================================================ */
.zp-switch{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.zp-switch button{font-family:var(--font-disp);font-weight:600;font-size:15px;padding:11px 22px;
  border-radius:999px;border:1.5px solid var(--line-2);background:var(--paper);color:var(--ink-2);cursor:pointer;
  transition:all .16s;display:inline-flex;align-items:center;gap:9px}
.zp-switch button svg{width:18px;height:18px}
.zp-switch button:hover{border-color:var(--tang)}
.zp-switch button.is-on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.zp-switch button.is-on svg{color:var(--gold)}

.zp-panel{display:none}
.zp-panel.is-on{display:block;animation:zpfade .35s ease}
@keyframes zpfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.zp-panel__grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.zp-panel__copy h3{font-size:clamp(24px,3vw,32px);margin-bottom:14px}
.zp-panel__copy p{font-size:17px;color:var(--ink-2);margin-bottom:20px}
.zp-uses{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.zp-uses li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--ink)}
.zp-uses svg{flex:0 0 auto;width:22px;height:22px;color:var(--leaf);margin-top:1px}
.zp-panel__card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:30px;box-shadow:var(--shadow)}
.zp-panel__card h4{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px}
.zp-receipt{font-family:var(--font-mono);font-size:13.5px;color:var(--ink-2)}
.zp-receipt__row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line-2)}
.zp-receipt__row.tot{border-bottom:0;border-top:2px solid var(--ink);margin-top:6px;padding-top:12px;
  font-family:var(--font-disp);font-weight:700;font-size:16px;color:var(--ink)}
.zp-receipt__tip{color:var(--gold)}

/* ============================================================
   PULL QUOTE
   ============================================================ */
.zp-quote{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);padding:46px;box-shadow:var(--shadow)}
.zp-quote__mark{font-family:var(--font-disp);font-size:80px;line-height:.6;color:var(--tang);opacity:.3}
.zp-quote blockquote{margin:0;font-family:var(--font-disp);font-weight:600;font-size:clamp(21px,2.4vw,28px);
  line-height:1.34;letter-spacing:-.02em}
.zp-quote__by{display:flex;align-items:center;gap:13px;margin-top:24px}
.zp-quote__av{width:48px;height:48px;border-radius:50%;background:linear-gradient(145deg,var(--tang),var(--gold));
  display:grid;place-items:center;color:#fff;font-family:var(--font-disp);font-weight:700;flex:0 0 auto}
.zp-quote__by b{display:block;font-size:15px}
.zp-quote__by span{font-size:13.5px;color:var(--ink-3)}
.zp-quote__side{background:var(--cream-2);border-radius:var(--r-lg);padding:26px;text-align:center}
.zp-quote__side .big{font-family:var(--font-disp);font-weight:800;font-size:44px;color:var(--tang);line-height:1}
.zp-quote__side .sm{font-size:14px;color:var(--ink-2);margin-top:8px}

/* ============================================================
   PRICING
   ============================================================ */
.zp-toggle{display:inline-flex;gap:4px;padding:5px;background:var(--cream-2);border:1px solid var(--line);
  border-radius:999px;margin:0 auto 44px}
.zp-toggle button{font-family:var(--font-disp);font-weight:600;font-size:14px;padding:9px 20px;border:0;
  background:none;color:var(--ink-2);border-radius:999px;cursor:pointer;transition:all .15s}
.zp-toggle button.is-on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-sm)}
.zp-toggle button small{color:var(--leaf);font-weight:700;margin-left:5px}

.zp-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.zp-tier{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);padding:32px;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);position:relative}
.zp-tier--pop{border:2px solid var(--tang);box-shadow:var(--shadow);transform:translateY(-8px)}
.zp-tier__tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--tang);color:#fff;
  font-family:var(--font-disp);font-weight:700;font-size:12px;padding:6px 16px;border-radius:999px;
  box-shadow:var(--shadow-tang)}
.zp-tier__name{font-family:var(--font-disp);font-weight:700;font-size:20px}
.zp-tier__price{font-family:var(--font-disp);font-weight:800;font-size:38px;letter-spacing:-.03em;margin:14px 0 2px}
.zp-tier__price small{font-size:15px;font-weight:600;color:var(--ink-3)}
.zp-tier__sub{font-family:var(--font-mono);font-size:13px;color:var(--ink-3);margin-bottom:18px}
.zp-tier__desc{font-size:15px;color:var(--ink-2);margin-bottom:22px}
.zp-tier ul{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:11px}
.zp-tier li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--ink)}
.zp-tier li svg{flex:0 0 auto;width:19px;height:19px;color:var(--leaf);margin-top:1px}
.zp-tier .zp-btn{margin-top:auto}

/* comparison strip */
.zp-compare{width:100%;border-collapse:collapse;font-size:14.5px;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.zp-compare th,.zp-compare td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line)}
.zp-compare thead th{font-family:var(--font-disp);background:var(--cream-2);font-size:14px}
.zp-compare tbody th{font-weight:500;color:var(--ink-2)}
.zp-compare td{text-align:center;font-family:var(--font-mono);font-size:13.5px}
.zp-compare tr:last-child td,.zp-compare tr:last-child th{border-bottom:0}
.zp-compare .yes{color:var(--leaf);font-weight:700}

/* ============================================================
   FAQ
   ============================================================ */
.zp-faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.zp-faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:4px 24px;
  box-shadow:var(--shadow-sm)}
.zp-faq summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:18px 0;font-family:var(--font-disp);font-weight:600;font-size:17px}
.zp-faq summary::-webkit-details-marker{display:none}
.zp-faq summary::after{content:"+";font-size:24px;color:var(--tang);font-weight:400;transition:transform .2s;flex:0 0 auto}
.zp-faq details[open] summary::after{transform:rotate(45deg)}
.zp-faq p{padding:0 0 20px;color:var(--ink-2);font-size:15.5px}

/* ============================================================
   CTA BAND
   ============================================================ */
.zp-cta{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--tang),var(--berry));
  border-radius:var(--r-xl);padding:60px;text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.zp-cta::before{content:"";position:absolute;inset:0;
  background:radial-gradient(500px 280px at 12% 0%,rgba(231,163,52,.4),transparent 60%);pointer-events:none}
.zp-cta h2{position:relative;font-size:clamp(30px,4vw,46px);margin-bottom:16px}
.zp-cta p{position:relative;font-size:18px;color:rgba(255,255,255,.9);max-width:54ch;margin:0 auto 28px}
.zp-cta__btns{position:relative;display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.zp-cta .zp-btn--solid{background:#fff;color:var(--tang-deep);box-shadow:0 12px 30px rgba(0,0,0,.18)}
.zp-cta .zp-btn--solid:hover{background:var(--cream)}
.zp-cta .zp-btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.zp-cta .zp-btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}

/* ============================================================
   PAGE HEADER (inner pages)
   ============================================================ */
.zp-phead{padding:64px 0 40px;position:relative;overflow:hidden}
.zp-phead::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(700px 360px at 80% -20%,var(--tang-soft),transparent 60%)}
.zp-phead__in{max-width:760px}
.zp-phead h1{font-size:clamp(36px,5vw,58px);margin:18px 0 18px;letter-spacing:-.03em}
.zp-phead h1 em{font-style:normal;color:var(--tang)}
.zp-phead p{font-size:19px;color:var(--ink-2);max-width:54ch}

/* split section (used on terminals / in-store) */
.zp-split{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.zp-split--rev .zp-split__media{order:2}
.zp-split__copy h2{font-size:clamp(26px,3.2vw,38px);margin:14px 0 14px}
.zp-split__copy h2 em{font-style:normal;color:var(--tang)}
.zp-split__copy p{font-size:17px;color:var(--ink-2);margin-bottom:18px}
.zp-feats{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.zp-feats li{display:flex;gap:13px;align-items:flex-start}
.zp-feats b{display:block;font-family:var(--font-disp);font-size:16px}
.zp-feats span{font-size:15px;color:var(--ink-2)}
.zp-feats .ic{flex:0 0 auto;width:36px;height:36px;border-radius:10px;background:var(--tang-soft);
  color:var(--tang-deep);display:grid;place-items:center}
.zp-feats .ic svg{width:19px;height:19px}

/* device showcase card (terminals page) */
.zp-device{background:linear-gradient(160deg,var(--cream-2),var(--cream));border:1px solid var(--line);
  border-radius:var(--r-xl);padding:40px;box-shadow:var(--shadow);text-align:center;position:relative;overflow:hidden}
.zp-device .zp-term{margin:0 auto}
.zp-devgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.zp-devcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;
  box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.zp-devcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.zp-devcard__pic{height:140px;border-radius:var(--r);background:linear-gradient(160deg,var(--cream-2),#fff);
  border:1px solid var(--line);display:grid;place-items:center;margin-bottom:20px}
.zp-devcard__pic svg{width:60px;height:60px;color:var(--tang)}
.zp-devcard h3{font-size:19px;margin-bottom:6px}
.zp-devcard p{font-size:14.5px;color:var(--ink-2);margin-bottom:14px}
.zp-devcard__price{font-family:var(--font-mono);font-size:13px;color:var(--leaf);font-weight:600}

/* ============================================================
   FORMS (contact / signin)
   ============================================================ */
.zp-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);padding:36px;
  box-shadow:var(--shadow)}
.zp-field{margin-bottom:18px}
.zp-field label{display:block;font-family:var(--font-disp);font-weight:600;font-size:14px;margin-bottom:7px}
.zp-input,.zp-textarea,.zp-select{width:100%;font-family:var(--font);font-size:15.5px;color:var(--ink);
  background:var(--cream);border:1.5px solid var(--line-2);border-radius:var(--r-sm);padding:13px 15px;
  transition:border-color .15s,box-shadow .15s}
.zp-input:focus,.zp-textarea:focus,.zp-select:focus{outline:none;border-color:var(--tang);
  box-shadow:0 0 0 4px var(--tang-soft);background:#fff}
.zp-textarea{min-height:130px;resize:vertical}
.zp-field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.zp-form__note{font-size:13px;color:var(--ink-3);margin-top:6px}

.zp-contact{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:start}
.zp-aside{display:flex;flex-direction:column;gap:18px}
.zp-aside__card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;
  box-shadow:var(--shadow-sm)}
.zp-aside__card h3{font-size:17px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.zp-aside__card h3 svg{width:20px;height:20px;color:var(--tang)}
.zp-aside__card p{font-size:14.5px;color:var(--ink-2)}
.zp-aside__card a{color:var(--tang-deep);font-weight:600}

/* signin */
.zp-auth{min-height:calc(100vh - 74px);display:grid;grid-template-columns:1fr 1fr}
.zp-auth__form{display:flex;align-items:center;justify-content:center;padding:60px 28px}
.zp-auth__inner{width:100%;max-width:400px}
.zp-auth__inner h1{font-size:32px;margin-bottom:8px}
.zp-auth__inner>p{color:var(--ink-2);margin-bottom:28px}
.zp-auth__side{background:linear-gradient(160deg,var(--ink),#2c1b10);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;padding:60px;position:relative;overflow:hidden}
.zp-auth__side::before{content:"";position:absolute;inset:0;
  background:radial-gradient(500px 300px at 80% 10%,rgba(240,100,30,.3),transparent 60%)}
.zp-auth__side h2{position:relative;font-size:30px;margin-bottom:16px}
.zp-auth__side h2 em{font-style:normal;color:var(--gold)}
.zp-auth__side p{position:relative;color:#d9c8b6;font-size:16px;margin-bottom:24px}
.zp-auth__pts{position:relative;list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.zp-auth__pts li{display:flex;gap:12px;align-items:center;font-size:15px}
.zp-auth__pts svg{width:22px;height:22px;color:var(--gold);flex:0 0 auto}
.zp-demo-note{background:var(--tang-soft);border:1px solid var(--tang);border-radius:var(--r);padding:14px 16px;
  font-size:13.5px;color:var(--berry);margin-top:22px}

/* ============================================================
   LEGAL
   ============================================================ */
.zp-legal{padding:56px 0 80px}
.zp-legal__in{max-width:820px;margin:0 auto}
.zp-legal h1{font-size:clamp(32px,4vw,46px);margin:14px 0 10px}
.zp-legal__meta{font-family:var(--font-mono);font-size:13px;color:var(--ink-3);margin-bottom:32px}
.zp-legal__toc{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px 26px;
  margin-bottom:36px;box-shadow:var(--shadow-sm)}
.zp-legal__toc h4{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:12px}
.zp-legal__toc ol{margin:0;padding-left:20px;columns:2;column-gap:30px}
.zp-legal__toc li{margin-bottom:7px;font-size:14.5px}
.zp-legal__toc a{color:var(--ink-2)}
.zp-legal__toc a:hover{color:var(--tang-deep)}
.zp-legal__body h2{font-size:22px;margin:34px 0 12px;scroll-margin-top:90px}
.zp-legal__body p,.zp-legal__body li{font-size:16px;color:var(--ink-2);margin-bottom:12px}
.zp-legal__body ul{padding-left:22px}
.zp-legal__body a{color:var(--tang-deep);font-weight:600}
.zp-legal__body strong{color:var(--ink)}

/* ============================================================
   FOOTER
   ============================================================ */
.zp-foot{background:var(--ink);color:var(--cream);padding:64px 0 30px;position:relative;overflow:hidden}
.zp-foot__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:34px;margin-bottom:44px}
.zp-foot .zp-logo{color:var(--cream)}
.zp-foot__blurb{font-size:14.5px;color:#bfae9c;margin:16px 0 18px;max-width:34ch;line-height:1.6}
.zp-foot__badges{display:flex;flex-wrap:wrap;gap:8px}
.zp-foot__badge{font-family:var(--font-mono);font-size:11px;font-weight:500;padding:5px 10px;border-radius:999px;
  background:rgba(255,255,255,.07);color:#d9c8b6;border:1px solid rgba(255,255,255,.1)}
.zp-foot__col h4{font-family:var(--font-disp);font-size:13px;text-transform:uppercase;letter-spacing:.08em;
  color:#fff;margin-bottom:16px}
.zp-foot__col a{display:block;font-size:14.5px;color:#bfae9c;padding:5px 0;transition:color .15s}
.zp-foot__col a:hover{color:var(--gold)}
.zp-foot__big{font-family:var(--font-disp);font-weight:800;font-size:clamp(60px,16vw,200px);line-height:.8;
  letter-spacing:-.04em;color:rgba(255,255,255,.04);margin:10px 0 0;user-select:none;pointer-events:none}
.zp-foot__base{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding-top:26px;border-top:1px solid rgba(255,255,255,.1);font-size:13.5px;color:#9c8b7a}
.zp-foot__base .zp-lang__btn{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#d9c8b6}
.zp-foot__base .zp-lang__btn:hover{border-color:var(--gold);color:#fff}

/* ============================================================
   REVEAL
   ============================================================ */
[data-rise]{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
[data-rise].is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-rise]{opacity:1;transform:none;transition:none}}

/* ============================================================
   RESPONSIVE — tablet ≤768
   ============================================================ */
@media (max-width:980px){
  .zp-bento{grid-template-columns:repeat(4,1fr)}
  .zp-card--span3{grid-column:span 2}
  .zp-card--span2{grid-column:span 2}
  .zp-card--span6{grid-column:span 4}
  .zp-foot__top{grid-template-columns:1fr 1fr 1fr;gap:30px}
  .zp-foot__brand{grid-column:1 / -1}
}

@media (max-width:768px){
  body{font-size:16px}
  .zp-shell{padding:0 20px}
  .zp-nav,.zp-head__act .zp-login,.zp-head__act .zp-btn{display:none}
  .zp-head__act{margin-left:0;gap:8px}
  .zp-head__act .zp-lang{margin-left:auto}
  .zp-burger{display:flex}
  .zp-sec{padding:60px 0}
  .zp-phead{padding:48px 0 32px}

  .zp-hero{padding:40px 0 60px}
  .zp-hero__grid{grid-template-columns:1fr;gap:54px}
  .zp-hero__lede{max-width:none}
  .zp-mock{max-width:360px;margin-top:10px}

  .zp-rail{grid-template-columns:1fr 1fr;gap:34px 16px}
  .zp-rail::before{display:none}

  .zp-omni,.zp-split,.zp-panel__grid,.zp-quote,.zp-contact,.zp-auth{grid-template-columns:1fr;gap:34px}
  .zp-split--rev .zp-split__media{order:0}
  .zp-quote{padding:34px}
  .zp-quote__mark{display:none}
  .zp-auth{min-height:0;display:block}
  .zp-auth__side{display:none}
  .zp-auth__form{padding:36px 0}

  .zp-stats{grid-template-columns:1fr 1fr;gap:30px 24px}
  .zp-tiers{grid-template-columns:1fr;gap:30px}
  .zp-tier--pop{transform:none}
  .zp-devgrid{grid-template-columns:1fr 1fr}
  .zp-cta{padding:42px 26px}
  .zp-foot__top{grid-template-columns:1fr 1fr;gap:28px}
  .zp-legal__toc ol{columns:1}
  /* horizontal-scroll wrappers */
  .zp-scrollx{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .zp-scrollx .zp-compare{min-width:560px}
}

/* ============================================================
   RESPONSIVE — phone ≤480
   ============================================================ */
@media (max-width:480px){
  .zp-shell{padding:0 16px}
  .zp-hero h1{font-size:clamp(33px,9vw,42px)}
  .zp-hero__cta{flex-direction:column}
  .zp-hero__cta .zp-btn{width:100%}
  .zp-hero__pill{flex-wrap:wrap}
  .zp-mock{max-width:300px}
  .zp-phone{width:92px;right:-2%}
  .zp-mock__chip--b{left:-8px}

  .zp-bento{grid-template-columns:1fr;gap:16px}
  .zp-card--span3,.zp-card--span2,.zp-card--span6{grid-column:span 1}
  .zp-card{padding:24px}

  .zp-rail{grid-template-columns:1fr;gap:28px}
  .zp-stats{grid-template-columns:1fr;gap:24px;text-align:center}
  .zp-stat{text-align:center}
  .zp-devgrid{grid-template-columns:1fr}
  .zp-switch button{flex:1;justify-content:center;font-size:14px;padding:10px 14px}
  .zp-foot__top{grid-template-columns:1fr;gap:24px}
  .zp-foot__base{flex-direction:column;align-items:flex-start;gap:16px}
  .zp-form,.zp-cta{padding:28px 22px}
  .zp-quote__side .big{font-size:38px}
  .zp-sechead h2,.zp-cta h2,.zp-omni__copy h2{font-size:clamp(26px,7vw,32px)}
}
