:root{--bg:#f5f7fb;--card:#fff;--line:#e5e7eb;--text:#111827;--muted:#6b7280;--primary:#2563eb;--primary2:#1d4ed8;--green:#059669;--red:#dc2626;--amber:#d97706;--nav:#0f172a}
*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans KR",sans-serif;background:var(--bg);color:var(--text)}button,input,select,textarea{font:inherit}button{border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 12px;cursor:pointer}button:hover{background:#f8fafc}.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.primary:hover{background:var(--primary2)}.danger{color:#b91c1c}.muted{color:var(--muted)}.boot,.center{min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{width:min(460px,92vw);background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px;box-shadow:0 20px 60px rgba(15,23,42,.08)}.logo{width:54px;height:54px;border-radius:18px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:26px;margin-bottom:18px}.seg{display:flex;gap:8px;background:#f1f5f9;padding:5px;border-radius:12px}.seg button{flex:1;border:0;background:transparent}.seg button.on{background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.08)}label{display:block;font-size:13px;color:#374151;margin:12px 0 4px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff}textarea{min-height:84px}.wideBtn{width:100%;margin-top:14px}.msg{padding:10px 12px;border-radius:10px;background:#eff6ff;color:#1d4ed8;margin:12px 0}.err{padding:10px 12px;border-radius:10px;background:#fef2f2;color:#b91c1c;margin:12px 0;white-space:pre-wrap}.shell{display:grid;grid-template-columns:252px 1fr;min-height:100vh}.side{background:var(--nav);color:#fff;padding:20px;display:flex;flex-direction:column;gap:18px}.brand{display:flex;gap:12px;align-items:center}.brandMark{width:44px;height:44px;border-radius:14px;background:#2563eb;display:flex;align-items:center;justify-content:center;font-weight:800}.brand small{color:#94a3b8}.nav{display:grid;gap:6px}.nav button{display:flex;align-items:center;gap:10px;color:#cbd5e1;background:transparent;border:0;text-align:left}.nav button.active,.nav button:hover{background:#1e293b;color:#fff}.sideFoot{margin-top:auto}.main{padding:28px}.top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:20px}.top h1{margin:0;font-size:28px}.top p{margin:6px 0 0;color:var(--muted)}.user{font-size:13px;color:var(--muted);text-align:right}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin:12px 0 18px}.toolbar .left,.toolbar .right{display:flex;gap:8px;align-items:center}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 6px 16px rgba(15,23,42,.03);margin-bottom:16px}.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.kpi span{display:block;color:var(--muted);font-size:13px}.kpi b{display:block;font-size:25px;margin-top:8px}.kpi.blue{border-top:4px solid var(--primary)}.kpi.green{border-top:4px solid var(--green)}.kpi.amber{border-top:4px solid var(--amber)}.kpi.red{border-top:4px solid var(--red)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.tableWrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{color:#475569;background:#f8fafc}.num{text-align:right}.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px}.badge.매출{background:#dbeafe;color:#1d4ed8}.badge.매입{background:#f3f4f6;color:#374151}.badge.완료{background:#dcfce7;color:#15803d}.badge.취소{background:#fee2e2;color:#b91c1c}.rowBtns{display:flex;gap:6px;flex-wrap:wrap}.formGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.formGrid .full{grid-column:1/-1}.items{display:grid;gap:8px}.itemRow{display:grid;grid-template-columns:2fr 1.2fr .8fr 1fr 1fr auto;gap:8px;align-items:center}.payRow{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:8px;align-items:center}.modalBack{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:50;display:flex;align-items:center;justify-content:center;padding:18px}.modal{background:#fff;border-radius:20px;max-height:92vh;overflow:auto;width:min(900px,96vw);padding:22px}.modal.full{width:min(1180px,98vw)}.modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.modalHead h2{margin:0}.actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.docPreview{background:#fff;border:1px solid var(--line);padding:26px;margin-top:14px}.docPreview h1{text-align:center;margin:0 0 22px}.docMeta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.loading{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.6);z-index:60}.spinner{width:44px;height:44px;border-radius:50%;border:4px solid #bfdbfe;border-top-color:#2563eb;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;right:22px;bottom:22px;background:#0f172a;color:#fff;padding:13px 16px;border-radius:14px;z-index:70}.empty{padding:30px;text-align:center;color:var(--muted)}.help{font-size:13px;color:var(--muted)}.chart{height:240px;display:flex;gap:14px;align-items:flex-end;padding:18px 10px 10px}.chartLegend{display:flex;gap:16px;align-items:center;font-size:13px;color:#475569;margin:0 0 4px 10px}.chartLegend span{display:flex;align-items:center;gap:6px}.chartLegend i{display:inline-block;width:10px;height:10px;border-radius:50%}.salesDot{background:#2563eb}.purchaseDot{background:#94a3b8}.barGroup{min-width:54px;text-align:center}.barValue{font-size:12px;font-weight:700;color:#2563eb;line-height:1.15;min-height:14px;white-space:nowrap}.barValue.purchase{color:#64748b;margin-bottom:3px}.bar{height:180px;display:flex;gap:5px;align-items:flex-end;justify-content:center}.bar i{display:block;width:20px;background:#2563eb;border-radius:5px 5px 0 0;min-height:4px}.bar i:last-child{background:#94a3b8}.barLabel{text-align:center;font-size:12px;color:#64748b;margin-top:4px}@media(max-width:900px){.shell{grid-template-columns:1fr}.side{position:static}.kpis,.grid2{grid-template-columns:1fr}.itemRow,.payRow{grid-template-columns:1fr}.formGrid{grid-template-columns:1fr}}

.optionBox{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;padding:12px}.optionBox label{display:flex;gap:8px;align-items:center;margin:0;font-size:14px}.optionBox input[type=checkbox]{width:auto}.optionBox p{margin:6px 0 0;font-size:13px}

/* v5.4: 입력 칸 의미 표시 및 자동 합계 가독성 개선 */
.rowGuide{font-size:13px;color:#475569;background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:9px 11px;margin:6px 0 8px}
.itemHeader,.payHeader{display:grid;gap:8px;align-items:center;color:#475569;font-size:12px;font-weight:700;margin-bottom:4px;padding:0 2px}
.itemHeader{grid-template-columns:2fr 1.2fr .8fr 1fr 1fr .8fr 1fr auto}
.payHeader{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr auto}
.itemRow{grid-template-columns:2fr 1.2fr .8fr 1fr 1fr .8fr 1fr auto}
.payRow{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr auto}
.readonlyTotal,.editableTotal{background:#f8fafc;color:#111827;font-weight:700;text-align:right}.editableTotal{background:#fff;border-color:#93c5fd}
@media(max-width:900px){.itemHeader,.payHeader{display:none}.itemRow,.payRow{grid-template-columns:1fr}}
.hint{font-size:13px;color:#475569;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:12px}
.cardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.cardHead h2{margin:0}.smallSeg{width:auto;flex:0 0 auto}.smallSeg button{white-space:nowrap;padding:7px 11px}.badge.예정{background:#eef2ff;color:#3730a3}.badge.연체{background:#fef3c7;color:#92400e}.badge.진행{background:#e0f2fe;color:#0369a1}
@media(max-width:900px){.cardHead{display:block}.smallSeg{margin-top:10px;overflow:auto}.smallSeg button{flex:0 0 auto}}

.moneyInput,[data-money]{text-align:right}
.inlineLabel{font-size:13px;color:#475569;margin:0 4px 0 0}
.summaryGrid{align-items:start}
.miniSummary h3{margin:0 0 10px}.miniSummary .totalRow td{font-weight:800;background:#f8fafc}.miniSummary table{font-size:13px}

/* v5.10: 매출·매입 리스트 매출처/매입처 분리 필터 */
.toolbar .left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.dangerZone{border-color:#fecaca;background:#fff7f7}.hint{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;margin-top:10px;color:#475569;font-size:13px}.totalRow td{font-weight:800;background:#f8fafc}.miniSummary table{font-size:13px}

/* v5.14: 납품건별 정산 펼침형 화면과 잔금 현금흐름 */
.linkBtn{border:0;background:transparent;color:#2563eb;font-weight:800;padding:2px 0}.linkBtn:hover{background:transparent;text-decoration:underline}.settlementTop td{background:#fff}.settlementChild td{background:#f8fafc}.nested table{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.flowCards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.flowCard{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:14px}.kpi small{display:block;font-size:11px;color:#94a3b8;margin-top:2px}.badge.잔금{background:#fef3c7;color:#92400e}.badge.정산완료{background:#dcfce7;color:#15803d}@media(max-width:900px){.flowCards{grid-template-columns:1fr}}
.grid1{display:grid;grid-template-columns:1fr;gap:18px}
.pager{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.pager button{padding:6px 10px;border-radius:9px;border:1px solid #dbe3ef;background:#fff;cursor:pointer}
.pager button.on{background:#2563eb;color:#fff;border-color:#2563eb}
.kpiGrid.smallKpi{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:10px 0 14px}
.kpiGrid.smallKpi>div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:10px;text-align:center}
.kpiGrid.smallKpi b{font-size:22px;display:block}
.kpiGrid.smallKpi span{font-size:12px;color:#64748b}

/* v5.25 UX refinements */
.partnerGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.partnerCard{border:1px solid var(--line);background:#fff;border-radius:14px;padding:14px}
.partnerCard h3{margin:0 0 8px;font-size:17px}.partnerCard p{margin:6px 0;color:#334155}.grid1{display:grid;grid-template-columns:1fr;gap:16px}
.settlementTop td{background:#eef6ff;border-top:2px solid #bfdbfe;border-bottom:1px solid #dbeafe;font-weight:500}
.settlementTop:hover td{background:#e0f2fe}.settlementChild td{background:#f8fafc;padding:16px 18px 20px}.childBox{background:#f8fafc;border:1px solid #dbe3ef;border-radius:16px;padding:14px;margin:2px 0 6px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.6)}
.childBox h4{margin:0 0 12px;color:#0f172a}.nested table{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.childBalanceSummary{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap;margin-top:12px;padding:12px;border:1px solid #dbeafe;background:#fff;border-radius:12px}.childBalanceSummary span{font-size:13px;color:#475569}.childBalanceSummary b{font-size:15px;color:#0f172a}.childBalanceSummary .net{border-left:1px solid #dbe3ef;padding-left:10px;color:#1d4ed8}
@media(max-width:900px){.partnerGrid{grid-template-columns:1fr}.childBalanceSummary{justify-content:flex-start}.childBalanceSummary .net{border-left:0;padding-left:0}}

/* v5.26 확정/예정 4계열 차트 */
.plannedSalesDot{background:#f59e0b}.plannedPurchaseDot{background:#ef4444}.fourLegend{flex-wrap:wrap}.fourBars{min-width:82px}.fourChart{gap:18px}.fourBars .bar{gap:4px}.fourBars .bar i{width:14px}.fourBars .bar i:nth-child(1){background:#2563eb}.fourBars .bar i:nth-child(2){background:#94a3b8}.fourBars .bar i:nth-child(3){background:#f59e0b}.fourBars .bar i:nth-child(4){background:#ef4444}.barValue.planned{color:#f59e0b;margin-bottom:3px}.barValue.plannedPurchase{color:#ef4444;margin-bottom:3px}

.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:10px;padding:10px 14px;text-decoration:none;font-weight:700;cursor:pointer}
.btn:hover{background:#f8fafc}

/* v5.33 문서 양식/문서 관리 버튼 개선 */
.slipDoc{width:760px;max-width:100%;margin:0 auto;background:#fff;color:#111;font-family:"Noto Sans KR",Arial,sans-serif;font-size:13px;line-height:1.25;border:2px solid #1d4ed8;padding:8px}
.statementSlip{border-color:#1d4ed8;color:#1d4ed8}.orderSlip{border-color:#dc2626;color:#dc2626}
.slipTop{display:grid;grid-template-columns:130px 1fr 150px;align-items:center;border-bottom:1px solid currentColor;margin-bottom:4px}
.slipTop h1{text-align:center;font-size:28px;letter-spacing:14px;margin:4px 0 8px;color:currentColor}.slipDate{border-right:1px solid currentColor;padding:4px;text-align:center;min-height:44px}.slipBoxes{display:grid;grid-template-columns:repeat(5,1fr);gap:0;align-self:stretch}.slipBoxes i{border-left:1px solid currentColor;border-bottom:1px solid currentColor;min-height:22px}.slipBoxes small{grid-column:1/-1;text-align:center;padding:2px 0;font-size:11px}.slipNo{padding:4px 2px;border-bottom:1px solid currentColor;color:currentColor}
.slipParties{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:4px 0}.slipParty{display:grid;grid-template-columns:26px 1fr;border:1px solid currentColor}.slipSideTitle{writing-mode:vertical-rl;text-align:center;border-right:1px solid currentColor;font-weight:800;letter-spacing:4px;display:flex;align-items:center;justify-content:center}.slipParty table,.slipItems,.slipSummary{width:100%;border-collapse:collapse;color:inherit}.slipParty th,.slipParty td,.slipItems th,.slipItems td,.slipSummary th,.slipSummary td{border:1px solid currentColor;padding:4px 5px;height:26px}.slipParty th{width:80px;text-align:center;font-weight:700}.slipItems th{text-align:center}.slipItems td{height:28px}.slipSummary{margin-top:4px}.slipSummary th{width:90px;text-align:center}.docPreview{overflow:auto}.docPreview .slipDoc table th{background:transparent;color:inherit}.docPreview .slipDoc .num{text-align:right}.modal .actions .danger{border-color:#fecaca;background:#fff7f7}.modal .actions .danger:hover{background:#fee2e2}
@media(max-width:900px){.slipTop{grid-template-columns:1fr}.slipBoxes{display:none}.slipParties{grid-template-columns:1fr}.slipTop h1{letter-spacing:6px;font-size:24px}}

/* v5.33 거래명세표 2부 출력: 공급받는자 보관용 + 공급자 보관용 */
.statementPair{display:flex;flex-direction:column;gap:10px;align-items:center;background:#fff}
.statementPair .slipDoc{margin:0 auto}
.statementPair .supplierCopy{border-color:#dc2626;color:#dc2626}
.statementPair .buyerCopy{border-color:#1d4ed8;color:#1d4ed8}
.slipDivider{width:760px;max-width:100%;border-top:1px dashed #9ca3af;margin:2px auto}

/* v5.33 발주서 전용 양식 + 관리대장 */
.purchaseOrderForm{width:720px;max-width:100%;margin:0 auto;background:#fff;color:#111;font-family:"Noto Sans KR",Arial,sans-serif;font-size:13px;line-height:1.35;padding:8px 14px}
.purchaseOrderForm h1{text-align:center;font-size:30px;letter-spacing:16px;margin:0 0 22px;color:#111}
.poIntro{display:grid;grid-template-columns:1.25fr 1fr;gap:30px;margin-bottom:16px;font-weight:700}.poIntroLeft{padding-left:28px}.poIntroRight{font-size:12px;line-height:1.55}
.poMeta,.poItems,.poNote{width:100%;border-collapse:collapse;color:#111}.poMeta th,.poMeta td,.poItems th,.poItems td,.poNote th,.poNote td{border:2px solid #111;padding:6px 8px;height:28px}.poMeta th{width:110px;text-align:center;background:#f8fafc}.poItems{margin-top:14px}.poItems th{text-align:center;background:#d9d9d9;font-weight:800}.poItems th:nth-child(1){width:48px}.poItems th:nth-child(2){width:180px}.poItems th:nth-child(3){width:160px}.poItems th:nth-child(4){width:80px}.poItems td{border-width:1px;border-style:dotted;border-color:#444;height:25px}.poItems thead th{border:2px solid #111}.poItems td:nth-child(1),.poItems td:nth-child(4){text-align:center}.poNote th{width:42px;writing-mode:vertical-rl;text-align:center;letter-spacing:4px}.poNote td{height:72px}.poLedgerCards{grid-template-columns:repeat(4,minmax(120px,1fr));margin-bottom:14px}.poLedgerCards .card b{font-size:22px;display:block}.poLedgerCards .card span{color:#64748b;font-size:13px}
@media(max-width:900px){.poIntro{grid-template-columns:1fr;gap:8px}.purchaseOrderForm h1{letter-spacing:8px;font-size:24px}.poLedgerCards{grid-template-columns:repeat(2,1fr)}}

/* v5.34-R2: 매출·매입 조회 화면 전용 보강 */
.txLookupCard{border-radius:20px;box-shadow:0 14px 34px rgba(15,23,42,.06)}
.txLookupCard .cardHead{padding-bottom:10px;border-bottom:1px solid #eef2f7}
.txSearchBar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:16px 0 14px}
.txSearchBar select{width:92px;min-width:92px;border-radius:12px;background:#fff}
.txSearchBar input{width:min(420px,100%);border-radius:12px}
.txSearchBar button{border-radius:12px}
.txTable{border:1px solid #e5e7eb;border-radius:16px;background:#fff}
.txTable table{font-size:13.5px}
.txTable th{background:#f8fafc;color:#334155;font-weight:800;padding:12px 10px;white-space:nowrap}
.txTable td{padding:12px 10px;vertical-align:middle;white-space:nowrap}
.txTable tbody tr:hover td{background:#f8fbff}
.txTable .strongNum{font-weight:800;color:#0f172a}
.txTable .handledNum{color:#2563eb;font-weight:700}
.txTable .doneNum{color:#059669;font-weight:900}
.txTable .dueNum{color:#dc2626;font-weight:900}
.badge.txStatus{font-weight:800;min-width:66px;text-align:center}
.badge.txStatus.정산완료{background:#dcfce7;color:#047857}
.badge.txStatus.잔금{background:#fee2e2;color:#b91c1c}
.badge.txStatus.초과정산{background:#fef3c7;color:#92400e}
.pager{display:flex;gap:6px;justify-content:flex-end;margin-top:14px}.pager button.on{background:#2563eb;color:#fff;border-color:#2563eb}
@media(max-width:900px){.txSearchBar{align-items:stretch}.txSearchBar select,.txSearchBar input,.txSearchBar button{width:100%;min-width:0}.txTable td,.txTable th{white-space:nowrap}}


/* v5.34-R3: 사용자 화면 구조 정리 - 거래 원장 / 미수·미지급 / 납품건 정산 */
.txSearchBar select#txPartnerFilterSelect{width:140px;min-width:140px}
.badge.txType{display:inline-flex;margin-top:4px;font-size:11px;border-radius:999px;padding:3px 8px;font-weight:800}
.badge.txType.매출,.badge.매출{background:#dbeafe;color:#1d4ed8}
.badge.txType.매입,.badge.매입{background:#ffedd5;color:#c2410c}
.balanceManageCard{border-radius:20px;box-shadow:0 14px 34px rgba(15,23,42,.06)}
.balanceSummaryGrid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin:16px 0 16px}
.balanceCard{border:1px solid #e2e8f0;border-radius:16px;background:#fff;padding:14px;min-height:92px}
.balanceCard span{display:block;color:#64748b;font-size:13px;font-weight:800;margin-bottom:8px}
.balanceCard b{display:block;font-size:18px;color:#0f172a;line-height:1.2}
.balanceCard small{display:block;color:#94a3b8;margin-top:8px;font-size:12px}
.balanceCard.receive{background:#f0fdf4;border-color:#bbf7d0}.balanceCard.receive b{color:#047857}
.balanceCard.pay{background:#fff7ed;border-color:#fed7aa}.balanceCard.pay b{color:#c2410c}
.balanceCard.month{background:#eff6ff;border-color:#bfdbfe}.balanceCard.month b{color:#1d4ed8}
.balanceCard.overdue{background:#fef2f2;border-color:#fecaca}.balanceCard.overdue b{color:#dc2626}
.balanceTable{border:1px solid #e5e7eb;border-radius:16px;background:#fff}
.balanceTable th{background:#f8fafc;color:#334155;font-weight:800;padding:12px 10px;white-space:nowrap}
.balanceTable td{padding:12px 10px;vertical-align:middle;white-space:nowrap}
.balanceTable tbody tr:hover td{background:#f8fbff}
.balanceStatus.잔금{background:#fee2e2;color:#b91c1c}.balanceStatus.지연{background:#fee2e2;color:#991b1b}.balanceStatus.정산완료{background:#dcfce7;color:#047857}
.overdueText{color:#dc2626;font-weight:900}
.badge.지연{background:#fee2e2;color:#991b1b}.badge.양쪽잔금{background:#fef3c7;color:#92400e}.badge.매출잔금{background:#fee2e2;color:#b91c1c}.badge.매입잔금{background:#ffedd5;color:#c2410c}
.settlementTop .dueNum,.settlementTop .doneNum{font-weight:900}
@media(max-width:1200px){.balanceSummaryGrid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:700px){.balanceSummaryGrid{grid-template-columns:1fr}.txSearchBar select#txPartnerFilterSelect{width:100%;min-width:0}}


/* v5.34-R4: 데모 화면과 실제 화면 시각 구조 일치 보정 */
.demoParity{border-radius:18px;box-shadow:0 6px 18px rgba(15,23,42,.04)}
.demoParity .cardHead{border-bottom:0;padding-bottom:0;margin-bottom:14px}.demoParity .cardHead h2{font-size:22px;letter-spacing:-.02em}.centerCol{text-align:center}.note.settlementNote{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:14px;padding:12px 14px;font-size:13px;margin-bottom:14px}.balanceSummaryGrid.demoLike{gap:12px}.balanceControlBar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:0 0 14px}.balanceFilterGroup{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.balanceFilterBtn{border:1px solid #e2e8f0;background:#fff;color:#334155;border-radius:12px;padding:10px 13px;font-weight:800}.balanceFilterBtn.on{background:#111827;color:#fff;border-color:#111827}.balanceFilterBtn b{font-weight:900;margin-left:3px}.balanceControlBar input{width:min(360px,100%);border-radius:12px}.balanceControlBar button{border-radius:12px}.settlementCard .tableWrap{border:1px solid #e5e7eb;border-radius:16px;background:#fff}.settlementDemoTable th{background:#f8fafc;color:#334155;font-weight:900;white-space:nowrap}.settlementDemoTable td{vertical-align:middle;white-space:nowrap}.settlementTop.demoTop td{background:#eff6ff;border-top:1px solid #bfdbfe;border-bottom:1px solid #dbeafe;font-weight:500}.settlementTop.demoTop:hover td{background:#dbeafe}.profitNum{font-weight:900;color:#2563eb}.demoChild{background:#f8fbff;border:1px solid #dbeafe;border-radius:16px;padding:14px;margin:0;box-shadow:none}.demoChild .nested table{border-radius:12px}.demoChild h4{margin:0 0 12px}.badge.txStatus.양쪽잔금,.badge.txStatus.매출잔금,.badge.txStatus.매입잔금,.badge.txStatus.잔금{background:#fee2e2;color:#b91c1c}.badge.txStatus.정산완료{background:#dcfce7;color:#047857}.badge.txStatus.초과정산{background:#fef3c7;color:#92400e}@media(max-width:900px){.balanceControlBar input,.balanceControlBar button{width:100%}.balanceFilterGroup{width:100%}.balanceFilterBtn{flex:1 1 auto}}


/* v5.35 거래처 마스터 확장 */
.partnerMasterCard .partnerSearchBar{display:flex;gap:10px;align-items:center;margin:14px 0;flex-wrap:wrap}
.partnerMasterCard .partnerSearchBar select{min-width:140px}
.partnerMasterCard .partnerSearchBar input{flex:1;min-width:260px}
.partnerMasterTable table th,.partnerMasterTable table td{white-space:nowrap}
.badge.partnerRole.매출처{background:#dcfce7;color:#166534;border:1px solid #86efac}
.badge.partnerRole.매입처{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.badge.partnerRole.공통{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}
