/* CrewOS marketing site — built on the brand foundations. */
@import url('/colors_and_type.css?v=f3dbda2812');

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body { background: var(--color-card); color: var(--color-text); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
button, a { font-family: inherit; }
a { color: inherit; text-decoration: none; }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 28px; }
section { position: relative; }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; padding: 12px 20px; border-radius: var(--radius-lg); font: 600 15px/1 var(--font-sans); border: 1px solid transparent; cursor: pointer; transition: background .16s, box-shadow .16s, transform .05s; }
.btn:active { transform: translateY(1px); }
.btn svg { width: 17px; height: 17px; }
.btn-primary { background: var(--color-accent); color: #fff; }
.btn-primary:hover { background: var(--color-accent-hover); }
.btn-light { background: #fff; color: #1a2e1a; }
.btn-light:hover { background: #eef1f5; }
.btn-outline { background: transparent; color: var(--color-text); border-color: var(--color-border-strong); }
.btn-outline:hover { background: var(--color-card-alt); }
.btn-sm { padding: 9px 15px; font-size: 14px; }

/* ---- nav ---- */
header.nav { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.88); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-border-subtle); }
.nav-in { display: flex; align-items: center; gap: 28px; height: 66px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 800; font-size: 19px; letter-spacing: -.4px; }
.brand .os { color: var(--sage-700); }
.plate { width: 32px; height: 32px; border-radius: 9px; background: var(--color-logo-bg); display: flex; flex-direction: column; align-items: center; justify-content: center; line-height: .9; }
.plate .crewmark { width: 66%; height: 66%; }
.plate .c { color: #fff; font-weight: 700; font-size: 10px; letter-spacing: -.3px; }
.plate .o { color: #7aa37a; font-weight: 600; font-size: 7.5px; letter-spacing: 1.5px; }
.nav-links { display: flex; gap: 24px; margin-left: 12px; }
.nav-links a { font-size: 15px; color: var(--color-text-dim); font-weight: 500; }
.nav-links a:hover { color: var(--color-text); }
/* product dropdown */
.nav-drop { position: relative; }
.nav-drop-trigger { display: inline-flex; align-items: center; gap: 4px; cursor: pointer; }
.nav-drop-trigger svg { transition: transform .15s ease; }
.nav-drop:hover .nav-drop-trigger svg { transform: rotate(180deg); }
.nav-menu { position: absolute; top: 100%; left: -16px; margin-top: 12px; width: 560px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
  background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg); padding: 12px; z-index: 50;
  opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .15s ease, transform .15s ease; }
.nav-drop:hover .nav-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-menu::before { content: ""; position: absolute; top: -12px; left: 0; right: 0; height: 12px; }
.nav-menu-item { display: flex; align-items: flex-start; gap: 12px; padding: 11px 13px; border-radius: 10px; }
.nav-menu-item:hover { background: var(--color-card-alt); }
.nav-menu .nm-ic { width: 34px; height: 34px; flex-shrink: 0; border-radius: 9px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; }
.nav-menu .nm-txt { display: flex; flex-direction: column; gap: 2px; }
.nav-menu .nm-label { font-size: 14px; font-weight: 600; color: var(--color-text); }
.nav-menu .nm-desc { font-size: 12.5px; color: var(--color-text-muted); font-weight: 400; }
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.nav-right .signin { font-size: 15px; font-weight: 600; color: var(--color-text-dim); }
.nav-right .signin:hover { color: var(--color-text); }

/* ---- hero ---- */
.hero { padding: 76px 0 64px; background: linear-gradient(180deg, #f4f7f4 0%, #ffffff 100%); border-bottom: 1px solid var(--color-border-subtle); }
.hero-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 54px; align-items: center; }
.eyebrow { display: inline-flex; align-items: center; gap: 7px; font: 600 12.5px/1 var(--font-sans); text-transform: uppercase; letter-spacing: .07em; color: var(--sage-700); background: #e6ede6; border: 1px solid #d0ddd0; padding: 7px 12px; border-radius: 9999px; margin-bottom: 22px; }
.eyebrow svg { width: 14px; height: 14px; }
.hero h1 { font-family: var(--font-display); font-weight: 800; font-size: 50px; line-height: 1.06; letter-spacing: -.025em; margin: 0 0 20px; color: var(--color-text); text-wrap: balance; }
.hero p.lede { font: 400 19px/1.5 var(--font-sans); color: var(--color-text-dim); margin: 0 0 30px; max-width: 520px; }
.hero-cta { display: flex; gap: 12px; align-items: center; margin-bottom: 22px; flex-wrap: wrap; }
.trust { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--color-text-muted); }
.trust svg { width: 16px; height: 16px; color: var(--color-success); }

/* product mock window */
.mock { border-radius: var(--radius-xl); border: 1px solid var(--color-border); background: #fff; box-shadow: 0 24px 60px rgba(17,24,39,.14); overflow: hidden; }
.mock-bar { height: 36px; background: var(--color-card-alt); border-bottom: 1px solid var(--color-border); display: flex; align-items: center; gap: 6px; padding: 0 14px; }
.mock-bar .dot { width: 10px; height: 10px; border-radius: 9999px; }
.mock-body { display: flex; min-height: 300px; }
.mock-sb { width: 64px; background: #fff; border-right: 1px solid var(--color-border-subtle); padding: 12px 0; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.mock-sb .mp { width: 26px; height: 26px; border-radius: 7px; background: var(--color-logo-bg); }
.mock-sb .mi { color: var(--color-text-faint); }
.mock-sb .mi.on { color: var(--color-accent); }
.mock-main { flex: 1; padding: 16px; background: var(--color-bg); }
.mock-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 10px; }
.mk { background: #fff; border: 1px solid var(--color-border); border-radius: 9px; padding: 10px; }
.mk .v { font-weight: 700; font-size: 18px; }
.mk .k { font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--color-text-faint); margin-top: 3px; }
.mrow { background: #fff; border: 1px solid var(--color-border); border-radius: 9px; padding: 9px 11px; display: flex; align-items: center; gap: 9px; margin-bottom: 7px; font-size: 11.5px; }
.mrow .ml { width: 4px; align-self: stretch; border-radius: 3px; }
.mpill { margin-left: auto; font-size: 9.5px; padding: 2px 8px; border-radius: 9999px; font-weight: 600; }

/* ---- industries strip ---- */
.strip { padding: 30px 0; border-bottom: 1px solid var(--color-border-subtle); }
.strip .lbl { text-align: center; font-size: 12.5px; text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-faint); font-weight: 600; margin-bottom: 18px; }
.strip-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px 14px; }
.ichip { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: 9999px; border: 1px solid var(--color-border); background: var(--color-card-alt); font-size: 14px; font-weight: 500; color: var(--color-text-dim); }
.ichip svg { width: 17px; height: 17px; color: var(--sage-700); }

/* ---- section heading ---- */
.sec { padding: 78px 0; }
.sec-head { max-width: 660px; margin: 0 auto 48px; text-align: center; }
.sec-head .ov { font: 600 13px/1 var(--font-sans); text-transform: uppercase; letter-spacing: .08em; color: var(--color-accent-hover); margin-bottom: 14px; }
.sec-head h2 { font-family: var(--font-display); font-weight: 800; font-size: 38px; line-height: 1.12; letter-spacing: -.02em; margin: 0 0 14px; text-wrap: balance; }
.sec-head p { font-size: 17px; line-height: 1.55; color: var(--color-text-dim); margin: 0; }

/* ---- feature rows ---- */
.feat { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; margin-bottom: 72px; scroll-margin-top: 96px; }
.feat:last-child { margin-bottom: 0; }
.feat.rev .ftext { order: 2; }
.fbadge { width: 46px; height: 46px; border-radius: 12px; background: #e6ede6; border: 1px solid #d0ddd0; display: flex; align-items: center; justify-content: center; color: var(--sage-700); margin-bottom: 18px; }
.fbadge svg { width: 24px; height: 24px; }
.feat h3 { font-family: var(--font-display); font-weight: 700; font-size: 25px; line-height: 1.2; letter-spacing: -.01em; margin: 0 0 12px; }
.feat .pain { font-size: 14px; color: var(--color-danger); font-weight: 600; margin: 0 0 8px; }
.feat p { font-size: 16px; line-height: 1.6; color: var(--color-text-dim); margin: 0 0 16px; }
.feat ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 9px; }
.feat li { display: flex; gap: 9px; align-items: flex-start; font-size: 15px; color: var(--color-text-dim); }
.feat li svg { width: 18px; height: 18px; color: var(--color-success); flex-shrink: 0; margin-top: 1px; }
.fvis { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 22px; box-shadow: var(--shadow-md); }

/* ---- capability carousel ("What it actually does") ---- */
.cap-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 9px; margin: 0 auto 44px; max-width: 840px; }
.cap-tab { display: inline-flex; align-items: center; gap: 8px; font: 600 14.5px/1 var(--font-sans); color: var(--color-text-dim); background: var(--color-card); border: 1px solid var(--color-border); border-radius: 9999px; padding: 10px 17px; cursor: pointer; transition: background .18s, color .18s, border-color .18s; }
.cap-tab svg { width: 16px; height: 16px; color: var(--color-text-faint); transition: color .18s; }
.cap-tab:hover { background: var(--color-card-alt); }
.cap-tab.active { background: var(--color-accent-bg); border-color: var(--color-accent); color: var(--color-accent-hover); font-weight: 700; }
.cap-tab.active svg { color: var(--color-accent-hover); }
.cap-panel { margin-bottom: 0; animation: capFade .32s ease; }
@keyframes capFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .cap-panel { animation: none; } }

/* ---- product tour (real screenshots) ---- */
.tour-sec { background: var(--color-bg); border-top: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); }
.browser { border-radius: 14px; border: 1px solid var(--color-border); overflow: hidden; box-shadow: 0 24px 60px rgba(17,24,39,.14); background: #fff; }
.browser-bar { height: 40px; background: var(--color-card-alt); border-bottom: 1px solid var(--color-border); display: flex; align-items: center; gap: 7px; padding: 0 15px; }
.browser-bar .dot { width: 11px; height: 11px; border-radius: 9999px; }
.browser-bar .url { margin-left: 10px; font-family: var(--font-mono); font-size: 12px; color: var(--color-text-faint); background: var(--color-card); border: 1px solid var(--color-border); border-radius: 7px; padding: 4px 12px; }
.browser-shot { height: 430px; overflow: hidden; background: #fff; }
.browser-shot img { display: block; width: 118.5%; max-width: none; margin-left: -18.5%; height: auto; }
.browser-shot img[src*="s-fieldwork"] { width: 124%; margin-left: -24%; }
/* settings screenshots have a second (settings) nav column — crop deeper so just the panel shows */
.browser-shot.is-settings img { width: 143%; margin-left: -43%; margin-top: -48px; }
/* placeholder frame shown until a real screenshot is dropped in */
.shot-ph { height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; text-align: center; padding: 24px;
  background: repeating-linear-gradient(135deg, #f6f8f7 0 14px, #eef2f0 14px 28px); color: var(--color-text-muted); }
.shot-ph .ic { width: 46px; height: 46px; border-radius: 12px; background: var(--color-card); border: 1px solid var(--color-border); display: flex; align-items: center; justify-content: center; color: var(--sage-700); box-shadow: var(--shadow-sm); }
.shot-ph .ic svg { width: 24px; height: 24px; }
.shot-ph .lbl { font: 600 14px/1.2 var(--font-sans); color: var(--color-text-dim); }
.shot-ph .file { font: 500 12px/1 var(--font-mono); color: var(--color-text-faint); background: var(--color-card); border: 1px solid var(--color-border); border-radius: 6px; padding: 5px 10px; }
.tour-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 22px; align-items: start; }
.tour-cap { font-size: 13.5px; color: var(--color-text-muted); margin: 12px 2px 0; display: flex; align-items: center; gap: 7px; }
.tour-cap svg { width: 15px; height: 15px; color: var(--color-accent); }
.phone-card { background: linear-gradient(160deg,#eef2f0,#e2e7ea); border: 1px solid var(--color-border); border-radius: 16px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.phone-card img { display: block; width: 100%; height: auto; }
@media (max-width: 880px) { .tour-grid { grid-template-columns: 1fr; } }

/* ---- industries page ---- */
.ind-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 22px; box-shadow: var(--shadow-sm); transition: box-shadow .16s, border-color .16s; }
.ind-card:hover { box-shadow: var(--shadow-md); border-color: var(--color-border-strong); }
.ind-card .ti { width: 44px; height: 44px; border-radius: 11px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.ind-name { font-family: var(--font-display); font-weight: 800; font-size: 19px; margin-bottom: 12px; letter-spacing: -.01em; }
.ind-row { display: flex; gap: 10px; padding: 7px 0; border-top: 1px solid var(--color-border-subtle); font-size: 13px; }
.ind-k { color: var(--color-text-faint); width: 86px; flex-shrink: 0; }
.ind-v { color: var(--color-text-dim); font-weight: 500; }
.term-table { border: 1px solid var(--color-border); border-radius: var(--radius-xl); overflow: hidden; background: #fff; box-shadow: var(--shadow-sm); }
.term-row { display: grid; grid-template-columns: 1.1fr 1fr 1fr 1fr; }
.term-row.head { background: var(--color-logo-bg); }
.term-row.head .term-cell { color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 13.5px; }
.term-row.head .term-cell.lead { color: var(--sage-300); }
.term-cell { padding: 14px 18px; font-size: 14px; color: var(--color-text-dim); border-bottom: 1px solid var(--color-border-subtle); border-right: 1px solid var(--color-border-subtle); }
.term-cell:last-child { border-right: 0; }
.term-row:last-child .term-cell { border-bottom: 0; }
.term-cell.lead { font-weight: 600; color: var(--color-text); background: var(--color-card-alt); }
@media (max-width: 880px) { .term-row { grid-template-columns: 1fr 1fr; } }
.tpl-sec { background: var(--color-bg); border-top: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); }
.tpl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.tpl { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 18px; display: flex; align-items: center; gap: 14px; box-shadow: var(--shadow-sm); transition: box-shadow .16s, border-color .16s; }
.tpl:hover { box-shadow: var(--shadow-md); border-color: var(--color-border-strong); }
.tpl .ti { width: 40px; height: 40px; border-radius: 10px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.tpl .ti svg { width: 21px; height: 21px; }
.tpl .tn { font-weight: 600; font-size: 15px; }
.tpl .td { font-size: 12.5px; color: var(--color-text-muted); margin-top: 2px; }

/* ---- pricing ---- */
.price-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; align-items: stretch; }
.plan { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 26px 22px; display: flex; flex-direction: column; box-shadow: var(--shadow-sm); }
.plan.pop { border: 2px solid var(--color-accent); box-shadow: 0 12px 36px rgba(22,163,74,.14); position: relative; }
.plan .tag { position: absolute; top: -11px; left: 22px; white-space: nowrap; background: var(--color-accent); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; padding: 4px 10px; border-radius: 9999px; }
.plan .pn { font-family: var(--font-display); font-weight: 700; font-size: 17px; }
.plan .pp { font-family: var(--font-display); font-weight: 800; font-size: 36px; letter-spacing: -.02em; margin: 12px 0 2px; }
.plan .pp span { font-size: 15px; font-weight: 500; color: var(--color-text-muted); }
.plan .plim { font-size: 13.5px; color: var(--color-text-muted); margin-bottom: 18px; min-height: 38px; }
.plan ul { margin: 0 0 22px; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.plan li { display: flex; gap: 8px; font-size: 14px; color: var(--color-text-dim); }
.plan li svg { width: 16px; height: 16px; color: var(--color-success); flex-shrink: 0; margin-top: 1px; }

/* ---- CTA band ---- */
.cta-band { background: var(--color-logo-bg); color: #fff; }
.cta-band .wrap { padding: 64px 28px; text-align: center; }
.cta-band h2 { font-family: var(--font-display); font-weight: 800; font-size: 36px; line-height: 1.15; letter-spacing: -.02em; margin: 0 0 14px; color: #fff; text-wrap: balance; }
.cta-band p { font-size: 17px; color: #b5cdb5; margin: 0 0 28px; }
.cta-band .row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ---- footer ---- */
footer.site { background: var(--color-card-alt); border-top: 1px solid var(--color-border); padding: 50px 0 34px; }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 28px; margin-bottom: 36px; }
.foot-grid h5 { font: 600 12px/1 var(--font-sans); text-transform: uppercase; letter-spacing: .07em; color: var(--color-text-faint); margin: 0 0 14px; }
.foot-grid a { display: block; font-size: 14px; color: var(--color-text-dim); margin-bottom: 10px; }
.foot-grid a:hover { color: var(--color-text); }
.foot-blurb { font-size: 14px; color: var(--color-text-muted); line-height: 1.55; margin: 14px 0 0; max-width: 280px; }
/* grouped settings column */
.foot-settings .foot-sub { margin-bottom: 16px; }
.foot-settings .foot-sub:last-child { margin-bottom: 0; }
.foot-settings .foot-sub-h { font: 600 11px/1 var(--font-sans) !important; text-transform: uppercase; letter-spacing: .06em; color: var(--color-text-faint) !important; margin-bottom: 9px !important; }
.foot-settings .foot-sub-h:hover { color: var(--color-accent-hover) !important; }
.foot-settings .foot-sub a:not(.foot-sub-h) { margin-bottom: 8px; }
/* small nav dropdown (Settings) */
.nav-menu.sm { width: 280px; grid-template-columns: 1fr; }
.foot-bot { border-top: 1px solid var(--color-border); padding-top: 20px; display: flex; justify-content: space-between; font-size: 13px; color: var(--color-text-muted); flex-wrap: wrap; gap: 10px; }

/* ---- legal docs (privacy, terms) ---- */
.legal-hero { background: var(--color-card-alt); border-bottom: 1px solid var(--color-border); padding: 52px 0 40px; }
.legal-hero h1 { font: 700 40px/1.08 var(--font-display); letter-spacing: -.02em; margin: 16px 0 10px; }
.legal-sub { font-size: 15px; color: var(--color-text-muted); margin: 0; }
.legal-body { padding: 48px 0 72px; }
.legal-grid { display: grid; grid-template-columns: 248px 1fr; gap: 56px; align-items: start; }
.legal-toc { position: sticky; top: 88px; }
.legal-toc-in { max-height: calc(100vh - 120px); overflow-y: auto; }
.legal-toc h4 { font: 600 11px/1 var(--font-sans); text-transform: uppercase; letter-spacing: .07em; color: var(--color-text-faint); margin: 0 0 14px; }
.legal-toc nav { display: flex; flex-direction: column; gap: 2px; border-left: 2px solid var(--color-border); }
.legal-toc nav a { font-size: 13px; color: var(--color-text-muted); padding: 6px 0 6px 14px; margin-left: -2px; border-left: 2px solid transparent; line-height: 1.35; }
.legal-toc nav a:hover { color: var(--color-text); border-left-color: var(--color-accent); }
.legal-content { max-width: 760px; min-width: 0; }
.legal-section { scroll-margin-top: 88px; margin-bottom: 36px; }
.legal-section h2 { font: 700 21px/1.25 var(--font-display); color: var(--color-text); margin: 0 0 14px; }
.legal-content p { font-size: 15px; line-height: 1.68; color: var(--color-text-dim); margin: 0 0 14px; }
.legal-content ul { margin: 0 0 16px; padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 10px; }
.legal-content li { position: relative; font-size: 15px; line-height: 1.62; color: var(--color-text-dim); padding-left: 22px; }
.legal-content li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 6px; height: 6px; border-radius: 9999px; background: var(--color-accent); }
.legal-content strong { color: var(--color-text); font-weight: 600; }
.legal-content a { color: var(--color-accent-hover); text-decoration: underline; text-underline-offset: 2px; }
.legal-table-wrap { overflow-x: auto; margin: 0 0 18px; border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.legal-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.legal-table th { text-align: left; font: 600 12px/1.3 var(--font-sans); color: var(--color-text-muted); background: var(--color-card-alt); padding: 11px 14px; border-bottom: 1px solid var(--color-border); }
.legal-table td { padding: 11px 14px; color: var(--color-text-dim); border-bottom: 1px solid var(--color-border-subtle); vertical-align: top; line-height: 1.5; }
.legal-table tr:last-child td { border-bottom: 0; }
@media (max-width: 860px) {
  .legal-grid { grid-template-columns: 1fr; gap: 24px; }
  .legal-toc { position: static; }
  .legal-toc-in { max-height: none; }
}

/* ---- help center ---- */
.help-hero { background: var(--color-card-alt); border-bottom: 1px solid var(--color-border); padding: 56px 0 44px; text-align: center; }
.help-hero .eyebrow { margin: 0 auto 18px; white-space: nowrap; }
.help-hero h1 { font: 700 42px/1.06 var(--font-display); letter-spacing: -.02em; margin: 0 0 12px; }
.help-lede { font-size: 16px; color: var(--color-text-muted); max-width: 540px; margin: 0 auto 28px; }
.help-search { display: flex; align-items: center; gap: 10px; max-width: 600px; margin: 0 auto; background: var(--color-card); border: 1px solid var(--color-border-strong); border-radius: var(--radius-xl); padding: 8px 8px 8px 16px; box-shadow: var(--shadow-sm); }
.help-search > svg { color: var(--color-text-faint); flex-shrink: 0; }
.help-search input { flex: 1; border: 0; background: transparent; font-size: 15px; font-family: var(--font-sans); color: var(--color-text); outline: none; }
.help-search input::placeholder { color: var(--color-text-faint); }
.help-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.help-card { display: flex; flex-direction: column; align-items: flex-start; background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 22px; box-shadow: var(--shadow-sm); }
.help-card:hover { border-color: var(--color-accent-border); box-shadow: var(--shadow-md); }
.help-card-ic { width: 44px; height: 44px; border-radius: var(--radius-lg); background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.help-card h3 { font: 600 16px/1.3 var(--font-sans); color: var(--color-text); margin: 0 0 6px; }
.help-card > p { font-size: 13.5px; line-height: 1.5; color: var(--color-text-muted); margin: 0 0 16px; }
.help-card ul { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 6px; width: 100%; }
.help-art { display: flex; align-items: center; gap: 9px; width: 100%; padding: 9px 10px; border-radius: var(--radius-lg); font-size: 13px; color: var(--color-text-dim); border: 1px solid transparent; }
.help-art:hover { background: var(--color-accent-bg); border-color: var(--color-accent-border); color: var(--color-accent-hover); }
.help-art > svg:first-child { color: var(--color-text-faint); flex-shrink: 0; }
.help-art:hover > svg:first-child { color: var(--color-accent-hover); }
.help-art span { flex: 1; min-width: 0; }
.help-art-arrow { opacity: 0; color: var(--color-accent-hover); flex-shrink: 0; transition: opacity .12s ease, transform .12s ease; }
.help-art:hover .help-art-arrow { opacity: 1; transform: translateX(2px); }
.help-card-link { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; font: 600 13px/1 var(--font-sans); color: var(--color-accent-hover); }
.help-card:hover .help-card-link svg { transform: translateX(2px); }
.help-card-link svg { transition: transform .15s ease; }
.help-contact { padding: 56px 0 72px; }
.help-contact-in { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; background: var(--color-card-alt); border: 1px solid var(--color-border); border-radius: var(--radius-2xl); padding: 40px; }
.help-contact-copy h2 { font: 700 26px/1.2 var(--font-display); margin: 0 0 12px; }
.help-contact-copy p { font-size: 15px; line-height: 1.6; color: var(--color-text-muted); margin: 0 0 20px; }
.help-contact-meta { display: flex; flex-direction: column; gap: 10px; }
.help-contact-meta span { display: flex; align-items: center; gap: 9px; font-size: 14px; color: var(--color-text-dim); }
.help-contact-meta svg { color: var(--color-accent-hover); }
.help-form { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-sm); }
.help-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.help-fld { margin-bottom: 14px; }
.help-fld label { display: block; font: 600 11px/1.4 var(--font-sans); text-transform: uppercase; letter-spacing: .03em; color: var(--color-text-muted); margin-bottom: 6px; }
.help-fld input, .help-fld textarea { width: 100%; padding: 10px 12px; border: 1px solid var(--color-border-strong); border-radius: var(--radius-lg); font-size: 14px; font-family: var(--font-sans); background: var(--color-card); color: var(--color-text); resize: vertical; }
.help-fld input::placeholder, .help-fld textarea::placeholder { color: var(--color-text-faint); }
@media (max-width: 1000px) { .help-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px) { .help-grid { grid-template-columns: 1fr; } .help-contact-in { grid-template-columns: 1fr; gap: 28px; padding: 28px; } .help-form-row { grid-template-columns: 1fr; } }

@media (max-width: 880px) {
  .hero-grid, .feat, .feat.rev .ftext { grid-template-columns: 1fr; }
  .feat.rev .ftext { order: 0; }
  .price-grid { grid-template-columns: repeat(2, 1fr); }
  .tpl-grid { grid-template-columns: repeat(2, 1fr); }
  .hero h1 { font-size: 38px; }
  .nav-links { display: none; }
}

/* ════════════════════════════════════════════════════════════
   LANDING PAGE v2 — breadth map, lifecycle, moats, proof, FAQ
   ════════════════════════════════════════════════════════════ */

/* hero scope chips */
.hero-scope { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 22px; }
.hero-scope span { display: inline-flex; align-items: center; gap: 6px; font: 600 12px/1 var(--font-sans); color: var(--color-text-dim); background: var(--color-card); border: 1px solid var(--color-border); border-radius: 9999px; padding: 7px 12px; }
.hero-scope svg { color: var(--color-accent-hover); }

/* ---- breadth map ("one platform, the whole job") ---- */
.breadth { background: var(--color-bg); border-top: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); }
.breadth-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.breadth-card { position: relative; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 20px; box-shadow: var(--shadow-sm); transition: box-shadow .16s, border-color .16s, transform .16s; display: block; }
.breadth-card:hover { box-shadow: var(--shadow-lg); border-color: var(--color-accent-border); transform: translateY(-2px); }
.breadth-card .bi { width: 42px; height: 42px; border-radius: 11px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.breadth-card h3 { font: 700 17px/1.1 var(--font-display); letter-spacing: -.01em; margin: 0 0 6px; color: var(--color-text); }
.breadth-card p { font-size: 13px; line-height: 1.5; color: var(--color-text-muted); margin: 0; }
.breadth-card .barrow { position: absolute; top: 18px; right: 18px; color: var(--color-text-faint); opacity: 0; transition: opacity .16s, transform .16s; }
.breadth-card:hover .barrow { opacity: 1; transform: translateX(2px); }

/* ---- lead-to-cash lifecycle strip ---- */
.lifecycle { background: var(--color-logo-bg); color: #fff; }
.lifecycle .sec-head h2 { color: #fff; }
.lifecycle .sec-head .ov { color: var(--sage-300); }
.lifecycle .sec-head p { color: #b5cdb5; }
.lc-track { display: grid; grid-template-columns: repeat(8, 1fr); gap: 0; margin-top: 8px; }
.lc-step { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; padding: 0 8px; }
.lc-step .lc-ico { width: 50px; height: 50px; border-radius: 14px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); color: #fff; display: flex; align-items: center; justify-content: center; margin-bottom: 13px; position: relative; z-index: 2; }
.lc-step.gate .lc-ico { background: var(--color-accent); border-color: var(--color-accent); box-shadow: 0 8px 20px rgba(22,163,74,.4); }
.lc-step .lc-n { font: 700 11px/1 var(--font-mono); color: var(--sage-300); margin-bottom: 6px; }
.lc-step .lc-t { font: 600 13px/1.3 var(--font-sans); color: #fff; }
.lc-step .lc-d { font-size: 11.5px; line-height: 1.4; color: #93b393; margin-top: 4px; }
.lc-step::before { content: ""; position: absolute; top: 25px; left: -50%; width: 100%; height: 2px; background: rgba(255,255,255,.14); z-index: 1; }
.lc-step:first-child::before { display: none; }
.lc-note { text-align: center; margin-top: 30px; font-size: 13.5px; color: #b5cdb5; }
.lc-note b { color: #fff; font-weight: 600; }

/* ---- why CrewOS / moats ---- */
.moats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.moat-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-sm); }
.moat-card.feature { grid-column: span 3; display: grid; grid-template-columns: 1fr 1fr; gap: 0; padding: 0; overflow: hidden; }
.moat-card .mi { width: 44px; height: 44px; border-radius: 11px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; margin-bottom: 15px; }
.moat-card h3 { font: 700 18px/1.2 var(--font-display); letter-spacing: -.01em; margin: 0 0 9px; color: var(--color-text); }
.moat-card p { font-size: 14px; line-height: 1.55; color: var(--color-text-muted); margin: 0; }
/* versus framing */
.versus { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 18px; }
.versus-col { border-radius: var(--radius-xl); padding: 22px; border: 1px solid var(--color-border); }
.versus-col.them { background: var(--color-card-alt); }
.versus-col.us { background: var(--color-accent-bg); border-color: var(--color-accent-border); }
.versus-col h4 { font: 600 12px/1 var(--font-sans); text-transform: uppercase; letter-spacing: .06em; margin: 0 0 14px; }
.versus-col.them h4 { color: var(--color-text-faint); }
.versus-col.us h4 { color: var(--color-accent-hover); }
.versus-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.versus-col li { display: flex; align-items: flex-start; gap: 9px; font-size: 14px; line-height: 1.45; }
.versus-col.them li { color: var(--color-text-muted); }
.versus-col.us li { color: var(--color-text-dim); font-weight: 500; }
.versus-col li svg { flex-shrink: 0; margin-top: 2px; }
.versus-col.them li svg { color: var(--color-text-faint); }
.versus-col.us li svg { color: var(--color-success); }

/* ---- proof ---- */
.proof-sec { background: var(--color-bg); border-top: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); }
.outcomes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 28px; }
.outcome { text-align: center; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 28px 20px; box-shadow: var(--shadow-sm); }
.outcome .on { font: 800 40px/1 var(--font-display); letter-spacing: -.02em; color: var(--color-accent-hover); margin-bottom: 8px; }
.outcome .ol { font-size: 14px; color: var(--color-text-muted); line-height: 1.45; }
.proof-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.quote-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.quote-card .qm { font-size: 15px; line-height: 1.6; color: var(--color-text-dim); margin: 0 0 20px; }
.quote-card .qm::before { content: "\201C"; }
.quote-card .qm::after { content: "\201D"; }
.quote-by { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.quote-av { width: 42px; height: 42px; border-radius: 9999px; background: var(--color-accent-bg); color: var(--color-accent-hover); display: flex; align-items: center; justify-content: center; font: 700 14px/1 var(--font-sans); flex-shrink: 0; }
.quote-meta .qn { font-size: 14px; font-weight: 600; color: var(--color-text); }
.quote-meta .qr { font-size: 12.5px; color: var(--color-text-muted); }
.proof-placeholder { font-size: 12px; color: var(--color-text-faint); font-style: italic; margin-top: 14px; text-align: center; }

/* ---- FAQ ---- */
.faq-wrap { max-width: 760px; margin: 0 auto; border-top: 1px solid var(--color-border); }
.faq-item { border-bottom: 1px solid var(--color-border); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 4px; background: none; border: 0; text-align: left; cursor: pointer; font: 600 17px/1.4 var(--font-display); color: var(--color-text); }
.faq-q .fchev { flex-shrink: 0; color: var(--color-text-faint); transition: transform .2s ease; }
.faq-item.open .faq-q .fchev { transform: rotate(180deg); color: var(--color-accent-hover); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.faq-a-in { padding: 0 4px 22px; font-size: 15px; line-height: 1.65; color: var(--color-text-muted); }
.faq-a-in a { color: var(--color-accent-hover); text-decoration: underline; text-underline-offset: 2px; }

@media (max-width: 1000px) {
  .breadth-grid { grid-template-columns: repeat(2, 1fr); }
  .lc-track { grid-template-columns: repeat(4, 1fr); row-gap: 30px; }
  .lc-step:nth-child(5)::before, .lc-step:nth-child(1)::before { display: none; }
}
@media (max-width: 880px) {
  .moats-grid, .moat-card.feature, .versus, .outcomes, .proof-grid { grid-template-columns: 1fr; }
  .moat-card.feature .moat-feat-img { display: none; }
}
@media (max-width: 620px) {
  .breadth-grid, .lc-track { grid-template-columns: 1fr; }
  .lc-step { flex-direction: row; gap: 14px; text-align: left; align-items: flex-start; }
  .lc-step::before { display: none; }
  .lc-step .lc-ico { margin-bottom: 0; }
}
