/* =========================================================================
   Momento Automation — "In Good Order"
   A reconciliation aesthetic for tax, bookkeeping & accounting firms.

   Palette is a semantic accounting tri-color:
     green = in the black (trust, action, resolved)
     red   = in the red   (the before/overdue pain — used sparingly)
     ember = the Momento brand spark (logo, live pulse, accents)
   Type: Newsreader (display serif) / IBM Plex Sans (body) / IBM Plex Mono (data).
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* paper */
  --paper:#FBFAF5;       /* warm fresh-sheet ivory */
  --paper-2:#F4F0E6;     /* secondary panel / ruled band */
  --sheet:#FFFFFF;       /* a clean sheet (cards) */

  /* ink */
  --ink:#16241D;         /* deep pine-ink near-black */
  --ink-2:#39453E;       /* body text */
  --ink-soft:#5E6A62;    /* muted sage-grey */

  /* rules */
  --rule:#E6E0D2;        /* warm hairline ledger rule */
  --rule-2:#D6CFBD;

  /* in the black */
  --green:#0F6B47;
  --green-2:#0B5236;     /* hover / deep */
  --green-soft:#E7F0EA;  /* tint bg */
  --green-line:#C5DCCD;

  /* in the red (pain only) */
  --flag:#B23A26;
  --flag-soft:#F6E5DF;

  /* Momento brand spark */
  --ember:#E2622E;
  --ember-2:#C44E1F;
  --ember-soft:#FBEADD;

  --shadow-sm:0 1px 2px rgba(22,36,29,.05), 0 2px 8px rgba(22,36,29,.04);
  --shadow:0 4px 14px rgba(22,36,29,.06), 0 18px 50px rgba(22,36,29,.08);
  --shadow-lg:0 10px 30px rgba(22,36,29,.08), 0 40px 90px rgba(22,36,29,.12);

  --max:1120px;
  --radius:16px;
}

html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body {
  background:var(--paper);
  color:var(--ink-2);
  font-family:'IBM Plex Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size:1.0625rem;          /* 17px — easy to read */
  line-height:1.7;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Subtle ruled-paper texture — the ledger lives on lined paper. */
body::before {
  content:'';
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:linear-gradient(var(--rule) 1px, transparent 1px);
  background-size:100% 32px;
  opacity:.30;
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 200px, #000 calc(100% - 200px), transparent);
  mask-image:linear-gradient(180deg, transparent, #000 200px, #000 calc(100% - 200px), transparent);
}

img { max-width:100%; display:block; }

/* ---- typography -------------------------------------------------------- */
h1, h2, h3 { color:var(--ink); font-weight:600; line-height:1.08; letter-spacing:-.02em; }

.display { font-family:'Newsreader', Georgia, 'Times New Roman', serif; font-weight:500; }
.serif-italic { font-family:'Newsreader', Georgia, serif; font-style:italic; font-weight:500; }

h1 {
  font-family:'Newsreader', Georgia, serif;
  font-weight:500;
  font-size:clamp(2.4rem, 4.4vw, 3.7rem);
  line-height:1.04;
  letter-spacing:-.022em;
}
h2 {
  font-family:'Newsreader', Georgia, serif;
  font-weight:500;
  font-size:clamp(1.9rem, 3.6vw, 2.9rem);
  line-height:1.08;
  letter-spacing:-.02em;
}
h3 { font-size:1.18rem; letter-spacing:-.01em; }

a { color:var(--green); text-decoration:none; transition:color .18s; }
a:hover { color:var(--green-2); }

strong { color:var(--ink); font-weight:600; }

/* The mono "data" voice: labels, figures, ledger entries. */
.mono { font-family:'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace; font-variant-numeric:tabular-nums; }

.label {
  font-family:'IBM Plex Mono', monospace;
  font-size:.72rem; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  color:var(--green); display:inline-flex; align-items:center; gap:9px;
}
.label::before { content:''; width:18px; height:1.5px; background:var(--green); display:inline-block; }
.label--center { justify-content:center; }

/* ---- layout ------------------------------------------------------------ */
.wrap { max-width:var(--max); margin:0 auto; padding:0 28px; }
.section { padding:96px 0; position:relative; }
.section-head { max-width:680px; }
.section-head--center { margin:0 auto; text-align:center; }
.section-head h2 { margin:14px 0 0; }
.lede { color:var(--ink-soft); font-size:1.1rem; line-height:1.7; margin-top:18px; }

/* ---- buttons ----------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:'IBM Plex Sans', sans-serif; font-weight:600; font-size:.98rem; line-height:1;
  padding:15px 26px; border-radius:11px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; white-space:nowrap;
  transition:background .18s, border-color .18s, color .18s, transform .12s, box-shadow .18s;
}
.btn:hover { transform:translateY(-2px); }
.btn:active { transform:translateY(0); }
.btn--go { background:var(--green); color:#fff; box-shadow:0 8px 22px rgba(15,107,71,.22); }
.btn--go:hover { background:var(--green-2); color:#fff; box-shadow:0 12px 28px rgba(15,107,71,.28); }
.btn--ghost { background:transparent; color:var(--ink); border-color:var(--rule-2); }
.btn--ghost:hover { background:var(--sheet); border-color:var(--ink-soft); color:var(--ink); }
.btn--block { width:100%; }
.btn-arrow { transition:transform .18s; }
.btn:hover .btn-arrow { transform:translateX(3px); }

/* ---- accessibility ----------------------------------------------------- */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, summary:focus-visible {
  outline:2.5px solid var(--ember); outline-offset:3px; border-radius:8px;
}
.svc-card > input:focus-visible + .svc-inner,
.svc-card > input:focus-visible + .svc-rec + .svc-inner {
  outline:2.5px solid var(--ember); outline-offset:3px;
}
.skip-link {
  position:absolute; left:-9999px; top:8px; z-index:200;
  background:var(--ink); color:#fff; padding:10px 18px; border-radius:8px; font-weight:600;
}
.skip-link:focus { left:16px; color:#fff; }

/* ======================================================================== */
/*  NAV                                                                       */
/* ======================================================================== */
.nav {
  position:sticky; top:0; z-index:100;
  background:rgba(251,250,245,.85);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--rule);
}
.nav-inner {
  max-width:var(--max); margin:0 auto; padding:14px 28px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.brand { display:flex; align-items:center; gap:11px; text-decoration:none; }
.brand-mark { width:30px; height:30px; flex-shrink:0; }
.brand-name { font-family:'Newsreader', serif; font-weight:600; font-size:1.32rem; color:var(--ink); letter-spacing:-.01em; }
.nav-links { display:flex; align-items:center; gap:30px; list-style:none; }
.nav-links a { color:var(--ink-soft); font-size:.92rem; font-weight:500; }
.nav-links a:hover { color:var(--ink); }
.nav-links .nav-cta {
  background:var(--green); color:#fff; padding:10px 18px; border-radius:9px; font-weight:600;
  box-shadow:0 6px 16px rgba(15,107,71,.20);
}
.nav-links .nav-cta:hover { background:var(--green-2); color:#fff; }

/* ======================================================================== */
/*  HERO — the self-reconciling worksheet                                    */
/* ======================================================================== */
.hero { padding:74px 0 88px; }
.hero-inner { display:grid; grid-template-columns:1.04fr .96fr; gap:56px; align-items:center; }
.hero-copy { max-width:540px; }
.hero h1 { margin:20px 0 0; }
.hero h1 .serif-italic {
  color:var(--ink);
  background-image:linear-gradient(var(--ember), var(--ember));
  background-size:100% .085em;
  background-position:0 92%;
  background-repeat:no-repeat;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
}
.hero-sub { margin-top:24px; font-size:1.16rem; line-height:1.65; color:var(--ink-soft); max-width:480px; }
.hero-ctas { display:flex; flex-wrap:wrap; gap:13px; margin-top:34px; }
.hero-reassure { margin-top:18px; font-size:.88rem; color:var(--ink-soft); display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hero-reassure .tick { color:var(--green); font-weight:700; }

.hero-trust { margin-top:40px; padding-top:26px; border-top:1px solid var(--rule); }
.hero-trust .mono { display:block; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
.hero-trust ul { list-style:none; display:flex; flex-wrap:wrap; gap:10px 22px; }
.hero-trust li { display:flex; align-items:center; gap:8px; font-size:.9rem; color:var(--ink-2); }
.hero-trust li::before { content:'✓'; color:var(--green); font-weight:700; }

/* --- the worksheet card --- */
.worksheet {
  background:var(--sheet); border:1px solid var(--rule-2); border-radius:18px;
  box-shadow:var(--shadow-lg); overflow:hidden; position:relative;
}
.worksheet-top {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:18px 22px; border-bottom:1px solid var(--rule);
  background:linear-gradient(var(--paper), var(--sheet));
}
.worksheet-title { font-family:'Newsreader',serif; font-weight:600; font-size:1.08rem; color:var(--ink); }
.worksheet-stamp { font-family:'IBM Plex Mono', monospace; font-size:.68rem; letter-spacing:.08em; color:var(--ink-soft); display:flex; align-items:center; gap:7px; }
.live-dot {
  width:8px; height:8px; border-radius:50%; background:var(--ember);
  box-shadow:0 0 0 0 rgba(226,98,46,.5); animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0% { box-shadow:0 0 0 0 rgba(226,98,46,.45); }
  70% { box-shadow:0 0 0 9px rgba(226,98,46,0); }
  100% { box-shadow:0 0 0 0 rgba(226,98,46,0); }
}

.recon-rows { padding:8px 0; }
.recon-row {
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:14px;
  padding:15px 22px; border-bottom:1px solid var(--rule); position:relative;
}
.recon-row:last-child { border-bottom:0; }
.recon-task { font-size:.95rem; color:var(--ink); font-weight:500; }
.recon-meta { font-family:'IBM Plex Mono', monospace; font-size:.74rem; color:var(--ink-soft); margin-top:3px; }

.chip {
  font-family:'IBM Plex Mono', monospace; font-size:.72rem; font-weight:500;
  padding:6px 11px; border-radius:100px; white-space:nowrap;
  display:inline-flex; align-items:center; gap:6px;
  transition:opacity .45s ease, transform .45s ease;
}
.chip--before { background:var(--flag-soft); color:var(--flag); }
.chip--after  { background:var(--green-soft); color:var(--green); }
.chip-slot { position:relative; display:inline-grid; }
.chip-slot > .chip { grid-area:1 / 1; }
.chip--after { opacity:0; transform:translateY(4px); }
.recon-row.is-done .chip--before { opacity:0; transform:translateY(-4px); }
.recon-row.is-done .chip--after  { opacity:1; transform:translateY(0); }

.worksheet-foot { padding:18px 22px; border-top:1.5px solid var(--rule-2); background:var(--paper-2); }
.balance-bar { height:8px; border-radius:100px; background:var(--rule-2); overflow:hidden; margin-bottom:13px; }
.balance-fill { height:100%; width:0; border-radius:100px; background:linear-gradient(90deg, var(--green), #1f9466); transition:width 2.6s cubic-bezier(.4,0,.2,1); }
.balance-row { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.balance-label { font-family:'IBM Plex Mono', monospace; font-size:.78rem; color:var(--ink-soft); letter-spacing:.04em; }
.balance-status { font-family:'IBM Plex Mono', monospace; font-size:.82rem; font-weight:600; color:var(--flag); display:inline-flex; align-items:center; gap:7px; transition:color .4s; }
.worksheet.is-settled .balance-status { color:var(--green); }
.balance-status .dot { width:7px; height:7px; border-radius:50%; background:currentColor; }

/* ======================================================================== */
/*  HOW IT WORKS — numbered ledger entries (order is real information)        */
/* ======================================================================== */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:54px; border-top:1px solid var(--rule-2); }
.step { padding:34px 30px 34px 0; border-bottom:1px solid var(--rule-2); position:relative; }
.steps .step:not(:last-child) { border-right:1px solid var(--rule-2); }
.steps .step:not(:first-child) { padding-left:30px; }
.step-index { font-family:'IBM Plex Mono', monospace; font-size:.78rem; font-weight:600; color:var(--green); letter-spacing:.06em; display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.step-index::after { content:''; flex:1; height:1px; background:var(--green-line); }
.step h3 { color:var(--ink); margin-bottom:10px; line-height:1.25; }
.step p { font-size:.96rem; color:var(--ink-soft); line-height:1.65; }
.step-tag { display:inline-block; margin-top:14px; font-family:'IBM Plex Mono', monospace; font-size:.68rem; letter-spacing:.06em; color:var(--green); background:var(--green-soft); padding:4px 10px; border-radius:6px; }

/* ======================================================================== */
/*  BUILDER — services are line items that sum to a running total            */
/* ======================================================================== */
.builder { background:var(--paper-2); border-top:1px solid var(--rule-2); border-bottom:1px solid var(--rule-2); }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; align-items:stretch; }
.svc-card { position:relative; display:block; cursor:pointer; }
.svc-card > input { position:absolute; opacity:0; width:1px; height:1px; pointer-events:none; }
.svc-inner {
  height:100%; display:flex; flex-direction:column;
  background:var(--sheet); border:1.5px solid var(--rule-2); border-radius:16px;
  padding:24px 22px; transition:border-color .2s, box-shadow .2s, transform .2s;
}
.svc-card:hover .svc-inner { transform:translateY(-3px); border-color:var(--green-line); box-shadow:var(--shadow); }
.svc-card.on .svc-inner { border-color:var(--green); box-shadow:0 0 0 1.5px var(--green), var(--shadow); }
.svc-top { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:15px; }
.svc-ix { font-family:'IBM Plex Mono', monospace; font-size:.72rem; font-weight:600; letter-spacing:.08em; color:var(--ink-soft); }
.svc-check { width:24px; height:24px; border-radius:7px; border:1.5px solid var(--rule-2); background:var(--paper); flex-shrink:0; position:relative; transition:all .2s; }
.svc-card.on .svc-check { background:var(--green); border-color:var(--green); }
.svc-card.on .svc-check::after { content:''; position:absolute; left:8px; top:4px; width:6px; height:11px; border:solid #fff; border-width:0 2.5px 2.5px 0; transform:rotate(45deg); }
.svc-rec {
  position:absolute; top:-11px; left:20px; z-index:2;
  background:var(--ember); color:#fff; font-family:'IBM Plex Mono',monospace;
  font-size:.64rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  padding:4px 11px; border-radius:100px; white-space:nowrap;
}
.svc-name { font-family:'Newsreader',serif; font-weight:600; font-size:1.18rem; color:var(--ink); margin-bottom:9px; line-height:1.2; }
.svc-desc { font-size:.88rem; color:var(--ink-soft); line-height:1.55; margin-bottom:14px; }
.svc-eg { font-size:.82rem; color:var(--ink-2); line-height:1.5; margin-bottom:15px; padding:12px 14px; background:var(--green-soft); border-left:2.5px solid var(--green); border-radius:0 8px 8px 0; }
.svc-eg-tag { display:block; font-family:'IBM Plex Mono',monospace; font-size:.62rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--green); margin-bottom:5px; }
.svc-feats { list-style:none; display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.svc-feats li { display:flex; gap:9px; align-items:flex-start; font-size:.83rem; color:var(--ink-2); line-height:1.45; }
.svc-feats li::before { content:'✓'; color:var(--green); font-weight:700; font-size:.82rem; flex-shrink:0; margin-top:1px; }
.svc-price { display:flex; justify-content:space-between; align-items:baseline; gap:10px; padding-top:14px; border-top:1px solid var(--rule); margin-top:auto; }
.svc-price .s { font-family:'IBM Plex Mono',monospace; font-size:.78rem; color:var(--ink-soft); }
.svc-price .s b { color:var(--ink); font-weight:600; font-size:.95rem; }
.svc-price .m b { color:var(--green); }
.svc-note { font-size:.72rem; color:var(--ink-soft); margin-top:11px; line-height:1.45; font-style:italic; }

.builder-total { margin-top:26px; background:var(--sheet); border:1.5px solid var(--green); border-radius:18px; box-shadow:var(--shadow); overflow:hidden; }
.bt-head { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; padding:22px 28px; border-bottom:1px dashed var(--rule-2); }
.bt-count { font-family:'IBM Plex Mono',monospace; font-size:.86rem; color:var(--ink-soft); font-weight:500; }
.bt-badge { display:inline-block; margin-left:12px; font-family:'IBM Plex Mono',monospace; font-size:.7rem; font-weight:600; color:var(--green); background:var(--green-soft); border:1px solid var(--green-line); padding:3px 10px; border-radius:100px; }
.bt-figs { display:flex; gap:38px; align-items:flex-end; flex-wrap:wrap; }
.bt-fig { display:flex; flex-direction:column; gap:4px; }
.bt-fig .lbl { font-family:'IBM Plex Mono',monospace; font-size:.66rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-soft); font-weight:500; }
.bt-fig .val { font-family:'IBM Plex Mono',monospace; font-weight:600; font-size:1.7rem; line-height:1; color:var(--ink); }
.bt-fig .val.mo { color:var(--green); }
.bt-fig .val small { font-size:.78rem; color:var(--ink-soft); font-weight:400; }
.bt-body { padding:20px 28px 24px; }
.bt-cta { display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.bt-nudge { font-family:'IBM Plex Mono',monospace; font-size:.8rem; color:var(--ember-2); font-weight:500; }
.bt-note { font-size:.84rem; color:var(--ink-soft); margin-top:16px; line-height:1.6; }
.bt-note strong { color:var(--ink); }
.bt-custom { color:var(--ink-2); background:var(--green-soft); border:1px solid var(--green-line); border-radius:10px; padding:12px 14px; }

/* ======================================================================== */
/*  LIVE DEMO                                                                 */
/* ======================================================================== */
.demo-note { text-align:center; margin-top:30px; font-size:.92rem; color:var(--ink-soft); }
.demo-note strong { color:var(--ink); }
.demo-label { text-align:center; margin:56px 0 0; }
.demo-frame-wrap { margin-top:26px; border:1px solid var(--rule-2); border-radius:18px; overflow:hidden; background:var(--sheet); box-shadow:var(--shadow); }
.demo-frame { display:block; width:100%; height:880px; border:0; }
.demo-caption { text-align:center; margin-top:15px; font-size:.82rem; color:var(--ink-soft); }
.demo-cta { text-align:center; margin-top:32px; }

/* ======================================================================== */
/*  FAQ                                                                       */
/* ======================================================================== */
.faq-list { margin-top:44px; border-top:1px solid var(--rule-2); }
.faq-item { border-bottom:1px solid var(--rule-2); }
.faq-item summary {
  list-style:none; cursor:pointer; padding:24px 44px 24px 0; position:relative;
  font-family:'Newsreader',serif; font-weight:600; font-size:1.2rem; color:var(--ink); display:block;
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:'+'; position:absolute; right:6px; top:50%; transform:translateY(-50%); font-family:'IBM Plex Mono',monospace; font-size:1.5rem; color:var(--green); font-weight:400; transition:transform .2s; }
.faq-item[open] summary::after { content:'–'; }
.faq-item p { padding:0 44px 26px 0; color:var(--ink-soft); font-size:1rem; line-height:1.7; }

/* ======================================================================== */
/*  CONTACT + FORM                                                            */
/* ======================================================================== */
.contact-split { display:grid; grid-template-columns:1fr 1.04fr; gap:52px; align-items:center; }
.contact-pitch { max-width:440px; }
.contact-pitch h2 { margin:14px 0 18px; }
.contact-pitch > p { color:var(--ink-soft); font-size:1.08rem; line-height:1.7; margin-bottom:28px; }
.contact-or { display:flex; flex-direction:column; align-items:flex-start; gap:13px; padding-top:24px; border-top:1px solid var(--rule); }
.contact-or span { font-size:.92rem; color:var(--ink-soft); }
.intk-wrap { background:var(--sheet); border:1px solid var(--rule-2); border-radius:18px; padding:34px 32px; box-shadow:var(--shadow); }
.intk-form { display:flex; flex-direction:column; gap:16px; }
.intk-head { margin-bottom:6px; }
.intk-head h3 { font-family:'Newsreader',serif; font-size:1.4rem; color:var(--ink); margin-bottom:6px; }
.intk-head p { color:var(--ink-soft); font-size:.92rem; }
.intk-row { display:flex; gap:14px; }
.intk-row > div { flex:1; }
.intk-field { display:flex; flex-direction:column; gap:7px; }
.intk-field label { font-size:.84rem; font-weight:600; color:var(--ink); }
.intk-field label .opt { color:var(--ink-soft); font-weight:400; }
.intk-field .req { color:var(--ember-2); }
.intk-input, .intk-select, .intk-textarea {
  width:100%; background:var(--paper); border:1.5px solid var(--rule-2); border-radius:10px;
  padding:12px 14px; color:var(--ink); font-family:'IBM Plex Sans',sans-serif; font-size:.95rem;
  transition:border-color .18s, box-shadow .18s;
}
.intk-input::placeholder, .intk-textarea::placeholder { color:var(--ink-soft); opacity:.8; }
.intk-input:focus, .intk-select:focus, .intk-textarea:focus { outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(15,107,71,.13); }
.intk-textarea { min-height:96px; resize:vertical; }
.intk-select {
  appearance:none; -webkit-appearance:none; padding-right:38px; cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%235E6A62' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:right 14px center;
}
.intk-consent { display:flex; gap:12px; align-items:flex-start; background:var(--green-soft); border:1px solid var(--green-line); border-radius:12px; padding:14px 16px; }
.intk-consent input[type=checkbox] { width:18px; height:18px; flex-shrink:0; margin-top:1px; accent-color:var(--green); cursor:pointer; }
.intk-consent label { font-size:.78rem; color:var(--ink-soft); line-height:1.55; cursor:pointer; font-weight:400; }
.intk-submit {
  margin-top:4px; background:var(--green); color:#fff; font-family:'IBM Plex Sans',sans-serif;
  font-weight:600; font-size:.98rem; padding:15px; border:none; border-radius:11px; cursor:pointer;
  transition:background .18s, transform .12s, opacity .2s; box-shadow:0 8px 22px rgba(15,107,71,.2);
}
.intk-submit:hover { background:var(--green-2); transform:translateY(-1px); }
.intk-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.intk-err { display:none; color:var(--flag); font-size:.82rem; text-align:center; font-weight:500; }
.intk-foot { text-align:center; font-size:.76rem; color:var(--ink-soft); }
.intk-done { display:none; text-align:center; padding:26px 8px; }
.intk-done h3 { font-family:'Newsreader',serif; font-size:1.45rem; color:var(--green); margin-bottom:10px; }
.intk-done p { color:var(--ink-soft); font-size:.95rem; line-height:1.65; }

/* ======================================================================== */
/*  FOOTER                                                                    */
/* ======================================================================== */
.footer { border-top:1px solid var(--rule-2); background:var(--paper-2); }
.footer-inner { max-width:var(--max); margin:0 auto; padding:30px 28px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.footer p { font-size:.84rem; color:var(--ink-soft); }
.footer-links { display:flex; gap:24px; flex-wrap:wrap; }
.footer-links a { font-size:.84rem; color:var(--ink-soft); }
.footer-links a:hover { color:var(--green); }

/* ======================================================================== */
/*  LEGAL PAGES (privacy / terms)                                             */
/* ======================================================================== */
.legal-wrap { max-width:760px; margin:0 auto; padding:64px 28px 80px; }
.legal-wrap h1 { font-size:clamp(2.1rem,5vw,3.2rem); margin:14px 0 12px; }
.legal-updated { font-family:'IBM Plex Mono',monospace; font-size:.82rem; color:var(--ink-soft); margin-bottom:40px; padding-bottom:28px; border-bottom:1px solid var(--rule-2); }
.legal-highlight { background:var(--green-soft); border:1px solid var(--green-line); border-radius:12px; padding:20px 24px; margin-bottom:36px; }
.legal-highlight p { color:var(--ink-2); margin:0; }
.legal-section { margin-bottom:36px; }
.legal-section h2 { font-size:1.3rem; font-family:'Newsreader',serif; font-weight:600; margin-bottom:13px; }
.legal-section p { color:var(--ink-2); font-size:1rem; line-height:1.75; margin-bottom:13px; }
.legal-section p:last-child { margin-bottom:0; }
.legal-section ul { list-style:none; display:flex; flex-direction:column; gap:9px; margin:0 0 13px; }
.legal-section ul li { display:flex; gap:11px; align-items:flex-start; color:var(--ink-2); font-size:1rem; line-height:1.7; }
.legal-section ul li::before { content:'→'; color:var(--green); font-weight:700; flex-shrink:0; margin-top:2px; }
.nav-back { color:var(--ink-soft); font-size:.9rem; font-weight:500; display:inline-flex; align-items:center; gap:6px; }
.nav-back:hover { color:var(--green); }

/* ======================================================================== */
/*  RESPONSIVE                                                                */
/* ======================================================================== */
@media (max-width:920px) {
  .hero-inner { grid-template-columns:1fr; gap:44px; }
  .hero-copy { max-width:none; }
  .worksheet { max-width:520px; }
  .contact-split { grid-template-columns:1fr; gap:36px; }
  .contact-pitch { max-width:none; }
}
@media (max-width:760px) {
  .section { padding:68px 0; }
  .nav-links li.nav-hide { display:none; }
  .steps { grid-template-columns:1fr; }
  .steps .step { border-right:0 !important; padding:28px 0 !important; }
  .steps .step:first-child { padding-top:30px !important; }
  .svc-grid { grid-template-columns:1fr; }
  .bt-head { flex-direction:column; align-items:flex-start; }
  .intk-row { flex-direction:column; gap:16px; }
  .demo-frame { height:1040px; }
  .footer-inner { flex-direction:column; text-align:center; }
}
@media (max-width:420px) {
  .wrap { padding:0 20px; }
  .hero-ctas .btn { width:100%; }
}

/* ======================================================================== */
/*  REDUCED MOTION — render the settled, reconciled state immediately         */
/* ======================================================================== */
@media (prefers-reduced-motion:reduce) {
  * { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .recon-row .chip--before { opacity:0; }
  .recon-row .chip--after { opacity:1; transform:none; }
  .balance-fill { width:100% !important; transition:none; }
  .live-dot { animation:none; }
}
