*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#080808;
  --fg:#ffffff;
  --muted:rgba(255,255,255,.62);
  --line:rgba(255,255,255,.12);
}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,Segoe UI,Roboto,Arial;background:var(--bg);color:var(--fg);overflow-x:hidden}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
.hidden{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:14px 18px;
  background:rgba(10,10,10,.40);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.nav-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}
.brand-logo{width:22px;height:22px;border-radius:6px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04)}
.brand-text{letter-spacing:.18em;font-weight:600;font-size:14px}
.nav-links{display:flex;gap:18px;margin-left:auto;margin-right:14px}
.nav-links a{
  position:relative;
  color:rgba(255,255,255,.70);
  text-decoration:none;
  font-size:14px;
  padding-bottom:6px;
  transition:color .2s ease;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:2px;
  background:linear-gradient(90deg, rgba(255,255,255,.15), rgba(255,255,255,.8), rgba(255,255,255,.15));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s cubic-bezier(.2,1,.2,1);
  opacity:.9;
}
.nav-links a:hover{color:rgba(255,255,255,.92)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{
  text-decoration:none;padding:10px 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:#fff;
  transition:transform .22s ease,background .22s ease,border-color .22s ease;
}
.nav-cta:hover{transform:translateY(-2px);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.28)}

/* ===== Background ===== */
.bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.blob{position:absolute;border-radius:999px;filter:blur(64px);background:rgba(255,255,255,.08);opacity:.9}
.b1{width:520px;height:520px;left:-160px;top:-160px}
.b2{width:560px;height:560px;right:-220px;top:80px;background:rgba(255,255,255,.06)}
.b3{width:520px;height:520px;left:20%;bottom:-240px;background:rgba(255,255,255,.05)}
.grain{
  position:absolute;inset:0;opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
@media (max-width:820px){.grain{display:none}}

/* ===== Hero ===== */
.hero{min-height:100vh;padding-top:92px;display:grid;place-items:center;position:relative}
.hero-lottie{
  position:relative;
  display:block;
  pointer-events:none;
  z-index:6;
  opacity:1;
  transition:opacity .5s ease;
  min-height:320px;
}
.hero-lottie.hide{opacity:0}
.lottie-stage{
  position:absolute;
  left:50%;
  top:50%;
  width:min(58vw, 520px);
  height:min(58vw, 520px);
  opacity:0;
  transform:translate3d(calc(-50% + var(--lottie-x, 0%)), -50%, 0) scale(.92);
  transition:opacity .35s ease, transform .5s cubic-bezier(.2,1,.2,1);
}
.lottie-stage.show{opacity:1;transform:translate3d(calc(-50% + var(--lottie-x, 0%)), -50%, 0) scale(1)}
.lottie-growth{
  width:min(34vw, 300px);
  height:min(34vw, 300px);
  top:22%;
  z-index:1;
  --lottie-x:6%;
}
.lottie-handshake{
  top:63%;
  z-index:2;
}
@media (max-width:820px){
  .lottie-growth{top:42%}
}
.hero-copy{
  position:relative;
  z-index:5;
  text-align:center;
  max-width:980px;
  padding:0 18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}
.title{font-size:clamp(3.6rem,7.4vw,6.2rem);letter-spacing:.18em;font-weight:600;line-height:1.02}
.hero-copy .title{margin-top:10px}
.title-anim{opacity:0;transform:translateY(14px)}
.tagline,
.hero-actions{opacity:0;transform:translateY(14px) scale(.99)}
.title-shine{
  display:inline-block;
  background:linear-gradient(90deg,rgba(255,255,255,.55),rgba(255,255,255,1),rgba(255,255,255,.55));
  background-size:240% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shine 2.4s ease-in-out infinite;
}
@keyframes shine{0%{background-position:0% 0%}50%{background-position:100% 0%}100%{background-position:0% 0%}}
.tagline{margin-top:18px;color:rgba(255,255,255,.62);font-size:14px;letter-spacing:.22em;text-transform:none}
.hero-actions{margin-top:30px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 22px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  text-decoration:none;color:#fff;background:rgba(255,255,255,.05);
  font-size:16px;font-weight:600;
  transition:transform .22s ease,background .22s ease,border-color .22s ease;
}
.btn:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28)}
.btn.primary{background:rgba(255,255,255,.90);color:#000;border-color:rgba(255,255,255,.55)}

/* ===== Sections ===== */
.section{max-width:1180px;margin:0 auto;padding:110px 18px}
.section-head h2{font-size:2.6rem;font-weight:600}
.section-head p{margin-top:10px;color:var(--muted);line-height:1.6;max-width:760px}
.section-head.center{text-align:center}
.section-head.center p{margin-left:auto;margin-right:auto}

/* ===== Apple style scroll reveal (blur + lift) ===== */
.scroll-reveal{
  opacity:0;
  transform:translateY(14px);
  filter:blur(10px);
  transition:opacity .75s ease, transform .75s cubic-bezier(.2,1,.2,1), filter .75s ease;
  will-change:opacity, transform, filter;
}
.scroll-reveal.in{
  opacity:1;
  transform:translateY(0);
  filter:blur(0px);
}

/* Cards */
.cards{margin-top:34px;display:grid;gap:18px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card,.big-card,.process-card,.form,.contact-selector,.find-tile{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:22px;
}
.card,.big-card{padding:26px}
.card h3{font-weight:600;margin-bottom:10px;font-size:20px}
.card p{color:rgba(255,255,255,.62);line-height:1.6;font-size:16px}
.card.scroll-reveal,
.big-card.scroll-reveal{
  transition-delay:calc(var(--i, 0) * 90ms);
}
.card:hover,
.big-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.04);
}

.two-col{margin-top:34px;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.big-card h3{margin-top:14px;font-weight:600;line-height:1.25;font-size:22px}
.pill{display:inline-block;padding:7px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.60);font-size:12px;letter-spacing:.08em}
.bullets{margin-top:14px;display:grid;gap:10px;padding-left:18px}
.bullets li{color:rgba(255,255,255,.62);line-height:1.55;font-size:16px}

/* Process simple */
.process-wrap{position:relative;margin-top:34px;padding-left:42px}
.process-rail{
  position:absolute;
  left:14px;
  top:8px;
  bottom:8px;
  width:2px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.35), rgba(255,255,255,.08));
  opacity:.7;
}
.process-ball{
  position:absolute;
  left:50%;
  top:0;
  width:12px;height:12px;border-radius:50%;
  background:rgba(255,255,255,.96);
  box-shadow:0 0 0 8px rgba(255,255,255,.06), 0 12px 28px rgba(0,0,0,.35);
  transform:translate3d(-50%, 0, 0);
  transition:transform .7s cubic-bezier(.2,1,.2,1);
}
.process-simple .process-list{display:grid;gap:24px}
.process-card{
  position:relative;
  padding:24px 22px;
  display:flex;gap:18px;align-items:flex-start;
  overflow:hidden;
  transform:translate3d(0, calc(10px + var(--parallax, 0px) + var(--shift, 0px)), 0) scale(.985);
  transition:
    transform .9s cubic-bezier(.16,1.2,.3,1),
    border-color .5s ease,
    background .5s ease,
    box-shadow .6s ease,
    filter .6s ease,
    opacity .6s ease;
  transition-delay:calc(var(--i, 0) * 90ms);
  box-shadow:0 0 0 rgba(0,0,0,0);
}
.process-card::before{
  content:"";
  position:absolute;inset:-1px;
  background:
    radial-gradient(140% 120% at 20% 0%, rgba(255,255,255,.18), transparent 60%),
    linear-gradient(110deg, rgba(255,255,255,.18), transparent 40%, rgba(255,255,255,.12));
  opacity:0;
  transition:opacity .7s ease;
  pointer-events:none;
}
.process-card::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 45%, transparent 70%);
  transform:translateX(-120%);
  opacity:.75;
  transition:transform 1.2s cubic-bezier(.2,1,.2,1);
  pointer-events:none;
}
.process-card.scroll-reveal.in{
  transform:translate3d(0, calc(var(--parallax, 0px) + var(--shift, 0px)), 0) scale(1);
  box-shadow:0 18px 60px rgba(0,0,0,.35);
}
.process-card.scroll-reveal.in::before{opacity:1}
.process-card.scroll-reveal.in::after{transform:translateX(120%)}
.process-card.is-dim{
  filter:blur(8px);
  opacity:.28;
  transform:translate3d(0, calc(var(--parallax, 0px) + var(--shift, 0px)), 0) scale(.98);
}
.process-card.is-active{
  filter:blur(0);
  opacity:1;
  border-color:rgba(255,255,255,.26);
  background:rgba(255,255,255,.06);
}
.process-card:hover{
  transform:translate3d(0, calc(-6px + var(--parallax, 0px)), 0) scale(1.01);
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
}
.pc-num{
  min-width:40px;
  font-size:12px;
  letter-spacing:.18em;
  color:rgba(255,255,255,.50);
  padding-top:6px;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,1,.2,1);
  transition-delay:calc(var(--i, 0) * 90ms + 80ms);
}
.pc-main h3{font-size:22px;font-weight:600}
.pc-main p{margin-top:8px;color:rgba(255,255,255,.62);line-height:1.6;font-size:17px}
.process-card.scroll-reveal.in .pc-num{
  opacity:1;
  transform:translateY(0);
}
.process-card .pc-main{
  opacity:0;
  transform:translateY(12px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,1,.2,1);
  transition-delay:calc(var(--i, 0) * 90ms + 140ms);
}
.process-card.scroll-reveal.in .pc-main{
  opacity:1;
  transform:translateY(0);
}

/* Contact simple */
.contact-simple .contact-wrap{margin-top:34px;width:min(760px,92vw);margin-left:auto;margin-right:auto;display:grid;gap:20px}
.contact-selector{padding:10px;display:grid;gap:8px}
.label{font-size:14px;color:rgba(255,255,255,.65);font-weight:600}
.form.simple{padding:10px;display:grid;gap:10px}
.form.simple .btn{
  display:flex;
  margin:10px auto 0;
  font-size:18px;
}
select,input,textarea{
  width:100%;
  padding:9px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.02);
  color:#fff;
  outline:none;
  font-size:16px;
  line-height:1.45;
  font-weight:500;
  transition:border-color .22s ease, background .22s ease, box-shadow .22s ease;
  -webkit-appearance:none;appearance:none;
}
textarea{min-height:130px;resize:vertical}
::placeholder{color:rgba(255,255,255,.40);font-weight:500}
select:focus,input:focus,textarea:focus{
  border-color:rgba(255,255,255,.30);
  background:rgba(255,255,255,.03);
  box-shadow:0 0 0 7px rgba(255,255,255,.05);
}
select{
  padding-right:44px;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.75) 50%),
    linear-gradient(135deg, rgba(255,255,255,.75) 50%, transparent 50%);
  background-position: calc(100% - 22px) 50%, calc(100% - 16px) 50%;
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}

/* Find us (appealing) */
.find-us{margin-top:22px;padding:0;position:relative}
.find-us::before{display:none}
.find-head{position:relative}
.find-head h3{font-size:22px;font-weight:600}
.find-head p{margin-top:6px;color:rgba(255,255,255,.62);line-height:1.5}
.find-grid{
  position:relative;
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.find-tile{
  padding:16px;
  text-decoration:none;
  color:#fff;
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  gap:12px;
  transition:transform .22s ease, background .22s ease, border-color .22s ease;
}
.find-tile:hover{
  transform:translateY(-4px);
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.22);
}
.ft-icon{
  width:30px;height:30px;border-radius:10px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  flex:0 0 auto;
}
.ft-icon svg{width:16px;height:16px;fill:currentColor;opacity:.85}
.ft-title{display:block;font-weight:600;font-size:16px}

/* Footer */
.footer{padding:36px 18px;border-top:1px solid rgba(255,255,255,.08)}
.footer-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px;color:rgba(255,255,255,.55)}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-name{letter-spacing:.18em;font-weight:600;color:rgba(255,255,255,.75);font-size:12px}

/* Responsive */
@media (max-width:1020px){
  .nav-links{display:none}
  .cards.three{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .find-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;align-items:flex-start}
}
