:root { --green:#2D6A4F; --bg:#f7f6f2; --line:#e2e0d8; --muted:#7a776e; }
* { box-sizing: border-box; }
body { margin:0; font:16px/1.5 system-ui, sans-serif; background:var(--bg); color:#222; }
#app { max-width:560px; margin:0 auto; padding:16px 16px 64px; }
header h1 { margin:.2em 0 0; font-size:1.4rem; }
h2 { font-size:1rem; margin:1.4em 0 .4em; color:var(--green); }
.muted { color:var(--muted); font-size:.88rem; }
.err { color:#b00; white-space:pre-wrap; }
button { font:inherit; padding:.7em 1em; border:1px solid var(--line); border-radius:10px; background:#fff; cursor:pointer; }
button.primary { background:var(--green); color:#fff; border-color:var(--green); }
button:disabled { opacity:.45; cursor:not-allowed; }
.row { display:flex; gap:8px; margin-top:14px; }
.row.wrap { flex-wrap:wrap; }
.primary { font-weight:600; }
label { display:block; margin:12px 0; }
label input, label select { display:block; width:100%; margin-top:4px; padding:.6em; font:inherit; border:1px solid var(--line); border-radius:8px; background:#fff; }
.list { list-style:none; padding:0; }
.list li { padding:14px; background:#fff; border:1px solid var(--line); border-radius:10px; margin:8px 0; cursor:pointer; display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
table { width:100%; border-collapse:collapse; font-size:.92rem; }
td { padding:6px 8px; border-bottom:1px solid var(--line); vertical-align:top; }
.pill { display:inline-block; font-size:.72rem; background:#d7ede2; color:var(--green); padding:1px 7px; border-radius:999px; margin-left:6px; vertical-align:middle; }
#map { height:300px; border-radius:12px; border:1px solid var(--line); }
.photo-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:10px; }
.photo-card { margin:0; background:#fff; border:1px solid var(--line); border-radius:10px; overflow:hidden; }
.photo-card img.thumb { width:100%; height:120px; object-fit:cover; display:block; }
.photo-card figcaption { padding:6px 8px; font-size:.82rem; }
#pk-prev img.thumb, #ov-prev img.thumb { max-width:100%; max-height:240px; width:auto; height:auto; border-radius:10px; border:1px solid var(--line); margin-top:8px; }
.photo-attach { margin-top:6px; padding:.45em .7em; font-size:.9rem; }
.overlay { position:fixed; inset:0; z-index:1000; background:rgba(0,0,0,.45); display:flex; align-items:center; justify-content:center; padding:16px; }
.overlay .sheet { background:var(--bg); border-radius:14px; padding:18px; max-width:520px; width:100%; max-height:90vh; overflow:auto; }
.overlay .sheet h2 { margin-top:0; }
details.connus { margin-top:18px; border:1px solid var(--line); border-radius:10px; background:#fff; padding:0 14px; }
details.connus > summary { cursor:pointer; padding:14px 0; color:var(--muted); font-size:.9rem; list-style-position:inside; }
details.connus[open] > summary { border-bottom:1px solid var(--line); margin-bottom:8px; }
.question, .result { background:#fff; border:1px solid var(--line); border-radius:12px; padding:18px; margin-top:14px; }
.result h2 { font-size:1.6rem; color:var(--green); margin:.2em 0; }
