.site-shell {
  position: relative;
  min-height: 100vh;
  opacity: 0;
  overflow: hidden;
}

.topbar {
  position: relative;
  z-index: 30;
  width: 100%;
  padding: 24px 34px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.topbar-left,
.topbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.brand-mark img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
}

.brand-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.brand-name {
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.brand-domain {
  font-size: 0.74rem;
  color: rgba(239, 247, 255, 0.58);
}

.hero-section {
  position: relative;
  z-index: 10;
  min-height: calc(100vh - 90px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 22px 56px;
}

.hero-content {
  position: relative;
  z-index: 15;
  width: min(1100px, 100%);
  text-align: center;
}

.site-footer {
  position: relative;
  z-index: 20;
  padding: 0 24px 24px;
  text-align: center;
  color: rgba(239, 247, 255, 0.56);
  font-size: 0.82rem;
}