/* =========================================================
   TraceCallerID — Design System
   ========================================================= */

:root{
  --blue-50:#EFF6FF;
  --blue-100:#DBEAFE;
  --blue-200:#BFDBFE;
  --blue-300:#93C5FD;
  --blue-400:#60A5FA;
  --blue-500:#3B82F6;
  --blue-600:#2563EB;
  --blue-700:#1D4ED8;
  --blue-800:#1E40AF;
  --blue-900:#1E3A8A;

  --brand:#0B49B4;
  --brand-dark:#033BA3;
  --brand-light:#1E88E5;
  --brand-gradient:linear-gradient(135deg,#1565C0 0%,#0B49B4 50%,#033BA3 100%);
  --brand-gradient-soft:linear-gradient(135deg,#E3F0FF 0%,#F5F9FF 100%);

  --ink-900:#0B1733;
  --ink-800:#0F172A;
  --ink-700:#1E293B;
  --ink-600:#334155;
  --ink-500:#475569;
  --ink-400:#64748B;
  --ink-300:#94A3B8;
  --ink-200:#CBD5E1;
  --ink-100:#E2E8F0;
  --ink-50:#F1F5F9;

  --white:#FFFFFF;
  --off:#F8FAFC;

  --success:#10B981;
  --success-soft:#D1FAE5;
  --danger:#EF4444;
  --warn:#F59E0B;

  --r-sm:8px;
  --r-md:14px;
  --r-lg:20px;
  --r-xl:28px;
  --r-2xl:40px;
  --r-pill:999px;

  --shadow-xs:0 1px 2px rgba(15,23,42,.06);
  --shadow-sm:0 4px 14px rgba(15,23,42,.06);
  --shadow-md:0 12px 30px rgba(15,23,42,.08);
  --shadow-lg:0 24px 60px rgba(15,23,42,.12);
  --shadow-blue:0 20px 55px -10px rgba(11,73,180,.45);
  --shadow-glow:0 0 0 8px rgba(11,73,180,.10), 0 30px 80px -20px rgba(11,73,180,.45);

  --container:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* === Editorial layer === */
  --display-italic:'Instrument Serif',Georgia,'Times New Roman',serif;
  --accent:#10D87F;
  --accent-soft:#D6F8E7;
  --accent-dark:#0A9B5A;
  --grain:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:'Montserrat',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  color:var(--ink-700);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
img{max-width:100%;display:block;}
a{color:var(--brand);text-decoration:none;transition:color .2s var(--ease);}
a:hover{color:var(--brand-dark);}
h1,h2,h3,h4,h5{
  font-family:'Montserrat',system-ui,sans-serif;
  color:var(--ink-900);
  letter-spacing:-0.025em;
  line-height:1.12;
  margin:0 0 .5em;
  font-weight:800;
}
h1{font-size:clamp(2.3rem,5.2vw,3.9rem);letter-spacing:-.035em;font-weight:900;}
h2{font-size:clamp(1.8rem,3.6vw,2.85rem);font-weight:800;}
h3{font-size:clamp(1.25rem,2.2vw,1.6rem);}
p{margin:0 0 1em;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
section{padding:90px 0;position:relative;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}

/* ============ Utility ============ */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.8rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--brand);
  background:var(--blue-50);
  padding:7px 14px;border-radius:var(--r-pill);
  border:1px solid var(--blue-100);
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px rgba(11,73,180,.2);}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px;}
.section-head h2{margin-top:16px;margin-bottom:14px;}
.section-head p{color:var(--ink-500);font-size:1.08rem;}
.muted{color:var(--ink-500);}
.gradient-text{background:var(--brand-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:600;font-size:.98rem;letter-spacing:-.01em;
  padding:14px 26px;border-radius:var(--r-pill);
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--brand-gradient);color:#fff;
  box-shadow:var(--shadow-blue);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 25px 60px -10px rgba(11,73,180,.6);color:#fff;}
.btn-ghost{background:#fff;color:var(--ink-800);border:1px solid var(--ink-100);}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-2px);}
.btn-light{background:#fff;color:var(--brand);}
.btn-light:hover{color:var(--brand-dark);transform:translateY(-2px);}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5);}
.btn-outline-light:hover{background:#fff;color:var(--brand);transform:translateY(-2px);}

.btn-lg{padding:16px 32px;font-size:1.02rem;}
.btn-icon{width:20px;height:20px;}

/* App store style */
.store-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:#0B1733;color:#fff;
  padding:12px 22px;border-radius:var(--r-md);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  text-align:left;line-height:1.1;
}
.store-btn small{display:block;font-size:.68rem;letter-spacing:.06em;opacity:.75;text-transform:uppercase;}
.store-btn strong{font-size:1rem;font-weight:600;}
.store-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);color:#fff;}
.store-btn svg{width:26px;height:26px;flex-shrink:0;}

/* ============ Top utility bar ============ */
.top-bar{
  background:var(--brand-dark);
  color:#fff;
  font-size:13px;
  padding:9px 0;
}
.top-bar .container{
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
}
.top-bar-left{display:flex;gap:24px;flex-wrap:wrap;}
.top-bar-left span{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.92);}
.top-bar-left a{color:#fff;font-weight:500;}
.top-bar-left a:hover{color:var(--brand-light);}
.top-bar-right{display:flex;align-items:center;gap:10px;font-weight:500;color:rgba(255,255,255,.92);}
.top-bar-dot{opacity:.5;font-size:18px;line-height:1;}
.top-bar svg{width:13px;height:13px;flex-shrink:0;opacity:.9;}

/* ============ Main header ============ */
.site-header{
  background:#fff;
  box-shadow:0 2px 10px rgba(15,23,42,.06);
  position:sticky;top:0;z-index:100;
  transition:box-shadow .25s var(--ease);
}
.site-header.scrolled{box-shadow:0 4px 24px rgba(15,23,42,.08);}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:14px 24px;
}

.brand{display:flex;align-items:center;gap:12px;flex-shrink:0;color:var(--ink-900);}
.brand:hover{color:var(--ink-900);}
.brand-logo{
  height:44px;width:auto;display:block;
  -webkit-user-select:none;user-select:none;
}
@media (max-width:1000px){.brand-logo{height:40px;}}
@media (max-width:720px){.brand-logo{height:36px;}}
.brand-mark{
  width:50px;height:50px;border-radius:14px;
  background:var(--brand-gradient);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-blue);flex-shrink:0;
}
.brand-mark svg{width:26px;height:26px;color:#fff;}
.brand-name{display:flex;flex-direction:column;line-height:1.15;}
.brand-name .bn-title{
  font-family:'Montserrat',sans-serif;
  font-size:1.4rem;font-weight:800;letter-spacing:-.02em;
  color:var(--ink-900);white-space:nowrap;
}
.brand-name .bn-title span{color:var(--brand);}
.brand-name .bn-tag{
  font-size:.72rem;color:var(--ink-500);font-weight:500;
  margin-top:2px;letter-spacing:.01em;white-space:nowrap;
}

nav.primary-nav{display:flex;align-items:center;justify-content:center;flex:1;}
.nav-menu{
  display:flex;align-items:center;gap:0;list-style:none;margin:0;padding:0;
}
.nav-menu li{position:relative;}
.nav-menu > li > a{
  display:block;padding:22px 16px;
  color:var(--ink-700);font-weight:500;font-size:.95rem;
  transition:color .2s var(--ease);white-space:nowrap;position:relative;
}
.nav-menu > li > a:hover{color:var(--brand);}
.nav-menu > li.active > a{color:var(--brand);}
.nav-menu > li.active > a::after{
  content:"";position:absolute;bottom:0;left:16px;right:16px;
  height:3px;background:var(--brand);border-radius:3px 3px 0 0;
}

.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0;}
.header-right .btn{padding:12px 22px;font-size:.92rem;}

.nav-toggle{
  display:none;width:44px;height:44px;border-radius:10px;
  align-items:center;justify-content:center;
  background:#fff;border:1px solid var(--ink-100);color:var(--ink-700);
}
.nav-toggle:hover{border-color:var(--brand);color:var(--brand);}
.nav-toggle svg{width:22px;height:22px;}

/* ============ Hero ============ */
.hero{
  padding:90px 0 80px;
  background:
    radial-gradient(1200px 600px at 85% -10%,rgba(66,165,245,.18),transparent 60%),
    radial-gradient(900px 500px at -5% 20%,rgba(11,73,180,.10),transparent 60%),
    linear-gradient(180deg,#F5FAFF 0%,#FFFFFF 85%);
  overflow:hidden;position:relative;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
}
.hero h1 span.accent{color:var(--brand);position:relative;white-space:nowrap;}
.hero h1 span.accent::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;height:.14em;
  background:linear-gradient(90deg,rgba(11,73,180,.25),rgba(11,73,180,.55));border-radius:6px;
}
.hero-lede{font-size:1.15rem;color:var(--ink-500);max-width:540px;margin-bottom:32px;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:36px;}
.hero-trust{display:flex;align-items:center;gap:22px;flex-wrap:wrap;color:var(--ink-500);font-size:.92rem;}
.hero-trust .stars{display:inline-flex;gap:3px;color:#F59E0B;}
.hero-trust .stars svg{width:18px;height:18px;}
.hero-trust .divider{width:1px;height:18px;background:var(--ink-100);}

/* Hero visual — layered phone */
.hero-visual{position:relative;display:flex;justify-content:center;}
.hero-blob{
  position:absolute;inset:-40px -20px;z-index:0;
  background:var(--brand-gradient);
  border-radius:48% 52% 52% 48% / 48% 48% 52% 52%;
  filter:blur(0);opacity:.10;
  animation:blobFloat 14s ease-in-out infinite;
}
@keyframes blobFloat{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg);border-radius:48% 52% 52% 48%/48% 48% 52% 52%;}
  50%{transform:translate3d(-10px,-14px,0) rotate(6deg);border-radius:54% 46% 44% 56%/52% 44% 56% 48%;}
}
.hero-phone-wrap{position:relative;z-index:2;animation:float 6s ease-in-out infinite;}
@keyframes float{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-12px);}
}

/* Phone mockup */
.phone{
  width:290px;
  background:#0B1733;
  border-radius:42px;
  padding:12px;
  box-shadow:var(--shadow-glow);
  position:relative;
}
.phone::before{
  content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:110px;height:22px;background:#0B1733;border-radius:999px;z-index:2;
}
.phone-screen{
  border-radius:32px;overflow:hidden;background:#F5F8FF;
  aspect-ratio:9/19.5;position:relative;
}
.phone-screen img{width:100%;height:100%;object-fit:cover;display:block;}

.phone-lg{width:320px;}
.phone-sm{width:240px;}

/* Floating badges around hero phone */
.float-card{
  position:absolute;background:#fff;border-radius:16px;padding:14px 16px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;
  font-size:.88rem;font-weight:600;color:var(--ink-800);
  z-index:3;animation:float 7s ease-in-out infinite;
}
.float-card .fc-icon{
  width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.float-card .fc-icon svg{width:20px;height:20px;}
.fc-success{background:var(--success-soft);color:var(--success);}
.fc-brand{background:var(--blue-50);color:var(--brand);}
.fc-warn{background:#FEF3C7;color:var(--warn);}

.fc-1{top:14%;left:-26px;animation-delay:-2s;}
.fc-2{bottom:18%;right:-40px;animation-delay:-4s;}
.fc-3{top:62%;left:-52px;animation-delay:-6s;}

/* ============ Logos / trust strip ============ */
.trust-strip{
  padding:44px 0;border-top:1px solid var(--ink-100);border-bottom:1px solid var(--ink-100);
  background:#FCFDFF;
}
.trust-strip-inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap;justify-content:center;}
.trust-strip .label{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-400);font-weight:600;}
.trust-logos{display:flex;gap:40px;flex-wrap:wrap;justify-content:center;align-items:center;opacity:.7;}
.trust-logos span{font-weight:700;color:var(--ink-400);letter-spacing:-.01em;font-size:1.1rem;}

/* ============ Stats ============ */
.stats{
  padding:60px 0;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  background:var(--brand-gradient);
  border-radius:var(--r-xl);
  padding:44px 32px;color:#fff;
  box-shadow:var(--shadow-blue);
  position:relative;overflow:hidden;
}
.stats-grid::before{
  content:"";position:absolute;inset:-50%;
  background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.2),transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.12),transparent 50%);
  pointer-events:none;
}
.stat{text-align:center;position:relative;}
.stat .num{font-size:clamp(2rem,4vw,2.6rem);font-weight:800;font-family:'Montserrat',sans-serif;letter-spacing:-.03em;line-height:1;}
.stat .label{font-size:.92rem;opacity:.88;margin-top:8px;}

/* ============ TraceCallerID deep-dive ============ */
.showcase{background:var(--off);}
.showcase-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.showcase-visual{
  position:relative;display:flex;justify-content:center;align-items:center;
  padding:30px 0;min-height:600px;
}
.showcase-visual .phone{position:absolute;transition:transform .5s var(--ease);}
.showcase-visual .phone.p1{transform:translate(-110px,0) rotate(-6deg) scale(.9);z-index:1;}
.showcase-visual .phone.p2{z-index:3;box-shadow:var(--shadow-glow);}
.showcase-visual .phone.p3{transform:translate(110px,0) rotate(6deg) scale(.9);z-index:1;}
.showcase-visual:hover .phone.p1{transform:translate(-140px,-6px) rotate(-8deg) scale(.9);}
.showcase-visual:hover .phone.p3{transform:translate(140px,-6px) rotate(8deg) scale(.9);}

.feature-list{margin-top:32px;display:grid;gap:18px;}
.feature-list li{
  display:flex;gap:14px;align-items:flex-start;
  padding:18px;border-radius:var(--r-md);
  background:#fff;border:1px solid var(--ink-100);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.feature-list li:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.feature-list .fi{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--blue-50);color:var(--brand);
  display:flex;align-items:center;justify-content:center;
}
.feature-list .fi svg{width:22px;height:22px;}
.feature-list h4{margin:0 0 4px;font-size:1.05rem;color:var(--ink-900);}
.feature-list p{margin:0;color:var(--ink-500);font-size:.94rem;line-height:1.55;}

/* ============ Utilities Grid (12-in-1) ============ */
.utilities{position:relative;}
.utilities::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--ink-100);opacity:.6;
}
.util-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.util-card{
  position:relative;
  background:#fff;border:1px solid var(--ink-100);
  border-radius:var(--r-lg);padding:28px 24px;
  transition:all .3s var(--ease);overflow:hidden;
}
.util-card::after{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .3s var(--ease);
  background:linear-gradient(135deg,rgba(66,165,245,.06),rgba(11,73,180,.03));
  pointer-events:none;
}
.util-card:hover{transform:translateY(-6px);border-color:var(--blue-200);box-shadow:var(--shadow-md);}
.util-card:hover::after{opacity:1;}
.util-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;position:relative;z-index:1;
}
.util-icon svg{width:26px;height:26px;}
.util-card h3{font-size:1.1rem;margin:0 0 8px;position:relative;z-index:1;}
.util-card p{margin:0;color:var(--ink-500);font-size:.92rem;line-height:1.6;position:relative;z-index:1;}

/* icon color variants */
.i-blue{background:#E3F0FF;color:#0B49B4;}
.i-green{background:#D1FAE5;color:#10B981;}
.i-purple{background:#EDE9FE;color:#7C3AED;}
.i-pink{background:#FCE7F3;color:#EC4899;}
.i-orange{background:#FFEDD5;color:#F97316;}
.i-yellow{background:#FEF3C7;color:#D97706;}
.i-cyan{background:#CFFAFE;color:#06B6D4;}
.i-red{background:#FEE2E2;color:#EF4444;}
.i-indigo{background:#E0E7FF;color:#4F46E5;}
.i-teal{background:#CCFBF1;color:#14B8A6;}
.i-rose{background:#FFE4E6;color:#F43F5E;}
.i-lime{background:#ECFCCB;color:#65A30D;}

/* ============ How it works ============ */
.how{background:linear-gradient(180deg,#fff 0%, #F5FAFF 100%);}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;
}
.steps::before{
  content:"";position:absolute;top:48px;left:15%;right:15%;height:2px;
  background:repeating-linear-gradient(90deg,var(--blue-200),var(--blue-200) 6px,transparent 6px,transparent 12px);
  z-index:0;
}
.step{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:34px 28px;text-align:center;position:relative;z-index:1;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--brand-gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.2rem;
  margin:0 auto 18px;box-shadow:var(--shadow-blue);
  font-family:'Montserrat',sans-serif;
}
.step h3{margin-bottom:8px;}
.step p{color:var(--ink-500);margin:0;}

/* ============ Why Us ============ */
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.why-card{
  padding:32px 28px;border-radius:var(--r-lg);
  background:#fff;border:1px solid var(--ink-100);
  transition:all .3s var(--ease);
}
.why-card:hover{transform:translateY(-6px);border-color:var(--blue-200);box-shadow:var(--shadow-md);}
.why-card .wi{
  width:52px;height:52px;border-radius:14px;
  background:var(--brand-gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;box-shadow:var(--shadow-blue);
}
.why-card .wi svg{width:26px;height:26px;}
.why-card h3{font-size:1.1rem;margin:0 0 8px;}
.why-card p{color:var(--ink-500);margin:0;font-size:.94rem;line-height:1.6;}

/* ============ Testimonials ============ */
.testimonials{background:var(--off);}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.test-card{
  background:#fff;border-radius:var(--r-lg);padding:30px;
  border:1px solid var(--ink-100);
  position:relative;transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.test-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.test-stars{display:flex;gap:3px;color:#F59E0B;margin-bottom:16px;}
.test-stars svg{width:18px;height:18px;}
.test-card blockquote{margin:0 0 22px;color:var(--ink-700);font-size:1rem;line-height:1.7;}
.test-author{display:flex;align-items:center;gap:12px;}
.avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--brand-gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1rem;
}
.test-author strong{display:block;color:var(--ink-900);font-size:.96rem;}
.test-author span{color:var(--ink-400);font-size:.84rem;}

/* ============ FAQ ============ */
.faq-wrap{max-width:820px;margin:0 auto;}
.faq-item{
  border:1px solid var(--ink-100);border-radius:var(--r-md);
  margin-bottom:12px;overflow:hidden;background:#fff;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.faq-item[open],.faq-item:hover{border-color:var(--blue-200);box-shadow:var(--shadow-xs);}
.faq-q{
  list-style:none;cursor:pointer;padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-weight:600;color:var(--ink-800);font-size:1rem;
}
.faq-q::-webkit-details-marker{display:none;}
.faq-q .chev{
  width:32px;height:32px;border-radius:10px;background:var(--blue-50);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s var(--ease);
}
.faq-q .chev svg{width:16px;height:16px;}
.faq-item[open] .faq-q .chev{transform:rotate(180deg);}
.faq-a{padding:0 24px 22px;color:var(--ink-500);line-height:1.7;}

/* ============ CTA ============ */
.cta{
  background:var(--brand-gradient);color:#fff;
  border-radius:var(--r-2xl);padding:70px 60px;
  position:relative;overflow:hidden;text-align:center;
  box-shadow:var(--shadow-blue);
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 15% 20%,rgba(255,255,255,.2),transparent 35%),
             radial-gradient(circle at 85% 75%,rgba(255,255,255,.12),transparent 40%);
  pointer-events:none;
}
.cta h2{color:#fff;max-width:720px;margin:0 auto 16px;position:relative;}
.cta p{color:rgba(255,255,255,.9);max-width:600px;margin:0 auto 32px;font-size:1.08rem;position:relative;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}
.cta-qr{
  position:relative;
  display:inline-flex;align-items:center;gap:14px;
  margin:28px auto 0;padding:10px 20px 10px 10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  text-align:left;
}
.cta-qr .qr-img{
  width:84px;height:84px;display:block;flex-shrink:0;
  background:#fff;border-radius:8px;padding:6px;box-sizing:content-box;
}
.cta-qr .qr-caption strong{
  display:block;color:#fff;font-weight:700;font-size:.98rem;letter-spacing:.01em;
}
.cta-qr .qr-caption span{
  display:block;margin-top:3px;color:rgba(255,255,255,.72);font-size:.84rem;
}

/* ============ Footer ============ */
.site-footer{
  background:var(--ink-900);color:var(--ink-300);padding:70px 0 30px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:50px;
}
.site-footer .brand{color:#fff;margin-bottom:18px;}
.site-footer .brand:hover{color:#fff;}
.footer-about p{color:var(--ink-300);max-width:340px;font-size:.94rem;line-height:1.65;}
.social{display:flex;gap:10px;margin-top:20px;}
.social a{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.06);color:var(--ink-200);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s var(--ease);
}
.social a:hover{background:var(--brand);color:#fff;transform:translateY(-2px);}
.social svg{width:18px;height:18px;}
.footer-col h5{
  color:#fff;font-size:.88rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;margin:0 0 18px;
}
.footer-col ul{display:grid;gap:10px;}
.footer-col a{color:var(--ink-300);font-size:.94rem;}
.footer-col a:hover{color:#fff;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-size:.88rem;color:var(--ink-400);
}
.footer-bottom a{color:var(--ink-400);}
.footer-bottom a:hover{color:#fff;}

/* ============ Subpage hero ============ */
.page-hero{
  padding:70px 0 60px;
  background:
    radial-gradient(900px 500px at 100% -20%,rgba(66,165,245,.16),transparent 60%),
    linear-gradient(180deg,#F5FAFF 0%,#fff 100%);
  text-align:center;
}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);}
.page-hero p{color:var(--ink-500);max-width:640px;margin:14px auto 0;font-size:1.06rem;}
.page-hero .eyebrow{margin-bottom:18px;}

/* ============ Features page — detailed blocks ============ */
.feat-block{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
  margin-bottom:28px;padding:40px 0;
}
.feat-block:nth-child(even) .feat-visual{order:2;}
.feat-visual{
  background:var(--brand-gradient-soft);
  border-radius:var(--r-xl);padding:48px;
  display:flex;align-items:center;justify-content:center;
  min-height:320px;position:relative;overflow:hidden;
  border:1px solid var(--blue-100);
}
.feat-visual .big-icon{
  width:140px;height:140px;border-radius:40px;
  background:#fff;color:var(--brand);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);
}
.feat-visual .big-icon svg{width:72px;height:72px;}
.feat-block h2{font-size:1.9rem;}
.feat-block ul.check{display:grid;gap:12px;margin-top:20px;}
.feat-block ul.check li{
  display:flex;gap:10px;align-items:flex-start;color:var(--ink-600);
}
.feat-block ul.check li::before{
  content:"";width:22px;height:22px;border-radius:50%;flex-shrink:0;margin-top:2px;
  background:var(--success-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310B981' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/14px no-repeat;
}

/* ============ About page ============ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.about-grid img,.about-visual{border-radius:var(--r-xl);}
.about-visual{
  background:var(--brand-gradient-soft);border:1px solid var(--blue-100);
  padding:50px;min-height:380px;display:flex;align-items:center;justify-content:center;
}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.value-card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:32px 28px;transition:all .3s var(--ease);
}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-200);}
.value-card .vi{
  width:48px;height:48px;border-radius:12px;background:var(--blue-50);color:var(--brand);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.value-card .vi svg{width:24px;height:24px;}
.value-card h3{font-size:1.1rem;margin:0 0 8px;}
.value-card p{margin:0;color:var(--ink-500);font-size:.94rem;line-height:1.6;}

/* ============ Contact ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:start;}
.contact-info{display:grid;gap:16px;}
.info-card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:24px;display:flex;gap:16px;align-items:flex-start;
  transition:all .25s var(--ease);
}
.info-card:hover{border-color:var(--blue-200);box-shadow:var(--shadow-sm);transform:translateY(-2px);}
.info-card .ii{
  width:46px;height:46px;border-radius:12px;background:var(--blue-50);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.info-card .ii svg{width:22px;height:22px;}
.info-card h4{margin:0 0 4px;font-size:1rem;color:var(--ink-900);}
.info-card p,.info-card a{margin:0;color:var(--ink-500);font-size:.94rem;}
.info-card a:hover{color:var(--brand);}
.contact-form{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-xl);
  padding:36px;box-shadow:var(--shadow-sm);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:18px;}
.field label{display:block;font-size:.88rem;font-weight:600;color:var(--ink-700);margin-bottom:6px;}
.field input,.field textarea,.field select{
  width:100%;padding:13px 16px;border:1px solid var(--ink-100);border-radius:12px;
  font-family:inherit;font-size:.96rem;color:var(--ink-800);background:#fff;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(11,73,180,.15);
}
.field textarea{min-height:130px;resize:vertical;}

/* ============ Legal / long-form ============ */
.legal-body{max-width:820px;margin:0 auto;}
.legal-body h2{margin-top:40px;font-size:1.4rem;}
.legal-body h3{margin-top:28px;font-size:1.1rem;color:var(--ink-800);}
.legal-body p,.legal-body li{color:var(--ink-600);line-height:1.75;}
.legal-body ul{list-style:disc;padding-left:22px;margin-bottom:18px;}
.legal-body ul li{margin-bottom:6px;}
.legal-body .updated{color:var(--ink-400);font-size:.9rem;margin-bottom:30px;}

/* ============ Features page — category nav & inline code ============ */
.cat-nav{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  padding:18px;border-radius:var(--r-lg);
  background:var(--brand-gradient-soft);border:1px solid var(--blue-100);
}
.cat-nav a{
  display:inline-flex;align-items:center;
  font-size:.82rem;font-weight:600;color:var(--ink-600);
  padding:8px 14px;border-radius:var(--r-pill);
  background:#fff;border:1px solid var(--ink-100);
  transition:all .2s var(--ease);
}
.cat-nav a:hover{color:#fff;background:var(--brand);border-color:var(--brand);transform:translateY(-1px);}

.feat-block code,.legal-body code,.faq-a code{
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:.86em;color:var(--brand-dark);
  background:var(--blue-50);padding:1px 7px;border-radius:6px;
  border:1px solid var(--blue-100);
}
.feat-block ul.check li strong{color:var(--ink-900);font-weight:700;}

/* ============ Reveal on scroll ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease), transform .7s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.08s;}
.reveal-delay-2{transition-delay:.16s;}
.reveal-delay-3{transition-delay:.24s;}

/* ============ Mobile nav ============ */
.mobile-menu{
  display:none;
  position:fixed;left:0;right:0;bottom:0;top:113px;background:#fff;z-index:90;
  padding:28px 24px;transform:translateY(-120%);transition:transform .35s var(--ease);
  border-top:1px solid var(--ink-100);
  box-shadow:var(--shadow-lg);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu a{
  display:block;padding:14px 16px;color:var(--ink-800);font-size:1.05rem;
  font-weight:500;border-radius:12px;margin-bottom:4px;
}
.mobile-menu a:hover,.mobile-menu a.active{background:var(--blue-50);color:var(--brand);}
.mobile-menu .btn{width:100%;margin-top:14px;}

/* ============ Responsive ============ */
@media (max-width:1024px){
  .hero-grid,.showcase-grid,.about-grid{grid-template-columns:1fr;gap:48px;}
  .util-grid,.why-grid{grid-template-columns:repeat(3,1fr);}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:28px;}
  .test-grid{grid-template-columns:repeat(2,1fr);}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
  .feat-block{grid-template-columns:1fr;gap:32px;padding:32px 0;}
  .feat-block:nth-child(even) .feat-visual{order:-1;}
  .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:1000px){
  nav.primary-nav{display:none;}
  .nav-toggle{display:inline-flex;}
  .brand-name .bn-tag{display:none;}
  .mobile-menu{display:block;}
}
@media (max-width:720px){
  section{padding:64px 0;}
  .top-bar{display:none;}
  .site-header{top:0;}
  .mobile-menu{top:80px;}
  .header-right .btn{display:none;}
  .util-grid,.why-grid{grid-template-columns:repeat(2,1fr);gap:14px;}
  .util-card{padding:22px 18px;}
  .steps{grid-template-columns:1fr;}
  .steps::before{display:none;}
  .test-grid,.values-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}
  .cta{padding:48px 24px;}
  .hero{padding:54px 0 60px;}
  .hero-lede{font-size:1.02rem;}
  .phone{width:260px;}
  .phone-lg{width:270px;}
  .showcase-visual{min-height:520px;}
  .showcase-visual .phone{width:210px;}
  .showcase-visual .phone.p1{transform:translate(-72px,0) rotate(-6deg) scale(.88);}
  .showcase-visual .phone.p3{transform:translate(72px,0) rotate(6deg) scale(.88);}
  .fc-1{left:-10px;top:8%;}
  .fc-2{right:-10px;bottom:12%;}
  .fc-3{left:-18px;top:65%;}
  .form-row{grid-template-columns:1fr;}
  .contact-form{padding:24px;}
  .stats-grid{padding:32px 20px;}
}
@media (max-width:420px){
  .hero-cta{flex-direction:column;align-items:stretch;}
  .hero-cta .btn,.hero-cta .store-btn{width:100%;}
  .cta-actions{flex-direction:column;align-items:stretch;}
  .cta-actions .btn{width:100%;}
  .cta-qr{width:100%;max-width:320px;margin-left:auto;margin-right:auto;}
}

/* ============================================================
   EDITORIAL LAYER — section labels, live card, marquee, italics
   ============================================================ */

/* Italic display accent — Instrument Serif inside Montserrat heads */
h1 em, h2 em, h3 em, .display-italic{
  font-family:var(--display-italic);
  font-style:italic;
  font-weight:400;
  letter-spacing:-.018em;
  color:var(--brand);
}
h1 em{font-size:1.06em;line-height:.96;}

/* Numbered, ruled section label */
.section-label{
  display:inline-flex;align-items:center;gap:14px;
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;font-weight:700;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-500);
  margin-bottom:22px;
}
.section-label::before{
  content:"";width:38px;height:1.5px;background:var(--brand);
  flex-shrink:0;
}
.section-label em{
  font-family:var(--display-italic);font-style:italic;font-weight:400;
  font-size:1.4em;letter-spacing:0;color:var(--brand);
  text-transform:none;line-height:1;
}
.section-label strong{color:var(--ink-900);font-weight:700;}

/* Editorial corner crosshair */
.cross{position:relative;}
.cross::before,.cross::after{
  content:"";position:absolute;width:18px;height:18px;
  border:1.5px solid var(--brand);opacity:.22;pointer-events:none;
}
.cross::before{top:-9px;left:-9px;border-right:none;border-bottom:none;}
.cross::after{bottom:-9px;right:-9px;border-left:none;border-top:none;}

/* === Hero amplification === */
.hero{
  padding:96px 0 90px;
  position:relative;
  background:
    radial-gradient(1100px 580px at 88% -8%,rgba(11,73,180,.18),transparent 62%),
    radial-gradient(820px 460px at -8% 28%,rgba(3,59,163,.10),transparent 62%),
    radial-gradient(680px 340px at 50% 110%,rgba(16,216,127,.10),transparent 60%),
    linear-gradient(180deg,#F5F9FF 0%,#FFFFFF 88%);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--grain);background-size:240px 240px;
  opacity:.05;mix-blend-mode:multiply;z-index:1;
}
.hero > .container{position:relative;z-index:2;}

/* Live "NEW" badge for the hero */
.hero-pill{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;
  background:#0B1733;color:#fff;
  padding:9px 16px 9px 12px;border-radius:var(--r-pill);
  margin-bottom:24px;
  box-shadow:0 12px 28px -10px rgba(11,23,51,.45);
}
.hero-pill .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(16,216,127,.25);
  animation:livePulse 1.8s ease-in-out infinite;
}
.hero-pill .arrow{margin-left:2px;opacity:.6;}
@keyframes livePulse{
  0%,100%{box-shadow:0 0 0 4px rgba(16,216,127,.25);}
  50%{box-shadow:0 0 0 7px rgba(16,216,127,.10);}
}

.hero h1{font-size:clamp(2.6rem,5.8vw,4.9rem);line-height:1.02;letter-spacing:-.04em;}
.hero h1 em{color:var(--brand);}
.hero h1 .accent{position:relative;display:inline-block;color:var(--ink-900);}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;height:.18em;
  background:var(--accent);opacity:.45;border-radius:6px;z-index:-1;
}

.hero-lede{font-size:1.18rem;color:var(--ink-500);max-width:540px;margin-bottom:32px;}

/* === Live caller-ID card (replaces generic float chips) === */
.live-card{
  position:absolute;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(11,23,51,.06);
  border-radius:22px;
  padding:18px 20px 16px;
  box-shadow:
    0 30px 80px -10px rgba(11,23,51,.32),
    0 6px 20px -6px rgba(11,23,51,.18);
  display:flex;gap:14px;align-items:flex-start;
  width:300px;
  z-index:5;
}
.live-card-tag{
  position:absolute;top:-10px;left:18px;
  background:var(--accent);color:#0B1733;
  font-size:.62rem;font-weight:800;letter-spacing:.18em;
  padding:4px 10px;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 8px 20px -6px rgba(16,216,127,.5);
}
.live-card-tag .dot{
  width:6px;height:6px;border-radius:50%;background:#0B1733;
  animation:livePulse 1.6s ease-in-out infinite;
}
.live-avatar{
  width:50px;height:50px;border-radius:50%;flex-shrink:0;
  background:var(--brand-gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.05rem;letter-spacing:-.02em;
  box-shadow:var(--shadow-sm);
}
.live-body{flex:1;min-width:0;}
.live-name{
  font-size:1.05rem;font-weight:800;color:var(--ink-900);
  margin:0;letter-spacing:-.02em;line-height:1.15;
}
.live-meta{font-size:.78rem;color:var(--ink-500);margin:3px 0 9px;letter-spacing:.01em;}
.live-badges{display:flex;gap:5px;flex-wrap:wrap;}
.live-badges span{
  font-size:.62rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--r-pill);
  background:var(--accent-soft);color:var(--accent-dark);
}
.live-badges .warn{background:#FEE2E2;color:#B91C1C;}

.live-card-1{top:18%;left:-44px;}
.live-card-2{bottom:14%;right:-30px;width:240px;}
.live-card-2 .live-avatar{background:#FEE2E2;color:#B91C1C;}

/* === Marquee strip — scrolling blocked numbers === */
.marquee-band{
  background:#0B1733;color:rgba(255,255,255,.78);
  padding:18px 0;overflow:hidden;position:relative;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.marquee-band::before,.marquee-band::after{
  content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.marquee-band::before{left:0;background:linear-gradient(90deg,#0B1733 0%,transparent 100%);}
.marquee-band::after{right:0;background:linear-gradient(270deg,#0B1733 0%,transparent 100%);}
.marquee-track{
  display:flex;gap:54px;white-space:nowrap;
  animation:marqueeScroll 50s linear infinite;
  width:max-content;
  align-items:center;
}
.marquee-band:hover .marquee-track{animation-play-state:paused;}
.marquee-item{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.85rem;letter-spacing:.02em;
  font-variant-numeric:tabular-nums;
}
.marquee-item .num{
  font-family:var(--display-italic);
  font-style:italic;font-weight:400;font-size:1.18rem;
  color:#fff;letter-spacing:0;
}
.marquee-item .pip{
  width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 3px rgba(16,216,127,.18);
}
.marquee-item .tag{
  font-size:.68rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);padding-left:2px;
}
.marquee-item .tag.red{color:#FB7185;}
.marquee-item .tag.amber{color:#FBBF24;}
@keyframes marqueeScroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* === USP band italic accent (already defined; one extra selector) === */
.usp-text h2 em{color:#fff;opacity:.92;}

/* Mobile / small adjustments for editorial layer */
@media (max-width:1024px){
  .live-card-1{top:8%;left:-10px;}
  .live-card-2{bottom:8%;right:-10px;}
}
@media (max-width:720px){
  .hero{padding:64px 0 60px;}
  .live-card-1,.live-card-2{position:static;margin:14px auto;width:90%;}
  .live-card-2 + .live-card-2{margin-top:-6px;}
  .marquee-track{animation-duration:30s;gap:32px;}
  .marquee-item{font-size:.78rem;gap:10px;}
  .marquee-item .num{font-size:1rem;}
  .section-label{font-size:.68rem;letter-spacing:.18em;}
}

/* ============ Language switcher ============ */
.lang-switcher{position:relative;display:inline-block;}
.lang-trigger{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--ink-700);
  border:1px solid var(--ink-100);
  padding:9px 14px;border-radius:var(--r-pill);
  font-family:inherit;font-size:.85rem;font-weight:600;
  cursor:pointer;
  transition:all .2s var(--ease);
}
.lang-trigger:hover{border-color:var(--brand);color:var(--brand);}
.lang-switcher.open .lang-trigger{border-color:var(--brand);color:var(--brand);background:var(--blue-50);}
.lang-trigger svg{width:16px;height:16px;flex-shrink:0;}
.lang-trigger .lang-current-code{font-weight:700;letter-spacing:.04em;line-height:1;}
.lang-trigger .lang-chev{width:12px;height:12px;transition:transform .2s var(--ease);}
.lang-switcher.open .lang-trigger .lang-chev{transform:rotate(180deg);}

.lang-panel{
  position:absolute;top:calc(100% + 10px);right:0;
  width:340px;max-height:460px;
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-md);
  box-shadow:0 30px 70px -10px rgba(11,23,51,.22),0 6px 20px -6px rgba(11,23,51,.10);
  display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s var(--ease);
  z-index:120;
  overflow:hidden;
}
.lang-switcher.open .lang-panel{opacity:1;visibility:visible;transform:translateY(0);}

.lang-search{
  padding:14px 14px 10px;
  border-bottom:1px solid var(--ink-50);
  position:relative;
  flex-shrink:0;
}
.lang-search svg{
  position:absolute;left:24px;top:50%;transform:translateY(-30%);
  width:16px;height:16px;color:var(--ink-400);pointer-events:none;
}
.lang-search input{
  width:100%;padding:10px 14px 10px 38px;
  border:1px solid var(--ink-100);border-radius:10px;
  font-family:inherit;font-size:.9rem;color:var(--ink-800);
  background:var(--off);
  transition:all .2s var(--ease);
}
.lang-search input:focus{
  outline:none;border-color:var(--brand);background:#fff;
  box-shadow:0 0 0 4px rgba(11,73,180,.12);
}
.lang-search input::placeholder{color:var(--ink-400);}

.lang-list{
  overflow-y:auto;flex:1;padding:8px;
  scrollbar-width:thin;
  scrollbar-color:var(--ink-200) transparent;
}
.lang-list::-webkit-scrollbar{width:8px;}
.lang-list::-webkit-scrollbar-thumb{background:var(--ink-200);border-radius:4px;}
.lang-list::-webkit-scrollbar-track{background:transparent;}

.lang-group{margin-bottom:6px;}
.lang-group h6{
  font-size:.7rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-400);
  margin:10px 12px 4px;padding:0;
}
.lang-list button{
  width:100%;text-align:left;
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:9px 12px;border-radius:8px;
  background:none;border:none;color:var(--ink-700);
  font-family:inherit;cursor:pointer;
  transition:background .15s var(--ease);
}
.lang-list button:hover{background:var(--blue-50);}
.lang-list button .lang-text{display:flex;flex-direction:column;gap:1px;min-width:0;}
.lang-list button .ln{font-size:.95rem;font-weight:600;color:var(--ink-900);line-height:1.2;}
.lang-list button .le{font-size:.78rem;color:var(--ink-500);}
.lang-list button .check{
  width:18px;height:18px;border-radius:50%;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;opacity:0;
  font-size:.6rem;font-weight:900;
}
.lang-list button.active{background:var(--blue-50);}
.lang-list button.active .check{opacity:1;}
.lang-list .lang-empty{
  text-align:center;padding:30px 14px;color:var(--ink-400);font-size:.88rem;
}

@media (max-width:1000px){
  .lang-trigger{padding:8px 12px;}
  .lang-trigger .lang-current-code{display:none;}
}
@media (max-width:720px){
  .lang-panel{
    position:fixed;top:auto;bottom:0;left:0;right:0;
    width:100%;max-height:70vh;
    border-radius:18px 18px 0 0;
    transform:translateY(100%);
  }
  .lang-switcher.open .lang-panel{transform:translateY(0);}
  .lang-list{padding:8px 8px 24px;}
}

/* ============ Hide Google Translate native UI ============ */
.skiptranslate, .goog-te-banner-frame, #goog-gt-tt, .goog-te-balloon-frame{display:none !important;}
body{top:0 !important;}
.goog-tooltip, .goog-tooltip:hover{display:none !important;}
.goog-text-highlight{background:none !important;box-shadow:none !important;}
font[style*="background-color"]{background-color:transparent !important;}

/* ============ Translation loading state — no flash of English ============ */
html.translating body{opacity:0 !important;pointer-events:none;}
html.translating.translation-ready body{
  opacity:1 !important;pointer-events:auto;
  transition:opacity .35s var(--ease);
}
html.translating::before{
  content:"";position:fixed;inset:0;
  background:linear-gradient(180deg,#F5F9FF 0%,#FFFFFF 100%);
  z-index:99998;
}
html.translating::after{
  content:"";position:fixed;
  top:50%;left:50%;
  width:48px;height:48px;
  margin:-24px 0 0 -24px;
  border:3px solid #E3F0FF;
  border-top-color:var(--brand);
  border-radius:50%;
  animation:tcidSpin .7s linear infinite;
  z-index:99999;
}
html.translation-ready::before,
html.translation-ready::after{
  opacity:0;
  pointer-events:none;
  transition:opacity .35s var(--ease);
}
@keyframes tcidSpin{to{transform:rotate(360deg);}}

/* ============ Translation overflow guards ============
   When a viewer translates the page, Indic / CJK / RTL scripts can run
   much wider than Latin. These rules prevent the layout from blowing
   out horizontally and force long translated words to wrap.
   ============================================================ */

/* Hard cap: never allow horizontal scroll */
html, body{overflow-x:clip;max-width:100%;}

/* Let text break inside headings, paragraphs, and inline copy */
h1, h2, h3, h4, h5, p,
.hero-lede, .section-head p,
.live-name, .live-meta,
.partner-name, .partner-note,
.job-title, .job-desc,
.price-name, .price-tagline,
.faq-q, .faq-a,
.test-card blockquote,
.value-card p, .why-card p, .util-card p,
.feature-list h4, .feature-list p,
.usp-text p, .usp-text h2{
  overflow-wrap:anywhere;
  word-break:break-word;
  hyphens:auto;
}

/* Grid / flex children must be allowed to shrink below their content
   width — otherwise long Tamil/Hindi words expand the column past 1fr */
.hero-grid > *,
.about-grid > *,
.contact-grid > *,
.partner-apply-grid > *,
.advertise-grid > *,
.showcase-grid > *,
.feat-block > *,
.usp-card > *,
.cookie-content > *{min-width:0;}

/* When Google Translate has translated the page, dial down display
   sizes and relax Latin-tight tracking so non-Latin scripts fit. */
html.translated-ltr h1, html.translated-rtl h1,
html.translated-ltr h2, html.translated-rtl h2,
html.translated-ltr h3, html.translated-rtl h3{
  letter-spacing:normal !important;
  word-spacing:normal;
  hyphens:auto;
}
html.translated-ltr h1, html.translated-rtl h1{
  font-size:clamp(1.7rem, 4.4vw, 3rem);
  line-height:1.2;
}
html.translated-ltr .hero h1, html.translated-rtl .hero h1{
  font-size:clamp(1.85rem, 4.6vw, 3.4rem);
  line-height:1.2;
}
html.translated-ltr h2, html.translated-rtl h2{
  font-size:clamp(1.4rem, 3vw, 2.2rem);
  line-height:1.25;
}
html.translated-ltr .hero h1 em, html.translated-rtl .hero h1 em{font-size:1em;}
html.translated-ltr .hero h1 .accent, html.translated-rtl .hero h1 .accent{display:inline;}

/* Buttons: allow wrap when translated so longer phrases don't push the
   header / hero out of bounds */
html.translated-ltr .btn, html.translated-rtl .btn,
html.translated-ltr .store-btn, html.translated-rtl .store-btn,
html.translated-ltr .filter-search, html.translated-rtl .filter-search,
html.translated-ltr .price-cta, html.translated-rtl .price-cta,
html.translated-ltr .lang-trigger, html.translated-rtl .lang-trigger{
  white-space:normal;
  text-align:center;
  height:auto;
  line-height:1.25;
}
html.translated-ltr .btn-lg, html.translated-rtl .btn-lg{padding:14px 24px;}

/* The marquee numbers shouldn't translate (they're sample phone numbers),
   so add notranslate at runtime — but as a fallback also keep them on one
   line so wrapping doesn't break the strip */
.marquee-item .num,
.marquee-item .tag{white-space:nowrap;}

/* RTL languages (Arabic, Hebrew, Urdu, Persian) need direction flipped on
   text-heavy containers; Google flips body but inline-flex toolbars look
   better still in LTR — keep nav/CTAs LTR */
html.translated-rtl .legal-body,
html.translated-rtl .hero-lede,
html.translated-rtl .section-head p,
html.translated-rtl p{direction:rtl;text-align:right;}
html.translated-rtl .nav-menu,
html.translated-rtl .header-right,
html.translated-rtl .hero-cta,
html.translated-rtl .cta-actions,
html.translated-rtl .marquee-track,
html.translated-rtl .lang-trigger,
html.translated-rtl .lang-panel,
html.translated-rtl .live-card,
html.translated-rtl .float-card{direction:ltr;}

/* CRITICAL: when translated, switch to the mobile-burger nav so the
   language switcher + Download button always have room. Translated nav
   items can be 30-60% wider than English; the inline desktop nav pushes
   .header-right past the viewport edge where overflow-x:hidden clips it. */
html.translated-ltr nav.primary-nav,
html.translated-rtl nav.primary-nav{display:none !important;}
html.translated-ltr .nav-toggle,
html.translated-rtl .nav-toggle{display:inline-flex !important;}

/* Keep the current-language code visible on the trigger when translated
   (default rule hides it under 1000px) so the pill is clearly identifiable */
html.translated-ltr .lang-trigger .lang-current-code,
html.translated-rtl .lang-trigger .lang-current-code{display:inline !important;}
@media (max-width:720px){
  html.translated-ltr .lang-trigger .lang-current-code,
  html.translated-rtl .lang-trigger .lang-current-code{display:none !important;}
}

/* ============ Cookie consent banner ============ */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:998;
  background:#fff;
  border-top:1px solid var(--ink-100);
  box-shadow:0 -10px 40px -8px rgba(11,23,51,.10);
  padding:18px 0;
  transform:translateY(110%);
  transition:transform .55s var(--ease);
}
.cookie-banner.visible{transform:translateY(0);}
.cookie-content{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.cookie-text{
  display:flex;align-items:flex-start;gap:14px;flex:1;min-width:0;
}
.cookie-icon{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:var(--blue-50);color:var(--brand);
  display:flex;align-items:center;justify-content:center;
}
.cookie-icon svg{width:22px;height:22px;}
.cookie-text p{
  margin:0;font-size:.9rem;color:var(--ink-600);line-height:1.55;max-width:760px;
}
.cookie-text a{
  color:var(--brand);font-weight:600;
  text-decoration:underline;text-underline-offset:3px;
}
.cookie-text a:hover{color:var(--brand-dark);}
.cookie-actions{display:flex;gap:10px;flex-shrink:0;}
.cookie-btn{
  font-family:inherit;cursor:pointer;
  padding:11px 22px;border-radius:var(--r-pill);
  font-size:.88rem;font-weight:600;
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.cookie-decline{
  background:#fff;color:var(--ink-700);
  border:1px solid var(--ink-100);
}
.cookie-decline:hover{
  border-color:var(--ink-300);color:var(--ink-900);
  transform:translateY(-1px);
}
.cookie-accept{
  background:var(--brand-gradient);color:#fff;border:none;
  box-shadow:var(--shadow-blue);
}
.cookie-accept:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 48px -12px rgba(11,73,180,.55);
}

@media (max-width:720px){
  .cookie-banner{padding:16px 0;}
  .cookie-content{flex-direction:column;align-items:stretch;gap:14px;}
  .cookie-actions{display:grid;grid-template-columns:1fr 1.3fr;gap:8px;}
  .cookie-btn{padding:12px 16px;width:100%;}
  .cookie-icon{width:36px;height:36px;}
  .cookie-icon svg{width:18px;height:18px;}
  .cookie-text p{font-size:.85rem;}
}

/* ============ USP band (voice translation) ============ */
.usp-band{
  padding:70px 0;
  background:linear-gradient(180deg,#F5FAFF 0%,#fff 100%);
}
.usp-card{
  background:var(--brand-gradient);
  border-radius:var(--r-2xl);padding:64px 56px;
  color:#fff;position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  box-shadow:var(--shadow-blue);
}
.usp-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 12% 18%,rgba(255,255,255,.22),transparent 36%),
             radial-gradient(circle at 88% 82%,rgba(255,255,255,.14),transparent 42%);
  pointer-events:none;
}
.usp-text{position:relative;z-index:1;}
.usp-text h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:16px;}
.usp-text p{color:rgba(255,255,255,.92);font-size:1.06rem;max-width:520px;margin-bottom:28px;}
.usp-actions{display:flex;gap:14px;flex-wrap:wrap;}
.usp-demo{
  position:relative;z-index:1;
  display:flex;flex-direction:column;gap:14px;align-items:center;
  padding:14px;
}
.usp-bubble{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);
  border-radius:18px;padding:18px 22px;
  width:100%;max-width:360px;
}
.usp-bubble-from{align-self:flex-start;border-bottom-left-radius:4px;}
.usp-bubble-to{align-self:flex-end;background:rgba(255,255,255,.94);color:var(--ink-800);border-bottom-right-radius:4px;border-color:transparent;}
.usp-bubble p{margin:0;font-size:1.02rem;line-height:1.5;}
.usp-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;font-weight:700;opacity:.85;margin-bottom:6px;
}
.usp-bubble-to .usp-tag{color:var(--brand-dark);opacity:1;}
.usp-arrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.18);border:1px dashed rgba(255,255,255,.4);
  border-radius:var(--r-pill);padding:6px 14px;
  font-size:.78rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;
}
.usp-arrow svg{width:16px;height:16px;transform:rotate(90deg);}
@media (max-width:960px){
  .usp-card{grid-template-columns:1fr;gap:36px;padding:48px 32px;}
  .usp-demo{padding:0;}
  .usp-bubble{max-width:100%;}
}

/* ============ Pricing page ============ */
.price-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch;
}
.price-card{
  position:relative;background:#fff;border:1px solid var(--ink-100);
  border-radius:var(--r-xl);padding:36px 32px;
  display:flex;flex-direction:column;gap:22px;
  transition:all .3s var(--ease);
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--blue-200);}
.price-card-featured{
  border:2px solid var(--brand);
  background:linear-gradient(180deg,#F5FAFF 0%,#fff 40%);
  box-shadow:var(--shadow-blue);
  transform:translateY(-6px);
}
.price-card-featured:hover{transform:translateY(-10px);}
.popular-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--brand-gradient);color:#fff;
  font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 14px;border-radius:var(--r-pill);
  box-shadow:var(--shadow-sm);
}
.price-name{font-size:1.1rem;font-weight:700;color:var(--ink-900);margin:0;letter-spacing:-0.01em;}
.price-tagline{color:var(--ink-500);font-size:.92rem;margin:4px 0 0;}
.price-amount-row{display:flex;align-items:baseline;gap:6px;margin:8px 0 0;}
.price-currency{font-size:1.2rem;color:var(--ink-500);font-weight:600;}
.price-amount{font-family:'Montserrat',sans-serif;font-size:2.6rem;font-weight:700;color:var(--ink-900);line-height:1;letter-spacing:-0.02em;}
.price-period{color:var(--ink-400);font-size:.95rem;}
.price-usd{color:var(--ink-400);font-size:.86rem;margin:4px 0 0;}
.price-cta{display:block;text-align:center;padding:14px 18px;border-radius:var(--r-pill);font-weight:600;transition:all .25s var(--ease);}
.price-cta-primary{background:var(--brand-gradient);color:#fff;box-shadow:var(--shadow-blue);}
.price-cta-primary:hover{transform:translateY(-2px);color:#fff;}
.price-cta-ghost{background:var(--blue-50);color:var(--brand);border:1px solid var(--blue-100);}
.price-cta-ghost:hover{background:var(--brand);color:#fff;}
.price-features{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.price-features li{
  position:relative;padding-left:28px;color:var(--ink-600);font-size:.95rem;line-height:1.55;
}
.price-features li::before{
  content:"";position:absolute;left:0;top:4px;width:18px;height:18px;
  border-radius:50%;background:var(--success-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310B981' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='5 12 10 17 19 8'/%3E%3C/svg%3E");
  background-size:12px;background-position:center;background-repeat:no-repeat;
}
.price-features li strong{color:var(--ink-900);}
.price-divider{height:1px;background:var(--ink-100);margin:4px 0;}
.price-note{
  max-width:720px;margin:48px auto 0;text-align:center;
  color:var(--ink-500);font-size:.95rem;
}
@media (max-width:1024px){
  .price-grid{grid-template-columns:1fr;gap:20px;}
  .price-card-featured{transform:none;}
  .price-card-featured:hover{transform:translateY(-6px);}
}

/* ============ Careers page ============ */
.careers-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.careers-stat{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:26px 22px;text-align:center;
  transition:all .25s var(--ease);
}
.careers-stat:hover{border-color:var(--blue-200);box-shadow:var(--shadow-sm);transform:translateY(-2px);}
.careers-stat .num{
  font-family:'Montserrat',sans-serif;font-size:1.9rem;font-weight:700;
  color:var(--brand);line-height:1;letter-spacing:-0.02em;
  background:var(--brand-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.careers-stat .label{color:var(--ink-500);font-size:.86rem;margin-top:8px;line-height:1.45;}

/* ----- Job filters bar ----- */
.job-filters{
  display:grid;
  grid-template-columns:1.1fr 1.6fr 1.2fr 1.1fr auto;
  gap:14px;align-items:center;
  background:#fff;border:1px solid var(--ink-100);
  border-radius:var(--r-lg);padding:14px;
  box-shadow:var(--shadow-sm);
  margin-bottom:28px;
}
.filter-field{position:relative;display:flex;align-items:center;}
.filter-field .filter-icon{
  position:absolute;left:14px;width:16px;height:16px;color:var(--ink-400);pointer-events:none;
}
.filter-field input,
.filter-field select{
  width:100%;
  padding:13px 16px 13px 40px;
  border:1px solid var(--ink-100);
  border-radius:var(--r-md);
  font-family:inherit;font-size:.94rem;color:var(--ink-800);background:#fff;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
  -webkit-appearance:none;appearance:none;
}
.filter-field select{
  padding-left:16px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:14px;
  padding-right:40px;color:var(--ink-600);cursor:pointer;
}
.filter-field input:focus,
.filter-field select:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(11,73,180,.12);
}
.filter-field input::placeholder{color:var(--ink-400);}
.filter-search{
  background:var(--brand-gradient);color:#fff;
  font-weight:700;font-size:.85rem;letter-spacing:.08em;
  padding:14px 26px;border-radius:var(--r-md);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:var(--shadow-sm);
  transition:all .25s var(--ease);white-space:nowrap;
}
.filter-search:hover{transform:translateY(-1px);box-shadow:var(--shadow-blue);}
.filter-search span{font-size:1.1rem;line-height:1;}

/* ----- Job cards (full width, screenshot-style) ----- */
.job-list-wrap{display:grid;gap:20px;}
.job-card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:30px 34px;display:flex;flex-direction:column;gap:16px;
  transition:all .3s var(--ease);position:relative;overflow:hidden;
  box-shadow:var(--shadow-xs);
}
.job-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--brand-gradient);opacity:0;transition:opacity .3s var(--ease);
}
.job-card:hover{
  transform:translateY(-3px);border-color:var(--blue-200);
  box-shadow:var(--shadow-md);
}
.job-card:hover::before{opacity:1;}

.job-card-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;
}
.job-title{
  font-size:1.35rem;margin:0;color:var(--ink-900);
  letter-spacing:-0.015em;font-weight:700;line-height:1.25;
}
.job-posted{color:var(--ink-400);font-size:.86rem;font-weight:500;white-space:nowrap;}

.job-pills{display:flex;flex-wrap:wrap;gap:8px;}
.pill{
  display:inline-flex;align-items:center;
  font-size:.82rem;font-weight:500;color:var(--ink-600);
  background:var(--ink-50);
  padding:6px 14px;border-radius:var(--r-pill);
  letter-spacing:-0.005em;
}
.pill-location{
  color:var(--brand);background:var(--blue-50);
}

.job-desc{
  color:var(--ink-500);font-size:.96rem;margin:0;
  line-height:1.65;max-width:900px;
}

.job-card-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  margin-top:4px;
}
.job-skills{display:flex;flex-wrap:wrap;gap:8px;}
.skill{
  display:inline-flex;align-items:center;
  font-size:.82rem;font-weight:500;color:var(--ink-600);
  background:var(--ink-50);
  padding:7px 16px;border-radius:var(--r-pill);
  border:1px solid transparent;
  transition:all .2s var(--ease);
}
.skill:hover{background:var(--blue-50);color:var(--brand);border-color:var(--blue-100);}

.btn-view{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--brand-gradient);color:#fff;
  font-weight:600;font-size:.94rem;
  padding:12px 24px;border-radius:var(--r-md);
  box-shadow:var(--shadow-sm);transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn-view:hover{transform:translateY(-2px);color:#fff;box-shadow:var(--shadow-blue);}

@media (max-width:1024px){
  .careers-stats{grid-template-columns:repeat(2,1fr);}
  .job-filters{
    grid-template-columns:1fr 1fr;gap:12px;
  }
  .filter-search{grid-column:1 / -1;}
}
@media (max-width:720px){
  .careers-stats{grid-template-columns:repeat(2,1fr);gap:12px;}
  .careers-stat{padding:20px 14px;}
  .careers-stat .num{font-size:1.55rem;}
  .job-filters{grid-template-columns:1fr;padding:12px;}
  .job-card{padding:24px 22px;}
  .job-title{font-size:1.15rem;}
  .job-card-bottom{flex-direction:column;align-items:stretch;}
  .btn-view{justify-content:center;}
}

/* ----- Nav dropdown (Partners) ----- */
.nav-menu .nav-dropdown > a{display:inline-flex;align-items:center;gap:5px;}
.nav-menu .nav-dropdown > a svg{width:12px;height:12px;transition:transform .2s var(--ease);}
.nav-menu .nav-dropdown:hover > a svg{transform:rotate(180deg);}
.nav-menu .dropdown-menu{
  position:absolute;top:100%;left:0;min-width:220px;
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-md);
  box-shadow:var(--shadow-md);
  padding:8px;margin-top:-4px;
  list-style:none;
  opacity:0;visibility:hidden;
  transform:translateY(6px);
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s var(--ease);
  z-index:50;
}
.nav-menu .nav-dropdown:hover .dropdown-menu,
.nav-menu .nav-dropdown:focus-within .dropdown-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-menu .dropdown-menu li{margin:0;}
.nav-menu .dropdown-menu a{
  display:block;padding:11px 14px;border-radius:8px;
  color:var(--ink-700);font-size:.93rem;font-weight:500;white-space:nowrap;
  transition:all .18s var(--ease);
}
.nav-menu .dropdown-menu a:hover{background:var(--blue-50);color:var(--brand);}
.nav-menu .dropdown-menu a.active{background:var(--blue-50);color:var(--brand);}

/* ----- Vertical steps variant (for partner/advertise forms) ----- */
.steps-vertical{display:grid;grid-template-columns:1fr;gap:16px;}
.steps-vertical::before{display:none;}
.steps-vertical .step{
  text-align:left;padding:22px 24px;
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:flex-start;
}
.steps-vertical .step-num{margin:0;width:48px;height:48px;font-size:1rem;}
.steps-vertical .step h3{margin:0 0 4px;font-size:1.04rem;}
.steps-vertical .step p{margin:0;font-size:.92rem;line-height:1.6;}

/* ----- Partner / Advertise pages ----- */
.partner-apply-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;
}
.partner-apply-grid .contact-form{margin:0;}
.partner-side-title{margin:0 0 18px;font-size:1.1rem;color:var(--ink-900);}

.advertise-grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:48px;align-items:start;
}
.advertise-grid .contact-form{margin:0;}
.info-card-stack{display:grid;gap:16px;}

.ad-format-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.ad-format-card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--r-lg);
  padding:30px 26px;transition:all .3s var(--ease);
  position:relative;overflow:hidden;
}
.ad-format-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--brand-gradient);opacity:0;transition:opacity .3s var(--ease);
}
.ad-format-card:hover{transform:translateY(-4px);border-color:var(--blue-200);box-shadow:var(--shadow-md);}
.ad-format-card:hover::before{opacity:1;}
.ad-format-card .af-icon{
  width:52px;height:52px;border-radius:14px;
  background:var(--brand-gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;box-shadow:var(--shadow-blue);
}
.ad-format-card .af-icon svg{width:26px;height:26px;}
.ad-format-card h3{font-size:1.1rem;margin:0 0 8px;}
.ad-format-card p{color:var(--ink-500);font-size:.93rem;margin:0;line-height:1.6;}

@media (max-width:1024px){
  .partner-apply-grid,.advertise-grid{grid-template-columns:1fr;gap:36px;}
  .ad-format-grid{grid-template-columns:1fr;gap:16px;}
}

/* ----- Partners & integrations grid ----- */
.partner-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.partner-card{
  background:#fff;border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  padding:22px 22px 22px 20px;
  display:flex;gap:16px;align-items:flex-start;
  transition:all .3s var(--ease);
  position:relative;overflow:hidden;
}
.partner-card::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--brand-gradient);opacity:0;transition:opacity .3s var(--ease);
}
.partner-card:hover{
  transform:translateY(-3px);
  border-color:var(--blue-200);
  box-shadow:var(--shadow-sm);
}
.partner-card:hover::after{opacity:1;}
.partner-logo{
  width:54px;height:54px;border-radius:14px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:1.05rem;letter-spacing:-0.02em;
}
.partner-body{
  display:flex;flex-direction:column;gap:6px;min-width:0;flex:1;
}
.partner-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  flex-wrap:wrap;
}
.partner-name{
  font-size:1.02rem;color:var(--ink-900);margin:0;font-weight:700;
  letter-spacing:-0.01em;line-height:1.2;
}
.partner-tag{
  font-size:.66rem;font-weight:700;color:var(--ink-400);letter-spacing:.1em;
  text-transform:uppercase;white-space:nowrap;
  background:var(--ink-50);padding:3px 9px;border-radius:var(--r-pill);
}
.partner-note{
  color:var(--ink-500);font-size:.86rem;margin:0;line-height:1.5;
}
.partner-footnote{
  text-align:center;margin:32px auto 0;
  color:var(--ink-500);font-size:.96rem;
}
.partner-footnote a{font-weight:600;}
.partner-footnote a:hover{text-decoration:underline;}

@media (max-width:1024px){
  .partner-grid{grid-template-columns:repeat(2,1fr);gap:14px;}
}
@media (max-width:560px){
  .partner-grid{grid-template-columns:1fr;}
  .partner-card{padding:18px;}
}

/* ============ Pricing compare table ============ */
.compare-wrap{
  overflow-x:auto;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.compare-table{
  width:100%;border-collapse:collapse;min-width:720px;
  font-size:.95rem;color:var(--ink-700);
}
.compare-table thead th{
  background:var(--blue-50);
  padding:18px 22px;
  font-weight:700;color:var(--ink-900);
  font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;
  border-bottom:2px solid var(--blue-100);
  text-align:left;
}
.compare-table thead th.c{text-align:center;}
.compare-table thead th.premium{color:var(--brand);}
.compare-table thead th.business{color:var(--success);}
.compare-table tbody tr{
  border-top:1px solid var(--ink-100);
  transition:background .18s var(--ease);
}
.compare-table tbody tr:hover{background:var(--off);}
.compare-table tbody td{
  padding:14px 22px;
  vertical-align:middle;
}
.compare-table tbody td.feat{font-weight:500;color:var(--ink-800);}
.compare-table tbody td.c{text-align:center;}
.compare-table .yes{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:var(--success-soft);color:var(--success);
  font-weight:700;font-size:.85rem;
}
.compare-table .no{color:var(--ink-300);font-size:1.05rem;}
.compare-table .limit{
  color:var(--ink-500);font-size:.86rem;font-weight:500;
  background:var(--ink-50,#F1F5F9);padding:4px 10px;border-radius:var(--r-pill);
  display:inline-block;
}
.compare-table .limit.brand{color:var(--brand);background:var(--blue-50);}
.compare-table .limit.success{color:var(--success);background:var(--success-soft);}

/* =============================================================
   Review modal — footer "Leave a Review" button + popup
   ============================================================= */
.footer-review-btn{
  display:inline-flex;align-items:center;gap:9px;
  margin-top:18px;padding:10px 18px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  color:#fff;font-weight:600;font-size:.92rem;line-height:1;
  cursor:pointer;transition:all .2s var(--ease);
  font-family:inherit;
}
.footer-review-btn:hover{
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28);
  transform:translateY(-1px);
}
.footer-review-btn svg{width:17px;height:17px;color:#FBBF24;}

/* =============================================================
   WhatsApp chat widget — floating bubble + 5-question chat
   ============================================================= */
.tcid-chat-bubble{
  position:fixed;bottom:24px;right:24px;z-index:998;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;border:0;cursor:pointer;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.tcid-chat-bubble:hover{transform:scale(1.06);box-shadow:0 12px 32px rgba(37,211,102,.55);}
.tcid-chat-bubble svg{width:30px;height:30px;}
.tcid-chat-bubble.hide{display:none;}
.tcid-chat-bubble::after{
  content:"";position:absolute;top:6px;right:6px;
  width:12px;height:12px;border-radius:50%;
  background:#FF4D4F;border:2px solid #fff;
  animation:tcidPulse 1.6s ease-in-out infinite;
}
@keyframes tcidPulse{
  0%,100%{transform:scale(1);opacity:1;}
  50%{transform:scale(1.18);opacity:.85;}
}

.tcid-chat-panel{
  position:fixed;bottom:24px;right:24px;z-index:999;
  width:380px;max-width:calc(100vw - 32px);
  height:560px;max-height:calc(100vh - 48px);
  background:#fff;border-radius:18px;
  box-shadow:0 24px 60px rgba(15,23,42,.18);
  display:none;flex-direction:column;overflow:hidden;
  transform:translateY(20px) scale(.96);opacity:0;
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.tcid-chat-panel.open{display:flex;transform:none;opacity:1;}

.tcid-chat-header{
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;padding:16px 18px;
  display:flex;align-items:center;gap:12px;
}
.tcid-chat-header .avatar{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;flex-shrink:0;
}
.tcid-chat-header .meta{flex:1;min-width:0;}
.tcid-chat-header .name{font-weight:700;font-size:.98rem;margin:0;}
.tcid-chat-header .status{font-size:.78rem;opacity:.9;display:flex;align-items:center;gap:6px;margin:1px 0 0;}
.tcid-chat-header .status::before{
  content:"";width:8px;height:8px;border-radius:50%;background:#7EE787;
  box-shadow:0 0 0 0 rgba(126,231,135,.5);
  animation:tcidDot 2s ease-in-out infinite;
}
@keyframes tcidDot{
  0%,100%{box-shadow:0 0 0 0 rgba(126,231,135,.5);}
  50%{box-shadow:0 0 0 6px rgba(126,231,135,0);}
}
.tcid-chat-close{
  background:rgba(255,255,255,.16);border:0;color:#fff;
  width:32px;height:32px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;flex-shrink:0;
}
.tcid-chat-close:hover{background:rgba(255,255,255,.28);}
.tcid-chat-close svg{width:16px;height:16px;}

.tcid-chat-body{
  flex:1;overflow-y:auto;padding:18px 16px;
  background:#F0F2F5;
  display:flex;flex-direction:column;gap:8px;
  scroll-behavior:smooth;
}
.tcid-msg{
  max-width:78%;padding:9px 13px;border-radius:14px;
  font-size:.92rem;line-height:1.45;
  animation:tcidMsgIn .25s var(--ease);
  word-wrap:break-word;white-space:pre-wrap;
}
@keyframes tcidMsgIn{
  from{transform:translateY(6px);opacity:0;}
  to{transform:none;opacity:1;}
}
.tcid-msg.bot{
  background:#fff;color:var(--ink-800);
  align-self:flex-start;border-bottom-left-radius:4px;
  box-shadow:0 1px 1px rgba(15,23,42,.05);
}
.tcid-msg.user{
  background:#DCF8C6;color:var(--ink-800);
  align-self:flex-end;border-bottom-right-radius:4px;
  box-shadow:0 1px 1px rgba(15,23,42,.05);
}
.tcid-typing{
  align-self:flex-start;background:#fff;
  padding:11px 14px;border-radius:14px;border-bottom-left-radius:4px;
  display:flex;gap:4px;
  box-shadow:0 1px 1px rgba(15,23,42,.05);
}
.tcid-typing span{
  width:7px;height:7px;border-radius:50%;background:#94A3B8;
  animation:tcidTyping 1.2s infinite ease-in-out;
}
.tcid-typing span:nth-child(2){animation-delay:.15s;}
.tcid-typing span:nth-child(3){animation-delay:.3s;}
@keyframes tcidTyping{
  0%,60%,100%{transform:translateY(0);opacity:.4;}
  30%{transform:translateY(-5px);opacity:1;}
}

.tcid-summary{
  background:#fff;border-radius:14px;padding:14px 16px;margin:6px 0;
  align-self:stretch;border:1px solid var(--ink-100);
  animation:tcidMsgIn .25s var(--ease);
}
.tcid-summary h6{
  margin:0 0 10px;font-size:.78rem;font-weight:700;
  color:var(--ink-900);text-transform:uppercase;letter-spacing:.08em;
}
.tcid-summary dl{margin:0 0 12px;display:grid;gap:8px;}
.tcid-summary dt{
  font-size:.72rem;font-weight:600;color:var(--ink-500);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px;
}
.tcid-summary dd{
  margin:0;font-size:.9rem;color:var(--ink-800);word-wrap:break-word;
}
.tcid-send-mail{
  width:100%;padding:11px;border-radius:10px;
  background:#25D366;color:#fff;font-weight:600;
  border:0;cursor:pointer;font-size:.95rem;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;transition:background .15s, opacity .15s;
}
.tcid-send-mail:hover:not(:disabled){background:#1FB855;}
.tcid-send-mail:disabled{opacity:.85;cursor:wait;}
.tcid-send-mail svg{width:18px;height:18px;}
.tcid-restart{
  width:100%;padding:9px;margin-top:8px;border-radius:10px;
  background:transparent;color:var(--ink-500);
  border:1px solid var(--ink-100);cursor:pointer;
  font-size:.85rem;font-family:inherit;
  transition:background .15s, color .15s;
}
.tcid-restart:hover:not(:disabled){background:var(--ink-50);color:var(--ink-800);}
.tcid-restart:disabled{opacity:.5;cursor:wait;}

.tcid-spinner{
  width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:tcidSpin .8s linear infinite;display:inline-block;
}
@keyframes tcidSpin{to{transform:rotate(360deg);}}

.tcid-error{
  background:#FEE2E2;color:#B91C1C;
  padding:10px 12px;border-radius:8px;
  font-size:.84rem;line-height:1.4;margin:-4px 0 12px;
  border-left:3px solid #DC2626;
}

.tcid-thanks{
  background:#fff;border-radius:14px;padding:22px 18px;margin:6px 0;
  align-self:stretch;border:1px solid var(--ink-100);
  text-align:center;
  animation:tcidMsgIn .25s var(--ease);
}
.tcid-thanks-icon{
  width:56px;height:56px;border-radius:50%;
  background:var(--success-soft);color:var(--success);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;
}
.tcid-thanks-icon svg{width:28px;height:28px;}
.tcid-thanks h6{
  margin:0 0 6px;font-size:1.05rem;font-weight:700;
  color:var(--ink-900);text-transform:none;letter-spacing:0;
}
.tcid-thanks p{
  margin:0 0 14px;color:var(--ink-500);
  font-size:.9rem;line-height:1.5;
}

.tcid-chat-input{
  padding:12px 14px;background:#fff;
  border-top:1px solid var(--ink-100);
  display:flex;gap:8px;align-items:flex-end;
}
.tcid-chat-input textarea{
  flex:1;min-height:38px;max-height:100px;padding:9px 13px;
  border:1px solid var(--ink-100);border-radius:18px;
  font-family:inherit;font-size:.92rem;color:var(--ink-800);
  resize:none;background:var(--off);line-height:1.4;
  transition:border-color .15s, background .15s;
  box-sizing:border-box;
}
.tcid-chat-input textarea:focus{outline:0;border-color:#25D366;background:#fff;}
.tcid-chat-input button{
  width:38px;height:38px;border-radius:50%;border:0;
  background:#25D366;color:#fff;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.tcid-chat-input button:hover:not(:disabled){background:#1FB855;}
.tcid-chat-input button:disabled{background:var(--ink-200);cursor:not-allowed;}
.tcid-chat-input button svg{width:16px;height:16px;}

@media (max-width:520px){
  .tcid-chat-bubble{bottom:18px;right:18px;width:54px;height:54px;}
  .tcid-chat-bubble svg{width:26px;height:26px;}
  .tcid-chat-panel{
    bottom:0;right:0;width:100%;max-width:100%;
    height:100dvh;max-height:100dvh;border-radius:0;
  }
}
