/* Registry: registration form + directory extras */
.reg-form { max-width: 920px; margin: 0 auto; display: grid; gap: 22px; }
.reg-step { border: 1px solid var(--line); border-radius: var(--radius); padding: 22px 24px; margin: 0; background: #fff; }
.reg-step legend { font-weight: 800; color: var(--ink); padding: 0 10px; font-size: 1.05rem; }
.reg-step legend small { font-weight: 400; color: var(--muted); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .grid-2 { grid-template-columns: 1fr; } }
.reg-form label { display: block; font-size: 13px; font-weight: 600; color: var(--navy-700); }
.reg-form label.full { grid-column: 1 / -1; }
.reg-form label small { font-weight: 400; color: var(--muted); }
.reg-form input, .reg-form select, .reg-form textarea {
  width: 100%; margin-top: 6px; padding: 10px 12px; border: 1px solid var(--line);
  border-radius: 9px; font: inherit; font-weight: 400; color: var(--text); background: #fff;
}
.reg-form input:focus, .reg-form select:focus, .reg-form textarea:focus { outline: 2px solid rgba(138,90,43,.3); border-color: var(--gold); }
.reg-form label.req span::after, .reg-form label.req::after {}
.cond-tag { display: inline-block; background: var(--gold-soft); color: #6e4622; font-size: 11px; padding: 1px 7px; border-radius: 6px; font-weight: 600; }

/* category picker */
.cat-grid-pick { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
.cat-pick { position: relative; border: 1.5px solid var(--line); border-radius: 12px; padding: 18px 12px; text-align: center; cursor: pointer; transition: all .15s; font-weight: 600; color: var(--ink); }
.cat-pick:hover { border-color: var(--gold); }
.cat-pick.active { border-color: var(--gold); background: var(--gold-soft); box-shadow: var(--shadow); }
.cat-pick input { position: absolute; opacity: 0; pointer-events: none; }
.cat-pick-ic { display: block; font-size: 26px; margin-bottom: 8px; }
.cat-pick-label { display: block; font-size: 14px; }

/* conditional meta blocks */
.meta-block { border: 1px dashed var(--gold); border-radius: var(--radius); padding: 20px 24px; background: var(--gold-soft); }
.meta-block h3 { margin-bottom: 14px; font-size: 1rem; }

/* completeness meter */
.reg-meter { display: flex; align-items: center; gap: 14px; }
.reg-meter-bar { flex: 1; height: 10px; background: var(--line); border-radius: 999px; overflow: hidden; }
.reg-meter-bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-2)); transition: width .25s ease; }
#completeText { font-size: 13px; font-weight: 600; color: var(--muted); white-space: nowrap; }

.reg-form .check, .filters-panel .check { display: flex; align-items: center; gap: 8px; font-weight: 500; }
.reg-form .check input, .filters-panel .check input { width: auto; margin: 0; }

/* directory pager */
.pager { display: flex; gap: 6px; justify-content: center; margin-top: 28px; }
.page-link { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 9px; font-weight: 600; color: var(--ink); }
.page-link:hover { border-color: var(--gold); }
.page-link.active { background: var(--navy-800); color: #fff; border-color: var(--navy-800); }
