:root{
  --bg:#07080c; --bg2:#0b0d14; --panel:rgba(255,255,255,.035); --panel2:rgba(255,255,255,.05);
  --text:#EAEEF6; --muted:#8b94a8; --line:rgba(255,255,255,.09);
  --signal:#F5B23E; --signal2:#E8902E; --accent:#6D9BFF; --accent2:#8E7BFF;
  --r:18px; --maxw:1180px;
  --ff-display:"Space Grotesk",system-ui,sans-serif; --ff-body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:74px}
body{
  font-family:var(--ff-body); background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; overflow-x:hidden; line-height:1.55;
}
a{color:inherit;text-decoration:none}
b{font-weight:600;color:#fff}
em{font-style:normal;color:var(--signal)}
.muted{color:var(--muted)}

/* background */
.bg-grid{position:fixed;inset:0;z-index:-3;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 35%,transparent 75%); opacity:.5}
.bg-glow{position:fixed;z-index:-2;border-radius:50%;filter:blur(90px);opacity:.4;pointer-events:none}
.glow-a{width:640px;height:640px;top:-220px;left:-120px;background:radial-gradient(circle,var(--signal2),transparent 65%);opacity:.22}
.glow-b{width:720px;height:720px;top:120px;right:-260px;background:radial-gradient(circle,var(--accent2),transparent 65%);opacity:.20}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:18px 28px;}
.nav.scrolled{background:rgba(7,8,12,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
  margin:0;max-width:none;padding-left:max(28px,calc((100vw - var(--maxw))/2 + 28px));padding-right:max(28px,calc((100vw - var(--maxw))/2 + 28px))}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:700;letter-spacing:.14em}
.brand-name{font-size:16px}
.brand-mark{width:16px;height:16px;border-radius:5px;background:conic-gradient(from 210deg,var(--signal),var(--signal2),var(--accent),var(--signal));
  box-shadow:0 0 14px rgba(245,178,62,.55)}
.nav-links{display:flex;gap:28px;margin-left:auto;font-size:14px}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover{color:#fff}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-display);font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:12px;color:#0a0a0a;
  background:linear-gradient(180deg,#ffd277,var(--signal));border:1px solid rgba(255,255,255,.2);
  box-shadow:0 8px 30px -8px rgba(245,178,62,.5);transition:transform .18s,box-shadow .18s;white-space:nowrap}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 38px -8px rgba(245,178,62,.65)}
.btn-sm{padding:9px 15px;font-size:13px}
.btn-lg{padding:14px 24px;font-size:15px;border-radius:14px}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{background:var(--panel);border-color:rgba(255,255,255,.22)}

/* hero */
.hero{max-width:var(--maxw);margin:0 auto;padding:44px 28px 60px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;min-height:auto}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);
  border:1px solid var(--line);background:var(--panel);padding:7px 13px;border-radius:999px;margin-bottom:24px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal);animation:pulse 2.4s infinite}
h1{font-family:var(--ff-display);font-weight:700;font-size:clamp(44px,6vw,76px);line-height:1.02;letter-spacing:-.02em}
.grad{background:linear-gradient(100deg,var(--signal),#ffd98a 40%,var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{color:#c2c9d6;font-size:clamp(16px,1.6vw,19px);max-width:560px;margin:24px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;align-items:center;gap:18px;margin-top:38px;color:var(--muted);font-size:14px;flex-wrap:wrap}
.hero-meta b{font-family:var(--ff-display);color:#fff;font-size:18px;margin-right:6px}
.hero-meta i{width:1px;height:20px;background:var(--line)}

/* hub-and-spoke */
.hero-visual{display:flex;justify-content:center}
.orbit{position:relative;width:min(440px,86vw);aspect-ratio:1}
.wires{position:absolute;inset:0;width:100%;height:100%}
.wires line{stroke:rgba(245,178,62,.32);stroke-width:1.3;stroke-dasharray:5 7;animation:dash 18s linear infinite}
.core{position:absolute;top:50%;left:50%;translate:-50% -50%;width:140px;height:140px;border-radius:24px;
  display:flex;align-items:center;justify-content:center;text-align:center;z-index:2;
  background:radial-gradient(circle at 50% 30%,rgba(245,178,62,.22),rgba(255,255,255,.03));
  border:1px solid rgba(245,178,62,.45);box-shadow:0 0 50px -6px rgba(245,178,62,.45),inset 0 0 30px rgba(245,178,62,.12)}
.core-label{font-family:var(--ff-display);font-weight:600;font-size:13px;letter-spacing:.08em;color:#ffe6b8}
.core-ring{position:absolute;inset:-14px;border:1px solid rgba(245,178,62,.25);border-radius:32px;animation:ripple 3.6s ease-out infinite}
.core-ring.r2{inset:-14px;animation-delay:1.8s}
.node{position:absolute;width:104px;display:flex;flex-direction:column;align-items:center;gap:7px;z-index:3}
.node .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:20px;color:#ffe6b8;
  background:var(--panel2);border:1px solid var(--line);box-shadow:0 8px 26px -10px rgba(0,0,0,.7)}
.node .ic svg{width:23px;height:23px}
.node label{font-size:12.5px;color:var(--muted)}
.n1{top:8%;left:2%}.n2{top:8%;right:2%}.n3{bottom:8%;left:2%}.n4{bottom:8%;right:2%}

/* sections */
.section{max-width:var(--maxw);margin:0 auto;padding:60px 28px}
.section.alt{max-width:none;background:linear-gradient(180deg,transparent,rgba(255,255,255,.018),transparent);border-block:1px solid var(--line)}
.section.alt > *{max-width:var(--maxw);margin-inline:auto}
.section-head{max-width:720px;margin-bottom:32px}
.kicker{font-family:var(--ff-display);font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);margin-bottom:14px}
h2{font-family:var(--ff-display);font-weight:700;font-size:clamp(28px,3.6vw,44px);line-height:1.08;letter-spacing:-.015em}
.section-head p{color:#bcc4d2;font-size:17px;margin-top:16px}

/* cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:transform .2s,border-color .2s,background .2s}
.card:hover{transform:translateY(-4px);border-color:rgba(245,178,62,.35);background:var(--panel2)}
.card-ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:22px;color:var(--signal);
  background:rgba(245,178,62,.10);border:1px solid rgba(245,178,62,.25);margin-bottom:18px}
.card h3{font-family:var(--ff-display);font-size:19px;font-weight:600;margin-bottom:9px}
.card p{color:var(--muted);font-size:14.5px}

.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.chan{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px;transition:transform .2s,border-color .2s}
.chan:hover{transform:translateY(-4px);border-color:rgba(109,155,255,.4)}
.chan-ic{font-size:24px;color:var(--accent);display:block;margin-bottom:14px}
.chan-ic svg{width:26px;height:26px;display:block}
.chan h3{font-family:var(--ff-display);font-size:17px;font-weight:600;margin-bottom:8px}
.chan p{color:var(--muted);font-size:13.5px}

/* split / intelligence */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split-copy p{color:#bcc4d2;font-size:16px;margin:16px 0 22px}
.ticks{list-style:none;display:flex;flex-direction:column;gap:12px}
.ticks li{position:relative;padding-left:30px;color:#d4dae5;font-size:15px}
.ticks li::before{content:"→";position:absolute;left:0;color:var(--signal);font-weight:700}
.panel{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:0 30px 80px -30px rgba(0,0,0,.8)}
.panel-top{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-family:var(--ff-display);margin-bottom:20px}
.panel-top b{color:var(--muted);font-weight:500;margin-left:6px}
.d{width:10px;height:10px;border-radius:50%}.d.red{background:#ff6b6b}.d.amb{background:var(--signal)}.d.grn{background:#4ade80}
.bars{display:flex;flex-direction:column;gap:14px}
.bar{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:12px;font-size:13px}
.bar label{color:var(--muted)}
.bar span{height:9px;border-radius:6px;background:rgba(255,255,255,.06);position:relative;overflow:hidden}
.bar span::after{content:"";position:absolute;inset:0;width:var(--w);border-radius:6px;background:linear-gradient(90deg,var(--signal2),var(--signal))}
.bar b{font-family:var(--ff-display);font-size:13px}
.panel-foot{margin-top:18px;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.panel-foot em{margin-left:auto;opacity:.6}
.pulse{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 10px #4ade80;animation:pulse 1.8s infinite}

/* demo */
.demo-wrap{display:grid;grid-template-columns:1.4fr .8fr;gap:28px;align-items:start}
.chat{background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:0 40px 100px -40px rgba(0,0,0,.85)}
.chat-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.chat-avatar{width:40px;height:40px;border-radius:12px;background:conic-gradient(from 200deg,var(--signal),var(--signal2),var(--accent));box-shadow:0 0 18px rgba(245,178,62,.4);flex:none}
.chat-head b{font-family:var(--ff-display);font-size:14.5px}
.chat-head small{display:block;color:var(--muted);font-size:12px}
.chat-live{margin-left:auto;font-size:12px;color:#4ade80;display:flex;align-items:center;gap:6px}
.chat-live i{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:pulse 1.8s infinite}
.chat-body{padding:20px 18px;height:380px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth}
.msg{max-width:82%;padding:11px 15px;border-radius:15px;font-size:14.5px;line-height:1.45;animation:rise .35s ease both}
.msg.bot{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);border-bottom-left-radius:5px}
.msg.me{align-self:flex-end;background:linear-gradient(180deg,#ffd277,var(--signal));color:#0a0a0a;border-bottom-right-radius:5px;font-weight:500}
.msg.bot.flag{border-color:rgba(245,178,62,.4);background:rgba(245,178,62,.07)}
.msg .tag{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--signal);margin-bottom:4px;font-weight:600}
.msg-src{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:10px;padding-top:9px;border-top:1px solid var(--line)}
.msg-src-lbl{font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-right:2px}
.src-chip{font-size:11px;color:#e7d6ad;background:rgba(245,178,62,.10);border:1px solid rgba(245,178,62,.28);padding:2px 8px;border-radius:999px}
.typing{align-self:flex-start;display:flex;gap:5px;padding:14px 16px;background:var(--panel2);border:1px solid var(--line);border-radius:15px;border-bottom-left-radius:5px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:blink 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
.chat-chips{display:flex;gap:8px;padding:2px 18px 6px;flex-wrap:nowrap;overflow-x:auto;
  scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;
  scrollbar-width:none;-ms-overflow-style:none}
.chat-chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;white-space:nowrap;scroll-snap-align:start;font-size:12.5px;color:#cdd4e0;background:var(--panel);border:1px solid var(--line);padding:7px 12px;border-radius:999px;cursor:pointer;transition:.18s}
.chip:hover{border-color:rgba(245,178,62,.5);color:#fff}
.chat-input{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line)}
.chat-input input{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:#fff;font-family:var(--ff-body);font-size:14.5px;outline:none}
.chat-input input:focus{border-color:rgba(245,178,62,.5)}
.send{width:46px;border:none;border-radius:12px;background:linear-gradient(180deg,#ffd277,var(--signal));color:#0a0a0a;font-size:18px;cursor:pointer;transition:.18s}
.send:hover{filter:brightness(1.08)}
.chat-disclaimer{font-size:11px;color:var(--muted);text-align:center;padding:0 18px 14px}
.demo-side{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:24px}
.demo-side h4{font-family:var(--ff-display);font-size:15px;margin-bottom:14px}
.demo-side ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:18px}
.demo-side li{position:relative;padding-left:24px;font-size:14px;color:#cdd4e0}
.demo-side li::before{content:"◆";position:absolute;left:0;color:var(--signal);font-size:11px;top:3px}
.demo-note{font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:16px}

/* CTA + foot */
.cta{max-width:880px;margin:24px auto 0;padding:52px 28px;text-align:center}
.cta h2{margin-bottom:14px}
.cta p{color:#bcc4d2;font-size:18px;margin-bottom:30px}
.foot{max-width:var(--maxw);margin:36px auto 0;padding:26px 28px 48px;border-top:1px solid var(--line);display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.foot p{color:var(--muted);font-size:13px;margin-left:auto}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* anims */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes dash{to{stroke-dashoffset:-200}}
@keyframes ripple{0%{transform:scale(.85);opacity:.6}100%{transform:scale(1.25);opacity:0}}

/* responsive */
@media(max-width:920px){
  .hero{grid-template-columns:1fr;padding-top:30px;min-height:auto}
  .hero-visual{order:-1;margin-bottom:10px}
  .split{grid-template-columns:1fr;gap:30px}
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .demo-wrap{grid-template-columns:1fr}
  .nav-links{display:none}
}
@media(max-width:560px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .hero-meta i{display:none}
  h1{font-size:clamp(38px,11vw,52px)}
}

/* ============ embedded chat widget on a mock candidate site ============ */
.siteframe{position:relative;display:flex;flex-direction:column;min-height:580px;
  background:#0c0d12;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 40px 100px -40px rgba(0,0,0,.85)}
.siteframe-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.03)}
.siteframe-url{margin-left:8px;font-size:12px;color:var(--muted);background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:8px;padding:4px 14px}

/* faux candidate landing page (light, so it clearly reads as THEIR website) */
.fakesite{flex:1;background:linear-gradient(180deg,#f5f7fb,#e8edf6);color:#1a2230;overflow:hidden}
.fakesite-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;border-bottom:1px solid rgba(0,0,0,.06)}
.fakesite-logo{font-family:var(--ff-display);font-weight:700;font-size:16px;letter-spacing:.02em;color:#0b2a5b}
.fakesite-logo b{color:#c1272d}
.fakesite-links{display:flex;align-items:center;gap:16px;font-size:12.5px;color:#3a4660}
.fakesite-donate{background:#c1272d;color:#fff;padding:6px 13px;border-radius:7px;font-weight:600}
.fakesite-hero{padding:46px 24px;max-width:440px}
.fakesite-eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#c1272d}
.fakesite-hero h3{font-family:var(--ff-display);font-size:clamp(24px,3.4vw,32px);line-height:1.06;color:#0b2a5b;margin:10px 0 8px}
.fakesite-hero p{font-size:14px;color:#46506a;margin-bottom:18px}
.fakesite-cta{display:flex;gap:10px;flex-wrap:wrap}
.fakesite-btn{background:#0b2a5b;color:#fff;font-weight:600;font-size:13px;padding:9px 16px;border-radius:8px}
.fakesite-btn.ghost{background:transparent;color:#0b2a5b;border:1px solid rgba(11,42,91,.3)}

/* the embedded Revere widget, pinned to the frame's corner */
.cwidget{position:absolute;right:16px;bottom:16px;z-index:5;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.cwidget-panel{width:min(360px,calc(100vw - 64px));height:min(468px,64vh);display:none}
.cwidget.open .cwidget-panel{display:block;animation:popin .22s ease both}
@keyframes popin{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:none}}
.cwidget-panel .chat{height:100%;display:flex;flex-direction:column;background:#0e1016;box-shadow:0 30px 70px -20px rgba(0,0,0,.85)}
.cwidget-panel .chat-body{height:auto;flex:1 1 auto;min-height:0}
.cwidget-launcher{position:relative;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  display:grid;place-items:center;color:#0a0a0a;
  background:conic-gradient(from 210deg,var(--signal),var(--signal2),var(--accent),var(--signal));
  box-shadow:0 14px 30px -8px rgba(245,178,62,.6);animation:fabpulse 2.8s ease-in-out infinite;transition:transform .2s}
.cwidget-launcher:hover{transform:scale(1.06)}
.cwidget-launcher svg{width:26px;height:26px}
.cwidget-launcher .ic-close{display:none}
.cwidget.open .cwidget-launcher{animation:none}
.cwidget.open .cwidget-launcher .ic-chat{display:none}
.cwidget.open .cwidget-launcher .ic-close{display:block}
.cwidget-badge{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;border-radius:9px;background:#c1272d;color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;padding:0 4px;border:2px solid #0c0d12}
.cwidget.open .cwidget-badge{display:none}
@keyframes fabpulse{
  0%,100%{box-shadow:0 14px 30px -8px rgba(245,178,62,.55),0 0 0 0 rgba(245,178,62,.40)}
  50%{box-shadow:0 14px 30px -8px rgba(245,178,62,.55),0 0 0 13px rgba(245,178,62,0)}
}
.chat-close{margin-left:auto;background:transparent;border:none;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}
.chat-close:hover{color:#fff}
.chat-id{min-width:0}
@media(max-width:560px){
  .siteframe{min-height:560px}
  .fakesite-links a:not(.fakesite-donate){display:none}
  /* center the popup inside the campaign frame (instead of corner-pinned) + dim the site behind it */
  .cwidget{display:contents}
  .cwidget-launcher{position:absolute;right:16px;bottom:16px;z-index:6}
  .cwidget-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    width:min(326px,calc(100% - 30px));height:min(420px,calc(100% - 96px));z-index:5}
  .cwidget.open .cwidget-panel{animation:popinCenter .22s ease both}
  .siteframe:has(.cwidget.open)::after{content:"";position:absolute;inset:0;background:rgba(2,4,10,.5);z-index:4}
  /* smaller, easier-to-read chat text on phones */
  .cwidget-panel .chat-head{padding:12px 14px}
  .cwidget-panel .chat-head b{font-size:12.5px}
  .cwidget-panel .chat-head small{font-size:10.5px}
  .cwidget-panel .chat-body{padding:13px 12px;gap:9px}
  .cwidget-panel .msg{font-size:12.5px;line-height:1.4;padding:8px 11px;max-width:88%}
  .cwidget-panel .chat-chips{padding:2px 12px 6px}
  .cwidget-panel .chip{font-size:11px;padding:5px 10px}
  .cwidget-panel .chat-input{padding:9px 12px}
  .cwidget-panel .chat-input input{font-size:13px;padding:9px 11px}
  .cwidget-panel .send{width:40px;font-size:16px}
  .cwidget-panel .chat-disclaimer{font-size:9.5px;padding:0 12px 9px}
}
@keyframes popinCenter{from{opacity:0;transform:translate(-50%,-46%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%)}}

/* ============ channel showcases (Text · Voice) ============ */
.showcase{display:grid;grid-template-columns:330px 1fr;gap:40px;align-items:start}
@media(max-width:920px){ .showcase{grid-template-columns:1fr;gap:28px;justify-items:center} .showcase-side{max-width:560px} }

/* iPhone */
.phone{display:flex;justify-content:center;width:100%}
.phone-frame{position:relative;width:300px;height:600px;border-radius:48px;
  background:linear-gradient(180deg,#0e1017,#0a0b10);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 0 0 9px #14161e,0 0 0 10px rgba(255,255,255,.05),0 40px 90px -28px rgba(0,0,0,.9);
  padding:13px 11px 0;display:flex;flex-direction:column;overflow:hidden}
.phone-island{position:absolute;top:13px;left:50%;translate:-50% 0;width:92px;height:25px;background:#000;border-radius:14px;z-index:6}
.phone-status{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:#fff;font-weight:600;padding:5px 14px 9px}
.imsg-head{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 0 10px;border-bottom:1px solid rgba(255,255,255,.06)}
.imsg-avatar{width:40px;height:40px;border-radius:50%;background:conic-gradient(from 200deg,var(--signal),var(--signal2),var(--accent))}
.imsg-who{text-align:center}
.imsg-who b{font-family:var(--ff-display);font-size:13px}
.imsg-who small{display:block;color:var(--muted);font-size:10.5px}
.imsg-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:12px 4px;scroll-behavior:smooth}
.imsg-body::-webkit-scrollbar{width:0}
.imsg-msg{max-width:80%;padding:8px 12px;border-radius:17px;font-size:13.5px;line-height:1.34;animation:rise .3s ease both;word-wrap:break-word}
.imsg-msg.them{align-self:flex-start;background:#26262b;color:#fff;border-bottom-left-radius:5px}
.imsg-msg.me{align-self:flex-end;background:linear-gradient(180deg,#37a0ff,#1f86ff);color:#fff;border-bottom-right-radius:5px}
.imsg-typing{align-self:flex-start;display:flex;gap:4px;padding:10px 12px;background:#26262b;border-radius:15px;border-bottom-left-radius:5px}
.imsg-typing.me{align-self:flex-end;background:#1f86ff;border-bottom-right-radius:5px;border-bottom-left-radius:15px}
.imsg-typing span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.65);animation:blink 1.2s infinite}
.imsg-typing span:nth-child(2){animation-delay:.2s}.imsg-typing span:nth-child(3){animation-delay:.4s}
.imsg-input{display:flex;justify-content:space-between;align-items:center;margin:4px 2px 9px;padding:7px 8px 7px 14px;border:1px solid rgba(255,255,255,.16);border-radius:18px;color:var(--muted);font-size:12.5px}
.imsg-send{width:23px;height:23px;border-radius:50%;background:#1f86ff;color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700}
.phone-home{width:116px;height:4px;border-radius:3px;background:rgba(255,255,255,.45);margin:0 auto 9px}

/* Instagram DM */
.ig{display:flex;justify-content:center;width:100%}
.ig-card{width:100%;max-width:330px;height:600px;display:flex;flex-direction:column;
  background:#0b0c11;border:1px solid var(--line);border-radius:24px;overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.9)}
.ig-head{display:flex;align-items:center;gap:9px;padding:13px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.ig-back{color:var(--muted);font-size:24px;line-height:1;margin-right:-2px}
.ig-avatar{width:34px;height:34px;border-radius:50%;flex:none;position:relative;padding:2px;
  background:conic-gradient(from 10deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5,#feda75)}
.ig-avatar::after{content:"";position:absolute;inset:3px;border-radius:50%;background:radial-gradient(circle at 50% 32%,var(--signal),var(--signal2))}
.ig-who{flex:1;min-width:0}
.ig-who b{display:flex;align-items:center;gap:4px;font-size:13.5px;font-family:var(--ff-display)}
.ig-who small{display:block;color:var(--muted);font-size:11px}
.ig-verified{width:13px;height:13px;flex:none}
.ig-actions{display:flex;gap:15px;color:#fff;opacity:.85}
.ig-actions svg{width:21px;height:21px}
.ig-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:14px 12px;scroll-behavior:smooth}
.ig-body::-webkit-scrollbar{width:0}
.ig-msg{max-width:80%;padding:9px 13px;border-radius:20px;font-size:13.5px;line-height:1.34;animation:rise .3s ease both;word-wrap:break-word}
.ig-msg.them{align-self:flex-start;background:#262630;color:#fff;border-bottom-left-radius:6px}
.ig-msg.me{align-self:flex-end;color:#fff;border-bottom-right-radius:6px;background:linear-gradient(118deg,#5b51d8,#a033c4 55%,#e0518a)}
.ig-typing{align-self:flex-start;display:flex;gap:4px;padding:11px 13px;background:#262630;border-radius:18px;border-bottom-left-radius:6px}
.ig-typing span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.6);animation:blink 1.2s infinite}
.ig-typing span:nth-child(2){animation-delay:.2s}.ig-typing span:nth-child(3){animation-delay:.4s}
.ig-input{display:flex;align-items:center;justify-content:space-between;margin:8px 12px 12px;padding:9px 14px;border:1px solid rgba(255,255,255,.16);border-radius:20px;color:var(--muted);font-size:13px}
.ig-icons{opacity:.7;letter-spacing:1px}

/* call screen */
.call{display:flex;justify-content:center;width:100%}
.call-card{width:100%;max-width:380px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 40px 100px -40px rgba(0,0,0,.85)}
.call-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.call-avatar{width:46px;height:46px;border-radius:50%;background:conic-gradient(from 200deg,var(--signal),var(--signal2),var(--accent));flex:none}
.call-who b{font-family:var(--ff-display);font-size:15px}
.call-who small{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;margin-top:2px}
.call-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:pulse 1.8s infinite}
.wave{display:flex;align-items:center;justify-content:center;gap:3px;height:46px;margin:4px 0 16px}
.wave span{width:3px;height:7px;border-radius:3px;background:linear-gradient(180deg,var(--signal),var(--accent));animation:wv 1s ease-in-out infinite}
@keyframes wv{0%,100%{height:7px;opacity:.45}50%{height:32px;opacity:1}}
.call-transcript{display:flex;flex-direction:column;gap:13px;max-height:300px;overflow-y:auto;scroll-behavior:smooth}
.call-transcript::-webkit-scrollbar{width:0}
.vline{animation:rise .3s ease both}
.vwho{display:block;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.vline.ai .vwho{color:var(--signal)}
.vtext{font-size:14px;line-height:1.45;color:#d4dae5}
.vline.ai .vtext{color:#fff}

/* shared side panel */
.showcase-side{display:flex;flex-direction:column;gap:18px;width:100%}
.stat-row{display:flex;gap:14px}
.stat{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.stat b{font-family:var(--ff-display);font-size:25px;line-height:1;display:block;margin-bottom:5px;background:linear-gradient(100deg,var(--signal),#ffd98a);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{font-size:12.5px;color:var(--muted)}
.showcase-side h4{font-family:var(--ff-display);font-size:15px;margin-bottom:11px}
.cap-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.cap-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:13.5px;color:#d4dae5;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:9px 13px}
.cap-list li span{font-size:11px;color:var(--signal);background:rgba(245,178,62,.10);border:1px solid rgba(245,178,62,.25);padding:2px 8px;border-radius:999px;white-space:nowrap}
.cap-list.plain li{display:block;color:#cdd4e0}
.vs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vs-col{border:1px solid var(--line);border-radius:14px;padding:14px 15px}
.vs-col.good{border-color:rgba(245,178,62,.3);background:rgba(245,178,62,.045)}
.vs-col h5{font-family:var(--ff-display);font-size:12.5px;margin-bottom:10px}
.vs-col ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.vs-col li{font-size:12.5px;color:var(--muted);padding-left:18px;position:relative}
.vs-col.bad li::before{content:"✕";position:absolute;left:0;color:#ff6b6b;font-size:11px}
.vs-col.good li{color:#d4dae5}
.vs-col.good li::before{content:"✓";position:absolute;left:0;color:#4ade80;font-size:11px}

/* ============ dashboard ============ */
.dash{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:0 40px 100px -40px rgba(0,0,0,.85)}
.dash-bar{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-family:var(--ff-display);margin-bottom:18px;flex-wrap:wrap}
.dash-bar b{color:var(--muted);font-weight:500;margin-left:4px}
.dash-live{margin-left:auto;display:flex;align-items:center;gap:6px;color:#4ade80}
.dash-illus{opacity:.55;font-style:italic}
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.w{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px}
.w h5{font-family:var(--ff-display);font-size:12.5px;color:#cdd4e0;margin-bottom:13px}
.w.wide{grid-column:span 2}
.w .bars{gap:10px}
.w .bar{grid-template-columns:78px 1fr auto;font-size:12px}
.kpi span{font-size:12px;color:var(--muted)}
.kpi b{font-family:var(--ff-display);font-size:25px;display:block;margin:5px 0 3px}
.kpi i{font-size:12px;font-style:normal}
.kpi i.up{color:#4ade80}
.big-num{font-family:var(--ff-display);font-size:30px;display:block;margin-bottom:6px}
.w-sub{font-size:12px;color:var(--muted)}
.funnel{display:flex;flex-direction:column;gap:9px}
.fn{display:flex;align-items:center;gap:12px;font-size:12.5px}
.fn label{color:var(--muted);width:92px;flex:none}
.fn span{height:26px;border-radius:6px;background:linear-gradient(90deg,var(--signal2),var(--signal));display:flex;align-items:center;padding:0 11px;color:#0a0a0a;font-weight:600;font-size:12px;min-width:54px}
.split-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;border:1px solid var(--line)}
.split-bar i{display:block;height:100%}
.split-bar .en{background:linear-gradient(90deg,var(--signal2),var(--signal))}
.split-bar .es{background:linear-gradient(90deg,var(--accent2),var(--accent))}
.split-leg{display:flex;justify-content:space-between;gap:14px;margin-top:8px;font-size:11.5px;color:var(--muted)}
.msg-donate{display:inline-flex;align-items:center;gap:8px;margin-top:10px;padding:8px 14px;border-radius:10px;font-family:var(--ff-display);font-weight:600;font-size:13px;color:#0a0a0a;background:linear-gradient(180deg,#ffd277,var(--signal));border:1px solid rgba(255,255,255,.22);box-shadow:0 6px 18px -6px rgba(245,178,62,.55);transition:transform .15s,box-shadow .15s;text-decoration:none}
.msg-donate:hover{transform:translateY(-1px);box-shadow:0 10px 24px -6px rgba(245,178,62,.7)}

/* post-chat survey */
/* exit survey — contained INSIDE the candidate-site frame (a feature of the chat widget) */
.survey-overlay{position:absolute;inset:0;z-index:30;background:rgba(4,6,12,.74);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:18px;animation:fadein .25s ease both}
.survey-overlay.open{display:flex}
.survey{position:relative;background:linear-gradient(180deg,#161821,#0e1016);border:1px solid var(--line);border-radius:16px;padding:18px;width:min(332px,100%);box-shadow:0 30px 70px -20px rgba(0,0,0,.85);animation:slideup .3s cubic-bezier(.2,.7,.2,1) both}
.survey-x{position:absolute;top:10px;right:12px;width:30px;height:30px;border:none;background:transparent;color:var(--muted);font-size:22px;cursor:pointer;border-radius:8px}
.survey-x:hover{color:#fff;background:var(--panel)}
.survey-kicker{font-family:var(--ff-display);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--signal)}
.survey-head h3{font-family:var(--ff-display);font-size:18px;font-weight:600;margin:7px 0 5px}
.survey-head p{color:var(--muted);font-size:12.5px;line-height:1.4;margin-bottom:14px}
.survey-q1{display:flex;gap:8px;margin-bottom:14px}
.survey-opt{flex:1;padding:10px 12px;border-radius:11px;background:var(--panel);border:1px solid var(--line);color:#cdd4e0;font-family:var(--ff-body);font-size:13.5px;cursor:pointer;transition:.15s}
.survey-opt:hover{border-color:rgba(245,178,62,.5);color:#fff}
.survey-opt.on{border-color:var(--signal);background:rgba(245,178,62,.12);color:#fff}
.survey-q2{display:block;font-size:12.5px;color:var(--muted);margin-bottom:14px}
.survey-q2 span{display:block;margin-bottom:6px}
.survey-q2 em{font-style:normal;color:var(--muted);opacity:.7}
.survey-q2 input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:#fff;font-family:var(--ff-body);font-size:13.5px;outline:none}
.survey-q2 input:focus{border-color:rgba(245,178,62,.5)}
.survey-actions{display:flex;gap:8px;justify-content:flex-end}
.survey-actions .btn:disabled{opacity:.5;pointer-events:none}
.survey-thanks{margin-top:12px;font-size:13px;color:#4ade80;text-align:center;padding:9px;border-radius:8px;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.25)}
@keyframes fadein{from{opacity:0}to{opacity:1}}
@keyframes slideup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.intel-feed{list-style:none;display:flex;flex-direction:column;gap:7px;max-height:188px;overflow:hidden;font-size:12px;color:#cdd4e0}
.intel-feed li{display:flex;align-items:baseline;gap:7px;padding:5px 8px;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:8px;animation:rise .35s ease both}
.intel-feed li b{font-family:var(--ff-display);color:var(--signal);font-weight:600;font-size:11px}
.intel-feed li.muted{justify-content:center;border-style:dashed;color:var(--muted)}
.intel-feed time{margin-left:auto;color:var(--muted);font-size:10.5px;flex:none}
.intel-feed .pill{display:inline-block;padding:1px 7px;border-radius:999px;background:rgba(245,178,62,.10);border:1px solid rgba(245,178,62,.28);font-size:10px;color:#e7d6ad;text-transform:uppercase;letter-spacing:.05em;font-family:var(--ff-display)}
.dash-why{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.dash-why li{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--signal);border-radius:12px;padding:15px 16px;font-size:13.5px;color:#cdd4e0}
.dash-why b{display:block;font-family:var(--ff-display);color:#fff;margin-bottom:5px;font-size:14px}
@media(max-width:920px){ .dash-grid{grid-template-columns:repeat(2,1fr)} .dash-why{grid-template-columns:1fr} }
@media(max-width:560px){ .dash-grid{grid-template-columns:1fr} .w.wide{grid-column:span 1} .vs{grid-template-columns:1fr} }
