.signup-hero { position: relative; overflow: hidden; background: radial-gradient(120% 100% at 100% 0%, rgba(74,144,217,.12), rgba(74,144,217,0) 60%), radial-gradient(100% 100% at 0% 100%, rgba(30,58,95,.07), rgba(30,58,95,0) 55%); min-height: calc(100vh - 71px); display: flex; align-items: center; }
.star-a { top: 8%; right: 8%; font-size: 100px; opacity: .08; }
.star-b { bottom: 10%; left: 7%; font-size: 60px; opacity: .12; transform: rotate(-8deg); }
.star-c { top: 60%; right: 20%; font-size: 22px; opacity: .22; transform: rotate(12deg); }

.signup-wrap { position: relative; z-index: 1; max-width: 560px; }
.signup-logo { height: 30px; width: auto; margin: 0 auto 40px; }
.signup-title { font-size: clamp(34px,4.5vw,48px); font-weight: 800; line-height: 1.1; letter-spacing: -.02em; color: #0F0E17; margin: 0 0 20px; }
.signup-sub { font-size: 18px; line-height: 1.6; color: rgba(15,14,23,.68); margin: 0 auto 40px; max-width: 460px; }

.signup-form-row { display: flex; gap: 12px; justify-content: center; margin: 0; }
.signup-form-row p { margin: 0; }
@media (max-width: 520px) { .signup-form-row { flex-direction: column; } }
.form-field { flex: 1; max-width: 320px; display: flex; flex-direction: column; text-align: left; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.signup-input { flex: 1; max-width: 320px; padding: 14px 20px; border-radius: 999px; border: 1.5px solid #E7EAEE; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 15px; color: #0F0E17; outline: none; width: 100%; }
.signup-input:focus { border-color: #1e3a5f; }
.signup-note { font-size: 13px; color: rgba(15,14,23,.5); margin: 16px 0 0; }
.form-error { font-size: 13px; color: #b3261e; margin: 12px 0 0; display: none; }
.form-error.visible { display: block; }
.honeypot-field { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.thanks-card { max-width: 420px; margin: 0 auto; background: #fff; border: 1px solid #E7EAEE; border-radius: 24px; padding: 40px 36px; box-shadow: 0 30px 60px -32px rgba(30,58,95,.25); }
.thanks-icon { width: 52px; height: 52px; border-radius: 50%; background: rgba(30,58,95,.08); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.thanks-check { width: 18px; height: 10px; border-left: 2.5px solid #1e3a5f; border-bottom: 2.5px solid #1e3a5f; transform: rotate(-45deg) translateY(-2px); }
.thanks-text { font-size: 19px; font-weight: 700; color: #0F0E17; margin: 0; }

[hidden] { display: none !important; }
