@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* ============================================================
   FTEngine — landing page styles
   Tokens are FROZEN (from the design system). The only additions,
   pre-approved in HANDOFF_LANDING §"Proposed additions":
   display H1, dark band, FAQ accordion, pricing highlight.
   ============================================================ */

:root{
  --paper:#FBF9F4; --surface:#FFFFFF; --ink:#202A44; --ink-hover:#2C3A60;
  --gold:#E9C04C; --gray-warm:#8B8678;
  --border-soft:#E2DCC7; --border-strong:#C9C2AE; --dot-idle:#DDD7C6;
  --success:#3E7A52; --success-tint:#E7EFE4;
  --warning:#C97B2E; --warning-tint:#F6E9D7;
  --danger:#B5503C;  --danger-tint:#F4DFD9;
  --r-card:12px; --r-control:8px; --r-badge:6px; --r-seg:4px;
  --font-ui:'Space Grotesk',system-ui,sans-serif;
  --font-data:'IBM Plex Mono',ui-monospace,monospace;
  --container:1120px;
  --overlay:rgba(32,42,68,.45);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{margin:0;background:var(--paper);color:var(--ink);font:400 15px/1.5 var(--font-ui);-webkit-font-smoothing:antialiased}
.mono{font-family:var(--font-data)}
a{color:inherit}
h1,h2,h3,p{margin:0}
img,svg{display:block}
:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
.container{max-width:var(--container);margin:0 auto;width:100%;padding:0 24px}
.eyebrow{font:500 12px/1.4 var(--font-data);letter-spacing:.04em;text-transform:uppercase;color:var(--gray-warm);margin:0 0 14px}

/* ====== Wordmark ====== */
.wordmark{font:500 22px/1 var(--font-ui);white-space:nowrap;color:var(--ink);user-select:none;display:inline-block;text-decoration:none}
.wordmark .hl{background:var(--gold);padding:0 .14em;border-radius:.12em}
.wordmark.lg{font-size:30px}

/* ====== Buttons ====== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:42px;padding:0 20px;border-radius:var(--r-control);font:500 14px var(--font-ui);cursor:pointer;border:1px solid transparent;background:none;color:var(--ink);transition:background .12s,color .12s,border-color .12s;white-space:nowrap;text-decoration:none}
.btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--ink-hover)}
.btn-secondary{background:var(--surface);border-color:var(--border-strong)}
.btn-secondary:hover{background:var(--paper)}
.btn-quiet{color:var(--gray-warm);padding:0 10px}
.btn-quiet:hover{color:var(--ink)}
.btn-block{width:100%}
.btn-sm{height:36px;padding:0 14px;font-size:13px}
/* Inverted primary — for the dark band only (paper bg, ink text) */
.btn-inverted{background:var(--paper);color:var(--ink)}
.btn-inverted:hover{background:#fff}

/* ====== Chips / badges ====== */
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--border-soft);border-radius:var(--r-control);padding:8px 12px;font:400 13px var(--font-data)}
.badge{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:var(--r-badge);font:500 12px var(--font-ui);white-space:nowrap}
.badge-gold{background:var(--gold);color:var(--ink)}

/* ====== Cards ====== */
.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);padding:24px}

/* ====== Nav ====== */
.nav{position:sticky;top:0;z-index:40;background:var(--paper);transition:border-color .15s,background .15s}
.nav.scrolled{border-bottom:1px solid var(--border-soft);background:rgba(251,249,244,.92);backdrop-filter:none}
.nav .container{height:64px;display:flex;align-items:center;gap:28px}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-link{background:none;border:0;font:400 14px var(--font-ui);color:var(--gray-warm);cursor:pointer;padding:8px 12px;border-radius:6px;text-decoration:none}
.nav-link:hover{color:var(--ink)}
.nav-spacer{flex:1}
.nav-cta{display:flex;align-items:center;gap:6px}
.nav-toggle{display:none;width:40px;height:40px;border:1px solid var(--border-strong);border-radius:var(--r-control);background:var(--surface);cursor:pointer;align-items:center;justify-content:center;color:var(--ink)}

/* ====== Sections ====== */
section{padding:96px 0}
.sec-head{max-width:680px;margin:0 0 44px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
h2.sec-title{font:500 28px/1.2 var(--font-ui);letter-spacing:-.01em}
.sec-sub{font-size:17px;color:var(--gray-warm);margin-top:12px;text-wrap:pretty}

/* ====== Hero ====== */
.hero{padding:72px 0 88px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font:500 40px/1.15 var(--font-ui);letter-spacing:-.015em;margin:0 0 20px;text-wrap:balance}
.hero-sub{font-size:18px;line-height:1.55;color:var(--ink);max-width:33em;text-wrap:pretty}
.hero-ctas{display:flex;gap:12px;margin:32px 0 18px;flex-wrap:wrap}
.hero-micro{font:400 12px/1.6 var(--font-data);color:var(--gray-warm);text-wrap:pretty}

/* ====== Laptop frame ====== */
.laptop{width:100%;display:flex;flex-direction:column;align-items:center;filter:drop-shadow(0 22px 38px rgba(32,42,68,.22))}
.laptop-screen{width:100%;background:#1b2238;border:1px solid #2a3454;border-radius:16px 16px 8px 8px;padding:18px 12px 12px;position:relative}
.laptop-screen::before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:#3a456a}
.screen-view{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;background:var(--surface)}
.screen-view .browser,.screen-view .sheet{position:absolute;top:0;left:0;width:880px;height:495px;transform-origin:0 0;transform:scale(var(--s,0.5))}
.laptop-base{width:116%;height:14px;background:linear-gradient(#d4cfc0,#bdb7a4);border:1px solid #b0aa97;border-top:0;border-radius:0 0 12px 12px;position:relative}
.laptop-base::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:88px;height:7px;background:#a9a390;border-radius:0 0 7px 7px}

/* ====== Hero mock — shown inside a browser window ====== */
.browser{background:var(--surface);border:none;border-radius:0;overflow:hidden;display:flex;flex-direction:column;height:100%}
.browser-app{flex:1;min-height:0;display:flex;flex-direction:column}
.browser-chrome{display:flex;align-items:center;gap:8px;padding:14px 16px;background:var(--paper);border-bottom:1px solid var(--border-soft)}
.browser-chrome .tl{width:11px;height:11px;border-radius:50%;background:var(--dot-idle)}
.urlbar{flex:1;display:flex;align-items:center;gap:7px;height:30px;margin-left:8px;padding:0 14px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-control);font:400 13px var(--font-data);color:var(--gray-warm)}
.urlbar svg{flex:none;color:var(--gray-warm)}
.browser-app{padding:0}
.app-top{display:flex;align-items:center;gap:18px;padding:14px 26px;border-bottom:1px solid var(--border-soft)}
.app-nav{display:flex;gap:18px;font:400 14px var(--font-ui);color:var(--gray-warm);margin-left:4px}
.app-nav .cur{color:var(--ink)}
.app-avatar{margin-left:auto;width:32px;height:32px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;font:500 12px var(--font-data)}
.mock{padding:26px 30px;flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center}
.mock-bar{display:flex;align-items:center;gap:7px;margin-bottom:18px}
.mock-dot{width:9px;height:9px;border-radius:50%;background:var(--dot-idle)}
.mock-file{margin-left:6px;font:400 13px var(--font-data);color:var(--gray-warm)}
.mock-label{font:400 14px var(--font-data);color:var(--gray-warm);margin:0 0 14px}
.mock-pct{font:500 48px/1 var(--font-ui);margin:0 0 20px}
.hl-value{background:var(--gold);color:var(--ink);padding:0 .12em;border-radius:.1em}
.segbar{display:flex;gap:6px;width:100%}
.seg{flex:1;height:12px;border-radius:var(--r-seg);background:var(--dot-idle)}
.seg.on{background:var(--gold)}
.steps{list-style:none;margin:24px 0 0;padding:0;font-size:15px}
.steps li{display:flex;align-items:center;gap:11px;padding:7px 0;color:var(--ink)}
.steps li.done{color:var(--success)}
.steps li.wait{color:var(--gray-warm)}
.steps svg{flex:none}
.spin{width:14px;height:14px;border:2px solid var(--dot-idle);border-top-color:var(--ink);border-radius:50%;animation:spin 1s linear infinite;flex:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ====== Context strip ====== */
.context{padding:0 0 8px}
.context-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.context-cell{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);padding:20px;font-size:14px;line-height:1.45;display:flex;gap:12px;align-items:flex-start}
.context-cell svg{flex:none;color:var(--ink);margin-top:1px}

/* ====== Generic card grid ====== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature-card h3{font:500 17px var(--font-ui);margin:0 0 8px}
.feature-card p{font-size:14px;line-height:1.5;color:var(--gray-warm)}

/* Benefit card — the mirror of the problem grid */
.benefit-card{position:relative;border-color:var(--border-strong)}
.benefit-card .b-head{display:flex;align-items:flex-start;gap:10px;margin:0 0 8px}
.benefit-card .b-tick{flex:none;width:22px;height:22px;border-radius:6px;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;margin-top:1px}
.benefit-card h3{font:500 17px/1.25 var(--font-ui);margin:0}
.benefit-card p{font-size:14px;line-height:1.5;color:var(--gray-warm)}

/* ====== Feature blocks (split) ====== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.mirror .split-text{order:2}
.split.mirror .split-visual{order:1}
.lead{font-size:17px;line-height:1.55;color:var(--ink);margin:14px 0 24px;text-wrap:pretty}
.blist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.blist li{display:flex;gap:12px;align-items:flex-start;font-size:14px;line-height:1.5}
.blist .tick{color:var(--ink);flex:none;margin-top:2px}
.blist b{font-weight:500;color:var(--ink)}
.blist span{color:var(--gray-warm)}
.out-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.subnote{margin-top:26px;border-top:1px solid var(--border-soft);padding-top:22px}
.subnote h4{font:500 14px var(--font-ui);margin:0 0 6px}
.subnote p{font-size:13px;line-height:1.5;color:var(--gray-warm)}

/* ====== Matrix mock ====== */
.matrix-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);overflow:hidden}
.matrix-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-soft)}
.matrix-head .t{font:400 12px var(--font-data);color:var(--gray-warm)}
.mtable{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}
.mtable th,.mtable td{padding:9px 10px;border-top:1px solid var(--border-soft);text-align:center}
.mtable thead th{border-top:0;border-bottom:1px solid var(--border-strong);background:var(--paper);font-weight:500;color:var(--ink);font-size:11px}
.mtable thead th:first-child,.mtable td:first-child{text-align:left}
.mtable td:first-child{font-family:var(--font-data);font-size:11px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mcell{display:inline-flex;width:22px;height:22px;border-radius:6px;align-items:center;justify-content:center}
.mcell.ok{background:var(--success-tint);color:var(--success)}
.mcell.warn{background:var(--warning-tint);color:var(--warning)}
.mcell.bad{background:var(--danger-tint);color:var(--danger)}
.matrix-foot{display:flex;align-items:center;gap:8px;padding:11px 18px;border-top:1px solid var(--border-soft);background:var(--danger-tint);color:var(--danger);font-size:12px}
.matrix-foot svg{flex:none}

/* ====== Two app screens (16:9), stacked beside the text ====== */
.shot-stack{display:flex;flex-direction:column;gap:30px}
.shot{margin:0}
.shot .screen-view{border:1px solid var(--border-soft);box-shadow:0 16px 34px -20px rgba(32,42,68,.32)}
.shot-cap{font:400 13px var(--font-data);color:var(--gray-warm);margin-top:12px}

/* CV document at 880-wide design scale */
.browser .doc-page{flex:1;min-height:0;padding:22px 44px;overflow:hidden}
.browser .doc-kicker{font:500 14px var(--font-data);letter-spacing:.03em;text-transform:uppercase;color:var(--gray-warm);margin:0 0 6px}
.browser .doc-name{font:500 27px var(--font-ui);margin:0 0 12px}
.browser .doc-h{font:500 14px var(--font-data);letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border-soft)}
.browser .doc-entry{margin:0 0 8px}
.browser .doc-meta{font:400 16px var(--font-data);color:var(--gray-warm);margin:0 0 5px}
.browser .doc-role{font:500 19px var(--font-ui);color:var(--ink);margin:0 0 6px}
.browser .doc-body{font:400 16px/1.5 var(--font-ui);color:var(--ink);margin:0}
.hi{background:var(--warning-tint);color:var(--warning);border-radius:4px;padding:1px 6px;font-family:var(--font-data);font-size:.9em}

/* Spreadsheet screen */
.sheet{display:flex;flex-direction:column;background:var(--surface)}
.sheet-bar{display:flex;align-items:center;gap:9px;padding:16px 20px;border-bottom:1px solid var(--border-soft);background:var(--paper);font:400 17px var(--font-data);color:var(--ink)}
.sheet-bar .tl{width:12px;height:12px;border-radius:50%;background:var(--dot-idle)}
.sheet-bar .tab-badge{margin-left:auto;height:30px;display:inline-flex;align-items:center;padding:0 13px;font-size:14px;background:var(--surface);border:1px solid var(--border-strong);color:var(--gray-warm)}
.sheet .mtable{font-size:17px}
.sheet .mtable th,.sheet .mtable td{padding:15px 18px}
.sheet .mtable thead th{font-size:15px}
.sheet .mtable td:first-child{font-size:15px}
.sheet .mcell{width:30px;height:30px;border-radius:7px}
.sheet .matrix-foot{margin-top:auto;font-size:16px;padding:16px 20px}

/* ====== Before/after mock ====== */
.ba{display:flex;flex-direction:column;gap:14px}
.ba-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);padding:18px}
.ba-tag{font:400 11px var(--font-data);text-transform:uppercase;letter-spacing:.05em;color:var(--gray-warm);margin:0 0 10px}
.ba-text{font-size:13.5px;line-height:1.6;color:var(--ink)}
.ba-arrow{display:flex;justify-content:center;color:var(--gray-warm)}
.kw{font-weight:500;color:var(--ink)}

/* ====== How it works ====== */
.steps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.step-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);padding:22px}
.step-idx{font:500 13px var(--font-data);color:var(--gray-warm);margin:0 0 14px}
.step-card h3{font:500 16px var(--font-ui);margin:0 0 7px}
.step-card p{font-size:13.5px;line-height:1.5;color:var(--gray-warm)}
.hiw-close{margin-top:28px;font-size:15px;color:var(--ink);max-width:620px}
.hiw-bar{margin-top:32px}

/* ====== Pricing ====== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.price-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-card);padding:28px;display:flex;flex-direction:column}
.price-card.pop{border:2px solid var(--ink);padding:27px}
.price-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;min-height:24px}
.price-name{font:500 16px var(--font-ui)}
.price-amount{font:500 34px/1 var(--font-ui);letter-spacing:-.01em}
.price-amount .per{font:400 14px var(--font-ui);color:var(--gray-warm)}
.price-vol{font:400 13px var(--font-data);color:var(--ink);margin:10px 0 0}
.price-desc{font-size:14px;line-height:1.5;color:var(--gray-warm);margin:16px 0 24px;flex:1}
.price-foot{font-size:13px;line-height:1.6;color:var(--gray-warm);max-width:760px;margin:28px auto 0;text-align:center;text-wrap:pretty}
.price-foot a{color:var(--gray-warm);text-decoration:underline;text-underline-offset:2px}
.price-foot a:hover{color:var(--ink)}

/* ====== FAQ accordion ====== */
.faq{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border-soft)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 4px;font:500 15px var(--font-ui);color:var(--ink);text-align:left}
.faq-q:hover{color:var(--ink)}
.faq-chev{flex:none;color:var(--gray-warm);transition:transform .2s ease}
.faq-q[aria-expanded="true"] .faq-chev{transform:rotate(180deg)}
.faq-a{overflow:hidden;height:0}
.faq-a-inner{padding:0 4px 22px;font-size:14px;line-height:1.6;color:var(--gray-warm);max-width:64ch;text-wrap:pretty}

/* ====== Dark final CTA band ====== */
.band{background:var(--ink);color:var(--paper);border-radius:0;padding:96px 0}
.band .inner{max-width:680px;margin:0 auto;text-align:center}
.band h2{font:500 28px/1.2 var(--font-ui);letter-spacing:-.01em;color:var(--paper)}
.band p{font-size:17px;line-height:1.55;color:rgba(251,249,244,.78);margin:14px 0 32px;text-wrap:pretty}
.band-ctas{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}
.band .btn-quiet{color:rgba(251,249,244,.7)}
.band .btn-quiet:hover{color:var(--paper)}

/* ====== Footer ====== */
.footer{padding:56px 0 48px}
.footer-grid{display:flex;align-items:flex-start;justify-content:space-between;gap:32px;flex-wrap:wrap}
.footer-line{font:400 12px var(--font-data);color:var(--gray-warm);margin-top:14px}
.footer-links{display:flex;gap:8px 18px;flex-wrap:wrap;font-size:13px}
.footer-links a{color:var(--gray-warm);text-decoration:none}
.footer-links a:hover{color:var(--ink)}
.dots{display:flex;gap:9px;align-items:center;margin-top:24px}
.dots i{width:5px;height:5px;border-radius:50%;background:var(--dot-idle)}
.dots i.g{width:6px;height:6px;background:var(--gold)}

/* ====== Modal ====== */
.overlay{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;padding:24px;z-index:60;opacity:0;pointer-events:none;transition:opacity .2s ease}
.overlay.open{opacity:1;pointer-events:auto}
.modal{background:var(--surface);border-radius:var(--r-card);width:100%;max-width:400px;padding:28px;position:relative;transform:translateY(8px);transition:transform .2s ease}
.overlay.open .modal{transform:translateY(0)}
.modal-x{position:absolute;top:14px;right:14px;width:32px;height:32px;border:0;background:none;border-radius:var(--r-control);cursor:pointer;color:var(--gray-warm);display:flex;align-items:center;justify-content:center}
.modal-x:hover{color:var(--ink);background:var(--paper)}
.modal h3{font:500 20px var(--font-ui);margin:0 0 8px}
.modal .msub{font-size:14px;line-height:1.5;color:var(--gray-warm);margin:0 0 22px}
.field{display:flex;flex-direction:column;margin-bottom:14px}
.fl{font-size:13px;color:var(--gray-warm);margin:0 0 6px}
.input{height:38px;padding:0 12px;border:1px solid var(--border-strong);border-radius:var(--r-control);background:var(--surface);font:400 14px var(--font-ui);color:var(--ink);width:100%}
.input::placeholder{color:var(--gray-warm)}
.input:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-color:var(--ink)}
.input.err{border-color:var(--danger)}
.msg-err{font-size:12px;color:var(--danger);margin:6px 0 0}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden}
.modal-done{text-align:center;padding:8px 0}
.modal-done .check{width:52px;height:52px;border-radius:50%;background:var(--success-tint);color:var(--success);display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}
.modal-done h3{margin-bottom:8px}
.modal-done p{font-size:14px;line-height:1.5;color:var(--gray-warm);margin:0 0 22px}

/* ====== Responsive ====== */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .split,.split.mirror{grid-template-columns:1fr;gap:36px}
  .split.mirror .split-text,.split.mirror .split-visual{order:initial}
  .context-grid{grid-template-columns:1fr 1fr}
  .steps-grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .two-screens{grid-template-columns:1fr}
  .blist.cols2{grid-template-columns:1fr}
  .grid-3,.price-grid{grid-template-columns:1fr}
  .price-card.pop{order:-1}
}
@media (max-width:680px){
  section{padding:64px 0}
  .hero h1{font-size:28px}
  h2.sec-title{font-size:24px}
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .nav-cta .btn-login{display:none}
  .context-grid{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .footer-grid{flex-direction:column}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .spin{animation:none}
  .faq-chev,.faq-a,.overlay,.modal{transition:none}
}
