:root{
  --paper:#F6F2EC; --surface:#FFFFFF; --ink:#2A2521; --muted:#8B8278; --faint:#B6ACA0;
  --line:#E7DFD4; --line-soft:#F0EAE1; --wine:#7C2D3B; --wine-deep:#62212C;
  --rose:#C58794; --rose-bg:#F7EBED; --sage:#3E6A51; --sage-bg:#E9F0EB;
  --over:#B23B3B; --over-bg:#FBECEC;
  --shadow:0 1px 2px rgba(42,37,33,.04),0 8px 24px rgba(42,37,33,.06); --radius:18px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:"Pretendard Variable",Pretendard,-apple-system,sans-serif;background:var(--paper);
  color:var(--ink);font-feature-settings:"tnum";line-height:1.5;-webkit-font-smoothing:antialiased}
.serif{font-family:"Nanum Myeongjo",serif}
.app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--paper);position:relative;padding-bottom:88px}

header{padding:calc(24px + env(safe-area-inset-top)) 22px 10px}
.eyebrow{font-size:12px;letter-spacing:.22em;color:var(--rose);font-weight:700;text-transform:uppercase}
h1{font-size:32px;margin:8px 0 0;font-weight:800;letter-spacing:-.01em}
.meta{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.count{font-size:13.5px;color:var(--muted)}
.count b{color:var(--wine);font-weight:700}
.pill{font-size:12px;font-weight:600;border-radius:999px;padding:5px 11px;cursor:pointer;
  border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;gap:5px;color:var(--muted)}
.pill.cloud{border-color:#CFE0D5;background:var(--sage-bg);color:var(--sage)}
.pill .dotlive{width:6px;height:6px;border-radius:50%;background:var(--sage)}

.subnav{display:flex;gap:6px;padding:6px 22px 0;overflow-x:auto;scrollbar-width:none}
.subnav::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line);background:var(--surface);color:var(--muted);
  font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;cursor:pointer;transition:.15s;font-family:inherit}
.chip[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}

.screen{padding:14px 14px 8px;display:flex;flex-direction:column;gap:14px}
.loading{text-align:center;color:var(--faint);font-size:13.5px;padding:40px 0}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card.sel{border-color:var(--sage);box-shadow:0 0 0 1.5px var(--sage),var(--shadow)}
.card-top{padding:15px 16px 4px}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.hall-name{font-size:19px;font-weight:700;letter-spacing:-.01em;line-height:1.25;display:flex;align-items:center;gap:7px}
.seltag{font-size:11px;font-weight:800;color:#fff;background:var(--sage);border-radius:6px;padding:2px 7px}
.hall-sub{font-size:13px;color:var(--muted);margin-top:3px;display:flex;flex-wrap:wrap;gap:4px 8px}
.acts{display:flex;gap:2px;flex:0 0 auto;margin:-4px -6px 0 0}
.icon-btn{width:34px;height:34px;border:none;background:transparent;border-radius:10px;cursor:pointer;color:var(--faint);display:grid;place-items:center;transition:.15s}
.icon-btn:hover{background:var(--line-soft);color:var(--ink)}
.icon-btn svg{width:17px;height:17px}

.dates{padding:2px 16px 0;display:flex;flex-wrap:wrap;gap:6px}
.date-chip{font-size:12px;background:var(--rose-bg);color:var(--wine);border-radius:8px;padding:4px 9px;font-weight:600}
.no-dates{font-size:12.5px;color:var(--faint);padding:2px 16px 0}
.memo-line{padding:6px 16px 0;font-size:12.5px;color:var(--muted);line-height:1.5;white-space:pre-wrap}

.compare{margin:13px 16px 12px;background:var(--line-soft);border-radius:14px;padding:13px 14px 11px}
.cmp-grid{display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
.cmp-col .lbl{font-size:11px;color:var(--muted);font-weight:700}
.cmp-col .amt{font-size:15px;font-weight:600;margin-top:2px;white-space:nowrap}
.cmp-col.list .amt{color:var(--faint);text-decoration:line-through;text-decoration-thickness:1.5px}
.cmp-col.consult{text-align:right}
.cmp-col.consult .amt{font-size:20px;font-weight:800;color:var(--ink)}
.arrow{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--faint) 0 4px,transparent 4px 8px);margin:0 6px 9px;min-width:14px}
.bar{height:7px;border-radius:99px;background:#E4DCD0;margin-top:11px;overflow:hidden}
.bar>i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--rose),var(--wine))}
.save-row{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.save-amt{font-size:12px;color:var(--muted)}
.badge{font-size:13px;font-weight:800;padding:4px 11px;border-radius:999px}
.badge.pos{background:var(--sage-bg);color:var(--sage)}
.badge.zero{background:#EFEAE2;color:var(--muted)}
.badge.neg{background:var(--over-bg);color:var(--over)}
.empty-cmp{font-size:12.5px;color:var(--faint);text-align:center;padding:4px 0 2px}
.netcost{margin:0 16px 14px;display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--ink)}
.netcost span{font-size:10.5px;font-weight:700;color:var(--sage);background:var(--sage-bg);border-radius:5px;padding:1px 6px}
.netcost b{margin-left:auto;font-size:16px;color:var(--wine)}
.netbox{margin-top:10px;background:var(--line-soft);border-radius:10px;padding:10px 12px}
.netbox .nl{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted)}
.netbox .nl.tot{font-size:13.5px;font-weight:800;color:var(--ink);border-top:1px solid var(--line);margin-top:7px;padding-top:7px}
.netbox .nl.tot span:last-child{color:var(--wine)}

.card-foot{display:flex;border-top:1px solid var(--line-soft)}
.card-foot button{flex:1;background:none;border:none;font-family:inherit;font-size:13px;font-weight:700;color:var(--muted);padding:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px}
.card-foot button+button{border-left:1px solid var(--line-soft)}
.card-foot button.selbtn{color:var(--sage)}
.card-foot button.selbtn.on{background:var(--sage-bg)}
.card-foot svg{width:14px;height:14px}

.simple{padding:15px 16px}
.simple .nm{font-size:18px;font-weight:700}
.simple .amts{display:flex;gap:18px;margin-top:8px;flex-wrap:wrap}
.simple .amt-b .l{font-size:11px;color:var(--muted);font-weight:700}
.simple .amt-b .v{font-size:17px;font-weight:700;margin-top:1px}
.simple .amt-b .v.disc{color:var(--wine)}
.simple .amt-b .v.strike{color:var(--faint);text-decoration:line-through}

.empty{margin:24px 4px;text-align:center;padding:44px 24px;border:1.5px dashed var(--line);border-radius:20px;background:var(--surface)}
.empty .em{font-size:30px}
.empty h3{font-size:17px;margin:14px 0 6px;font-weight:700}
.empty p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.6}

/* compact 2-up hall cards */
.hall-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.card.mini{padding:13px 12px 8px;display:flex;flex-direction:column}
.mini .mname{font-size:14.5px;font-weight:700;line-height:1.25;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.mini .seltag{font-size:9px;padding:1px 5px}
.mini .msub{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.3}
.mini .mamt{font-size:17px;font-weight:800;margin-top:8px;line-height:1.1}
.mini .mamt.none{font-size:12px;color:var(--faint);font-weight:600}
.mini .mlist{font-size:11px;color:var(--faint);text-decoration:line-through;margin-top:2px}
.mini .mbadge{align-self:flex-start;margin-top:6px;font-size:10.5px}
.mini .mdate{font-size:10.5px;color:var(--wine);margin-top:6px;line-height:1.45}
.mini .mmemo{font-size:10.5px;color:var(--muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini .macts{display:flex;gap:1px;margin-top:9px;padding-top:6px;border-top:1px solid var(--line-soft)}
.mini .macts button{flex:1;height:30px;border:none;background:transparent;border-radius:8px;color:var(--faint);display:grid;place-items:center;cursor:pointer}
.mini .macts button svg{width:15px;height:15px}
.mini .macts button.on{color:var(--sage)}
.mini .macts button:active{background:var(--line-soft)}

/* budget linked detail + etc items */
.tdetail{padding:3px 4px 9px 16px;display:flex;flex-direction:column;gap:3px;border-bottom:1px solid var(--line-soft)}
.tdetail .src{font-size:11.5px;color:var(--sage);font-weight:700}
.tdetail .dl{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted)}
.tdetail .none{font-size:11.5px;color:var(--faint)}
.etc-add{margin:7px 0 2px 16px;border:1px dashed var(--line);background:none;color:var(--muted);font-family:inherit;font-size:12px;font-weight:600;border-radius:9px;padding:7px 10px;cursor:pointer}
.etc-item{padding:9px 2px 11px 16px;border-bottom:1px solid var(--line-soft)}
.etc-top{display:flex;gap:6px;align-items:center}
.etc-top .en{flex:1;font-size:13px;padding:8px 10px;border-radius:8px}
.etc-top .rm{background:none;border:none;color:var(--faint);font-size:18px;cursor:pointer;padding:0 2px}
.etc-amts{display:flex;gap:8px;margin-top:7px}
.etc-amts .ea-wrap{position:relative;flex:1;display:flex;align-items:center}
.etc-amts .eal{position:absolute;left:9px;font-size:10px;color:var(--faint);font-weight:700;pointer-events:none}
.etc-amts .ea-wrap input{width:100%;text-align:right;padding:8px 22px 8px 38px;font-size:12.5px;border-radius:8px}
.etc-amts .ea-wrap .sfx{position:absolute;right:8px;font-size:11px;color:var(--faint)}

/* summary / budget input panels */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.panel .ptitle{font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:10px;letter-spacing:.02em}
.sum-amts{display:flex;gap:20px;flex-wrap:wrap}
.sum-b .l{font-size:11.5px;color:var(--muted);font-weight:700}
.sum-b .v{font-size:22px;font-weight:800;margin-top:2px}
.sum-b .v.disc{color:var(--wine)}
.sum-b .v.muted{color:var(--faint);font-size:18px;text-decoration:line-through}
.sum-pick{font-size:12.5px;color:var(--faint);margin-top:10px}

.ai-btn{width:100%;border:1px solid var(--wine);background:var(--rose-bg);color:var(--wine);font-family:inherit;
  font-size:14.5px;font-weight:700;padding:13px;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}
.ai-btn svg{width:17px;height:17px}
.ai-out{margin-top:12px;font-size:13.5px;line-height:1.7;color:var(--ink);white-space:normal}
.ai-out h4{font-size:14px;margin:14px 0 4px;color:var(--wine)}
.ai-out strong{font-weight:700}

/* budget tree */
.tree{display:flex;flex-direction:column}
.trow{display:grid;grid-template-columns:1fr auto;gap:6px 10px;padding:11px 4px;border-bottom:1px solid var(--line-soft)}
.trow:last-child{border-bottom:none}
.trow .nm{font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}
.trow.lv0 .nm{font-size:15.5px;font-weight:800}
.trow.lv1{padding-left:14px}.trow.lv1 .nm{color:var(--ink)}
.trow.lv2{padding-left:28px}.trow.lv2 .nm{font-size:13.5px;color:var(--muted)}
.trow.lv0{background:var(--line-soft);border-radius:10px;margin:4px 0;padding-left:10px;padding-right:8px}
.linktag{font-size:10px;font-weight:700;color:var(--sage);background:var(--sage-bg);border-radius:5px;padding:1px 5px}
.tnums{display:flex;flex-direction:column;align-items:flex-end;gap:2px;grid-column:2}
.tnums .set{font-size:11px;color:var(--muted)}
.tnums .act{font-size:15px;font-weight:700}
.tdiff{font-size:11.5px;font-weight:700}
.tdiff.pos{color:var(--sage)}.tdiff.neg{color:var(--over)}
.binput{width:108px;font-family:inherit;font-size:13.5px;text-align:right;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:6px 8px;color:var(--ink)}
.binput:focus{outline:none;border-color:var(--rose)}
.blabel{font-size:10px;color:var(--faint);text-align:right}

.homechip{display:none;background:none;border:none;font-family:inherit;font-size:13px;font-weight:700;color:var(--wine);cursor:pointer;padding:0 0 8px;margin-left:-1px}

.home-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:16px 8px 14px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px}
.tile:active{transform:translateY(1px)}
.tile .ti{font-size:25px;line-height:1}
.tile .tn{font-size:13.5px;font-weight:700}
.tile .ts{font-size:10.5px;color:var(--muted);line-height:1.3}

.cal{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:15px 14px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-head .mtitle{font-size:17px;font-weight:800}
.cal-nav{display:flex;gap:6px}
.cal-nav button{width:32px;height:32px;border:1px solid var(--line);background:var(--paper);border-radius:9px;cursor:pointer;font-size:14px;color:var(--ink);display:grid;place-items:center;font-family:inherit}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:10.5px;color:var(--muted);font-weight:700;margin-bottom:5px}
.cal-week .s0{color:#c0584f}.cal-week .s6{color:#4f6bc0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-cell{min-height:44px;display:flex;flex-direction:column;align-items:center;padding-top:7px;border-radius:10px;overflow:hidden}
.cal-cell.empty{visibility:hidden}
.cal-cell .cnum{font-size:12.5px;color:var(--ink);line-height:1}
.cal-cell .cnum.s0{color:#c0584f}.cal-cell .cnum.s6{color:#4f6bc0}
.cal-cell.today{background:var(--rose-bg)}
.cal-cell.today .cnum{color:var(--wine);font-weight:800}
.cdots{display:flex;gap:2.5px;margin-top:5px;height:6px;align-items:center}
.cdot{width:5px;height:5px;border-radius:50%}

/* d-day hero */
.dday{background:linear-gradient(135deg,var(--wine),var(--wine-deep));color:#fff;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}
.dday .big{font-family:"Nanum Myeongjo",serif;font-size:30px;font-weight:800;line-height:1}
.dday .sub{font-size:12px;color:rgba(255,255,255,.85);margin-top:5px}
.dday .rgt{text-align:right;font-size:11.5px;color:rgba(255,255,255,.92);line-height:1.5}
.dday.empty{background:var(--surface);color:var(--muted);border:1.5px dashed var(--line);justify-content:center;text-align:center}
.dday.empty .big{font-size:15px;font-family:inherit;font-weight:700}

/* upcoming */
.up-list{display:flex;flex-direction:column;gap:8px}
.up-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:11px 12px;box-shadow:var(--shadow)}
.up-d{flex:0 0 auto;font-size:12px;font-weight:800;color:var(--wine);width:50px}
.up-t{flex:1;font-size:13px;font-weight:600;line-height:1.35}
.up-tag{flex:0 0 auto;font-size:10px;font-weight:700;color:#fff;border-radius:5px;padding:2px 6px}
.up-empty{font-size:12.5px;color:var(--faint);padding:6px 2px}

/* checklist */
.cl-home{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:15px 16px;cursor:pointer;display:flex;align-items:center;gap:13px}
.cl-home .ti{font-size:24px}
.cl-home .nm{font-size:14.5px;font-weight:700}
.cl-home .ts{font-size:11.5px;color:var(--muted);margin-top:2px}
.cl-home .pbar{height:7px;background:var(--line-soft);border-radius:99px;margin-top:8px;overflow:hidden}
.cl-home .pbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--rose),var(--wine));border-radius:99px}
.prog{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:15px 16px}
.prog .pt{display:flex;justify-content:space-between;align-items:baseline}
.prog .pn{font-size:14px;font-weight:700}
.prog .pp{font-size:14px;color:var(--wine);font-weight:800}
.prog .pbar{height:8px;background:var(--line-soft);border-radius:99px;margin-top:10px;overflow:hidden}
.prog .pbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--rose),var(--wine));border-radius:99px;transition:width .3s}
.cl-group{margin-top:16px}
.cl-gtitle{font-size:12.5px;font-weight:800;color:var(--muted);margin:0 2px 8px;letter-spacing:.02em}
.cl-item{display:flex;align-items:flex-start;gap:11px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 13px;margin-bottom:8px}
.cl-check{flex:0 0 auto;width:22px;height:22px;border-radius:7px;border:2px solid var(--line);cursor:pointer;display:grid;place-items:center;margin-top:1px}
.cl-check.on{background:var(--sage);border-color:var(--sage)}
.cl-check svg{width:13px;height:13px;color:#fff;opacity:0}
.cl-check.on svg{opacity:1}
.cl-body{flex:1;min-width:0}
.cl-text{font-size:14px;line-height:1.4}
.cl-item.done .cl-text{color:var(--faint);text-decoration:line-through}
.cl-due{font-size:11.5px;color:var(--wine);font-weight:600}
.cl-meta{display:flex;gap:8px;align-items:center;margin-top:4px;flex-wrap:wrap}
.cl-cat{font-size:10.5px;font-weight:700;color:var(--wine);background:var(--rose-bg);border-radius:5px;padding:1px 6px}
.cl-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px}
.seg{display:flex;background:var(--line-soft);border-radius:10px;padding:3px}
.seg button{border:none;background:none;font-family:inherit;font-size:13px;font-weight:700;color:var(--muted);padding:7px 15px;border-radius:8px;cursor:pointer}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.cl-manage{border:1px solid var(--line);background:var(--surface);font-family:inherit;font-size:12.5px;font-weight:600;color:var(--muted);border-radius:9px;padding:8px 12px;cursor:pointer}
.cat-list{display:flex;flex-direction:column;gap:8px}
.cat-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14px;font-weight:600}
.cat-row button{background:none;border:none;color:var(--faint);font-size:18px;cursor:pointer}
.cl-del{flex:0 0 auto;background:none;border:none;color:var(--faint);cursor:pointer;font-size:17px;padding:0 2px}
.cl-seed{width:100%;border:1px dashed var(--line);background:none;color:var(--muted);font-family:inherit;font-size:13px;font-weight:600;border-radius:12px;padding:13px;cursor:pointer;margin-top:8px}

.agenda{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.agenda-empty{font-size:12.5px;color:var(--faint);text-align:center;padding:14px 0}
.ag-row{display:flex;gap:11px;align-items:stretch}
.ag-date{flex:0 0 auto;width:46px;text-align:center;padding-top:1px}
.ag-date .d{font-size:18px;font-weight:800;line-height:1}
.ag-date .w{font-size:10px;color:var(--muted);margin-top:1px}
.ag-body{flex:1;border-left:3px solid var(--line);padding-left:11px}
.ag-tag{font-size:10px;font-weight:700;color:#fff;border-radius:5px;padding:1px 6px;display:inline-block}
.ag-title{font-size:13.5px;font-weight:600;margin-top:3px}
.ag-time{font-size:11.5px;color:var(--muted);margin-top:1px}
.home-sec{font-size:12.5px;font-weight:700;color:var(--muted);margin:18px 2px 2px;letter-spacing:.02em}

.side{font-size:10px;font-weight:700;border-radius:5px;padding:1px 6px;color:#fff}
.side.groom{background:#4f6bc0}.side.bride{background:#c0588a}.side.both{background:#8b8278}
.gstat{font-size:11px;font-weight:700;border-radius:6px;padding:2px 9px}
.gstat.go{background:var(--sage-bg);color:var(--sage)}.gstat.no{background:var(--over-bg);color:var(--over)}.gstat.maybe{background:#EFEAE2;color:var(--muted)}
.ginv{font-size:11px;font-weight:700;color:var(--wine)}
.paytoggle{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:7px 12px;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--muted);cursor:pointer}
.paytoggle.on{background:var(--sage-bg);border-color:#cfe0d5;color:var(--sage)}
.thumb{display:block;width:100%;max-height:170px;object-fit:cover;background:var(--line-soft)}
.linkrow{padding:8px 16px 0;display:flex;gap:6px;flex-wrap:wrap}
.linkchip{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:600;color:var(--wine);background:var(--rose-bg);border-radius:8px;padding:5px 10px;text-decoration:none}

.ledger{margin:0 16px 14px;background:var(--line-soft);border-radius:12px;padding:12px}
.led-head{font-size:12px;font-weight:800;color:var(--muted);display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.led-head span{font-size:11px;font-weight:700;color:var(--ink)}
.led-empty{font-size:11.5px;color:var(--faint);text-align:center;padding:4px 0 8px}
.pay-line{display:flex;gap:6px;align-items:center}
.pay-line .pl-label{flex:1.25;font-size:12.5px;padding:8px 9px;border-radius:8px;min-width:0}
.pay-line .pl-amt{position:relative;flex:1;display:flex;align-items:center;min-width:0}
.pay-line .pl-amt input{width:100%;text-align:right;padding:8px 22px 8px 9px;font-size:12.5px;border-radius:8px}
.pay-line .pl-amt .sfx{position:absolute;right:8px;font-size:11px;color:var(--faint)}
.pay-line .pl-del{background:none;border:none;color:var(--faint);font-size:17px;cursor:pointer;padding:0 2px}
.pl-rem{font-size:11px;color:var(--sage);font-weight:700;text-align:right;margin:3px 26px 9px 0}
.pl-rem.over{color:var(--over)}
.pl-add{width:100%;border:1px dashed var(--line);background:var(--surface);color:var(--muted);font-family:inherit;font-size:12px;font-weight:600;border-radius:9px;padding:9px;cursor:pointer;margin-top:2px}

.exg{border-bottom:1px solid var(--line-soft);padding:8px 0 9px}
.exg:last-child{border-bottom:none}
.exg-top{display:flex;gap:6px;align-items:center}
.exg-top .exn2{flex:1;font-size:13px;padding:8px 10px;border-radius:8px}
.exg-top .rm{background:none;border:none;color:var(--faint);font-size:18px;cursor:pointer;padding:0 2px}
.exg-amts{display:flex;gap:8px;margin-top:7px}
.exg-amts .exa-wrap{position:relative;flex:1;display:flex;align-items:center}
.exg-amts .eal{position:absolute;left:9px;font-size:10px;color:var(--faint);font-weight:700;pointer-events:none}
.exg-amts .exa-wrap input{width:100%;text-align:right;padding:8px 22px 8px 38px;font-size:12.5px;border-radius:8px}
.exg-amts .exa-wrap .sfx{position:absolute;right:8px;font-size:11px;color:var(--faint)}

.show-others{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;border:1px solid var(--line);background:var(--surface);color:var(--muted);font-family:inherit;font-size:13px;font-weight:700;border-radius:12px;padding:12px;cursor:pointer;margin-bottom:14px;box-shadow:var(--shadow)}
.show-others svg{width:15px;height:15px}
.tnums .paid{font-size:11px;color:var(--sage);font-weight:700;text-align:right}

.nav{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:rgba(246,242,236,.94);
  backdrop-filter:blur(10px);border-top:1px solid var(--line);display:flex;padding:8px 6px calc(8px + env(safe-area-inset-bottom));z-index:5}
.nav button{flex:1;background:none;border:none;font-family:inherit;cursor:pointer;color:var(--faint);
  font-size:11px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0}
.nav button .ni{font-size:18px;line-height:1}
.nav button[aria-current="true"]{color:var(--wine)}

.fab{position:fixed;bottom:calc(86px + env(safe-area-inset-bottom));right:0;left:0;max-width:480px;margin:0 auto;pointer-events:none;z-index:6}
.fab button{pointer-events:auto;position:absolute;right:18px;bottom:0;height:50px;padding:0 20px;border:none;border-radius:999px;
  background:var(--wine);color:#fff;font-size:14.5px;font-weight:700;font-family:inherit;cursor:pointer;
  box-shadow:0 8px 22px rgba(124,45,59,.32);display:flex;align-items:center;gap:7px}
.fab button:active{transform:translateY(1px)}
.fab svg{width:17px;height:17px}

.overlay{position:fixed;inset:0;background:rgba(42,37,33,.42);z-index:20;display:none;align-items:flex-end;justify-content:center}
.overlay.show{display:flex}
.sheet{background:var(--paper);width:100%;max-width:480px;max-height:94vh;border-radius:24px 24px 0 0;display:flex;flex-direction:column;animation:up .28s cubic-bezier(.2,.8,.2,1)}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.grip{width:40px;height:4px;background:var(--line);border-radius:99px;margin:10px auto 0}
.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 12px}
.sheet-head h2{font-size:19px;font-weight:700;margin:0}
.sheet-head .x{background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;line-height:1;padding:4px}
.sheet-body{overflow-y:auto;padding:4px 20px calc(20px + env(safe-area-inset-bottom));flex:1}

.field{margin-bottom:14px}
.field>label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:6px}
input,select,textarea{width:100%;font-family:inherit;font-size:15.5px;color:var(--ink);background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:12px 13px;outline:none;transition:.15s}
textarea{resize:vertical;min-height:64px;line-height:1.5}
input:focus,textarea:focus{border-color:var(--rose);box-shadow:0 0 0 3px var(--rose-bg)}
input::placeholder,textarea::placeholder{color:var(--faint)}

.date-add{display:flex;gap:8px}
.date-add button{flex:0 0 auto;border:1px solid var(--wine);background:var(--rose-bg);color:var(--wine);font-weight:700;font-size:14px;border-radius:12px;padding:0 16px;cursor:pointer;font-family:inherit}
.date-list{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.date-list:empty{display:none}
.date-tag{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:6px 8px 6px 11px;font-size:13px;font-weight:600}
.date-tag button{background:none;border:none;color:var(--faint);font-size:16px;cursor:pointer;line-height:1;padding:0}

.extras-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.ex-row{display:flex;gap:8px;align-items:center}
.ex-row .exn{flex:1.3}
.ex-row .exa-wrap{flex:1;position:relative}
.ex-row .exa-wrap .sfx{position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--faint)}
.ex-row .exa-wrap input{padding-right:30px;text-align:right}
.ex-row .rm{flex:0 0 auto;background:none;border:none;color:var(--faint);font-size:20px;cursor:pointer;padding:0 2px}
.ex-add{margin-top:8px;width:100%;border:1px dashed var(--line);background:none;color:var(--muted);font-family:inherit;font-size:13px;font-weight:600;border-radius:10px;padding:9px;cursor:pointer}

.section-tab{display:flex;gap:6px;margin:18px 0 14px;background:var(--line-soft);padding:4px;border-radius:12px}
.section-tab button{flex:1;border:none;background:none;font-family:inherit;font-size:13.5px;font-weight:700;color:var(--muted);padding:9px;border-radius:9px;cursor:pointer;transition:.15s}
.section-tab button.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.quote-pane{display:none}.quote-pane.on{display:block}
.quote-hint{font-size:12.5px;color:var(--muted);background:var(--rose-bg);border-radius:10px;padding:9px 12px;margin-bottom:14px;line-height:1.5}
.quote-hint.list-hint{background:var(--line-soft)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.suffix-wrap{position:relative}
.suffix-wrap .sfx{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--faint);pointer-events:none}
.suffix-wrap input{padding-right:34px;text-align:right}

.calc-box{background:var(--ink);color:#fff;border-radius:14px;padding:14px 16px;margin-top:6px}
.calc-line{display:flex;justify-content:space-between;font-size:12.5px;color:#D9D1C7;margin-bottom:6px}
.calc-total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid rgba(255,255,255,.15);padding-top:9px;margin-top:3px}
.calc-total .l{font-size:13px;color:#D9D1C7;font-weight:600}
.calc-total .v{font-size:21px;font-weight:800}

.submit{width:100%;border:none;background:var(--wine);color:#fff;font-family:inherit;font-size:16px;font-weight:700;padding:15px;border-radius:14px;cursor:pointer;margin-top:18px}
.submit:active{background:var(--wine-deep)}

.detail-toggle{width:100%;background:none;border:none;border-top:1px solid var(--line-soft);font-family:inherit;font-size:12.5px;font-weight:600;color:var(--muted);padding:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px}
.detail-toggle svg{width:13px;height:13px;transition:.2s}
.detail-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}
.detail{display:none;padding:2px 16px 16px}.detail.show{display:block}
.detail-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;font-size:12.5px}
.detail-grid>div{padding:7px 4px;border-bottom:1px solid var(--line-soft)}
.detail-grid .h{font-weight:700;color:var(--muted);font-size:11px;border-bottom:1px solid var(--line)}
.detail-grid .rl{color:var(--muted)}
.detail-grid .num{text-align:right;font-weight:600}
.detail-grid .num.l{color:var(--faint)}

.room-screen{position:fixed;inset:0;z-index:30;background:var(--paper);display:none;align-items:center;justify-content:center;padding:24px}
.room-screen.show{display:flex}
.room-card{max-width:360px;width:100%;text-align:center}
.room-card .em{font-size:34px}
.room-card h2{font-size:22px;font-weight:800;margin:12px 0 6px}
.room-card p{font-size:14px;color:var(--muted);line-height:1.6;margin:0 0 22px}
.room-card input{text-align:center;font-size:17px;font-weight:600;margin-bottom:12px}
.room-card .hint{font-size:12px;color:var(--faint);margin-top:14px;line-height:1.5}

.toast{position:fixed;bottom:150px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;font-size:13.5px;font-weight:600;padding:11px 18px;border-radius:12px;opacity:0;pointer-events:none;transition:.25s;z-index:40;max-width:320px;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== 예산 표 ===== */
.btable{width:100%;border-collapse:collapse;font-size:13px}
.btable thead{position:sticky;top:0;z-index:1}
.bhdr th{background:var(--ink);color:#fff;font-size:11px;font-weight:700;padding:9px 6px;text-align:right}
.bhdr th.bnm{text-align:left;padding-left:14px}
.brow td{padding:8px 6px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.brow.lv0 td{background:var(--line-soft);font-weight:800;font-size:14px}
.brow.lv0 td.bnm{padding-left:10px}
.brow.lv1leaf td,.brow.lv2leaf td{background:var(--surface)}
.brow.lv1leaf td{font-size:13px}
.brow.lv2leaf td{font-size:12.5px}
.bnm{text-align:left;font-weight:600;color:var(--ink)}
.bval{text-align:right;color:var(--muted);white-space:nowrap}
.bval.wine{color:var(--wine);font-weight:700}
.bval.sage{color:var(--sage);font-weight:700}
.bval.over{color:var(--over);font-weight:700}
.bval .binput{width:90px;font-size:12px;padding:5px 6px;border-radius:7px;text-align:right}
.bdetail td{padding:0;background:var(--surface)}
.bdetail .tdetail{margin:0;border-bottom:none;padding:4px 6px 6px 22px}
.bdetail .none{font-size:11.5px;color:var(--faint);padding:4px 22px 6px}
.bdetail .etc-item{padding:6px 6px 8px 14px}
.bdetail .etc-add{margin:4px 0 6px 14px}

/* 예산 보기 토글 */
.bview-btn{border:1px solid var(--line);background:var(--surface);color:var(--muted);font-family:inherit;font-size:12.5px;font-weight:600;border-radius:9px;padding:7px 13px;cursor:pointer}
.bview-btn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
