.lp-wrap{
  width:min(1120px, calc(100% - 32px));
  margin-inline:auto;
}

.lp-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(7,12,22,.88);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.1);
}

.lp-topbar{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.lp-brand{
  color:var(--text);
  text-decoration:none;
  font-weight:800;
  letter-spacing:.3px;
  font-size:1.05rem;
  flex:0 0 auto;
}

.lp-login{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:auto;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.lp-login input{
  width:200px;
  max-width:42vw;
  padding:10px 12px;
}

.lp-login button,
.lp-session button,
.lp-linkbtn{
  border:0;
  border-radius:10px;
  padding:10px 14px;
  font-weight:700;
  text-decoration:none;
  cursor:pointer;
  background:var(--primary);
  color:#fff;
}

.lp-register-btn{
  border:1px solid rgba(255,255,255,.2);
  border-radius:10px;
  padding:10px 14px;
  font-weight:700;
  text-decoration:none;
  cursor:pointer;
  background:rgba(255,255,255,.08);
  color:#fff;
}

.lp-session{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

#topSessionName{
  color:var(--text);
  font-weight:700;
  padding:8px 10px;
  border-radius:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
}

.lp-linkbtn{
  background:rgba(255,255,255,.14);
}

.lp-hero{
  padding:72px 0 38px;
}

.lp-kicker{
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#7db1ff;
  font-size:.78rem;
  margin:0 0 14px;
  font-weight:700;
}

.lp-hero h1{
  margin:0;
  max-width:900px;
  font-size:clamp(1.9rem, 3.4vw, 3rem);
  line-height:1.08;
}

.lp-sub{
  margin-top:16px;
  max-width:820px;
  color:var(--muted);
  font-size:1.05rem;
  line-height:1.6;
}

.lp-section{
  padding:18px 0 34px;
}

.lp-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}

.lp-card{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  padding:20px;
}

.lp-card h2{
  margin:0 0 10px;
  font-size:1.12rem;
}

.lp-card p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

.lp-cta{
  padding-top:8px;
  padding-bottom:80px;
}

.lp-cta h2{
  margin:0 0 8px;
  font-size:1.45rem;
}

.lp-cta p{
  margin:0;
  color:var(--muted);
  line-height:1.6;
  max-width:820px;
}

.lp-status{
  width:min(1120px, calc(100% - 32px));
  margin:0 auto 30px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.26);
}

.lp-status.err{border-color:rgba(255,95,115,.45); color:#ff8a9a;}
.lp-status.ok{border-color:rgba(57,217,138,.45); color:#75e5af;}
.hidden{display:none !important;}

@media (max-width: 960px){
  .lp-grid{grid-template-columns:1fr;}
  .lp-topbar{align-items:flex-start; padding:10px 0;}
  .lp-login,
  .lp-session{width:100%;}
  .lp-login input{width:100%; max-width:none;}
}
