/* =============================================
   REGISTRATION FORM STYLES
   ============================================= */

.reg-section { background: var(--off-white); padding-top: 64px; padding-bottom: 96px; }

.reg-container { max-width: 860px; }

.reg-intro { margin-bottom: 40px; }
.reg-note {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--sage-light);
  border: 1px solid var(--sage-mid);
  border-radius: var(--radius-md);
  padding: 18px 20px;
}
.reg-note svg { color: var(--sage); flex-shrink: 0; margin-top: 2px; }
.reg-note p { font-size: 0.9rem; color: var(--grey-700); margin: 0; }

/* Form sections */
.form-section {
  background: var(--white);
  border: 1px solid var(--grey-100);
  border-radius: var(--radius-lg);
  padding: 36px 40px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
}
.form-section-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--navy);
  margin-bottom: 28px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.form-section-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--sage);
  color: var(--white);
  border-radius: 50%;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  flex-shrink: 0;
}
.form-section-desc {
  font-size: 0.92rem;
  color: var(--grey-500);
  margin-bottom: 24px;
  margin-top: -12px;
}

/* Form grid */
.form-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: 0.85rem; font-weight: 500; color: var(--grey-700); }
.form-group input,
.form-group textarea,
.form-group select {
  padding: 10px 13px;
  border: 1.5px solid var(--grey-300);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.93rem;
  color: var(--navy);
  background: var(--white);
  transition: border-color 0.15s;
  outline: none;
  width: 100%;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(126,161,138,0.12); }
.form-group textarea { resize: vertical; min-height: 80px; }
.req { color: var(--sage); }

/* Column spans */
.col-full  { grid-column: span 12; }
.col-1-2   { grid-column: span 6; }
.col-1-3   { grid-column: span 4; }
.col-2-3   { grid-column: span 8; }
.col-1-4   { grid-column: span 3; }
.col-3-4   { grid-column: span 9; }

/* Health questions */
.health-questions { display: flex; flex-direction: column; gap: 0; }
.hq-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid var(--grey-100);
}
.hq-row:last-child { border-bottom: none; }
.hq-question {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.hq-num {
  font-weight: 600;
  color: var(--sage);
  font-size: 0.88rem;
  min-width: 24px;
  padding-top: 1px;
}
.hq-question label {
  font-size: 0.92rem;
  color: var(--grey-700);
  line-height: 1.4;
}
.hq-answer {
  display: flex;
  gap: 10px;
  align-items: center;
  min-width: 380px;
}
.hq-answer-single { min-width: 380px; }
.hq-answer select {
  width: 110px;
  flex-shrink: 0;
  padding: 9px 10px;
  border: 1.5px solid var(--grey-300);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--navy);
  background: var(--white);
  outline: none;
  transition: border-color 0.15s;
  cursor: pointer;
}
.hq-answer select:focus { border-color: var(--sage); }
.hq-answer input[type="text"] {
  flex: 1;
  padding: 9px 12px;
  border: 1.5px solid var(--grey-300);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--navy);
  background: var(--white);
  outline: none;
  transition: border-color 0.15s;
  display: none;
}
.hq-answer-single input[type="text"] { display: block; }
.hq-answer input[type="text"]:focus { border-color: var(--sage); }

/* Submit section */
.form-submit-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.consent-notice {
  background: var(--grey-100);
  border-radius: var(--radius-sm);
  padding: 16px 18px;
}
.consent-notice p {
  font-size: 0.85rem;
  color: var(--grey-500);
  margin: 0;
}
.consent-notice a { color: var(--sage); text-decoration: underline; }
.btn-submit { align-self: flex-start; min-width: 220px; justify-content: center; }

.form-success {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--sage-light);
  border: 1px solid var(--sage-mid);
  border-radius: var(--radius-md);
  padding: 20px 24px;
}
.form-success svg { color: var(--sage); flex-shrink: 0; margin-top: 2px; }
.form-success strong { display: block; color: var(--navy); margin-bottom: 4px; }
.form-success p { font-size: 0.9rem; color: var(--grey-700); margin: 0; }
.form-error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: var(--radius-sm);
  padding: 14px 18px;
  font-size: 0.9rem;
  color: #991b1b;
}
.form-error a { color: #991b1b; font-weight: 600; }

/* Page hero override for this page */
.page-hero strong { color: var(--sage-mid); }

/* NHS Warning Bar */
.nhs-warning-bar {
  background: #7a2020;
  border-bottom: 3px solid #5a1515;
  padding: 18px 0;
}
.nhs-warning-inner {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.nhs-warning-bar svg {
  color: #ffcaca;
  flex-shrink: 0;
  margin-top: 1px;
}
.nhs-warning-bar p {
  color: rgba(255,255,255,0.9);
  font-size: 0.95rem;
  line-height: 1.5;
  margin: 0;
}
.nhs-warning-bar strong {
  color: #ffffff;
  font-weight: 600;
}
.nhs-warning-bar a {
  color: #ffcaca;
  text-decoration: underline;
  font-weight: 500;
}
.nhs-warning-bar a:hover { color: #ffffff; }

/* Responsive */
@media (max-width: 900px) {
  .form-section { padding: 28px 24px; }
  .hq-row { grid-template-columns: 1fr; gap: 10px; }
  .hq-answer { min-width: unset; flex-wrap: wrap; }
  .hq-answer-single { min-width: unset; }
  .hq-answer select { width: 120px; }
}
@media (max-width: 600px) {
  .form-section { padding: 22px 16px; }
  .col-1-2, .col-1-3, .col-2-3, .col-1-4, .col-3-4 { grid-column: span 12; }
  .btn-submit { width: 100%; }
}
