:root{
  --bg:#f6fbff;
  --bg2:#eef7ff;
  --text:rgba(10,18,33,.94);
  --muted:rgba(10,18,33,.68);
  --muted2:rgba(10,18,33,.52);
  --stroke:rgba(10,18,33,.12);
  --stroke2:rgba(10,18,33,.08);
  --surface:rgba(255,255,255,.78);
  --surface2:rgba(255,255,255,.92);
  --primary:#16b4d9;
  --primary2:#0aa7d3;
  --primary3:#62d6ff;
  --shadow:0 24px 90px rgba(10,18,33,.14);
  --radius:18px;
  --radius2:28px;
  --container:1120px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
html.no-scroll{overflow:hidden}
body{
  margin:0;
  font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 520px at 18% 0%, rgba(22,180,217,.18), transparent 62%),
    radial-gradient(900px 560px at 92% 10%, rgba(98,214,255,.14), transparent 62%),
    radial-gradient(1100px 760px at 50% 115%, rgba(22,180,217,.10), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit;color:inherit}
.container{width:min(var(--container),calc(100% - 40px));margin-inline:auto}

.skip-link{
  position:absolute;left:14px;top:14px;
  background:var(--surface2);
  border:1px solid var(--stroke);
  color:var(--text);
  padding:10px 12px;border-radius:12px;
  transform:translateY(-160%);
  transition:transform .2s var(--ease);
  z-index:9999;
}
.skip-link:focus{transform:translateY(0)}

.header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:16px 0;transition:padding .25s var(--ease);
}
.header.is-scrolled{padding:10px 0}
.header::before{
  content:"";position:absolute;inset:0;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(10,18,33,.08);
  opacity:0;transition:opacity .25s var(--ease);
}
.header.is-scrolled::before{opacity:1}
.nav{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  width:min(var(--container),calc(100% - 40px));
  margin-inline:auto;
}
.brand__logo{
  height:44px;
  width:auto;
  max-width: 420px;
  object-fit: contain;
}
.nav__links{display:flex;gap:18px;align-items:center}
.nav__cta{padding:10px 14px;border-radius:14px}
.nav__links a{
  padding:10px 10px;border-radius:12px;color:var(--muted);
  transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);
}
.nav__links a:hover{color:var(--text);background:rgba(10,18,33,.06);transform:translateY(-1px)}
.nav__burger{
  display:none;width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(10,18,33,.14);
  background:rgba(255,255,255,.70);
  backdrop-filter:blur(18px);
  cursor:pointer;
}
.nav__burger span{display:block;height:2px;width:18px;background:rgba(10,18,33,.80);margin:4px auto;border-radius:999px}

.drawer{
  position:fixed;inset:0;background:rgba(10,18,33,.38);
  backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease);
}
.drawer.is-open{opacity:1;pointer-events:auto}
.drawer__inner{
  position:absolute;top:14px;right:14px;left:14px;
  padding:18px;border-radius:22px;
  border:1px solid rgba(10,18,33,.12);
  background:rgba(255,255,255,.86);
  box-shadow:var(--shadow);
  transform:translateY(-10px);
  transition:transform .25s var(--ease);
}
.drawer.is-open .drawer__inner{transform:translateY(0)}
.drawer__inner a{display:block;padding:12px 12px;border-radius:14px}
.drawer__inner a:hover{background:rgba(10,18,33,.06)}

.hero{position:relative;padding:122px 0 0}
.bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.bg__blob{
  position:absolute;width:520px;height:520px;border-radius:999px;
  filter:blur(44px);opacity:.28;mix-blend-mode:multiply;
  will-change:transform;
}
.bg__blob--a{left:-140px;top:120px;background:radial-gradient(circle at 30% 30%, rgba(22,180,217,.70), rgba(22,180,217,0) 65%)}
.bg__blob--b{right:-180px;top:-60px;background:radial-gradient(circle at 40% 40%, rgba(98,214,255,.55), rgba(98,214,255,0) 65%)}

.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:stretch;padding-bottom:26px}
.kicker{display:inline-flex;gap:10px;align-items:center;color:var(--muted);margin:0 0 12px}
.kicker::before{
  content:"";width:10px;height:10px;border-radius:999px;
  background:radial-gradient(circle at 30% 30%, var(--primary3), var(--primary));
  box-shadow:0 0 0 6px rgba(22,180,217,.16);
  animation: ping 1.6s var(--ease) infinite;
}
.hero__title{
  font-size:clamp(38px,5.2vw,64px);
  line-height:1.02;margin:0 0 16px;letter-spacing:-0.03em;
  font-weight:900;
}
.hero__headline{display:flex;flex-wrap:wrap;gap:12px;align-items:baseline}
.hero__leadword{color:rgba(10,18,33,.92)}
.slashes{
  display:inline-block;
  margin-left: 6px;
  color: var(--primary2);
  letter-spacing: .06em;
  transform: translateY(-.02em);
  text-shadow: 0 10px 30px rgba(22,180,217,.22);
  animation: slashblink 2.6s var(--ease) infinite;
}
.rotator{
  position:relative;
  display:inline-grid;
  align-items:baseline;
  height: 1.05em;
  overflow:hidden;
  padding-right: 4px;
}
.rotator__list{
  display:block;
  will-change: transform;
  animation: rotateWords 7.5s var(--ease) infinite;
}
.rotator__item{
  display:block;
  height: 1.05em;
  line-height: 1.05em;
  color: rgba(10,18,33,.96);
}
.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.accent{
  display:block;
  margin-top:10px;
  font-size: clamp(15px, 1.65vw, 18px);
  letter-spacing: .02em;
  font-weight: 700;
  color: rgba(10,18,33,.70);
}
.hero__lead{margin:0 0 22px;color:var(--muted);font-size:16.5px;line-height:1.7;max-width:64ch}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid rgba(10,18,33,.14);
  background:rgba(255,255,255,.72);
  cursor:pointer;user-select:none;
  transition:transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease), box-shadow .18s var(--ease);
}
.btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.92);border-color:rgba(10,18,33,.22)}
.btn:active{transform:translateY(0)}
.btn--primary{
  position:relative;overflow:hidden;
  border-color:rgba(22,180,217,.35);
  background:linear-gradient(135deg, rgba(22,180,217,.95), rgba(10,167,211,.78));
  box-shadow:0 18px 46px rgba(22,180,217,.20);
  color:rgba(255,255,255,.96);
}
.btn--primary::after{
  content:"";position:absolute;inset:-2px;
  background:radial-gradient(220px 120px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.28), transparent 60%);
  opacity:0;transition:opacity .18s var(--ease);pointer-events:none;
}
.btn--primary:hover{
  background:linear-gradient(135deg, rgba(22,180,217,.98), rgba(10,167,211,.84));
  color:rgba(255,255,255,.98);
  box-shadow:0 22px 64px rgba(22,180,217,.26);
}
.btn--primary:hover::after{opacity:.9}
.btn--soft{border-color:rgba(22,180,217,.22);background:rgba(22,180,217,.10)}
.btn--ghost{background:transparent;border-color:rgba(10,18,33,.14);color:var(--muted)}
.btn--ghost:hover{color:var(--text);background:rgba(10,18,33,.04)}

.hero__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.chip{
  display:inline-flex;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(10,18,33,.12);
  background:rgba(255,255,255,.78);
  color:rgba(10,18,33,.72);
  font-size:12px;
}

.hero__visual{display:flex;align-items:stretch}
.hero-shot{
  position:relative;width:100%;margin:0;
  border-radius: var(--radius2);
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 30px 120px rgba(10,18,33,.16);
  overflow:hidden;
}
.hero-shot::before{
  content:"";position:absolute;inset:-2px;
  background: radial-gradient(620px 360px at 25% 25%, rgba(22,180,217,.14), transparent 60%);
  opacity:.9;pointer-events:none;
}
.hero-shot img{
  width:100%;height:100%;min-height: 460px;
  object-fit:cover;display:block;
  transform: translate3d(0,0,0) scale(1.06);
  filter:saturate(1.06) contrast(1.05);
  transition: transform .75s var(--ease), filter .75s var(--ease);
}
.hero-shot:hover img{transform: translate3d(0,0,0) scale(1.10);filter:saturate(1.12) contrast(1.08)}
.hero-shot__cap{
  position:absolute;left:16px;bottom:16px;
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:999px;
  background:rgba(255,255,255,.70);
  backdrop-filter: blur(14px);
  border:1px solid rgba(10,18,33,.12);
  color:rgba(10,18,33,.74);
  font-size: 12.5px;
}
.dot{width:8px;height:8px;border-radius:999px;background:var(--primary3);box-shadow:0 0 0 6px rgba(98,214,255,.12)}

.marquee{
  margin-top: 22px;
  border-top: 1px solid rgba(10,18,33,.08);
  border-bottom: 1px solid rgba(10,18,33,.08);
  overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.marquee__inner{display:flex;width:max-content}
.marquee__track{
  display:flex;gap:18px;padding: 14px 0;white-space:nowrap;flex-shrink:0;
  animation:marquee 14s linear infinite;
  color:rgba(10,18,33,.56);letter-spacing:.06em;text-transform:uppercase;font-size:12px;
}

.section{padding:72px 0}
.section--alt{
  background: rgba(255,255,255,.55);
  border-top:1px solid rgba(10,18,33,.06);
  border-bottom:1px solid rgba(10,18,33,.06);
}
.section__header{margin-bottom: 18px}
.section__title{margin:0;font-size:clamp(26px,3.2vw,40px);letter-spacing:-0.02em}
.section__subtitle{margin:8px 0 0;color:var(--muted);max-width:70ch;line-height:1.7}
.seo-note{
  margin:14px 0 0;
  color: var(--muted);
  line-height: 1.75;
  max-width: 92ch;
}

.flow{padding: 34px 0 10px}
.flow__inner{
  display:grid;
  grid-template-columns: 240px 1fr;
  gap: 22px;
  align-items:start;
}
.rail{
  position:sticky;
  top: 92px;
  border-radius: 22px;
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.78);
  box-shadow: 0 18px 60px rgba(10,18,33,.10);
  padding: 10px;
}
.rail__item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius: 14px;
  color: var(--muted);
  transition: background .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
}
.rail__item:hover{background:rgba(10,18,33,.05);color:var(--text);transform:translateY(-1px)}
.rail__dot{
  width:10px;height:10px;border-radius:999px;
  border:1px solid rgba(22,180,217,.35);
  background: rgba(22,180,217,.10);
  box-shadow: 0 0 0 0 rgba(22,180,217,.0);
  transition: box-shadow .25s var(--ease), background .25s var(--ease), transform .25s var(--ease);
}
.rail__item.is-active{color:var(--text);background:rgba(22,180,217,.10)}
.rail__item.is-active .rail__dot{
  background: rgba(22,180,217,.45);
  box-shadow: 0 0 0 7px rgba(22,180,217,.14);
  transform: scale(1.06);
}
.chapters{min-width:0}
.chapter{padding: 20px 0 6px}
.chapter + .chapter{border-top:1px solid rgba(10,18,33,.08);margin-top: 22px}
.chapter__head{
  display:flex;
  gap:14px;
  align-items:flex-start;
  margin-bottom: 16px;
}
.section__title .slashes{
  margin-left: 0;
  margin-right: 10px;
  font-size: 1.05em;
  vertical-align: baseline;
  text-shadow: 0 12px 34px rgba(22,180,217,.20);
}

.bento{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
  margin-top: 18px;
}
.bento__tile{
  grid-column: span 6;
  border-radius: var(--radius2);
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 60px rgba(10,18,33,.12);
  padding: 18px;
}
.bento__tile h3{margin:0 0 10px;font-size:20px;letter-spacing:-0.01em}
.bento__tile p{margin:0;color:var(--muted);line-height:1.75}
.bento__tile--quote{
  grid-column: 1 / -1;
  background: linear-gradient(135deg, rgba(98,214,255,.20), rgba(255,255,255,.92));
  border-color: rgba(22,180,217,.22);
}

.kpis{
  position:relative;
  height:100%;
  min-height:260px;
  padding:18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:stretch;
  align-content:flex-start;
}
.kpis--strip{
  min-height:auto;
  height:auto;
  padding:0;
  margin-top: 12px;
}
.kpi{
  flex: 1 1 180px;
  border-radius:18px;
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 18px 60px rgba(10,18,33,.10);
  padding:12px 12px;
  overflow:hidden;
  position:relative;
}
.kpi::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(260px 160px at 25% 25%, rgba(22,180,217,.14), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.kpi::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:18px;
  background: conic-gradient(from 0deg, rgba(22,180,217,.0), rgba(22,180,217,.55), rgba(98,214,255,.0));
  opacity:0;
  pointer-events:none;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  padding:1px;
}
.kpi.is-inview::after{
  opacity:1;
  animation: kpiRing 3.8s linear 1;
  animation-delay: var(--delay, 0ms);
}
.kpi__value{
  position:relative;
  font-weight:900;
  letter-spacing:-0.02em;
  font-size: clamp(18px, 2.2vw, 28px);
  color: rgba(10,18,33,.96);
}
.kpi.is-inview .kpi__value{
  animation: kpiAppear 900ms var(--ease) both;
  animation-delay: var(--delay, 0ms);
}
.kpi__label{
  position:relative;
  margin-top:4px;
  color: var(--muted);
  font-weight:650;
  font-size: 12.5px;
}
.kpis__hint{
  width:100%;
  margin-top:2px;
  color: rgba(10,18,33,.70);
  font-weight:650;
  display:flex;
  align-items:center;
  gap:10px;
  font-size: 12.5px;
}

.cards{display:grid;grid-template-columns: repeat(3, 1fr);gap:12px;margin-top: 18px}
.cardx{
  border-radius: var(--radius2);
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 60px rgba(10,18,33,.12);
  overflow:hidden;
  transition: transform .22s var(--ease), border-color .22s var(--ease);
}
.cardx:hover{transform: translateY(-2px); border-color: rgba(22,180,217,.22)}
.cardx__media{height: 220px; overflow:hidden; position:relative}
.cardx__media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform: scale(1.06);
  filter:saturate(1.06) contrast(1.05);
  transition: transform .7s var(--ease), filter .7s var(--ease);
}
.cardx:hover .cardx__media img{transform: scale(1.12);filter:saturate(1.12) contrast(1.08)}
.cardx.is-inview .cardx__media img{transform: scale(1.02);filter:saturate(1.12) contrast(1.08)}
.cardx__body{padding:16px 16px 18px}
.cardx__body h3{margin:0 0 8px;font-size:18px;letter-spacing:-0.01em}
.cardx__body p{margin:0;color:var(--muted);line-height:1.7}

.grid{display:grid;gap:14px}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:repeat(3,1fr)}

.feature{
  position:relative;border-radius:var(--radius2);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80));
  border:1px solid rgba(10,18,33,.10);
  padding:18px;overflow:hidden;
  transition:transform .18s var(--ease), border-color .18s var(--ease);
}
.feature::before{
  content:"";position:absolute;inset:-2px;
  background: radial-gradient(380px 240px at 20% 10%, rgba(22,180,217,.14), transparent 60%);
  opacity:0;transition:opacity .18s var(--ease);
}
.feature:hover{transform: translateY(-2px); border-color: rgba(22,180,217,.22)}
.feature:hover::before{opacity:1}
.feature > *{position:relative}
.feature__icon{
  width:46px;height:46px;border-radius:16px;display:grid;place-items:center;
  background:rgba(22,180,217,.12);
  border:1px solid rgba(22,180,217,.22);
  color:var(--primary2);
  margin-bottom:12px;
}
.monoicon{
  width:26px;
  height:26px;
  stroke: currentColor;
  stroke-width: 1.9;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.feature h3{margin:0 0 8px}
.feature p{margin:0;color:var(--muted);line-height:1.75}

.tile{
  border-radius: var(--radius2);
  padding: 20px;
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.88);
  overflow:hidden;
  position:relative;
  box-shadow: 0 18px 60px rgba(10,18,33,.12);
}
.tile::before{
  content:"";position:absolute;inset:-2px;
  background: radial-gradient(420px 220px at 25% 25%, rgba(98,214,255,.14), transparent 60%);
  opacity:.9;pointer-events:none;
}
.tile > *{position:relative}
.tile h3{margin:0 0 6px}
.tile p{margin:0 0 14px;color:var(--muted);line-height:1.7}

.contact{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block}
label span{display:block;font-size:13px;color:var(--muted);margin:0 0 6px}
input,textarea{
  width:100%;padding:12px;border-radius:14px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(10,18,33,.14);
  outline:none;
  transition:border-color .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
}
textarea{resize:vertical;min-height:140px}
input:focus,textarea:focus{
  border-color:rgba(22,180,217,.45);
  box-shadow:0 0 0 4px rgba(98,214,255,.20);
  background:rgba(255,255,255,1);
}
.form__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.form__hint{margin:12px 0 0;color:var(--muted2);font-size:12.5px;line-height:1.6}
.muted{color:var(--muted)}
.side__list{display:grid;gap:10px;margin-top:14px}
.side__item{
  display:flex;justify-content:space-between;gap:12px;
  padding:12px;border-radius:14px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(10,18,33,.10);
  transition:transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.side__item:hover{transform:translateY(-1px);border-color:rgba(22,180,217,.22);background:rgba(255,255,255,.96)}
.side__k{color:var(--muted);font-size:12px}
.side__v{font-weight:650}

.footer{padding:28px 0 36px}
.footer__inner{
  display:grid;grid-template-columns:1.3fr .7fr;gap:16px;
  align-items:start;border-top:1px solid rgba(10,18,33,.08);padding-top:18px;
}
.footer__logo{height:30px;width:auto}
.footer__links{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.footer__links a{color:var(--muted);padding:8px 10px;border-radius:12px}
.footer__links a:hover{background:rgba(10,18,33,.06);color:var(--text)}
.footer__legal{grid-column:1 / -1;margin:0;text-align:center;color:var(--muted2)}
.footer__legal p{margin:0}
.legal{margin-top:10px;display:inline-block;text-align:left}
.legal summary{
  cursor:pointer;
  user-select:none;
  list-style:none;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.78);
  color: var(--text);
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.legal summary::-webkit-details-marker{display:none}
.legal summary:hover{background:rgba(255,255,255,.92);transform:translateY(-1px)}
.legal[open] summary{background:rgba(255,255,255,.92)}
.legal__body{
  margin-top:10px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(10,18,33,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 60px rgba(10,18,33,.10);
}
.legal__sep{
  border:0;
  height:1px;
  background: rgba(10,18,33,.10);
  margin: 10px 0;
}
.legal__body p{margin:0 0 10px;color:var(--muted);line-height:1.65}
.legal__body p:last-child{margin-bottom:0}
.legal__src a{text-decoration:underline}

.act-modal{
  width:min(920px, calc(100% - 28px));
  border:none;
  padding:0;
  border-radius:24px;
  overflow:hidden;
  background: rgba(255,255,255,.96);
  color: var(--text);
  box-shadow: 0 40px 140px rgba(10,18,33,.22);
}
.act-modal::backdrop{
  background: rgba(10,18,33,.38);
  backdrop-filter: blur(10px);
}
.act-modal__media{
  background: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(10,18,33,.08);
}
.act-modal__media img{
  width:100%;
  height:min(46vh, 420px);
  object-fit:cover;
  display:block;
}
.act-modal__body{padding:16px 18px 20px}
.act-modal__title{margin:0 0 8px;font-size:22px;letter-spacing:-0.01em}
.act-modal__text{margin:0;color:var(--muted);line-height:1.7}
.act-modal__close{
  position:absolute;
  top:12px;
  right:12px;
  width:44px;
  height:44px;
  border-radius:16px;
  border:1px solid rgba(10,18,33,.12);
  background: rgba(255,255,255,.78);
  color: rgba(10,18,33,.82);
  cursor:pointer;
  font-size:24px;
  line-height:1;
}
.act-modal__close:hover{background: rgba(255,255,255,.96)}

@media (prefers-reduced-motion: no-preference){
  .act-modal[open]{
    animation: modalIn .28s var(--ease) both;
  }
}
@keyframes modalIn{
  from{opacity:0; transform: translateY(8px) scale(.985)}
  to{opacity:1; transform:none}
}

.reveal{opacity:0;transform:translateY(10px);filter:blur(6px)}
.reveal.is-visible{
  opacity:1;transform:none;filter:none;
  transition:opacity .55s var(--ease), transform .55s var(--ease), filter .55s var(--ease);
}

@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-100%)}}
@keyframes kpiRing{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes kpiAppear{from{opacity:0;transform:translateY(4px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}
@keyframes rotateWords{
  0%{transform:translateY(0)}
  22%{transform:translateY(0)}
  28%{transform:translateY(-1.05em)}
  47%{transform:translateY(-1.05em)}
  53%{transform:translateY(-2.10em)}
  72%{transform:translateY(-2.10em)}
  78%{transform:translateY(-3.15em)}
  97%{transform:translateY(-3.15em)}
  100%{transform:translateY(-4.20em)}
}
@keyframes slashblink{
  0%{transform: translateY(-.02em) scale(1); opacity:1}
  40%{transform: translateY(-.02em) scale(1); opacity:1}
  52%{transform: translateY(-.02em) scale(1.06); opacity:.92}
  64%{transform: translateY(-.02em) scale(1); opacity:1}
  100%{transform: translateY(-.02em) scale(1); opacity:1}
}
@keyframes ping{
  0%{transform:scale(.92); box-shadow:0 0 0 0 rgba(22,180,217,.18)}
  45%{transform:scale(1); box-shadow:0 0 0 10px rgba(22,180,217,.10)}
  100%{transform:scale(.92); box-shadow:0 0 0 0 rgba(22,180,217,.0)}
}
@keyframes titlewipe{
  0%{transform:scaleX(0);opacity:.0}
  14%{opacity:1}
  55%{transform:scaleX(1);opacity:1}
  100%{transform:scaleX(1);opacity:0}
}
@keyframes titlepop{
  0%{transform:translateY(6px);opacity:0}
  100%{transform:translateY(0);opacity:1}
}

.titlefx{
  position:relative;
  display:inline-block;
}
.titlefx::after{
  content:"";
  position:absolute;
  left:-2%;
  right:-2%;
  bottom:-0.10em;
  height:0.18em;
  background:rgba(22,180,217,.22);
  border-radius:999px;
  transform-origin:left center;
  transform:scaleX(0);
  opacity:0;
  animation:titlewipe 2.8s var(--ease) infinite;
}
.reveal.is-visible.titlefx{
  animation:titlepop .55s var(--ease) both;
}

@media (max-width: 980px){
  .hero__inner{grid-template-columns:1fr;gap:16px}
  .hero-shot img{min-height:420px}
  .cards{grid-template-columns:1fr}
  .grid--3,.grid--2{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .bento__tile{grid-column: span 12}
  .flow__inner{grid-template-columns:1fr}
  .rail{position:relative;top:auto}
  .footer__inner{grid-template-columns:1fr}
  .footer__links{justify-content:flex-start}
}
@media (max-width: 820px){
  .nav__links{display:none}
  .nav__burger{display:inline-block}
  .form__row{grid-template-columns:1fr}
  .brand__logo{height:40px;max-width:300px}
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .marquee__track{animation:none !important}
  .titlefx::after{animation:none !important;opacity:1;transform:scaleX(1)}
  .reveal.is-visible.titlefx{animation:none}
  .kicker::before{animation:none !important}
  .rotator__list{animation:none !important;transform:translateY(0)}
  .slashes{animation:none !important}
  .kpi::after{display:none}
  .kpi.is-inview .kpi__value{animation:none}
  .reveal{opacity:1;transform:none;filter:none}
  .reveal.is-visible{transition:none}
}
