:root{--bg:#fff8f0;--panel:#ffffffcc;--mint:#b7e4c7;--mint2:#95d5b2;--blue:#a2d2ff;--pink:#ffc8dd;--yellow:#ffe8a3;--text:#264653;--muted:#607d8b;--danger:#ef476f;--good:#2a9d8f;--shadow:0 18px 50px rgba(38,70,83,.13);--radius:28px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--text);background:linear-gradient(135deg,#fff8f0,#f1fbf7 45%,#eaf6ff);min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;background:#ffffffb8;backdrop-filter:blur(16px);position:sticky;top:0;z-index:1000;box-shadow:0 6px 22px rgba(38,70,83,.08)}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);font-weight:900;font-size:22px}.logo{width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,var(--mint),var(--blue));display:grid;place-items:center;box-shadow:var(--shadow)}.nav{display:flex;gap:10px;flex-wrap:wrap}.hero{max-width:1120px;margin:34px auto;padding:28px;display:grid;grid-template-columns:1.1fr .9fr;gap:24px}.card,.install-card{background:var(--panel);border:1px solid #fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}.install-card{max-width:760px;margin:40px auto}h1{font-size:clamp(34px,5vw,62px);line-height:1.02;margin:0 0 14px}h2{margin:0 0 14px}.lead{font-size:20px;color:var(--muted);line-height:1.55}.btn,button{appearance:none;border:0;border-radius:18px;background:#eef8f5;color:var(--text);padding:12px 16px;text-decoration:none;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.btn.primary,button.primary{background:linear-gradient(135deg,var(--mint2),var(--blue));color:#123}.btn.danger,button.danger{background:var(--danger);color:white}.btn.warn{background:var(--yellow)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.form-grid{display:grid;gap:14px}label{font-weight:800;color:var(--muted)}input,select,textarea{width:100%;margin-top:7px;border:2px solid #e1f0ed;border-radius:16px;padding:13px 14px;font-size:16px;background:white;color:var(--text)}.full{width:100%}.alert{padding:14px;border-radius:18px;margin:12px 0}.alert.good{background:#d8f3dc}.alert.bad{background:#ffd6df}.codebox{padding:18px;border-radius:18px;background:#eef8f5;font-size:20px}.map-wrap{height:calc(100vh - 86px);display:grid;grid-template-columns:330px 1fr;gap:14px;padding:14px}.side{overflow:auto}.member{display:flex;gap:12px;align-items:center;padding:12px;border-radius:20px;background:white;margin-bottom:10px;border:1px solid #edf6f2}.member img{width:48px;height:48px;border-radius:18px;object-fit:cover}.member b{display:block}.muted{color:var(--muted);font-size:13px}.map{min-height:480px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:6px solid white}.leaflet-popup-content{font-family:Inter,system-ui}.pulse{animation:pulse 1.4s infinite}@keyframes pulse{50%{transform:scale(1.02)}}.footer{padding:24px;text-align:center;color:var(--muted)}table{width:100%;border-collapse:collapse;background:white;border-radius:20px;overflow:hidden}th,td{padding:12px;border-bottom:1px solid #edf6f2;text-align:left}th{background:#eef8f5}@media(max-width:800px){.hero{grid-template-columns:1fr;margin:12px;padding:12px}.map-wrap{grid-template-columns:1fr;height:auto}.map{height:62vh}.topbar{align-items:flex-start;flex-direction:column}.nav{width:100%}.btn{justify-content:center}.card,.install-card{padding:18px;border-radius:22px}}
/* v0.1.3 polish */
body.manual-pin-active .map{outline:5px dashed var(--danger);outline-offset:-12px}body.manual-pin-active .leaflet-container{cursor:crosshair!important}.pin-help{background:#fff3bf;border:2px dashed #f4a261;border-radius:18px;padding:13px 14px;margin:12px 0;color:#6b4e16}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:900;letter-spacing:.01em;border-radius:999px;padding:4px 8px;margin-top:5px;background:#eef8f5;color:var(--text)}.badge.manual{background:#fff3bf}.badge.web{background:#dff3ff}.badge.sos{background:#ffd6df;color:#87233a}.legend{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.legend span{font-size:12px;color:var(--muted);background:white;border:1px solid #edf6f2;border-radius:999px;padding:6px 9px}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:-1px}.dot.gps{background:#74c0fc}.dot.manual{background:#f4a261}.dot.sos-dot{background:var(--danger)}.member .member-meta{display:flex;flex-direction:column;gap:2px}.mini-actions{display:flex;gap:8px;flex-wrap:wrap}.btn.small,button.small{padding:7px 10px;border-radius:12px;font-size:12px}.status-pill{border-radius:999px;padding:4px 8px;font-weight:900;font-size:12px;display:inline-block}.status-pill.active{background:#d8f3dc;color:#1b6b5f}.status-pill.off{background:#ffd6df;color:#87233a}

/* v0.1.4 PWA/mobile polish */
.logo img{width:30px;height:30px;display:block}.button-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.install-help ol{padding-left:22px;line-height:1.65}.card-lite{background:#fff;border:1px solid #edf6f2;border-radius:22px;padding:18px;box-shadow:0 10px 26px rgba(38,70,83,.08);margin:14px 0}.help-grid{align-items:start}.install-now{margin:14px 0 20px}.diagnostic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin:14px 0}.result-box{white-space:pre-wrap;word-break:break-word;background:#17313a;color:#ecfeff;border-radius:18px;padding:16px;min-height:90px;overflow:auto}.map-actions .btn{min-height:44px}.map-topbar{padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right))}@media(max-width:800px){body{font-size:16px}.topbar{gap:12px;padding:12px}.brand{font-size:20px}.logo{width:38px;height:38px;border-radius:14px}.logo img{width:28px;height:28px}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.nav .btn,.nav button{width:100%;min-height:46px;padding:11px 10px;font-size:14px;justify-content:center}.map-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.map-actions .btn{font-size:13px;min-height:44px}.map-wrap{padding:10px;gap:10px}.side{order:2}.map{order:1;height:58vh;min-height:360px;border-width:4px}.member{padding:10px}.button-row{display:grid;grid-template-columns:1fr;gap:8px}.button-row .btn,.button-row button{width:100%;justify-content:center}.lead{font-size:18px}.codebox{font-size:14px;overflow-wrap:anywhere}}@media(max-width:430px){.map-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.nav{grid-template-columns:1fr 1fr}.card,.install-card{padding:16px}.map{height:55vh;min-height:330px}}

/* v0.1.5 status notes */
.note-label{display:block;margin:12px 0}.note-label textarea{min-height:74px;resize:vertical}.pin-note{margin-top:6px;padding:7px 9px;background:#fff8e1;border-left:4px solid #f4a261;border-radius:10px;color:#4f3b12;font-size:12px;line-height:1.35}.leaflet-popup-content .pin-note{font-size:13px;max-width:240px;white-space:pre-wrap}.member .pin-note{max-width:190px}


/* v0.1.6 invite links + contact/admin polish */
.compact-details{padding:12px 14px}.compact-details summary{cursor:pointer;font-weight:900;color:var(--text)}.copy-field{font-size:12px;padding:8px 10px;min-width:260px}.wide-card{max-width:1180px;margin:30px auto;background:var(--panel);border:1px solid #fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;overflow:auto}.admin-table td,.admin-table th{vertical-align:middle}.admin-table a{color:#1b6b5f;font-weight:800}.form-grid .card-lite label{display:block;margin-top:10px}@media(max-width:800px){.wide-card{margin:10px;padding:12px;border-radius:20px}.copy-field{min-width:180px}.admin-table{font-size:13px}.admin-table th,.admin-table td{padding:8px}}


/* v0.1.9 satellite layer toggle */
.auto-status{font-size:12px;font-weight:800;line-height:1.35;border-radius:16px;padding:10px 12px;margin:-4px 0 12px;background:#eef8f5;color:var(--muted);border:1px solid #d9eee8}.auto-status.good{background:#e3f8ea;color:#1b6b5f}.auto-status.warn{background:#fff3bf;color:#6b4e16}.auto-status.bad{background:#ffd6df;color:#87233a}

/* v0.1.9 satellite/street layer toggle */
.leaflet-control-layers {
  border-radius: 16px;
  border: 0;
  box-shadow: 0 10px 26px rgba(0,0,0,.16);
  font: 800 13px system-ui, -apple-system, Segoe UI, sans-serif;
}
.leaflet-control-layers-expanded {
  padding: 8px 10px;
}
.leaflet-control-layers label {
  cursor: pointer;
  margin: 3px 0;
}
@media (max-width: 760px) {
  .leaflet-control-layers {
    font-size: 12px;
  }
}

.member.clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;background:#fff}.member.clickable:hover,.member.clickable:focus{transform:translateY(-1px);box-shadow:0 10px 24px rgba(38,70,83,.12);border-color:var(--blue);outline:none}.member.selected{border-color:var(--danger);box-shadow:0 0 0 3px rgba(239,71,111,.18),0 12px 28px rgba(38,70,83,.14);background:#fff8fb}.member.selected b::after{content:' • selected';color:var(--danger);font-size:11px;font-weight:900}
