/* (removed stray h1 Arial default — was overriding Noto Sans theme) */

/* ════════════════════════════════════════
   정산관리 모듈 CSS (stl- prefix)
   ════════════════════════════════════════ */

/* toast */
#stl-toast-area{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.stl-toast{background:var(--gray-800,#1F2937);color:#fff;padding:10px 16px;border-radius:var(--radius,10px);font-size:12.5px;font-weight:500;box-shadow:0 10px 15px -3px rgba(0,0,0,.08);max-width:340px;animation:stlSlide .3s ease;pointer-events:auto}
.stl-toast.success{background:var(--success,#10B981)}
.stl-toast.error{background:var(--danger,#EF4444)}
.stl-toast.warn{background:var(--warning,#F59E0B);color:#111827}
@keyframes stlFi{from{opacity:0}to{opacity:1}}
@keyframes stlSi{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes stlSlide{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes stlUp{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
@keyframes stlPulse{0%,100%{opacity:1}50%{opacity:.5}}

/* layout */
#stl-wrap{display:flex;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}

/* topbar */
.stl-top{height:48px;background:var(--card,#fff);border-bottom:1px solid var(--border,#E2E8F0);
  display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;z-index:50}
.stl-bc{display:none;align-items:center;gap:6px;font-size:12.5px;color:var(--text-muted,#94A3B8);margin-left:14px}
.stl-bc a{color:var(--primary,#4F46E5);font-weight:600;cursor:pointer}
.stl-bc-nm{color:var(--text,#0F172A);font-weight:700;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stl-top-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.stl-sbadge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;
  padding:4px 10px;border-radius:20px;border:1px solid transparent;transition:all .2s cubic-bezier(.4,0,.2,1)}
.stl-sbadge.ok{background:#D1FAE5;border-color:#6EE7B7;color:#10B981}
.stl-sbadge.saving{background:#DBEAFE;border-color:#93C5FD;color:#3B82F6;animation:stlPulse 1s infinite}
.stl-sbadge.err{background:#FEE2E2;border-color:#FCA5A5;color:#EF4444}
.stl-sbadge.idle{background:var(--gray-100,#F3F4F6);border-color:var(--border,#E2E8F0);color:var(--text-muted,#94A3B8)}

/* list */
#stl-list{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.stl-toolbar{padding:12px 20px;background:var(--card,#fff);border-bottom:1px solid var(--border,#E2E8F0);
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;position:relative}
.stl-ym{display:flex;align-items:center;gap:4px}
.stl-ymb{width:28px;height:28px;border:1px solid var(--border,#E2E8F0);background:var(--card,#fff);
  border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted,#94A3B8);font-size:13px;transition:all .2s;font-family:inherit}
.stl-ymb:hover,.stl-ymb.on{background:var(--primary,#4F46E5);border-color:var(--primary,#4F46E5);color:#fff}
.stl-yml{font-size:13px;font-weight:700;font-family:var(--font-mono,'JetBrains Mono',monospace);
  padding:4px 10px;color:var(--text,#0F172A);background:none;border:1px solid var(--border,#E2E8F0);
  border-radius:6px;cursor:pointer;transition:all .2s;line-height:1.5}
.stl-yml:hover,.stl-yml.open{background:#EEF2FF;border-color:var(--primary,#4F46E5);color:var(--primary,#4F46E5)}
.stl-ymp{position:fixed;background:var(--card,#fff);
  border:1px solid var(--border,#E2E8F0);border-radius:14px;box-shadow:0 10px 15px -3px rgba(0,0,0,.08);
  z-index:600;padding:14px;min-width:200px;animation:stlSi .15s ease;display:none}
.stl-ymp.open{display:block}
.stl-ymp-yr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.stl-ymp-yrn{font-size:14px;font-weight:700;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-ymp-yb{width:26px;height:26px;border:1px solid var(--border,#E2E8F0);background:var(--card,#fff);
  border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted,#94A3B8);font-size:13px;transition:all .2s;font-family:inherit}
.stl-ymp-yb:hover{background:var(--primary,#4F46E5);border-color:var(--primary,#4F46E5);color:#fff}
.stl-ymp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.stl-ymp-m{padding:7px 4px;text-align:center;border-radius:6px;cursor:pointer;
  font-size:12.5px;font-weight:600;color:var(--text-secondary,#475569);transition:all .2s;border:1.5px solid transparent}
.stl-ymp-m:hover{background:#EEF2FF;color:var(--primary,#4F46E5)}
.stl-ymp-m.cur{background:var(--primary,#4F46E5);color:#fff;border-color:var(--primary,#4F46E5)}

/* date range picker */
.stl-drp{position:relative}
.stl-drp-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 11px;
  border:1px solid var(--border,#E2E8F0);border-radius:10px;font-size:13px;
  color:var(--text,#0F172A);background:var(--card,#fff);cursor:pointer;transition:all .2s;
  font-family:inherit;text-align:left}
.stl-drp-btn:hover,.stl-drp-btn.open{border-color:var(--primary,#4F46E5);box-shadow:0 0 0 3px #EEF2FF}
.stl-drp-lbl{flex:1;font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:12.5px}
.stl-drp-lbl.placeholder{color:var(--text-muted,#94A3B8);font-family:inherit;font-size:13px}
.stl-drp-pop{position:fixed;background:var(--card,#fff);
  border:1px solid var(--border,#E2E8F0);border-radius:14px;box-shadow:0 10px 15px -3px rgba(0,0,0,.08);
  z-index:600;padding:16px;animation:stlSi .15s ease;display:none;min-width:264px;max-width:calc(100vw - 32px)}
.stl-drp-pop.open{display:block}
.stl-drp-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.stl-drp-title{font-size:13.5px;font-weight:700;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-drp-nb{width:26px;height:26px;border:1px solid var(--border,#E2E8F0);background:var(--card,#fff);
  border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted,#94A3B8);font-size:13px;transition:all .2s;font-family:inherit}
.stl-drp-nb:hover{background:var(--primary,#4F46E5);border-color:var(--primary,#4F46E5);color:#fff}
.stl-drp-wd{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.stl-drp-wdn{text-align:center;font-size:10.5px;font-weight:700;color:var(--text-muted,#94A3B8);padding:3px 0}
.stl-drp-wdn:first-child{color:#EF4444}.stl-drp-wdn:last-child{color:#3B82F6}
.stl-drp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.stl-drp-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background .1s,color .1s}
.stl-drp-day:hover:not(.empty):not(.disabled){background:#EEF2FF;color:var(--primary,#4F46E5)}
.stl-drp-day.empty,.stl-drp-day.disabled{pointer-events:none;color:transparent}
.stl-drp-day.start,.stl-drp-day.end{background:var(--primary,#4F46E5)!important;color:#fff!important;font-weight:700}
.stl-drp-day.inrange{background:#EEF2FF;color:var(--primary,#4F46E5)}
.stl-drp-day.sun{color:#EF4444}.stl-drp-day.sat{color:#3B82F6}
.stl-drp-day.start.sun,.stl-drp-day.end.sun,.stl-drp-day.start.sat,.stl-drp-day.end.sat{color:#fff}
.stl-drp-status{margin-top:10px;padding-top:10px;border-top:1px solid #F1F5F9;
  display:flex;gap:8px;align-items:center;font-size:11.5px;color:var(--text-muted,#94A3B8)}
.stl-drp-st{flex:1;background:#F9FAFB;border-radius:6px;padding:5px 8px;text-align:center}
.stl-drp-st strong{display:block;font-size:12px;font-family:var(--font-mono,'JetBrains Mono',monospace);color:var(--text,#0F172A);font-weight:700}
.stl-drp-st span{font-size:10.5px;color:var(--text-muted,#94A3B8)}
.stl-drp-reset{padding:4px 10px;font-size:11px;border:1px solid var(--border,#E2E8F0);
  border-radius:6px;background:none;cursor:pointer;color:var(--text-muted,#94A3B8);transition:all .2s;font-family:inherit}
.stl-drp-reset:hover{border-color:#EF4444;color:#EF4444}

.stl-srch{position:relative;flex:1;min-width:180px;max-width:280px}
.stl-srch input{padding-left:32px}
.stl-srch svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#9CA3AF;pointer-events:none}
.stl-stats{display:flex;gap:14px;margin-left:auto}
.stl-stat{font-size:12px;color:var(--text-muted,#94A3B8)}
.stl-stat strong{color:var(--text,#0F172A);font-weight:700}
.stl-list-body{flex:1;overflow-y:auto;padding:20px;min-height:0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;align-content:start}
.stl-list-body::-webkit-scrollbar{width:5px}
.stl-list-body::-webkit-scrollbar-thumb{background:#E5E7EB;border-radius:3px}

/* project card */
.stl-pcard{background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);border-radius:14px;
  padding:16px;cursor:pointer;transition:all .2s}
.stl-pcard:hover{border-color:var(--primary,#4F46E5);box-shadow:0 4px 6px -1px rgba(0,0,0,.07);transform:translateY(-1px)}
.stl-pcard-nm{font-size:14px;font-weight:700;margin-bottom:6px;line-height:1.4;
  display:flex;align-items:flex-start;gap:8px;justify-content:space-between}
.stl-pcard-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11.5px;color:var(--text-muted,#94A3B8);margin-bottom:10px}
.stl-pcard-row{display:flex;gap:10px;padding-top:10px;border-top:1px solid #F1F5F9}
.stl-pcard-amt{flex:1}
.stl-pcard-albl{font-size:10.5px;color:var(--text-muted,#94A3B8);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.stl-pcard-aval{font-size:13px;font-weight:700;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-pcard-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:10px}
.stl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;color:var(--text-muted,#94A3B8);gap:12px;text-align:center;grid-column:1/-1}

/* editor */
#stl-editor{flex:1;overflow:hidden;display:none;flex-direction:column;min-height:0}
.stl-shell{flex:1;overflow:hidden;display:flex;min-height:0}

/* sidebar */
.stl-sidebar{width:194px;min-width:194px;background:var(--card,#fff);border-right:1px solid var(--border,#E2E8F0);
  display:flex;flex-direction:column;overflow:hidden}
.stl-sb-nav{flex:1;overflow-y:auto;padding:10px 8px;min-height:0}
.stl-sb-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;
  border-radius:6px;transition:all .2s;color:var(--text-secondary,#475569);
  font-size:12.5px;font-weight:500;margin-bottom:2px}
.stl-sb-item:hover{background:#F3F4F6;color:var(--text,#0F172A)}
.stl-sb-item.on{background:#EEF2FF;color:var(--primary,#4F46E5)}
.stl-sb-cnt{background:#E5E7EB;color:#4B5563;font-size:10px;font-weight:700;
  border-radius:10px;padding:1px 6px;margin-left:auto;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-sb-item.on .stl-sb-cnt{background:var(--primary,#4F46E5);color:#fff}
.stl-sb-sep{height:1px;background:var(--border,#E2E8F0);margin:6px 0}
.stl-sb-totals{padding:12px 10px;border-top:1px solid var(--border,#E2E8F0)}
.stl-sb-trow{display:flex;justify-content:space-between;padding:3px 0;font-size:11.5px}
.stl-sb-tlbl{color:var(--text-muted,#94A3B8)}
.stl-sb-tval{font-weight:700;font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:12px}

/* content */
.stl-content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg,#F8FAFC);padding:20px;min-height:0}
.stl-content::-webkit-scrollbar{width:5px}
.stl-content::-webkit-scrollbar-thumb{background:#E5E7EB;border-radius:3px}
.stl-view{display:none;animation:stlUp .2s ease}
.stl-view.on{display:block;min-height:10px}

/* dashboard */
.stl-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stl-agg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.stl-agg-card{background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);border-radius:14px;padding:14px 16px}
.stl-agg-ttl{font-size:11px;font-weight:700;color:var(--text-muted,#94A3B8);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.stl-agg-sum{font-size:15px;font-weight:800;font-family:var(--font-mono,'JetBrains Mono',monospace);margin-bottom:7px}
.stl-agg-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:11.5px}
.stl-agg-key{min-width:72px;color:var(--text-secondary,#475569);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stl-agg-bwrap{flex:1}
.stl-agg-bg{height:4px;background:#F3F4F6;border-radius:2px}
.stl-agg-fill{height:4px;border-radius:2px;transition:width .4s}
.stl-agg-val{font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:11px;min-width:64px;text-align:right}
.stl-sum-bar{background:linear-gradient(135deg,#111827 0%,#1E293B 100%);border-radius:14px;overflow:hidden;margin-top:14px}
.stl-sum-row{display:flex;align-items:center;padding:10px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.stl-sum-row:last-child{border-bottom:none}
.stl-sum-lbl{color:rgba(255,255,255,.5);font-size:12.5px;flex:1}
.stl-sum-val{color:#fff;font-size:13px;font-weight:600;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-sum-row.total .stl-sum-lbl{color:#fff;font-weight:700}
.stl-sum-row.total .stl-sum-val{font-size:16px;font-weight:800}

/* form */
.stl-fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stl-full{grid-column:1/-1}
.stl-fg{display:flex;flex-direction:column;gap:4px}
.stl-ca-bar{display:flex;gap:16px;align-items:center;background:#F9FAFB;
  border:1px solid var(--border,#E2E8F0);border-radius:14px;padding:16px 20px;flex-wrap:wrap}
.stl-ca-item{display:flex;flex-direction:column;gap:3px;flex:1;min-width:120px}
.stl-ca-lbl{font-size:10.5px;font-weight:600;color:var(--text-muted,#94A3B8);text-transform:uppercase;letter-spacing:.04em}
.stl-ca-val{font-size:16px;font-weight:800;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-ca-sep{width:1px;height:36px;background:var(--border,#E2E8F0);flex-shrink:0}

/* tab header */
.stl-th{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.stl-th-title{font-size:15px;font-weight:700;flex:1}
.stl-th-badge{background:#EEF2FF;color:var(--primary,#4F46E5);font-size:12px;
  font-weight:700;padding:3px 10px;border-radius:20px;font-family:var(--font-mono,'JetBrains Mono',monospace)}
.stl-fbar{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.stl-hint{font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;
  background:#FEF3C7;border:1px solid #FDE68A;color:#374151}
.stl-add-row{display:flex;align-items:center;justify-content:center;gap:6px;
  padding:9px 14px;color:var(--text-muted,#94A3B8);font-size:12.5px;cursor:pointer;
  border:1.5px dashed var(--border,#E2E8F0);background:transparent;width:100%;
  border-radius:0 0 14px 14px;transition:all .2s;font-family:inherit;margin-top:-1px}
.stl-add-row:hover{color:var(--primary,#4F46E5);background:#EEF2FF;border-color:var(--primary,#4F46E5)}
.stl-del{width:24px;height:24px;border:none;background:none;cursor:pointer;border-radius:4px;
  color:#9CA3AF;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:14px;font-family:inherit}
.stl-del:hover{background:#FEE2E2;color:#EF4444}

/* quick status dropdown */
.stl-qs-wrap{position:relative;display:inline-block}
.stl-qs-pop{position:absolute;bottom:calc(100% + 4px);right:0;background:var(--card,#fff);
  border:1px solid var(--border,#E2E8F0);border-radius:14px;box-shadow:0 10px 15px -3px rgba(0,0,0,.08);
  z-index:400;padding:5px;min-width:130px;animation:stlSi .15s ease;display:none}
.stl-qs-pop.open{display:block}
.stl-qs-opt{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;
  cursor:pointer;font-size:12.5px;font-weight:600;transition:all .2s;white-space:nowrap}
.stl-qs-opt:hover{background:#F3F4F6}
.stl-qs-opt.cur{background:#EEF2FF;color:var(--primary,#4F46E5)}
.stl-qs-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* status chip */
.stl-sts-chip{display:none;align-items:center;gap:6px;padding:5px 12px;
  border-radius:20px;border:1.5px solid transparent;cursor:pointer;
  font-size:12px;font-weight:700;transition:all .2s;white-space:nowrap;font-family:inherit;background:none}
.stl-sts-chip.visible{display:inline-flex}
.stl-sts-chip:hover{opacity:.8}
.stl-sts-chip[data-s="estimate"]{background:#DBEAFE;border-color:#3B82F6;color:#3B82F6}
.stl-sts-chip[data-s="contracted"]{background:#FEF3C7;border-color:#F59E0B;color:#F59E0B}
.stl-sts-chip[data-s="ongoing"]{background:#D1FAE5;border-color:#10B981;color:#10B981}
.stl-sts-chip[data-s="settled"]{background:#EDE9FE;border-color:#8B5CF6;color:#8B5CF6}
.stl-sts-chip[data-s="completed"]{background:#F3F4F6;border-color:#9CA3AF;color:#4B5563}
.stl-sts-pop{position:absolute;background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);
  border-radius:14px;box-shadow:0 10px 15px -3px rgba(0,0,0,.08);z-index:300;
  padding:6px;min-width:140px;display:none;animation:stlSi .15s ease}
.stl-sts-pop.open{display:block}
.stl-sts-opt{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;
  cursor:pointer;font-size:12.5px;font-weight:600;transition:all .2s}
.stl-sts-opt:hover{background:#F3F4F6}
.stl-sts-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* FAB (mobile) */
.stl-fab-wrap{display:none;position:fixed;bottom:20px;right:16px;z-index:500;align-items:flex-end;flex-direction:column;gap:8px}
.stl-fab-wrap.visible{display:flex}
.stl-fab{width:50px;height:50px;background:var(--primary,#4F46E5);border-radius:50%;border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(79,70,229,.4);transition:all .2s;color:#fff;font-size:20px;flex-shrink:0}
.stl-fab:hover{background:#3730A3;transform:scale(1.05)}
.stl-fab.open{transform:rotate(45deg)}
.stl-fab-menu{display:flex;flex-direction:column;gap:6px;transition:all .2s;
  align-items:flex-end;pointer-events:none;opacity:0;transform:translateY(8px)}
.stl-fab-menu.open{pointer-events:auto;opacity:1;transform:translateY(0)}
.stl-fab-item{display:flex;align-items:center;gap:8px;cursor:pointer;pointer-events:auto}
.stl-fab-lbl{background:#111827;color:#fff;font-size:12px;font-weight:600;
  padding:5px 10px;border-radius:20px;white-space:nowrap;box-shadow:0 4px 6px -1px rgba(0,0,0,.07)}
.stl-fab-icon{width:38px;height:38px;background:var(--card,#fff);border:1.5px solid var(--border,#E2E8F0);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:16px;box-shadow:0 4px 6px -1px rgba(0,0,0,.07);flex-shrink:0;transition:all .2s}
.stl-fab-item:hover .stl-fab-icon{border-color:var(--primary,#4F46E5);background:#EEF2FF}
.stl-fab-item.on .stl-fab-icon{background:var(--primary,#4F46E5);border-color:var(--primary,#4F46E5)}
.stl-fab-item.on .stl-fab-lbl{background:var(--primary,#4F46E5)}
.stl-fab-overlay{position:fixed;inset:0;z-index:499;display:none;background:rgba(0,0,0,.15)}
.stl-fab-overlay.open{display:block}

/* KPI cards for settlement */
.kpi-card{background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);border-radius:14px;padding:16px 18px;position:relative;overflow:hidden;transition:all .2s}
.kpi-card:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.07);transform:translateY(-1px)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.kpi-card.kpi-primary::before{background:var(--primary,#4F46E5)}
.kpi-card.kpi-success::before{background:#10B981}
.kpi-card.kpi-danger::before{background:#EF4444}
.kpi-card.kpi-warning::before{background:#F59E0B}
.kpi-card.kpi-info::before{background:#3B82F6}
.kpi-lbl{font-size:11.5px;color:var(--text-muted,#94A3B8);font-weight:600;margin-bottom:6px}
.kpi-val{font-size:20px;font-weight:800;letter-spacing:-.02em;line-height:1.2;font-variant-numeric:tabular-nums}
.kpi-sub{font-size:11.5px;color:var(--text-muted,#94A3B8);margin-top:5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.kpi-chip{font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px}
.kpi-chip.up{background:#D1FAE5;color:#10B981}
.kpi-chip.dn{background:#FEE2E2;color:#EF4444}
.prog{height:5px;background:#F3F4F6;border-radius:3px;overflow:hidden;width:100%;margin-top:5px}
.prog-bar{height:100%;border-radius:3px;transition:width .5s ease}

/* settlement modal */
.stl-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:16px}
.stl-modal-bg.open{display:flex;animation:stlFi .15s ease}
.stl-modal{background:var(--card,#fff);border-radius:20px;width:min(540px,100%);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 25px -5px rgba(0,0,0,.08);animation:stlSi .2s ease}
.stl-modal-hdr{padding:16px 20px;border-bottom:1px solid var(--border,#E2E8F0);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.stl-modal-title{font-size:15px;font-weight:700}
.stl-modal-x{width:28px;height:28px;border:none;background:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted,#94A3B8)}
.stl-modal-x:hover{background:#F3F4F6;color:var(--text,#0F172A)}
.stl-modal-body{padding:20px;overflow-y:auto;flex:1}
.stl-modal-foot{padding:12px 20px;border-top:1px solid var(--border,#E2E8F0);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}

/* settlement table overrides */
#stl-wrap .tbl-wrap{overflow-x:auto;border:1px solid var(--border,#E2E8F0);border-radius:14px;background:var(--card,#fff)}
#stl-wrap .tbl{width:100%;border-collapse:collapse;font-size:12.5px;min-width:500px}
#stl-wrap .tbl th{background:#F9FAFB;color:var(--text-muted,#94A3B8);font-weight:600;font-size:11px;padding:8px 10px;border-bottom:1px solid var(--border,#E2E8F0);text-align:left;white-space:nowrap;letter-spacing:.03em}
#stl-wrap .tbl th.r,#stl-wrap .tbl td.r{text-align:right}
#stl-wrap .tbl th.c,#stl-wrap .tbl td.c{text-align:center}
#stl-wrap .tbl td{padding:7px 10px;border-bottom:1px solid #F1F5F9;color:var(--text,#0F172A);vertical-align:middle}
#stl-wrap .tbl td.num{text-align:right;font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:12px}
#stl-wrap .tbl tr:hover td{background:#F9FAFB}
#stl-wrap .tbl tr:last-child td{border-bottom:none}
#stl-wrap .tbl tfoot td{background:#F9FAFB;font-weight:700;border-top:2px solid var(--border,#E2E8F0);border-bottom:none;padding:8px 10px;font-size:12.5px}
#stl-wrap .tbl .inp-sm{border-color:transparent;background:transparent;min-width:50px}
#stl-wrap .tbl .inp-sm:focus{border-color:var(--primary,#4F46E5);background:var(--card,#fff);box-shadow:0 0 0 2px #EEF2FF}
#stl-wrap .tbl .vat-inp{text-align:right;font-family:var(--font-mono,'JetBrains Mono',monospace);border-color:rgba(245,158,11,.3);background:rgba(254,243,199,.2)}
#stl-wrap .tbl .vat-inp:focus{border-color:#F59E0B;background:#FEF3C7}
#stl-wrap .inp{width:100%;padding:8px 11px;border:1px solid var(--border,#E2E8F0);border-radius:10px;font-size:13px;color:var(--text,#0F172A);background:var(--card,#fff);transition:all .2s;font-family:inherit}
#stl-wrap .inp:focus{outline:none;border-color:var(--primary,#4F46E5);box-shadow:0 0 0 3px #EEF2FF}
#stl-wrap .inp-sm{padding:4px 7px;font-size:12px;border-radius:6px}
#stl-wrap .inp-r{text-align:right;font-family:var(--font-mono,'JetBrains Mono',monospace)}
#stl-wrap .sel{padding:7px 10px;border:1px solid var(--border,#E2E8F0);border-radius:10px;font-size:13px;color:var(--text,#0F172A);background:var(--card,#fff);cursor:pointer;font-family:inherit;transition:all .2s}
#stl-wrap .sel:focus{outline:none;border-color:var(--primary,#4F46E5);box-shadow:0 0 0 3px #EEF2FF}
#stl-wrap .lbl{display:block;font-size:11.5px;font-weight:600;color:var(--text-secondary,#475569);margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}
#stl-wrap .card{background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);border-radius:14px;padding:20px}
#stl-wrap .card+.card{margin-top:12px}
#stl-wrap .badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}
#stl-wrap .badge-blue{background:#DBEAFE;color:#3B82F6}
#stl-wrap .badge-green{background:#D1FAE5;color:#10B981}
#stl-wrap .badge-orange{background:#FEF3C7;color:#F59E0B}
#stl-wrap .badge-purple{background:#EDE9FE;color:#8B5CF6}
#stl-wrap .badge-gray{background:#F3F4F6;color:#6B7280}
#stl-wrap .btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:inherit;line-height:1.4}
#stl-wrap .btn-sm{padding:5px 12px;font-size:12px;border-radius:6px}
#stl-wrap .btn-xs{padding:3px 8px;font-size:11px;border-radius:4px}
#stl-wrap .btn-primary{background:var(--primary,#4F46E5);color:#fff}
#stl-wrap .btn-primary:hover{background:#3730A3}
#stl-wrap .btn-outline{background:var(--card,#fff);border:1px solid var(--border,#E2E8F0);color:var(--text-secondary,#475569)}
#stl-wrap .btn-outline:hover{border-color:#9CA3AF;background:#F9FAFB}
#stl-wrap .btn-ghost{background:transparent;color:var(--text-secondary,#475569)}
#stl-wrap .btn-ghost:hover{background:#F3F4F6}

/* responsive */
@media(max-width:900px){
  .stl-kpi-grid{grid-template-columns:1fr 1fr}
  .stl-sidebar{display:none}
  .stl-fab-wrap{display:flex}
  .stl-content{padding:14px}
  .stl-stats{display:none}
}
@media(max-width:600px){
  .stl-list-body{grid-template-columns:1fr;padding:12px}
  .stl-kpi-grid{grid-template-columns:1fr 1fr}
  .stl-fgrid{grid-template-columns:1fr}
  .stl-full{grid-column:auto}
  .stl-ca-bar{flex-direction:column;gap:10px}
  .stl-ca-sep{display:none}
}
@media(max-width:440px){
  .stl-kpi-grid{grid-template-columns:1fr}
  .stl-agg-grid{grid-template-columns:1fr}
}
@media print{
  .stl-top,.stl-toolbar,.stl-sidebar,.stl-mobbar,.stl-fbar,
  .stl-add-row,.stl-del,.btn,#stl-toast-area,.stl-modal-bg{display:none!important}
  #stl-wrap{height:auto!important;overflow:visible!important}
  .stl-content{padding:0!important;overflow:visible!important}
  .stl-view.on{display:block!important}
  .tbl-wrap{overflow:visible!important}
}
