/* ============================================================
   사람찾기 — 디자인 시스템 (공통)
   화이트 / 구글 톤
   ============================================================ */
:root{
  --paper:#ffffff;
  --paper-2:#f8f9fa;
  --card:#ffffff;
  --ink:#202124;
  --muted:#565a60;
  --line:#ececec;
  --line-2:#dadce0;
  --accent:#1a73e8;
  --accent-deep:#1557b0;
  --accent-soft:#e8f0fe;
  --ok:#188038;
  --ok-soft:#e6f4ea;
  --warn:#b06000;
  --warn-soft:#fef7e0;
  --danger:#d93025;
  --danger-soft:#fce8e6;
  --shadow:0 1px 2px rgba(60,64,67,.06), 0 4px 16px -8px rgba(60,64,67,.16);
  --shadow-lg:0 1px 3px rgba(60,64,67,.10), 0 12px 32px -14px rgba(60,64,67,.22);
  --r:12px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"IBM Plex Sans KR",system-ui,sans-serif;
  color:var(--ink);
  background:#ffffff;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  font-weight:400;
  letter-spacing:-.01em;
}
.wrap{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:0 20px 80px;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select,textarea{font-family:inherit;font-size:16px;color:var(--ink);}

/* ---------- header ---------- */
header.bar{
  position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;
  max-width:920px;margin:0 auto;padding:18px 20px 16px;
}
.brand{display:flex;align-items:center;gap:9px;cursor:pointer;}
.brand .mark{width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #5b9bf5, var(--accent) 60%, var(--accent-deep));
  box-shadow:0 2px 8px -2px rgba(26,115,232,.55);position:relative;flex:none;}
.brand .mark::after{content:"";position:absolute;width:11px;height:11px;border:2.4px solid #fff;
  border-radius:50%;top:6px;left:6px;}
.brand .mark::before{content:"";position:absolute;width:7px;height:2.4px;background:#fff;border-radius:3px;
  bottom:6.5px;right:4.5px;transform:rotate(45deg);}
.brand b{font-family:"Gowun Batang",serif;font-size:21px;font-weight:700;letter-spacing:.02em;color:var(--ink);}
nav.menu{display:flex;gap:4px;}
nav.menu a{font-size:15px;color:var(--muted);padding:7px 13px;border-radius:9px;font-weight:500;transition:.15s;}
nav.menu a:hover{background:#0000000a;color:var(--ink);}
nav.menu a.on{color:var(--accent-deep);background:var(--accent-soft);}
nav.menu a.bell{font-size:16.5px;padding:7px 10px;position:relative;}
nav.menu .who-mini{font-size:14px;color:var(--ink);font-weight:600;padding:7px 6px 7px 10px;}
nav.menu a.logout{font-size:13.5px;color:var(--muted);padding:7px 10px;}
nav.menu a.logout:hover{color:var(--danger);}
.badge{display:inline-flex;min-width:17px;height:17px;padding:0 5px;margin-left:5px;border-radius:9px;
  background:var(--accent);color:#fff;font-size:11px;font-weight:600;align-items:center;justify-content:center;}

/* ---------- section / cards ---------- */
.sec-title{font-family:"Gowun Batang",serif;font-size:26px;font-weight:700;margin:48px 0 4px;}
.sec-sub{color:var(--muted);font-size:14.5px;margin:0 0 20px;}
.grid{display:grid;gap:14px;}
.post{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow);
  transition:.16s;cursor:pointer;position:relative;overflow:hidden;display:block;}
.post:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.post .meta{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-bottom:9px;}
.tag{font-size:12px;font-weight:600;padding:4px 10px;border-radius:8px;background:var(--accent-soft);color:var(--accent-deep);}
.tag.t2{background:var(--ok-soft);color:var(--ok);}
.tag.t3{background:#f1f3f4;color:var(--muted);}
.tag.tg{background:#f3e8fd;color:#7b1fa2;}
.post h3{font-family:"Gowun Batang",serif;font-size:20px;margin:0 0 6px;font-weight:700;color:var(--ink);}
.post .desc{color:#4d5156;font-size:15.5px;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.post .foot{display:flex;align-items:center;justify-content:space-between;margin-top:13px;}
.post .who{font-size:13.5px;color:var(--muted);}
.respond-btn{font-size:14px;font-weight:600;color:var(--accent-deep);background:var(--accent-soft);padding:8px 14px;border-radius:10px;transition:.15s;white-space:nowrap;}
.post:hover .respond-btn{background:var(--accent);color:#fff;}
.resp-count{font-size:12px;color:var(--ok);font-weight:600;}
.empty{text-align:center;color:var(--muted);font-size:15.5px;padding:46px 20px;border:1px dashed var(--line-2);border-radius:var(--r);background:var(--paper-2);}

/* ---------- forms / panels ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px 30px;box-shadow:var(--shadow);margin-top:24px;}
.panel.lg{max-width:none;margin:24px auto 0;}  /* v29.1: .wrap(920px) 전체 사용 — 목록 화면과 폭 통일 */
.ptitle{font-family:"Gowun Batang",serif;font-size:30px;font-weight:700;margin:0 0 4px;}
.pdesc{color:var(--muted);font-size:15.5px;margin:0 0 24px;line-height:1.6;}
.field{margin-bottom:18px;}
.field > label{display:block;font-size:14.5px;font-weight:600;margin-bottom:7px;color:#3c4043;}
.field .req{color:var(--accent);}
.field .hint{font-size:13px;color:var(--muted);font-weight:400;margin-left:6px;}
.ctrl{width:100%;border:1px solid var(--line-2);background:var(--paper-2);border-radius:10px;padding:12px 14px;outline:none;transition:.15s;}
.ctrl:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(26,115,232,.12);}
/* 키보드 포커스 표시(접근성) */
a:focus-visible,button:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible,.post:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;}
input:focus-visible{outline:2px solid var(--accent);outline-offset:1px;}
textarea.ctrl{resize:vertical;min-height:80px;line-height:1.6;}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.vq{border:1px solid var(--line);background:var(--paper-2);border-radius:12px;padding:14px;margin-bottom:10px;position:relative;}
.vq .row{margin-bottom:0;}
.vq .del{position:absolute;top:10px;right:10px;font-size:12px;color:var(--danger);font-weight:600;}
.addq{font-size:14px;font-weight:600;color:var(--accent-deep);border:1px dashed var(--line-2);border-radius:10px;padding:11px;width:100%;transition:.15s;}
.addq:hover{border-color:var(--accent);background:var(--accent-soft);}
.submit{background:var(--accent);color:#fff;font-weight:600;font-size:16.5px;padding:14px 28px;border-radius:12px;width:100%;
  box-shadow:0 6px 18px -6px rgba(26,115,232,.45);transition:.15s;margin-top:8px;}
.submit:hover{background:var(--accent-deep);}
.backlink{font-size:14.5px;color:var(--muted);font-weight:500;margin:24px 0 0;display:inline-flex;gap:5px;align-items:center;}
.backlink:hover{color:var(--accent-deep);}
.info-strip{background:var(--accent-soft);border:1px solid #c5dbf7;border-radius:12px;padding:12px 16px;font-size:12.5px;color:var(--accent-deep);line-height:1.6;margin-bottom:18px;}
.info-strip b{font-weight:700;}

/* ---------- detail ---------- */
.detail-head{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px;}
.kv{display:grid;grid-template-columns:104px 1fr;gap:7px 14px;font-size:15.5px;line-height:1.6;margin:14px 0;}
.kv .k{color:var(--muted);font-weight:500;}
.kv .v{color:var(--ink);}
.lockbox{background:var(--paper-2);border:1px dashed var(--line-2);border-radius:12px;padding:16px;color:var(--muted);font-size:14px;text-align:center;line-height:1.6;}
.lockbox .lk{font-size:20px;}

/* ---------- dashboard ---------- */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:8px;}
.tabs a{padding:11px 14px;font-size:15px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;}
.tabs a.on{color:var(--accent-deep);border-bottom-color:var(--accent);}
.resp-item{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--paper-2);margin-bottom:12px;}
.resp-item .top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;}
.stat{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px;}
.stat.pending{background:var(--warn-soft);color:var(--warn);}
.stat.owner_approved{background:var(--accent-soft);color:var(--accent-deep);}
.stat.exchanged{background:var(--ok-soft);color:var(--ok);}
.stat.rejected{background:var(--danger-soft);color:var(--danger);}
.vcheck{margin:12px 0;font-size:14.5px;}
.vcheck .qrow{padding:9px 0;border-bottom:1px dashed var(--line);}
.vcheck .qrow:last-child{border:none;}
.vcheck .q{color:var(--muted);font-size:12.5px;margin-bottom:3px;}
.vcheck .ans{font-weight:600;}
.vcheck .correct{color:var(--ok);font-size:12px;margin-left:8px;font-weight:500;}
.vcheck .miss{color:var(--danger);font-size:12px;margin-left:8px;font-weight:500;}
.btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.btn-ok{background:var(--ok);color:#fff;font-weight:600;font-size:14px;padding:9px 16px;border-radius:9px;}
.btn-ok:hover{filter:brightness(.94);}
.btn-no{background:var(--danger-soft);color:var(--danger);font-weight:600;font-size:14px;padding:9px 16px;border-radius:9px;}
.btn-no:hover{filter:brightness(.97);}
.btn-line{border:1px solid var(--line-2);background:#fff;font-weight:600;font-size:14px;padding:9px 16px;border-radius:9px;color:var(--ink);}
.btn-line:hover{border-color:var(--accent);color:var(--accent-deep);}
.reveal{background:linear-gradient(180deg,var(--ok-soft),#fff);border:1px solid #bfe6cd;border-radius:12px;padding:16px;text-align:center;margin-top:12px;}
.reveal .num{font-family:"Gowun Batang",serif;font-size:24px;font-weight:700;color:var(--ok);letter-spacing:.03em;}
.thread{margin:10px 0;}
.msg{font-size:13px;padding:8px 12px;border-radius:10px;margin-bottom:6px;max-width:85%;line-height:1.5;}
.msg.owner{background:var(--accent-soft);color:var(--accent-deep);margin-right:auto;}
.msg.responder{background:#e7eef3;color:#2a4a6a;margin-left:auto;text-align:right;}
.progress{display:flex;gap:4px;margin:10px 0 4px;}
.step{flex:1;height:5px;border-radius:4px;background:var(--line);}
.step.done{background:var(--accent);}
.step.now{background:var(--accent);opacity:.5;}

/* ---------- 대분류 탭 (둘러보기) ---------- */
.cat-tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 8px;margin:26px 0 2px;-webkit-overflow-scrolling:touch;}
.cat-tabs::-webkit-scrollbar{height:0;}
.cat-tab{flex:none;font-size:14.5px;font-weight:600;padding:8px 15px;border-radius:22px;border:1px solid var(--line-2);
  background:#fff;color:var(--muted);white-space:nowrap;transition:.15s;}
.cat-tab:hover{border-color:var(--accent);color:var(--accent-deep);}
.cat-tab.on{background:var(--accent);border-color:var(--accent);color:#fff;}
.cat-tab .c{font-weight:500;margin-left:6px;font-size:12px;opacity:.85;}

/* ---------- 보조 필터 ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:4px 0 10px;}
.fseg{display:inline-flex;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;}
.fseg button{padding:9px 15px;font-size:14px;font-weight:600;color:var(--muted);background:#fff;border-right:1px solid var(--line);transition:.12s;}
.fseg button:last-child{border-right:none;}
.fseg button.on{background:var(--accent);color:#fff;}
.kind-seg button{padding:11px 18px;}
.fsel{border:1px solid var(--line-2);background:#fff;border-radius:10px;padding:9px 13px;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;}
.fsel:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(26,115,232,.12);}
.fclear{font-size:13.5px;color:var(--muted);font-weight:600;padding:8px 10px;border-radius:8px;}
.fclear:hover{color:var(--accent-deep);background:var(--accent-soft);}

/* ---------- 지역 콤보박스 (RegionPicker) ---------- */
.rp{position:relative;width:100%;}
.rp-input{width:100%;}
.rp-panel{position:absolute;z-index:40;top:calc(100% + 5px);left:0;right:0;background:#fff;border:1px solid var(--line-2);
  border-radius:11px;box-shadow:var(--shadow-lg);max-height:300px;overflow:auto;display:none;padding:5px;}
.rp-panel.open{display:block;}
.rp-item{padding:10px 13px;font-size:14.5px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;border-radius:8px;}
.rp-item:hover,.rp-item.active{background:var(--accent-soft);color:var(--accent-deep);}
.rp-item .lv{font-size:11px;color:var(--muted);font-weight:500;flex:none;}
.rp-item:hover .lv,.rp-item.active .lv{color:var(--accent-deep);}
.rp-empty{padding:12px;color:var(--muted);font-size:13px;text-align:center;}
.fpick{flex:0 0 240px;max-width:240px;}

/* ---------- 응답 신뢰도 / 신고 ---------- */
.vscore{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;}
.vscore.good{background:var(--ok-soft);color:var(--ok);}
.vscore.mid{background:var(--warn-soft);color:var(--warn);}
.vscore.bad{background:var(--danger-soft);color:var(--danger);}
.report-link{display:inline-block;margin-top:16px;font-size:12.5px;color:var(--muted);font-weight:500;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;}
.report-link:hover{color:var(--danger);}
.notice{text-align:center;color:var(--muted);font-size:15.5px;padding:40px 20px;line-height:1.7;}

/* ---------- 휴대폰 본인확인 ---------- */
.pv-row{display:flex;gap:8px;align-items:center;}
.pv-row .ctrl{flex:1;}
.pv-row .btn-line,.pv-row .btn-ok{flex:none;white-space:nowrap;}
.pv-code{margin-top:10px;}
.pv-demo{font-size:12.5px;color:var(--accent-deep);background:var(--accent-soft);border-radius:8px;padding:8px 12px;margin-bottom:8px;line-height:1.5;}
.pv-hint{color:var(--muted);font-weight:400;}
.pv-done{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--ok);background:var(--ok-soft);border-radius:10px;padding:11px 14px;}
.pv-done .pv-num{color:var(--ink);font-weight:500;}
.pv-reset{margin-left:auto;font-size:12px;color:var(--muted);font-weight:600;text-decoration:underline;}

/* ---------- 자동완성 래퍼 / 본인확인 배지 ---------- */
.ac{position:relative;}
.vbadge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--ok-soft);color:var(--ok);}

/* ---------- 신고 사유 박스 ---------- */
.report-box{border:1px solid var(--line-2);border-radius:12px;padding:14px 16px;margin-top:12px;background:var(--paper-2);}
.report-box .rl{font-size:13px;font-weight:600;color:#3c4043;}
.report-box .rr{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0;}
.report-box .rr button{font-size:12.5px;padding:7px 12px;border-radius:20px;border:1px solid var(--line-2);background:#fff;color:var(--muted);font-weight:600;}
.report-box .rr button.on{background:var(--danger-soft);border-color:var(--danger);color:var(--danger);}

/* ---------- 필터 토글 (본인확인 글만) ---------- */
.ftoggle{font-size:14px;font-weight:600;padding:8px 14px;border-radius:10px;border:1px solid var(--line-2);background:#fff;color:var(--muted);transition:.12s;}
.ftoggle:hover{border-color:var(--accent);color:var(--accent-deep);}
.ftoggle.on{background:var(--ok);border-color:var(--ok);color:#fff;}

/* ---------- 알림 목록 ---------- */
.noti{display:flex;align-items:center;gap:12px;padding:15px 16px;border:1px solid var(--line);border-radius:12px;
  background:var(--card);margin-bottom:10px;box-shadow:var(--shadow);transition:.15s;}
.noti:hover{border-color:var(--line-2);transform:translateY(-1px);}
.noti.unread{background:var(--accent-soft);border-color:#c5dbf7;}
.noti-dot{width:8px;height:8px;border-radius:50%;background:transparent;flex:none;}
.noti.unread .noti-dot{background:var(--accent);}
.noti-text{flex:1;font-size:15.5px;line-height:1.5;color:var(--ink);}
.noti-time{flex:none;font-size:12px;color:var(--muted);}

/* ---------- 전환 ---------- */
@keyframes sf-in{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.post{animation:sf-in .24s ease both;}
.toast{animation:sf-in .2s ease both;}

/* ---------- 접근성 / 반응형 ---------- */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,.cat-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;}
@media(max-width:560px){
  .fpick{flex:1 1 100%;max-width:none;}
  .filters{gap:8px;}
  .fsel,.fseg{width:auto;}
}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);background:var(--ink);color:#fff;padding:14px 24px;border-radius:30px;font-size:15px;font-weight:500;z-index:99;box-shadow:var(--shadow-lg);}

@media(max-width:560px){
  .row,.row3{grid-template-columns:1fr;}
  .panel{padding:22px 18px;}
  nav.menu a{padding:7px 9px;font-size:13.5px;}
  .kv{grid-template-columns:78px 1fr;}
}

/* ── v26 UI 폴리시 ── */
.submit{transition:background .15s, transform .08s;}
.submit:active{transform:translateY(1px);}
.btn-ok,.btn-no{transition:filter .15s, transform .08s;}
.btn-ok:hover{filter:brightness(1.06);}
.btn-no:hover{filter:brightness(1.04);}
.btn-line:active,.btn-ok:active,.btn-no:active{transform:translateY(1px);}
.fseg button{cursor:pointer;}
.fseg button:hover:not(.on){background:var(--paper-2);color:var(--ink);}
.cat-tab{cursor:pointer;}
.report-link:hover{color:var(--danger);}
.backlink:hover{color:var(--accent-deep);}
.tag.tg{transition:.15s;}

/* ============================================================
   v30 모바일 최적화 — 휴대폰 화면 보강
   ============================================================ */
@media (max-width: 720px){
  html{ -webkit-text-size-adjust: 100%; }
  .row{ display: block !important; }
  .row .field{ width: 100% !important; margin: 0 0 14px !important; }
  input.ctrl, select.ctrl, textarea.ctrl{
    width: 100%; box-sizing: border-box;
    font-size: 16px;          /* iOS 자동 확대 방지 */
    min-height: 44px;         /* 터치 표적 최소 크기 */
  }
  button, .btn-ok, .btn-line, .btn-no{ min-height: 44px; }
  .pv-row{ display: flex; flex-wrap: wrap; gap: 8px; }
  table{ display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  h1{ font-size: 1.5rem; } h2{ font-size: 1.2rem; }
}
@media (max-width: 480px){
  .container, main, header nav{ padding-left: 14px; padding-right: 14px; }
}

/* ============================================================
   v30.1 모바일 헤더 보강 — 메뉴 세로 깨짐 수정
   ============================================================ */
.brand b{white-space:nowrap;}
nav.menu a{white-space:nowrap;flex:none;}
@media (max-width:720px){
  header.bar{padding:12px 14px 10px;gap:10px;}
  .brand{gap:7px;}
  .brand b{font-size:18px;}
  .brand .mark{width:26px;height:26px;}
  nav.menu{flex:1;min-width:0;justify-content:flex-end;gap:1px;
    overflow-x:auto;-webkit-overflow-scrolling:touch;}
  nav.menu::-webkit-scrollbar{height:0;}
  nav.menu a{padding:7px 8px;font-size:13.5px;}
  nav.menu a.bell{padding:7px 7px;}
  nav.menu .who-mini{padding:7px 4px 7px 6px;font-size:13px;}
}

/* ============================================================
   v32 — 알림 배지 깜빡임 + 모바일 분류 드롭다운
   ============================================================ */
@keyframes sf-blink{ 0%,100%{opacity:1;} 50%{opacity:.35;} }
.badge.blink{ animation:sf-blink 1.3s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce){ .badge.blink{ animation:none; } }

.cat-pick{ display:none; margin:26px 0 2px; }
@media (max-width:720px){
  .cat-tabs{ display:none; }
  .cat-pick{ display:block; }
  .cat-pick .fsel{ min-height:46px; font-size:15.5px; }
}

/* ============================================================
   v36-4 모바일 헤더 마감 — 닉네임 세로 꺾임 + 첫 메뉴 잘림 수정
   ============================================================ */
nav.menu .who-mini{
  white-space:nowrap;flex:none;display:inline-block;
  max-width:110px;overflow:hidden;text-overflow:ellipsis;
  vertical-align:middle;color:var(--accent-deep);font-weight:600;
}
nav.menu a.logout{white-space:nowrap;flex:none;}
@media (max-width:720px){
  /* flex-end 정렬은 넘칠 때 왼쪽 항목을 잘라 스크롤로도 못 보게 만든다.
     flex-start + 첫 항목 auto 마진으로: 공간이 남으면 오른쪽 정렬,
     넘치면 처음부터 끝까지 스와이프 가능. */
  nav.menu{justify-content:flex-start;}
  nav.menu > a:first-child{margin-left:auto;}
  nav.menu .who-mini{max-width:84px;font-size:13.5px;padding:7px 2px;}
}

/* v36-5: 모바일 헤더 4개만 — 찾기·사람등록은 로고/홈버튼으로 대체 */
@media (max-width:720px){
  nav.menu a.m-hide{display:none;}
  nav.menu > a:first-child{margin-left:0;}
  nav.menu > :nth-child(3){margin-left:auto;}  /* 내 활동부터 오른쪽 정렬 */
  nav.menu a{padding:7px 9px;font-size:14px;}
}
