/* ===== 경비 장부 — 토스st 깔끔 화이트 ===== */
:root{
  --bg:#f2f4f6; --card:#ffffff; --ink:#191f28; --sub:#8b95a1; --sub2:#b0b8c1;
  --line:#eceef1; --line2:#e5e8eb;
  --brand:#3182f6; --brand-weak:#e8f1ff; --brand-press:#1b64da;
  --red:#f04452; --red-weak:#fdeced; --green:#13bd7e; --green-weak:#e7f8f1;
  --radius:20px; --radius-sm:14px;
  --shadow:0 2px 8px rgba(17,24,39,.04), 0 1px 2px rgba(17,24,39,.04);
  --shadow-lg:0 8px 30px rgba(17,24,39,.10);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,system-ui,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.45;
  font-feature-settings:'tnum' 1;
  letter-spacing:-.01em;
}
button,input,select,textarea{font-family:inherit;font-size:16px;color:inherit}
button{cursor:pointer;border:none;background:none}
a{color:inherit}
.hidden{display:none!important}
.num,.value,.hero-amount,.txn-amt,.rank-amt,.a-num{font-feature-settings:'tnum' 1;font-variant-numeric:tabular-nums}

/* ===== 로그인 ===== */
.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:28px;
  background:radial-gradient(120% 80% at 50% -10%, #eaf2ff 0%, #f7f9fb 42%, #ffffff 100%)}
.login-box{width:100%;max-width:380px;text-align:center}
.login-title{margin:0 0 10px;font-size:40px;line-height:1.05;
  font-family:'Pretendard Variable',Pretendard,-apple-system,'Helvetica Neue',Arial,sans-serif;
  font-weight:900;letter-spacing:-.03em}
.t-blk{color:#16181d}
.t-pur{color:#7c3aed}
.login-desc{margin:0 0 4px;color:var(--sub);font-size:15px;font-weight:500}
.login-form{margin-top:30px;text-align:left}
.login-form .field input{padding:16px;font-size:16px}
.btn-lg{padding:17px;font-size:17px;border-radius:15px;margin-top:6px}
.login-foot{margin-top:26px;color:var(--sub2);font-size:12.5px;font-weight:500;line-height:1.5}
.field{text-align:left;margin-bottom:12px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--sub);margin-bottom:7px;padding-left:2px}
.field input,.field select,.field textarea{
  width:100%;padding:15px 16px;border:none;background:#f2f4f6;border-radius:14px;font-weight:500;
  transition:box-shadow .15s,background .15s}
.field input::placeholder{color:var(--sub2)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;background:#fff;box-shadow:0 0 0 2px var(--brand) inset}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 18px;border-radius:14px;font-weight:700;font-size:16px;
  transition:transform .08s,background .15s,filter .15s}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--brand);color:#fff;width:100%}
.btn-primary:hover{background:var(--brand-press)}
.btn-primary:disabled{background:#c9d3e0;cursor:default}
.btn-ghost{background:#f2f4f6;color:#4e5968;font-weight:600}
.btn-ghost:hover{background:#e8ebee}
.btn-danger{background:var(--red-weak);color:var(--red)}
.btn-sm{padding:7px 12px;font-size:13px;font-weight:600;border-radius:10px;gap:4px}
.btn-icon{width:38px;height:38px;padding:0;font-size:24px;font-weight:300;line-height:1;border-radius:12px;flex-shrink:0}
.login-err{color:var(--red);font-size:13px;margin-top:12px;min-height:18px;font-weight:500}

/* ===== 상단바 ===== */
.topbar{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;
  padding:13px 18px;padding-top:max(13px,env(safe-area-inset-top))}
.topbar .brand{font-weight:900;font-size:19px;letter-spacing:-.03em;display:flex;align-items:center;gap:6px}
.topbar .spacer{flex:1}
.usermenu{position:relative}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--brand-weak);color:var(--brand);font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:15px}
.dropdown{position:absolute;right:0;top:48px;background:#fff;border:1px solid var(--line2);border-radius:16px;
  box-shadow:var(--shadow-lg);min-width:190px;padding:7px;z-index:40}
.dropdown button{display:flex;width:100%;align-items:center;gap:10px;padding:12px;border-radius:11px;font-size:15px;font-weight:600;text-align:left;color:#4e5968}
.dropdown button:hover{background:#f2f4f6}

.container{max-width:1320px;margin:0 auto;padding:20px 18px 120px}
@media(min-width:860px){
  .container{padding:30px 32px 48px}
  .with-nav{display:grid;grid-template-columns:228px minmax(0,1fr);gap:34px;align-items:start}
  .with-nav>main{min-width:0}
}

/* ===== 네비게이션 ===== */
.sidenav{display:none}
@media(min-width:860px){
  .sidenav{display:block;position:sticky;top:88px}
  .sidenav button{display:flex;width:100%;align-items:center;gap:13px;padding:13px 15px;border-radius:14px;
    font-weight:700;font-size:15px;color:var(--sub);margin-bottom:3px}
  .sidenav button:hover{background:#fff;color:#4e5968}
  .sidenav button.active{background:var(--brand-weak);color:var(--brand)}
  .sidenav button .ico{display:inline-flex}
  .sidenav button .ico svg{width:20px;height:20px;display:block}
}
.bottomnav{position:fixed;bottom:0;left:0;right:0;z-index:30;background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(14px);border-top:1px solid var(--line);display:flex;
  padding-bottom:env(safe-area-inset-bottom)}
@media(min-width:860px){.bottomnav{display:none}}
.bottomnav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 0 9px;
  font-size:11px;color:var(--sub2);font-weight:700}
.bottomnav button .ico{display:inline-flex;line-height:1}
.bottomnav button .ico svg{width:24px;height:24px;display:block}
.bottomnav button.active{color:var(--brand)}

/* ===== 카드/공통 ===== */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.card+.card{margin-top:14px}
.section-title{font-size:15px;font-weight:800;color:var(--ink);margin:0 0 16px;
  display:flex;align-items:center;justify-content:space-between;letter-spacing:-.02em}
.section-title>span{font-size:13px;font-weight:600;color:var(--sub)}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:nowrap}
.page-head h2{margin:0;font-size:24px;font-weight:800;letter-spacing:-.04em;white-space:nowrap}
.page-head .btn{flex-shrink:0;white-space:nowrap}

/* 필터 */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.filters select,.filters input{padding:11px 14px;border:none;background:#fff;border-radius:13px;font-size:14px;font-weight:600;
  box-shadow:var(--shadow);color:#4e5968}
.filters select:focus,.filters input:focus{outline:none;box-shadow:0 0 0 2px var(--brand) inset}

/* 대시보드 히어로 */
.hero{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:14px}
.hero .h-label{font-size:14px;color:var(--sub);font-weight:600}
.hero .h-amount{font-size:36px;font-weight:800;letter-spacing:-.045em;margin:6px 0 4px;color:var(--ink)}
.hero .h-sub{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.hero .pill{background:#f2f4f6;border-radius:11px;padding:8px 12px;font-size:13px;font-weight:600;color:#4e5968;display:flex;gap:6px;align-items:center}
.hero .pill b{font-weight:800}
.hero .pill .t{color:var(--sub)}
.hero .pill.inc b{color:var(--green)}
.hero .pill.net b{color:var(--brand)}

.grid-2{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:760px){.grid-2{grid-template-columns:1fr 1fr}}
/* 대시보드 2단 그리드 — 가로 공간을 꽉 채움 */
.dash{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}
@media(min-width:820px){.dash{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
.dash .span2{grid-column:1 / -1}
.dash>*{min-width:0}
.dash>.card,.dash>.hero{margin:0}
.dash .chart-box{height:300px}
/* 넓은 화면에서 리스트가 과하게 늘어지지 않도록 (읽기 좋은 폭 유지) */
@media(min-width:860px){
  #txnList{max-width:900px}
  .cat-list{max-width:640px}
}
.chart-box{position:relative;height:268px}
.empty{text-align:center;color:var(--sub);padding:44px 16px;font-size:15px;font-weight:500;line-height:1.6}
.empty .big{font-size:46px;margin-bottom:10px}

/* 순위 리스트 */
.rank-list{display:flex;flex-direction:column;gap:18px}
.rank-item{display:flex;align-items:center;gap:13px}
.rank-ico{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rank-main{flex:1;min-width:0}
.rank-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.rank-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-amt{font-weight:800;font-size:15px;white-space:nowrap}
.rank-bar{height:8px;border-radius:6px;background:#f2f4f6;margin-top:8px;overflow:hidden}
.rank-bar>i{display:block;height:100%;border-radius:6px}
.rank-pct{font-size:12px;color:var(--sub);margin-top:5px;font-weight:600}

/* 거래 리스트 */
.txn-day{font-size:13px;font-weight:700;color:var(--sub);margin:22px 4px 10px}
.txn-day:first-child{margin-top:4px}
.txn-group{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.txn{display:flex;align-items:center;gap:13px;padding:15px 18px;cursor:pointer}
.txn+.txn{border-top:1px solid var(--line)}
.txn:active{background:#f7f8fa}
.txn-ico{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}
.txn-body{flex:1;min-width:0}
.txn-t1{font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}
.txn-t2{font-size:13px;color:var(--sub);margin-top:3px;display:flex;gap:7px;flex-wrap:wrap;align-items:center;font-weight:500}
.txn-acc{display:inline-flex;align-items:center;gap:5px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.txn-amt{font-weight:800;font-size:17px;white-space:nowrap;letter-spacing:-.02em}
.txn-amt.exp{color:var(--ink)} .txn-amt.inc{color:var(--brand)}

/* 계좌 카드 — 깨끗한 흰 카드 + 컬러 액센트 */
.acc-grid{display:grid;grid-template-columns:1fr;gap:13px}
@media(min-width:560px){.acc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.acc-grid{grid-template-columns:1fr 1fr 1fr}}
.acc-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;
  position:relative;overflow:hidden;cursor:pointer;transition:transform .1s,box-shadow .15s}
.acc-card:hover{box-shadow:var(--shadow-lg)}
.acc-card:active{transform:scale(.99)}
.acc-card .a-strip{position:absolute;left:0;top:0;bottom:0;width:5px}
.acc-card .a-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:18px}
.acc-card .a-name{font-weight:800;font-size:17px;letter-spacing:-.03em;display:flex;align-items:center;gap:8px}
.acc-card .a-name .cdot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.acc-card .a-memo{font-size:12px;color:var(--sub);font-weight:500;margin-top:2px;margin-left:19px}
.acc-card .a-lab{font-size:13px;color:var(--sub);font-weight:600}
.acc-card .a-num{font-size:25px;font-weight:800;letter-spacing:-.04em;margin-top:2px}
.acc-card .a-sub{font-size:12px;color:var(--sub);margin-top:12px;display:flex;gap:12px;font-weight:600;flex-wrap:wrap}
.acc-card .a-sub b{color:#4e5968;font-weight:700}
.acc-edit{background:#f2f4f6;border-radius:10px;width:32px;height:32px;font-size:15px;color:#8b95a1;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.acc-edit:hover{background:#e8ebee}
.acc-add{border:2px dashed var(--line2);border-radius:var(--radius);background:transparent;color:var(--sub);font-weight:700;font-size:15px;
  min-height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.acc-add:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.acc-add .plus{font-size:32px;font-weight:400}
.acc-go{color:var(--sub2);display:inline-flex;flex-shrink:0;align-self:flex-start}
.acc-go svg{width:20px;height:20px}
.acc-card:hover .acc-go{color:var(--brand)}

/* 계좌 상세 화면 */
.backlink{display:inline-flex;align-items:center;gap:1px;color:var(--sub);font-weight:600;font-size:14px;
  padding:6px 12px 6px 6px;margin-bottom:8px;border-radius:10px}
.backlink:hover{color:var(--ink);background:#fff}
.backlink svg{width:18px;height:18px}
.acct-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.acct-head-l{display:flex;align-items:center;gap:12px;min-width:0}
.acct-head-l>div{min-width:0}
.acct-head-l h2{margin:0;font-size:24px;font-weight:800;letter-spacing:-.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cdot-lg{width:14px;height:14px;border-radius:50%;flex-shrink:0}
.acct-memo{font-size:13px;color:var(--sub);font-weight:500;margin-top:2px}
.sub-head{margin-top:24px}
.sub-head h2{font-size:18px;display:flex;align-items:center;gap:8px}
.cnt-badge{font-size:13px;font-weight:700;color:var(--sub);background:#f2f4f6;border-radius:8px;padding:2px 9px}

/* 카테고리 관리 */
.cat-list{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.cat-row{display:flex;align-items:center;gap:11px;padding:8px 14px}
.cat-row+.cat-row{border-top:1px solid var(--line)}
.cat-row .cico{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px}
.cat-row .cname{flex:1;font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px;letter-spacing:-.02em}
.muted-badge{font-size:11px;color:var(--sub);background:#f2f4f6;padding:3px 9px;border-radius:8px;font-weight:600}

/* FAB */
.fab{position:fixed;right:20px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:35;
  width:60px;height:60px;border-radius:20px;background:var(--brand);color:#fff;font-size:30px;font-weight:300;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(49,130,246,.4)}
@media(min-width:860px){.fab{bottom:30px;right:30px}}
.fab:hover{background:var(--brand-press)}
.fab:active{transform:scale(.93)}

/* 모달 */
.modal-back{position:fixed;inset:0;background:rgba(17,24,39,.45);z-index:50;display:flex;align-items:flex-end;justify-content:center;
  animation:fade .18s}
@media(min-width:560px){.modal-back{align-items:center;padding:20px}}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:#fff;width:100%;max-width:480px;border-radius:26px 26px 0 0;padding:10px 22px 26px;
  max-height:93dvh;overflow-y:auto;animation:slideup .26s cubic-bezier(.16,1,.3,1)}
@media(min-width:560px){.modal{border-radius:26px}}
@keyframes slideup{from{transform:translateY(60px)}to{transform:translateY(0)}}
.modal .grab{width:44px;height:5px;border-radius:3px;background:#e5e8eb;margin:8px auto 18px}
.modal h3{margin:0 0 20px;font-size:21px;font-weight:800;text-align:center;letter-spacing:-.03em}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* 금액 입력 */
.amount-input{position:relative;margin-bottom:14px}
.amount-input input{font-size:32px;font-weight:800;text-align:right;padding:16px 46px 16px 16px;letter-spacing:-.04em;background:#f2f4f6}
.amount-input .won{position:absolute;right:18px;top:50%;transform:translateY(-50%);font-weight:800;color:var(--sub);font-size:20px}

/* 타입 토글 */
.type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.type-toggle button{padding:14px;border-radius:14px;font-weight:700;background:#f2f4f6;color:var(--sub)}
.type-toggle button.act-exp{background:var(--red);color:#fff}
.type-toggle button.act-inc{background:var(--green);color:#fff}

/* 카테고리 선택 */
.cat-pick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:4px}
.cat-pick button{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 4px;border-radius:14px;
  background:#f2f4f6;font-size:11px;font-weight:600;color:var(--sub);transition:background .12s}
.cat-pick button .e{font-size:22px}
.cat-pick button.sel{background:var(--brand);color:#fff}

/* 색상 선택 */
.color-pick{display:flex;gap:10px;flex-wrap:wrap}
.color-pick button{width:36px;height:36px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1px var(--line2);transition:transform .1s}
.color-pick button.sel{box-shadow:0 0 0 2.5px var(--brand);transform:scale(1.1)}

.modal-actions{display:flex;gap:10px;margin-top:22px}
.modal-actions .btn{flex:1}
.modal-actions .btn-danger{flex:0 0 auto;padding-left:22px;padding-right:22px}
.icon-pick{display:flex;gap:7px;flex-wrap:wrap;max-height:124px;overflow-y:auto}
.icon-pick button{width:42px;height:42px;border-radius:12px;background:#f2f4f6;font-size:21px}
.icon-pick button.sel{background:var(--brand);box-shadow:0 0 0 2px var(--brand)}
.field label.check{display:flex;align-items:center;gap:9px;font-size:15px;color:#4e5968;font-weight:600;cursor:pointer}
.field label.check input{width:auto}

.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#191f28;color:#fff;
  padding:13px 20px;border-radius:14px;font-size:15px;font-weight:600;z-index:90;box-shadow:var(--shadow-lg);
  animation:fade .18s;white-space:nowrap}
.spin{display:inline-block;width:40px;height:40px;border:4px solid #eceef1;border-top-color:var(--brand);
  border-radius:50%;animation:rot .7s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.loading-full{min-height:55dvh;display:flex;align-items:center;justify-content:center}
