:root{font-family:SUIT Variable,Pretendard,Noto Sans KR,Apple SD Gothic Neo,sans-serif;color:#111827;line-height:1.45;font-weight:500;--line: #d6deea;--muted: #475569}*{box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden}body{margin:0;background:#f6f9ff}#root{width:100%;height:100%;overflow:hidden}h1,h2,h3,p,dl,dt,dd,ul{margin:0}button,input,select,textarea{font:inherit}.page-shell{position:relative;width:100%;height:100%;padding:0;overflow:hidden}.primary-button,.ghost-button{border:0;border-radius:999px;padding:.62rem 1rem;cursor:pointer}.primary-button{width:100%;background:linear-gradient(135deg,#111827,#334155);color:#fff;font-weight:700}.primary-button:disabled{opacity:.5;cursor:not-allowed}.ghost-button{background:#e7edf6;color:#0f172a;font-weight:700}.inline-warning{background:#fff4dff2;border:1px solid #f7d69a;color:#8a4f00;border-radius:10px;padding:.55rem .68rem;font-size:.82rem}.panel-error{color:#9f1239}.map-stage{position:relative;width:100%;height:100%;background:#dbe4f2;overflow:hidden}.map-canvas{width:100%;height:100%}.map-loading,.map-fallback{display:grid;place-items:center;min-height:100%;color:var(--muted);font-size:.88rem}.map-loading{position:absolute;inset:0;z-index:2;background:#fff9;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.map-overlay-root{position:absolute;inset:0;display:grid;grid-template-rows:auto 1fr auto;gap:.6rem;padding:.7rem;pointer-events:none}.map-top-stack,.map-bottom-sheet{pointer-events:auto}.map-top-stack{display:grid;gap:.5rem;align-content:start}.inline-ad-card{width:100%;max-width:100%;min-width:0;min-height:94px;padding:.28rem;border-radius:12px;border:1px solid rgba(214,222,234,.95);background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 18px #0f172a14;overflow:hidden}.inline-ad-slot{width:100%!important;max-width:100%!important;min-width:0!important;min-height:90px}.restaurant-list-ad-item{list-style:none;max-width:100%;min-width:0}.inline-ad-card-list{margin:.05rem 0}.inline-ad-card-detail{margin:.1rem 0}.map-action-row{display:flex;justify-content:center;gap:.45rem}.map-location-button{width:2.15rem;height:2.15rem;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #c3d1e7;background:#e7edf6f5}.map-location-icon{width:1.02rem;height:1.02rem;stroke:#0f172a;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.map-location-button.is-loading .map-location-icon{animation:map-location-spin 1s linear infinite}@keyframes map-location-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.map-refresh-button{width:auto;justify-self:center;padding:.4rem .72rem;font-size:.78rem;line-height:1.2;border:1px solid #c3d1e7;background:#e7edf6f5}.map-refresh-button:disabled{opacity:.55}.map-refresh-button.is-active{border-color:#111827;background:#0f172a;color:#fff;box-shadow:0 8px 20px #0f172a33}.map-topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.5rem;padding:.7rem;border-radius:14px;background:#ffffffe6;border:1px solid rgba(214,222,234,.95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 18px #0f172a1a}.map-topbar h1{font-size:1.22rem;letter-spacing:-.02em}.map-topbar p{color:var(--muted);margin-top:.12rem;font-size:.82rem}.map-topbar-actions{display:flex;align-items:center;justify-self:end;gap:.4rem}.map-donate-button{width:auto;padding:.45rem .72rem;border:1px solid #f3cf96;background:linear-gradient(135deg,#fff3df,#ffe8bf);color:#7a4305;font-size:.76rem;line-height:1.2;white-space:nowrap}.map-submit-button{width:auto;justify-self:end;padding:.45rem .78rem;font-size:.8rem;line-height:1.2}.map-search-row{display:flex;align-items:center;gap:.42rem}.map-search-input{width:100%;min-width:0;border:1px solid #c8d4e6;border-radius:12px;background:#fffffff0;color:#111827;padding:.56rem .68rem;font-size:.84rem}.map-search-submit{width:auto;border:1px solid #c3d1e7;background:#e7edf6f5;font-size:.76rem;padding:.38rem .62rem;line-height:1.15;white-space:nowrap}.map-search-status{color:var(--muted);font-size:.75rem;padding:0 .2rem}.map-card{background:#fffffff0;border:1px solid rgba(214,222,234,.95);border-radius:14px;overflow:hidden;box-shadow:0 6px 18px #0f172a14}.map-filter-card .filters{gap:.55rem;padding:.7rem;border-bottom:0}.filters label,.form-grid label{display:grid;gap:.35rem;font-size:.82rem;color:var(--muted)}.filters select,.filters input,.form-grid input,.form-grid select,.form-grid textarea{border:1px solid #c8d4e6;border-radius:10px;background:#fff;color:#111827;padding:.58rem .65rem}@supports (-webkit-touch-callout: none){.modal-card input:not([type=hidden]),.modal-card select,.modal-card textarea{font-size:16px}}.map-floating-error{padding:.62rem .68rem;border-radius:10px;background:#fff1f2f2;border:1px solid #fda4af;font-size:.82rem}.map-bottom-sheet{align-self:end;display:grid;gap:.55rem;padding-bottom:env(safe-area-inset-bottom,0px)}.map-bottom-content{display:grid;gap:.6rem;max-height:47dvh}.map-bottom-content.is-list-only{max-width:460px}.map-bottom-content.is-detail-only{max-width:460px;max-height:56dvh}.map-detail-card{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(env(safe-area-inset-bottom,0px) + .35rem)}.map-bottom-actions{display:flex;align-items:center;justify-content:space-between;gap:.45rem;width:100%}.map-location-fab{box-shadow:0 10px 24px #0f172a33}.map-location-fab:disabled{opacity:.7}.map-list-fab{border:0;border-radius:999px;padding:.55rem .9rem;font-weight:800;font-size:.82rem;color:#fff;background:linear-gradient(135deg,#0f172a,#334155);box-shadow:0 10px 24px #0f172a38;cursor:pointer}.map-list-fab.is-open{background:linear-gradient(135deg,#334155,#475569)}.map-list-sheet-overlay{position:absolute;inset:0;z-index:8;pointer-events:auto;background:#0f172a4d;display:grid;align-items:end}.map-list-sheet{background:#fff;border-radius:18px 18px 0 0;border:1px solid #d4def1;box-shadow:0 -12px 34px #0f172a38;max-height:min(72dvh,640px);overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr);padding-bottom:calc(env(safe-area-inset-bottom,0px) + .35rem);touch-action:pan-y;overscroll-behavior:contain}.map-list-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.75rem .8rem .5rem}.map-icon-button{width:2rem;height:2rem;border:0;border-radius:999px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;background:#e7edf6}.map-icon-button svg{width:1rem;height:1rem;stroke:#0f172a;fill:none;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.map-list-sheet-close{background:transparent}.map-list-sheet .restaurant-list{max-height:none;height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;padding-bottom:calc(.7rem + env(safe-area-inset-bottom,0px))}.map-list-sheet .restaurant-item{touch-action:pan-y}.map-list-sheet .panel-note,.map-list-sheet .panel-error,.map-list-card .panel-note,.map-list-card .panel-error,.map-detail-card .panel-note,.map-detail-card .panel-error{padding:.8rem}.panel-note{color:var(--muted)}.restaurant-list{list-style:none;margin:0;padding:.6rem;display:grid;gap:.45rem;max-height:24dvh;overflow-y:auto;overflow-x:hidden}.restaurant-list>li{max-width:100%;min-width:0}.restaurant-item{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:.62rem;display:grid;gap:.42rem;text-align:left;cursor:pointer}.restaurant-item.is-selected{border-color:#111827;box-shadow:0 8px 20px #0f172a1f}.restaurant-item h3{font-size:.94rem;margin-bottom:.12rem}.restaurant-item p{font-size:.8rem;color:var(--muted)}.restaurant-distance{margin-top:.15rem;font-size:.75rem;color:#1d4ed8;font-weight:600}.restaurant-item-meta{display:flex;justify-content:space-between;align-items:center;gap:.55rem}.restaurant-item-meta strong{color:#0f172a;font-size:.9rem}.restaurant-item-meta small{color:#475569;font-size:.78rem}.detail-panel{padding:.9rem;display:grid;align-content:start;gap:.66rem}.detail-panel header{display:grid;gap:.25rem}.detail-panel-header{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:.55rem}.detail-title-wrap{min-width:0;display:grid;gap:.25rem}.detail-title-row{display:flex;align-items:start;gap:.35rem;min-width:0}.detail-title-row h2{min-width:0;flex:1 1 auto}.detail-panel header p{color:var(--muted);font-size:.84rem}.detail-restaurant-image-row{display:flex;align-items:center;gap:.42rem;min-width:0}.detail-restaurant-image-strip{display:flex;gap:.42rem;overflow-x:auto;padding-bottom:.1rem;min-width:0;flex:1 1 auto}.detail-image-zoom-trigger{border:0;padding:0;margin:0;background:transparent;border-radius:10px;cursor:zoom-in;display:block}.detail-restaurant-image-strip img{width:96px;height:72px;object-fit:cover;border-radius:10px;border:1px solid #d4deef;background:#f8fbff;flex:0 0 auto}.detail-restaurant-image-add-trigger{width:2.1rem;height:2.1rem;min-height:2.1rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;flex:0 0 auto}.detail-restaurant-image-add-trigger svg{width:1rem;height:1rem;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.detail-restaurant-image-add-trigger.is-loading{opacity:.55}.detail-restaurant-image-add-trigger input{display:none}.detail-back-button{width:2rem;height:2rem;padding:0;border:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;background:transparent}.detail-back-button svg{width:1rem;height:1rem;stroke:#0f172a;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.detail-meta-grid{display:grid;gap:.48rem;grid-template-columns:repeat(2,minmax(0,1fr))}.detail-meta-item{padding:.56rem .58rem;border-radius:11px;background:#f8fbff;border:1px solid #dde6f5;min-width:0}.detail-meta-item-note{grid-column:1 / -1}.detail-panel dt{color:#475569;font-size:.74rem}.detail-panel dd{margin-top:.22rem;font-size:.84rem;font-weight:700;word-break:break-word}.detail-note-value{white-space:pre-line}.detail-actions{display:grid;grid-template-columns:minmax(0,1fr);gap:.45rem;align-items:start}.detail-comments{display:grid;gap:.55rem}.detail-comments h3{font-size:.84rem}.detail-comment-form{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:end;gap:.42rem}.detail-comment-form textarea{grid-column:1 / -1;border:1px solid #c8d4e6;border-radius:10px;padding:.52rem .6rem;background:#fff;color:#111827;min-height:2.4rem;resize:vertical}.detail-comment-form .primary-button{width:auto;justify-self:end;padding:.44rem .7rem;font-size:.78rem;min-height:2.4rem}.detail-comment-image-trigger{justify-self:start;min-height:2.4rem;padding:.4rem .64rem;font-size:.76rem;display:inline-flex;align-items:center;justify-content:center}.detail-comment-image-trigger input{display:none}.detail-comment-image-preview-list{list-style:none;margin:0;padding:0;display:flex;gap:.38rem;overflow-x:auto}.detail-comment-image-preview-list li{position:relative;flex:0 0 auto}.detail-comment-image-preview-list img{width:56px;height:56px;object-fit:cover;border-radius:9px;border:1px solid #d4deef;background:#f8fbff}.detail-comment-image-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border:0;border-radius:999px;background:#0f172ab8;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.detail-comment-image-remove svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.detail-comment-error{font-size:.76rem}.detail-comment-list{list-style:none;margin:0;padding:0;display:grid;gap:.36rem;max-height:18dvh;overflow:auto}.detail-comment-list li{border:1px solid #dbe4f2;border-radius:10px;background:#fff;padding:.44rem .55rem;display:grid;gap:.16rem}.detail-comment-list p{font-size:.8rem;color:#0f172a}.detail-comment-image-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.3rem}.detail-comment-image-grid .detail-image-zoom-trigger{width:100%;border-radius:8px}.detail-comment-image-grid img{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:8px;border:1px solid #d4deef;background:#f8fbff}.detail-comment-list small{font-size:.7rem;color:#64748b}.detail-image-lightbox-overlay{position:fixed;inset:0;z-index:70;background:#0f172ad1;display:grid;place-items:center;padding:1rem}.detail-image-lightbox-card{width:min(960px,100%);max-height:92vh;position:relative;display:grid;justify-items:center}.detail-image-lightbox-image{width:auto;max-width:100%;max-height:calc(92vh - 2.6rem);object-fit:contain;border-radius:12px;background:#02061799}.detail-image-lightbox-close{justify-self:end;margin-bottom:.4rem;border:0;border-radius:999px;background:#f1f5f9f0;color:#0f172a;padding:.36rem .62rem;cursor:pointer}.detail-link-button{width:100%;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;padding:.45rem .66rem;font-size:.76rem;line-height:1.2;min-height:2.05rem}.detail-action-menu{position:relative}.detail-action-menu-trigger{width:2.05rem;height:2.05rem;min-height:2.05rem;padding:0;display:inline-flex;align-items:center;justify-content:center}.detail-action-menu-trigger svg{width:1rem;height:1rem;fill:currentColor}.detail-action-menu-list{position:absolute;right:0;top:calc(100% + .28rem);z-index:5;display:grid;gap:.18rem;min-width:8.6rem;padding:.24rem;border:1px solid #d7e0ef;border-radius:10px;background:#fff;box-shadow:0 10px 24px #0f172a24}.detail-action-menu-list button{border:0;border-radius:8px;background:#f8fbff;color:#0f172a;padding:.42rem .55rem;font-size:.76rem;text-align:left;cursor:pointer}.detail-action-menu-list button:hover{background:#edf3ff}.modal-overlay{position:fixed;inset:0;background:#0f172a73;display:grid;align-items:end;z-index:30}.modal-card{width:100%;max-height:90vh;overflow:auto;background:#fff;border-radius:18px 18px 0 0;border:1px solid #d4def1;box-shadow:0 -12px 34px #0f172a33}.modal-card>header{display:flex;justify-content:space-between;align-items:center;padding:.9rem .9rem .45rem}.modal-card>header button{border:0;background:#eef2f9;border-radius:999px;padding:.35rem .6rem;cursor:pointer}.form-grid{padding:.45rem .9rem .9rem;display:grid;gap:.7rem}.form-grid span{color:#9f1239;font-size:.77rem}.donation-modal-card{max-height:86vh}.donation-modal-content{gap:.52rem}.donation-copy-grid{display:grid;gap:.42rem}.donation-copy-item{border:1px solid #d4deef;border-radius:12px;background:#f8fbff;padding:.58rem .62rem;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.5rem}.donation-copy-text{min-width:0}.donation-copy-item h3{margin:0;font-size:.82rem;color:#0f172a}.donation-copy-item p{margin:.08rem 0 0;font-size:.76rem;color:#334155;word-break:break-all}.donation-copy-icon-button{width:1.9rem;height:1.9rem;border:1px solid #c3d1e7;background:#e7edf6f5}.search-tool{display:grid;gap:.45rem}.search-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem;align-items:end}.search-keyword-label{min-width:0}.search-action-group{display:flex;align-items:end;gap:.35rem}.search-trigger{justify-self:auto;align-self:end;min-height:2.35rem;padding:.45rem .72rem;font-size:.82rem;white-space:nowrap}.search-more-trigger{min-height:2.1rem;padding:.38rem .56rem;font-size:.76rem;white-space:nowrap}.search-hint,.search-selected-address,.search-message{margin:0;font-size:.77rem;color:var(--muted)}.search-message{color:#0f172a}.search-selected-address{color:#334155}.search-error{margin:0;color:#9f1239;font-size:.77rem}.search-candidate-list{list-style:none;margin:0;padding:0;display:grid;gap:.35rem}.search-candidate-item{width:100%;text-align:left;border:1px solid #c8d4e6;border-radius:10px;background:#fff;color:#1e293b;padding:.48rem .58rem;cursor:pointer;font-size:.8rem;display:grid;gap:.15rem}.search-candidate-item:hover{background:#f8fbff}.search-candidate-item small{color:#64748b;font-size:.72rem}.search-candidate-name{font-weight:700}.input-inline{display:grid;gap:.7rem;grid-template-columns:1fr}.submit-image-field{display:grid;gap:.45rem}.submit-image-trigger{justify-self:start;min-height:2.35rem;padding:.42rem .66rem;font-size:.78rem;display:inline-flex;align-items:center;justify-content:center}.submit-image-trigger input{display:none}.submit-image-preview-list{list-style:none;margin:0;padding:0;display:flex;gap:.4rem;overflow-x:auto}.submit-image-preview-list li{position:relative;flex:0 0 auto}.submit-image-preview-list img{width:62px;height:62px;object-fit:cover;border-radius:10px;border:1px solid #d4deef;background:#f8fbff}.submit-image-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border:0;border-radius:999px;background:#0f172ab8;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.submit-image-remove svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.submit-image-message{margin:0;font-size:.77rem;color:#9f1239}.toast-viewport{position:fixed;left:.75rem;right:.75rem;bottom:.75rem;display:grid;gap:.5rem;z-index:50}.toast{width:100%;padding:.68rem;border-radius:12px;border:1px solid;display:flex;justify-content:space-between;gap:.72rem;align-items:center}.toast-success{border-color:#86efac;background:#f0fdf4;color:#14532d}.toast-error{border-color:#fda4af;background:#fff1f2;color:#881337}.toast button{border:0;border-radius:8px;background:#0f172a1a;cursor:pointer;padding:.25rem .4rem}@media(min-width:900px){.map-overlay-root{padding:.95rem;gap:.75rem}.map-topbar{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.8rem;padding:.78rem;max-width:860px}.map-topbar h1{font-size:1.5rem}.map-topbar p{font-size:.9rem}.map-topbar .map-donate-button,.map-topbar .map-submit-button{width:auto;min-width:96px}.map-search-row,.map-search-status,.map-filter-card{max-width:860px}.map-filter-card .filters{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end}.map-bottom-content{grid-template-columns:minmax(0,1fr) minmax(0,1fr);max-width:860px;max-height:40vh}.map-bottom-content.is-list-only,.map-bottom-content.is-detail-only{grid-template-columns:minmax(0,1fr);max-width:460px}.map-list-sheet-overlay{justify-items:start}.map-list-sheet{width:min(520px,calc(100vw - 1.9rem));border-radius:18px;margin:0 0 .95rem .95rem}.restaurant-list{max-height:30vh}.restaurant-item{display:flex;justify-content:space-between;gap:.8rem}.restaurant-item-meta{display:grid;justify-items:end}.detail-panel{min-height:100%}.detail-actions{grid-template-columns:minmax(0,1fr)}.input-inline{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-overlay{place-items:center;padding:1rem}.modal-card{width:min(640px,100%);border-radius:18px;box-shadow:0 30px 60px #0f172a38}.toast-viewport{left:auto;right:1rem;width:min(320px,calc(100vw - 2rem))}}
