:root {
  --asset-navy: #061f3a;
  --asset-blue: #0b66c3;
  --asset-cyan: #20b8ff;
  --asset-green: #20b486;
  --asset-orange: #f29d38;
  --page: #f3f7fb;
  --card: #ffffff;
  --text: #132238;
  --muted: #66758a;
  --border: #dbe5f0;
  font-family: Inter, Segoe UI, Arial, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--page); color: var(--text); }
button, select, input { font: inherit; }
button { border: 0; border-radius: 999px; padding: 10px 16px; background: var(--asset-blue); color: white; font-weight: 700; cursor: pointer; }
button.secondary { background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25); }
button.small { padding: 7px 12px; font-size: 12px; }
select, input { border: 1px solid var(--border); border-radius: 12px; padding: 11px 12px; background: white; min-width: 160px; }
.app-header { height: 76px; display:flex; align-items:center; justify-content:space-between; padding: 12px 22px; background: linear-gradient(135deg, var(--asset-navy), #0b3561); color: white; box-shadow: 0 8px 24px rgba(6,31,58,0.22); }
.brand-block, .login-brand { display:flex; align-items:center; gap: 14px; }
.brand-mark { width:42px; height:42px; border-radius:14px; display:grid; place-items:center; font-weight:900; background: linear-gradient(135deg, var(--asset-cyan), var(--asset-blue)); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.3); }
.brand-mark.large { width:64px; height:64px; border-radius:22px; font-size: 22px; }
.eyebrow { text-transform:uppercase; letter-spacing:.16em; font-size:11px; color:#9fe0ff; font-weight:800; }
h1 { margin:0; font-size:28px; line-height:1; }
h2 { margin: 0 0 12px; font-size:16px; color: var(--asset-navy); }
.header-actions { display:flex; align-items:center; gap:10px; }
.status, .user-pill { border-radius:999px; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2); padding: 8px 12px; font-size: 12px; }
.layout { height: calc(100vh - 76px); display:grid; grid-template-columns: minmax(0,1fr) 380px; gap:16px; padding:16px; }
.map-card, .side-panel, .login-panel { background: var(--card); border: 1px solid var(--border); border-radius:24px; box-shadow: 0 14px 34px rgba(35,65,95,0.12); }
.map-card { min-height: 0; display:flex; flex-direction:column; overflow:hidden; }
.map-toolbar { display:flex; gap:10px; padding:12px; border-bottom: 1px solid var(--border); align-items:center; background:#fbfdff; }
#map { flex:1; min-height: 420px; }
.side-panel { padding:16px; overflow:auto; }
.summary-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px; }
.summary-grid div { border-radius:18px; padding:15px; background: linear-gradient(180deg,#f8fbff,#eef6ff); border:1px solid var(--border); }
.summary-grid b { display:block; font-size:27px; color:var(--asset-blue); }
.summary-grid span { color:var(--muted); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.list { display:grid; gap:10px; margin-bottom:20px; }
.item { border:1px solid var(--border); background:#fff; border-radius:16px; padding:12px; display:flex; flex-wrap:wrap; gap:7px; align-items:center; }
.item strong { width:100%; color:var(--asset-navy); }
.item small { width:100%; color:var(--muted); }
.chip { border-radius:999px; background:#eaf3ff; color:var(--asset-blue); padding:4px 8px; font-size:12px; font-weight:800; }
.chip.orange { background:#fff1dc; color:#a85d00; }
.chip.green { background:#e3fbf3; color:#147c60; }
.login-page { min-height:100vh; background: radial-gradient(circle at top left, #0f77c7, transparent 34%), linear-gradient(135deg, #061f3a 0%, #0d2c4d 60%, #071827 100%); color:white; display:grid; place-items:center; padding:24px; }
.login-wrap { width:min(520px, 100%); }
.login-panel { padding:30px; background: rgba(255,255,255,0.97); color:var(--text); }
.login-brand { padding-bottom:24px; border-bottom:1px solid var(--border); margin-bottom:22px; }
.login-brand h1 { color:var(--asset-navy); margin-bottom: 8px; }
.login-brand p { margin:0; color:var(--muted); }
.login-form { display:grid; gap:10px; }
.login-form label { font-weight:800; color:var(--asset-navy); font-size:13px; }
.login-form input, .login-form select { width:100%; }
.login-button { margin-top:8px; padding:13px 16px; }
.login-status { min-height:24px; color:var(--muted); font-size:13px; }
.login-status.error { color:#b3261e; font-weight:800; }
.login-footer { text-align:center; margin-top:16px; color:rgba(255,255,255,0.75); font-size:13px; }
@media (max-width: 980px) {
  .app-header { height:auto; align-items:flex-start; gap:12px; flex-direction:column; }
  .layout { height:auto; min-height: calc(100vh - 120px); grid-template-columns:1fr; }
  .side-panel { max-height:none; }
}
