:root {
  --bg:#030304;
  --panel:#0b0b0d;
  --text:#f7f7f8;
  --muted:#a1a1aa;
  --line:rgba(255,255,255,.11);
  --line2:rgba(255,255,255,.18);
  --accent:#7b52e2;
  --soft:#a996ff;
  --radius:28px;
  --container:1180px
}
* {
  box-sizing:border-box
}
html {
  scroll-behavior:smooth
}
body {
  margin:0;
  background:radial-gradient(circle at 80% 0%,rgba(123,82,226,.18),transparent 30%),var(--bg);
  color:var(--text);
  font-family:Manrope,Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden
}
a {
  color:inherit;
  text-decoration:none
}
button,input,textarea,select {
  font:inherit
}
.noise {
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E")
}
.container {
  width:min(var(--container),calc(100vw - 48px));
  margin:0 auto;
  position:relative;
  z-index:1
}
.section {
  padding:92px 0;
  position:relative
}
.small {
  font-size:14px
}
.muted {
  color:var(--muted)
}
.eyebrow {
  color:var(--soft);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:13px;
  font-weight:800;
  margin:0 0 24px
}
h1,h2,h3,p {
  margin-top:0
}
h1 {
  font-size:clamp(56px,7.4vw,112px);
  line-height:.96;
  letter-spacing:-.07em;
  max-width:800px;
  margin-bottom:28px
}
h2 {
  font-size:clamp(36px,4.2vw,64px);
  line-height:1.02;
  letter-spacing:-.055em;
  margin-bottom:20px
}
h3 {
  font-size:22px;
  letter-spacing:-.03em
}
.lead,.section-lead {
  color:#d5d5da;
  font-size:clamp(18px,2vw,22px);
  line-height:1.55;
  max-width:610px
}
p {
  color:var(--muted);
  line-height:1.72
}
.site-header {
  width:min(1280px,calc(100vw - 40px));
  height:76px;
  position:fixed;
  z-index:50;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 18px 0 22px;
  border:1px solid transparent;
  border-radius:22px;
  transition:.3s
}
.site-header.scrolled {
  background:rgba(8,8,10,.72);
  backdrop-filter:blur(22px);
  border-color:var(--line)
}
.brand {
  display:flex;
  align-items:center;
  gap:14px;
  font-weight:800;
  letter-spacing:.34em;
  font-size:14px
}
.logo-mark {
  fill:var(--text);
  flex:none
}
.nav {
  display:flex;
  align-items:center;
  gap:28px;
  font-size:14px;
  font-weight:700
}
.nav a {
  color:#ededf0;
  opacity:.82;
  transition:.2s
}
.nav a:hover,.nav a.active {
  opacity:1;
  color:#fff
}
/*.nav a.active:after {*/
/*  content:"";*/
/*  display:block;*/
/*  width:6px;*/
/*  height:6px;*/
/*  border-radius:99px;*/
/*  background:var(--soft);*/
/*  margin:7px auto 0*/
/*}*/
.button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 22px;
  border-radius:12px;
  border:1px solid var(--line);
  font-weight:800;
  transition:transform .22s,border-color .22s,background .22s
}
.button:hover {
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.32)
}
.button-primary {
  background:#fff;
  color:#08080a;
  box-shadow:0 16px 40px rgba(255,255,255,.10)
}
.button-ghost {
  background:rgba(255,255,255,.04)
}
.button-link {
  opacity:.82;
  min-height:48px;
  display:inline-flex;
  align-items:center;
  font-weight:800
}
.actions {
  display:flex;
  align-items:center;
  gap:24px;
  margin-top:34px
}
.lang {
  position:relative
}
.lang-button {
  height:38px;
  min-width:64px;
  padding:0 12px;
  border-radius:11px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:#fff;
  cursor:pointer;
  font-weight:800
}
.lang-menu {
  position:absolute;
  top:48px;
  right:0;
  min-width:170px;
  background:rgba(12,12,14,.94);
  border:1px solid var(--line);
  border-radius:16px;
  padding:8px;
  display:none;
  backdrop-filter:blur(20px)
}
.lang.open .lang-menu {
  display:block
}
.lang-menu a {
  display:block;
  padding:11px 12px;
  border-radius:11px
}
.lang-menu a:hover,.lang-menu a.active {
  background:rgba(255,255,255,.08)
}
.nav-toggle {
  display:none;
  background:none;
  border:0;
  width:44px;
  height:44px
}
.nav-toggle span {
  display:block;
  height:2px;
  background:#fff;
  margin:7px 0
}
.hero {
  min-height:780px;
  display:flex;
  align-items:center;
  padding-top:150px;
  overflow:hidden
}
.hero-compact {
  min-height:620px
}
.hero-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center
}
.hero-copy {
  position:relative;
  z-index:3
}
.orbital {
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden
}
.arc {
  position:absolute;
  width:900px;
  height:420px;
  border-radius:50%;
  right:-70px;
  top:150px;
  transform:rotate(-14deg);
  border-top:2px solid rgba(255,255,255,.5);
  background:linear-gradient(180deg,rgba(255,255,255,.13),rgba(255,255,255,.01) 38%,transparent);
  filter:drop-shadow(0 0 24px rgba(123,82,226,.24))
}
.arc-2 {
  top:260px;
  right:-190px;
  opacity:.75
}
.arc-3 {
  top:420px;
  right:120px;
  width:980px;
  opacity:.42
}
.trust {
  padding-top:0
}
.logo-row {
  display:flex;
  gap:70px;
  flex-wrap:wrap;
  color:#bdbdc4;
  font-weight:800;
  opacity:.72;
  margin-top:24px
}
.cards-section {
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)
}
.feature-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px
}
.feature-card,.work-card {
  border:1px solid var(--line);
  border-radius:22px;
  padding:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  transition:.25s
}
.feature-card:hover,.work-card:hover {
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.24)
}
.icon-dot {
  width:52px;
  height:52px;
  border-radius:15px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  margin-bottom:24px;
  color:#fff
}
.process-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:64px
}
.process-item span {
  color:var(--soft);
  font-size:28px;
  font-weight:800;
  display:block;
  margin-bottom:28px
}
.impact-card {
  min-height:360px;
  overflow:hidden;
  display:grid;
  grid-template-columns:1.1fr 1fr .7fr;
  border:1px solid var(--line2);
  border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.018))
}
.impact-card>div {
  padding:56px
}
.planet {
  min-height:320px;
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
  background:radial-gradient(circle at 80% 60%,rgba(123,82,226,.5),transparent 34%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.38),transparent 20%)
}
.metrics {
  display:grid;
  align-content:center
}
.metrics div,.stats-bar div {
  border-bottom:1px solid var(--line);
  padding:24px 0
}
.metrics strong,.stats-bar strong {
  font-size:48px;
  display:block;
  color:#fff;
  letter-spacing:-.06em
}
.metrics span,.stats-bar span {
  color:var(--muted)
}
.cta-panel {
  min-height:190px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  border:1px solid var(--line2);
  border-radius:var(--radius);
  padding:44px 56px;
  background:radial-gradient(circle at 85% 40%,rgba(123,82,226,.33),transparent 34%),linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02))
}
.split-card {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:56px;
  background:rgba(255,255,255,.035)
}
.value-list {
  display:grid;
  gap:20px
}
.value-list div {
  display:grid;
  grid-template-columns:42px 1fr;
  column-gap:16px
}
.value-list span {
  grid-row:span 2;
  width:42px;
  height:42px;
  border-radius:14px;
  background:rgba(123,82,226,.13);
  display:grid;
  place-items:center;
  color:var(--soft)
}
.value-list strong {
  color:#fff
}
.value-list p {
  margin:4px 0 0
}
.stats-bar {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden
}
.stats-bar div {
  padding:34px;
  border-bottom:0;
  border-right:1px solid var(--line)
}
.jobs {
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  margin-top:34px
}
.job-row {
  display:grid;
  grid-template-columns:1fr 160px 160px 40px;
  gap:16px;
  align-items:center;
  padding:22px 28px;
  border-bottom:1px solid var(--line);
  transition:.2s
}
.job-row:hover {
  background:rgba(255,255,255,.05)
}
.job-row:last-child {
  border-bottom:0
}
.job-row span {
  color:var(--muted)
}
.work-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px
}
.work-card {
  min-height:260px
}
.work-card span {
  color:var(--soft);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px
}
.contact-section {
  padding-top:170px
}
.contact-grid {
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:80px;
  align-items:start
}
.contact-form {
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  background:rgba(255,255,255,.045);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px
}
.contact-form label {
  color:#fff;
  font-weight:800;
  font-size:13px;
  display:grid;
  gap:10px
}
.contact-form .full {
  grid-column:1/-1
}
input,textarea,select {
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  background:#070708;
  color:#fff;
  padding:15px 16px;
  outline:none;
  transition:.2s
}
input:focus,textarea:focus,select:focus {
  border-color:var(--soft);
  box-shadow:0 0 0 4px rgba(123,82,226,.12)
}
.form-status {
  grid-column:1/-1;
  min-height:24px
}
.contact-note {
  margin-top:42px;
  display:grid;
  gap:8px
}
.contact-note strong {
  font-size:22px
}
.contact-note span {
  color:var(--muted)
}
.footer {
  border-top:1px solid var(--line);
  padding-bottom:34px
}
.footer-grid {
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:64px
}
.footer a {
  display:block;
  color:var(--muted);
  margin:10px 0;
  transition:.2s
}
.footer a:hover {
  color:#fff
}
.footer h4 {
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px
}
.footer-brand {
  margin-bottom:22px
}
.socials {
  display:flex;
  gap:12px;
  margin-top:22px
}
.socials a {
  width:34px;
  height:34px;
  border:1px solid var(--line);
  border-radius:10px;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:12px
}
.copyright {
  color:#777;
  border-top:1px solid var(--line);
  margin-top:50px;
  padding-top:28px;
  font-size:13px
}
.reveal {
  opacity:0;
  transform:translateY(22px);
  transition:opacity .7s,transform .7s;
  transition-delay:var(--delay,0ms)
}
.reveal.visible {
  opacity:1;
  transform:translateY(0)
}
@media(max-width:920px) {
  .site-header {
    top:12px
  }
  .nav-toggle {
    display:block
  }
  .nav {
    position:fixed;
    top:84px;
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding:20px;
    background:rgba(8,8,10,.96);
    border:1px solid var(--line);
    border-radius:22px;
    backdrop-filter:blur(22px)
  }
  .nav.open {
    display:flex
  }
  .nav a.active:after {
    display:none
  }
  .hero {
    min-height:720px
  }
  .hero-grid,.split-card,.contact-grid {
    grid-template-columns:1fr
  }
  .feature-grid,.process-grid,.work-grid {
    grid-template-columns:1fr
  }
  .impact-card {
    grid-template-columns:1fr
  }
  .planet {
    display:none
  }
  .stats-bar {
    grid-template-columns:1fr 1fr
  }
  .footer-grid {
    grid-template-columns:1fr 1fr
  }
  .job-row {
    grid-template-columns:1fr
  }
  .contact-form {
    grid-template-columns:1fr
  }

}
@media(max-width:560px) {
  .container {
    width:min(100% - 28px,var(--container))
  }
  .brand span {
    letter-spacing:.22em
  }
  h1 {
    font-size:54px
  }
  .section {
    padding:68px 0
  }
  .hero {
    padding-top:130px
  }
  .actions,.cta-panel {
    flex-direction:column;
    align-items:flex-start
  }
  .cta-panel,.split-card,.feature-card,.work-card {
    padding:26px
  }
  .stats-bar,.footer-grid {
    grid-template-columns:1fr
  }

}



/* Production header, navigation, and language selector polish */
.site-header {
  isolation: isolate;
}

.nav {
  min-width: 0;
}

.nav-cta {
  white-space: nowrap;
}

.lang {
  position: relative;
  display: flex;
  align-items: center;
  flex: none;
}

.lang-button {
  height: 42px;
  min-width: 76px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, .055);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.lang-button:hover {
  background: rgba(255, 255, 255, .09);
  border-color: rgba(255, 255, 255, .22);
}

.lang-current {
  letter-spacing: .04em;
}

.lang-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: .7;
  transform: translateY(-1px);
  transition: transform .2s ease, opacity .2s ease;
}

.lang.open .lang-chevron {
  transform: translateY(-1px) rotate(180deg);
  opacity: 1;
}

.lang-menu {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  z-index: 90;
  min-width: 210px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(12, 12, 14, .96);
  box-shadow: 0 26px 80px rgba(0, 0, 0, .38);
  backdrop-filter: blur(22px);
  display: none;
}

.lang.open .lang-menu {
  display: grid;
  gap: 4px;
}

.lang-menu a {
  min-height: 42px;
  padding: 0 12px;
  border-radius: 12px;
  color: #ededf0;
  opacity: .86;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  text-decoration: none;
  white-space: nowrap;
}

.lang-menu a:hover,
.lang-menu a.active {
  background: rgba(255, 255, 255, .085);
  color: #fff;
  opacity: 1;
}

.lang-label {
  overflow: hidden;
  text-overflow: ellipsis;
}

.lang-check {
  color: var(--soft);
  font-weight: 900;
  flex: none;
}

.nav-toggle {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, .045);
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}

.nav-toggle:hover {
  background: rgba(255, 255, 255, .08);
  border-color: rgba(255, 255, 255, .2);
}

.nav-toggle span {
  border-radius: 999px;
  transition: transform .22s ease, opacity .22s ease;
}

.nav-toggle.open span:first-child {
  transform: translateY(4.5px) rotate(45deg);
}

.nav-toggle.open span:last-child {
  transform: translateY(-4.5px) rotate(-45deg);
}

@media (max-width: 1100px) {
  .nav {
    gap: 18px;
  }
}

@media (max-width: 920px) {
  .site-header {
    width: min(100% - 24px, 1280px);
    height: 68px;
    padding: 0 12px 0 16px;
    background: rgba(8, 8, 10, .78);
    border-color: var(--line);
    backdrop-filter: blur(22px);
  }

  .brand {
    min-width: 0;
  }

  .brand span {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .nav-toggle {
    display: block;
    flex: none;
  }

  .nav {
    position: fixed;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: rgba(8, 8, 10, .97);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .36);
    backdrop-filter: blur(24px);
  }

  .nav.open {
    display: flex;
  }

  .nav > a:not(.button) {
    min-height: 46px;
    padding: 0 12px;
    border-radius: 14px;
    display: flex;
    align-items: center;
  }

  .nav > a:not(.button):hover,
  .nav > a:not(.button).active {
    background: rgba(255, 255, 255, .06);
  }

  .nav a.active::after {
    display: none;
  }

  .nav-cta {
    width: 100%;
    margin-top: 4px;
  }

  .lang {
    width: 100%;
    display: block;
  }

  .lang-button {
    width: 100%;
    height: 46px;
    justify-content: space-between;
    border-radius: 14px;
    padding: 0 12px;
  }

  .lang-menu {
    position: static;
    width: 100%;
    min-width: 0;
    margin-top: 8px;
    box-shadow: none;
    background: rgba(255, 255, 255, .045);
  }

  .lang-menu a {
    min-height: 44px;
  }
}

@media (max-width: 560px) {
  .site-header {
    width: calc(100% - 20px);
    top: 10px;
    border-radius: 18px;
  }

  .brand span {
    max-width: 124px;
  }
}

/* Final premium language selector polish */
.lang {
  position: relative;
  display: flex;
  align-items: center;
  flex: none;
}

.lang-button {
  height: 42px;
  min-width: 76px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .035));
  color: #fff;
  cursor: pointer;
  font-weight: 800;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
  transition:
    background .2s ease,
    border-color .2s ease,
    box-shadow .2s ease,
    transform .2s ease;
}

.lang-button:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .055));
  border-color: rgba(255, 255, 255, .24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .12),
    0 12px 34px rgba(0, 0, 0, .22);
}

.lang-current {
  letter-spacing: .045em;
}

.lang-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: .72;
  transform: translateY(-1px);
  transition: transform .2s ease, opacity .2s ease;
}

.lang.open .lang-chevron {
  transform: translateY(-1px) rotate(180deg);
  opacity: 1;
}

.lang-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 90;
  width: 188px;
  min-width: 188px;
  padding: 7px;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .02)),
    rgba(9, 9, 12, .965);
  box-shadow:
    0 26px 80px rgba(0, 0, 0, .42),
    inset 0 1px 0 rgba(255, 255, 255, .06);
  backdrop-filter: blur(24px);
  display: none;
  transform-origin: top right;
}

.lang.open .lang-menu {
  display: grid;
  gap: 3px;
  animation: langMenuIn .16s ease-out both;
}

@keyframes langMenuIn {
  from {
    opacity: 0;
    transform: translateY(-4px) scale(.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.lang-menu a {
  min-height: 38px;
  padding: 0 10px 0 12px;
  border-radius: 12px;
  color: #ededf0;
  opacity: .72;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background .18s ease,
    color .18s ease,
    opacity .18s ease,
    transform .18s ease;
}

.lang-menu a:hover {
  background: rgba(255, 255, 255, .065);
  color: #fff;
  opacity: 1;
  transform: translateX(1px);
}

.lang-menu a.active {
  background: rgba(160, 132, 255, .14);
  color: #fff;
  opacity: 1;
  font-weight: 800;
}

.lang-label {
  overflow: hidden;
  text-overflow: ellipsis;
}

.lang-code {
  min-width: 26px;
  padding: 3px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .06);
  color: rgba(255, 255, 255, .58);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-align: center;
  flex: none;
}

.lang-menu a.active .lang-code {
  background: rgba(160, 132, 255, .20);
  color: #b9a7ff;
}

.lang-check {
  display: none;
}

@media (max-width: 920px) {
  .lang {
    width: 100%;
    display: block;
  }

  .lang-button {
    width: 100%;
    height: 48px;
    justify-content: space-between;
    border-radius: 15px;
    padding: 0 13px;
  }

  .lang-menu {
    position: static;
    width: 100%;
    min-width: 0;
    margin-top: 8px;
    padding: 6px;
    box-shadow: none;
    background: rgba(255, 255, 255, .045);
    transform-origin: top center;
  }

  .lang-menu a {
    min-height: 44px;
  }
}
