:root{
  --bg:#07080d;
  --bg-soft:#0b0c14;
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.08);
  --text:#f1f2f8;
  --muted:#9aa0b2;
  /* SIYA brand palette, from the colorful "d" in the logo */
  --green:#8cc63f;
  --amber:#f5a623;
  --pink:#ec1e79;
  --purple:#9b51e0;
  --accent:var(--pink);
  --accent-2:var(--amber);
  --grad:linear-gradient(115deg,#8cc63f 0%,#f5a623 38%,#ec1e79 72%,#9b51e0 100%);
  --radius:20px;
  --font-display:'Outfit',sans-serif;
  --font-body:'Outfit',sans-serif;
  --ease-soft:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  background-image:radial-gradient(ellipse 90% 50% at 50% -10%,rgba(155,81,224,.10),transparent 60%);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--pink);color:#fff}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.1;letter-spacing:-.02em;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1200px,92%);margin-inline:auto}

/* ---------- ambient particle background ---------- */
#bgfx{position:fixed;inset:0;z-index:-1;pointer-events:none}

/* ---------- scroll progress ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:1000;transition:width .1s linear}

/* ---------- grain overlay ---------- */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:999;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- nav ---------- */
nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  width:min(1200px,94%);z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;border-radius:60px;
  background:rgba(9,10,17,.55);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--border);
  transition:box-shadow .4s,background .4s;
}
nav.scrolled{background:rgba(9,10,17,.88);box-shadow:0 12px 40px rgba(0,0,0,.5)}
.logo img{height:34px;width:auto}
footer .logo img{height:40px}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links>li>a{font-size:.92rem;color:var(--muted);position:relative;transition:color .35s var(--ease-soft)}
.nav-links>li>a::after{
  content:"";position:absolute;left:0;right:0;bottom:-5px;height:2px;
  background:var(--grad);border-radius:2px;
  transform:scaleX(0);transform-origin:center;
  transition:transform .45s var(--ease-soft);
}
.nav-links>li>a:hover{color:var(--text)}
.nav-links>li>a:hover::after{transform:scaleX(1)}
.nav-links>li>a.active{color:var(--text)}
.nav-links>li>a.active::after{transform:scaleX(1)}

/* ---------- full-width mega menus ---------- */
/* .mega is positioned against the nav pill itself (nav's transform makes it
   the containing block), so the panel spans the full nav width. */
.nav-links .has-mega>a{display:inline-flex;align-items:center;gap:6px}
.nav-links .chev{width:13px;height:13px;transition:transform .4s var(--ease-soft)}
.has-mega.open .chev,.has-mega:focus-within .chev{transform:rotate(180deg)}
.mega{
  position:absolute;top:calc(100% + 14px);left:0;right:0;
  padding:16px;border-radius:24px;
  background:rgba(10,11,18,.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--border);box-shadow:0 30px 70px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(14px);
  transition:opacity .4s var(--ease-soft),transform .4s var(--ease-soft),visibility .4s;
}
.mega::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.has-mega.open .mega,.has-mega:focus-within .mega{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
}
.mega-inner{display:grid;grid-template-columns:300px 1fr;gap:16px;align-items:stretch}
.mega-feat{
  display:flex;flex-direction:column;justify-content:flex-end;gap:10px;
  padding:26px 24px;border-radius:18px;
  background:linear-gradient(150deg,rgba(140,198,63,.13),rgba(245,166,35,.1) 45%,rgba(236,30,121,.14));
  border:1px solid rgba(245,166,35,.25);
  transition:border-color .4s var(--ease-soft);
}
.mega-feat:hover{border-color:rgba(245,166,35,.55)}
.mega-feat .kicker{margin-bottom:auto}
.mega-feat b{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.2}
.mega-feat p{color:var(--muted);font-size:.84rem;line-height:1.5}
.mega-feat .feat-link{font-weight:600;font-size:.88rem;color:var(--amber);display:inline-flex;gap:7px;align-items:center}
.mega-feat .feat-link .arrow{transition:transform .35s var(--ease-soft)}
.mega-feat:hover .feat-link .arrow{transform:translateX(5px)}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;align-content:center}
.mega-item{
  display:flex;gap:14px;align-items:center;
  padding:13px 16px;border-radius:14px;
  transition:background .35s var(--ease-soft),transform .35s var(--ease-soft);
}
.mega-item:hover{background:var(--surface-2);transform:translateX(4px)}
.mi-thumb{width:42px;height:42px;flex-shrink:0;border-radius:11px;object-fit:cover;filter:saturate(.85)}
.mega-item .mi-icon{
  width:40px;height:40px;flex-shrink:0;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(236,30,121,.14),rgba(245,166,35,.1));
  border:1px solid rgba(236,30,121,.3);transition:transform .3s;
}
.mega-item:hover .mi-icon{transform:scale(1.08)}
.mega-item .mi-icon svg{width:20px;height:20px;stroke:var(--amber)}
.mega-item b{display:block;font-family:var(--font-display);font-size:.92rem;font-weight:600;color:var(--text)}
.mega-item small{display:block;color:var(--muted);font-size:.78rem;line-height:1.45;margin-top:3px}
.mega-cta{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-radius:14px;
  font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--text);
  background:linear-gradient(120deg,rgba(140,198,63,.13),rgba(245,166,35,.11) 50%,rgba(236,30,121,.13));
  border:1px solid rgba(245,166,35,.25);transition:border-color .3s,transform .25s;
}
.mega-cta:hover{border-color:rgba(245,166,35,.55);transform:translateX(3px)}
.mega-cta .arrow{transition:transform .3s;color:var(--amber)}
.mega-cta:hover .arrow{transform:translateX(5px)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  padding:13px 28px;border-radius:50px;cursor:pointer;border:none;
  position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.2,.9,.3,1.4),box-shadow .3s;
}
.btn-primary{background:var(--grad);background-size:200% 200%;color:#fff;animation:gradShift 9s ease infinite}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.btn-primary:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 14px 40px rgba(236,30,121,.4)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--amber);transform:translateY(-3px)}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(5px)}
.nav-cta{padding:11px 24px;font-size:.88rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}

/* ---------- home hero ---------- */
header.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding:170px 0 100px;overflow:hidden;
}
.orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4;will-change:transform}
.orb-1{width:540px;height:540px;background:#3a1660;top:-150px;left:-130px;animation:float1 26s ease-in-out infinite}
.orb-2{width:440px;height:440px;background:#5c0f35;bottom:-110px;right:-90px;animation:float2 32s ease-in-out infinite}
.orb-3{width:300px;height:300px;background:#6e4203;top:30%;right:18%;animation:float3 24s ease-in-out infinite;opacity:.28}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(70px,50px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-60px,-60px)}}
@keyframes float3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-40px,40px) scale(1.15)}}
.hero-grid-lines{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 0%,transparent 70%);
}
.hero-inner{position:relative;z-index:2;text-align:center;max-width:940px;margin-inline:auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.8rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);
  border:1px solid rgba(245,166,35,.28);background:rgba(245,166,35,.06);
  padding:9px 20px;border-radius:50px;margin-bottom:32px;
  opacity:0;animation:fadeUp 1.2s ease .1s forwards;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--amber);animation:pulse 3s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.7}}
.hero h1{
  font-size:clamp(2.7rem,6.5vw,5.4rem);font-weight:600;margin-bottom:28px;line-height:1.06;
}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);animation:riseUp 1s cubic-bezier(.2,.7,.2,1) forwards}
.hero h1 .line:nth-child(2)>span{animation-delay:.15s}
@keyframes riseUp{to{transform:translateY(0)}}
.gradient-text{background:var(--grad);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradShift 9s ease infinite}
.word-rotator{display:inline-block;position:relative;text-align:left;vertical-align:bottom}
.word-rotator .word{
  position:absolute;left:0;top:0;opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s;white-space:nowrap;
  background:var(--grad);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradShift 9s ease infinite;
}
.word-rotator .word.active{position:relative;opacity:1;transform:translateY(0)}
.hero p.lede{
  font-size:clamp(1.02rem,1.6vw,1.22rem);color:var(--muted);max-width:660px;margin:0 auto 46px;
  opacity:0;animation:fadeUp .9s ease .45s forwards;
}
.hero-ctas{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .9s ease .65s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
.hero-partners{margin-top:80px;opacity:0;animation:fadeUp 1s ease .9s forwards}
.hero-partners small{display:block;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.scroll-hint{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  width:26px;height:42px;border:2px solid rgba(255,255,255,.22);border-radius:16px;z-index:2;
}
.scroll-hint::after{content:"";position:absolute;left:50%;top:8px;width:4px;height:8px;margin-left:-2px;border-radius:3px;background:var(--amber);animation:wheel 2.2s ease infinite}
@keyframes wheel{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{opacity:0}}

/* ---------- interior page hero ---------- */
.page-hero{position:relative;padding:200px 0 96px;overflow:hidden}
.page-hero .orb{opacity:.32}
.page-hero .crumbs{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  font-size:.8rem;letter-spacing:.06em;color:var(--muted);margin-bottom:20px;
  opacity:0;animation:fadeUp 1s ease .1s forwards;
}
.page-hero .crumbs a{transition:color .25s}
.page-hero .crumbs a:hover{color:var(--amber)}
.page-hero .crumbs .sep{opacity:.45}
.page-hero h1{
  font-size:clamp(2.4rem,5.2vw,4.2rem);font-weight:600;max-width:840px;
  opacity:0;animation:fadeUp .9s ease .15s forwards;
}
.page-hero .lede,.hero p.lede{font-weight:300}
.page-hero .lede{
  color:var(--muted);max-width:660px;font-size:clamp(1rem,1.5vw,1.18rem);margin-top:22px;
  opacity:0;animation:fadeUp .9s ease .3s forwards;
}
.page-hero .hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:36px;opacity:0;animation:fadeUp .9s ease .45s forwards}
.page-hero.banner{padding:230px 0 110px}
.page-hero.banner .bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.75) brightness(.5)}
.page-hero.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,8,13,.55),rgba(7,8,13,.92) 90%)}
.page-hero.banner .container{position:relative;z-index:2}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;position:relative;padding:8px 0;
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
}
.marquee-track{display:flex;align-items:center;gap:70px;width:max-content;animation:marquee 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee img{height:26px;width:auto;filter:brightness(0) invert(1);opacity:.45;transition:opacity .3s}
.marquee img:hover{opacity:.95}

/* ---------- sections ---------- */
section{padding:120px 0;position:relative}
.section-head{max-width:700px;margin-bottom:70px}
.section-head.center{margin-inline:auto;text-align:center}
.kicker{
  display:inline-block;font-size:.76rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--amber);margin-bottom:16px;
}
.section-head h2{font-size:clamp(1.9rem,3.7vw,3rem);font-weight:600;margin-bottom:18px}
.section-head p{color:var(--muted);font-size:1.05rem}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(42px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"]{transition-delay:.48s}

/* ---------- stats ---------- */
.stats{padding:72px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-soft)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{
  font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,4.4vw,3.4rem);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat .label{color:var(--muted);font-size:.92rem;margin-top:6px}

/* ---------- bento services ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:22px}
.card{
  position:relative;border-radius:var(--radius);padding:40px 36px;
  background:var(--surface);border:1px solid var(--border);
  overflow:hidden;transition:transform .45s cubic-bezier(.2,.7,.2,1),border-color .45s;
  display:block;
}
.card:hover{transform:translateY(-7px);border-color:rgba(245,166,35,.4)}
.card::before{ /* mouse spotlight */
  content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .4s;
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,50%),rgba(245,166,35,.1),transparent 60%);
}
.card:hover::before{opacity:1}
.card>*{position:relative;z-index:1}
.card .icon{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:26px;
  background:linear-gradient(135deg,rgba(236,30,121,.14),rgba(245,166,35,.1));
  border:1px solid rgba(236,30,121,.3);transition:transform .4s;
}
.card:hover .icon{transform:scale(1.1) rotate(-6deg)}
.card .icon svg{width:26px;height:26px;stroke:var(--amber)}
.card h3{font-size:1.34rem;margin-bottom:12px}
.card p{color:var(--muted);font-size:.96rem}
.card .more{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-weight:600;font-size:.9rem;color:var(--amber)}
.card .more svg{width:15px;height:15px;transition:transform .3s}
.card:hover .more svg{transform:translateX(5px)}
.b-3{grid-column:span 3}
.b-2{grid-column:span 2}

/* ---------- feature grid (interior pages) ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{
  position:relative;padding:32px 30px;border-radius:18px;
  background:var(--surface);border:1px solid var(--border);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s;
}
.feat:hover{transform:translateY(-6px);border-color:rgba(245,166,35,.4)}
.feat .f-num{font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.2em;color:var(--amber)}
.feat h4{font-size:1.08rem;margin:14px 0 10px}
.feat p{color:var(--muted);font-size:.92rem}

.feat-grid.cols-4{grid-template-columns:repeat(4,1fr)}

/* ---------- FAQ accordion ---------- */
.faq{display:grid;gap:14px;max-width:860px}
.faq details{
  border:1px solid var(--border);border-radius:16px;background:var(--surface);
  overflow:hidden;transition:border-color .3s;
}
.faq details[open]{border-color:rgba(245,166,35,.4)}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:22px 26px;font-family:var(--font-display);font-weight:600;font-size:1.02rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;font-weight:400;color:var(--amber);line-height:1;transition:transform .3s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-body{padding:0 26px 24px;color:var(--muted);font-size:.95rem;max-width:720px}

/* ---------- outcome stat rows ---------- */
.stats-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.stats-inline{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px;
}
.stats-inline .stat{
  padding:26px 20px;border:1px solid var(--border);border-radius:16px;
  background:var(--surface);text-align:center;
}
.stats-inline .stat .num{font-size:clamp(1.7rem,2.6vw,2.3rem)}
.stats-inline .stat .label{font-size:.85rem}

.feat .more{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-weight:600;font-size:.88rem;color:var(--amber)}
.feat .more svg{width:14px;height:14px;transition:transform .3s}
a.feat:hover .more svg{transform:translateX(4px)}

/* ---------- legal pages ---------- */
.legal-copy{max-width:840px}
.legal-copy .updated{display:inline-block;font-size:.82rem;letter-spacing:.08em;color:var(--muted);margin-bottom:34px}
.legal-copy h2{font-size:1.4rem;margin:46px 0 14px}
.legal-copy p{color:var(--muted);margin-bottom:14px;font-size:.97rem}
.legal-copy ul{list-style:disc;margin:0 0 18px 22px;color:var(--muted);font-size:.97rem}
.legal-copy ul li{margin-bottom:8px}
.legal-copy a{color:var(--amber)}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{
  padding:30px 26px;border-radius:18px;background:var(--surface);border:1px solid var(--border);
  transition:transform .4s,border-color .4s;
}
.step:hover{transform:translateY(-6px);border-color:rgba(236,30,121,.4)}
.step b{
  display:block;font-family:var(--font-display);font-size:2.2rem;font-weight:700;margin-bottom:12px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.step h4{font-size:1.05rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.9rem}

/* ---------- split (text + image) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.flip>.split-img{order:2}
.split-img{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--border)}
.split-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3.1;filter:saturate(.85);transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.split-img:hover img{transform:scale(1.05)}
.split-copy h2{font-size:clamp(1.8rem,3.2vw,2.6rem);margin-bottom:20px}
.split-copy p{color:var(--muted);margin-bottom:16px}
.ticks{list-style:none;margin:26px 0 36px;display:grid;gap:14px}
.ticks li{display:flex;gap:13px;align-items:flex-start;color:#cfd2dd;font-size:.98rem}
.ticks svg{width:21px;height:21px;flex-shrink:0;stroke:var(--amber);margin-top:2px}

/* ---------- platform logo grid ---------- */
.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.stack-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  padding:34px 18px;border-radius:16px;border:1px solid var(--border);background:var(--surface);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s;
}
.stack-item:hover{transform:translateY(-5px);border-color:rgba(245,166,35,.45)}
.stack-item img{height:34px;width:auto;max-width:140px;filter:brightness(0) invert(1);opacity:.7;transition:opacity .3s,transform .3s}
.stack-item:hover img{opacity:1;transform:scale(1.06)}
.stack-item span{font-size:.85rem;color:var(--muted);font-weight:500}
.stack-item .stack-name{
  font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:rgba(255,255,255,.75);
  line-height:34px;transition:color .3s;
}
.stack-item:hover .stack-name{color:#fff}

/* ---------- related service cards ---------- */
.rel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.rel-card{
  display:flex;gap:16px;align-items:center;padding:20px 22px;border-radius:16px;
  border:1px solid var(--border);background:var(--surface);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,background .35s;
}
.rel-card:hover{transform:translateY(-4px);border-color:rgba(236,30,121,.4);background:var(--surface-2)}
.rel-card .mi-icon{
  width:44px;height:44px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(236,30,121,.14),rgba(245,166,35,.1));
  border:1px solid rgba(236,30,121,.3);
}
.rel-card .mi-icon svg{width:21px;height:21px;stroke:var(--amber)}
.rel-card b{display:block;font-family:var(--font-display);font-size:.98rem;font-weight:600}
.rel-card small{display:block;color:var(--muted);font-size:.8rem;line-height:1.45;margin-top:2px}
.rel-card .arrow{margin-left:auto;color:var(--amber);font-weight:600;transition:transform .3s}
.rel-card:hover .arrow{transform:translateX(5px)}

/* ---------- chips ---------- */
.chip-row{display:flex;flex-wrap:wrap;gap:12px}
.chip{
  font-size:.86rem;font-weight:500;padding:10px 20px;border-radius:40px;
  border:1px solid var(--border);background:var(--surface);transition:.3s;
}
a.chip:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-2px)}

/* ---------- about visual ---------- */
.about-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}
.about-visual{position:relative;aspect-ratio:1/.92;border-radius:26px;overflow:hidden;border:1px solid var(--border);background:radial-gradient(circle at 30% 20%,rgba(155,81,224,.24),transparent 55%),radial-gradient(circle at 75% 80%,rgba(236,30,121,.18),transparent 50%),var(--bg-soft)}
.ring{position:absolute;border:1px solid rgba(255,255,255,.12);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%)}
.ring-1{width:62%;aspect-ratio:1;animation:spin 34s linear infinite}
.ring-2{width:84%;aspect-ratio:1;animation:spin 50s linear infinite reverse;border-style:dashed}
.ring .sat{position:absolute;top:-7px;left:50%;width:14px;height:14px;border-radius:50%;background:var(--pink);box-shadow:0 0 16px var(--pink)}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.core{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:38%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;text-align:center;
  background:rgba(255,255,255,.04);border:1px solid var(--border);backdrop-filter:blur(8px);
  padding:14%;
}
.core img{width:100%;height:auto}
.float-chip{
  position:absolute;display:flex;align-items:center;gap:9px;font-size:.8rem;font-weight:600;
  background:rgba(10,11,18,.82);border:1px solid var(--border);backdrop-filter:blur(10px);
  padding:10px 16px;border-radius:40px;animation:bob 7s ease-in-out infinite;
}
.float-chip .dot2{width:8px;height:8px;border-radius:50%}
.chip-1{top:9%;left:7%}
.chip-2{bottom:13%;right:8%;animation-delay:2s}
.chip-3{top:16%;right:12%;animation-delay:3.6s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
.about-copy h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:22px}
.about-copy p{color:var(--muted);margin-bottom:18px}

/* ---------- industries ---------- */
.industries{background:var(--bg-soft);border-block:1px solid var(--border)}
.ind-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.ind{
  position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/3.8;display:block;
  border:1px solid var(--border);transition:transform .45s cubic-bezier(.2,.7,.2,1),border-color .45s;
}
.ind:hover{transform:translateY(-8px);border-color:rgba(245,166,35,.45)}
.ind img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.8) brightness(.72);transition:transform .7s cubic-bezier(.2,.7,.2,1),filter .5s}
.ind:hover img{transform:scale(1.08);filter:saturate(1) brightness(.85)}
.ind::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,8,13,.05) 35%,rgba(7,8,13,.88) 100%)}
.ind h3{position:absolute;bottom:18px;left:18px;right:14px;z-index:1;font-size:1.05rem;font-weight:600}
/* larger industry cards (industries overview page) */
.ind-grid.lg{grid-template-columns:repeat(3,1fr);gap:24px}
.ind-grid.lg .ind{aspect-ratio:4/3.4}
.ind-grid.lg .ind h3{font-size:1.3rem;bottom:48px}
.ind-grid.lg .ind .sub{
  position:absolute;bottom:20px;left:18px;right:18px;z-index:1;
  color:var(--muted);font-size:.85rem;
}

/* ---------- work ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.work-card{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);display:block;
  background:var(--surface);transition:transform .45s cubic-bezier(.2,.7,.2,1),border-color .45s;
}
.work-card:hover{transform:translateY(-8px);border-color:rgba(236,30,121,.4)}
.work-thumb{height:210px;position:relative;overflow:hidden}
.work-thumb img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.85);transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.work-card:hover .work-thumb img.bg{transform:scale(1.07)}
.work-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,8,13,.08),rgba(7,8,13,.5))}
.work-thumb .tag{
  position:absolute;top:16px;left:16px;z-index:1;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(8,9,15,.78);border:1px solid var(--border);padding:7px 14px;border-radius:30px;backdrop-filter:blur(6px);
}
.work-body{padding:26px}
.work-body h3{font-size:1.18rem;margin-bottom:10px}
.work-body p{color:var(--muted);font-size:.93rem}
.work-metric{margin-top:18px;display:flex;align-items:baseline;gap:9px}
.work-metric b{font-family:var(--font-display);font-size:1.5rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.work-metric span{font-size:.82rem;color:var(--muted)}

/* ---------- testimonial ---------- */
.quote-wrap{max-width:840px;margin-inline:auto;text-align:center}
.quote-mark{font-family:var(--font-display);font-size:5rem;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.quote-wrap blockquote{font-family:var(--font-display);font-size:clamp(1.3rem,2.6vw,1.9rem);font-weight:500;line-height:1.45;margin:10px 0 30px}
.quote-wrap cite{font-style:normal;color:var(--muted);font-size:.95rem}
.quote-wrap cite b{color:var(--text);display:block;font-size:1.02rem}

/* ---------- contact ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.info-cards{display:grid;gap:18px}
.info-card{
  display:flex;gap:18px;align-items:flex-start;padding:26px;
  border:1px solid var(--border);border-radius:18px;background:var(--surface);
  transition:border-color .3s,transform .3s;
}
.info-card:hover{border-color:rgba(245,166,35,.4);transform:translateY(-3px)}
.info-card .icon{
  width:46px;height:46px;flex-shrink:0;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(236,30,121,.14),rgba(245,166,35,.1));
  border:1px solid rgba(236,30,121,.3);
}
.info-card .icon svg{width:22px;height:22px;stroke:var(--amber)}
.info-card h4{font-size:1rem;margin-bottom:5px}
.info-card p,.info-card a{color:var(--muted);font-size:.92rem}
.info-card a:hover{color:var(--amber)}
.contact-form{
  padding:40px;border-radius:24px;background:var(--surface);border:1px solid var(--border);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;margin-bottom:8px;color:#cfd2dd}
.field input,.field select,.field textarea{
  width:100%;padding:14px 18px;border-radius:13px;color:var(--text);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color .3s,box-shadow .3s;
}
.field select option{background:var(--bg-soft);color:var(--text)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,166,35,.12)}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px}
.form-thanks{text-align:center;padding:60px 20px;animation:fadeUp .8s var(--ease-soft)}
.form-thanks .tick-circle{
  width:74px;height:74px;border-radius:50%;margin:0 auto 26px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(140,198,63,.18),rgba(245,166,35,.12));
  border:1px solid rgba(140,198,63,.45);
}
.form-thanks .tick-circle svg{width:34px;height:34px;stroke:var(--green)}
.form-thanks h3{font-size:1.5rem;margin-bottom:12px}
.form-thanks p{color:var(--muted);max-width:380px;margin:0 auto}

/* ---------- CTA ---------- */
.cta-band{
  position:relative;border-radius:30px;padding:96px 50px;text-align:center;overflow:hidden;
  background:linear-gradient(140deg,rgba(155,81,224,.15),rgba(236,30,121,.07) 50%,rgba(245,166,35,.13));
  border:1px solid rgba(236,30,121,.28);
}
.cta-band::before{
  content:"";position:absolute;inset:-40%;
  background:conic-gradient(from 0deg,transparent 0 70%,rgba(236,30,121,.2) 80%,transparent 90%);
  animation:spinFull 14s linear infinite;
}
@keyframes spinFull{to{transform:rotate(360deg)}}
.cta-band .inner{position:relative;z-index:1}
.cta-band h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-bottom:18px}
.cta-band p{color:var(--muted);max-width:560px;margin:0 auto 38px}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--border);padding:80px 0 36px;background:var(--bg-soft)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.foot-grid h4{font-family:var(--font-display);font-size:.95rem;margin-bottom:20px;letter-spacing:.04em}
.foot-grid ul{list-style:none;display:grid;gap:12px}
.foot-grid ul a{color:var(--muted);font-size:.92rem;transition:color .25s,padding-left .25s}
.foot-grid ul a:hover{color:var(--amber);padding-left:5px}
.foot-brand p{color:var(--muted);font-size:.92rem;margin:20px 0 24px;max-width:300px}
.socials{display:flex;gap:12px}
.socials a{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  border:1px solid var(--border);transition:.3s;
}
.socials a:hover{background:var(--pink);border-color:var(--pink);transform:translateY(-4px)}
.socials svg{width:17px;height:17px;fill:var(--text)}
.foot-bottom{border-top:1px solid var(--border);padding-top:30px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}
.foot-bottom .legal{display:flex;gap:24px}
.foot-bottom a:hover{color:var(--text)}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-3,.b-2{grid-column:span 1}
  .about-wrap,.split,.contact-wrap{grid-template-columns:1fr;gap:50px}
  .split.flip>.split-img{order:0}
  .ind-grid{grid-template-columns:repeat(3,1fr)}
  .ind-grid.lg{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:1fr 1fr}
  .feat-grid,.feat-grid.cols-4{grid-template-columns:1fr 1fr}
  .stats-inline{grid-template-columns:1fr}
  .stats-grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
  .rel-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px}
}
@media(max-width:680px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  nav.open .nav-links{
    display:flex;position:absolute;top:calc(100% + 12px);left:0;right:0;
    flex-direction:column;gap:6px;padding:22px;border-radius:24px;
    background:rgba(9,10,17,.96);border:1px solid var(--border);backdrop-filter:blur(18px);
  }
  nav.open .nav-links a{display:block;padding:10px 6px;font-size:1.05rem}
  .mega{display:none}
  .nav-links .chev{display:none}
  .bento,.work-grid,.feat-grid,.feat-grid.cols-4,.steps,.form-row{grid-template-columns:1fr}
  .stats-grid.cols-3{grid-template-columns:1fr}
  .stack-grid{grid-template-columns:1fr 1fr;gap:12px}
  .ind-grid,.ind-grid.lg{grid-template-columns:1fr 1fr}
  .ind{aspect-ratio:4/4.2}
  .foot-grid{grid-template-columns:1fr}
  section{padding:84px 0}
  .cta-band{padding:64px 26px}
  .page-hero{padding:170px 0 70px}
  .contact-form{padding:28px 22px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .hero h1 .line>span{transform:none}
  .eyebrow,.hero p.lede,.hero-ctas,.hero-partners{opacity:1}
  .page-hero .crumbs,.page-hero h1,.page-hero .lede,.page-hero .hero-actions{opacity:1}
  #bgfx{display:none}
}
