{
  "icp": "mid-market and enterprise revenue teams already running their pipeline on Salesforce Sales Cloud — B2B SaaS, financial services, manufacturing, and professional services that close on the phone",
  "capabilities": {
    "availability": {
      "headline": "Captures the website inquiry or caller as the right Salesforce record, books the meeting if there's real intent, and feeds one unified conversion pipe for your website forms AND your AI Receptionist.",
      "lede": "Every caller who lands on the line becomes the right Salesforce record (a Lead when they're net-new, a Task on the existing Contact when they're already on an Account, with the right OwnerId, LeadSource, and Account link). When they want a meeting, AnyCRM creates a native Salesforce Event on the matched team member's calendar. AND the same lead event flows through one unified pipe (with the same shape, same source attribution, and same server-side conversion path used by your website forms) so your Salesforce business logic and your Google / Facebook / LinkedIn Ads both stay in sync.",
      "cards": [
        {
          "num": "A.01",
          "title": "Every caller becomes the right Salesforce record, not a stray missed call",
          "body": "The AI Receptionist captures first name, last name, email, phone, company, and call intent. Then AnyCRM writes the record into Salesforce as a Lead (with the right OwnerId, LeadSource, and RecordTypeId) for net-new callers, or as a Task on the existing Contact and any open Opportunity for returning ones. DURING the call."
        },
        {
          "num": "A.02",
          "title": "Books meetings as native Salesforce Events",
          "body": "The meeting lands as a Salesforce Event with OwnerId set to the matched team member (so it lands on their calendar, not the integration user's), WhoId pointing at the Lead or Contact, and WhatId pointing at the related Account or Opportunity. Surfaces on the activity timeline of every related record, and syncs to the team member's Google or Outlook calendar through Lightning Sync or Einstein Activity Capture."
        },
        {
          "num": "A.03",
          "title": "Sends the lead event straight to your CRM. You decide what happens next.",
          "body": "AnyCRM does not pretend to know your deal-creation rules. Every Lead-create and every Event-book sends a lead event straight to your CRM (with <code>source: \"AI Receptionist Call\"</code> or <code>source: \"AI Receptionist Web\"</code>) where YOUR business logic takes over. Convert the Lead, open the Opportunity, set the Stage, assign the Territory, route through a Flow. We set up the receiving end inside your Salesforce org for you during onboarding, tuned to your industry and your client configuration. AnyCRM doesn't get in the way of policy you've already encoded."
        }
      ],
      "apiSummary": "The AI Receptionist asks AnyCRM for availability against the people on your team and gets back open slots in the caller's timezone. No double bookings. Your busy time is always respected. Every AnyCRM call prevents duplicate records by running cross-object dedup across Lead and Contact, links to the existing Account, sets the OwnerId (matched from your team), sends the <code>Sforce-Auto-Assign: TRUE</code> header so your Assignment Rules and Territory rules fire, writes the Event so Lightning Sync / Einstein Activity Capture surfaces it on the team member's connected Google or Outlook calendar, and sends the lead event straight into your CRM tagged with <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>. The same lead also feeds the AnyCRM Conversion Lift pipeline (covered in the next capability) so your Google, Facebook, and LinkedIn Ads start optimising against the call and chat leads that actually pick up the phone.",
      "tools": [
        "getSalesforceAvailability",
        "createSalesforceContactAppointment"
      ],
      "curl1Path": "/mcp/tools/getSalesforceAvailability",
      "curl2Path": "/mcp/tools/createSalesforceContactAppointment",
      "pipeIntro": "Most businesses run two completely separate conversion-tracking stacks: one for the website (Web-to-Lead forms, chatflows, page-load pixels) and a totally absent one for the phone and the AI Receptionist. So Google Ads and Facebook Ads only learn from form-fills, the bidding optimises for the wrong audience, attribution is broken, and analytics double-count or miss real conversations entirely. AnyCRM closes that gap by running BOTH surfaces through a single conversion pipe.",
      "pipeStages": [
        {
          "stage": "1. Capture",
          "body": "A lead arrives either through your website form / chatflow OR through the AI Receptionist on phone / chat. Either way, AnyCRM produces the same clean lead-event shape, tagged at source with either <code>AI Receptionist Call</code>, <code>AI Receptionist Web</code>, or your website's form identifier. One vocabulary across both surfaces."
        },
        {
          "stage": "2. Deliver to your CRM",
          "body": "AnyCRM sends the lead event straight to your Salesforce org, into the receiving flow we wired up for you at onboarding. Your business logic decides what happens next: which Lead Queue, which Assignment Rule, which Opportunity, which Stage, which Flow. You don't have to maintain two sets of rules. Web leads and AI Receptionist leads both arrive through the same door."
        },
        {
          "stage": "3. Fire server-side conversion to your ad platforms",
          "body": "The same lead event fires server-side into Google Ads, Facebook Ads, and your analytics platform, using the origin of the domain you registered with AnyCRM. Server-side means the conversion can't be blocked by ad-blockers, doesn't degrade under iOS / Safari tracking restrictions, and lands with full attribution context."
        },
        {
          "stage": "4. Optimise, attribute, report",
          "body": "Because website conversions AND AI Receptionist conversions flow through the same pipe with the same source taxonomy, your Google Ads bid strategy now optimises against real revenue (not just form-fill noise), your Facebook Ads campaigns see the high-intent traffic that picks up the phone, your analytics platform sees a single unified funnel, and attribution stops fragmenting between web and voice."
        }
      ],
      "outcomes": [
        "<strong>Higher ROAS.</strong> Ad bidding optimises against actual conversations and booked Salesforce Events, not against the noisy subset of leads that happen to fill a Web-to-Lead form.",
        "<strong>Lower ad costs.</strong> Once Google Ads and Facebook Ads learn what a real lead looks like, they stop spending against lookalikes of low-quality form-fills.",
        "<strong>Enriched analytics.</strong> Every conversation surface (web form, web chat, phone call, AI Receptionist chat) feeds the same event shape into your analytics, so funnels are complete instead of half-blind.",
        "<strong>Correct attribution.</strong> A caller who first saw a Google Ad, then visited the site, then phoned three days later gets attributed end-to-end. Voice traffic stops being invisible to your marketing stack.",
        "<strong>One source of truth for lead policy.</strong> Your Salesforce flow owns Lead conversion, Opportunity creation, and Stage routing. AnyCRM doesn't drift out of date because AnyCRM never tried to own that policy in the first place."
      ],
      "whyThisIsBetter": "Most competitor AI Receptionists try to maintain rules for when an Opportunity is created, what Stage it goes in, and which LeadSource to apply. That approach breaks the moment your business changes, and it ignores the conversion-tracking surface entirely. AnyCRM inverts the responsibility. AnyCRM stays focused on the conversation (capture, dedup, route, book, cancel) and delivers a clean lead event to the two destinations that matter: your Salesforce org (for business logic) and your ad platforms server-side (for conversion optimisation, attribution, and ROAS). This is a custom service baked into the AI Receptionist package. We configure the lead-receiving flow inside your Salesforce org AND the server-side conversion tracking at onboarding, matched to your specific industry, ad mix, and analytics setup.",
      "honestAside": "We'll be candid: as far as we can tell, none of our competitors have thought of this yet. They sell AI Receptionists as a phone-answering product. AnyCRM treats the AI Receptionist as one of two equally weighted entries into a unified lead-event pipe, and that's where the real compounding value sits."
    },
    "adsConversionLift": {
      "headline": "Turns every call and chat into a real conversion event your Google, Facebook, and LinkedIn Ads can actually optimise against. So Cost per Lead drops, ROAS goes up, and CAC stops being a guess.",
      "lede": "If you run paid Ads on Google, Facebook, or LinkedIn, here is the uncomfortable truth: those platforms only get smarter when they see real conversions. Today, a Web-to-Lead form-fill counts. A real phone call from a high-intent buyer who picked up the phone at 7pm does NOT count. So Google bids harder on the audience that fills forms (often the cheaper, lower-intent one) and ignores the audience that actually calls. Cost per Lead looks fine. CAC quietly creeps up. ROAS looks misleading. AnyCRM fixes this. Every call and chat the AI Receptionist handles is sent as a real conversion event to Google Ads, Facebook Ads, AND LinkedIn Ads. The bidding algorithm finally sees what's actually working.",
      "cards": [
        {
          "num": "1b.01",
          "title": "Every phone call and every chat becomes a tracked conversion. Not just website form-fills.",
          "body": "Today, Google Ads and Facebook Ads probably think your only conversions are Web-to-Lead form-fills. That's why your Cost per Lead looks low but your AEs complain the leads are weak. The high-intent traffic is calling you instead of filling a form, and the Ad platforms have no idea. AnyCRM sends every call and every chat the AI Receptionist handles into your Ad platforms as a real conversion event. Suddenly Google, Facebook, and LinkedIn can see the FULL picture of who is converting from your Ads."
        },
        {
          "num": "1b.02",
          "title": "Lower Cost per Lead. Better ROAS. Smaller CAC.",
          "body": "Once your Ad platforms can see the phone calls and chats as real conversions, they re-train on a better signal. Bidding shifts toward audiences that actually pick up the phone, not just the audience that loves filling out forms. In practice this means: <strong>Cost per Lead drops</strong> because you stop overpaying for low-intent form-fills; <strong>Return on Ad Spend goes up</strong> because the Ads now find people closer to ready-to-buy; and <strong>Customer Acquisition Cost shrinks</strong> because more of your Ad budget reaches buyers who will actually convert into closed-won Opportunities."
        },
        {
          "num": "1b.03",
          "title": "The same pipe carries your website forms too. One source of truth across Ads, Salesforce, and Analytics.",
          "body": "AnyCRM doesn't just track AI Receptionist conversions. It also runs your existing Web-to-Lead forms and chatflows through the same pipeline. So a lead from a Google Ad that fills a form on your website AND a lead from a Facebook Ad that called the AI Receptionist three days later both end up tagged, attributed, and counted in exactly the same way. Your Ads platform stops double-counting, your analytics stop fragmenting, and your Salesforce org stops being half-blind to where your leads actually came from."
        }
      ],
      "apiSummary": "Every Lead-create and Event-book fires through AnyCRM's Conversion Lift pipeline. The lead event lands inside your Salesforce org for business logic, AND fires a real conversion event server-side into Google Ads, Facebook Ads, and LinkedIn Ads using the verified origin of your registered domain. Server-side means the conversion can't be blocked by ad-blockers, doesn't degrade on iOS or Safari, and arrives with full attribution context so the Ad platforms' bidding algorithms can re-train on it. Your existing Web-to-Lead forms run through the same pipeline, so Web and Voice conversions feed the SAME training signal.",
      "businessImpact": [
        "<strong>Cost per Lead drops.</strong> Because Google, Facebook, and LinkedIn stop wasting your Ad budget on lookalikes of low-intent form-fillers, and start finding the audience that picks up the phone.",
        "<strong>Return on Ad Spend (ROAS) goes up.</strong> Because the Ads now optimise toward conversations that actually close, not toward whichever cheap audience generates the most Web-to-Lead submissions.",
        "<strong>Customer Acquisition Cost (CAC) shrinks.</strong> Because a higher share of every Ad dollar reaches buyers ready to talk to a human (or in this case, your AI Receptionist).",
        "<strong>Analytics get a complete funnel.</strong> Web and voice leads sit side by side, with the same source taxonomy. You stop seeing \"50% of revenue: unknown source.\"",
        "<strong>Attribution stops fragmenting.</strong> A buyer who first clicked a Google Ad, then called the business three days later, finally shows up correctly attributed. Today, that buyer is invisible to your Ads stack.",
        "<strong>You finally know if Ads are working.</strong> Most businesses cannot honestly tell you whether their Google or Facebook spend is profitable. With AnyCRM's Conversion Lift, you can."
      ],
      "plainEnglishExample": "Imagine you spend $5,000/month on Google Ads. Today, you see 80 Web-to-Lead form-fills and assume that's the full picture. With AnyCRM running, you'll also see (say) 60 phone calls and 45 web chats the AI Receptionist handled, all flowing into Google Ads as real conversions. Suddenly Google sees 185 conversions a month instead of 80. It re-trains on that bigger, better signal. Within weeks, the bidding finds you more of the right kind of buyer. Same $5,000 spend, more real conversations, lower Cost per Lead, higher revenue. That is what \"AI Receptionist with AnyCRM\" actually means for the bottom line. Not just \"it answers the phone.\"",
      "tools": [
        "createOrUpdatesSalesforceContact",
        "createSalesforceContactAppointment"
      ]
    },
    "lifecycle": {
      "headline": "Manages the full Event and Task lifecycle inside Salesforce for anyone calling or chatting.",
      "lede": "Every \"push the demo to Thursday\" or \"actually, cancel that\" lands with the AI Receptionist instead of in your email inbox. AnyCRM reschedules update the existing Salesforce Event in place. Cancellations follow Salesforce's own idiom. Outcome flagged, reason captured as a completed Task on the related record. Instead of DELETING the Event and erasing the activity timeline, you get crystal clarity on when a Salesforce Event was created, and when and why it was updated by your AI Receptionist.",
      "cards": [
        {
          "num": "B.01",
          "title": "Finds the meeting by email in a single step without needing a Salesforce record ID",
          "body": "Customers DO NOT quote Salesforce 18-character record IDs over the phone. We've tested with hundreds of callers and each time they were asked 'Can you tell me the meeting ID from your email?', the response was the same: 'Why can't you find it yourself?'. AnyCRM gives the AI Receptionist an easy way to find the soonest upcoming Event associated to the matching Lead or Contact. And the AnyCRM response forces the AI Receptionist to be human. It reads back the Subject, date, time, and owning team member before changing anything."
        },
        {
          "num": "B.02",
          "title": "Reschedules in place and keeps the Event data clean",
          "body": "Rescheduling updates the existing Event in a single confirmation. No cancel-then-rebook round-trip means the Event history, the WhoId/WhatId links to the Contact and Opportunity, and the calendar sync all stay intact. Failed reschedules leave the original Event untouched."
        },
        {
          "num": "B.03",
          "title": "Cancels without erasing the audit trail",
          "body": "When a caller cancels, AnyCRM flags the Event cancelled the way Salesforce's own reporting expects (a completed Task with the reason on the related Lead, Contact, or Opportunity, plus the Event updated in place). No DELETE that would Recycle-Bin the record and strip WHY the meeting fell through. This lets you intuitively track changes for Salesforce Events created or updated by your AI Receptionist."
        }
      ],
      "apiSummary": "AnyCRM's search, reschedule, and cancel all accept just an email. The soonest upcoming Salesforce Event linked to the matching Lead or Contact is resolved inside AnyCRM. No record IDs at the AI Receptionist layer.",
      "tools": [
        "searchSalesforceAppointments",
        "rescheduleSalesforceAppointment",
        "cancelSalesforceAppointment"
      ],
      "curl1Path": "/mcp/tools/searchSalesforceAppointments",
      "curl2Path": "/mcp/tools/rescheduleSalesforceAppointment",
      "curl3Path": "/mcp/tools/cancelSalesforceAppointment"
    },
    "routing": {
      "headline": "Routes every caller to the right team member. And maintains the existing OwnerId on the Lead, Contact, or Opportunity instead of randomly reassigning to someone else.",
      "lede": "Salesforce orgs run on Users, Roles, Profiles, Queues, and Territories. At setup AnyCRM imports your active Salesforce User roster into its database and enriches each team member with lane, expertise, languages, timezone, and the meeting templates they actually book. The AI Receptionist then routes each caller to the team member who actually handles that lane. Existing OwnerId on Leads, Contacts, and Opportunities is honoured as the source of truth.",
      "cards": [
        {
          "num": "C.01",
          "title": "Routes by lane: AE vs SDR vs CS vs SE",
          "body": "\"I'd like to talk to someone about pricing\" routes to your AE pool. \"I'm still evaluating\" routes to an SDR for qualification. \"I'm already a customer and have a question\" routes to the CSM looking after the Account. And the existing OwnerId on the Contact or Opportunity is always preserved."
        },
        {
          "num": "C.02",
          "title": "Honours existing OwnerId on Leads, Contacts, and Opportunities",
          "body": "If a Lead, Contact, or Opportunity already has an OwnerId, the AI Receptionist doesn't reassign. The Task, the Event, and any new related record attach under the existing Owner. No orphaned duplicate Lead, no Opportunity poached off a team member's forecast."
        },
        {
          "num": "C.03",
          "title": "Matches fresh inbound callers and website chatters to the right person on the team",
          "body": "New leads with no existing Lead or Contact get assigned via the Lead Queue and Assignment Rule you've designated for that lane, honouring the criteria you set in AnyCRM for matching a lead to a team member. AnyCRM sends <code>Sforce-Auto-Assign: TRUE</code> on every Lead create so your Territory rules, Round-Robin Flows, and Einstein Lead Scoring kick in normally. The AI Receptionist doesn't fight the rules you already use."
        }
      ],
      "apiSummary": "Team details live in AnyCRM's database, pulled once from Salesforce at setup (every active User with their Profile, Role, Queue memberships, and timezone), enriched with lane, expertise, languages, timezone, and meeting-template duration (valuable context for the AI Receptionist that Salesforce doesn't provide by default). At runtime, one read of the team roster matches caller → lane → team member. New Leads get the matched team member as OwnerId (or drop into the right Queue). Existing records keep theirs. AnyCRM does NOT cache your Opportunity stages, your Lead conversion paths, or your Flows. That policy stays inside your Salesforce org, where it belongs.",
      "tools": [
        "listSalesforceTeamMembers",
        "getSalesforceUserProfile"
      ],
      "curl1Path": "/mcp/tools/listSalesforceTeamMembers",
      "curl2Path": "/mcp/tools/getSalesforceUserProfile"
    }
  },
  "setup": {
    "headline": "Setup in 3 steps. Battle-tested on real <span data-tpl-crm>Salesforce</span> orgs.",
    "lede": "You connect <span data-tpl-crm>Salesforce</span> once. AnyCRM imports your team, your LeadSource picklist, your Record Types, your Queues, and your meeting templates. AnyCRM also wires up the receiving end inside your Salesforce org so lead events from the AI Receptionist land where your business logic can act on them. Then the AI Receptionist starts capturing leads and booking meetings the same afternoon. No middleware. No prompt-engineering by you.",
    "steps": [
      {
        "num": "S.01",
        "title": "Connect Salesforce (Connected App OAuth, 60 seconds)",
        "body": "Authorize AnyCRM on your Salesforce org via the OAuth 2.0 Web Server flow against our Connected App. AnyCRM scopes to the least amount of access needed for the booking lifecycle (REST and SOQL on the standard objects, plus offline refresh). Nothing for analytics, marketing, billing, or forecast data. You can always revoke permissions at any time from Setup → Connected Apps OAuth Usage. Every update to your Salesforce org is signed with AnyCRM's Connected App credentials so it's easy to track what the AI Receptionist did when you audit in Login History and Setup Audit Trail."
      },
      {
        "num": "S.02",
        "title": "Import the team. Lock in your picklists and Record Types. Wire up your CRM's lead-receiving flow.",
        "body": "AnyCRM imports every active Salesforce User as a bookable team member with lane, expertise, languages, timezone, and meeting-template duration. AnyCRM also freezes your LeadSource picklist values, your Record Type IDs per object, and your active Lead Queues so the AI Receptionist can only write values that actually exist in your org, and locks inbound-call source attribution (always <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>) so reporting stays consistent. During onboarding we set up the receiving flow inside your Salesforce org so the lead events from the AI Receptionist land where your business logic can act on them. AnyCRM does NOT replicate your Opportunity stages, your conversion Flows, or your Approval processes. Your Salesforce org decides what happens after a lead is captured. AnyCRM just delivers a clean event."
      },
      {
        "num": "S.03",
        "title": "Drop the AI Receptionist on your phone line and your site",
        "body": "Forward your business number to the AI Receptionist's number and paste the chat widget into your site. The same AI Receptionist (same team roster, same Salesforce org, same lead-event pipe into your CRM and your ad platforms) answers both voice and web. Live the same afternoon."
      }
    ],
    "nativeAlternative": {
      "headline": "Why not just use Salesforce's <strong>Web-to-Lead + Salesforce Scheduler + Agentforce</strong>?",
      "body": "Web-to-Lead, Salesforce Scheduler, and Salesforce's own Agentforce (the AI agent platform formerly known as Einstein Copilot, with its SDR agent and Agentforce Voice) are excellent at the steps AFTER a prospect has chosen to come to you via your website, your authenticated portal, or your existing customer-service surface. They don't pick up your inbound business phone line. A new caller at 9pm gets a missed call, not a Lead. A Web-to-Lead submission sits in the Lead Queue until someone reads it. Agentforce is powerful, but it lives inside your Salesforce licensing footprint (Agentforce Sales tiers start at $175/user/month and climb steeply), it's tuned to the agent-building paradigm rather than the inbound-phone-receptionist paradigm, and the configuration work to make it answer the phone, capture the right Lead, and book on the right team member's calendar is substantial. The AI Receptionist is the layer BEFORE all of that. It picks up the call, asks the right qualifying questions, books the meeting as a native Salesforce Event on the right team member's calendar, writes a clean Lead (with the source set to <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>, the right RecordTypeId, your locked LeadSource, and a call summary as a Task), AND sends the same lead event straight into your CRM's downstream business logic plus your ad platforms server-side. So your Salesforce Flows, your analytics, and your Google / Facebook Ads bidding all start optimising on a real conversation, not a name and a missed call. Buyers who already run Agentforce: AnyCRM sits in front, captures the call cleanly, and hands the Lead off to Agentforce's downstream agents the way the rest of your stack expects."
    },
    "enrichmentSummary": "Every tool the AI Receptionist calls is an opinionated wrapper inside AnyCRM. AnyCRM does the messy work for you. Cross-object dedup across Lead and Contact, Account linking, picklist validation against your Record Type, polymorphic WhoId/WhatId pairing, ActivityDateTime UTC math, validation-rule survival, error normalisation, lead-event delivery into your Salesforce org, and server-side conversion tracking into your ad platforms. All of it happens before the LLM ever sees a response. So the AI Receptionist reasons over clean, AI-aligned payloads instead of raw Salesforce internals.",
    "enrichmentExamples": [
      {
        "title": "Capturing a new lead",
        "raw": "Writing a Lead straight into Salesforce looks simple. But Salesforce does not dedup for you across Lead and Contact (the two objects are separate, and a caller who is already a Contact under an existing Account becomes a fresh Lead under the wrong stage if you don't check both). LeadSource is a restricted picklist (send a value not in the picklist and the Lead rejects on a field integrity error). RecordTypeId is required on orgs with multiple Record Types and there is no default (omit it and the Lead is rejected or lands on the wrong page layout). Many production orgs run validation rules requiring Company, Country, or a Lead Score threshold, and the rules surface as opaque field-custom-validation errors with messages your end-users wrote. If you want the Lead routed through a Lead Queue with an Assignment Rule, you need to pass the <code>Sforce-Auto-Assign: TRUE</code> header (it's off by default, so naive integrations create Leads that sit unassigned in the integration user's personal queue forever). And nothing in raw Salesforce fires a server-side conversion event to your ad platforms, so call-driven and chat-driven leads never get optimised for.",
        "mcp": "<code>createOrUpdatesSalesforceContact</code> accepts <code>name</code>, <code>email</code>, <code>phone</code>, <code>note</code>, <code>company</code>, <code>lead_intent</code>, plus the matched team member. AnyCRM runs the cross-object dedup across Lead and Contact, picks the surviving record (or creates a new Lead with the right Record Type, your locked LeadSource, and required fields populated from setup defaults), always sends <code>Sforce-Auto-Assign: TRUE</code> so your Assignment Rules fire, parses validation-rule errors into human-readable messages, attaches the call note as a Task on the resulting record, sends the lead event straight into your CRM (with source <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>), AND fires a server-side conversion event into your ad platforms using the origin of your registered domain. All in one AnyCRM call."
      },
      {
        "title": "Booking the meeting",
        "raw": "Creating an Event directly against Salesforce is a tight contract. The polymorphic relationship fields are unforgiving: WhoId is restricted to Lead or Contact only; WhatId is Account, Opportunity, Case, Campaign, or any custom object enabled for Activities. Pass a Contact ID in WhatId and the Event rejects. Pass an Opportunity ID in WhoId and same. ActivityDateTime must be UTC; DurationInMinutes is required and there is no default. OwnerId is the calendar the Event lands on (omit it and the Event lands on the integration user's calendar, not the team member's, so they walk into Tuesday morning unaware they have a 10am demo). To get the Event onto the team member's connected Google or Outlook calendar, the team member must have Lightning Sync or Einstein Activity Capture configured.",
        "mcp": "<code>createSalesforceContactAppointment</code> takes <code>email</code>, <code>scheduled_datetime</code> (a naive date and time, no offset needed), <code>invitee_timezone</code>, and <code>meeting_template_key</code>. AnyCRM resolves the right team member from the lane, handles the timezone and duration math, builds the polymorphic WhoId/WhatId pair correctly (Lead with no WhatId, or Contact with the Account in WhatId, or Contact with the open Opportunity in WhatId), sets OwnerId to the routed team member so the Event lands on their calendar (not the integration user's), sends the lead event straight into your CRM with the booking context, fires the server-side conversion event into your ad platforms, and returns both local and UTC start times in the response."
      },
      {
        "title": "Cancelling with a reason",
        "raw": "Deleting an Event in Salesforce moves the record to the Recycle Bin for 15 days, then permanently removes it. The activity timeline on the related Lead, Contact, or Opportunity loses the entry. The connected-calendar sync drops the entry too. There's no standard CancellationReason field on the Event object, no completed-but-cancelled status, no audit hook. The Event is just gone. Salesforce's own best practice is to preserve the audit trail with a completed Task on the related record carrying the reason, plus an in-place update on the Event itself, instead of a destructive DELETE. Doing that cleanly takes several round-trips.",
        "mcp": "<code>cancelSalesforceAppointment</code> takes <code>email</code> and <code>reason</code>. AnyCRM resolves the soonest upcoming Event, writes a completed Task with the reason as Description on the related Lead, Contact, or Opportunity, and updates the Event in place with the reason on a CancellationReason field (or a <code>[CANCELLED]</code> Subject prefix if the custom field isn't deployed). All in one AnyCRM call. No DELETE, full audit trail, the Event stays on the activity timeline and in the team member's Activity reporting."
      }
    ],
    "alignmentSummary": "Every AnyCRM tool for Salesforce follows the same AI-alignment contract, so the AI Receptionist never has to think about transport:",
    "alignment": [
      "<strong>Naive datetimes in, Salesforce-native shape out.</strong> The AI Receptionist passes <code>2026-05-15T11:00:00</code> and a timezone string. AnyCRM converts to UTC ActivityDateTime and splits DurationInMinutes from the meeting template.",
      "<strong>Email is the identity.</strong> Cancel and reschedule never need a Salesforce 18-character ID at the AI Receptionist layer. Email and soonest-upcoming resolves inside AnyCRM across Lead and Contact.",
      "<strong>LeadSource, Record Type, Stage, and meeting template come from setup, not the LLM.</strong> The AI Receptionist can't invent free-text values that violate your restricted picklists or validation rules. Every value is inherited from the setup-time freeze.",
      "<strong>Existing OwnerId is sacred.</strong> Lead, Contact, and Opportunity OwnerId is preserved on every write. New Leads only get the matched team member (or drop into the right Queue) when no Owner exists.",
      "<strong>Cancellation preserves the audit trail.</strong> Salesforce's idiom for completed-but-cancelled meetings is honoured so reporting stays accurate, the activity timeline keeps the entry, and the Recycle Bin doesn't swallow the audit trail.",
      "<strong>Assignment Rules fire on every Lead create.</strong> AnyCRM always sends <code>Sforce-Auto-Assign: TRUE</code> so your Territory, Round-Robin, and Einstein Lead Scoring rules kick in. Leads don't get orphaned in the integration user's personal queue.",
      "<strong>Every lead event leaves AnyCRM in two places at once.</strong> Your CRM gets the lead event so your business logic can run. Your ad platforms get the server-side conversion event so bidding optimises against real conversations. Both happen on the same AnyCRM call. No race conditions, no missing events.",
      "<strong>Flat, deterministic shapes.</strong> Every AnyCRM response has the same top-level keys across every tool, so the AI Receptionist's prompt never grows with edge-case branching.",
      "<strong>Errors are messages, not codes.</strong> A field-custom-validation error from Salesforce becomes a one-sentence reason the AI Receptionist can repeat to the caller without translation.",
      "<strong>Idempotent reschedules.</strong> If a reschedule fails mid-flight, the original Salesforce Event is preserved. The customer never ends up with nothing."
    ],
    "industryLine": "Currently running for <strong>B2B SaaS revenue teams, financial-services advisors, manufacturing sales orgs, and professional-services partners</strong>. Anyone whose pipeline is in Salesforce but whose phone keeps ringing after the AE has logged off.",
    "teamsSetup": {
      "headline": "Multi-team-member setup. Team roster, lanes & system-prompt assembly",
      "body": "If you run more than one team member on Salesforce, AnyCRM imports the team roster once, you link each team member to the lanes they actually cover (AE / SDR / CSM / SE / Partner), and AnyCRM bakes the result into the AI Receptionist's system prompt at setup time. Not at runtime. The AI Receptionist doesn't query your team roster on every call. It already knows who handles what.",
      "steps": [
        "<strong>Team roster import.</strong> AnyCRM imports your active Salesforce Users once and writes each one into its database keyed by <code>crm_user_id</code> (with name, role, lane, timezone, Profile, and Queue memberships).",
        "<strong>Per-team-member meeting templates.</strong> For each team member AnyCRM resolves the default Record Type per object, the meeting templates they actually book (discovery, demo, technical, executive), and the duration per template. One call per person, cached.",
        "<strong>Lane visibility.</strong> Each lane is flagged <em>Public</em>, <em>Private</em> or <em>Ignored</em>. The AI Receptionist only routes to and books on Public lanes. You toggle this in the AnyCRM dashboard without re-deploying.",
        "<strong>Lead-event receiving flow inside your CRM.</strong> During onboarding we wire up the flow inside your Salesforce org that receives lead events from AnyCRM. That's where your Lead-conversion and Opportunity-creation policy lives. AnyCRM doesn't try to own it.",
        "<strong>System-prompt assembly.</strong> The cached team roster, lane, picklist, and meeting-template JSON is prepended to the AI Receptionist's system prompt before the humaniser splits (personality, etiquettes, tone, speech style). So the AI Receptionist reads the team before it reads its own instructions.",
        "<strong>Runtime stays minimal.</strong> On a live call the AI Receptionist makes at most one availability call and one booking call. Never a team roster lookup or a picklist describe. Updates to team members, lanes, or templates re-run the cache. The AI Receptionist picks them up on its next deploy."
      ],
      "note": "The end result: the AI Receptionist can match \"I'd like to demo the platform with someone on the sales team\" → the AE pool → that team member's <em>Demo</em> meeting template → that team member's calendar availability → a booked Salesforce Event on the right team member's calendar with the Lead in WhoId and the Account in WhatId → a lead event delivered straight into your Salesforce org → a server-side conversion event in your ad platforms. Without a single team roster query during the call."
    }
  },
  "privacy": {
    "headline": "Your <span data-tpl-crm>Salesforce</span> data passes through AnyCRM. It doesn't stick.",
    "lede": "AnyCRM processes your <span data-tpl-crm>Salesforce</span> data to answer the call. Then forgets it. The only thing AnyCRM persists is a conversation history ID so the AI Receptionist can recognise a returning caller. Leads, Contacts, Accounts, Opportunities, Events, Tasks. All of it stays in Salesforce, owned by your Salesforce org.",
    "cards": [
      {
        "kind": "stored",
        "label": "What AnyCRM stores",
        "body": "<strong>Conversation history IDs only.</strong> So the AI Receptionist can pick up where it left off if a caller hangs up and rings back. No call audio, no transcripts of record data, no caller PII."
      },
      {
        "kind": "not-stored",
        "label": "What AnyCRM doesn't",
        "body": "Caller names, emails, phone numbers, Salesforce 18-character IDs, your team roster, your picklists, your Record Types, your Opportunity stages, your forecast data. None of it. AnyCRM reads what it needs, hands it to the LLM, fires the events, and discards the payload."
      },
      {
        "kind": "data-lives",
        "label": "Where data lives",
        "body": "<strong>In your Salesforce org and in whatever systems your CRM's flow forwards lead events to.</strong> Leads, Contacts, Accounts, Opportunities, Events, Tasks all live in Salesforce. Source-attributed (always <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>), attributable to AnyCRM's Connected App in Login History and Setup Audit Trail, revocable. AnyCRM does not build a shadow CRM alongside yours."
      },
      {
        "kind": "revoke",
        "label": "Revocation",
        "body": "Revoke the AnyCRM Connected App in Setup → Connected Apps OAuth Usage and the AI Receptionist loses access immediately. There is no \"export your data\" step because there is no data to export. It was never AnyCRM's to hold."
      }
    ],
    "scopesSummary": "Salesforce uses OAuth 2.0 scopes on a Connected App. AnyCRM requests only the smallest set required for the contact + meeting capture lifecycle. Nothing for analytics, nothing for marketing, nothing for billing, nothing for forecast or quote data.",
    "scopes": [
      "<strong><code>api</code> (REST + SOQL).</strong> Read and write on Lead, Contact, Account, Opportunity, Event, Task, User. The lead-capture and booking work.",
      "<strong><code>refresh_token</code>, <code>offline_access</code>.</strong> So the AI Receptionist can refresh its access token without re-prompting your admin every two hours.",
      "<strong>Read-only on User, Profile, UserRole, Group, GroupMember.</strong> The SOQL the setup workflow runs once to hydrate the team roster. No write access to User records.",
      "<strong>Read on Account and Opportunity.</strong> So an inbound call from a Contact in an open Opportunity is attached to the right WhatId, not orphaned on the Account.",
      "<strong>Not requested:</strong> Forecast, Quote, Order, Product2, PricebookEntry, AccountTeamMember, OpportunityLineItem, billing or subscription objects, custom finance objects, your other Connected Apps."
    ],
    "surfaceNote": "Same OAuth grant any Salesforce AppExchange app uses. Just a smaller surface. AnyCRM holds the access and refresh tokens (every write is signed by AnyCRM's Connected App credentials, so each Event and Lead change is attributable to AnyCRM in your org's Login History and Setup Audit Trail). The LLM never sees the token, and every tool call is logged with the operation name, never the raw payload."
  },
  "failureModes": [
    {
      "title": "Duplicate Leads when the caller is already a Contact",
      "raw": "Salesforce treats Lead and Contact as separate objects with no implicit cross-object dedup. Duplicate Rules and Matching Rules exist but are off by default and only fire if your admin has deployed them. <strong>My AI Front Desk's</strong> native Salesforce connector and Zapier paths upsert into either Lead OR Contact based on a single configured strategy (their own integration page documents Phone-then-Email matching against ONE chosen object). A caller who's already a Contact under an Account but the integration is set to \"Create Lead\" becomes a fresh duplicate Lead, the existing Account is never updated, and the AE on the open Opportunity has no idea the customer called. <strong>Goodcall</strong> writes through a connector positioned as \"sync your contacts\" with no published cross-object dedup rule. <strong>Smith.ai's AI tier</strong> pushes a Lead and a conversation-summary Task after the call through a similar one-shot create. None of these can do a real cross-object \"search-then-write\" because their architecture is one call in, one call out.",
      "mcp": "AnyCRM does NOT do a one-shot create. AnyCRM first searches Salesforce across BOTH Lead and Contact on a normalised lowercased + trimmed email, then on a normalised phone, then decides whether to update the existing record or create a new Lead. A returning Contact lands on the existing record with a new Task on the activity timeline (and on any open Opportunity), never as a duplicate Lead. This costs us extra API calls per contact-create. We do it anyway, because the alternative is the duplicate-Lead mess Smith.ai, My AI Front Desk, and Goodcall users live with. Four checks where they do one.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Leads stuck in the integration user's personal queue",
      "raw": "By default, a Lead create against Salesforce assigns the new Lead to the running user (the OAuth user the Connected App authenticated as). Assignment Rules, Lead Queues, Territory rules, and Einstein Lead Scoring do not fire unless the request carries the <code>Sforce-Auto-Assign: TRUE</code> header. <strong>My AI Front Desk's</strong> Zapier-style \"Create Lead\" action and Zapier surfaces generally don't set this header. <strong>Goodcall</strong> writes through a connector that applies whatever default behaviour the underlying integration shipped with. <strong>Smith.ai</strong> pushes Leads in without published documentation that the header is set. So captured Leads sit in the integration user's personal queue, invisible to your actual sales team, with no Lead Score, no Territory assignment, and no AE notification.",
      "mcp": "AnyCRM always sends <code>Sforce-Auto-Assign: TRUE</code> on Lead creates. Your Assignment Rules, Lead Queues, Territory rules, and Einstein Lead Scoring all fire automatically. The captured Lead lands in the right Queue, on the right team member, with the right score, the way a Web-to-Lead submission would. Two steps (set the header, write the Lead) where Smith.ai/My AI Front Desk/Goodcall do one.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Inventing LeadSource and Record Type values that don't exist in your org",
      "raw": "Production Salesforce orgs run dozens of validation rules and restricted picklist fields (LeadSource, Industry, Rating). <strong>My AI Front Desk's</strong> connector and Zapier action take whatever the AI generates and post it. There is no \"read your org's real picklist values first\" step in a Zapier path or a vanilla native connector: it's a single action. So the AI invents a LeadSource like \"AI Call\" when your picklist values are <em>Web</em>, <em>Phone Inquiry</em>, <em>Partner Referral</em>, the write fails on a field-integrity error, and the integration looks broken. (My AI Front Desk's own help docs even call out FIELD_CUSTOM_VALIDATION_EXCEPTION as a known integration failure.) <strong>Goodcall's</strong> connector hands the value through to Salesforce the same way. <strong>Smith.ai's</strong> AI tier picks values from a generic playbook that doesn't match your org's picklists.",
      "mcp": "AnyCRM reads your org's real LeadSource picklist values, Record Type IDs per object, required-field set, and the human-readable explanation of each validation rule at setup, and bakes them into the AI Receptionist's system prompt as a frozen table. So when the AI Receptionist captures a lead, it CAN ONLY pick from values that actually exist in your org. Unexpected validation-rule errors are parsed into human-readable sentences so even an edge case becomes a recoverable response. Two extra setup calls Smith.ai/My AI Front Desk/Goodcall don't make, and the difference between writes that always succeed and writes that silently rot your reporting.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Events on the wrong calendar (the integration user's)",
      "raw": "Creating an Event in Salesforce defaults OwnerId to the running user (which, on an integration, is the OAuth user the Connected App authenticated as), not the routed-to team member. <strong>My AI Front Desk's</strong> Zapier and native connector surfaces have no documented way to set OwnerId to the matched team member dynamically per call. <strong>Goodcall's</strong> connector defaults assign based on the underlying integration's behaviour rather than the lane the call belongs to. <strong>Smith.ai's</strong> human receptionists log Tasks rather than create Events with calendar-correct OwnerId. The Event lands on the integration user's calendar (or nowhere on a real team member's calendar at all), Lightning Sync / Einstein Activity Capture never surfaces it on the team member's connected Google or Outlook calendar, and the team member walks into Tuesday morning unaware they have a 10am demo.",
      "mcp": "AnyCRM does multiple things in one call: matches the lane (sales / qualification / customer-success) from the call's intent, looks up the right team member from the AnyCRM team roster, filters out deactivated Users, sets OwnerId to the matched team member's Salesforce User ID, validates the polymorphic WhoId/WhatId pair, AND checks whether the existing Lead/Contact/Opportunity already has an Owner. If the existing Owner contradicts the inferred lane, AnyCRM refuses to overwrite. The Event lands on the team member's Salesforce calendar AND syncs through to their connected Google or Outlook calendar atomically. Five checks where Smith.ai/My AI Front Desk/Goodcall do one.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai"]
    },
    {
      "title": "Wrong WhoId / WhatId polymorphic pairing",
      "raw": "Salesforce Event relationships are polymorphic but asymmetrical. WhoId is restricted to Lead or Contact only. WhatId is Account, Opportunity, Case, Campaign, or custom objects with Activities enabled. Pass a Contact ID in WhatId and the Event rejects. Pass an Account ID in WhoId and same. <strong>My AI Front Desk's</strong> Zapier-style \"Create Event\" action takes whichever ID the AI generates and posts it (no validation against polymorphic eligibility, no inference of the right slot from what's already in the org). <strong>Goodcall's</strong> connector doesn't expose the polymorphic slot logic in its published surface at all. <strong>Smith.ai</strong> doesn't create Events with structured polymorphic links from a phone call. A naive AI Receptionist that picks the wrong slot rejects the booking, leaves the caller with no meeting, and doesn't know which field the error was about.",
      "mcp": "AnyCRM resolves the polymorphic pair inside the wrapper based on what it found in the dedup step. Lead in WhoId with no WhatId. Contact in WhoId with the Account in WhatId. Contact in WhoId with the open Opportunity in WhatId when one exists. The AI Receptionist can't pick the wrong slot because it doesn't pick the slot at all. AnyCRM does that. Three branches where Smith.ai/My AI Front Desk/Goodcall do zero.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall"]
    },
    {
      "title": "Cancelling by DELETE instead of by completed Task + Event update",
      "raw": "A raw DELETE on a Salesforce Event moves it to the Recycle Bin for 15 days, then permanently removes it. The activity timeline on the related Lead/Contact/Opportunity loses the entry. The connected-calendar sync drops the entry too. There's no standard CancellationReason field on the Event object. Activity History reporting forgets the meeting ever happened. <strong>My AI Front Desk's</strong> Zapier-style cancel action (where it exists at all) issues a single DELETE, that's the only Salesforce operation Zapier exposes for it. <strong>Goodcall's</strong> cancellation, if any, goes through its own scheduler rather than the Salesforce Event itself, so the Salesforce timeline never reflects the cancellation reason. <strong>Smith.ai</strong> receptionists log a note rather than properly updating the Event, so Activity reporting doesn't count it correctly.",
      "mcp": "AnyCRM's cancellation is multi-step. Find the soonest upcoming Event, capture the caller's reason, write a completed Task with the reason as Description on the related Lead/Contact/Opportunity, AND update the Event in place with a CancellationReason field (or a <code>[CANCELLED]</code> Subject prefix if the custom field isn't deployed). The Event stays on the timeline, queryable in Activity reporting, with the reason attached. Three operations where Smith.ai/My AI Front Desk/Goodcall do one (and usually the wrong one).",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai"]
    },
    {
      "title": "Encoding your deal-creation policy in the prompt or in middleware",
      "raw": "<strong>My AI Front Desk's</strong> Zapier action set includes a hardcoded \"Change Opportunity Stage\" and \"Create Event\" pair that fires on every inbound call. There is no \"only progress the Opportunity if the caller is actually ready to buy\" logic. The action is single-step, so every call risks pushing an Opportunity Stage forward incorrectly, or clogging the AE's forecast with unqualified Opportunities. Worse, the moment you change your Opportunity Stages or your Lead-conversion flow, you have to go back into Zapier and rebuild the zap. <strong>Goodcall's</strong> connector applies whatever default behaviour the underlying integration shipped with: change your business, and the connector keeps doing what it did six months ago. <strong>Smith.ai's</strong> AI tier and human receptionists work from playbooks that drift out of date as your real Salesforce policy evolves. Even <strong>Salesforce's own Agentforce</strong> (powerful as it is) requires you to encode your Lead-conversion and Opportunity-creation logic inside the agent itself, in Agent Builder, with prompts and Actions and Apex.",
      "mcp": "AnyCRM does not encode your Opportunity policy at all. AnyCRM sends a clean lead event straight into your Salesforce org, into the receiving flow we wire up for you at onboarding. YOUR flow decides what happens. New conversion path? Update the flow. New Stage? Update the flow. New LeadSource scheme? Update the flow. AnyCRM's behaviour stays consistent because AnyCRM's job stops at the conversation. Smith.ai/My AI Front Desk/Goodcall can't separate these concerns because their architecture forces business policy into Zapier middleware or a hardcoded action.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Web leads and AI Receptionist leads run on two separate conversion-tracking stacks",
      "raw": "<strong>Smith.ai, My AI Front Desk, and Goodcall</strong> all treat phone and chat conversions as separate from Web-to-Lead and chatflow conversions. None of them fire a real conversion event into Google Ads, Facebook Ads, or LinkedIn Ads when the AI Receptionist closes a call. So your Ad platforms only see the Web-to-Lead form-fills, the bidding optimises for that (lower-intent) audience, your Cost per Lead looks deceptively low, ROAS reporting becomes a fiction, and the high-intent traffic that picks up the phone stays invisible to your Ad stack. Worse, when these competitors DO fire any tracking, it's client-side: blocked by ad-blockers and degraded under iOS / Safari tracking restrictions.",
      "mcp": "AnyCRM runs your Web-to-Lead conversions AND your AI Receptionist conversions through the same Conversion Lift pipeline. Same event shape, same source taxonomy, same delivery to your Salesforce org, AND the same server-side conversion event into Google Ads, Facebook Ads, and LinkedIn Ads, using the verified origin of your registered domain. Server-side means it can't be blocked client-side and doesn't degrade on iOS or Safari. The result is what Smith.ai/My AI Front Desk/Goodcall structurally can't deliver: lower Cost per Lead, higher ROAS, smaller CAC, complete analytics funnels, and attribution that doesn't fragment between web and voice.",
      "competitorsAffected": ["Smith.ai", "My AI Front Desk", "Goodcall"]
    }
  ],
  "failureModesMeta": {
    "headline": "How most AI Receptionists built on <strong>Smith.ai, My AI Front Desk, or Goodcall</strong> fail for <strong>B2B SaaS revenue teams, financial-services advisors, manufacturing sales orgs, and professional-services partners</strong> that use <span data-tpl-crm>Salesforce</span>. And why AnyCRM can't.",
    "lede": "Most AI Receptionists fail on Salesforce in the same handful of ways. Duplicate Leads when the caller is already a Contact, Leads orphaned in the integration user's personal queue, invented LeadSource and Record Type values that fail validation, Events on the wrong calendar, wrong polymorphic WhoId/WhatId pairing, destructive DELETEs that erase the activity timeline, hardcoded Opportunity-Stage rules that drift away from your real policy, and conversion data that never reaches your ad platforms server-side. AnyCRM can't fail in any of these ways, because each failure was solved one layer down inside AnyCRM. And because AnyCRM delegates Lead-conversion and Opportunity-creation policy to your CRM's own flow rather than trying to encode it, AND runs web and AI Receptionist conversions through a single unified conversion pipe instead of two disconnected stacks.",
    "closer": "The AI Receptionist is honest because AnyCRM doesn't let it lie. And AnyCRM is sophisticated because it doesn't pretend to own policy that belongs inside your Salesforce org, while quietly fixing the conversion-tracking gap nobody else has thought to close."
  },
  "comparisonTable": {
    "headline": "AnyCRM vs Smith.ai, My AI Front Desk, Goodcall on <span data-tpl-crm>Salesforce</span>",
    "columns": [
      { "key": "anycrm", "label": "AnyCRM" },
      { "key": "smithai", "label": "Smith.ai" },
      { "key": "myaifrontdesk", "label": "My AI Front Desk" },
      { "key": "goodcall", "label": "Goodcall" }
    ],
    "rows": [
      {
        "capability": "Live Salesforce Event booked DURING the call",
        "anycrm": "<strong>Yes.</strong> Native Salesforce Event, team-member-matched OwnerId, calendar-synced via Lightning Sync / Einstein Activity Capture.",
        "smithai": "No. Task logged for manual follow-up.",
        "myaifrontdesk": "Partial. \"Create Event\" connector action without OwnerId-as-routed-team-member or polymorphic-pair validation.",
        "goodcall": "Partial. Scheduler hop, not a structured native Salesforce Event."
      },
      {
        "capability": "Cross-object dedup-before-write across Lead AND Contact on email and phone",
        "anycrm": "<strong>Yes. Always.</strong>",
        "smithai": "Manual.",
        "myaifrontdesk": "No. Dedups against one chosen object, not cross-object.",
        "goodcall": "No published guarantee."
      },
      {
        "capability": "Preserves existing OwnerId on Leads, Contacts, and Opportunities for returning callers",
        "anycrm": "<strong>Yes.</strong> Existing OwnerId is sacred.",
        "smithai": "Implicit, not guaranteed.",
        "myaifrontdesk": "No. Can overwrite.",
        "goodcall": "Depends on the underlying connector's defaults."
      },
      {
        "capability": "Routes by lane (AE / SDR / CSM / SE)",
        "anycrm": "<strong>Yes.</strong> Lane is part of AnyCRM's team roster.",
        "smithai": "Manual, depends on the receptionist.",
        "myaifrontdesk": "No.",
        "goodcall": "No."
      },
      {
        "capability": "LeadSource, Record Type & meeting templates frozen from your real org values",
        "anycrm": "<strong>Yes.</strong> Read at setup, baked into the prompt as a frozen table.",
        "smithai": "Not API-enforced.",
        "myaifrontdesk": "No. Writes can fail on unknown values (FIELD_CUSTOM_VALIDATION_EXCEPTION).",
        "goodcall": "No structural guard."
      },
      {
        "capability": "Assignment Rules fire on every Lead create (<code>Sforce-Auto-Assign: TRUE</code>)",
        "anycrm": "<strong>Yes.</strong> Always set.",
        "smithai": "Not documented.",
        "myaifrontdesk": "No. Zapier surfaces don't set it.",
        "goodcall": "Not documented."
      },
      {
        "capability": "Cancellation preserves the audit trail (completed Task + Event update, not DELETE)",
        "anycrm": "<strong>Yes.</strong> Salesforce-native cancellation.",
        "smithai": "Manual.",
        "myaifrontdesk": "No. DELETE strips the timeline.",
        "goodcall": "No. Cancellation happens in the scheduler, not the Event."
      },
      {
        "capability": "Reschedule in place (no cancel-then-rebook)",
        "anycrm": "<strong>Yes.</strong>",
        "smithai": "Manual.",
        "myaifrontdesk": "No.",
        "goodcall": "No."
      },
      {
        "capability": "Lead-conversion / Opportunity-creation policy delegated to YOUR Salesforce flow",
        "anycrm": "<strong>Yes.</strong> Lead event delivered straight into your CRM, into the receiving flow we wire up at onboarding.",
        "smithai": "No. Policy lives in Zapier or in the receptionist's training.",
        "myaifrontdesk": "No. Hardcoded \"Create Lead\" / \"Change Opportunity Stage\" actions.",
        "goodcall": "No. Connector-default behaviour."
      },
      {
        "capability": "Unified conversion pipe: web forms AND AI Receptionist → CRM + ad platforms server-side",
        "anycrm": "<strong>Yes.</strong> Same shape, same source taxonomy, same server-side delivery to your CRM and your ad platforms.",
        "smithai": "No. Web and voice run on separate stacks.",
        "myaifrontdesk": "No. Web and voice run on separate stacks.",
        "goodcall": "No. Web and voice run on separate stacks."
      },
      {
        "capability": "Server-side conversion events to Google Ads, Facebook Ads, and analytics (origin = your registered domain)",
        "anycrm": "<strong>Yes.</strong> Every call and chat lead lands server-side.",
        "smithai": "No.",
        "myaifrontdesk": "No.",
        "goodcall": "No."
      },
      {
        "capability": "Source attribution stays consistent across web and voice",
        "anycrm": "<strong>Yes.</strong> <code>AI Receptionist Call</code>, <code>AI Receptionist Web</code>, plus your Web-to-Lead form identifiers.",
        "smithai": "Manual / inconsistent.",
        "myaifrontdesk": "No standardised taxonomy.",
        "goodcall": "Whatever the underlying connector defaults to."
      },
      {
        "capability": "Scale ceiling",
        "anycrm": "Bounded by Salesforce API limits, not by staffing.",
        "smithai": "Bounded by human receptionist staffing.",
        "myaifrontdesk": "Bounded by Zapier rate limits and action contracts.",
        "goodcall": "Bounded by the scheduler-and-sync hop."
      }
    ],
    "footer": "Every row in this table is solved one layer down inside AnyCRM. Not in the prompt. Not by humans. Not by Zapier."
  },
  "faqs": [
    {
      "q": "Does this actually work with my Salesforce org?",
      "a": "Yes. AnyCRM uses Salesforce's official REST and SOQL APIs via a Connected App OAuth grant. Every captured caller lands as the right record type (Lead for net-new, Task on Contact for existing customers) with the right OwnerId, the right LeadSource, the right Record Type, and a first call note. Meetings land as native Salesforce Events on the right team member's calendar, with the WhoId/WhatId pair set so the Event surfaces on the related Account or Opportunity."
    },
    {
      "q": "Will it create duplicate Leads in Salesforce?",
      "a": "No. AnyCRM resolves the existing record first by running cross-object dedup across BOTH Lead and Contact (normalising email and phone) before writing. A returning caller who already exists as a Contact becomes a new Task on the existing Contact (and on any open Opportunity), never a duplicate Lead. The existing OwnerId is preserved."
    },
    {
      "q": "Can it route different leads to different team members?",
      "a": "Yes. AnyCRM reads your active Salesforce User roster once at setup. Every active team member, with their Profile, Role, Queue memberships, and timezone. Sales-side, qualification-side, and customer-side calls each route differently, and existing OwnerId on the Lead, Contact, or Opportunity is always preserved. New Leads send the <code>Sforce-Auto-Assign: TRUE</code> header so your Assignment Rules and Territory rules fire normally."
    },
    {
      "q": "Where do the meetings actually live, calendar or Salesforce?",
      "a": "Both. AnyCRM writes the meeting as a native Salesforce Event with OwnerId set to the matched team member, the right polymorphic WhoId/WhatId pair, and the right timing. If Lightning Sync or Einstein Activity Capture is configured for that team member, the Event syncs to their connected Google or Outlook calendar. You see one Event on the activity timeline of the related Lead/Contact/Account/Opportunity, one calendar invite on the team member's calendar, one source-attributed record."
    },
    {
      "q": "Can it cancel or reschedule a meeting from a phone call?",
      "a": "Yes. The caller gives their email, AnyCRM finds the soonest upcoming Event linked to the matching Lead or Contact, the AI Receptionist reads it back, and AnyCRM either reschedules in place or cancels by writing a completed Task with the reason on the related record and updating the Event in place. Never a DELETE that would Recycle-Bin the Event and erase the activity-timeline entry."
    },
    {
      "q": "What if a caller has two upcoming Events in Salesforce?",
      "a": "AnyCRM returns every upcoming Event for that Lead or Contact (Subject, date, time, owning team member) and the AI Receptionist asks which one to change before doing anything. It never assumes."
    },
    {
      "q": "Does it handle our validation rules and restricted picklists?",
      "a": "Yes. At setup AnyCRM reads your LeadSource picklist values, your Record Type IDs per object, your required-field set, and the human-readable explanation of each validation rule, and bakes them into the AI Receptionist's system prompt as a frozen table. The agent can't invent free-text picklist values or skip required fields. Unexpected validation-rule errors are parsed into human-readable sentences so even an edge case becomes a recoverable response on the call."
    },
    {
      "q": "Does it handle timezones correctly?",
      "a": "Yes. The AI Receptionist confirms the caller's country/timezone, AnyCRM converts the meeting time into UTC for ActivityDateTime (which is how Salesforce expects it), and the AI Receptionist reads the time back to the caller in <em>their</em> local timezone. No customer-facing UTC strings, no off-by-an-hour confirmations."
    },
    {
      "q": "How is this different from Salesforce's own Agentforce?",
      "a": "Agentforce is Salesforce's AI agent platform: powerful, deeply integrated, and priced as part of the Salesforce licensing footprint (Agentforce Sales tiers start at $175/user/month). It's designed as a build-your-own-agent platform with Agent Builder, Atlas Reasoning, and Agentforce Voice. AnyCRM is the inbound-phone-receptionist layer that sits in front. We answer the business line, capture the lead cleanly into your Salesforce org through the same Connected App contract Agentforce respects, and hand off to your downstream Salesforce flows (which may include Agentforce agents for service or SDR follow-up). You don't have to choose. AnyCRM in front, Agentforce behind, your Salesforce flow in the middle."
    },
    {
      "q": "Does it create Opportunities?",
      "a": "Not directly. AnyCRM stays focused on the conversation surface: capturing the Lead or Contact, matching the right team member, booking the Event. Lead conversion, Opportunity creation, Stage routing — that's YOUR business policy, and that policy lives inside your Salesforce org, in the receiving flow we wire up for you at onboarding. Every Lead-create and every Event-book in AnyCRM sends a lead event straight into that flow (tagged with source <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>). Your flow decides which Stage, which pipeline, which LeadSource, which Flow trigger. AnyCRM doesn't try to encode policy that will drift out of date the moment your business changes."
    },
    {
      "q": "How does the conversion tracking work?",
      "a": "Every lead event AnyCRM produces (from a phone call, a chat conversation, OR a Web-to-Lead form / chatflow) flows through a single conversion pipe. It lands in your Salesforce org for business logic. AND it fires server-side into Google Ads, Facebook Ads, and your analytics platform, using the origin of the domain you registered with AnyCRM. Server-side means the conversion can't be blocked by ad-blockers and doesn't degrade under iOS / Safari tracking restrictions. The result: higher ROAS, lower ad costs, enriched analytics, and attribution that doesn't fragment between web and voice. As far as we can tell, none of our competitors have built this yet."
    },
    {
      "q": "What about my existing website forms? Do they go through the same pipe?",
      "a": "Yes — that's the whole point. Web-to-Lead forms / chatflows AND the AI Receptionist produce the same lead-event shape with the same source taxonomy. They land in the same place in your Salesforce org, and they fire the same server-side conversion event into your ad platforms. So your bid strategy optimises against unified, real conversions instead of fragmenting across web-only and voice-only stacks."
    },
    {
      "q": "How long until it's actually capturing leads into Salesforce?",
      "a": "Most teams are live the same afternoon. The Connected App OAuth grant takes a minute. The team roster, picklist, Record Type, and Queue import is automatic. We wire up the lead-receiving flow inside your Salesforce org during onboarding. The phone integration is usually under an hour. Web chat is faster."
    }
  ]
}
