/* ============================================================
   1. GRUNDGERÜST & FARBEN (Flowmotion Lila)
   ============================================================ */
:root {
    --primary-color: #9E159E;
    --primary-light: #9E159E21;
    --primary-border: #9E159EBF;
    --primary-dark: #741574;
    --neutral-dark: #554447;
    --bg-pink: #9e159e15; /* Pinker Hintergrund für den Rahmen-Effekt */
    --color-font: #7A7A7A;
}

/* Globaler Schutz gegen horizontales Scrollen */
html, body {
    max-width: 100%;
    overflow-x: hidden;
    margin: 0;
    padding: 0;
}

body.nimbuscloud-custom-form {
    background-color: var(--bg-pink) !important;
    /* Erzeugt den pinken Rand rechts/links auf Mobile */
    padding: 20px 15px !important; 
    font-family: Arial, Helvetica, sans-serif !important;
    box-sizing: border-box;
}

#nimbuscloud-public-form {
    background: #ffffff !important;
    padding: 30px !important;
    border-radius: 12px !important;
    max-width: 800px;
    margin: 0 auto !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05) !important;
    box-sizing: border-box;
}

#nimbuscloud-public-form::before {
    content: "VERTRAGSKÜNDIGUNG";
    display: block;
    font-size: 1.2em;
    color: var(--primary-dark);
    border-bottom: 2px solid var(--primary-border);
    padding-bottom: 8px;
    margin-bottom: 30px;
    font-weight: bold;
    letter-spacing: 1px;
}

/* ============================================================
   2. DESKTOP-LAYOUT: STERN VOR TEXT & STABILE FELDER
   ============================================================ */

.form-group {
    display: flex !important;
    flex-wrap: nowrap;
    align-items: flex-start !important; 
    margin-bottom: 20px !important;
    position: relative;
    border: none !important;
}

/* Der rote Stern */
.required-item {
    order: 1 !important; 
    position: static !important;
    color: #bc0001 !important;
    font-size: 18px !important;
    flex: 0 0 15px !important;
    margin-right: 5px !important;
    padding-top: 8px; 
    display: inline-block !important;
}

/* Das Label */
.form-group > label:not(.checkbox-inline) {
    order: 2 !important;
    flex: 0 0 185px !important;
    width: 185px !important;
    font-weight: 600 !important;
    color: var(--neutral-dark) !important;
    padding-top: 8px;
    line-height: 1.3;
}

/* Einrückung für optionale Felder (nur Desktop) */
@media (min-width: 651px) {
    .form-group:not(:has(.required-item)) > label:not(.checkbox-inline) {
        margin-left: 20px !important; 
    }
}

/* Eingabefelder */
.form-group .form-control, 
.form-group input:not([type="checkbox"]), 
.form-group select {
    order: 3 !important;
    flex: 1 1 auto !important;
    border: 1px solid #dce1e5 !important;
    border-radius: 6px !important;
    padding: 10px 15px !important;
    height: 42px !important; 
    color: var(--color-font) !important;
}

.form-group textarea {
    order: 3 !important;
    flex: 1 1 auto !important;
    min-height: 100px !important;
    border: 1px solid #dce1e5 !important;
    border-radius: 6px !important;
}

/* ============================================================
   3. DATENSCHUTZ-FIX (Stern & Text in einer Zeile)
   ============================================================ */

.form-group:has(input[type="checkbox"]) {
    display: flex !important;
    flex-wrap: wrap !important; /* Erlaubt das Umbrechen der Checkbox-Zeile */
    background: #fcfaff;
    padding: 20px !important;
    border: 1px solid var(--primary-border) !important;
    border-radius: 8px !important;
    align-items: center !important;
}

/* Sternchen im Datenschutz-Block */
.form-group:has(input[type="checkbox"]) > .required-item {
    order: 1 !important;
    padding-top: 0 !important;
    margin-bottom: 10px !important;
}

/* Wort "Datenschutz" */
.form-group:has(input[type="checkbox"]) > label:first-of-type {
    order: 2 !important;
    flex: 1 1 auto !important;
    width: auto !important;
    padding-top: 0 !important;
    margin-bottom: 10px !important;
}

/* Die Checkbox-Zeile darunter */
.form-group:has(input[type="checkbox"]) > div {
    order: 3 !important;
    width: 100% !important; /* Zwingt die Checkbox in die nächste Zeile */
}

.checkbox-inline {
    display: flex !important;
    align-items: flex-start !important;
    font-weight: normal !important;
    font-size: 14px !important;
    line-height: 1.5;
}

.checkbox-inline input[type="checkbox"] {
    margin: 4px 12px 0 0 !important;
    flex: 0 0 18px !important;
    width: 18px !important;
    height: 18px !important;
}

/* ============================================================
   4. BUTTON & FOOTER (Kein Scrollen!)
   ============================================================ */

.form-submit-container {
    margin: 30px -30px -30px -30px !important;
    padding: 25px !important;
    background: #f8f9fa !important;
    border-top: 1px solid #eee !important;
    border-radius: 0 0 12px 12px;
    display: flex !important;
    justify-content: center !important;
}

.form-submit-container button, .btn-primary, #nimbuscloud-public-form .btn {
    background: var(--primary-color) !important;
    color: #ffffff !important;
    padding: 12px 45px !important;
    border-radius: 4px !important;
    font-weight: bold !important;
    text-transform: uppercase !important;
    border: none !important;
}

/* ============================================================
   5. MOBILE ANSICHT (Pinker Rand & Stabilität)
   ============================================================ */

@media (max-width: 650px) {
    #nimbuscloud-public-form {
        padding: 20px 15px !important;
        width: 100% !important; 
        box-sizing: border-box;
    }

    .form-group {
        flex-wrap: wrap !important;
        margin-bottom: 22px !important;
    }

    /* Stern und Label oben nebeneinander */
    .required-item {
        order: 1 !important;
        flex: 0 0 auto !important;
        padding-top: 0 !important;
    }

    .form-group > label:not(.checkbox-inline) {
        order: 2 !important;
        flex: 1 1 auto !important;
        width: auto !important;
        padding-top: 0 !important;
    }

    /* Input-Feld darunter */
    .form-group .form-control, 
    .form-group input:not([type="checkbox"]), 
    .form-group select,
    .form-group textarea {
        order: 3 !important;
        flex: 0 0 100% !important;
        width: 100% !important;
        margin-top: 8px !important;
    }

    .form-group:not(:has(.required-item)) > label:not(.checkbox-inline) {
        margin-left: 0 !important;
    }

    /* Footer-Margins auf Mobile reduzieren, damit kein Scrollbalken entsteht */
    .form-submit-container {
        margin: 20px -15px -20px -15px !important;
    }
}