*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{color:#172033;background:#f6f7f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,a{font:inherit}.map-page{min-height:100vh;position:relative;overflow:hidden}.map-canvas{background-color:#dfe8ee;background-image:linear-gradient(#ffffff75 1px,#0000 1px),linear-gradient(90deg,#ffffff75 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:40px 40px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;min-height:100vh;padding:0;display:grid}.app-header{top:max(12px, env(safe-area-inset-top));z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;border:1px solid #d0d7ded1;border-radius:18px;justify-content:flex-start;align-items:center;gap:12px;width:auto;min-height:58px;padding:8px 14px;display:flex;position:fixed;left:16px;right:16px;box-shadow:0 14px 34px #0f172a1f}.app-header__logo{background:#fff;border:1px solid #d8e0e7;border-radius:13px;flex:none;place-items:center;width:42px;height:42px;display:grid;position:relative;overflow:hidden}.app-header__logo-ring{border-radius:999px;position:absolute}.app-header__logo-ring--outer{background:#fff;border:4px solid #111827;width:30px;height:30px}.app-header__logo-ring--middle{background:#fff;border:4px solid #16a34a;width:20px;height:20px}.app-header__logo-pin{background:#111827;border:3px solid #ef4444;border-radius:999px 999px 999px 3px;width:12px;height:12px;position:relative;transform:rotate(45deg)}.app-header__brand{text-align:left;justify-items:start;gap:1px;min-width:0;display:grid}.app-header h1{color:#111827;letter-spacing:0;margin:0;font-size:1.125rem;font-weight:900;line-height:1.1}.app-header p{color:#64748b;margin:0;font-size:.75rem;line-height:1.15}.naver-map-shell{background:#dfe8ee;width:100%;min-height:100vh;position:relative;overflow:hidden}.naver-map{width:100%;height:100%;min-height:100vh}.map-controls{right:16px;bottom:var(--map-control-bottom,16px);z-index:25;gap:8px;transition:bottom .16s;display:grid;position:absolute}.map-page--drawer-dragging .map-controls{transition:none}.map-control{color:#111827;cursor:pointer;background:#fff;border:1px solid #dce4ec;border-radius:16px;place-items:center;width:46px;height:46px;display:grid;box-shadow:0 10px 25px #0f172a29}.map-control:hover{border-color:#16a34a}.map-control-status{color:#172033;text-align:right;background:#fff;border:1px solid #dce4ec;border-radius:10px;max-width:11rem;margin:0;padding:7px 9px;font-size:.75rem;line-height:1.25;box-shadow:0 10px 25px #0f172a24}.map-toast{top:calc(max(12px, env(safe-area-inset-top)) + 70px);z-index:30;color:#111827;text-align:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;border:1px solid #d1d5dbeb;border-radius:14px;width:min(100vw - 32px,360px);padding:11px 14px;font-size:.86rem;font-weight:750;line-height:1.25;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 16px 34px #0f172a29}.viewer-location-marker{width:24px;height:24px;position:relative}.viewer-location-marker__ring,.viewer-location-marker__dot{border-radius:999px;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%)}.viewer-location-marker__ring{background:#2563eb21;border:3px solid #2563eb52;width:22px;height:22px}.viewer-location-marker__dot{background:#2563eb;border:2px solid #fff;width:10px;height:10px;box-shadow:0 2px 8px #0f172a38}.map-state{text-align:center;background:#f6f7f9e6;place-items:center;gap:8px;padding:24px;display:grid;position:absolute;inset:0}.map-state h1,.map-state p{max-width:36rem;margin:0}.map-state h1{font-size:1.25rem}.map-state--loading{color:#172033}.map-state--error{color:#8f2f3d}.map-bottom-sheet{z-index:20;height:min(var(--drawer-height,380px), 86vh);overscroll-behavior:contain;touch-action:pan-y;background:#fff;border-radius:26px 26px 0 0;flex-direction:column;min-height:68px;max-height:86vh;padding:12px 16px 18px;transition:height .16s;display:flex;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -18px 44px #0f172a2e}.map-bottom-sheet--dragging{transition:none}.map-bottom-sheet--content-sized{height:auto;min-height:0;overflow-y:visible}.map-bottom-sheet--content-sized .map-bottom-sheet__handle{display:none}.map-bottom-sheet__handle{cursor:ns-resize;touch-action:none;background:0 0;border:0;justify-content:center;align-self:center;align-items:center;width:72px;height:28px;margin:0 0 10px;padding:0;display:inline-flex}.map-bottom-sheet__handle span{background:#c9d3dd;border-radius:999px;width:44px;height:4px}.map-bottom-sheet__handle:focus-visible{outline-offset:2px;outline:2px solid #2f6f8f}.map-bottom-sheet__details{border-bottom:1px solid #e3e8ef;gap:10px;margin-bottom:16px;padding-bottom:16px;display:grid}.map-bottom-sheet__details h2,.map-bottom-sheet__details p,.map-bottom-sheet__list p{margin:0}.map-bottom-sheet__details h2{padding-right:72px;font-size:1.15rem;line-height:1.25}.map-bottom-sheet__details p,.map-bottom-sheet__list p,.map-bottom-sheet__list small{color:#657488}.map-bottom-sheet__close{color:#172033;cursor:pointer;background:#fff;border:1px solid #d0d7de;border-radius:8px;justify-self:end;min-height:36px;padding:7px 11px}.map-bottom-sheet__actions{flex-wrap:wrap;gap:8px;display:flex}.map-bottom-sheet__actions a{color:#fff;background:#2f6f8f;border-radius:8px;padding:8px 10px;text-decoration:none}.map-bottom-sheet__list{flex-direction:column;gap:8px;display:flex}.map-bottom-sheet__list button{color:#172033;text-align:left;cursor:pointer;background:#fff;border:1px solid #d0d7de;border-radius:8px;flex-direction:column;gap:4px;padding:12px;display:flex}.map-bottom-sheet__list button:hover,.map-bottom-sheet__close:hover{border-color:#2f6f8f}.machine-type-badges{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.machine-type-badge{letter-spacing:0;white-space:nowrap;border:1px solid;border-radius:999px;justify-content:center;align-items:center;min-height:24px;padding:0 9px;font-size:.72rem;font-weight:800;line-height:1;display:inline-flex}.machine-type-badge--phoenix_dart{color:#b91c1c;background:#fff1f2;border-color:#fecdd3}.machine-type-badge--dartslive{color:#047857;background:#ecfdf5;border-color:#bbf7d0}.poi-panel{background:#fff;border:1px solid #c9d3dd;border-radius:8px;width:min(360px,100vw - 48px);padding:16px;position:fixed;bottom:24px;right:24px;box-shadow:0 18px 40px #0f172a29}.poi-panel__close{float:right}.poi-panel__details{gap:6px;margin:16px 0;display:grid}.poi-panel__details div{justify-content:space-between;gap:12px;display:flex}.poi-panel__details dt{color:#657488}.poi-panel__details dd{margin:0}.poi-panel__actions{gap:8px;display:flex}.poi-panel__actions a{color:#fff;background:#2f6f8f;border-radius:8px;padding:8px 10px;text-decoration:none}.dart-marker{pointer-events:auto;width:100px;height:100px;position:relative}.dart-marker--cluster{place-items:center;display:grid}.dart-marker__label{text-overflow:ellipsis;white-space:nowrap;border-radius:8px;place-items:center;width:min-content;min-width:82px;max-width:96px;height:38px;padding:0 12px;font-size:13px;font-weight:850;line-height:1;display:grid;position:absolute;bottom:18px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 10px 20px #0f172a33}.dart-marker--cluster-active .dart-marker__label{color:#fff;background:#111827;border:2px solid #16a34a}.dart-marker--cluster-muted .dart-marker__label{color:#fff;background:#111827b8;border:2px dashed #fff}.dart-marker--poi{place-items:center;display:grid}.dart-marker--poi:before{content:"";background:#111827;border:2px solid #fff;border-radius:999px;width:34px;height:34px;position:absolute;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 11px 22px #0f172a38}.dart-marker__poi-core{background:#dc2626;border:5px solid #16a34a;border-radius:999px;width:18px;height:18px;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.dart-marker__tail{border-top:16px solid #111827;border-left:10px solid #0000;border-right:10px solid #0000;width:0;height:0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}@media (width>=761px){.app-header{width:258px;right:auto}.map-controls{bottom:24px;right:384px}.map-bottom-sheet{border-left:1px solid #d0d7de;border-radius:0;width:360px;height:auto;max-height:none;padding:20px 16px;inset:0 0 0 auto;box-shadow:-18px 0 44px #0f172a24}.map-bottom-sheet__handle{display:none}}
