/* =============================================
   GATE STYLES — apply.html & unlock.html
   ============================================= */

.gate-body {
  min-height: 100dvh;
  background: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
}

.gate-wrap {
  width: 100%;
  max-width: 680px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.gate-wrap--narrow {
  max-width: 460px;
}

/* Logo */
.gate-logo {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  text-align: left;
}

.gate-logo-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gate-logo-primary {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
}

.gate-logo-sub {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Card */
.gate-card {
  width: 100%;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

.gate-card--centered {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-5);
}

/* Card header */
.gate-card-header {
  margin-bottom: var(--space-6);
}

.gate-card-header--center {
  text-align: center;
  margin-bottom: 0;
}

.gate-card-header h1 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.gate-card-header p {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 52ch;
}

/* Lock icon */
.lock-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: var(--color-primary-highlight);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  margin: 0 auto;
}

/* Form grid */
.gate-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  margin-bottom: var(--space-6);
}

.gate-form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.gate-form-group--full {
  grid-column: 1 / -1;
}

.gate-form-group label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.field-note {
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--color-text-muted);
}

.gate-form-group input,
.gate-form-group select,
.gate-form-group textarea {
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-2);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  color: var(--color-text);
  resize: vertical;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.gate-form-group input:focus,
.gate-form-group select:focus,
.gate-form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-highlight);
}

.gate-form-group input::placeholder,
.gate-form-group textarea::placeholder {
  color: var(--color-text-faint);
}

.gate-form-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: flex-start;
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-divider);
}

.gate-disclaimer {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  max-width: none;
}

/* Already approved link */
.gate-already-approved {
  text-align: center;
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.gate-already-approved a {
  color: var(--color-primary);
  font-weight: 600;
}

/* Success state */
.gate-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
  padding: var(--space-8) 0;
}

.gate-success h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-primary);
}

.gate-success p {
  color: var(--color-text-muted);
  max-width: 42ch;
}

.gate-success-sub {
  font-size: var(--text-sm);
}

/* Unlock form */
.code-input-wrap {
  display: flex;
  gap: var(--space-3);
}

.code-input-wrap input {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-2);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  color: var(--color-text);
  letter-spacing: 0.1em;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.code-input-wrap input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-highlight);
}

.code-error {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: #a12c7b;
  margin-top: var(--space-2);
  max-width: none;
}

/* Shake animation for wrong code */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-8px); }
  40% { transform: translateX(8px); }
  60% { transform: translateX(-6px); }
  80% { transform: translateX(6px); }
}
.shake { animation: shake 0.45s ease; }

/* Divider */
.gate-divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  color: var(--color-text-faint);
  font-size: var(--text-xs);
}
.gate-divider::before,
.gate-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-divider);
}

/* Footer note */
.gate-footer-note {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-align: center;
  max-width: none;
}

/* Responsive */
@media (max-width: 560px) {
  .gate-card { padding: var(--space-5); }
  .gate-form-grid { grid-template-columns: 1fr; }
  .gate-form-group--full { grid-column: 1; }
  .code-input-wrap { flex-direction: column; }
  .code-input-wrap .btn { width: 100%; justify-content: center; }
  .gate-logo { flex-direction: column; text-align: center; }
}
