/* ============================================================
   AutoPresent — reusable feature-page sections
   Shared across the 6 core features. Content is driven by a
   per-page  window.FEATURE  config + static/js/feature-page.js
   Brand: teal #077A8D · navy #162355 · teal panel #21657F
   Headings: Crimson Pro · Body: Hanken Grotesk
   ============================================================ */
body { font-family: 'Hanken Grotesk', system-ui, sans-serif; color: #374151; }

/* Mirror the site's Tailwind `container mx-auto px-4 md:px-6` so feature
   content lines up with the header logo / homepage / smart-templates. */
.ft-wrap { width: 100%; margin-left: auto; margin-right: auto; padding-left: 1rem; padding-right: 1rem; }
@media (min-width: 640px)  { .ft-wrap { max-width: 640px; } }
@media (min-width: 768px)  { .ft-wrap { max-width: 768px; padding-left: 1.5rem; padding-right: 1.5rem; } }
@media (min-width: 1024px) { .ft-wrap { max-width: 1024px; } }
@media (min-width: 1280px) { .ft-wrap { max-width: 1280px; } }
@media (min-width: 1536px) { .ft-wrap { max-width: 1536px; } }

/* ---------- Hero ---------- */
.ft-hero { padding: 52px 0 40px; }
@media (min-width: 1024px) { .ft-hero { padding: 84px 0 64px; } }
.ft-hero-grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
@media (min-width: 1024px) { .ft-hero-grid { grid-template-columns: 0.68fr 1.32fr; gap: 44px; } }
.ft-hero .ft-body { max-width: 27rem; }

.ft-eyebrow { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: #077A8D; background: #EAF6F8; padding: 6px 12px; border-radius: 9999px; margin-bottom: 22px; }
.ft-title { font-family: 'Crimson Pro', Georgia, serif; font-weight: 300; color: #162355; font-size: clamp(2.6rem, 5vw, 4rem); line-height: 1.04; letter-spacing: -0.01em; margin-bottom: 18px; }
.ft-subtitle { font-family: 'Hanken Grotesk', system-ui, sans-serif; font-weight: 400; color: #575757; font-size: 1rem; line-height: 1.625; max-width: 36rem; margin-bottom: 30px; }
@media (min-width: 768px) { .ft-subtitle { font-size: 1.125rem; } }
.ft-body { font-size: 1.02rem; line-height: 1.65; color: #5B6573; max-width: 34rem; margin-bottom: 30px; }
.ft-cta-row { display: flex; flex-wrap: wrap; gap: 14px; }
.ft-btn { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; padding: 13px 24px; border-radius: 11px; cursor: pointer; transition: all 0.2s ease; }
.ft-btn svg { width: 16px; height: 16px; }
.ft-btn-primary { background: #162355; color: #fff; border: 1px solid #162355; }
.ft-btn-primary:hover { background: #0f1a40; transform: translateY(-1px); }
.ft-btn-secondary { background: #fff; color: #162355; border: 1px solid #E2E6EC; }
.ft-btn-secondary:hover { border-color: #162355; }

/* Hero CTAs — exact match to the index.html hero (btn-style700 family from main.css) */
.ft-hero .btn-style700-primary,
.ft-hero .btn-style700-teal {
    font-family: 'Hanken Grotesk', system-ui, sans-serif;
    font-weight: 300;
    letter-spacing: 0.01em;
}

/* ---------- Showcase (compare or media) ---------- */
.ft-showcase { background: #fff; border: 1px solid #EAECF0; border-radius: 20px; box-shadow: 0 36px 70px -36px rgba(22, 35, 85, 0.30); padding: 18px; }
.ft-showcase-media .ft-media { width: 100%; border-radius: 12px; display: block; aspect-ratio: 16 / 10; object-fit: cover; background: #f4f6f9; }
.ft-compare { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 14px; }
.ft-pane { background: #F4F6F9; border-radius: 12px; padding: 14px; }
.ft-pane-after { background: #fff; box-shadow: 0 8px 24px -12px rgba(22, 35, 85, 0.20); }
.ft-pane-label { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #077A8D; margin-bottom: 10px; }
.ft-pane img { width: 100%; border-radius: 8px; display: block; }
.ft-compare-arrow { width: 40px; height: 40px; border-radius: 9999px; background: #fff; box-shadow: 0 6px 16px rgba(22, 35, 85, 0.16); display: flex; align-items: center; justify-content: center; color: #077A8D; flex: none; }
.ft-compare-arrow svg { width: 18px; height: 18px; }
@media (max-width: 560px) { .ft-compare { grid-template-columns: 1fr; } .ft-compare-arrow { transform: rotate(90deg); margin: 2px auto; } }

/* ---------- Showcase: before/after "Convert" wipe ---------- */
.ft-wipe { padding: 12px; }
.ft-wipe-card { position: relative; aspect-ratio: 16 / 9; border-radius: 14px; overflow: hidden; background: #0e1830; }
.ft-wipe-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; user-select: none; -webkit-user-drag: none; }
.ft-wipe-before { z-index: 1; }
.ft-wipe-after { z-index: 2; clip-path: polygon(0 0, 0 0, 0 100%, 0 100%); }
.ft-wipe-bar { position: absolute; top: -10%; height: 120%; width: 70px; z-index: 3; transform: translateX(-50%) rotate(2.5deg); pointer-events: none; opacity: 0; }
.ft-wipe-bar::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(91,172,191,.40) 42%, rgba(91,172,191,.55) 50%, rgba(91,172,191,.40) 58%, transparent); filter: blur(9px); }
.ft-wipe-bar::after { content: ''; position: absolute; left: 50%; top: 0; height: 100%; width: 4px; transform: translateX(-50%); border-radius: 4px; background: linear-gradient(180deg, transparent, #5BACBF 14%, #077A8D 50%, #5BACBF 86%, transparent); box-shadow: 0 0 22px 3px rgba(7,122,141,.66), 0 0 54px 9px rgba(7,122,141,.33); }
.ft-wipe-pills { position: absolute; top: 14px; left: 14px; z-index: 4; height: 34px; }
.ft-wipe-pill { position: absolute; top: 0; left: 0; display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,.94); border: 1px solid rgba(15,23,42,.08); border-radius: 999px; box-shadow: 0 8px 22px rgba(15,23,42,.14); padding: 7px 14px 7px 11px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.ft-wipe-pill .dot { width: 8px; height: 8px; border-radius: 999px; }
.ft-wipe-pill-before { color: #64748b; }
.ft-wipe-pill-before .dot { background: #94a3b8; }
.ft-wipe-pill-after { color: #077A8D; opacity: 0; }
.ft-wipe-pill-after .dot { background: #077A8D; }
.ft-wipe-convert { flex: none; display: inline-flex; align-items: center; gap: 8px; background: #077A8D; color: #fff; font-weight: 600; font-size: 13.5px; padding: 10px 20px; border: none; border-radius: 10px; cursor: pointer; transition: background .2s ease, transform .12s ease; }
.ft-wipe-convert:hover { background: #055e6d; }
.ft-wipe-convert:active { transform: scale(.96); }
.ft-wipe-convert svg { width: 16px; height: 16px; }
.ft-wipe-nav { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; gap: 12px; }
.ft-wipe-caption { font-size: 12.5px; font-weight: 600; color: #5B6573; }
.ft-wipe-arrows { display: flex; align-items: center; gap: 8px; }
.ft-wipe-arrow { width: 34px; height: 34px; border-radius: 9px; border: 1px solid #E6E9EE; background: #fff; color: #51607A; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s ease; }
.ft-wipe-arrow:hover { border-color: #077A8D; color: #077A8D; }
.ft-wipe-arrow svg { width: 16px; height: 16px; }
.ft-wipe-dots { display: flex; align-items: center; gap: 6px; }
.ft-wipe-dot { width: 7px; height: 7px; border-radius: 999px; background: #D8DCE6; border: none; padding: 0; cursor: pointer; transition: all .25s ease; }
.ft-wipe-dot.is-active { width: 20px; background: #162355; }

/* ---------- Theme switcher controls (palette dropdown + apply) ---------- */
.ft-theme-controls { display: flex; align-items: center; gap: 12px; margin-top: 14px; flex-wrap: wrap; }
.ft-theme-dd { position: relative; flex: 1 1 auto; min-width: 200px; }
.ft-theme-trigger { display: inline-flex; align-items: center; gap: 10px; width: 100%; background: #fff; border: 1px solid #E2E6EC; border-radius: 11px; padding: 11px 14px; font-size: 14px; font-weight: 600; color: #162355; cursor: pointer; transition: border-color .18s ease, box-shadow .18s ease; }
.ft-theme-trigger:hover { border-color: #CBD2DC; }
.ft-theme-dd.is-open .ft-theme-trigger { border-color: #077A8D; box-shadow: 0 0 0 3px rgba(7, 122, 141, .12); }
.ft-theme-cur { flex: 1; text-align: left; }
.ft-theme-trigger > svg { width: 15px; height: 15px; color: #8A94A6; transition: transform .2s ease; }
.ft-theme-dd.is-open .ft-theme-trigger > svg { transform: rotate(180deg); }
.ft-theme-sw { display: inline-flex; gap: 3px; flex: none; }
.ft-sw { width: 11px; height: 11px; border-radius: 50%; box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .1); }
.ft-theme-menu { position: absolute; top: calc(100% + 8px); left: 0; right: 0; background: #fff; border: 1px solid #E6E9EE; border-radius: 13px; box-shadow: 0 24px 54px -26px rgba(22, 35, 85, .55); padding: 6px; z-index: 30; opacity: 0; transform: translateY(-6px); pointer-events: none; transition: opacity .16s ease, transform .16s ease; }
.ft-theme-dd.is-open .ft-theme-menu { opacity: 1; transform: none; pointer-events: auto; }
.ft-theme-opt { display: flex; align-items: center; gap: 11px; width: 100%; padding: 9px 10px; border: none; background: none; border-radius: 9px; font-size: 14px; font-weight: 500; color: #2A2F3A; cursor: pointer; transition: background .14s ease; }
.ft-theme-opt:hover { background: #F3F6F9; }
.ft-theme-opt.is-active { background: #EAF6F8; color: #055e6d; font-weight: 600; }
.ft-theme-optname { flex: 1; text-align: left; }
.ft-theme-apply { flex: none; display: inline-flex; align-items: center; gap: 8px; background: #077A8D; color: #fff; font-weight: 600; font-size: 14px; padding: 12px 22px; border: none; border-radius: 11px; cursor: pointer; box-shadow: 0 12px 28px -10px rgba(7, 122, 141, .5); transition: background .2s ease, transform .12s ease; }
.ft-theme-apply:hover { background: #055e6d; }
.ft-theme-apply:active { transform: scale(.97); }
.ft-theme-apply svg { width: 15px; height: 15px; }

/* ---------- Showcase: Prompt -> Deck (type + wipe) ---------- */
.ft-ptd { padding: 12px; display: flex; flex-direction: column; gap: 12px; }
.ptd-prompt { background: #fff; border: 1px solid #E6E9EE; border-radius: 14px; padding: 15px 16px; }
.ptd-q { font-size: 12.5px; font-weight: 600; color: #162355; margin-bottom: 9px; }
.ptd-input { min-height: 42px; font-size: 13.5px; line-height: 1.5; color: #2A3340; }
/* document attachment chips */
.ptd-attach { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 6px; }
.ptd-attach:empty { display: none; }
.ptd-file { display: inline-flex; align-items: center; gap: 9px; background: #F7F9FC; border: 1px solid #E6E9EE; border-radius: 10px; padding: 8px 12px 8px 9px; animation: ptdFileIn .45s cubic-bezier(0.33, 1, 0.68, 1) both; }
@keyframes ptdFileIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.ptd-file-ic { font-size: 8.5px; font-weight: 800; letter-spacing: .03em; color: #fff; border-radius: 5px; padding: 4px 5px; flex: none; line-height: 1; }
.ptd-file-pdf { background: #C0394B; } .ptd-file-doc { background: #2B6CB0; } .ptd-file-xls { background: #1E8E5A; } .ptd-file-ppt { background: #C2571E; } .ptd-file-csv { background: #0E7C66; } .ptd-file-img { background: #7A4E9E; } .ptd-file-gen { background: #51607A; }
.ptd-file-name { font-size: 12.5px; font-weight: 600; color: #2A3340; }
.ptd-file.is-clickable { cursor: pointer; transition: border-color .15s ease, box-shadow .15s ease; }
.ptd-file.is-clickable:hover { border-color: #077A8D; box-shadow: 0 4px 14px -6px rgba(7,122,141,.4); }
.ptd-file-view { margin-left: 3px; font-size: 10.5px; font-weight: 700; color: #077A8D; }
/* homepage streaming-text spans (exact reuse) */
.ap-stream-word { display: inline-block; }
.ap-stream-char { display: inline-block; will-change: transform, opacity; }
.ptd-ph { color: #9AA3B2; }
.ptd-caret { display: none; width: 2px; height: 1.05em; background: #077A8D; margin-left: 1px; vertical-align: -2px; }
.ptd-caret.on { display: inline-block; animation: ptdBlink 1s steps(1) infinite; }
@keyframes ptdBlink { 50% { opacity: 0; } }
.ptd-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 13px; flex-wrap: wrap; }
.ptd-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.ptd-chip { font-size: 11px; font-weight: 500; color: #51607A; background: #F4F6F9; border: 1px solid #EAECF0; border-radius: 8px; padding: 5px 9px; white-space: nowrap; }
.ptd-generate { flex: none; display: inline-flex; align-items: center; gap: 7px; background: #077A8D; color: #fff; font-weight: 600; font-size: 12.5px; padding: 9px 16px; border: none; border-radius: 9px; cursor: pointer; transition: background .2s ease; }
.ptd-generate:hover { background: #055e6d; }
.ptd-generate[disabled] { opacity: .7; cursor: default; }
.ptd-generate svg { width: 14px; height: 14px; }
.ptd-stage { background: #fff; }
.ptd-skeleton { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, #ffffff, #f5f8fb); display: flex; align-items: center; justify-content: center; }
.ptd-status { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; gap: 8px; color: #9AA3B2; font-size: 13.5px; font-weight: 600; }
.ptd-status svg { width: 18px; height: 18px; color: #B6BEC9; }
.ptd-ell { display: inline-flex; align-items: flex-end; gap: 3px; margin-left: 1px; }
.ptd-ell i { width: 3.5px; height: 3.5px; border-radius: 50%; background: currentColor; animation: ptdDot 1.2s ease-in-out infinite; }
.ptd-ell i:nth-child(2) { animation-delay: .18s; }
.ptd-ell i:nth-child(3) { animation-delay: .36s; }
@keyframes ptdDot { 0%, 70%, 100% { opacity: .3; transform: translateY(0); } 35% { opacity: 1; transform: translateY(-3px); } }
.ptd-nav { display: flex; align-items: center; justify-content: center; gap: 8px; }
.ptd-dot { width: 7px; height: 7px; border-radius: 999px; background: #D8DCE6; border: none; padding: 0; cursor: pointer; transition: all .25s ease; }
.ptd-dot.is-active { width: 20px; background: #162355; }
.ft-ptd-single .ft-wipe-nav { display: none; }

/* ---------- Gallery mode: deck slides fall in -> Present (UIGallery3) ---------- */
.ft-ptd-gallery .ptd-gstage { position: relative; border: 1px solid #E7EAEF; border-radius: 16px; background: linear-gradient(180deg, #ffffff, #f6f9fb); box-shadow: 0 26px 60px -42px rgba(22, 35, 85, .5); padding: 18px; min-height: 320px; }
.ptd-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 11px; perspective: 1400px; }
@media (max-width: 640px) { .ptd-gallery { grid-template-columns: repeat(3, 1fr); gap: 8px; } }
.ptd-gtile { padding: 0; border: 1px solid #E6E9EE; border-radius: 9px; overflow: hidden; background: #fff; cursor: pointer; opacity: 0; box-shadow: 0 10px 22px -14px rgba(22, 35, 85, .42); transition: box-shadow .16s ease, transform .16s ease; }
.ptd-gtile:hover { box-shadow: 0 18px 34px -14px rgba(22, 35, 85, .55); transform: translateY(-2px); }
.ptd-gtile img { display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
.ptd-bar { display: flex; justify-content: center; margin-top: 16px; opacity: 0; transform: translateY(10px); transition: opacity .35s ease, transform .35s ease; pointer-events: none; }
.ptd-bar.is-in { opacity: 1; transform: none; pointer-events: auto; }
.ptd-present { display: inline-flex; align-items: center; gap: 9px; background: #077A8D; color: #fff; font-weight: 600; font-size: 14px; padding: 12px 26px; border: none; border-radius: 11px; cursor: pointer; box-shadow: 0 12px 28px -10px rgba(7, 122, 141, .55); transition: background .2s ease, transform .12s ease; }
.ptd-present:hover { background: #055e6d; }
.ptd-present:active { transform: scale(.97); }
.ptd-present svg { width: 14px; height: 14px; }

/* ---------- Present overlay (full-bleed slideshow) ---------- */
.ft-present { position: fixed; inset: 0; z-index: 1100; display: none; align-items: center; justify-content: center; background: rgba(8, 12, 26, .94); padding: 4vw; }
.ft-present.is-open { display: flex; animation: ftPresentIn .22s ease; }
@keyframes ftPresentIn { from { opacity: 0; } to { opacity: 1; } }
.ft-present-img { max-width: 92vw; max-height: 86vh; border-radius: 8px; box-shadow: 0 50px 120px -34px rgba(0, 0, 0, .7); }
.ft-present-close { position: absolute; top: 22px; right: 26px; width: 42px; height: 42px; border: none; border-radius: 50%; background: rgba(255, 255, 255, .12); color: #fff; font-size: 25px; line-height: 1; cursor: pointer; }
.ft-present-close:hover { background: rgba(255, 255, 255, .22); }
.ft-present-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 54px; height: 54px; border: none; border-radius: 50%; background: rgba(255, 255, 255, .12); color: #fff; font-size: 30px; line-height: 1; cursor: pointer; transition: background .2s ease; }
.ft-present-nav:hover { background: rgba(255, 255, 255, .22); }
.ft-present-prev { left: 3vw; }
.ft-present-next { right: 3vw; }
.ft-present-count { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); color: rgba(255, 255, 255, .82); font-size: 13px; font-weight: 600; letter-spacing: .04em; }

/* ---------- Document viewer modal (FileExplorer-style) ---------- */
.ft-viewer { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center; padding: 4vh 4vw; }
.ft-viewer.is-open { display: flex; }
.ft-viewer-scrim { position: absolute; inset: 0; background: rgba(16, 26, 38, .55); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); animation: ftvFade .2s ease; }
@keyframes ftvFade { from { opacity: 0; } to { opacity: 1; } }
.ft-viewer-card { position: relative; width: min(900px, 100%); max-height: 92vh; display: flex; flex-direction: column; background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 44px 120px rgba(12, 20, 34, .5); animation: ftvIn .26s cubic-bezier(0.22, 0.61, 0.36, 1); }
@keyframes ftvIn { from { opacity: 0; transform: translateY(18px) scale(.98); } to { opacity: 1; transform: none; } }
.ft-viewer-bar { display: flex; align-items: center; gap: 11px; height: 48px; padding: 0 16px; color: #fff; flex: none; }
.ft-viewer-ext { background: rgba(255, 255, 255, .22); border-radius: 6px; font-size: 11px; font-weight: 800; padding: 4px 8px; flex: none; }
.ft-viewer-name { font-size: 14.5px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-viewer-close { margin-left: auto; background: none; border: none; color: #fff; font-size: 22px; line-height: 1; cursor: pointer; opacity: .9; flex: none; }
.ft-viewer-close:hover { opacity: 1; }
.ft-viewer-canvas { flex: 1; overflow-y: auto; background: #e9ebee; padding: 28px; }
.ft-viewer-page { max-width: 720px; margin: 0 auto; background: #fff; border-radius: 3px; box-shadow: 0 8px 30px rgba(0, 0, 0, .18); padding: 56px 64px; }
.ft-viewer-page h1 { font-family: 'Crimson Pro', Georgia, serif; font-weight: 600; color: #1c1c1c; font-size: 30px; line-height: 1.2; letter-spacing: -.01em; margin: 0 0 20px; }
.ft-viewer-page h2 { color: #162355; font-size: 19px; font-weight: 700; margin: 26px 0 10px; }
.ft-viewer-page h3 { color: #162355; font-size: 16px; font-weight: 700; margin: 20px 0 8px; }
.ft-viewer-page p { color: #33373b; font-size: 15px; line-height: 1.75; margin: 0 0 16px; }
.ft-viewer-page ul, .ft-viewer-page ol { margin: 0 0 16px; padding-left: 22px; }
.ft-viewer-page li { color: #33373b; font-size: 15px; line-height: 1.65; margin: 0 0 7px; }
.ft-viewer-page strong { color: #1c1c1c; font-weight: 700; }
.ft-viewer-page code { background: #eef1f3; border-radius: 4px; font-family: Consolas, monospace; font-size: 13.5px; padding: 1px 6px; }
.ft-viewer-page hr { border: none; border-top: 1px solid #e3e3e3; margin: 22px 0; }
@media (max-width: 640px) { .ft-viewer-page { padding: 32px 24px; } }

/* ---------- Section: supported file types (floating tiles) ---------- */
.ft-types-sec { padding: 56px 0 64px; text-align: center; }
.ft-types-sub { font-size: 1.02rem; line-height: 1.6; color: #5B6573; max-width: 34rem; margin: -20px auto 32px; }
.ft-types { display: flex; flex-wrap: wrap; justify-content: center; gap: 18px; }
.ft-type { display: inline-flex; flex-direction: column; align-items: center; gap: 12px; width: 132px; padding: 24px 16px; background: #fff; border: 1px solid #EAECF0; border-radius: 16px; box-shadow: 0 14px 34px -22px rgba(22, 35, 85, .34); animation: ftTypeFloat 4.5s ease-in-out infinite; }
@keyframes ftTypeFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
.ft-type-ic { width: 46px; height: 46px; border-radius: 12px; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 800; letter-spacing: .03em; box-shadow: 0 8px 18px -8px rgba(0, 0, 0, .4); }
.ft-type-label { font-size: 13.5px; font-weight: 600; color: #162355; }
@media (prefers-reduced-motion: reduce) { .ft-type { animation: none; } }

/* ---------- Stats strip ---------- */
.ft-stats-sec { padding: 12px 0 42px; }
.ft-stats { display: grid; grid-template-columns: 1fr; border: 1px solid #EAECF0; border-radius: 18px; background: #fff; overflow: hidden; box-shadow: 0 12px 36px -28px rgba(22, 35, 85, 0.30); }
@media (min-width: 768px) { .ft-stats { grid-template-columns: repeat(4, 1fr); } }
.ft-stat { display: flex; gap: 14px; padding: 24px 26px; }
@media (min-width: 768px) { .ft-stat + .ft-stat { border-left: 1px solid #EEF0F4; } }
@media (max-width: 767px) { .ft-stat + .ft-stat { border-top: 1px solid #EEF0F4; } }
.ft-stat-ic { flex: none; width: 38px; height: 38px; border-radius: 10px; background: #EAF6F8; color: #077A8D; display: flex; align-items: center; justify-content: center; }
.ft-stat-ic svg { width: 19px; height: 19px; }
.ft-stat-t { font-weight: 700; color: #162355; font-size: 15px; margin-bottom: 3px; }
.ft-stat-d { font-size: 13px; line-height: 1.5; color: #6B7280; }

/* ---------- How it works ---------- */
.ft-steps-sec { padding: 36px 0 58px; }
.ft-h2 { font-family: 'Crimson Pro', Georgia, serif; font-weight: 300; color: #162355; font-size: clamp(1.9rem, 3.2vw, 2.6rem); line-height: 1.1; letter-spacing: -0.005em; margin-bottom: 34px; }
.ft-steps { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 768px) { .ft-steps { grid-template-columns: repeat(4, 1fr); gap: 8px; } }
.ft-step { position: relative; padding: 22px; border-radius: 16px; background: #fff; border: 1px solid #EEF0F4; }
@media (min-width: 768px) { .ft-step { padding: 6px 30px 6px 4px; background: transparent; border: none; } }
.ft-step-n { font-size: 12px; font-weight: 700; color: #AEB6C2; margin-bottom: 12px; }
.ft-step-t { font-weight: 700; color: #162355; font-size: 15.5px; line-height: 1.3; margin-bottom: 6px; }
.ft-step-d { font-size: 13.5px; line-height: 1.55; color: #6B7280; margin-bottom: 20px; }
.ft-step-ic { width: 54px; height: 54px; border-radius: 12px; border: 1px solid #E6E9EE; display: flex; align-items: center; justify-content: center; color: #077A8D; background: #fff; }
.ft-step-ic svg { width: 24px; height: 24px; }
.ft-step-arrow { display: none; }
@media (min-width: 768px) { .ft-step-arrow { display: flex; position: absolute; top: 46px; right: -3px; color: #C6CEDA; } .ft-step:last-child .ft-step-arrow { display: none; } }
.ft-step-arrow svg { width: 18px; height: 18px; }

/* ---------- Capabilities ---------- */
.ft-caps-sec { padding: 76px 0 96px; background: #FAFBFC; border-top: 1px solid #EEF1F4; }
.ft-caps { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: start; }
@media (min-width: 900px) { .ft-caps { grid-template-columns: 0.85fr 1.15fr; gap: 56px; } }
.ft-caps-sub { font-size: 1.02rem; line-height: 1.6; color: #5B6573; margin-bottom: 22px; max-width: 30rem; }
.ft-caps-link { display: inline-flex; align-items: center; gap: 8px; color: #077A8D; font-weight: 600; font-size: 14.5px; }
.ft-caps-link:hover { color: #055e6d; }
.ft-caps-link svg { width: 16px; height: 16px; }
.ft-checklist { display: flex; flex-direction: column; gap: 28px; }
.ft-check { display: flex; gap: 13px; align-items: flex-start; }
.ft-check-ic { flex: none; width: 22px; height: 22px; border-radius: 6px; background: #EAF6F8; color: #077A8D; display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.ft-check-ic svg { width: 14px; height: 14px; }
.ft-check-t { font-size: 15px; line-height: 1.5; color: #2A3340; }

/* ---------- Final CTA (full-bleed teal) ---------- */
.ft-cta-sec { background: #21657F; padding: 56px 0; }
@media (min-width: 768px) { .ft-cta-sec { padding: 80px 0; } }
.ft-cta-inner { text-align: center; }
.ft-cta-h { font-family: 'Crimson Pro', Georgia, serif; font-weight: 300; color: #fff; font-size: clamp(1.9rem, 3.4vw, 2.7rem); line-height: 1.12; margin-bottom: 14px; }
.ft-cta-s { color: rgba(255, 255, 255, 0.85); font-size: 1rem; line-height: 1.55; max-width: 34rem; margin: 0 auto 28px; }
.ft-cta-btn { display: inline-block; background: #fff; color: #21657F; font-weight: 600; font-size: 15px; padding: 14px 30px; border-radius: 11px; transition: background 0.2s ease; }
.ft-cta-btn:hover { background: #EAF6F8; }
