/* =====================================================================
   Victoria — AI Receptionist | marketing site
   Design tokens + responsive, mobile-first styles.
   Palette: deep indigo canvas, cyan/teal energy, warm coral CTAs.
   Professional + colourful, not garish. No framework — modern CSS only.
   ===================================================================== */

:root {
  /* Brand palette */
  --ink: #0b1020;            /* near-black navy canvas */
  --ink-2: #141a32;
  --indigo: #6d28d9;
  --indigo-2: #4f46e5;
  --cyan: #06b6d4;
  --cyan-2: #22d3ee;
  --coral: #fb7185;          /* primary CTA */
  --coral-2: #f43f5e;
  --amber: #f59e0b;
  --paper: #ffffff;
  --mist: #f6f8fc;           /* light section bg */
  --mist-2: #eef2fb;
  --slate: #334155;
  --slate-soft: #64748b;
  --line: #e2e8f0;

  --hero-grad: radial-gradient(1200px 600px at 80% -10%, rgba(34,211,238,.25), transparent 60%),
               radial-gradient(900px 500px at 0% 10%, rgba(109,40,217,.35), transparent 55%),
               linear-gradient(160deg, #0b1020 0%, #141a32 60%, #1b1340 100%);
  --cta-grad: linear-gradient(135deg, var(--coral) 0%, var(--coral-2) 55%, #e11d48 100%);
  --accent-grad: linear-gradient(135deg, var(--cyan-2), var(--indigo-2));

  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 10px 30px -12px rgba(2,6,23,.25);
  --shadow-lg: 0 30px 60px -20px rgba(2,6,23,.45);
  --maxw: 1180px;
  --font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --display: "Sora", var(--font);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; width: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font);
  color: var(--slate);
  background: var(--paper);
  line-height: 1.6;
  font-size: clamp(16px, 1.05vw, 18px);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, h4 { font-family: var(--display); color: #0f172a; line-height: 1.12; letter-spacing: -0.02em; margin: 0 0 .5em; }
h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.4rem); }
p { margin: 0 0 1rem; }
a { color: var(--indigo-2); text-decoration: none; }
img { max-width: 100%; display: block; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(18px, 4vw, 40px); }
.section { padding: clamp(56px, 9vw, 120px) 0; }
.section--tint { background: var(--mist); }
.section--ink { background: var(--ink); color: #cbd5e1; }
.section--ink h2, .section--ink h3 { color: #fff; }
.eyebrow { display:inline-block; font-family: var(--display); font-weight:700; letter-spacing:.14em; text-transform:uppercase; font-size:.72rem; color: var(--indigo-2); margin-bottom: .9rem; }
.section--ink .eyebrow { color: var(--cyan-2); }
.lede { font-size: clamp(1.05rem, 1.6vw, 1.25rem); color: var(--slate-soft); max-width: 60ch; }
.section--ink .lede { color: #94a3b8; }
.center { text-align: center; }
.center .lede { margin-inline: auto; }

/* ---------- Buttons ---------- */
.btn { display:inline-flex; align-items:center; gap:.55em; font-family:var(--display); font-weight:700; font-size:1rem;
  padding: .9em 1.5em; border-radius: 999px; border: 0; cursor: pointer; transition: transform .15s ease, box-shadow .25s ease, background .25s; white-space: nowrap; }
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--cta-grad); color:#fff; box-shadow: 0 12px 26px -10px rgba(244,63,94,.6); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 18px 34px -10px rgba(244,63,94,.7); }
.btn--ghost { background: rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.25); backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255,255,255,.16); }
.btn--dark { background:#0f172a; color:#fff; }
.btn--dark:hover { transform: translateY(-2px); }
.btn--block { width:100%; justify-content:center; }
.btn--lg { font-size:1.08rem; padding:1.05em 1.8em; }

/* ---------- Header / nav ---------- */
.site-header { position: sticky; top:0; z-index: 50; background: rgba(11,16,32,.72); backdrop-filter: blur(12px); border-bottom:1px solid rgba(255,255,255,.08); }
.nav { display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand { display:flex; align-items:center; gap:.6rem; font-family:var(--display); font-weight:800; font-size:1.25rem; color:#fff; letter-spacing:-.02em; }
.brand .dot { width:12px; height:12px; border-radius:50%; background: var(--cta-grad); box-shadow:0 0 0 4px rgba(251,113,133,.25); animation: pulse 2.4s infinite; }
@keyframes pulse { 0%,100%{ box-shadow:0 0 0 4px rgba(251,113,133,.25);} 50%{ box-shadow:0 0 0 9px rgba(251,113,133,0);} }
.nav-links { display:flex; align-items:center; gap:1.6rem; list-style:none; margin:0; padding:0; }
.nav-links a { color:#cbd5e1; font-weight:600; font-size:.95rem; }
.nav-links a:hover { color:#fff; }
.nav-cta { display:flex; align-items:center; gap:.8rem; }
.nav-tel { color:#fff; font-weight:700; font-family:var(--display); display:inline-flex; align-items:center; gap:.4rem; }
.nav-toggle { display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span { display:block; width:24px; height:2px; background:#fff; margin:5px 0; transition:.3s; }

/* ---------- Hero ---------- */
.hero { background: var(--hero-grad); color:#fff; position:relative; overflow:hidden; }
.hero::after { content:""; position:absolute; inset:auto 0 -1px 0; height:120px; background:linear-gradient(to bottom, transparent, var(--paper)); pointer-events:none; }
.hero-grid { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(24px,5vw,64px); align-items:center; padding: clamp(48px,8vw,96px) 0 clamp(80px,10vw,130px); }
.hero h1 { color:#fff; font-size: clamp(2.3rem, 5.4vw, 4rem); }
.hero h1 .grad { background: linear-gradient(120deg, var(--cyan-2), #c4b5fd); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero p.sub { font-size: clamp(1.05rem,1.7vw,1.3rem); color:#c7d2fe; max-width: 52ch; margin-bottom:1.8rem; }
.hero-cta { display:flex; flex-wrap:wrap; gap:.9rem; align-items:center; }
.hero-trust { display:flex; flex-wrap:wrap; gap:1.2rem 1.8rem; margin-top:2.2rem; color:#94a3b8; font-size:.9rem; }
.hero-trust b { color:#fff; }
.hero-trust span { display:inline-flex; align-items:center; gap:.5rem; }
.tick { color: var(--cyan-2); font-weight:900; }

/* Hero visual / image frame */
.hero-visual { position:relative; }
.hero-photo { position:relative; border-radius: 26px; overflow:hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/5; background:
  linear-gradient(135deg, rgba(34,211,238,.18), rgba(109,40,217,.35)); border:1px solid rgba(255,255,255,.14); }
.hero-photo img { width:100%; height:100%; object-fit:cover; }
.hero-photo .placeholder { position:absolute; inset:0; display:grid; place-content:center; text-align:center; gap:.6rem; color:#e2e8f0; padding:24px; }
.hero-photo .placeholder svg { width:96px; height:96px; opacity:.9; margin:0 auto; }
.hero-badge { position:absolute; backdrop-filter: blur(8px); background: rgba(15,23,42,.55); border:1px solid rgba(255,255,255,.18); color:#fff; border-radius:14px; padding:.7rem .9rem; box-shadow: var(--shadow); font-size:.85rem; }
.hero-badge b { display:block; font-family:var(--display); font-size:1.1rem; }
.hero-badge--tl { top:18px; left:-14px; }
.hero-badge--br { bottom:24px; right:-14px; }
.hero-badge .k { color:var(--cyan-2); }

/* ---------- Logos / trust strip ---------- */
.strip { background:#0f172a; color:#94a3b8; padding:18px 0; }
.strip .container { display:flex; flex-wrap:wrap; gap:1rem 2.2rem; align-items:center; justify-content:center; text-align:center; font-size:.92rem; }
.strip b { color:#fff; }

/* ---------- Generic grid of cards ---------- */
.grid { display:grid; gap: clamp(16px,2.4vw,26px); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

.card { background:var(--paper); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(20px,2.4vw,30px); box-shadow: var(--shadow); transition: transform .2s ease, box-shadow .25s ease; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card .ico { width:52px; height:52px; border-radius:14px; display:grid; place-content:center; margin-bottom:1rem; background: var(--accent-grad); color:#fff; }
.card .ico svg { width:26px; height:26px; }
.card h3 { margin-bottom:.4rem; }
.card p { color:var(--slate-soft); margin:0; font-size:.98rem; }

/* capability split */
.cap-head { display:flex; flex-wrap:wrap; gap:.6rem; align-items:center; margin-bottom:1.4rem; }
.pill { font-family:var(--display); font-weight:700; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; padding:.4em .85em; border-radius:999px; }
.pill--cust { background: rgba(6,182,212,.14); color:#0e7490; }
.pill--owner { background: rgba(109,40,217,.14); color:#6d28d9; }
.section--ink .pill--cust { background: rgba(34,211,238,.18); color:#a5f3fc; }
.section--ink .pill--owner { background: rgba(167,139,250,.2); color:#ddd6fe; }
.cap-list { list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.cap-list li { display:flex; gap:.7rem; align-items:flex-start; }
.cap-list .tick { margin-top:.15rem; }

/* ---------- How it works (steps) ---------- */
.steps { counter-reset: step; display:grid; gap: clamp(18px,2.5vw,28px); grid-template-columns: repeat(3,1fr); }
.step { position:relative; padding-top: 16px; }
.step .num { font-family:var(--display); font-weight:800; font-size:2.6rem; background: var(--accent-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.step h3 { margin:.2rem 0 .35rem; }
.step p { color:var(--slate-soft); margin:0; }

/* ---------- Comparison table ---------- */
.compare { overflow-x:auto; border-radius: var(--radius); border:1px solid var(--line); box-shadow:var(--shadow); background:#fff; }
table.cmp { width:100%; border-collapse:collapse; min-width:680px; }
table.cmp th, table.cmp td { padding:16px 18px; text-align:center; border-bottom:1px solid var(--line); }
table.cmp thead th { background:#0f172a; color:#fff; font-family:var(--display); font-size:.95rem; }
table.cmp thead th.victoria { background: var(--accent-grad); }
table.cmp tbody th { text-align:left; color:#0f172a; font-weight:600; background:var(--mist); }
table.cmp td .yes { color:#10b981; font-weight:900; }
table.cmp td .no { color:#cbd5e1; font-weight:900; }
table.cmp td.victoria { background: rgba(34,211,238,.07); font-weight:700; color:#0f172a; }

/* ---------- Use cases ---------- */
.usecases { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(14px,2vw,22px); }
.uc { border-radius: var(--radius); padding: clamp(18px,2.2vw,26px); color:#fff; min-height:180px; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden; box-shadow:var(--shadow); }
.uc::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(2,6,23,.05), rgba(2,6,23,.78)); z-index:0; }
.uc > * { position:relative; z-index:1; }
.uc h3 { color:#fff; margin-bottom:.25rem; }
.uc p { color:#e2e8f0; font-size:.92rem; margin:0; }
.uc .tag { position:absolute; top:14px; left:14px; z-index:1; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.3); backdrop-filter:blur(6px); color:#fff; padding:.3em .7em; border-radius:999px; font-size:.75rem; font-weight:700; }
.uc-plumber { background:linear-gradient(135deg,#0ea5e9,#1e3a8a); }
.uc-electric { background:linear-gradient(135deg,#f59e0b,#b45309); }
.uc-builder { background:linear-gradient(135deg,#10b981,#065f46); }
.uc-locksmith{ background:linear-gradient(135deg,#8b5cf6,#4c1d95); }
.uc-mechanic { background:linear-gradient(135deg,#ef4444,#7f1d1d); }
.uc-salon    { background:linear-gradient(135deg,#ec4899,#831843); }

/* ---------- Pricing ---------- */
.price-toggle { display:inline-flex; gap:.3rem; background:var(--mist-2); border-radius:999px; padding:.3rem; margin: 0 auto 2.4rem; }
.price-toggle button { border:0; background:none; cursor:pointer; font-family:var(--display); font-weight:700; padding:.55em 1.1em; border-radius:999px; color:var(--slate-soft); }
.price-toggle button.active { background:#fff; color:#0f172a; box-shadow:var(--shadow); }
.price-toggle .save { color:var(--coral-2); font-size:.78rem; }

.pricing { display:grid; grid-template-columns: repeat(4,1fr); gap: clamp(14px,1.6vw,20px); align-items:stretch; }
.tier { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: clamp(20px,2vw,28px); display:flex; flex-direction:column; box-shadow:var(--shadow); position:relative; }
.tier.featured { border:2px solid transparent; background:
  linear-gradient(#fff,#fff) padding-box,
  var(--accent-grad) border-box; transform: scale(1.02); box-shadow: var(--shadow-lg); }
.tier .flag { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background: var(--accent-grad); color:#fff; font-family:var(--display); font-weight:700; font-size:.72rem; letter-spacing:.06em; padding:.4em 1em; border-radius:999px; text-transform:uppercase; white-space:nowrap; }
.tier h3 { margin-bottom:.1rem; }
.tier .who { color:var(--slate-soft); font-size:.88rem; min-height:2.4em; margin-bottom:.6rem; }
.tier .price { font-family:var(--display); font-weight:800; color:#0f172a; font-size:2.3rem; line-height:1; }
.tier .price small { font-size:.85rem; color:var(--slate-soft); font-weight:600; }
.tier .price .mo { font-size:1rem; }
.tier ul { list-style:none; margin:1.2rem 0 1.6rem; padding:0; display:grid; gap:.6rem; font-size:.94rem; }
.tier ul li { display:flex; gap:.55rem; align-items:flex-start; }
.tier ul li .tick { color:#10b981; margin-top:.15rem; }
.tier ul li.muted { color:var(--slate-soft); }
.tier .btn { margin-top:auto; }
.price-foot { color:var(--slate-soft); font-size:.9rem; margin-top:1.6rem; }

/* ---------- Try Victoria ---------- */
.try { background: var(--hero-grad); color:#fff; border-radius: clamp(20px,3vw,32px); padding: clamp(30px,5vw,60px); text-align:center; position:relative; overflow:hidden; box-shadow:var(--shadow-lg); }
.try h2 { color:#fff; }
.try .number { font-family:var(--display); font-weight:800; font-size: clamp(2rem,5vw,3.2rem); color:#fff; margin:.4rem 0 1rem; letter-spacing:.01em; }
.try .number a { color:#fff; }
.try .hint { color:#c7d2fe; max-width:46ch; margin:0 auto 1.6rem; }
.try .chips { display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-top:1.4rem; }
.try .chip { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22); border-radius:999px; padding:.5em 1em; font-size:.86rem; color:#e0e7ff; }

/* ---------- FAQ ---------- */
.faq { max-width: 820px; margin:0 auto; display:grid; gap:.8rem; }
.faq details { background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm); padding: .2rem 1.2rem; box-shadow:var(--shadow); }
.faq summary { cursor:pointer; list-style:none; font-family:var(--display); font-weight:700; color:#0f172a; padding:1rem 0; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; font-size:1.5rem; color:var(--indigo-2); transition:transform .2s; }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq details p { color:var(--slate-soft); padding-bottom:1rem; margin:0; }

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,4vw,48px); align-items:start; }
.form { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: clamp(22px,3vw,34px); box-shadow:var(--shadow); }
.field { margin-bottom:1rem; }
.field label { display:block; font-weight:600; color:#0f172a; font-size:.9rem; margin-bottom:.35rem; }
.field input, .field select, .field textarea { width:100%; padding:.8em .9em; border:1px solid var(--line); border-radius:12px; font:inherit; color:#0f172a; background:#fff; transition:border .2s, box-shadow .2s; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--indigo-2); box-shadow:0 0 0 3px rgba(79,70,229,.15); }
.field textarea { min-height:120px; resize:vertical; }
.form .row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form .small { font-size:.82rem; color:var(--slate-soft); margin-top:.4rem; }
.form-success { display:none; background:#ecfdf5; border:1px solid #a7f3d0; color:#065f46; padding:1rem; border-radius:12px; margin-bottom:1rem; }
.contact-aside .card { margin-bottom:1rem; }
.contact-aside .big-call { font-family:var(--display); font-weight:800; font-size:1.4rem; color:#0f172a; }

/* ---------- Footer ---------- */
.site-footer { background:#070b18; color:#94a3b8; padding: clamp(40px,6vw,70px) 0 30px; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: clamp(20px,3vw,40px); }
.site-footer h4 { color:#fff; font-size:.95rem; letter-spacing:.04em; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a { color:#94a3b8; display:block; padding:.25rem 0; }
.site-footer a:hover { color:#fff; }
.foot-bottom { border-top:1px solid rgba(255,255,255,.08); margin-top:2.4rem; padding-top:1.4rem; display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; justify-content:space-between; font-size:.85rem; }

/* ---------- Voice sample player ---------- */
.voice-sample { margin-top:1.8rem; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:16px; padding:.9rem 1rem; max-width:420px; backdrop-filter:blur(6px); }
.voice-sample .vs-label { display:flex; align-items:center; gap:.5rem; color:#c7d2fe; font-size:.85rem; font-weight:600; margin-bottom:.55rem; }
.voice-sample .vs-label .wave { color:var(--cyan-2); }
.voice-sample audio { width:100%; height:38px; }

/* ---------- Testimonials ---------- */
.quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,22px); margin-top:2.4rem; }
.quote { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:clamp(20px,2.4vw,28px); box-shadow:var(--shadow); display:flex; flex-direction:column; gap:.9rem; }
.quote .stars { color:#f59e0b; letter-spacing:2px; }
.quote p { color:#0f172a; font-size:1.02rem; margin:0; }
.quote .who { display:flex; align-items:center; gap:.7rem; margin-top:auto; }
.quote .avatar { width:42px; height:42px; border-radius:50%; background:var(--accent-grad); color:#fff; display:grid; place-content:center; font-family:var(--display); font-weight:800; font-size:1rem; }
.quote .who b { display:block; color:#0f172a; font-size:.95rem; }
.quote .who span { color:var(--slate-soft); font-size:.85rem; }

/* ---------- Legal / simple content pages ---------- */
.legal { max-width:820px; }
.legal h1 { font-size:clamp(1.8rem,4vw,2.6rem); margin-bottom:.3em; }
.legal h2 { font-size:1.3rem; margin-top:2rem; }
.legal p, .legal li { color:var(--slate); }
.legal .muted { color:var(--slate-soft); font-size:.9rem; }
.legal a { text-decoration:underline; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity:1; transform:none; transition:none; } }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .grid--3, .grid--4, .steps, .usecases, .pricing { grid-template-columns: repeat(2,1fr); }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { max-width: 460px; margin: 8px auto 0; }
  .contact-grid { grid-template-columns:1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .nav-links, .nav-cta .nav-tel-text { display:none; }
  .nav-toggle { display:block; }
  .site-header.open .nav-links { display:flex; position:absolute; top:68px; left:0; right:0; flex-direction:column; gap:0; background:#0b1020; border-bottom:1px solid rgba(255,255,255,.1); padding:10px 0; }
  .site-header.open .nav-links li { width:100%; }
  .site-header.open .nav-links a { display:block; padding:14px 24px; }
  .grid--3, .grid--4, .steps, .usecases, .pricing, .grid--2, .cmp-wrap { grid-template-columns: 1fr; }
  .tier.featured { transform:none; }
  .form .row { grid-template-columns:1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .hero-badge--tl{ left:6px; } .hero-badge--br{ right:6px; }
}
@media (max-width: 460px) { .foot-grid { grid-template-columns: 1fr; } }

/* A touch more breathing room down the sides of the hero on phones, so the
   headline / trust ticks / voice player never touch the screen edges. */
@media (max-width: 600px) {
  .hero .container { padding-left: 28px; padding-right: 28px; }
}
