:root{
  --orange:#e85a2a; --orange-d:#c2431a; --peach:#ff9e75;
  --cream:#fffaf5; --cream2:#fff3ec; --ink:#1d1d1f; --mut:#6b6b72;
  --line:#efe7de; --line2:#e4d7c8; --ok:#27864F; --blue:#1a73e8;
  --amber:#f5a623; --red:#d93025; --grey:#9aa0a6;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased}
a{color:var(--orange-d)}
nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;
  background:#fff;border-bottom:1px solid var(--line2);padding:11px 18px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
nav .brand{font-weight:900;font-size:18px;letter-spacing:-.02em}
nav .brand span{color:var(--orange)}
nav .brand small{font-weight:600;color:var(--mut);font-size:11px;margin-left:4px;letter-spacing:0}
nav a.link{text-decoration:none;color:var(--ink);font-weight:600;font-size:14px;padding:5px 4px;border-bottom:2px solid transparent}
nav a.link.active{color:var(--orange-d);border-bottom-color:var(--orange)}
nav .sp{margin-left:auto}
nav .who{font-size:12.5px;color:var(--mut);font-weight:600}
main{max-width:920px;margin:0 auto;padding:16px 16px 60px}
h1{font-size:20px;letter-spacing:-.02em;margin:6px 0 2px}
.sub{color:var(--mut);font-size:13px;margin-bottom:14px}
.flash{background:var(--cream2);border:1px solid var(--line2);color:var(--orange-d);
  border-radius:10px;padding:9px 13px;margin:0 auto 12px;max-width:920px;font-size:13.5px;font-weight:600}
.bar{height:8px;background:var(--line);border-radius:99px;overflow:hidden;margin:8px 0 2px}
.bar>i{display:block;height:100%;background:var(--ok);width:0;transition:width .25s}

/* cards / list */
.zone{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mut);font-weight:800;margin:20px 0 8px}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:10px}
.card.done{border-color:#bfe3cc;background:#f4fbf6}
.chead{display:flex;align-items:flex-start;gap:10px}
.dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto;margin-top:5px;background:var(--grey)}
.name{font-weight:700;font-size:15px;line-height:1.2}
.meta{font-size:12px;color:var(--mut);margin-top:2px}
.meta a{color:var(--blue);text-decoration:none}
.pill{display:inline-block;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:99px;background:var(--cream2);color:var(--orange-d);margin-left:4px}
.others{margin-top:9px;border-top:1px dashed var(--line2);padding-top:8px}
.visit{font-size:12.5px;color:#444;margin-bottom:5px;display:flex;gap:7px;align-items:baseline;flex-wrap:wrap}
.visit b{color:var(--ink)}
.tag{font-size:10.5px;font-weight:800;padding:1px 7px;border-radius:99px;color:#fff}
.adminctl{margin-left:auto;display:flex;gap:6px}
.mine{margin-top:10px;background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:10px}
.mine .row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
label.cbx{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600}
select,textarea,input[type=text],input[type=email],input[type=password],input[type=number]{
  font:inherit;border:1px solid var(--line2);border-radius:8px;padding:7px 9px;background:#fff}
textarea{width:100%;min-height:42px;resize:vertical;margin-top:7px}
button,.btn{font:inherit;font-weight:700;font-size:13px;border:0;border-radius:8px;padding:8px 13px;cursor:pointer}
.btn-p{background:var(--orange);color:#fff}
.btn-p:hover{background:var(--orange-d)}
.btn-g{background:#fff;border:1px solid var(--line2);color:var(--ink)}
.btn-d{background:#fff;border:1px solid #f1c4bc;color:var(--red)}
.saved{font-size:12px;color:var(--ok);font-weight:700;opacity:0;transition:opacity .3s}
.saved.show{opacity:1}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(120% 80% at 80% -10%, #ffe7d8 0%, var(--cream) 60%)}
.login{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 26px 22px;
  width:100%;max-width:360px;box-shadow:0 10px 30px rgba(0,0,0,.07)}
.login .brand{font-weight:900;font-size:24px;letter-spacing:-.02em;text-align:center}
.login .brand span{color:var(--orange)}
.login .t{text-align:center;color:var(--mut);font-size:13px;margin:2px 0 18px}
.login label{display:block;font-size:12px;font-weight:700;color:var(--mut);margin:10px 0 4px}
.login input{width:100%}
.login .btn-p{width:100%;margin-top:16px;padding:11px}
.or{text-align:center;color:var(--mut);font-size:12px;margin:14px 0;position:relative}
.or::before,.or::after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--line2)}
.or::before{left:0}.or::after{right:0}
.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;
  border:1px solid var(--line2);border-radius:8px;background:#fff;text-decoration:none;color:var(--ink);font-weight:700;font-size:14px}
.gbtn:hover{background:#fafafa}
.gbtn svg{width:18px;height:18px}

/* admin */
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:13px}
th,td{text-align:left;padding:9px 11px;border-bottom:1px solid var(--line)}
th{background:var(--cream2);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut)}
tr:last-child td{border-bottom:0}
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:16px}
.panel h2{font-size:15px;margin:0 0 10px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid2 .full{grid-column:1/3}
.danger{border-color:#f1c4bc;background:#fff7f5}
#map{height:calc(100vh - 120px);border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.legend{background:#fff;padding:9px 11px;border-radius:8px;box-shadow:0 1px 6px rgba(0,0,0,.25);font-size:12.5px;line-height:1.7}
.legend .dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:6px;margin-top:0;vertical-align:middle}
