
:root{--green:#1f5d46;--green2:#2f7d5b;--deep:#12382d;--sand:#f2ead8;--cream:#fffaf0;--paper:#ffffff;--ink:#1f2a24;--muted:#66736d;--line:#ded4c1;--yellow:#c58900;--red:#b94a48;--gray:#73807a;--shadow:0 8px 24px rgba(31,42,36,.07);--font-base:14px;--radius:18px}
html[data-font-size="compact"]{--font-base:13px;--density:.84}html[data-font-size="normal"]{--font-base:15px;--density:1}html[data-font-size="large"]{--font-base:17px;--density:1.1}
*{box-sizing:border-box}html{scroll-behavior:smooth;font-size:var(--font-base)}body{margin:0;background:var(--cream);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.42}.skipLink{position:absolute;left:-999px;top:10px;background:white;color:var(--green);padding:10px;border-radius:10px;z-index:100}.skipLink:focus{left:10px}
h1,h2,h3,h4,p{margin-top:0}.eyebrow{text-transform:uppercase;letter-spacing:.08em;opacity:.82;margin:0 0 5px;font-size:.68rem;font-weight:850}.eyebrow.dark{color:var(--green);opacity:1}.hint{color:var(--muted);font-size:.88rem;line-height:1.42}.topHeader{position:relative;z-index:1200;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:16px clamp(14px,3vw,36px);background:linear-gradient(135deg,var(--green),var(--deep));color:white}.brandBlock h1{font-size:clamp(1.35rem,2.3vw,2.1rem);line-height:1.06;margin:0 0 5px}.brandBlock p:last-child{max-width:760px;margin:0;opacity:.92}.viewTools{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:10px}.segmented{display:flex;gap:6px;flex-wrap:wrap}.segmented button{padding:7px 10px}.segmented button.isActive{background:var(--green);color:white;border-color:var(--green)}button,.button{border:1px solid var(--line);border-radius:999px;padding:calc(8px*var(--density)) calc(12px*var(--density));text-decoration:none;color:var(--ink);background:var(--sand);font-weight:800;cursor:pointer;font:inherit}button:hover,button:focus-visible{border-color:var(--green2);outline:2px solid rgba(47,125,91,.16)}.viewTools button{background:white;color:var(--green);border-color:rgba(255,255,255,.4)}.ghostButton{background:transparent}
.regionBar{position:sticky;top:0;z-index:1100;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;background:rgba(255,250,240,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:10px clamp(12px,3vw,32px)}.regionBarIntro{display:flex;flex-direction:column;gap:2px;min-width:130px}.regionBarIntro span{color:var(--muted);font-size:.82rem}.regionChips{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:8px}.regionChip{background:white;border:1px solid var(--line);border-radius:16px;padding:10px 12px;text-align:left;box-shadow:none}.regionChip strong{display:block;font-size:1rem}.regionChip span{display:block;color:var(--muted);font-size:.82rem}.regionChip.isActive{border-color:var(--green2);background:#edf5ee;box-shadow:inset 0 0 0 1px rgba(47,125,91,.16)}
.tabs{position:relative;z-index:1000;display:flex;gap:6px;padding:7px clamp(12px,3vw,32px);border-bottom:1px solid var(--line);overflow:auto;background:#fbf5e6}.tabs a{color:var(--green);font-weight:800;text-decoration:none;padding:7px 10px;border-radius:999px;white-space:nowrap}.tabs a:hover{background:var(--sand)}
.mapLayout{isolation:isolate;display:grid;grid-template-columns:minmax(238px,280px) minmax(0,1fr);gap:14px;padding:14px clamp(10px,2vw,24px) 20px}.panel{position:relative;z-index:2;display:flex;flex-direction:column;gap:10px}.card,.provider{background:white;border:1px solid var(--line);border-radius:var(--radius);padding:calc(13px*var(--density));box-shadow:var(--shadow)}.card h2{font-size:1.02rem;margin-bottom:6px}.selectedAreaCard select{margin-bottom:8px}details.card{padding:0}details.card>summary{cursor:pointer;list-style:none;padding:calc(13px*var(--density));font-weight:900}details.card>summary::-webkit-details-marker{display:none}details.card[open]>summary{border-bottom:1px solid var(--line)}details.card>*:not(summary){margin-left:calc(13px*var(--density));margin-right:calc(13px*var(--density))}details.card>*:last-child{margin-bottom:calc(13px*var(--density))}
input,select{width:100%;font:inherit;border:1px solid var(--line);border-radius:12px;padding:8px;margin:5px 0 10px;background:white}.check{display:flex;align-items:center;gap:8px}.check input{width:auto;margin:0}.presetGrid{display:grid;grid-template-columns:1fr;gap:8px;margin:10px 0}.weights{display:flex;flex-direction:column;gap:10px}.weightRow label{display:flex;justify-content:space-between;gap:12px;font-size:.86rem}.weightRow input{margin:4px 0}.legend{display:grid;grid-template-columns:14px auto 1fr;gap:8px;align-items:center;margin:7px 0}.dot{width:11px;height:11px;border-radius:50%;display:inline-block}.dot.green{background:var(--green2)}.dot.yellow{background:var(--yellow)}.dot.red{background:var(--red)}.dot.gray{background:var(--gray)}
.content{min-width:0;position:relative;z-index:1}.toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.compactToolbar h2{font-size:1.22rem;margin:0 0 4px}.toolbarActions{display:flex;gap:7px;flex-wrap:wrap}.toolbarActions button{font-size:.9rem}.mapShell{position:relative;z-index:0;contain:layout paint;border:1px solid var(--line);border-radius:var(--radius);background:white;box-shadow:var(--shadow);margin-bottom:12px;overflow:hidden}.mapHead{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-bottom:1px solid var(--line)}.mapHead h3{margin:0 0 3px}.mapStage{position:relative;z-index:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,330px);min-height:420px}.map{position:relative;z-index:0;height:420px;background:#e7e1d2}.map.isHidden{display:none}.mapPreview{border-left:1px solid var(--line);background:#fffdf6;padding:14px;overflow:auto;max-height:420px}.mapPreview h3{font-size:1.1rem;margin-bottom:5px}.previewStatus{display:inline-block;background:#eef5ef;border:1px solid #cddfd1;border-radius:999px;padding:5px 8px;font-weight:850;margin-bottom:8px}.previewTip{background:white;border:1px solid var(--line);border-radius:14px;padding:9px;margin-top:10px}.previewActions{margin-top:10px}.simpleScore{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}.simpleScore span{background:var(--sand);border-radius:999px;padding:5px 8px;font-weight:800;font-size:.84rem}.question{border-left:4px solid var(--yellow);padding:8px 10px;background:#fff8e8;border-radius:10px;margin:7px 0}.question.mini{font-size:.86rem}.resultListHead{display:flex;justify-content:space-between;align-items:flex-start;margin:8px 0 8px}.resultListHead h3{margin-bottom:3px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.compactCards{max-height:none}.provider{display:flex;flex-direction:column;gap:8px}.provider h3{font-size:1rem;margin:0}.meta{color:var(--muted);font-size:.84rem}.badges{display:flex;gap:5px;flex-wrap:wrap}.badge{display:inline-flex;border-radius:999px;background:var(--sand);padding:4px 8px;font-size:.72rem;font-weight:850}.badge.green{background:#d9eee4;color:#174a37}.badge.yellow{background:#faedc7;color:#6f4d00}.badge.red{background:#f2d6d6;color:#7a2525}.badge.warn{background:#efe7d2;color:#5b4a22}.badge.gray{background:#e9ece8;color:#39433e}.scoreRow{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.scoreBox{background:var(--sand);border-radius:14px;padding:8px}.scoreBox span{font-size:.76rem;color:var(--muted)}.scoreBox strong{display:block;font-size:1.05rem}.links{display:flex;gap:8px;flex-wrap:wrap}.links a,.docLinks a{color:var(--green);font-weight:800;text-decoration:none}.links a:hover,.docLinks a:hover{text-decoration:underline}.decisionHint{border-left:4px solid var(--yellow);background:#fff8e8;border-radius:12px;padding:8px 10px}
.section{margin:16px clamp(10px,2vw,24px);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(13px,2vw,20px);box-shadow:var(--shadow)}.quietSection{max-width:1320px}.sectionHead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}h2{font-size:1.22rem}h3{font-size:1.02rem}.methodGrid,.statusGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.compareBox{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}.docLinks{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px}
dialog{border:0;border-radius:22px;max-width:960px;width:min(94vw,960px);box-shadow:0 30px 80px rgba(0,0,0,.25)}#detailContent{padding:10px}.detailGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.detailBox{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:11px}.statusNote{background:#eef5ef;border:1px solid #cddfd1;border-radius:16px;padding:12px;margin:12px 0}footer{padding:20px clamp(14px,3vw,36px);color:var(--muted)}
@media(max-width:1120px){.topHeader{grid-template-columns:1fr}.viewTools{justify-self:start}.regionBar{grid-template-columns:1fr}.regionChips{grid-template-columns:repeat(2,minmax(0,1fr))}.mapLayout{grid-template-columns:1fr}.panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.legendCard,.selectedAreaCard{grid-column:1/-1}.mapStage{grid-template-columns:1fr}.mapPreview{border-left:0;border-top:1px solid var(--line);max-height:none}.map{height:380px}.toolbar{flex-direction:column}}
@media(max-width:680px){html{font-size:var(--font-base)}.topHeader{padding:14px}.brandBlock h1{font-size:1.35rem}.regionChips,.panel,.cards,.scoreRow{grid-template-columns:1fr}.mapLayout{padding:10px;display:block}.panel{position:relative;z-index:2;display:flex;margin-bottom:10px}.map{height:310px}.toolbarActions button{flex:1 1 auto}.mapHead{flex-direction:column}.sectionHead{flex-direction:column}.tabs{font-size:.9rem}.viewTools{align-items:flex-start;flex-direction:column}.regionBar{position:static}.mapPreview{padding:12px}}

.leaflet-container{z-index:0}
.leaflet-pane,.leaflet-top,.leaflet-bottom{z-index:1}
.leaflet-control{z-index:2}
.regionChip span{font-size:.86rem}
.resultListHead{margin-top:14px}
.compactCards .provider:nth-child(n+7){display:none}

.map .leaflet-map-pane,.map .leaflet-tile-pane,.map .leaflet-overlay-pane,.map .leaflet-marker-pane,.map .leaflet-shadow-pane,.map .leaflet-popup-pane{z-index:auto}
.map .leaflet-popup{z-index:3}


/* v50: ruhige Kartenübersicht statt Punktwolke */
.tfCluster{border-radius:999px;display:grid;place-items:center;font-weight:900;color:#1f2b24;border:2px solid rgba(255,255,255,.92);box-shadow:0 6px 18px rgba(20,35,28,.24);background:#efe2bd;}
.tfCluster span{display:grid;place-items:center;width:100%;height:100%;border-radius:999px;font-size:.9rem;line-height:1;}
.tfCluster.hasGood{background:#d7eadb;color:#174a34;border-color:#2f7d5b;}
.tfCluster.mixed{background:#efd79a;color:#4b3a09;border-color:#c58900;}
.tfCluster.fewOnly{background:#dfe3de;color:#39433e;border-color:#73807a;}
.leaflet-popup-content small{display:block;margin-top:4px;color:#58645d;max-width:230px;}
.mapPointHint{max-width:72ch;}
.map .leaflet-marker-icon.tfCluster{z-index:2!important;}

/* v51-v54 refinement */
.provider .hint,.mapPreview p,.statusNote{max-width:72ch}
.detailBox{background:#fffdf7}
.locationHint{font-size:.86rem;color:var(--muted)}
.previewStatus{font-weight:800}


/* v64: Layout-Fix fuer Kartenansicht und rechte Kurzansicht
   - rechte Kurzansicht wird nicht mehr im Kartenkasten abgeschnitten
   - Seite scrollt normal statt interner Mini-Scrollbox
   - horizontales Ueberlaufen wird verhindert
   - Detaildialog ist auch bei langen Inhalten scrollbar
*/
html,body{max-width:100%;overflow-x:hidden}
.mapLayout,.content,.mapShell,.mapStage,.map,.mapPreview{min-width:0}
.mapLayout{width:100%;max-width:100vw}
.mapShell{overflow:visible;contain:layout;border-radius:var(--radius)}
.mapStage{align-items:start;overflow:visible}
.map{overflow:hidden;border-bottom-left-radius:var(--radius)}
.mapPreview{max-height:none;overflow:visible;overflow-wrap:anywhere;word-break:normal;align-self:stretch;border-bottom-right-radius:var(--radius)}
.mapPreview .toolbarActions{position:relative;z-index:3}
.mapPreview .question{break-inside:avoid}
.leaflet-popup{max-width:min(360px,calc(100vw - 36px))}
.leaflet-popup-content{min-width:220px;max-width:min(320px,calc(100vw - 58px));overflow-wrap:anywhere}
.leaflet-popup-content button{margin-top:10px;position:relative;z-index:4;pointer-events:auto}
dialog{max-height:90vh;overflow:auto}
#detailContent{max-height:calc(90vh - 80px);overflow:auto}
@media(min-width:1121px){
  .mapStage{grid-template-columns:minmax(0,1fr) minmax(300px,420px)}
  .map{height:min(58vh,520px);min-height:420px}
}
@media(max-width:1120px){
  .mapShell{overflow:hidden}
  .mapStage{display:block}
  .mapPreview{border-left:0;border-top:1px solid var(--line);border-bottom-left-radius:var(--radius);max-height:none;overflow:visible}
  .map{border-bottom-left-radius:0}
}
@media(max-width:680px){
  .leaflet-popup-content{min-width:190px}
  dialog{width:96vw;max-height:88vh}
  #detailContent{max-height:calc(88vh - 76px)}
}


/* v65-v67 release polish */
.modeHint{margin:-2px 0 10px;padding:9px 10px;border-radius:12px;background:#f6f0df;border:1px solid var(--line);color:var(--muted);font-size:.86rem;line-height:1.35}.modeHint.isWide{background:#fff4dd;border-color:#e4c178;color:#5d4211}.priorityCard[open]>summary{background:#fff8e8;border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.priorityScaleGuide{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin:8px calc(13px*var(--density)) 10px;color:var(--muted);font-size:.72rem}.priorityScaleGuide span{background:#f6f0df;border:1px solid var(--line);border-radius:9px;padding:4px;text-align:center}.prioritySummary{margin:8px calc(13px*var(--density));padding:10px;border-radius:12px;background:#eef5ef;border:1px solid #cbded1;color:var(--deep);font-size:.85rem;line-height:1.35}.prioritySummary span{color:var(--muted)}.weightRow{border-top:1px solid #eee5d3;padding-top:10px}.weightRow:first-child{border-top:0}.weightRow label strong{white-space:nowrap;color:var(--green)}.weightMeaning{display:flex;justify-content:space-between;color:var(--muted);font-size:.72rem;margin-top:-2px}.scoreHelp{margin-top:10px;padding:10px;border-radius:14px;background:#fff8e8;border:1px solid #ead7aa}.scoreHelp p{margin:5px 0 0;color:var(--muted);font-size:.86rem}.scoreExplain{margin:8px 0 0;color:var(--muted);font-size:.85rem}.releaseSection{background:#eef5ef;border-top:1px solid #d1e2d5;border-bottom:1px solid #d1e2d5}.simpleScore span{line-height:1.1}.resultListHead .hint{max-width:780px}#publicStatus option[value="recommended"]{font-weight:800}
@media(max-width:980px){.priorityScaleGuide{grid-template-columns:repeat(3,1fr)}}

/* v71-v73: Angler-/Social-Hinweise als eigene, vorsichtige Hinweisschicht */
.badge.info{background:#e3edf6;color:#234865;border:1px solid #bdd0e3}
.sourceHintBox{margin:10px 0;padding:10px 12px;border-radius:14px;background:#eef5fb;border:1px solid #c8d9e8;color:var(--ink)}
.sourceHintBox>strong{display:block;margin-bottom:4px;color:#234865}
.sourceHintBox p{margin:0 0 6px;color:var(--muted);font-size:.86rem;max-width:72ch}
.sourceHintBox ul{margin:6px 0 0;padding-left:18px}
.sourceHintBox li{margin:5px 0;font-size:.88rem;line-height:1.35}
.sourceHintBox a{color:var(--green);font-weight:800;text-decoration:none}
.sourceHintBox a:hover,.sourceHintBox a:focus{text-decoration:underline}
.hintAge{display:inline-block;margin-left:4px;color:#7a5b1b;font-size:.78rem;font-weight:800}
@media(max-width:680px){.sourceHintBox{padding:9px}.sourceHintBox li{font-size:.86rem}}

/* v74: Social-/Foren-Hinweise optional in die Sortierung einbeziehen */
.sourceRankingControl{margin:10px calc(13px*var(--density));padding:10px 12px;border:1px solid #d5e2d7;border-radius:14px;background:#f5fbf6}
.sourceRankingControl label{margin:0}
.sourceRankingControl select{margin-top:5px}
.sourceRankingControl .hint{margin:6px 0 0}
.opinionSummary{margin-top:10px;padding:10px 12px;border-radius:14px;background:#fffaf0;border:1px solid #ead7aa}
.opinionSummary>strong{display:block;margin-bottom:4px;color:#6b4a08}
.opinionSummary p{margin:0 0 6px;font-size:.88rem;line-height:1.4}
.opinionSummary p:last-child{margin-bottom:0}

/* v75: Mobile-Optimierung und transparente Auswahl für Anbieter mit wenigen öffentlichen Infos */
.evidenceHint{background:#f8f3e6;border-color:#e4d6b9}
.evidenceHint.isWide{background:#fff2d2;border-color:#dbbd70;color:#5b4212}
@media(max-width:780px){
  .topHeader{padding:12px 12px;gap:10px}
  .brandBlock h1{font-size:1.28rem;line-height:1.12}
  .brandBlock p:last-child{font-size:.92rem}
  .viewTools{width:100%;justify-content:space-between;align-items:flex-start}
  .regionBar{position:static;padding:9px 10px;gap:8px}
  .regionChips{display:flex;overflow-x:auto;gap:8px;padding-bottom:4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .regionChip{min-width:155px;scroll-snap-align:start;padding:9px 10px}
  .tabs{position:sticky;top:0;z-index:1050;padding:6px 10px}
  .mapLayout{padding:8px 8px 16px;gap:10px}
  .panel{display:flex;flex-direction:column;gap:9px}
  details.card>summary{padding:12px 13px}
  input,select,button,.button{min-height:42px}
  .toolbarActions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}
  .toolbarActions button{width:100%;padding-left:8px;padding-right:8px}
  .mapHead{padding:9px 10px}
  .map{height:340px}
  .mapPreview{padding:11px}
  .priorityScaleGuide{grid-template-columns:repeat(3,1fr);font-size:.72rem}
  .sourceRankingControl,.prioritySummary{margin:8px calc(10px*var(--density))}
  .simpleScore span{font-size:.8rem}
}
@media(max-width:420px){
  .toolbarActions{grid-template-columns:1fr}
  .map{height:320px}
  .regionChip{min-width:145px}
  .simpleScore span{width:100%}
}

/* v77: v75 beibehalten, linke Steuerung ruhiger gruppieren */
.quickViewCard h2,.priorityCard h2{margin-bottom:4px}
.quickViewGrid{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px}
.quickViewGrid button{display:block;text-align:left;width:100%;border:1px solid var(--line);background:#fffdf7;color:var(--ink);border-radius:14px;padding:10px 12px;box-shadow:none;cursor:pointer}
.quickViewGrid button strong{display:block;color:var(--green);font-size:.95rem;line-height:1.15}
.quickViewGrid button span{display:block;margin-top:3px;color:var(--muted);font-size:.8rem;line-height:1.25}
.quickViewGrid button.isActive{border-color:#9fc9ad;background:#eef7f1;box-shadow:inset 0 0 0 1px #b9dbc4}
.filterDetails>summary,.weightDetails>summary{font-weight:900;color:var(--green)}
.filterDetails>p.hint,.priorityCard>p.hint{margin-bottom:8px}
.priorityCard{display:block}
.priorityCard .prioritySummary{margin:8px 0 10px}
.priorityCard .presetGrid{margin:8px 0 10px}
.weightDetails{border-top:1px solid var(--line);margin-top:10px;padding-top:8px}
.weightDetails>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0}
.weightDetails>summary::-webkit-details-marker{display:none}
.weightDetails>summary::after{content:"öffnen";font-size:.76rem;color:var(--muted);background:#f6f0df;border:1px solid var(--line);border-radius:999px;padding:3px 8px;font-weight:800}
.weightDetails[open]>summary::after{content:"schließen"}
.weightDetails .priorityScaleGuide{margin:8px 0 10px}
.weightDetails .weights{margin-top:6px}
.sourceRankingHint{background:#f3f8fb;border-color:#c8d9e8;color:#234865}
@media(max-width:780px){
  .quickViewGrid{display:flex;overflow-x:auto;gap:8px;padding-bottom:4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .quickViewGrid button{min-width:168px;scroll-snap-align:start;padding:9px 10px}
  .priorityCard .presetGrid{display:flex;overflow-x:auto;gap:8px;padding-bottom:3px;-webkit-overflow-scrolling:touch}
  .priorityCard .presetGrid button{white-space:nowrap;min-width:max-content}
  .weightDetails>summary{min-height:42px}
}

/* v78: Mobile-Karte und Kurzansicht reparieren
   - Kartenpunkte liegen nicht mehr über dem Popup
   - Punkte sind auf Touch-Geräten leichter antippbar
   - ausgewählter Ort ist mobil standardmäßig eingeklappt, damit die Seite kürzer bleibt
*/
.map .leaflet-tile-pane{z-index:200!important}
.map .leaflet-overlay-pane{z-index:400!important}
.map .leaflet-marker-pane{z-index:500!important}
.map .leaflet-shadow-pane{z-index:300!important}
.map .leaflet-popup-pane{z-index:760!important;pointer-events:auto!important}
.map .leaflet-popup{z-index:780!important;pointer-events:auto!important}
.map .leaflet-popup-content-wrapper,.map .leaflet-popup-tip{background:#fff;position:relative;z-index:781;box-shadow:0 14px 36px rgba(20,35,28,.26)}
.map .leaflet-popup-content{position:relative;z-index:782;line-height:1.35}
.map .leaflet-popup-close-button{z-index:783!important;min-width:34px;min-height:34px;display:grid!important;place-items:center}
.map .leaflet-interactive{touch-action:manipulation}
.map .leaflet-popup-content button{min-height:46px;padding:10px 16px;border-radius:999px;font-size:.96rem}
.mobilePreviewDetails{display:block;border:0;background:transparent}
.mobilePreviewDetails>summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;padding:12px 2px}
.mobilePreviewDetails>summary::-webkit-details-marker{display:none}
.mobilePreviewDetails>summary b{display:block;font-size:1rem;line-height:1.18;color:var(--deep)}
.mobilePreviewDetails>summary small{display:block;margin-top:3px;color:var(--muted);font-size:.82rem;line-height:1.25}
.mobilePreviewDetails>summary em{font-style:normal;font-size:.78rem;color:var(--green);font-weight:900;background:#eef5ef;border:1px solid #cbded1;border-radius:999px;padding:5px 9px;white-space:nowrap}
.mobilePreviewDetails[open]>summary em{color:var(--muted);background:#f6f0df;border-color:var(--line)}
.mobilePreviewDetails[open]>summary em::before{content:"schließen"}
.mobilePreviewDetails[open]>summary em{font-size:0}
.mobilePreviewDetails[open]>summary em::before{font-size:.78rem}
.mobilePreviewBody{border-top:1px solid var(--line);padding-top:10px}
@media(max-width:680px){
  .mapShell{overflow:hidden}
  .map{height:min(48vh,340px);min-height:300px}
  .leaflet-popup{max-width:calc(100vw - 44px)!important}
  .leaflet-popup-content{min-width:180px!important;max-width:calc(100vw - 84px)!important}
  .leaflet-popup-content b{font-size:.95rem}
  .mapPreview{padding:10px 14px;background:#fffdf6}
  .mapPreview h3,.mapPreview h4,.mapPreview .simpleScore,.mapPreview .question,.mapPreview .sourceHintBox,.mapPreview .opinionSummary{margin-top:8px}
  .mobilePreviewBody .toolbarActions{grid-template-columns:1fr}
}
@media(pointer:coarse){
  .map .leaflet-control-zoom a{width:42px;height:42px;line-height:42px;font-size:1.35rem}
}


/* v79: Aufklappbare Menüs klar sichtbar machen
   Nutzer sollen sofort erkennen, dass "Suchst du etwas Bestimmtes?"
   und "Was ist dir wichtig?" geöffnet und wieder geschlossen werden können. */
details.card>summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:44px;
  border-radius:var(--radius);
}
details.card>summary::after{
  content:"aufklappen";
  flex:0 0 auto;
  font-size:.76rem;
  line-height:1;
  color:var(--green);
  background:#eef5ef;
  border:1px solid #cbded1;
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
}
details.card[open]>summary::after{
  content:"zuklappen";
  color:var(--muted);
  background:#f6f0df;
  border-color:var(--line);
}
details.card>summary:hover,
details.card>summary:focus-visible{
  background:#fff8e8;
  outline:2px solid rgba(47,125,91,.14);
  outline-offset:2px;
}
details.card[open]>summary{
  border-bottom:1px solid var(--line);
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}
@media(max-width:780px){
  details.card>summary{min-height:48px}
  details.card>summary::after{font-size:.74rem;padding:7px 9px}
}
@media(max-width:380px){
  details.card>summary::after{content:"öffnen"}
  details.card[open]>summary::after{content:"zu"}
}

/* v80: Mobile Leseführung statt endloser Scrollseite
   - ausgewählter Ort bleibt mobil zuerst eine kompakte Karte
   - Trefferliste ist mobil eingeklappt
   - Detaildialog ist in sinnvolle Abschnitte aufgeteilt
*/
.mobileSelectedCompact{background:#fffdf6;border:0;padding:0}
.mobileSelectedCompact h3{margin:2px 0 4px;font-size:1.06rem;line-height:1.18;color:var(--deep)}
.mobileSelectedCompact .hint{margin:6px 0 8px}
.mobileSelectedActions{margin:8px 0 8px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mobileSelectedActions button{min-height:46px}
.mobileResultsDetails{border:0;padding:0;margin:0;background:transparent}
.mobileResultsDetails>summary{display:none}
.detailHero{margin-bottom:10px}
.detailHero h2{margin-bottom:4px;line-height:1.12}
.detailSection{border:1px solid var(--line);border-radius:16px;background:#fffdf6;margin:10px 0;overflow:hidden}
.detailSection>summary{cursor:pointer;list-style:none;padding:12px 14px;font-weight:900;color:var(--green);display:flex;align-items:center;justify-content:space-between;gap:12px}
.detailSection>summary::-webkit-details-marker{display:none}
.detailSection>summary::after{content:"aufklappen";font-size:.76rem;color:var(--green);background:#eef5ef;border:1px solid #cbded1;border-radius:999px;padding:6px 9px;white-space:nowrap}
.detailSection[open]>summary{border-bottom:1px solid var(--line);background:#fff8e8}
.detailSection[open]>summary::after{content:"zuklappen";color:var(--muted);background:#f6f0df;border-color:var(--line)}
.detailSectionBody{padding:12px 14px}
.detailSectionBody>*:last-child{margin-bottom:0}
.detailFootnote{margin:12px 2px 0}
@media(min-width:681px){
  .mobileResultsDetails[open]>.resultListHead,.mobileResultsDetails[open]>.cards{display:grid}
  .mobileResultsDetails>.resultListHead{display:flex}
}
@media(max-width:680px){
  .mapPreview{border-top:1px solid var(--line);max-height:none;overflow:visible}
  .mobileSelectedActions{grid-template-columns:1fr 1fr}
  .mobilePreviewDetails{margin-top:8px;border-top:1px solid var(--line)}
  .mobilePreviewDetails>summary{padding:10px 0 8px}
  .mobilePreviewBody{padding-top:8px}
  .mobileResultsDetails{background:white;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:10px;overflow:hidden}
  .mobileResultsDetails>summary{display:flex;align-items:center;justify-content:space-between;gap:10px;list-style:none;cursor:pointer;padding:12px 14px;font-weight:900;color:var(--green)}
  .mobileResultsDetails>summary::-webkit-details-marker{display:none}
  .mobileResultsDetails>summary strong{display:block;color:var(--green)}
  .mobileResultsDetails>summary small{display:block;color:var(--muted);font-size:.78rem;font-weight:700;margin-top:2px}
  .mobileResultsDetails>summary::after{content:"öffnen";font-size:.78rem;color:var(--green);background:#eef5ef;border:1px solid #cbded1;border-radius:999px;padding:6px 9px}
  .mobileResultsDetails[open]>summary{border-bottom:1px solid var(--line);background:#fff8e8}
  .mobileResultsDetails[open]>summary::after{content:"schließen";color:var(--muted);background:#f6f0df;border-color:var(--line)}
  .mobileResultsDetails .resultListHead{display:none}
  .mobileResultsDetails .cards{padding:10px;grid-template-columns:1fr}
  dialog{width:96vw;max-height:88vh;border-radius:18px;padding:10px}
  #detailContent{padding:4px}
  .detailHero .statusNote{margin:9px 0}
  .detailSection{margin:8px 0;border-radius:14px}
  .detailSection>summary{padding:11px 12px;min-height:46px}
  .detailSection>summary::after{font-size:.72rem;padding:6px 8px}
  .detailSectionBody{padding:11px 12px}
  .detailSectionBody .scoreRow{grid-template-columns:1fr}
  .detailSectionBody .detailGrid{grid-template-columns:1fr}
  .detailHero h2{font-size:1.22rem}
}
@media(max-width:380px){
  .mobileSelectedActions{grid-template-columns:1fr}
  .detailSection>summary::after{content:"öffnen"}
  .detailSection[open]>summary::after{content:"zu"}
}

/* v81: Mobile nicht mehr als endlose Leseseite
   Ziel: erst Region + Karte, danach optionale Filter und Erklärungen.
   Alle Infos bleiben enthalten, werden mobil aber stärker eingeklappt. */
.heroShort{display:none}
.infoAccordion{border-radius:var(--radius)}
.infoAccordion>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:900;color:var(--green);padding:12px 14px}
.infoAccordion>summary::-webkit-details-marker{display:none}
.infoAccordion>summary::after{content:"öffnen";font-size:.78rem;color:var(--green);background:#eef5ef;border:1px solid #cbded1;border-radius:999px;padding:6px 10px;white-space:nowrap}
.infoAccordion[open]>summary{border-bottom:1px solid var(--line);background:#fff8e8}
.infoAccordion[open]>summary::after{content:"schließen";color:var(--muted);background:#f6f0df;border-color:var(--line)}
.infoAccordion .accordionBody{padding:10px 14px 14px}
.legendCard.infoAccordion .accordionBody{padding-top:4px}

@media(max-width:780px){
  body{background:#fbf7ef}
  .skipLink{display:none}
  .heroLong{display:none}
  .heroShort{display:block;margin:6px 0 0;font-size:.92rem;line-height:1.35;color:#e8f3ed}
  .topHeader{padding:10px 12px 12px;gap:8px;display:grid;grid-template-columns:1fr;background:#14543b}
  .brandBlock .eyebrow{font-size:.68rem;letter-spacing:.08em;margin-bottom:4px}
  .brandBlock h1{font-size:1.22rem;line-height:1.12;margin:0;max-width:18rem}
  .viewTools{margin-top:4px;width:100%;border-radius:16px;padding:7px 8px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22)}
  .viewTools strong{font-size:.82rem;white-space:nowrap}
  .segmented{gap:5px;display:flex;overflow-x:auto;padding-bottom:1px}
  .segmented button{min-height:34px;padding:6px 10px;font-size:.84rem;border-radius:999px;white-space:nowrap}

  .regionBar{position:sticky;top:0;z-index:1025;padding:8px 10px 7px;background:#fffaf0;border-bottom:1px solid var(--line)}
  .regionBarIntro{display:none}
  .regionChips{gap:8px;padding-bottom:2px}
  .regionChip{min-width:138px;padding:8px 10px;border-radius:18px}
  .regionChip strong{font-size:.92rem;line-height:1.1}
  .regionChip span{font-size:.78rem;line-height:1.15;margin-top:3px}

  .tabs{display:none}

  .mapLayout{display:flex;flex-direction:column;padding:8px 8px 16px;gap:10px}
  .content{order:1;min-width:0}
  .panel{order:2;min-width:0;gap:8px}
  .selectedAreaCard{display:none}

  .compactToolbar{padding:10px 12px;gap:8px;border-radius:18px;margin-bottom:8px;background:#fffdf6;box-shadow:var(--shadow)}
  .compactToolbar .eyebrow{font-size:.68rem;margin-bottom:2px}
  .compactToolbar h2{font-size:1.1rem;line-height:1.15;margin:0}
  .compactToolbar .hint{font-size:.78rem;line-height:1.3;margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .toolbarActions{display:flex!important;overflow-x:auto;gap:7px;width:100%;padding-bottom:3px;-webkit-overflow-scrolling:touch}
  .toolbarActions button{flex:0 0 auto;width:auto;min-height:36px;border-radius:999px;padding:7px 12px;font-size:.82rem;white-space:nowrap}

  .mapShell{border-radius:18px;box-shadow:var(--shadow);background:white;overflow:hidden}
  .mapHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;background:#fffdf6;border-bottom:1px solid var(--line)}
  .mapHead h3{font-size:1rem;margin:0}
  .mapHead .hint{display:none}
  #mapToggle{min-height:36px;padding:7px 12px;font-size:.84rem;border-radius:999px;white-space:nowrap}
  .map{height:min(54vh,390px);min-height:330px}
  .mapPreview{padding:10px 12px;background:#fffdf6;border-top:1px solid var(--line)}
  .mapPreview>.eyebrow{font-size:.68rem;margin-bottom:2px}
  .mapPreview h3{font-size:1.02rem;line-height:1.15;margin:0 0 4px}
  .mapPreview .hint{font-size:.84rem;line-height:1.35;margin:4px 0}
  .previewTip{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:.82rem;border:1px solid var(--line);border-radius:999px;padding:7px 10px;background:#fff;margin-top:8px}

  details.card{border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
  details.card>summary{padding:12px 14px;min-height:48px;font-size:.98rem;background:#fff}
  details.card>summary::after{content:"öffnen";font-size:.74rem;padding:7px 10px}
  details.card[open]>summary::after{content:"schließen"}
  .filterDetails,.weightDetails{margin:0;padding:0;border-top:0}
  .quickViewGrid button{min-width:152px}
  .priorityCard>p.hint,.filterDetails>p.hint,.priorityScaleGuide,.prioritySummary,.sourceRankingControl{font-size:.78rem}
  .priorityScaleGuide{grid-template-columns:repeat(3,1fr)}

  .legendCard{display:block}
  .legendCard .legend{grid-template-columns:auto 1fr;gap:8px 10px;align-items:start;margin:7px 0}
  .legendCard .legend span:last-child{grid-column:2;line-height:1.25;font-size:.82rem}
  .scoreHelp{padding:9px 10px;border-radius:12px}
  .scoreHelp p{font-size:.8rem;line-height:1.35}

  .mobileResultsDetails{margin-top:8px}
  .mobileResultsDetails>summary{padding:12px 14px}

  .section{padding:10px 8px;margin:0;background:transparent;border:0}
  .sectionHead{display:none}
  #compare .compareBox{border-radius:18px;background:white;border:1px solid var(--line);box-shadow:var(--shadow);padding:14px;margin:8px 0}
  #compare h2{font-size:1.15rem;margin:0 0 6px}
  .infoSection{padding-top:8px}
  .infoSection .infoAccordion{background:white;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;overflow:hidden}
  .infoSection .methodGrid{grid-template-columns:1fr;gap:8px;padding:10px}
  .infoSection .methodGrid .card{box-shadow:none;border-radius:14px;padding:12px}
  .infoSection .methodGrid .card h3{font-size:1rem;margin-bottom:5px}
  .infoSection .methodGrid .card p{font-size:.9rem;line-height:1.35}
}

@media(max-width:420px){
  .brandBlock h1{font-size:1.14rem;max-width:16rem}
  .heroShort{font-size:.86rem}
  .viewTools strong{font-size:.78rem}
  .segmented button{font-size:.8rem;padding:6px 9px}
  .regionChip{min-width:128px;padding:7px 9px}
  .compactToolbar .hint{display:none}
  .map{height:min(52vh,360px);min-height:315px}
}


/* v82: Mobile Kopf und Auswahl beruhigen
   - Kopf deutlich kleiner
   - Textgröße als einklappbares Menü
   - aktive Textgröße eindeutig markiert
   - doppelte Region-Auswahl und unwichtige Hinweise mobil ausblenden
*/
.heroLong{display:none!important}
.fontMenu{position:relative;display:block;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.20);border-radius:16px;padding:0;color:white;min-width:190px}
.fontMenu>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;font-weight:900}
.fontMenu>summary::-webkit-details-marker{display:none}
.fontMenu>summary span{font-size:.86rem;opacity:.95}
.fontMenu>summary strong{font-size:.78rem;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.20);border-radius:999px;padding:4px 8px;white-space:nowrap}
.fontMenu .segmented{padding:0 10px 10px;display:flex;gap:8px;flex-wrap:wrap}
.fontMenu .segmented button{background:rgba(255,255,255,.12);color:white;border-color:rgba(255,255,255,.35);box-shadow:none}
.fontMenu .segmented button.isActive{background:#fff;color:var(--green);border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.22)}
.fontMenu .segmented button.isActive::before{content:"✓ ";font-weight:900}
.fontMenu:not([open]) .segmented{display:none}
.fontMenu[open]>summary{border-bottom:1px solid rgba(255,255,255,.16)}
.selectedAreaCard{display:none!important}

@media(max-width:900px){
  .skipLink{display:none}
  .topHeader{padding:8px 12px 9px!important;gap:6px!important;display:grid!important;grid-template-columns:1fr!important;background:#14543b!important}
  .brandBlock .eyebrow{font-size:.58rem!important;letter-spacing:.07em;margin-bottom:3px!important}
  .brandBlock h1{font-size:1.02rem!important;line-height:1.08!important;margin:0!important;max-width:18rem!important}
  .heroShort{display:block!important;margin:4px 0 0!important;font-size:.76rem!important;line-height:1.25!important;color:#dcebe4!important;opacity:.92!important}
  .viewTools.fontMenu{margin-top:5px!important;width:100%!important;border-radius:14px!important;background:rgba(255,255,255,.09)!important}
  .fontMenu>summary{min-height:38px;padding:7px 9px!important}
  .fontMenu>summary span{font-size:.78rem!important}
  .fontMenu>summary strong{font-size:.72rem!important;padding:4px 7px!important}
  .fontMenu .segmented{padding:0 8px 8px!important;gap:7px!important;overflow-x:auto;flex-wrap:nowrap}
  .fontMenu .segmented button{min-height:34px!important;font-size:.78rem!important;padding:6px 10px!important;white-space:nowrap!important}

  .regionBar{position:sticky!important;top:0!important;z-index:1025!important;padding:7px 10px!important;background:#fffaf0!important;border-bottom:1px solid var(--line)!important;display:block!important}
  .regionBarIntro{display:none!important}
  .regionChips{display:flex!important;gap:8px!important;overflow-x:auto!important;padding-bottom:2px!important;-webkit-overflow-scrolling:touch!important}
  .regionChip{flex:0 0 auto;min-width:138px!important;padding:8px 10px!important;border-radius:18px!important}
  .regionChip strong{font-size:.9rem!important;line-height:1.1!important}
  .regionChip span{font-size:.76rem!important;line-height:1.15!important;margin-top:3px!important}
  .tabs{display:none!important}

  .mapLayout{display:flex!important;flex-direction:column!important;padding:8px 8px 16px!important;gap:10px!important}
  .content{order:1!important;min-width:0!important}
  .panel{order:2!important;min-width:0!important;gap:8px!important;display:flex!important;flex-direction:column!important}
  .compactToolbar{padding:9px 11px!important;gap:7px!important;border-radius:18px!important;margin-bottom:8px!important;background:#fffdf6!important;box-shadow:var(--shadow)!important}
  .compactToolbar .eyebrow{font-size:.64rem!important;margin-bottom:2px!important}
  .compactToolbar h2{font-size:1.02rem!important;line-height:1.12!important;margin:0!important}
  .compactToolbar .hint{display:none!important}
  .toolbarActions{display:flex!important;overflow-x:auto!important;gap:7px!important;width:100%!important;padding-bottom:3px!important;-webkit-overflow-scrolling:touch!important}
  .toolbarActions button{flex:0 0 auto!important;width:auto!important;min-height:36px!important;border-radius:999px!important;padding:7px 12px!important;font-size:.8rem!important;white-space:nowrap!important}
  .mapShell{border-radius:18px!important;box-shadow:var(--shadow)!important;background:white!important;overflow:hidden!important}
  .mapHead{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:10px!important;padding:8px 10px!important;background:#fffdf6!important;border-bottom:1px solid var(--line)!important}
  .mapHead h3{font-size:.98rem!important;margin:0!important}
  .mapHead .hint{display:none!important}
  #mapToggle{min-height:34px!important;padding:6px 11px!important;font-size:.8rem!important;border-radius:999px!important;white-space:nowrap!important}
  .map{height:min(56vh,390px)!important;min-height:330px!important}
  .mapPreview{padding:9px 11px!important;background:#fffdf6!important;border-top:1px solid var(--line)!important}
  .mapPreview>.eyebrow{font-size:.64rem!important;margin-bottom:2px!important}
  .mapPreview h3{font-size:1rem!important;line-height:1.15!important;margin:0 0 4px!important}
  .mapPreview .hint{font-size:.82rem!important;line-height:1.32!important;margin:4px 0!important}
  details.card{border-radius:18px!important;box-shadow:var(--shadow)!important;overflow:hidden!important}
  details.card>summary{padding:11px 13px!important;min-height:46px!important;font-size:.94rem!important;background:#fff!important}
  .legendCard{display:none!important}
  .infoSection{padding-top:8px!important}
  .infoSection .infoAccordion{background:white!important;border:1px solid var(--line)!important;box-shadow:var(--shadow)!important;border-radius:18px!important;overflow:hidden!important}
}
@media(max-width:430px){
  .brandBlock h1{font-size:.98rem!important;max-width:17rem!important}
  .heroShort{font-size:.73rem!important}
  .map{height:min(54vh,360px)!important;min-height:315px!important}
  .regionChip{min-width:128px!important}
}

/* v89: Footer/Recht heller, kontrastreicher und standardmäßig eingeklappt */
.siteFooter{
  margin-top:18px;
  background:var(--cream);
  color:var(--ink);
  border-top:1px solid var(--line);
  padding:18px clamp(12px,3vw,32px) 28px;
  display:grid;
  gap:12px;
}
.siteFooter .footerDetails{
  background:#ffffff;
  color:var(--ink);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.siteFooter .footerDetails>summary{
  list-style:none;
  cursor:pointer;
  padding:13px 15px;
  font-weight:900;
  color:var(--green);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#fffdf6;
}
.siteFooter .footerDetails>summary::-webkit-details-marker{display:none}
.siteFooter .footerDetails>summary::after{
  content:"öffnen";
  font-size:.76rem;
  background:#eef5ef;
  border:1px solid #cbded1;
  border-radius:999px;
  padding:6px 10px;
  color:var(--green);
  white-space:nowrap;
}
.siteFooter .footerDetails[open]>summary{
  border-bottom:1px solid var(--line);
  background:#f7f0df;
}
.siteFooter .footerDetails[open]>summary::after{content:"schließen";color:var(--muted);background:#fffaf0;border-color:var(--line)}
.siteFooter .legalText{padding:14px 16px 16px;max-width:98ch;color:var(--ink);font-size:.94rem;line-height:1.58}
.siteFooter .legalText>*:first-child{margin-top:0}
.siteFooter .legalText>*:last-child{margin-bottom:0}
.siteFooter p{margin:.45rem 0 .82rem;color:var(--ink);max-width:92ch}
.siteFooter h3{font-size:1rem;margin:1rem 0 .3rem;color:var(--green)}
.siteFooter code{background:#f2ead8;border:1px solid var(--line);border-radius:7px;padding:1px 5px;color:var(--ink)}
.siteFooter .statusGrid{margin:14px 16px 0;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.siteFooter .statusGrid .card{box-shadow:none;background:#fffaf0;color:var(--ink)}
.siteFooter .statusGrid .hint{color:#46534d}
.siteFooter .docLinks{margin:12px 0 0;display:flex;gap:8px;flex-wrap:wrap}
.siteFooter .docLinks a{color:var(--green);background:#eef5ef;border:1px solid #cbded1;border-radius:999px;padding:7px 10px;text-decoration:none;font-weight:850;font-size:.84rem}
.siteFooter .docLinks a:hover,.siteFooter .docLinks a:focus-visible{background:#dcebe4;outline:2px solid rgba(47,125,91,.18);text-decoration:none}
.siteFooter .legalLinks a{background:#fffaf0}
.impressumAddress{font-style:normal;margin:8px 0 10px;color:var(--ink);line-height:1.52}
.impressumContact{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.mailProtected a{color:var(--green);text-decoration:underline;text-underline-offset:3px;font-weight:850}
.footerMiniButton{border:1px solid #cbded1;background:#eef5ef;color:var(--green);border-radius:999px;padding:7px 11px;font-weight:850;cursor:pointer}
.footerMiniButton:hover,.footerMiniButton:focus-visible{background:#dcebe4;outline:2px solid rgba(47,125,91,.18)}
.smallLegalNote{font-size:.84rem;color:#53615a}
@media(max-width:900px){
  .siteFooter{margin-top:10px;padding:12px 8px 22px;gap:9px}
  .siteFooter .footerDetails{border-radius:16px}
  .siteFooter .footerDetails>summary{padding:12px 13px;font-size:.98rem;min-height:46px}
  .siteFooter .legalText{padding:13px 13px 15px;font-size:.93rem;line-height:1.55}
  .siteFooter p{font-size:.93rem;line-height:1.55;margin:.45rem 0 .78rem}
  .siteFooter h3{font-size:.98rem;margin:.95rem 0 .25rem}
  .siteFooter .statusGrid{grid-template-columns:1fr;margin:12px 13px 0}
  .siteFooter .docLinks{max-height:42vh;overflow:auto}
  .siteFooter .docLinks a{font-size:.82rem}
}

/* v89: Desktop-Filter startet eingeklappt; mobile Filter bleiben erreichbar */
.panelCollapseAction{background:#eef5ef;color:var(--green);border-color:#cbded1}
.mapLayout.panelCollapsed{grid-template-columns:minmax(0,1fr)}
.mapLayout.panelCollapsed .panel{display:none}
.mapLayout.panelCollapsed .content{grid-column:1/-1}
@media(max-width:900px){
  .panelCollapseAction{display:none!important}
  .mapLayout.panelCollapsed .panel{display:flex!important}
}


/* v89: bessere Lesbarkeit fuer Allgemeine Hinweise/Datenschutz/Impressum */
.siteFooter .legalReadable{background:#fff!important;border-color:#cfc6b3!important}
.siteFooter .legalReadable>summary{background:#ffffff!important;color:#163f31!important;border-bottom:0;font-size:1rem}
.siteFooter .legalReadable[open]>summary{background:#f3ead8!important;border-bottom:1px solid #cfc6b3!important}
.siteFooter .legalText{background:#ffffff!important;color:#17231d!important;font-size:1rem;line-height:1.68}
.siteFooter .legalText p,.siteFooter .legalText li,.siteFooter .legalText address{color:#17231d!important}
.siteFooter .legalText h3{color:#163f31!important}
.siteFooter .legalText a{color:#174f3a!important;text-decoration:underline;text-underline-offset:3px}
.siteFooter .statusGrid .card{background:#ffffff!important;border-color:#d8cfbc!important}
.siteFooter .statusGrid .hint{color:#30423a!important}
.smallLegalNote{color:#3c4a43!important}


/* v90: sichtbarer HaliNor-Hinweis und kontaktfreundliches Impressum ohne sichtbare Klartext-Mail */
.appPromoBanner{
  margin:14px clamp(10px,2vw,24px) 0;
  padding:16px clamp(14px,2vw,22px);
  border:1px solid #cfe0d3;
  border-radius:22px;
  background:linear-gradient(135deg,#f5fff8 0%,#eef7f0 52%,#fff8e8 100%);
  box-shadow:var(--shadow);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.appPromoText{max-width:850px}
.appPromoText h2{margin:.12rem 0 .25rem;font-size:clamp(1.15rem,2.2vw,1.7rem);color:#123f2f}
.appPromoText p{margin:0;color:#263d34;line-height:1.45}
.promoKicker{margin:0 0 .2rem!important;font-size:.8rem!important;font-weight:900!important;text-transform:uppercase;letter-spacing:.08em;color:#1e6a47!important}
.promoButton{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:11px 15px;
  border-radius:999px;
  background:#0e5f3d;
  color:#fff!important;
  text-decoration:none!important;
  font-weight:900;
  box-shadow:0 10px 22px rgba(14,95,61,.18);
}
.promoButton:hover,.promoButton:focus-visible{background:#09492f}
.impressumContactActions{display:flex;flex-wrap:wrap;gap:8px;margin:.35rem 0 .65rem}
.mailProtected{display:inline-block;margin-left:.25rem;color:#33443c!important;font-weight:800}

.appPromoBanner .mapSearchBar,
.appPromoBanner .materialSearchBar,
.appPromoBanner .searchFieldWrap,
.appPromoBanner input[type="search"],
.appPromoBanner label[for="search"],
.appPromoBanner #inlineFilterButton{display:none!important}

@media(max-width:760px){
  .appPromoBanner{display:block;margin-top:10px;padding:14px}
  .promoButton{width:100%;margin-top:12px;text-align:center}
}


/* v96: Ortssuche direkt ueber der Karte und Live-Filter klar erklaert */
.mapSearchBar{
  margin:0 0 10px;
  padding:12px 14px;
  border:1px solid #cbded1;
  border-radius:18px;
  background:#f5fbf6;
  box-shadow:var(--shadow);
}
.mapSearchBar label{
  display:block;
  margin:0 0 6px;
  color:#123f2f;
  font-size:1rem;
  font-weight:900;
}
.mapSearchBar input{
  margin:0;
  min-height:44px;
  border-color:#b9d3c1;
  background:#ffffff;
  font-size:1rem;
}
.mapSearchBar p{
  margin:7px 0 0;
  color:#30423a;
  font-size:.9rem;
  line-height:1.4;
}
@media(max-width:900px){
  .mapSearchBar{margin-bottom:8px;padding:11px 12px;border-radius:18px}
  .mapSearchBar label{font-size:.96rem}
  .mapSearchBar input{min-height:42px;font-size:.95rem}
  .mapSearchBar p{font-size:.84rem;line-height:1.35}
}

/* v96: Material-3-artige Filter-Sheet-UX, schnelle Orientierung, wenig Menuepunkte */
.quickExplain{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:14px clamp(10px,2vw,24px) 0;
}
.quickExplain div{
  background:linear-gradient(180deg,#ffffff,#f6fbf7);
  border:1px solid #d6e3da;
  border-radius:22px;
  padding:13px 14px;
  box-shadow:0 10px 28px rgba(31,42,36,.08);
}
.quickExplain strong{display:block;color:#123f2f;font-size:1rem;margin-bottom:3px}
.quickExplain span{display:block;color:#506159;font-size:.9rem}
.filterSheetLayout{grid-template-columns:minmax(0,1fr)}
.filterDialog{
  width:min(720px,100vw);
  max-width:100vw;
  height:min(92vh,780px);
  max-height:92vh;
  padding:0;
  border:0;
  border-radius:28px;
  overflow:hidden;
  background:#fbfdf9;
  box-shadow:0 28px 80px rgba(0,0,0,.32);
}
.filterDialog::backdrop{background:rgba(12,24,18,.44);backdrop-filter:blur(3px)}
.filterHeader{
  position:sticky;
  top:0;
  z-index:3;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:8px;
  min-height:64px;
  padding:12px 18px;
  background:#0d4f36;
  color:white;
}
.filterHeader h2{margin:0;font-size:1.25rem;color:white}
.iconButton,.textButton{background:transparent;border:0;color:white;box-shadow:none}
.iconButton{font-size:1.45rem;padding:8px 10px;border-radius:999px}
.textButton{font-weight:900;padding:8px 10px}
.filterLiveBox{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  padding:14px 20px;
  background:#eef8ef;
  border-bottom:1px solid #d7e5dc;
}
.filterLiveBox strong{font-size:1.15rem;color:#123f2f}
.filterLiveBox span{color:#45574f;font-size:.9rem;text-align:right}
.filterBody{padding:16px 20px 92px;overflow:auto;height:calc(100% - 64px - 62px)}
.filterGroup{
  background:white;
  border:1px solid #dce6df;
  border-radius:22px;
  padding:16px;
  margin-bottom:14px;
  box-shadow:0 8px 22px rgba(31,42,36,.06);
}
.filterGroup h3{font-size:1.04rem;margin:0 0 10px;color:#17251e}
.filterRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:center;
  min-height:54px;
  border-top:1px solid #edf2ee;
  font-size:1rem;
}
.filterRow:first-of-type{border-top:0}
.filterRow span{padding:10px 0;color:#23312b}
.filterRow input{width:28px;height:28px;margin:0;accent-color:#0d6b49}
.filterSelect select{margin-top:8px;min-height:48px;border-radius:16px}
.filterHint{color:#5a6a62;font-size:.9rem;margin:0 0 10px}
.materialPresetGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.materialPresetGrid button{border-radius:18px;background:#f0f7f1;border-color:#cfe1d5;min-height:44px;text-align:left}
.advancedFilter>summary{cursor:pointer;font-weight:900;color:#0d4f36;list-style:none}
.advancedFilter>summary::-webkit-details-marker{display:none}
.filterFooter{
  position:sticky;
  bottom:0;
  z-index:4;
  padding:14px 18px calc(14px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(251,253,249,.78),#fbfdf9 28%);
  border-top:1px solid #dce6df;
}
.primaryButton{
  width:100%;
  min-height:54px;
  border-radius:16px;
  border:0;
  background:#0d6b49;
  color:white;
  font-size:1.05rem;
  box-shadow:0 10px 24px rgba(13,107,73,.24);
}
.materialSearchBar{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  background:#f7fbf7;
  border:1px solid #cfe1d5;
  border-radius:24px;
  padding:12px;
}
.searchIcon{
  width:42px;height:42px;border-radius:999px;
  display:grid;place-items:center;
  background:#e8f4ea;color:#0d4f36;font-size:1.4rem;font-weight:900;
}
.searchFieldWrap label{font-size:.84rem;margin:0;color:#4f6454}
.searchFieldWrap input{
  width:100%;
  border:1px solid #cfe1d5;
  border-radius:16px;
  background:#fcfdfa;
  margin:0;
  padding:12px 14px;
  font-size:1.05rem;
  color:var(--ink);
}
.searchFieldWrap input::placeholder{color:#758173;opacity:1}
.searchFieldWrap p{margin:8px 0 0;font-size:.84rem;color:#52645b;line-height:1.4}
.filterOpenButton{background:#0d6b49!important;color:white!important;border:0!important;box-shadow:0 8px 18px rgba(13,107,73,.22)}
.quickSortChips{display:flex;gap:8px;overflow:auto;margin:0 0 8px;padding:10px 8px 8px;background:#f7fbf7;border:1px solid #dce8de;border-radius:22px;-webkit-overflow-scrolling:touch}
.quickSortChips button{flex:0 0 auto;background:#eef6ef;border:1px solid #cde0d2;color:#123f2f;border-radius:18px;min-height:40px;padding:9px 12px;font-weight:900;transition:background .18s,color .18s,border-color .18s}
.quickSortChips button#sortConfidence{background:#eef6ef;border-color:#cde0d2;color:#123f2f}
.quickSortChips button:hover,.quickSortChips button:focus-visible{background:#e8f2e8;color:#0f352b;border-color:#9fc9ad;outline:none}
.quickSortChips button:active{background:#dfece1;color:#0f352b;border-color:#8cbf9e}
.quickSortChips button.isActive{background:#e7f1e7;color:#143a29;border-color:#9fc9ad;box-shadow:inset 0 0 0 1px rgba(31,125,87,.14)}
@media(max-width:760px){
  .quickExplain{grid-template-columns:1fr;margin-top:10px;gap:8px}
  .quickExplain div{padding:11px 12px;border-radius:18px}
  .regionBarIntro span{display:none}
  .regionChips{display:flex;overflow:auto;-webkit-overflow-scrolling:touch}
  .regionChip{min-width:155px}
  .filterDialog{width:100vw;height:100dvh;max-height:100dvh;border-radius:0}
  .filterHeader{min-height:62px;padding:10px 16px;background:#0b4a92}
  .filterBody{height:calc(100dvh - 62px - 64px);padding:14px 16px 96px}
  .filterLiveBox{padding:12px 16px;align-items:flex-start;flex-direction:column;gap:3px}
  .filterLiveBox span{text-align:left}
  .filterGroup{border-radius:20px;padding:14px;margin-bottom:12px}
  .filterRow{min-height:62px;font-size:1.02rem}
  .materialPresetGrid{grid-template-columns:1fr}
  .materialSearchBar{grid-template-columns:auto minmax(0,1fr);gap:10px;border-radius:20px}
  .materialSearchBar .filterOpenButton{grid-column:1/-1;width:100%;min-height:44px}
  .quickSortChips{margin-bottom:6px;gap:6px}
  .topMapActions{display:none!important}
}


/* v96: klare Vorpruefung statt Buchungsseite, einfache Kontrollkaestchen */
.topHeader{
  background:radial-gradient(circle at 10% 10%,rgba(255,255,255,.22),transparent 28%),linear-gradient(135deg,#063b33,#0b6b49 58%,#0a4f8f);
  color:#fff;
}
.brandBlock h1{max-width:900px;letter-spacing:-.035em}
.heroShort{max-width:940px;font-size:clamp(1rem,1.9vw,1.28rem);line-height:1.45;color:rgba(255,255,255,.92)}
.heroShort strong{color:#fff}
.heroProofChips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.heroProofChips span{border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.13);color:#fff;border-radius:999px;padding:8px 12px;font-weight:850;font-size:.92rem}
.purposePanel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;margin:14px clamp(10px,2vw,24px) 0;padding:18px;border:1px solid #cfe0d4;border-radius:28px;background:linear-gradient(135deg,#ffffff,#eef9f1);box-shadow:0 14px 36px rgba(31,42,36,.1)}
.purposePanel h2{margin:.15rem 0 .35rem;color:#10251d;font-size:clamp(1.35rem,2.6vw,2.2rem);letter-spacing:-.025em}
.purposePanel p:not(.eyebrow){max-width:880px;color:#33443c;font-size:1.03rem;line-height:1.52;margin:0}
.startButton{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 18px;border-radius:18px;background:#0d6b49;color:white;text-decoration:none;font-weight:950;box-shadow:0 12px 26px rgba(13,107,73,.22);white-space:nowrap}
.quickExplain div{position:relative;overflow:hidden}
.quickExplain div::before{content:"";position:absolute;inset:auto 14px 0 14px;height:3px;background:#0d6b49;border-radius:999px}
.filterIntroGroup{background:linear-gradient(180deg,#ffffff,#f4fbf6)}
.simplePrioritySummary{margin-top:10px;padding:10px 12px;border-radius:16px;background:#f2f7f3;color:#33443c;font-size:.9rem;line-height:1.35}
.availableGroup .filterRow span{font-weight:760}
.compactRegionGroup{margin-bottom:4px}
.filterLiveBox{background:linear-gradient(90deg,#eaf8ed,#eef7ff)}
.mapSearchBar{border-color:#bfd8c7;box-shadow:0 10px 28px rgba(31,42,36,.1)}
.searchFieldWrap p{font-weight:760;color:#2c4639}
.quickSortChips button{font-weight:900}
#resultTitle::after{content:" · keine Buchung";font-size:.72em;color:#5a6a62;font-weight:800}
.mapPreview .previewTip{line-height:1.65}
@media(max-width:760px){
  .purposePanel{grid-template-columns:1fr;padding:14px;border-radius:22px;gap:12px}
  .startButton{width:100%}
  .heroProofChips span{font-size:.84rem;padding:7px 10px}
  .filterHeader{background:#0d6b49}
  .quickExplain div::before{left:12px;right:12px}
}

/* v96: klare Vorpruefung statt Buchungsseite, einfache Kontrollkaestchen statt Schieberegler */
.purposePanel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;margin:0 0 14px;padding:18px;border:1px solid #d7e8dc;background:linear-gradient(135deg,#ffffff,#eef8f1);border-radius:28px;box-shadow:0 14px 34px rgba(31,42,36,.09)}
.purposePanel h2{margin:.1rem 0 .35rem;font-size:clamp(1.4rem,3.5vw,2.2rem);color:#0b3d2a}
.purposePanel p:not(.eyebrow){font-size:1.03rem;line-height:1.52;margin:0}
.startButton{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 18px;border-radius:18px;background:#0d6b49;color:white;text-decoration:none;font-weight:950;box-shadow:0 12px 26px rgba(13,107,73,.22);white-space:nowrap}
.quickExplain div{position:relative;overflow:hidden}
.quickExplain div::before{content:"";position:absolute;inset:auto 14px 0 14px;height:3px;background:#0d6b49;border-radius:999px}
.filterIntroGroup{background:linear-gradient(180deg,#ffffff,#f4fbf6)}
.needCheckList{display:grid;grid-template-columns:1fr;gap:8px}
.priorityRow{min-height:54px;border-color:#cfe0d4;background:#fbfdfb;box-shadow:0 6px 14px rgba(31,42,36,.04)}
.priorityRow span{font-weight:850;color:#1f3028}
.priorityRow input[type="checkbox"],.filterRow input[type="checkbox"]{width:28px;height:28px;accent-color:#0d6b49;flex:0 0 auto}
.priorityRow:has(input:checked){background:#eef8f1;border-color:#0d6b49;box-shadow:0 8px 20px rgba(13,107,73,.12)}
.priorityRow:has(input:checked) span{color:#0b3d2a}
.simplePrioritySummary{margin-top:10px;padding:10px 12px;border-radius:16px;background:#f2f7f3;color:#33443c;font-size:.9rem;line-height:1.35}
.availableGroup .filterRow span{font-weight:760}
.compactRegionGroup{margin-bottom:4px}
.filterLiveBox{background:linear-gradient(90deg,#eaf8ed,#eef7ff)}
.mapSearchBar{border-color:#bfd8c7;box-shadow:0 10px 28px rgba(31,42,36,.1)}
.searchFieldWrap p{font-weight:760;color:#2c4639}
.quickSortChips button{font-weight:900}
#resultTitle::after{content:" · keine Buchung";font-size:.72em;color:#5a6a62;font-weight:800}
.mapPreview .previewTip{line-height:1.65}
@media(max-width:760px){
  .purposePanel{grid-template-columns:1fr;padding:14px;border-radius:22px;gap:12px}
  .startButton{width:100%}
  .heroProofChips span{font-size:.84rem;padding:7px 10px}
  .priorityRow{min-height:58px}
  .filterHeader{background:#0d6b49}
  .quickExplain div::before{left:12px;right:12px}
}


/* v96: mobil nur ein Suchfeld, direkt ueber der Karte. Veraltete/zweite Suchfelder unter der Karte werden ausgeblendet. */
.primaryMapSearch{order:0}
.mapShell{order:2}
.quickSortChips{order:1}
@media(max-width:760px){
  #resultsView{display:flex;flex-direction:column}
  .primaryMapSearch{order:0!important;margin-bottom:8px!important}
  .quickSortChips{order:1!important}
  .mapShell{order:2!important}
  .mobileResultsDetails{order:3!important}
  .mapShell ~ .mapSearchBar,
  .mapShell ~ .materialSearchBar,
  .mobileResultsDetails .mapSearchBar,
  .mobileResultsDetails .materialSearchBar,
  .mapPreview .mapSearchBar,
  .mapPreview .materialSearchBar,
  .cards input[type="search"],
  .mapPreview input[type="search"]{display:none!important}
}


/* v96: Agentur-UX-Schnitt – schneller Zweck, Karte frueher, Filter einfacher */
.agencyHero{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  padding-top:clamp(14px,2.4vw,28px);
  padding-bottom:clamp(14px,2.4vw,26px);
}
.agencyHero .brandBlock h1{
  font-size:clamp(1.65rem,4.2vw,3.45rem);
  line-height:.98;
  max-width:980px;
  margin-bottom:10px;
}
.agencyHero .heroShort{
  max-width:880px;
  font-size:clamp(1.02rem,1.8vw,1.28rem);
  margin:0;
}
.heroActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;align-items:center}
.heroPrimary,.heroSecondary{
  display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 17px;border-radius:16px;font-weight:950;text-decoration:none;cursor:pointer;font:inherit;
}
.heroPrimary{background:#fff;color:#0b4f36;border:1px solid rgba(255,255,255,.76);box-shadow:0 12px 28px rgba(0,0,0,.18)}
.heroSecondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.36)}
.agencyHero .heroProofChips{margin-top:12px}
.agencyHero .heroProofChips span{padding:7px 11px;font-size:.88rem;background:rgba(255,255,255,.10)}
.regionBar{padding-top:8px;padding-bottom:8px}
.regionChip{padding:8px 10px;border-radius:14px}.regionChip strong{font-size:.95rem}.regionChip span{font-size:.78rem}
.tabs{padding-top:5px;padding-bottom:5px}.tabs a{padding:7px 11px}
main{padding-top:0}.mapLayout{padding-top:10px}
.instantGuide{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 10px;align-items:center}
.instantGuide span{display:inline-flex;align-items:center;gap:7px;border:1px solid #d5e5da;background:#fff;border-radius:999px;padding:7px 10px;color:#21342b;font-weight:850;box-shadow:0 4px 12px rgba(31,42,36,.04)}
.instantGuide strong{display:grid;place-items:center;width:22px;height:22px;border-radius:999px;background:#0d6b49;color:white;font-size:.78rem;line-height:1}
.compactToolbar{margin-bottom:10px}.compactToolbar h2{font-size:clamp(1.25rem,2.4vw,2rem);letter-spacing:-.025em;margin-bottom:2px}
.primaryMapSearch{margin-bottom:8px}.materialSearchBar{box-shadow:0 12px 34px rgba(31,42,36,.13);border:1px solid #cfe1d5;background:#f7fbf7}
.searchFieldWrap input{font-size:1.12rem;font-weight:780}.searchFieldWrap p{font-size:.86rem}
.quickSortChips{margin-bottom:8px}.quickSortChips button{min-height:40px;background:#eef6ef;border:1px solid #cde0d2;color:#123f2f}
.mapShell{border-radius:24px;overflow:hidden;border:1px solid #d7e6dc;background:#fff;box-shadow:0 16px 38px rgba(31,42,36,.08)}
.mapHead{background:linear-gradient(180deg,#fff,#f7fbf8);border-bottom:1px solid #e1ece5}
.mapFirst .map{height:min(58vh,560px);min-height:390px}
.filterDialog{border-radius:30px;background:#fcfffd}.filterHeader{background:#0b5f42}.filterBody{padding-top:14px}.filterGroup{box-shadow:0 10px 28px rgba(31,42,36,.07);border-color:#d8e6dd}
.compactStartGroup{background:linear-gradient(180deg,#ffffff,#f1faf4)}
.filterRow{min-height:56px}.filterRow span{font-weight:760}.filterRow input[type="checkbox"]{border-radius:8px}
.filterLiveBox strong::before{content:"Live: ";font-weight:950}.modeHint{font-size:.86rem;line-height:1.35;color:#52645b;background:#f6fbf7;border:1px solid #dbe9df;border-radius:14px;padding:8px 10px;margin-top:8px}
.agencyProviderCard{border-radius:22px;border:1px solid #dce8df;background:linear-gradient(180deg,#fff,#fbfefc);box-shadow:0 10px 26px rgba(31,42,36,.07)}
.agencyProviderCard h3{font-size:1.08rem;letter-spacing:-.01em;margin-bottom:3px}.agencyProviderCard .hint{display:none}
.cardInsight,.cardQuestion{display:grid;gap:3px;margin:9px 0;padding:10px 11px;border-radius:16px;background:#f5faf6;border:1px solid #dce9e0}
.cardQuestion{background:#fff8e8;border-color:#ead7aa}.cardInsight strong,.cardQuestion strong{color:#0d4f36;font-size:.8rem;text-transform:uppercase;letter-spacing:.045em}.cardInsight span,.cardQuestion span{color:#2d3e36;font-size:.9rem;line-height:1.38}
.simpleScore{gap:6px}.simpleScore span{background:#eff7f1;border-color:#cfe1d5;color:#163b2c}
.appPromoSlim{margin:12px clamp(10px,2vw,24px) 0;padding:14px 16px;border-radius:22px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;background:linear-gradient(135deg,#eef8f1,#ffffff);border:1px solid #d2e2d7;box-shadow:0 10px 28px rgba(31,42,36,.06)}
.appPromoSlim h2{font-size:1.15rem;margin:0 0 4px}.appPromoSlim p{margin:0}.appPromoSlim .promoKicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:#0d6b49;font-weight:950;margin-bottom:3px}.promoButton{white-space:nowrap;background:#0d6b49;color:white!important;border:0!important;text-decoration:none!important;border-radius:16px;padding:13px 15px;font-weight:950}
#resultTitle::after{content:" · keine Buchung";font-size:.66em;color:#607168;font-weight:850}
@media(max-width:900px){
  .agencyHero{grid-template-columns:1fr;padding:14px 12px 13px}.viewTools{display:none}.agencyHero .brandBlock h1{font-size:2rem;line-height:1.03}.agencyHero .heroShort{font-size:1rem;line-height:1.38}.heroActions{margin-top:12px}.heroPrimary,.heroSecondary{flex:1 1 150px;min-height:46px}.agencyHero .heroProofChips{display:none}
  .regionBar{position:static;grid-template-columns:1fr;padding:8px 10px}.regionBarIntro{display:none}.tabs{position:sticky;top:0;z-index:1050;justify-content:flex-start}.tabs a{flex:0 0 auto}
  .mapLayout{padding:8px 8px 14px}.instantGuide{display:grid;grid-template-columns:1fr;gap:6px}.instantGuide span{border-radius:16px;padding:8px 10px}.compactToolbar h2{font-size:1.35rem}.compactToolbar .hint{font-size:.86rem}.topMapActions{display:none!important}
  .materialSearchBar{grid-template-columns:auto minmax(0,1fr);border-radius:20px;background:#f7fbf7;border:1px solid #cfe1d5}.materialSearchBar .filterOpenButton{grid-column:1/-1}.mapFirst .map{height:min(56vh,430px);min-height:340px}.mapHead h3{font-size:1rem}.mapHead .hint{font-size:.8rem}.filterDialog{border-radius:0}.filterRow{min-height:60px}.appPromoSlim{grid-template-columns:1fr;gap:10px;margin:10px 8px 0}.promoButton{width:100%;text-align:center}
}
@media(max-width:430px){
  .agencyHero .brandBlock h1{font-size:1.78rem}.heroShort{font-size:.95rem}.heroPrimary,.heroSecondary{flex-basis:100%}.mapFirst .map{min-height:320px}.searchIcon{display:none}.materialSearchBar{grid-template-columns:1fr}.searchFieldWrap input{font-size:1.02rem}.quickSortChips button{font-size:.86rem}
}


/* v98: Fernweh-Hero, klarer Starttitel und HaliNor-Logo */
.agencyHero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 18%, rgba(159,205,181,.42), transparent 28%),
    radial-gradient(circle at 14% 8%, rgba(255,250,240,.20), transparent 26%),
    linear-gradient(135deg,#073b2b 0%,#0b5f42 48%,#143b59 100%);
}
.agencyHero::before{
  content:"";
  position:absolute;
  inset:-30% -8% auto auto;
  width:min(620px,72vw);
  height:min(620px,72vw);
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:inset 0 0 0 38px rgba(255,255,255,.025);
  pointer-events:none;
}
.agencyHero::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-1px;height:62px;
  background:
    radial-gradient(80px 24px at 12% 24px, rgba(255,255,255,.30) 0 38%, transparent 40%),
    radial-gradient(96px 26px at 34% 34px, rgba(255,255,255,.20) 0 38%, transparent 40%),
    linear-gradient(180deg,transparent,rgba(255,250,240,.11));
  opacity:.9;
  pointer-events:none;
}
.agencyHero .brandBlock{position:relative;z-index:1}
.agencyHero .eyebrow{color:#d9efe4;opacity:.95}
.agencyHero .brandBlock h1{max-width:1120px;text-wrap:balance;letter-spacing:-.045em}
.agencyHero .heroShort{max-width:900px;text-wrap:balance;color:#edf8f1}
.heroPrimary{background:linear-gradient(180deg,#fff,#f3fff6);color:#073b2b}
.heroSecondary{background:rgba(255,255,255,.16);backdrop-filter:blur(6px)}
.heroPrimary::after{content:" →";font-weight:950}.heroSecondary::after{content:" ✓";font-weight:950}
.agencyHero .heroProofChips span{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.24);backdrop-filter:blur(4px)}
.instantGuide span{background:linear-gradient(180deg,#ffffff,#f4fbf6)}
.mapHead h3::before{content:"↟ ";color:#0d6b49}.mapShell{box-shadow:0 18px 44px rgba(20,45,36,.11)}
.appPromoWithLogo{grid-template-columns:auto minmax(0,1fr) auto;background:linear-gradient(135deg,#fffaf0,#eef8f1 54%,#ffffff);overflow:hidden;position:relative}
.appPromoWithLogo::after{content:"";position:absolute;right:-30px;bottom:-54px;width:170px;height:170px;border-radius:50%;background:rgba(13,107,73,.06);pointer-events:none}
.appPromoLogo{width:70px;height:70px;border-radius:18px;object-fit:cover;box-shadow:0 12px 26px rgba(31,42,36,.16);border:1px solid rgba(13,107,73,.18);background:#fffaf0}
.appPromoWithLogo .promoButton{position:relative;z-index:1}
@media(max-width:900px){
  .agencyHero::before{width:88vw;height:88vw;right:-32vw;top:-38vw}
  .agencyHero::after{height:42px;opacity:.62}
  .agencyHero .brandBlock h1{font-size:clamp(1.68rem,8vw,2.25rem)!important;line-height:1.02!important;max-width:21rem!important}
  .agencyHero .heroShort{font-size:.98rem!important;line-height:1.38!important;max-width:31rem!important}
  .appPromoWithLogo{grid-template-columns:auto minmax(0,1fr);align-items:center}
  .appPromoLogo{width:58px;height:58px;border-radius:16px}
  .appPromoWithLogo .promoButton{grid-column:1/-1;width:100%}
}
@media(max-width:430px){
  .agencyHero .brandBlock h1{font-size:1.75rem!important;max-width:18.5rem!important}
  .agencyHero .heroShort{font-size:.93rem!important}
  .appPromoLogo{width:52px;height:52px}
}


/* v98: Begriffe vereinfacht und mobile Ansicht nach Handy-Test verdichtet */
@media(max-width:900px){
  .agencyHero{padding:10px 14px 12px!important;}
  .agencyHero .brandBlock h1{font-size:clamp(1.48rem,6.8vw,1.95rem)!important;line-height:1.04!important;max-width:26rem!important;margin-bottom:8px!important;}
  .agencyHero .heroShort{font-size:.91rem!important;line-height:1.34!important;max-width:32rem!important;}
  .heroActions{display:grid!important;grid-template-columns:1fr 1fr;gap:8px!important;margin-top:10px!important;}
  .heroPrimary,.heroSecondary{min-height:42px!important;border-radius:14px!important;padding:0 10px!important;font-size:.92rem!important;flex:initial!important;}
  .heroPrimary::after,.heroSecondary::after{content:""!important;}
  .regionChip{min-width:132px!important;padding:7px 9px!important;}
  .regionChip strong{font-size:.89rem!important;}
  .regionChip span{font-size:.74rem!important;}
  .instantGuide{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:6px!important;margin-bottom:8px!important;}
  .instantGuide span{display:grid!important;grid-template-columns:auto minmax(0,1fr);gap:5px!important;align-items:center;border-radius:14px!important;padding:7px 7px!important;font-size:.78rem!important;line-height:1.1!important;}
  .instantGuide strong{width:20px!important;height:20px!important;font-size:.72rem!important;}
  .compactToolbar{margin-bottom:8px!important;}
  .compactToolbar h2{font-size:1.08rem!important;}
  .primaryMapSearch{padding:10px!important;border-radius:18px!important;}
  .searchFieldWrap label{font-size:.76rem!important;}
  .searchFieldWrap input{font-size:.96rem!important;}
  .searchFieldWrap p{font-size:.79rem!important;line-height:1.3!important;}
  .quickSortChips button{min-height:36px!important;font-size:.79rem!important;padding:7px 10px!important;}
  .mapHead{padding:9px 10px!important;}
  .mapHead h3{font-size:.98rem!important;}
  .mapHead .hint{font-size:.76rem!important;line-height:1.3!important;}
}
@media(max-width:430px){
  .agencyHero .brandBlock h1{font-size:1.46rem!important;max-width:24rem!important;}
  .heroActions{grid-template-columns:1fr 1fr!important;}
  .heroPrimary,.heroSecondary{font-size:.86rem!important;}
  .instantGuide span{font-size:.72rem!important;padding:6px 5px!important;}
}


/* v115 agency polish: Kontakt nutzbar, aber ruhig */
.contactTeaser{display:flex;align-items:center;gap:6px;flex-wrap:wrap;border:1px solid #dfe9e2;background:#f7fbf8;border-radius:14px;padding:7px 9px;font-size:.86rem;line-height:1.25}
  .contactTeaser strong{color:#2f5f49}.contactTeaser a{color:#2f7d5b;font-weight:850;text-decoration:none}.contactTeaser a:hover{text-decoration:underline}.contactTeaser.open{background:#f7f5ee;border-color:#e5dcc8;color:#5c5549}.contactTeaser.weak{background:#fff8e8;border-color:#f1dfb4}.contactTeaser.good{background:#f1f8f3;border-color:#cfe4d5}.contactQualityBox{border:1px solid #dce8df;background:#f7fbf8;border-radius:16px;padding:10px 12px;margin:0 0 10px}.contactQualityBox strong{display:block;margin-bottom:4px}.contactQualityBox p{margin:0 0 4px}.contactQualityBox a{font-weight:900;color:#2f7d5b;text-decoration:none}.contactQualityBox a:hover{text-decoration:underline}.contactQualityBox.none{background:#f7f5ee;border-color:#e5dcc8}.contactQualityBox.info_only{background:#fff8e8;border-color:#f1dfb4}.agencyProviderCard .badges{min-height:0}.agencyProviderCard .badge:nth-child(n+4){display:none}.agencyProviderCard .cardInsight,.agencyProviderCard .cardQuestion{padding:8px 9px;border-radius:14px;background:#fbfaf3;border:1px solid #ece4d0}.agencyProviderCard .cardInsight strong,.agencyProviderCard .cardQuestion strong{display:block;font-size:.76rem;text-transform:none;color:#536257;margin-bottom:2px}.agencyProviderCard .cardInsight span,.agencyProviderCard .cardQuestion span{font-size:.88rem;line-height:1.3}

/* v121: mobile release audit – less duplication, shorter path to results */
.emptyCompare{margin:0;padding:4px 2px}
.agencyProviderCard .badges{gap:6px}
.agencyProviderCard .badge:nth-child(n+3){display:none}
.agencyProviderCard .cardInsight span,.agencyProviderCard .cardQuestion span{
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden
}
.detailHero .meta{color:var(--muted)}

@media(max-width:900px){
  .agencyHero{padding:9px 14px 10px!important}
  .agencyHero .brandBlock h1{font-size:clamp(1.3rem,6vw,1.72rem)!important;line-height:1.06!important;margin-bottom:5px!important;max-width:28rem!important}
  .agencyHero .heroShort{font-size:.84rem!important;line-height:1.3!important;max-width:34rem!important}
  .heroActions{margin-top:8px!important;gap:7px!important}
  .heroPrimary,.heroSecondary{min-height:38px!important;font-size:.82rem!important;border-radius:12px!important}
  .regionBar{padding:6px 8px!important}
  .regionChip{min-width:124px!important;padding:6px 8px!important}
  .compactToolbar{padding:7px 10px!important;margin-bottom:6px!important;box-shadow:none!important;border:1px solid #e2e7df}
  .compactToolbar h2{font-size:1rem!important}
  .compactToolbar .eyebrow{font-size:.61rem!important}
  .compactToolbar .hint{display:none!important}
  .primaryMapSearch{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:8px!important;padding:9px!important;margin-bottom:6px!important}
  .primaryMapSearch .filterOpenButton{grid-column:auto!important;align-self:end;min-width:104px;min-height:42px}
  .searchFieldWrap label{font-size:.72rem!important}
  .searchFieldWrap input{min-height:42px;font-size:.94rem!important}
  .searchFieldWrap p{display:none!important}
  .quickSortChips{padding:6px!important;margin-bottom:6px!important;border-radius:16px}
  .quickSortChips button{min-height:34px!important;font-size:.76rem!important;padding:6px 9px!important}
  .mapHead{padding:8px 10px!important}
  .mapHead .hint{font-size:.72rem!important}
  .mapFirst .map{height:min(40vh,350px)!important;min-height:270px!important;touch-action:pan-y pinch-zoom!important}
  .agencyProviderCard{padding:13px!important}
  .agencyProviderCard .cardInsight,.agencyProviderCard .cardQuestion{margin:7px 0;padding:8px 9px}
  .agencyProviderCard .toolbarActions{gap:6px}
  .agencyProviderCard .toolbarActions button{padding:8px 9px;font-size:.82rem}
  .appPromoWithLogo{grid-template-columns:44px minmax(0,1fr) auto!important;gap:9px!important;padding:10px 12px!important;align-items:center}
  .appPromoLogo{width:44px!important;height:44px!important;border-radius:13px!important}
  .appPromoSlim h2{font-size:.96rem;line-height:1.2;margin:0}
  .appPromoText .promoKicker{font-size:.64rem}
  .appPromoText>p:last-child{display:none}
  .appPromoWithLogo .promoButton{grid-column:auto!important;width:auto!important;padding:10px 11px;font-size:.8rem;border-radius:12px}
  #detailContent{font-size:.94rem}
  .detailHero{padding-bottom:4px}
  .detailHero .statusNote{padding:10px;margin:9px 0}
  .detailSection>summary{padding:11px 12px}
  .detailSectionBody{padding:10px!important}
}

@media(max-width:430px){
  .agencyHero .brandBlock h1{font-size:1.3rem!important}
  .heroActions{grid-template-columns:1fr 1fr!important}
  .primaryMapSearch{grid-template-columns:minmax(0,1fr) 92px!important}
  .primaryMapSearch .filterOpenButton{min-width:92px;padding-inline:8px}
  .appPromoWithLogo{grid-template-columns:40px minmax(0,1fr)!important}
  .appPromoLogo{width:40px!important;height:40px!important}
  .appPromoWithLogo .promoButton{grid-column:1/-1!important;width:100%!important;padding:9px!important}
}

/* v122: Desktop/Pageview-Polish – mobile Ansicht bleibt über bestehende <=900px-Regeln unverändert */
.desktopTitle,.desktopHeroCopy,.desktopHeroNav,.desktopAppHint{display:none}

@media(min-width:901px){
  body{background:linear-gradient(180deg,#fffaf0 0,#f8f2e4 420px,#fffaf0 100%)}
  .mobileTitle,.mobileHeroCopy{display:none!important}
  .desktopTitle,.desktopHeroCopy{display:inline!important}
  .agencyHero{
    grid-template-columns:minmax(0,1fr) minmax(190px,auto);
    align-items:start;
    gap:18px;
    padding:14px clamp(22px,3vw,42px) 16px!important;
    min-height:0;
  }
  .agencyHero::before{width:min(420px,34vw);height:min(420px,34vw);right:-90px;top:-180px;opacity:.72}
  .agencyHero::after{height:34px;opacity:.42}
  .agencyHero .eyebrow{font-size:.66rem;margin-bottom:4px}
  .agencyHero .brandBlock h1{
    font-size:clamp(1.55rem,2.7vw,2.65rem)!important;
    line-height:1.02!important;
    max-width:880px!important;
    margin-bottom:6px!important;
    letter-spacing:-.035em!important;
  }
  .agencyHero .heroShort{
    max-width:820px!important;
    font-size:clamp(.95rem,1.15vw,1.08rem)!important;
    line-height:1.36!important;
  }
  .heroActions{margin-top:11px!important;gap:8px!important}
  .heroPrimary,.heroSecondary{min-height:40px!important;padding:0 13px!important;border-radius:13px!important;font-size:.9rem!important}
  .heroPrimary::after,.heroSecondary::after{content:""!important}
  .desktopHeroNav{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
    margin-top:10px;
    align-items:center;
  }
  .desktopHeroNav a,.desktopHeroNav button{
    min-height:34px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0 11px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.26);
    background:rgba(255,255,255,.10);
    color:#fff;
    text-decoration:none;
    font-weight:850;
    font-size:.82rem;
    box-shadow:none;
  }
  .desktopHeroNav a:hover,.desktopHeroNav button:hover,
  .desktopHeroNav a:focus-visible,.desktopHeroNav button:focus-visible{background:rgba(255,255,255,.18);outline:2px solid rgba(255,255,255,.18);outline-offset:2px}
  .desktopAppHint{
    display:inline-flex;
    margin:9px 0 0;
    padding:6px 10px;
    width:max-content;
    max-width:100%;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.24);
    background:rgba(255,255,255,.11);
    color:#eaf7ef;
    font-size:.82rem;
    font-weight:820;
  }
  .viewTools.fontMenu{
    justify-self:end;
    align-self:start;
    padding:7px 8px!important;
    border-radius:14px!important;
    max-width:230px;
    background:rgba(255,255,255,.10)!important;
  }
  .viewTools.fontMenu summary{font-size:.78rem;cursor:pointer}
  .viewTools.fontMenu .segmented button{padding:6px 8px;font-size:.78rem;min-height:32px}
  .tabs{display:none!important}
  .regionBar{
    position:relative!important;
    top:auto!important;
    z-index:20!important;
    grid-template-columns:auto minmax(0,1fr)!important;
    gap:10px!important;
    padding:7px clamp(22px,3vw,42px)!important;
    background:rgba(255,250,240,.92)!important;
    border-bottom:1px solid #e5dac6!important;
  }
  .regionBarIntro{min-width:118px!important;gap:0!important}
  .regionBarIntro strong{font-size:.86rem;color:#15392d}
  .regionBarIntro span{font-size:.72rem!important;line-height:1.2}
  .regionChips{grid-template-columns:repeat(4,minmax(118px,1fr))!important;gap:6px!important}
  .regionChip{padding:7px 9px!important;border-radius:13px!important;background:rgba(255,255,255,.84)!important}
  .regionChip strong{font-size:.86rem!important}
  .regionChip span{font-size:.7rem!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mapLayout{padding:11px clamp(14px,2vw,26px) 18px!important}
  .compactToolbar{
    padding:10px 12px;
    border:1px solid #dfe8e1;
    border-radius:18px;
    background:rgba(255,255,255,.78);
    box-shadow:0 8px 22px rgba(31,42,36,.05);
  }
  .compactToolbar h2{font-size:clamp(1.12rem,1.6vw,1.42rem)!important}
  .compactToolbar .hint{font-size:.84rem;max-width:82ch}
  .primaryMapSearch{box-shadow:0 8px 22px rgba(31,42,36,.07)!important;border-radius:20px!important}
  .searchIcon{width:36px;height:36px;font-size:1.15rem}
  .searchFieldWrap label{font-size:.78rem!important}
  .searchFieldWrap input{font-size:1rem!important;min-height:42px!important;padding:10px 12px!important}
  .quickSortChips{box-shadow:none!important;background:rgba(247,251,247,.86)!important}
  .quickSortChips button{min-height:36px!important;padding:7px 10px!important;font-size:.8rem!important}
  .mapShell{border-radius:20px!important;box-shadow:0 12px 30px rgba(20,45,36,.08)!important}
  .mapHead{padding:9px 12px!important}
  .mapHead h3{font-size:1rem!important}
  .mapHead .hint{font-size:.78rem!important}
  .mapFirst .map{height:min(54vh,510px)!important;min-height:370px!important}
  .mapPreview{max-height:min(54vh,510px)!important;padding:12px!important}
  .mapPreview .hint,.mapPreview p{font-size:.87rem;line-height:1.34}
  .mapPreview .question{font-size:.84rem;padding:7px 9px;margin:6px 0}
  .agencyProviderCard .contactTeaserLink{display:none!important}
  .agencyProviderCard .cardInsight span,.agencyProviderCard .cardQuestion span{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
}

@media(min-width:1180px){
  #resultsView{
    display:grid;
    grid-template-columns:minmax(0,1.48fr) minmax(330px,.72fr);
    grid-template-areas:
      "toolbar toolbar"
      "search sort"
      "map cards";
    gap:10px 14px;
    align-items:start;
  }
  .compactToolbar{grid-area:toolbar;margin:0!important}
  .primaryMapSearch{grid-area:search;margin:0!important}
  .quickSortChips{grid-area:sort;margin:0!important;align-self:stretch;justify-content:flex-end;flex-wrap:wrap;overflow:visible;padding:8px!important}
  .quickSortChips button{flex:1 1 128px}
  .mapShell{grid-area:map;margin:0!important}
  .mobileResultsDetails{
    grid-area:cards;
    display:block;
    position:sticky;
    top:12px;
    border:1px solid #dce8df;
    border-radius:20px;
    background:#fff;
    box-shadow:0 12px 30px rgba(31,42,36,.07);
    max-height:calc(100vh - 22px);
    overflow:auto;
    margin:0!important;
  }
  .mobileResultsDetails>.resultListHead{
    position:sticky;
    top:0;
    z-index:2;
    margin:0!important;
    padding:13px 14px 9px;
    background:linear-gradient(180deg,#fff,#fbfefc);
    border-bottom:1px solid #e3eee7;
  }
  .mobileResultsDetails>.resultListHead h3{font-size:1rem;margin:0 0 3px}
  .mobileResultsDetails>.resultListHead .hint{font-size:.79rem;line-height:1.3;margin:0}
  .mobileResultsDetails>.cards{display:grid!important;grid-template-columns:1fr!important;gap:9px!important;padding:12px 14px 14px!important}
  .agencyProviderCard{padding:11px!important;border-radius:18px!important;gap:7px!important}
  .agencyProviderCard h3{font-size:1rem!important;line-height:1.18!important}
  .agencyProviderCard .meta{font-size:.78rem!important}
  .agencyProviderCard .contactTeaser{font-size:.78rem;padding:6px 8px;border-radius:12px}
  .agencyProviderCard .cardInsight,.agencyProviderCard .cardQuestion{padding:7px 8px!important;margin:5px 0!important;border-radius:12px!important}
  .agencyProviderCard .cardInsight strong,.agencyProviderCard .cardQuestion strong{font-size:.68rem!important;letter-spacing:.035em!important}
  .agencyProviderCard .cardInsight span,.agencyProviderCard .cardQuestion span{font-size:.8rem!important;line-height:1.28!important}
  .agencyProviderCard .toolbarActions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:5px!important}
  .agencyProviderCard .toolbarActions button{min-height:34px;padding:6px 6px!important;font-size:.75rem!important;border-radius:12px!important}
}

