/* File: leden-aanmelding/assets/css/frontend.css */
.lid-form-wrap { max-width: 820px; }
.lid-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lid-grid label { display: block; }
.lid-grid input, .lid-grid select { width: 100%; box-sizing: border-box; padding: 8px; }
.lid-type label { margin-right: 16px; }
.lid-household { margin-top: 12px; padding: 12px; border: 1px solid #ddd; }
.lid-member { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 10px; align-items: end; padding: 10px 0; border-bottom: 1px dashed #ddd; }
.lid-member input { width: 100%; padding: 8px; box-sizing: border-box; }
.lid-help { color: #555; }
.lid-consents label { display:block; margin: 8px 0; }
.lid-price-box { background:#f7f7f7; padding: 12px; border: 1px solid #ddd; }
.lid-birth-split { display:flex; gap: 8px; }
.lid-birth-split input { width: 90px; }
.lid-modal { position: fixed; left:0; top:0; right:0; bottom:0; background: rgba(0,0,0,.55); z-index: 99999; display:flex; align-items:center; justify-content:center; }
.lid-modal-inner { background:#fff; max-width: 720px; width: calc(100% - 30px); border-radius: 6px; padding: 14px; position:relative; }
.lid-modal-close { position:absolute; right:8px; top:6px; border:0; background:transparent; font-size: 22px; cursor:pointer; }
.lid-modal-body { max-height: 70vh; overflow:auto; }
.lid-errors ul { margin: 8px 0 0 18px; }

/* Thankyou UI */
.lid-thankyou { max-width: 860px; margin: 24px auto; padding: 0 16px; }
.lid-card { background: #fff; border: 1px solid #e5e5e5; border-radius: 14px; padding: 18px; box-shadow: 0 2px 10px rgba(0,0,0,.04); }
.lid-card__header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.lid-title { margin:0; font-size: 22px; line-height: 1.2; }
.lid-subtitle { margin-top: 6px; opacity: .8; }
.lid-note { margin-top: 12px; background:#f6f7f7; border:1px solid #e5e5e5; padding:10px; border-radius: 10px; font-size: 13px; }
.lid-grid2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 14px; }
@media (max-width: 640px){ .lid-grid2 { grid-template-columns: 1fr; } }

.lid-kv { border:1px solid #eee; border-radius: 12px; padding: 12px; background:#fafafa; }
.lid-kv__label { font-size: 12px; opacity: .75; margin-bottom: 4px; }
.lid-kv__value { font-size: 15px; }

.lid-badge { display:inline-flex; align-items:center; padding: 6px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; border:1px solid transparent; white-space:nowrap; }
.lid-badge--paid { background:#ecf7ee; border-color:#b9e2c2; }
.lid-badge--pending { background:#fff6e5; border-color:#f2d19b; }
.lid-badge--failed, .lid-badge--expired, .lid-badge--canceled { background:#fdecec; border-color:#f1b0b7; }
.lid-badge--unknown { background:#f1f1f1; border-color:#ddd; }

.lid-callout { margin-top: 16px; padding: 14px; border-radius: 12px; border:1px solid #e5e5e5; background:#f8f9fb; }
.lid-callout--success { background:#ecf7ee; border-color:#b9e2c2; }
.lid-callout--warn { background:#fff6e5; border-color:#f2d19b; }

.lid-actions { margin-top: 12px; display:flex; gap:10px; flex-wrap: wrap; }
.lid-footnote { margin-top: 12px; opacity: .8; font-size: 13px; }

.lid-invalid {
  border-color: #d63638 !important;
  box-shadow: 0 0 0 1px rgba(214,54,56,.15);
  outline: none;
}
.lid-field-error { line-height: 1.2; }
/* Bootstrap-ish helper if theme has no Bootstrap: keep it mild */
.invalid-feedback { display:none; }
.is-invalid { border-color:#dc3545 !important; box-shadow: 0 0 0 .1rem rgba(220,53,69,.15); }

