html, body.kart-mode { height: 100vh; overflow: hidden; margin: 0; padding: 0; }
body.kart-mode main.kart-map-wrap { max-width: none; padding: 0; margin: 0; width: 100%; }
.kart-shell { display: grid; grid-template-columns: 380px 1fr; height: 100vh; width: 100vw; }

.kart-panel { display: flex; flex-direction: column; border-right: 1px solid var(--line); background: var(--bg); min-width: 0; }
.kart-head { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.25rem; border-bottom: 1px solid var(--line); }
.kart-head .logo { font-size: 1.1rem; }
.kart-nav { display: flex; gap: 1rem; font-size: .85rem; }
.kart-nav a { color: var(--muted); text-decoration: none; padding: .25rem .5rem; border-radius: 6px; }
.kart-nav a:hover { color: var(--ink); }
.kart-nav a.active { color: var(--accent); background: var(--accent-soft); }

.kart-search { padding: 1rem 1.25rem; border-bottom: 1px solid var(--line); position: relative; }
.kart-search .search-wrap { position: relative; }
.kart-search input { width: 100%; padding: .6rem 1rem; border: 1px solid var(--line); border-radius: 10px; font: inherit; background: var(--bg-alt); color: var(--ink); }
.kart-search input:focus { outline: none; border-color: var(--accent); }

.panel-body { flex: 1; overflow-y: auto; padding: 1.25rem; }
.panel-empty { color: var(--muted); font-size: .9rem; line-height: 1.6; }
.panel-empty strong { color: var(--ink); font-weight: 500; display: block; margin-bottom: .5rem; }
.panel-empty p { margin-bottom: .75rem; }

.panel-prop h2 { font-family: "Fraunces", serif; font-weight: 500; font-size: 1.6rem; letter-spacing: -0.02em; margin-bottom: .25rem; }
.panel-prop .sub { color: var(--muted); font-size: .85rem; margin-bottom: 1rem; }
.panel-prop .mn { font-family: ui-monospace, Menlo, monospace; color: var(--accent); font-size: .8rem; }
.panel-stats { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-bottom: 1.25rem; }
.panel-stat { padding: .85rem 1rem; border: 1px solid var(--line); border-radius: 10px; background: var(--bg-alt); }
.panel-stat .l { font-size: .7rem; color: var(--dim); letter-spacing: .1em; text-transform: uppercase; margin-bottom: .2rem; }
.panel-stat .v { font-family: "Fraunces", serif; font-size: 1.25rem; letter-spacing: -0.015em; }

.panel-kv { border: 1px solid var(--line); border-radius: 10px; overflow: hidden; margin-bottom: 1.25rem; }
.panel-kv .row { display: grid; grid-template-columns: 1fr 1fr; padding: .7rem 1rem; border-bottom: 1px solid var(--line-soft); font-size: .85rem; }
.panel-kv .row:last-child { border-bottom: none; }
.panel-kv .k { color: var(--muted); }
.panel-kv .v { text-align: right; font-weight: 500; }
.panel-kv .v.mono { font-family: ui-monospace, Menlo, monospace; font-size: .8rem; }
.panel-kv .v.dim { color: var(--dim); font-weight: 400; }

.panel-cta { display: block; width: 100%; text-align: center; padding: .7rem; background: var(--accent); color: var(--bg); border: 1px solid var(--accent); border-radius: 10px; font: inherit; font-weight: 500; cursor: pointer; text-decoration: none; }
.panel-cta:hover { filter: brightness(1.08); }

.panel-notice { padding: 1rem; border: 1px dashed var(--line); border-radius: 10px; color: var(--muted); font-size: .82rem; line-height: 1.5; margin-bottom: 1.25rem; }
.panel-notice strong { color: var(--ink); font-weight: 500; }

.kart-foot { padding: .75rem 1.25rem; border-top: 1px solid var(--line); color: var(--dim); font-size: .72rem; }

.kart-map-wrap { position: relative; min-width: 0; height: 100vh; }
.kart-map-wrap #map { position: absolute; inset: 0; height: 100%; width: 100%; filter: none; }
.kart-map-wrap .leaflet-container { background: #e9e3d3; cursor: crosshair; }

.kart-legend { position: absolute; bottom: 1rem; left: 1rem; background: rgba(14,13,11,.82); backdrop-filter: blur(8px); color: var(--muted); font-size: .72rem; padding: .6rem .85rem; border: 1px solid var(--line); border-radius: 12px; display: grid; grid-template-columns: auto auto; gap: .35rem 1rem; z-index: 400; max-width: 280px; }
.kart-legend div { display: flex; align-items: center; gap: .45rem; }
.kart-legend .sw { display: inline-block; width: 14px; height: 3px; border-radius: 2px; flex-shrink: 0; }
.kart-legend .sw-grunn { background: #e85d3b; }
.kart-legend .sw-jord { background: #3a9b3a; }
.kart-legend .sw-anlegg { background: #8a5ccc; }
.kart-legend .sw-marker { background: var(--accent); width: 8px; height: 8px; border-radius: 999px; }
.kart-legend .sw-high { background: #ffd966; height: 2px; box-shadow: 0 0 6px rgba(255,217,102,.7); }

.leaflet-control-layers { background: rgba(14,13,11,.9) !important; backdrop-filter: blur(8px); color: var(--ink) !important; border: 1px solid var(--line) !important; border-radius: 10px !important; padding: .5rem .65rem !important; font-family: "Inter", sans-serif; font-size: .8rem; }
.leaflet-control-layers label { color: var(--ink); }
.leaflet-control-layers-separator { border-top-color: var(--line) !important; }

.highlight-overlay img { filter: drop-shadow(0 0 4px rgba(255,217,102,.5)) drop-shadow(0 0 10px rgba(255,217,102,.3)); pointer-events: none; }

@media (max-width: 900px) {
  html, body.kart-mode { height: auto; overflow: auto; }
  .kart-shell { grid-template-columns: 1fr; grid-template-rows: auto auto; height: auto; min-height: 100vh; }
  .kart-panel { border-right: none; border-bottom: 1px solid var(--line); max-height: none; min-height: 40vh; }
  .kart-map-wrap { height: 60vh; }
  .kart-map-wrap #map { height: 60vh; position: relative; }
  .kart-legend { position: absolute; bottom: .5rem; left: .5rem; font-size: .65rem; padding: .4rem .6rem; grid-template-columns: 1fr; gap: .2rem .5rem; max-width: 180px; }
}

@media (max-width: 480px) {
  .kart-head { padding: .75rem 1rem; }
  .kart-search { padding: .75rem 1rem; }
  .panel-body { padding: 1rem; }
  .panel-stats { grid-template-columns: 1fr; gap: .5rem; }
  .kart-map-wrap { height: 55vh; }
  .kart-map-wrap #map { height: 55vh; }
  .leaflet-control-layers { font-size: .72rem !important; }
}
