/* ──────────────────────────────────────────────────────────
   Toss 풍 라이트 테마. 흰 카드 + 토스블루 포인트 + 친근한 큰 타이포.
   클래스 이름은 기존 JS가 생성하는 마크업과 호환되도록 유지.
   ────────────────────────────────────────────────────────── */
:root{
  --bg:#f2f4f6;
  --card:#ffffff;
  --ink:#191f28;        /* 본문 진한 글자 */
  --ink2:#333d4b;
  --sub:#4e5968;        /* 보조 글자 */
  --muted:#8b95a1;      /* 흐린 글자 */
  --line:#e5e8eb;       /* 경계선 */
  --line2:#f2f4f6;
  --blue:#3182f6;       /* 토스블루 (포인트/플러스) */
  --blue-dark:#1b64da;
  --blue-soft:#e8f3ff;
  --green:#1aa873;      /* 플러스/긍정 */
  --rust:#f04452;       /* 마이너스/지출 (toss red) */
  --gold:#3182f6;       /* 기존 .gold 강조 → 토스블루로 통일 */
  --violet:#8b5cf6;
  --pink:#f7637e;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
.num{font-feature-settings:"tnum";letter-spacing:-.02em}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ── shell ── */
.wrap{max-width:720px;margin:0 auto;padding:max(18px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) 112px max(16px,env(safe-area-inset-left))}
header.top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:0;color:var(--blue);margin-bottom:6px}
h1.brand{font-weight:800;font-size:clamp(22px,5.5vw,28px);line-height:1.25;letter-spacing:-.03em;color:var(--ink)}
h1.brand .accent{color:var(--blue)}
.sub{color:var(--sub);font-size:14px;margin-top:6px}

.top-actions{display:flex;align-items:center;gap:8px;flex:none}
.icon-btn{position:relative;background:#fff;border:1px solid var(--line);color:var(--sub);border-radius:14px;padding:9px 13px;cursor:pointer;font-size:13px;font-weight:600;transition:.15s}
.icon-btn:hover{background:var(--line2)}
.badge{position:absolute;top:-7px;right:-7px;background:var(--rust);color:#fff;border-radius:20px;font-size:10px;font-weight:700;padding:2px 6px;min-width:18px;text-align:center}
.badge.hide{display:none}

/* ── 하단 탭 바 (Toss 스타일) ── */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:45;display:flex;background:rgba(255,255,255,.94);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--line);padding:6px 4px calc(6px + env(safe-area-inset-bottom));max-width:720px;margin:0 auto}
.bottom-nav button{flex:1;background:none;border:none;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:var(--muted);transition:.12s}
.bottom-nav button .bi{font-size:21px;line-height:1;filter:grayscale(1) opacity(.55);transition:.12s}
.bottom-nav button .bl{font-size:11px;font-weight:700}
.bottom-nav button.active{color:var(--blue)}
.bottom-nav button.active .bi{filter:none}

/* ── KPI 큰 숫자 카드 ── */
.kpis{display:grid;grid-template-columns:1fr;gap:12px;margin:0 0 16px}
.kpi{background:var(--card);border-radius:20px;padding:20px 22px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.kpi.hero{background:linear-gradient(135deg,#3182f6,#1b64da);color:#fff}
.kpi .label{font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:600}
.kpi.hero .label{color:rgba(255,255,255,.85)}
.kpi .big{font-size:clamp(26px,7vw,34px);font-weight:800;letter-spacing:-.03em;color:var(--ink)}
.kpi.hero .big{color:#fff}
.kpi .big.gold{color:var(--blue)}
.kpi .foot{font-size:12.5px;color:var(--muted);margin-top:7px}
.kpi.hero .foot{color:rgba(255,255,255,.8)}
@media (min-width:560px){.kpis.three{grid-template-columns:repeat(3,1fr)}}

/* ── 홈 overview 타일 ── */
.ov-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.ov{text-align:left;background:var(--card);border:none;border-radius:20px;padding:18px 20px;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:.15s;font-family:inherit}
.ov:hover{box-shadow:0 4px 14px rgba(0,0,0,.08);transform:translateY(-1px)}
.ov:active{transform:scale(.99)}
.ov-l{font-size:13px;color:var(--muted);font-weight:600}
.ov-v{font-size:21px;font-weight:800;letter-spacing:-.03em;color:var(--ink);margin-top:6px;line-height:1.2}
.ov-v.over{color:var(--rust)}
.ov-go{font-size:12.5px;color:var(--blue);font-weight:600;margin-top:8px}

/* ── 카드 ── */
.card{background:var(--card);border-radius:20px;padding:22px;margin-bottom:14px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.card h2{font-size:18px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px;display:flex;align-items:center;gap:7px;color:var(--ink)}
.card h2 .dot{display:none}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-head h2{margin-bottom:4px}
.link-go{background:none;border:none;color:var(--blue);font-weight:700;font-size:13.5px;cursor:pointer;font-family:inherit;flex:none;padding:4px}
.link-go:hover{text-decoration:underline}

/* ── 지출 달력 ── */
.cal-nav{display:flex;align-items:center;gap:10px;flex:none}
.cal-nav .mini-x{font-size:22px;color:var(--sub);line-height:1}
.cal-nav span{font-size:15px;font-weight:700;min-width:84px;text-align:center}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-top:10px}
.cal-dow span{text-align:center;font-size:12px;font-weight:600;color:var(--muted);padding:6px 0}
.cal-dow span:first-child{color:var(--rust)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-cell{aspect-ratio:1/1;border-radius:12px;background:var(--line2);padding:6px 4px 4px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;cursor:pointer;border:2px solid transparent;transition:.12s;overflow:hidden}
.cal-cell.empty{background:transparent;cursor:default}
.cal-cell:not(.empty):hover{background:#e9edf1}
.cal-cell .cd{font-size:12px;color:var(--sub);font-weight:600}
.cal-cell.today .cd{color:var(--blue);font-weight:800}
.cal-cell .cv{font-size:11px;font-weight:800;margin-top:auto;color:var(--ink);letter-spacing:-.02em;line-height:1.1;text-align:center;word-break:keep-all}
.cal-cell.has{background:#e8f3ff}
.cal-cell.over{background:#fdecee}
.cal-cell.over .cv{color:var(--rust)}
.cal-cell.sel{border-color:var(--blue)}
.cal-foot{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;padding-top:14px;border-top:2px solid var(--line);font-weight:800}
.cal-foot .num{font-size:17px}
.cal-foot.over .num{color:var(--rust)}
#calDetail{margin-top:6px}
.day-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}
.day-item .di-c{font-weight:600;font-size:14px}
.day-item .di-m{color:var(--muted);font-size:12.5px}
.card .hint{font-size:13px;color:var(--muted);margin-bottom:16px;line-height:1.5}
.grid2{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
.stack{display:flex;flex-direction:column;gap:14px}

/* ── 폼 ── */
label.field{display:block;font-size:13px;color:var(--sub);font-weight:600;margin:12px 0 6px}
input[type=text],input[type=number],input[type=date],input[type=month],input[type=password],select,textarea{
  width:100%;background:var(--line2);border:1px solid transparent;color:var(--ink);
  border-radius:12px;padding:13px 14px;font-family:inherit;font-size:16px;outline:none;transition:.15s
} /* 16px: iOS Safari 포커스 시 자동 확대 방지 */
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{background:#fff;border-color:var(--blue)}
/* iOS 날짜/월 입력칸이 카드 밖으로 삐져나가는 것 방지 (내부 min-content 너비 무력화) */
input[type=date],input[type=month]{min-width:0;max-width:100%;-webkit-appearance:none;appearance:none}
textarea{min-height:90px;resize:vertical}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row > *{flex:1;min-width:130px}
button.btn{background:var(--blue);color:#fff;border:none;border-radius:14px;padding:13px 18px;font-weight:700;cursor:pointer;font-size:15px;font-family:inherit;transition:.15s}
button.btn:hover{background:var(--blue-dark)}
button.btn:active{transform:scale(.985)}
button.btn.ghost{background:var(--line2);color:var(--sub)}
button.btn.ghost:hover{background:var(--line)}
button.btn.danger{background:#fdecee;color:var(--rust)}
.btn-row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;align-items:center}

/* ── 표 ── */
table{width:100%;border-collapse:collapse;margin-top:4px;font-size:14px}
th,td{text-align:right;padding:13px 6px;border-bottom:1px solid var(--line);vertical-align:middle}
th:first-child,td:first-child{text-align:left}
thead th{font-size:12px;color:var(--muted);font-weight:600}
td .num{font-size:14px}
.swatch{display:inline-block;width:8px;height:8px;border-radius:3px;margin-right:8px;vertical-align:middle}
tr.total-row td{border-top:2px solid var(--line);border-bottom:none;font-weight:800;padding-top:14px}
tr.total-row td .num{color:var(--ink);font-size:16px}
.lock{font-size:11px;color:var(--violet);font-weight:600}
.free{font-size:11px;color:var(--green);font-weight:600}
.tag{display:inline-block;font-size:12px;font-weight:600;padding:3px 9px;border-radius:8px;background:var(--line2);color:var(--sub)}
.mini-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:4px}
.mini-x:hover{color:var(--rust)}

/* ── 토글/슬라이더 ── */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line)}
.toggle-row:last-of-type{border-bottom:none}
.t-label{font-size:15px;font-weight:600}.t-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.switch{position:relative;width:50px;height:30px;flex:none;cursor:pointer}
.switch input{opacity:0;width:0;height:0}
.slider-sw{position:absolute;inset:0;background:#d1d6db;border-radius:30px;transition:.25s}
.slider-sw::before{content:"";position:absolute;height:24px;width:24px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch input:checked + .slider-sw{background:var(--blue)}
.switch input:checked + .slider-sw::before{transform:translateX(20px)}
.control{margin:18px 0 4px}
.control .c-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.control .c-name{font-size:14px;font-weight:600;color:var(--ink2)}
.control .c-val{font-size:14px;color:var(--blue);font-weight:700}
input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:6px;background:var(--line);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 1px 4px rgba(0,0,0,.25),0 0 0 1px var(--line)}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.c-note{font-size:12px;color:var(--muted);margin-top:7px;line-height:1.5}
.divider{height:1px;background:var(--line);margin:18px 0}
.chart-wrap{position:relative;height:300px;margin-top:6px}

/* ── 현금흐름 ── */
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.cf-item{background:var(--line2);border-radius:14px;padding:15px 16px}
.cf-item .cf-l{font-size:12.5px;color:var(--muted);font-weight:600}
.cf-item .cf-v{font-size:19px;font-weight:800;margin-top:5px;letter-spacing:-.02em;color:var(--ink)}
.cf-item.pos .cf-v{color:var(--blue)}.cf-item.neg .cf-v{color:var(--rust)}

/* ── 메모/인사이트 ── */
.insight{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--line)}
.insight:last-child{border-bottom:none}
.insight .ix{font-size:20px;flex:none;width:26px;line-height:1.3;color:var(--blue)}
.insight .it{font-size:14px;color:var(--sub);flex:1;line-height:1.6}
.insight .it b{color:var(--ink);font-weight:700}
.insight .it .ti{color:var(--ink);font-weight:700;font-size:15px;display:block;margin-bottom:4px}
.pin{color:var(--blue);font-size:12px;font-weight:700}

/* ── 다이제스트/카드형 리스트 ── */
.dg{border:1px solid var(--line);border-radius:16px;padding:16px 18px;margin-bottom:10px;background:#fff}
.dg .dg-cat{font-size:12px;font-weight:700;color:var(--blue)}
.dg .dg-t{font-size:15.5px;font-weight:700;margin:4px 0;color:var(--ink)}
.dg .dg-s{font-size:13.5px;color:var(--sub);line-height:1.55}
.dg .dg-d{font-size:12px;color:var(--muted);margin-top:8px}

/* ── 알림 서랍 ── */
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;z-index:40}
.drawer-bg.open{display:block}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,92vw);background:#fff;z-index:50;transform:translateX(100%);transition:.28s cubic-bezier(.2,.8,.2,1);padding:22px;overflow-y:auto}
.drawer.open{transform:translateX(0)}
.notif{border-bottom:1px solid var(--line);padding:14px 0}
.notif.unread{background:var(--blue-soft);margin:0 -22px;padding:14px 22px;border-bottom:1px solid var(--line)}
.notif .nt{font-size:14.5px;font-weight:700;color:var(--ink)}
.notif .nb{font-size:13px;color:var(--sub);margin-top:4px;line-height:1.5}
.notif .nd{font-size:11.5px;color:var(--muted);margin-top:6px}

/* ── 모달 (이런 집 나오면 알려줘) ── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;z-index:55;align-items:flex-end;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:#fff;width:100%;max-width:560px;max-height:88vh;overflow-y:auto;border-radius:24px 24px 0 0;padding:24px 22px 30px;transform:translateY(100%);transition:.28s cubic-bezier(.2,.8,.2,1)}
.modal-bg.open .modal{transform:translateY(0)}
@media (min-width:560px){.modal-bg{align-items:center}.modal{border-radius:24px;transform:translateY(20px)}}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.modal-head h2{font-size:20px;font-weight:800;letter-spacing:-.02em}

/* ── 로그인 ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;border-radius:24px;padding:34px 30px;width:min(400px,100%);box-shadow:0 4px 24px rgba(0,0,0,.06)}
.login-card .eyebrow{font-size:13px}
.login-card h1{font-weight:800;font-size:26px;letter-spacing:-.03em;margin-bottom:8px}
.login-card .accent{color:var(--blue)}
.login-card p{color:var(--sub);font-size:14.5px;margin-bottom:22px;line-height:1.5}
.err{color:var(--rust);font-size:13px;margin-top:10px;min-height:17px;font-weight:600}

/* ── 공통 ── */
section[id^="tab-"]{animation:secfade .26s cubic-bezier(.2,.8,.2,1)}
@keyframes secfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.hidden{display:none !important}
.empty{color:var(--muted);font-size:14px;padding:28px 0;text-align:center}
footer{margin-top:26px;font-size:12px;color:var(--muted);text-align:center;line-height:1.7;padding-top:18px;border-top:1px solid var(--line)}
.pill{display:inline-block;background:var(--blue-soft);color:var(--blue);border-radius:999px;padding:3px 11px;font-size:12px;font-weight:600;margin:0 2px}
.toast{position:fixed;bottom:84px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--ink);color:#fff;padding:13px 20px;border-radius:14px;font-size:14px;font-weight:600;z-index:60;opacity:0;transition:.22s;pointer-events:none;box-shadow:0 6px 20px rgba(0,0,0,.18);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 좁은 화면 (iPhone 13 mini = 375px 등) ── */
@media (max-width:430px){
  h1.brand{font-size:22px}
  .card{padding:18px 16px;border-radius:18px}
  /* 폼 입력칸이 겹치지 않게 한 줄에 하나씩 (날짜 입력칸 등) */
  .row{flex-direction:column;gap:0}
  .row > *{min-width:100%;flex:none}
  .ov-grid{gap:10px}
  .ov{padding:15px 16px}
  .ov-v{font-size:19px}
  .icon-btn{padding:9px 11px}
  /* 달력: 칸 작아져도 금액 보이게 */
  .cal-grid{gap:4px}
  .cal-cell{border-radius:10px;padding:4px 2px 3px}
  .cal-cell .cd{font-size:11px}
  .cal-cell .cv{font-size:10px}
  .cal-dow span{font-size:11px}
  /* 표 좌우 여백 축소 */
  th,td{padding:11px 4px}
  /* 하단탭 6개도 들어가게 */
  .bottom-nav button .bi{font-size:20px}
  .bottom-nav button .bl{font-size:10px}
}
@media (max-width:360px){
  .cal-cell .cv{font-size:9px}
  .bottom-nav button .bl{font-size:9px}
}
