/* ============================================================================
   ICS — Internal Collection System · UI Theme v3.0
   KAI Platform Design System (DealView/ONVALUE 룩앤필) 이식판.
   ─ White 중심 · Navy 포인트 · Blue 강조 · Modern Enterprise Admin ─

   ※ 본 파일은 "표현(UI)"만 담당한다.
     API / AJAX / 세션 / 권한 / 비즈니스 로직 / JS 기능과 무관하며,
     기존 ICS 클래스명을 100% 그대로 유지한 채 룩앤필만 교체한다.
   ※ JS 모듈이 인라인으로 참조하는 토큰
     (--primary --primary-d --primary-bg --pos --pos-bg --neg --neg-bg
      --sales --sales-bg --cost --cost-bg --cardc --cardc-bg --cash --cash-bg
      --sub --border-soft …)은 그대로 보존하여 색만 새 팔레트로 정렬한다.
   ============================================================================ */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css');

/* ───────────────────────── Design tokens ───────────────────────── */
:root{
  /* KAI 공용 토큰(샘플 kai-design.css 동일) */
  --bg:#F7F9FC; --card:#FFFFFF; --ink:#0F172A; --ink2:#1E293B;
  --point:#2563EB; --point-d:#1D4ED8; --point-soft:#EFF4FF;
  --ai:#0EA5E9; --ai-soft:#E0F2FE;
  --navy:#0F172A; --navy2:#0E2A47; --navy3:#16365C;
  --line:#E2E8F0; --line-soft:#EEF2F7; --surface:#F1F5F9; --surface2:#E8EEF6;
  --ok:#059669; --ok-soft:#ECFDF5; --warn:#D97706; --warn-soft:#FEF3E7;
  --red:#DC2626; --red-soft:#FEF2F2; --purple:#7C3AED;
  --r:14px; --r-pill:999px; --top-h:60px; --side-w:248px; --side-w-min:68px;
  --font:'Pretendard','Noto Sans KR',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Segoe UI',sans-serif;

  /* ── ICS 레거시 별칭 — 기존 JS/마크업이 참조하는 이름을 새 팔레트로 매핑 ── */
  --primary:#2563EB; --primary-d:#1D4ED8; --primary-l:#60A5FA; --primary-bg:#EFF4FF;
  --text:#0F172A; --sub:#64748B; --muted:#94A3B8;
  --border:#E2E8F0; --border-soft:#EEF2F7;
  --pos:#059669; --pos-bg:#ECFDF5;
  --neg:#DC2626; --neg-bg:#FEF2F2;
  --sales:#2563EB;  --sales-bg:#EFF4FF;
  --cost:#7C3AED;   --cost-bg:#F3E8FF;
  --cardc:#0EA5E9;  --cardc-bg:#E0F2FE;
  --cash:#D97706;   --cash-bg:#FEF3E7;
  --warn-bg:#FEF3E7; --warn-bd:#FCD9A5;
  --r-lg:14px; --r-md:12px; --r-sm:10px; --r-xs:8px;
  --sidebar-w:248px;

  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 4px 16px rgba(15,23,42,.08);
  --shadow-h:0 12px 40px rgba(15,23,42,.14);
  --shadow-lg:0 12px 40px rgba(15,23,42,.14);
  --ring:0 0 0 4px rgba(37,99,235,.16);
}

[data-theme="dark"]{
  --bg:#0B1220; --card:#111A2E; --ink:#E8EEF8; --ink2:#CBD5E1; --sub:#8B9AB3; --muted:#64748B;
  --point-soft:#16294D; --ai-soft:#0C2A3A;
  --line:#23304B; --line-soft:#1B273E; --surface:#172238; --surface2:#1E2C46;
  --ok-soft:#0E2A22; --warn-soft:#2E2210; --red-soft:#2E1417;
  /* 레거시 별칭 다크 매핑 */
  --text:#E8EEF8; --border:#23304B; --border-soft:#1B273E;
  --primary-bg:#16294D; --navy:#E8EEF8;
  --pos-bg:#0E2A22; --neg-bg:#2E1417; --sales-bg:#16294D; --cost-bg:#241640;
  --cardc-bg:#0C2A3A; --cash-bg:#2E2210; --warn-bg:#2E2210; --warn-bd:#3a2c12;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4); --shadow:0 4px 16px rgba(0,0,0,.45);
  --shadow-h:0 12px 40px rgba(0,0,0,.55); --shadow-lg:0 12px 40px rgba(0,0,0,.55);
}

/* ───────────────────────── Base ───────────────────────── */
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--ink);}
body{font-family:var(--font);font-size:14px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}
a{color:inherit;text-decoration:none;}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum";}
::selection{background:rgba(37,99,235,.18);}
[data-lucide]{width:1em;height:1em;stroke-width:2;vertical-align:-2px;}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cdd6e3;border-radius:9px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#aab6c8}
[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#2b3a57;border-color:var(--bg)}

@keyframes rise{from{opacity:0;transform:translateY(8px)}}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{transform:scale(.96) translateY(8px);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{100%{background-position:-200% 0;}}
@keyframes vizPulse{0%,100%{transform:scaleY(.55)}50%{transform:scaleY(1)}}

/* ───────────────────────── App shell (grid) ───────────────────────── */
.app{display:flex;min-height:100vh;}            /* 레거시 폴백 */
.app-shell{display:grid;grid-template-columns:var(--side-w) 1fr;grid-template-rows:var(--top-h) 1fr;
  grid-template-areas:"brand top" "side main";min-height:100vh;transition:grid-template-columns .18s ease;}
.app-shell.collapsed{grid-template-columns:var(--side-w-min) 1fr;}

/* Brand cell (좌상단) */
.brand-cell{grid-area:brand;display:flex;align-items:center;gap:10px;padding:0 16px;height:var(--top-h);
  background:var(--card);border-bottom:1px solid var(--line);border-right:1px solid var(--line);}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:-.02em;
  overflow:hidden;white-space:nowrap;color:var(--ink);}
.brand .logo{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:0 0 auto;color:#fff;
  font-size:13px;font-weight:800;background:linear-gradient(135deg,var(--point),var(--ai));
  box-shadow:0 4px 12px rgba(37,99,235,.32);}
.brand .bt{line-height:1.12;}
.brand small{display:block;font-weight:600;color:var(--sub);font-size:9.5px;letter-spacing:.06em;margin-top:1px;}
.collapsed .brand .bt,.collapsed .brand small{display:none;}
.tb-toggle{width:36px;height:36px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);
  display:grid;place-items:center;color:var(--ink);flex:0 0 auto;transition:.13s;}
.tb-toggle:hover{background:var(--surface);border-color:var(--point);color:var(--point);}

/* Topbar (상단바) */
.topbar{grid-area:top;height:var(--top-h);display:flex;align-items:center;gap:14px;padding:0 22px;
  background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;}
.topbar .crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--sub);font-weight:600;}
.topbar .crumb b{color:var(--ink);font-weight:800;letter-spacing:-.01em;}
.topbar .crumb .sep{color:var(--muted);}
.tb-spacer{flex:1;}
.tb-search{height:38px;min-width:200px;max-width:360px;display:flex;align-items:center;gap:9px;padding:0 13px;
  border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--sub);
  font-size:13px;font-weight:500;transition:.13s;}
.tb-search:hover{border-color:#cbd5e1;}
.tb-search:focus-within{border-color:var(--point);background:var(--card);box-shadow:var(--ring);}
.tb-search input{border:none;background:none;outline:none;flex:1;min-width:0;font-size:13px;color:var(--ink);padding:0;}
.tb-search .kbd{font-size:11px;font-weight:700;color:var(--muted);background:var(--card);
  border:1px solid var(--line);border-radius:6px;padding:2px 6px;}
.tb-util{display:flex;align-items:center;gap:8px;}
.icon-btn{width:38px;height:38px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);
  display:grid;place-items:center;color:var(--ink);position:relative;flex:0 0 auto;transition:.13s;}
.icon-btn:hover{background:var(--surface);border-color:var(--point);color:var(--point);}
.icon-btn .dot{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;
  background:var(--red);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;line-height:1;border:2px solid var(--card);}
.env-badge{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:800;letter-spacing:.04em;
  padding:5px 10px;border-radius:var(--r-pill);text-transform:uppercase;}
.env-badge.prod{background:var(--ok-soft);color:var(--ok);}
.env-badge.dev{background:var(--warn-soft);color:var(--warn);}
.env-badge .blip{width:6px;height:6px;border-radius:50%;background:currentColor;}
.user-chip{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--r-pill);
  border:1px solid var(--line);background:var(--card);transition:.13s;}
.user-chip:hover{background:var(--surface);}
.user-chip .avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;
  font-weight:800;font-size:13px;background:linear-gradient(135deg,var(--point),var(--ai));flex:0 0 auto;}
.user-chip .who{line-height:1.2;text-align:left;min-width:0;}
.user-chip .who b{font-size:12.5px;font-weight:700;display:block;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;}
.user-chip .who span{font-size:10.5px;color:var(--sub);}
.logout{width:36px;height:36px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);
  display:grid;place-items:center;color:var(--sub);flex:0 0 auto;transition:.13s;}
.logout:hover{background:var(--red-soft);border-color:var(--red);color:var(--red);}

/* Sidebar */
.sidebar{grid-area:side;background:var(--card);border-right:1px solid var(--line);padding:16px 12px;
  position:sticky;top:var(--top-h);height:calc(100vh - var(--top-h));overflow-y:auto;
  display:flex;flex-direction:column;}
.sb-nav{display:flex;flex-direction:column;}
.nav-group{margin-bottom:16px;}
.nav-title,.sb-nav .sect{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);
  font-weight:800;padding:0 12px;margin-bottom:8px;}
.collapsed .nav-title,.collapsed .sb-nav .sect{text-align:center;font-size:9px;padding:0;}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:600;color:var(--sub);margin-bottom:3px;position:relative;transition:.12s;
  border:none;background:transparent;text-align:left;cursor:pointer;}
.nav-item [data-lucide]{font-size:18px;flex:0 0 auto;color:var(--muted);transition:color .12s;}
.nav-item:hover{background:var(--surface);color:var(--ink);}
.nav-item:hover [data-lucide]{color:var(--point);}
.nav-item.active,.nav-item.on{background:var(--point-soft);color:var(--point);font-weight:700;}
.nav-item.active [data-lucide],.nav-item.on [data-lucide]{color:var(--point);}
.nav-item.active::before,.nav-item.on::before{content:"";position:absolute;left:-12px;top:50%;
  transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--point);}
.nav-item .lbl{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.collapsed .nav-item{justify-content:center;padding:10px;}
.collapsed .nav-item .lbl{display:none;}
.side-foot{margin-top:auto;padding:12px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--muted);}
.side-foot .b{color:var(--ink2);font-weight:800;font-size:11.5px;}
.collapsed .side-foot .v-detail{display:none;}
.collapsed .side-foot{text-align:center;font-size:9px;padding:10px 4px;}

/* Main content host (#viewHost) */
.content{grid-area:main;padding:26px 32px 64px;max-width:1440px;width:100%;margin:0;}
.main{flex:1;min-width:0;display:flex;flex-direction:column;}      /* 레거시 폴백 */
.wrap{max-width:1240px;width:100%;margin:0 auto;padding:26px 28px 64px;}

/* ───────────────────────── Page head ───────────────────────── */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px;}
.page-head h1{font-size:24px;font-weight:800;letter-spacing:-.025em;margin:0;color:var(--ink);
  display:flex;align-items:center;gap:10px;line-height:1.2;}
.page-head h1 [data-lucide]{font-size:23px;color:var(--point);}
.page-head .lead{font-size:13.5px;color:var(--sub);margin:6px 0 0;}
.page-head .right,.page-head .actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap;}

/* ───────────────────────── Buttons ───────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13.5px;font-weight:700;
  padding:9px 15px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--card);color:var(--ink);
  transition:.13s;white-space:nowrap;line-height:1;}
.btn [data-lucide]{font-size:16px;color:var(--sub);}
.btn:hover{border-color:var(--point);color:var(--point);background:var(--point-soft);}
.btn:hover [data-lucide]{color:var(--point);}
.btn.primary{background:var(--point);border-color:var(--point);color:#fff;}
.btn.primary [data-lucide]{color:#fff;}
.btn.primary:hover{background:var(--point-d);border-color:var(--point-d);color:#fff;}
.btn.danger{color:var(--red);border-color:var(--line);}
.btn.danger [data-lucide]{color:var(--red);}
.btn.danger:hover{background:var(--red-soft);border-color:var(--red);color:var(--red);}
.btn.ghost{background:transparent;color:var(--sub);font-weight:600;}
.btn.ghost:hover{background:var(--surface);border-color:var(--point);color:var(--point);}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:var(--r-xs);}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.row-actions{display:flex;gap:6px;justify-content:flex-end;}

/* ───────────────────────── KPI (stat) ───────────────────────── */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px;}
.kpi{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:18px 18px 16px;box-shadow:var(--shadow-sm);overflow:hidden;
  transition:transform .18s ease,box-shadow .18s;animation:rise .45s both;}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.kpi::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--accent,var(--point));opacity:0;transition:opacity .15s;}
.kpi:hover::after{opacity:1;}
.kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;}
.kpi .chip{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
  font-size:19px;color:var(--accent,var(--point));background:var(--accent-bg,var(--point-soft));}
.kpi .lbl{font-size:12px;color:var(--sub);font-weight:600;}
.kpi .val{font-size:26px;font-weight:800;letter-spacing:-.025em;color:var(--ink);line-height:1.04;}
.kpi .foot{margin-top:8px;font-size:11.5px;color:var(--muted);}

/* ───────────────────────── Cards ───────────────────────── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);animation:rise .45s both;margin-bottom:16px;}
.card.pad{padding:22px;}
.card-head{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line-soft);}
.card-head h3{margin:0;font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--ink);
  display:flex;align-items:center;gap:9px;}
.card-head h3 [data-lucide]{font-size:17px;color:var(--point);}
.card-head .right{margin-left:auto;display:flex;align-items:center;gap:8px;}
.chart-host{padding:8px 12px 14px;min-height:60px;}
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px;}

/* ───────────────────────── Tables ───────────────────────── */
.tbl-scroll{overflow-x:auto;border-radius:0 0 var(--r) var(--r);}
table{width:100%;border-collapse:collapse;font-size:13.5px;}
thead th{position:sticky;top:0;z-index:1;background:var(--surface);padding:11px 16px;font-size:11px;font-weight:700;
  color:var(--sub);text-align:right;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase;
  border-bottom:1px solid var(--line);}
thead th.l{text-align:left;}
tbody td{padding:13px 16px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;
  border-bottom:1px solid var(--line-soft);color:var(--ink);vertical-align:middle;}
tbody td.l{text-align:left;}
tbody tr{transition:background .12s;}
tbody tr.click{cursor:pointer;}
tbody tr.click:hover td,tbody tr:hover td{background:var(--point-soft);}
tbody tr:last-child td{border-bottom:none;}
tfoot td{padding:14px 16px;text-align:right;font-variant-numeric:tabular-nums;
  border-top:2px solid var(--line);background:var(--surface);font-weight:800;color:var(--ink);}
tfoot td.l{text-align:left;}
.co-ava{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;
  font-size:13px;font-weight:800;color:#fff;}
.co-cell{display:flex;align-items:center;gap:10px;}

/* 정렬 가능한 헤더 */
thead th.sortable{cursor:pointer;user-select:none;transition:color .13s;}
thead th.sortable:hover{color:var(--point);}
thead th.sortable .si{font-size:11px;opacity:.45;vertical-align:-1px;margin-left:3px;}
thead th.sortable.act .si{opacity:1;color:var(--point);}

/* ───────────────────────── Tags / badges ───────────────────────── */
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 9px;border-radius:7px;font-weight:700;}
.tag.sales{background:var(--point-soft);color:var(--point);}
.tag.purchase{background:#F3E8FF;color:var(--purple);}
.tag.card{background:var(--ai-soft);color:var(--ai);}
.tag.cash{background:var(--warn-soft);color:var(--warn);}
.tag.excel{background:var(--ok-soft);color:var(--ok);}
.tag.hometax{background:var(--point-soft);color:var(--point);}

/* ───────────────────────── Forms / filters ───────────────────────── */
.frm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px 18px;}
.frm label{display:block;font-size:11.5px;color:var(--sub);font-weight:600;margin-bottom:6px;}
.frm input,.frm select,.frm textarea{width:100%;height:42px;padding:0 13px;border:1.5px solid var(--line);
  border-radius:var(--r-sm);background:var(--bg);font-size:14px;color:var(--ink);transition:.13s;}
.frm textarea{height:auto;padding:11px 13px;min-height:80px;line-height:1.5;}
.frm input:focus,.frm select:focus,.frm textarea:focus{outline:none;border-color:var(--point);
  box-shadow:var(--ring);background:var(--card);}
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;}
.filters .f{display:flex;flex-direction:column;gap:5px;}
.filters .f label{font-size:11px;color:var(--sub);font-weight:600;}
.filters .f input,.filters .f select{height:40px;padding:0 12px;border:1.5px solid var(--line);
  border-radius:var(--r-sm);background:var(--card);font-size:13px;color:var(--ink);min-width:130px;transition:.13s;}
.filters .f input:focus,.filters .f select:focus{outline:none;border-color:var(--point);box-shadow:var(--ring);}

.settings-grid{display:grid;grid-template-columns:minmax(300px,420px) minmax(420px,1fr);gap:16px;align-items:start;}
.admin-list{display:flex;flex-direction:column;gap:8px;}
.admin-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);
  border-radius:var(--r-sm);background:var(--bg);}
.admin-row .avatar{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;
  font-weight:800;background:linear-gradient(135deg,var(--point),var(--ai));flex:0 0 auto;}
.admin-row .meta{min-width:0;flex:1;line-height:1.35;}
.admin-row .meta b{display:block;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.admin-row .meta span{display:block;font-size:12px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.admin-row .role{font-size:11px;font-weight:800;padding:4px 8px;border-radius:999px;background:var(--point-soft);color:var(--point);}
@media(max-width:1080px){.settings-grid{grid-template-columns:1fr;}}

/* 회사 선택 셀렉터 */
.dash-co{appearance:none;height:40px;padding:0 34px 0 13px;font-size:13.5px;font-weight:700;color:var(--ink);
  border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--card)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")
    no-repeat right 11px center;cursor:pointer;min-width:190px;transition:.13s;}
.dash-co:hover{border-color:var(--point);}
.dash-co:focus{outline:none;border-color:var(--point);box-shadow:var(--ring);}

/* ───────────────────────── HomeTax panel ───────────────────────── */
.htx-status{font-size:11.5px;font-weight:700;padding:5px 12px;border-radius:999px;
  display:inline-flex;align-items:center;gap:6px;}
.htx-status::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor;}
.htx-status.NOT_LINKED,.htx-status.READY{background:var(--surface);color:var(--sub);}
.htx-status.RUNNING{background:var(--warn-soft);color:var(--warn);}
.htx-status.SUCCESS{background:var(--ok-soft);color:var(--ok);}
.htx-status.FAIL,.htx-status.FAILED{background:var(--red-soft);color:var(--red);}
.htx-warn{background:var(--warn-soft);border:1px solid rgba(217,119,6,.25);color:var(--warn);
  border-radius:var(--r-sm);padding:12px 15px;font-size:12.5px;margin-top:13px;display:flex;gap:9px;
  line-height:1.6;font-weight:600;}
.htx-warn [data-lucide]{font-size:17px;flex:none;margin-top:1px;}

/* ───────────────────────── Dropzone / upload ───────────────────────── */
.dropzone{border:1.5px dashed var(--line);border-radius:var(--r-sm);background:var(--surface);
  padding:34px 24px;text-align:center;cursor:pointer;transition:.15s;color:var(--sub);}
.dropzone:hover,.dropzone.drag{border-color:var(--point);background:var(--point-soft);color:var(--point);}
.dropzone [data-lucide]{font-size:34px;color:var(--muted);stroke-width:1.5;}
.dropzone:hover [data-lucide],.dropzone.drag [data-lucide]{color:var(--point);}
.dropzone h4{margin:12px 0 4px;font-size:15px;color:var(--ink);font-weight:700;}
.dropzone p{margin:0;font-size:12.5px;color:var(--sub);}
.filelist{margin-top:16px;display:flex;flex-direction:column;gap:8px;}
.fileitem{display:flex;align-items:center;gap:11px;padding:11px 14px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r-sm);font-size:13px;}
.fileitem .nm{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink);font-weight:500;}
.fileitem .st{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:7px;}
.fileitem .st.PENDING{background:var(--surface);color:var(--sub);}
.fileitem .st.SUCCESS{background:var(--ok-soft);color:var(--ok);}
.fileitem .st.FAILED{background:var(--red-soft);color:var(--red);}
.fileitem .st.DUPLICATE{background:var(--warn-soft);color:var(--warn);}
.fileitem .rm{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;}
.fileitem .rm:hover{color:var(--red);}

/* ───────────────────────── States ───────────────────────── */
.empty{text-align:center;color:var(--sub);padding:48px 16px;font-size:13px;}
.empty [data-lucide]{font-size:46px;color:var(--muted);stroke-width:1.5;display:block;margin:0 auto 12px;}
.spinner{width:16px;height:16px;border:2px solid rgba(37,99,235,.25);border-top-color:var(--point);
  border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle;}
.errbox{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 16px;text-align:center;color:var(--red);}
.errbox [data-lucide]{font-size:30px;}
.errbox .msg{font-size:13.5px;color:var(--ink);max-width:520px;line-height:1.6;}
.errbox .btn{color:var(--point);}

/* 스켈레톤 */
.skeleton{background:linear-gradient(90deg,var(--line-soft) 25%,var(--surface) 37%,var(--line-soft) 63%);
  background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:var(--r-sm);}
.sk-kpi{height:106px;border-radius:var(--r);}
.sk-chart{height:280px;border-radius:var(--r);}
.sk-row{height:18px;margin:10px 16px;border-radius:6px;}

/* ───────────────────────── Modal / overlay ───────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;z-index:100;padding:18px;animation:fade .2s;}
.modal{background:var(--card);border-radius:var(--r);max-width:560px;width:100%;padding:26px;
  box-shadow:var(--shadow-lg);animation:pop .24s cubic-bezier(.34,1.4,.64,1);max-height:88vh;overflow:auto;}
.modal h3{margin:0 0 5px;font-size:18px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:9px;}
.modal h3 [data-lucide]{font-size:21px;color:var(--point);}
.modal .meta{font-size:13px;color:var(--sub);line-height:1.7;margin-bottom:16px;}
.modal .meta b{color:var(--ink);}
.modal-actions{display:flex;gap:10px;margin-top:18px;}
.modal-actions button{flex:1;padding:13px;font-size:14px;font-weight:700;border-radius:var(--r-sm);
  cursor:pointer;border:1px solid transparent;transition:.13s;}
.btn-go{background:var(--point);color:#fff;border-color:var(--point);}
.btn-go:hover{background:var(--point-d);border-color:var(--point-d);}
.btn-cancel{background:var(--surface);color:var(--sub);border-color:var(--line);}
.btn-cancel:hover{background:var(--line-soft);color:var(--ink);}

/* ───────────────────────── Toast ───────────────────────── */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:13px 20px;border-radius:11px;font-size:13.5px;font-weight:600;z-index:200;
  box-shadow:var(--shadow-lg);animation:rise .26s both;display:flex;align-items:center;gap:9px;max-width:90vw;}
.toast [data-lucide]{font-size:17px;}
.toast.err{background:#7F1D1D;} .toast.ok{background:#065F46;}

/* ───────────────────────── Autocomplete ───────────────────────── */
.ac-wrap{position:relative;}
.ac-list{position:absolute;z-index:60;left:0;right:0;top:calc(100% + 4px);background:var(--card);
  border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow);max-height:280px;
  overflow:auto;display:none;}
.ac-list.on{display:block;animation:rise .16s both;}
.ac-item{padding:9px 13px;font-size:13px;cursor:pointer;display:flex;justify-content:space-between;gap:10px;
  border-bottom:1px solid var(--line-soft);}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover,.ac-item.active{background:var(--point-soft);color:var(--point);}
.ac-item .amt{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px;}

/* ───────────────────────── Pagination ───────────────────────── */
.pager{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;flex-wrap:wrap;}
.pager button{min-width:34px;padding:7px 10px;font-size:13px;font-weight:600;border:1px solid var(--line);
  background:var(--card);color:var(--ink);border-radius:8px;cursor:pointer;transition:.13s;}
.pager button:hover:not(:disabled){border-color:var(--point);color:var(--point);}
.pager button.on{background:var(--point);border-color:var(--point);color:#fff;}
.pager button:disabled{opacity:.4;cursor:not-allowed;}
.pager .info{font-size:12.5px;color:var(--sub);margin:0 6px;}

/* 작은 메타 라인 */
.meta-line{font-size:12px;color:var(--sub);display:flex;align-items:center;gap:6px;}
.hidden{display:none!important;}

/* ───────────────────────── Auth (login) ───────────────────────── */
.auth{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh;}
.auth-brand{position:relative;overflow:hidden;color:#fff;padding:60px 56px;display:flex;flex-direction:column;
  justify-content:space-between;background:linear-gradient(150deg,var(--navy2),#1b3f66 60%,#234e7d);}
.auth-brand::before{content:'';position:absolute;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,233,.35),transparent 70%);top:-120px;right:-120px;}
.auth-brand::after{content:'';position:absolute;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.3),transparent 70%);bottom:-100px;left:-80px;}
.auth-brand>*{position:relative;z-index:1;}
.auth-brand .logo{display:flex;align-items:center;gap:12px;font-size:17px;font-weight:800;}
.auth-brand .logo .mark{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.14);
  display:grid;place-items:center;font-size:20px;}
.auth-spark,.auth-viz{display:flex;align-items:flex-end;gap:8px;height:92px;margin:14px 0 26px;}
.auth-spark .b,.auth-viz i{flex:1;border-radius:6px 6px 0 0;transform-origin:bottom;
  background:linear-gradient(180deg,var(--ai),rgba(14,165,233,.25));animation:vizPulse 2.4s ease-in-out infinite;opacity:.9;}
.auth-brand h2{font-size:31px;font-weight:800;line-height:1.26;letter-spacing:-.025em;margin:8px 0 14px;max-width:15ch;}
.auth-brand .desc{font-size:14.5px;line-height:1.72;color:#C7D7EC;max-width:38ch;margin:0;}
.auth-brand .feat{display:flex;flex-direction:column;gap:12px;margin-top:30px;}
.auth-brand .feat span{font-size:13.5px;color:#CFE0F2;display:flex;align-items:center;gap:11px;}
.auth-brand .feat [data-lucide]{font-size:18px;color:var(--ai);flex:none;}
.auth-brand .copy{font-size:12px;color:#93A7C7;}
.auth-form-wrap{display:flex;align-items:center;justify-content:center;padding:44px 32px;background:var(--bg);}
.auth-form{width:100%;max-width:380px;}
.auth-form h1{font-size:25px;font-weight:800;letter-spacing:-.02em;margin:0 0 7px;color:var(--ink);}
.auth-form .lead{font-size:13.5px;color:var(--sub);margin:0 0 26px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:7px;}
.field input{width:100%;height:46px;padding:0 15px;font-size:14.5px;border:1.5px solid var(--line);
  border-radius:var(--r-sm);background:var(--card);outline:none;transition:.13s;color:var(--ink);}
.field input:focus{border-color:var(--point);box-shadow:var(--ring);}
.auth-btn{width:100%;height:48px;font-size:15px;font-weight:700;border:none;border-radius:var(--r-sm);
  background:var(--point);color:#fff;cursor:pointer;margin-top:8px;transition:.13s;
  display:flex;align-items:center;justify-content:center;gap:8px;}
.auth-btn:hover{background:var(--point-d);}
.auth-btn:active{transform:translateY(1px);}
.auth-err{color:var(--red);font-size:12.5px;min-height:18px;margin-top:12px;text-align:center;font-weight:600;}
.auth-hint{margin-top:20px;padding:11px 14px;background:var(--point-soft);border:1px solid rgba(37,99,235,.18);
  border-radius:var(--r-xs);font-size:12px;color:var(--point-d);text-align:center;}

/* ───────────────────────── Responsive ───────────────────────── */
@media(max-width:980px){.chart-grid{grid-template-columns:1fr;}}
@media(max-width:880px){.auth{grid-template-columns:1fr;} .auth-brand{display:none;}}
@media (max-width:860px){
  .app-shell{grid-template-columns:0 1fr;}
  .brand-cell{border-right:none;}
  .sidebar{position:fixed;left:0;top:var(--top-h);width:var(--side-w-min);z-index:70;transform:translateX(-100%);
    transition:transform .2s ease;box-shadow:var(--shadow-lg);}
  .app-shell.mob-open .sidebar{transform:translateX(0);width:240px;}
  .app-shell.mob-open .sidebar .nav-item .lbl,.app-shell.mob-open .sidebar .nav-title{display:block;}
  .content{padding:20px 16px 50px;}
  .tb-search{display:none;}
  .page-head h1{font-size:21px;}
  .user-chip .who{display:none;}
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:560px){
  .kpis{grid-template-columns:1fr;}
  .topbar{padding:0 14px;gap:10px;}
  .env-badge{display:none;}
}

/* 접근성 — 모션 최소화 */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
}
