main.svelte-1lfrfvx{min-height:100vh;display:flex;flex-direction:column;padding:1rem 1rem 5rem;box-sizing:border-box}footer.svelte-1lfrfvx{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-1lfrfvx nav:where(.svelte-1lfrfvx) a:where(.svelte-1lfrfvx){color:#4a90d9;text-decoration:none}footer.svelte-1lfrfvx nav:where(.svelte-1lfrfvx) a:where(.svelte-1lfrfvx):hover{text-decoration:underline}.title-group.svelte-1lfrfvx{text-align:right}.title-group.svelte-1lfrfvx h1:where(.svelte-1lfrfvx){font-size:1.25rem;margin:0}.layout.svelte-1lfrfvx{display:grid;grid-template-columns:1fr;gap:2rem;flex:1}@media(min-aspect-ratio:1/1)and (min-width:768px){.layout.svelte-1lfrfvx{grid-template-columns:1fr 1fr}.visualization.svelte-1lfrfvx{order:0;position:sticky;top:1rem;align-self:start}.left-column.svelte-1lfrfvx{order:0}}@media(max-aspect-ratio:1/1),(max-width:767px){.visualization.svelte-1lfrfvx{order:-1}.left-column.svelte-1lfrfvx{order:0}}section.svelte-1lfrfvx{margin-bottom:1.5rem}section.svelte-1lfrfvx h2:where(.svelte-1lfrfvx){font-size:1.25rem;margin-bottom:.75rem;border-bottom:1px solid #eee;padding-bottom:.5rem}section.svelte-1lfrfvx h3:where(.svelte-1lfrfvx){font-size:1.05rem;margin:1rem 0 .5rem}.description.svelte-1lfrfvx p:where(.svelte-1lfrfvx){margin:.5rem 0;line-height:1.6}.description.svelte-1lfrfvx ul:where(.svelte-1lfrfvx){margin:.5rem 0;padding-left:1.5rem}.description.svelte-1lfrfvx li:where(.svelte-1lfrfvx){margin:.25rem 0;line-height:1.5}.controls.svelte-1lfrfvx{background:#f9f9f9;padding:1rem;border-radius:8px}.hint.svelte-1lfrfvx{font-size:.8rem;color:#888;margin:0 0 .75rem}.point-inputs.svelte-1lfrfvx{display:flex;flex-direction:column;gap:.5rem;max-height:250px;overflow-y:auto}.point-row.svelte-1lfrfvx{display:flex;align-items:center;gap:.5rem}.point-label.svelte-1lfrfvx{font-weight:700;font-size:.8rem;min-width:1.75rem;padding:.2rem .4rem;border-radius:3px;color:#fff;text-align:center}.vertex-label.svelte-1lfrfvx{background:#4a90d9}.point-row.svelte-1lfrfvx label:where(.svelte-1lfrfvx){display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#555}.point-row.svelte-1lfrfvx input[type=number]:where(.svelte-1lfrfvx){width:60px;padding:.35rem .4rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.8rem}.remove-btn.svelte-1lfrfvx{padding:0 .4rem;background:transparent;color:#999;font-size:1rem;line-height:1;min-width:1.5rem;cursor:pointer;border:none}.remove-btn.svelte-1lfrfvx:hover:not(:disabled){color:#f44336}.remove-btn.svelte-1lfrfvx:disabled{opacity:.3;cursor:not-allowed}.button-row.svelte-1lfrfvx{display:flex;gap:.5rem;margin-bottom:.75rem}.button-row.svelte-1lfrfvx button:where(.svelte-1lfrfvx){flex:1;padding:.4rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}button.svelte-1lfrfvx{padding:.5rem 1rem;border:none;border-radius:4px;background:#4a90d9;color:#fff;cursor:pointer;font-size:.875rem}button.svelte-1lfrfvx:hover:not(:disabled){background:#357abd}button.svelte-1lfrfvx:disabled{opacity:.5;cursor:not-allowed}button.secondary.svelte-1lfrfvx{background:#666}button.secondary.svelte-1lfrfvx:hover:not(:disabled){background:#555}.result.svelte-1lfrfvx{margin-top:.75rem;padding:.75rem 1rem;border-radius:4px;background:#e8f5e9;border-left:4px solid #4caf50;font-family:monospace;display:flex;flex-direction:column;gap:.25rem}.result.info.svelte-1lfrfvx{background:#f5f5f5;border-left-color:#bbb;color:#666;font-family:inherit;font-size:.85rem}.result-row.svelte-1lfrfvx{display:flex;justify-content:space-between;align-items:center;padding:.15rem 0}.result-label.svelte-1lfrfvx{font-size:.85rem}.result-value.svelte-1lfrfvx{font-size:1rem;font-weight:700;color:#333}.formula.svelte-1lfrfvx{background:#f5f5f5;padding:.75rem;border-radius:4px;font-family:monospace;font-size:.9rem;margin:.5rem 0;text-align:center}.visualization.svelte-1lfrfvx{overflow:hidden;display:flex;flex-direction:column;min-height:300px}.canvas-wrapper.svelte-1lfrfvx{width:100%;aspect-ratio:1;max-width:500px;touch-action:none}svg{-webkit-user-select:none;user-select:none}.grid-line.svelte-1lfrfvx{stroke:#e8e8e8;stroke-width:.5}.axis-line.svelte-1lfrfvx{stroke:#bbb;stroke-width:1}.axis-label.svelte-1lfrfvx{font-size:10px;fill:#999;text-anchor:middle}.polygon-fill.svelte-1lfrfvx{fill:#4caf5014;stroke:none}.edge-line.svelte-1lfrfvx{stroke:#4a90d9;stroke-width:2;stroke-linecap:round}.vertex-point.svelte-1lfrfvx{fill:#4a90d9;stroke:#fff;stroke-width:2}.interior-dot.svelte-1lfrfvx{fill:#2196f3;stroke:none}.boundary-dot.svelte-1lfrfvx{fill:#ff9800;stroke:none}.point-hitarea.svelte-1lfrfvx{fill:transparent;cursor:grab}.point-text.svelte-1lfrfvx{font-size:10px;fill:#555;pointer-events:none;font-weight:600}.draggable.svelte-1lfrfvx{cursor:grab}.draggable.svelte-1lfrfvx:active{cursor:grabbing}
