
:root{
  color-scheme: dark;
  --bg:#0e0619;
  --bg2:#140a25;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.09);
  --line: rgba(255,255,255,.12);
  --text:#f7f2ff;
  --muted: rgba(247,242,255,.72);
  --muted2: rgba(247,242,255,.52);
  --accent:#dfc8ff;
  --accent2:#b47cff;
  --shadow: 0 28px 60px rgba(0,0,0,.28);
  --radius: 28px;
  --max: 1180px;
  --ease:cubic-bezier(.2,.8,.2,1);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; min-width:320px; background:
    radial-gradient(circle at top, rgba(177,117,255,.17), transparent 34%),
    radial-gradient(circle at 80% 20%, rgba(226,191,255,.08), transparent 28%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  color:var(--text);
}
img{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font:inherit}
.wrap{position:relative; min-height:100vh; overflow:hidden}
.grain{
  position:fixed; inset:0; pointer-events:none; opacity:.06;
  background-image:radial-gradient(rgba(255,255,255,.85) 1px, transparent 1px);
  background-size:18px 18px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.9), transparent 95%);
}
.orb{
  position:fixed; border-radius:999px; filter: blur(70px); pointer-events:none;
}
.orb.one{left:-120px; top:120px; width:320px; height:320px; background:rgba(161,76,255,.18)}
.orb.two{right:-110px; top:260px; width:420px; height:420px; background:rgba(231,196,255,.11)}
.topbar{
  position:sticky; top:0; z-index:30;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:16px 22px; border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(24px); background: rgba(14,6,25,.78);
}
.brand{
  display:flex; align-items:center; gap:12px; min-width:0;
}
.brand-mark{
  width:46px; height:46px; border-radius:16px; overflow:hidden;
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.05);
  box-shadow:0 12px 30px rgba(0,0,0,.24);
  flex:none;
}
.brand-mark img{width:100%; height:100%; object-fit:cover}
.brand-text{line-height:1}
.brand-name{font-size:18px; font-weight:700; letter-spacing:-.03em}
.brand-sub{font-size:12px; color:var(--muted2); margin-top:5px}
.nav{display:none; gap:8px; align-items:center}
.nav a{
  padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.78); transition:transform .18s var(--ease), background .18s var(--ease), color .18s var(--ease);
}
.nav a:hover{transform:translateY(-1px); background:rgba(255,255,255,.1); color:#fff}
.nav a.active{background:#fff; color:#180b29; box-shadow:0 14px 32px rgba(0,0,0,.2)}
.actions{display:flex; gap:12px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:13px 20px; border-radius:999px;
  font-weight:600; font-size:14px; transition:transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.btn:hover{transform:translateY(-1px)}
.btn-outline{border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.05)}
.btn-solid{background:#fff; color:#180b29; border:1px solid rgba(255,255,255,.08)}
.container{max-width:var(--max); margin:0 auto; padding:28px 20px 88px; position:relative; z-index:1}
.kicker{
  text-transform:uppercase; letter-spacing:.38em; font-size:11px; color:rgba(232,216,255,.72); margin:0;
}
.page-title{
  margin:14px 0 0; max-width:980px; font-size:clamp(40px,6vw,72px); line-height:.97; letter-spacing:-.05em;
}
.hero{
  position:relative; overflow:hidden; margin-top:28px; border:1px solid rgba(255,255,255,.1);
  border-radius:32px; box-shadow:var(--shadow);
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.14), transparent 22%),
    linear-gradient(135deg, rgba(127,50,216,.3), rgba(58,20,88,.38) 50%, rgba(17,8,31,.94));
  padding:28px;
}
.hero-grid{display:grid; gap:24px}
.badge{
  display:inline-flex; align-items:center; gap:8px; margin:0; padding:7px 12px;
  border-radius:999px; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.07);
  text-transform:uppercase; font-size:12px; letter-spacing:.28em; color:rgba(255,255,255,.74)
}
.hero h1{
  margin:16px 0 0; font-size:clamp(40px,5.8vw,74px); line-height:.96; letter-spacing:-.06em; max-width:820px;
}
.hero h1 strong{color:var(--accent)}
.region{margin:16px 0 0; color:rgba(255,255,255,.48); text-transform:uppercase; letter-spacing:.3em; font-size:11px}
.hero p.copy{margin:20px 0 0; max-width:840px; line-height:1.8; color:var(--muted); font-size:15px}
.row{display:flex; gap:12px; flex-wrap:wrap; margin-top:26px}
.stat-grid{display:grid; gap:16px; grid-template-columns:repeat(3,minmax(0,1fr)); margin-top:18px}
.stat{
  padding:18px; border-radius:22px; border:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.2)
}
.stat .value{font-size:28px; font-weight:700; letter-spacing:-.04em}
.stat .label{margin-top:8px; color:rgba(255,255,255,.56); font-size:12px; text-transform:uppercase; letter-spacing:.28em}
.hero-side{
  display:grid; gap:14px; padding:5px
}
.mini{
  padding:16px; border-radius:22px; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.05)
}
.mini h3{margin:0; font-size:18px}
.mini p{margin:8px 0 0; color:var(--muted); line-height:1.7; font-size:14px}

.grid-3{display:grid; gap:16px; margin-top:24px}
.card{
  padding:24px; border-radius:28px; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.05);
  box-shadow:0 16px 40px rgba(0,0,0,.16); backdrop-filter: blur(16px);
}
.card h2,.card h3{margin:0}
.card p{color:var(--muted); line-height:1.8}
.icon{
  width:48px; height:48px; display:grid; place-items:center; border-radius:18px;
  background:rgba(255,255,255,.1); margin-bottom:16px; color:var(--accent)
}
.two-col{display:grid; gap:16px; margin-top:24px}
.panel{padding:24px; border-radius:28px; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.05)}
.panel h2,.panel h3{margin:0}
.panel p{color:var(--muted); line-height:1.8}
.service-grid{display:grid; gap:12px; grid-template-columns:repeat(2,minmax(0,1fr)); margin-top:22px}
.service-chip{
  display:flex; align-items:center; gap:10px; padding:12px 14px; border-radius:18px;
  border:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.16); color:rgba(255,255,255,.8); font-size:14px;
}
.stack{display:grid; gap:16px}
.panel-soft{background:rgba(255,255,255,.045)}
.icon-title{display:flex; align-items:center; gap:10px}
.terms{
  margin-top:20px; padding:18px; border-radius:20px; border:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.18)
}
.steps{list-style:none; padding:0; margin:20px 0 0; display:grid; gap:12px}
.step{display:flex; gap:12px; padding:14px; border-radius:18px; border:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.16)}
.step span{
  width:32px; height:32px; border-radius:999px; background:rgba(255,255,255,.1); display:grid; place-items:center; flex:none; font-weight:700
}
.step p{margin:4px 0 0; color:rgba(255,255,255,.78); line-height:1.7}
.note{margin-top:16px; padding:14px; border-radius:18px; border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.05); color:rgba(255,255,255,.7); line-height:1.7}

.intro{
  position:fixed; inset:0; z-index:60; display:flex; align-items:center; justify-content:center;
  background:#0b0415; overflow:hidden;
}
.intro .orb-a,.intro .orb-b{position:absolute; border-radius:999px; filter:blur(70px)}
.intro .orb-a{left:-24px; top:40px; width:280px; height:280px; background:rgba(141,60,255,.25)}
.intro .orb-b{right:-40px; bottom:-20px; width:360px; height:360px; background:rgba(208,107,255,.20)}
.intro-center{text-align:center; padding:0 24px; position:relative}
.intro-center .eyebrow{margin-bottom:18px}
.intro-brand{font-size:clamp(54px,7vw,100px); margin:0; font-weight:700; letter-spacing:-.06em}
.split-text{font-size:clamp(18px,2.5vw,26px); margin:24px 0 0}
.split-text .white{color:#fff}
.split-text .accent{color:#c8a7ff}
.intro-copy{color:rgba(255,255,255,.75); line-height:1.7; font-size:18px; margin:0}
.intro-line{
  margin:14px auto 0; width:min(120%,620px); height:2px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.92), transparent);
  border-radius:999px;
}
.shine{
  position:absolute; inset:0; background:linear-gradient(90deg, transparent, rgba(255,255,255,.11), transparent);
  width:45%; transform:skewX(-16deg); opacity:0;
}
.intro .shine{animation:sweep 4.8s linear infinite}
@keyframes sweep{0%{transform:translateX(-140%) skewX(-16deg); opacity:0}15%{opacity:.75}100%{transform:translateX(140%) skewX(-16deg); opacity:0}}
@keyframes floaty{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(18px,-14px,0)}}
.intro .orb-a{animation:floaty 12s ease-in-out infinite}
.intro .orb-b{animation:floaty 14s ease-in-out infinite reverse}
.reveal{opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease), transform .6s var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}

@media (min-width: 800px){
  .nav{display:flex}
  .hero-grid{grid-template-columns:1.15fr .85fr; align-items:center}
  .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .two-col{grid-template-columns:.95fr 1.05fr; align-items:start}
}
@media (max-width: 799px){
  .topbar{padding:14px 16px}
  .actions{display:none}
  .page-wrap{padding:22px 16px 72px}
  .hero{padding:22px}
  .stat-grid{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
}
