/* =========================================================
   LimeSurvey Custom Theme auf Basis Fruity TwentyThree
   SITsolutions / DPMS-nahe Business-Optik
   ========================================================= */

:root {
    --sit-green: #80CC28;
    --sit-dark: #313c48;
    --sea-navy: #002244;
    --sea-green: #69BE28;

    --page-bg: #f3f5f9;
    --card-bg: #ffffff;
    --border: #e5e9f2;
    --soft-border: #edf1f7;
    --muted-text: #667085;
    --help-bg: #f7f9fc;
}

/* Grundlayout */
html,
body {
    background: var(--page-bg) !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    color: var(--sit-dark) !important;
}

/* Hauptbreite */
#outerframeContainer,
.outerframe,
.survey-container,
.container {
    max-width: 1120px !important;
}

/* Titel */
h1,
h2,
.group-title,
.group-name {
    color: var(--sea-navy) !important;
    font-weight: 750 !important;
    letter-spacing: -0.02em !important;
}

.group-title,
.group-name {
    font-size: 30px !important;
    margin-bottom: 10px !important;
}

.group-description {
    color: var(--muted-text) !important;
    font-size: 16px !important;
    margin-bottom: 26px !important;
}

/* Fortschrittsbalken */
.progress {
    height: 10px !important;
    background: #e9edf5 !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    box-shadow: none !important;
}

.progress-bar {
    background: linear-gradient(90deg, var(--sit-green), var(--sea-green)) !important;
}

/* Fragekarten */
.question-container,
.question-wrapper,
.ls-question-block {
    background: var(--card-bg) !important;
    border: 1px solid var(--border) !important;
    border-radius: 18px !important;
    box-shadow: 0 10px 26px rgba(0, 34, 68, 0.07) !important;
    overflow: hidden !important;
    margin-bottom: 26px !important;
}

/* Fragekopf */
.question-title-container {
    background: #ffffff !important;
    border-bottom: 1px solid var(--soft-border) !important;
    padding: 24px 28px 18px 34px !important;
    position: relative !important;
}

.question-title-container::before {
    content: "";
    position: absolute;
    left: 0;
    top: 18px;
    bottom: 18px;
    width: 5px;
    background: var(--sit-green);
    border-radius: 0 8px 8px 0;
}

.question-title-container,
.question-title-container *,
.question-title,
.question-text,
.ls-label-question {
    color: var(--sit-dark) !important;
    font-weight: 700 !important;
    font-size: 18px !important;
}

/* Hilfetexte neutral */
.ls-questionhelp,
.ls-question-message,
.question-help-container,
.questionhelp,
.question-valid-container {
    background: var(--help-bg) !important;
    color: var(--muted-text) !important;
    border-top: 1px solid var(--soft-border) !important;
    border-bottom: 1px solid var(--soft-border) !important;
    border-left: none !important;
    border-right: none !important;
    box-shadow: none !important;
    padding: 14px 28px !important;
}

/* Fragezeichen-Icons ausblenden */
.ls-questionhelp .fa,
.ls-question-message .fa,
.question-help-container .fa,
.questionhelp .fa,
.question-valid-container .fa,
.ls-questionhelp i,
.ls-question-message i,
.question-help-container i,
.questionhelp i,
.question-valid-container i {
    display: none !important;
}

/* Antwortbereich */
.answer-container,
.ls-answers,
.question-answer {
    background: #ffffff !important;
    padding: 26px 34px 32px 34px !important;
}

/* Checkboxen und Radio-Buttons klickbar lassen */
input[type="radio"],
input[type="checkbox"],
.form-check-input {
    accent-color: var(--sit-green);
    pointer-events: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
}

label,
.form-check-label {
    cursor: pointer !important;
    pointer-events: auto !important;
}

/* Eingabefelder */
.form-control,
.form-select,
textarea,
input[type="text"],
input[type="email"],
input[type="number"],
input[type="date"],
select {
    background: #ffffff !important;
    border: 1px solid #d7dde8 !important;
    border-radius: 10px !important;
    color: var(--sit-dark) !important;
    padding: 11px 13px !important;
    box-shadow: none !important;
}

.form-control:focus,
.form-select:focus,
textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
select:focus {
    border-color: var(--sea-green) !important;
    box-shadow: 0 0 0 4px rgba(105, 190, 40, 0.18) !important;
    outline: none !important;
}

textarea.form-control,
textarea {
    min-height: 130px !important;
}

/* Buttons */
.btn,
button,
input[type="submit"] {
    border-radius: 12px !important;
    font-weight: 650 !important;
    padding: 11px 22px !important;
}

.btn-primary,
button[name="move"],
button.submit,
.submit,
#movenextbtn,
#movesubmitbtn {
    background: var(--sea-navy) !important;
    border-color: var(--sea-navy) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 18px rgba(0, 34, 68, 0.22) !important;
}

.btn-primary:hover,
button[name="move"]:hover,
button.submit:hover,
.submit:hover,
#movenextbtn:hover,
#movesubmitbtn:hover {
    background: #001a35 !important;
    border-color: #001a35 !important;
}

#moveprevbtn {
    background: #ffffff !important;
    border: 1px solid #d7dde8 !important;
    color: var(--sit-dark) !important;
    box-shadow: none !important;
}

/* Keine Antwort dezenter */
.noanswer-item,
.noanswer-text {
    color: #8a93a6 !important;
}

/* Mobile */
@media (max-width: 768px) {
    .question-title-container {
        padding: 20px 20px 14px 26px !important;
    }

    .answer-container,
    .ls-answers,
    .question-answer {
        padding: 18px 22px 24px 22px !important;
    }

    .group-title,
    .group-name {
        font-size: 24px !important;
    }

    .question-container,
    .question-wrapper,
    .ls-question-block {
        border-radius: 14px !important;
    }
}