/* ============================================================
   ApexHQ Vet — site components (Colour Blocks system)
   Shared across all pages. Loads after base.css.
   ============================================================ */

/* ---------- SECTION ---------- */
.section { padding: 96px 0; }
.section-sm { padding: 64px 0; }
.sec-head { max-width: 720px; margin: 0 auto 56px; text-align: center; }
.sec-head.left { margin-left: 0; text-align: left; }
.sec-head h2 { font-size: clamp(30px, 3.8vw, 46px); }
.sec-head p { font-size: 18px; color: var(--body); margin-top: 16px; }

/* tinted bands */
.band-mint { background: linear-gradient(180deg, var(--teal-tint), #fff); }
.band-lav { background: linear-gradient(180deg, var(--violet-tint), #fff); }
.band-blue { background: linear-gradient(180deg, var(--blue-tint), #fff); }
.band-coral { background: linear-gradient(180deg, var(--coral-tint), #fff); }
.band-paper { background: var(--paper-2); }

/* ---------- HOME HERO (centred) ---------- */
.hero { position: relative; overflow: hidden; padding: 88px 0 0; text-align: center; background:
  radial-gradient(ellipse 50% 45% at 50% -5%, var(--teal-tint) 0%, transparent 60%),
  radial-gradient(circle 36% at 12% 18%, var(--blue-tint) 0%, transparent 45%),
  radial-gradient(circle 36% at 88% 14%, var(--coral-tint) 0%, transparent 45%),
  radial-gradient(circle 30% at 78% 40%, var(--violet-tint) 0%, transparent 50%),
  #fff; }
.hero-inner { max-width: 880px; margin: 0 auto; }
.hero .pill-row { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 26px; }
.hero h1 { font-size: clamp(42px, 6vw, 76px); letter-spacing: -0.04em; }
.hero h1 .grad { background: linear-gradient(100deg, var(--blue), var(--teal) 45%, var(--coral)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-sub { font-size: 20px; color: var(--body); margin: 24px auto 0; max-width: 600px; }
.hero-cta { display: flex; gap: 13px; justify-content: center; margin-top: 34px; flex-wrap: wrap; }
.hero-note { margin-top: 18px; font-size: 13.5px; color: var(--muted); display: flex; gap: 8px; justify-content: center; align-items: center; flex-wrap: wrap; }
.hero-note svg { width: 15px; height: 15px; color: var(--teal); }

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero { position: relative; overflow: hidden; padding: 72px 0 64px; }
.page-hero.tint-blue { background: radial-gradient(ellipse 60% 70% at 85% 0%, var(--blue-tint), transparent 60%), var(--paper-2); }
.page-hero.tint-violet { background: radial-gradient(ellipse 60% 70% at 85% 0%, var(--violet-tint), transparent 60%), var(--paper-2); }
.page-hero.tint-coral { background: radial-gradient(ellipse 60% 70% at 85% 0%, var(--coral-tint), transparent 60%), var(--paper-2); }
.page-hero.tint-teal { background: radial-gradient(ellipse 60% 70% at 85% 0%, var(--teal-tint), transparent 60%), var(--paper-2); }
.page-hero-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 52px; align-items: center; }
.page-hero-grid.solo { grid-template-columns: 1fr; max-width: 760px; }
.page-hero h1 { font-size: clamp(36px, 4.8vw, 58px); letter-spacing: -0.035em; }
.page-hero .lead { font-size: 19px; color: var(--body); margin-top: 20px; max-width: 540px; }
.page-hero .hero-cta { display: flex; gap: 13px; margin-top: 30px; flex-wrap: wrap; justify-content: flex-start; }
.breadcrumb { font-size: 13px; color: var(--muted); margin-bottom: 18px; display: flex; gap: 8px; align-items: center; }
.breadcrumb a:hover { color: var(--teal-ink); }
.breadcrumb svg { width: 13px; height: 13px; }

/* ---------- LOGO / INTEGRATION STRIP ---------- */
.strip { padding: 36px 0; }
.strip-lab { text-align: center; font-size: 13px; font-weight: 700; letter-spacing: .04em; color: var(--muted); text-transform: uppercase; margin-bottom: 22px; }
.strip-row { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.strip-item { display: flex; align-items: center; gap: 9px; padding: 11px 20px; border-radius: 12px; background: #fff; font-weight: 800; color: var(--ink-2); font-size: 15px; box-shadow: var(--sh-sm); }
.strip-item svg { width: 18px; height: 18px; color: var(--teal); }
.strip-item.native { background: var(--ink); color: #fff; }
.strip-item.native svg { color: var(--mint); }
.strip-ph { width: 116px; height: 30px; }

/* ---------- PROBLEM colour cards ---------- */
.prob-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.prob-col { border-radius: var(--r-xl); padding: 36px; }
.prob-col.clinic { background: linear-gradient(160deg, #eaf1fe, #f4f8ff); }
.prob-col.owner { background: linear-gradient(160deg, #ffeef2, #fff5f7); }
.prob-col h3 { font-size: 23px; display: flex; align-items: center; gap: 12px; margin-bottom: 6px; }
.prob-col .pc-ic { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; color: #fff; flex-shrink: 0; }
.prob-col.clinic .pc-ic { background: var(--blue); }
.prob-col.owner .pc-ic { background: var(--coral); }
.prob-col > p { font-size: 15px; color: var(--ink-2); margin-bottom: 24px; font-weight: 500; }
.prob-list { display: grid; gap: 14px; }
.prob-item { display: flex; gap: 13px; background: rgba(255,255,255,.75); border-radius: 14px; padding: 14px 16px; }
.prob-item .pi-ic { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.prob-col.clinic .pi-ic { background: var(--blue-tint); color: var(--blue); }
.prob-col.owner .pi-ic { background: var(--coral-tint); color: var(--coral); }
.prob-item .pi-ic svg { width: 16px; height: 16px; }
.prob-item h4 { font-size: 15px; margin-bottom: 2px; }
.prob-item p { font-size: 13.5px; color: var(--muted); line-height: 1.5; }

/* ---------- PILLARS colour-filled ---------- */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.pillar { position: relative; border-radius: var(--r-xl); padding: 32px; overflow: hidden; color: #fff; transition: transform .3s, box-shadow .3s; }
.pillar:hover { transform: translateY(-8px); }
.pillar.book { background: linear-gradient(155deg, #2f6fe0, #1f4e79); box-shadow: 0 20px 44px -16px rgba(37,99,235,.55); }
.pillar.ai { background: linear-gradient(155deg, #8b5cf6, #6d28d9); box-shadow: 0 20px 44px -16px rgba(124,58,237,.55); }
.pillar.market { background: linear-gradient(155deg, #fb7a99, #e2547a); box-shadow: 0 20px 44px -16px rgba(251,111,146,.5); }
.pillar.consult { background: linear-gradient(155deg, #15bcab, #0b7d74); box-shadow: 0 20px 44px -16px rgba(14,165,165,.5); }
.pillars.pillars-4 { grid-template-columns: repeat(2, 1fr); max-width: 980px; margin: 0 auto; }
.pillar::after { content: ''; position: absolute; top: -40px; right: -40px; width: 160px; height: 160px; border-radius: 50%; background: rgba(255,255,255,.12); }
.pillar-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; position: relative; }
.pillar-ic { width: 54px; height: 54px; border-radius: 15px; display: grid; place-items: center; background: rgba(255,255,255,.18); border: 1.5px solid rgba(255,255,255,.28); }
.pillar-ic svg { width: 27px; height: 27px; }
.pillar .badge { background: rgba(255,255,255,.95); }
.pillar h3 { font-size: 22px; margin-bottom: 9px; color: #fff; position: relative; }
.pillar > p { font-size: 14.5px; color: rgba(255,255,255,.85); line-height: 1.55; position: relative; }
.pillar-feats { list-style: none; margin-top: 20px; display: grid; gap: 10px; position: relative; }
.pillar-feats li { display: flex; gap: 9px; font-size: 13.5px; color: #fff; align-items: flex-start; }
.pillar-feats svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; opacity: .9; }
.pillar-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 22px; font-size: 14px; font-weight: 800; color: #fff; position: relative; }
.pillar-link svg { width: 15px; height: 15px; transition: transform .2s; }
.pillar:hover .pillar-link svg { transform: translateX(4px); }

/* ---------- FEATURE ROW (alternating text/visual) ---------- */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.feature + .feature { margin-top: 90px; }
.feature.flip .feat-text { order: 2; }
.feat-text .eyebrow { margin-bottom: 16px; }
.feat-text h2 { font-size: clamp(26px, 3vw, 38px); }
.feat-text > p { font-size: 17px; color: var(--body); margin-top: 16px; }
.feat-list { list-style: none; margin-top: 24px; display: grid; gap: 14px; }
.feat-list li { display: flex; gap: 13px; align-items: flex-start; }
.feat-list .fl-ic { width: 30px; height: 30px; border-radius: 9px; background: var(--teal-tint); color: var(--teal-ink); display: grid; place-items: center; flex-shrink: 0; }
.feat-list .fl-ic svg { width: 16px; height: 16px; }
.feat-list h4 { font-size: 15.5px; margin-bottom: 2px; }
.feat-list p { font-size: 14px; color: var(--muted); line-height: 1.5; }
.feat-visual { position: relative; }

/* coloured accent variants for feature icons */
.accent-blue .eyebrow, .accent-blue .eyebrow .dot { color: var(--blue); }
.accent-blue .eyebrow .dot { background: var(--blue); }
.accent-blue .fl-ic { background: var(--blue-tint); color: var(--blue); }
.accent-violet .eyebrow { color: var(--violet); } .accent-violet .eyebrow .dot { background: var(--violet); }
.accent-violet .fl-ic { background: var(--violet-tint); color: var(--violet); }
.accent-coral .eyebrow { color: #d23a63; } .accent-coral .eyebrow .dot { background: var(--coral); }
.accent-coral .fl-ic { background: var(--coral-tint); color: var(--coral); }

/* ---------- STEP CARDS (booking 6 steps, generic) ---------- */
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.step-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px; transition: transform .3s, box-shadow .3s, border-color .3s; }
.step-card:hover { transform: translateY(-5px); box-shadow: var(--sh-md); border-color: var(--blue); }
.step-card .sc-num { display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: 12px; background: var(--blue); color: #fff; font-weight: 800; font-size: 16px; margin-bottom: 16px; }
.step-card h4 { font-size: 17px; margin-bottom: 7px; }
.step-card p { font-size: 14px; color: var(--muted); line-height: 1.5; }

/* ---------- STATS ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat { text-align: center; padding: 28px 16px; border-radius: var(--r-lg); background: #fff; box-shadow: var(--sh-sm); }
.stat .num { font-size: clamp(34px, 4.2vw, 50px); font-weight: 800; letter-spacing: -.03em; line-height: 1; }
.stat:nth-child(4n+1) .num { color: var(--blue); }
.stat:nth-child(4n+2) .num { color: var(--teal); }
.stat:nth-child(4n+3) .num { color: var(--violet); }
.stat:nth-child(4n+4) .num { color: var(--coral); }
.stat .lab { font-size: 14px; color: var(--muted); margin-top: 10px; font-weight: 500; }

/* ---------- SAVINGS ---------- */
.savings { border-radius: var(--r-xl); padding: 0; overflow: hidden; box-shadow: var(--sh-lg); display: grid; grid-template-columns: 1.05fr 1fr; }
.savings-l { background: linear-gradient(160deg, var(--ink), #143b4a); color: #fff; padding: 48px; }
.savings-l h2 { color: #fff; font-size: clamp(28px, 3.2vw, 38px); }
.savings-l .sv-sub { color: #b9c6d8; font-size: 16px; margin-top: 16px; line-height: 1.6; }
.savings-r { background: #fff; padding: 40px; display: flex; flex-direction: column; justify-content: center; }
.sv-row { display: flex; align-items: center; justify-content: space-between; padding: 13px 0; border-bottom: 1px solid var(--line-2); }
.sv-row .sv-l { font-size: 14.5px; color: var(--body); }
.sv-row .sv-v { font-size: 16px; font-weight: 700; color: var(--ink); }
.sv-row.total .sv-l { font-weight: 700; color: var(--ink); }
.sv-row.apex { border: none; }
.sv-row.apex .sv-l { color: var(--teal-ink); font-weight: 800; }
.sv-row.apex .sv-v { color: var(--teal); font-size: 22px; font-weight: 800; }
.sv-save { margin-top: 16px; text-align: center; background: var(--teal-tint); border-radius: 14px; padding: 18px; }
.sv-save .big { font-size: 32px; font-weight: 800; color: var(--teal-ink); letter-spacing: -.02em; }
.sv-save .lab { font-size: 13px; color: var(--teal-ink); opacity: .8; }

/* ---------- DIFFERENTIATORS multi-hued ---------- */
.diffs { display: flex; flex-wrap: wrap; gap: 13px; justify-content: center; max-width: 960px; margin: 0 auto; }
.diff { display: inline-flex; align-items: center; gap: 9px; padding: 14px 22px; border-radius: 999px; font-weight: 700; font-size: 16px; box-shadow: var(--sh-sm); transition: .25s; }
.diff:hover { transform: translateY(-4px) scale(1.02); }
.diff svg { width: 18px; height: 18px; }
.diff.c1 { background: var(--blue-tint); color: var(--blue); } .diff.c1 svg { color: var(--blue); }
.diff.c2 { background: var(--teal-tint); color: var(--teal-ink); } .diff.c2 svg { color: var(--teal); }
.diff.c3 { background: var(--violet-tint); color: var(--violet); } .diff.c3 svg { color: var(--violet); }
.diff.c4 { background: var(--coral-tint); color: #d23a63; } .diff.c4 svg { color: var(--coral); }
.diff.c5 { background: var(--amber-tint); color: #b45309; } .diff.c5 svg { color: var(--amber); }
.diff.c6 { background: var(--green-tint); color: #0a7d54; } .diff.c6 svg { color: var(--green); }

/* ---------- TRUST ---------- */
.trust { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.trust-item { background: #fff; border-radius: var(--r-lg); padding: 28px 22px; box-shadow: var(--sh-sm); }
.trust-item .ti-ic { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 16px; }
.trust-item:nth-child(4n+1) .ti-ic { background: var(--teal-tint); color: var(--teal-ink); }
.trust-item:nth-child(4n+2) .ti-ic { background: var(--blue-tint); color: var(--blue); }
.trust-item:nth-child(4n+3) .ti-ic { background: var(--violet-tint); color: var(--violet); }
.trust-item:nth-child(4n+4) .ti-ic { background: var(--coral-tint); color: var(--coral); }
.trust-item .ti-ic svg { width: 25px; height: 25px; }
.trust-item h4 { font-size: 16px; margin-bottom: 7px; }
.trust-item p { font-size: 13.5px; color: var(--muted); line-height: 1.5; }

/* ---------- CLOSING CTA ---------- */
.cta-final { padding: 0; }
.cta-final.section { padding: 96px 0; }
.cta-card { border-radius: var(--r-xl); text-align: center; padding: 84px 40px; position: relative; overflow: hidden; background: linear-gradient(135deg, var(--blue) 0%, var(--teal) 55%, var(--mint) 110%); }
.cta-card::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 80% 0%, rgba(255,255,255,.25), transparent 50%); }
.cta-card h2 { color: #fff; font-size: clamp(34px, 4.4vw, 52px); max-width: 740px; margin: 0 auto; position: relative; }
.cta-card p { color: rgba(255,255,255,.92); font-size: 19px; margin: 18px auto 32px; max-width: 520px; position: relative; }
.cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; position: relative; }
.btn-on-grad { background: rgba(255,255,255,.16); color: #fff; border-color: rgba(255,255,255,.3); }
.btn-on-grad:hover { background: rgba(255,255,255,.26); transform: translateY(-2px); }

/* ---------- MOCK BOOKING UI ---------- */
.bk-head { background: linear-gradient(135deg, var(--blue-ink), #2a64a0); color: #fff; padding: 18px 22px; display: flex; align-items: center; gap: 12px; }
.bk-logo { width: 38px; height: 38px; border-radius: 10px; background: rgba(255,255,255,.18); border: 1.5px solid rgba(255,255,255,.3); display: grid; place-items: center; font-weight: 800; font-size: 14px; flex-shrink: 0; }
.bk-head .bk-h-t { font-weight: 800; font-size: 15px; line-height: 1.25; }
.bk-head .bk-h-s { font-size: 12px; opacity: .85; }
.bk-wide { display: grid; grid-template-columns: 200px 1fr; }
.bk-side { background: var(--paper-2); border-right: 1px solid var(--line-2); padding: 18px; }
.bk-step-v { display: flex; gap: 11px; align-items: center; padding: 9px 0; font-size: 13px; color: var(--muted); }
.bk-step-v .num { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 11px; font-weight: 800; background: #fff; border: 1.5px solid var(--line); color: var(--muted); flex-shrink: 0; }
.bk-step-v.done .num { background: var(--green); border-color: var(--green); color: #fff; }
.bk-step-v.now { color: var(--ink); font-weight: 700; }
.bk-step-v.now .num { background: var(--blue-ink); border-color: var(--blue-ink); color: #fff; }
.bk-main { padding: 22px; text-align: left; }
.bk-label { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px; }
.bk-pets { display: grid; grid-template-columns: repeat(3, 1fr); gap: 11px; }
.bk-pet { border: 1.5px solid var(--line); border-radius: 14px; padding: 16px 8px; text-align: center; transition: .2s; }
.bk-pet.sel { border-color: var(--blue-ink); background: #f3f8fd; box-shadow: 0 0 0 3px rgba(31,78,121,.08); }
.bk-pet .emoji { font-size: 30px; line-height: 1; }
.bk-pet .pn { font-size: 13px; font-weight: 700; color: var(--ink); margin-top: 8px; }
.bk-cta { margin-top: 18px; background: var(--blue-ink); color: #fff; text-align: center; padding: 13px; border-radius: 12px; font-weight: 700; font-size: 14px; }

/* ---------- MOCK AI PHONE ---------- */
.ai-ui { font-size: 11px; }
.ai-top { background: var(--ink); color: #fff; padding: 26px 14px 11px; display: flex; align-items: center; gap: 8px; }
.ai-top > div { min-width: 0; }
.ai-top .rec { width: 9px; height: 9px; border-radius: 50%; background: #ff5a5f; animation: pulse-rec 1.4s infinite; flex-shrink: 0; }
@keyframes pulse-rec { 0%,100% { opacity: 1; } 50% { opacity: .3; } }
.ai-top .at-t { font-weight: 700; font-size: 12px; white-space: nowrap; }
.ai-top .at-s { font-size: 10px; opacity: .7; }
.ai-wave { display: flex; align-items: flex-end; gap: 3px; height: 30px; padding: 12px 16px 4px; }
.ai-wave i { flex: 1; background: linear-gradient(var(--teal), var(--mint)); border-radius: 2px; animation: wave 1.1s ease-in-out infinite; }
@keyframes wave { 0%,100% { height: 25%; } 50% { height: 100%; } }
.ai-note { padding: 8px 16px 18px; text-align: left; }
.ai-note .ann { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--violet); margin-bottom: 7px; display: flex; align-items: center; gap: 5px; }
.ai-line { height: 7px; border-radius: 4px; background: var(--line-2); margin-bottom: 7px; }
.ai-line.w1 { width: 90%; } .ai-line.w2 { width: 70%; } .ai-line.w3 { width: 82%; } .ai-line.w4 { width: 55%; }
.ai-chip { display: inline-block; font-size: 9px; font-weight: 700; color: var(--violet); background: var(--violet-tint); padding: 3px 8px; border-radius: 6px; margin-top: 4px; }

/* ---------- PRICING ---------- */
.price-toggle { display: inline-flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 6px; box-shadow: var(--sh-sm); }
.price-toggle button { border: none; background: transparent; padding: 9px 18px; border-radius: 999px; font-weight: 700; font-size: 14px; color: var(--muted); transition: .2s; white-space: nowrap; }
.price-toggle button.on { background: var(--ink); color: #fff; }
.price-toggle .save-tag { font-size: 12px; font-weight: 700; color: var(--green); background: var(--green-tint); padding: 4px 10px; border-radius: 999px; }
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: start; }
.plan { background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); padding: 32px; position: relative; transition: transform .3s, box-shadow .3s; }
.plan:hover { transform: translateY(-5px); box-shadow: var(--sh-md); }
.plan.featured { border: 2px solid var(--teal); box-shadow: 0 24px 50px -18px rgba(14,165,165,.4); }
.plan-pop { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: linear-gradient(180deg, var(--teal-bright), var(--teal)); color: #fff; font-size: 12px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; padding: 6px 14px; border-radius: 999px; box-shadow: var(--sh-teal); white-space: nowrap; }
.plan h3 { font-size: 20px; }
.plan .plan-for { font-size: 13.5px; color: var(--muted); margin-top: 4px; }
.plan .price { margin: 22px 0 6px; display: flex; align-items: baseline; gap: 4px; }
.plan .price .amt { font-size: 46px; font-weight: 800; letter-spacing: -.03em; color: var(--ink); }
.plan .price .per { font-size: 14px; color: var(--muted); font-weight: 600; }
.plan .price-note { font-size: 13px; color: var(--muted); }
.plan .btn { width: 100%; margin: 24px 0; }
.plan-feats { list-style: none; display: grid; gap: 12px; }
.plan-feats li { display: flex; gap: 10px; font-size: 14px; color: var(--ink-2); align-items: flex-start; line-height: 1.45; }
.plan-feats svg { width: 17px; height: 17px; color: var(--teal); flex-shrink: 0; margin-top: 2px; }
.plan-feats li.muted { color: var(--subtle); } .plan-feats li.muted svg { color: var(--subtle); }
.plan-feats .grp { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--subtle); margin-top: 6px; }

/* ---------- COMPARISON TABLE ---------- */
.cmp { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; }
.cmp th, .cmp td { padding: 16px 20px; text-align: left; border-bottom: 1px solid var(--line-2); font-size: 14.5px; }
.cmp thead th { background: var(--paper-2); font-weight: 700; color: var(--ink); font-size: 14px; }
.cmp thead th.apex { background: var(--ink); color: #fff; }
.cmp td.feat { font-weight: 600; color: var(--ink-2); }
.cmp td.center, .cmp th.center { text-align: center; }
.cmp .yes { color: var(--green); } .cmp .no { color: var(--subtle); }
.cmp .yes svg, .cmp .no svg { width: 19px; height: 19px; }
.cmp tbody tr:last-child td { border-bottom: none; }
.cmp td.apex-col { background: rgba(14,165,165,.05); font-weight: 600; color: var(--teal-ink); }
.cmp-wrap { overflow-x: auto; border-radius: var(--r-lg); }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin: 0 auto; display: grid; gap: 12px; }
.faq-item { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; transition: box-shadow .2s, border-color .2s; }
.faq-item.open { border-color: var(--teal); box-shadow: var(--sh-sm); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; background: none; border: none; text-align: left; font-size: 16.5px; font-weight: 700; color: var(--ink); }
.faq-q .chev { width: 22px; height: 22px; flex-shrink: 0; color: var(--teal); transition: transform .3s; }
.faq-item.open .faq-q .chev { transform: rotate(180deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s cubic-bezier(.4,0,.2,1); }
.faq-item.open .faq-a { max-height: 320px; }
.faq-a-inner { padding: 0 24px 22px; font-size: 15px; color: var(--body); line-height: 1.6; }

/* ---------- FORM ---------- */
.form-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); padding: 40px; box-shadow: var(--sh-md); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { margin-bottom: 18px; }
.field label { display: block; font-size: 13.5px; font-weight: 700; color: var(--ink-2); margin-bottom: 7px; }
.field .req { color: var(--coral); }
.field input, .field select, .field textarea {
  width: 100%; font-family: inherit; font-size: 15px; color: var(--ink);
  background: var(--paper-2); border: 1.5px solid var(--line); border-radius: 12px; padding: 12px 14px; transition: .15s;
}
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--teal); background: #fff; box-shadow: 0 0 0 4px rgba(14,165,165,.12); }
.field input.invalid, .field select.invalid, .field textarea.invalid { border-color: var(--coral); background: #fff5f7; }
.field .err { font-size: 12.5px; color: #d23a63; margin-top: 6px; display: none; }
.field.show-err .err { display: block; }
.form-success { display: none; text-align: center; padding: 30px 0; }
.form-success.show { display: block; }
.form-success .fs-ic { width: 64px; height: 64px; border-radius: 50%; background: var(--green-tint); color: var(--green); display: grid; place-items: center; margin: 0 auto 18px; }
.form-success .fs-ic svg { width: 32px; height: 32px; }
.form-success h3 { font-size: 24px; margin-bottom: 8px; }
.form-success p { color: var(--body); font-size: 16px; }

/* ---------- CONFIG GRID (For Clinics) ---------- */
.config-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.config-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 24px; transition: transform .25s, box-shadow .25s, border-color .25s; }
.config-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--teal); }
.config-card .cc-top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.config-card .cc-num { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 12px; font-weight: 600; color: var(--subtle); }
.config-card .cc-ic { width: 40px; height: 40px; border-radius: 11px; background: var(--teal-tint); color: var(--teal-ink); display: grid; place-items: center; flex-shrink: 0; }
.config-card .cc-ic svg { width: 20px; height: 20px; }
.config-card h4 { font-size: 16px; margin-bottom: 6px; }
.config-card p { font-size: 13.5px; color: var(--muted); line-height: 1.5; }

/* ---------- ROADMAP ---------- */
.roadmap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; position: relative; }
.phase { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 30px; position: relative; }
.phase .ph-badge { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; padding: 5px 12px; border-radius: 999px; margin-bottom: 16px; }
.phase.now { border-color: var(--green); }
.phase.now .ph-badge { background: var(--green-tint); color: #0a7d54; }
.phase.next .ph-badge { background: var(--blue-tint); color: var(--blue); }
.phase.future { background: linear-gradient(160deg, #fff, var(--coral-tint)); }
.phase.future .ph-badge { background: var(--amber-tint); color: #b45309; }
.phase h4 { font-size: 19px; margin-bottom: 8px; }
.phase p { font-size: 14.5px; color: var(--body); line-height: 1.55; }
.phase .ph-num { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 13px; color: var(--subtle); margin-bottom: 10px; }

/* ---------- generic content card ---------- */
.card-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.card-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.info-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 30px; }
.info-card .ic-ic { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 18px; background: var(--teal-tint); color: var(--teal-ink); }
.info-card .ic-ic svg { width: 25px; height: 25px; }
.info-card h3 { font-size: 19px; margin-bottom: 9px; }
.info-card h4 { font-size: 17px; margin-bottom: 8px; }
.info-card p { font-size: 14.5px; color: var(--body); line-height: 1.55; }
.info-card ul { list-style: none; margin-top: 14px; display: grid; gap: 10px; }
.info-card ul li { display: flex; gap: 9px; font-size: 14px; color: var(--ink-2); align-items: flex-start; }
.info-card ul svg { width: 16px; height: 16px; color: var(--teal); flex-shrink: 0; margin-top: 3px; }

/* roadmap chip list */
.chip-list { display: flex; flex-wrap: wrap; gap: 10px; }
.chip { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: 999px; background: var(--paper-3); font-size: 14px; font-weight: 600; color: var(--ink-2); }
.chip svg { width: 15px; height: 15px; color: var(--teal); }
.chip.road { background: var(--amber-tint); color: #b45309; } .chip.road svg { color: var(--amber); }

/* placeholder note */
.ph-note { font-size: 12.5px; color: var(--subtle); font-style: italic; margin-top: 10px; }

/* ---------- SOAP template chips ---------- */
.tmpl-row { display: flex; flex-wrap: wrap; gap: 10px; }
.tmpl { display: inline-flex; align-items: center; gap: 8px; padding: 11px 17px; border-radius: 999px; border: 1.5px solid var(--line); background: #fff; font-size: 14px; font-weight: 700; color: var(--ink-2); transition: .2s; }
.tmpl svg { width: 15px; height: 15px; }
.tmpl.on { border-color: var(--violet); background: var(--violet-tint); color: var(--violet); }
.tmpl.on svg { color: var(--violet); }

/* ---------- multi-source consult content ---------- */
.src-list { display: grid; gap: 10px; }
.src-item { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 13px 15px; }
.src-ic { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; flex-shrink: 0; }
.src-ic svg { width: 18px; height: 18px; }
.src-item .src-t { font-size: 13.5px; font-weight: 700; color: var(--ink); }
.src-item .src-s { font-size: 12px; color: var(--muted); }
.src-status { margin-left: auto; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .03em; padding: 4px 9px; border-radius: 6px; flex-shrink: 0; }
.src-status.ok { background: var(--green-tint); color: #0a7d54; }
.src-status.proc { background: var(--violet-tint); color: var(--violet); }

/* ---------- iOS app showcase ---------- */
.appshow { display: grid; grid-template-columns: 1fr 1.05fr; gap: 52px; align-items: center; }
.appshow-phones { display: flex; gap: 20px; justify-content: center; align-items: flex-start; }
.appshow-phones .phone { width: 230px; }
.appshow-phones .phone:nth-child(2) { margin-top: 30px; }
.app-scr { font-size: 12px; background: var(--paper-2); min-height: 420px; display: flex; flex-direction: column; }
.app-head { background: linear-gradient(160deg, #0f1f35, #143b4a); color: #fff; padding: 30px 15px 15px; }
.app-greet { font-size: 11.5px; color: #9fb8c8; }
.app-h-title { font-size: 17px; font-weight: 800; color: #fff; margin-top: 2px; }
.app-clinic { font-size: 11px; color: var(--mint); font-weight: 600; margin-top: 2px; }
.app-stats { display: flex; gap: 7px; margin-top: 13px; }
.app-stat { flex: 1; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 10px 6px; text-align: center; }
.app-stat .n { font-size: 18px; font-weight: 800; color: #fff; line-height: 1; }
.app-stat .l { font-size: 8.5px; color: #9fb8c8; margin-top: 4px; }
.app-stat.on { background: rgba(45,212,191,.14); border-color: rgba(45,212,191,.3); }
.app-stat.on .n { color: var(--mint); }
.app-body { padding: 13px; flex: 1; }
.app-sec { font-size: 12px; font-weight: 800; color: var(--ink); margin-bottom: 9px; }
.app-appt { background: #fff; border: 1px solid var(--line); border-radius: 13px; padding: 12px; }
.app-appt .ti { font-size: 10.5px; color: var(--muted); display: flex; gap: 6px; align-items: center; }
.app-appt .pt { font-weight: 800; color: var(--ink); font-size: 13px; margin-top: 7px; }
.app-appt .meta { font-size: 10.5px; color: var(--muted); margin-top: 1px; }
.app-appt .start { margin-top: 10px; padding-top: 9px; border-top: 1px solid var(--line-2); color: var(--teal-ink); font-weight: 700; font-size: 12px; display: flex; align-items: center; gap: 6px; }
.app-appt .start svg { width: 13px; height: 13px; }
.app-rec { background: #fff; border: 1px solid var(--line); border-radius: 13px; padding: 11px 12px; margin-bottom: 8px; }
.app-rec .rh { display: flex; align-items: center; gap: 8px; }
.app-rec .av { width: 26px; height: 26px; border-radius: 50%; background: var(--teal-tint); color: var(--teal-ink); display: grid; place-items: center; font-size: 11px; font-weight: 800; flex-shrink: 0; }
.app-rec .nm { font-size: 12.5px; font-weight: 800; color: var(--ink); }
.app-rec .sp { font-size: 9px; font-weight: 700; color: var(--blue); background: var(--blue-tint); padding: 2px 7px; border-radius: 5px; }
.app-rec .chips { display: flex; gap: 6px; margin-top: 9px; padding-top: 9px; border-top: 1px solid var(--line-2); }
.app-rec .mc { font-size: 9px; font-weight: 700; padding: 3px 8px; border-radius: 6px; }
.app-rec .mc.done { background: var(--green-tint); color: #0a7d54; }
.app-rec .mc.rev { background: var(--amber-tint); color: #b45309; }
.app-rec .mc.appr { background: var(--blue-tint); color: var(--blue); }
.app-aihero { text-align: center; padding: 18px 8px 12px; }
.app-aihero .sp-ic { width: 54px; height: 54px; border-radius: 50%; background: var(--teal-tint); color: var(--teal); display: grid; place-items: center; margin: 0 auto 12px; }
.app-aihero .sp-ic svg { width: 26px; height: 26px; }
.app-aihero h5 { font-size: 16px; color: var(--ink); }
.app-aihero p { font-size: 11px; color: var(--muted); margin-top: 6px; line-height: 1.45; }
.app-qa { display: grid; gap: 8px; margin-top: 14px; }
.app-qa-item { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 11px 12px; }
.app-qa-item .qa-ic { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.app-qa-item .qa-ic svg { width: 15px; height: 15px; }
.app-qa-item .qt { font-size: 12.5px; font-weight: 700; color: var(--ink); flex: 1; }
.app-qa-item .ch { color: var(--subtle); }
.app-qa-item .ch svg { width: 13px; height: 13px; }
.app-tabs { display: flex; justify-content: space-around; padding: 9px 6px calc(9px + env(safe-area-inset-bottom)); border-top: 1px solid var(--line-2); background: #fff; }
.app-tab { display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 8px; color: var(--subtle); font-weight: 600; }
.app-tab svg { width: 17px; height: 17px; }
.app-tab.on { color: var(--teal); }

/* ---------- announcement bar ---------- */
.announce {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: linear-gradient(90deg, var(--ink), #143b4a 55%, #0b6e6e);
  color: #dff7f1; font-size: 14px; font-weight: 600; padding: 10px 20px;
  text-align: center; transition: filter .2s;
}
.announce:hover { filter: brightness(1.12); }
.announce .an-new { background: var(--mint); color: var(--ink); font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; padding: 3px 9px; border-radius: 999px; flex-shrink: 0; }
.announce svg { width: 15px; height: 15px; flex-shrink: 0; }
@media (max-width: 560px) { .announce { font-size: 12.5px; flex-wrap: wrap; gap: 7px; } }

/* ---------- responsive ---------- */
@media (max-width: 940px) {
  .page-hero-grid, .feature, .prob-grid, .pillars, .savings, .trust, .stats,
  .steps-grid, .plans, .config-grid, .roadmap, .card-grid-2, .card-grid-3, .form-row, .appshow { grid-template-columns: 1fr; }
  .feature.flip .feat-text { order: 0; }
  .feature + .feature { margin-top: 60px; }
  .showcase .phone { display: none; }
  .appshow-phones .phone:nth-child(2) { margin-top: 0; }
  .bk-wide { grid-template-columns: 1fr; } .bk-side { display: none; }
  .stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .section { padding: 64px 0; }
  .trust, .stats, .steps-grid, .config-grid { grid-template-columns: 1fr; }
  .savings-l, .savings-r, .cta-card, .form-card { padding: 30px 24px; }
}

/* ---- real product screenshots ---- */
.shot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 26px;margin-top:8px}
@media(max-width:760px){.shot-grid{grid-template-columns:1fr}}
.shot-item{display:flex;flex-direction:column}
.shot-card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 18px 50px -22px rgba(15,31,53,.28)}
.shot-card img{width:100%;display:block}
.shot-cap{font-weight:800;color:var(--ink);font-size:15.5px;margin-top:14px}
.shot-sub{font-size:13.5px;color:var(--muted);margin-top:3px}
.browser .shot-embed{width:100%;display:block}

/* ---- hero three-product showcase ---- */
.hero-trio{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:34px;align-items:start;margin-top:58px}
.trio-item{display:flex;flex-direction:column;align-items:center;gap:14px;min-width:0}
.trio-item .browser{width:100%}
.trio-item .phone{width:min(250px,100%)}
.trio-tag{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 16px;box-shadow:0 6px 18px -10px rgba(15,31,53,.25)}
.trio-tag .pulse-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.trio-cap{font-size:13.5px;color:var(--muted);text-align:center;max-width:280px;line-height:1.45}
@media(max-width:980px){.hero-trio{grid-template-columns:1fr 1fr}.trio-item:first-child{grid-column:1/-1}}
@media(max-width:620px){.hero-trio{grid-template-columns:1fr}}

/* ---- pain cards (problem section) ---- */
.pain-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:8px}
.pain-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px 26px;box-shadow:0 16px 40px -28px rgba(15,31,53,.35)}
.pain-card h3{font-size:18.5px;color:var(--ink);margin:16px 0 8px;line-height:1.3}
.pain-card p{font-size:14.5px;color:var(--muted);line-height:1.55}
.pain-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center}
.pain-bridge{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:36px;font-weight:800;color:var(--teal-ink);font-size:15.5px}
@media(max-width:980px){.pain-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pain-grid{grid-template-columns:1fr}}

/* ---- six-step timeline ---- */
.flow-wrap{display:grid;grid-template-columns:.85fr 1.3fr;gap:64px;align-items:start}
.flow-left{position:sticky;top:110px}
.steps-flow{list-style:none;margin:0;padding:0}
.step-row{display:grid;grid-template-columns:56px 1fr;gap:20px;position:relative;padding-bottom:34px}
.step-row:not(:last-child)::before{content:"";position:absolute;left:27px;top:60px;bottom:6px;width:2px;border-radius:2px;background:linear-gradient(180deg,var(--blue) 0%,rgba(37,99,235,.15) 100%)}
.step-num{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,var(--blue),#5b8bf7);color:#fff;font-weight:800;font-size:20px;display:grid;place-items:center;box-shadow:0 10px 22px -10px rgba(37,99,235,.55);flex-shrink:0}
.step-body{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 24px;box-shadow:0 12px 30px -24px rgba(15,31,53,.35)}
.step-body h4{font-size:17px;color:var(--ink);margin-bottom:6px}
.step-body p{font-size:14.5px;color:var(--muted);line-height:1.55}
@media(max-width:880px){.flow-wrap{grid-template-columns:1fr;gap:36px}.flow-left{position:static}}

/* ---- pet graphics ---- */
.pet-cluster{display:flex;margin-top:26px}
.pet-bub{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:27px;border:3px solid #fff;box-shadow:0 8px 20px -10px rgba(15,31,53,.35);margin-left:-12px}
.pet-bub:first-child{margin-left:0}
.pet-bub:nth-child(odd){transform:rotate(-6deg)}
.pet-bub:nth-child(even){transform:rotate(6deg)}
.pet-bub.more{background:var(--ink);color:#fff;font-size:22px;font-weight:800}
.mini-chips{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.mini-chip{font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:9px;background:var(--paper-2);border:1px solid var(--line-2);color:var(--muted)}
.mini-chip.sel{background:var(--blue-tint);border-color:rgba(37,99,235,.3);color:var(--blue);font-weight:700}
.mini-chip.ai{background:var(--violet-tint);border-color:rgba(124,58,237,.25);color:var(--violet);font-weight:700}
.mini-chip.ok{background:var(--green-tint);border-color:rgba(16,185,129,.3);color:#0a7d54;font-weight:700}
.paws-bg{position:relative}
.paws-bg::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cg fill='rgba(37,99,235,0.055)'%3E%3Cellipse cx='40' cy='44' rx='11' ry='14'/%3E%3Ccircle cx='26' cy='28' r='5.5'/%3E%3Ccircle cx='40' cy='23' r='5.5'/%3E%3Ccircle cx='54' cy='28' r='5.5'/%3E%3C/g%3E%3Cg fill='rgba(37,99,235,0.04)' transform='rotate(24 120 120)'%3E%3Cellipse cx='118' cy='118' rx='9' ry='12'/%3E%3Ccircle cx='106' cy='104' r='4.5'/%3E%3Ccircle cx='118' cy='100' r='4.5'/%3E%3Ccircle cx='130' cy='104' r='4.5'/%3E%3C/g%3E%3C/svg%3E")}
.paws-bg>.container{position:relative;z-index:1}

/* ---- hero product list ---- */
.hero-products{display:flex;flex-direction:column;gap:11px;align-items:center;margin:18px auto 6px;max-width:640px}
.hp-row{display:flex;align-items:baseline;gap:12px;font-size:16.5px;color:var(--muted);text-align:left;line-height:1.5}
.hp-row strong{color:var(--ink)}
.hp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;position:relative;top:-2px}
@media(max-width:640px){.hp-row{font-size:15px}}

/* ---- hero product cards ---- */
.hero-prodcards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:1280px;margin:40px auto 12px}
.hpc{display:block;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);border:1.5px solid var(--line);border-radius:22px;padding:32px 34px 28px;text-align:left;box-shadow:0 20px 44px -28px rgba(15,31,53,.45);text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease;cursor:pointer}
.hpc:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(15,31,53,.5)}
.hpc-blue:hover{border-color:var(--blue);background:linear-gradient(170deg,var(--blue-tint),rgba(255,255,255,.92))}
.hpc-violet:hover{border-color:var(--violet);background:linear-gradient(170deg,var(--violet-tint),rgba(255,255,255,.92))}
.hpc-teal:hover{border-color:var(--teal);background:linear-gradient(170deg,var(--teal-tint),rgba(255,255,255,.92))}
.hpc-more{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:14px;font-weight:800;opacity:0;transform:translateX(-6px);transition:opacity .25s ease,transform .25s ease}
.hpc-blue .hpc-more{color:var(--blue)}.hpc-violet .hpc-more{color:var(--violet)}.hpc-teal .hpc-more{color:var(--teal-ink)}
.hpc:hover .hpc-more{opacity:1;transform:translateX(0)}
@media(hover:none){.hpc-more{opacity:1;transform:none}}
.hpc-top{display:flex;align-items:center;gap:14px;margin-bottom:13px}
.hpc-ic{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;flex-shrink:0}
.hpc h3{font-size:20px;color:var(--ink);margin:0}
.hpc p{font-size:15.5px;color:var(--muted);line-height:1.6;margin:0}
@media(max-width:860px){.hero-prodcards{grid-template-columns:1fr;max-width:420px}}

/* ---- AI engine chip in hero headline ---- */
.ai-mark{display:inline-flex;align-items:baseline;gap:.12em;font-size:inherit;font-weight:inherit;background:linear-gradient(115deg,#2563eb 0%,#7c3aed 55%,#14c8b8 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.ai-mark svg{width:.5em;height:.5em;flex-shrink:0;align-self:center;color:#7c3aed;animation:aiTwinkle 3.2s ease-in-out infinite;transform-origin:center}
@keyframes aiShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes aiTwinkle{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.82) rotate(12deg);opacity:.85}}
@media (prefers-reduced-motion: reduce){.ai-mark,.ai-mark svg{animation:none}}

/* ---- responsive polish (phone + tablet) ---- */
.browser-url{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.cmp{min-width:680px}
.cmp-wrap{-webkit-overflow-scrolling:touch}
@media (max-width: 940px){
  .hero{padding-top:48px}
  .hero-trio{gap:26px}
  .flow-left{margin-bottom:6px}
}
@media (max-width: 700px){
  .hero-prodcards{grid-template-columns:1fr;max-width:440px;gap:14px}
  .hpc{padding:24px 26px 22px}
}
@media (max-width: 560px){
  .hero h1{font-size:clamp(34px,9.5vw,42px)}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
  .cta-btns{flex-direction:column;align-items:stretch}
  .cta-btns .btn{width:100%;justify-content:center}
  .step-num{width:44px;height:44px;font-size:17px;border-radius:13px}
  .step-row{grid-template-columns:46px 1fr;gap:14px;padding-bottom:24px}
  .step-row:not(:last-child)::before{left:22px;top:50px}
  .step-body{padding:16px 18px}
  .pet-bub{width:46px;height:46px;font-size:22px}
  .trio-cap{font-size:12.5px}
  .pain-card{padding:22px 20px}
  .shot-cap{font-size:14.5px}
  .hero-prodcards{margin-top:24px}
  .pillars.pillars-4{grid-template-columns:1fr}
}
@media (max-width: 860px) and (min-width: 701px){
  .hero-prodcards{grid-template-columns:repeat(3,1fr);max-width:100%;gap:14px}
  .hpc{padding:20px 18px 18px}
  .hpc h3{font-size:16.5px}
  .hpc p{font-size:13.5px}
}
