*{box-sizing:border-box}html,body,#app,#map{height:100%;margin:0}#map{position:fixed;inset:0;width:100%;touch-action:pan-x pan-y}.fab{position:fixed;right:14px;bottom:18px;z-index:20;padding:10px 14px;border-radius:9999px;background:#111;color:#fff;border:1px solid #0001;box-shadow:0 8px 24px #0003}.search-here{position:fixed;left:50%;top:calc(env(safe-area-inset-top,0px) + 16px);transform:translate(-50%);z-index:25;display:none;align-items:center;gap:6px;padding:11px 20px;border-radius:9999px;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;border:none;box-shadow:0 14px 36px #f9731659;font-size:13px;font-weight:700;letter-spacing:-.01em;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;opacity:.94}.search-here:active{transform:translate(-50%) scale(.98);box-shadow:0 8px 20px #ef44444d}.search-here:hover{opacity:1}.search-here.show{display:inline-flex}.panel{position:fixed;left:0;right:0;bottom:-100%;max-height:min(90vh,640px);background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -10px 32px #0003;border:1px solid #e5e7eb;z-index:30;transition:bottom .25s ease;pointer-events:none;display:flex;flex-direction:column;overflow:hidden}.panel.open{bottom:0;pointer-events:auto}.panel-hd{display:flex;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid #f0f0f0}.panel-hd h1{margin:0;font-size:16px}.panel-body{padding:12px 14px 18px;font-size:13px;line-height:1.5;flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;--panel-actions-h: 64px;padding-bottom:calc(var(--panel-actions-h) + 18px + env(safe-area-inset-bottom,0px))}.row{display:flex;align-items:center;gap:8px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mt4{margin-top:4px}.mt6{margin-top:6px}.mt8{margin-top:8px}.mt12{margin-top:12px}.w100{width:100%}.btn{font-size:12px;border:1px solid #e5e7eb;border-radius:10px;padding:6px 10px;background:#fff;cursor:pointer}.btn.primary{background:#111;color:#fff;border-color:#111}.btn.ghost{background:#fff}.btn.icon{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center}.chips{display:flex;flex-wrap:wrap;gap:6px}.chips .chip{padding:6px 10px;border:1px solid #e5e7eb;border-radius:9999px;background:linear-gradient(#fff,#fafafa);font-size:12px;cursor:pointer}.chips .chip.active{background:#111;color:#fff;border-color:#111}select{border:1px solid #e5e7eb;border-radius:10px;padding:6px 10px;background:#fff}input[type=checkbox]{appearance:none;width:18px;height:18px;display:inline-grid;place-content:center;border-radius:6px;border:2px solid #cbd5e1;background:#fff;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}input[type=checkbox]:before{content:"";width:10px;height:10px;border-radius:3px;transform:scale(0);transition:transform .15s ease;background:#111;box-shadow:inset 0 0 0 1px #111}input[type=checkbox]:checked{border-color:#111}input[type=checkbox]:checked:before{transform:scale(1)}input[type=checkbox]:hover{border-color:#94a3b8}input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px #1112}.panel-actions{display:flex;gap:10px;padding:10px 14px;border-top:1px solid #e5e7eb;background:#fff;position:relative}.panel-actions .btn{flex:1 1 0}.range input[type=range]{appearance:none;height:4px;background:var(--range-track, #e5e7eb46);border-radius:9999px;width:100%;z-index:2}.range input[type=range]::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:#111;box-shadow:0 2px 6px #0003;z-index:100}.range input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;border:none;background:#111;box-shadow:0 2px 6px #0003;z-index:100}.dual-range{position:relative;height:32px}.dual-range input[type=range]{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);pointer-events:none;background:transparent;z-index:1}.dual-range .range-min,.dual-range .range-max{z-index:50}.dual-range input[type=range]::-webkit-slider-thumb{pointer-events:auto;z-index:100}.dual-range input[type=range]::-moz-range-thumb{pointer-events:auto;z-index:100}.hint{color:#6b7280;font-size:12px}@media (min-width: 1024px){.panel{inset:16px auto auto 16px;max-height:88vh;width:360px;border-radius:16px}.fab{display:none}}.modal{position:fixed;inset:0;display:none;z-index:50}.modal.open{display:block}.modal .backdrop{position:absolute;inset:0;background:#0f172a80}.modal .sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:16px 16px 0 0;padding:14px 16px 16px;box-shadow:0 -10px 30px #0003}.modal .title{font-weight:700;font-size:16px;margin:0 28px 4px 0}.modal .subtitle{color:#64748b;font-size:12px}.modal .row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px 10px}.badge{border:1px solid #e5e7eb;border-radius:9999px;padding:4px 8px;font-size:12px;background:#fff}.modal .actions{margin-top:12px;display:flex;gap:8px}.modal .actions .btn{flex:1 1 0;border:none;color:#fff;font-weight:700;padding:10px 12px;border-radius:12px;box-shadow:0 10px 24px #0f172a33;text-align:center;cursor:pointer}.modal .actions .btn.kakao{background:linear-gradient(135deg,#fee500,#facc15);color:#111827}.modal .actions .btn.naver{background:linear-gradient(135deg,#16a34a,#22c55e)}.modal .actions .btn.google{background:linear-gradient(135deg,#3b82f6,#0ea5e9)}.modal .close{position:absolute;right:8px;top:8px;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid #e5e7eb;background:#fff}
