:root{
  --brand:#a4144a;
  --brand-dark:#7d0f39;
  --green:#56ae31;
  --blue:#00a7dc;
  --ink:#222;
  --bg:#f4f4f3;
  --card:#fff;
  --shadow:0 4px 16px rgba(0,0,0,.18);
  --topbar-h:56px;
  --filterbar-h:76px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);}
body{overflow:hidden;-webkit-tap-highlight-color:transparent;}

/* Welcome-Splash */
.splash{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:rgba(0,0,0,.55);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:1;transition:opacity .4s ease;
}
.splash.hide{opacity:0;pointer-events:none;}
.splash-card{
  width:100%;max-width:380px;
  background:var(--card);border-radius:24px;
  box-shadow:0 12px 40px rgba(0,0,0,.35);
  padding:32px 28px 28px;text-align:center;
  animation:splash-in .45s cubic-bezier(.22,.61,.36,1) both;
}
@keyframes splash-in{
  from{opacity:0;transform:translateY(16px) scale(.96);}
  to{opacity:1;transform:none;}
}
.splash-logo{width:180px;max-width:70%;height:auto;display:block;margin:0 auto 20px;}
.splash-title{
  margin:0 0 12px;font-size:22px;line-height:1.25;font-weight:700;color:var(--ink);
}
.splash-text{
  margin:0 0 24px;font-size:15px;line-height:1.55;color:#555;
}
.splash-btn{
  display:inline-block;width:100%;
  background:var(--brand);color:#fff;border:0;
  padding:14px 24px;border-radius:30px;
  font-size:16px;font-weight:600;cursor:pointer;
  box-shadow:0 4px 14px rgba(164,20,74,.35);
  transition:background .15s ease;
}
.splash-btn:active{background:var(--brand-dark);}

@media (prefers-reduced-motion: reduce){
  .splash,.splash-card{animation:none;transition:none;}
}

/* Topbar */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:30;
  background:var(--brand);color:#fff;display:flex;align-items:center;
  padding:0 8px;gap:8px;box-shadow:0 2px 12px rgba(0,0,0,.28),0 1px 0 rgba(0,0,0,.08);
}
.title-wrap{flex:1;display:flex;align-items:center;justify-content:center;line-height:1;}
.topbar-logo{height:34px;width:auto;max-width:70%;display:block;}
.icon-btn{
  background:transparent;border:0;color:inherit;cursor:pointer;text-decoration:none;
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:18px;line-height:1;flex:none;
}
.icon-btn:active{background:rgba(255,255,255,.18);}
/* Filter-Dot: sichtbar wenn ein Filter aktiv ist */
#searchBtn{position:relative;}
#searchBtn.has-filter::after{
  content:"";position:absolute;top:6px;right:6px;
  width:8px;height:8px;border-radius:50%;
  background:#ffd400;border:1.5px solid var(--brand);
}

/* Map */
.map-viewport{
  position:fixed;top:var(--topbar-h);left:0;right:0;bottom:0;
  overflow:hidden;background:#e9e7e2;touch-action:none;cursor:grab;
}
.map-viewport:active{cursor:grabbing;}
.map-canvas{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform;}
#mapImg{display:block;width:100%;height:auto;user-select:none;pointer-events:none;}
.marker-layer{position:absolute;inset:0;}

/* Marker */
.marker{
  position:absolute;transform:translate(-50%,-50%);
  width:26px;height:26px;border-radius:50%;
  border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-weight:700;color:#fff;cursor:pointer;line-height:1;padding:0;
  transition:transform .08s ease;
  touch-action:none;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none;
}
.marker .m-label{display:inline-block;white-space:nowrap;transform-origin:center;font-size:11px;}
.marker:active{transform:translate(-50%,-50%) scale(1.15);}
.marker.aussteller{background:var(--green);}
.marker.speisen{background:var(--brand);}
.marker.attraktion{background:var(--blue);}
.marker.service{background:#6b7280;}
.marker.dim{opacity:.18;pointer-events:none;}
.marker.active{outline:3px solid #ffd400;z-index:5;transform:translate(-50%,-50%) scale(1.25);}

/* Speisen: etwas größer, Gabel/Messer-Icon über dem Text */
.marker.speisen{width:36px;height:36px;gap:1px;}
.marker.speisen .m-icon{
  width:15px;height:15px;background:#fff;
  -webkit-mask:url(eating.svg) center/contain no-repeat;mask:url(eating.svg) center/contain no-repeat;
}
.marker.speisen .m-label{font-size:9px;}

/* Symbole (Erste Hilfe, WC, Parken): quadratisch, weiße Outline, eigener Look */
.marker.symbol{border-radius:7px;border:2px solid #fff;}
.marker.symbol .m-label{color:#fff;font-weight:800;}

/* Erste Hilfe: weißes Quadrat mit rotem Kreuz */
.marker.erstehilfe{width:32px;height:32px;background:#fff;}
.marker.erstehilfe .m-icon{
  width:19px;height:19px;background:#e11900;
  clip-path:polygon(38% 0,62% 0,62% 38%,100% 38%,100% 62%,62% 62%,62% 100%,38% 100%,38% 62%,0 62%,0 38%,38% 38%);
}

/* WC: dunkelgraues, um 45° gekipptes Quadrat (Raute), weißer Text aufrecht */
.marker.wc{width:34px;height:34px;background:transparent;border:0;box-shadow:none;}
.marker.wc::before{
  content:"";position:absolute;inset:2px;background:#4b5563;
  border:2px solid #fff;border-radius:6px;transform:rotate(45deg);
  box-shadow:0 1px 4px rgba(0,0,0,.4);
}
.marker.wc .m-label{position:relative;z-index:1;font-size:11px;}
/* Auswahl-Outline auf die gedrehte Raute legen (statt aufs achsenparallele Quadrat) */
.marker.wc.active{outline:none;}
.marker.wc.active::before{outline:3px solid #ffd400;outline-offset:2px;}

/* Fahrradparkplatz: blaues Quadrat, weißes „P" */
.marker.parken{width:30px;height:30px;background:#0a7bd0;}
.marker.parken .m-label{font-size:15px;}

/* Attraktion: Stern/Seal-Form, etwas größer, ohne Rand */
.marker.attraktion{
  --star:polygon(50.0% 0.0%, 60.1% 12.3%, 75.0% 6.7%, 77.6% 22.4%, 93.3% 25.0%, 87.7% 39.9%, 100.0% 50.0%, 87.7% 60.1%, 93.3% 75.0%, 77.6% 77.6%, 75.0% 93.3%, 60.1% 87.7%, 50.0% 100.0%, 39.9% 87.7%, 25.0% 93.3%, 22.4% 77.6%, 6.7% 75.0%, 12.3% 60.1%, 0.0% 50.0%, 12.3% 39.9%, 6.7% 25.0%, 22.4% 22.4%, 25.0% 6.7%, 39.9% 12.3%);
  width:40px;height:40px;border:0;box-shadow:none;border-radius:0;background:transparent;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.45));
}
/* Zweischichtiger Stern: weiße Outline (::before) + blauer Stern darüber (::after) */
.marker.attraktion::before,
.marker.attraktion::after{content:"";position:absolute;clip-path:var(--star);}
.marker.attraktion::before{inset:0;background:#fff;}
.marker.attraktion::after{inset:2px;background:var(--blue);}
.marker.attraktion .m-label{position:relative;z-index:1;font-size:10px;}
.marker.attraktion.active{outline:0;}

/* Zoom controls */
.zoom-controls{
  position:fixed;right:12px;bottom:calc(var(--filterbar-h) + 16px);z-index:25;
  display:flex;flex-direction:column;gap:8px;
}
.icon-btn.round{
  width:44px;height:44px;color:var(--ink);
  border-radius:50%;font-size:24px;font-weight:600;
  background:rgba(255,255,255,.80);
  -webkit-backdrop-filter:blur(16px) saturate(1.6);backdrop-filter:blur(16px) saturate(1.6);
  border:1px solid rgba(255,255,255,.5);
  box-shadow:0 4px 16px rgba(0,0,0,.14),0 1px 0 rgba(255,255,255,.6) inset;
}
.icon-btn.round:active{background:rgba(240,240,240,.85);}

/* Filterbar */
.filterbar{
  position:fixed;left:12px;right:12px;bottom:10px;z-index:25;
  height:auto;min-height:56px;
  border-radius:20px;
  background:rgba(255,255,255,.78);
  -webkit-backdrop-filter:blur(22px) saturate(1.8);backdrop-filter:blur(22px) saturate(1.8);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 8px 30px rgba(0,0,0,.16),0 1px 0 rgba(255,255,255,.55) inset;
  display:flex;align-items:center;
  padding:8px 10px;gap:6px;
}
.fb-btn{
  flex:1;min-width:0;
  background:#f4f4f4;border:1.5px solid #e8e8e8;border-radius:14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:8px 4px;
  font-size:10.5px;font-weight:600;color:#999;
  cursor:pointer;line-height:1;
  transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .18s ease;
  -webkit-tap-highlight-color:transparent;
}
.fb-btn:active{transform:scale(.93);}
.fb-dot{
  width:16px;height:16px;border-radius:50%;
  background:var(--fb-clr,#ccc);opacity:.65;flex:none;
}
.fb-dot.all{background:linear-gradient(135deg,var(--green) 50%,var(--brand) 50%);opacity:.75;}
.fb-btn.active{
  background:var(--fb-clr,var(--brand));border-color:var(--fb-clr,var(--brand));
  color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.2);
}
.fb-btn.active .fb-dot{background:rgba(255,255,255,.3);opacity:1;}
.fb-btn.active .fb-dot.all{background:rgba(255,255,255,.3);}

/* Aktiver-Filter-Pill (ersetzt die Buttons wenn ein Filter gesetzt ist) */
.fb-pill{
  display:flex;align-items:center;width:100%;
  background:rgba(164,20,74,.07);border:1.5px solid rgba(164,20,74,.28);border-radius:14px;
  padding:8px 8px 8px 14px;gap:10px;
}
.fb-pill-inner{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.fb-pill-header{font-size:10px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.04em;}
.fb-pill-value{font-size:14px;font-weight:700;color:var(--brand);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fb-pill-clear{
  background:var(--brand);border:0;color:#fff;
  width:34px;height:34px;border-radius:50%;
  font-size:16px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex:none;
  -webkit-tap-highlight-color:transparent;
}
.fb-pill-clear:active{background:var(--brand-dark);transform:scale(.9);}

/* Panel */
.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:40;}
.panel{
  position:fixed;top:0;left:0;bottom:0;width:88%;max-width:380px;z-index:50;
  background:var(--card);box-shadow:var(--shadow);transform:translateX(-105%);
  transition:transform .25s ease;display:flex;flex-direction:column;
}
.panel.open{transform:translateX(0);}
.panel-head{display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;background:var(--brand);color:#fff;}
.panel-body{padding:12px 14px;overflow-y:auto;flex:1;}
#searchInput{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:10px;font-size:16px;margin-bottom:12px;}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.chip{
  border:1px solid #ddd;background:#fafafa;border-radius:18px;padding:7px 12px;font-size:13px;cursor:pointer;color:var(--ink);
}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand);}
.type-chip{display:inline-flex;align-items:center;gap:7px;}
.type-chip::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--chip-dot,transparent);box-shadow:0 0 0 1px rgba(0,0,0,.12);}
.type-chip:not([style*="--chip-dot"])::before{display:none;}

/* Panel section labels & dividers */
.ps-label{font-size:11px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.05em;padding:10px 0 5px;margin:0;}
.ps-count{font-size:11px;font-weight:400;text-transform:none;letter-spacing:0;color:#bbb;margin-left:5px;}
.ps-divider{height:1px;background:#ebebeb;margin:4px -14px 0;}
#gewerkSection[hidden]{display:none;}

.chip-hidden{display:none;}
.chips-toggle{
  background:none;border:0;padding:2px 0 8px;margin:0;
  font-size:12px;font-weight:600;color:var(--brand);cursor:pointer;
  -webkit-tap-highlight-color:transparent;display:block;
}
.chips-toggle:active{opacity:.65;}

.result-list{display:flex;flex-direction:column;gap:6px;}
.result-item{
  display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #eee;border-radius:10px;cursor:pointer;background:#fff;
  text-align:left;width:100%;color:var(--ink);
}
.result-text{flex:1;min-width:0;}
.result-item:active{background:#f6f6f6;}
.result-badge{flex:none;width:30px;height:30px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;}
.result-text b{display:block;font-size:14px;}
.result-text span{font-size:12px;color:#666;}
.result-empty{color:#888;font-size:14px;padding:10px 2px;}

/* Bottom sheet */
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:45;
  background:rgba(255,255,255,.88);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);backdrop-filter:blur(24px) saturate(1.6);
  border:1px solid rgba(255,255,255,.5);
  border-radius:18px 18px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.18);
  transform:translateY(110%);opacity:0;
  transition:transform .32s cubic-bezier(.22,.61,.36,1), opacity .32s ease;
  padding:8px 18px calc(env(safe-area-inset-bottom,0) + 20px);max-height:60%;overflow-y:auto;
}
.sheet.open{transform:translateY(0);opacity:1;}
/* Sanfter Übergang beim Wechsel zur nächsten Karte (Sheet bleibt offen) */
.sheet-content{transition:opacity .15s ease, transform .15s ease;}
.sheet-content.swapping{opacity:0;transform:translateY(10px);}
.sheet-handle{
  width:60px;height:5px;background:#ccc;border-radius:3px;margin:0 auto;
  padding:11px 40px;background-clip:content-box;box-sizing:content-box;
  touch-action:none;cursor:grab;
}
.sheet-handle:active{cursor:grabbing;}
.sheet-content h2{margin:0 0 4px;font-size:20px;}
.sheet-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#fff;padding:4px 10px;border-radius:14px;margin-bottom:10px;}
.sheet-kat{color:var(--brand);font-weight:600;font-size:13px;margin:2px 0 8px;}
.sheet-desc{font-size:15px;line-height:1.45;color:#333;}
.sheet-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}
.sheet-tag{font-size:12px;background:#f0eef0;color:#555;padding:4px 10px;border-radius:14px;}
.sheet-close{position:absolute;top:10px;right:14px;background:#eee;border:0;color:var(--ink);width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;}

@media (prefers-reduced-motion: reduce){
  .map-canvas,.sheet,.sheet-content{transition:none !important;}
}

@media (min-width:700px){
  .panel{border-radius:0 14px 14px 0;}
  .sheet{
    left:auto;right:16px;bottom:16px;width:360px;border-radius:14px;max-height:70%;
    transform:translateY(20px);opacity:0;pointer-events:none;
    transition:transform .25s ease,opacity .25s ease;
    border-bottom:1px solid rgba(255,255,255,.5);
  }
  .sheet.open{transform:translateY(0);opacity:1;pointer-events:auto;}
}
