/* ===== Paperlogy (제목용) — jsDelivr fonts-archive ===== */
@font-face{font-family:'Paperlogy';font-weight:500;font-style:normal;font-display:swap;src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy-5Medium.woff2') format('woff2')}
@font-face{font-family:'Paperlogy';font-weight:600;font-style:normal;font-display:swap;src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy-6SemiBold.woff2') format('woff2')}
@font-face{font-family:'Paperlogy';font-weight:700;font-style:normal;font-display:swap;src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy-7Bold.woff2') format('woff2')}
@font-face{font-family:'Paperlogy';font-weight:800;font-style:normal;font-display:swap;src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy-8ExtraBold.woff2') format('woff2')}
@font-face{font-family:'Paperlogy';font-weight:900;font-style:normal;font-display:swap;src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy-9Black.woff2') format('woff2')}

:root{
  --bg:#F2F4F6; --acc:#3182F6; --ink:#191F28; --sub:#8B95A1; --sub2:#4E5968;
  --line:#E5E8EB; --soft:#F2F4F6; --danger:#F04452; --danger-bg:#FDECEE; --naver:#03C75A;
  --display:'Paperlogy','Pretendard',sans-serif;
  --body:'Pretendard',-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{font-family:var(--body);background:#DCE0E5;color:var(--ink)}
::-webkit-scrollbar{width:0;height:0}
@keyframes pulseRing{0%{transform:translate(-50%,-50%) scale(.8);opacity:.55}70%{transform:translate(-50%,-50%) scale(2.4);opacity:0}100%{opacity:0}}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.stage{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px;
  background:radial-gradient(120% 120% at 50% 0%, #E7EAEE 0%, #D2D7DD 100%)}
.phone{position:relative;width:390px;height:844px;background:var(--bg);border-radius:46px;
  box-shadow:0 2px 6px rgba(0,0,0,.08),0 30px 70px rgba(20,30,50,.28);overflow:hidden;border:1px solid rgba(0,0,0,.06)}
@media (max-width:480px){
  .stage{padding:0;background:var(--bg)}
  .phone{width:100vw;height:100vh;height:100dvh;border-radius:0;border:none;box-shadow:none}
}

/* 상태바 */
.statusbar{position:absolute;top:0;left:0;right:0;height:48px;display:flex;align-items:center;
  justify-content:space-between;padding:0 28px;z-index:40;pointer-events:none}
.statusbar .time{font-size:15px;font-weight:700;letter-spacing:.3px}
.statusbar .icons{display:flex;align-items:center;gap:6px}
.signal{display:flex;align-items:flex-end;gap:2px;height:11px}
.signal i{width:3px;background:var(--ink);border-radius:1px;display:block}
.battery{width:22px;height:11px;border:1.5px solid var(--ink);border-radius:3px;padding:1.5px;position:relative}
.battery .lvl{width:70%;height:100%;background:var(--ink);border-radius:1px}

#app{position:absolute;inset:0}
.screen{position:absolute;inset:0;display:flex;flex-direction:column;padding-top:48px}

/* 공통 텍스트/요소 */
.step{font-size:13px;font-weight:700;color:var(--acc);letter-spacing:.2px}
.h1{font-family:var(--display);font-size:25px;font-weight:800;letter-spacing:-.5px;margin-top:8px}
.lead{font-size:14px;color:var(--sub);margin-top:6px;line-height:1.45}
.muted{color:var(--sub)}
.back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer}

.cta{height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:800;color:#fff;background:var(--acc);cursor:pointer;font-family:var(--display)}
.cta.disabled{background:#D1D6DB;cursor:default}

/* ===== 인원 설정 ===== */
.head{padding:18px 22px 14px}
.list{flex:1;overflow-y:auto;padding:4px 16px 16px}
.list-cap{font-size:13px;font-weight:700;color:var(--sub);padding:2px 6px 10px}
.member{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:13px 14px;
  box-shadow:0 1px 2px rgba(0,0,0,.04);margin-bottom:8px}
.avatar{width:40px;height:40px;border-radius:13px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;font-size:14px;font-weight:800;color:#fff}
.avatar.sm{width:34px;height:34px;border-radius:10px;font-size:12px}
.avatar.xs{width:30px;height:30px;border-radius:9px;font-size:11px}
.m-main{flex:1;min-width:0;cursor:pointer}
.m-name{font-size:15px;font-weight:700}
.m-name input{font-size:15px;font-weight:700;border:none;background:transparent;width:100%;padding:0;outline:none;color:var(--ink)}
.m-loc{display:flex;align-items:center;gap:5px;margin-top:3px}
.m-loc .ring{width:12px;height:12px;border-radius:50%;border:3px solid;box-sizing:border-box}
.m-loc .txt{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip-edit{font-size:12px;font-weight:700;color:var(--sub);background:var(--soft);border-radius:9px;padding:7px 11px;cursor:pointer;flex-shrink:0}
.chip-x{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#C4C9D0;font-size:18px;cursor:pointer;flex-shrink:0}
.add{display:flex;align-items:center;justify-content:center;gap:7px;border:1.5px dashed #C9D0D8;border-radius:16px;
  padding:15px;cursor:pointer;color:var(--sub2);font-size:14px;font-weight:700}
.add span{font-size:18px;color:var(--acc)}
.footer{padding:12px 18px 26px;background:linear-gradient(to top,var(--bg) 70%,rgba(242,244,246,0))}

/* ===== 지도 ===== */
.map{position:relative;border-radius:20px;overflow:hidden;background:#E6EBEF;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.map .tag{position:absolute;right:10px;bottom:10px;font-family:ui-monospace,monospace;font-size:10px;color:#9AA6B0;
  background:rgba(255,255,255,.8);padding:3px 7px;border-radius:6px;z-index:5;pointer-events:none}
.map.ph{display:flex;align-items:center;justify-content:center}
.ph-grid::before{content:'';position:absolute;inset:0;background:
  linear-gradient(115deg,transparent 48%,#D7DEE4 48%,#D7DEE4 52%,transparent 52%),
  linear-gradient(35deg,transparent 60%,#DCE3E8 60%,#DCE3E8 63%,transparent 63%)}
.ph-pin{position:absolute;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;border:2.5px solid #fff;
  box-shadow:0 2px 5px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff}

.region-chips{display:flex;flex-wrap:wrap;gap:8px}
.rchip{padding:11px 16px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;border:1.5px solid}

/* ===== 결과 ===== */
.result-top{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 8px}
.result-title{display:flex;align-items:center;gap:2px}
.result-title b{font-size:17px;font-weight:800;font-family:var(--display)}
.tabs{display:flex;flex-shrink:0;background:#E5E8EB;border-radius:11px;padding:3px;gap:2px}
.tab{padding:6px 12px;border-radius:9px;font-size:12px;font-weight:700;cursor:pointer}
.tab.on{background:var(--ink);color:#fff}
.tab.off{color:var(--sub)}
.scroll{flex:1;overflow-y:auto;padding:6px 16px 22px}

.card{background:#fff;border-radius:20px;padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.sel-name{font-family:var(--display);font-size:22px;font-weight:800;letter-spacing:-.4px}
.big-min{font-size:26px;font-weight:800;color:var(--acc);line-height:1.1;font-family:var(--display)}
.stat3{display:flex;gap:8px;margin-top:14px}
.stat{flex:1;background:var(--soft);border-radius:12px;padding:10px 12px}
.stat .k{font-size:11px;font-weight:700;color:var(--sub)}
.stat .v{font-size:15px;font-weight:800;margin-top:2px}

.lasttrain{display:flex;align-items:center;gap:12px;background:var(--danger-bg);border-radius:16px;padding:14px 16px;margin-top:10px}
.lasttrain .k{font-size:12px;font-weight:800;color:var(--danger)}
.lasttrain .v{font-size:14px;font-weight:700;margin-top:2px}
.lasttrain .go{font-size:12px;font-weight:800;color:var(--danger);background:#fff;border-radius:10px;padding:8px 12px;cursor:pointer;flex-shrink:0}

.cand-row{display:flex;gap:8px;margin-top:12px}
.cand{flex:1;border-radius:14px;padding:12px 10px;cursor:pointer;border:1.5px solid}
.cand .n{font-size:13px;font-weight:800}
.cand .a{font-size:18px;font-weight:800;color:var(--acc);margin-top:4px}

.section-cap{font-size:13px;font-weight:700;color:var(--sub);margin:18px 4px 10px}
.rows{background:#fff;border-radius:18px;padding:8px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.row{display:flex;align-items:center;gap:11px;padding:10px;cursor:pointer}
.row .body{flex:1;min-width:0}
.row .l1{display:flex;align-items:center;justify-content:space-between}
.row .nm{font-size:14px;font-weight:700}
.row .nm small{font-size:12px;color:#B0B8C1;font-weight:600}
.row .tm{font-size:14px;font-weight:800}
.bar{height:6px;background:#EEF1F4;border-radius:4px;margin-top:7px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:4px}

/* 비교형 카드 */
.compare{border-radius:18px;padding:16px;cursor:pointer;border:2px solid;margin-bottom:10px}
.compare .top{display:flex;align-items:center;justify-content:space-between}
.compare .nm{font-size:18px;font-weight:800;font-family:var(--display)}
.badge{font-size:11px;font-weight:800;color:#fff;background:var(--acc);padding:3px 8px;border-radius:7px}
.compare .sub{font-size:12px;color:var(--sub);margin-top:3px}
.compare .kv{display:flex;gap:18px;margin-top:12px}
.compare .kv .k{font-size:11px;font-weight:700;color:var(--sub)}
.compare .kv .v{font-size:14px;font-weight:800;margin-top:2px}

/* 요약형 히어로 */
.hero{background:var(--ink);border-radius:22px;padding:22px;color:#fff;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;right:-30px;top:-30px;width:140px;height:140px;border-radius:50%;background:rgba(49,130,246,.25)}
.hero .cap{font-size:12px;font-weight:800;color:#7FB0FF;letter-spacing:.3px;position:relative}
.hero .nm{font-family:var(--display);font-size:30px;font-weight:800;margin-top:8px;letter-spacing:-.5px;position:relative}
.hero .big{display:flex;align-items:flex-end;gap:6px;margin-top:14px;position:relative}
.hero .big b{font-size:40px;font-weight:800;line-height:1;font-family:var(--display)}
.hero .big span{font-size:14px;color:#9DA7B3;margin-bottom:5px}
.hero .pills{display:flex;gap:8px;margin-top:8px;position:relative;flex-wrap:wrap}
.hero .pill{font-size:12px;font-weight:700;padding:7px 12px;border-radius:10px;cursor:pointer;color:var(--ink)}

.rank-row{display:flex;align-items:center;gap:10px;padding:11px 12px;cursor:pointer}
.rank-row .nm{font-size:14px;font-weight:700;width:54px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-row .bar{flex:1;margin-top:0;height:7px}
.rank-row .tm{font-size:13px;font-weight:800;width:34px;text-align:right}
.rank-row .last{font-size:12px;width:46px;text-align:right}

/* ===== 바텀시트 ===== */
.sheet-wrap{position:absolute;inset:0;z-index:60;animation:fadeIn .15s ease}
.scrim{position:absolute;inset:0;background:rgba(20,30,45,.4)}
.sheet{position:absolute;left:0;right:0;bottom:0;max-height:82%;background:#fff;border-radius:24px 24px 0 0;
  animation:sheetUp .25s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;padding-bottom:20px}
.grip{display:flex;justify-content:center;padding:12px}
.grip i{width:38px;height:4px;border-radius:2px;background:#E0E4E8}
.sheet h3{padding:0 22px;font-size:19px;font-weight:800;font-family:var(--display)}
.sheet .sub{padding:3px 22px 12px;font-size:13px;color:var(--sub)}
.search{margin:0 18px 10px;display:flex;align-items:center;gap:8px;background:var(--soft);border-radius:13px;padding:12px 14px}
.search input{flex:1;border:none;background:transparent;outline:none;font-size:15px;font-family:var(--body);color:var(--ink)}
.sheet-list{flex:1;overflow-y:auto;padding:0 14px}
.opt{display:flex;align-items:center;gap:12px;padding:13px 12px;border-radius:13px;cursor:pointer}
.opt:active{background:var(--soft)}
.opt .ic{width:34px;height:34px;border-radius:50%;background:#EAF2FE;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.opt .ic i{width:12px;height:12px;border-radius:50%;border:3px solid var(--acc);box-sizing:border-box}
.opt .t1{font-size:15px;font-weight:700}
.opt .t2{font-size:12px;color:var(--sub);margin-top:1px}
.opt .ck{color:var(--acc);font-size:18px;font-weight:800}
.empty{padding:30px 22px;text-align:center;color:var(--sub);font-size:14px;line-height:1.5}

/* ===== 경로 오버레이 ===== */
.overlay{position:absolute;inset:0;z-index:70;background:var(--bg);animation:fadeIn .15s ease;display:flex;flex-direction:column;padding-top:48px}
.ov-top{display:flex;align-items:center;gap:6px;padding:6px 14px 10px}
.ov-top b{font-size:17px;font-weight:800;font-family:var(--display)}
.route-head{display:flex;align-items:center;gap:12px;background:#fff;border-radius:18px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.route-head .body{flex:1;min-width:0}
.route-head .nm{font-size:16px;font-weight:800}
.route-head .od{font-size:13px;color:var(--sub);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.route-head .tot{font-size:20px;font-weight:800;color:var(--acc);font-family:var(--display)}
.legs{background:#fff;border-radius:18px;padding:18px 18px 8px;margin-top:12px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.leg{display:flex;gap:14px;padding-bottom:16px}
.leg .rail{display:flex;flex-direction:column;align-items:center}
.leg .rail .dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}
.leg .rail .line{width:2px;flex:1;background:var(--line);margin-top:2px}
.leg .b{flex:1;margin-top:-3px}
.leg .l1{display:flex;align-items:center;justify-content:space-between}
.leg .md{font-size:15px;font-weight:800}
.leg .mn{font-size:14px;font-weight:800;color:var(--sub2)}
.leg .sb{font-size:12px;color:var(--sub);margin-top:3px}
.naver-btn{height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:16px;font-weight:800;color:#fff;background:var(--naver);margin-top:14px;cursor:pointer;text-decoration:none;font-family:var(--display)}
/* 권역 pill (결과 헤더) */
.region-pill{font-size:11px;font-weight:700;color:var(--acc);background:#EAF2FE;border-radius:7px;padding:3px 8px;margin-left:8px}

/* 피커 모드 탭 */
.pmodes{display:flex;gap:6px;margin:2px 18px 12px}
.pmode{flex:1;text-align:center;padding:9px;border-radius:11px;font-size:13px;font-weight:700;color:var(--sub);background:var(--soft);cursor:pointer}
.pmode.on{background:var(--ink);color:#fff}
/* 지도에서 선택 */
.pickmap-wrap{position:relative;margin:0 16px;border-radius:16px;overflow:hidden}
.pickmap-wrap .map{border-radius:16px}
.pickpin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);font-size:30px;z-index:10;pointer-events:none;filter:drop-shadow(0 3px 4px rgba(0,0,0,.3))}
.pick-foot{padding:14px 18px 4px}
.pick-addr{font-size:14px;font-weight:700;color:var(--ink);min-height:20px;margin-bottom:12px;line-height:1.4}

/* 토스트 */
.toast{position:absolute;left:50%;bottom:60px;transform:translateX(-50%) translateY(10px);max-width:80%;
  background:rgba(25,31,40,.95);color:#fff;font-size:13px;font-weight:600;padding:11px 16px;border-radius:12px;
  opacity:0;pointer-events:none;transition:.22s;z-index:90;text-align:center;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--sub)}
.spinner{width:34px;height:34px;border:3px solid #E5E8EB;border-top-color:var(--acc);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
