/* Mitglieder – Aufnahmeantrag Formular
   Schriften und Hauptfarben werden vom Theme geerbt. */

.mg-form-wrap {
    --mg-accent:   var(--e-global-color-primary, var(--wp--preset--color--primary, #1f4e79));
    --mg-border:   #e5e7eb;
    --mg-muted:    #6b7280;
    --mg-radius:   12px;
    --mg-bg-card:  #ffffff;

    color: inherit;
}
.mg-form-wrap *, .mg-form-wrap *::before, .mg-form-wrap *::after { box-sizing: border-box; }

.mg-form {
    background: var(--mg-bg-card);
    border: 1px solid var(--mg-border);
    border-radius: var(--mg-radius);
    padding: 24px;
    max-width: 900px;
}

.mg-form-head h2 {
    margin: 0 0 6px;
    font-weight: 800;
    font-size: 1.6em;
}
.mg-intro {
    color: var(--mg-muted);
    margin: 0 0 20px;
}

.mg-section {
    border: 1px solid var(--mg-border);
    border-radius: var(--mg-radius);
    padding: 18px;
    margin: 0 0 18px;
}
.mg-section legend {
    padding: 0 8px;
    font-weight: 700;
    color: var(--mg-accent);
}

.mg-row { display: grid; gap: 14px; margin-bottom: 12px; }
.mg-row-2 { grid-template-columns: 1fr 1fr; }
.mg-row-3 { grid-template-columns: 2fr 1fr 2fr; }
@media (max-width: 640px) {
    .mg-row-2, .mg-row-3 { grid-template-columns: 1fr; }
}

.mg-field { display: flex; flex-direction: column; gap: 4px; }
.mg-field > span { font-weight: 600; font-size: .95em; }
.mg-field input[type="text"],
.mg-field input[type="url"],
.mg-field input[type="tel"],
.mg-field input[type="email"],
.mg-field input[type="number"],
.mg-field input[type="date"] {
    width: 100%;
    border: 1px solid var(--mg-border);
    border-radius: 8px;
    padding: 10px 12px;
    font: inherit;
    background: #fff;
    transition: border-color .15s;
}
.mg-field input:focus {
    outline: 2px solid color-mix(in srgb, var(--mg-accent) 30%, white);
    border-color: var(--mg-accent);
    outline-offset: 0;
}

.mg-fee output {
    font-size: 1.4em;
    font-weight: 800;
    color: var(--mg-accent);
    background: #f5f8fb;
    border: 1px solid var(--mg-border);
    border-radius: 8px;
    padding: 10px 12px;
    display: block;
}
.mg-fee-hint {
    margin: 4px 0 0;
    color: var(--mg-muted);
    font-size: .9em;
}

.mg-help {
    color: var(--mg-muted);
    margin: 0 0 12px;
}

.mg-checkbox {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    margin-bottom: 10px;
}
.mg-checkbox input { margin-top: 4px; }

.mg-sig-tabs { display: flex; gap: 0; margin-bottom: 10px; }
.mg-sig-tab {
    background: #f3f4f6;
    border: 1px solid var(--mg-border);
    color: inherit;
    padding: 8px 14px;
    cursor: pointer;
    font: inherit;
}
.mg-sig-tab:first-child { border-top-left-radius: 8px; border-bottom-left-radius: 8px; }
.mg-sig-tab:last-child  { border-top-right-radius: 8px; border-bottom-right-radius: 8px; border-left: 0; }
.mg-sig-tab.is-active {
    background: var(--mg-accent);
    color: #fff;
    border-color: var(--mg-accent);
}
.mg-sig-panel { display: none; }
.mg-sig-panel.is-active { display: block; }

.mg-sigpad-wrap {
    position: relative;
    border: 1px dashed var(--mg-border);
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    max-width: 600px;
}
.mg-sigpad {
    display: block;
    width: 100%;
    height: 180px;
    touch-action: none;
    cursor: crosshair;
}
.mg-sigpad-clear {
    position: absolute;
    top: 6px; right: 6px;
    background: #fff;
    border: 1px solid var(--mg-border);
    border-radius: 6px;
    font: inherit;
    padding: 4px 8px;
    cursor: pointer;
}

.mg-actions { margin-top: 8px; }
.mg-submit {
    background: var(--mg-accent);
    color: #fff;
    border: 0;
    border-radius: 10px;
    padding: 12px 22px;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: filter .15s;
}
.mg-submit:hover { filter: brightness(.92); }

.mg-hp { position: absolute !important; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden; }

.mg-notice {
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 16px;
    border: 1px solid var(--mg-border);
}
.mg-notice-ok {
    background: #ecfdf5;
    border-color: #34d399;
    color: #065f46;
}
.mg-notice-fail {
    background: #fef2f2;
    border-color: #f87171;
    color: #7f1d1d;
}
