:root{
  --paper:#FAF8F3;
  --paper-2:#F1EDE4;
  --ink:#16181D;
  --ink-2:#23262E;
  --ink-3:#31353F;
  --text:#2B2E35;
  --muted:#5F646E;
  --muted-light:#9BA1AC;
  --brand:#ED751C;
  --brand-bright:#FF8A33;
  --brand-dim:rgba(237,117,28,.1);
  --live:#1FBF7A;
  --live-bright:#2BD98D;
  --line:rgba(22,24,29,.12);
  --line-dark:rgba(250,248,243,.12);
  --radius:14px;
  --font-display:"Hanken Grotesk",sans-serif;
  --font-body:"Hanken Grotesk",sans-serif;
  --font-mono:"IBM Plex Mono",monospace;
  --shadow-card:0 1px 2px rgba(22,24,29,.05),0 8px 28px rgba(22,24,29,.07);
  --shadow-lift:0 2px 4px rgba(22,24,29,.06),0 18px 44px rgba(22,24,29,.13);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--brand);color:#fff}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.1;letter-spacing:-.02em;font-weight:800}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.mono{font-family:var(--font-mono)}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ---------- status dots ---------- */
.dot{position:relative;width:9px;height:9px;border-radius:50%;background:var(--live);display:inline-block;flex:none}
.dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid var(--live);opacity:0;animation:ping 2.4s cubic-bezier(0,0,.2,1) infinite}
.dot.orange{background:var(--brand)}
.dot.orange::after{border-color:var(--brand)}
@keyframes ping{0%{transform:scale(.5);opacity:.9}70%,100%{transform:scale(1.6);opacity:0}}

/* ---------- top ticker ---------- */
.ticker{background:var(--ink);color:var(--muted-light);font-family:var(--font-mono);font-size:11.5px;letter-spacing:.06em;padding:8px 0;position:relative;z-index:60}
.ticker .wrap{display:flex;justify-content:space-between;gap:6px 18px;align-items:center;flex-wrap:wrap}
.ticker .stat{display:flex;align-items:center;gap:8px;white-space:nowrap}
.ticker .stat b{color:#F2EFE8;font-weight:500}
.ticker a:hover b{color:var(--brand-bright)}
@media(max-width:920px){.ticker .hide-m{display:none}}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,248,243,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s;
}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(22,24,29,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo img{height:34px;width:auto}
.nav-links{display:flex;gap:34px;font-weight:600;font-size:15px;color:var(--ink-2)}
.nav-links a{position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--brand);transition:width .3s cubic-bezier(.22,1,.36,1)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-weight:700;font-size:15px;
  padding:13px 24px;border-radius:11px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,background .25s,color .25s,border-color .25s;
  white-space:nowrap;
}
.btn .short{display:none}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(22,24,29,.22);background:var(--ink-3)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-1px)}
.btn-accent{background:var(--brand);color:#fff}
.btn-accent:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(237,117,28,.32);background:var(--brand-bright)}
.btn svg{width:16px;height:16px;transition:transform .25s}
.btn:hover svg{transform:translateX(3px)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}
@media(max-width:920px){
  .nav-links,.nav-cta .btn-ghost{display:none}
  .menu-btn{display:block}
  .mobile-menu{position:fixed;inset:76px 0 auto 0;background:var(--paper);border-bottom:1px solid var(--line);padding:18px 28px 26px;display:none;flex-direction:column;gap:4px;z-index:49;box-shadow:0 24px 48px rgba(22,24,29,.12)}
  .mobile-menu.open{display:flex}
  .mobile-menu a{padding:13px 4px;font-weight:600;font-size:17px;border-bottom:1px solid var(--line)}
  .mobile-menu a:last-child{border:none}
}
@media(min-width:921px){.mobile-menu{display:none!important}}
@media(max-width:560px){
  .logo img{height:26px}
  .nav-cta .btn-primary{padding:11px 16px;font-size:13.5px}
  .nav-cta .btn-primary .long{display:none}
  .nav-cta .btn-primary .short{display:inline}
}

/* ---------- hero ---------- */
.hero{position:relative;padding:88px 0 96px;overflow:hidden}
.hero-grid-bg{display:none}
.hero-glow{display:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:24px;
}
.hero h1{font-size:clamp(40px,5.2vw,64px);margin-bottom:24px}
.hero h1 em{font-style:normal;color:var(--brand)}
.hero p.lede{font-size:19px;color:var(--muted);max-width:52ch;margin-bottom:36px}
.hero p.lede b{color:var(--ink);font-weight:700}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-proof{display:flex;gap:28px;flex-wrap:wrap;font-size:13.5px;color:var(--muted)}
.hero-proof span{display:flex;align-items:center;gap:8px}
.hero-proof svg{width:17px;height:17px;flex:none}

/* hero panel (status card) */
.hero-panel{position:relative}
.panel{
  background:var(--ink);border-radius:20px;padding:28px;color:#DDD9D0;
  box-shadow:0 30px 80px rgba(22,24,29,.35);
  font-size:14px;position:relative;overflow:hidden;
}
.panel::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 85% 0%,rgba(237,117,28,.14),transparent 55%);
}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-light)}
.panel-head .live-tag{display:flex;align-items:center;gap:8px;color:var(--live-bright)}
.panel-rows{display:flex;flex-direction:column;gap:10px}
.prow{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:rgba(250,248,243,.05);border:1px solid var(--line-dark);
  border-radius:12px;padding:14px 16px;
  transition:background .3s;
}
.prow:hover{background:rgba(250,248,243,.09)}
.prow .l{display:flex;align-items:center;gap:12px;min-width:0}
.prow .ic{width:34px;height:34px;border-radius:9px;background:rgba(237,117,28,.15);display:grid;place-items:center;flex:none}
.prow .ic svg{width:17px;height:17px}
.prow .t b{display:block;color:#F7F4EE;font-weight:600;font-size:13.5px}
.prow .t span{font-size:12px;color:var(--muted-light)}
.prow .s{font-family:var(--font-mono);font-size:11px;color:var(--live-bright);display:flex;align-items:center;gap:7px;white-space:nowrap}
.prow .s i{width:6px;height:6px;border-radius:50%;background:var(--live);display:inline-block;animation:blink 2s infinite}
.prow:nth-child(2) .s i{animation-delay:.5s}
.prow:nth-child(3) .s i{animation-delay:1s}
.prow:nth-child(4) .s i{animation-delay:1.5s}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.panel-foot{margin-top:20px;padding-top:18px;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:11px;color:var(--muted-light)}
.panel-foot b{color:var(--live-bright);font-weight:500}
@media(max-width:980px){
  .hero{padding:56px 0 72px}
  .hero-inner{grid-template-columns:1fr;gap:56px}
}

/* ---------- trust band ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2);padding:22px 0}
.trust .wrap{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.trust .item{display:flex;align-items:center;gap:11px;font-weight:600;font-size:14px;color:var(--ink-2)}
.trust .item svg{width:22px;height:22px;flex:none}
.trust .item small{display:block;font-weight:500;color:var(--muted);font-size:12px}
@media(max-width:760px){.trust .wrap{justify-content:flex-start}}

/* ---------- sections ---------- */
section{padding:104px 0}
.sec-head{max-width:680px;margin-bottom:60px}
.kicker{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);font-weight:700;margin-bottom:16px}
.sec-head h2{font-size:clamp(30px,3.6vw,44px);margin-bottom:18px}
.sec-head p{font-size:17.5px;color:var(--muted)}
.dark .sec-head h2{color:#F7F4EE}
.dark .sec-head p{color:var(--muted-light)}
.dark .kicker{color:var(--brand-bright)}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;position:relative;
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
  box-shadow:var(--shadow-card);
}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:rgba(237,117,28,.45)}
.svc .ic{
  width:48px;height:48px;border-radius:12px;background:var(--brand-dim);
  display:grid;place-items:center;margin-bottom:22px;
}
.svc h3{font-size:20px;font-weight:700;margin-bottom:10px}
.svc p{font-size:14.5px;color:var(--muted)}
.svc.wide{grid-column:span 3;display:grid;grid-template-columns:48px 1fr auto;gap:22px;align-items:center;padding:26px 28px}
.svc.wide .ic{margin:0}
.svc.wide h3{margin-bottom:4px}
.svc.wide .go{font-size:12.5px;letter-spacing:.08em;color:var(--brand);font-weight:700;display:flex;align-items:center;gap:8px;white-space:nowrap}
.svc-cat{font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--muted);margin:46px 0 18px;display:flex;align-items:center;gap:14px}
.svc-cat::after{content:"";flex:1;height:1px;background:var(--line)}
@media(max-width:920px){
  .svc-grid{grid-template-columns:1fr 1fr}
  .svc.wide{grid-column:span 2;grid-template-columns:48px 1fr}
  .svc.wide .go{display:none}
}
@media(max-width:600px){
  .svc-grid{grid-template-columns:1fr}
  .svc.wide{grid-column:span 1}
}

/* ---------- switch / process (dark) ---------- */
.dark{background:var(--ink);color:#CFCBC2;position:relative;overflow:hidden}
.dark .grid-bg{display:none}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.step{padding:34px 28px 10px;border-left:1px solid var(--line-dark);position:relative}
.step:first-child{border-left:none;padding-left:0}
.step .num{
  font-size:12.5px;font-weight:700;color:var(--brand-bright);
  display:flex;align-items:center;gap:10px;margin-bottom:20px;letter-spacing:.1em;
}
.step .num i{width:8px;height:8px;border-radius:50%;background:var(--brand);flex:none;box-shadow:0 0 0 4px rgba(237,117,28,.18)}
.step h3{color:#F7F4EE;font-size:19px;margin-bottom:12px;font-weight:700}
.step p{font-size:14px;color:var(--muted-light)}
.switch-note{
  margin-top:64px;background:rgba(237,117,28,.09);border:1px solid rgba(237,117,28,.3);
  border-radius:var(--radius);padding:26px 30px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between;
}
.switch-note p{color:#F3E9DD;font-size:15.5px;max-width:62ch}
.switch-note p b{color:#fff}
@media(max-width:920px){
  .steps{grid-template-columns:1fr 1fr}
  .step{padding:30px 24px 10px}
  .step:nth-child(odd){border-left:none;padding-left:0}
}
@media(max-width:600px){
  .steps{grid-template-columns:1fr}
  .step{border-left:none;padding:26px 0 8px;border-top:1px solid var(--line-dark)}
  .step:first-child{border-top:none}
}

/* ---------- why us ---------- */
.why-inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:72px;align-items:start}
.why-sticky{position:sticky;top:120px}
.why-list{display:flex;flex-direction:column;gap:14px}
.why{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 28px;display:grid;grid-template-columns:46px 1fr;gap:20px;
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
  box-shadow:var(--shadow-card);
}
.why:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);border-color:rgba(237,117,28,.4)}
.why .ic{width:46px;height:46px;border-radius:12px;background:var(--ink);display:grid;place-items:center}
.why .ic svg{width:21px;height:21px}
.why h3{font-size:17.5px;font-weight:700;margin-bottom:6px}
.why p{font-size:14.5px;color:var(--muted)}
@media(max-width:920px){.why-inner{grid-template-columns:1fr;gap:48px}.why-sticky{position:static}}

/* ---------- testimonials ---------- */
.testi{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;
  display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-card);
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s;
}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.tcard .q{font-size:15.5px;color:var(--text);font-weight:500;flex:1}
.tcard .q::before{
  content:"“";display:block;font-family:var(--font-display);font-size:52px;line-height:.6;
  color:var(--brand);margin-bottom:14px;font-weight:800;
}
.tcard .who{display:flex;align-items:center;gap:13px;border-top:1px solid var(--line);padding-top:18px}
.tcard .av{
  width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--brand-bright);
  display:grid;place-items:center;font-size:13px;font-weight:700;flex:none;
}
.tcard .who b{display:block;font-size:14px;color:var(--ink)}
.tcard .who span{font-size:12.5px;color:var(--muted)}
.tcard.feature{background:var(--ink);border-color:var(--ink)}
.tcard.feature .q{color:#F0EDE6;font-size:17px}
.tcard.feature .who{border-top-color:var(--line-dark)}
.tcard.feature .who b{color:#fff}
.tcard.feature .who span{color:var(--muted-light)}
.tcard.feature .av{background:var(--brand);color:#fff}
.tcard.invite{background:var(--brand-dim);border-color:rgba(237,117,28,.4);justify-content:center;align-items:flex-start}
@media(max-width:920px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.testi-grid{grid-template-columns:1fr}}

/* ---------- CTA / contact ---------- */
.cta{padding:110px 0}
.cta-card{
  background:var(--ink);border-radius:24px;padding:72px 64px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:start;
  box-shadow:0 40px 90px rgba(22,24,29,.3);
}
.cta-card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 15% 110%,rgba(237,117,28,.2),transparent 50%);
}
.cta-card h2{color:#fff;font-size:clamp(30px,3.6vw,44px);margin-bottom:18px;position:relative}
.cta-card>div{position:relative}
.cta-card p{color:var(--muted-light);font-size:17px;margin-bottom:34px;max-width:46ch}
.cta-contact{display:flex;flex-direction:column;gap:14px}
.crow{
  display:flex;align-items:center;gap:16px;background:rgba(250,248,243,.06);
  border:1px solid var(--line-dark);border-radius:12px;padding:17px 20px;
  transition:background .3s;
}
.crow:hover{background:rgba(250,248,243,.11)}
.crow .ic{width:40px;height:40px;border-radius:11px;background:rgba(237,117,28,.16);display:grid;place-items:center;flex:none}
.crow .ic svg{width:18px;height:18px}
.crow b{display:block;color:#fff;font-size:15px;font-weight:600}
.crow span{font-size:12px;color:var(--muted-light);letter-spacing:.06em}
@media(max-width:920px){.cta-card{grid-template-columns:1fr;padding:52px 36px;gap:44px}}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#CFCBC2;padding:64px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;margin-bottom:52px}
.foot-grid h4{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-light);margin-bottom:18px;font-weight:700}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:11px;font-size:14.5px;color:#DDD9D0}
.foot-grid ul a{transition:color .2s}
.foot-grid ul a:hover{color:var(--brand-bright);text-decoration:underline;text-underline-offset:3px}
.foot-brand img{height:38px;width:auto}
.foot-brand p{font-size:14px;color:var(--muted-light);margin-top:18px;max-width:30ch}
.foot-bottom{border-top:1px solid var(--line-dark);padding-top:26px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--muted-light)}
.foot-bottom .mono{font-size:11.5px;display:flex;align-items:center;gap:8px}
@media(max-width:920px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.foot-grid{grid-template-columns:1fr}}

/* ---------- subpages ---------- */
.page-hero{position:relative;padding:64px 0 72px;overflow:hidden}
.page-hero .inner{position:relative;max-width:820px}
.breadcrumb{font-size:12.5px;letter-spacing:.06em;font-weight:600;color:var(--muted);margin-bottom:24px;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.breadcrumb a{transition:color .2s}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb span.sep{color:var(--muted-light)}
.page-hero h1{font-size:clamp(34px,4.6vw,52px);margin-bottom:22px}
.page-hero h1 em{font-style:normal;color:var(--brand)}
.prose{max-width:780px;font-size:16.5px;color:var(--text)}
.prose p{margin-bottom:18px}
.prose p:last-child{margin-bottom:0}
.prose b{color:var(--ink)}
.faq{display:flex;flex-direction:column;gap:12px;max-width:840px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card)}
.faq summary{cursor:pointer;font-weight:700;font-family:var(--font-display);font-size:17px;color:var(--ink);padding:20px 24px;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--brand);flex:none;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 24px 22px;color:var(--muted);font-size:15px;max-width:64ch}
section.tight{padding:84px 0}

/* ---------- nav services dropdown ---------- */
.nav-drop{position:relative}
.nav-drop>a{display:inline-flex;align-items:center;gap:7px}
.nav-drop .chev{width:11px;height:11px;transition:transform .25s}
.nav-drop:hover .chev{transform:rotate(180deg)}
.drop-panel{position:absolute;top:100%;left:-24px;padding-top:16px;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s cubic-bezier(.22,1,.36,1),transform .25s cubic-bezier(.22,1,.36,1),visibility .25s;z-index:55}
.nav-drop:hover .drop-panel,.nav-drop:focus-within .drop-panel{opacity:1;visibility:visible;transform:none}
.drop-inner{display:flex;gap:10px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lift);padding:16px}
.drop-col{min-width:225px;display:flex;flex-direction:column;gap:2px}
.drop-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--muted);padding:6px 12px 8px}
.drop-col a{padding:9px 12px;border-radius:9px;font-weight:600;font-size:14px;color:var(--ink-2);transition:background .2s,color .2s}
.drop-col a::after{display:none!important}
.drop-col a:hover{background:var(--brand-dim);color:var(--ink)}
.mm-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--muted);padding:16px 4px 6px}
.mobile-menu{max-height:calc(100dvh - 150px);overflow:auto}

/* ---------- live motion ---------- */
.prow .s .st{display:inline-block;font-weight:500}
.prow .s.checking{color:#E8B441}
.prow .s.checking i{background:#E8B441;animation:blink .7s infinite}
.prow .s.flip .st{animation:statusPop .45s cubic-bezier(.34,1.56,.64,1)}
@keyframes statusPop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
.panel{transition:transform .35s ease;will-change:transform}

.trust{position:relative;overflow:hidden}
.trust .pulse{position:absolute;inset:0;width:100%;height:100%;opacity:.18;pointer-events:none}
.trust .pulse path{stroke:var(--brand);stroke-width:2;fill:none;stroke-dasharray:1200 1200;animation:pulseDraw 8s linear infinite}
@keyframes pulseDraw{from{stroke-dashoffset:2400}to{stroke-dashoffset:0}}
.trust .wrap{position:relative}

.hero h1 em,.page-hero h1 em{position:relative;white-space:nowrap}
.hero h1 em::after,.page-hero h1 em::after{
  content:"";position:absolute;left:1px;right:1px;bottom:-3px;height:3px;border-radius:2px;
  background:var(--brand);transform:scaleX(0);transform-origin:left;
  animation:drawLine .9s cubic-bezier(.22,1,.36,1) 1s forwards;
}
@keyframes drawLine{to{transform:scaleX(1)}}

.svc .ic{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.svc:hover .ic{transform:scale(1.08)}

.steps::before{content:"";position:absolute;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--brand-bright));width:0;transition:width 1.4s cubic-bezier(.22,1,.36,1) .2s}
.steps.drawn::before{width:100%}
.steps .step{padding-top:34px}

.cta-card::before{animation:glowDrift 9s ease-in-out infinite alternate}
@keyframes glowDrift{from{opacity:.65}to{opacity:1;transform:translate3d(50px,-35px,0) scale(1.08)}}

/* ---------- meet the team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.tm{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 24px 26px;text-align:center;box-shadow:var(--shadow-card);
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
}
.tm:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:rgba(237,117,28,.4)}
.tm .ph{
  width:120px;height:120px;border-radius:50%;margin:0 auto 18px;overflow:hidden;
  background:var(--brand-dim);border:1px solid var(--line);
  display:grid;place-items:center;position:relative;
}
.tm .ph img{width:100%;height:100%;object-fit:cover}
.tm .ph svg{width:56px;height:56px;color:var(--muted-light)}
.tm .ph .ini{font-family:var(--font-display);font-weight:800;font-size:38px;color:var(--ink);letter-spacing:.01em}
.tm .ph::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:inset 0 0 0 3px rgba(237,117,28,.0);transition:box-shadow .3s}
.tm:hover .ph::after{box-shadow:inset 0 0 0 3px rgba(237,117,28,.5)}
.tm h3{font-size:18px;font-weight:700;margin-bottom:3px}
.tm .role{color:var(--brand);font-weight:700;font-size:13px;letter-spacing:.02em}
.tm p{font-size:13.5px;color:var(--muted);margin-top:12px;line-height:1.55}
.team-note{margin-top:36px;text-align:center;font-size:15px;color:var(--muted)}
.team-note a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:3px}
@media(max-width:920px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}

/* ---------- legal / terms page ---------- */
.legal{max-width:864px;margin:0 auto;font-size:15.5px;color:var(--text)}
.legal p{margin:0 0 14px}
.legal h2{font-size:clamp(24px,2.6vw,32px);margin:56px 0 8px;padding-top:24px;border-top:1px solid var(--line)}
.legal h3{font-size:21px;margin:40px 0 6px}
.legal h4{font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:6px 0 18px;font-weight:700}
.legal ol{list-style:none;margin:0;padding:0}
.legal ol.d1{counter-reset:l1}
.legal ol.d1>li{counter-increment:l1;margin-top:30px;padding-left:2.5em;position:relative}
.legal ol.d2{counter-reset:l2;margin-top:6px}
.legal ol.d2>li{counter-increment:l2;margin:12px 0;padding-left:3.1em;position:relative}
.legal ol.d3{counter-reset:l3;margin-top:6px}
.legal ol.d3>li{counter-increment:l3;margin:8px 0;padding-left:2.6em;position:relative}
.legal ol.d4{counter-reset:l4;margin-top:6px}
.legal ol.d4>li{counter-increment:l4;margin:8px 0;padding-left:2.6em;position:relative}
.legal li>.lead{display:block}
.legal ol.d1>li>.lead{font-family:var(--font-display);font-weight:800;font-size:19px;color:var(--ink);line-height:1.3}
.legal ol.d1>li>.lead::before{content:counter(l1) ".";position:absolute;left:0;color:var(--brand);font-weight:800}
.legal ol.d1>li>.lead strong{font-weight:800}
.legal ol.d2>li>.lead::before{content:counter(l1) "." counter(l2);position:absolute;left:0;font-weight:700;color:var(--ink-2)}
.legal ol.d3>li>.lead::before{content:"(" counter(l3,lower-alpha) ")";position:absolute;left:0;color:var(--muted);font-weight:600}
.legal ol.d4>li>.lead::before{content:"(" counter(l4,lower-roman) ")";position:absolute;left:0;color:var(--muted);font-weight:600}
.legal p.defn{margin:8px 0 8px 0;padding-left:1.2em}
.legal p.defn strong{color:var(--ink)}
.tc-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:14.5px}
.tc-table th,.tc-table td{border:1px solid var(--line);padding:12px 14px;text-align:left;vertical-align:top}
.tc-table th{background:var(--paper-2);font-weight:700;color:var(--ink);width:34%}
.legal-meta{color:var(--muted);font-size:14px;margin-bottom:8px}
.legal-intro{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin-bottom:40px;font-size:14.5px;color:var(--muted)}
@media(max-width:600px){
  .legal ol.d1>li{padding-left:2.1em}
  .legal ol.d2>li{padding-left:2.7em}
  .tc-table th{width:auto}
  .tc-table,.tc-table tbody,.tc-table tr,.tc-table th,.tc-table td{display:block;width:auto}
  .tc-table th{border-bottom:none}
}

/* ---------- blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.post-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:28px 26px;box-shadow:var(--shadow-card);
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:rgba(237,117,28,.45)}
.post-cat{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--brand);margin-bottom:12px}
.post-card h3{font-size:19px;font-weight:700;line-height:1.25;margin-bottom:10px}
.post-card p{font-size:14.5px;color:var(--muted);flex:1;margin-bottom:18px}
.post-meta{font-size:13px;color:var(--muted-light);font-weight:600;letter-spacing:.02em}
article.prose{max-width:760px}
article.prose h2{font-size:24px;margin:34px 0 12px;line-height:1.2}
article.prose ul{margin:0 0 18px;padding-left:22px}
article.prose li{margin:7px 0;font-size:16px}
article.prose a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.page-hero .post-meta{font-size:14px;margin-top:4px}
@media(max-width:920px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}

/* ---------- contact form (Athena lead capture) ---------- */
.cta-form h3{color:#fff;font-size:19px;font-weight:700;margin-bottom:16px}
.cf{display:flex;flex-direction:column;gap:13px}
.cf .row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.cf label{display:block;font-size:12px;font-weight:600;color:var(--muted-light);margin-bottom:5px;letter-spacing:.02em}
.cf input,.cf textarea{
  width:100%;background:rgba(250,248,243,.06);border:1px solid var(--line-dark);
  border-radius:11px;padding:12px 14px;color:#fff;font-family:var(--font-body);font-size:15px;
  transition:border-color .2s,background .2s;
}
.cf input::placeholder,.cf textarea::placeholder{color:rgba(155,161,172,.7)}
.cf input:focus,.cf textarea:focus{outline:none;border-color:var(--brand);background:rgba(250,248,243,.1)}
.cf textarea{resize:vertical;min-height:92px}
.cf .hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.cf button{margin-top:4px;justify-content:center;width:100%}
.cf button[disabled]{opacity:.65;cursor:default}
.cf-status{font-size:14px;line-height:1.5;margin-top:2px;display:none}
.cf-status.ok{display:block;color:var(--live-bright)}
.cf-status.err{display:block;color:#ff9a9a}
@media(max-width:480px){.cf .row{grid-template-columns:1fr}}

/* ---------- CSAT widget embed ---------- */
.testi-head{display:flex;justify-content:space-between;align-items:center;gap:44px;margin-bottom:60px;flex-wrap:wrap}
.testi-head .sec-head{margin-bottom:0;max-width:600px}
.csat-embed{flex:none;display:flex;flex-direction:column;align-items:center;gap:8px}
.csat-embed iframe{display:block}
.csat-embed .csat-cap{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
@media(max-width:760px){.testi-head{gap:24px}.csat-embed{margin:0 auto}}
