/* 둥지(Nest) — 공용 스타일. 따뜻한 라이트 테마, 한국어 우선. var(--*) 토큰만 사용. */
:root{
  --bg:#faf7f2; --card:#ffffff; --fg:#2b2622; --sub:#8a817a; --border:#ece5db;
  --acc:#e0863a; --acc-ink:#9a541b; --acc-soft:#fbe7cd;
  --green:#2f8f63; --green-soft:#dff1e6;
  --blue:#3f78b5; --blue-soft:#e2edf8;
  --gold:#b88a2c; --gold-soft:#f6ecd0;
  --gray-soft:#eee9e1; --danger:#c0563f;
  --radius:14px; --shadow:0 1px 3px rgba(60,45,30,.08), 0 6px 18px rgba(60,45,30,.05);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);
  font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Noto Sans KR",Segoe UI,Roboto,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:880px;margin:0 auto;padding:0 18px}

/* 헤더 */
.nav{position:sticky;top:0;background:rgba(250,247,242,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);z-index:10}
.nav .wrap{display:flex;align-items:center;gap:18px;height:58px}
.brand{font-weight:800;font-size:19px;letter-spacing:-.02em}
.brand .egg{margin-right:6px}
.nav a.link{color:var(--sub);font-size:14px;font-weight:600}
.nav a.link.active,.nav a.link:hover{color:var(--acc-ink)}
.nav .spacer{flex:1}
.btn{border:0;cursor:pointer;border-radius:10px;font-weight:700;font-size:14px;padding:9px 15px;
  background:var(--acc);color:#fff;transition:filter .15s}
.btn:hover{filter:brightness(1.05)}
.btn.ghost{background:var(--gray-soft);color:var(--fg)}
.btn.sm{padding:6px 11px;font-size:13px}
.btn:disabled{opacity:.5;cursor:default}

/* 히어로 */
.hero{padding:34px 0 14px}
.hero h1{font-size:27px;margin:0 0 8px;letter-spacing:-.03em}
.hero p{color:var(--sub);margin:0;font-size:15px;max-width:620px}
.hero .rule{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.pill{background:var(--card);border:1px solid var(--border);border-radius:999px;padding:6px 12px;
  font-size:13px;color:var(--sub);box-shadow:var(--shadow)}
.pill b{color:var(--acc-ink)}

/* 필터 탭 */
.tabs{display:flex;gap:8px;margin:18px 0 6px}
.tab{border:1px solid var(--border);background:var(--card);border-radius:999px;padding:7px 15px;
  font-size:14px;font-weight:600;color:var(--sub);cursor:pointer}
.tab.active{background:var(--acc-soft);border-color:var(--acc);color:var(--acc-ink)}

/* 앱 그리드 */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;margin:14px 0 40px}
.appcard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);display:flex;gap:13px;align-items:flex-start;transition:transform .12s}
.appcard:hover{transform:translateY(-2px)}
.appcard .ico{width:48px;height:48px;border-radius:12px;background:var(--gray-soft);flex:0 0 auto;
  object-fit:cover;display:flex;align-items:center;justify-content:center;font-size:22px}
.appcard .name{font-weight:700;font-size:16px;letter-spacing:-.01em}
.appcard .tag{color:var(--sub);font-size:13.5px;margin-top:2px}
.appcard .meta{margin-top:9px;display:flex;gap:6px;flex-wrap:wrap}

/* 칩 */
.chip{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.chip.bucket{background:var(--green-soft);color:var(--green)}
.chip.web{background:var(--blue-soft);color:var(--blue)}
.chip.group{background:var(--gray-soft);color:var(--sub)}
.chip.gold{background:var(--gold-soft);color:var(--gold)}
.chip.s-open{background:var(--gray-soft);color:var(--sub)}
.chip.s-planned{background:var(--blue-soft);color:var(--blue)}
.chip.s-in-progress{background:var(--acc-soft);color:var(--acc-ink)}
.chip.s-done{background:var(--green-soft);color:var(--green)}
.chip.s-declined{background:#f3e3e0;color:var(--danger)}

/* 상세 */
.apphead{display:flex;gap:16px;align-items:flex-start;padding:26px 0 14px}
.apphead .ico{width:64px;height:64px;border-radius:15px;font-size:30px}
.apphead h1{margin:0;font-size:23px;letter-spacing:-.02em}
.apphead .links{margin-top:8px;display:flex;gap:10px}
.apphead .links a{font-size:13px;font-weight:700;color:var(--acc-ink)}
.section-t{font-size:16px;font-weight:800;margin:26px 0 10px}

/* 투표 보드 */
.req{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 16px;margin-bottom:12px;box-shadow:var(--shadow)}
.req .top{display:flex;gap:12px;align-items:flex-start}
.vote{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;
  border:1px solid var(--border);border-radius:11px;padding:7px 11px;cursor:pointer;min-width:52px;background:#fff}
.vote.on{background:var(--acc-soft);border-color:var(--acc)}
.vote .n{font-weight:800;font-size:17px}
.vote .l{font-size:11px;color:var(--sub)}
.req .title{font-weight:700;font-size:15.5px}
.req .body{color:var(--fg);font-size:14px;margin-top:3px;white-space:pre-wrap}
.req .sub{display:flex;gap:8px;align-items:center;margin-top:9px;color:var(--sub);font-size:13px}
.cmts{margin-top:11px;border-top:1px dashed var(--border);padding-top:10px;display:none}
.cmts.open{display:block}
.cmt{font-size:13.5px;margin:6px 0}
.cmt b{font-weight:700}
.cmt .when{color:var(--sub);font-size:12px;margin-left:6px}

/* 폼 */
input.f,textarea.f,select.f{width:100%;border:1px solid var(--border);border-radius:10px;
  padding:10px 12px;font:inherit;background:#fff;color:var(--fg)}
textarea.f{min-height:80px;resize:vertical}
.row{margin:10px 0}
.muted{color:var(--sub);font-size:13px}
.empty{text-align:center;color:var(--sub);padding:48px 0}
.empty .big{font-size:40px;margin-bottom:10px}

/* 푸터 */
footer{border-top:1px solid var(--border);margin-top:30px;padding:22px 0 40px;color:var(--sub);font-size:13px}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--fg);color:#fff;
  padding:11px 18px;border-radius:11px;font-size:14px;font-weight:600;opacity:0;transition:opacity .2s;z-index:50;pointer-events:none}
.toast.show{opacity:.96}
