/* styles.css – v9.4 (komplett, kompakt) */
:root{
    --bg:#fff; --text:#111827; --muted:#6b7280; --line:#e5e7eb;
    --panel:#f9fafb; --brand:#dc2626; --radius:8px; --shadow:0 4px 16px rgba(0,0,0,.08)
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font:14px/1.4 system-ui,-apple-system,Segoe UI,Roboto;color:var(--text);background:var(--bg)}

.topbar{height:52px;display:flex;align-items:center;gap:10px;padding:0 12px;border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700}
.topbar .searchbar{display:flex;gap:6px;margin-left:auto}
.topbar input{width:280px;max-width:45vw;padding:6px 10px;border:1px solid var(--line);border-radius:var(--radius);font-size:13px}
.topbar input:focus{border-color:#cbd5e1;box-shadow:0 0 0 2px rgba(203,213,225,.5)}

.btn{border:1px solid var(--brand);background:var(--brand);color:#fff;padding:6px 10px;border-radius:var(--radius);cursor:pointer;font-size:13px}
.btn:hover{filter:brightness(.95)}
.btn.outline{background:#fff;color:var(--brand)}
.btn.danger{background:#fff;border-color:#991b1b;color:#991b1b}
.tool{border:1px solid var(--line);background:#fff;border-radius:6px;padding:4px 6px;cursor:pointer;font-size:13px}
.tool:hover{background:#fafafa}
.toolrow{display:flex;flex-wrap:wrap;gap:4px}

.layout{display:grid;grid-template-columns:280px 1fr;height:calc(100vh - 52px)}
.sidebar{overflow:auto;border-right:1px solid var(--line);background:#fff;padding:4px 0}
.mapwrap{position:relative} #map{position:absolute;inset:0}

.panel{border-bottom:1px solid var(--line);margin-bottom:4px}
.panel .head{padding:8px 12px;font-weight:700;font-size:13px;background:var(--panel);border-bottom:1px solid var(--line)}
.panel .body{padding:8px 12px}
.panel .body.compact .toolrow{gap:4px}
.row{display:grid;grid-template-columns:110px 1fr;gap:6px;align-items:center;margin-bottom:6px}
label{color:var(--muted);font-size:13px}
.hint{color:var(--muted);font-size:12px;margin-top:4px}
input[type="text"],input[type="number"],select{width:100%;padding:6px 8px;font-size:13px;border:1px solid var(--line);border-radius:var(--radius)}
input[type="text"]:focus,input[type="number"]:focus,select:focus{border-color:#cbd5e1;box-shadow:0 0 0 2px rgba(203,213,225,.4)}
input[type="color"]{width:100%;height:30px;padding:0;border:1px solid var(--line);border-radius:var(--radius)}

.accordion details{border:1px solid var(--line);border-radius:10px;margin-bottom:6px;background:#fff;overflow:hidden;box-shadow:var(--shadow)}
.accordion summary{cursor:pointer;padding:8px 10px;background:#fff;font-weight:600;font-size:13px;list-style:none}
.accordion summary::-webkit-details-marker{display:none}
.palette{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px;background:#fff}
.pal{border:1px solid var(--line);border-radius:10px;padding:6px;display:flex;flex-direction:column;align-items:center;gap:4px}
.pal img{width:28px;height:28px}
.pal .small{font-size:11px;color:var(--muted);text-align:center}

.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:5000}
.modal.open{display:flex}
.modal__box{width:min(560px,92vw);background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal__head{padding:10px 14px;font-weight:700;border-bottom:1px solid var(--line)}
.modal__body{padding:10px 14px}
.modal__foot{padding:8px 14px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}

.lk-label{background:rgba(255,255,255,.92);color:#111;border:1px solid rgba(0,0,0,.2);padding:2px 5px;border-radius:5px;font-weight:700;font-size:12px;pointer-events:none}
.lk-route{background:rgba(255,255,255,.85);color:#065f46;border:1px solid rgba(6,95,70,.25);padding:2px 5px;border-radius:5px;font-weight:700;font-size:12px;pointer-events:none}

.hr{border:none;border-top:1px solid var(--line);margin:8px 0}
.addrlist{max-height:280px;overflow:auto;border:1px solid var(--line);border-radius:10px}
#addrTable{width:100%;border-collapse:collapse;font-size:13px}
#addrTable th,#addrTable td{border-bottom:1px solid var(--line);padding:6px}
#addrTable td:last-child{text-align:right}

.leaflet-bar a,.leaflet-bar a:hover{background:#fff;border-bottom:1px solid var(--line);color:#333;font-size:13px}
.leaflet-bar{border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}

@media(max-width:960px){.layout{grid-template-columns:240px 1fr}}
@media(max-width:760px){
    .layout{grid-template-columns:1fr}
    .sidebar{height:300px;border-right:none;border-bottom:1px solid var(--line)}
    .mapwrap{height:calc(100vh - 52px - 300px)}
    .topbar .searchbar input{max-width:40vw}
}
/* Modal immer über Leaflet */
.modal-backdrop { z-index: 3000 !important; }
.modal-backdrop .modal { display:block; opacity:1; }
/* Falls ein fremdes CSS .modal {display:none} setzt */