/* ============================================================
   PGSPACE — landing page styles
   ============================================================ */

/* ---------- HERO ---------- */
.hero{ min-height:100vh; display:flex; align-items:center; padding:120px 0 80px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; will-change:transform; }
.hero-title{ margin:22px 0 24px; }
.hero-actions{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-meta{ display:flex; align-items:center; gap:24px; margin-top:46px; }
.hero-meta > div{ display:flex; flex-direction:column; }
.hero-meta b{ font-family:var(--display); font-size:30px; line-height:1; }
.hero-meta span{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); margin-top:7px; }
.hero-meta .sep{ width:1px; height:36px; background:var(--line-2); }

/* ---- 3D stage + card ---- */
.hero-stage{ position:relative; perspective:1400px; display:flex; justify-content:center; }
.hero-card{
  position:relative; width:min(420px,90%); padding:30px; border-radius:24px;
  transform-style:preserve-3d; transition:transform .15s ease-out;
  background:linear-gradient(160deg, rgba(28,32,52,.92), rgba(13,15,26,.92));
  box-shadow:0 40px 90px -30px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.06);
}
.hero-card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1.4px;
  background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.85;
}
.hc-glow{ position:absolute; inset:-2px; border-radius:24px; background:var(--grad); filter:blur(36px); opacity:.28; z-index:-1; }
.hc-head{ display:flex; gap:16px; align-items:center; transform-style:preserve-3d; }
.hc-logo{ height:58px; width:auto; filter:drop-shadow(0 6px 16px rgba(224,86,110,.4)); }
.hc-kicker{ font-family:var(--mono); font-size:10.5px; letter-spacing:.26em; color:var(--ink-mute); }
.hc-title{ font-family:var(--display); font-size:22px; font-weight:600; line-height:1.1; margin-top:4px; }
.hc-rows{ margin:26px 0 22px; display:flex; flex-direction:column; gap:10px; transform-style:preserve-3d; }
.hc-row{ display:flex; align-items:center; gap:12px; padding:13px 14px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid var(--line); }
.hc-row.dim{ opacity:.7; }
.hc-ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; color:#fff; font-size:16px; flex-shrink:0; }
.hc-name{ flex:1; font-size:15px; font-weight:600; }
.hc-foot{ display:flex; justify-content:space-between; align-items:center; padding-top:18px; border-top:1px solid var(--line); }
.hc-mono{ font-family:var(--mono); font-size:11px; color:var(--ink-mute); }
.hc-bars{ display:flex; gap:4px; align-items:flex-end; height:18px; }
.hc-bars i{ width:4px; background:var(--grad); border-radius:2px; animation:eq 1.4s var(--ease) infinite; }
.hc-bars i:nth-child(1){ height:40%; animation-delay:0s; }
.hc-bars i:nth-child(2){ height:80%; animation-delay:.2s; }
.hc-bars i:nth-child(3){ height:55%; animation-delay:.4s; }
.hc-bars i:nth-child(4){ height:95%; animation-delay:.6s; }
@keyframes eq{ 0%,100%{ transform:scaleY(.5); } 50%{ transform:scaleY(1); } }

/* floating satellites */
.sat{ position:absolute; z-index:3; font-family:var(--mono); font-size:12px; padding:9px 14px; border-radius:12px;
  background:rgba(16,18,31,.8); border:1px solid var(--line-2); backdrop-filter:blur(10px); color:var(--ink-soft); }
.sat.s1{ top:6%; left:-4%; } .sat.s2{ bottom:14%; right:-6%; } .sat.s3{ top:64%; left:-8%; }

/* scroll cue */
.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); width:24px; height:40px; border:1.5px solid var(--line-2); border-radius:14px; display:grid; place-items:start center; padding-top:8px; }
.scroll-cue span{ width:4px; height:8px; border-radius:3px; background:var(--grad); animation:cue 1.6s infinite; }
@keyframes cue{ 0%{ opacity:0; transform:translateY(-4px); } 40%{ opacity:1; } 80%,100%{ opacity:0; transform:translateY(12px); } }

@media (max-width:920px){
  .hero-grid{ grid-template-columns:1fr; gap:60px; }
  .hero-stage{ order:-1; }
  .scroll-cue{ display:none; }
}

/* ---------- generic section ---------- */
.sec{ padding:110px 0; }
.sec-head{ max-width:680px; margin-bottom:54px; }
.sec-head h2{ margin:18px 0 0; }
.sec-head .lead{ margin-top:18px; }

/* ---------- SERVICES ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc{ padding:30px; border-radius:var(--radius); }
.svc .num{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); letter-spacing:.18em; }
.svc .ic{ width:48px; height:48px; border-radius:13px; display:grid; place-items:center; font-size:22px; margin:18px 0 18px; background:rgba(255,255,255,.04); border:1px solid var(--line); }
.svc h3{ font-size:21px; margin-bottom:10px; }
.svc p{ color:var(--ink-soft); font-size:15px; margin:0; }
@media (max-width:820px){ .svc-grid{ grid-template-columns:1fr; } }

/* ---------- ECOSYSTEM (scroll-pinned) ---------- */
.eco{ position:relative; }
.eco-sticky{ position:sticky; top:0; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
.eco-inner{ width:100%; }
.eco-orbit{ position:relative; height:clamp(380px,52vw,560px); perspective:1300px; }
.eco-plane{ position:absolute; inset:0; transform-style:preserve-3d; transition:transform .12s linear; }
.eco-core{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:clamp(150px,20vw,210px); height:clamp(150px,20vw,210px); border-radius:50%;
  display:grid; place-items:center; text-align:center; background:radial-gradient(circle at 50% 35%, rgba(40,46,72,.95), rgba(12,14,24,.95));
  border:1px solid var(--line-2); box-shadow:0 0 90px -10px rgba(122,95,134,.6); z-index:5; }
.eco-core img{ height:64px; }
.eco-core .lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.24em; color:var(--ink-mute); margin-top:8px; }
.eco-ring{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); border-radius:50%; border:1px dashed var(--line); }
.eco-ring.r1{ width:58%; padding-bottom:58%; } .eco-ring.r2{ width:90%; padding-bottom:90%; }
.eco-node{ position:absolute; transform:translate(-50%,-50%); width:clamp(130px,15vw,168px); }
.eco-node .card{ padding:18px; border-radius:16px; }
.eco-node .ic{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; color:#fff; font-size:18px; }
.eco-node h4{ font-size:16px; margin:12px 0 6px; }
.eco-node p{ font-size:12.5px; color:var(--ink-soft); margin:0 0 12px; line-height:1.5; }

@media (max-width:820px){
  .eco-sticky{ position:relative; min-height:auto; padding:40px 0; }
  .eco-orbit{ height:auto; perspective:none; }
  .eco-plane{ position:static; transform:none !important; transform-style:flat; display:flex; flex-direction:column; gap:16px; }
  .eco-ring{ display:none; }
  .eco-core{ position:relative; left:auto; top:auto; transform:none; margin:0 auto 14px; }
  .eco-node{ position:relative !important; left:auto !important; top:auto !important; transform:none !important; width:100%; opacity:1 !important; filter:none !important; }
}

/* ---------- PROCESS ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.step{ padding:26px; border-radius:var(--radius); position:relative; }
.step .n{ font-family:var(--display); font-size:40px; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.step h4{ font-size:18px; margin:16px 0 8px; }
.step p{ font-size:14px; color:var(--ink-soft); margin:0; }
@media (max-width:820px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .steps{ grid-template-columns:1fr; } }

/* ---------- STATS ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; text-align:center; }
.stat b{ font-family:var(--display); font-size:clamp(36px,5vw,56px); background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; display:block; }
.stat span{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
@media (max-width:620px){ .stats{ grid-template-columns:1fr 1fr; gap:34px; } }

/* ---------- CTA ---------- */
.cta-band{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:clamp(48px,7vw,90px); text-align:center;
  background:linear-gradient(160deg, rgba(28,32,52,.9), rgba(13,15,26,.9)); border:1px solid var(--line-2); }
.cta-band::before{ content:""; position:absolute; inset:0; background:var(--grad); opacity:.14; }
.cta-band::after{ content:""; position:absolute; width:420px; height:420px; border-radius:50%; background:var(--grad); filter:blur(120px); opacity:.4; top:-40%; left:50%; transform:translateX(-50%); }
.cta-band > *{ position:relative; }
.cta-band h2{ margin:16px auto 0; max-width:16ch; }
.cta-band .lead{ margin:20px auto 32px; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
