:root{--bg:#0a0a0a; --ink:#e5e7eb; --muted:#9ca3af; --card:#111214; --line:#1f2937; --accent:#ffd54a;}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);font:15px/1.65 ui-sans-serif,system-ui,Apple SD Gothic Neo,Malgun Gothic,Roboto,sans-serif}
.header{position:sticky;top:0;z-index:20;backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg,rgba(10,10,10,.9),rgba(10,10,10,.4) 70%,rgba(10,10,10,0));border-bottom:1px solid var(--line)}
.wrap{max-width:1200px;margin:0 auto;padding:12px 12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

/* 모바일에서 가로 스크롤 가능한 지역 바 (스크롤바 숨김) */
.regions-scroll{ margin-top:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none;
  mask-image:linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%); }
.regions-scroll::-webkit-scrollbar{ display:none }
.regions{ display:flex; gap:8px; padding:2px 4px 6px; min-width:max-content; }
.regions button{ background:#15161a;color:#e5e7eb;border:1px solid #1f2937;border-radius:999px; padding:6px 12px;cursor:pointer;white-space:nowrap }
.regions .on{ background:var(--ink); color:#111 }

.hero{max-width:1200px;margin:16px auto 6px;padding:0 12px}
.hero h1{margin:0 0 6px;font-size:24px;font-weight:900}
.hero p{margin:0;color:var(--muted)}

/* 반응형: 모바일 1열, 태블릿 2열, 데스크톱 3열 */
.grid{ display:grid; gap:16px; margin:12px auto; max-width:1200px; padding:0 12px; }
@media (max-width:639px){ .grid{ grid-template-columns:1fr; } }
@media (min-width:640px) and (max-width:1023px){ .grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .grid{ grid-template-columns:repeat(3,1fr); } }

.card{background:var(--card);border:1px solid var(--line);border-radius:20px;overflow:hidden;transform:translateY(12px);opacity:0;transition:transform .45s ease,opacity .45s ease, box-shadow .3s ease}
.card.show{transform:none;opacity:1}
.card:hover{box-shadow:0 8px 24px rgba(0,0,0,.45)}
.thumb{display:block;background:#0d0f11}
.thumb img{width:100%;height:auto;display:block}
.meta{padding:12px}
.head{display:flex;align-items:center;gap:8px}
.rank{background:var(--accent);color:#111;padding:4px 10px;border-radius:10px;font-weight:900}
.name{font-size:18px;font-weight:800}
.one{color:var(--muted);margin:8px 0 10px}
.menus{color:var(--muted);font-size:14px;margin:6px 0}
.addr a{color:#93c5fd;text-decoration:none;border-bottom:1px dotted #375a7f}
.actions{margin-top:10px}
.actions button{background:#222;color:#fff;border:none;border-radius:10px;padding:10px 12px;cursor:pointer}
.pagination{display:flex;justify-content:center;gap:6px;margin:12px 0 10px;flex-wrap:wrap}
.pagination button{background:#15161a;color:#e5e7eb;border:1px solid #1f2937;border-radius:999px;padding:8px 12px;min-width:40px;cursor:pointer}
.pagination .on{background:var(--ink);color:#111}
footer{color:var(--muted);text-align:center;padding:16px;border-top:1px solid var(--line);margin-top:8px}
