.public-page {
  --public-max: 1180px;
  max-width: var(--public-max);
  margin: 0 auto;
  padding: 24px 24px 64px;
}

.public-nav {
  position: sticky;
  top: 12px;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border: 1px solid rgba(122, 170, 255, 0.26);
  border-radius: 18px;
  padding: 10px 12px;
  background: rgba(5, 12, 31, 0.82);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 28px rgba(2, 8, 21, 0.38);
}

.public-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.public-brand img {
  width: min(250px, 40vw);
  height: auto;
  display: block;
  border-radius: 11px;
}

.public-nav-links {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.public-nav-links .menu-link,
.public-nav-links .button-link {
  font-size: 13px;
}

.hero {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 18px;
  border: 1px solid rgba(122, 170, 255, 0.28);
  border-radius: 24px;
  padding: clamp(20px, 3.4vw, 36px);
  background:
    radial-gradient(140% 120% at 8% -8%, rgba(47, 123, 255, 0.24), transparent 46%),
    radial-gradient(110% 120% at 100% 100%, rgba(108, 43, 255, 0.2), transparent 56%),
    rgba(6, 14, 36, 0.9);
  box-shadow: 0 22px 44px rgba(3, 9, 25, 0.52);
}

.hero-kicker {
  margin: 0 0 12px;
  color: #b5c7ec;
  font-weight: 650;
  letter-spacing: 0.02em;
}

.hero h1 {
  margin: 0;
  font-size: clamp(34px, 5.2vw, 62px);
  line-height: 1.02;
  text-wrap: balance;
  text-shadow: 0 0 16px rgba(47, 227, 233, 0.24), 0 0 32px rgba(108, 43, 255, 0.2);
  animation: hero-heartbeat 7.5s ease-in-out infinite;
}

.hero p {
  margin: 14px 0 0;
  max-width: 64ch;
  color: var(--muted);
  line-height: 1.5;
}

.hero-cta,
.cta-row {
  margin-top: 20px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hero-panel {
  border: 1px solid rgba(122, 170, 255, 0.24);
  border-radius: 18px;
  background: rgba(3, 11, 30, 0.8);
  padding: 16px;
  display: grid;
  gap: 10px;
}

.hero-panel .meta-card {
  border: 1px solid rgba(122, 170, 255, 0.2);
  border-radius: 13px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.02);
}

.section {
  margin-top: 18px;
  border: 1px solid rgba(122, 170, 255, 0.2);
  border-radius: 18px;
  background: rgba(10, 20, 45, 0.84);
  padding: clamp(18px, 2.5vw, 24px);
}

.section h2 {
  margin: 0 0 10px;
  font-size: clamp(28px, 4vw, 40px);
  letter-spacing: -0.01em;
}

.section h3 {
  margin: 0 0 8px;
  font-size: 18px;
}

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

.grid-3, .grid-4, .grid-2, .steps-3 {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.steps-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.public-card,
.step-card,
.plan-card,
.faq-item,
.policy-card {
  border: 1px solid rgba(122, 170, 255, 0.2);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.02);
  padding: 14px;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.step-number {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  font-weight: 800;
  color: #04142d;
  margin-bottom: 8px;
  background: linear-gradient(120deg, var(--brand-cyan), var(--brand-violet));
}

.plan-price {
  margin: 8px 0;
  font-size: 28px;
  font-weight: 780;
  color: #f6f8ff;
}

.fine-print {
  margin-top: 12px;
  font-size: 13px;
  color: #95a8cf;
}

.footer {
  margin-top: 22px;
  border: 1px solid rgba(122, 170, 255, 0.2);
  border-radius: 18px;
  background: rgba(8, 17, 39, 0.9);
  padding: 18px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.footer-title {
  margin: 0 0 8px;
  font-size: 14px;
  color: #dce7ff;
}

.footer-links {
  display: grid;
  gap: 7px;
}

.footer a { color: var(--muted); text-decoration: none; }
.footer a:hover, .footer a:focus-visible { color: #e5eeff; }

.final-band {
  margin-top: 18px;
  border: 1px solid rgba(90, 225, 236, 0.25);
  border-radius: 18px;
  padding: 20px;
  background: linear-gradient(130deg, rgba(7, 17, 41, 0.88), rgba(20, 12, 42, 0.86));
}

@keyframes hero-heartbeat {
  0%, 38%, 100% { transform: scale(1); text-shadow: 0 0 16px rgba(47, 227, 233, 0.24), 0 0 32px rgba(108, 43, 255, 0.2); }
  42% { transform: scale(1.008); text-shadow: 0 0 20px rgba(47, 227, 233, 0.30), 0 0 38px rgba(108, 43, 255, 0.26); }
  46% { transform: scale(1.003); }
}

@media (hover: hover) {
  .public-card:hover,
  .step-card:hover,
  .plan-card:hover,
  .faq-item:hover,
  .policy-card:hover {
    transform: translateY(-2px);
    border-color: rgba(123, 184, 255, 0.38);
    box-shadow: 0 10px 24px rgba(2, 10, 28, 0.4);
  }
}

@media (max-width: 1040px) {
  .hero { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .public-page { padding: 14px 12px 42px; }
  .public-nav { position: static; }
  .grid-4, .grid-3, .grid-2, .steps-3, .footer-grid { grid-template-columns: 1fr; }
  .public-brand img { width: min(220px, 72vw); }
}

@media (prefers-reduced-motion: reduce) {
  .hero h1,
  .public-card,
  .step-card,
  .plan-card,
  .faq-item,
  .policy-card { animation: none !important; transition: none !important; transform: none !important; }
}
