/* 공용 디자인 시스템 — 허브 / 축의금 / 가계부 (자금계산기는 fund.html 자체 스타일) */
:root{
  --bg:#eef2f6; --surface:#fff; --surface-2:#f8fafc;
  --line:#e2e8f0; --line-2:#cbd5e1;
  --ink:#0f172a; --ink-2:#334155; --muted:#64748b;
  --primary:#4f46e5; --primary-weak:#eef2ff; --primary-bd:#c7d2fe;
  --pos:#15803d; --pos-bg:#f0fdf4; --neg:#dc2626; --neg-bg:#fef2f2; --warn:#b45309;
  --r-sm:8px; --r-md:12px; --r-lg:16px;
  --sh:0 1px 2px rgba(15,23,42,.04),0 2px 8px rgba(15,23,42,.06);
}
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{ margin:0; background:var(--bg); color:var(--ink);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard","Segoe UI",sans-serif;
  font-variant-numeric:tabular-nums; }
td,th,.v,.num,.stat-v{ font-variant-numeric:tabular-nums; }
a{ color:var(--primary); }
/* 공용 네비 */
.appnav{ position:sticky; top:0; z-index:20; display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.92); backdrop-filter:saturate(1.3) blur(8px); border-bottom:1px solid var(--line); padding:10px 24px; }
.appnav .brand{ font-weight:800; font-size:15px; color:var(--ink); text-decoration:none; letter-spacing:-.01em; }
.appnav .navlinks{ display:flex; gap:6px; margin-left:auto; flex-wrap:wrap; }
.appnav .navlinks a{ font-size:13px; font-weight:600; color:var(--muted); text-decoration:none; padding:6px 11px; border-radius:8px; }
.appnav .navlinks a:hover{ background:var(--surface-2); color:var(--ink); }
.appnav .navlinks a.active{ background:var(--primary-weak); color:var(--primary); }
/* 레이아웃 */
.page{ max-width:1100px; margin:0 auto; padding:22px 24px 48px; }
.page > h1{ margin:0 0 4px; font-size:22px; font-weight:800; letter-spacing:-.01em; }
.page > .sub{ margin:0 0 20px; color:var(--muted); font-size:13px; }
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:16px 18px; margin-bottom:14px; box-shadow:var(--sh); }
.card h2{ margin:0 0 12px; font-size:13px; font-weight:700; color:var(--ink); }
/* 허브 타일 */
.hubgrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:16px; }
.tile{ display:flex; flex-direction:column; gap:8px; text-decoration:none; color:var(--ink);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--sh);
  transition:transform .12s, box-shadow .12s, border-color .12s; }
.tile:hover{ transform:translateY(-2px); box-shadow:0 10px 24px rgba(15,23,42,.10); border-color:var(--primary-bd); }
.tile.is-soon{ opacity:.72; }
.tile .ic{ font-size:30px; line-height:1; }
.tile .t{ font-size:17px; font-weight:800; letter-spacing:-.01em; display:flex; align-items:center; gap:8px; }
.tile .d{ font-size:13px; color:var(--muted); }
.badge{ font-size:11px; font-weight:700; color:var(--warn); background:#fffbeb; border:1px solid #fde68a; border-radius:999px; padding:2px 8px; }
/* KPI / 통계 */
.kpis{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; }
.kpi{ border:1px solid var(--line); border-radius:var(--r-md); padding:13px 15px; background:var(--surface-2); }
.kpi .k{ color:var(--muted); font-size:11px; font-weight:600; }
.kpi .v{ font-size:18px; font-weight:800; margin-top:3px; letter-spacing:-.01em; }
.kpi .sub{ color:var(--muted); font-size:11px; margin-top:2px; }
.kpi.accent{ background:linear-gradient(135deg,#eef2ff,#f5f3ff); border-color:var(--primary-bd); }
.kpi.accent .v{ color:var(--primary); }
/* 표 */
table{ width:100%; border-collapse:collapse; font-size:13px; }
th,td{ padding:9px 10px; border-bottom:1px solid var(--line); text-align:right; }
th{ color:var(--muted); font-weight:600; font-size:11px; }
th:first-child,td:first-child,th.l,td.l{ text-align:left; }
tbody tr:hover{ background:var(--surface-2); }
.pill{ display:inline-block; font-size:11px; font-weight:600; padding:2px 8px; border-radius:999px; background:var(--surface-2); border:1px solid var(--line); color:var(--ink-2); }
/* 입력/폼 */
.field, input, select{ height:36px; padding:0 11px; border:1px solid var(--line-2); border-radius:var(--r-sm);
  font:inherit; background:#fff; color:var(--ink); }
input,select{ width:100%; }
input:focus,select:focus{ outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-weak); }
input[type=number],.ta-r{ text-align:right; }
.formrow{ display:grid; gap:8px; align-items:center; }
button{ font:inherit; font-weight:600; height:36px; padding:0 16px; border:1px solid var(--line-2); background:#fff; border-radius:var(--r-sm); cursor:pointer; color:var(--ink-2); }
button:hover{ background:#f1f5f9; } button:active{ transform:translateY(1px); }
button.primary{ background:var(--primary); border-color:var(--primary); color:#fff; }
button.primary:hover{ background:#4338ca; }
button.icon{ width:32px; height:32px; padding:0; color:var(--muted); }
button.icon:hover{ color:var(--neg); background:var(--neg-bg); border-color:#fecaca; }
.muted{ color:var(--muted); }
.hint{ color:var(--muted); font-size:11.5px; margin-top:3px; line-height:1.5; }
.toolbar{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:12px; }
.toolbar input,.toolbar select{ width:auto; min-width:120px; }
.grow{ flex:1; min-width:120px; }
/* 개발중 placeholder */
.soon{ text-align:center; padding:64px 20px; }
.soon .ic{ font-size:56px; }
.soon h2{ font-size:20px; margin:14px 0 6px; }
.soon p{ color:var(--muted); margin:0; }
/* 반응형 */
@media(max-width:600px){
  .appnav{ padding:9px 14px; gap:8px; } .appnav .brand{ font-size:13px; } .appnav .navlinks a{ padding:5px 8px; font-size:12px; }
  .page{ padding:16px 14px 40px; }
  .kpis{ grid-template-columns:1fr 1fr; gap:10px; }
  .toolbar input,.toolbar select{ min-width:0; }
}
