/* ==========================================
   Data Royalty - Index Page Styles
   Styles specific to the waitlist homepage
   ========================================== */

/* Layout specific to index page */
.grid {
  display: grid; 
  gap: 40px;
}

@media (min-width:768px) {
  .grid {
    grid-template-columns: 1fr 1fr; 
    gap: 64px; 
    padding-top: 24px;
  }
}

/* Hero section - using .hero-title class from common.css */

.lead {
  margin-top: 12px; 
  color: var(--neutral); 
  max-width: 55ch;
}

.bullets {
  display: flex; 
  flex-wrap: wrap; 
  gap: 12px; 
  margin-top: 16px; 
  color: var(--neutral); 
  font-size: 14px;
}

/* Card (form) */
.card {
  border-radius: var(--radius-2xl); 
  padding: 24px; 
  backdrop-filter: saturate(140%) blur(6px); 
  background: rgba(11,11,11,.4); 
  border: 1px solid rgba(249,250,251,.12); 
  box-shadow: var(--shadow-strong);
}

@media (min-width:768px) {
  .card {
    padding: 32px;
  }
}

.card h2 {
  margin: 0 0 6px; 
  font-size: 24px;
}

.support {
  font-size: 14px; 
  color: var(--neutral);
}

.field {
  display: block; 
  margin-top: 14px;
}

.field label {
  display: block; 
  font-size: 14px; 
  font-weight: 600; 
  margin-bottom: 8px;
}

.input {
  width: 100%; 
  border-radius: 12px; 
  background: transparent; 
  border: 1px solid rgba(249,250,251,.18); 
  color: var(--bg-light); 
  padding: 12px 16px; 
  outline: none;
}

.error {
  color: var(--accent); 
  font-size: 14px; 
  margin-top: 6px;
}

#mosparo-box {
  margin-top: 16px;
}

.btn {
  position: relative; 
  width: 100%; 
  border: 0; 
  border-radius: 12px; 
  padding: 14px 20px; 
  font-weight: 700; 
  cursor: pointer; 
  background: var(--primary); 
  color: #fff; 
  box-shadow: 0 8px 24px rgba(94,59,238,.35); 
  overflow: hidden; 
  margin-top: 16px;
}

.btn::after {
  content: ""; 
  position: absolute; 
  inset: 0; 
  border-radius: 12px; 
  opacity: 0; 
  transition: opacity .25s ease; 
  background: linear-gradient(90deg, rgba(244,201,93,0), rgba(244,201,93,.25), rgba(244,201,93,0));
}

.btn:hover::after {
  opacity: 1;
}

.cred {
  margin-top: 16px; 
  font-size: 14px; 
  border: 1px solid rgba(249,250,251,.12); 
  background: rgba(249,250,251,.03); 
  border-radius: 12px; 
  padding: 12px;
}

.small {
  font-size: 12px; 
  color: var(--neutral); 
  margin-top: 8px;
}

.success {
  display: none;
}

.success.show {
  display: flex; 
  flex-direction: column; 
  align-items: flex-start; 
  gap: 10px;
}

.success h2 {
  margin: 0; 
  font-size: 24px;
}