/* ==========================================================================
   WBIZ marketing site: design system (premium SaaS landing)
   Brand #1BAE63. One typeface (DM Sans). Body text never below 16px.
   No inline styles. Generous spacing, layered depth, gradient accents.
   ========================================================================== */

:root {
  /* Brand ramp from the logo green */
  --brand: #1bae63;
  --brand-400: #34c47a;
  --brand-500: #1bae63;
  --brand-600: #15994f;
  --brand-700: #0f7e44;
  --brand-800: #0b5f34;
  --brand-50: #ecfaf2;
  --brand-100: #d2f3e0;
  --brand-200: #a9e7c5;
  --grad: linear-gradient(135deg, #25c873 0%, #1bae63 45%, #0f9c52 100%);
  --grad-soft: linear-gradient(135deg, #eafaf1, #f3fbf7);

  /* Ink + neutrals, faintly green-tinted. Darkened for clear readability. */
  --ink: #07150e;
  --ink-2: #14271d;
  --body: #2f3d36;
  --muted: #54635b;
  --faint: #879389;
  --line: #e8efeb;
  --line-2: #f0f5f2;
  --bg: #ffffff;
  --bg-alt: #f5faf7;
  --bg-soft: #eef8f2;
  --dark: #06140d;
  --dark-2: #0c2117;
  --dark-3: #112c1e;
  --dark-line: #1c3b29;

  --radius: 18px;
  --radius-sm: 12px;
  --radius-lg: 28px;
  --radius-pill: 999px;

  /* Layered, soft shadows (the SaaS look) */
  --sh-xs: 0 1px 2px rgba(7,21,14,.06);
  --sh-sm: 0 2px 6px rgba(7,21,14,.05), 0 8px 20px rgba(7,21,14,.05);
  --sh: 0 10px 24px rgba(7,21,14,.07), 0 4px 8px rgba(7,21,14,.04);
  --sh-lg: 0 30px 70px rgba(7,21,14,.16), 0 10px 24px rgba(7,21,14,.08);
  --sh-glow: 0 20px 60px rgba(27,174,99,.28);

  --font: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --maxw: 1200px;
  --header-h: 78px;

  /* Spacing scale */
  --s-1: 6px; --s-2: 10px; --s-3: 16px; --s-4: 24px; --s-5: 36px; --s-6: 56px; --s-7: 80px; --s-8: 120px;

  /* Type: body 17px, never below 16px */
  --fs-body: 1.0625rem;   /* 17px */
  --fs-sm: 1rem;          /* 16px */
  --fs-lg: 1.25rem;       /* 20px */
  --fs-h1: clamp(2.6rem, 5.6vw, 4.25rem);
  --fs-h2: clamp(2rem, 4vw, 3rem);
  --fs-h3: clamp(1.25rem, 2vw, 1.55rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--font); font-size: var(--fs-body);
  line-height: 1.7; color: var(--body); background: var(--bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--brand-700); text-decoration: none; transition: color .15s; }
a:hover { color: var(--brand-800); }
h1, h2, h3, h4 { color: var(--ink); line-height: 1.18; margin: 0 0 .5em; font-weight: 800; letter-spacing: -.03em; }
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: 700; letter-spacing: -.02em; }
p { margin: 0 0 1rem; }
strong { color: var(--ink); }
::selection { background: var(--brand-200); color: var(--ink); }
.sr-only, .skip-link { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link:focus { position: fixed; top: 12px; left: 12px; width: auto; height: auto; clip: auto; background: var(--ink); color: #fff; padding: 10px 16px; border-radius: 10px; z-index: 200; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
/* Full-bleed container for the header (and any edge-to-edge band). */
.container-fluid { width: 100%; max-width: none; margin: 0; padding: 0 clamp(20px, 4vw, 56px); }
.section { padding: var(--s-8) 0; }
.section-sm { padding: var(--s-6) 0; }
.bg-alt { background: var(--bg-alt); }
.bg-tint { background: var(--grad-soft); }
.center { text-align: center; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 12px; font-size: .8rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: var(--brand-700);
  background: none; border: 0; padding: 0; border-radius: 0;
  margin-bottom: 20px; box-shadow: none;
}
.eyebrow::before { content: ""; width: 26px; height: 2px; border-radius: 2px; background: var(--grad); box-shadow: none; }
.section-head.center .eyebrow { gap: 0; flex-direction: column; }
.section-head.center .eyebrow::before { width: 36px; margin-bottom: 14px; }
.section-head { max-width: 760px; margin: 0 auto var(--s-6); }
.section-head.center { text-align: center; }
.section-head.center .eyebrow { margin-left: auto; margin-right: auto; }
.lede { font-size: var(--fs-lg); color: var(--muted); line-height: 1.6; }
.grad-text { background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: var(--brand); }

/* ----------------------------------------------------------------- buttons */
.btn {
  position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: inherit; font-size: var(--fs-sm); font-weight: 700; line-height: 1;
  padding: 15px 24px; border-radius: 14px; border: 1.5px solid transparent; cursor: pointer;
  transition: transform .14s ease, box-shadow .18s ease, background .18s, border-color .18s, color .18s;
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--grad); color: #fff; box-shadow: 0 10px 24px rgba(27,174,99,.30), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 16px 34px rgba(27,174,99,.38), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-ghost { background: #fff; color: var(--ink); border-color: var(--line); box-shadow: var(--sh-xs); }
.btn-ghost:hover { color: var(--ink); border-color: var(--brand-200); background: #fff; transform: translateY(-2px); box-shadow: var(--sh-sm); }
.btn-dark { background: var(--ink); color: #fff; }
.btn-dark:hover { background: var(--ink-2); color: #fff; }
.btn-block { width: 100%; }
.btn-lg { padding: 17px 30px; font-size: 1.05rem; border-radius: 15px; }

/* ----------------------------------------------------------------- header */
/* Transparent overlay by default: the hero sits underneath it. On scroll (or
   when the mobile menu is open) it turns into a solid glass bar. */
.site-header { position: sticky; top: 0; z-index: 100; background: transparent; border-bottom: 1px solid transparent; transition: background .25s, border-color .25s, box-shadow .25s, backdrop-filter .25s; }
.site-header.scrolled, .site-header.menu-open { background: rgba(255,255,255,.85); backdrop-filter: saturate(160%) blur(16px); -webkit-backdrop-filter: saturate(160%) blur(16px); border-bottom-color: var(--line); box-shadow: 0 6px 24px rgba(7,21,14,.05); }
.header-inner { display: flex; align-items: center; gap: 28px; height: 78px; }
.brand { display: flex; align-items: center; gap: 11px; }
.brand img { height: 34px; width: auto; }
.brand-sub { font-size: .72rem; font-weight: 700; letter-spacing: .02em; color: var(--muted); border-left: 1px solid var(--line); padding-left: 11px; }
.main-nav { margin-left: 6px; }
.nav-list { display: flex; align-items: center; gap: 2px; list-style: none; margin: 0; padding: 0; }
.nav-link { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-sm); font-weight: 600; color: var(--body); background: none; border: 0; cursor: pointer; font-family: inherit; padding: 9px 14px; border-radius: var(--radius-pill); transition: background .15s, color .15s; }
.nav-link:hover { color: var(--ink); background: var(--bg-alt); }
.nav-link.is-active { color: var(--brand-700); background: var(--brand-50); }
.nav-link .caret { width: 15px; height: 15px; transition: transform .2s; }
.has-mega.open .caret { transform: rotate(180deg); }
.header-cta { margin-left: auto; display: flex; align-items: center; gap: 10px; }

/* mega menu */
.has-mega { position: static; }
.mega-panel { position: absolute; left: 0; right: 0; top: 100%; background: #fff; border-top: 1px solid var(--line); box-shadow: 0 30px 60px rgba(7,21,14,.12); opacity: 0; visibility: hidden; transform: translateY(-10px); transition: opacity .2s, transform .2s, visibility .2s; }
.has-mega.open .mega-panel { opacity: 1; visibility: visible; transform: none; }
.mega-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; padding: 26px 28px; }
.mega-item { display: flex; gap: 14px; padding: 14px; border-radius: 14px; transition: background .15s, transform .15s; }
.mega-item:hover { background: var(--bg-alt); transform: translateX(2px); }
.mega-ico { flex: none; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: var(--brand-50); color: var(--brand-700); border: 1px solid var(--brand-100); }
.mega-ico svg { width: 21px; height: 21px; }
.mega-name { display: block; font-weight: 700; color: var(--ink); font-size: var(--fs-sm); }
.mega-tag { display: block; font-size: .9rem; color: var(--muted); margin-top: 2px; line-height: 1.45; }

.nav-toggle { display: none; margin-left: auto; background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 9px; color: var(--ink); cursor: pointer; box-shadow: var(--sh-xs); }
.nav-toggle svg { width: 22px; height: 22px; display: block; }
.nav-toggle .nt-open, .nav-toggle .nt-close { display: inline-flex; }
.nav-toggle .nt-close { display: none; }
.site-header.menu-open .nav-toggle .nt-open { display: none; }
.site-header.menu-open .nav-toggle .nt-close { display: inline-flex; }
.mobile-nav { display: none; border-top: 1px solid var(--line); background: #fff; max-height: 80vh; overflow: auto; }
.mobile-nav ul { list-style: none; margin: 0; padding: 16px 24px 26px; }
.mobile-nav a { display: block; padding: 12px 8px; font-weight: 600; color: var(--ink); font-size: var(--fs-sm); border-radius: 10px; }
.mobile-nav a:hover { background: var(--bg-alt); }
.mob-group-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); font-weight: 700; padding: 12px 8px 4px; }
.mob-sep { height: 1px; background: var(--line); margin: 12px 0; }

/* ----------------------------------------------------------------- hero */
.hero { position: relative; margin-top: calc(-1 * var(--header-h)); padding: calc(var(--header-h) + clamp(40px, 6vw, 80px)) 0 clamp(60px, 8vw, 100px); overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(1100px 520px at 78% -12%, rgba(27,174,99,.16), transparent 60%),
    radial-gradient(820px 460px at -5% 8%, rgba(37,200,115,.10), transparent 55%); }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image: linear-gradient(rgba(7,21,14,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(7,21,14,.035) 1px, transparent 1px);
  background-size: 46px 46px; mask-image: radial-gradient(900px 500px at 75% 0%, #000, transparent 75%); -webkit-mask-image: radial-gradient(900px 500px at 75% 0%, #000, transparent 75%); }
.hero-grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: 64px; align-items: center; }
.hero h1 { margin-bottom: 22px; }
.hero .lede { margin-bottom: 32px; max-width: 38ch; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 26px; }
.hero-trust { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; color: var(--muted); font-size: .96rem; font-weight: 500; }
.hero-trust .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--brand); }

/* ----------------------------------------------------------------- cards / grids */
.grid { display: grid; gap: 24px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.card { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 30px; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s, border-color .2s; }
.card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); border-color: var(--brand-200); }
.card-ico { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: var(--grad-soft); color: var(--brand-700); border: 1px solid var(--brand-100); margin-bottom: 20px; box-shadow: inset 0 1px 0 #fff; }
.card-ico svg { width: 25px; height: 25px; }
.card h3 { margin-bottom: 9px; }
.card p { color: var(--muted); margin: 0; font-size: var(--fs-sm); line-height: 1.6; }
.card-link { display: inline-flex; align-items: center; gap: 7px; margin-top: 18px; font-weight: 700; font-size: var(--fs-sm); color: var(--brand-700); }
.card-link svg { width: 16px; height: 16px; transition: transform .18s; }
.card:hover .card-link svg, .card-link:hover svg { transform: translateX(4px); }

/* ----------------------------------------------------------------- bento grid */
.bento { display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; }
.bento-card { position: relative; grid-column: span 3; display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 34px; box-shadow: var(--sh-sm); overflow: hidden; transition: transform .22s, box-shadow .22s, border-color .22s; }
.bento-card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); border-color: var(--brand-200); }
.bento-card.b-wide { grid-column: span 4; display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: center; }
.bento-card.b-narrow { grid-column: span 2; }
.bento-head { display: flex; flex-direction: column; }
.bento-head .card-ico { margin-bottom: 24px; }
.bento-head h3 { margin-bottom: 14px; line-height: 1.18; }
.bento-head p { color: var(--muted); margin: 0 0 20px; line-height: 1.7; font-size: var(--fs-sm); }
.bento-head .card-link { margin-top: auto; }
.bento-preview { margin-top: 24px; border: 1px solid var(--brand-100); background: var(--grad-soft); border-radius: 16px; padding: 18px; overflow: hidden; box-shadow: inset 0 1px 0 #fff; }
.bento-card.b-wide .bento-preview { margin-top: 0; }

/* mini mockups inside bento tiles */
.mini { display: flex; flex-direction: column; gap: 9px; }
.mini-chat { gap: 8px; }
.mini .bubble { max-width: 86%; font-size: .82rem; padding: 9px 12px; }
.mini .mock-flow { margin-bottom: 0; }
.mini .flow-node { font-size: .72rem; padding: 7px 10px; }
.mini-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.mini-kpi { background: #fff; border: 1px solid var(--brand-100); border-radius: 11px; padding: 10px; text-align: center; }
.mini-kpi b { display: block; color: var(--ink); font-size: 1.05rem; letter-spacing: -.02em; }
.mini-kpi span { font-size: .68rem; color: var(--muted); }
.mini-bars { display: flex; align-items: flex-end; gap: 7px; height: 56px; margin-top: 12px; }
.mini-bars i { flex: 1; display: block; background: var(--grad); border-radius: 5px 5px 0 0; opacity: .9; }
.mini-bars i:nth-child(1) { height: 38%; } .mini-bars i:nth-child(2) { height: 60%; } .mini-bars i:nth-child(3) { height: 48%; } .mini-bars i:nth-child(4) { height: 78%; } .mini-bars i:nth-child(5) { height: 66%; } .mini-bars i:nth-child(6) { height: 90%; } .mini-bars i:nth-child(7) { height: 72%; }
.mini-code { background: var(--dark); border: 1px solid var(--dark-line); border-radius: 12px; padding: 15px; display: flex; flex-direction: column; gap: 9px; }
.mini-code .ln { font-size: .78rem; color: #cfe9da; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: .01em; }
.mini-code .k { color: var(--brand-400); font-weight: 700; } .mini-code .mut { color: #7fa692; } .mini-code .ok { color: #34c47a; }

.feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.feature-row.flip .feature-media { order: -1; }
/* equal-height dashboard mockups across feature rows */
.feature-media .mockup { width: 100%; }
.feature-media .mock-window { display: flex; flex-direction: column; height: 430px; }
.feature-media .mock-window > .mock-body,
.feature-media .mock-window > .mock-main { flex: 1 1 auto; min-height: 0; }
.feature-media .mock-body { height: auto; }
.feature-media .mock-main { overflow: hidden; }
.check-list { list-style: none; margin: 22px 0 0; padding: 0; }
.check-list li { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 14px; font-size: var(--fs-sm); color: var(--body); }
.check-list .tick { flex: none; width: 24px; height: 24px; border-radius: 50%; background: var(--grad-soft); color: var(--brand-700); display: grid; place-items: center; border: 1px solid var(--brand-100); }
.check-list .tick svg { width: 14px; height: 14px; }

.stat-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 28px; }
.stat { text-align: center; }
.stat .num { font-size: clamp(2.2rem, 4vw, 3rem); font-weight: 800; letter-spacing: -.03em; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stat .lbl { color: var(--muted); font-size: var(--fs-sm); margin-top: 2px; }

/* CTA band */
.cta-band { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--dark), var(--dark-3)); color: #cfe9da; border-radius: var(--radius-lg); padding: clamp(40px, 6vw, 72px); text-align: center; box-shadow: var(--sh-lg); }
.cta-band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(600px 300px at 50% -20%, rgba(27,174,99,.35), transparent 65%); }
.cta-band > * { position: relative; }
.cta-band h2 { color: #fff; }
.cta-band p { color: #a9c9b6; max-width: 56ch; margin: 0 auto 30px; font-size: var(--fs-lg); }

/* ----------------------------------------------------------------- footer */
.site-footer { background: var(--bg); border-top: 1px solid var(--line); color: var(--muted); margin-top: 0; }

/* newsletter row */
.footer-news-row { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; padding: 48px 28px; border-bottom: 1px solid var(--line); }
.footer-news-copy h3 { font-size: clamp(1.2rem, 2.2vw, 1.6rem); color: var(--ink); margin: 0; line-height: 1.25; }
.news-form { display: flex; align-items: stretch; gap: 10px; }
.news-field { position: relative; display: block; }
.news-field .news-ico { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--faint); pointer-events: none; display: flex; }
.news-field .news-ico svg { width: 18px; height: 18px; }
.news-form input { width: 320px; max-width: 60vw; background: var(--bg-alt); border: 1.5px solid var(--line); color: var(--ink); border-radius: 14px; padding: 15px 16px 15px 44px; font-family: inherit; font-size: .95rem; }
.news-form input::placeholder { color: var(--faint); }
.news-form input:focus { outline: none; border-color: var(--brand-200); box-shadow: 0 0 0 4px rgba(27,174,99,.12); }

/* main row */
.footer-top { display: grid; grid-template-columns: 1.5fr 1.7fr; gap: 40px; padding: 56px 28px 40px; }
.footer-brand img { height: 36px; margin-bottom: 18px; }
.footer-blurb { font-size: var(--fs-sm); color: var(--muted); max-width: 40ch; line-height: 1.65; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.footer-col h4 { color: var(--ink); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 16px; }
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 11px; }
.footer-col a { color: var(--muted); font-size: var(--fs-sm); }
.footer-col a:hover { color: var(--brand-700); }

/* Meta verified badge */
.meta-badge { display: inline-flex; align-items: center; gap: 14px; margin-top: 24px; padding: 18px 22px; background: var(--bg-alt); border: 1px solid var(--line); border-radius: 18px; }
.meta-logo { width: 34px; height: 34px; flex: none; fill: #0866ff; }
.meta-badge-text { display: flex; flex-direction: column; gap: 3px; line-height: 1.35; }
.meta-badge-text strong { font-size: .95rem; color: var(--ink); font-weight: 700; }
.meta-badge-text span { font-size: .78rem; color: var(--muted); }
.meta-verified { flex: none; width: 24px; height: 24px; border-radius: 50%; background: #0866ff; color: #fff; display: grid; place-items: center; }
.meta-verified svg { width: 14px; height: 14px; stroke-width: 3; }

/* bottom bar */
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 22px 28px 40px; border-top: 1px solid var(--line); }
.copy { margin: 0; font-size: .9rem; color: var(--faint); }
.copy a { color: var(--brand-700); font-weight: 600; }
.legal-links { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; }
.legal-links a { color: var(--faint); font-size: .9rem; }
.legal-links a:hover { color: var(--brand-700); }

/* ----------------------------------------------------------------- mockups */
.mockup { position: relative; }
.mockup::before { content: ""; position: absolute; inset: -8% -4% -10% -4%; z-index: -1; background: radial-gradient(60% 60% at 60% 35%, rgba(27,174,99,.22), transparent 70%); filter: blur(10px); }
.mock-window { background: #fff; border: 1px solid var(--line); border-radius: 20px; box-shadow: var(--sh-lg); overflow: hidden; animation: floaty 7s ease-in-out infinite; }
.mock-window.tilt { animation: floatyTilt 9s ease-in-out infinite; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes floatyTilt { 0%,100% { transform: perspective(1500px) rotateY(-8deg) rotateX(3deg) translateY(0); } 50% { transform: perspective(1500px) rotateY(-8deg) rotateX(3deg) translateY(-12px); } }
.mock-bar { display: flex; align-items: center; gap: 7px; padding: 13px 16px; background: var(--bg-alt); border-bottom: 1px solid var(--line); }
.mock-dot { width: 11px; height: 11px; border-radius: 50%; }
.mock-dot:nth-child(1) { background: #ff5f57; } .mock-dot:nth-child(2) { background: #febc2e; } .mock-dot:nth-child(3) { background: #28c840; }
.mock-url { margin-left: 12px; flex: 1; height: 24px; border-radius: 8px; background: #fff; border: 1px solid var(--line); }
.mock-body { display: grid; grid-template-columns: 140px 1fr; min-height: 340px; }
.mock-side { background: linear-gradient(180deg, var(--dark-2), var(--dark)); padding: 18px 13px; display: flex; flex-direction: column; gap: 10px; }
.mock-side .s-logo { height: 20px; width: 68px; border-radius: 7px; background: #1f4030; margin-bottom: 8px; }
.mock-side .s-item { height: 13px; border-radius: 7px; background: #163322; }
.mock-side .s-item.on { background: var(--grad); width: 86%; }
.mock-main { padding: 20px; background: #fff; }
.mock-row { display: flex; gap: 12px; margin-bottom: 14px; }
.sk { background: linear-gradient(100deg, #eef4f0 30%, #f8fbf9 50%, #eef4f0 70%); background-size: 200% 100%; animation: shimmer 1.8s linear infinite; border-radius: 8px; }
@keyframes shimmer { to { background-position: -200% 0; } }
.sk.h10 { height: 10px; } .sk.h14 { height: 14px; } .sk.h18 { height: 18px; } .sk.h40 { height: 40px; } .sk.h64 { height: 64px; } .sk.h120 { height: 120px; }
.sk.w40 { width: 40%; } .sk.w60 { width: 60%; } .sk.w80 { width: 80%; } .sk.full { width: 100%; } .sk.pill { border-radius: 999px; }
.mock-kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 16px; }
.mock-kpi { border: 1px solid var(--line); border-radius: 12px; padding: 14px; background: #fff; }
.mock-kpi .v { font-weight: 800; color: var(--ink); font-size: 1.35rem; letter-spacing: -.02em; }
.mock-kpi .l { font-size: .72rem; color: var(--muted); }
.mock-chat { display: flex; flex-direction: column; gap: 10px; }
.bubble { max-width: 74%; padding: 10px 13px; border-radius: 14px; font-size: .85rem; line-height: 1.45; }
.bubble.in { background: var(--bg-alt); border: 1px solid var(--line); border-bottom-left-radius: 4px; align-self: flex-start; color: var(--ink); }
.bubble.out { background: var(--grad-soft); border: 1px solid var(--brand-100); border-bottom-right-radius: 4px; align-self: flex-end; color: var(--brand-800); }
.bubble.pop { animation: pop .5s ease both; }
.bubble.d1 { animation-delay: .5s; } .bubble.d2 { animation-delay: 1s; } .bubble.d3 { animation-delay: 1.5s; }
@keyframes pop { from { opacity: 0; transform: translateY(7px) scale(.97); } to { opacity: 1; transform: none; } }
.mock-chart { display: flex; align-items: flex-end; gap: 9px; height: 118px; padding-top: 8px; }
.mock-chart .bar { flex: 1; background: var(--brand-100); border-radius: 7px 7px 0 0; position: relative; animation: grow 1.2s cubic-bezier(.2,.8,.2,1) both; }
.mock-chart .bar::after { content: ""; position: absolute; inset: auto 0 0 0; height: 42%; background: var(--grad); border-radius: 7px 7px 0 0; }
@keyframes grow { from { transform: scaleY(.18); transform-origin: bottom; opacity: .4; } to { transform: none; opacity: 1; } }
.mock-flow { display: flex; align-items: center; flex-wrap: wrap; margin-bottom: 14px; }
.flow-node { border: 1.5px solid var(--brand-200); background: var(--grad-soft); color: var(--brand-800); font-size: .78rem; font-weight: 700; padding: 10px 13px; border-radius: 11px; box-shadow: var(--sh-xs); }
.flow-link { width: 28px; height: 2px; background: var(--brand-200); }
.mock-chip { position: absolute; background: #fff; border: 1px solid var(--line); box-shadow: var(--sh); border-radius: 14px; padding: 11px 14px; display: flex; align-items: center; gap: 10px; font-size: .83rem; font-weight: 700; color: var(--ink); z-index: 2; }
.mock-chip svg { width: 18px; height: 18px; color: var(--brand); }
.mock-chip.tl { top: -16px; left: -20px; animation: floaty 6s ease-in-out infinite; }
.mock-chip.br { bottom: -18px; right: -18px; animation: floaty 6.5s ease-in-out .5s infinite; }

.logo-strip { display: flex; align-items: center; justify-content: center; gap: 48px; flex-wrap: wrap; opacity: .65; }
.logo-strip span { font-weight: 800; color: var(--muted); font-size: 1.15rem; letter-spacing: -.02em; }

/* ----------------------------------------------------------------- headline rotator */
.rotator { display: inline-grid; vertical-align: bottom; }
.rotator > span { grid-area: 1 / 1; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; opacity: 0; animation: rotword 10s linear infinite; }
.rotator > span:nth-child(1) { animation-delay: 0s; } .rotator > span:nth-child(2) { animation-delay: 2s; } .rotator > span:nth-child(3) { animation-delay: 4s; } .rotator > span:nth-child(4) { animation-delay: 6s; } .rotator > span:nth-child(5) { animation-delay: 8s; }
@keyframes rotword { 0%,16% { opacity: 1; transform: translateY(0); } 20%,100% { opacity: 0; transform: translateY(-14px); } }
@media (prefers-reduced-motion: reduce) { .rotator > span { animation: none; } .rotator > span:nth-child(1) { opacity: 1; } }

/* ----------------------------------------------------------------- steps */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.step { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 28px; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; }
.step:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.step .step-num { width: 48px; height: 48px; border-radius: 14px; background: var(--grad); color: #fff; font-weight: 800; display: grid; place-items: center; margin-bottom: 18px; font-size: 1.25rem; box-shadow: 0 8px 18px rgba(27,174,99,.28); }
.step h3 { margin-bottom: 7px; }
.step p { color: var(--muted); font-size: var(--fs-sm); margin: 0; }

/* connected icon timeline variant */
.steps.timeline { gap: 0; align-items: start; }
.steps.timeline .step { background: none; border: 0; box-shadow: none; padding: 0; text-align: center; }
.steps.timeline .step:hover { transform: none; box-shadow: none; }
.steps.timeline .step-ico { position: relative; width: 60px; height: 60px; border-radius: 16px; margin: 0 auto 22px; display: grid; place-items: center; background: var(--grad-soft); color: var(--brand-700); border: 1px solid var(--brand-100); z-index: 1; }
.steps.timeline .step-ico svg { width: 26px; height: 26px; }
/* dashed connector between icons */
.steps.timeline .step:not(:last-child) .step-ico::after { content: ""; position: absolute; left: calc(50% + 40px); top: 50%; width: calc(100% - 80px); height: 0; border-top: 2px dashed var(--brand-200); }
.steps.timeline .step h3 { margin-bottom: 9px; }
.steps.timeline .step p { max-width: 30ch; margin: 0 auto; }

/* ----------------------------------------------------------------- comparison */
.compare { width: 100%; border-collapse: separate; border-spacing: 0; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--sh-sm); }
.compare th, .compare td { padding: 17px 20px; text-align: left; border-bottom: 1px solid var(--line-2); }
.compare thead th { background: var(--bg-alt); font-size: .82rem; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); }
.compare thead th:first-child { color: var(--ink); }
.compare th.us, .compare td.us { background: var(--brand-50); }
.compare thead th.us { color: var(--brand-700); }
.compare .yes { color: var(--brand-700); font-weight: 800; }
.compare .no { color: #c2cdc7; }
.compare tbody tr:last-child td { border-bottom: 0; }
.compare tbody td:first-child { font-weight: 600; color: var(--ink); }

/* ----------------------------------------------------------------- testimonials */
.testi { display: flex; flex-direction: column; gap: 16px; }
.testi .quote { font-size: 1.1rem; color: var(--ink); line-height: 1.6; font-weight: 500; }
.testi .who { font-size: .92rem; color: var(--muted); font-weight: 600; }

/* ----------------------------------------------------------------- FAQ */
.faq { max-width: 820px; margin: 0 auto; }
.faq details { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 4px 22px; margin-bottom: 14px; box-shadow: var(--sh-xs); transition: border-color .15s, box-shadow .15s; }
.faq details[open] { border-color: var(--brand-200); box-shadow: var(--sh-sm); }
.faq summary { cursor: pointer; list-style: none; padding: 19px 0; font-weight: 700; color: var(--ink); display: flex; justify-content: space-between; gap: 16px; align-items: center; font-size: var(--fs-sm); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 1.5rem; color: var(--brand); font-weight: 400; line-height: 1; transition: transform .2s; }
.faq details[open] summary::after { content: "\2013"; }
.faq .answer { padding: 0 0 20px; color: var(--muted); font-size: var(--fs-sm); line-height: 1.65; }

/* ----------------------------------------------------------------- use cases */
.usecase h3 { display: flex; align-items: center; gap: 12px; }
.usecase .uc-ico { width: 44px; height: 44px; border-radius: 12px; background: var(--grad-soft); color: var(--brand-700); display: grid; place-items: center; border: 1px solid var(--brand-100); }
.usecase .uc-ico svg { width: 21px; height: 21px; }

/* ----------------------------------------------------------------- pricing */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: start; }
.price-card { position: relative; display: flex; flex-direction: column; }
.price-card.is-popular { border-color: var(--brand); box-shadow: var(--sh-lg); }
.price-badge { position: absolute; top: -13px; left: 28px; background: var(--grad); color: #fff; font-size: .72rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; padding: 5px 13px; border-radius: 999px; box-shadow: 0 6px 14px rgba(27,174,99,.3); }
.price-desc { color: var(--muted); font-size: var(--fs-sm); margin: 2px 0 16px; }
.price-amount { font-size: 2.6rem; font-weight: 800; color: var(--ink); letter-spacing: -.03em; }
.price-interval { color: var(--muted); font-size: .9rem; margin-bottom: 20px; }
.price-card .btn { margin: 6px 0 18px; }
.price-features { list-style: none; margin: 0; padding: 0; }
.price-features li { position: relative; padding: 8px 0 8px 28px; font-size: var(--fs-sm); color: var(--body); border-top: 1px solid var(--line-2); }
.price-features li::before { content: ""; position: absolute; left: 0; top: 14px; width: 14px; height: 8px; border-left: 2px solid var(--brand); border-bottom: 2px solid var(--brand); transform: rotate(-45deg); }
.price-loading, .price-fallback { text-align: center; color: var(--muted); padding: 36px; grid-column: 1 / -1; }
.price-fallback p { margin-bottom: 16px; }

/* ----------------------------------------------------------------- inner page hero + prose */
.page-hero { position: relative; margin-top: calc(-1 * var(--header-h)); padding: calc(var(--header-h) + 44px) 0 52px; overflow: hidden; background: var(--grad-soft); border-bottom: 1px solid var(--line-2); }
.page-hero::after { content: ""; position: absolute; inset: 0; z-index: 0; background: radial-gradient(700px 320px at 80% -20%, rgba(27,174,99,.12), transparent 60%); }
.page-hero .container { position: relative; z-index: 1; }
.page-hero h1 { margin-bottom: 14px; }
.page-hero .lede { max-width: 62ch; }
.breadcrumb { font-size: .85rem; color: var(--muted); margin-bottom: 16px; }
.breadcrumb a { color: var(--muted); } .breadcrumb a:hover { color: var(--brand-700); }
.prose { max-width: 780px; margin: 0 auto; }
.prose h2 { font-size: 1.7rem; margin: 42px 0 14px; }
.prose h3 { font-size: 1.25rem; margin: 30px 0 8px; }
.prose p, .prose li { font-size: var(--fs-body); color: var(--body); line-height: 1.75; }
.prose ul, .prose ol { padding-left: 24px; margin: 0 0 18px; }
.prose li { margin-bottom: 9px; }
.prose a { text-decoration: underline; }
.prose table { width: 100%; border-collapse: collapse; margin: 20px 0; }
.prose th, .prose td { border: 1px solid var(--line); padding: 11px 13px; text-align: left; font-size: var(--fs-sm); }
.prose th { background: var(--bg-alt); }

/* blog cards */
.post-card { position: relative; display: flex; flex-direction: column; height: 100%; padding: 26px; }
.post-card .post-ico { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: var(--grad-soft); color: var(--brand-700); border: 1px solid var(--brand-100); margin-bottom: 16px; }
.post-card .post-ico svg { width: 21px; height: 21px; }
.post-card .cat { font-size: .74rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--brand-700); }
.post-card h3 { margin: 8px 0 9px; font-size: 1.2rem; line-height: 1.3; }
.post-card h3 a { color: var(--ink); }
.post-card h3 a::after { content: ""; position: absolute; inset: 0; border-radius: inherit; }
.post-card:hover h3 a { color: var(--brand-700); }
.post-card p { color: var(--muted); font-size: var(--fs-sm); line-height: 1.6; flex: 1; margin: 0; }
.post-card .post-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--line-2); }
.post-card .post-arrow { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; color: var(--brand-700); transition: background .15s, transform .15s; }
.post-card .post-arrow svg { width: 15px; height: 15px; }
.post-card:hover .post-arrow { background: var(--brand-50); transform: translateX(3px); }
.post-meta { font-size: .85rem; color: var(--faint); margin-top: 16px; }
.post-card .post-meta { margin-top: 0; }

/* featured post */
.post-feature { display: grid; grid-template-columns: 1.45fr 1fr; overflow: hidden; }
.post-feature .pf-body { padding: clamp(28px, 4vw, 52px); display: flex; flex-direction: column; }
.post-feature .pf-tags { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.post-feature .pf-tags .cat { font-size: .74rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.post-feature h2 { font-size: clamp(1.5rem, 3vw, 2.2rem); line-height: 1.18; margin-bottom: 14px; }
.post-feature h2 a { color: var(--ink); }
.post-feature h2 a:hover { color: var(--brand-700); }
.post-feature p { color: var(--muted); font-size: 1.02rem; line-height: 1.65; margin: 0; max-width: 54ch; }
.post-feature .pf-cover { position: relative; background: var(--grad); display: grid; place-items: center; min-height: 260px; overflow: hidden; }
.post-feature .pf-cover::after { content: ""; position: absolute; inset: 0; background: radial-gradient(420px 220px at 70% 20%, rgba(255,255,255,.28), transparent 60%); }
.post-feature .pf-cover svg { width: 84px; height: 84px; color: #fff; opacity: .92; position: relative; }

/* single article hero banner (a post is the only blog page with .post-meta) */
body[data-page="blog"] .page-hero .cat { display: inline-block; font-size: .74rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--brand-700); background: var(--brand-50); border: 1px solid var(--brand-100); padding: 5px 13px; border-radius: var(--radius-pill); margin-bottom: 18px; }
body[data-page="blog"] .page-hero:has(.post-meta) { text-align: center; padding-bottom: clamp(44px, 6vw, 72px); }
body[data-page="blog"] .page-hero:has(.post-meta) .breadcrumb { display: none; }
body[data-page="blog"] .page-hero:has(.post-meta) h1 { max-width: 22ch; margin: 0 auto 6px; font-size: clamp(2rem, 4.6vw, 3.1rem); line-height: 1.14; }
body[data-page="blog"] .page-hero:has(.post-meta) .post-meta { margin-top: 18px; font-size: .92rem; color: var(--muted); }
.prose > p:first-of-type { font-size: 1.16rem; line-height: 1.7; color: var(--ink); }
.prose h2 { scroll-margin-top: calc(var(--header-h) + 16px); }
.prose ul li::marker, .prose ol li::marker { color: var(--brand); }

/* ----------------------------------------------------------------- contact */
.contact-grid { align-items: start; gap: 40px; }
.contact-card { padding: clamp(26px, 3vw, 40px); }
.contact-card h2 { font-size: 1.5rem; margin-bottom: 8px; }

.contact-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form .field { display: block; margin-bottom: 16px; }
.contact-form .field-label { display: block; font-size: .8rem; font-weight: 700; color: var(--body); margin-bottom: 7px; }
.contact-form .field-opt { color: var(--faint); font-weight: 500; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1.5px solid var(--line); border-radius: 12px; background: var(--bg-alt); padding: 13px 15px; font-family: inherit; font-size: .95rem; color: var(--ink); }
.contact-form select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2354635b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-size: 18px; padding-right: 40px; cursor: pointer; }
.contact-form textarea { resize: vertical; line-height: 1.6; }
.contact-form input::placeholder, .contact-form textarea::placeholder { color: var(--faint); }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { outline: none; border-color: var(--brand-200); box-shadow: 0 0 0 4px rgba(27,174,99,.12); background-color: #fff; }
.contact-form .form-foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; padding-top: 18px; border-top: 1px solid var(--line-2); margin-top: 4px; }
.contact-form .form-foot .muted-note { margin: 0; max-width: 38ch; }
.contact-form .form-foot .btn { flex: none; }

/* three-reason cards */
.reason-card { position: relative; display: flex; flex-direction: column; padding: 28px; }
.reason-card .r-ico { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 22px; border: 1px solid var(--line); }
.reason-card .r-ico svg { width: 23px; height: 23px; }
.reason-card .r-ico.t-green { background: var(--grad-soft); color: var(--brand-700); border-color: var(--brand-100); }
.reason-card .r-ico.t-indigo { background: #eef0ff; color: #5b5bd6; border-color: #e0e3ff; }
.reason-card .r-ico.t-amber { background: #fff6e8; color: #b4690e; border-color: #ffe7c2; }
.reason-card .r-label { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .09em; color: var(--faint); }
.reason-card h3 { margin: 7px 0 16px; font-size: 1.2rem; color: var(--ink); }
.reason-card .r-email { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: var(--fs-sm); color: var(--brand-700); }
.reason-card .r-email svg { width: 16px; height: 16px; transition: transform .15s; }
.reason-card .r-email::after { content: ""; position: absolute; inset: 0; border-radius: inherit; }
.reason-card:hover .r-email svg { transform: translateX(4px); }
.reason-card .r-note { margin-top: 12px; font-size: .82rem; color: var(--faint); }

/* ----------------------------------------------------------------- product pages */
/* drop the breadcrumb for the cleaner banner look used site-wide */
body[data-page^="product"] .breadcrumb { display: none; }

/* remove the stat strip and the closing CTA band on every product page */
body[data-page^="product"] .section-sm:has(.stat-strip),
body[data-page^="product"] .section:has(.cta-band) { display: none; }

/* premium gradient-border cards (matches the homepage gcard language) */
body[data-page^="product"] .card { border-color: transparent; box-shadow: var(--sh-sm); }
body[data-page^="product"] .card::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; background: linear-gradient(150deg, rgba(27,174,99,.5), rgba(27,174,99,0) 45%, rgba(27,174,99,.22) 100%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
body[data-page^="product"] .card:hover { border-color: transparent; }

/* the closing "plays nicely with" statement reads as an intentional panel */
body[data-page^="product"] .section:has(> .container > .section-head:only-child) > .container { background: var(--bg-alt); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(40px, 6vw, 72px) clamp(24px, 4vw, 56px); }
body[data-page^="product"] .section:has(> .container > .section-head:only-child) .section-head { margin-bottom: 0; }

/* hero: keep the product mockup from feeling cramped on the right */
body[data-page^="product"] .page-hero .feature-row { align-items: center; gap: clamp(40px, 5vw, 72px); }

/* ----------------------------------------------------------------- utilities */
.row-center { justify-content: center; }
.ta-center { text-align: center; }
.mx-auto { margin-left: auto; margin-right: auto; }
.ml-auto { margin-left: auto; }
.measure { max-width: 760px; }
.measure-wide { max-width: 900px; }
.measure-54 { max-width: 54ch; }
.p-sm { padding: 18px; } .p-md { padding: 26px; } .p-lg { padding: 28px; }
.ov-auto { overflow: auto; }
.mt-14 { margin-top: 14px; } .mt-16 { margin-top: 16px; } .mt-18 { margin-top: 18px; } .mt-24 { margin-top: 24px; } .mt-28 { margin-top: 28px; }
.muted-note { color: var(--muted); font-size: var(--fs-sm); }
.lead-strong { font-weight: 700; color: var(--ink); }
.mock-main--white { background: #fff; }
.icon-badge-lg { margin-left: auto; margin-right: auto; width: 64px; height: 64px; }
.cta-band .btn-ghost { color: #fff; border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.06); box-shadow: none; }
.cta-band .btn-ghost:hover { background: rgba(255,255,255,.14); color: #fff; border-color: rgba(255,255,255,.4); }

/* ==========================================================================
   PREMIUM "agency" theme: dark mesh, framed panel, gradient borders, tags,
   italic heading accent, numbered insights, integration chips.
   ========================================================================== */

/* italic gradient accent word inside headings: <h1>Run your WhatsApp <em>inbox.</em></h1> */
h1 em, h2 em, .h-accent { font-style: italic; font-weight: 700; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; padding: .04em .12em .08em 0; margin: 0 -.06em; -webkit-box-decoration-break: clone; box-decoration-break: clone; }

/* dark mesh surface (hero, CTA, dark boxes) */
.mesh-dark { position: relative; background: radial-gradient(900px 520px at 82% -10%, rgba(37,200,115,.35), transparent 58%), radial-gradient(700px 500px at 8% 110%, rgba(15,150,82,.28), transparent 60%), linear-gradient(160deg, #0b2417 0%, #06140d 60%); color: #cfe9da; overflow: hidden; }
.mesh-dark::after { content: ""; position: absolute; inset: 0; pointer-events: none; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 52px 52px; mask-image: radial-gradient(80% 70% at 70% 10%, #000, transparent 80%); -webkit-mask-image: radial-gradient(80% 70% at 70% 10%, #000, transparent 80%); }
.mesh-dark h1, .mesh-dark h2, .mesh-dark h3 { color: #fff; }
.mesh-dark p, .mesh-dark .lede { color: #a9c9b6; }
.on-dark-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #bdebcf; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16); padding: 7px 14px; border-radius: var(--radius-pill); margin-bottom: 22px; }
.on-dark-eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--brand-400); box-shadow: 0 0 0 4px rgba(37,200,115,.25); }

/* dark hero (overlaps the transparent header) */
.hero-dark { position: relative; margin-top: calc(-1 * var(--header-h)); padding: calc(var(--header-h) + clamp(60px, 8vw, 104px)) 0 calc(clamp(60px, 8vw, 104px) + 120px); }
.hero-dark .hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 60px; align-items: center; }
.hero-dark .lede { max-width: 40ch; margin-bottom: 30px; }
.hero-stats { display: flex; gap: 32px; flex-wrap: wrap; margin-top: 34px; padding-top: 26px; border-top: 1px solid rgba(255,255,255,.12); }
.hero-stats .hs b { display: block; font-size: 1.7rem; font-weight: 800; color: #fff; letter-spacing: -.02em; }
.hero-stats .hs span { font-size: .9rem; color: #93b1a1; }

/* the light page panel that rises over the dark hero (framed look) */
.panel-rise { position: relative; z-index: 2; background: var(--bg); border-radius: 32px 32px 0 0; margin-top: -120px; box-shadow: 0 -30px 60px rgba(7,21,14,.10); }
.panel-rise > .container:first-child { padding-top: clamp(48px, 6vw, 80px); }

/* light buttons on dark */
.btn-light { background: #fff; color: var(--ink); }
.btn-light:hover { background: #eafaf1; color: var(--ink); transform: translateY(-2px); }
.btn-outline-light { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.28); }
.btn-outline-light:hover { background: rgba(255,255,255,.14); color: #fff; border-color: rgba(255,255,255,.5); }

/* gradient-border card */
.gcard { position: relative; background: #fff; border-radius: 22px; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; }
.gcard::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; background: linear-gradient(150deg, rgba(27,174,99,.55), rgba(27,174,99,0) 42%, rgba(27,174,99,.22) 100%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.gcard:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }

/* tag chips */
.tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 16px; }
.tag { font-size: .76rem; font-weight: 600; color: var(--brand-700); background: var(--brand-50); border: 1px solid var(--brand-100); border-radius: var(--radius-pill); padding: 4px 11px; }
.tag.muted { color: var(--muted); background: var(--bg-alt); border-color: var(--line); }

/* services grid with a sticky left title (repeats while cards scroll) */
.svc-wrap { display: grid; grid-template-columns: 300px 1fr; gap: 48px; align-items: start; }
.svc-sticky { position: sticky; top: calc(var(--header-h) + 24px); }
.svc-sticky h2 { margin-bottom: 14px; }
.svc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.svc-card { padding: 24px; display: flex; flex-direction: column; }
.svc-card .svc-ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--grad-soft); color: var(--brand-700); border: 1px solid var(--brand-100); margin-bottom: 16px; }
.svc-card .svc-ico svg { width: 22px; height: 22px; }
.svc-card h3 { font-size: 1.15rem; margin-bottom: 8px; }
.svc-card p { color: var(--muted); font-size: var(--fs-sm); margin: 0; line-height: 1.6; }

/* dark boxed section (goals / use-cases list) */
.box-dark { border-radius: var(--radius-lg); padding: clamp(36px, 5vw, 64px); }
.goal-list { display: flex; flex-direction: column; gap: 0; margin-top: 12px; }
.goal-row { display: flex; align-items: center; gap: 18px; padding: 22px 4px; border-top: 1px solid rgba(255,255,255,.12); transition: padding-left .2s; }
.goal-row:last-child { border-bottom: 1px solid rgba(255,255,255,.12); }
.goal-row:hover { padding-left: 12px; }
.goal-row .g-name { font-size: clamp(1.2rem, 2.4vw, 1.8rem); font-weight: 700; color: #fff; }
.goal-row .g-tags { margin-left: auto; display: flex; gap: 8px; flex-wrap: wrap; }
.goal-row .g-tags span { font-size: .78rem; color: #bdebcf; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius-pill); padding: 5px 12px; }

/* integration / stack chips */
.stack-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.stack-chip { aspect-ratio: 1 / .82; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 9px; background: #fff; border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--sh-xs); transition: transform .15s, box-shadow .15s, border-color .15s; }
.stack-chip:hover { transform: translateY(-3px); box-shadow: var(--sh-sm); border-color: var(--brand-200); }
.stack-chip svg { width: 24px; height: 24px; color: var(--brand-700); }
.stack-chip span { font-size: .82rem; font-weight: 600; color: var(--body); }

/* ==== reference-style bento grid ==== */
.bento-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.bento-tile { border-radius: 26px; padding: clamp(30px, 3vw, 48px); position: relative; overflow: hidden; }
.tile-light { background: linear-gradient(158deg, #eef9f2 0%, #ffffff 62%); border: 1px solid var(--line); }
.tile-light .eyebrow { margin-bottom: 22px; }
.tile-light h2 { font-size: clamp(1.7rem, 3vw, 2.4rem); line-height: 1.12; margin-bottom: 20px; }
.tile-light h2 .muted-h { color: var(--faint); }
.tile-light p { color: var(--muted); max-width: 46ch; margin: 0; }
.tile-dark { display: flex; flex-direction: column; }
.tile-dark h3 { font-size: clamp(1.4rem, 2.4vw, 1.9rem); color: #fff; margin-bottom: 10px; }
.tile-dark > p { color: #a9c9b6; margin: 0 0 26px; }
.chip-cloud { display: flex; flex-wrap: wrap; gap: 12px; margin-top: auto; }
.chip-cloud .chip { display: inline-flex; align-items: center; gap: 9px; padding: 11px 17px; border-radius: var(--radius-pill); background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); color: #dceae2; font-weight: 600; font-size: .95rem; transition: background .15s, transform .15s; }
.chip-cloud .chip:hover { background: rgba(255,255,255,.12); transform: translateY(-2px); }
.chip-cloud .chip svg { width: 17px; height: 17px; color: var(--brand-400); }

.bento-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 24px; }
.bento-feat { background: linear-gradient(158deg, #eef9f2 0%, #ffffff 66%); border: 1px solid var(--line); border-radius: 26px; padding: clamp(28px, 2.6vw, 40px); transition: transform .2s, box-shadow .2s; }
.bento-feat:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.bento-feat .svc-ico { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: #fff; color: var(--brand-700); border: 1px solid var(--brand-100); box-shadow: var(--sh-xs); margin-bottom: 28px; }
.bento-feat .svc-ico svg { width: 24px; height: 24px; }
.bento-feat h3 { font-size: 1.35rem; margin-bottom: 12px; }
.bento-feat p { color: var(--muted); margin: 0; line-height: 1.65; }

/* ==== use-case tabs ==== */
.uc-tabs { display: inline-flex; flex-wrap: wrap; gap: 6px; padding: 6px; background: var(--bg-alt); border: 1px solid var(--line); border-radius: var(--radius-pill); margin: 0 auto var(--s-6); }
.uc-tab { border: 0; background: transparent; font: inherit; font-weight: 600; font-size: var(--fs-sm); color: var(--muted); padding: 10px 20px; border-radius: var(--radius-pill); cursor: pointer; transition: background .15s, color .15s, box-shadow .15s; }
.uc-tab:hover { color: var(--ink); }
.uc-tab.is-active { background: #fff; color: var(--brand-700); box-shadow: var(--sh-xs); }
.uc-panel { display: none; }
.uc-panel.is-active { display: block; }

/* ==== full-bleed dark CTA ==== */
.cta-build { position: relative; overflow: hidden; padding: clamp(72px, 11vw, 140px) 0; }
.eyebrow-dark { display: inline-flex; align-items: center; gap: 11px; font-size: .8rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--brand-400); margin-bottom: 22px; }
.eyebrow-dark::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--brand-400); box-shadow: 0 0 0 4px rgba(37,200,115,.22); }
.cta-build h2 { color: #fff; font-size: clamp(2.4rem, 6vw, 4.6rem); line-height: 1.04; margin: 0; max-width: 18ch; }
.cta-build-row { display: flex; align-items: center; gap: 28px; margin-top: 40px; flex-wrap: wrap; }
.cta-build-note { color: #a9c9b6; font-size: var(--fs-sm); max-width: 38ch; margin: 0; line-height: 1.6; }
.btn-cta-pill { display: inline-flex; align-items: center; gap: 14px; background: var(--grad); color: #fff; font-weight: 700; font-size: 1.05rem; padding: 12px 12px 12px 28px; border-radius: var(--radius-pill); box-shadow: 0 16px 34px rgba(27,174,99,.4); transition: transform .15s, box-shadow .15s; white-space: nowrap; }
.btn-cta-pill:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 22px 44px rgba(27,174,99,.5); }
.cta-arrow { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.22); display: grid; place-items: center; flex: none; }
.cta-arrow svg { width: 18px; height: 18px; transform: rotate(-45deg); }

/* ==== comparison cell marks ==== */
.compare .yes { display: inline-grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: var(--grad-soft); color: var(--brand-700); border: 1px solid var(--brand-100); }
.compare .yes svg { width: 15px; height: 15px; }
.compare .no { display: inline-grid; place-items: center; width: 26px; height: 26px; color: #c2cdc7; }
.compare .no svg { width: 15px; height: 15px; }
.compare .lim { font-size: .82rem; font-weight: 600; color: var(--muted); }
.compare th.us, .compare td.us { text-align: center; }
.compare thead th:not(:first-child), .compare tbody td:not(:first-child) { text-align: center; }

/* ==== detailed comparison ==== */
.compare-rich { table-layout: fixed; min-width: 680px; }
.compare-rich thead th { vertical-align: bottom; padding: 22px 18px; }
.compare-rich thead th:first-child { width: 38%; }
.compare-rich .th-lead { font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.compare-rich .th-name { display: block; font-size: 1.05rem; font-weight: 800; letter-spacing: -.02em; color: var(--ink); text-transform: none; }
.compare-rich .th-sub { display: block; margin-top: 4px; font-size: .74rem; font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--muted); }
.compare-rich thead th.us { background: var(--grad-soft); border-top: 2px solid var(--brand); border-radius: 14px 14px 0 0; }
.compare-rich thead th.us .th-name { color: var(--brand-700); }
.compare-rich thead th.us .th-sub { color: var(--brand-700); opacity: .8; }
.compare-rich tbody td { vertical-align: middle; }
.compare-rich .cmp-feat { display: block; font-weight: 700; color: var(--ink); font-size: var(--fs-sm); }
.compare-rich .cmp-desc { display: block; margin-top: 3px; font-size: .82rem; font-weight: 400; color: var(--muted); line-height: 1.5; }
.compare-rich td.us { background: rgba(27,174,99,.06); }
.compare-rich tbody tr:last-child td.us { border-radius: 0 0 14px 14px; }
.compare-rich .cmp-val { font-weight: 700; font-size: .9rem; color: var(--ink); }
.compare-rich td.us .cmp-val { color: var(--brand-700); }

[data-table] { overflow-x: auto; }

/* ==== use-case panel heading ==== */
.h-lg { font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height: 1.15; margin-bottom: 4px; }

/* ==== single testimonial ==== */
.testi-single { max-width: 820px; margin: 0 auto; text-align: center; }
.testi-single blockquote { margin: 0; font-size: clamp(1.3rem, 2.6vw, 1.85rem); line-height: 1.4; font-weight: 600; color: var(--ink); letter-spacing: -.01em; }
.testi-single blockquote::before { content: "\201C"; }
.testi-single blockquote::after { content: "\201D"; }
.testi-single figcaption { display: inline-flex; align-items: center; gap: 12px; margin-top: 26px; text-align: left; }
.testi-single .t-avatar { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: var(--grad); color: #fff; }
.testi-single .t-avatar svg { width: 22px; height: 22px; }
.testi-single figcaption b { display: block; color: var(--ink); font-size: var(--fs-sm); }
.testi-single .t-role { font-size: .88rem; color: var(--muted); }

/* numbered insight rows */
.insights-list { border-top: 1px solid var(--line); }
.insight-row { display: grid; grid-template-columns: 44px 1fr auto; gap: 18px; align-items: center; padding: 22px 8px; border-bottom: 1px solid var(--line); transition: background .15s, padding-left .2s; }
.insight-row:hover { background: var(--bg-alt); padding-left: 16px; }
.insight-row .i-num { font-family: inherit; font-weight: 800; color: var(--brand-200); font-size: 1.15rem; }
.insight-row .i-title { font-weight: 700; color: var(--ink); font-size: 1.1rem; }
.insight-row .i-cat { display: block; font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--brand-700); margin-bottom: 3px; }
.insight-row .i-arrow { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; color: var(--brand-700); transition: background .15s, transform .15s; }
.insight-row:hover .i-arrow { background: var(--brand-50); transform: translateX(4px); }
.insight-row .i-arrow svg { width: 17px; height: 17px; }

/* two-column FAQ (title left, accordions right) */
.faq-split { display: grid; grid-template-columns: 360px 1fr; gap: 48px; align-items: start; }
.faq-split .faq { max-width: none; margin: 0; }

/* dark hero/section nav: light header text over the dark hero until scrolled */
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .nav-link { color: rgba(255,255,255,.85); }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .nav-link:hover { color: #fff; background: rgba(255,255,255,.12); }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .nav-link.is-active { color: #fff; background: rgba(255,255,255,.14); }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .brand-sub { color: rgba(255,255,255,.72); border-color: rgba(255,255,255,.22); }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .btn-ghost { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,.24); box-shadow: none; }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .nav-toggle { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,.24); }
body.dark-hero .site-header:not(.scrolled):not(.menu-open) .brand img { filter: brightness(0) invert(1); }

/* ----------------------------------------------------------------- scroll reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ----------------------------------------------------------------- book a call */
.booking-grid { grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: start; }
.booking-h2 { margin-bottom: 6px; }
.booking-embed { border: 1px solid var(--line); border-radius: 18px; background: var(--card, #fff); box-shadow: 0 10px 40px rgba(16,24,32,.06); overflow: hidden; }
.calendly-inline-widget { min-width: 320px; width: 100%; height: 720px; }
.booking-embed noscript { display: block; padding: 28px; text-align: center; color: var(--muted); }

.booking-points { display: grid; gap: 14px; }
.bpoint { display: flex; gap: 14px; align-items: center; padding: 14px 16px; border: 1px solid var(--line); border-radius: 14px; background: var(--bg-alt); }
.bpoint .bp-ico { flex: none; width: 42px; height: 42px; border-radius: 12px; background: var(--grad-soft); color: var(--brand-700); display: grid; place-items: center; border: 1px solid var(--brand-100); }
.bpoint .bp-ico svg { width: 20px; height: 20px; }
.bpoint strong { display: block; font-size: var(--fs-sm); color: var(--ink); }
.bpoint span { font-size: .85rem; color: var(--muted); }

@media (max-width: 900px) {
  .booking-grid { grid-template-columns: 1fr; gap: 32px; }
  .calendly-inline-widget { height: 1000px; }
}

/* ----------------------------------------------------------------- form states + honeypot */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form-error { margin: 14px 0 0; padding: 12px 14px; border-radius: 10px; background: #FEF2F2; border: 1px solid #FCA5A5; color: #B91C1C; font-size: var(--fs-sm); }
.form-error a { color: inherit; text-decoration: underline; }
.news-note { margin: 10px 0 0; font-size: .9rem; }
.news-ok { color: var(--brand-700, #157a47); }
.news-err { color: #DC2626; }
