:root{--bg: #0e0f12;--panel: #14161b;--text: #e9e9ee;--muted: #a9a9b6;--border: #242833;--btn: #1f2430;--btn2: #2a3142}*{box-sizing:border-box}html,body{height:100%;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;background:var(--bg);color:var(--text)}.topbar{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--border);background:#0b0c10}.title{font-weight:700;letter-spacing:.4px}.layout{display:grid;grid-template-columns:1.4fr .9fr;gap:12px;height:calc(100% - 52px);padding:12px}#map{border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:320px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column}.row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.row:last-of-type{border-bottom:none}.label{color:var(--muted)}.value{text-align:right}.value.small{font-size:13px;line-height:1.3;white-space:pre-wrap}.actions{display:flex;gap:8px;padding:10px 0;flex-wrap:wrap}.btn{background:var(--btn);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer}.btn:hover{background:var(--btn2)}.btn:disabled{opacity:.5;cursor:not-allowed}.primary{background:#1b3a2a;border-color:#25583f}.primary:hover{background:#224a36}.hint{color:var(--muted);font-size:12px;margin-top:auto}hr{border:none;border-top:1px solid var(--border);margin:12px 0}@media(max-width:900px){.layout{grid-template-columns:1fr}#map{height:55vh}}
