*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;min-height:100dvh;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,sans-serif;background:#fff;color:#111}button{font:inherit}.app{min-height:100dvh;width:100%}.start-screen{min-height:100dvh;width:100%;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:.75rem;box-sizing:border-box;background:#000}.landing-buttons{min-height:0}.landing-sample-column{min-height:0;display:grid;grid-template-rows:repeat(3,minmax(0,1fr));gap:.75rem}.landing-button{position:relative;width:100%;height:100%;min-height:0;border:1px solid rgba(255,255,255,.45);border-radius:16px;background:#222 center / cover no-repeat;overflow:hidden;cursor:pointer}.landing-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#00000094,#0000002e)}.landing-button__label{position:absolute;left:1rem;bottom:1rem;color:#fff;font-size:clamp(1rem,2.1vw,1.7rem);font-weight:700;letter-spacing:.02em}.landing-button--upload{min-height:calc(100dvh - 1.5rem);background:#111;color:#fff;display:grid;place-items:center}.landing-button--upload:before{background:radial-gradient(circle at center,#ffffff12,#0003)}.landing-upload-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.8rem}.landing-upload-icon{width:clamp(52px,7vw,88px);height:clamp(52px,7vw,88px);opacity:.95}.landing-upload-label{color:#fff;font-size:clamp(1rem,2vw,1.6rem);font-weight:700;letter-spacing:.02em}.landing-button:hover{filter:brightness(1.04)}.landing-upload-input{display:none}@media(max-width:880px){.start-screen{grid-template-columns:1fr;grid-template-rows:minmax(45dvh,1fr) minmax(45dvh,1fr)}.landing-button--upload{min-height:unset}}.image-input-frame{position:relative;display:block;flex-shrink:0;overflow:hidden;border:2px solid #111;border-radius:4px;background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none}.image-input-frame:hover{filter:brightness(.98)}.image-input-frame__empty{display:block;width:100%;height:100%;background:#fafafa;background-image:repeating-linear-gradient(-45deg,transparent,transparent 10px,rgba(0,0,0,.04) 10px,rgba(0,0,0,.04) 20px)}.image-input-frame__img{display:block;width:100%;height:100%;object-fit:contain;object-position:center;pointer-events:none}.image-input-frame__native{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;font-size:0}.image-input-frame--floating{box-shadow:0 10px 36px #0000002e}.image-input-frame--cover .image-input-frame__img{object-fit:cover}.map-root{position:fixed;top:0;right:0;bottom:0;left:0;background:#e8e8e8}.map-viewport{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none;cursor:grab}.map-viewport:active{cursor:grabbing}.map-tiles{position:relative;background:repeating-linear-gradient(45deg,#ddd,#ddd 8px,#e4e4e4 8px,#e4e4e4 16px),#e0e0e0}.map-tile-slot{position:absolute;left:0;top:0;will-change:transform;background:#d8d8d8}.map-tile-img{display:block;width:100%;height:100%;object-fit:fill;opacity:0;transition:opacity .12s ease-out;pointer-events:none}.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.map-overlay__center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.map-overlay__center .image-input-frame{pointer-events:auto}.map-back{position:absolute;top:1rem;left:1rem;padding:.45rem .9rem;border:1px solid #333;border-radius:4px;background:#fff;cursor:pointer;pointer-events:auto;font-size:13px}.map-back:hover{background:#f4f4f4}.map-status{position:absolute;top:1rem;left:50%;transform:translate(-50%);padding:.5rem 1rem;background:#141414d9;color:#fff;border-radius:999px;font-size:13px;font-weight:500;pointer-events:none;box-shadow:0 2px 12px #00000026}.map-status:before{content:"";display:inline-block;width:8px;height:8px;margin-right:8px;border-radius:50%;background:#ffd54a;animation:map-status-pulse 1.2s ease-in-out infinite;vertical-align:middle}@keyframes map-status-pulse{0%,to{opacity:.4}50%{opacity:1}}.map-feather-control{position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%);width:min(560px,90vw);padding:.6rem 1rem .5rem;background:#fffffff2;border:1px solid #ccc;border-radius:12px;pointer-events:auto;box-shadow:0 4px 18px #0000001f}.map-feather-label{text-align:center;font-size:13px;font-weight:600;color:#222;margin-bottom:.25rem}.map-feather-slider{width:100%;margin:0;cursor:pointer}.map-feather-ticks{display:flex;justify-content:space-between;margin-top:.25rem;font-size:11px;color:#888}.map-feather-ticks span.map-feather-tick--active{color:#111;font-weight:600}.map-report-panel{position:absolute;top:.75rem;right:.75rem;bottom:.75rem;width:320px;overflow:auto;padding:0;background:#fffffff5;border:1px solid #ccc;border-radius:10px;pointer-events:auto;font-size:12px;line-height:1.45;box-shadow:0 4px 18px #0000001a}.map-report-panel--collapsed{bottom:auto;height:auto}.map-report-toggle{display:block;width:100%;padding:.4rem .6rem;border:0;border-bottom:1px solid #ddd;background:#fafafa;cursor:pointer;font:inherit;font-weight:600;text-align:left;border-radius:10px 10px 0 0}.map-report-toggle:hover{background:#f0f0f0}.map-report-body{padding:.75rem .85rem}.map-report-body section{margin-bottom:.85rem;padding-bottom:.6rem;border-bottom:1px dashed #ddd}.map-report-body section:last-of-type{border-bottom:0}.map-report-body h3{margin:0 0 .3rem;font-size:12px;font-weight:700;color:#333}.map-report-body .report-name{font-size:14px;font-weight:600;color:#111}.map-report-body .report-sub{color:#666;font-size:11px}.map-report-body ul{margin:.3rem 0 0;padding-left:1.1rem}.map-report-body li{margin-bottom:.15rem}.map-report-body .report-disclaimer{margin-top:.5rem;padding:.4rem;background:#fff8e1;border-radius:6px;font-size:11px;color:#6b5a00}.map-log-panel{position:absolute;bottom:.75rem;left:.75rem;width:280px;max-height:calc(100vh - 7rem);overflow:auto;padding:.5rem;background:#ffffffe6;border:1px solid #bbb;border-radius:10px;pointer-events:auto;font:11px/1.35 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.map-log-panel--collapsed{width:auto;min-width:2.75rem;max-width:4rem;padding:.35rem;overflow:hidden}.map-log-toggle{display:block;width:100%;margin:0 0 .35rem;padding:.25rem .35rem;border:1px solid #999;border-radius:4px;background:#fff;cursor:pointer;font:inherit}.map-log-toggle:hover{background:#f0f0f0}.map-log-panel__body{white-space:pre-wrap;word-break:break-word}
