:root {
  --black: #000;
  --white: #fff;
  --soft-white: rgba(255,255,255,.86);
  --muted: rgba(255,255,255,.58);
  --panel: rgba(7,7,8,.97);
}
* { box-sizing: border-box; }
[hidden] { display: none !important; }
html, body { min-height: 100%; }
body {
  margin: 0;
  color: var(--white);
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.052), transparent 34rem),
    radial-gradient(circle at 50% 90%, rgba(140,150,160,.075), transparent 24rem),
    #000;
  font-family: Helvetica, Arial, sans-serif;
  letter-spacing: .02em;
}
.grain {
  position: fixed; inset: 0; pointer-events: none; opacity: .10;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
}
.splash {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: clamp(42px, 7vh, 86px) 22px;
}
.brand-stage {
  width: min(1120px, 96vw);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  animation: reveal 1.25s ease both;
}
.wordmark {
  width: min(1020px, 94vw);
  max-height: 34vh;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 0 34px rgba(255,255,255,.11));
}
.copy-block {
  margin-top: clamp(36px, 5vh, 58px);
  width: min(760px, 90vw);
}
.eyebrow {
  margin: 0 0 26px;
  font-size: clamp(16px, 1.75vw, 22px);
  line-height: 1.65;
  letter-spacing: .34em;
  color: var(--soft-white);
  text-transform: uppercase;
}
.support {
  max-width: 720px;
  margin: 0 auto;
  color: var(--muted);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(13px, 1.28vw, 16px);
  line-height: 1.75;
}
.zero-button {
  appearance: none;
  margin-top: clamp(40px, 5.6vh, 70px);
  width: clamp(84px, 9.6vw, 118px);
  height: clamp(84px, 9.6vw, 118px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 50%;
  background: rgba(255,255,255,.018);
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 0 0 1px rgba(255,255,255,.035) inset, 0 0 46px rgba(255,255,255,.07);
  transition: transform .3s ease, border-color .3s ease, background .3s ease, box-shadow .3s ease;
}
.zero-button img {
  width: 92%;
  height: 92%;
  object-fit: contain;
  opacity: .98;
  display: block;
}
.zero-button:hover {
  transform: translateY(-2px) scale(1.018);
  border-color: rgba(255,255,255,.55);
  background: rgba(255,255,255,.045);
  box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, 0 0 62px rgba(255,255,255,.14);
}
.button-label {
  margin: 18px 0 0;
  color: rgba(255,255,255,.72);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
}
.footer-line {
  margin: clamp(46px, 6vh, 70px) 0 0;
  color: rgba(255,255,255,.45);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
}
.modal-backdrop {
  position: fixed; inset: 0; z-index: 20;
  display: grid; place-items: center; padding: 24px;
  background: rgba(0,0,0,.84);
  backdrop-filter: blur(16px);
}
.modal-panel {
  position: relative;
  width: min(820px, 96vw);
  max-height: 92vh;
  overflow: auto;
  padding: clamp(28px, 5vw, 54px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), transparent 34%), var(--panel);
  box-shadow: 0 24px 80px rgba(0,0,0,.8);
}
.close-button {
  position: absolute; top: 18px; right: 22px;
  border: 0; background: transparent; color: rgba(255,255,255,.74);
  font-size: 30px; line-height: 1; cursor: pointer;
}
.modal-icon { width: 82px; display: block; margin: 0 auto 20px; opacity: .94; }
.modal-panel h1 {
  margin: 0; text-align: center;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 400; letter-spacing: .05em;
}
.modal-intro, .disclaimer {
  max-width: 610px; margin: 14px auto 30px; text-align: center;
  color: rgba(255,255,255,.58); line-height: 1.55; font-size: 14px;
}
.field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
label { display: block; margin-bottom: 16px; color: rgba(255,255,255,.74); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; }
input, select, textarea {
  width: 100%; margin-top: 8px; border: 1px solid rgba(255,255,255,.15); border-radius: 14px;
  background: rgba(255,255,255,.045); color: #fff; padding: 14px 14px;
  font: 15px/1.4 Helvetica, Arial, sans-serif; outline: none;
}
select option { color: #111; }
textarea { resize: vertical; min-height: 140px; }
input:focus, select:focus, textarea:focus { border-color: rgba(255,255,255,.55); }
.hidden-field { display: none; }
.submit-button {
  appearance: none; width: 100%; border: 1px solid rgba(255,255,255,.32); background: rgba(255,255,255,.02); color: #fff;
  margin-top: 6px; padding: 15px 28px; border-radius: 16px; text-transform: uppercase; letter-spacing: .22em; font-size: 11px; cursor: pointer;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
}
.submit-button:hover { border-color: rgba(255,255,255,.72); background: rgba(255,255,255,.08); transform: translateY(-1px); }
@keyframes reveal { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@media (max-width: 720px) {
  .splash { padding-top: 48px; padding-bottom: 48px; }
  .wordmark { width: 95vw; max-height: 30vh; }
  .copy-block { margin-top: 34px; }
  .eyebrow { font-size: 13px; letter-spacing: .24em; margin-bottom: 22px; }
  .support { font-size: 13px; }
  .field-grid { grid-template-columns: 1fr; gap: 0; }
  .modal-panel { border-radius: 22px; }
}
