*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;color:#111}.app{display:grid;grid-template-columns:1fr 380px;grid-template-rows:48px 1fr;height:100vh}.topbar{grid-column:1 / -1}.map-pane{position:relative}.floating-toolbar{position:absolute;top:12px;left:12px;z-index:10;background:#fff}.side{border-left:1px solid #ddd;background:#fafafa;display:flex;flex-direction:column;min-height:0}.side .mantine-Tabs-panel.side-panel{flex:1;overflow-y:auto;min-height:0;padding:12px}.site-card{background:#fff;border:1px solid #ddd;border-radius:6px;padding:12px;margin-bottom:12px}.site-card h3{margin:0 0 4px;font-size:15px}.site-card .meta{font-size:12px;color:#666;margin-bottom:8px}.site-card .back-text{background:#f3f3f3;border:1px dashed #bbb;padding:6px 8px;margin:6px 0;font-family:ui-monospace,monospace;font-size:11px;white-space:pre-wrap}.site-card .cross-area-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:11px;color:#6b4f00;background:#fff8e0;border:1px solid #e8d28a;border-radius:4px;padding:4px 6px;margin-bottom:8px}.site-card .cross-area-label{font-weight:600}.site-card .cross-area-chip{background:#fff;border:1px solid #d8c178;border-radius:3px;padding:1px 6px;white-space:nowrap}.site-card .cross-area-chip strong{text-transform:uppercase;letter-spacing:.04em;font-size:10px}.site-card .cross-area-routes{color:#6b6b6b}.panel-row{display:grid;grid-template-columns:1fr 60px 80px 28px;align-items:center;gap:6px;padding:6px 0;border-top:1px solid #eee;font-size:13px}.panel-row:first-of-type{border-top:none}.panel-row .dest{font-weight:500}.panel-row .km{font-variant-numeric:tabular-nums;text-align:right}.panel-row .color{font-size:11px}.panel-row .routes{font-size:10px;color:#888}.color-tag{display:inline-block;padding:1px 5px;border-radius:3px;font-size:11px;border:1px solid}.color-tag.tre{background:#f5efe0;border-color:#c4a44a;color:#6b4f00}.color-tag.gronn{background:#1f6b3a;border-color:#1f6b3a;color:#fff}.actions{display:flex;gap:6px;margin-top:8px}.actions button{flex:1;background:#fff;border:1px solid #ccc;border-radius:4px;padding:5px 10px;font-size:12px;cursor:pointer}.actions button.primary{background:#1a3a5c;color:#fff;border-color:#1a3a5c}.actions button.danger{color:#a32d2d}.empty{color:#888;font-size:13px;padding:24px;text-align:center}.maplibregl-popup{max-width:240px}.area-report-row:hover{background:#f4f8fc}
