/* GardaCast — Vignettenrechner (v5.2.59) */
.gc-vignette, .gc-vignette *, .gc-vignette *::before, .gc-vignette *::after { box-sizing: border-box; }
.gc-vignette {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 1.5em 0 !important;
    padding: 1.5em !important;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    overflow: visible;
    position: relative;
}
.gc-vignette__header { margin: 0 0 1.2em; }
.gc-vignette__title { font-size: 1.35rem; line-height: 1.3; margin: 0 0 0.3em; color: #185FA5; font-weight: 700; }
.gc-vignette__subtitle { font-size: 0.92rem; line-height: 1.5; color: #5F5E5A; margin: 0; }

.gc-vignette__form { display: flex; flex-direction: column; gap: 1.1em; margin-bottom: 1.4em; }
.gc-vignette__field { display: flex; flex-direction: column; gap: 0.5em; }
.gc-vignette__label { font-size: 0.92rem; font-weight: 600; color: #2a2a2a; }
.gc-vignette__label--checkbox { display: flex; align-items: center; gap: 0.5em; font-weight: 500; cursor: pointer; }
.gc-vignette__label--checkbox input { margin: 0; cursor: pointer; }

.gc-vignette__btngroup { display: flex; flex-wrap: wrap; gap: 0.5em; }
.gc-vignette__btngroup button {
    appearance: none; -webkit-appearance: none;
    flex: 1; min-width: 110px;
    padding: 0.55em 0.9em;
    border: 1px solid #d4d4d4; background: #fafafa;
    border-radius: 9px;
    cursor: pointer; font-size: 0.92rem; font-family: inherit; font-weight: 500;
    color: #555; line-height: 1.3; text-align: center;
    transition: all 0.18s;
}
.gc-vignette__btngroup button:hover { background: #f0f6fc; border-color: #185FA5; }
.gc-vignette__btngroup button.is-active { background: #185FA5; color: #fff; border-color: #185FA5; }

.gc-vignette__slider { width: 100%; appearance: none; height: 6px; background: linear-gradient(90deg, #10b981 0%, #f59e0b 50%, #f97316 80%, #dc2626 100%); border-radius: 99px; outline: none; }
.gc-vignette__slider::-webkit-slider-thumb { appearance: none; width: 22px; height: 22px; background: #185FA5; border: 3px solid #fff; border-radius: 50%; cursor: pointer; box-shadow: 0 2px 4px rgba(0,0,0,0.18); }
.gc-vignette__slider::-moz-range-thumb { width: 22px; height: 22px; background: #185FA5; border: 3px solid #fff; border-radius: 50%; cursor: pointer; box-shadow: 0 2px 4px rgba(0,0,0,0.18); }
.gc-vignette__slider-marks { display: flex; justify-content: space-between; font-size: 0.75rem; color: #888; padding: 0 4px; }

.gc-vignette__result { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 12px; padding: 1.2em; }
.gc-vignette__result-title { margin: 0 0 0.8em; color: #185FA5; font-size: 1.1rem; }
.gc-vignette__loading { padding: 1em; color: #888; font-style: italic; text-align: center; }

.gc-vignette__options { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.6em; }
.gc-vignette__option {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 0.85em 1em;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px 12px;
    align-items: baseline;
    position: relative;
}
.gc-vignette__option.is-best {
    border-color: #10b981;
    background: rgba(16,185,129,0.06);
    box-shadow: 0 2px 6px rgba(16,185,129,0.12);
}
.gc-vignette__badge {
    position: absolute;
    top: -10px; left: 12px;
    background: #10b981; color: #fff;
    padding: 2px 8px; border-radius: 99px;
    font-size: 0.72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.4px;
}
.gc-vignette__opt-name { font-weight: 600; color: #2a2a2a; font-size: 1rem; line-height: 1.3; }
.gc-vignette__opt-cost { font-size: 1.25rem; font-weight: 700; color: #185FA5; line-height: 1.2; text-align: right; }
.gc-vignette__opt-detail { grid-column: 1 / -1; font-size: 0.82rem; color: #64748b; line-height: 1.4; }

.gc-vignette__hint { margin: 1em 0 0; padding: 0.8em 1em; background: #fff8e6; border-left: 3px solid #f59e0b; border-radius: 0 8px 8px 0; font-size: 0.92rem; color: #78350f; }

.gc-vignette__footer { margin: 1em 0 0; padding: 0.7em 0 0; border-top: 1px solid #ececec; font-size: 0.78rem; color: #888; }
.gc-vignette__footer a { color: #185FA5; }

@media (max-width: 480px) {
    .gc-vignette__btngroup button { min-width: 0; flex: 1 1 calc(50% - 0.25em); }
    .gc-vignette__option { grid-template-columns: 1fr; }
    .gc-vignette__opt-cost { text-align: left; }
}
