/* ════════════════════════════════════════════════════════════════
   Cerclepay — Membership & recurring revenue platform
   Light · warm cream · rounded · lavender + coral
   Single-page friendly SaaS
   ════════════════════════════════════════════════════════════════ */

:root {
  --bg:#faf5ec;
  --bg-2:#fce6cf;
  --bg-3:#f0eafd;
  --bg-4:#1a1424;
  --surface:#ffffff;
  --ink:#1a1424;
  --ink-2:#54486c;
  --ink-3:#8a809e;
  --lav:#6c4ff5;
  --lav-dk:#4b2dd8;
  --lav-soft:#e8e0fb;
  --coral:#ff8a6c;
  --coral-dk:#e26a4a;
  --mint:#5fc798;
  --amber:#f5b942;
  --line:rgba(26,20,36,.10);
  --line-2:rgba(26,20,36,.16);
  --r:24px;
  --r-m:18px;
  --r-s:12px;
  --shadow-sm:0 4px 14px rgba(26,20,36,.06);
  --shadow:0 14px 40px rgba(26,20,36,.08);
  --shadow-lg:0 30px 70px rgba(26,20,36,.10);
  --disp:"Plus Jakarta Sans", system-ui, sans-serif;
  --sans:"Plus Jakarta Sans", system-ui, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --ease:cubic-bezier(.2,.7,.2,1);
  --shell:1240px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html, body { overflow-x:hidden; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:15.5px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  position:relative;
}
img,svg { display:block; max-width:100%; }
button { background:none; border:none; cursor:pointer; font:inherit; color:inherit; }
a { color:inherit; text-decoration:none; }
input,textarea,select,button { font:inherit; }
::selection { background:var(--lav); color:#fff; }

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

h1,h2,h3,h4 { font-family:var(--disp); font-weight:700; line-height:1.05; letter-spacing:-.02em; color:var(--ink); }
p { font-family:var(--sans); }

/* ── reveal animation ─────────────────────────────────────── */
[data-rise] { opacity:0; transform:translateY(20px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-rise].is-in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ [data-rise]{ opacity:1; transform:none; transition:none; } }

/* ── shared ───────────────────────────────────────────────── */
.cp-pill {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px 6px 6px;
  font-family:var(--sans); font-size:12.5px; font-weight:600;
  color:var(--ink-2); background:var(--surface);
  border-radius:999px; box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
}
.cp-pill b {
  display:inline-flex; align-items:center; gap:5px;
  font-size:11px; padding:3px 9px;
  background:var(--lav); color:#fff;
  border-radius:999px; font-weight:600;
}
.cp-pill b::before {
  content:""; width:5px; height:5px; border-radius:50%; background:#fff;
  box-shadow:0 0 5px rgba(255,255,255,.7);
}
.cp-h1 { font-size:clamp(2.8rem, 6.4vw, 5.6rem); }
.cp-h2 { font-size:clamp(2.2rem, 4.6vw, 3.6rem); }
.cp-h3 { font-size:clamp(1.4rem, 2.2vw, 1.8rem); }
.cp-h1 em, .cp-h2 em, .cp-h3 em {
  font-style:normal;
  color:var(--lav);
  background:linear-gradient(120deg, var(--lav) 0%, var(--coral) 100%);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}

.cp-sec { padding:110px 0; position:relative; }
.cp-sec--peach { background:var(--bg-2); }
.cp-sec--lav { background:var(--bg-3); }
.cp-sec--ink { background:var(--bg-4); color:#f0e9d6; }
.cp-sec--ink h1,.cp-sec--ink h2,.cp-sec--ink h3 { color:#fff; }
.cp-sec--ink em { color:var(--coral); -webkit-text-fill-color:initial; background:none; }

.cp-sechead { display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap; margin-bottom:56px; }
.cp-sechead > div:first-child { flex:1 1 30em; min-width:0; }
.cp-sechead .cp-pill { margin-bottom:18px; }
.cp-sechead--c { text-align:center; flex-direction:column; align-items:center; max-width:50em; margin-left:auto; margin-right:auto; }
.cp-sechead--c .cp-pill { margin:0 auto 18px; }

/* ── buttons ──────────────────────────────────────────────── */
.cp-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--sans); font-weight:600; font-size:14.5px;
  height:50px; padding:0 26px; border-radius:999px; white-space:nowrap;
  transition:background .2s, color .2s, border-color .2s, transform .25s var(--ease), box-shadow .25s var(--ease);
  letter-spacing:-.01em;
}
.cp-btn--ink { background:var(--ink); color:#fff; box-shadow:var(--shadow-sm); }
.cp-btn--ink:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.cp-btn--lav { background:var(--lav); color:#fff; box-shadow:0 8px 24px rgba(108,79,245,.32); }
.cp-btn--lav:hover { background:var(--lav-dk); transform:translateY(-2px); box-shadow:0 14px 36px rgba(108,79,245,.4); }
.cp-btn--coral { background:var(--coral); color:#1a1424; }
.cp-btn--coral:hover { background:var(--coral-dk); color:#fff; transform:translateY(-2px); }
.cp-btn--soft { background:var(--surface); color:var(--ink); border:1px solid var(--line-2); }
.cp-btn--soft:hover { background:var(--lav-soft); border-color:var(--lav); color:var(--lav); }
.cp-btn--paper { background:#fff; color:var(--ink); }
.cp-btn--paper:hover { background:var(--lav); color:#fff; }
.cp-btn--lg { height:58px; padding:0 30px; font-size:15px; }
.cp-btn--sm { height:40px; padding:0 18px; font-size:13px; }
.cp-btn--wide { width:100%; }
.cp-btn svg { width:15px; height:15px; }

/* ── HEADER (pill nav) ────────────────────────────────────── */
.cp-head {
  position:sticky; top:18px; z-index:100;
  padding:0 18px; margin-top:18px;
  transition:top .3s;
}
.cp-head__bar {
  display:flex; align-items:center; gap:18px;
  height:62px; padding:6px 6px 6px 24px;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(20px) saturate(160%); backdrop-filter:blur(20px) saturate(160%);
  border:1px solid var(--line); border-radius:999px;
  box-shadow:var(--shadow-sm);
  max-width:var(--shell); margin:0 auto;
  transition:box-shadow .3s, background .3s;
}
.cp-head.is-stuck .cp-head__bar { box-shadow:var(--shadow); background:rgba(255,255,255,.98); }
.cp-logo { display:inline-flex; align-items:center; gap:10px; flex:none; }
.cp-logo__mark {
  width:30px; height:30px; border-radius:50%;
  background:var(--ink); position:relative;
  display:flex; align-items:center; justify-content:center;
}
.cp-logo__mark::before {
  content:""; width:16px; height:16px; border-radius:50%;
  border:2px solid var(--coral);
}
.cp-logo__mark::after {
  content:""; position:absolute; width:6px; height:6px; border-radius:50%;
  background:var(--lav);
  top:50%; left:50%; transform:translate(-50%,-50%);
}
.cp-logo__word { font-family:var(--disp); font-weight:700; font-size:19px; letter-spacing:-.02em; color:var(--ink); }

.cp-nav { display:flex; gap:0; flex:1; justify-content:center; }
.cp-nav a {
  font-size:14px; font-weight:500; color:var(--ink-2);
  padding:9px 14px; border-radius:999px;
  transition:color .2s, background .2s;
}
.cp-nav a:hover { color:var(--ink); background:var(--bg); }

.cp-head__act { display:flex; align-items:center; gap:8px; flex:none; }
.cp-head__act .cp-login {
  font-size:14px; font-weight:500; color:var(--ink-2); padding:8px 12px;
  transition:color .2s;
}
.cp-head__act .cp-login:hover { color:var(--ink); }

/* language */
.cp-lang { position:relative; }
.cp-lang__btn {
  display:inline-flex; align-items:center; gap:5px;
  font-size:12.5px; color:var(--ink-2); padding:6px 11px;
  border:1px solid var(--line); border-radius:999px;
  background:var(--surface);
  transition:border-color .2s, color .2s;
}
.cp-lang__btn:hover { color:var(--ink); border-color:var(--line-2); }
.cp-lang__btn svg { width:12px; height:12px; }
.cp-lang__chev { width:9px !important; height:9px !important; transition:transform .25s; }
.cp-lang.open .cp-lang__chev { transform:rotate(180deg); }
.cp-lang__menu {
  position:absolute; top:calc(100% + 8px); right:0;
  background:var(--surface); border:1px solid var(--line); border-radius:16px;
  padding:5px; min-width:160px; box-shadow:var(--shadow);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .2s, transform .2s, visibility .2s;
  z-index:120;
}
.cp-lang.open .cp-lang__menu { opacity:1; visibility:visible; transform:none; }
.cp-lang--up .cp-lang__menu { top:auto; bottom:calc(100% + 8px); }
.cp-lang__menu button {
  display:block; width:100%; text-align:left; font-size:12.5px;
  color:var(--ink-2); padding:9px 12px; border-radius:10px; transition:background .15s, color .15s;
}
.cp-lang__menu button:hover { background:var(--bg); color:var(--ink); }
.cp-lang__menu button.is-on { color:var(--lav); }

.cp-burger { display:none; flex-direction:column; gap:4px; width:40px; height:40px; align-items:center; justify-content:center; flex:none; border-radius:50%; border:1px solid var(--line); background:var(--surface); }
.cp-burger span { width:14px; height:1.6px; background:var(--ink); transition:transform .25s var(--ease), opacity .2s; }
.cp-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
.cp-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.cp-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-5px) rotate(-45deg); }
.cp-mobile {
  display:none; flex-direction:column; gap:2px; padding:14px 22px 22px; margin-top:10px;
  background:var(--surface); border:1px solid var(--line); border-radius:24px;
  box-shadow:var(--shadow); max-width:var(--shell); margin-left:auto; margin-right:auto;
}
.cp-mobile[hidden]{ display:none; }
.cp-mobile.is-open { display:flex; }
.cp-mobile a { font-size:15px; font-weight:500; color:var(--ink-2); padding:12px 4px; }
.cp-mobile .cp-btn { margin-top:10px; }

/* ── HERO ─────────────────────────────────────────────────── */
.cp-hero { padding:100px 0 70px; position:relative; }
.cp-hero__deco { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.cp-hero__circle {
  position:absolute; border-radius:50%;
}
.cp-hero__circle--a { top:6%; right:-60px; width:240px; height:240px; background:var(--coral); opacity:.7; }
.cp-hero__circle--b { top:36%; left:-110px; width:220px; height:220px; background:var(--lav-soft); }
.cp-hero__circle--c { bottom:-80px; right:18%; width:160px; height:160px; background:var(--amber); opacity:.5; }
.cp-hero__in { text-align:center; max-width:980px; margin:0 auto; position:relative; z-index:2; }
.cp-hero__h1 { font-size:clamp(2.8rem, 7vw, 6rem); margin:24px auto 0; line-height:1.0; max-width:14em; letter-spacing:-.025em; }
.cp-hero__h1 em { font-style:normal; color:transparent; background:linear-gradient(120deg, var(--lav), var(--coral) 80%); -webkit-background-clip:text; background-clip:text; }
.cp-hero__lede { margin:24px auto 0; max-width:38em; font-size:18px; color:var(--ink-2); line-height:1.55; }
.cp-hero__cta { display:inline-flex; gap:12px; margin-top:34px; flex-wrap:wrap; justify-content:center; }
.cp-hero__small { margin-top:18px; font-size:13px; color:var(--ink-3); display:inline-flex; align-items:center; gap:7px; }
.cp-hero__small::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--mint); }

/* hero dashboard mockup */
.cp-hero__mock { margin:64px auto 0; max-width:1080px; position:relative; z-index:2; }
.cp-hero__mock-frame {
  border:1px solid var(--line); border-radius:28px;
  background:var(--surface); box-shadow:var(--shadow-lg);
  padding:22px;
  position:relative;
  overflow:hidden;
}
.cp-hero__mock-frame::before {
  content:""; position:absolute; top:-30%; right:-10%; width:340px; height:340px;
  background:radial-gradient(circle, var(--lav-soft), transparent 70%);
  pointer-events:none;
}
.cpm { display:grid; grid-template-columns:1fr 1fr; gap:18px; position:relative; z-index:2; }
.cpm__panel {
  background:var(--bg); border-radius:18px; padding:22px;
  display:flex; flex-direction:column; gap:14px;
}
.cpm__panel--white { background:var(--surface); border:1px solid var(--line); }
.cpm__panel--lav { background:var(--lav); color:#fff; }
.cpm__panel--lav h4, .cpm__panel--lav b { color:#fff; }
.cpm__hd { display:flex; align-items:center; justify-content:space-between; }
.cpm__hd span { font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--ink-3); text-transform:uppercase; }
.cpm__panel--lav .cpm__hd span { color:rgba(255,255,255,.7); }
.cpm__hd b { display:inline-flex; align-items:center; gap:5px; font-size:11px; color:var(--mint); }
.cpm__hd b::before { content:""; width:6px; height:6px; border-radius:50%; background:currentColor; }
.cpm__big { font-family:var(--disp); font-size:2.2rem; font-weight:700; line-height:1; letter-spacing:-.02em; }
.cpm__sub { font-size:13px; color:var(--ink-2); }
.cpm__panel--lav .cpm__sub { color:rgba(255,255,255,.75); }
.cpm__chart { display:flex; align-items:flex-end; gap:4px; height:70px; }
.cpm__chart i { flex:1; background:var(--ink); border-radius:5px 5px 0 0; min-height:6px; opacity:.55; }
.cpm__chart i:nth-child(odd) { opacity:.9; }
.cpm__panel--lav .cpm__chart i { background:#fff; }
.cpm__ring {
  width:120px; height:120px; border-radius:50%;
  background:conic-gradient(var(--lav) 0 72%, var(--coral) 72% 86%, var(--amber) 86% 96%, var(--ink) 96% 100%);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto;
}
.cpm__ring::before {
  content:""; width:80px; height:80px; border-radius:50%; background:var(--bg);
}
.cpm__legend { display:flex; flex-direction:column; gap:8px; }
.cpm__legend li { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--ink-2); justify-content:space-between; }
.cpm__legend i { width:9px; height:9px; border-radius:50%; flex:none; }
.cpm__legend b { font-family:var(--mono); font-size:12px; font-weight:500; color:var(--ink); }
.cpm__rows {
  background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:6px;
}
.cpm__row {
  display:grid; grid-template-columns:32px 1fr auto; align-items:center; gap:11px;
  padding:8px 10px; font-size:13px; border-radius:8px;
}
.cpm__row + .cpm__row { border-top:1px solid var(--line); }
.cpm__row .cpm__av {
  width:28px; height:28px; border-radius:50%; flex:none;
  background:linear-gradient(135deg, var(--lav), var(--coral));
}
.cpm__row b { font-weight:600; }
.cpm__row em { font-family:var(--mono); font-size:11.5px; font-style:normal; color:var(--mint); font-weight:600; }
.cpm__row em.is-coral { color:var(--coral-dk); }

/* ── TRUST STRIP ──────────────────────────────────────────── */
.cp-trust { padding:36px 0; }
.cp-trust__lbl {
  display:block; text-align:center; font-size:13px; color:var(--ink-3); margin-bottom:24px;
}
.cp-trust__row {
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
  padding:20px 30px; background:var(--surface); border:1px solid var(--line); border-radius:24px;
  box-shadow:var(--shadow-sm);
}
.cp-trust__logo {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--disp); font-weight:700; font-size:18px; color:var(--ink-2);
  letter-spacing:-.01em; opacity:.7; transition:opacity .2s, color .2s;
}
.cp-trust__logo:hover { opacity:1; color:var(--ink); }
.cp-trust__logo i {
  width:18px; height:18px; border-radius:50%; background:currentColor; opacity:.4;
}
.cp-trust__logo--ring i { border:2px solid currentColor; background:transparent; opacity:1; }

/* ── PROBLEM CARDS ────────────────────────────────────────── */
.cp-problem { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; }
.cp-prob {
  padding:30px;
  background:var(--surface); border-radius:24px;
  box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.cp-prob:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.cp-prob__emoji { font-size:34px; margin-bottom:14px; }
.cp-prob h3 { font-size:1.3rem; margin-bottom:10px; }
.cp-prob p { font-size:14.5px; color:var(--ink-2); line-height:1.6; }

/* ── FEATURES (rounded) ───────────────────────────────────── */
.cp-features { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; }
.cp-feat {
  padding:32px 28px; background:var(--surface); border-radius:24px;
  box-shadow:var(--shadow-sm); transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  display:flex; flex-direction:column;
}
.cp-feat:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.cp-feat--lg { grid-column:span 2; }
.cp-feat__icon {
  width:48px; height:48px; border-radius:14px;
  background:var(--lav-soft); color:var(--lav);
  display:flex; align-items:center; justify-content:center; margin-bottom:20px;
}
.cp-feat__icon--coral { background:#ffe0d4; color:var(--coral-dk); }
.cp-feat__icon--mint { background:#d8f3e3; color:var(--mint); }
.cp-feat__icon--amber { background:#fceacd; color:#b87f1f; }
.cp-feat__icon svg { width:22px; height:22px; }
.cp-feat h3 { font-size:1.35rem; margin-bottom:10px; }
.cp-feat p { font-size:14.5px; color:var(--ink-2); line-height:1.65; }
.cp-feat__meta { display:inline-flex; align-items:center; gap:7px; margin-top:18px; font-family:var(--mono); font-size:11.5px; color:var(--lav); font-weight:500; }

/* ── BIG SPLIT (product showcase) ──────────────────────────── */
.cp-split { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.cp-split--rev { direction:rtl; }
.cp-split--rev > * { direction:ltr; }
.cp-split p { font-size:16px; color:var(--ink-2); line-height:1.7; margin:18px 0; }
.cp-split ul { list-style:none; margin-top:18px; }
.cp-split li {
  position:relative; padding-left:32px; margin:14px 0; font-size:15px; color:var(--ink-2);
  line-height:1.6;
}
.cp-split li::before {
  content:""; position:absolute; left:0; top:5px; width:20px; height:20px; border-radius:50%;
  background:var(--lav-soft);
}
.cp-split li::after {
  content:""; position:absolute; left:6px; top:11px; width:8px; height:5px;
  border-left:1.6px solid var(--lav); border-bottom:1.6px solid var(--lav);
  transform:rotate(-45deg);
}
.cp-split li b { color:var(--ink); font-weight:600; }
.cp-split__art {
  position:relative; aspect-ratio:5/4;
  background:var(--surface); border-radius:24px;
  box-shadow:var(--shadow); overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.cp-split__art--peach { background:linear-gradient(135deg, var(--bg-2), #fad9c3); }
.cp-split__art--lav { background:linear-gradient(135deg, var(--bg-3), var(--lav-soft)); }
.cp-split__art--ink { background:linear-gradient(135deg, var(--bg-4), #2a2236); }

/* ── HOW IT WORKS (numbered cards) ────────────────────────── */
.cp-how { display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
.cp-step {
  padding:32px 26px; background:var(--surface); border-radius:24px;
  position:relative; box-shadow:var(--shadow-sm);
}
.cp-step--lav { background:var(--lav); color:#fff; }
.cp-step--coral { background:var(--coral); color:#fff; }
.cp-step--lav h3, .cp-step--coral h3 { color:#fff; }
.cp-step--lav p, .cp-step--coral p { color:rgba(255,255,255,.85); }
.cp-step--lav .cp-step__n, .cp-step--coral .cp-step__n { color:rgba(255,255,255,.4); }
.cp-step__n {
  font-family:var(--disp); font-size:3.2rem; line-height:.9; font-weight:700; color:var(--lav);
  letter-spacing:-.04em;
}
.cp-step h3 { font-size:1.3rem; margin:14px 0 10px; }
.cp-step p { font-size:14px; color:var(--ink-2); line-height:1.6; }

/* ── STATS STRIP ──────────────────────────────────────────── */
.cp-stats { display:grid; grid-template-columns:repeat(4, 1fr); gap:1px; background:var(--line); border-radius:24px; overflow:hidden; }
.cp-stat {
  background:var(--surface); padding:30px 26px;
  display:flex; flex-direction:column; gap:6px;
}
.cp-stat__n { font-family:var(--disp); font-weight:700; font-size:clamp(2.2rem, 4vw, 3rem); line-height:1; letter-spacing:-.03em; color:var(--ink); }
.cp-stat__n em { font-style:normal; color:var(--coral); }
.cp-stat__l { font-size:13px; color:var(--ink-3); }
.cp-stat__d { font-size:13px; color:var(--ink-2); line-height:1.5; margin-top:10px; }

/* ── USE CASES (industry cards) ──────────────────────────── */
.cp-cases { display:grid; grid-template-columns:repeat(2, 1fr); gap:20px; }
.cp-case {
  padding:36px; border-radius:24px; box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden; min-height:280px;
  display:flex; flex-direction:column; justify-content:flex-end;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.cp-case:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.cp-case--ink { background:var(--bg-4); color:#fff; }
.cp-case--peach { background:var(--bg-2); }
.cp-case--lav { background:var(--bg-3); }
.cp-case--white { background:var(--surface); }
.cp-case__tag {
  position:absolute; top:24px; right:24px;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase;
  padding:5px 11px; background:rgba(255,255,255,.85); border-radius:999px;
  color:var(--ink);
}
.cp-case--ink .cp-case__tag { background:rgba(255,255,255,.12); color:#fff; }
.cp-case__emoji { font-size:42px; margin-bottom:14px; }
.cp-case h3 { font-size:1.7rem; margin-bottom:10px; }
.cp-case--ink h3 { color:#fff; }
.cp-case p { font-size:14.5px; color:var(--ink-2); line-height:1.6; }
.cp-case--ink p { color:rgba(255,255,255,.75); }
.cp-case__stat {
  margin-top:16px; font-family:var(--mono); font-size:12.5px; color:var(--lav); font-weight:600;
  display:inline-flex; gap:8px;
}
.cp-case--ink .cp-case__stat { color:var(--coral); }

/* ── QUOTES (carousel-style) ──────────────────────────────── */
.cp-quotes { display:grid; grid-template-columns:repeat(3, 1fr); gap:20px; }
.cp-quote {
  padding:30px 28px;
  background:var(--surface); border-radius:24px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:18px;
}
.cp-quote__stars { color:var(--amber); font-size:15px; letter-spacing:2px; }
.cp-quote__text { font-size:15.5px; color:var(--ink-2); line-height:1.6; }
.cp-quote__text em { font-style:normal; color:var(--ink); font-weight:600; }
.cp-quote__by { display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid var(--line); margin-top:auto; }
.cp-quote__av { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg, var(--lav), var(--coral)); flex:none; }
.cp-quote__name { font-size:14px; font-weight:600; }
.cp-quote__role { font-size:12px; color:var(--ink-3); margin-top:2px; }

/* ── PRICING ─────────────────────────────────────────────── */
.cp-tiers { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; }
.cp-tier {
  padding:36px 32px; background:var(--surface); border-radius:24px;
  box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  display:flex; flex-direction:column;
}
.cp-tier:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.cp-tier--pop { background:var(--ink); color:#fff; position:relative; }
.cp-tier--pop h3, .cp-tier--pop b { color:#fff; }
.cp-tier--pop p, .cp-tier--pop li { color:rgba(255,255,255,.75); }
.cp-tier--pop .cp-tier__per { color:rgba(255,255,255,.6); }
.cp-tier__tag {
  position:absolute; top:-12px; left:24px;
  font-size:11px; padding:5px 12px; border-radius:999px;
  background:var(--coral); color:var(--ink); font-weight:700;
  letter-spacing:.02em;
}
.cp-tier__name { font-size:13px; font-weight:600; color:var(--ink-3); margin-bottom:6px; }
.cp-tier--pop .cp-tier__name { color:rgba(255,255,255,.6); }
.cp-tier__price { font-family:var(--disp); font-size:3.4rem; font-weight:700; line-height:1; letter-spacing:-.03em; }
.cp-tier__price em { font-style:normal; color:var(--coral); }
.cp-tier__per { font-size:13px; color:var(--ink-3); margin-top:8px; }
.cp-tier__desc { font-size:14px; color:var(--ink-2); line-height:1.6; margin:20px 0 24px; padding-top:20px; border-top:1px solid var(--line); }
.cp-tier--pop .cp-tier__desc { border-top-color:rgba(255,255,255,.15); }
.cp-tier__list { list-style:none; flex:1; display:flex; flex-direction:column; gap:11px; margin-bottom:24px; }
.cp-tier__list li {
  position:relative; padding-left:26px; font-size:14px; line-height:1.55;
}
.cp-tier__list li::before {
  content:""; position:absolute; left:0; top:4px; width:18px; height:18px; border-radius:50%;
  background:var(--lav-soft);
}
.cp-tier__list li::after {
  content:""; position:absolute; left:5px; top:9px; width:8px; height:5px;
  border-left:1.6px solid var(--lav); border-bottom:1.6px solid var(--lav); transform:rotate(-45deg);
}
.cp-tier--pop .cp-tier__list li::before { background:rgba(255,255,255,.16); }
.cp-tier--pop .cp-tier__list li::after { border-color:var(--coral); }

/* ── INTEGRATIONS ───────────────────────────────────────── */
.cp-integrations {
  display:grid; grid-template-columns:repeat(6, 1fr); gap:14px;
}
.cp-int {
  aspect-ratio:1/1; background:var(--surface); border-radius:20px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.cp-int:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.cp-int__mark {
  width:34px; height:34px; border-radius:50%;
  background:linear-gradient(135deg, var(--lav), var(--coral));
}
.cp-int__mark--ring { background:var(--surface); border:2px solid var(--ink); }
.cp-int__mark--coral { background:var(--coral); border:none; }
.cp-int__mark--amber { background:var(--amber); }
.cp-int__mark--ink { background:var(--ink); }
.cp-int__mark--mint { background:var(--mint); }
.cp-int__mark--soft { background:var(--lav-soft); }
.cp-int span { font-size:12px; font-weight:600; color:var(--ink-2); }

/* ── FAQ ──────────────────────────────────────────────────── */
.cp-faq { max-width:860px; margin:0 auto; }
.cp-faq details {
  margin-bottom:14px; padding:22px 28px;
  background:var(--surface); border-radius:18px;
  transition:box-shadow .25s;
}
.cp-faq details[open] { box-shadow:var(--shadow); }
.cp-faq summary {
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  font-size:1.1rem; font-weight:600; cursor:pointer; list-style:none;
  letter-spacing:-.01em;
}
.cp-faq summary::-webkit-details-marker { display:none; }
.cp-faq summary::after {
  content:""; width:32px; height:32px; flex:none;
  background:var(--lav-soft); color:var(--lav); border-radius:50%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%236c4ff5' stroke-width='2' stroke-linecap='round'><path d='M3 7h8M7 3v8'/></svg>");
  background-repeat:no-repeat; background-position:center;
  transition:transform .25s, background-color .25s;
}
.cp-faq details[open] summary::after { transform:rotate(45deg); background-color:var(--lav); background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round'><path d='M3 7h8M7 3v8'/></svg>"); }
.cp-faq p { margin-top:14px; font-size:15px; color:var(--ink-2); line-height:1.7; }

/* ── FINAL CTA ────────────────────────────────────────────── */
.cp-cta {
  padding:120px 0; text-align:center;
  background:linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  position:relative; overflow:hidden;
}
.cp-cta::before, .cp-cta::after {
  content:""; position:absolute; border-radius:50%;
  pointer-events:none;
}
.cp-cta::before { top:10%; left:-80px; width:200px; height:200px; background:var(--lav-soft); opacity:.6; }
.cp-cta::after { bottom:5%; right:-80px; width:240px; height:240px; background:var(--coral); opacity:.25; }
.cp-cta__in { position:relative; z-index:2; }
.cp-cta h2 { font-size:clamp(2.4rem, 5vw, 4.4rem); margin:18px auto 22px; max-width:14em; }
.cp-cta p { font-size:17px; color:var(--ink-2); max-width:36em; margin:0 auto 30px; }
.cp-cta__row { display:inline-flex; gap:12px; flex-wrap:wrap; justify-content:center; }

/* ── FOOTER ──────────────────────────────────────────────── */
.cp-foot {
  padding:80px 0 30px;
  background:var(--bg-4); color:rgba(255,255,255,.7);
}
.cp-foot .cp-shell { color:rgba(255,255,255,.7); }
.cp-foot__top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr 1fr; gap:36px;
  padding-bottom:54px;
}
.cp-foot__brand .cp-logo__word { color:#fff; }
.cp-foot__brand .cp-logo__mark { background:#fff; }
.cp-foot__brand .cp-logo__mark::before { border-color:var(--lav); }
.cp-foot__brand .cp-logo__mark::after { background:var(--coral); }
.cp-foot__blurb { font-size:13.5px; color:rgba(255,255,255,.6); max-width:24em; line-height:1.6; margin:18px 0; }
.cp-foot__sub {
  display:flex; gap:8px; max-width:24em;
}
.cp-foot__sub input {
  flex:1; height:42px; padding:0 16px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16);
  border-radius:999px; color:#fff; font-size:13.5px; outline:none;
}
.cp-foot__sub input::placeholder { color:rgba(255,255,255,.4); }
.cp-foot__sub input:focus { border-color:var(--coral); }
.cp-foot__sub button {
  height:42px; padding:0 18px;
  background:var(--coral); color:var(--ink); border-radius:999px;
  font-size:13.5px; font-weight:600;
}
.cp-foot__col h4 { color:#fff; font-size:13px; font-weight:600; margin-bottom:16px; }
.cp-foot__col a {
  display:block; font-size:13.5px; color:rgba(255,255,255,.6); padding:6px 0; transition:color .2s;
}
.cp-foot__col a:hover { color:var(--coral); }
.cp-foot__base {
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
  padding-top:28px; border-top:1px solid rgba(255,255,255,.10);
  font-size:12.5px; color:rgba(255,255,255,.5);
}
.cp-foot__base a { color:rgba(255,255,255,.7); }
.cp-foot__base a:hover { color:var(--coral); }
.cp-foot__big {
  font-family:var(--disp); font-weight:700;
  font-size:clamp(5rem, 16vw, 13rem); line-height:.9; letter-spacing:-.05em;
  color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.18);
  text-align:center; padding:14px 0; user-select:none;
}

/* ── INNER PAGES (signin/contact/legal) ──────────────────── */
.cp-phead { padding:90px 0 40px; }
.cp-phead__in { max-width:54em; margin:0 auto; text-align:center; }
.cp-phead h1 { font-size:clamp(2.4rem, 5.4vw, 4rem); margin:18px 0 18px; }
.cp-phead p { font-size:16.5px; color:var(--ink-2); max-width:32em; margin:0 auto; }

.cp-field { margin-top:18px; }
.cp-field:first-child { margin-top:0; }
.cp-label-row { display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.cp-label { display:block; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:8px; }
.cp-input, .cp-textarea, .cp-select {
  width:100%; font-family:var(--sans); font-size:14.5px; color:var(--ink);
  background:var(--surface); border:1px solid var(--line-2); border-radius:14px; outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.cp-input, .cp-select { height:50px; padding:0 16px; }
.cp-textarea { min-height:130px; padding:13px 16px; resize:vertical; line-height:1.6; }
.cp-input::placeholder, .cp-textarea::placeholder { color:var(--ink-3); }
.cp-input:focus, .cp-textarea:focus, .cp-select:focus { border-color:var(--lav); box-shadow:0 0 0 4px rgba(108,79,245,.12); }
.cp-select {
  appearance:none; cursor:pointer; padding-right:42px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%238a809e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 5 7 9 11 5'/></svg>");
  background-repeat:no-repeat; background-position:right 16px center;
}
.cp-input-wrap { position:relative; }
.cp-input-wrap .cp-input { padding-right:46px; }
.cp-eye { position:absolute; right:6px; top:50%; transform:translateY(-50%); width:38px; height:38px; display:flex; align-items:center; justify-content:center; color:var(--ink-3); border-radius:10px; transition:color .2s, background .2s; }
.cp-eye:hover { color:var(--lav); background:var(--lav-soft); }
.cp-eye svg { width:17px; height:17px; }
.cp-field-error { display:none; margin-top:7px; font-size:12.5px; color:var(--coral-dk); }
.cp-field.is-invalid .cp-input, .cp-field.is-invalid .cp-textarea { border-color:var(--coral); }
.cp-field.is-invalid .cp-field-error { display:block; }
.cp-forgot { font-size:12.5px; color:var(--lav); font-weight:500; }
.cp-forgot:hover { text-decoration:underline; }
.cp-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cp-check { display:flex; align-items:center; gap:11px; margin-top:18px; cursor:pointer; font-size:14px; color:var(--ink-2); }
.cp-check input { position:absolute; opacity:0; width:0; height:0; }
.cp-check__box { flex:none; width:20px; height:20px; border:1.6px solid var(--line-2); border-radius:6px; background:var(--surface); display:flex; align-items:center; justify-content:center; color:#fff; }
.cp-check__box svg { width:12px; height:12px; opacity:0; }
.cp-check input:checked + .cp-check__box { background:var(--lav); border-color:var(--lav); }
.cp-check input:checked + .cp-check__box svg { opacity:1; }
.cp-alert { display:none; align-items:center; gap:10px; margin-top:18px; padding:13px 16px; background:#ffece4; border:1px solid var(--coral); border-radius:14px; font-size:13.5px; color:var(--coral-dk); }
.cp-alert.is-on { display:flex; }
.cp-alert svg { width:16px; height:16px; flex:none; }
.cp-spin { display:none; width:18px; height:18px; border-radius:999px; border:2.2px solid rgba(255,255,255,.4); border-top-color:#fff; animation:cp-sp .6s linear infinite; }
.cp-btn.is-loading .cp-btn-label { display:none; }
.cp-btn.is-loading .cp-spin { display:block; }
.cp-btn.is-loading { pointer-events:none; }
@keyframes cp-sp { to { transform:rotate(360deg); } }
.cp-divider { display:flex; align-items:center; gap:14px; margin:22px 0; color:var(--ink-3); }
.cp-divider::before, .cp-divider::after { content:""; flex:1; height:1px; background:var(--line); }
.cp-divider span { font-size:11.5px; font-weight:500; letter-spacing:.06em; text-transform:uppercase; }
.cp-oauth { display:flex; flex-direction:column; gap:10px; }
.cp-oauth__btn {
  display:flex; align-items:center; justify-content:center; gap:10px; height:48px;
  border:1px solid var(--line-2); border-radius:14px;
  font-size:13.5px; color:var(--ink); background:var(--surface);
  transition:border-color .2s, background .2s;
}
.cp-oauth__btn:hover { border-color:var(--lav); background:var(--lav-soft); }

.cp-auth { padding:60px 0 100px; }
.cp-auth__wrap { width:100%; max-width:460px; margin:0 auto; }
.cp-authcard { background:var(--surface); border-radius:24px; padding:42px 38px 32px; box-shadow:var(--shadow); }
.cp-auth__h { font-size:2.2rem; margin-top:10px; }
.cp-auth__h em { font-style:normal; color:transparent; background:linear-gradient(120deg, var(--lav), var(--coral)); -webkit-background-clip:text; background-clip:text; }
.cp-auth__sub { margin:12px 0 26px; font-size:14.5px; color:var(--ink-2); }
.cp-auth__submit { margin-top:22px; }
.cp-auth__foot { margin-top:22px; text-align:center; font-size:13.5px; color:var(--ink-2); }
.cp-auth__foot a { color:var(--lav); font-weight:500; }
.cp-auth__foot a:hover { text-decoration:underline; }
.cp-auth__trust { display:flex; align-items:center; justify-content:center; gap:8px; margin-top:22px; font-size:11.5px; color:var(--ink-3); }
.cp-auth__trust svg { width:13px; height:13px; color:var(--mint); }
.cp-authdone { text-align:center; padding:6px 0; }
.cp-success { width:64px; height:64px; margin:0 auto 20px; border-radius:50%; background:var(--mint); color:#fff; display:flex; align-items:center; justify-content:center; }
.cp-success svg { width:28px; height:28px; }

.cp-modal { position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:24px; }
.cp-modal[hidden] { display:none; }
.cp-modal__scrim { position:absolute; inset:0; background:rgba(26,20,36,.5); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.cp-modal__card { position:relative; width:100%; max-width:440px; background:var(--surface); border-radius:24px; padding:42px 36px; text-align:center; box-shadow:var(--shadow-lg); }
.cp-modal__x { position:absolute; top:14px; right:14px; width:36px; height:36px; display:flex; align-items:center; justify-content:center; color:var(--ink-3); border-radius:50%; transition:color .2s, background .2s; }
.cp-modal__x:hover { color:var(--ink); background:var(--bg); }
.cp-modal__x svg { width:16px; height:16px; }
.cp-modal__h { font-size:1.8rem; }
.cp-modal__h em { font-style:normal; color:var(--lav); }
.cp-modal__p { margin:10px 0 4px; font-size:14.5px; color:var(--ink-2); line-height:1.6; }
.cp-modal .cp-btn { margin-top:22px; }

.cp-contact { padding:30px 0 100px; }
.cp-contact__in { display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:start; }
.cp-contact__form { background:var(--surface); border-radius:24px; padding:38px; box-shadow:var(--shadow-sm); }
.cp-contact__aside { display:flex; flex-direction:column; gap:14px; }
.cp-info {
  border-radius:18px; padding:24px; background:var(--surface); box-shadow:var(--shadow-sm);
}
.cp-info--lav { background:var(--lav); color:#fff; }
.cp-info--lav h3 { color:#fff; }
.cp-info--lav p { color:rgba(255,255,255,.85); }
.cp-info--lav a { color:#fff; }
.cp-info--coral { background:var(--coral); color:var(--ink); }
.cp-info svg { width:24px; height:24px; margin-bottom:12px; color:var(--lav); }
.cp-info--lav svg, .cp-info--coral svg { color:currentColor; }
.cp-info h3 { font-size:1.2rem; margin-bottom:6px; }
.cp-info p { font-size:13.5px; color:var(--ink-2); line-height:1.55; }
.cp-info a { color:var(--lav); font-weight:500; }

.cp-legal { padding:30px 0 100px; }
.cp-legal__in { max-width:760px; margin:0 auto; }
.cp-legal h1 { font-size:clamp(2rem, 4vw, 3rem); margin-top:14px; }
.cp-legal h1 em { font-style:normal; color:var(--lav); }
.cp-legal__meta { margin-top:14px; font-size:13px; color:var(--ink-3); }
.cp-legal__toc { margin-top:32px; padding:24px 28px; background:var(--surface); border-radius:18px; box-shadow:var(--shadow-sm); }
.cp-legal__toc h4 { font-size:12px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px; font-weight:600; }
.cp-legal__toc ol { padding-left:22px; }
.cp-legal__toc li { font-size:14px; margin:6px 0; color:var(--ink-2); }
.cp-legal__toc a { transition:color .2s; }
.cp-legal__toc a:hover { color:var(--lav); }
.cp-legal__body { margin-top:36px; }
.cp-legal__body h2 { font-size:1.5rem; margin:34px 0 12px; scroll-margin-top:100px; }
.cp-legal__body h2:first-child { margin-top:0; }
.cp-legal__body p { margin:11px 0; font-size:15px; color:var(--ink-2); line-height:1.7; }
.cp-legal__body ul { margin:12px 0; padding-left:0; }
.cp-legal__body li { position:relative; padding-left:22px; margin:8px 0; font-size:15px; color:var(--ink-2); list-style:none; line-height:1.7; }
.cp-legal__body li::before { content:""; position:absolute; left:0; top:9px; width:8px; height:8px; border-radius:50%; background:var(--lav); }
.cp-legal__body a { color:var(--lav); }
.cp-legal__body strong { color:var(--ink); font-weight:600; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width:1080px){
  .cp-features { grid-template-columns:1fr 1fr; }
  .cp-feat--lg { grid-column:span 2; }
  .cp-how { grid-template-columns:1fr 1fr; }
  .cp-integrations { grid-template-columns:repeat(4,1fr); }
  .cp-quotes { grid-template-columns:1fr 1fr; }
  .cp-foot__top { grid-template-columns:1fr 1fr 1fr; gap:28px; }
  .cp-foot__brand { grid-column:1 / -1; }
}
@media (max-width:860px){
  .cp-nav, .cp-head__act .cp-btn, .cp-head__act .cp-login, .cp-head__act .cp-lang { display:none; }
  .cp-burger { display:flex; }
  .cp-problem, .cp-features, .cp-tiers, .cp-stats, .cp-quotes, .cp-cases { grid-template-columns:1fr 1fr; }
  .cp-feat--lg { grid-column:span 1; }
  .cp-split, .cp-contact__in { grid-template-columns:1fr; gap:36px; }
  .cp-sec { padding:80px 0; }
  .cpm { grid-template-columns:1fr; }
}
@media (max-width:580px){
  .cp-shell { padding:0 18px; }
  .cp-sec { padding:60px 0; }
  .cp-hero { padding:60px 0 50px; }
  .cp-hero__mock { margin-top:46px; }
  .cp-problem, .cp-features, .cp-tiers, .cp-stats, .cp-quotes, .cp-cases, .cp-how { grid-template-columns:1fr; }
  .cp-integrations { grid-template-columns:repeat(3,1fr); }
  .cp-foot__top { grid-template-columns:1fr; }
  .cp-head { top:10px; margin-top:10px; padding:0 12px; }
  .cp-head__bar { padding:5px 5px 5px 16px; gap:8px; height:54px; }
  .cp-logo__word { font-size:17px; }
  .cp-row { grid-template-columns:1fr; }
  .cp-trust__row { padding:14px 18px; gap:14px 22px; justify-content:flex-start; }
  .cp-tier__price { font-size:2.6rem; }
  .cp-foot__big { font-size:3.4rem; }
  .cp-faq details { padding:18px 22px; }
  .cp-faq summary { font-size:1rem; gap:12px; }
  .cp-faq summary::after { width:28px; height:28px; }
  .cp-case { min-height:240px; padding:28px; }
}

/* ════════════════════════════════════════════════════════════════
   CERCLEPAY — EDITORIAL MASTHEAD · POSTCARD FOOTER
   Totally different from Reparpay's pill-bar / dense column footer
   ════════════════════════════════════════════════════════════════ */

/* ── Masthead header ──────────────────────────────────────── */
.cp-mast {
  position:sticky; top:0; z-index:100;
  background:rgba(250,245,236,.94);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.cp-mast.is-stuck { box-shadow:var(--shadow-sm); }
.cp-mast__ann {
  background:linear-gradient(90deg, var(--lav) 0%, var(--lav-dk) 100%);
  color:#fff;
  padding:9px 0;
  text-align:center;
  font-size:12.5px;
  font-weight:500;
  letter-spacing:-.005em;
}
.cp-mast__ann a {
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.4);
  padding-bottom:1px;
  transition:border-color .2s;
}
.cp-mast__ann a:hover { border-bottom-color:#fff; }
.cp-mast__wrap { position:relative; }
.cp-mast__row {
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:22px 0 18px;
  gap:24px;
}
.cp-mast__side-l { display:flex; align-items:center; gap:18px; justify-self:start; }
.cp-mast__side-r { display:flex; align-items:center; gap:10px; justify-self:end; }
.cp-mast__brand {
  display:inline-flex; align-items:center; gap:12px; justify-self:center;
}
.cp-mast__brand .cp-logo__mark {
  width:34px; height:34px;
}
.cp-mast__word {
  font-family:var(--disp); font-weight:700;
  font-size:30px; letter-spacing:-.03em; color:var(--ink);
  display:inline-flex; align-items:baseline; gap:0;
}
.cp-mast__word i { font-style:normal; color:var(--coral); }
.cp-mast__nav {
  display:flex; align-items:center; justify-content:center; gap:16px;
  padding:14px 0 18px;
  border-top:1px solid var(--line);
  font-size:14px;
  font-weight:500;
  flex-wrap:wrap;
}
.cp-mast__nav a {
  color:var(--ink-2); padding:4px 0;
  border-bottom:1px solid transparent;
  transition:color .2s, border-color .2s;
  letter-spacing:-.01em;
}
.cp-mast__nav a:hover { color:var(--lav); border-bottom-color:var(--lav); }
.cp-mast__nav em {
  font-style:normal; color:var(--ink-3); font-size:13px;
}
.cp-mast .cp-login {
  font-size:14px; font-weight:500; color:var(--ink-2);
  transition:color .2s;
}
.cp-mast .cp-login:hover { color:var(--ink); }
.cp-mast .cp-lang__btn {
  background:transparent; border-color:var(--line);
  padding:6px 11px; font-size:12.5px;
}
.cp-mast .cp-lang__btn:hover { border-color:var(--line-2); color:var(--ink); }

@media (max-width:860px){
  .cp-mast__nav { display:none; }
  .cp-mast__row {
    grid-template-columns:auto 1fr auto;
    padding:14px 0;
    gap:12px;
  }
  .cp-mast__side-l .cp-login { display:none; }
  .cp-mast__side-l { gap:8px; }
  .cp-mast__brand { gap:8px; }
  .cp-mast__word { font-size:22px; }
  .cp-mast__brand .cp-logo__mark { width:28px; height:28px; }
  .cp-mast__side-r .cp-btn--sm { display:none; }
  .cp-mast__ann { font-size:11px; padding:7px 18px; }
  .cp-mast__ann a {
    display:inline-block; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  }
}
@media (max-width:480px){
  .cp-mast__side-l .cp-lang { display:none; }
}

/* ── Postcard footer ──────────────────────────────────────── */
.cp-letter {
  background:var(--bg);
  padding:90px 0 50px;
  position:relative;
  overflow:hidden;
}
.cp-letter::before, .cp-letter::after {
  content:""; position:absolute; border-radius:50%; pointer-events:none;
}
.cp-letter::before { top:60px; right:-100px; width:240px; height:240px; background:var(--bg-2); opacity:.45; }
.cp-letter::after { bottom:80px; left:-110px; width:200px; height:200px; background:var(--lav-soft); opacity:.55; }

.cp-letter__card {
  position:relative; z-index:2;
  background:var(--surface);
  border-radius:32px;
  padding:60px 60px 50px;
  box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column; gap:0;
}
.cp-letter__top {
  display:flex; flex-direction:column; align-items:flex-start; gap:12px;
  padding-bottom:50px; border-bottom:1px dashed var(--line-2);
  margin-bottom:50px;
}
.cp-letter__stamp {
  font-family:var(--mono); font-size:11.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-3);
  padding:6px 14px; border:1.5px dashed var(--line-2); border-radius:999px;
}
.cp-letter__h {
  font-family:var(--disp); font-weight:700;
  font-size:clamp(2.4rem, 5vw, 4.2rem); line-height:1; letter-spacing:-.03em;
  margin-top:14px; max-width:14em;
}
.cp-letter__h em {
  font-style:normal;
  background:linear-gradient(120deg, var(--lav) 0%, var(--coral) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.cp-letter__p {
  margin-top:14px; max-width:36em;
  font-size:16.5px; color:var(--ink-2); line-height:1.6;
}
.cp-letter__cta { display:flex; gap:12px; flex-wrap:wrap; margin-top:30px; }

.cp-letter__cards {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:24px;
  padding-bottom:48px; border-bottom:1px dashed var(--line-2);
  margin-bottom:48px;
}
.cp-letter__card-i {
  display:flex; flex-direction:column; gap:8px;
  padding:24px 22px;
  background:var(--bg);
  border-radius:18px;
}
.cp-letter__lbl {
  font-family:var(--mono); font-size:10.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-3); font-weight:500;
}
.cp-letter__card-i a {
  font-family:var(--disp); font-weight:700; font-size:1.15rem;
  letter-spacing:-.015em; color:var(--ink);
  transition:color .2s;
}
.cp-letter__card-i a:hover { color:var(--lav); }
.cp-letter__card-i p {
  font-size:13.5px; color:var(--ink-2); line-height:1.55; margin-top:2px;
}
.cp-letter__kvk {
  margin-top:8px;
  font-family:var(--mono); font-size:11px; color:var(--ink-3);
  letter-spacing:.04em;
}

.cp-letter__sitemap {
  display:grid; grid-template-columns:repeat(3, 1fr) 1.4fr;
  gap:36px;
  padding-bottom:38px;
  border-bottom:1px dashed var(--line-2);
  margin-bottom:30px;
}
.cp-letter__sm-col h4 {
  font-family:var(--sans); font-size:12.5px; font-weight:700;
  color:var(--ink); margin-bottom:14px; letter-spacing:-.005em;
}
.cp-letter__sm-col a {
  display:block; font-size:13.5px; color:var(--ink-2);
  padding:5px 0; transition:color .2s;
}
.cp-letter__sm-col a:hover { color:var(--lav); }
.cp-letter__news h4 {
  font-family:var(--sans); font-size:13px; font-weight:700; color:var(--ink); margin-bottom:8px;
}
.cp-letter__news p {
  font-size:13px; color:var(--ink-2); margin-bottom:14px; line-height:1.5; max-width:22em;
}
.cp-letter__news-row { display:flex; gap:8px; max-width:24em; }
.cp-letter__news-row input {
  flex:1; height:44px; padding:0 16px;
  border:1px solid var(--line-2); border-radius:999px; background:var(--surface);
  font-size:13.5px; color:var(--ink); outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.cp-letter__news-row input::placeholder { color:var(--ink-3); }
.cp-letter__news-row input:focus { border-color:var(--lav); box-shadow:0 0 0 4px rgba(108,79,245,.12); }
.cp-letter__news-row button {
  height:44px; padding:0 18px;
  background:var(--ink); color:#fff; border-radius:999px;
  font-size:13px; font-weight:600;
  transition:background .2s;
}
.cp-letter__news-row button:hover { background:var(--lav); }

.cp-letter__base {
  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11.5px; color:var(--ink-3); letter-spacing:.02em;
}
.cp-letter__base .cp-lang__btn { background:var(--surface); }

/* ── postmark ticker (replaces giant outlined wordmark) ── */
.cp-letter__strip {
  margin-top:38px; padding:14px 0;
  border-top:1px dashed var(--line-2); border-bottom:1px dashed var(--line-2);
  overflow:hidden; position:relative; z-index:2;
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-image:linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}
.cp-letter__strip-row {
  display:flex; align-items:center; gap:28px;
  width:max-content;
  animation:cp-marq 38s linear infinite;
}
.cp-letter__stamp-w {
  display:inline-flex; align-items:baseline; gap:2px;
  font-family:var(--disp); font-weight:700; font-size:22px;
  letter-spacing:-.02em; color:var(--ink);
  flex:none;
}
.cp-letter__stamp-w i { font-style:normal; color:var(--coral); }
.cp-letter__stamp-w:nth-child(3n+2) { color:var(--coral); }
.cp-letter__stamp-w:nth-child(3n+2) i { color:var(--lav); }
.cp-letter__stamp-w:nth-child(3n+3) { color:var(--lav); }
.cp-letter__stamp-w:nth-child(3n+3) i { color:var(--ink); }
.cp-letter__strip-row .cp-letter__dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--coral); flex:none; opacity:.6;
}
.cp-letter__strip-row .cp-letter__dot:nth-child(6n) { background:var(--lav); }
.cp-letter__strip-row .cp-letter__dot:nth-child(6n+3) { background:var(--ink); opacity:.35; }
@keyframes cp-marq { to { transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .cp-letter__strip-row { animation:none; } }
@media (max-width:760px){
  .cp-letter__stamp-w { font-size:18px; }
  .cp-letter__strip-row { gap:20px; }
  .cp-letter__strip { margin-top:28px; }
}

@media (max-width:1080px){
  .cp-letter__cards { grid-template-columns:1fr 1fr; }
  .cp-letter__sitemap { grid-template-columns:1fr 1fr; gap:30px 28px; }
  .cp-letter__news { grid-column:1 / -1; }
}
@media (max-width:760px){
  .cp-letter { padding:60px 0 30px; }
  .cp-letter__card { padding:36px 26px 30px; border-radius:24px; }
  .cp-letter__top { padding-bottom:32px; margin-bottom:32px; }
  .cp-letter__h { font-size:clamp(2rem, 8vw, 2.6rem); }
  .cp-letter__cards { grid-template-columns:1fr; gap:14px; padding-bottom:30px; margin-bottom:30px; }
  .cp-letter__card-i { padding:18px 20px; }
  .cp-letter__sitemap { grid-template-columns:1fr 1fr; gap:24px; padding-bottom:26px; margin-bottom:24px; }
  .cp-letter__news { grid-column:1 / -1; }
  .cp-letter__big { font-size:clamp(2.6rem, 16vw, 4rem); padding-top:30px; }
  .cp-letter__base { font-size:10.5px; }
}
@media (max-width:480px){
  .cp-letter__sitemap { grid-template-columns:1fr; }
  .cp-letter__cta { flex-direction:column; }
  .cp-letter__cta .cp-btn { width:100%; }
}
