:root{--bg:#f7f8fa;--card:#fff;--text:#0f172a;--muted:#475569;--border:#e5e7eb;--primary:#2563eb;--danger:#dc2626;--shadow:0 10px 30px #0f172a0f;--radius:14px;--sans:system-ui, "Segoe UI", "Microsoft YaHei", sans-serif;--mono:ui-monospace, Consolas, monospace;font:14px/1.55 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%}body{background:var(--bg);margin:0}#app{height:100vh}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.strong{font-weight:600}.app-shell{height:100%;display:flex}.sidebar{box-sizing:border-box;background:var(--card);border-right:1px solid var(--border);width:240px;padding:18px 14px}.brand{border:1px solid var(--border);border-radius:var(--radius);background:#fff;justify-content:center;align-items:center;padding:10px;display:flex}.brand-logo{max-width:140px;height:auto;display:block}.nav{flex-direction:column;gap:8px;margin-top:12px;display:flex}.nav-item{text-align:left;height:40px;color:var(--text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:12px;padding:0 12px}.nav-item:hover{background:#f1f5f9}.nav-item.active{color:#0b2c7f;background:#2563eb14;border-color:#2563eb40}.main{box-sizing:border-box;flex:1;padding:18px;overflow:auto}.page{min-height:calc(100vh - 36px)}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px;display:flex}.page-title{font-size:18px;font-weight:700}.page-subtitle{color:var(--muted);margin-top:4px;font-size:12px}.page-actions{align-items:center;gap:10px;display:flex}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.toolbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-end;gap:12px;padding:14px;display:flex}.toolbar-right{gap:10px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.label{color:var(--muted);font-size:12px}.input{border:1px solid var(--border);height:36px;color:var(--text);background:#fff;border-radius:10px;outline:none;padding:0 10px}.input:focus{border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb1f}.btn{border:1px solid var(--border);height:36px;color:var(--text);cursor:pointer;background:#fff;border-radius:10px;padding:0 12px}.btn:hover{background:#f8fafc}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{color:#0b2c7f;background:#2563eb1a;border-color:#2563eb59}.btn.primary:hover{background:#2563eb24}.btn.danger{color:#7f1d1d;background:#dc262614;border-color:#dc262659}.btn.small{border-radius:9px;height:30px;padding:0 10px;font-size:12px}.btn.full{width:100%}.alert{border:1px solid var(--border);background:#f8fafc;border-radius:12px;margin:12px 14px 0;padding:10px 12px;font-size:12px}.alert.danger{color:#7f1d1d;background:#dc262614;border-color:#dc262659}.toast{color:#166534;text-align:center;background:#16a34a1a;border:1px solid #16a34a59;border-radius:10px;margin:0 14px;padding:8px 12px;font-size:12px;animation:.25s toast-in}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.table-wrap{overflow:auto}.table{border-collapse:collapse;width:100%}.table th,.table td{border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;padding:12px 14px;font-size:13px}.table th{color:var(--muted);background:#fbfcfe;font-size:12px;font-weight:600}.row-actions{gap:8px;display:flex}.modal-mask{box-sizing:border-box;background:#0f172a59;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border);background:#fff;border-radius:16px;width:680px;max-width:100%;box-shadow:0 20px 60px #0f172a2e}.modal-title{padding:14px 16px 0;font-size:16px;font-weight:700}.modal-body{padding:14px 16px 0}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal-footer{justify-content:flex-end;gap:10px;padding:14px 16px 16px;display:flex}.map-layout{grid-template-columns:1fr 360px;gap:12px;display:grid}.map-left{height:calc(100vh - 110px);overflow:hidden}.map-canvas{width:100%;height:100%}.share-page{background:var(--bg);box-sizing:border-box;flex-direction:column;gap:12px;height:100vh;padding:14px;display:flex}.share-page .map-canvas{min-height:300px}.share-topbar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:12px;padding:12px 14px;display:flex}.share-logo{flex-shrink:0;max-width:100px;height:auto;display:block}.share-title{font-size:16px;font-weight:800}.share-subtitle{color:var(--muted);margin-top:4px;font-size:12px}.share-map{flex:1;overflow:hidden}.map-right{box-sizing:border-box;flex-direction:column;height:calc(100vh - 110px);padding:14px;display:flex;overflow:hidden}.panel-title{align-items:center;gap:8px;margin:6px 0 10px;font-size:13px;font-weight:700;display:flex}.panel-form{border-bottom:1px solid var(--border);flex-direction:column;gap:10px;padding-bottom:12px;display:flex}.badge{color:#0b2c7f;background:#2563eb1a;border:1px solid #2563eb40;border-radius:999px;align-items:center;height:20px;padding:0 8px;font-size:12px;font-weight:600;display:inline-flex}.result-list{margin-top:10px;padding-right:2px;overflow:auto}.result-item{text-align:left;border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;width:100%;margin-bottom:10px;padding:10px}.result-item:hover{background:#f8fafc}.result-name{font-size:13px;font-weight:700}.result-meta{align-items:center;gap:8px;margin-top:4px;font-size:12px;display:flex}
