/* ============================================================
   DataVendor public site styles — no build step (Bluehost-friendly)
   Brand colors (--brand, --accent) are injected from admin Settings
   via an inline <style> in the layout <head>, overriding these defaults.
   ============================================================ */
:root{
  --brand:#1c64f2; --brand-d:#1a4fd0; --accent:#06b6d4;
  --ink:#0f172a; --muted:#64748b; --faint:#94a3b8;
  --line:#e7ebf0; --line2:#dde4ec; --page:#f6f8fb; --surface:#fff; --soft:#f1f5f9;
  --green:#16a34a; --green-bg:#e9f7ef; --amber:#b45309; --amber-bg:#fdf2e0; --red:#dc2626; --red-bg:#fdeaea;
  --radius:14px; --wa:#25D366;
  --hero-img:linear-gradient(135deg,#0b1220,#13284d 55%,#0b1220);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--page);color:var(--ink);
  font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.ic{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;vertical-align:-4px}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:10px;padding:11px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:hover{background:var(--brand-d)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line2)}
.btn.ghost:hover{background:var(--soft)}
.btn.wa{background:var(--wa);color:#fff}
.btn.lg{padding:14px 24px;font-size:15px}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px;background:var(--soft);color:var(--muted)}
.pill.brandish{background:color-mix(in srgb,var(--brand) 12%,#fff);color:var(--brand)}

/* nav */
header.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:11px}
.logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;overflow:hidden}
.logo img{width:100%;height:100%;object-fit:cover}
.brand b{font-size:18px;font-weight:700;letter-spacing:-.02em}
.brand span{font-size:11px;color:var(--muted);display:block;margin-top:-3px;font-weight:500}
nav.links{display:flex;gap:4px;align-items:center}
nav.links a{padding:9px 13px;border-radius:9px;font-size:14px;font-weight:500;color:var(--muted)}
nav.links a:hover{background:var(--soft);color:var(--ink)}
nav.links a.active{color:var(--brand);background:color-mix(in srgb,var(--brand) 9%,#fff)}
.nav-cta{display:flex;gap:9px;align-items:center}

/* headings + sections */
section{padding:78px 0}
h1{font-size:52px;line-height:1.06;letter-spacing:-.03em;margin:0 0 16px}
h2{font-size:34px;letter-spacing:-.02em;margin:0 0 10px}
h3{font-size:18px;margin:0 0 6px}
.lead{font-size:18px;color:var(--muted);max-width:620px;margin:0 0 26px}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:700;color:var(--brand);margin-bottom:12px}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* hero */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(900px 380px at 80% -10%, color-mix(in srgb,var(--accent) 16%,transparent), transparent),
    radial-gradient(700px 360px at 0% 10%, color-mix(in srgb,var(--brand) 14%,transparent), transparent);
  padding:100px 0 80px}
.hero-bg{position:absolute;inset:0;z-index:0;background-image:var(--hero-img);background-size:cover;background-position:center;opacity:.12}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.trust{display:flex;gap:26px;margin-top:30px;flex-wrap:wrap}
.trust div{font-size:13px;color:var(--muted)}
.trust b{display:block;font-size:24px;color:var(--ink);font-weight:800;letter-spacing:-.02em}

/* dark dialer shot */
.shot{background:#0b1220;border-radius:16px;padding:14px;box-shadow:0 30px 60px -20px rgba(15,23,42,.4);border:1px solid #1e293b}
.shot .bar{display:flex;gap:6px;padding:4px 4px 10px}
.shot .bar i{width:11px;height:11px;border-radius:50%;background:#334155}
.shot .bar i:nth-child(1){background:#ef4444}.shot .bar i:nth-child(2){background:#f59e0b}.shot .bar i:nth-child(3){background:#22c55e}
.shot-body{background:#0f172a;border-radius:10px;padding:16px;color:#cbd5e1;font-size:12px}
.dline{display:flex;align-items:center;justify-content:space-between;padding:9px 11px;border-radius:8px;background:#1e293b;margin-bottom:8px}
.dline.lit{background:color-mix(in srgb,var(--brand) 30%,#1e293b);color:#fff}
.dnum{font-family:ui-monospace,Menlo,monospace;letter-spacing:.04em}
.badge{font-size:10px;padding:3px 8px;border-radius:6px;background:#334155;color:#cbd5e1}
.badge.g{background:color-mix(in srgb,var(--green) 35%,#0f172a);color:#86efac}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:12px}
.keypad b{background:#1e293b;color:#e2e8f0;border-radius:8px;padding:11px 0;text-align:center;font-size:15px;font-weight:600}
.callbtn{margin-top:9px;background:var(--green);color:#fff;border-radius:8px;padding:11px;text-align:center;font-weight:700}

/* cards / grids */
.grid{display:grid;gap:20px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.card .ico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--brand) 12%,#fff);color:var(--brand);margin-bottom:14px}
.card p{color:var(--muted);font-size:14px;margin:0}
.card.feature{border-top:3px solid var(--brand)}
.price{font-size:34px;font-weight:800;letter-spacing:-.02em;margin:6px 0}

/* trust badges */
.trustbadge{display:flex;gap:12px;align-items:center;padding:8px}
.trustbadge svg{width:30px;height:30px;color:var(--brand);flex:none}
.trustbadge b{display:block;font-size:14px}
.trustbadge span{font-size:12px;color:var(--muted)}

/* logo strip + testimonials */
.logos{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:22px;opacity:.8}
.logos .lg{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:12px 22px;font-weight:800;color:var(--faint);letter-spacing:-.02em;font-size:17px}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.quote p{font-size:15px;color:var(--ink);margin:0 0 16px}
.quote .who{display:flex;align-items:center;gap:11px}
.quote .ava{width:40px;height:40px;border-radius:50%;background:color-mix(in srgb,var(--brand) 14%,#fff);color:var(--brand);font-weight:800;display:flex;align-items:center;justify-content:center}
.quote .who b{font-size:14px;display:block}
.quote .who span{font-size:12px;color:var(--muted)}
.stars{color:#f59e0b;font-size:14px;margin-bottom:10px;letter-spacing:2px}

/* ViciDial mock screens */
.vici-cap{font-size:11px;color:#64748b;background:#0f172a;border:1px solid #1e293b;border-bottom:0;border-radius:10px 10px 0 0;padding:7px 12px}
.vici-cap b{color:#cbd5e1}
.vici-shot{background:#0f172a;border:1px solid #1e293b;border-radius:0 0 12px 12px;padding:14px;color:#cbd5e1;font-size:12px}
.vbar{display:flex;justify-content:space-between;font-size:11px;color:#94a3b8;margin-bottom:12px;flex-wrap:wrap;gap:6px}
.vrow{display:flex;align-items:center;justify-content:space-between;padding:11px 13px;border-radius:8px;background:#1e293b;margin-bottom:12px}
.vrow.lit{background:color-mix(in srgb,var(--brand) 32%,#1e293b);color:#fff}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.vbtn{background:#1e293b;border-radius:7px;padding:11px 6px;text-align:center;font-size:11px;font-weight:600;color:#e2e8f0}
.vctl{display:flex;gap:7px;margin-top:9px}
.vc{flex:1;background:#1e293b;border-radius:7px;padding:10px;text-align:center;font-size:11px;font-weight:600}
.vc.red{background:color-mix(in srgb,#ef4444 40%,#1e293b);color:#fecaca}
.vc.green{background:color-mix(in srgb,var(--green) 45%,#1e293b);color:#bbf7d0}
.vstat{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.vstat div{background:#1e293b;border-radius:8px;padding:11px;text-align:center}
.vstat b{display:block;font-size:20px;color:#fff;font-weight:800}
.vstat span{font-size:10px;color:#94a3b8}
.vbarchart{display:flex;gap:7px;align-items:flex-end;height:90px;padding:0 4px}
.vbarchart i{flex:1;background:linear-gradient(180deg,var(--accent),var(--brand));border-radius:4px 4px 0 0}

/* table */
.tbl{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.tbl th,.tbl td{padding:13px 16px;text-align:left;font-size:14px;border-bottom:1px solid var(--line)}
.tbl th{background:var(--soft);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.tbl tr:last-child td{border-bottom:0}
.mono{font-family:ui-monospace,Menlo,monospace}

/* forms */
.formcard{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px}
label{display:block;font-size:13px;font-weight:600;margin:14px 0 6px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line2);border-radius:10px;font-size:14px;font-family:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* compliance banner */
.compliance{background:var(--green-bg);border:1px solid color-mix(in srgb,var(--green) 30%,#fff);border-radius:14px;padding:18px 22px;display:flex;gap:14px;align-items:center}
.compliance svg{color:var(--green);flex:none}

/* doc pages */
.doc{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:40px;max-width:820px;margin:0 auto}
.doc h2{margin-top:28px}.doc h2:first-child{margin-top:0}
.doc p,.doc li{color:#334155;font-size:15px}

/* alerts */
.alert{border-radius:12px;padding:14px 18px;font-size:14px;font-weight:500;margin-bottom:18px}
.alert.success{background:var(--green-bg);color:var(--green);border:1px solid color-mix(in srgb,var(--green) 30%,#fff)}
.alert.error{background:var(--red-bg);color:var(--red);border:1px solid color-mix(in srgb,var(--red) 30%,#fff)}
.field-error{color:var(--red);font-size:12px;margin-top:4px}

/* footer */
footer{background:#0b1220;color:#94a3b8;padding:54px 0 30px;margin-top:30px}
footer .grid{grid-template-columns:1.6fr 1fr 1fr 1fr}
footer a{display:block;color:#94a3b8;font-size:14px;padding:5px 0}
footer a:hover{color:#fff}
footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
.foot-bot{border-top:1px solid #1e293b;margin-top:34px;padding-top:22px;display:flex;justify-content:space-between;font-size:13px;flex-wrap:wrap;gap:10px}

/* WhatsApp float */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:50;display:flex;align-items:center;gap:10px;background:var(--wa);color:#fff;padding:13px 18px;border-radius:999px;font-weight:700;font-size:14px;box-shadow:0 12px 30px -8px rgba(37,211,102,.6)}
.wa-float svg{width:22px;height:22px}

@media(max-width:880px){
  .hero-grid,.g3,.g4,footer .grid,.row2{grid-template-columns:1fr}
  nav.links{display:none}
  h1{font-size:34px}
}
