﻿:root {
  --bg-main: #f4f6ee;
  --bg-panel: rgba(255,255,255,0.88);
  --bg-panel-strong: #ffffff;
  --text-main: #14211b;
  --text-soft: #4d5f55;
  --accent: #0c7c59;
  --accent-2: #d96c32;
  --line: #d8dfd7;
  --shadow: 0 10px 35px rgba(15,34,27,0.12);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Space Grotesk","Segoe UI",sans-serif;
  color: var(--text-main);
  background: radial-gradient(circle at 0% 0%,#e7efe4 0%,#f4f6ee 45%),linear-gradient(160deg,#edf2e4 0%,#f7f4ec 100%);
  overflow-x: hidden;
}

.bg-shape { position: fixed; z-index: 0; pointer-events: none; filter: blur(2px); }
.shape-1 { width:36rem;height:36rem;top:-8rem;right:-8rem;border-radius:56% 44% 64% 36% / 54% 61% 39% 46%;background:radial-gradient(circle,rgba(12,124,89,0.18) 0%,rgba(12,124,89,0) 70%);animation:drift1 14s ease-in-out infinite alternate; }
.shape-2 { width:28rem;height:28rem;left:-10rem;bottom:-8rem;border-radius:41% 59% 31% 69% / 59% 39% 61% 41%;background:radial-gradient(circle,rgba(217,108,50,0.16) 0%,rgba(217,108,50,0) 70%);animation:drift2 16s ease-in-out infinite alternate; }
@keyframes drift1 { from{transform:translateY(0) rotate(0deg)} to{transform:translateY(1.5rem) rotate(8deg)} }
@keyframes drift2 { from{transform:translateY(0) rotate(0deg)} to{transform:translateY(-1.4rem) rotate(-7deg)} }

.page {
  position: relative; z-index: 1;
  width: min(1200px,95vw);
  margin: 2rem auto;
  display: grid; gap: 1.4rem;
}

.top, .map-section {
  background: var(--bg-panel);
  border: 1px solid rgba(255,255,255,0.65);
  box-shadow: var(--shadow);
  backdrop-filter: blur(8px);
  border-radius: 1rem;
}

.top { padding: 1.1rem 1rem 1rem; }

.eyebrow { margin:0; text-transform:uppercase; letter-spacing:0.09em; font-size:0.72rem; font-weight:700; color:var(--accent); }
h1 { margin:0.25rem 0 1rem; line-height:1.15; font-family:"Spectral",Georgia,serif; font-size:clamp(1.3rem,2vw,2rem); }

.search-wrap label { display:block; font-size:0.88rem; margin-bottom:0.4rem; color:var(--text-soft); }
.search-row { display:grid; grid-template-columns:1fr auto; gap:0.55rem; }

input[type="search"] { border:1px solid var(--line); border-radius:0.72rem; padding:0.78rem 0.9rem; font:inherit; background:#fff; }
input[type="search"]:focus { outline:2px solid color-mix(in srgb,var(--accent) 55%,white); outline-offset:1px; }

button { border:0; border-radius:0.72rem; padding:0.75rem 0.95rem; font:inherit; font-weight:600; color:white; background:linear-gradient(120deg,var(--accent),#159c72); cursor:pointer; transition:transform 150ms ease,filter 150ms ease; }
button:hover { transform:translateY(-1px); filter:brightness(1.04); }

.search-results { list-style:none; margin:0.55rem 0 0; padding:0; display:grid; gap:0.36rem; max-height:11rem; overflow:auto; }
.search-results li { background:var(--bg-panel-strong); border:1px solid var(--line); border-radius:0.62rem; padding:0.48rem 0.66rem; cursor:pointer; display:flex; justify-content:space-between; gap:0.5rem; }
.search-results li:hover { border-color:var(--accent); }

/* Map section */
.map-section { padding: 0.85rem; }
.map-toolbar { display:flex; align-items:center; gap:0.8rem; margin-bottom:0.75rem; }
.load-status { margin:0; font-size:0.88rem; color:var(--text-soft); font-weight:600; }
.load-status.ready { color:#1f6f4f; }
.load-status.error { color:#b2412d; }

.map-admin-link { margin-left:auto; font-size:0.82rem; font-weight:600; color:var(--accent); text-decoration:none; border:1px solid var(--accent); border-radius:0.55rem; padding:0.28rem 0.65rem; transition:background 150ms,color 150ms; }
.map-admin-link:hover { background:var(--accent); color:white; }

/* Map + panel side by side */
.map-and-panel { display:flex; gap:0; border-radius:0.95rem; overflow:hidden; border:1px solid var(--line); height: min(68vh, 720px); }

#map { flex:1; min-width:0; }

/* Info panel */
.info-panel {
  width: 320px; flex-shrink:0;
  background: var(--bg-panel-strong);
  border-left: 1px solid var(--line);
  overflow-y: auto;
  font-size: 0.88rem;
}

.info-placeholder {
  height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.5rem;
  color: var(--text-soft); padding: 1.5rem; text-align:center;
}
.info-placeholder span { font-size:1.6rem; opacity:0.35; }
.info-placeholder p { margin:0; }

.info-header {
  padding: 1rem 1.1rem 0.8rem;
  border-bottom: 1px solid var(--line);
  background: #f0f7f3;
}
.info-header h3 { margin:0 0 0.15rem; font-size:1.05rem; }
.info-canton { font-size:0.78rem; color:var(--text-soft); letter-spacing:0.04em; }

.info-section {
  padding: 0.7rem 1.1rem;
  border-bottom: 1px solid var(--line);
}
.info-row { display:flex; justify-content:space-between; gap:0.5rem; padding:0.22rem 0; }
.info-label { color:var(--text-soft); font-weight:600; font-size:0.81rem; }

.info-section-title {
  margin: 0; padding: 0.5rem 1.1rem 0.3rem;
  font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em;
  color:var(--text-soft); background:#f9faf7; border-bottom:1px solid var(--line);
}

.contact-card {
  padding: 0.75rem 1.1rem;
  border-bottom: 1px solid var(--line);
}
.contact-card-header { display:flex; align-items:center; gap:0.55rem; margin-bottom:0.45rem; flex-wrap:wrap; }
.role-badge { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; padding:0.18rem 0.48rem; border-radius:999px; }
.badge-brunnmeister { background:#d6f0e6; color:#0c5c42; }
.badge-netzbetreiber { background:#d6e9f8; color:#1a5a8a; }
.contact-name { font-weight:600; font-size:0.9rem; }
.contact-row { display:block; color:var(--accent); text-decoration:none; font-size:0.85rem; padding:0.12rem 0; word-break:break-all; }
.contact-row:hover { text-decoration:underline; }

.info-no-data { padding:1.2rem 1.1rem; color:var(--text-soft); margin:0; }
.info-no-data a { color:var(--accent); }
.info-updated { padding:0.65rem 1.1rem; font-size:0.75rem; color:var(--text-soft); margin:0; border-top:1px solid var(--line); background:#f9faf7; }

/* Legend */
.map-legend { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; margin-top:0.6rem; font-size:0.82rem; color:var(--text-soft); }
.legend-dot { display:inline-block; width:0.9rem; height:0.9rem; border-radius:50%; margin-right:0.28rem; vertical-align:middle; }
.legend-green { background:#22a06b; }
.legend-blue  { background:#5a9fd4; }
.legend-grey  { background:#c0c0c0; }
.legend-border { border-bottom:3px solid #000; padding-bottom:1px; }

@media (max-width: 860px) {
  .map-and-panel { flex-direction:column; height:auto; }
  #map { height:55vh; }
  .info-panel { width:100%; height:auto; border-left:0; border-top:1px solid var(--line); }
  .info-placeholder { height:6rem; }
}

@media (max-width: 600px) {
  .page { margin:0.8rem auto; width:97vw; }
  .map-toolbar { flex-direction:column; align-items:stretch; }
  .map-admin-link { margin-left:0; text-align:center; }
}
