/* 약국정보 — 검색 플랫폼 디자인 (프차넷 토스풍 토큰 차용 + 헬스 그린) */
:root{
  --bg:#fcfcfd; --surface:#fff; --surface-2:#fafafa;
  --border:#ebebec; --border-strong:#d4d4d8;
  --text:#0d0d0d; --text-2:#3f3f46; --text-3:#71717a; --text-4:#a1a1aa;
  --brand:#10b364; --brand-hover:#0a9152; --brand-soft:#e7f8ef; --brand-text:#0a8f50;
  --sky-bg:#eff6ff; --sky:#2563eb; --mint-bg:#ecfdf5; --mint:#059669;
  --peach-bg:#fff7ed; --peach:#ea580c; --lav-bg:#f5f3ff; --lav:#7c3aed;
  --rose-bg:#fdf2f8; --rose:#db2777; --slate-bg:#f8fafc; --slate:#475569; --indigo:#4f46e5;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --shadow:0 4px 12px rgba(0,0,0,.04),0 0 0 1px rgba(0,0,0,.02);
  --shadow-lg:0 12px 40px -8px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04);
  --radius:10px; --radius-lg:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Pretendard',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Segoe UI',sans-serif;background:var(--bg);color:var(--text);line-height:1.55;letter-spacing:-0.011em;-webkit-font-smoothing:antialiased;padding-bottom:64px}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:22px 20px 48px}

/* ── 상단 네비 ── */
.topbar{background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}
.tb-in{max-width:1080px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:12px 20px}
.tb-in .logo{font-size:19px;font-weight:800;color:var(--brand-text);white-space:nowrap;letter-spacing:-.03em}
.tb-in .logo b{color:var(--text)}
.tb-search{display:flex;flex:1;max-width:440px;background:var(--surface-2);border:1px solid var(--border);border-radius:11px;overflow:hidden}
.tb-search input{flex:1;padding:9px 14px;border:0;background:transparent;font-size:14px;outline:none;font-family:inherit}
.tb-search button{padding:0 14px;background:transparent;border:0;cursor:pointer;font-size:15px;color:var(--text-3)}

/* ── 검색 히어로 ── */
.hero{position:relative;text-align:center;padding:54px 20px 40px;margin:-22px -20px 26px;overflow:hidden;
  background:radial-gradient(1200px 560px at 50% -10%,var(--brand-soft),transparent 70%),linear-gradient(180deg,#f6fdf9,transparent)}
.hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(16,179,100,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(16,179,100,.05) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:radial-gradient(ellipse 700px 340px at 50% 0,#000,transparent 70%);mask-image:radial-gradient(ellipse 700px 340px at 50% 0,#000,transparent 70%);pointer-events:none}
.hero-in{position:relative;max-width:680px;margin:0 auto;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:#fff;padding:6px 14px 6px 8px;border-radius:999px;font-size:12px;font-weight:700;color:var(--text-2);border:1px solid var(--border);margin-bottom:18px;box-shadow:var(--shadow-sm)}
.hero-badge .dot{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#0ea5e9);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900}
.hero h1{font-size:38px;font-weight:900;letter-spacing:-0.045em;line-height:1.12;margin:0 0 12px;color:var(--text)}
.hero h1 .accent{background:linear-gradient(135deg,var(--brand),#0ea5e9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:16px;color:var(--text-3);margin:0 auto 24px;max-width:520px}
.hero-sub b{color:var(--brand-text);font-weight:700}
.hsearch{max-width:560px;margin:0 auto;display:flex;gap:8px;background:#fff;padding:8px;border-radius:16px;border:1px solid var(--border);box-shadow:0 12px 40px -12px rgba(16,179,100,.22),var(--shadow-sm);transition:.25s}
.hsearch:focus-within{box-shadow:0 16px 46px -8px rgba(16,179,100,.3),0 0 0 4px rgba(16,179,100,.12);transform:translateY(-1px);border-color:rgba(16,179,100,.3)}
.hsearch input{flex:1;border:0;outline:0;background:transparent;font-size:16px;padding:0 12px;font-family:inherit;color:var(--text)}
.hsearch button{background:var(--brand);color:#fff;border:0;border-radius:11px;padding:0 22px;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit}
.hsearch button:hover{background:var(--brand-hover)}
.hot{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.hot a{background:#fff;border:1px solid var(--border);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:700;color:var(--text-2);box-shadow:var(--shadow-sm)}
.hot a:hover{border-color:var(--brand);color:var(--brand-text)}
.hot a.now{background:var(--brand);border-color:var(--brand);color:#fff}

/* ── 카테고리 칩 그리드 ── */
.cat-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:24px}
.cat{display:flex;flex-direction:column;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 6px;text-align:center;box-shadow:var(--shadow-sm);transition:.16s}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}
.cat .ci{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--mint-bg)}
.cat .cl{font-size:12.5px;font-weight:700;color:var(--text-2);line-height:1.3}
.cat.c-now .ci{background:var(--brand-soft)} .cat.c-night .ci{background:var(--slate-bg)} .cat.c-sun .ci{background:var(--sky-bg)} .cat.c-hol .ci{background:var(--rose-bg)} .cat.c-h24 .ci{background:var(--peach-bg)} .cat.c-map .ci{background:var(--lav-bg)}

/* ── 섹션 ── */
.sec{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.sec h1{margin:0 0 6px;font-size:24px;font-weight:800;letter-spacing:-.03em}
.sec h2{margin:0 0 16px;font-size:18px;font-weight:800;letter-spacing:-.02em}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}
.sec-head h2{margin:0}.sec-head a{font-size:13px;font-weight:700;color:var(--brand-text)}
.cnt{color:var(--brand);font-size:16px;font-weight:800}
.lead{color:var(--text-3);margin:0 0 16px;font-size:14.5px}

/* ── 지역 그리드 ── */
.region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.region-card{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-weight:700;transition:.15s}
.region-card:hover{border-color:var(--brand);background:var(--brand-soft)}
.rc-cnt{color:var(--text-4);font-size:12.5px;font-weight:700;background:var(--surface-2);border-radius:999px;padding:2px 10px}

/* ── 필터/구목록 ── */
.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.fbtn{background:var(--surface);border:1px solid var(--border);color:var(--text-2);padding:8px 15px;border-radius:999px;font-weight:700;font-size:13.5px;box-shadow:var(--shadow-sm)}
.fbtn:hover{border-color:var(--brand);color:var(--brand-text)}
.fbtn.on{background:var(--brand);border-color:var(--brand);color:#fff}
.fbtn.map{background:var(--sky-bg);border-color:#bfdbfe;color:var(--sky)}
.gu-list{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.gu-list a{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:7px 13px;font-size:13.5px;font-weight:600}
.gu-list a:hover{border-color:var(--brand);color:var(--brand-text)}
.gu-list a i{color:var(--text-4);font-style:normal;font-size:12px;margin-left:4px}

/* ── 약국 카드 ── */
.ph-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}
.ph-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm);transition:.16s}
.ph-card:hover{border-color:transparent;box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.ph-top{display:flex;align-items:center;gap:7px;margin-bottom:6px;flex-wrap:wrap}
.ph-name{font-weight:800;font-size:15.5px;letter-spacing:-.02em}
.ph-addr{color:var(--text-3);font-size:13px;margin-bottom:9px;line-height:1.45}
.ph-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px}
.ph-tel{color:var(--brand-text);font-weight:700}
.ph-time{color:var(--text-3)}
.ph-time.off{color:var(--text-4)}
.badge{font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;line-height:1.3}
.badge.open{background:var(--brand-soft);color:var(--brand-text)}
.badge.closed{background:var(--surface-2);color:var(--text-4)}
.badge.night{background:#1e293b;color:#fff}
.badge.region{background:var(--mint-bg);color:var(--mint)}
.badge.dist{background:var(--sky-bg);color:var(--sky)}

/* ── breadcrumb ── */
.crumb{font-size:13px;color:var(--text-4);margin-bottom:16px}
.crumb a:hover{color:var(--brand-text)}.crumb span{color:var(--text-2)}

/* ── 상세 ── */
.detail{display:flex;flex-direction:column;gap:14px}
.dt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}
.dt-card>*:last-child{margin-bottom:0}
.dt-card .dt-h2{margin-top:0}
.dt-lazy{display:contents} /* lazy 컨테이너는 박스 없이, JS가 넣은 .dt-card 들을 형제 카드로 */
.dt-hero .kmap.mini{margin-bottom:0}
.dt-head h1{margin:0 0 10px;font-size:26px;font-weight:800;letter-spacing:-.03em}
.dt-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.dt-actions{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:18px}
.act-btn{padding:12px 20px;border-radius:12px;font-weight:800;font-size:14px}
.act-btn.call{background:var(--brand);color:#fff}
.act-btn.map{background:#fee500;color:#3a1d1d}
.act-btn.map2{background:#03c75a;color:#fff}
.dt-info,.hours{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:18px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.dt-info th,.hours th{text-align:left;width:96px;padding:11px 14px;background:var(--surface-2);font-size:13.5px;color:var(--text-3);font-weight:700;border-bottom:1px solid var(--border)}
.dt-info td,.hours td{padding:11px 14px;font-size:14px;border-bottom:1px solid var(--border)}
.dt-info tr:last-child th,.dt-info tr:last-child td,.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}
.hours tr.today th{background:var(--brand-soft);color:var(--brand-text)}
.hours tr.today td{background:#f4fdf8;font-weight:700}
.off{color:var(--text-4)}
.dt-h2{font-size:17px;font-weight:800;margin:24px 0 12px;letter-spacing:-.02em}
.dt-note{font-size:12.5px;color:var(--text-3);background:var(--surface-2);border-radius:var(--radius);padding:12px 15px;margin:0}
.near-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:9px}
.near-list a{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.near-list a:hover{border-color:var(--brand)}
.near-list b{display:block;font-size:14px}.near-list span{font-size:12px;color:var(--text-3)}

/* ── 피드 ── */
.feed-list{display:grid;gap:9px;margin-bottom:8px}
.feed-item{display:block;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px}
.feed-item:hover{border-color:var(--brand)}
.feed-item b{display:block;font-size:14px;color:var(--text);margin-bottom:3px}
.feed-item span{font-size:12.5px;color:var(--text-3);line-height:1.5}
.feed-item.news b{color:var(--sky)}

/* ── 지도 ── */
.kmap{width:100%;height:60vh;min-height:380px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}
.kmap.mini{height:240px;margin:0 0 18px}
.map-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}
.map-head h1{margin:0 0 14px;font-size:22px;font-weight:800;letter-spacing:-.03em}
.map-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.map-filters #mSi{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:700;max-width:170px;font-family:inherit;background:var(--surface-2)}
.map-cats{display:flex;gap:7px;flex-wrap:wrap}
.mc{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:700;cursor:pointer;color:var(--text-2);font-family:inherit}
.mc.on{background:var(--brand);border-color:var(--brand);color:#fff}
.map-status{margin-top:10px;font-size:13px;color:var(--text-3);text-align:center}

/* ── 히어로 CTA / 내주변 ── */
.hero-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.hc-btn{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);padding:11px 20px;border-radius:12px;font-weight:800;font-size:15px;box-shadow:var(--shadow-sm)}
.hc-btn:hover{border-color:var(--brand);color:var(--brand-text)}
.hc-btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.hc-btn.primary:hover{background:var(--brand-hover);color:#fff}
.near-status{text-align:center;padding:16px 0 20px;font-size:15px}
.near-status .loading{color:var(--text-3)}

/* ── 정보/기타 ── */
.info-list{margin:6px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.info-list li{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 15px;font-size:14px;color:var(--text-2)}
.info-list li b{color:var(--text)}
.info-note{font-size:13px;color:var(--text-3);margin:12px 0 0}
.more-note,.empty{color:var(--text-3);font-size:14px;text-align:center;padding:24px}
.err{text-align:center;padding:54px 20px}

/* ── 광고 ── */
.ad-foot,.ad-mid{margin:20px 0;text-align:center;min-height:90px}

/* ── 푸터 ── */
.ft{background:var(--surface);border-top:1px solid var(--border);margin-top:30px}
.ft-in{max-width:1080px;margin:0 auto;padding:28px 20px}
.ft-regions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.ft-regions a{font-size:13px;color:var(--text-3);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:5px 12px}
.ft-regions a:hover{color:var(--brand-text);border-color:var(--brand)}
.ft-note{font-size:12px;color:var(--text-4);margin:0 0 6px}.ft-copy{font-size:12px;color:var(--text-4);margin:0}

/* ── 하단 탭바 ── */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}
.tabbar .tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0 9px;font-size:11px;font-weight:700;color:var(--text-4)}
.tabbar .tab .ic{font-size:19px}
.tabbar .tab.on{color:var(--brand-text)}

@media(max-width:680px){
  .wrap{padding:16px 14px 40px}
  .hero{padding:38px 16px 30px;margin:-16px -14px 20px}
  .hero h1{font-size:28px}.hero-sub{font-size:14.5px}
  .cat-strip{grid-template-columns:repeat(3,1fr)}
  .sec,.dt-card,.map-wrap{padding:18px}
  .kmap{height:52vh}
}

/* ── 실시간 통계 밴드 ── */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:18px}
.statband .stat{background:var(--surface);padding:16px 12px;text-align:center;display:flex;flex-direction:column;gap:3px}
.statband .stat .sv{font-size:22px;font-weight:900;letter-spacing:-.03em;color:var(--text)}
.statband .stat .sl{font-size:12px;color:var(--text-3);font-weight:600}
.statband .stat.live .sv{color:var(--brand)}
.statband .stat.live{background:var(--brand-soft)}
/* 하단 여백 정리 */
.ft{margin-top:22px}
.ft-in{padding:22px 20px}
body{padding-bottom:60px}
@media(max-width:680px){
  .statband{grid-template-columns:repeat(2,1fr)}
  .statband .stat .sv{font-size:19px}
}

/* ── 섹션 헤더 액센트 (구분 강화) ── */
.sec{padding:22px 22px 24px}
.sec h2, .sec-head h2{position:relative;padding-left:13px;font-size:18px}
.sec h2::before, .sec-head h2::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:18px;border-radius:3px;background:var(--brand)}
.sec-head{align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.sec-head a{display:inline-flex;align-items:center;gap:3px;white-space:nowrap}
/* ── 약국 많은 동네 — 카드 그리드 ── */
.town-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:9px}
.town-card{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;transition:.14s}
.town-card:hover{background:var(--brand-soft);border-color:var(--brand)}
.town-card .tn{font-size:13.5px;font-weight:700;color:var(--text)}
.town-card .tn small{display:block;font-size:11.5px;font-weight:500;color:var(--text-4);margin-top:1px}
.town-card .tc{font-size:12px;font-weight:800;color:var(--brand-text);background:#fff;border:1px solid var(--border);border-radius:999px;padding:2px 9px;flex-shrink:0}
/* 통계밴드 라벨 줄바꿈 안정화 */
.statband .stat .sl{white-space:nowrap;line-height:1.3}
.statband .stat .sv{line-height:1.1}

/* ===== 메인 비주얼 업그레이드 v2 ===== */
/* 히어로 정제 */
.hero{padding:62px 20px 48px}
.hero h1{font-size:42px;letter-spacing:-0.05em}
.hero-sub{font-size:16.5px}
.hsearch{box-shadow:0 16px 50px -14px rgba(16,179,100,.28),var(--shadow-sm)}
/* 라이브 펄스 */
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(255,255,255,.55)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(16,179,100,.5)}70%{box-shadow:0 0 0 6px rgba(16,179,100,0)}100%{box-shadow:0 0 0 0 rgba(16,179,100,0)}}
.hot a.now{display:inline-flex;align-items:center;gap:6px}
.hot a.now .pulse{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulseRing 1.8s infinite}
.hot a.now b{font-weight:900}
/* 카테고리 — 앱 아이콘풍 그라데이션 타일 */
.cat{padding:20px 6px 15px;border-radius:16px}
.cat .ci{width:50px;height:50px;border-radius:15px;font-size:24px;box-shadow:0 6px 16px -6px rgba(0,0,0,.18)}
.cat.c-now .ci{background:linear-gradient(135deg,#10b364,#06b6d4)}
.cat.c-night .ci{background:linear-gradient(135deg,#475569,#1e293b)}
.cat.c-sun .ci{background:linear-gradient(135deg,#60a5fa,#2563eb)}
.cat.c-hol .ci{background:linear-gradient(135deg,#f472b6,#db2777)}
.cat.c-h24 .ci{background:linear-gradient(135deg,#fb923c,#ea580c)}
.cat.c-map .ci{background:linear-gradient(135deg,#a78bfa,#7c3aed)}
.cat .cl{font-weight:700;color:var(--text-2)}
.cat:hover{box-shadow:0 14px 34px -10px rgba(16,179,100,.18)}
/* 통계밴드 — 부드러운 카드 */
.statband{border:1px solid var(--border);background:var(--surface);gap:0;box-shadow:var(--shadow);position:relative}
.statband .stat{position:relative;padding:18px 12px}
.statband .stat + .stat::before{content:'';position:absolute;left:0;top:24%;height:52%;width:1px;background:var(--border)}
.statband .stat .sv{font-size:25px}
.statband .stat.live{background:linear-gradient(180deg,var(--brand-soft),#fff)}
.statband .stat.live .sl{display:flex;align-items:center;justify-content:center;gap:5px;color:var(--brand-text);font-weight:700}
.statband .stat.live .ldot{width:7px;height:7px;border-radius:50%;background:var(--brand);animation:pulseDot 1.8s infinite}
/* 약국 카드 호버 정제 */
.ph-card:hover{box-shadow:0 14px 36px -12px rgba(16,179,100,.16)}
.ph-name{font-size:16px}
/* 섹션 리듬 */
.cat-strip{margin-bottom:18px}
.sec{margin-bottom:16px}
.region-card{padding:15px 16px}
.region-card .rc-name{font-size:14.5px}

/* ===== SVG 아이콘 ===== */
svg{display:inline-block;vertical-align:middle;flex-shrink:0}
.tb-in .logo{display:inline-flex;align-items:center;gap:7px}
.lg-ic{width:23px;height:23px;color:var(--brand)}
.tb-search button .ic16{width:18px;height:18px}
.hero-badge .dot svg{width:11px;height:11px;color:#fff}
/* 카테고리 타일 — 화이트 SVG */
.cat .ci{color:#fff}
.cat .ci svg{width:25px;height:25px}
/* hot 칩 아이콘 */
.hot a{display:inline-flex;align-items:center;gap:6px}
.hot a .hic{width:15px;height:15px;color:var(--text-3)}
.hot a:hover .hic{color:var(--brand)}
.hot a.now .hic{color:#fff}
/* 하단 탭바 SVG */
.tabbar .tab .ic{width:22px;height:22px;color:currentColor}
.tabbar .tab.on .ic{color:var(--brand)}

/* ===== 지역/랭킹 섹션 디자인 업그레이드 ===== */
.region-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}
.region-card{flex-direction:column;align-items:stretch;gap:10px;padding:14px 15px 13px;background:var(--surface)}
.region-card .rc-head{display:flex;align-items:baseline;justify-content:space-between}
.region-card .rc-name{font-size:15px;font-weight:800;color:var(--text)}
.region-card .rc-cnt{background:none;border:0;padding:0;color:var(--brand-text);font-size:15.5px;font-weight:900}
.region-card .rc-cnt i{font-style:normal;font-size:11px;color:var(--text-4);font-weight:600;margin-left:1px}
.region-card .rc-bar{height:5px;background:var(--surface-2);border-radius:99px;overflow:hidden}
.region-card .rc-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),#06b6d4);border-radius:99px;transition:width .5s}
.region-card:hover{border-color:var(--brand);background:var(--surface);box-shadow:0 10px 24px -12px rgba(16,179,100,.3);transform:translateY(-2px)}
/* 랭킹 카드 */
.rank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.rank-card{display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:10px 13px;transition:.14s}
.rank-card:hover{background:#fff;border-color:var(--brand);box-shadow:0 8px 20px -10px rgba(16,179,100,.25)}
.rank-card.top{background:linear-gradient(135deg,#ffffff,var(--brand-soft));border-color:#c7f0db}
.rk{width:27px;height:27px;flex-shrink:0;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;background:var(--surface);border:1px solid var(--border);color:var(--text-4)}
.rk.r1{background:linear-gradient(135deg,#fcd34d,#f59e0b);color:#fff;border:0;box-shadow:0 3px 8px -2px rgba(245,158,11,.5)}
.rk.r2{background:linear-gradient(135deg,#e2e8f0,#94a3b8);color:#fff;border:0}
.rk.r3{background:linear-gradient(135deg,#fdba74,#ea580c);color:#fff;border:0}
.rk-name{flex:1;font-size:14px;font-weight:700;line-height:1.2;color:var(--text)}
.rk-name small{display:block;font-size:11px;color:var(--text-4);font-weight:500;margin-top:2px}
.rk-cnt{font-size:14.5px;font-weight:900;color:var(--brand-text)}
@media(max-width:680px){.rank-grid{grid-template-columns:1fr 1fr}.region-grid{grid-template-columns:repeat(2,1fr)}}

/* ── 상세 액션 버튼 (카카오맵 추가) ── */
.act-btn{display:inline-flex;align-items:center;gap:6px}
.act-btn .aic{width:17px;height:17px}
.act-btn.kakao{background:#fee500;color:#181600}
.act-btn.kakao:hover{background:#fada0a}
.act-btn.route{background:#eef2f7;color:#334155}
.act-btn.route:hover{background:#e2e8f0}
.act-btn.map2{background:#03c75a;color:#fff}
.act-btn.map2:hover{background:#02b350}

/* ── 카카오 평점·사진·리뷰 ── */
.kk-rate{display:flex;align-items:center;gap:9px;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:14px}
.kk-stars{color:#f59e0b;font-size:16px;letter-spacing:1px;line-height:1}
.kk-stars .off{color:#e2e8f0}
.kk-rate b{font-size:18px;font-weight:900}
.kk-rc{font-size:13px;color:var(--text-3);font-weight:600}
.kk-more{margin-left:auto;font-size:13px;font-weight:700;color:var(--brand-text)}
.kk-photos{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:16px}
.kk-photos a{flex:0 0 auto}
.kk-photos img{width:118px;height:118px;object-fit:cover;border-radius:12px;border:1px solid var(--border);display:block}
.kk-reviews{display:grid;gap:10px}
.kk-rv{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:13px 15px}
.kk-rv .kk-stars{font-size:13px}
.kk-rv p{margin:6px 0 0;font-size:13.5px;color:var(--text-2);line-height:1.6}
.kk-rv img{margin-top:10px;max-width:170px;border-radius:10px;border:1px solid var(--border)}

/* ── 리뷰 작성자 ── */
.kk-rv-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px}
.kk-ava{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.kk-ava.ph{display:flex;align-items:center;justify-content:center;background:var(--brand-soft);color:var(--brand-text);font-weight:800;font-size:12px}
.kk-author{font-size:13px;font-weight:700;color:var(--text)}
.kk-date{font-size:12px;color:var(--text-4);margin-left:auto}
.kk-rv .kk-stars{font-size:12.5px}
.kk-rvimg{margin-top:10px;max-width:170px;border-radius:10px;border:1px solid var(--border)}

/* ── 카드 썸네일 (카카오 매장사진 1장) ── */
.ph-card{display:flex;gap:13px;align-items:center}
.ph-thumb{flex:0 0 76px;width:76px;height:76px;border-radius:12px;background:var(--brand-soft) center/cover no-repeat;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ph-thumb .tph{width:26px;height:26px;color:var(--brand);opacity:.5}
.ph-thumb.has .tph{display:none}
.ph-body{flex:1;min-width:0}
.ph-body .ph-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:inline-block;vertical-align:bottom}
@media(max-width:680px){.ph-thumb{flex-basis:64px;width:64px;height:64px}}

/* ── 지도 이미지 핀 ── */
.map-pin{position:relative;width:46px;height:46px;cursor:pointer}
.map-pin img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 3px 9px rgba(0,0,0,.32);display:block;background:#fff}
.map-pin i{position:absolute;left:50%;bottom:-5px;transform:translateX(-50%);width:0;height:0;border:6px solid transparent;border-top-color:#fff;filter:drop-shadow(0 2px 1px rgba(0,0,0,.25))}
.map-pin.noimg{width:18px;height:18px;background:var(--brand);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 7px rgba(0,0,0,.3)}
.map-pin.noimg img{display:none}.map-pin.noimg i{display:none}

/* ── 지도/로드뷰 토글 ── */
.dmap-tab{display:inline-flex;margin-bottom:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:3px}
.dmt{border:0;background:transparent;padding:7px 20px;border-radius:8px;font-size:13.5px;font-weight:700;color:var(--text-3);cursor:pointer;font-family:inherit}
.dmt.on{background:#fff;color:var(--brand-text);box-shadow:var(--shadow-sm)}

/* ── 카카오 블로그 리뷰 ── */
.kk-blogs{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.kk-blog{display:flex;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-decoration:none;color:inherit;transition:.15s}
.kk-blog:hover{border-color:var(--brand);box-shadow:var(--shadow-sm)}
.kk-blog-th{flex:0 0 76px;width:76px;height:76px;border-radius:9px;overflow:hidden;background:var(--surface-2)}
.kk-blog-th img{width:100%;height:100%;object-fit:cover;display:block}
.kk-blog-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.kk-blog-body b{font-size:14.5px;font-weight:700;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.kk-blog-desc{font-size:12.5px;color:var(--text-3);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.kk-blog-meta{font-size:11.5px;color:var(--text-3);opacity:.85;margin-top:1px}

/* ── 페이지네이션 ── */
.pager{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center;margin:26px 0 4px}
.pg{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:14px;font-weight:700;text-decoration:none;transition:.15s}
.pg:hover{border-color:var(--brand);color:var(--brand-text)}
.pg.on{background:var(--brand);border-color:var(--brand);color:#fff}
.pg.nav{font-weight:600;color:var(--text-3)}
.pg-gap{color:var(--text-4);padding:0 2px}
@media(max-width:560px){ .pg.nav span{display:none} .pg{min-width:36px;height:36px;padding:0 9px} }

/* ── 카드 평점 ── */
.ph-rate{font-size:12.5px;font-weight:800;color:#b45309}
.ph-rate i{font-style:normal;color:var(--text-4);font-weight:600;font-size:11.5px}

/* ── 평점/리뷰 가로 스크롤 랭킹 섹션 ── */
.sec-rank .sec-head2{margin-top:22px;padding-top:20px;border-top:1px solid var(--border)}
.sec-tag{font-size:12px;font-weight:700;color:var(--text-3);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:3px 11px}
.ph-list.ph-scroll{display:flex;grid-template-columns:none;overflow-x:auto;gap:11px;padding:2px 2px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.ph-scroll .ph-card{flex:0 0 270px;scroll-snap-align:start}
.ph-scroll::-webkit-scrollbar{height:6px}
.ph-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}
.ph-thumb{position:relative}
.ph-rank{position:absolute;top:0;left:0;min-width:22px;height:22px;padding:0 5px;display:flex;align-items:center;justify-content:center;background:rgba(13,13,13,.72);color:#fff;font-size:12px;font-weight:800;border-radius:0 0 9px 0}
.ph-rank.top{background:var(--brand)}
@media(max-width:680px){ .ph-scroll .ph-card{flex-basis:240px} }

/* ── 전역 카테고리 메뉴 ── */
.catnav{border-top:1px solid var(--border);background:rgba(255,255,255,.9)}
.catnav-in{max-width:1080px;margin:0 auto;display:flex;gap:1px;padding:0 12px;overflow-x:auto;scrollbar-width:none}
.catnav-in::-webkit-scrollbar{display:none}
.cn{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:11px 12px;font-size:13.5px;font-weight:700;color:var(--text-3);border-bottom:2px solid transparent;transition:.12s}
.cn:hover{color:var(--text)}
.cn.on{color:var(--brand-text);border-bottom-color:var(--brand)}
.cn-ic{width:16px;height:16px;color:currentColor}
@media(max-width:560px){ .cn{padding:10px 11px;font-size:13px} .cn-ic{display:none} }

/* ── 상세 텍스트 콘텐츠 / FAQ ── */
.dt-text p{margin:0 0 11px;font-size:14.5px;line-height:1.72;color:var(--text-2)}
.dt-text p:last-child{margin-bottom:0}
.dt-faq .faq-item{padding:14px 0;border-bottom:1px solid var(--border)}
.dt-faq .faq-item:first-of-type{padding-top:4px}
.dt-faq .faq-item:last-child{border-bottom:0;padding-bottom:0}
.dt-faq .faq-q{margin:0 0 6px;font-size:14.5px;font-weight:800;color:var(--text)}
.dt-faq .faq-q::before{content:'Q ';color:var(--brand);font-weight:900}
.dt-faq .faq-a{margin:0;font-size:14px;line-height:1.66;color:var(--text-3)}

/* ── 약국 지도 2단 레이아웃 (좌 목록 + 우 지도) ── */
.gmap{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);height:calc(100vh - 210px);min-height:540px}
.gmap-side{flex:0 0 348px;display:flex;flex-direction:column;border-right:1px solid var(--border);min-width:0}
.gmap-head{padding:17px 18px 12px}
.gmap-head h1{margin:0 0 6px;font-size:20px;font-weight:800;letter-spacing:-.03em;display:flex;align-items:center;gap:7px}
.gmap-hic{width:20px;height:20px;color:var(--brand)}
.gmap-sub{margin:0;font-size:12.5px;color:var(--text-3);line-height:1.5}
.gmap-sub b{color:var(--brand-text);font-weight:800}
.gmap-cats{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 13px;border-bottom:1px solid var(--border)}
.gc{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:12.5px;font-weight:700;cursor:pointer;color:var(--text-2);font-family:inherit}
.gc:hover{border-color:var(--brand);color:var(--brand-text)}
.gc.on{background:var(--brand);border-color:var(--brand);color:#fff}
.gmap-regions{display:flex;flex-wrap:wrap;gap:5px;padding:12px 16px;border-bottom:1px solid var(--border)}
.gr{background:transparent;border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:12.5px;font-weight:700;cursor:pointer;color:var(--text-3);font-family:inherit}
.gr:hover{border-color:var(--brand);color:var(--brand-text)}
.gr.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand-text)}
.gmap-list{flex:1;overflow-y:auto;padding:7px;scrollbar-width:thin}
.gli{display:flex;align-items:center;gap:11px;padding:9px 9px;border-radius:11px;cursor:pointer;transition:.12s}
.gli:hover{background:var(--surface-2)}
.gli-th{flex:0 0 46px;width:46px;height:46px;border-radius:10px;background:var(--brand-soft) center/cover no-repeat;display:flex;align-items:center;justify-content:center;overflow:hidden}
.gli-th .tph{width:20px;height:20px;color:var(--brand);opacity:.5}
.gli-th.has .tph{display:none}
.gli-b{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.gli-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gli-addr{font-size:12px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gli-go{flex:0 0 auto;color:var(--text-4);font-size:22px;font-weight:700;line-height:1;padding:0 6px;text-decoration:none}
.gli-go:hover{color:var(--brand)}
.gmap-more,.gmap-empty{text-align:center;font-size:12px;color:var(--text-3);padding:14px 8px}
.gmap-map{flex:1;min-width:0;position:relative}
.gmap-canvas{position:absolute;inset:0;width:100%;height:100%}
.map-iw{padding:7px 11px;font-size:12.5px;line-height:1.5;min-width:120px}
.map-iw b{display:block;font-weight:800;margin-bottom:3px;color:var(--text)}
.map-iw a{color:var(--brand-text);font-weight:700;font-size:12px}
@media(max-width:860px){
  .gmap{flex-direction:column;height:auto;min-height:0}
  .gmap-map{order:-1;height:44vh;min-height:300px}
  .gmap-side{flex:none;border-right:0}
  .gmap-list{max-height:46vh}
}

/* ── 지도 사이드 검색 / 더보기 ── */
.gmap-search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:8px 12px;margin:9px 0 6px}
.gmap-search .gs-ic{width:16px;height:16px;color:var(--text-3);flex:0 0 auto}
.gmap-search input{flex:1;border:0;background:transparent;outline:none;font-size:14px;font-family:inherit;color:var(--text);min-width:0}
.gmap-morebtn{display:block;width:calc(100% - 14px);margin:8px auto 12px;padding:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;font-size:13.5px;font-weight:700;color:var(--text-2);cursor:pointer;font-family:inherit;transition:.12s}
.gmap-morebtn:hover{border-color:var(--brand);color:var(--brand-text)}
.gmap-morebtn span{color:var(--text-4);font-weight:600;margin-left:3px}

/* ── 지도 시군구 드릴다운 ── */
.gmap-gus{display:flex;flex-wrap:wrap;gap:5px;padding:10px 16px;border-bottom:1px solid var(--border);max-height:120px;overflow-y:auto;scrollbar-width:thin}
.gmap-gus:empty{display:none}
.gg{background:transparent;border:1px solid var(--border);border-radius:7px;padding:5px 9px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-3);font-family:inherit;white-space:nowrap}
.gg:hover{border-color:var(--brand);color:var(--brand-text)}
.gg.on{background:var(--brand);border-color:var(--brand);color:#fff}
/* ── 지도 위 커스텀 컨트롤 (내 위치 / 전체보기) ── */
.map-ctrls{position:absolute;left:12px;bottom:14px;z-index:2;display:flex;flex-direction:column;gap:7px}
.mctrl{width:40px;height:40px;border-radius:10px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-2);transition:.12s}
.mctrl:hover{color:var(--brand-text);border-color:var(--brand)}
.mctrl.on{color:var(--brand);opacity:.6}
.mctrl-ic{width:19px;height:19px}

/* ── 가이드 (정보형 콘텐츠) ── */
.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.guide-card{display:flex;flex-direction:column;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:.16s}
.guide-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}
.guide-card h2{margin:0;font-size:17px;font-weight:800;letter-spacing:-.02em;line-height:1.35;color:var(--text)}
.guide-card p{margin:0;font-size:13px;color:var(--text-3);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.guide-cat{align-self:flex-start;font-size:11.5px;font-weight:800;color:var(--brand-text);background:var(--brand-soft);border-radius:999px;padding:3px 11px}
.guide-more{margin-top:auto;font-size:13px;font-weight:700;color:var(--brand-text)}
.guide-article .guide-cat{margin-bottom:12px}
.guide-article h1{margin:0 0 10px;font-size:25px;font-weight:800;letter-spacing:-.03em;line-height:1.3}
.guide-meta{margin:0 0 20px;font-size:12.5px;color:var(--text-4)}
.guide-content{font-size:15px;line-height:1.82;color:var(--text-2)}
.guide-content h2{font-size:19px;font-weight:800;color:var(--text);margin:30px 0 13px;padding-top:18px;border-top:1px solid var(--border);letter-spacing:-.02em}
.guide-content h2:first-child{margin-top:0;padding-top:0;border-top:0}
.guide-content h3{font-size:16px;font-weight:800;color:var(--text);margin:22px 0 9px}
.guide-content p{margin:0 0 14px}
.guide-content ul,.guide-content ol{margin:0 0 16px;padding-left:22px}
.guide-content li{margin-bottom:7px}
.guide-content b{font-weight:700;color:var(--text)}
.guide-content code{background:var(--surface-2);padding:2px 7px;border-radius:5px;font-size:.92em}
.guide-content a{color:var(--brand-text);font-weight:700}
.guide-content a:hover{text-decoration:underline}
.guide-faq{margin-top:30px;padding-top:8px;border-top:1px solid var(--border)}
.guide-rel-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.guide-rel-list a{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px}
.guide-rel-list a:hover{border-color:var(--brand)}
.guide-rel-list b{display:block;font-size:14px;margin-bottom:4px}
.guide-rel-list span{font-size:12px;color:var(--text-3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
