/* =========================================================
   SWR Online-Anmeldung – stabile Plugin-Version
   ========================================================= */
.swr-oa-wrap{--swr-orange:#d17b13;--swr-orange-dark:#a75e08;--swr-soft:#fff8ef;--swr-text:#111;--swr-muted:#5e5e5e;--swr-line:rgba(17,17,17,.12);max-width:1180px;margin:0 auto;padding:22px;font-family:Inter,Arial,sans-serif;color:var(--swr-text)!important}.swr-oa-wrap *{box-sizing:border-box}.swr-oa-wrap a{color:inherit}.swr-oa-hero{position:relative;overflow:hidden;margin:16px 0 28px;padding:64px 42px;border-radius:34px;background:radial-gradient(circle at 82% 18%,rgba(209,123,19,.26),transparent 28rem),linear-gradient(135deg,#030303,#111 62%,#1b1005);color:#fff!important}.swr-oa-hero *{color:#fff!important}.swr-oa-eyebrow{display:inline-flex;align-items:center;gap:9px;padding:9px 14px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:rgba(255,255,255,.07);color:#f4d1a3!important;font-size:13px;font-weight:900}.swr-oa-eyebrow:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--swr-orange);box-shadow:0 0 18px rgba(209,123,19,.85)}.swr-oa-hero h1{max-width:820px;margin:22px 0 0;font-size:clamp(42px,7vw,78px);line-height:.94;letter-spacing:-.07em}.swr-oa-hero h1 span{color:var(--swr-orange)!important}.swr-oa-hero p{max-width:700px;margin:18px 0 0;color:rgba(255,255,255,.78)!important;font-size:18px;line-height:1.7}.swr-oa-form-shell,.swr-oa-booking-shell,.swr-oa-success{overflow:hidden;border:1px solid var(--swr-line);border-radius:34px;background:linear-gradient(180deg,#fff,#fffaf5);color:#111!important;box-shadow:0 26px 70px rgba(0,0,0,.10)}.swr-oa-form-head{padding:26px 28px 0}.swr-oa-progress-top{display:flex;justify-content:space-between;gap:14px;margin-bottom:12px;color:#111!important;font-size:14px;font-weight:950}.swr-oa-progress-bar{height:10px;overflow:hidden;border-radius:999px;background:#eee4d8!important}.swr-oa-progress-fill{height:100%;width:11%;border-radius:999px;background:linear-gradient(90deg,var(--swr-orange-dark),var(--swr-orange))!important;transition:width .25s ease}.swr-oa-step{display:none;padding:34px 28px 28px;color:#111!important}.swr-oa-step.active{display:block}.swr-oa-step h2{margin:0;color:#111!important;font-size:clamp(32px,4vw,50px);line-height:1;letter-spacing:-.055em}.swr-oa-step h3{color:#111!important}.swr-oa-step p{color:#555!important}.swr-oa-step-lead{max-width:760px;margin:12px 0 28px;color:#666!important;font-size:17px;line-height:1.7}.swr-oa-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.swr-oa-class-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.swr-oa-field{display:grid;gap:9px}.swr-oa-field label,.swr-oa-check-row label{color:#4f4f4f!important;font-size:13px;font-weight:850}.swr-oa-field input,.swr-oa-field select,.swr-oa-field textarea{width:100%;min-height:56px;padding:0 18px;border:2px solid #e3d5c5!important;border-radius:18px;outline:none;background:#fffdf9!important;color:#111!important;-webkit-text-fill-color:#111!important;font:inherit;box-shadow:0 6px 18px rgba(0,0,0,.05);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.swr-oa-field input:hover,.swr-oa-field select:hover,.swr-oa-field textarea:hover{border-color:#d8c2aa!important;background:#fff!important}.swr-oa-field input:focus,.swr-oa-field select:focus,.swr-oa-field textarea:focus{border-color:var(--swr-orange)!important;background:#fff!important;box-shadow:0 0 0 4px rgba(209,123,19,.16),0 8px 22px rgba(0,0,0,.07)}.swr-oa-field input::placeholder,.swr-oa-field textarea::placeholder{color:#9a9a9a!important;opacity:1}.swr-oa-field select option{background:#fff!important;color:#111!important}.swr-oa-hidden-radio{position:absolute!important;opacity:0!important;pointer-events:none!important;width:1px!important;height:1px!important}.swr-oa-card{position:relative;min-height:154px;padding:20px 18px 22px;border:1px solid var(--swr-line);border-radius:22px;background:#fff!important;color:#111!important;display:flex;align-items:center;justify-content:center;overflow:visible;cursor:pointer;box-shadow:0 14px 30px rgba(0,0,0,.05);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.swr-oa-card:hover{transform:translateY(-3px);border-color:rgba(209,123,19,.34);box-shadow:0 0 0 4px rgba(209,123,19,.08),0 20px 42px rgba(0,0,0,.08)}.swr-oa-card input{display:none}.swr-oa-card:after{content:"";position:absolute;left:18px;right:18px;bottom:16px;height:4px;border-radius:999px;background:linear-gradient(90deg,rgba(209,123,19,.42),rgba(209,123,19,.08))}.swr-oa-card-inner{width:100%;min-height:92px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;position:relative;z-index:3}.swr-oa-card h3{margin:0;width:100%;color:#111!important;-webkit-text-fill-color:#111!important;font-size:clamp(19px,1.45vw,23px);line-height:1.05;letter-spacing:-.055em;text-align:center;word-break:normal;hyphens:manual}.swr-oa-info-icon{width:40px!important;height:40px!important;flex:0 0 40px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border-radius:999px!important;border:1px solid rgba(209,123,19,.42)!important;background:linear-gradient(180deg,#fffaf3,#fff2df)!important;color:#7a4306!important;-webkit-text-fill-color:#7a4306!important;box-shadow:0 0 0 5px rgba(209,123,19,.08),0 14px 28px rgba(209,123,19,.12)!important;cursor:help!important;transition:transform .2s ease,background .2s ease,box-shadow .2s ease,border-color .2s ease!important}.swr-oa-info-icon svg{width:23px!important;height:23px!important;display:block!important;fill:none!important;stroke:currentColor!important;stroke-width:2.2!important;stroke-linecap:round!important;stroke-linejoin:round!important;color:#7a4306!important}.swr-oa-info-icon:hover,.swr-oa-info-icon:focus{outline:none!important;transform:translateY(-2px) scale(1.04)!important;border-color:rgba(209,123,19,.72)!important;background:linear-gradient(135deg,#d17b13,#f09a28)!important;color:#fff!important;-webkit-text-fill-color:#fff!important;box-shadow:0 0 0 6px rgba(209,123,19,.14),0 18px 34px rgba(209,123,19,.26)!important}.swr-oa-info-icon:hover svg,.swr-oa-info-icon:focus svg{color:#fff!important}.swr-oa-tooltip{position:absolute;left:50%;bottom:calc(100% + 14px);z-index:80;width:min(330px,88vw);padding:16px 18px;border-radius:18px;border:1px solid rgba(209,123,19,.24);background:linear-gradient(180deg,#fffaf3,#fff2df)!important;color:#3f2b14!important;-webkit-text-fill-color:#3f2b14!important;font-size:14px;font-weight:750;line-height:1.55;letter-spacing:-.01em;text-align:left;box-shadow:0 24px 54px rgba(0,0,0,.18),0 0 0 1px rgba(255,255,255,.70) inset!important;opacity:0;visibility:hidden;transform:translateX(-50%) translateY(8px);transition:opacity .22s ease,transform .22s ease,visibility .22s ease;pointer-events:none}.swr-oa-tooltip:after{content:"";position:absolute;left:50%;bottom:-7px;width:14px;height:14px;border-right:1px solid rgba(209,123,19,.18);border-bottom:1px solid rgba(209,123,19,.18);background:#fff2df!important;transform:translateX(-50%) rotate(45deg)}.swr-oa-card:hover .swr-oa-tooltip,.swr-oa-card:focus-within .swr-oa-tooltip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.swr-oa-card.selected{border-color:#d17b13!important;background:#fff3e3!important;box-shadow:0 0 0 4px rgba(209,123,19,.18),0 22px 48px rgba(209,123,19,.16)!important;transform:translateY(-2px)}.swr-oa-card.selected:before{content:"Ausgewählt";position:absolute;top:14px;left:14px;z-index:10;padding:5px 9px;border-radius:999px;background:#d17b13;color:#fff!important;-webkit-text-fill-color:#fff!important;font-size:11px;font-weight:950;line-height:1;box-shadow:0 10px 22px rgba(209,123,19,.24)}.swr-oa-card.selected h3{color:#7a4306!important;-webkit-text-fill-color:#7a4306!important}.swr-oa-card.selected .swr-oa-info-icon{border-color:rgba(209,123,19,.72)!important;background:linear-gradient(135deg,#d17b13,#f09a28)!important;color:#fff!important;-webkit-text-fill-color:#fff!important}.swr-oa-card.selected .swr-oa-info-icon svg{color:#fff!important}.swr-oa-step-action-row{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:12px;margin-top:26px}.swr-oa-advice-btn,.swr-oa-skip-btn{min-height:48px;padding:0 18px;border-radius:999px;font-size:14px;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.swr-oa-advice-btn{border:1px solid rgba(209,123,19,.28);background:#fff8ef!important;color:#7a4306!important;-webkit-text-fill-color:#7a4306!important;box-shadow:0 12px 28px rgba(0,0,0,.05)}.swr-oa-advice-btn:hover{transform:translateY(-2px);border-color:rgba(209,123,19,.46);background:#fff2df!important;box-shadow:0 18px 36px rgba(0,0,0,.075)}.swr-oa-advice-icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#d17b13!important;color:#fff!important;-webkit-text-fill-color:#fff!important;font-size:13px;font-weight:950}.swr-oa-skip-btn{border:1px solid rgba(17,17,17,.10);background:#fff!important;color:#111!important;-webkit-text-fill-color:#111!important;box-shadow:0 12px 28px rgba(0,0,0,.05)}.swr-oa-skip-btn:hover{transform:translateY(-2px);border-color:rgba(209,123,19,.28);background:#fffaf5!important;box-shadow:0 18px 36px rgba(0,0,0,.075)}.swr-oa-price-selection{display:grid;gap:16px}.swr-oa-price-empty{padding:22px;border-radius:22px;border:1px solid rgba(209,123,19,.22);background:#fff8ef;color:#3f2b14!important;box-shadow:0 14px 30px rgba(0,0,0,.05)}.swr-oa-price-empty strong{display:block;margin-bottom:6px;color:#111!important;font-size:16px;font-weight:950}.swr-oa-price-empty span{display:block;color:#555!important;font-size:14px;line-height:1.55}.swr-oa-price-box,.swr-oa-contract-box,.swr-oa-summary-box,.swr-oa-info-box,.swr-oa-calendar-box{overflow:hidden;border:1px solid var(--swr-line);border-radius:26px;background:#fff!important;color:#111!important;box-shadow:0 14px 30px rgba(0,0,0,.05)}.swr-oa-price-head{display:flex;justify-content:space-between;gap:18px;padding:22px;background:#080808;color:#fff!important}.swr-oa-price-head *{color:#fff!important}.swr-oa-price-head strong{font-size:23px}.swr-oa-price-description{padding:18px 20px;color:#555!important;line-height:1.6;border-bottom:1px solid rgba(0,0,0,.06);background:#fffaf5}.swr-oa-price-box table{width:100%;border-collapse:collapse}.swr-oa-price-box td{padding:16px 20px;border-top:1px solid rgba(0,0,0,.06);color:#555!important}.swr-oa-price-box td:last-child{text-align:right;color:#111!important;font-weight:900}.swr-oa-check-row{display:flex;align-items:flex-start;gap:14px;margin-top:16px;padding:18px 20px;border:1px solid rgba(17,17,17,.12)!important;border-radius:22px;background:#fff!important;color:#111!important;box-shadow:0 12px 28px rgba(0,0,0,.04)}.swr-oa-check-row input[type="checkbox"]{display:inline-block!important;visibility:visible!important;opacity:1!important;width:22px!important;height:22px!important;margin:2px 0 0!important;flex:0 0 22px!important;accent-color:#d17b13!important}.swr-oa-check-row label{display:grid!important;gap:4px!important;visibility:visible!important;opacity:1!important;color:#111!important;-webkit-text-fill-color:#111!important;font-size:14px!important;line-height:1.5!important;margin:0!important}.swr-oa-check-row label strong{display:block!important;color:#111!important;-webkit-text-fill-color:#111!important;font-size:14px!important;font-weight:950!important}.swr-oa-check-row label span{display:block!important;color:#555!important;-webkit-text-fill-color:#555!important;font-size:13px!important;font-weight:650!important;line-height:1.45!important}.swr-oa-check-row a{color:#d17b13!important;-webkit-text-fill-color:#d17b13!important;font-weight:900;text-decoration:none}.swr-oa-contract-box{max-height:360px;overflow:auto;padding:24px;color:#666!important;line-height:1.7}.swr-oa-contract-box p{color:#555!important}.swr-oa-info-box{margin-top:16px;padding:22px;background:#fff8ef!important;color:#555!important;line-height:1.6}.swr-oa-info-box h3{margin:0 0 8px;color:#111!important;font-size:20px;font-weight:950;letter-spacing:-.035em}.swr-oa-info-box p{margin:0 0 10px;color:#555!important;font-size:14px;line-height:1.65}.swr-oa-checklist-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.swr-oa-card-option{max-width:680px;align-items:flex-start;justify-content:flex-start;min-height:auto}.swr-oa-badge{align-self:flex-start;margin-bottom:14px;padding:7px 10px;border-radius:999px;background:#fff2df;color:#7a4306!important;font-size:12px;font-weight:950}.swr-oa-summary-box{display:grid;gap:0;padding:18px 20px}.swr-oa-summary-box>div{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-bottom:1px solid rgba(0,0,0,.06);align-items:flex-start}.swr-oa-summary-box>div:last-child{border-bottom:0}.swr-oa-summary-box span{color:#555!important;-webkit-text-fill-color:#555!important}.swr-oa-summary-box strong{color:#111!important;-webkit-text-fill-color:#111!important;text-align:right;font-weight:950}.swr-oa-nav-row{display:flex;justify-content:space-between;gap:12px;padding:0 28px 28px}.swr-oa-btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 22px;border:0;border-radius:999px;cursor:pointer;font-size:14px;font-weight:900;text-decoration:none;transition:transform .22s ease,box-shadow .22s ease,background .22s ease}.swr-oa-btn:hover{transform:translateY(-2px)}.swr-oa-btn.full{width:100%}.swr-oa-btn-primary{background:linear-gradient(135deg,#a75e08,var(--swr-orange));color:#fff!important;-webkit-text-fill-color:#fff!important;box-shadow:0 16px 34px rgba(209,123,19,.32)}.swr-oa-btn-secondary{border:1px solid rgba(0,0,0,.08);background:#fff;color:#111!important;-webkit-text-fill-color:#111!important;box-shadow:0 12px 24px rgba(0,0,0,.08)}.swr-oa-alert,.swr-oa-inline-error{margin:24px 28px;padding:18px 20px;border:1px solid rgba(157,31,31,.18);border-radius:22px;background:#fff0f0;color:#9d1f1f!important;-webkit-text-fill-color:#9d1f1f!important;font-weight:850;line-height:1.5}.swr-oa-inline-error{margin:-10px 0 22px;font-size:14px}.swr-oa-field-error{border-color:#9d1f1f!important;box-shadow:0 0 0 4px rgba(157,31,31,.10),0 8px 22px rgba(0,0,0,.07)!important}.swr-oa-selection-error .swr-oa-card{border-color:rgba(157,31,31,.35)!important}.swr-oa-success{padding:70px 28px;text-align:center}.swr-oa-success-icon{display:grid;place-items:center;width:78px;height:78px;margin:0 auto 18px;border-radius:999px;background:#fff2df;color:#a75e08!important;font-size:2rem}.swr-oa-success h2{margin:0 0 14px;color:#111!important;font-size:clamp(40px,6vw,66px);line-height:.95;letter-spacing:-.07em}.swr-oa-success p{max-width:680px;margin:0 auto 24px;color:#666!important;font-size:17px;line-height:1.75}.swr-oa-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:12px}.swr-oa-booking-shell{display:grid;grid-template-columns:320px 1fr;gap:22px;padding:22px}.swr-oa-booking-side{padding:24px;border-radius:28px;background:#111;color:#fff!important}.swr-oa-booking-side *{color:#fff!important}.swr-oa-booking-side h2{margin:18px 0 12px;font-size:42px;line-height:1;letter-spacing:-.06em}.swr-oa-booking-side p{color:rgba(255,255,255,.72)!important;line-height:1.65}.swr-oa-mini-list{display:grid;gap:10px;margin-top:22px}.swr-oa-mini-list div{padding:12px;border:1px solid rgba(255,255,255,.10);border-radius:18px;background:rgba(255,255,255,.07)}.swr-oa-calendar-box{padding:18px}.swr-oa-day-group{margin-bottom:16px}.swr-oa-day-title{display:flex;justify-content:space-between;align-items:center;margin:0 0 10px;color:#111!important;font-weight:950;letter-spacing:-.02em}.swr-oa-slots{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.swr-oa-slot{display:block}.swr-oa-slot input{display:none}.swr-oa-slot span{display:flex;align-items:center;justify-content:center;min-height:54px;border:1px solid rgba(0,0,0,.10);border-radius:18px;background:#fff!important;color:#111!important;cursor:pointer;font-weight:900;transition:background .2s ease,color .2s ease,box-shadow .2s ease,border-color .2s ease}.swr-oa-slot input:checked+span{border-color:#111;background:#111!important;color:#fff!important;box-shadow:0 12px 26px rgba(0,0,0,.18)}.swr-oa-safe-note{margin:12px 0 0;color:rgba(255,255,255,.76)!important;font-size:13px}.swr-oa-admin-card{max-width:980px;background:#fff;border:1px solid #dcdcde;border-radius:12px;padding:18px;margin:18px 0}
@media(max-width:1000px){.swr-oa-class-grid,.swr-oa-license-grid,.swr-oa-training-grid{grid-template-columns:1fr!important}.swr-oa-card{min-height:136px}.swr-oa-card h3{font-size:24px}.swr-oa-tooltip{left:18px;right:18px;bottom:calc(100% + 12px);width:auto;transform:translateY(8px)}.swr-oa-tooltip:after{left:50%;transform:translateX(-50%) rotate(45deg)}.swr-oa-card:hover .swr-oa-tooltip,.swr-oa-card:focus-within .swr-oa-tooltip{transform:translateY(0)}.swr-oa-booking-shell{grid-template-columns:1fr}.swr-oa-slots{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.swr-oa-wrap{padding:12px}.swr-oa-hero{padding:44px 22px;border-radius:26px}.swr-oa-hero h1{font-size:clamp(42px,13vw,60px)}.swr-oa-form-shell,.swr-oa-booking-shell,.swr-oa-success{border-radius:26px}.swr-oa-form-head{padding:22px 18px 0}.swr-oa-step{padding:28px 18px}.swr-oa-grid-2,.swr-oa-slots{grid-template-columns:1fr}.swr-oa-field input,.swr-oa-field select,.swr-oa-field textarea{min-height:54px;border-radius:16px}.swr-oa-nav-row{flex-direction:column-reverse;padding:0 18px 22px}.swr-oa-btn,.swr-oa-advice-btn,.swr-oa-skip-btn{width:100%}.swr-oa-summary-box>div{flex-direction:column;gap:4px}.swr-oa-summary-box strong{text-align:left}.swr-oa-price-box td{display:block;text-align:left!important}.swr-oa-progress-top{gap:10px;font-size:13px}.swr-oa-booking-shell{padding:14px}.swr-oa-success{padding:48px 18px}.swr-oa-checklist-actions{flex-direction:column}}

/* =========================================================
   SWR RESCUE CSS FIX v1.3 – Sichtbare Felder & Texte
   Dieser Block steht absichtlich ganz am Ende und überschreibt Theme-CSS.
   ========================================================= */

body .swr-oa-wrap,
body .swr-oa-wrap .swr-oa-form-shell,
body .swr-oa-wrap .swr-oa-step,
body .swr-oa-wrap .swr-oa-step *:not(.swr-oa-btn):not(.swr-oa-btn *):not(.swr-oa-btn-primary):not(.swr-oa-btn-primary *):not(.swr-oa-info-icon):not(.swr-oa-info-icon *),
body .swr-oa-wrap .swr-oa-summary-box,
body .swr-oa-wrap .swr-oa-summary-box * {
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
}

body .swr-oa-wrap .swr-oa-step-lead,
body .swr-oa-wrap .swr-oa-field label,
body .swr-oa-wrap .swr-oa-check-row label span,
body .swr-oa-wrap .swr-oa-card p,
body .swr-oa-wrap .swr-oa-card li,
body .swr-oa-wrap .swr-oa-info-box p,
body .swr-oa-wrap .swr-oa-summary-box span {
    color: #555555 !important;
    -webkit-text-fill-color: #555555 !important;
}

/* Eingabefelder bewusst sichtbar machen */
body .swr-oa-wrap .swr-oa-field input:not([type="radio"]):not([type="checkbox"]),
body .swr-oa-wrap .swr-oa-field select,
body .swr-oa-wrap .swr-oa-field textarea {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    min-height: 58px !important;
    padding: 0 18px !important;
    border: 2px solid #d9c3aa !important;
    border-radius: 18px !important;
    background: #fff7ee !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
    caret-color: #111111 !important;
    box-shadow:
        0 0 0 1px rgba(255,255,255,.85) inset,
        0 10px 24px rgba(0,0,0,.055) !important;
    outline: none !important;
}

body .swr-oa-wrap .swr-oa-field textarea {
    min-height: 120px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
}

body .swr-oa-wrap .swr-oa-field input:not([type="radio"]):not([type="checkbox"]):hover,
body .swr-oa-wrap .swr-oa-field select:hover,
body .swr-oa-wrap .swr-oa-field textarea:hover {
    background: #ffffff !important;
    border-color: #cfa678 !important;
}

body .swr-oa-wrap .swr-oa-field input:not([type="radio"]):not([type="checkbox"]):focus,
body .swr-oa-wrap .swr-oa-field select:focus,
body .swr-oa-wrap .swr-oa-field textarea:focus {
    background: #ffffff !important;
    border-color: #d17b13 !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
    box-shadow:
        0 0 0 4px rgba(209,123,19,.18),
        0 12px 28px rgba(0,0,0,.075) !important;
}

body .swr-oa-wrap .swr-oa-field input::placeholder,
body .swr-oa-wrap .swr-oa-field textarea::placeholder {
    color: #8a8a8a !important;
    -webkit-text-fill-color: #8a8a8a !important;
    opacity: 1 !important;
}

body .swr-oa-wrap .swr-oa-field select option {
    color: #111111 !important;
    background: #ffffff !important;
    -webkit-text-fill-color: #111111 !important;
}

/* Autofill-Fix Chrome/Safari */
body .swr-oa-wrap input:-webkit-autofill,
body .swr-oa-wrap input:-webkit-autofill:hover,
body .swr-oa-wrap input:-webkit-autofill:focus,
body .swr-oa-wrap textarea:-webkit-autofill,
body .swr-oa-wrap select:-webkit-autofill {
    -webkit-text-fill-color: #111111 !important;
    box-shadow: 0 0 0 1000px #fff7ee inset !important;
    transition: background-color 9999s ease-in-out 0s !important;
}

/* Checkbox-Zeilen sichtbar */
body .swr-oa-wrap .swr-oa-check-row {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    min-height: 68px !important;
    padding: 18px 20px !important;
    border: 1px solid rgba(17,17,17,.13) !important;
    border-radius: 22px !important;
    background: #ffffff !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.045) !important;
}

body .swr-oa-wrap .swr-oa-check-row input[type="checkbox"] {
    display: inline-block !important;
    appearance: auto !important;
    -webkit-appearance: checkbox !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 22px !important;
    height: 22px !important;
    margin: 2px 0 0 !important;
    flex: 0 0 22px !important;
    accent-color: #d17b13 !important;
}

body .swr-oa-wrap .swr-oa-check-row label {
    display: grid !important;
    gap: 4px !important;
    visibility: visible !important;
    opacity: 1 !important;
    margin: 0 !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
    font-size: 14px !important;
    font-weight: 750 !important;
    line-height: 1.5 !important;
}

body .swr-oa-wrap .swr-oa-check-row label strong {
    display: block !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
    font-weight: 950 !important;
}

body .swr-oa-wrap .swr-oa-check-row label span {
    display: block !important;
    color: #555555 !important;
    -webkit-text-fill-color: #555555 !important;
    font-weight: 650 !important;
}

body .swr-oa-wrap .swr-oa-check-row a {
    color: #d17b13 !important;
    -webkit-text-fill-color: #d17b13 !important;
    font-weight: 900 !important;
}

/* Karten/Buttons absichern */
body .swr-oa-wrap .swr-oa-card {
    background: #ffffff !important;
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
}

body .swr-oa-wrap .swr-oa-card.selected {
    border-color: #d17b13 !important;
    background: #fff3e3 !important;
    box-shadow: 0 0 0 4px rgba(209,123,19,.18), 0 22px 48px rgba(209,123,19,.16) !important;
}

body .swr-oa-wrap .swr-oa-info-icon,
body .swr-oa-wrap .swr-oa-advice-icon {
    color: #7a4306 !important;
    -webkit-text-fill-color: #7a4306 !important;
    background: linear-gradient(180deg,#fffaf3,#fff2df) !important;
}

body .swr-oa-wrap .swr-oa-info-icon svg {
    color: #7a4306 !important;
    stroke: currentColor !important;
}

body .swr-oa-wrap .swr-oa-btn-primary,
body .swr-oa-wrap .swr-oa-btn-primary *,
body .swr-oa-wrap button.swr-oa-btn-primary {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

body .swr-oa-wrap .swr-oa-btn-secondary,
body .swr-oa-wrap .swr-oa-btn-secondary *,
body .swr-oa-wrap button.swr-oa-btn-secondary,
body .swr-oa-wrap .swr-oa-skip-btn,
body .swr-oa-wrap .swr-oa-skip-btn * {
    color: #111111 !important;
    -webkit-text-fill-color: #111111 !important;
}

/* Dunkle Hero-Fläche bleibt hell */
body .swr-oa-wrap .swr-oa-hero,
body .swr-oa-wrap .swr-oa-hero * {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

body .swr-oa-wrap .swr-oa-hero h1 span {
    color: #d17b13 !important;
    -webkit-text-fill-color: #d17b13 !important;
}

@media (max-width: 720px) {
    body .swr-oa-wrap .swr-oa-field input:not([type="radio"]):not([type="checkbox"]),
    body .swr-oa-wrap .swr-oa-field select,
    body .swr-oa-wrap .swr-oa-field textarea {
        min-height: 56px !important;
        border-radius: 16px !important;
    }
}


/* =========================================================
   SWR Online-Anmeldung integriert V4
   Nutzung per Shortcode: [swr_anmeldung_page] oder [swr_anmeldung_integrated]
========================================================= */

.swr-application-template {
    --swr-orange: #d17b13;
    --swr-orange-dark: #a75e08;
    --swr-black: #050505;
    --swr-dark: #101010;
    --swr-form-dark: #151515;
    --swr-form-darker: #0f0f0f;
    --swr-text: #0b0b0b;
    --swr-muted: #555555;
    --swr-white: #ffffff;
    width: 100%;
    min-height: calc(100vh - 80px);
    padding: 56px 20px 64px;
    overflow-x: hidden;
    background:
        radial-gradient(circle at 78% 18%, rgba(209,123,19,.08), transparent 28rem),
        linear-gradient(135deg, #ffffff 0%, #f7f4ef 100%);
    font-family: Inter, Arial, sans-serif;
    color: var(--swr-text);
}

.swr-application-template,
.swr-application-template * {
    box-sizing: border-box;
}

.swr-application-layout {
    width: min(1660px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 380px minmax(0, 1fr);
    gap: 50px;
    align-items: stretch;
}

.swr-application-side,
.swr-application-main,
.swr-form-frame {
    min-width: 0;
}

.swr-application-side {
    width: 100%;
    min-height: 100%;
    align-self: stretch;
    display: flex;
    flex-direction: column;
    padding: 8px 0;
}

.swr-application-main {
    width: 100%;
    display: flex;
    align-self: stretch;
}

.swr-side-brand {
    margin-bottom: 38px;
}

.swr-side-brand strong {
    display: block;
    color: #080808;
    font-size: 22px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: -.06em;
}

.swr-side-brand span {
    display: block;
    margin-top: 4px;
    color: var(--swr-orange);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.swr-side-title {
    max-width: 360px;
    margin: 0 0 18px;
    color: #070707;
    font-size: clamp(52px, 4.9vw, 72px);
    line-height: .90;
    letter-spacing: -.08em;
    font-weight: 950;
}

.swr-side-title span {
    display: block;
    color: var(--swr-orange);
}

.swr-side-text {
    max-width: 350px;
    margin: 0;
    color: #4e4e4e;
    font-size: 16px;
    line-height: 1.75;
    font-weight: 520;
}

.swr-side-help {
    position: relative;
    width: 100%;
    margin-top: auto;
    padding: 26px;
    overflow: hidden;
    border-radius: 26px;
    background:
        radial-gradient(circle at 90% 0%, rgba(209,123,19,.10), transparent 12rem),
        linear-gradient(180deg, #0b0b0b, #111111);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow:
        0 18px 44px rgba(0,0,0,.16),
        inset 0 1px 0 rgba(255,255,255,.04);
}

.swr-side-help::before {
    content: "";
    position: absolute;
    left: 0;
    top: 18px;
    bottom: 18px;
    width: 1px;
    background: linear-gradient(180deg, rgba(209,123,19,.75), rgba(209,123,19,.08));
}

.swr-side-help-kicker {
    margin-bottom: 12px;
    color: var(--swr-orange);
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.swr-side-help h3 {
    margin: 0 0 10px;
    color: #ffffff;
    font-size: 26px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: -.055em;
}

.swr-side-help p {
    margin: 0;
    color: rgba(255,255,255,.66);
    font-size: 14px;
    line-height: 1.65;
    font-weight: 560;
}

.swr-side-help-actions {
    display: grid;
    gap: 11px;
    margin-top: 20px;
}

.swr-side-help-btn {
    min-height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    border-radius: 16px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 900;
    transition: background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.swr-side-help-btn:hover {
    transform: translateY(-1px);
}

.swr-side-help-btn.primary {
    background: linear-gradient(135deg, var(--swr-orange-dark), var(--swr-orange));
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(209,123,19,.24);
}

.swr-side-help-btn.secondary {
    background: #101010;
    color: #ffffff;
    border: 1px solid rgba(255,255,255,.08);
}

.swr-side-help-btn.outline {
    background: rgba(209,123,19,.08);
    color: #ffffff;
    border: 1px solid rgba(209,123,19,.30);
}

.swr-side-help-btn svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.swr-side-help-note {
    margin-top: 15px;
    color: rgba(255,255,255,.42);
    font-size: 12px;
    line-height: 1.5;
}

.swr-form-frame {
    position: relative;
    width: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 30px;
    background:
        radial-gradient(circle at 88% 8%, rgba(209,123,19,.14), transparent 24rem),
        linear-gradient(180deg, var(--swr-form-dark) 0%, var(--swr-form-darker) 100%);
    border: 1px solid rgba(255,255,255,.11);
    box-shadow:
        0 34px 90px rgba(0,0,0,.25),
        inset 0 1px 0 rgba(255,255,255,.06);
    padding: 28px;
}

.swr-form-frame-header {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    align-items: start;
    margin-bottom: 22px;
}

.swr-form-frame-title {
    display: flex;
    gap: 14px;
    align-items: center;
    min-width: 0;
}

.swr-form-frame-icon {
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
    border-radius: 15px;
    display: grid;
    place-items: center;
    background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
    border: 1px solid rgba(255,255,255,.12);
    color: #ffffff;
}

.swr-form-frame-icon svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.swr-form-frame-title strong {
    display: block;
    color: #ffffff;
    font-size: 24px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: -.055em;
}

.swr-form-frame-title strong span {
    display: block;
    color: var(--swr-orange);
}

.swr-form-frame-title small {
    display: block;
    margin-top: 3px;
    color: rgba(255,255,255,.72);
    font-size: 13px;
    font-weight: 750;
}

/* Plugin-Formular im dunklen integrierten Frame */
.swr-form-frame .swr-oa-wrap,
.swr-form-frame .swr-oa-form-shell,
.swr-form-frame .swr-oa-form,
.swr-form-frame form {
    max-width: none !important;
    width: 100% !important;
    min-width: 0 !important;
}

.swr-form-frame .swr-oa-wrap {
    padding: 0 !important;
    margin: 0 !important;
    color: #ffffff !important;
    background: transparent !important;
}

.swr-form-frame .swr-oa-hero,
.swr-form-frame .swr-oa-page-hero,
.swr-form-frame .swr-oa-form-intro {
    display: none !important;
}

.swr-form-frame .swr-oa-form-shell {
    margin: 0 !important;
    padding: clamp(20px, 2.3vw, 34px) !important;
    box-shadow: none !important;
    border-radius: 24px !important;
    background: rgba(255,255,255,.045) !important;
    border: 1px solid rgba(255,255,255,.09) !important;
    flex: 1 1 auto;
}

.swr-form-frame .swr-oa-safe-note {
    display: none !important;
}

.swr-form-frame .swr-oa-form-shell,
.swr-form-frame .swr-oa-form-shell * {
    color: rgba(255,255,255,.86);
}

.swr-form-frame .swr-oa-form-shell h1,
.swr-form-frame .swr-oa-form-shell h2,
.swr-form-frame .swr-oa-form-shell h3,
.swr-form-frame .swr-oa-form-shell h4,
.swr-form-frame .swr-oa-form-shell label,
.swr-form-frame .swr-oa-form-shell strong,
.swr-form-frame .swr-oa-form-shell b {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.swr-form-frame .swr-oa-form-shell p,
.swr-form-frame .swr-oa-form-shell span,
.swr-form-frame .swr-oa-form-shell small,
.swr-form-frame .swr-oa-form-shell li {
    color: rgba(255,255,255,.76) !important;
    -webkit-text-fill-color: rgba(255,255,255,.76) !important;
}

.swr-form-frame .swr-oa-field input,
.swr-form-frame .swr-oa-field select,
.swr-form-frame .swr-oa-field textarea,
.swr-form-frame input[type="text"],
.swr-form-frame input[type="email"],
.swr-form-frame input[type="tel"],
.swr-form-frame input[type="date"],
.swr-form-frame input[type="number"],
.swr-form-frame input[type="password"],
.swr-form-frame select,
.swr-form-frame textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 58px;
    padding: 0 18px !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255,255,255,.24) !important;
    background: rgba(255,255,255,.10) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    box-shadow: none !important;
    outline: none !important;
}

.swr-form-frame textarea {
    min-height: 130px;
    padding-top: 16px !important;
    padding-bottom: 16px !important;
}

.swr-form-frame input::placeholder,
.swr-form-frame textarea::placeholder {
    color: rgba(255,255,255,.60) !important;
    opacity: 1 !important;
}

.swr-form-frame input:focus,
.swr-form-frame select:focus,
.swr-form-frame textarea:focus {
    border-color: rgba(209,123,19,.82) !important;
    box-shadow: 0 0 0 4px rgba(209,123,19,.14) !important;
}

.swr-form-frame select option {
    color: #111111 !important;
    background: #ffffff !important;
}

.swr-form-frame .swr-oa-card,
.swr-form-frame .swr-oa-panel,
.swr-form-frame .swr-oa-summary,
.swr-form-frame .swr-oa-price-box,
.swr-form-frame .swr-oa-confirm-box,
.swr-form-frame .swr-oa-choice,
.swr-form-frame .swr-oa-class-card {
    background: rgba(255,255,255,.065) !important;
    border-color: rgba(255,255,255,.15) !important;
    color: #ffffff !important;
}

.swr-form-frame .swr-oa-card h3 {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.swr-form-frame .swr-oa-card.selected,
.swr-form-frame .swr-oa-card:has(input[type="radio"]:checked),
.swr-form-frame .swr-oa-card:has(input[type="checkbox"]:checked) {
    border-color: #d17b13 !important;
    background: rgba(209,123,19,.14) !important;
    box-shadow: 0 18px 42px rgba(209,123,19,.18) !important;
}

.swr-form-frame button,
.swr-form-frame input[type="submit"],
.swr-form-frame .swr-oa-btn,
.swr-form-frame .button {
    min-height: 52px;
    border-radius: 16px !important;
    background: linear-gradient(180deg, var(--swr-orange), var(--swr-orange-dark)) !important;
    border: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-weight: 900 !important;
    box-shadow: 0 16px 34px rgba(209,123,19,.26) !important;
}

.swr-form-frame a {
    color: #ffac3d !important;
}

.swr-form-frame table,
.swr-form-frame .swr-oa-table {
    width: 100%;
    max-width: 100%;
    display: block;
    overflow-x: auto;
}

.swr-form-template-note {
    margin-top: auto;
    padding-top: 18px;
    display: flex;
    align-items: center;
    gap: 9px;
    color: rgba(255,255,255,.68);
    font-size: 12px;
    font-weight: 650;
}

.swr-form-template-note svg {
    width: 15px;
    height: 15px;
    color: rgba(255,255,255,.76);
}

/* Kleine native Radio-/Checkbox-Inputs in Auswahlkarten ausblenden */
.swr-oa-card input[type="radio"],
.swr-oa-card input[type="checkbox"],
.swr-oa-training-card input[type="radio"],
.swr-oa-license-card input[type="radio"],
[data-training-card] input[type="radio"],
[data-class-card] input[type="radio"],
.swr-oa-hidden-radio {
    position: absolute !important;
    opacity: 0 !important;
    width: 1px !important;
    height: 1px !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
}

.swr-oa-card input[type="radio"]:focus,
.swr-oa-card input[type="radio"]:focus-visible,
.swr-oa-card input[type="checkbox"]:focus,
.swr-oa-card input[type="checkbox"]:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

/* Trust Strip */
.swr-trust-strip {
    width: 100%;
    background: #c9700c;
    font-family: Inter, Arial, sans-serif;
    padding: 0 20px;
}

.swr-trust-strip-inner {
    width: min(1320px, 100%);
    min-height: 54px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.swr-trust-item {
    min-height: 54px;
    padding: 0 34px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #ffffff;
    position: relative;
}

.swr-trust-item:not(:last-child)::after {
    content: "";
    position: absolute;
    right: 0;
    top: 12px;
    bottom: 12px;
    width: 1px;
    background: rgba(255,255,255,.28);
}

.swr-trust-icon {
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
}

.swr-trust-icon svg {
    width: 23px;
    height: 23px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.15;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.swr-trust-item:nth-child(2) .swr-trust-icon svg {
    fill: currentColor;
    stroke: none;
}

.swr-trust-item strong {
    display: block;
    color: #ffffff;
    font-size: 15px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: -.025em;
}

.swr-trust-item span:not(.swr-trust-icon) {
    display: block;
    color: rgba(255,255,255,.92);
    font-size: 11px;
    line-height: 1.15;
    font-weight: 750;
}

@media (max-width: 1280px) and (min-width: 981px) {
    .swr-application-layout {
        grid-template-columns: 330px minmax(0, 1fr);
        gap: 34px;
    }

    .swr-side-title {
        max-width: 320px;
        font-size: clamp(46px, 4.7vw, 62px);
    }

    .swr-side-text {
        max-width: 315px;
        font-size: 15px;
    }

    .swr-side-help {
        padding: 22px;
    }

    .swr-side-help h3 {
        font-size: 23px;
    }
}

@media (max-width: 980px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    .swr-application-template {
        padding: 32px 14px 42px;
    }

    .swr-application-layout {
        width: 100%;
        max-width: 100%;
        grid-template-columns: minmax(0, 1fr);
        gap: 28px;
        align-items: start;
    }

    .swr-application-side {
        height: auto;
        min-height: auto;
        display: block;
        max-width: 100%;
        padding: 0;
    }

    .swr-side-title,
    .swr-side-text {
        max-width: 100%;
    }

    .swr-side-help {
        margin-top: 24px;
        padding: 18px;
        max-width: 520px;
    }

    .swr-application-main,
    .swr-form-frame {
        width: 100%;
        max-width: 100%;
    }

    .swr-form-frame {
        min-height: auto;
        padding: 18px;
        border-radius: 24px;
    }

    .swr-form-frame .swr-oa-form-shell {
        padding: 18px !important;
    }

    .swr-form-frame .swr-oa-class-grid,
    .swr-form-frame .swr-oa-grid-2 {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .swr-trust-strip-inner {
        justify-content: flex-start;
        overflow-x: auto;
        scrollbar-width: none;
    }

    .swr-trust-strip-inner::-webkit-scrollbar {
        display: none;
    }

    .swr-trust-item {
        flex: 0 0 auto;
        padding: 0 24px;
    }
}

@media (max-width: 720px) {
    .swr-application-template {
        padding: 28px 12px 42px;
    }

    .swr-side-brand {
        margin-bottom: 22px;
    }

    .swr-side-title {
        font-size: clamp(40px, 13vw, 54px);
    }

    .swr-side-text {
        font-size: 14px;
    }

    .swr-side-help {
        max-width: 100%;
        margin-top: 20px;
        padding: 16px;
        border-radius: 18px;
    }

    .swr-form-frame {
        border-radius: 20px;
        padding: 14px;
    }

    .swr-form-frame-header {
        margin-bottom: 16px;
    }

    .swr-form-frame-title {
        align-items: flex-start;
    }

    .swr-form-frame-icon {
        width: 48px;
        height: 48px;
        flex: 0 0 48px;
    }

    .swr-form-frame-title strong {
        font-size: 21px;
    }

    .swr-form-frame .swr-oa-form-shell {
        padding: 14px !important;
        border-radius: 18px !important;
    }

    .swr-form-frame button,
    .swr-form-frame input[type="submit"],
    .swr-form-frame .swr-oa-btn,
    .swr-form-frame .button {
        width: 100%;
    }

    .swr-trust-strip {
        padding: 10px 12px;
    }

    .swr-trust-strip-inner {
        min-height: auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .swr-trust-item {
        min-height: 48px;
        width: 100%;
        padding: 0 14px;
        border-radius: 14px;
        background: rgba(255,255,255,.08);
    }

    .swr-trust-item:not(:last-child)::after {
        display: none;
    }
}


/* =========================================================
   SWR Online-Anmeldung v1.3.3
   Formularlayout nach Screenshot: kompakt, zentriert, Premium-Dark
========================================================= */

/* Rahmen insgesamt kompakter und stärker wie ein Formular-Panel */
.swr-form-frame {
    max-width: 1120px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    border-radius: 30px !important;
    padding: clamp(22px, 2.2vw, 32px) !important;
    background:
        radial-gradient(circle at 82% 10%, rgba(209,123,19,.16), transparent 24rem),
        radial-gradient(circle at 12% 22%, rgba(255,255,255,.045), transparent 20rem),
        linear-gradient(180deg, #181818 0%, #101010 100%) !important;
}

/* Plugin-Formular als innere Fläche ähnlich Screenshot */
.swr-form-frame .swr-oa-form-shell {
    padding: clamp(30px, 3vw, 54px) clamp(34px, 4vw, 64px) !important;
    border-radius: 24px !important;
    background:
        radial-gradient(circle at 55% 30%, rgba(255,255,255,.045), transparent 22rem),
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)) !important;
    border: 1px solid rgba(255,255,255,.11) !important;
}

/* Kopfleiste im Template etwas kompakter */
.swr-form-frame-header {
    margin-bottom: 16px !important;
}

.swr-form-frame-title strong {
    font-size: 23px !important;
}

.swr-form-frame-title strong span {
    color: #f28a0b !important;
}

/* Schritt-Überschriften genau wie Screenshot: groß, klar, links */
.swr-form-frame .swr-oa-form-shell h2 {
    margin: 0 0 10px !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: clamp(36px, 4vw, 58px) !important;
    line-height: .94 !important;
    letter-spacing: -.065em !important;
    font-weight: 950 !important;
}

.swr-form-frame .swr-oa-step-lead {
    max-width: 780px !important;
    margin: 0 0 30px !important;
    color: rgba(255,255,255,.78) !important;
    -webkit-text-fill-color: rgba(255,255,255,.78) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    font-weight: 750 !important;
}

/* Progress-Bereich kompakter wie oben im Screenshot */
.swr-form-frame .swr-oa-progress,
.swr-form-frame .swr-oa-step-progress {
    margin-bottom: 26px !important;
}

.swr-form-frame .swr-oa-progress-meta,
.swr-form-frame .swr-oa-step-meta {
    font-size: 12px !important;
    font-weight: 900 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.swr-form-frame .swr-oa-progress-track,
.swr-form-frame .swr-oa-step-progress-track {
    height: 7px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.14) !important;
}

.swr-form-frame .swr-oa-progress-bar,
.swr-form-frame .swr-oa-step-progress-bar,
.swr-form-frame .swr-oa-progress-fill,
.swr-form-frame .swr-oa-step-progress-fill {
    height: 7px !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, #d17b13, #f08b12) !important;
}

/* Auswahlkarten: flacher, breiter, screenshotnah */
.swr-form-frame .swr-oa-class-grid,
.swr-form-frame .swr-oa-training-grid,
.swr-form-frame .swr-oa-license-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 18px !important;
    margin: 24px 0 28px !important;
    width: 100% !important;
}

.swr-form-frame .swr-oa-card,
.swr-form-frame .swr-oa-training-card,
.swr-form-frame .swr-oa-license-card {
    position: relative !important;
    min-height: 118px !important;
    padding: 24px 20px 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.055),
        0 14px 34px rgba(0,0,0,.18) !important;
    overflow: visible !important;
    cursor: pointer !important;
}

.swr-form-frame .swr-oa-card::after,
.swr-form-frame .swr-oa-training-card::after,
.swr-form-frame .swr-oa-license-card::after {
    content: "" !important;
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 14px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, rgba(209,123,19,.95), rgba(209,123,19,.20)) !important;
}

.swr-form-frame .swr-oa-card-inner,
.swr-form-frame .swr-oa-training-card-inner,
.swr-form-frame .swr-oa-license-card-inner {
    width: 100% !important;
    display: grid !important;
    place-items: center !important;
    gap: 13px !important;
    text-align: center !important;
}

.swr-form-frame .swr-oa-card h3,
.swr-form-frame .swr-oa-training-card h3,
.swr-form-frame .swr-oa-license-card h3 {
    margin: 0 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: clamp(17px, 1.5vw, 21px) !important;
    line-height: 1.08 !important;
    font-weight: 950 !important;
    letter-spacing: -.035em !important;
}

/* Info-Icon kleiner, mittig unter Text */
.swr-form-frame .swr-oa-info-icon,
.swr-form-frame .swr-oa-license-info-icon {
    width: 23px !important;
    height: 23px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    border: 1px solid rgba(209,123,19,.95) !important;
    background: rgba(0,0,0,.25) !important;
    color: #f19a22 !important;
    position: relative !important;
    z-index: 4 !important;
}

.swr-form-frame .swr-oa-info-icon svg,
.swr-form-frame .swr-oa-license-info-icon svg {
    width: 16px !important;
    height: 16px !important;
    stroke: currentColor !important;
}

/* Tooltips bleiben funktional, aber weniger störend */
.swr-form-frame .swr-oa-tooltip,
.swr-form-frame .swr-oa-training-tooltip,
.swr-form-frame .swr-oa-license-tooltip {
    z-index: 20 !important;
}

/* Aktive Karte hochwertig markieren */
.swr-form-frame .swr-oa-card.selected,
.swr-form-frame .swr-oa-card:has(input[type="radio"]:checked),
.swr-form-frame .swr-oa-training-card:has(input[type="radio"]:checked),
.swr-form-frame .swr-oa-license-card:has(input[type="radio"]:checked),
.swr-form-frame [data-training-card]:has(input[type="radio"]:checked),
.swr-form-frame [data-class-card]:has(input[type="radio"]:checked) {
    border-color: rgba(209,123,19,.92) !important;
    background:
        radial-gradient(circle at 50% 0%, rgba(209,123,19,.20), transparent 9rem),
        linear-gradient(180deg, rgba(209,123,19,.16), rgba(255,255,255,.035)) !important;
    box-shadow:
        0 18px 46px rgba(209,123,19,.18),
        inset 0 1px 0 rgba(255,255,255,.075) !important;
}

/* Kleine native Inputs vollständig entfernen */
.swr-form-frame .swr-oa-card input[type="radio"],
.swr-form-frame .swr-oa-card input[type="checkbox"],
.swr-form-frame [data-training-card] input[type="radio"],
.swr-form-frame [data-class-card] input[type="radio"],
.swr-form-frame .swr-oa-hidden-radio {
    position: absolute !important;
    left: -9999px !important;
    top: auto !important;
    opacity: 0 !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    pointer-events: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
}

/* Beratungs- und Skip-Zeile wie Screenshot: mittig */
.swr-form-frame .swr-oa-step-action-row,
.swr-form-frame .swr-oa-training-action-row,
.swr-form-frame .swr-oa-license-action-row {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    margin: 28px auto 26px !important;
    text-align: center !important;
}

.swr-form-frame .swr-oa-advice-btn {
    min-height: 32px !important;
    max-width: 520px !important;
    padding: 0 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(209,123,19,.70) !important;
    background: rgba(0,0,0,.20) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
}

.swr-form-frame .swr-oa-advice-icon {
    width: 18px !important;
    height: 18px !important;
    flex: 0 0 18px !important;
    border-radius: 999px !important;
    display: inline-grid !important;
    place-items: center !important;
    background: #d17b13 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 11px !important;
    line-height: 1 !important;
}

.swr-form-frame .swr-oa-skip-btn,
.swr-form-frame .swr-oa-skip-training-btn,
.swr-form-frame .swr-oa-skip-license-btn {
    width: auto !important;
    min-width: 255px !important;
    min-height: 48px !important;
    padding: 0 24px !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, #d17b13, #bd690b) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 950 !important;
    box-shadow: 0 18px 38px rgba(209,123,19,.24) !important;
}

/* Zurück/Weiter unten außen im Formularpanel */
.swr-form-frame .swr-oa-actions,
.swr-form-frame .swr-oa-form-actions,
.swr-form-frame .swr-oa-nav,
.swr-form-frame .swr-oa-buttons {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin-top: 34px !important;
}

.swr-form-frame .swr-oa-actions button,
.swr-form-frame .swr-oa-form-actions button,
.swr-form-frame .swr-oa-nav button,
.swr-form-frame .swr-oa-buttons button,
.swr-form-frame .swr-oa-btn {
    width: auto !important;
    min-width: 86px !important;
    min-height: 54px !important;
    padding: 0 22px !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, #d17b13, #bd690b) !important;
    box-shadow: 0 18px 38px rgba(209,123,19,.22) !important;
}

.swr-form-frame .swr-oa-actions button:first-child,
.swr-form-frame .swr-oa-form-actions button:first-child,
.swr-form-frame .swr-oa-nav button:first-child,
.swr-form-frame .swr-oa-buttons button:first-child {
    margin-right: auto !important;
}

.swr-form-frame .swr-oa-actions button:last-child,
.swr-form-frame .swr-oa-form-actions button:last-child,
.swr-form-frame .swr-oa-nav button:last-child,
.swr-form-frame .swr-oa-buttons button:last-child {
    margin-left: auto !important;
}

/* Inputs in normalen Schritten bleiben groß und lesbar */
.swr-form-frame .swr-oa-field input,
.swr-form-frame .swr-oa-field select,
.swr-form-frame .swr-oa-field textarea {
    min-height: 58px !important;
    border-radius: 16px !important;
}

/* Mobile: Screenshot-Layout wird einspaltig und bleibt innerhalb des Viewports */
@media (max-width: 980px) {
    .swr-form-frame {
        max-width: 100% !important;
        padding: 18px !important;
        border-radius: 24px !important;
    }

    .swr-form-frame .swr-oa-form-shell {
        padding: 26px 18px 28px !important;
    }

    .swr-form-frame .swr-oa-class-grid,
    .swr-form-frame .swr-oa-training-grid,
    .swr-form-frame .swr-oa-license-grid {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .swr-form-frame .swr-oa-card,
    .swr-form-frame .swr-oa-training-card,
    .swr-form-frame .swr-oa-license-card {
        min-height: 104px !important;
    }

    .swr-form-frame .swr-oa-form-shell h2 {
        font-size: clamp(32px, 10vw, 44px) !important;
    }

    .swr-form-frame .swr-oa-actions,
    .swr-form-frame .swr-oa-form-actions,
    .swr-form-frame .swr-oa-nav,
    .swr-form-frame .swr-oa-buttons {
        margin-top: 28px !important;
    }
}

@media (max-width: 560px) {
    .swr-form-frame {
        padding: 12px !important;
    }

    .swr-form-frame .swr-oa-form-shell {
        padding: 22px 14px 24px !important;
        border-radius: 18px !important;
    }

    .swr-form-frame .swr-oa-advice-btn {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 38px !important;
        white-space: normal !important;
        line-height: 1.25 !important;
        padding: 8px 12px !important;
    }

    .swr-form-frame .swr-oa-skip-btn,
    .swr-form-frame .swr-oa-skip-training-btn,
    .swr-form-frame .swr-oa-skip-license-btn {
        width: 100% !important;
        min-width: 0 !important;
    }

    .swr-form-frame .swr-oa-actions,
    .swr-form-frame .swr-oa-form-actions,
    .swr-form-frame .swr-oa-nav,
    .swr-form-frame .swr-oa-buttons {
        flex-direction: row !important;
    }
}
/* =========================================================
   FIX: Fehlermeldungen im Dark-Formular lesbar darstellen
   Bitte ganz unten in assets/swr-form.css einfügen
========================================================= */

.swr-form-frame .swr-oa-alert,
.swr-form-frame .swr-oa-inline-error,
#swr-anmeldung .swr-oa-alert,
#swr-anmeldung .swr-oa-inline-error {
    width: 100% !important;
    margin: 18px 0 22px !important;
    padding: 16px 18px !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    border-radius: 16px !important;
    background:
        radial-gradient(circle at 92% 0%, rgba(209,123,19,.10), transparent 12rem),
        rgba(120, 24, 24, .24) !important;
    border: 1px solid rgba(255, 90, 90, .30) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.045),
        0 14px 34px rgba(0,0,0,.18) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    font-weight: 800 !important;
}

/* Text in Fehlermeldungen wirklich sichtbar halten */
.swr-form-frame .swr-oa-alert *,
.swr-form-frame .swr-oa-inline-error *,
#swr-anmeldung .swr-oa-alert *,
#swr-anmeldung .swr-oa-inline-error * {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Optionales Warn-Icon vor der Meldung */
.swr-form-frame .swr-oa-alert::before,
.swr-form-frame .swr-oa-inline-error::before,
#swr-anmeldung .swr-oa-alert::before,
#swr-anmeldung .swr-oa-inline-error::before {
    content: "!";
    width: 22px;
    height: 22px;
    min-width: 22px;
    margin-top: -1px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(180deg, #d17b13 0%, #a75e08 100%) !important;
    border: 2px solid rgba(255,255,255,.90);
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 12px;
    line-height: 1;
    font-weight: 950;
    box-shadow: 0 10px 22px rgba(209,123,19,.24);
}

/* Falls ein Theme/Plugin die Meldung als p/div/span innen hell färbt */
.swr-form-frame .swr-oa-alert p,
.swr-form-frame .swr-oa-alert span,
.swr-form-frame .swr-oa-inline-error p,
.swr-form-frame .swr-oa-inline-error span,
#swr-anmeldung .swr-oa-alert p,
#swr-anmeldung .swr-oa-alert span,
#swr-anmeldung .swr-oa-inline-error p,
#swr-anmeldung .swr-oa-inline-error span {
    margin: 0 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Feld mit Fehler sauber markieren */
.swr-form-frame .swr-oa-field-error,
#swr-anmeldung .swr-oa-field-error {
    border-color: rgba(255, 90, 90, .78) !important;
    box-shadow:
        0 0 0 4px rgba(255, 90, 90, .12),
        0 8px 22px rgba(0,0,0,.16) !important;
}

/* Mobile etwas kompakter */
@media (max-width: 560px) {
    .swr-form-frame .swr-oa-alert,
    .swr-form-frame .swr-oa-inline-error,
    #swr-anmeldung .swr-oa-alert,
    #swr-anmeldung .swr-oa-inline-error {
        padding: 14px 15px !important;
        border-radius: 14px !important;
        font-size: 12.5px !important;
    }
}
/* =========================================================
   GLOBAL MOBILE FIX: Zurück / Weiter in einer Reihe
   Bitte ganz unten in assets/swr-form.css einfügen
========================================================= */

@media (max-width: 720px) {
    .swr-form-frame .swr-oa-nav-row,
    #swr-anmeldung .swr-oa-nav-row {
        width: 100% !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
        margin-top: 28px !important;
        padding: 0 0 22px !important;
    }

    .swr-form-frame .swr-oa-nav-row .swr-oa-btn,
    .swr-form-frame .swr-oa-nav-row button,
    #swr-anmeldung .swr-oa-nav-row .swr-oa-btn,
    #swr-anmeldung .swr-oa-nav-row button,
    .swr-form-frame #swrPrevBtn,
    .swr-form-frame #swrNextBtn,
    .swr-form-frame #swrSubmitBtn,
    #swr-anmeldung #swrPrevBtn,
    #swr-anmeldung #swrNextBtn,
    #swr-anmeldung #swrSubmitBtn {
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        flex: 1 1 0 !important;
        min-height: 48px !important;
        padding: 0 14px !important;
        border-radius: 14px !important;
        font-size: 13px !important;
        line-height: 1.1 !important;
        white-space: nowrap !important;
    }

    /* Falls nur ein Button sichtbar ist, bleibt er rechts und wird nicht riesig */
    .swr-form-frame .swr-oa-nav-row #swrNextBtn:first-child,
    .swr-form-frame .swr-oa-nav-row #swrSubmitBtn:first-child,
    #swr-anmeldung .swr-oa-nav-row #swrNextBtn:first-child,
    #swr-anmeldung .swr-oa-nav-row #swrSubmitBtn:first-child {
        flex: 0 0 auto !important;
        min-width: 118px !important;
        margin-left: auto !important;
    }
}

@media (max-width: 380px) {
    .swr-form-frame .swr-oa-nav-row,
    #swr-anmeldung .swr-oa-nav-row {
        gap: 8px !important;
    }

    .swr-form-frame .swr-oa-nav-row .swr-oa-btn,
    .swr-form-frame .swr-oa-nav-row button,
    #swr-anmeldung .swr-oa-nav-row .swr-oa-btn,
    #swr-anmeldung .swr-oa-nav-row button {
        min-height: 46px !important;
        padding: 0 10px !important;
        font-size: 12px !important;
    }
}

/* =========================================================
   GLOBAL MOBILE FIX: Step-Überschriften laufen nicht raus
   Gilt für alle Schritte der SWR Online-Anmeldung
========================================================= */

#swr-anmeldung .swr-oa-step,
#swr-anmeldung .swr-oa-step > div,
#swr-anmeldung .swr-oa-step h2,
.swr-form-frame .swr-oa-step,
.swr-form-frame .swr-oa-step > div,
.swr-form-frame .swr-oa-step h2 {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    white-space: normal !important;
}

#swr-anmeldung .swr-oa-step h2,
.swr-form-frame .swr-oa-step h2 {
    width: 100% !important;
    hyphens: none !important;
}

/* Lead-Text unter der Überschrift */
#swr-anmeldung .swr-oa-step-lead,
.swr-form-frame .swr-oa-step-lead {
    max-width: 100% !important;
    min-width: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
}

/* Tablet / kleinere Screens */
@media (max-width: 720px) {
    #swr-anmeldung .swr-oa-step h2,
    .swr-form-frame .swr-oa-step h2 {
        font-size: clamp(30px, 8.6vw, 38px) !important;
        line-height: 1.04 !important;
        letter-spacing: -0.045em !important;
        margin-bottom: 10px !important;
    }

    #swr-anmeldung .swr-oa-step-lead,
    .swr-form-frame .swr-oa-step-lead {
        font-size: 14px !important;
        line-height: 1.5 !important;
        margin-bottom: 22px !important;
    }
}

/* Sehr kleine Smartphones */
@media (max-width: 430px) {
    #swr-anmeldung .swr-oa-step h2,
    .swr-form-frame .swr-oa-step h2 {
        font-size: clamp(28px, 8vw, 33px) !important;
        line-height: 1.06 !important;
        letter-spacing: -0.035em !important;
    }
}

/* Mini-Screens */
@media (max-width: 360px) {
    #swr-anmeldung .swr-oa-step h2,
    .swr-form-frame .swr-oa-step h2 {
        font-size: 27px !important;
        line-height: 1.08 !important;
        letter-spacing: -0.025em !important;
    }
}
/* =========================================================
   FIX: Buttons orange + Tooltips lesbar
   Für Template/Plugin: .swr-form-frame .swr-oa-*
   Ganz unten in das Template-CSS oder assets/swr-form.css einfügen
========================================================= */

/* 1) Zurück- und Weiter-Button: beide orange mit weißer Schrift */
.swr-form-frame .swr-oa-nav-row .swr-oa-btn,
.swr-form-frame .swr-oa-nav-row button,
.swr-form-frame #swrPrevBtn,
.swr-form-frame #swrNextBtn,
.swr-form-frame #swrSubmitBtn {
    background: linear-gradient(180deg, #d17b13 0%, #a75e08 100%) !important;
    border: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    box-shadow: 0 16px 34px rgba(209, 123, 19, .28) !important;
}

/* Auch der sekundäre Zurück-Button darf nicht grau werden */
.swr-form-frame .swr-oa-btn-secondary,
.swr-form-frame #swrPrevBtn.swr-oa-btn-secondary {
    background: linear-gradient(180deg, #d17b13 0%, #a75e08 100%) !important;
    border: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Button-Hover */
.swr-form-frame .swr-oa-nav-row .swr-oa-btn:hover,
.swr-form-frame .swr-oa-nav-row button:hover,
.swr-form-frame #swrPrevBtn:hover,
.swr-form-frame #swrNextBtn:hover,
.swr-form-frame #swrSubmitBtn:hover {
    background: linear-gradient(180deg, #e48616 0%, #b96909 100%) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    transform: translateY(-1px);
}

/* 2) Beratungsbutton ebenfalls orange, falls du ihn als Button statt Outline möchtest */
.swr-form-frame .swr-oa-advice-btn {
    background: linear-gradient(180deg, #d17b13 0%, #a75e08 100%) !important;
    border: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    box-shadow: 0 12px 26px rgba(209, 123, 19, .22) !important;
}

.swr-form-frame .swr-oa-advice-btn span,
.swr-form-frame .swr-oa-advice-btn * {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Das kleine ? im Beratungsbutton optisch sauber halten */
.swr-form-frame .swr-oa-advice-icon {
    background: rgba(255,255,255,.18) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border: 1px solid rgba(255,255,255,.28) !important;
}

/* 3) Skip-Button sauber orange */
.swr-form-frame .swr-oa-skip-btn,
.swr-form-frame .swr-oa-skip-training-btn,
.swr-form-frame .swr-oa-skip-license-btn {
    background: linear-gradient(180deg, #d17b13 0%, #a75e08 100%) !important;
    border: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    box-shadow: 0 16px 34px rgba(209, 123, 19, .28) !important;
}

/* 4) Infotexte / Tooltips: dunkler Hintergrund, weiße Schrift */
.swr-form-frame .swr-oa-tooltip,
.swr-form-frame .swr-oa-training-tooltip,
.swr-form-frame .swr-oa-license-tooltip {
    background: #111111 !important;
    background-color: #111111 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border: 1px solid rgba(209, 123, 19, .42) !important;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .42) !important;
}

/* Tooltip-Texte innerhalb des Tooltip ebenfalls weiß */
.swr-form-frame .swr-oa-tooltip *,
.swr-form-frame .swr-oa-training-tooltip *,
.swr-form-frame .swr-oa-license-tooltip * {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Falls das Plugin Tooltip über :before/:after mit weißem Pfeil erzeugt */
.swr-form-frame .swr-oa-tooltip::before,
.swr-form-frame .swr-oa-tooltip::after,
.swr-form-frame .swr-oa-training-tooltip::before,
.swr-form-frame .swr-oa-training-tooltip::after,
.swr-form-frame .swr-oa-license-tooltip::before,
.swr-form-frame .swr-oa-license-tooltip::after {
    background: #111111 !important;
    border-color: rgba(209, 123, 19, .42) !important;
}

/* 5) Info-Icon: nicht als weißer Punkt, sondern passend orange/dunkel */
.swr-form-frame .swr-oa-info-icon,
.swr-form-frame .swr-oa-license-info-icon {
    background: rgba(0,0,0,.35) !important;
    border: 1px solid rgba(209, 123, 19, .95) !important;
    color: #f4a034 !important;
    -webkit-text-fill-color: #f4a034 !important;
    box-shadow: 0 0 0 3px rgba(209,123,19,.08) !important;
}

.swr-form-frame .swr-oa-info-icon svg,
.swr-form-frame .swr-oa-license-info-icon svg {
    stroke: currentColor !important;
}

/* 6) Sicherheitsnetz: weiße Schrift auf weißen Tooltip-Hintergründen verhindern */
.swr-form-frame .swr-oa-card .swr-oa-tooltip,
.swr-form-frame .swr-oa-card .swr-oa-training-tooltip,
.swr-form-frame .swr-oa-card .swr-oa-license-tooltip {
    background: #111111 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}
/* =========================================================
   FIX STEP 1: Persönliche Daten / erstes Formular
   Bitte ganz unten im Template-CSS oder in assets/swr-form.css einfügen
========================================================= */

/* Abstand zwischen Progressbar und Überschrift korrigieren */
.swr-form-frame .swr-oa-form-head {
    margin-bottom: 36px !important;
}

/* Überschrift auf Seite 1 sauber setzen */
.swr-form-frame .swr-oa-personal-step h2,
.swr-form-frame .swr-oa-step[data-step="1"] h2 {
    margin: 0 0 10px !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: clamp(34px, 3.7vw, 54px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.045em !important;
    word-spacing: .08em !important;
    font-weight: 950 !important;
    max-width: 100% !important;
}

/* Beschreibung unter der Überschrift */
.swr-form-frame .swr-oa-personal-step .swr-oa-step-lead,
.swr-form-frame .swr-oa-step[data-step="1"] .swr-oa-step-lead {
    margin: 0 0 28px !important;
    color: rgba(255,255,255,.78) !important;
    -webkit-text-fill-color: rgba(255,255,255,.78) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    font-weight: 700 !important;
}

/* Wichtig: Dein erster Schritt nutzt .swr-oa-grid-2 */
.swr-form-frame .swr-oa-grid-2,
.swr-form-frame .swr-oa-personal-grid {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px 22px !important;
    margin: 0 !important;
}

/* Felder bündig und stabil */
.swr-form-frame .swr-oa-grid-2 .swr-oa-field,
.swr-form-frame .swr-oa-personal-grid .swr-oa-field {
    min-width: 0 !important;
    margin: 0 !important;
}

/* Labels über den Feldern */
.swr-form-frame .swr-oa-grid-2 .swr-oa-field label,
.swr-form-frame .swr-oa-personal-grid .swr-oa-field label {
    display: block !important;
    margin: 0 0 8px !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
    font-weight: 850 !important;
}

/* Inputs auf Seite 1 etwas kompakter */
.swr-form-frame .swr-oa-grid-2 input,
.swr-form-frame .swr-oa-personal-grid input {
    min-height: 54px !important;
    border-radius: 15px !important;
}

/* Navigation nicht in den Formularinhalt rutschen lassen */
.swr-form-frame .swr-oa-nav-row {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin-top: 40px !important;
    padding-top: 0 !important;
}

/* Auf Schritt 1 soll Zurück unsichtbar sein, aber seinen Platz nicht zerstören */
.swr-form-frame #swrPrevBtn {
    margin-right: auto !important;
}

/* Weiter-Button rechts unten sauber ausrichten */
.swr-form-frame #swrNextBtn,
.swr-form-frame #swrSubmitBtn {
    margin-left: auto !important;
    align-self: flex-end !important;
}

/* Wenn der Zurück-Button per JS versteckt wird, bleibt Weiter trotzdem rechts */
.swr-form-frame .swr-oa-nav-row #swrNextBtn:first-child,
.swr-form-frame .swr-oa-nav-row #swrSubmitBtn:first-child {
    margin-left: auto !important;
}

/* Mobile */
@media (max-width: 980px) {
    .swr-form-frame .swr-oa-grid-2,
    .swr-form-frame .swr-oa-personal-grid {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .swr-form-frame .swr-oa-personal-step h2,
    .swr-form-frame .swr-oa-step[data-step="1"] h2 {
        font-size: clamp(32px, 10vw, 44px) !important;
        line-height: 1.03 !important;
        letter-spacing: -0.04em !important;
    }

    .swr-form-frame .swr-oa-nav-row {
        margin-top: 30px !important;
    }
}

@media (max-width: 560px) {
    .swr-form-frame .swr-oa-nav-row {
        gap: 10px !important;
    }

    .swr-form-frame #swrNextBtn,
    .swr-form-frame #swrSubmitBtn {
        min-width: 104px !important;
    }
}