/* ========================================
   BOOKING FORMS
======================================== */

/* =========================
   BASE FIELDS
========================= */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="password"],
.wpcf7 textarea,
.wpcf7 input.air-datepicker {
    font: 400 18px/1.62857143 Mulish, sans-serif !important;
    letter-spacing: -0.00208em !important;
    color: #a1a1a1 !important;
    -webkit-text-fill-color: #a1a1a1 !important;
    background: transparent !important;
    border: 1px solid #a1a1a1 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    padding: 12px 20px !important;
    transition: border-color 0.3s ease, color 0.3s ease !important;
}

.wpcf7 textarea {
    min-height: 160px !important;
    resize: vertical !important;
    position: relative;
    z-index: 1;
}

.codedropz-upload-handler {
    border: 1px dashed #a1a1a1;
}

.dnd-upload-status .dnd-upload-image
{
	border: 0px;
}

.dnd-upload-status .dnd-upload-details .name
{
	color: #ffffff;
}


/* =========================
   PLACEHOLDER
========================= */
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder,
.wpcf7 input::-webkit-input-placeholder,
.wpcf7 textarea::-webkit-input-placeholder,
.wpcf7 input::-moz-placeholder,
.wpcf7 textarea::-moz-placeholder,
.wpcf7 input:-ms-input-placeholder,
.wpcf7 textarea:-ms-input-placeholder,
.wpcf7 input::-ms-input-placeholder,
.wpcf7 textarea::-ms-input-placeholder {
    color: transparent !important;
    opacity: 0 !important;
}

/* =========================
   FILLED / FOCUS
========================= */
.wpcf7 input:not([type="submit"]):not(:placeholder-shown),
.wpcf7 textarea:not(:placeholder-shown),
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 input[type="password"]:focus,
.wpcf7 textarea:focus,
.wpcf7 input.air-datepicker:focus {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border-color: #ffffff !important;
}

.wpcf7 input.air-datepicker {
    color: #a1a1a1 !important;
    -webkit-text-fill-color: #a1a1a1 !important;
    opacity: 1 !important;
    caret-color: #a1a1a1 !important;
}

/* =========================
   BUTTONS
========================= */
button,
a.button,
.vc_btn3,
.wpcf7 input[type="submit"],
.wpcf7-submit {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #a1a1a1 !important;
    font-family: Hind, sans-serif !important;
    font-size: 13px !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    padding: 18px 35px 17px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-weight: 400 !important;
}

button:hover,
a.button:hover,
.vc_btn3:hover,
.wpcf7 input[type="submit"]:hover,
.wpcf7-submit:hover {
    color: #ffffff !important;
    border-color: #ffffff !important;
}

/* =========================
   AIR DATEPICKER
========================= */
.air-datepicker {
    font-family: Mulish, sans-serif !important;
    background: #111111 !important;
    border: 1px solid #ffffff !important;
}

.air-datepicker-nav--title {
    color: #ffffff !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

.air-datepicker-nav--action {
    color: #a1a1a1 !important;
}

.air-datepicker-nav--action:hover {
    color: #ffffff !important;
}

.air-datepicker-body--day-name {
    color: #a1a1a1 !important;
    text-transform: uppercase !important;
}

.air-datepicker-cell {
    color: #a1a1a1 !important;
    border: 1px solid transparent !important;
}

.air-datepicker-cell:hover {
    background-color: #a1a1a1 !important;
    color: #111111 !important;
}

.air-datepicker-cell.-selected- {
    color: #ffffff !important;
    border-color: #ffffff !important;
    background: transparent !important;
}

.air-datepicker-cell.-disabled- {
    color: rgba(161, 161, 161, 0.25) !important;
    cursor: not-allowed !important;
}

.air-datepicker-body--cells {
    grid-template-columns: repeat(7, 1fr) !important;
}

/* =========================
   INLINE CALENDAR WRAPPER
========================= */
.calendar-wrapper,
#air-datepicker-inline,
#air-datepicker-inline-audio,
#air-datepicker-inline-p2g {
    width: 100% !important;
    max-width: 100% !important;
}

#air-datepicker-inline .air-datepicker,
#air-datepicker-inline-audio .air-datepicker,
#air-datepicker-inline-p2g .air-datepicker {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    border: 1px solid #a1a1a1 !important;
    transition: border-color 0.3s ease !important;
}

#air-datepicker-inline.is-filled .air-datepicker,
#air-datepicker-inline-audio.is-filled .air-datepicker,
#air-datepicker-inline-p2g.is-filled .air-datepicker {
    border-color: #ffffff !important;
}

#air-datepicker-inline.is-error .air-datepicker,
#air-datepicker-inline-audio.is-error .air-datepicker,
#air-datepicker-inline-p2g.is-error .air-datepicker {
    border-color: #df6666 !important;
}

/* =========================
   FIELD ERRORS
========================= */
.wpcf7 input[type="text"].is-error-field,
.wpcf7 input[type="email"].is-error-field,
.wpcf7 input[type="tel"].is-error-field,
.wpcf7 input[type="password"].is-error-field,
.wpcf7 textarea.is-error-field,
.wpcf7 input.air-datepicker.is-error-field {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border-color: #df6666 !important;
}

.wpcf7 input[type="text"].is-error-field:focus,
.wpcf7 input[type="email"].is-error-field:focus,
.wpcf7 input[type="tel"].is-error-field:focus,
.wpcf7 textarea.is-error-field:focus,
.wpcf7 input.air-datepicker.is-error-field:focus {
    border-color: #df6666 !important;
    outline: none !important;
    box-shadow: none !important;
}

body .wpcf7 input.wpcf7-not-valid:not(.is-error-field),
body .wpcf7 textarea.wpcf7-not-valid:not(.is-error-field),
body .wpcf7 input[aria-invalid="true"]:not(.is-error-field),
body .wpcf7 textarea[aria-invalid="true"]:not(.is-error-field) {
    border: 1px solid #a1a1a1 !important;
    box-shadow: none !important;
    outline: none !important;
}

body .wpcf7 input[type="password"].wpcf7-not-valid:not(.is-error-field),
body .wpcf7 input[type="password"][aria-invalid="true"]:not(.is-error-field) {
    border: 1px solid #a1a1a1 !important;
    box-shadow: none !important;
    outline: none !important;
}

/* =========================
   CODEDROPZ UPLOAD ERROR
========================= */
.wpcf7 .codedropz-upload-wrapper.is-error-group .codedropz-upload-handler,
.wpcf7 .codedropz-upload-wrapper.wpcf7-not-valid .codedropz-upload-handler,
.wpcf7 .codedropz-upload-wrapper[aria-invalid="true"] .codedropz-upload-handler {
    border: 1px solid #df6666 !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
}

.wpcf7 .codedropz-upload-wrapper.is-error-group {
    padding: 0 !important;
}

/* =========================
   FLOATING LABELS
========================= */
.wpcf7 .wpcf7-form-control-wrap {
    position: relative;
    display: block;
    padding-bottom: 0;
}

.wpcf7 .wpcf7-form-control-wrap.has-floating-label::after {
    content: attr(data-label);
    position: absolute;
    top: -5px;
    left: 20px;
    padding: 0 6px;
    background: #111111 !important;
    font-size: 12px;
    line-height: 1;
    color: #a1a1a1;
    pointer-events: none;
    z-index: 3;
}

.wpcf7 .wpcf7-form-control-wrap.has-floating-label.has-error-label::after,
.wpcf7 .wpcf7-form-control-wrap.has-error-label::after {
    content: attr(data-error);
    color: #df6666 !important;
}

.wpcf7-not-valid-tip {
    display: none !important;
}

/* =========================
   BASIC CHECKBOX STYLE
========================= */
.wpcf7 input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    position: relative;
    top: 4px;
    width: 20px;
    height: 20px;
    margin: 0 15px 0 0;
    flex-shrink: 0;
    border: 1px solid #a1a1a1;
    background: transparent !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.wpcf7 input[type="checkbox"]:active,
.wpcf7 input[type="checkbox"]:focus {
    background: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

.wpcf7 input[type="checkbox"]:hover {
    border-color: #ffffff;
}

.wpcf7 input[type="checkbox"]:checked {
    border-color: #ffffff;
    background: transparent !important;
}

.wpcf7 input[type="checkbox"]:checked::after {
    content: "X";
    position: absolute;
    inset: 0;
    color: #ffffff;
    font-size: 14px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wpcf7 .wpcf7-list-item {
    display: flex;
    align-items: center;
}

.wpcf7 .wpcf7-list-item-label {
    line-height: 1.4;
}

/* =========================
   CHECKBOX / RADIO ERROR
   Funktioniert über CF7-Wrap UND direkte Gruppen-ID
========================= */
.wpcf7 .wpcf7-form-control-wrap.is-error-group input[type="checkbox"],
.wpcf7 .wpcf7-form-control-wrap.is-error-group input[type="radio"],
#booking-box-selection.is-error-group input[type="checkbox"],
#booking-box-selection.is-error-group input[type="radio"],
#booking-audio-selection.is-error-group input[type="checkbox"],
#booking-audio-selection.is-error-group input[type="radio"],
#audiogb-selection.is-error-group input[type="checkbox"],
#audiogb-selection.is-error-group input[type="radio"],
#bg-selection.is-error-group input[type="checkbox"],
#bg-selection.is-error-group input[type="radio"] {
    accent-color: #df6666 !important;
}

.wpcf7 .wpcf7-form-control-wrap.is-error-group input[type="checkbox"],
#booking-box-selection.is-error-group input[type="checkbox"],
#booking-audio-selection.is-error-group input[type="checkbox"],
#audiogb-selection.is-error-group input[type="checkbox"],
#bg-selection.is-error-group input[type="checkbox"] {
    border-color: #df6666 !important;
    outline: 1px solid #df6666 !important;
}

.wpcf7 .wpcf7-form-control-wrap.is-error-group input[type="checkbox"]:checked::after,
#booking-box-selection.is-error-group input[type="checkbox"]:checked::after,
#booking-audio-selection.is-error-group input[type="checkbox"]:checked::after,
#audiogb-selection.is-error-group input[type="checkbox"]:checked::after,
#bg-selection.is-error-group input[type="checkbox"]:checked::after {
    color: #df6666 !important;
}

/* =========================
   IMAGE PICKER ERROR STATES
   sichtbare Kachel statt hidden checkbox
========================= */
.wpcf7 .wpcf7-form-control-wrap.is-error-group .box-pick .wpcf7-list-item-label,
.wpcf7 .wpcf7-form-control-wrap.is-error-group .audiogb-pick .wpcf7-list-item-label,
.wpcf7 .wpcf7-form-control-wrap.is-error-group .bg-pick .wpcf7-list-item-label,
#booking-box-selection.is-error-group .wpcf7-list-item-label,
#booking-audio-selection.is-error-group .wpcf7-list-item-label,
#audiogb-selection.is-error-group .wpcf7-list-item-label,
#bg-selection.is-error-group .wpcf7-list-item-label {
    border-color: #df6666 !important;
    box-shadow: inset 0 0 0 1px #df6666 !important;
}

/* =========================
   FORM LAYOUT
========================= */
.f-row {
    display: flex;
    gap: 20px;
}

.f-half,
.f-half1 {
    flex: 1;
}

.f-half:first-child {
    flex: 0 0 30%;
}

.f-half:last-child {
    flex: 1;
}

/* ========================================
   IMAGE PICKERS SHARED
======================================== */
.bg-pick,
.audiogb-pick,
.box-pick {
    overflow: visible !important;
}

.bg-pick .wpcf7-list-item,
.audiogb-pick .wpcf7-list-item,
.box-pick .wpcf7-list-item {
    margin: 0 !important;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow: visible !important;
}

.bg-pick .wpcf7-list-item label,
.audiogb-pick .wpcf7-list-item label,
.box-pick .wpcf7-list-item label {
    display: block;
    position: relative;
    cursor: pointer;
    font-size: 0;
    line-height: 0;
}

.bg-pick .wpcf7-list-item input[type="checkbox"],
.audiogb-pick .wpcf7-list-item input[type="checkbox"],
.box-pick .wpcf7-list-item input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.bg-pick .wpcf7-list-item-label,
.audiogb-pick .wpcf7-list-item-label,
.box-pick .wpcf7-list-item-label {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    border: 2px solid rgba(255,255,255,0.18);
    border-radius: 14px !important;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden !important;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
    position: relative !important;
}

.bg-pick .wpcf7-list-item-label::before,
.audiogb-pick .wpcf7-list-item-label::before,
.box-pick .wpcf7-list-item-label::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.04), rgba(0,0,0,0.16));
    pointer-events: none;
    border-radius: 14px !important;
}

.bg-pick .wpcf7-list-item-label::after,
.audiogb-pick .wpcf7-list-item-label::after,
.box-pick .wpcf7-list-item-label::after {
    content: none !important;
}

.bg-pick .wpcf7-list-item:hover,
.audiogb-pick .wpcf7-list-item:hover,
.box-pick .wpcf7-list-item:hover {
    z-index: 5;
}

.bg-pick .wpcf7-list-item-label:hover,
.audiogb-pick .wpcf7-list-item-label:hover,
.box-pick .wpcf7-list-item-label:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,0.55);
}

.bg-pick input[type="checkbox"]:checked + .wpcf7-list-item-label,
.audiogb-pick input[type="checkbox"]:checked + .wpcf7-list-item-label,
.box-pick input[type="checkbox"]:checked + .wpcf7-list-item-label {
    border-color: #ffffff;
    transform: translateY(-2px);
}

.bg-pick input[type="checkbox"]:checked + .wpcf7-list-item-label::after,
.audiogb-pick input[type="checkbox"]:checked + .wpcf7-list-item-label::after,
.box-pick input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
    content: "✓" !important;
    position: absolute;
    top: 10px;
    right: 10px;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: rgba(17,17,17,0.88);
    color: #ffffff;
    font-size: 15px;
    line-height: 28px;
    text-align: center;
    font-weight: 600;
}

.bg-pick .wpcf7-list-item::after,
.audiogb-pick .wpcf7-list-item::after,
.box-pick .wpcf7-list-item::after {
    display: block;
    margin: 0;
    font: 400 14px/1.35 Mulish, sans-serif;
    letter-spacing: 0.01em;
    text-align: center;
    color: #a1a1a1;
    content: "";
    transition: color 0.2s ease, transform 0.2s ease;
}

.bg-pick .wpcf7-list-item:hover::after,
.audiogb-pick .wpcf7-list-item:hover::after,
.box-pick .wpcf7-list-item:hover::after,
.bg-pick .wpcf7-list-item:has(input:checked)::after,
.audiogb-pick .wpcf7-list-item:has(input:checked)::after,
.box-pick .wpcf7-list-item:has(input:checked)::after {
    color: #ffffff;
}

/* =========================
   GRIDS
========================= */
.bg-pick .wpcf7-checkbox,
.audiogb-pick .wpcf7-checkbox {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    overflow: visible !important;
}

.box-pick .wpcf7-checkbox {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible !important;
}

@media (max-width: 900px) {
    .bg-pick .wpcf7-checkbox,
    .audiogb-pick .wpcf7-checkbox {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 520px) {
    .bg-pick .wpcf7-checkbox,
    .audiogb-pick .wpcf7-checkbox,
    .box-pick .wpcf7-checkbox {
        grid-template-columns: 1fr;
    }
}

/* =========================
   BACKGROUND CAPTIONS
========================= */
.bg-pick .wpcf7-list-item:has(input[value="Weiß"])::after { content: "Weiß"; }
.bg-pick .wpcf7-list-item:has(input[value="Grau"])::after { content: "Grau"; }
.bg-pick .wpcf7-list-item:has(input[value="Braun"])::after { content: "Braun"; }
.bg-pick .wpcf7-list-item:has(input[value="Grün"])::after { content: "Grün"; }
.bg-pick .wpcf7-list-item:has(input[value="Glitzer"])::after { content: "Glitzer"; }

/* =========================
   BACKGROUND IMAGES
========================= */
.bg-pick input[value="Weiß"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/cal_weiss.webp"); }
.bg-pick input[value="Grau"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/cal_grau.webp"); }
.bg-pick input[value="Braun"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/cal_braun.webp"); }
.bg-pick input[value="Grün"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/cal_gruen.webp"); }
.bg-pick input[value="Glitzer"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/cal_glitter.webp"); }

/* =========================
   AUDIO CAPTIONS
========================= */
.audiogb-pick .wpcf7-list-item:has(input[value="Modell 20ty"])::after { content: "Modell 20ty"; }
.audiogb-pick .wpcf7-list-item:has(input[value="Modell 30ty"])::after { content: "Modell 30ty"; }
.audiogb-pick .wpcf7-list-item:has(input[value="Modell 60ty"])::after { content: "Modell 60ty"; }

/* =========================
   AUDIO IMAGES
========================= */
.audiogb-pick input[value="Modell 20ty"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/20ty.webp"); }
.audiogb-pick input[value="Modell 30ty"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/30ty.webp"); }
.audiogb-pick input[value="Modell 60ty"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/60ty.webp"); }

/* =========================
   BOX CAPTIONS
========================= */
.box-pick .wpcf7-list-item:has(input[value="Pinky"])::after { content: "Pinky"; }
.box-pick .wpcf7-list-item:has(input[value="Woody"])::after { content: "Woody"; }

/* =========================
   BOX IMAGES
========================= */
.box-pick input[value="Pinky"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/pink_square.webp"); }
.box-pick input[value="Woody"] + .wpcf7-list-item-label { background-image: url("/wp-content/uploads/2026/04/wood_square.webp"); }

/* =========================
   DISABLED IMAGE OVERLAY
========================= */
.box-pick input[type="checkbox"]:disabled + .wpcf7-list-item-label,
.audiogb-pick input[type="checkbox"]:disabled + .wpcf7-list-item-label {
    opacity: 0.5;
    cursor: not-allowed;
}

.box-pick input[type="checkbox"]:disabled + .wpcf7-list-item-label::after,
.audiogb-pick input[type="checkbox"]:disabled + .wpcf7-list-item-label::after {
    content: "nicht verfügbar" !important;
    position: absolute !important;
    inset: 0;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center;
    color: #ffffff !important;
    background: rgba(0,0,0,0.65) !important;
    z-index: 999 !important;
    pointer-events: none;
    border-radius: 12px !important;
}

/* ========================================
   PORTAL LOGIN FIELDS
======================================== */

/* gleiche Basis wie deine anderen Felder */
.wpcf7 input[type="password"] {
    font: 400 18px/1.62857143 Mulish, sans-serif !important;
    letter-spacing: -0.00208em !important;
    color: #a1a1a1 !important;
    -webkit-text-fill-color: #a1a1a1 !important;
    background: transparent !important;
    border: 1px solid #a1a1a1 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    padding: 12px 20px !important;
    transition: border-color 0.3s ease, color 0.3s ease !important;
}

/* placeholder ausblenden */
.wpcf7 input[type="password"]::placeholder,
.wpcf7 input[type="password"]::-webkit-input-placeholder,
.wpcf7 input[type="password"]::-moz-placeholder,
.wpcf7 input[type="password"]:-ms-input-placeholder,
.wpcf7 input[type="password"]::-ms-input-placeholder {
    color: transparent !important;
    opacity: 0 !important;
}

/* focus / gefüllt */
.wpcf7 input[type="password"]:focus,
.wpcf7 input[type="password"]:not(:placeholder-shown) {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border-color: #ffffff !important;
}

/* wrap für floating label */
.dfb-portal-form .wpcf7-form-control-wrap {
    position: relative;
    display: block;
}

/* label im rahmen */
.dfb-portal-form .wpcf7-form-control-wrap::after {
    position: absolute;
    top: -5px;
    left: 20px;
    padding: 0 6px;
    background: #111111 !important;
    font-size: 12px;
    line-height: 1;
    color: #a1a1a1;
    pointer-events: none;
    z-index: 3;
}

/* email-label */
.dfb-portal-form .wpcf7-form-control-wrap.dfb_email::after {
    content: "E-Mail";
}

/* password-label */
.dfb-portal-form .wpcf7-form-control-wrap.dfb_password::after {
    content: "Passwort";
}

/* button optional an dein styling angleichen */
.dfb-portal-form .dfb-portal-btn {
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #a1a1a1 !important;
    font-family: Hind, sans-serif !important;
    font-size: 13px !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    padding: 18px 35px 17px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    font-weight: 400 !important;
}

.dfb-portal-form .dfb-portal-btn:hover {
    color: #ffffff !important;
    border-color: #ffffff !important;
}