.feedback-wrap {
  max-width: 620px;
  margin: 0 auto;
  padding: 30px 0 60px;
}

.feedback-header {
  text-align: center;
  padding: 30px 0 24px;
}
.feedback-header h1 {
  font-size: 1.5rem;
  color: var(--text-accent);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.feedback-header p {
  color: var(--text-muted);
  font-size: 0.85rem;
  letter-spacing: 1px;
}

.feedback-form-card {
  background: var(--bg-panel);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--border-panel);
  border-radius: 10px;
  padding: 32px 36px;
}

.form-field {
  margin-bottom: 20px;
}
.form-field label {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted-dim);
  margin-bottom: 7px;
}
.form-field .field-note {
  font-size: 0.72rem;
  color: var(--text-hint);
  letter-spacing: 0.5px;
  text-transform: none;
  margin-left: 8px;
}

.form-field select,
.form-field input[type="text"],
.form-field textarea {
  width: 100%;
  padding: 10px 14px;
  background: var(--bg-input);
  border: 1px solid var(--border-input);
  border-radius: 6px;
  color: var(--text-primary);
  outline: none;
  font-size: 0.93rem;
  font-family: inherit;
  transition: border-color 0.2s;
}
.form-field select:focus,
.form-field input[type="text"]:focus,
.form-field textarea:focus {
  border-color: var(--text-accent);
}
.form-field select option {
  background: var(--bg-input);
}
.form-field textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.55;
}
.form-field input::placeholder,
.form-field textarea::placeholder {
  color: var(--text-placeholder);
}

/* Type badge colours in the select */
.type-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.type-idea     { background: rgba(99,102,241,0.18); color: #a5b4fc; border: 1px solid rgba(99,102,241,0.35); }
.type-bug      { background: rgba(239,68,68,0.15);  color: #fca5a5; border: 1px solid rgba(239,68,68,0.3); }
.type-feedback { background: rgba(34,197,94,0.13);  color: #86efac; border: 1px solid rgba(34,197,94,0.28); }

.form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.btn-submit {
  padding: 11px 28px;
  background: var(--btn-primary);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.9rem;
  cursor: pointer;
  letter-spacing: 1px;
  font-family: inherit;
  transition: background 0.2s;
}
.btn-submit:hover:not(:disabled) { background: var(--btn-primary-hover); }
.btn-submit:disabled { background: var(--btn-primary-disabled); cursor: not-allowed; opacity: 0.7; }

.recaptcha-note {
  font-size: 0.7rem;
  color: var(--text-hint);
  line-height: 1.5;
}
.recaptcha-note a { color: var(--text-hint); }

/* Messages */
.fb-msg {
  padding: 13px 16px;
  border-radius: 7px;
  font-size: 0.88rem;
  margin-top: 20px;
  line-height: 1.6;
}
.fb-msg-success {
  background: rgba(74,222,128,0.1);
  border: 1px solid rgba(74,222,128,0.35);
  color: #4ade80;
}
.fb-msg-error {
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.35);
  color: #f87171;
}

/* Honeypot — visually hidden but accessible to screen readers would be confusing,
   so we mark it aria-hidden and take it out of tab order */
.hp-field {
  position: absolute;
  left: -9999px;
  top: -9999px;
  opacity: 0;
  pointer-events: none;
  tab-index: -1;
}

/* Spinner (reused from admin) */
.spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(126,184,247,0.2);
  border-top-color: var(--text-accent);
  border-radius: 50%;
  animation: fb-spin 0.8s linear infinite;
  vertical-align: middle;
  margin-right: 8px;
}
@keyframes fb-spin { to { transform: rotate(360deg); } }

/* Hide the reCAPTCHA badge (using inline disclosure text instead) */
.grecaptcha-badge { visibility: hidden !important; }

@media (max-width: 600px) {
  .feedback-form-card {
    padding: 24px 18px;
  }
  .form-actions {
    flex-direction: column;
    align-items: flex-start;
  }
  .btn-submit {
    width: 100%;
  }
}
