/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("0150de25-d6fb-42e5-9a16-abb9f6af7aae.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("cd0307ff-6dc5-46cb-bf91-bf892407d2c2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("9041f523-a05c-4c6b-adef-fedb1b2b3e96.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("0150de25-d6fb-42e5-9a16-abb9f6af7aae.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("cd0307ff-6dc5-46cb-bf91-bf892407d2c2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("9041f523-a05c-4c6b-adef-fedb1b2b3e96.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("0150de25-d6fb-42e5-9a16-abb9f6af7aae.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("cd0307ff-6dc5-46cb-bf91-bf892407d2c2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("9041f523-a05c-4c6b-adef-fedb1b2b3e96.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("0150de25-d6fb-42e5-9a16-abb9f6af7aae.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("cd0307ff-6dc5-46cb-bf91-bf892407d2c2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("9041f523-a05c-4c6b-adef-fedb1b2b3e96.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("12f008a6-525b-4a92-97a6-7c11cf9ed3a7.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("15c6f11b-ed8b-48ec-a0b6-e3efef2fc673.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("ac96e31b-5751-4cbc-8c27-f81e8f5e9ad6.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("274f0519-0e1b-4d4c-9deb-dff2eb8a8244.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("2588263e-17d6-4489-990c-1b21ba083a5f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("0c208c80-9f1f-4b48-80b4-681d0f292370.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("1b5186dc-0e10-483e-9d0a-3973296f9ae3.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("d9faa7ec-da97-4922-867a-8ce6f2adef82.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("081afb25-00cb-4bc2-b83d-d39a5475cdc0.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("27fb4981-35a4-4b75-b19c-ed968ca43bde.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("2588263e-17d6-4489-990c-1b21ba083a5f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("0c208c80-9f1f-4b48-80b4-681d0f292370.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("1b5186dc-0e10-483e-9d0a-3973296f9ae3.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("d9faa7ec-da97-4922-867a-8ce6f2adef82.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("081afb25-00cb-4bc2-b83d-d39a5475cdc0.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("27fb4981-35a4-4b75-b19c-ed968ca43bde.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("2588263e-17d6-4489-990c-1b21ba083a5f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("0c208c80-9f1f-4b48-80b4-681d0f292370.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("1b5186dc-0e10-483e-9d0a-3973296f9ae3.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("d9faa7ec-da97-4922-867a-8ce6f2adef82.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("081afb25-00cb-4bc2-b83d-d39a5475cdc0.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("27fb4981-35a4-4b75-b19c-ed968ca43bde.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("2588263e-17d6-4489-990c-1b21ba083a5f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("0c208c80-9f1f-4b48-80b4-681d0f292370.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("1b5186dc-0e10-483e-9d0a-3973296f9ae3.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("d9faa7ec-da97-4922-867a-8ce6f2adef82.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("081afb25-00cb-4bc2-b83d-d39a5475cdc0.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("27fb4981-35a4-4b75-b19c-ed968ca43bde.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ---- next block ---- */

/* =========================================================================
   Clai Landing — page-scoped styles. Sits on top of design tokens.
   Aesthetic: cream paper hero w/ ink-green accents, dark "engine room"
   processing band, return to cream for resolution + cta. Mono labels,
   serif italic punches, geist body. Echoes Onboarding + Upload Processing.
   ========================================================================= */

html { scroll-behavior: auto; scroll-padding-top: 96px; }

:root {
  --paper:        #F6F4EE;
  --paper-2:      #FBFAF6;
  --paper-3:      #ECE7DA;
  --ink:          #17201C;
  --ink-2:        #2C342F;
  --ink-mute:     #5E6B64;
  --ink-dim:      #8E978F;
  --hair:         rgba(20,30,25,0.10);
  --hair-2:       rgba(20,30,25,0.18);
  --hair-soft:    rgba(20,30,25,0.06);
  --green:        #2F8F5E;
  --green-deep:   #1E6B43;
  --green-soft:   rgba(47,143,94,0.10);
  --green-tile:   rgba(68,186,130,0.18);
  --amber:        #E5B64A;
  --amber-soft:   rgba(229,182,74,0.20);
  --peach:        #E5694A;
  --peach-soft:   rgba(229,105,74,0.14);
  --sky:          #6DA8E5;
  --sky-soft:     rgba(109,168,229,0.16);
  --lilac:        #A891E3;
  --lilac-soft:   rgba(168,145,227,0.18);
  --citrus:       #B8B83A;
  --rose:         #D58FA0;

  /* Engine room (dark band) */
  --engine-bg:        #0E1110;
  --engine-bg-2:      #141818;
  --engine-surface:   rgba(255,255,255,0.05);
  --engine-surface-2: rgba(255,255,255,0.08);
  --engine-border:    rgba(255,255,255,0.10);
  --engine-text:      #ECEFED;
  --engine-mute:      #9BA39F;

  --font-sans:  "Geist", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --font-serif: "Instrument Serif", ui-serif, Georgia, serif;

  --max-w: 1280px;
  --gutter: clamp(20px, 4vw, 56px);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: var(--paper); }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01","cv11";
  overflow-x: hidden;
}
::selection { background: rgba(68,186,130,0.30); color: var(--ink); }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
em { font-style: italic; font-family: var(--font-serif); font-weight: 400; letter-spacing: -0.01em; }

/* ============ Type / shared utilities ============ */
.eyebrow {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green-deep);
  display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 0 4px rgba(47,143,94,0.12);
}
.eyebrow--ink { color: var(--ink-mute); }
.eyebrow--ink::before { background: var(--ink); box-shadow: 0 0 0 4px rgba(20,30,25,0.06); }
.eyebrow--paper { color: rgba(255,255,255,0.7); }
.eyebrow--paper::before { background: var(--clai-green-300, #7FDCA7); box-shadow: 0 0 0 4px rgba(127,220,167,0.14); }

.serif { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
.mono  { font-family: var(--font-mono); }

.hairline { height: 1px; background: var(--hair); border: 0; }

/* ============ Page chrome ============ */
.page { width: 100%; }

.shell {
  max-width: var(--max-w);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

/* ============ Top nav ============ */
.nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  background: rgba(246,244,238,0.7);
  border-bottom: 1px solid transparent;
  transition: background 200ms ease, border-color 200ms ease;
}
.nav.is-stuck {
  background: rgba(246,244,238,0.92);
  border-bottom-color: var(--hair);
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.nav__logo {
  display: flex; align-items: center; gap: 10px;
  color: var(--ink);
}
.nav__logo svg { width: 24px; height: 24px; color: var(--ink); }
.nav__logo b { font-weight: 600; letter-spacing: -0.01em; font-size: 18px; }
.nav__logo .tag {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
  padding: 3px 7px; border: 1px solid var(--hair); border-radius: 4px;
  margin-left: 4px;
}
.nav__links { display: flex; align-items: center; gap: 28px; }
.nav__links a {
  font-size: 14px; color: var(--ink-mute);
  transition: color 160ms ease;
}
.nav__links a:hover { color: var(--ink); }
.nav__cta {
  display: inline-flex; align-items: center; gap: 8px;
  height: 38px; padding: 0 16px;
  background: var(--ink); color: var(--paper);
  border-radius: 999px; border: 0;
  font-size: 14px; font-weight: 500; letter-spacing: -0.005em;
  transition: transform 160ms ease, background 160ms ease;
}
.nav__cta:hover { background: var(--green-deep); transform: translateY(-1px); }
.nav__cta svg { width: 14px; height: 14px; }
@media (max-width: 880px) {
  .nav__links { display: none; }
}

/* ============ HERO ============ */
.hero {
  position: relative;
  padding: clamp(48px, 7vw, 96px) 0 clamp(60px, 6vw, 88px);
  overflow: hidden;
}
.hero__glow {
  position: absolute; inset: -120px -10% auto -10%; height: 720px;
  background:
    radial-gradient(620px 320px at 78% 18%, rgba(68,186,130,0.16), transparent 70%),
    radial-gradient(520px 280px at 12% 70%, rgba(229,182,74,0.18), transparent 70%);
  pointer-events: none; z-index: 0;
}
.hero__inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
}
@media (max-width: 980px) { .hero__inner { grid-template-columns: 1fr; } }

.hero__l { display: flex; flex-direction: column; gap: 24px; max-width: 640px; }
.hero__pill {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 12px 6px 8px;
  border-radius: 999px;
  border: 1px solid var(--hair-2);
  background: rgba(255,255,255,0.55);
  font: 500 12px/1 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.hero__pill .nub {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--green); color: white;
  display: inline-grid; place-items: center;
  font-size: 10px;
}
.hero__pill .nub svg { width: 10px; height: 10px; }
.hero__pill em { font-style: normal; color: var(--ink); }

.hero__h1 {
  font-family: var(--font-sans);
  font-size: clamp(36px, 5.6vw, 76px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 500;
  margin: 0;
  text-wrap: balance;
}
.hero__h1-emph {
  display: inline-block;
  margin-top: 0.05em;
  background: linear-gradient(180deg, var(--ink) 0%, var(--green-deep) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink);
}
.hero__h1 .swap {
  display: inline-block;
  position: relative;
  vertical-align: baseline;
  color: var(--green-deep);
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  border-bottom: 2px solid rgba(47,143,94,0.32);
  padding: 0 4px;
  min-width: 5ch;
}
.hero__h1 .swap-word {
  display: inline-block;
  animation: swapIn 360ms cubic-bezier(0.22,1,0.36,1) both;
}
@keyframes swapIn {
  from { opacity: 0; transform: translateY(8px); filter: blur(2px); }
  to   { opacity: 1; transform: none; filter: none; }
}

.hero__lede {
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.55; color: var(--ink-mute);
  max-width: 56ch;
  margin: 0;
  text-wrap: pretty;
}
.hero__lede b { color: var(--ink); font-weight: 500; }

.hero__cta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 8px; }
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 0 22px; height: 52px;
  border-radius: 999px; border: 0;
  font-size: 15px; font-weight: 500; letter-spacing: -0.005em;
  transition: transform 200ms cubic-bezier(0.22,1,0.36,1),
              box-shadow 220ms ease, background 200ms ease;
}
.btn--primary {
  background: var(--ink); color: white;
  box-shadow: 0 10px 28px rgba(20,30,25,0.18), inset 0 1px 0 rgba(255,255,255,0.08);
}
.btn--primary:hover { transform: translateY(-2px); background: var(--green-deep); box-shadow: 0 14px 32px rgba(30,107,67,0.32); }
.btn--ghost {
  background: transparent; color: var(--ink);
  border: 1px solid var(--hair-2);
}
.btn--ghost:hover { background: rgba(20,30,25,0.04); border-color: var(--ink); }
.btn svg { width: 16px; height: 16px; }
.btn--green {
  background: var(--green); color: white;
  box-shadow: 0 12px 30px rgba(47,143,94,0.32);
}
.btn--green:hover { background: var(--green-deep); transform: translateY(-2px); }

.hero__trust {
  display: flex; align-items: center; gap: 18px;
  margin-top: 16px;
  font: 500 12px/1 var(--font-mono);
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.hero__trust .dot { color: var(--ink-dim); }
.hero__trust b { color: var(--ink); font-weight: 500; }

/* Right side: live-ghost-PDF + orbit */
.hero__r { position: relative; min-height: 540px; height: 100%; }

/* ============ Pipeline ribbon (between hero + processing) ============ */
.ribbon {
  display: flex; align-items: center; gap: 20px;
  padding: 22px 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  overflow: hidden;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.ribbon__track {
  display: flex; gap: 56px; align-items: center;
  animation: ribbonScroll 36s linear infinite;
  white-space: nowrap;
}
.ribbon__dot { width: 4px; height: 4px; border-radius: 50%; background: var(--ink-dim); flex: none; }
.ribbon__cell { display: inline-flex; align-items: center; gap: 14px; }
@keyframes ribbonScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============ Section scaffolding ============ */
.section { position: relative; padding: clamp(96px, 11vw, 168px) 0; }
.section__hd {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: end;
  margin-bottom: 72px;
}
@media (max-width: 880px) { .section__hd { grid-template-columns: 1fr; } }
.section__title {
  font-size: clamp(32px, 4.2vw, 56px);
  line-height: 1.0;
  letter-spacing: -0.03em;
  font-weight: 500;
  margin: 12px 0 0;
  text-wrap: balance;
}
.section__title em {
  font-family: var(--font-serif); font-style: italic; font-weight: 400;
}
.section__sub {
  font-size: 17px; line-height: 1.55;
  color: var(--ink-mute); margin: 0;
  max-width: 50ch;
  text-wrap: pretty;
}

/* ============ Processing band (dark) ============ */
.engine {
  background: var(--engine-bg);
  color: var(--engine-text);
  position: relative;
  overflow: hidden;
}
.engine::before {
  content: ""; position: absolute; inset: -1px 0 auto 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(127,220,167,0.4), transparent);
}
.engine .section__title { color: var(--engine-text); }
.engine .section__sub { color: var(--engine-mute); }
.engine__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(900px 540px at 80% 10%, rgba(68,186,130,0.10), transparent 60%),
    radial-gradient(700px 460px at 10% 80%, rgba(109,168,229,0.06), transparent 60%);
  pointer-events: none;
}
.engine .shell { position: relative; }

/* ============ Capability grid (cards) ============ */
.caps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 980px) { .caps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .caps { grid-template-columns: 1fr; } }

.cap {
  position: relative;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: 18px;
  padding: 22px 22px 24px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 220px;
  overflow: hidden;
  cursor: default;
  transition: transform 240ms cubic-bezier(0.22,1,0.36,1),
              border-color 240ms ease,
              box-shadow 240ms ease;
}
.cap:hover {
  transform: translateY(-3px);
  border-color: var(--hair-2);
  box-shadow: 0 18px 40px rgba(20,30,25,0.06);
}
.cap__h {
  display: flex; align-items: center; gap: 10px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.cap__icon {
  width: 32px; height: 32px; border-radius: 10px;
  display: grid; place-items: center;
  background: var(--green-tile);
  color: var(--green-deep);
  flex: none;
}
.cap__icon svg { width: 16px; height: 16px; }
.cap[data-tone="amber"]  .cap__icon { background: var(--amber-soft);  color: #8A6513; }
.cap[data-tone="sky"]    .cap__icon { background: var(--sky-soft);    color: #1A5FA0; }
.cap[data-tone="lilac"]  .cap__icon { background: var(--lilac-soft);  color: #5b48a8; }
.cap[data-tone="peach"]  .cap__icon { background: var(--peach-soft);  color: #A8452B; }
.cap[data-tone="ink"]    .cap__icon { background: rgba(20,30,25,0.08);color: var(--ink); }
.cap__t {
  font-family: var(--font-sans);
  font-size: 22px; line-height: 1.15; font-weight: 500;
  letter-spacing: -0.01em; color: var(--ink); margin: 4px 0 0;
}
.cap__t em { font-family: var(--font-serif); font-style: italic; }
.cap__d {
  font-size: 14px; line-height: 1.5; color: var(--ink-mute);
  text-wrap: pretty;
}
.cap__visual {
  margin-top: auto;
  height: 86px; border-radius: 12px;
  border: 1px solid var(--hair);
  background: var(--paper);
  position: relative; overflow: hidden;
}

/* ============ How-it-works walkthrough (3 steps, numbered, paper) ============ */
.flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border: 1px solid var(--hair);
  border-radius: 22px;
  background: var(--paper-2);
  overflow: hidden;
}
.flow__row {
  display: grid;
  grid-template-columns: 60px 1.1fr 1.4fr;
  gap: 32px;
  padding: 36px 36px;
  border-bottom: 1px solid var(--hair);
  align-items: center;
}
.flow__row:last-child { border-bottom: 0; }
@media (max-width: 880px) { .flow__row { grid-template-columns: 1fr; padding: 28px; gap: 18px; } }
.flow__num {
  font-family: var(--font-mono);
  font-size: 28px; font-weight: 500;
  color: var(--green-deep);
  letter-spacing: -0.01em;
}
.flow__copy h3 {
  font-size: 28px; line-height: 1.05; letter-spacing: -0.02em;
  font-weight: 500; margin: 0 0 8px;
}
.flow__copy h3 em { font-family: var(--font-serif); font-style: italic; }
.flow__copy p { font-size: 15px; line-height: 1.55; color: var(--ink-mute); margin: 0; max-width: 38ch; }
.flow__visual {
  height: 200px;
  border-radius: 14px; border: 1px solid var(--hair);
  background: var(--paper);
  position: relative; overflow: hidden;
}

/* ============ Stats / counters ============ */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--hair);
  border-radius: 18px;
  background: var(--paper-2);
  overflow: hidden;
}
@media (max-width: 880px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat { padding: 30px 26px; border-right: 1px solid var(--hair); }
.stat:last-child { border-right: 0; }
@media (max-width: 880px) {
  .stat { border-right: 0; border-bottom: 1px solid var(--hair); }
  .stat:nth-child(2n) { border-right: 0; }
  .stat:last-child { border-bottom: 0; }
}
.stat__k {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}
.stat__k::before {
  content:""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
}
.stat__v {
  font-size: clamp(40px, 4.4vw, 60px);
  line-height: 0.96;
  letter-spacing: -0.035em;
  font-weight: 500;
  color: var(--ink);
  display: flex; align-items: baseline; gap: 4px;
}
.stat__v small { font-size: 0.45em; color: var(--ink-mute); font-weight: 400; }
.stat__d { margin-top: 10px; font-size: 13px; line-height: 1.4; color: var(--ink-mute); max-width: 28ch; }

/* ============ Testimonials ============ */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 980px) { .quotes { grid-template-columns: 1fr; } }
.quote {
  border: 1px solid var(--hair);
  background: var(--paper-2);
  border-radius: 18px;
  padding: 26px 26px 24px;
  display: flex; flex-direction: column; gap: 18px;
}
.quote__t {
  font-size: 19px; line-height: 1.4;
  color: var(--ink); margin: 0;
  text-wrap: pretty; letter-spacing: -0.005em;
}
.quote__t em { font-family: var(--font-serif); font-style: italic; }
.quote__by { display: flex; align-items: center; gap: 12px; }
.quote__av {
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  font: 500 13px/1 var(--font-sans);
  background: var(--green-tile); color: var(--green-deep);
  flex: none;
}
.quote__by .nm { font-weight: 500; font-size: 14px; }
.quote__by .ro { font-size: 12px; color: var(--ink-mute); font-family: var(--font-mono); letter-spacing: 0.06em; }

/* ============ CTA / form ============ */
.cta {
  position: relative;
  padding: clamp(64px, 8vw, 120px) 0 clamp(64px, 8vw, 100px);
  overflow: hidden;
}
.cta__glow {
  position: absolute; inset: -100px -10% auto -10%;
  height: 600px;
  background:
    radial-gradient(640px 360px at 30% 30%, rgba(68,186,130,0.20), transparent 70%),
    radial-gradient(560px 320px at 80% 70%, rgba(229,182,74,0.16), transparent 70%);
  pointer-events: none;
}
.cta__card {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: clamp(28px, 5vw, 72px);
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 28px;
  padding: clamp(28px, 4vw, 56px);
  box-shadow: 0 30px 80px rgba(20,30,25,0.08);
}
@media (max-width: 980px) { .cta__card { grid-template-columns: 1fr; } }
.cta__l { display: flex; flex-direction: column; gap: 18px; }
.cta__l h2 {
  font-size: clamp(32px, 4.2vw, 56px);
  line-height: 0.98; letter-spacing: -0.03em;
  font-weight: 500; margin: 8px 0 0;
}
.cta__l h2 em { font-family: var(--font-serif); font-style: italic; }
.cta__l p { color: var(--ink-mute); margin: 0; max-width: 42ch; }
.cta__bullets { display: flex; flex-direction: column; gap: 10px; margin-top: 6px; }
.cta__bullets li {
  list-style: none; display: flex; align-items: center; gap: 10px;
  font-size: 14px;
}
.cta__bullets li::marker { content: ""; }
.cta__bullets svg { width: 16px; height: 16px; color: var(--green-deep); flex: none; }

.form {
  display: flex; flex-direction: column; gap: 12px;
  background: var(--paper);
  border: 1px solid var(--hair);
  border-radius: 18px;
  padding: 22px;
}
.form__head {
  display: flex; align-items: center; gap: 10px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--green-deep);
  margin-bottom: 4px;
}
.form__head .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--green); position: relative; }
.form__head .pulse::after {
  content:""; position: absolute; inset: -4px;
  border-radius: 50%; border: 2px solid var(--green);
  animation: ringPulse 1.6s ease-out infinite;
}
@keyframes ringPulse {
  0%   { transform: scale(0.6); opacity: 1; }
  100% { transform: scale(1.6); opacity: 0; }
}
.field { display: flex; flex-direction: column; gap: 6px; }
.field label {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
}
.input {
  height: 44px; border-radius: 12px;
  border: 1px solid var(--hair-2);
  padding: 0 14px;
  background: var(--paper-2);
  font: 400 15px/1 var(--font-sans);
  color: var(--ink);
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.input:focus {
  outline: none;
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(47,143,94,0.16);
  background: var(--paper);
}
.field__row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.role-pick { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.role-pick button {
  height: 40px; border-radius: 10px;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  color: var(--ink);
  font: 500 13px/1 var(--font-sans);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  transition: all 160ms ease;
}
.role-pick button:hover { border-color: var(--ink); }
.role-pick button.is-on {
  background: var(--ink); color: white; border-color: var(--ink);
}
.form__submit {
  height: 50px; border-radius: 12px; border: 0;
  background: var(--green); color: white;
  font: 500 15px/1 var(--font-sans);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 6px;
  transition: background 160ms ease, transform 160ms ease;
}
.form__submit:hover { background: var(--green-deep); transform: translateY(-1px); }
.form__submit svg { width: 16px; height: 16px; }
.form__foot {
  font-size: 11px; color: var(--ink-mute); text-align: center; margin-top: 4px;
  font-family: var(--font-mono); letter-spacing: 0.04em;
}

.cta__success {
  text-align: left; padding: 6px 4px;
}
.cta__success h3 {
  font-size: 26px; letter-spacing: -0.02em; font-weight: 500; margin: 0 0 6px;
}
.cta__success h3 em { font-family: var(--font-serif); font-style: italic; }
.cta__success p { color: var(--ink-mute); margin: 0; }
.cta__success .stamp {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 14px;
  padding: 6px 12px; border-radius: 999px;
  background: var(--green-soft);
  color: var(--green-deep);
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
}

/* ============ Booking ticker (under CTA) ============ */
.ticker {
  margin-top: 18px;
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border: 1px dashed var(--hair-2);
  border-radius: 14px;
  background: rgba(255,255,255,0.4);
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.06em;
  color: var(--ink-mute);
  overflow: hidden; position: relative;
}
.ticker__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex: none;
  box-shadow: 0 0 0 4px rgba(47,143,94,0.16); }
.ticker__line { flex: 1; min-width: 0; position: relative; height: 18px; overflow: hidden; }
.ticker__row {
  position: absolute; inset: 0;
  display: flex; align-items: center;
  white-space: nowrap;
  transition: transform 480ms cubic-bezier(0.22,1,0.36,1), opacity 280ms ease;
}
.ticker__row b { color: var(--ink); font-weight: 500; margin-right: 6px; }

/* ============ Footer ============ */
.footer {
  background: var(--engine-bg);
  color: var(--engine-text);
  padding: 64px 0 40px;
}
.footer__inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 32px;
}
@media (max-width: 880px) { .footer__inner { grid-template-columns: 1fr 1fr; } }
.footer__brand { display: flex; flex-direction: column; gap: 16px; max-width: 36ch; }
.footer__brand .lo { display: flex; align-items: center; gap: 10px; }
.footer__brand .lo svg { width: 26px; height: 26px; color: white; }
.footer__brand .lo b { font-weight: 600; font-size: 18px; }
.footer__brand p { color: var(--engine-mute); margin: 0; font-size: 14px; }
.footer__col h6 {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--engine-mute);
  margin: 6px 0 16px;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer__col a { font-size: 14px; color: rgba(255,255,255,0.78); transition: color 160ms ease; }
.footer__col a:hover { color: white; }

.footer__bottom {
  margin-top: 56px; padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--engine-mute);
  flex-wrap: wrap; gap: 12px;
}

/* ============ Reveal animations ============ */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity 800ms cubic-bezier(0.22,1,0.36,1), transform 800ms cubic-bezier(0.22,1,0.36,1); }
.reveal.is-in { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: 80ms; }
.reveal[data-delay="2"] { transition-delay: 160ms; }
.reveal[data-delay="3"] { transition-delay: 240ms; }
.reveal[data-delay="4"] { transition-delay: 320ms; }
.reveal[data-delay="5"] { transition-delay: 400ms; }


/* ---- next block ---- */

/* =========================================================================
   Visual mechanics — ghost PDF, orbit cloud, processing demo,
   capability mini-visuals, flow visuals, signed doc with callouts.
   Each visual is small, self-contained, and CSS-animated.
   ========================================================================= */

/* ============ Hero ghost PDF + orbit ============ */
.hghost {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 600px;
  margin-left: auto;
}
.hghost__paper {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%) rotate(-2deg);
  width: 60%; aspect-ratio: 0.78 / 1;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 8px;
  box-shadow:
    0 30px 60px rgba(20,30,25,0.10),
    0 8px 18px rgba(20,30,25,0.06);
  overflow: hidden;
  padding: 22px 22px;
  z-index: 2;
  animation: paperFloat 9s ease-in-out infinite;
}
@keyframes paperFloat {
  0%, 100% { transform: translate(-50%, -50%) rotate(-2deg); }
  50%      { transform: translate(-50%, calc(-50% - 8px)) rotate(-1.4deg); }
}
.hghost__corner {
  position: absolute; top: 12px; right: 14px;
  font: 500 10px/1 var(--font-mono);
  color: var(--ink-dim); letter-spacing: 0.16em;
}
.hghost__filename {
  position: absolute; top: 14px; left: 16px;
  font: 500 10px/1 var(--font-mono);
  color: var(--green-deep); letter-spacing: 0.12em;
  text-transform: uppercase;
}
.hghost__title {
  margin: 30px 0 16px;
  font-family: var(--font-serif); font-style: italic;
  font-size: 22px; color: var(--ink); line-height: 1.05;
  letter-spacing: -0.01em;
}
.hghost__lines { display: flex; flex-direction: column; gap: 7px; }
.hghost__lines .ln {
  height: 6px; border-radius: 3px;
  background: rgba(20,30,25,0.10);
}
.hghost__row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  margin: 14px 0 10px;
}
.hghost__fld {
  border: 1px dashed rgba(20,30,25,0.18);
  background: rgba(255,255,255,0.5);
  border-radius: 6px;
  padding: 6px 8px 8px;
  height: 42px; position: relative;
  transition: border-color 280ms ease, background 280ms ease, box-shadow 280ms ease;
}
.hghost__fld .lbl {
  font: 500 8px/1 var(--font-mono);
  color: var(--ink-mute); letter-spacing: 0.14em; text-transform: uppercase;
}
.hghost__fld .val {
  margin-top: 6px;
  font-family: var(--font-serif); font-style: italic;
  font-size: 16px; color: var(--ink);
  white-space: nowrap; overflow: hidden;
}
.hghost__fld.is-lit {
  border-style: solid;
  border-color: var(--green);
  background: rgba(68,186,130,0.10);
  box-shadow: 0 0 0 4px rgba(47,143,94,0.10);
}
.hghost__fld.is-lit .val::after {
  content: ""; display: inline-block;
  width: 8px; height: 14px; margin-left: 2px;
  background: var(--green-deep);
  vertical-align: -2px;
  animation: caretBlink 0.9s steps(2) infinite;
}
@keyframes caretBlink { 50% { opacity: 0; } }

.hghost__sig {
  margin-top: 18px;
  height: 56px;
  border-bottom: 1px solid var(--hair-2);
  display: flex; align-items: flex-end;
  font-family: "Instrument Serif", serif; font-style: italic;
  font-size: 28px;
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.hghost__sig svg { width: 100%; height: 100%; }
.hghost__sig path {
  fill: none; stroke: var(--green-deep); stroke-width: 2.2;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 580; stroke-dashoffset: 580;
  animation: signWrite 4.5s cubic-bezier(0.65,0,0.35,1) infinite;
}
@keyframes signWrite {
  0%   { stroke-dashoffset: 580; }
  35%  { stroke-dashoffset: 0; }
  85%  { stroke-dashoffset: 0; opacity: 1; }
  100% { stroke-dashoffset: 0; opacity: 0; }
}
.hghost__sig .lbl {
  position: absolute; left: 0; bottom: -16px;
  font: 500 9px/1 var(--font-mono);
  color: var(--ink-mute); letter-spacing: 0.16em; text-transform: uppercase;
}

.hghost__stamp {
  position: absolute;
  right: -18px; top: -10px;
  transform: rotate(8deg);
  border: 2px solid var(--green-deep);
  color: var(--green-deep);
  background: rgba(255,255,255,0.5);
  padding: 4px 10px;
  font: 600 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  border-radius: 4px;
  z-index: 3;
  opacity: 0; pointer-events: none;
  animation: stampIn 9s ease-in-out infinite;
}
@keyframes stampIn {
  0%, 80%   { opacity: 0; transform: rotate(8deg) scale(1.4); }
  85%, 100% { opacity: 1; transform: rotate(8deg) scale(1); }
}

/* Sweep highlight */
.hghost__sweep {
  position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(47,143,94,0.10) 50%, transparent 70%);
  background-size: 250% 100%;
  background-position: 100% 0;
  animation: sweep 3.6s ease-in-out infinite;
  pointer-events: none;
}
@keyframes sweep {
  0%   { background-position: 130% 0; }
  100% { background-position: -30% 0; }
}

/* Orbit nodes around the paper */
.hghost__orbit {
  position: absolute; inset: 0; pointer-events: none;
}
.hghost__ring {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px dashed rgba(20,30,25,0.10);
  pointer-events: none;
}
.hghost__ring--a { width: 78%; height: 78%; }
.hghost__ring--b { width: 96%; height: 96%; border-color: rgba(20,30,25,0.06); }

.hghost__node {
  position: absolute; left: 50%; top: 50%;
  width: 56px; height: 56px;
  margin-left: -28px; margin-top: -28px;
  pointer-events: auto;
  animation: nodeFloat var(--ob-stamp-float, 3000ms) ease-in-out infinite;
  animation-delay: var(--ob-stamp-delay, 0ms);
}
@keyframes nodeFloat {
  0%, 100% { transform: translate(0, 0); }
  50%      { transform: translate(0, -4px); }
}
.hghost__chip {
  width: 100%; height: 100%;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 16px;
  display: grid; place-items: center;
  color: var(--ink);
  cursor: pointer;
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease, background 220ms ease;
  position: relative;
  box-shadow: 0 8px 20px rgba(20,30,25,0.06);
}
.hghost__chip svg { width: 22px; height: 22px; }
.hghost__chip:hover {
  transform: translateY(-3px) scale(1.05);
  border-color: var(--green);
  box-shadow: 0 12px 26px rgba(47,143,94,0.20);
}
.hghost__node[data-tone="green"]  .hghost__chip { color: var(--green-deep); background: rgba(68,186,130,0.12); }
.hghost__node[data-tone="amber"]  .hghost__chip { color: #8A6513; background: var(--amber-soft); }
.hghost__node[data-tone="sky"]    .hghost__chip { color: #1A5FA0; background: var(--sky-soft); }
.hghost__node[data-tone="lilac"]  .hghost__chip { color: #5b48a8; background: var(--lilac-soft); }
.hghost__node[data-tone="peach"]  .hghost__chip { color: #A8452B; background: var(--peach-soft); }
.hghost__node[data-tone="ink"]    .hghost__chip { color: var(--ink); background: var(--paper-2); }

.hghost__chip-ping {
  position: absolute; inset: -1px;
  border-radius: 16px;
  border: 1.5px solid currentColor;
  opacity: 0;
  animation: chipPing 2.6s ease-out infinite;
  animation-delay: var(--ob-stamp-delay, 0ms);
}
@keyframes chipPing {
  0%   { transform: scale(0.9); opacity: 0.7; }
  100% { transform: scale(1.4); opacity: 0; }
}
.hghost__tip {
  position: absolute; left: 50%; bottom: calc(100% + 10px);
  transform: translateX(-50%);
  background: var(--ink);
  color: white;
  padding: 8px 12px; border-radius: 8px;
  font-size: 12px; line-height: 1.3;
  white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity 200ms ease, transform 200ms ease;
  z-index: 5;
}
.hghost__tip::after {
  content:""; position: absolute; left: 50%; top: 100%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--ink);
}
.hghost__tip .k {
  display: block;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.6); margin-bottom: 2px;
}
.hghost__node:hover .hghost__tip {
  opacity: 1; transform: translateX(-50%) translateY(-2px);
}

/* ============ PROCESSING DEMO (engine band) ============ */
.proc {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  background: var(--engine-bg-2);
  border: 1px solid var(--engine-border);
  border-radius: 22px;
  padding: 28px;
  position: relative;
  overflow: hidden;
}
@media (max-width: 980px) { .proc { grid-template-columns: 1fr; } }
.proc::before {
  content:""; position: absolute; inset: 0;
  background:
    radial-gradient(420px 220px at 70% 0%, rgba(68,186,130,0.10), transparent 70%),
    radial-gradient(360px 220px at 0% 100%, rgba(229,182,74,0.08), transparent 70%);
  pointer-events: none;
}

.proc__l { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 18px; }
.proc__head {
  display: flex; align-items: center; gap: 10px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--engine-mute);
}
.proc__head .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--clai-green-300, #7FDCA7); position: relative; }
.proc__head .pulse::after {
  content: ""; position: absolute; inset: -4px;
  border: 1.5px solid rgba(127,220,167,0.6);
  border-radius: 50%;
  animation: ringPulse 1.6s ease-out infinite;
}

.proc__file {
  display: grid; grid-template-columns: 36px 1fr auto; gap: 12px; align-items: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--engine-border);
  border-radius: 12px;
  padding: 12px 14px;
}
.proc__file .ic {
  width: 36px; height: 36px; border-radius: 8px;
  background: rgba(68,186,130,0.18); color: #7FDCA7;
  display: grid; place-items: center;
}
.proc__file .ic svg { width: 18px; height: 18px; }
.proc__file .nm { font-size: 14px; color: var(--engine-text); font-weight: 500; }
.proc__file .me { font-size: 11px; color: var(--engine-mute); margin-top: 2px; font-family: var(--font-mono); letter-spacing: 0.04em; }
.proc__file .eta {
  font: 500 11px/1 var(--font-mono);
  color: var(--engine-mute); letter-spacing: 0.06em;
  display: inline-flex; align-items: center; gap: 6px;
}
.proc__file .eta b { color: var(--clai-green-300, #7FDCA7); font-weight: 500; }

.proc__steps { display: flex; flex-direction: column; gap: 12px; margin-top: 4px; }
.proc__step {
  display: grid; grid-template-columns: 28px 1fr auto;
  gap: 14px; align-items: flex-start;
  padding: 12px 4px;
  border-bottom: 1px dashed rgba(255,255,255,0.06);
  transition: opacity 200ms ease;
  opacity: 0.55;
}
.proc__step:last-child { border-bottom: 0; }
.proc__step.is-live, .proc__step.is-done { opacity: 1; }
.proc__step .dot {
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--engine-border);
  display: grid; place-items: center;
  font: 500 11px/1 var(--font-mono);
  color: var(--engine-mute);
  margin-top: 2px;
  flex: none;
}
.proc__step.is-done .dot {
  background: rgba(68,186,130,0.18);
  border-color: rgba(68,186,130,0.4);
  color: var(--clai-green-300, #7FDCA7);
}
.proc__step.is-live .dot {
  background: rgba(68,186,130,0.18);
  border-color: rgba(68,186,130,0.6);
  color: var(--clai-green-300, #7FDCA7);
  position: relative;
}
.proc__step.is-live .dot::after {
  content: ""; position: absolute; inset: -2px; border-radius: 50%;
  border: 2px solid rgba(127,220,167,0.6);
  animation: ringPulse 1.6s ease-out infinite;
}
.proc__step .dot svg { width: 12px; height: 12px; }
.proc__step .t { font-size: 14px; font-weight: 500; color: var(--engine-text); }
.proc__step .sub { font-size: 12px; color: var(--engine-mute); margin-top: 2px; line-height: 1.4; min-height: 16px; }
.proc__step .badge {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--engine-mute);
}
.proc__step.is-done .badge { color: var(--clai-green-300, #7FDCA7); }
.proc__step.is-live .badge { color: var(--clai-green-300, #7FDCA7); }

.proc__bar {
  position: relative;
  height: 4px; border-radius: 999px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
}
.proc__bar-fill {
  position: absolute; inset: 0 auto 0 0;
  background: linear-gradient(90deg, #44BA82, #86E7B8);
  border-radius: 999px;
  transition: width 380ms cubic-bezier(0.22,1,0.36,1);
  box-shadow: 0 0 12px rgba(127,220,167,0.4);
}

.proc__r {
  position: relative; z-index: 1;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--engine-border);
  border-radius: 16px;
  padding: 22px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 460px;
  overflow: hidden;
}
.proc__r-head {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--engine-mute);
}
.proc__r-head .live { display: inline-flex; align-items: center; gap: 6px; color: var(--clai-green-300, #7FDCA7); }
.proc__r-head .live .pl { width: 6px; height: 6px; border-radius: 50%; background: var(--clai-green-300, #7FDCA7); animation: blink 1.4s infinite; }
@keyframes blink { 50% { opacity: 0.3; } }

.proc__r-doc {
  flex: 1; min-height: 0;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--engine-border);
  border-radius: 10px;
  padding: 18px;
  position: relative;
  overflow: hidden;
}
.proc__r-doc .header {
  font: 500 10px/1 var(--font-mono);
  color: var(--engine-mute); letter-spacing: 0.12em;
  margin-bottom: 14px;
}
.proc__r-doc .title {
  font-family: var(--font-serif); font-style: italic;
  font-size: 18px; color: var(--engine-text);
  margin-bottom: 12px;
}
.proc__r-lines { display: flex; flex-direction: column; gap: 6px; }
.proc__r-lines .ln {
  height: 5px; border-radius: 3px;
  background: rgba(255,255,255,0.06);
  position: relative;
}
.proc__r-lines .ln.is-lit {
  background: rgba(127,220,167,0.16);
  box-shadow: 0 0 12px rgba(127,220,167,0.20);
}
.proc__r-lines .ln.is-lit::after {
  content: ""; position: absolute; left: 0; top: -2px; height: 9px;
  width: 60%; background: linear-gradient(90deg, transparent, rgba(127,220,167,0.36), transparent);
  animation: scanLight 2.2s ease-in-out infinite;
}
@keyframes scanLight {
  0%   { transform: translateX(-30%); }
  100% { transform: translateX(140%); }
}

.proc__r-pills {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px;
}
.proc__r-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px; border-radius: 999px;
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  background: rgba(127,220,167,0.10);
  color: var(--clai-green-300, #7FDCA7);
  border: 1px solid rgba(127,220,167,0.24);
  opacity: 0;
  animation: pillIn 360ms cubic-bezier(0.22,1,0.36,1) forwards;
}
.proc__r-pill::before {
  content:""; width: 4px; height: 4px; border-radius: 50%; background: currentColor;
}
@keyframes pillIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}

/* ============ Capability mini-visuals ============ */
.cv-doc {
  position: absolute; inset: 12px;
  display: flex; flex-direction: column; gap: 4px;
  padding: 8px 10px;
  background: var(--paper-2);
  border-radius: 6px;
}
.cv-doc .ln { height: 3px; border-radius: 2px; background: rgba(20,30,25,0.10); }
.cv-doc .ln.is-tag { background: var(--green); width: 30%; }
.cv-doc__chip {
  position: absolute; top: 14px; right: 14px;
  background: var(--green); color: white;
  font: 500 8px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 4px 6px; border-radius: 4px;
  animation: chipPop 2.4s ease-in-out infinite;
}
@keyframes chipPop {
  0%, 80%, 100% { transform: scale(1); }
  40% { transform: scale(1.06); }
}

.cv-sign { position: absolute; inset: 16px; display: flex; align-items: flex-end; }
.cv-sign svg { width: 100%; height: 56px; }
.cv-sign path {
  fill: none; stroke: var(--green-deep); stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 360; stroke-dashoffset: 360;
  animation: signWrite 5s ease-in-out infinite;
}
.cv-sign .base { position: absolute; bottom: 6px; left: 0; right: 0; height: 1px; background: var(--hair-2); }
.cv-sign .lbl { position: absolute; bottom: -2px; left: 0;
  font: 500 9px/1 var(--font-mono); color: var(--ink-mute); letter-spacing: 0.14em;
}

.cv-pay {
  position: absolute; inset: 14px;
  display: flex; align-items: center; justify-content: space-between;
}
.cv-pay__bars { display: flex; gap: 4px; align-items: flex-end; height: 60px; }
.cv-pay__bars span {
  width: 8px; border-radius: 2px;
  background: rgba(229,182,74,0.7);
  animation: barRise 2.4s ease-in-out infinite;
}
.cv-pay__bars span:nth-child(2) { background: rgba(229,182,74,0.5); animation-delay: 0.15s; }
.cv-pay__bars span:nth-child(3) { background: rgba(229,182,74,0.85); animation-delay: 0.30s; }
.cv-pay__bars span:nth-child(4) { background: rgba(229,182,74,0.6); animation-delay: 0.45s; }
.cv-pay__bars span:nth-child(5) { background: var(--amber); animation-delay: 0.60s; }
@keyframes barRise {
  0%, 100% { height: 18px; }
  50%      { height: 56px; }
}
.cv-pay__num { font-family: var(--font-mono); font-size: 11px; color: var(--ink); letter-spacing: 0.06em; }
.cv-pay__num b { font-size: 16px; display: block; font-family: var(--font-sans); font-weight: 500; }

.cv-bell { position: absolute; inset: 14px; display: flex; flex-direction: column; gap: 6px; }
.cv-bell__msg {
  background: rgba(255,255,255,0.7); border: 1px solid var(--hair);
  border-radius: 8px; padding: 6px 8px; font-size: 10px; color: var(--ink); line-height: 1.3;
  display: flex; gap: 6px; align-items: center;
  opacity: 0; transform: translateX(-8px);
  animation: msgIn 4s ease-in-out infinite;
}
.cv-bell__msg svg { width: 10px; height: 10px; color: var(--sky); flex: none; }
.cv-bell__msg:nth-child(2) { animation-delay: 1.4s; }
.cv-bell__msg:nth-child(3) { animation-delay: 2.6s; }
@keyframes msgIn {
  0%, 60% { opacity: 0; transform: translateX(-8px); }
  10%, 50% { opacity: 1; transform: none; }
  100% { opacity: 0; transform: translateX(8px); }
}

.cv-risk { position: absolute; inset: 14px; display: flex; flex-direction: column; gap: 4px; }
.cv-risk .row { display: flex; align-items: center; gap: 8px; }
.cv-risk .lbl { font: 500 9px/1 var(--font-mono); color: var(--ink-mute); letter-spacing: 0.14em; min-width: 50px; }
.cv-risk .bar { flex: 1; height: 4px; border-radius: 999px; background: rgba(20,30,25,0.06); overflow: hidden; }
.cv-risk .bar i { display: block; height: 100%; border-radius: 999px;
  background: var(--peach); transform-origin: left center;
  animation: scaleBar 3s ease-in-out infinite; }
.cv-risk .bar.lo i { background: var(--green); }
.cv-risk .bar.md i { background: var(--amber); }
@keyframes scaleBar {
  0%, 100% { transform: scaleX(0.2); }
  50%      { transform: scaleX(0.85); }
}

.cv-ask { position: absolute; inset: 14px; display: flex; flex-direction: column; gap: 6px; }
.cv-ask__q {
  display: inline-flex; align-self: flex-start;
  padding: 5px 10px; background: var(--ink); color: white;
  border-radius: 12px;
  font-size: 11px;
}
.cv-ask__q em { color: rgba(127,220,167,0.9); }
.cv-ask__a {
  align-self: flex-end;
  padding: 5px 10px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
  border-radius: 12px;
  font-size: 11px;
  color: var(--ink);
}
.cv-ask__a b { color: var(--green-deep); }

/* ============ Flow visuals ============ */
.fv-upload { position: absolute; inset: 14px; display: grid; place-items: center; }
.fv-upload .area {
  width: 80%; height: 70%;
  border: 2px dashed var(--green);
  border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(68,186,130,0.06);
  position: relative;
}
.fv-upload .file {
  position: absolute;
  width: 70px; height: 90px; border-radius: 6px;
  background: white; border: 1px solid var(--hair-2);
  box-shadow: 0 8px 18px rgba(20,30,25,0.10);
  display: grid; place-items: center;
  font: 500 9px/1 var(--font-mono); color: var(--ink-mute);
  letter-spacing: 0.06em;
  animation: fileDrop 4s ease-in-out infinite;
}
@keyframes fileDrop {
  0%   { transform: translate(-100px, -40px) rotate(-12deg); opacity: 0; }
  20%  { opacity: 1; }
  60%  { transform: translate(0,0) rotate(0); opacity: 1; }
  80%  { transform: translate(0,0) rotate(0); opacity: 1; }
  100% { transform: translate(0, 12px); opacity: 0; }
}

.fv-extract { position: absolute; inset: 14px; }
.fv-extract .doc {
  height: 100%; background: white; border: 1px solid var(--hair); border-radius: 8px;
  padding: 12px; display: flex; flex-direction: column; gap: 5px;
  position: relative; overflow: hidden;
}
.fv-extract .doc .ln { height: 4px; border-radius: 2px; background: rgba(20,30,25,0.10); }
.fv-extract .pop {
  position: absolute;
  background: white; border: 1px solid var(--green);
  box-shadow: 0 6px 16px rgba(47,143,94,0.18);
  padding: 4px 8px; border-radius: 6px;
  font: 500 9px/1 var(--font-mono); color: var(--green-deep);
  letter-spacing: 0.08em;
  opacity: 0;
  animation: popUp 4.5s ease-in-out infinite;
}
.fv-extract .pop.p1 { left: 14%; top: 18%; animation-delay: 0.3s; }
.fv-extract .pop.p2 { left: 56%; top: 32%; animation-delay: 1.0s; }
.fv-extract .pop.p3 { left: 28%; top: 58%; animation-delay: 1.7s; }
.fv-extract .pop.p4 { left: 64%; top: 74%; animation-delay: 2.4s; }
@keyframes popUp {
  0%, 80%, 100% { opacity: 0; transform: scale(0.8) translateY(4px); }
  10%, 70% { opacity: 1; transform: scale(1) translateY(0); }
}

.fv-launch { position: absolute; inset: 14px; }
.fv-launch .doc {
  position: absolute; left: 8%; top: 8%; right: 8%; bottom: 8%;
  background: white; border: 1px solid var(--hair); border-radius: 8px;
  padding: 12px;
}
.fv-launch .stamp {
  position: absolute; right: 14%; top: 14%; transform: rotate(8deg);
  border: 2px solid var(--green-deep); color: var(--green-deep);
  padding: 3px 8px; font: 600 9px/1 var(--font-mono); letter-spacing: 0.18em;
  border-radius: 4px;
  animation: stampFlash 3s ease-in-out infinite;
}
@keyframes stampFlash {
  0%, 90%, 100% { opacity: 0; transform: rotate(8deg) scale(1.2); }
  20%, 80% { opacity: 1; transform: rotate(8deg) scale(1); }
}
.fv-launch .doc .ln { height: 3px; background: rgba(20,30,25,0.08); border-radius: 2px; margin-bottom: 4px; }
.fv-launch .send {
  position: absolute; bottom: 18%; left: 50%; transform: translateX(-50%);
  background: var(--ink); color: white;
  padding: 6px 14px; border-radius: 999px;
  font: 500 10px/1 var(--font-sans);
  display: inline-flex; align-items: center; gap: 6px;
}
.fv-launch .send svg { width: 10px; height: 10px; }

/* ============ Stats counter helper ============ */
.stat__v.is-counting span { font-variant-numeric: tabular-nums; }


/* ---- next block ---- */

/* =========================================================================
   Clai Payments Landing — page-specific styles. Sits on top of the
   shared landing tokens (paper / ink / green / engine room) and adds
   money-flow visuals: cash beams, ACH wires, escrow vault, splits,
   ledger ticker.
   ========================================================================= */

:root {
  --bill:        #2F8F5E;      /* greenback */
  --bill-deep:   #1E6B43;
  --bill-soft:   rgba(47,143,94,0.10);
  --bill-tile:   rgba(68,186,130,0.18);
  --gold:        #C99A2E;
  --gold-soft:   rgba(201,154,46,0.16);
  --rail:        #6DA8E5;
  --rail-soft:   rgba(109,168,229,0.16);
  --warn:        #C46A3B;
  --warn-soft:   rgba(196,106,59,0.16);
}

/* ============ HERO — Pay-on-Sign tableau ============ */
.pos {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1.05;
  max-width: 580px;
  margin-left: auto;
}
.pos__paper {
  position: absolute;
  left: 6%; top: 8%;
  width: 64%;
  aspect-ratio: 0.78 / 1;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 10px;
  box-shadow:
    0 36px 64px rgba(20,30,25,0.12),
    0 8px 18px rgba(20,30,25,0.06);
  padding: 22px 22px;
  z-index: 2;
  overflow: hidden;
  animation: posPaperFloat 9s ease-in-out infinite;
}
@keyframes posPaperFloat {
  0%, 100% { transform: rotate(-2.4deg) translateY(0); }
  50%      { transform: rotate(-1.6deg) translateY(-6px); }
}
.pos__filename {
  font: 500 9.5px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--bill-deep);
  display: flex; justify-content: space-between; align-items: center;
}
.pos__filename .id { color: var(--ink-dim); }
.pos__title {
  margin: 14px 0 8px;
  font-family: var(--font-serif); font-style: italic;
  font-size: 19px; color: var(--ink); line-height: 1.05;
  letter-spacing: -0.01em;
}
.pos__sub {
  font: 500 9.5px/1 var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 12px;
}
.pos__lines { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.pos__lines .ln { height: 5px; border-radius: 3px; background: rgba(20,30,25,0.08); }
.pos__lines .ln.is-hi { background: var(--bill-tile); }
.pos__money {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin: 10px 0 10px;
}
.pos__mcell {
  border: 1px dashed rgba(20,30,25,0.18);
  background: rgba(255,255,255,0.6);
  border-radius: 8px;
  padding: 8px 10px;
  position: relative;
}
.pos__mcell .lbl {
  font: 500 8px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.pos__mcell .val {
  margin-top: 6px;
  font-family: var(--font-serif); font-style: italic;
  font-size: 18px; color: var(--ink);
  letter-spacing: -0.01em;
}
.pos__mcell.is-lit {
  border-style: solid;
  border-color: var(--bill);
  background: rgba(68,186,130,0.10);
  box-shadow: 0 0 0 4px rgba(47,143,94,0.10);
}
.pos__mcell .val .cur { color: var(--bill-deep); font-style: normal; font-family: var(--font-sans); font-weight: 600; }
.pos__sig {
  margin-top: 8px;
  height: 60px;
  border-bottom: 1px solid var(--hair-2);
  position: relative;
  overflow: hidden;
}
.pos__sig svg { width: 100%; height: 100%; }
.pos__sig path {
  fill: none; stroke: var(--bill-deep); stroke-width: 2.4;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 620; stroke-dashoffset: 620;
  animation: posSigWrite 6s cubic-bezier(0.65,0,0.35,1) infinite;
}
@keyframes posSigWrite {
  0%, 8%   { stroke-dashoffset: 620; opacity: 1; }
  38%      { stroke-dashoffset: 0;   opacity: 1; }
  78%      { stroke-dashoffset: 0;   opacity: 1; }
  92%, 100%{ stroke-dashoffset: 0;   opacity: 0; }
}
.pos__sig-lbl {
  position: absolute; left: 0; bottom: -16px;
  font: 500 9px/1 var(--font-mono);
  color: var(--ink-mute); letter-spacing: 0.14em; text-transform: uppercase;
}
.pos__paid {
  position: absolute;
  right: 12px; top: 14px;
  transform: rotate(7deg);
  border: 2.5px solid var(--bill-deep);
  color: var(--bill-deep);
  background: rgba(255,255,255,0.6);
  padding: 5px 10px;
  font: 600 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  border-radius: 4px;
  opacity: 0;
  animation: posPaidStamp 6s ease-in-out infinite;
}
.pos__paid::after {
  content: "$25,000 · CLEARED";
  display: block;
  margin-top: 3px;
  font: 500 8px/1 var(--font-mono);
  color: var(--bill);
}
@keyframes posPaidStamp {
  0%, 55%   { opacity: 0; transform: rotate(7deg) scale(1.6); }
  62%, 88%  { opacity: 1; transform: rotate(7deg) scale(1); }
  95%, 100% { opacity: 0; transform: rotate(7deg) scale(1); }
}

/* Cash beams — small green chits flying from doc to the bank node */
.pos__beam {
  position: absolute;
  z-index: 3;
  pointer-events: none;
  left: 55%; top: 60%;
  width: 14px; height: 9px;
  border-radius: 2px;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.10) 0 1px, transparent 1px 3px),
    var(--bill);
  box-shadow: 0 4px 10px rgba(47,143,94,0.32);
  opacity: 0;
}
.pos__beam::after {
  content: "$";
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font: 700 7px/1 var(--font-mono);
  color: rgba(255,255,255,0.9);
}
.pos__beam.b1 { animation: beam 4.2s ease-in 1.2s infinite; }
.pos__beam.b2 { animation: beam 4.2s ease-in 1.55s infinite; }
.pos__beam.b3 { animation: beam 4.2s ease-in 1.9s infinite; }
.pos__beam.b4 { animation: beam 4.2s ease-in 2.25s infinite; }
.pos__beam.b5 { animation: beam 4.2s ease-in 2.6s infinite; }
.pos__beam.b6 { animation: beam 4.2s ease-in 2.95s infinite; }
@keyframes beam {
  0%   { opacity: 0; transform: translate(0,0) rotate(-8deg) scale(0.6); }
  18%  { opacity: 1; transform: translate(40px, -36px) rotate(-6deg) scale(1); }
  64%  { opacity: 1; transform: translate(160px, -140px) rotate(8deg) scale(0.95); }
  82%  { opacity: 0.6; transform: translate(210px, -190px) rotate(12deg) scale(0.7); }
  100% { opacity: 0; transform: translate(230px, -210px) rotate(14deg) scale(0.4); }
}

/* Bank node — destination of beams */
.pos__bank {
  position: absolute;
  right: 4%; top: 8%;
  width: 30%;
  background: var(--ink);
  color: var(--paper);
  border-radius: 14px;
  padding: 14px 14px 14px;
  box-shadow: 0 20px 50px rgba(20,30,25,0.30);
  z-index: 4;
  animation: bankFloat 7s ease-in-out infinite;
}
@keyframes bankFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-5px); }
}
.pos__bank-h {
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  display: flex; align-items: center; gap: 6px;
}
.pos__bank-h::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--bill); box-shadow: 0 0 0 4px rgba(47,143,94,0.24);
}
.pos__bank-co {
  margin-top: 8px;
  font-size: 13px; font-weight: 500;
  letter-spacing: -0.005em;
}
.pos__bank-acct {
  margin-top: 2px;
  font: 500 9.5px/1.2 var(--font-mono);
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.12em;
}
.pos__bank-amt {
  margin-top: 12px;
  font-size: 22px; font-weight: 600; letter-spacing: -0.02em;
  color: white;
  font-variant-numeric: tabular-nums;
}
.pos__bank-amt::before { content: "+"; color: var(--bill); margin-right: 2px; }
.pos__bank-sweep {
  margin-top: 10px;
  height: 4px; border-radius: 2px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.pos__bank-sweep i {
  display: block; height: 100%; width: 30%;
  background: linear-gradient(90deg, transparent, var(--bill), transparent);
  animation: bankSweep 2.2s ease-in-out infinite;
}
@keyframes bankSweep {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(380%); }
}

/* Ledger card — bottom left running totals */
.pos__ledger {
  position: absolute;
  left: -2%; bottom: -2%;
  width: 56%;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 14px;
  padding: 14px 14px;
  box-shadow: 0 20px 40px rgba(20,30,25,0.08);
  z-index: 5;
}
.pos__ledger-h {
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; justify-content: space-between; align-items: center;
}
.pos__ledger-h .pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--bill);
  box-shadow: 0 0 0 0 rgba(47,143,94,0.45);
  animation: posPulse 1.6s ease-out infinite;
}
@keyframes posPulse {
  0%   { box-shadow: 0 0 0 0 rgba(47,143,94,0.45); }
  100% { box-shadow: 0 0 0 10px rgba(47,143,94,0); }
}
.pos__ledger-row {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--hair-soft);
  font-size: 12px;
}
.pos__ledger-row:last-child { border-bottom: 0; padding-bottom: 0; }
.pos__ledger-row .who { color: var(--ink); font-weight: 500; }
.pos__ledger-row .who small { color: var(--ink-mute); font-weight: 400; margin-left: 4px; }
.pos__ledger-row .amt {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--bill-deep);
}
.pos__ledger-row .amt.is-out { color: var(--warn); }

/* ============ Money flow engine band ============ */
.mflow {
  position: relative;
  display: grid;
  grid-template-columns: 1.2fr 1.2fr 1.2fr;
  gap: 22px;
  background: var(--engine-bg-2);
  border: 1px solid var(--engine-border);
  border-radius: 22px;
  padding: 28px 28px;
  overflow: hidden;
}
@media (max-width: 980px) { .mflow { grid-template-columns: 1fr; } }

.mflow__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(420px 280px at 18% 8%, rgba(68,186,130,0.10), transparent 70%),
    radial-gradient(420px 260px at 88% 92%, rgba(109,168,229,0.08), transparent 70%);
  pointer-events: none;
}
.mflow__col {
  position: relative;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.025);
  border-radius: 16px;
  padding: 20px 20px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 380px;
}
.mflow__step {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  display: flex; align-items: center; gap: 8px;
}
.mflow__step::before {
  content: attr(data-n);
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  display: grid; place-items: center;
  color: white; font-weight: 600;
}
.mflow__col[data-tone="bill"]  .mflow__step::before { background: var(--bill); }
.mflow__col[data-tone="gold"]  .mflow__step::before { background: var(--gold); }
.mflow__col[data-tone="rail"]  .mflow__step::before { background: var(--rail); }
.mflow__h {
  font-family: var(--font-sans);
  font-size: 22px; line-height: 1.1;
  letter-spacing: -0.01em; font-weight: 500;
  color: var(--engine-text);
}
.mflow__h em { font-family: var(--font-serif); font-style: italic; }
.mflow__d {
  font-size: 13px; line-height: 1.5;
  color: var(--engine-mute);
}

/* Flow connector arrows between columns */
.mflow__col + .mflow__col::before {
  content: ""; position: absolute;
  left: -22px; top: 60px;
  width: 22px; height: 1px;
  background: repeating-linear-gradient(90deg, rgba(255,255,255,0.4) 0 4px, transparent 4px 8px);
}
@media (max-width: 980px) { .mflow__col + .mflow__col::before { display: none; } }

/* Sign stage */
.mfStage--sign { position: relative; padding-top: 6px; }
.mfStage--sign .doc {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  padding: 14px;
  position: relative;
}
.mfStage--sign .doc .file {
  font: 500 8.5px/1 var(--font-mono);
  letter-spacing: 0.16em; color: rgba(255,255,255,0.6);
  margin-bottom: 8px;
}
.mfStage--sign .doc .ln {
  height: 5px; border-radius: 3px;
  background: rgba(255,255,255,0.10);
  margin-bottom: 6px;
}
.mfStage--sign .doc .ln.is-amt { background: var(--bill-tile); }
.mfStage--sign .doc .sig {
  margin-top: 10px;
  height: 38px;
  border-bottom: 1px solid rgba(255,255,255,0.18);
  position: relative;
}
.mfStage--sign .doc .sig svg { width: 100%; height: 100%; }
.mfStage--sign .doc .sig path {
  fill: none; stroke: var(--bill); stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 380; stroke-dashoffset: 380;
  animation: mfSigWrite 4s cubic-bezier(0.65,0,0.35,1) infinite;
}
@keyframes mfSigWrite {
  0%, 5%   { stroke-dashoffset: 380; }
  55%      { stroke-dashoffset: 0; }
  100%     { stroke-dashoffset: 0; }
}
.mfStage--sign .doc .ok {
  position: absolute; right: 10px; bottom: 8px;
  font: 600 9px/1 var(--font-mono);
  letter-spacing: 0.16em;
  color: var(--bill);
  opacity: 0;
  animation: mfOk 4s ease-out infinite;
}
@keyframes mfOk {
  0%, 60% { opacity: 0; transform: translateY(4px); }
  70%, 95% { opacity: 1; transform: none; }
}

/* Escrow vault stage */
.mfStage--vault { position: relative; }
.vault {
  position: relative;
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02)),
    radial-gradient(60% 80% at 50% 30%, rgba(201,154,46,0.16), transparent 70%);
  border: 1px solid rgba(201,154,46,0.30);
  padding: 18px 18px 22px;
  overflow: hidden;
}
.vault__h {
  display: flex; justify-content: space-between; align-items: center;
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.16em; color: rgba(255,255,255,0.65);
}
.vault__h .id { color: var(--gold); }
.vault__big {
  margin: 14px 0 4px;
  font-size: 34px; font-weight: 600;
  letter-spacing: -0.03em; color: white;
  font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: 4px;
}
.vault__big small {
  font-size: 12px; color: var(--gold); font-weight: 500;
  letter-spacing: 0.08em; font-family: var(--font-mono);
}
.vault__sub { font-size: 12px; color: rgba(255,255,255,0.55); }
.vault__bars {
  margin-top: 16px;
  display: flex; align-items: flex-end; gap: 6px;
  height: 60px;
}
.vault__bars span {
  flex: 1;
  background: linear-gradient(180deg, var(--gold), rgba(201,154,46,0.4));
  border-radius: 3px;
  animation: vaultBar 2.6s ease-in-out infinite;
  transform-origin: bottom;
}
.vault__bars span:nth-child(1) { animation-delay: 0.0s; height: 30%; }
.vault__bars span:nth-child(2) { animation-delay: 0.15s; height: 55%; }
.vault__bars span:nth-child(3) { animation-delay: 0.30s; height: 70%; }
.vault__bars span:nth-child(4) { animation-delay: 0.45s; height: 95%; }
.vault__bars span:nth-child(5) { animation-delay: 0.60s; height: 82%; }
.vault__bars span:nth-child(6) { animation-delay: 0.75s; height: 64%; }
.vault__bars span:nth-child(7) { animation-delay: 0.90s; height: 88%; }
@keyframes vaultBar {
  0%, 100% { transform: scaleY(0.85); }
  50%      { transform: scaleY(1); }
}
.vault__chk {
  position: absolute; right: 14px; top: 14px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--bill); color: white;
  display: grid; place-items: center;
  box-shadow: 0 0 0 4px rgba(47,143,94,0.18);
}
.vault__chk svg { width: 16px; height: 16px; }

/* Split / payout stage */
.mfStage--split { display: flex; flex-direction: column; gap: 10px; }
.split-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center; gap: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 12px; color: var(--engine-text);
}
.split-row .who { display: flex; align-items: center; gap: 8px; }
.split-row .av {
  width: 22px; height: 22px; border-radius: 50%;
  display: grid; place-items: center;
  font: 500 9px/1 var(--font-sans);
  color: white;
}
.split-row .av.l { background: var(--bill); }
.split-row .av.b { background: var(--rail); }
.split-row .av.f { background: var(--gold); color: var(--ink); }
.split-row .av.h { background: var(--warn); }
.split-row .who-meta b { font-weight: 500; }
.split-row .who-meta small {
  display: block;
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-top: 2px;
}
.split-row .pct {
  font: 500 11px/1 var(--font-mono);
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.06em;
}
.split-row .amt {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: white;
}
.split-row .wire {
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--bill) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: wireFlow 1.8s linear infinite;
  pointer-events: none;
}
@keyframes wireFlow {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ============ Capability mini-visuals (payment-specific) ============ */
/* ACH wire */
.cv-wire {
  position: relative; height: 100%; padding: 14px;
  display: flex; flex-direction: column; gap: 6px; justify-content: center;
}
.cv-wire .lbl {
  font: 500 8.5px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; justify-content: space-between;
}
.cv-wire .lbl b { color: var(--bill-deep); font-weight: 500; }
.cv-wire .wire {
  position: relative; height: 2px;
  background: var(--hair-2);
  margin: 6px 0;
  overflow: visible;
}
.cv-wire .wire::after {
  content: ""; position: absolute;
  left: -10px; top: -2px;
  width: 16px; height: 6px;
  border-radius: 3px;
  background: var(--bill);
  box-shadow: 0 4px 10px rgba(47,143,94,0.32);
  animation: cvWire 2.2s ease-in-out infinite;
}
@keyframes cvWire {
  0%   { left: -10px; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { left: calc(100% - 6px); opacity: 0; }
}
.cv-wire .meta {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-dim);
  margin-top: 4px;
  letter-spacing: 0.06em;
}

/* Commission split pie */
.cv-pie {
  position: relative; height: 100%;
  display: flex; align-items: center; gap: 14px;
  padding: 10px 14px;
}
.cv-pie__ring {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: conic-gradient(
    var(--bill) 0 50%,
    var(--rail) 50% 78%,
    var(--gold) 78% 92%,
    var(--warn) 92% 100%
  );
  position: relative;
  animation: pieSpin 16s linear infinite;
  flex: none;
}
.cv-pie__ring::after {
  content: ""; position: absolute; inset: 12px;
  border-radius: 50%; background: var(--paper);
}
.cv-pie__ring::before {
  content: "100%"; position: absolute; inset: 0;
  display: grid; place-items: center;
  font: 600 11px/1 var(--font-mono);
  color: var(--ink); z-index: 1;
}
@keyframes pieSpin {
  0%   { transform: rotate(0); }
  100% { transform: rotate(360deg); }
}
.cv-pie__legend { display: flex; flex-direction: column; gap: 4px; font-size: 11px; }
.cv-pie__legend span {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-mono);
  color: var(--ink-mute); letter-spacing: 0.04em;
}
.cv-pie__legend span::before {
  content: ""; width: 8px; height: 8px; border-radius: 2px;
}
.cv-pie__legend span:nth-child(1)::before { background: var(--bill); }
.cv-pie__legend span:nth-child(2)::before { background: var(--rail); }
.cv-pie__legend span:nth-child(3)::before { background: var(--gold); }
.cv-pie__legend span:nth-child(4)::before { background: var(--warn); }
.cv-pie__legend b { color: var(--ink); font-weight: 500; margin-left: auto; padding-left: 8px; }

/* Card tap */
.cv-tap {
  position: relative; height: 100%;
  display: grid; place-items: center;
}
.cv-tap__card {
  width: 78%; height: 50%;
  border-radius: 8px;
  background: linear-gradient(135deg, #1A2520, #2C342F);
  position: relative;
  overflow: hidden;
  box-shadow: 0 10px 18px rgba(20,30,25,0.16);
  animation: tapFloat 2.6s ease-in-out infinite;
}
@keyframes tapFloat {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50%      { transform: translateY(-3px) rotate(-1deg); }
}
.cv-tap__card .chip {
  position: absolute; left: 10px; top: 12px;
  width: 16px; height: 12px;
  background: linear-gradient(135deg, var(--gold), #E5C266);
  border-radius: 2px;
}
.cv-tap__card .num {
  position: absolute; left: 10px; bottom: 8px;
  font: 600 10px/1 var(--font-mono);
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.18em;
}
.cv-tap__card .brand {
  position: absolute; right: 10px; top: 10px;
  font: 600 10px/1 var(--font-mono);
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.08em;
}
.cv-tap__ping {
  position: absolute;
  right: -6%; top: 14%;
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 2px solid var(--bill);
  opacity: 0;
  animation: tapPing 2.6s ease-out infinite;
}
.cv-tap__ping.b { animation-delay: 0.6s; }
.cv-tap__ping.c { animation-delay: 1.2s; }
@keyframes tapPing {
  0%   { opacity: 0; transform: scale(0.5); }
  40%  { opacity: 1; }
  100% { opacity: 0; transform: scale(2.4); }
}

/* Recurring rhythm */
.cv-recur {
  height: 100%; padding: 14px;
  display: flex; flex-direction: column; gap: 8px; justify-content: center;
}
.cv-recur__row {
  display: grid; grid-template-columns: 60px 1fr auto;
  align-items: center; gap: 10px;
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.08em; color: var(--ink-mute);
}
.cv-recur__row .when { color: var(--ink); }
.cv-recur__bar {
  height: 4px; border-radius: 2px;
  background: var(--hair);
  position: relative; overflow: hidden;
}
.cv-recur__bar i {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--bill);
  width: 100%;
  transform: scaleX(0);
  transform-origin: left;
  animation: recurFill 5s ease-in-out infinite;
}
.cv-recur__row:nth-child(1) i { animation-delay: 0s; }
.cv-recur__row:nth-child(2) i { animation-delay: 0.6s; }
.cv-recur__row:nth-child(3) i { animation-delay: 1.2s; }
.cv-recur__row:nth-child(4) i { animation-delay: 1.8s; }
@keyframes recurFill {
  0%, 10%   { transform: scaleX(0); }
  60%       { transform: scaleX(1); }
  90%, 100% { transform: scaleX(1); opacity: 0.6; }
}
.cv-recur__row .amt {
  color: var(--bill-deep); font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* Refund / undo */
.cv-undo {
  position: relative; height: 100%; padding: 14px;
  display: flex; flex-direction: column; justify-content: center; gap: 8px;
}
.cv-undo__row {
  display: flex; align-items: center; gap: 8px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  padding: 6px 8px;
  border-radius: 6px;
  background: var(--paper-2);
  border: 1px solid var(--hair);
}
.cv-undo__row .am { font-variant-numeric: tabular-nums; color: var(--ink); margin-left: auto; }
.cv-undo__row.is-out .am { color: var(--warn); }
.cv-undo__row.is-out::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--warn);
  box-shadow: 0 0 0 3px rgba(196,106,59,0.16);
}
.cv-undo__row.is-in::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--bill);
  box-shadow: 0 0 0 3px rgba(47,143,94,0.16);
}
.cv-undo__row.is-in .am { color: var(--bill-deep); }

/* ============ Flow visuals (HowItWorks) ============ */
/* Step 1: line item editor on the contract */
.fv-line {
  position: relative; height: 100%;
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px;
}
.fv-line__head {
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 4px;
}
.fv-line__item {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 8px;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--hair);
  background: var(--paper-2);
  font-size: 12px;
}
.fv-line__item.is-new {
  border-style: dashed; border-color: var(--bill);
  background: rgba(68,186,130,0.08);
  animation: fvLineIn 0.6s ease-out;
}
@keyframes fvLineIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}
.fv-line__item .name { color: var(--ink); }
.fv-line__item .name small {
  display: block;
  font: 500 9px/1 var(--font-mono);
  color: var(--ink-mute); margin-top: 2px;
  letter-spacing: 0.06em;
}
.fv-line__item .amt {
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  color: var(--bill-deep); font-weight: 500;
}
.fv-line__total {
  margin-top: auto;
  display: flex; justify-content: space-between;
  padding-top: 8px;
  border-top: 1px solid var(--hair);
  font-size: 12px;
}
.fv-line__total b { font-family: var(--font-mono); color: var(--ink); font-weight: 600; }

/* Step 2: parallel sign + pay panels */
.fv-twin {
  height: 100%; padding: 14px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.fv-twin__pane {
  border-radius: 8px;
  border: 1px solid var(--hair);
  background: var(--paper-2);
  padding: 10px;
  display: flex; flex-direction: column; gap: 5px;
  position: relative;
}
.fv-twin__pane h6 {
  font: 500 8.5px/1 var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.fv-twin__pane .ln {
  height: 4px; border-radius: 2px;
  background: rgba(20,30,25,0.10);
}
.fv-twin__pane .ln.is-amt { background: var(--bill-tile); }
.fv-twin__pane .stamp {
  margin-top: auto;
  font: 600 9px/1 var(--font-mono);
  letter-spacing: 0.16em;
  color: var(--bill-deep);
  border: 1.5px solid var(--bill-deep);
  border-radius: 4px;
  padding: 4px 6px;
  text-align: center;
  align-self: flex-start;
  animation: fvStamp 3s ease-out infinite;
}
@keyframes fvStamp {
  0%, 60% { opacity: 0; transform: scale(1.3); }
  70%, 100% { opacity: 1; transform: scale(1); }
}

/* Step 3: payout tree */
.fv-tree {
  height: 100%; padding: 12px;
  position: relative;
}
.fv-tree__src {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 60px;
  background: var(--ink); color: var(--paper);
  border-radius: 8px;
  padding: 8px;
  text-align: center;
  font: 500 9px/1.2 var(--font-mono);
  letter-spacing: 0.06em;
}
.fv-tree__src b {
  display: block; margin-top: 4px;
  font-family: var(--font-sans);
  font-size: 12px; color: var(--bill);
  font-variant-numeric: tabular-nums;
}
.fv-tree__lines {
  position: absolute; left: 78px; right: 70px; top: 8px; bottom: 8px;
}
.fv-tree__lines svg { width: 100%; height: 100%; }
.fv-tree__lines path {
  fill: none; stroke: var(--bill);
  stroke-width: 1.5;
  stroke-dasharray: 4 6;
  animation: fvTreeDash 1.4s linear infinite;
}
@keyframes fvTreeDash {
  0%   { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -20; }
}
.fv-tree__dst {
  position: absolute; right: 10px; width: 60px;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 8px;
  padding: 6px 6px;
  text-align: right;
  font: 500 9px/1.2 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.fv-tree__dst b {
  display: block;
  font-family: var(--font-sans);
  font-size: 11px; color: var(--ink);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.fv-tree__dst.a { top: 14px; }
.fv-tree__dst.b { top: 50%; transform: translateY(-50%); }
.fv-tree__dst.c { bottom: 14px; }

/* Step 4: cleared confetti */
.fv-clear {
  position: relative; height: 100%;
  display: grid; place-items: center;
  overflow: hidden;
}
.fv-clear__big {
  font-size: 28px; font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  text-align: center;
}
.fv-clear__big small {
  display: block;
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.16em;
  color: var(--bill-deep);
  margin-top: 6px;
}
.fv-clear__chit {
  position: absolute;
  width: 10px; height: 6px;
  border-radius: 1px;
  background: var(--bill);
  opacity: 0;
  animation: chitFall 3s linear infinite;
}
.fv-clear__chit.gold { background: var(--gold); }
.fv-clear__chit.c1 { left: 16%; animation-delay: 0s; }
.fv-clear__chit.c2 { left: 32%; animation-delay: 0.4s; }
.fv-clear__chit.c3 { left: 48%; animation-delay: 0.8s; }
.fv-clear__chit.c4 { left: 64%; animation-delay: 1.2s; }
.fv-clear__chit.c5 { left: 80%; animation-delay: 1.6s; }
.fv-clear__chit.c6 { left: 24%; animation-delay: 2.0s; }
.fv-clear__chit.c7 { left: 56%; animation-delay: 2.4s; }
@keyframes chitFall {
  0%   { top: -10%; opacity: 0; transform: rotate(0); }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { top: 110%; opacity: 0; transform: rotate(360deg); }
}

/* ============ Live ledger — full-width section ============ */
.ledger {
  border: 1px solid var(--hair);
  border-radius: 22px;
  background: var(--paper-2);
  overflow: hidden;
}
.ledger__head {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1.2fr 1fr 1fr 1.4fr;
  padding: 12px 22px;
  background: var(--paper);
  border-bottom: 1px solid var(--hair);
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
  gap: 12px;
}
.ledger__row {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1.2fr 1fr 1fr 1.4fr;
  padding: 16px 22px;
  align-items: center;
  border-bottom: 1px solid var(--hair-soft);
  font-size: 14px; gap: 12px;
  transition: background 240ms ease;
  animation: ledgerIn 0.6s cubic-bezier(0.22,1,0.36,1);
}
@keyframes ledgerIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.ledger__row:hover { background: rgba(20,30,25,0.02); }
.ledger__row:last-child { border-bottom: 0; }
.ledger__deal {
  display: flex; flex-direction: column;
}
.ledger__deal b { font-weight: 500; }
.ledger__deal small {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); margin-top: 4px;
}
.ledger__amt {
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-weight: 500; color: var(--ink);
}
.ledger__method {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.06em; color: var(--ink-mute);
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px; border-radius: 4px;
  background: var(--paper); border: 1px solid var(--hair);
  width: max-content;
}
.ledger__method.is-card  { color: #5b48a8; }
.ledger__method.is-ach   { color: var(--bill-deep); }
.ledger__method.is-wire  { color: #1A5FA0; }
.ledger__from {
  font-size: 13px; color: var(--ink-mute);
}
.ledger__from b { color: var(--ink); font-weight: 500; }
.ledger__when {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.04em; color: var(--ink-mute);
}
.ledger__status {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 999px;
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  width: max-content;
}
.ledger__status.is-clear {
  background: var(--bill-soft); color: var(--bill-deep);
}
.ledger__status.is-route {
  background: var(--gold-soft); color: var(--gold);
}
.ledger__status.is-hold {
  background: rgba(196,106,59,0.10); color: var(--warn);
}
.ledger__status::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}
.ledger__status.is-route::before {
  animation: ledgerPulse 1.4s ease-in-out infinite;
}
@keyframes ledgerPulse {
  0%, 100% { transform: scale(0.7); opacity: 0.5; }
  50%      { transform: scale(1.3); opacity: 1; }
}

.ledger__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 22px;
  background: var(--paper);
  border-top: 1px solid var(--hair);
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.ledger__foot .total {
  font-family: var(--font-sans);
  font-size: 14px; letter-spacing: -0.01em;
  text-transform: none;
  color: var(--ink);
}
.ledger__foot .total b {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bill-deep); font-weight: 600;
  margin-left: 6px;
  font-size: 16px;
}

/* ============ Counters — bigger / metric panel ============ */
.metrics {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 0;
  border: 1px solid var(--hair);
  border-radius: 22px;
  overflow: hidden;
}
@media (max-width: 880px) { .metrics { grid-template-columns: 1fr 1fr; } }
.metric {
  background: var(--paper-2);
  padding: 32px 26px;
  border-right: 1px solid var(--hair);
  position: relative;
}
.metric:last-child { border-right: 0; }
@media (max-width: 880px) {
  .metric { border-right: 0; border-bottom: 1px solid var(--hair); }
}
.metric.is-feature {
  background:
    linear-gradient(180deg, var(--bill-deep), #185437);
  color: white;
}
.metric.is-feature .metric__k { color: rgba(255,255,255,0.6); }
.metric.is-feature .metric__d { color: rgba(255,255,255,0.7); }
.metric__k {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}
.metric__k::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--bill);
}
.metric.is-feature .metric__k::before { background: var(--gold); }
.metric__v {
  font-size: clamp(40px, 4.8vw, 64px);
  line-height: 0.96;
  letter-spacing: -0.035em;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: 3px;
}
.metric__v small {
  font-size: 0.45em; opacity: 0.6; font-weight: 400;
}
.metric__d {
  margin-top: 10px;
  font-size: 13px; line-height: 1.4;
  color: var(--ink-mute); max-width: 30ch;
}
.metric.is-feature .metric__bg {
  position: absolute; right: -40px; top: -40px;
  width: 240px; height: 240px;
  background:
    radial-gradient(closest-side, rgba(201,154,46,0.30), transparent 70%);
  pointer-events: none;
}

/* ============ Comparison strip ============ */
.compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 880px) { .compare { grid-template-columns: 1fr; } }
.col {
  position: relative;
  border-radius: 22px;
  padding: 28px 28px 24px;
  overflow: hidden;
}
.col--before {
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
}
.col--after {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink-2);
}
.col__h {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}
.col--before .col__h { color: var(--ink-mute); }
.col--after .col__h { color: rgba(255,255,255,0.55); }
.col__t {
  font-family: var(--font-sans);
  font-size: clamp(24px, 2.6vw, 30px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 500;
  margin: 0 0 16px;
}
.col__t em { font-family: var(--font-serif); font-style: italic; }
.col__steps {
  display: flex; flex-direction: column; gap: 10px;
  margin: 16px 0 8px;
  list-style: none; padding: 0;
}
.col__steps li {
  display: grid; grid-template-columns: 24px 1fr auto;
  align-items: center; gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 14px;
}
.col--before .col__steps li {
  background: var(--paper);
  border: 1px solid var(--hair);
}
.col--after .col__steps li {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
}
.col__steps li .n {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--ink-dim);
}
.col--after .col__steps li .n { color: rgba(255,255,255,0.5); }
.col__steps li .when {
  font: 500 10px/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.col--before .col__steps li .when { color: var(--warn); }
.col--after .col__steps li .when { color: var(--bill); }
.col__foot {
  margin-top: 16px;
  display: flex; justify-content: space-between; align-items: center;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.14em; text-transform: uppercase;
}
.col__foot .big {
  font-family: var(--font-sans);
  font-size: 20px; font-weight: 600;
  letter-spacing: -0.01em; text-transform: none;
  font-variant-numeric: tabular-nums;
}
.col--before .col__foot { color: var(--warn); }
.col--after .col__foot { color: var(--bill); }
.col--after .col__foot .big { color: white; }

/* Subtle running counter under "after" column */
.col__sweep {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--bill), transparent);
  background-size: 200% 100%;
  animation: colSweep 3.4s linear infinite;
}
@keyframes colSweep {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ============ Method strip ============ */
.methods {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
@media (max-width: 880px) { .methods { grid-template-columns: repeat(2, 1fr); } }
.method {
  border: 1px solid var(--hair);
  background: var(--paper-2);
  border-radius: 14px;
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 8px;
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}
.method:hover {
  transform: translateY(-3px);
  border-color: var(--bill);
  box-shadow: 0 12px 28px rgba(47,143,94,0.10);
}
.method__ic {
  width: 32px; height: 32px;
  border-radius: 10px;
  background: var(--bill-tile); color: var(--bill-deep);
  display: grid; place-items: center;
}
.method__ic svg { width: 16px; height: 16px; }
.method[data-tone="gold"] .method__ic { background: var(--gold-soft); color: var(--gold); }
.method[data-tone="rail"] .method__ic { background: var(--rail-soft); color: #1A5FA0; }
.method[data-tone="warn"] .method__ic { background: var(--warn-soft); color: var(--warn); }
.method[data-tone="ink"]  .method__ic { background: rgba(20,30,25,0.08); color: var(--ink); }
.method__t { font-size: 14px; font-weight: 500; letter-spacing: -0.005em; }
.method__d {
  font: 500 11px/1.4 var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}
.method__d b { color: var(--ink); font-weight: 500; }

/* Hero pill green accent */
.hero__pill .nub.is-bill { background: var(--bill); }

/* ============ Tweaks-friendly visual: deal counter chip ============ */
.hero__chip-row {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-top: 14px;
}
.hero__chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  color: var(--ink-mute);
}
.hero__chip b { color: var(--ink); font-weight: 500; }
.hero__chip .d {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--bill);
  box-shadow: 0 0 0 3px rgba(47,143,94,0.16);
}

/* ============ Closing CTA bill ============ */
.bill {
  position: relative;
  background: var(--paper-2);
  border: 1px solid var(--hair-2);
  border-radius: 24px;
  padding: 36px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 36px;
  align-items: center;
}
@media (max-width: 980px) { .bill { grid-template-columns: 1fr; } }
.bill__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(640px 360px at 90% 10%, rgba(68,186,130,0.16), transparent 70%),
    radial-gradient(560px 320px at 10% 90%, rgba(201,154,46,0.10), transparent 70%);
  pointer-events: none;
}
.bill__l { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 16px; }
.bill__l h2 {
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.0; letter-spacing: -0.02em;
  font-weight: 500; margin: 0;
}
.bill__l h2 em { font-family: var(--font-serif); font-style: italic; }
.bill__l p { color: var(--ink-mute); margin: 0; max-width: 44ch; }
.bill__cta-row { display: flex; gap: 10px; flex-wrap: wrap; }
.bill__r { position: relative; z-index: 1; }

/* Mini receipt visual */
.receipt {
  position: relative;
  background: var(--paper);
  border-radius: 14px;
  padding: 18px 20px 24px;
  box-shadow: 0 24px 50px rgba(20,30,25,0.08);
  background-image:
    radial-gradient(circle at 0 100%, transparent 8px, var(--paper) 8px),
    radial-gradient(circle at 100% 100%, transparent 8px, var(--paper) 8px);
  background-position: bottom left, bottom right;
  background-size: 50% 16px, 50% 16px;
  background-repeat: no-repeat;
  font-family: var(--font-mono);
  font-size: 12px;
}
.receipt::after {
  content: ""; position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 14px;
  background-image:
    repeating-linear-gradient(135deg, var(--paper-2) 0 8px, var(--paper) 8px 16px);
  -webkit-mask:
    radial-gradient(8px at 50% 100%, transparent 98%, #000 100%) repeat-x;
  -webkit-mask-size: 16px 16px;
  mask:
    radial-gradient(8px at 50% 100%, transparent 98%, #000 100%) repeat-x;
  mask-size: 16px 16px;
  display: none;
}
.receipt__h {
  display: flex; justify-content: space-between;
  font-size: 10px; letter-spacing: 0.16em;
  color: var(--ink-mute); text-transform: uppercase;
  margin-bottom: 12px;
  border-bottom: 1px dashed var(--hair-2);
  padding-bottom: 10px;
}
.receipt__row {
  display: flex; justify-content: space-between;
  padding: 5px 0;
  color: var(--ink-mute);
}
.receipt__row b { color: var(--ink); font-weight: 500; }
.receipt__row .amt {
  color: var(--ink); font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.receipt__total {
  display: flex; justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--hair-2);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}
.receipt__total .amt { color: var(--bill-deep); font-variant-numeric: tabular-nums; }
.receipt__stamp {
  margin-top: 14px;
  font: 600 10px/1 var(--font-mono);
  color: var(--bill-deep);
  letter-spacing: 0.18em;
  display: flex; align-items: center; gap: 8px;
  border: 1.5px dashed var(--bill);
  border-radius: 6px;
  padding: 7px 10px;
  background: var(--bill-soft);
}
.receipt__stamp .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--bill);
  animation: ringPulse 1.6s ease-out infinite;
}


/* ---- next block ---- */

.clai-skip{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.clai-skip:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;padding:10px 16px;background:#1a3d2a;color:#fff;border-radius:8px;text-decoration:none;font:600 14px/1 -apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;z-index:99999;box-shadow:0 4px 12px rgba(0,0,0,.2);outline:2px solid #fff;outline-offset:2px}