/* ================================================================
   TAPS 2026/2027 Pre-Registration — preregistration-styles.css
   Styles the markup in page-templates/template-preregistration.php.
   Re-uses the parent theme's design tokens (--primary, --secondary,
   --radius, --shadow-*, etc. from assets/css/global.css) so colours
   stay in sync with the rest of the site. Classes already provided
   by global.css (.container, .section, .section-header,
   .section-label, .section-title, .section-desc, .breadcrumb,
   .btn / .btn--primary / .btn--lg, .reveal) are intentionally NOT
   redefined here.
   ================================================================ */

/* ── HERO BANNER ─────────────────────────────────────────────── */
.prereg-hero {
  position: relative;
  overflow: hidden;
  background: var(--secondary);
  padding: 64px 0 0;
}
.prereg-hero .breadcrumb { color: rgba(255,255,255,.6); }
.prereg-hero .breadcrumb a { color: rgba(255,255,255,.6); }
.prereg-hero .breadcrumb a:hover { color: var(--primary); }
.prereg-hero .breadcrumb span:last-child { color: var(--primary); }

.prereg-hero__shape {
  position: absolute;
  border-radius: 50%;
  background: var(--primary);
  opacity: .12;
  pointer-events: none;
}
.prereg-hero__shape--1 { width: 320px; height: 320px; top: -120px; right: -80px; }
.prereg-hero__shape--2 { width: 220px; height: 220px; bottom: -100px; left: -60px; background: var(--white); opacity: .08; }

.prereg-hero__banner {
  position: relative;
  z-index: 1;
  margin-top: 28px;
  border-radius: var(--radius) var(--radius) 0 0;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  line-height: 0;
}
.prereg-hero__banner img { width: 100%; height: auto; display: block; max-height: 360px; object-fit: cover; }

/* ── FORM SECTION ─────────────────────────────────────────────── */
.prereg { background: var(--bg); }

.prereg__card {
  max-width: 760px;
  margin: 0 auto;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: 44px 48px;
  border: 1px solid rgba(135,70,103,.08);
  box-sizing: border-box;
}
.prereg__card *,
.prereg__card *::before,
.prereg__card *::after { box-sizing: border-box; }

.prereg__form { display: flex; flex-direction: column; gap: 22px; }
.prereg__form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ── FIELDS ──────────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: .82rem; font-weight: 600; color: var(--text-mid); }
.form-group label span { color: var(--secondary); }

.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--font);
  font-size: .9rem;
  color: var(--text);
  background: var(--bg-alt);
  border: 1.5px solid #e1e1e1;
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  width: 100%;
  line-height: 1.5;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--secondary);
  box-shadow: 0 0 0 3px rgba(135,70,103,.12);
}
.form-group input.tp-error,
.form-group select.tp-error,
.form-group textarea.tp-error { border-color: #e53e3e; }
.form-group textarea { resize: vertical; min-height: 100px; }
.form-group input:disabled,
.form-group select:disabled { background: #e1e1e1; opacity: .5; cursor: not-allowed; }

/* ── DYNAMIC CHILD BLOCKS ────────────────────────────────────── */
.prereg__children { display: flex; flex-direction: column; gap: 18px; }
.prereg__child {
  background: var(--bg-alt);
  border: 1.5px solid #e1e1e1;
  border-radius: var(--radius-sm);
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  animation: preregChildIn .35s var(--ease);
}
.prereg__child[hidden] { display: none; }
@keyframes preregChildIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.prereg__child-head { display: flex; align-items: center; gap: 12px; }
.prereg__child-num {
  width: 28px; height: 28px; flex-shrink: 0;
  background: var(--secondary); color: var(--white);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 700;
}
.prereg__child-head h3 { font-size: .92rem; font-weight: 700; color: var(--secondary); margin: 0; }

/* ── COMMITMENT FEE TOGGLE ───────────────────────────────────── */
.prereg__toggle { display: flex; gap: 14px; flex-wrap: wrap; }
.prereg__toggle-option {
  position: relative;
  flex: 1;
  min-width: 180px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg-alt);
  border: 1.5px solid #e1e1e1;
  border-radius: var(--radius-sm);
  padding: 13px 16px;
  cursor: pointer;
  font-size: .88rem;
  font-weight: 600;
  color: var(--text-mid);
  transition: var(--transition);
}
.prereg__toggle-option:hover { border-color: var(--secondary-light); }
.prereg__toggle-option input { position: absolute; opacity: 0; width: 0; height: 0; }
.prereg__toggle-option span { display: flex; align-items: center; gap: 10px; }
.prereg__toggle-option svg { flex-shrink: 0; color: #c8c8c8; transition: var(--transition); }
.prereg__toggle-option:has(input:checked),
.prereg__toggle-option.is-checked {
  border-color: var(--secondary);
  background: var(--secondary-pale);
  color: var(--secondary);
}
.prereg__toggle-option:has(input:checked) svg,
.prereg__toggle-option.is-checked svg { color: var(--secondary); }
.prereg__toggle-option:has(input:focus-visible) {
  outline: none;
  box-shadow: 0 0 0 3px rgba(135,70,103,.18);
}
.prereg__toggle.tp-error .prereg__toggle-option { border-color: #e53e3e; }

/* ── SUBMIT BUTTON ───────────────────────────────────────────── */
.prereg__submit { width: 100%; }
.prereg__submit:disabled { opacity: .7; cursor: not-allowed; transform: none; }

.prereg__form-note { font-size: .76rem; color: var(--text-light); text-align: center; margin: 0; }

/* ── SUCCESS / ERROR ─────────────────────────────────────────── */
.prereg__form-success[hidden] { display: none !important; }
.prereg__form-success {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: rgba(34,197,94,.1);
  border: 1.5px solid rgba(34,197,94,.3);
  border-radius: var(--radius-sm);
  padding: 20px 22px;
  animation: preregFadeIn .4s ease;
}
.prereg__form-success-row { display: flex; align-items: center; gap: 14px; }
.prereg__form-success-row span { font-size: 1.4rem; flex-shrink: 0; }
.prereg__form-success-row p { font-size: .88rem; color: #166534; font-weight: 500; margin: 0; }
.prereg__form-success-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.prereg__form-success-actions .btn { flex: 1; min-width: 180px; }
.prereg__form-success-countdown {
  margin: 0;
  font-size: .76rem;
  color: var(--text-light);
  text-align: center;
}
@keyframes preregFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@media (max-width: 480px) {
  .prereg__form-success-actions { flex-direction: column; }
  .prereg__form-success-actions .btn { width: 100%; }
}

.tp-form-error {
  margin: 0;
  padding: 14px 16px;
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: .86rem;
}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width: 860px) {
  .prereg__card { padding: 32px 24px; }
}
@media (max-width: 600px) {
  .prereg-hero__banner img { max-height: 220px; }
  .prereg__form-row { grid-template-columns: 1fr; }
  .prereg__card { padding: 26px 18px; border-radius: var(--radius-sm); }
  .prereg__toggle { flex-direction: column; }
}
