html, body { height: 100%; margin: 0; font-family: Arial, sans-serif; }
#map { position: fixed; left: 320px; top: 0; right: 0; bottom: 0; background: #151515; }
#sidebar { position: fixed; left: 0; top: 0; bottom: 0; width: 290px; padding: 15px; background: #f5f1e8; border-right: 1px solid #ccc; overflow:auto; z-index: 1000; }
h1 { margin: 0 0 12px; font-size: 22px; }
select,input,button,textarea { width:100%; box-sizing:border-box; padding:8px; margin: 6px 0; }
button { cursor:pointer; }
.filter { display:block; margin: 8px 0; }
.result { padding: 8px; border-bottom: 1px solid #ddd; cursor:pointer; }
.result:hover { background:#fff; }
.small { font-size: 12px; color:#666; }
.admin-wrap { max-width: 1100px; margin: 20px auto; padding: 0 15px; }
.nav a { margin-right: 12px; }
table { width:100%; border-collapse: collapse; margin: 12px 0; }
th,td { padding: 8px; border:1px solid #ddd; text-align:left; }
.notice { padding:10px; background:#fff3cd; border:1px solid #ffe69c; margin:10px 0; }
.ok { background:#d1e7dd; border-color:#badbcc; }
.error { background:#f8d7da; border-color:#f5c2c7; }
#adminMap { height: 640px; background:#151515; }
.leaflet-marker-icon.os-marker { border-radius:50%; border:2px solid #111; box-shadow:0 1px 4px rgba(0,0,0,.4); }
.progress-wrap{width:100%;background:#ddd;border-radius:6px;overflow:hidden;margin:12px 0;height:26px}
.progress-bar{height:26px;line-height:26px;text-align:center;background:#2b3260;color:#fff;transition:width .2s ease;font-size:13px}
.logbox{background:#111;color:#ddd;padding:10px;border-radius:6px;max-height:260px;overflow:auto;white-space:pre-wrap;font-size:12px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.notice.error{background:#ffe5e5;border-color:#b00020;color:#6b0000}
.notice.ok{background:#e5ffe8;border-color:#1f7a2e;color:#14551f}
