:root{font-family:system-ui,-apple-system,sans-serif;color-scheme:light dark}body{margin:0}.container{max-width:760px;margin:0 auto;padding:2rem 1rem}.hint{color:#666;font-size:.85rem;margin:.25rem 0}.form{display:grid;gap:.75rem;grid-template-columns:1fr 1fr 1fr;margin-bottom:1.5rem}.form label{display:flex;flex-direction:column;font-size:.85rem;gap:.25rem}.form label.full{grid-column:1 / -1}.form label.checkbox{flex-direction:row;align-items:center;gap:.5rem;align-self:end;padding-bottom:.5rem}.form label.checkbox input{width:auto}.form input,.form select{padding:.5rem;font:inherit;border:1px solid #ccc;border-radius:4px}.form button{grid-column:1 / -1;padding:.75rem;font-weight:700;cursor:pointer;border:0;border-radius:4px;background:#0a66c2;color:#fff}.form button:disabled{opacity:.5;cursor:not-allowed}.error{margin:.5rem 0;padding:.6rem .75rem;background:#fee;color:#900;border-radius:4px;font-size:.85rem}.banner{margin:.5rem 0 1rem;padding:.6rem .75rem;background:#fff8e1;color:#5d4037;border:1px solid #ffe082;border-radius:4px;font-size:.85rem}@media (prefers-color-scheme: dark){.banner{background:#2d2410;color:#ffcc80;border-color:#5d4037}}.card{margin:1rem 0;padding:1rem 1.25rem;border:1px solid #ddd;border-radius:8px;background:#fafafa}.card h2{margin:0 0 .5rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.row{display:flex;justify-content:space-between;gap:1rem;padding:.25rem 0;border-bottom:1px dashed #e0e0e0;font-size:.9rem}.row:last-child{border-bottom:0}.row .label{color:#666}.score{font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;background:#ccc;color:#222}.score[data-grade=a]{background:#2e7d32;color:#fff}.score[data-grade=b]{background:#aed581}.score[data-grade=c]{background:#ffd54f}.score[data-grade=d]{background:#ef9a9a}.poi-list{list-style:none;padding:0;margin:.5rem 0 0}.poi-list li{padding:.25rem 0;font-size:.9rem}.omi-zones{width:100%;border-collapse:collapse;font-size:.85rem;margin:.5rem 0}.omi-zones th,.omi-zones td{padding:.3rem .5rem;border-bottom:1px dashed #e0e0e0;vertical-align:top}.omi-zones th{text-align:left;color:#666;font-weight:600}@media (prefers-color-scheme: dark){.omi-zones th,.omi-zones td{border-bottom-color:#2a2a2a}.omi-zones th{color:#aaa}}.tabs{display:flex;gap:.25rem;margin:1rem 0 0;border-bottom:2px solid #ddd;overflow-x:auto}.tab{background:transparent;border:0;border-bottom:2px solid transparent;margin-bottom:-2px;padding:.6rem 1rem;font:inherit;cursor:pointer;color:#555;white-space:nowrap}.tab:hover{color:#0a66c2}.tab.active{color:#0a66c2;border-bottom-color:#0a66c2;font-weight:600}@media (prefers-color-scheme: dark){.tabs{border-bottom-color:#333}.tab{color:#bbb}.tab:hover{color:#4da3ff}.tab.active{color:#4da3ff;border-bottom-color:#4da3ff}}.map{height:360px;width:100%;border-radius:4px;margin:.5rem 0;border:1px solid #ddd}@media (prefers-color-scheme: dark){.map{border-color:#333}}.maplink{display:inline-block;margin-top:.5rem;font-size:.85rem;color:#0a66c2}pre{background:#f5f5f5;padding:.75rem;overflow:auto;border-radius:4px;font-size:.8rem;max-height:320px}code{background:#eee;padding:.05rem .3rem;border-radius:3px;font-size:.85em}@media (prefers-color-scheme: dark){.hint,.row .label{color:#aaa}.form input,.form select{background:#1a1a1a;color:#eee;border-color:#444}.card{background:#1a1a1a;border-color:#333}.row{border-bottom-color:#2a2a2a}pre{background:#111;color:#eee}code{background:#2a2a2a}.error{background:#401;color:#fbb}.score{background:#444;color:#eee}}.app-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.25rem}.app-header h1{margin:0}.user-box{display:flex;align-items:center;gap:.75rem;font-size:.85rem}.user-name{color:#555}.logout-btn{background:transparent;border:1px solid #bbb;color:#444;padding:.35rem .7rem;border-radius:4px;font:inherit;font-size:.8rem;cursor:pointer}.logout-btn:hover{background:#f0f0f0}.login-container{max-width:400px;padding-top:4rem}.login-card h1{margin-top:0;font-size:1.3rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form label{display:flex;flex-direction:column;font-size:.85rem;gap:.25rem}.login-form input{padding:.6rem;font:inherit;border:1px solid #ccc;border-radius:4px}.login-form button{padding:.75rem;font-weight:700;cursor:pointer;border:0;border-radius:4px;background:#0a66c2;color:#fff;margin-top:.25rem}.login-form button:disabled{opacity:.5;cursor:not-allowed}@media (prefers-color-scheme: dark){.user-name{color:#bbb}.logout-btn{color:#ddd;border-color:#555}.logout-btn:hover{background:#2a2a2a}.login-form input{background:#1a1a1a;color:#eee;border-color:#444}}
