/* =========================================================
   Pashupata Consulting
   Palette derived from the trishul logo:
   deep olive-charcoal · copper · light tan · copper-patina
   ========================================================= */

:root {
  --bg-0:#1c1f17;
  --bg-1:#23271d;
  --bg-2:#2a2f22;
  --bg-3:#323827;

  --line:  rgba(196,138,94,.16);
  --line-2:rgba(196,138,94,.30);

  --copper:#c3875d;
  --copper-bright:#d99b69;
  --tan:#ddac8a;
  --patina:#6bb39e;          /* copper oxidises — the one cool accent */

  --head:#f2ebda;
  --text:#e7e0d0;
  --muted:#b0aa98;
  --faint:#867f6e;

  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --r:14px;
  --r-sm:10px;
  --maxw:1180px;
  --pad:clamp(20px, 5vw, 44px);
  --shadow:0 24px 60px -30px rgba(0,0,0,.75);
}

/* ---------- reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--sans);
  font-size:clamp(1rem, .96rem + .2vw, 1.075rem);
  line-height:1.65;
  color:var(--muted);
  background:
    radial-gradient(1100px 620px at 80% -8%, rgba(195,135,93,.12), transparent 60%),
    radial-gradient(820px 520px at -5% 8%, rgba(107,179,158,.06), transparent 55%),
    var(--bg-0);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3{ color:var(--head); font-family:var(--display); font-weight:500; line-height:1.06; margin:0; letter-spacing:-.012em; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; }
ul,ol{ margin:0; padding:0; list-style:none; }
::selection{ background:rgba(195,135,93,.30); color:var(--head); }

:focus-visible{ outline:2px solid var(--copper-bright); outline-offset:3px; border-radius:4px; }

.skip-link{
  position:absolute; left:-9999px; top:.6rem; z-index:200;
  background:var(--copper); color:#1c1f17; padding:.6rem 1rem; border-radius:8px; font-weight:600;
}
.skip-link:focus{ left:1rem; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(74px, 10vw, 132px); position:relative; }
.section__head{ max-width:62ch; margin-bottom:clamp(38px,5vw,60px); }
.section__title{ font-size:clamp(1.9rem, 1.2rem + 2.6vw, 3.1rem); }
.section__intro{ margin-top:1rem; font-size:1.08rem; color:var(--muted); max-width:54ch; }

/* ---------- shared bits ---------- */
.ico{ width:1.05em; height:1.05em; display:inline-block; vertical-align:-.16em; flex:none; }
.ico use{ color:inherit; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--mono); font-size:.72rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; color:var(--copper);
  margin:0 0 1.1rem;
}
.eyebrow .ico{ color:var(--copper); width:1.15em; height:1.15em; }
.eyebrow__mark{ width:1.35em; height:1.35em; object-fit:contain; flex:none; }

/* ---------- header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  transition:background .3s ease, border-color .3s ease, box-shadow .3s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(28,31,23,.82);
  backdrop-filter:blur(12px) saturate(120%);
  -webkit-backdrop-filter:blur(12px) saturate(120%);
  border-bottom-color:var(--line);
  box-shadow:0 10px 30px -22px rgba(0,0,0,.8);
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; min-height:64px; gap:1.5rem; transition:min-height .28s ease; }
.site-header.is-scrolled .site-header__inner{ min-height:52px; }

.brand{ display:inline-flex; align-items:center; gap:.7rem; }
.brand__logo{ height:46px; width:auto; display:block; transition:height .28s ease; }
.site-header.is-scrolled .brand__logo{ height:36px; }
.brand__mark{
  display:grid; place-items:center; width:38px; height:38px; flex:none;
  color:var(--copper);
  border:1px solid var(--line-2); border-radius:11px;
  background:linear-gradient(160deg, rgba(195,135,93,.14), rgba(195,135,93,.02));
}
.brand__mark .ico{ width:21px; height:21px; }
.brand__word{ font-family:var(--display); font-weight:600; font-size:1.18rem; color:var(--head); letter-spacing:-.01em; line-height:1; }
.brand__sub{
  display:block; font-family:var(--mono); font-weight:400; font-size:.56rem;
  letter-spacing:.34em; text-transform:uppercase; color:var(--copper); margin-top:.32em; padding-left:.1em;
}

.site-nav{ display:flex; align-items:center; gap:1.9rem; }
.site-nav a{ font-size:.92rem; font-weight:500; color:var(--muted); transition:color .2s ease; }
.site-nav a:hover{ color:var(--tan); }
.site-nav__cta{ color:var(--text); }

.nav-toggle{
  display:none; width:44px; height:44px; border:1px solid var(--line-2); border-radius:10px;
  background:transparent; cursor:pointer; padding:0; place-items:center; gap:5px;
}
.nav-toggle span{ display:block; width:19px; height:1.6px; background:var(--tan); transition:transform .25s ease, opacity .2s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.6px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.6px) rotate(-45deg); }

.mobile-nav{
  display:flex; flex-direction:column; gap:.2rem;
  padding:.6rem var(--pad) 1.4rem;
  background:rgba(28,31,23,.96); border-bottom:1px solid var(--line);
}
.mobile-nav[hidden]{ display:none; }
.mobile-nav a{ padding:.85rem .2rem; font-size:1.05rem; color:var(--text); border-bottom:1px solid var(--line); }
.mobile-nav a:last-child{ border-bottom:0; color:var(--tan); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:.96rem; line-height:1;
  padding:.92em 1.4em; border-radius:11px; border:1px solid transparent;
  transition:transform .18s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease, color .2s ease;
}
.btn .ico{ width:1.1em; height:1.1em; transition:transform .2s ease; }
.btn--solid{
  color:#1b1e16;
  background:linear-gradient(165deg, var(--copper-bright), var(--copper));
  border-color:rgba(232,170,110,.5);
  box-shadow:0 14px 30px -14px rgba(195,135,93,.6);
}
.btn--solid:hover{ transform:translateY(-2px); box-shadow:0 20px 38px -14px rgba(195,135,93,.7); }
.btn--solid:hover .ico{ transform:translateX(3px); }
.btn--ghost{ color:var(--text); border-color:var(--line-2); background:rgba(255,255,255,.012); }
.btn--ghost:hover{ border-color:var(--copper); color:var(--tan); }
.btn--quiet{ color:var(--tan); padding-inline:.4em; }
.btn--quiet:hover{ color:var(--copper-bright); }
.btn--lg{ font-size:1.05rem; padding:1.05em 1.7em; }

/* ---------- hero ---------- */
.hero{ padding-top:clamp(40px,7vw,84px); padding-bottom:clamp(60px,8vw,104px); position:relative; }
.hero__grid{ display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(36px,5vw,72px); align-items:center; }
.hero__copy{ max-width:38rem; }
.hero__title{
  font-size:clamp(2.5rem, 1.3rem + 4.4vw, 4.5rem);
  letter-spacing:-.022em; margin:.3rem 0 1.5rem;
}
.hero__title em{ font-style:italic; font-weight:500; color:var(--tan); }
.hero__lead{ font-size:clamp(1.08rem,1.02rem + .35vw,1.28rem); color:var(--text); max-width:40ch; }
.hero__cta{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.4rem; margin-top:2.1rem; }

.stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
  margin-top:clamp(2.4rem,4vw,3.4rem); padding-top:1.9rem;
  border-top:1px solid var(--line);
}
.stat{ display:flex; flex-direction:column; gap:.3rem; }
.stat__v{ order:-1; font-family:var(--display); font-weight:500; font-size:clamp(2rem,1.4rem + 1.7vw,2.9rem); color:var(--tan); line-height:1; }
.stat__k{ font-size:.82rem; color:var(--faint); line-height:1.35; }
.stat__k .idx{ display:block; font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; color:var(--copper); margin-bottom:.35rem; }

/* ---------- hero schematic (signature) ---------- */
.schematic{ margin:0; align-self:center; }
.schematic__svg{ width:100%; max-width:480px; height:auto; margin-inline:auto; overflow:visible; }
.schematic__cap{
  margin-top:1.2rem; font-family:var(--mono); font-size:.7rem; line-height:1.6;
  letter-spacing:.02em; color:var(--faint); text-align:center; max-width:42ch; margin-inline:auto;
}
.sch-nodes rect{ fill:var(--bg-1); stroke:var(--line-2); stroke-width:1; }
.node--stream rect{ fill:var(--bg-2); }
.node--live rect{ stroke:rgba(107,179,158,.55); }
.node--terminal rect{ fill:var(--bg-0); }
.node--side rect{ stroke:var(--line); }
.node--engine rect{ fill:#2c3122; stroke:var(--copper); stroke-width:1.4; }
.node__tri{ color:var(--copper-bright); }
.n-t{ fill:var(--tan); font-family:var(--mono); font-size:13px; font-weight:500; letter-spacing:.1em; text-anchor:middle; }
.n-t--sm{ font-size:11px; }
.n-t--xs{ font-size:8.5px; letter-spacing:.06em; }
.n-s{ fill:var(--faint); font-family:var(--mono); font-size:8.5px; letter-spacing:.06em; text-anchor:middle; text-transform:uppercase; }
.node--live .n-t--sm{ fill:var(--patina); }

.lnk{ stroke:var(--line-2); stroke-width:1.3; }
.lnk.fan{ stroke:var(--line); }
.lnk.flow{ stroke:var(--copper); stroke-width:1.4; stroke-dasharray:4 7; animation:dashflow 1.1s linear infinite; }
.lnk--side{ stroke:var(--line); stroke-dasharray:2 5; }
@keyframes dashflow{ to{ stroke-dashoffset:-22; } }

.pulse{ fill:var(--copper-bright); filter:drop-shadow(0 0 5px rgba(217,155,105,.9)); }
.pulse.p1{ animation:spine 4.2s linear infinite; }
.pulse.p2{ animation:spine 4.2s linear infinite 1.4s; }
.pulse.p3{ animation:spine 4.2s linear infinite 2.8s; }
@keyframes spine{
  0%{ transform:translateY(6px); opacity:0; }
  8%{ opacity:1; }
  92%{ opacity:1; }
  100%{ transform:translateY(432px); opacity:0; }
}
.node--engine rect{ animation:enginepulse 3.4s ease-in-out infinite; }
@keyframes enginepulse{
  0%,100%{ stroke:var(--copper); filter:none; }
  50%{ stroke:var(--copper-bright); filter:drop-shadow(0 0 7px rgba(217,155,105,.45)); }
}

/* ---------- capabilities ---------- */
.cap-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:clamp(14px,1.6vw,20px); }
.cap{
  position:relative; padding:clamp(24px,2.4vw,32px); border-radius:var(--r);
  background:linear-gradient(168deg, rgba(255,255,255,.022), rgba(255,255,255,0));
  border:1px solid var(--line);
  transition:transform .25s ease, border-color .25s ease, background .25s ease;
}
.cap:hover{ transform:translateY(-4px); border-color:var(--line-2); background:linear-gradient(168deg, rgba(195,135,93,.07), rgba(255,255,255,0)); }
.cap__no{ font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; color:var(--copper); }
.cap__title{ font-size:1.34rem; margin:.9rem 0 .7rem; color:var(--head); }
.cap p{ font-size:.98rem; color:var(--muted); }

/* ---------- work ---------- */
.section--work{ background:linear-gradient(180deg, transparent, rgba(0,0,0,.16) 12%, rgba(0,0,0,.16) 88%, transparent); }
.work-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:clamp(14px,1.6vw,20px); }
.work{
  display:flex; flex-direction:column; padding:clamp(24px,2.4vw,30px);
  border-radius:var(--r); border:1px solid var(--line); background:var(--bg-1);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.work:hover{ transform:translateY(-4px); border-color:var(--line-2); box-shadow:var(--shadow); }
.work__top{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:.9rem; }
.work__name{ font-size:1.42rem; color:var(--head); }
.work__tag{
  flex:none; font-family:var(--mono); font-size:.62rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--copper); padding:.34em .7em; border:1px solid var(--line-2); border-radius:999px; white-space:nowrap;
}
.work__desc{ font-size:.97rem; color:var(--muted); }
.chips{ display:flex; flex-wrap:wrap; gap:.45rem; margin:1.2rem 0 1.3rem; }
.chips li{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.02em; color:var(--text);
  padding:.34em .65em; border-radius:7px; background:var(--bg-3); border:1px solid var(--line);
}
.work__link{
  margin-top:auto; display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--mono); font-size:.82rem; color:var(--tan); transition:gap .2s ease, color .2s ease;
}
.work__link .ico{ width:1em; height:1em; }
.work__link:hover{ color:var(--copper-bright); gap:.75em; }
.work__link--muted{ color:var(--faint); }

.more{ margin-top:clamp(32px,4vw,52px); padding-top:2rem; border-top:1px solid var(--line); }
.more__label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); margin-bottom:1.2rem; }
.more__chips{ display:flex; flex-wrap:wrap; gap:.7rem; }
.more__chips li{
  display:inline-flex; align-items:center; gap:.55em;
  font-weight:600; font-size:.92rem; color:var(--text);
  padding:.6em .95em; border-radius:10px; border:1px solid var(--line); background:rgba(255,255,255,.012);
}
.more__chips em{ font-family:var(--mono); font-style:normal; font-size:.68rem; color:var(--faint); letter-spacing:.02em; }
.dot{ width:7px; height:7px; border-radius:50%; background:var(--patina); box-shadow:0 0 8px rgba(107,179,158,.8); flex:none; }

/* ---------- approach ---------- */
.section--approach{ overflow:hidden; }
.approach__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(34px,5vw,76px); align-items:start; }
.approach__head{ position:relative; margin-bottom:0; }
.approach__tri{
  width:clamp(150px,20vw,230px); height:auto; opacity:.16;
  margin-top:2.4rem;
}
.steps{ display:flex; flex-direction:column; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.1rem,2vw,1.9rem); padding:clamp(1.6rem,2.4vw,2.2rem) 0; border-top:1px solid var(--line); }
.step:last-child{ border-bottom:1px solid var(--line); }
.step__no{ font-family:var(--mono); font-size:.92rem; color:var(--copper); padding-top:.5rem; }
.step__title{ font-size:1.7rem; color:var(--head); margin-bottom:.5rem; }
.step p{ color:var(--muted); max-width:46ch; }

/* ---------- stack ---------- */
.section--stack{ padding-block:clamp(60px,8vw,104px); }
.stack-grid{ display:flex; flex-wrap:wrap; gap:.7rem; }
.stack-grid li{
  font-family:var(--mono); font-size:.84rem; letter-spacing:.02em; color:var(--text);
  padding:.62em 1.05em; border-radius:9px; border:1px solid var(--line);
  background:rgba(255,255,255,.014); transition:color .2s ease, border-color .2s ease, transform .2s ease;
}
.stack-grid li:hover{ color:var(--tan); border-color:var(--line-2); transform:translateY(-2px); }

/* ---------- public sector / assurance ---------- */
.assure-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(22px,2.8vw,40px) clamp(28px,4vw,64px); margin-top:clamp(30px,4vw,50px); }
.assure-grid li{ padding-top:1.3rem; border-top:1px solid var(--line-2); }
.assure-grid h3{ font-family:var(--display); font-weight:500; font-size:1.24rem; color:var(--head); margin-bottom:.55rem; letter-spacing:-.01em; }
.assure-grid p{ color:var(--muted); font-size:.98rem; max-width:46ch; }

/* ---------- contact ---------- */
.section--contact{ padding-block:clamp(80px,11vw,150px); }
.contact{ max-width:46rem; }
.contact__title{ font-size:clamp(2.2rem,1.3rem + 3.4vw,3.7rem); margin:.4rem 0 1.2rem; }
.contact__lead{ font-size:1.18rem; color:var(--text); max-width:48ch; }
.contact__cta{ display:flex; flex-wrap:wrap; align-items:center; gap:1.2rem 1.8rem; margin-top:2.3rem; }
.contact__mail{ font-family:var(--mono); font-size:.94rem; color:var(--tan); border-bottom:1px solid var(--line-2); padding-bottom:.2em; transition:color .2s ease, border-color .2s ease; }
.contact__mail:hover{ color:var(--copper-bright); border-color:var(--copper); }

.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,60px); align-items:start; margin-top:clamp(34px,5vw,56px); }
.contact-form{ display:flex; flex-direction:column; gap:1.05rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--copper); }
.field .opt{ color:var(--faint); letter-spacing:.04em; }
.field input, .field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--text); width:100%;
  background:var(--bg-2); border:1px solid var(--line-2); border-radius:10px;
  padding:.8em .9em; resize:vertical; transition:border-color .2s ease, background .2s ease;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--copper); background:var(--bg-3); }
.contact-form .btn{ align-self:flex-start; margin-top:.3rem; }
.contact-form__note{ font-family:var(--mono); font-size:.72rem; color:var(--faint); line-height:1.5; min-height:1.1em; }
.contact-form__note.is-ok{ color:var(--patina); }
.contact-form__note.is-err{ color:#e0795f; }
.contact-form .btn[disabled]{ opacity:.6; cursor:progress; }
.hp-field{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; }

.contact-info{ display:flex; flex-direction:column; }
.contact-info__title{ font-size:1.5rem; color:var(--head); margin-bottom:1.4rem; }
.contact-list{ display:flex; flex-direction:column; gap:1.15rem; }
.contact-list li{ display:grid; grid-template-columns:80px 1fr; gap:1rem; align-items:start; }
.contact-list__k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--copper); padding-top:.3em; }
.contact-list__v{ color:var(--text); line-height:1.55; }
.contact-list__link{ color:var(--tan); transition:color .2s ease; }
.contact-list__link:hover{ color:var(--copper-bright); }
.contact-map{ margin-top:1.8rem; border:1px solid var(--line-2); border-radius:var(--r); overflow:hidden; height:clamp(220px,28vw,300px); background:var(--bg-2); }
.contact-map iframe{ width:100%; height:100%; border:0; display:block; filter:invert(.92) hue-rotate(180deg) brightness(.95) contrast(.9); }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); padding-block:clamp(40px,5vw,60px) 2rem; background:rgba(0,0,0,.18); }
.site-footer__inner{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:2rem; align-items:flex-start; }
.site-footer__brand{ display:flex; align-items:center; gap:1rem; }
.brand__mark--lg{ width:48px; height:48px; }
.brand__mark--lg .ico{ width:26px; height:26px; }
.site-footer__logo{ width:54px; height:54px; object-fit:contain; flex:none; }
.site-footer__name{ font-family:var(--display); font-weight:600; font-size:1.2rem; color:var(--head); }
.site-footer__tag{ font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--faint); margin-top:.3rem; }
.site-footer__nav{ display:flex; flex-wrap:wrap; gap:1.4rem; }
.site-footer__nav a{ font-size:.92rem; color:var(--muted); transition:color .2s ease; }
.site-footer__nav a:hover{ color:var(--tan); }
.site-footer__base{
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6rem;
  margin-top:clamp(28px,4vw,44px); padding-top:1.6rem; border-top:1px solid var(--line);
  font-size:.82rem; color:var(--faint);
}
.site-footer__base a{ color:var(--faint); }
.site-footer__base a:hover{ color:var(--tan); }

/* ---------- reveal animation ---------- */
.js .reveal{ opacity:0; transform:translateY(16px); transition:opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); }
.js .reveal.is-in{ opacity:1; transform:none; }
.js .reveal.stagger > *{ opacity:0; transform:translateY(14px); transition:opacity .6s ease, transform .6s ease; }

/* ---------- responsive ---------- */
@media (max-width:960px){
  .hero__grid{ grid-template-columns:1fr; }
  .schematic{ order:-1; max-width:420px; margin-inline:auto; }
  .approach__grid{ grid-template-columns:1fr; }
  .approach__tri{ display:none; }
}
@media (max-width:720px){
  .site-nav{ display:none; }
  .nav-toggle{ display:inline-grid; }
  .stats{ grid-template-columns:1fr; gap:1.5rem; padding-top:1.6rem; }
  .stat{ flex-direction:row; align-items:baseline; gap:.9rem; }
  .stat__v{ order:0; min-width:2.4ch; }
  .work__top{ flex-direction:column; gap:.5rem; align-items:flex-start; }
  .contact-grid{ grid-template-columns:1fr; }
  .assure-grid{ grid-template-columns:1fr; }
  .site-header__inner{ min-height:58px; }
  .brand__logo{ height:42px; }
  .site-header.is-scrolled .site-header__inner{ min-height:50px; }
  .site-header.is-scrolled .brand__logo{ height:34px; }
}
@media (max-width:420px){
  .hero__cta{ gap:.8rem; }
  .btn{ width:100%; justify-content:center; }
  .btn--quiet{ width:auto; }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .js .reveal{ opacity:1 !important; transform:none !important; }
  .lnk.flow{ stroke-dasharray:4 7; }
  .pulse{ display:none; }
}
