{
  "icp": "home-services operators running dispatch on Housecall Pro — HVAC, plumbing, electrical, cleaning, pest control, garage doors, appliance repair, and other trades that live or die by the booked job",
  "capabilities": {
    "availability": {
      "headline": "Captures the after-hours caller as a Housecall Pro customer, books the job in the same call, and feeds one unified conversion pipe for your website AND your AI Receptionist.",
      "lede": "Every after-hours call about a leaking water heater or a no-cool AC lands as a Housecall Pro customer with the right service address, the right job type, and a scheduled job on the right technician. AnyCRM writes the record into Housecall Pro DURING the call. 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 and online booking) so your dispatch board and your Google / Facebook / LinkedIn Ads both stay in sync.",
      "cards": [
        {
          "num": "A.01",
          "title": "Every caller becomes a Housecall Pro customer. Not a missed dispatch.",
          "body": "The AI Receptionist captures the homeowner's name, mobile number, email, full service address (with the second address line, city, state, ZIP, and access notes), and the nature of the issue. Then AnyCRM writes it into Housecall Pro as a customer with the service address attached DURING the call. Tagged with the inbound-call tag so the dispatch board can filter it later."
        },
        {
          "num": "A.02",
          "title": "Books native Housecall Pro jobs against a technician's real schedule",
          "body": "The job is created with the right job type, the right customer, the right service address, and a scheduled arrival window that honours drive time and the technician's working hours. Line items come pre-populated from the job-type template. So the technician arrives with the dispatch already on their mobile app, not as a phone-tag breadcrumb at 7am the next morning."
        },
        {
          "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 dispatch rules. Every customer-create and every job-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. Open the estimate. Convert the recurring-plan visit. Trigger the post-job survey. We wire up the receiving flow inside your CRM during onboarding, tuned to your trade and your dispatch configuration. AnyCRM doesn't get in the way of policy you've already encoded."
        }
      ],
      "apiSummary": "The AI Receptionist asks AnyCRM for availability against the technicians on your team and gets back open arrival windows in the customer's timezone. Drive time and busy time on other jobs are always respected. Every AnyCRM call prevents duplicate customers, normalises the service address, resolves the job type, assigns the right technician, writes the job so it lands on the technician's mobile app immediately, 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 AnyCRM's Conversion Lift pipeline (covered in the next capability) so your Google, Facebook, and LinkedIn Ads start optimising against the high-intent calls that actually pick up the phone.",
      "tools": [
        "getHousecallproAvailability",
        "createHousecallproContactAppointment"
      ],
      "curl1Path": "/mcp/tools/getHousecallproAvailability",
      "curl2Path": "/mcp/tools/createHousecallproContactAppointment",
      "pipeIntro": "Most home-services shops run two completely separate conversion-tracking stacks: one for the website (online-booking widget, contact forms, chat) and a totally absent one for the phone and the AI Receptionist. So Google Ads and Facebook Ads only learn from web form-fills, bidding optimises for the wrong audience, attribution is broken, and the high-intent emergency caller at 9pm stays invisible to your Ad stack. 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 (online-booking widget, contact form, chat) OR through the AI Receptionist on phone / chat. Either way, AnyCRM produces the same clean lead-event shape, tagged at source with <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 CRM, into the receiving flow we wire up for you at onboarding. Your dispatch logic decides what happens next: which job type, which technician, which arrival window, which line items, which follow-up SMS. 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 booked jobs (not just web form noise), your Facebook Ads campaigns finally see the after-hours emergency callers who picked up the phone, and your analytics platform sees one unified funnel instead of two half-blind ones."
        }
      ],
      "outcomes": [
        "<strong>Higher ROAS.</strong> Ad bidding optimises against actual booked jobs and estimates, not against the noisy subset of homeowners who happen to fill a form.",
        "<strong>Lower ad costs.</strong> Once Google Ads and Facebook Ads learn what a real $400 service-call lead looks like, they stop spending against lookalikes of low-intent form-fillers.",
        "<strong>Enriched analytics.</strong> Every conversation surface (online booking, web form, chat, phone call, AI Receptionist chat) feeds the same event shape, so funnels are complete instead of half-blind.",
        "<strong>Correct attribution.</strong> A homeowner who first saw a Facebook Ad, then visited the site, then phoned three days later when the AC died gets attributed end-to-end. Voice traffic stops being invisible to your marketing stack.",
        "<strong>One source of truth for dispatch policy.</strong> Your CRM's flow owns job-type assignment, technician routing, and estimate-vs-job decisions. 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 a job is created, which technician it goes to, and which tag 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 CRM (for dispatch 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 CRM AND the server-side conversion tracking at onboarding, matched to your specific trade, 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. Even Housecall Pro's own CSR AI sells itself as a 24/7 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 for a shop spending real money on Google and Facebook Ads."
    },
    "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 for your trade, here is the uncomfortable truth: those platforms only get smarter when they see real conversions. Today, a website form-fill counts. A real phone call from a homeowner with a dead AC at 8pm 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 on paper. 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 website form-fills or online-booking submissions. That's why your Cost per Lead looks low but your dispatcher complains the leads are weak. The high-intent emergency 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 homeowners closer to ready-to-buy; and <strong>Customer Acquisition Cost shrinks</strong> because more of your Ad budget reaches buyers who will actually book a job."
        },
        {
          "num": "1b.03",
          "title": "The same pipe carries your website forms too. One source of truth across Ads, CRM, and Analytics.",
          "body": "AnyCRM doesn't just track AI Receptionist conversions. It also runs your existing website forms, chat, and online-booking submissions through the same pipeline. So a lead from a Google Ad that filled out your booking widget AND a lead from a Facebook Ad that called the AI Receptionist three days later both end up tagged, attributed, and counted exactly the same way. Your Ads platform stops double-counting, your analytics stop fragmenting, and your dispatch board stops being half-blind to where your leads actually came from."
        }
      ],
      "apiSummary": "Every customer-create and job-book fires through AnyCRM's Conversion Lift pipeline. The lead event lands inside your CRM for dispatch 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 website forms and online-booking submissions 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 with a real emergency.",
        "<strong>Return on Ad Spend (ROAS) goes up.</strong> Because the Ads now optimise toward conversations that actually close into a booked job, not toward whichever cheap audience generates the most form submissions.",
        "<strong>Customer Acquisition Cost (CAC) shrinks.</strong> Because a higher share of every Ad dollar reaches homeowners ready to dispatch a truck.",
        "<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 homeowner who first clicked a Google Ad, then called the business three days later when the heater died, finally shows up correctly attributed. Today, that buyer is invisible to your Ads stack.",
        "<strong>You finally know if Ads are working.</strong> Most shops 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 for emergency HVAC service. Today, you see 80 web form-fills and assume that's the full picture. With AnyCRM running, you'll also see (say) 90 phone calls and 35 web chats the AI Receptionist handled, all flowing into Google Ads as real conversions. Suddenly Google sees 205 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 homeowner: the one with a dead AC at 7pm, not the one casually shopping a quote. Same $5,000 spend, more real booked jobs, lower Cost per Lead, higher revenue per truck-roll. That is what \"AI Receptionist with AnyCRM\" actually means for the bottom line. Not just \"it answers the phone.\"",
      "tools": [
        "createOrUpdatesHousecallproContact",
        "createHousecallproContactAppointment"
      ]
    },
    "lifecycle": {
      "headline": "Owns the full job lifecycle inside Housecall Pro.",
      "lede": "Every \"can you push the Tuesday morning slot to Wednesday?\" or \"actually, cancel that, my brother-in-law's a plumber\" lands with the AI Receptionist instead of on the dispatcher's missed-call list. Reschedules update the job's arrival window in place. Cancellations follow Housecall Pro's own idiom. The job is flagged cancelled the way Housecall Pro's reporting expects, with the reason captured as a note on the job and the customer. Instead of a DELETE that erases the audit trail.",
      "cards": [
        {
          "num": "B.01",
          "title": "Finds the job by email or phone. No job IDs on the call.",
          "body": "Customers DO NOT quote job IDs over the phone. The AI Receptionist asks AnyCRM for the soonest upcoming job linked to a customer matched on the caller's email or mobile number, then reads back the address, arrival window, and assigned technician before changing anything."
        },
        {
          "num": "B.02",
          "title": "Reschedules in place. Same job record.",
          "body": "Rescheduling updates the existing job's arrival window in a single confirmation. No cancel-then-rebook round-trip means the job number, the customer link, the line items, and the technician assignment all stay intact. Failed reschedules leave the original job untouched."
        },
        {
          "num": "B.03",
          "title": "Cancels with the reason on the timeline, not by deletion",
          "body": "The AI Receptionist flags the job cancelled the Housecall Pro-native way and writes the caller's reason as a note on both the job and the customer. Instead of issuing a DELETE that strips the job from reporting and erases WHY the slot opened up. The dispatcher walks in and can immediately see WHY they got a slot back."
        }
      ],
      "apiSummary": "AnyCRM's search, reschedule, and cancel all accept just an email (or a phone number). The soonest upcoming Housecall Pro job linked to the matching customer is resolved inside AnyCRM. No job IDs at the AI Receptionist layer.",
      "tools": [
        "searchHousecallproAppointments",
        "rescheduleHousecallproAppointment",
        "cancelHousecallproAppointment"
      ],
      "curl1Path": "/mcp/tools/searchHousecallproAppointments",
      "curl2Path": "/mcp/tools/rescheduleHousecallproAppointment",
      "curl3Path": "/mcp/tools/cancelHousecallproAppointment"
    },
    "routing": {
      "headline": "Routes every caller to the right job type and the right technician. And respects existing dispatch instead of randomly reassigning.",
      "lede": "Housecall Pro accounts run on employees, job types, and a daily dispatch board. At setup AnyCRM imports your Housecall Pro employee roster into its database and enriches each technician with trade lane (HVAC / plumbing / electrical / install / service / warranty), expertise, certifications, service zones, languages, timezone, and per-job-type duration. The AI Receptionist then routes each caller to the job type that fits the symptom AND the technician who actually covers that trade in that zone. Existing customer-to-technician affinity (when a returning customer says \"send Mike again\") is honoured as the source of truth.",
      "cards": [
        {
          "num": "C.01",
          "title": "Routes by trade lane: service call vs install vs warranty",
          "body": "\"My AC isn't blowing cold\" routes to your HVAC service technicians with a Service Call job type. \"I want a quote on a new system\" routes to your sales/comfort advisor with an estimate. \"You installed this six months ago and it's leaking\" routes to whoever ran the original job, and the warranty job type is selected automatically."
        },
        {
          "num": "C.02",
          "title": "Honours existing customer-technician affinity",
          "body": "If a returning customer has had three jobs run by the same technician, the AI Receptionist offers that technician's next opening first. Not a stranger from the round-robin. The customer's existing Housecall Pro record is updated in place, never duplicated."
        },
        {
          "num": "C.03",
          "title": "Matches fresh inbound callers to the right person on the team",
          "body": "Net-new callers with no existing Housecall Pro customer record get matched to a technician on the lane and zone you've designated, with on-shift status and existing job density honoured. The AI Receptionist doesn't fight whatever dispatch rule you already encode on the board."
        }
      ],
      "apiSummary": "Team details live in AnyCRM's database, pulled once from Housecall Pro at setup, enriched with trade lane, expertise, certifications, service-zone polygons, languages, timezone, and per-job-type duration (valuable context for the AI Receptionist that Housecall Pro's employee object doesn't carry by default). At runtime, one read of the team roster matches caller → trade lane → service zone → technician. New customers get the routed-to technician on the job. Existing customers keep their affinity technician where one exists. AnyCRM does NOT cache your dispatch automations, your tags, or your follow-up workflows. That policy stays inside your CRM, where it belongs.",
      "tools": [
        "listHousecallproTeamMembers",
        "getHousecallproSpecialistServices"
      ],
      "curl1Path": "/mcp/tools/listHousecallproTeamMembers",
      "curl2Path": "/mcp/tools/getHousecallproSpecialistServices"
    }
  },
  "setup": {
    "headline": "Setup in 3 steps. Battle-tested on real <span data-tpl-crm>Housecall Pro</span> accounts.",
    "lede": "You connect <span data-tpl-crm>Housecall Pro</span> once. AnyCRM imports your technicians, your job types, your line-item catalog, your tags, and your service zones. AnyCRM also wires up the receiving end inside your CRM so lead events from the AI Receptionist land where your dispatch logic can act on them. Then the AI Receptionist starts capturing calls and booking jobs the same afternoon. No middleware. No prompt-engineering by you.",
    "steps": [
      {
        "num": "S.01",
        "title": "Connect Housecall Pro (API key, 60 seconds)",
        "body": "Generate a Housecall Pro API key from My Apps → API in your Housecall Pro account (admin-only) and paste it in. AnyCRM scopes to the least amount of access needed for the booking lifecycle. Nothing for invoicing, payments, or marketing. You can always revoke the key at any time from the same My Apps screen. Every update AnyCRM makes to your Housecall Pro is tagged with the inbound-call tag so it's easy to track what the AI Receptionist did when you audit."
      },
      {
        "num": "S.02",
        "title": "Import technicians, job types, line items, tags & service zones. Wire up your CRM's lead-receiving flow.",
        "body": "AnyCRM imports every active Housecall Pro employee as a bookable technician (with role, mobile, color tag, and timezone), reads your job types (so the AI Receptionist can only book types you actually run), freezes your line-item catalog (so estimates are populated from your real prices, not LLM guesses), and locks the default tag for inbound-call jobs so every record is attributable to the AI Receptionist in the dispatch board's filters. Service zones are confirmed in the AnyCRM dashboard. During onboarding we set up the receiving flow inside your CRM so the lead events from the AI Receptionist land where your dispatch logic can act on them. AnyCRM does NOT replicate your dispatch rules, your tags, or your follow-up workflows. Your CRM 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 Housecall Pro account, 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 Housecall Pro's <strong>Online Booking</strong>, <strong>CSR AI</strong>, and voicemail?",
      "body": "Housecall Pro's Online Booking widget is excellent at the steps AFTER a homeowner has decided to come to you on your website. It doesn't pick up the phone. CSR AI (Housecall Pro's own AI customer-service rep) does answer calls and book jobs 24/7, and it's tightly integrated inside the Housecall Pro UI. But it sells itself as a phone-answering product. It doesn't run your website forms, your chat, AND your phone through one unified lead-event pipe. And it doesn't fire server-side conversion events into Google Ads, Facebook Ads, or LinkedIn Ads using the origin of your registered domain. So your bidding still optimises against the form-fill subset of your traffic. AnyCRM is the layer that captures the call, books the Housecall Pro job natively, writes a clean customer with the call summary as the first note (sourced <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>), AND sends the same lead event straight into your CRM's downstream dispatch logic plus your ad platforms server-side. So your Housecall Pro dispatch board, your analytics, and your Google / Facebook Ads bidding all start optimising on a real conversation, not just a name and a missed call."
    },
    "enrichmentSummary": "Every tool the AI Receptionist calls is an opinionated wrapper inside AnyCRM. AnyCRM does the messy work for you. Dedup, address normalisation, job-type resolution, arrival-window math, technician assignment, line-item lookup, pagination, error handling, lead-event delivery into your CRM, 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 CRM internals.",
    "enrichmentExamples": [
      {
        "title": "Capturing a new inquiry",
        "raw": "Writing a customer straight into Housecall Pro looks simple. But Housecall Pro doesn't dedup for you, and a customer with no service address is functionally useless for dispatch. The service address is a nested structure on the customer object with required fields and a type-tag that has to be set correctly. Get it wrong and the customer is created without a service address, leaving the dispatcher unable to book a job against them later. Mobile and home numbers are separate fields. Sending the caller's phone to the wrong one means the technician's mobile app texts a number nobody answers. And nothing in raw Housecall Pro fires a server-side conversion event to your ad platforms, so call-driven and chat-driven leads never get optimised for.",
        "mcp": "<code>createOrUpdatesHousecallproContact</code> accepts <code>name</code>, <code>email</code>, <code>mobile</code>, <code>service_address</code> (a single string AnyCRM parses), <code>note</code>, and the inferred trade lane. AnyCRM searches by email then mobile, picks the surviving record (or creates a new one with a properly-shaped service-address entry and the phone on the mobile field), creates or links the service address, assigns the routed-to technician, appends the note, tags the customer with the inbound-call tag so the record is attributable to AnyCRM in the dispatch board's filters, 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. Three raw operations collapsed to one, with rollback on partial failure."
      },
      {
        "title": "Booking the job",
        "raw": "Creating a job directly against Housecall Pro is a tight contract. The job type isn't free text. It must match an existing job type defined in your account exactly. The assigned-technician field is a flat array of UUIDs. Pass a single string and the request fails. Leave it empty and the job lands on the dispatch board unassigned, with no technician notified. The schedule is a nested object with three separate datetime fields, all in ISO-8601 with timezone offsets. Naive datetimes are silently interpreted as UTC and the technician shows up four hours late. Line items must be an array of structured objects with prices in CENTS. Send ten dollars as the integer 10 and Housecall Pro stores it as ten cents and the customer is invoiced for a dime.",
        "mcp": "<code>createHousecallproContactAppointment</code> takes <code>email</code>, <code>scheduled_datetime</code> (a naive date and time, no offset needed), <code>invitee_timezone</code>, <code>job_type</code>, and an optional arrival-window length. AnyCRM resolves the right technician from the trade lane, looks up the job-type identifier by name against your imported job-type table, handles the timezone and duration math, populates line items from the job-type template with prices in cents, sends the same 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 a job in Housecall Pro strips it off the customer's history, removes it from reporting, and clears the dispatch board entry. No reason, no cancellation outcome, no audit trail. The technician's mobile app simply loses the entry. The dispatcher gets no signal of WHY the slot opened up. Housecall Pro's own best practice is to flag the job cancelled the customer-cancelled way instead of deleting it, so it stays queryable in reporting and on the customer history. Doing that cleanly takes several round-trips against the raw API.",
        "mcp": "<code>cancelHousecallproAppointment</code> takes <code>email</code> and <code>reason</code>. AnyCRM resolves the soonest upcoming job, writes the reason as a note on both the job and the customer, and flags the job cancelled the Housecall Pro-native way. All in one AnyCRM call. No deletion, full audit trail, job stays queryable in reporting, and the dispatcher can see exactly why the slot opened up."
      }
    ],
    "alignmentSummary": "Every AnyCRM tool for Housecall Pro follows the same AI-alignment contract, so the AI Receptionist never has to think about transport:",
    "alignment": [
      "<strong>Naive datetimes in, Housecall Pro-native shape out.</strong> The AI Receptionist passes <code>2026-05-15T11:00:00</code> and a timezone string. AnyCRM converts to whatever shape the Housecall Pro job-schedule requires.",
      "<strong>Email is the identity.</strong> Cancel and reschedule never need a job ID at the AI Receptionist layer. Email and soonest-upcoming resolves inside AnyCRM.",
      "<strong>Job type, line items, and tags come from setup, not the LLM.</strong> The AI Receptionist can't invent a free-text job type. It inherits the values you configured at setup.",
      "<strong>Existing customer-technician affinity is sacred.</strong> If a returning customer has run jobs with a specific technician, AnyCRM offers that technician first. Round-robin only applies to net-new customers.",
      "<strong>Cancellation preserves the audit trail.</strong> Housecall Pro's idiom for customer-cancelled jobs is honoured so reporting stays accurate and the dispatcher can see why the slot opened up.",
      "<strong>Service addresses are first-class.</strong> Every customer write attaches a normalised service-address entry. No orphan customers with no place to send a truck.",
      "<strong>Prices are in cents.</strong> AnyCRM handles the dollar-to-cents conversion so line items quote ten dollars, not ten cents.",
      "<strong>Every lead event leaves AnyCRM in two places at once.</strong> Your CRM gets the lead event so your dispatch logic can run. Your ad platforms get the server-side conversion event so bidding optimises against real booked jobs. 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> An error from Housecall Pro 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 Housecall Pro job is preserved. The customer never ends up with no truck on the way."
    ],
    "industryLine": "Currently running for <strong>HVAC, plumbing, electrical, garage doors, appliance repair, pest control, cleaning, and other home-services trades</strong>. Anyone whose dispatch is in Housecall Pro but whose phone keeps ringing after the office closes.",
    "teamsSetup": {
      "headline": "Multi-technician setup. Team roster, trade lanes & system-prompt assembly",
      "body": "If you run more than one technician on Housecall Pro, AnyCRM imports the team roster once, you link each employee to the trade lanes and service zones they actually cover, 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 covers what.",
      "steps": [
        "<strong>Team roster import.</strong> AnyCRM imports your Housecall Pro employees once and writes each active one into its database keyed by <code>crm_user_id</code> (with name, role, trade lane, timezone, mobile, color tag).",
        "<strong>Per-technician job types &amp; zones.</strong> For each technician AnyCRM resolves the job types they actually run (with the typical duration per type), their certifications, and their service-zone polygons. 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 CRM that receives lead events from AnyCRM. That's where your dispatch policy lives. AnyCRM doesn't try to own it.",
        "<strong>System-prompt assembly.</strong> The cached team roster, lane, job-type, and zone data 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. Updates to technicians, lanes, or job types re-run the cache. The AI Receptionist picks them up on its next deploy."
      ],
      "note": "The end result: the AI Receptionist can match \"my AC isn't cooling and I'm in 90210\" → the HVAC service lane → a technician on shift in that zone → that technician's diagnostic service-call job type → that technician's next arrival window → a booked Housecall Pro job with the customer, service address, and line items populated → a lead event delivered straight into your CRM → 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>Housecall Pro</span> data passes through AnyCRM. It doesn't stick.",
    "lede": "AnyCRM processes your <span data-tpl-crm>Housecall Pro</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. Customers, addresses, jobs, estimates, line items. All of it stays in Housecall Pro, owned by your Housecall Pro account.",
    "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 customer records, no caller PII."
      },
      {
        "kind": "not-stored",
        "label": "What AnyCRM doesn't",
        "body": "Caller names, emails, phone numbers, service addresses, Housecall Pro customer IDs, your technician roster, your job types, your line-item catalog, your estimate 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 Housecall Pro account and in whatever systems your CRM's flow forwards lead events to.</strong> Customers, addresses, jobs, estimates, notes all live in Housecall Pro. Source-attributed (always <code>AI Receptionist Call</code> or <code>AI Receptionist Web</code>), tagged with the inbound-call tag, revocable. AnyCRM does not build a shadow dispatch system alongside yours."
      },
      {
        "kind": "revoke",
        "label": "Revocation",
        "body": "Revoke the AnyCRM API key in Housecall Pro under My Apps → API 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": "Housecall Pro uses a single account-level API key with the admin's full permissions. AnyCRM only touches the smallest set of endpoints required for the booking lifecycle. Nothing for invoicing, nothing for payments, nothing for marketing.",
    "scopes": [
      "<strong>Customers (read + write).</strong> Read and write customer records, dedup against existing customers, append notes.",
      "<strong>Service addresses (read + write).</strong> Write the service address against the customer so dispatch has somewhere to send the truck.",
      "<strong>Jobs (read + write).</strong> Read availability and write jobs on the assigned technician's dispatch board. Reschedule and cancel through the Housecall Pro-native customer-cancelled flow.",
      "<strong>Estimates (read + write).</strong> Open estimates when the caller is shopping rather than booking. Convert when they're ready.",
      "<strong>Employees (read).</strong> Read your technician roster at setup so the AI Receptionist knows who exists and who covers each trade lane.",
      "<strong>Job types &amp; line-item catalog (read).</strong> Read your job-type and line-item catalogs at setup so the agent can only book real job types with real prices.",
      "<strong>Not requested:</strong> invoices, payments, expense entries, payroll data, dispatch automations (dispatch-creation policy stays inside your CRM's own flow), your other integrations."
    ],
    "surfaceNote": "Same API key any Housecall Pro integration uses. Just a smaller surface. AnyCRM holds the key (every write is tagged with the inbound-call tag so each customer and job change is attributable to AnyCRM in the dispatch board's filters). The LLM never sees the key, and every tool call is logged with the operation name, never the raw payload."
  },
  "failureModes": [
    {
      "title": "Duplicate customers",
      "raw": "Raw customer-create against Housecall Pro will happily create a second record for the same homeowner. Same email, same mobile, different record. Housecall Pro has no implicit dedup. You have to search first and decide whether to update the existing record. <strong>My AI Front Desk</strong> runs on a Zapier-style \"Create Customer\" action — a single API call that hands the caller's email straight at Housecall Pro with no dedup. Same caller, slightly different casing? Duplicate. Phone-only? Duplicate. <strong>Goodcall</strong> writes through a connector that does the same single-step create. <strong>Smith.ai's AI tier</strong> logs the customer after the call through a similar one-shot create. <strong>Housecall Pro's own CSR AI</strong> writes directly inside the Housecall Pro UI and benefits from some native dedup, but only on exact email match. None of these can do a multi-step \"search-on-email, then search-on-phone, then write\" because their architecture is one call in, one call out.",
      "mcp": "AnyCRM does NOT do a one-shot create. AnyCRM first searches Housecall Pro on the caller's email, then on the caller's mobile number, then decides whether to update the existing customer or create a new one. A returning caller lands on the existing record with a new note and a refreshed service address. Never as a duplicate. This costs us an extra API call per customer-create. We do it anyway, because the alternative is the duplicate-customer mess Smith.ai, My AI Front Desk, and Goodcall users live with.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Customers with no service address",
      "raw": "Housecall Pro's customer-create accepts a customer object with no service address at all. The customer is created, the call is logged, the dispatcher feels productive. And then nobody can book a job against them because Housecall Pro requires a service address on every job. <strong>My AI Front Desk's</strong> Zapier-style \"Create Customer\" action typically flattens the address into a single free-text field with no type-tag, producing customers no dispatcher can actually book against. <strong>Goodcall's</strong> connector hands whatever the AI produces through to Housecall Pro the same way. <strong>Smith.ai's</strong> human receptionists ask the caller for the address but log it as note text rather than as a properly-shaped service-address entry. <strong>CSR AI</strong> captures the address inside the Housecall Pro UI, but won't normalise the second-address-line, ZIP+4, or access notes the way a USPS-style cleanup pass would.",
      "mcp": "AnyCRM always builds a properly-shaped service-address entry from the caller's free-text address, normalises it (USPS-style cleanup, ZIP+4 if available), and refuses to write the customer without one. The dispatcher never gets a customer they can't dispatch.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai"]
    },
    {
      "title": "Jobs that land on the dispatch board unassigned",
      "raw": "Housecall Pro's job-create accepts an empty assigned-technician array. The job lands on the dispatch board at 8am next Tuesday, no technician notified, no entry on anyone's mobile app, until the dispatcher manually drags it onto someone's row in the morning. <strong>My AI Front Desk's</strong> Zapier-style \"Create Job\" action posts whatever the AI generates and has no way to assemble the assigned-technician array structurally. <strong>Goodcall's</strong> booking flow is described as \"collect a preference, hand off to the dispatcher\" — so the dispatch board sees requests rather than booked jobs. <strong>Smith.ai's</strong> AI tier logs the inquiry; the job is booked by the dispatcher manually afterwards, so the technician-assignment never happens in the same transaction.",
      "mcp": "AnyCRM resolves the right technician from the trade lane + zone + on-shift roster and always passes a single-element, correctly-shaped UUID array on the job. The technician's mobile app gets the dispatch instantly. The job never lands unassigned. We do three checks (lane, zone, on-shift) where Smith.ai/My AI Front Desk/Goodcall do one.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Inventing job types and line-item prices",
      "raw": "Housecall Pro's job-type identifier is not free text. It must match an existing job type defined in your account. Send \"Service Call\" as a string and the request fails. Send the wrong identifier and the job lands with the wrong category in reporting. Line-item prices are in CENTS. Send ten dollars as the integer 10 and Housecall Pro stores it as ten cents and the customer is invoiced for a dime. <strong>My AI Front Desk's</strong> Zapier-style action takes whatever the AI generates and posts it — there is no \"read your account's real job-types first\" step in a Zapier path. <strong>Goodcall's</strong> connector applies a static default that distorts reporting. <strong>Smith.ai's</strong> AI tier picks values from a generic playbook that doesn't match your account's catalog. The architecture is one-shot. There is no \"check the account first\" step.",
      "mcp": "AnyCRM reads your account's real job-type identifiers and your real line-item catalog (with cents-denominated prices) at setup and bakes them into the AI Receptionist's system prompt as a frozen table. So when the AI Receptionist books a job, it CAN ONLY pick job types that exist in your account and populate line items with the prices you actually charge. Invalid-identifier failures and decimal-place pricing errors are structurally impossible.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (AI tier)"]
    },
    {
      "title": "Booking the wrong technician. Or an inactive one.",
      "raw": "Housecall Pro happily accepts any employee identifier on a job, including inactive employees or office admins who never run jobs. <strong>My AI Front Desk's</strong> Zapier action takes whichever technician name the AI generates — no \"is this person still active?\" check, no \"does this person cover this trade in this zone?\" check. So an HVAC service call gets dispatched to your accountant, or to a technician who quit two months ago. <strong>Goodcall's</strong> technician routing is implicit. No published model for trade lanes, service zones, or returning-customer affinity. <strong>Smith.ai's</strong> human receptionists rely on the receptionist's memory of who covers what (fine on a Tuesday morning, less reliable on a Friday at 8pm with a relief receptionist).",
      "mcp": "AnyCRM does the heavy work in multiple steps. Matches the trade lane from the call's symptom, filters the team roster to active field technicians, intersects with the service-zone polygons for the caller's address, AND checks for returning-customer affinity before falling back to round-robin. The AI Receptionist can't dispatch to a technician who isn't currently rostered for that trade in that zone. We do four checks where Smith.ai/My AI Front Desk/Goodcall do one.",
      "competitorsAffected": ["My AI Front Desk", "Goodcall", "Smith.ai (human tier)"]
    },
    {
      "title": "Cancelling by DELETE instead of by outcome",
      "raw": "Deleting a job from Housecall Pro strips it off the customer's history entirely. No reason, no cancellation outcome, no audit trace. The dispatcher gets no signal of WHY the slot opened up. <strong>My AI Front Desk's</strong> Zapier-style cancel action issues a single DELETE — that's the only operation Zapier exposes for it. The job vanishes, the technician gets no signal, and \"jobs booked vs cancelled\" reporting breaks because the job no longer exists to be counted. <strong>Goodcall's</strong> cancellation goes through its scheduler, not the Housecall Pro job — so the scheduler is updated but the dispatch board never reflects the cancellation reason. <strong>Smith.ai</strong> receptionists ask the caller why, but the cancellation lands as a note rather than as a properly outcome-flagged job, so Housecall Pro's reporting doesn't count it correctly.",
      "mcp": "AnyCRM's cancellation is multi-step. Find the soonest upcoming job, capture the caller's reason, write the reason as a note on both the job and the customer, AND flag the job cancelled the Housecall Pro-native way. The job stays queryable in 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 dispatch policy in the prompt or in middleware",
      "raw": "<strong>My AI Front Desk</strong> ships a hardcoded \"Create Job\" action that fires on every inbound call. There is no \"only create the job if the caller actually wants a truck rolled\" logic. The action is single-step, so every call becomes a job on the board — clogging the dispatcher's morning with quotes that nobody will run. Worse, the moment you change your job-type structure or add a new trade lane, 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, 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 dispatch policy evolves.",
      "mcp": "AnyCRM does not encode your dispatch policy at all. AnyCRM sends a clean lead event straight to your CRM, into the receiving flow we wire up for you at onboarding. YOUR flow decides what happens: new job type? Update the flow. New trade lane? Update the flow. New follow-up SMS? 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 either 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 form / online-booking conversions. None of them fire a real conversion event into Google Ads, Facebook Ads, or LinkedIn Ads when the AI Receptionist closes a call. <strong>Housecall Pro's own CSR AI</strong> books jobs natively but doesn't expose a server-side conversion path to your ad platforms in its published materials either. So your Ad platforms only see the website form-fills, the bidding optimises for that (lower-intent) audience, your Cost per Lead looks deceptively low, ROAS reporting becomes a fiction, and the after-hours emergency 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 website conversions AND your AI Receptionist conversions through the same Conversion Lift pipeline. Same event shape, same source taxonomy, same delivery to your CRM, 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, Goodcall, or Housecall Pro's own CSR AI</strong> fail for <strong>HVAC, plumbing, electrical, and other home-services shops</strong> that use <span data-tpl-crm>Housecall Pro</span>. And why AnyCRM can't.",
    "lede": "Most AI Receptionists fail on Housecall Pro in the same handful of ways. Duplicate customers, customers with no service address, jobs that land on the board unassigned, free-text job types and decimal-place pricing errors, the wrong technician's dispatch, DELETEs that erase the audit trail, hardcoded dispatch 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 dispatch 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 CRM, while quietly fixing the conversion-tracking gap nobody else (not even Housecall Pro's own CSR AI) has thought to close."
  },
  "comparisonTable": {
    "headline": "AnyCRM vs Smith.ai, My AI Front Desk, and Housecall Pro's own CSR AI on <span data-tpl-crm>Housecall Pro</span>",
    "columns": [
      { "key": "anycrm", "label": "AnyCRM" },
      { "key": "smithai", "label": "Smith.ai" },
      { "key": "myaifrontdesk", "label": "My AI Front Desk" },
      { "key": "goodcall", "label": "HCP CSR AI" }
    ],
    "rows": [
      {
        "capability": "Live Housecall Pro job booked DURING the call",
        "anycrm": "<strong>Yes.</strong> Native Housecall Pro job, technician-matched, dispatch-board-synced.",
        "smithai": "Partial. Booking depends on the integration path. AI tier logs the inquiry; human tier books manually.",
        "myaifrontdesk": "Partial. Zapier-style \"Create Job\" without structural detail for technician assignment.",
        "goodcall": "Yes. Native, but only inside the Housecall Pro UI."
      },
      {
        "capability": "Dedup-before-write on email AND phone",
        "anycrm": "<strong>Yes.</strong> Always. Two searches before any write.",
        "smithai": "Manual.",
        "myaifrontdesk": "No. Zapier dedup is exact-match only.",
        "goodcall": "Partial. Native dedup, but exact email match only."
      },
      {
        "capability": "Preserves existing customer-technician affinity",
        "anycrm": "<strong>Yes.</strong> Returning customers get their affinity technician first.",
        "smithai": "Receptionist memory only.",
        "myaifrontdesk": "No. Can overwrite.",
        "goodcall": "No published affinity model."
      },
      {
        "capability": "Routes by trade lane &amp; service zone (HVAC / plumbing / install / warranty)",
        "anycrm": "<strong>Yes.</strong> Lane + zone is part of AnyCRM's team roster.",
        "smithai": "Manual, depends on the receptionist.",
        "myaifrontdesk": "No.",
        "goodcall": "No structural trade-lane routing."
      },
      {
        "capability": "Job types &amp; line-item prices frozen from your real Housecall Pro catalog",
        "anycrm": "<strong>Yes.</strong> Read at setup, baked into the prompt as a frozen table. Prices in cents.",
        "smithai": "Not API-enforced.",
        "myaifrontdesk": "No. Writes can fail on unknown job types or quote a dime instead of ten dollars.",
        "goodcall": "Yes. Native to Housecall Pro."
      },
      {
        "capability": "Cancellation preserves the audit trail (outcome-flagged, not deleted)",
        "anycrm": "<strong>Yes.</strong> Housecall Pro-native customer-cancelled flow.",
        "smithai": "Manual.",
        "myaifrontdesk": "No. DELETE strips the customer history.",
        "goodcall": "Partial. Cancellation happens in the Housecall Pro UI, reason capture varies."
      },
      {
        "capability": "Reschedule in place (no cancel-then-rebook)",
        "anycrm": "<strong>Yes.</strong>",
        "smithai": "Manual.",
        "myaifrontdesk": "No.",
        "goodcall": "Yes."
      },
      {
        "capability": "Dispatch policy delegated to YOUR CRM's own 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 Job\" action.",
        "goodcall": "No. Policy lives inside CSR AI's settings, not in your CRM-side flow."
      },
      {
        "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. Phone-answering product. No server-side conversion path published."
      },
      {
        "capability": "Server-side conversion events sent 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 form identifiers.",
        "smithai": "Manual / inconsistent.",
        "myaifrontdesk": "No standardised taxonomy.",
        "goodcall": "Inbound call data only. No web-side parity."
      },
      {
        "capability": "Scale ceiling",
        "anycrm": "Bounded by Housecall Pro API limits, not by staffing.",
        "smithai": "Bounded by human receptionist staffing.",
        "myaifrontdesk": "Bounded by Zapier rate limits and action contracts.",
        "goodcall": "Bounded by CSR AI's per-seat licensing inside Housecall Pro."
      }
    ],
    "footer": "Every row in this table is solved one layer down inside AnyCRM. Not in the prompt. Not by humans. Not by Zapier. Not by a bot living inside one CRM's UI."
  },
  "faqs": [
    {
      "q": "Does this actually work with my Housecall Pro account?",
      "a": "Yes. AnyCRM uses Housecall Pro's official API. Every captured caller lands as a customer with a normalised service address and a first note from the call. Jobs land as native Housecall Pro jobs on the right technician's dispatch board, with line items pre-populated from your catalog so the invoice is ready before the truck arrives."
    },
    {
      "q": "Will it create duplicate customers in Housecall Pro?",
      "a": "No. AnyCRM searches Housecall Pro on the caller's email then mobile against your existing customers before writing. A returning caller becomes a refreshed note and an updated service address on the existing record, never a second customer, and their job history stays intact."
    },
    {
      "q": "Can it route different calls to different technicians on my team?",
      "a": "Yes. AnyCRM reads your Housecall Pro employee roster once at setup. Every active employee, with their trade lane (HVAC / plumbing / electrical / install / service / warranty), service zone, certifications, and per-job-type duration. Service calls, install quotes, warranty work, and recurring-plan visits each route differently, and returning-customer affinity with a specific technician is honoured."
    },
    {
      "q": "Where do the jobs actually live, calendar or Housecall Pro?",
      "a": "On Housecall Pro's dispatch board, on the assigned technician's mobile app, and in reporting. AnyCRM writes the job as a native Housecall Pro job with the right technician, the right arrival window in the customer's timezone, and line items populated from your catalog. No external calendar surface. The dispatch board is the source of truth."
    },
    {
      "q": "How is this different from Housecall Pro's own CSR AI?",
      "a": "CSR AI lives inside Housecall Pro and answers calls and books jobs 24/7. It's a great phone-answering product. AnyCRM is a different layer. AnyCRM treats voice as one of two equally weighted entries into a unified lead-event pipe that ALSO fires server-side conversion events into Google Ads, Facebook Ads, and LinkedIn Ads using the origin of your registered domain. CSR AI doesn't expose that pipe. So if you spend real money on Ads, AnyCRM compounds CSR AI's job-booking value with measurable Cost per Lead reductions and ROAS lift. They aren't the same product."
    },
    {
      "q": "Can it cancel or reschedule a job from a phone call?",
      "a": "Yes. The caller gives their email or mobile, AnyCRM finds the soonest upcoming job linked to the matching customer, the AI Receptionist reads it back, and AnyCRM either reschedules in place or flags the job cancelled the Housecall Pro-native way (with the reason captured as a note on the job and the customer). Never a DELETE that would strip the audit trail."
    },
    {
      "q": "What if a caller has two upcoming jobs in Housecall Pro?",
      "a": "AnyCRM lists every upcoming job for that customer (service address, arrival window, job type, assigned technician) and the AI Receptionist asks which one to change before doing anything. It never assumes."
    },
    {
      "q": "Does it handle timezones correctly?",
      "a": "Yes. The AI Receptionist confirms the service address's timezone, AnyCRM books the job in the technician's local timezone with the correct offset, and the AI Receptionist reads the arrival window back to the caller in <em>their</em> local timezone. No customer-facing UTC strings, no off-by-an-hour confirmations."
    },
    {
      "q": "Does it create jobs or estimates?",
      "a": "Both, by intent. Booking calls (\"my AC is out, please come fix it\") land as Housecall Pro jobs on the dispatch board. Shopping calls (\"how much for a new water heater?\") land as estimates against the customer. Not phantom jobs at 8am next Tuesday that nobody runs. Recurring-plan members get attached to the existing service plan. Job creation and the deeper dispatch policy are YOUR business rules, and that policy lives inside your CRM, in the receiving flow we wire up for you at onboarding. 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 website form / online-booking submission) flows through a single conversion pipe. It lands in your CRM for dispatch 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 (not Smith.ai, not My AI Front Desk, not Goodcall, not even Housecall Pro's own CSR AI) 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 forms, online-booking submissions, chat AND the AI Receptionist all produce the same lead-event shape with the same source taxonomy. They land in the same place in your CRM, 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 booking jobs into Housecall Pro?",
      "a": "Most shops are live the same afternoon. The Housecall Pro API key takes a minute. The roster, job-types, and line-item-catalog import is automatic. We wire up the lead-receiving flow inside your CRM during onboarding. The phone integration is usually under an hour. Web chat is faster."
    }
  ]
}
