main.svelte-1c2os1q{min-height:100vh;display:flex;flex-direction:column;padding:1rem 1rem 5rem;box-sizing:border-box}footer.svelte-1c2os1q{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid #eee;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;z-index:100}footer.svelte-1c2os1q nav:where(.svelte-1c2os1q) a:where(.svelte-1c2os1q){color:#4a90d9;text-decoration:none}footer.svelte-1c2os1q nav:where(.svelte-1c2os1q) a:where(.svelte-1c2os1q):hover{text-decoration:underline}.title-group.svelte-1c2os1q{text-align:right}.title-group.svelte-1c2os1q h1:where(.svelte-1c2os1q){font-size:1.25rem;margin:0}.layout.svelte-1c2os1q{display:grid;grid-template-columns:1fr;gap:2rem;flex:1}@media(min-aspect-ratio:1/1)and (min-width:768px){.layout.svelte-1c2os1q{grid-template-columns:1fr 1fr}.visualization.svelte-1c2os1q{order:0;position:sticky;top:1rem;align-self:start}.left-column.svelte-1c2os1q{order:0}}@media(max-aspect-ratio:1/1),(max-width:767px){.visualization.svelte-1c2os1q{order:-1}.left-column.svelte-1c2os1q{order:0}}section.svelte-1c2os1q{margin-bottom:1.5rem}section.svelte-1c2os1q h2:where(.svelte-1c2os1q){font-size:1.25rem;margin-bottom:.75rem;border-bottom:1px solid #eee;padding-bottom:.5rem}section.svelte-1c2os1q h3:where(.svelte-1c2os1q){font-size:1.05rem;margin:1rem 0 .5rem}.description.svelte-1c2os1q p:where(.svelte-1c2os1q){margin:.5rem 0;line-height:1.6}.description.svelte-1c2os1q ol:where(.svelte-1c2os1q){margin:.5rem 0;padding-left:1.5rem}.description.svelte-1c2os1q li:where(.svelte-1c2os1q){margin:.25rem 0;line-height:1.5}.controls.svelte-1c2os1q{background:#f9f9f9;padding:1rem;border-radius:8px}.hint.svelte-1c2os1q{font-size:.8rem;color:#888;margin:.5rem 0}.add-point-row.svelte-1c2os1q{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.add-point-row.svelte-1c2os1q label:where(.svelte-1c2os1q){display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#555}.add-point-row.svelte-1c2os1q input[type=number]:where(.svelte-1c2os1q){width:60px;padding:.35rem .4rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.85rem}.add-btn.svelte-1c2os1q{padding:.4rem .75rem;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600}.add-btn.svelte-1c2os1q:hover{background:#43a047}.button-row.svelte-1c2os1q{display:flex;gap:.5rem;margin-bottom:.75rem}.button-row.svelte-1c2os1q button:where(.svelte-1c2os1q){flex:1;padding:.4rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}button.svelte-1c2os1q{padding:.5rem 1rem;border:none;border-radius:4px;background:#4a90d9;color:#fff;cursor:pointer;font-size:.875rem}button.svelte-1c2os1q:hover:not(:disabled){background:#357abd}button.svelte-1c2os1q:disabled{opacity:.5;cursor:not-allowed}button.secondary.svelte-1c2os1q{background:#666}button.secondary.svelte-1c2os1q:hover:not(:disabled){background:#555}.point-list.svelte-1c2os1q{margin-top:.75rem;border-top:1px solid #eee;padding-top:.75rem}.point-list.svelte-1c2os1q h3:where(.svelte-1c2os1q){margin:0 0 .5rem;font-size:.9rem;color:#333}.point-scroll.svelte-1c2os1q{max-height:180px;overflow-y:auto}.point-item.svelte-1c2os1q{display:flex;align-items:center;gap:.4rem;padding:.3rem .4rem;border-radius:3px;font-family:monospace;font-size:.8rem}.point-item.hull-point.svelte-1c2os1q{background:#e3f2fd}.point-index.svelte-1c2os1q{color:#999;min-width:1.5rem}.point-coords.svelte-1c2os1q{flex:1}.badge.svelte-1c2os1q{font-size:.65rem;padding:.1rem .35rem;border-radius:2px;background:#4a90d9;color:#fff;font-weight:700}.remove-btn.svelte-1c2os1q{padding:0 .4rem;background:transparent;color:#999;font-size:1rem;line-height:1;min-width:1.5rem;cursor:pointer}.remove-btn.svelte-1c2os1q:hover{color:#f44336;background:transparent}.result.svelte-1c2os1q{margin-top:1rem;padding:.75rem 1rem;border-radius:4px;background:#e3f2fd;border-left:4px solid #4a90d9;font-family:monospace;display:flex;flex-direction:column;gap:.25rem}.result.info.svelte-1c2os1q{background:#f5f5f5;border-left-color:#bbb;color:#666;font-family:inherit;font-size:.85rem}.area-text.svelte-1c2os1q{color:#555;font-size:.875rem}.visualization.svelte-1c2os1q{overflow:hidden;display:flex;flex-direction:column;min-height:300px}.canvas-wrapper.svelte-1c2os1q{width:100%;aspect-ratio:1;max-width:500px;touch-action:none}svg{-webkit-user-select:none;user-select:none}.grid-line.svelte-1c2os1q{stroke:#e8e8e8;stroke-width:.5}.axis-line.svelte-1c2os1q{stroke:#bbb;stroke-width:1}.axis-label.svelte-1c2os1q{font-size:10px;fill:#999;text-anchor:middle}.hull-fill.svelte-1c2os1q{fill:#4a90d91a;stroke:none}.hull-edge.svelte-1c2os1q{stroke:#4a90d9;stroke-width:2;stroke-linecap:round}.hull-point-circle.svelte-1c2os1q{fill:#4a90d9;stroke:#fff;stroke-width:2}.inner-point-circle.svelte-1c2os1q{fill:#bbb;stroke:#fff;stroke-width:2}.point-hitarea.svelte-1c2os1q{fill:transparent;cursor:grab}.point-text.svelte-1c2os1q{font-size:10px;fill:#555;pointer-events:none;font-weight:600}.draggable.svelte-1c2os1q{cursor:grab}.draggable.svelte-1c2os1q:active{cursor:grabbing}
