/* LEVEL Graz Wohnungsfinder — Styles, gekapselt unter .lvf. Totes CSS (Drawer/Modal/Merkliste) entfernt. */
.lvf{
  /* Brand-Anbindung: konsumiert die Webflow-Variablen der Seite.
     Fallbacks greifen nur im lokalen Test ohne Webflow. */
  --wf-dark: var(--basis--primary-color_farbe-1, #242B39);
  --wf-light: var(--basis--secondary-color_farbe-2, #FFFFFF);
  --wf-accent: var(--color-variables--accent-elements, #6FBC8B);
  --wf-finder-bg: var(--color-variables--wohnungsfinder-bg, var(--wf-dark));
  --wf-finder-text: var(--color-variables--wohnungsfinder-text, #FFFFFF);
  --wf-btn-bg: var(--color-variables--secondary-button-bg, var(--wf-dark));
  --wf-btn-text: var(--color-variables--secondary-button-text, #FFFFFF);
  --font-head: var(--_typography---font-styles--heading, Montserrat, sans-serif);
  --font-body: var(--_typography---font-styles--body, Montserrat, sans-serif);

  /* abgeleitete Widget-Töne */
  --paper: var(--wf-light);
  --card: var(--wf-light);
  --ink: var(--wf-dark);
  --muted: color-mix(in srgb, var(--wf-dark) 55%, white);
  --line: color-mix(in srgb, var(--wf-dark) 14%, white);
  --moss: var(--wf-btn-bg);
  --moss-deep: color-mix(in srgb, var(--wf-btn-bg) 80%, black);
  --moss-tint: color-mix(in srgb, var(--wf-accent) 14%, white);
  --moss-line: color-mix(in srgb, var(--wf-accent) 34%, white);
  --sand: color-mix(in srgb, var(--wf-dark) 6%, white);
  --avail: var(--wf-accent);
  --radius:14px; --radius-s:9px;
}
.lvf, .lvf *{box-sizing:border-box;margin:0;padding:0}
.lvf{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){.lvf{scroll-behavior:auto}
.lvf, .lvf *{transition:none!important;animation:none!important}}
.lvf{background:var(--paper);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
/* Keine eigene Breitenbegrenzung/Seiten-Padding: das Webflow-Embed ist bereits
   wie alle Seitenelemente seitlich begrenzt — das Widget füllt diesen Container. */
.lvf .wrap{width:100%}
.lvf button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
.lvf button:focus-visible, .lvf a:focus-visible, .lvf input:focus-visible, .lvf select:focus-visible{outline:2px solid var(--moss);outline-offset:2px;border-radius:4px}
.lvf /* Quick finder */
.finder{margin:30px 0 8px;background:var(--wf-finder-bg);color:var(--wf-finder-text);border-radius:var(--radius);padding:30px clamp(20px,4vw,44px) 34px;position:relative;overflow:hidden}
.lvf .finder .eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:color-mix(in srgb, var(--wf-finder-text) 72%, transparent);font-weight:600}
.lvf .finder h2{font-family:var(--font-head);font-weight:600;font-size:clamp(22px,3.4vw,30px);margin-top:10px;max-width:520px}
.lvf .finder .opts{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.lvf .finder .opts button{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);color:var(--wf-finder-text);border-radius:99px;padding:10px 22px;font-size:15px;font-weight:500;transition:background .15s}
.lvf .finder .opts button:hover{background:rgba(255,255,255,.2)}
.lvf .finder h2.typing::after{content:"";display:inline-block;width:3px;height:1.05em;margin-left:3px;vertical-align:-.16em;background:currentColor;border-radius:1px;animation:lvfCaret .9s steps(1) infinite}
@keyframes lvfCaret{0%,49%{opacity:1}50%,100%{opacity:0}}
.lvf .finder .opts button.fopt-hold{opacity:0;pointer-events:none}
.lvf .finder .opts button.fopt-in{animation:lvfOptIn .42s cubic-bezier(.2,.7,.3,1) both}
@keyframes lvfOptIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.lvf .finder .meta{display:flex;justify-content:space-between;align-items:center;margin-top:24px;font-size:13px;color:color-mix(in srgb, var(--wf-finder-text) 62%, transparent)}
.lvf .finder .meta a{color:color-mix(in srgb, var(--wf-finder-text) 62%, transparent);text-decoration:underline;cursor:pointer}
.lvf .finder .steps{display:flex;gap:6px}
.lvf .finder .steps span{width:26px;height:3px;border-radius:2px;background:rgba(255,255,255,.22)}
.lvf .finder .steps span.on{background:color-mix(in srgb, var(--wf-finder-text) 72%, transparent)}
.lvf /* Finder: kompakte Zusammenfassung nach Abschluss */
.finder.done{padding:20px clamp(20px,4vw,44px) 22px}
.lvf .finder.done h2, .lvf .finder.done .opts, .lvf .finder.done .meta{display:none}
.lvf .fsum{display:none;align-items:center;gap:10px 12px;flex-wrap:wrap;margin-top:12px}
.lvf .finder.done .fsum{display:flex}
.lvf .fsum .slbl{font-size:14px;font-weight:500;color:color-mix(in srgb, var(--wf-finder-text) 82%, transparent)}
.lvf .fsum .schip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);border-radius:99px;padding:4px 14px;font-size:13.5px;font-weight:500}
.lvf .fsum .restart{color:color-mix(in srgb, var(--wf-finder-text) 72%, transparent);text-decoration:underline;font-size:13px;margin-left:auto;cursor:pointer;white-space:nowrap}
.lvf /* Filter bar */
.filterbar{position:sticky;top:0;z-index:40;background:var(--paper);padding:14px 0 12px;border-bottom:1px solid var(--line)}
.lvf .filterbar .rows{display:flex;flex-wrap:wrap;gap:10px 18px;align-items:center}
.lvf .fgroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.lvf .fgroup .lbl{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-right:2px;white-space:nowrap}
.lvf .chip{border:1px solid var(--line);background:var(--card);border-radius:99px;padding:6px 14px;font-size:14px;font-weight:500;transition:all .12s;white-space:nowrap}
.lvf .chip:hover{border-color:var(--moss)}
.lvf .chip.on{background:var(--moss);border-color:var(--moss);color:#fff}
.lvf .slider-grp{display:flex;align-items:center;gap:10px}
.lvf .slider-grp input[type=range]{accent-color:var(--moss);width:108px}
.lvf .slider-grp .val{font-size:14px;font-weight:600;min-width:64px}
.lvf .fmeta{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:10px;flex-wrap:wrap}
.lvf .fmeta .count{font-size:14px}
.lvf .fmeta .count b{font-weight:600}
.lvf .fc-pre{display:none}
.lvf .fmeta .right{display:flex;align-items:center;gap:14px}
.lvf .fmeta select{border:1px solid var(--line);background:var(--card);border-radius:99px;padding:6px 12px;font:inherit;font-size:13px;color:var(--ink)}
.lvf .fmeta .reset{font-size:13px;color:var(--muted);text-decoration:underline;cursor:pointer}
.lvf .toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;user-select:none}
.lvf .toggle .tk{width:34px;height:20px;border-radius:99px;background:color-mix(in srgb, var(--wf-dark) 22%, white);position:relative;transition:background .15s;flex:none}
.lvf .toggle .tk::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .15s}
.lvf .toggle.on .tk{background:var(--moss)}
.lvf .toggle.on .tk::after{left:16px}
.lvf .fopen{display:none;align-items:center;gap:7px;border:1px solid var(--line);background:var(--card);border-radius:99px;padding:7px 15px;font-size:13.5px;font-weight:600}
.lvf .fopen .fb{background:var(--moss);color:#fff;border-radius:99px;min-width:19px;height:19px;display:none;align-items:center;justify-content:center;font-size:11.5px;padding:0 5px}
.lvf .fopen .fb.show{display:inline-flex}
.lvf /* Type cards */
.results{padding:18px 0 70px}
.lvf .rhead{padding-top:26px}
.lvf .rhead h2{font-family:var(--font-head);font-weight:600;font-size:23px}
.lvf .rhead p{font-size:14px;color:var(--muted);margin-top:4px;max-width:560px}
.lvf .tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:visible}
.lvf .thead{display:flex;align-items:center;gap:18px;padding:18px clamp(16px,3vw,26px);width:100%;text-align:left;background:color-mix(in srgb, var(--ink) 6%, var(--card));transition:background .12s}
.lvf .thead:hover{background:color-mix(in srgb, var(--ink) 10%, var(--card))}
.lvf .plan{width:210px;height:158px;flex:none;background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative;cursor:zoom-in}
.lvf .plan img{width:100%;height:100%;object-fit:contain}
.lvf .plan .zoom{position:absolute;right:6px;bottom:6px;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);pointer-events:none}
.lvf .plan:hover .zoom{color:var(--moss);border-color:var(--moss)}
.lvf .tinfo{flex:1;min-width:0}
.lvf .teye{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.lvf .tinfo .tname{font-family:var(--font-head);font-size:18px;font-weight:500;margin-top:2px}
.lvf .tinfo .tmeta{display:flex;flex-wrap:wrap;gap:5px 14px;margin-top:5px;font-size:14px;color:var(--muted)}
.lvf .tinfo .tmeta .tag{background:color-mix(in srgb, var(--wf-accent) 22%, white);border:1px solid color-mix(in srgb, var(--wf-accent) 48%, white);color:var(--moss-deep);border-radius:6px;padding:2px 9px;font-size:12.5px;font-weight:600}
.lvf .tprice{text-align:right;flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.lvf .tprice .ab{font-size:12px;color:var(--muted)}
.lvf .tprice .p{font-size:18px;font-weight:700;white-space:nowrap}
.lvf .availpill{display:inline-flex;align-items:center;gap:6px;background:var(--avail);color:#fff;border-radius:99px;padding:4px 12px;font-size:12.5px;font-weight:700;white-space:nowrap}
.lvf .availpill::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;opacity:.85}
.lvf .availpill.none{background:var(--sand);color:var(--muted)}
.lvf .availpill.none::before{background:var(--muted);opacity:.6}
.lvf .chev{flex:none;color:var(--muted);transition:transform .2s}
.lvf .tstuck-av{display:none}
.lvf .tbody{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows .34s cubic-bezier(.4,0,.2,1)}
.lvf .tcard.open .tbody{grid-template-rows:1fr}
.lvf .tbody-inner{min-height:0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:0 clamp(16px,3vw,26px);transition:padding .34s cubic-bezier(.4,0,.2,1)}
.lvf .tcard.open .tbody-inner{padding-top:18px;padding-bottom:22px;border-top:1px solid var(--line)}
.lvf .texpand{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:var(--moss);color:#fff;padding:13px 16px;font-size:15px;font-weight:600;transition:background .12s}
.lvf .texpand:hover{background:var(--moss-deep)}
.lvf .tcard.open .texpand{background:var(--moss-tint);color:var(--moss-deep);border-top:1px solid var(--moss-line)}
.lvf .tcard.open .texpand:hover{background:var(--moss-line)}
.lvf .texpand svg{transition:transform .2s;flex:none}
.lvf .tcard.open .texpand svg{transform:rotate(180deg)}
/* Sticky-Typenkopf, der sich beim Anheften verdichtet (Desktop + Mobil).
   Karte hat overflow:visible; runde Ecken über die Rand-Kinder. */
.lvf .thead{border-radius:var(--radius) var(--radius) 0 0}
.lvf .texpand{border-radius:0 0 var(--radius) var(--radius)}
.lvf .tcard.open > .thead{position:sticky;top:var(--lvf-fbh,56px);z-index:6;transition:padding .22s ease,box-shadow .22s ease}
.lvf .thead .plan{transition:width .22s ease,height .22s ease}
.lvf .tcard.open.stuck > .thead{flex-wrap:nowrap;align-items:center;padding:9px clamp(14px,3vw,26px);box-shadow:0 6px 16px rgba(20,25,35,.12);border-bottom:1px solid var(--line)}
.lvf .tcard.open.stuck .plan{width:58px;height:58px}
.lvf .tcard.open.stuck .tmeta,.lvf .tcard.open.stuck .tprice{display:none}
.lvf .tcard.open.stuck .tinfo{min-width:0;gap:1px}
.lvf .tcard.open.stuck .teye{font-size:9.5px;letter-spacing:.13em}
.lvf .tcard.open.stuck .tname{font-size:15px;margin:0;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lvf .tcard.open.stuck .tname .tn-sep{display:inline}
.lvf .tcard.open.stuck .tname .tn-area{display:inline}
.lvf .tcard.open.stuck .tstuck-av{display:block;font-size:12px;font-weight:600;color:var(--avail)}
.lvf .tcard.open.stuck .tstuck-av.none{color:var(--muted)}
/* Einheiten-Kacheln (Foto-Grid) — Foto = Interieur, klar abgesetzt vom Linien-Grundriss des Typs */
.lvf .utile{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-s);overflow:hidden;text-decoration:none;color:var(--ink);transition:box-shadow .16s,transform .16s,border-color .16s}
.lvf a.utile:hover{border-color:var(--moss);box-shadow:0 12px 28px rgba(20,25,35,.13);transform:translateY(-3px)}
.lvf .utile-img{position:relative;aspect-ratio:4/3;background:var(--sand);overflow:hidden}
/* Bildslider: Foto ⇄ Grundriss (scroll-snap → Swipe gratis) */
.lvf .utile-slides{display:flex;width:100%;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;user-select:none}
.lvf .utile-slide img{-webkit-user-drag:none;user-drag:none}
.lvf .utile-slides::-webkit-scrollbar{display:none}
.lvf .utile-slide{flex:0 0 100%;width:100%;height:100%;position:relative;scroll-snap-align:start;display:flex;align-items:center;justify-content:center}
.lvf .utile-slide img{width:100%;height:100%;object-fit:cover;display:block}
.lvf .utile-slide-plan{background:#fff}
.lvf .utile-slide-plan img{object-fit:contain;padding:6px}
.lvf .utile-slide .utile-ph{display:none;position:absolute;inset:0;align-items:center;justify-content:center;color:color-mix(in srgb,var(--muted) 60%,white)}
.lvf .utile-slide.noimg .utile-ph{display:flex}
.lvf .utile-nav{position:absolute;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.94);box-shadow:0 1px 5px rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;color:var(--ink);z-index:2}
.lvf .utile-nav:hover{background:#fff}
.lvf .utile-nav.next{right:8px}
.lvf .utile-nav.prev{left:8px}
.lvf .utile-img[data-idx="0"] .utile-nav.prev{display:none}
.lvf .utile-img:not([data-idx="0"]) .utile-nav.next{display:none}
.lvf .utile-dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:2;pointer-events:none}
.lvf .utile-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.55);box-shadow:0 0 2px rgba(0,0,0,.35)}
.lvf .utile-dots i.on{background:#fff}
.lvf .utile-badge{position:absolute;left:9px;top:9px;background:rgba(255,255,255,.94);color:var(--ink);border-radius:6px;padding:3px 9px;font-size:11.5px;font-weight:600;backdrop-filter:blur(2px)}
.lvf .utile-sold{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;background:rgba(36,43,57,.5);color:#fff;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:13px}
.lvf .utile.gone{opacity:.72}
.lvf .utile-body{padding:12px 13px 13px;display:flex;flex-direction:column;gap:5px}
.lvf .utile-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.lvf .utile-top{font-weight:700;font-size:17px}
.lvf .utile-floor{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12.5px;white-space:nowrap}
.lvf .utile-specs{color:var(--muted);font-size:13.5px}
.lvf .utile-foot{display:flex;align-items:baseline;gap:6px;margin-top:5px}
.lvf .utile-mlabel{font-size:12px;color:var(--muted);font-weight:600}
.lvf .utile-price{font-weight:700;font-size:17px}
.lvf .utile-foot .badge-gone{margin-left:auto;align-self:center}
/* Ansehen-Button der Kachel: Secondary (Umrandung), eingerückt, dezent – füllt sich beim Hover. */
.lvf .utile-cta{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:11px;background:var(--card);color:var(--moss);border:1.5px solid var(--moss);border-radius:var(--radius-s);padding:9px 14px;font-size:14px;font-weight:600;transition:background .14s,color .14s}
.lvf a.utile:hover .utile-cta{background:var(--moss);color:var(--wf-btn-text,#fff)}
.lvf .utile-cta svg{flex:none;transition:transform .16s}
.lvf a.utile:hover .utile-cta svg{transform:translateX(3px)}
.lvf .badge-gone{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:2px 7px}
.lvf .lvl{flex:none}
.lvf .empty{padding:60px 20px;text-align:center;color:var(--muted)}
.lvf .empty-cta{margin-top:22px}
/* Mobiler Abschluss-CTA unter der Einheitenliste (Desktop aus, im Gate-Zustand aus) */
.lvf .lv-restart{display:none}
.lvf.gated .lv-restart{display:none}
.lvf .lv-restart p{color:var(--ink);font-size:19px;font-weight:600;margin-bottom:14px}
.lvf .empty b{color:var(--ink)}
.lvf /* Grundriss-Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(34,37,30,.72);z-index:90;display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lvf .lightbox.show{display:flex}
.lvf .lightbox .lb-inner{position:relative;max-width:min(1100px,94vw);max-height:92vh;display:flex;flex-direction:column}
.lvf .lightbox img{max-width:100%;max-height:calc(92vh - 52px);object-fit:contain;border-radius:10px;background:#fff;box-shadow:0 24px 70px rgba(0,0,0,.35)}
.lvf .lightbox .lb-cap{display:flex;align-items:center;justify-content:space-between;gap:14px;color:var(--wf-finder-text);font-size:14px;padding:12px 4px 0}
.lvf .lightbox .lb-x{position:absolute;top:-14px;right:-14px;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:0 4px 14px rgba(0,0,0,.25)}
@media (max-width:680px){.lvf .lightbox{padding:12px}
.lvf .lightbox .lb-x{top:-10px;right:-6px}}
/* Ansehen-Button im Gate (Alle Wohnungen anzeigen) */
.lvf .uview{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--moss);background:var(--card);color:var(--moss-deep);border-radius:99px;padding:7px 14px;font-size:13.5px;font-weight:600;white-space:nowrap}
.lvf .uview:hover{background:var(--moss-tint)}
@media (max-width:991px){.lvf .tbody-inner{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){
.lvf .results{padding-bottom:8px}
.lvf .lv-restart{display:block;text-align:center;padding:22px 16px 4px;margin-top:0;border-top:1px solid var(--line)}
.lvf .tbody-inner{grid-template-columns:1fr;gap:13px;padding-left:14px;padding-right:14px}
/* Typname: Fläche bricht mobil in eigene Zeile (Sticky-Kopf-Regeln sind jetzt allgemein, weiter oben) */
.lvf .tname .tn-sep{display:none}
.lvf .tname .tn-area{display:block}
.lvf .tprice .availpill{margin-right:auto}
.lvf .thead{gap:8px 12px;padding:14px 16px;flex-wrap:wrap}
.lvf .tprice{width:100%;flex-direction:row;align-items:center;justify-content:flex-start;gap:7px;margin-top:2px}
.lvf .plan{width:118px;height:92px}
.lvf .plan .zoom{width:22px;height:22px;right:4px;bottom:4px}
.lvf .slider-grp input[type=range]{width:100px}
.lvf .tinfo .tname{font-size:16.5px}
.lvf .tinfo .tmeta{font-size:13px;gap:4px 10px;margin-top:4px}
.lvf .tprice .p{font-size:16.5px}
.lvf /* Filterleiste mobil: eingeklappt, .lvf nur Zähler + Filter-Button */
  .filterbar{padding:10px 0}
.lvf .filterbar .wrap{display:flex;flex-direction:column-reverse}
.lvf .filterbar .rows, .lvf .fmeta .right{display:flex;max-height:0;overflow:hidden;opacity:0;margin-top:0;transition:max-height .32s cubic-bezier(.4,0,.2,1),opacity .22s ease,margin-top .32s cubic-bezier(.4,0,.2,1)}
.lvf .filterbar.expanded .rows{max-height:340px;opacity:1;margin-top:12px}
.lvf .filterbar.expanded .fmeta .right{max-height:170px;opacity:1;width:100%;justify-content:space-between;order:3;margin-top:12px}
.lvf .filterbar.expanded .fopen .chev{transform:rotate(180deg)}
.lvf .filterbar.expanded .fmeta{flex-wrap:wrap}
.lvf .fmeta{margin-top:0;flex-wrap:wrap;justify-content:space-between;align-items:center}
.lvf .fcount-suffix{display:none}
.lvf .fc-pre{display:inline}
.lvf .fmeta .count{flex:0 1 auto;min-width:0;font-size:14px}
.lvf .fopen{display:inline-flex;flex:none}
.lvf .fmeta .right{order:3;flex-basis:100%}
.lvf .chip{padding:9px 14px;font-size:14px}}
/* Mount + standalone availability stat (Webflow-Embed) */
.lvf .lv-stat{padding:4px 0 16px}
.lvf .stat{display:inline-flex;align-items:center;gap:10px;background:var(--moss-tint);border:1px solid var(--moss-line);color:var(--moss-deep);border-radius:99px;padding:7px 16px;font-size:14px;font-weight:500}
.lvf .stat .dot{width:8px;height:8px;border-radius:50%;background:var(--moss)}
.lvf .plan-ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted);font-size:12px;text-align:center;padding:10px}
.lvf .unit{display:none!important}

/* ===== Finder-Bühne: Finder nimmt beim Einstieg ~70vh ein ===== */
.lvf .finder{min-height:min(70vh,680px);display:flex;flex-direction:column;justify-content:center}
.lvf .finder h2{font-size:clamp(26px,4.6vw,46px);max-width:680px;line-height:1.15}
.lvf .finder .opts{margin-top:30px;gap:12px}
.lvf .finder .opts button{padding:15px 32px;font-size:17px}
.lvf .finder .meta{margin-top:36px;font-size:14px}
.lvf .finder.done{min-height:0;display:block}

/* ===== Blur-Gate: Liste als verschwommener Teaser mit Overlay ===== */
.lvf .lv-stagewrap{position:relative}
.lvf.gated .results{filter:blur(7px);pointer-events:none;user-select:none;max-height:190vh;overflow:hidden}
.lvf.gated .lv-stagewrap::after{content:"";position:absolute;left:0;right:0;bottom:0;height:220px;background:linear-gradient(180deg,transparent,var(--paper));pointer-events:none}
.lv-gate{position:absolute;inset:0;z-index:6;padding:0 20px}
.lvf .lv-gate-inner{position:sticky;top:0;min-height:100vh;display:flex;align-items:center;justify-content:center}
.lv-gate-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 22px 60px rgba(20,25,35,.18);padding:34px clamp(22px,4vw,46px);max-width:620px;text-align:center}
.lv-gate-card h3{font-family:var(--font-head);font-weight:600;font-size:clamp(20px,2.6vw,27px);line-height:1.25}
.lv-gate-card p{color:var(--muted);margin-top:10px;font-size:15.5px}
.lv-gate-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.lvf .lv-btn{background:var(--moss);color:var(--wf-btn-text,#fff);border-radius:99px;padding:14px 28px;font-size:15px;font-weight:600;transition:background .12s}
.lvf .lv-btn:hover{background:var(--moss-deep)}
.lv-gate-btns .uview{padding:12px 22px;font-size:14.5px}
@media (max-width:680px){
  .lvf .finder{min-height:min(62vh,560px)}
  .lv-gate{padding:0 16px}
  .lv-gate-btns{flex-direction:column}
  .lv-gate-btns .lv-btn,.lv-gate-btns .uview{width:100%;justify-content:center;text-align:center}
}


/* ===== Finder zentriert + dezentes Gebäude-Render im Hintergrund ===== */
.lvf .finder{align-items:center;text-align:center}
.lvf .finder::before{content:"";position:absolute;inset:0;z-index:0;background:var(--finder-bg,url("finder-bg.jpg")) center 28%/cover no-repeat;opacity:.16;pointer-events:none}
.lvf .finder::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,color-mix(in srgb,var(--wf-finder-bg) 30%,transparent),color-mix(in srgb,var(--wf-finder-bg) 70%,transparent));pointer-events:none}
.lvf .finder > *{position:relative;z-index:1}
.lvf .finder .eyebrow,.lvf .finder h2{margin-left:auto;margin-right:auto}
.lvf .finder .opts{flex-direction:column;align-items:center;gap:11px}
.lvf .finder .opts button{min-width:280px}
.lvf .finder .meta{flex-direction:column;align-items:center;gap:14px}
.lvf .finder .fsum{justify-content:center}
.lvf .finder.done::before,.lvf .finder.done::after{opacity:.12}
.lvf .finder.done .fsum .restart{margin-left:0}
/* Gate-Buttons auch am Desktop untereinander, zentriert */
.lvf .lv-gate-btns{flex-direction:column;align-items:center}
.lvf .lv-gate-btns .lv-btn,.lvf .lv-gate-btns .uview{width:100%;max-width:340px;justify-content:center;text-align:center}

/* willhaben-Muster: Zahlen stärker als Label */
.lvf .num{color:var(--ink);font-weight:700;font-size:15px}
.lvf .urow .floor .num{font-size:14.5px}

.lvf .tname .num-h{font-weight:700}
