/* ===== TrueCost investor gate ===== */
body.gate {
  margin: 0; min-height: 100vh; min-height: 100dvh;
  background: var(--tc-ink);
  display: grid; place-items: center;
  padding: 24px;
  color: #eef3f4;
}
.gate .stage-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(87,156,188,0.20), transparent 60%),
    radial-gradient(90% 70% at 90% 110%, rgba(255,200,0,0.08), transparent 55%),
    var(--tc-ink);
}

.gate-card {
  position: relative; z-index: 1;
  width: 100%; max-width: 440px;
  background: linear-gradient(155deg, #131c20 0%, #0c1215 100%);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 20px;
  padding: 40px 38px 34px;
  box-shadow: 0 40px 90px -30px rgba(0,0,0,0.6);
}
.gate-card .lockup { color: #fff; font-size: 24px; }
.gate-card .wordmark { font-size: 24px; }

.gate-tag {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase; opacity: 0.5; margin: 18px 0 0;
}
.gate-card h1 {
  font-family: var(--font-display); font-weight: 700; font-size: 30px;
  letter-spacing: -0.02em; margin: 10px 0 8px;
}
.gate-sub { font-size: 14.5px; line-height: 1.5; opacity: 0.7; margin: 0 0 24px; max-width: 36ch; }

#gateForm { display: flex; flex-direction: column; gap: 11px; }
#gateForm input[type="password"],
#gateForm input[type="text"],
#gateForm input[type="email"] {
  font-family: var(--font-body); font-size: 15px; color: #eef3f4;
  padding: 13px 15px; border-radius: 11px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  outline: none; transition: border-color 0.2s, background 0.2s;
}
#gateForm input::placeholder { color: rgba(238,243,244,0.4); }
#gateForm input:focus { border-color: var(--tc-primary); background: rgba(255,255,255,0.06); }

.gate-nda {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 12.5px; line-height: 1.45; opacity: 0.72; margin: 4px 0 6px; cursor: pointer;
}
.gate-nda input { margin: 2px 0 0; width: 16px; height: 16px; accent-color: var(--tc-primary); flex: none; }

.gate-btn {
  font-family: var(--font-body); font-weight: 700; font-size: 15.5px;
  color: #0e1417; background: var(--tc-gold); border: 0; border-radius: 999px;
  padding: 14px 22px; cursor: pointer; margin-top: 4px;
  transition: transform 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.gate-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 32px -12px rgba(255,200,0,0.5); }
.gate-btn:disabled { opacity: 0.6; cursor: default; transform: none; box-shadow: none; }

.gate-msg { min-height: 1.2em; font-size: 13px; margin: 8px 0 0; color: #ff8b7d; }
.gate-msg.ok { color: var(--tc-primary-light); }

@media (max-width: 480px) {
  .gate-card { padding: 32px 24px 28px; border-radius: 16px; }
  .gate-card h1 { font-size: 26px; }
}
