/* ============================================================================
   DealView — Web UI v3.0  ·  KAI Platform Design System
   ONVALUE 디자인 철학 기반 · White / Light-grey / Blue / Navy / Glass / Card
   색상: 배경 #F7F9FC · 카드 #FFF · 텍스트 #0F172A · 보조 #64748B
        포인트 #2563EB · AI #0EA5E9 · 성공 #059669 · 경고 #D97706 · 위험 #DC2626
   폰트: Pretendard · 아이콘: Lucide
   ※ 본 파일은 표현(UI)만 담당하며 기존 API/URL/세션/권한 로직과 무관.
   ============================================================================ */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css');

:root{
  --bg:#F7F9FC; --card:#FFFFFF; --ink:#0F172A; --ink2:#1E293B; --sub:#64748B; --sub2:#94A3B8;
  --point:#2563EB; --point-d:#1D4ED8; --point-soft:#EFF4FF; --ai:#0EA5E9; --ai-soft:#E0F2FE;
  --navy:#0E2A47; --navy2:#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;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 4px 16px rgba(15,23,42,.08);
  --sh:var(--shadow); --sh-sm:var(--shadow-sm);
  --shadow-lg:0 12px 40px rgba(15,23,42,.14);
  --r:14px; --r-sm:10px; --r-xs:8px; --r-pill:999px;
  --top-h:60px; --side-w:248px; --side-w-min:68px;
  --font:'Pretendard','Noto Sans KR',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'Pretendard',ui-monospace,SFMono-Regular,Menlo,monospace;
}
[data-theme="dark"]{
  --bg:#0B1220; --card:#111A2E; --ink:#E8EEF8; --ink2:#CBD5E1; --sub:#8B9AB3; --sub2:#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;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4); --shadow:0 4px 16px rgba(0,0,0,.45); --shadow-lg:0 12px 40px rgba(0,0,0,.55);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.num,.mono{font-variant-numeric:tabular-nums}
::-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)}

/* ─────────────────────────── App shell ─────────────────────────── */
.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}

/* 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}
.tb-toggle{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);flex:0 0 auto}
.tb-toggle:hover{background:var(--surface)}
.tb-search{flex:1;max-width:520px;height:40px;display:flex;align-items:center;gap:10px;padding:0 14px;
  border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--sub);font-size:13.5px;font-weight:500}
.tb-search:hover{border-color:#cbd5e1}
.tb-search .kbd{margin-left:auto;font-size:11px;font-weight:700;color:var(--sub2);background:var(--card);
  border:1px solid var(--line);border-radius:6px;padding:2px 6px}
.tb-spacer{flex:1}
.tb-util{display:flex;align-items:center;gap:8px}
.icon-btn{width:40px;height:40px;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}
.icon-btn:hover{background:var(--surface)}
.icon-btn .dot{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;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:11px;font-weight:800;letter-spacing:.04em;
  padding:5px 10px;border-radius:var(--r-pill);text-transform:uppercase}
.env-badge.dev{background:var(--warn-soft);color:var(--warn)}
.env-badge.prod{background:var(--ok-soft);color:var(--ok)}
.env-badge .blip{width:6px;height:6px;border-radius:50%;background:currentColor}
.user-chip{display:flex;align-items:center;gap:9px;padding:5px 8px 5px 6px;border-radius:var(--r-pill);
  border:1px solid var(--line);background:var(--card)}
.user-chip:hover{background:var(--surface)}
.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(--navy));flex:0 0 auto}
.avatar.xs{width:22px;height:22px;font-size:10px}
.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}
.user-chip .who b{font-size:13px;font-weight:700;display:block}
.user-chip .who span{font-size:11px;color:var(--sub)}

/* Brand cell */
.brand-cell{grid-area:brand;display:flex;align-items:center;gap:11px;padding:0 18px;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:19px;letter-spacing:-.02em;overflow:hidden;white-space:nowrap}
.brand .logo{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;
  background:linear-gradient(135deg,var(--point),var(--ai));color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.3)}
.brand small{display:block;font-weight:500;color:var(--sub);font-size:10px;letter-spacing:.05em;margin-top:1px}
.brand .bt{line-height:1.1}
.collapsed .brand .bt,.collapsed .brand small{display:none}

/* 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}
.nav-group{margin-bottom:18px}
.nav-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--sub2);font-weight:800;padding:0 12px;margin-bottom:8px}
.collapsed .nav-title{text-align:center;font-size:9px;padding:0}
.nav-item{display:flex;align-items:center;gap:11px;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}
.nav-item i[data-lucide],.nav-item svg{width:18px;height:18px;flex:0 0 auto}
.nav-item:hover{background:var(--surface);color:var(--ink)}
.nav-item.active{background:var(--point-soft);color:var(--point);font-weight:700}
.nav-item.active::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}
.nav-item .soon{font-size:9px;font-weight:800;color:var(--sub2);text-transform:uppercase;letter-spacing:.04em}
.collapsed .nav-item{justify-content:center;padding:10px}
.collapsed .nav-item .lbl,.collapsed .nav-item .soon{display:none}
.collapsed .nav-item.active::before{left:-12px}
.side-foot{margin-top:auto;padding:12px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--sub2)}
.collapsed .side-foot{text-align:center;font-size:9px;padding:10px 4px}
.collapsed .side-foot .v-detail{display:none}

/* Main content */
.content{grid-area:main;padding:26px 32px 60px;max-width:1440px;width:100%;margin-right:auto}
.crumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--sub);margin-bottom:10px;flex-wrap:wrap}
.crumb a:hover{color:var(--point)}
.crumb .sep{color:var(--sub2)}
.page-h{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-h h1{font-size:24px;font-weight:800;letter-spacing:-.025em;line-height:1.2}
.page-h .sub{color:var(--sub);font-size:13.5px;margin-top:4px}
.page-h .actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap}

/* ─────────────────────────── Cards & grid ─────────────────────────── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;
  box-shadow:var(--shadow-sm);margin-bottom:16px}
.card.flush{padding:0;overflow:hidden}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-title i[data-lucide],.card-title svg{width:17px;height:17px;color:var(--point)}
.card-title.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--sub);font-weight:800}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}

/* KPI / stat */
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--point);opacity:0;transition:.15s}
.stat:hover::after{opacity:1}
.stat .l{font-size:12px;color:var(--sub);font-weight:600;display:flex;align-items:center;gap:7px}
.stat .l i[data-lucide],.stat .l svg{width:15px;height:15px;color:var(--sub2)}
.stat .v{font-size:27px;font-weight:800;letter-spacing:-.02em;margin-top:9px;line-height:1}
.stat .v small{font-size:13px;color:var(--sub);font-weight:600}
.stat .h{font-size:11.5px;color:var(--sub);margin-top:6px}
.stat.accent{background:linear-gradient(180deg,var(--point-soft),var(--card))}
.metric{border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;background:var(--card)}
.metric .m-k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--sub);font-weight:700}
.metric .m-v{font-size:22px;font-weight:800;margin-top:6px;letter-spacing:-.02em;line-height:1}
.metric .m-h{font-size:11px;color:var(--sub);margin-top:5px}

/* ─────────────────────────── 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 i[data-lucide],.btn svg{width:16px;height:16px}
.btn:hover{border-color:var(--point);color:var(--point);background:var(--point-soft)}
.btn.primary{background:var(--point);color:#fff;border-color:var(--point)}
.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:hover{background:var(--red-soft);border-color:var(--red);color:var(--red)}
.btn.ai{background:var(--ai);color:#fff;border-color:var(--ai)}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--sub);font-weight:600}
.btn.ghost:hover{background:var(--surface);border-color:var(--point);color:var(--point)}
.btn.ai:hover{background:#0284c7;border-color:#0284c7;color:#fff}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:var(--r-xs)}
.btn.xs{padding:4px 9px;font-size:11.5px;border-radius:var(--r-xs);gap:5px}
.btn.full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-row{display:flex;gap:7px;flex-wrap:wrap;align-items:center}

/* ─────────────────────────── Forms ─────────────────────────── */
.field{margin-bottom:14px}
label{display:block;font-size:12px;color:var(--sub);font-weight:600;margin-bottom:6px}
input,select,textarea{width:100%;height:42px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:0 13px;font-size:14px;font-family:inherit;background:var(--bg);color:var(--ink);transition:.13s}
textarea{height:auto;padding:11px 13px;min-height:80px;line-height:1.5}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--point);background:var(--card);box-shadow:0 0 0 4px var(--point-soft)}
input[type=checkbox],input[type=radio]{width:17px;height:17px;height:auto;accent-color:var(--point);cursor:pointer}
input[type=file]{padding:9px 13px;height:auto}
.check{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink);font-weight:500;cursor:pointer}
.check input{width:17px;height:17px}
.inline-form{display:flex;gap:9px;flex-wrap:wrap;align-items:flex-end}
.inline-form .field{margin-bottom:0}
.form-grid{display:grid;gap:11px}

/* ─────────────────────────── Tables ─────────────────────────── */
.tbl-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--sub);
  font-weight:700;padding:11px 14px;background:var(--surface);border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:13px 14px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:.1s}
tbody tr:hover td{background:var(--point-soft)}
tr.row-link{cursor:pointer}
.t-right{text-align:right}.t-center{text-align:center}
.t-strong{font-weight:700}
.t-mut{color:var(--sub);font-size:12px}

/* ─────────────────────────── Badges / tags ─────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:7px;
  background:var(--surface);color:var(--sub)}
.badge.blue{background:var(--point-soft);color:var(--point)}
.badge.ai{background:var(--ai-soft);color:var(--ai)}
.badge.green{background:var(--ok-soft);color:var(--ok)}
.badge.amber{background:var(--warn-soft);color:var(--warn)}
.badge.red{background:var(--red-soft);color:var(--red)}
.badge.ink{background:var(--navy);color:#fff}
.badge.purple{background:#F3E8FF;color:var(--purple)}
.badge.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.grade-chip{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;flex:0 0 auto}
.grade-AAA,.grade-AA,.grade-A{background:var(--point)} .grade-BBB,.grade-BB,.grade-B{background:var(--purple)}
.grade-CCC,.grade-CC,.grade-C{background:var(--warn)} .grade-D{background:var(--red)} .grade-S{background:var(--ai)}

/* ─────────────────────────── Tabs ─────────────────────────── */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:0 0 22px;flex-wrap:wrap;overflow-x:auto}
.tab{display:inline-flex;align-items:center;gap:7px;padding:11px 16px;font-size:13.5px;font-weight:700;color:var(--sub);
  border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:.12s}
.tab i[data-lucide],.tab svg{width:16px;height:16px}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--point);border-color:var(--point)}
.pill-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}
.pill-tabs a{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--r-sm);font-weight:600;
  font-size:13.5px;color:var(--sub);border:1px solid var(--line);background:var(--card)}
.pill-tabs a.on,.pill-tabs a:hover{color:var(--point);border-color:var(--point);background:var(--point-soft)}

/* ─────────────────────────── Bars / meters / gauge ─────────────────────────── */
.bar{height:18px;background:var(--surface);border-radius:6px;overflow:hidden}
.bar>i{display:block;height:100%;border-radius:6px;background:var(--point);transition:width .4s ease}
.bar.brass>i{background:var(--ai)}
.distrow{display:flex;align-items:center;gap:10px;font-size:12.5px;margin-bottom:9px}
.distrow .k{width:72px;color:var(--sub);font-weight:600;flex:0 0 auto}
.distrow .n{width:28px;text-align:right;font-weight:700;flex:0 0 auto}
.meter{height:8px;border-radius:5px;background:var(--surface);overflow:hidden}
.meter>span{display:block;height:100%;background:linear-gradient(90deg,var(--ai),#38bdf8)}
.gauge-wrap{display:flex;align-items:center;gap:16px}
.gauge{width:96px;height:96px;flex:0 0 auto}
.gauge .track{fill:none;stroke:var(--surface);stroke-width:9}
.gauge .val{fill:none;stroke:var(--point);stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
.gauge-mid{font-size:22px;font-weight:800;fill:var(--ink)}

/* ─────────────────────────── Timeline ─────────────────────────── */
.timeline{position:relative;padding-left:6px}
.tl-item{position:relative;padding:0 0 16px 20px;border-left:2px solid var(--line)}
.tl-item:last-child{border-color:transparent}
.tl-item::before{content:"";position:absolute;left:-6px;top:2px;width:10px;height:10px;border-radius:50%;
  background:var(--card);border:2px solid var(--point)}
.tl-item.ok::before{border-color:var(--ok)} .tl-item.warn::before{border-color:var(--warn)}
.tl-item .tt{font-weight:700;font-size:13px}
.tl-item .td{font-size:12.5px;color:var(--sub);margin-top:2px}
.tl-item .tm{font-size:11px;color:var(--sub2);margin-top:3px}

/* Stage stepper */
.stepper{display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.step{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:6px 11px;border-radius:var(--r-pill);
  background:var(--surface);color:var(--sub)}
.step.on{background:var(--point);color:#fff}
.step.done{background:var(--ok-soft);color:var(--ok)}
.step .arrow{color:var(--sub2)}

/* ─────────────────────────── Engine health ─────────────────────────── */
.eng-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.eng{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--card)}
.eng .led{width:9px;height:9px;border-radius:50%;flex:0 0 auto;background:var(--sub2);box-shadow:0 0 0 3px var(--surface)}
.eng.up .led{background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft)}
.eng.down .led{background:var(--red);box-shadow:0 0 0 3px var(--red-soft)}
.eng.warn .led{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}
.eng .en{font-weight:700;font-size:12.5px}
.eng .ep{font-size:10.5px;color:var(--sub2);margin-left:auto}

/* ─────────────────────────── Drawer (slide panel) ─────────────────────────── */
.drawer-scrim{position:fixed;inset:0;background:rgba(15,23,42,.36);backdrop-filter:blur(2px);z-index:90;opacity:0;
  pointer-events:none;transition:.2s}
.drawer-scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:440px;max-width:92vw;background:var(--card);z-index:95;
  box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .24s ease;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-h{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 22px;border-bottom:1px solid var(--line-soft)}
.drawer-h h2{font-size:18px;font-weight:800;letter-spacing:-.02em}
.drawer-h .x{width:34px;height:34px;border:1px solid var(--line);border-radius:var(--r-xs);background:var(--card);display:grid;place-items:center;color:var(--sub);flex:0 0 auto}
.drawer-h .x:hover{background:var(--surface)}
.drawer-b{padding:20px 22px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:13.5px}
.kv .k{color:var(--sub)} .kv .v{font-weight:700;text-align:right}

/* Modal */
.modal-scrim{position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(2px);z-index:100;display:none;
  align-items:center;justify-content:center;padding:20px}
.modal-scrim.open{display:flex}
.modal{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-lg);width:100%;max-width:480px;overflow:hidden}
.modal-h{padding:18px 22px;border-bottom:1px solid var(--line-soft);font-weight:800;font-size:16px}
.modal-b{padding:22px}
.modal-f{padding:14px 22px;border-top:1px solid var(--line-soft);display:flex;justify-content:flex-end;gap:9px}

/* ─────────────────────────── Toast ─────────────────────────── */
.toast-wrap{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:9px;align-items:center}
.toast{display:flex;align-items:center;gap:9px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:11px;
  font-size:13.5px;font-weight:600;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(16px);transition:.22s;max-width:90vw}
.toast.show{opacity:1;transform:translateY(0)}
.toast.ok{background:#065F46}.toast.err{background:#7F1D1D}.toast i[data-lucide]{width:17px;height:17px}

/* ─────────────────────────── Command palette ─────────────────────────── */
.cmdk-scrim{position:fixed;inset:0;background:rgba(15,23,42,.42);backdrop-filter:blur(3px);z-index:150;display:none;
  align-items:flex-start;justify-content:center;padding:14vh 16px 16px}
.cmdk-scrim.open{display:flex}
.cmdk{width:100%;max-width:560px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-lg);overflow:hidden}
.cmdk-in{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--line-soft)}
.cmdk-in i[data-lucide]{width:19px;height:19px;color:var(--sub)}
.cmdk-in input{border:none;background:none;height:auto;padding:0;font-size:16px;box-shadow:none!important}
.cmdk-list{max-height:340px;overflow-y:auto;padding:8px}
.cmdk-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:var(--r-sm);cursor:pointer;font-size:14px}
.cmdk-item i[data-lucide]{width:17px;height:17px;color:var(--sub)}
.cmdk-item .meta{margin-left:auto;font-size:11px;color:var(--sub2)}
.cmdk-item.sel,.cmdk-item:hover{background:var(--point-soft);color:var(--point)}
.cmdk-item.sel i[data-lucide],.cmdk-item:hover i[data-lucide]{color:var(--point)}
.cmdk-empty{padding:30px;text-align:center;color:var(--sub);font-size:13.5px}
.cmdk-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--sub2);font-weight:800;padding:10px 13px 5px}

/* ─────────────────────────── Notification popover ─────────────────────────── */
.pop{position:absolute;top:50px;right:0;width:330px;max-width:88vw;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:60;display:none;overflow:hidden}
.pop.open{display:block}
.pop-h{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border-bottom:1px solid var(--line-soft);font-weight:700;font-size:14px}
.pop-list{max-height:360px;overflow-y:auto}
.pop-item{display:flex;gap:10px;padding:12px 15px;border-bottom:1px solid var(--line-soft);font-size:13px}
.pop-item:hover{background:var(--surface)}
.pop-empty{padding:32px;text-align:center;color:var(--sub);font-size:13px}

/* ─────────────────────────── States ─────────────────────────── */
.empty{padding:48px 24px;text-align:center;color:var(--sub)}
.empty .ico{width:54px;height:54px;border-radius:14px;background:var(--surface);display:grid;place-items:center;margin:0 auto 14px;color:var(--sub2)}
.empty .ico i[data-lucide]{width:26px;height:26px}
.empty h4{color:var(--ink);font-size:15px;margin-bottom:5px;font-weight:700}
.empty>i[data-lucide]{width:46px;height:46px;color:var(--sub2);margin-bottom:12px;stroke-width:1.5}
.empty h3{color:var(--ink);font-size:15px;margin:0 0 5px;font-weight:700}
.empty p{font-size:13px;margin:0}
.preparing{border:1px dashed var(--line);border-radius:var(--r-sm);padding:26px;text-align:center;color:var(--sub);background:var(--surface)}
.preparing b{color:var(--ink)}
.preparing>i[data-lucide]{width:18px;height:18px;vertical-align:-4px;color:var(--ai)}
.notice{display:flex;align-items:flex-start;gap:10px;background:var(--warn-soft);border:1px solid rgba(217,119,6,.25);
  border-radius:var(--r-sm);padding:14px 16px;color:var(--warn);font-weight:600;font-size:13.5px;margin-bottom:16px}
.notice.ok{background:var(--ok-soft);border-color:rgba(5,150,105,.25);color:var(--ok)}
.notice.info{background:var(--point-soft);border-color:rgba(37,99,235,.2);color:var(--point)}
.notice.err{background:var(--red-soft);border-color:rgba(220,38,38,.25);color:var(--red)}
.notice i[data-lucide]{width:18px;height:18px;flex:0 0 auto;margin-top:1px}
.err{color:var(--red);font-size:12.5px;margin:8px 0;font-weight:600}
.skel{background:linear-gradient(90deg,var(--surface) 25%,var(--line-soft) 37%,var(--surface) 63%);
  background-size:400% 100%;animation:skel 1.3s ease infinite;border-radius:6px;height:14px}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}
.aibox{border:1.5px solid #BAE6FD;background:linear-gradient(180deg,#F0F9FF,var(--card));border-radius:var(--r);padding:18px}
[data-theme="dark"] .aibox{border-color:#1e3a52;background:linear-gradient(180deg,#0c2233,var(--card))}
.aibox .cap{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--ai)}
.disclaimer{font-size:11.5px;color:var(--sub);background:var(--surface);border-left:3px solid var(--ai);border-radius:8px;padding:11px 13px;line-height:1.55}

/* spinner */
.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}

/* ─────────────────────────── Auth pages ─────────────────────────── */
.auth-split{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
.auth-left{background:linear-gradient(150deg,var(--navy),#1b3f66 60%,#234e7d);color:#fff;display:flex;flex-direction:column;
  justify-content:center;padding:64px 60px;position:relative;overflow:hidden}
.auth-left::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-left::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-left .inner{position:relative;z-index:1;max-width:440px}
.auth-left .brand{color:#fff;font-size:24px}
.auth-left .brand small{color:#9DB8D6}
.auth-left h2{font-size:32px;font-weight:800;letter-spacing:-.025em;line-height:1.25;margin:26px 0 14px}
.auth-left p{color:#B6CAE2;font-size:15px;line-height:1.7}
.auth-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:34px}
.auth-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-sm);padding:14px 13px;backdrop-filter:blur(6px)}
.auth-stat .l{font-size:11.5px;color:#9DB8D6;font-weight:600;display:flex;align-items:center;gap:6px}
.auth-stat .l i[data-lucide]{width:14px;height:14px}
.auth-stat .v{font-size:21px;font-weight:800;margin-top:7px;letter-spacing:-.02em}
.auth-feats{margin-top:30px;display:flex;flex-direction:column;gap:11px}
.auth-feat{display:flex;align-items:center;gap:11px;font-size:13.5px;color:#CFE0F2}
.auth-feat i[data-lucide]{width:18px;height:18px;color:var(--ai);flex:0 0 auto}
.auth-right{display:flex;align-items:center;justify-content:center;padding:40px 32px;background:var(--bg)}
.auth-card{width:100%;max-width:380px}
.auth-card .acard-brand{display:none}
.auth-card h1{font-size:24px;font-weight:800;letter-spacing:-.02em}
.auth-card .asub{color:var(--sub);font-size:13.5px;margin:6px 0 22px}
.auth-foot{margin-top:40px;font-size:11.5px;color:var(--sub2);text-align:center;line-height:1.7}
@media (max-width:880px){
  .auth-split{grid-template-columns:1fr}
  .auth-left{display:none}
  .auth-right{min-height:100vh}
  .auth-card .acard-brand{display:flex;justify-content:center;margin-bottom:18px}
}

/* ─────────────────────────── Utilities ─────────────────────────── */
.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}
.mb0{margin-bottom:0}.mb8{margin-bottom:8px}.mb16{margin-bottom:16px}
.mut{color:var(--sub)}.right{text-align:right}.center{text-align:center}
.flex{display:flex}.flex-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.flex-c{display:flex;align-items:center;gap:8px}.wrap{flex-wrap:wrap}.gap8{gap:8px}.gap12{gap:12px}
.fz12{font-size:12px}.fz13{font-size:13px}.b{font-weight:700}
.hide{display:none}

/* ─────────────────────────── Responsive ─────────────────────────── */
@media (max-width:1080px){
  .g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr}
}
@media (max-width:860px){
  :root{--side-w:0px}
  .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}
  .g2{grid-template-columns:1fr}.g4{grid-template-columns:1fr}
  .tb-search{display:none}
  .page-h h1{font-size:21px}
  .user-chip .who{display:none}
}

/* ─── KAI 공용 입력 포맷터 ─── */
.kai-rate-warn{border-color:var(--warn)!important;background:var(--warn-soft)!important;color:var(--warn)!important}
.dropzone{border:1.5px dashed var(--line);border-radius:var(--r-sm);padding:22px;text-align:center;color:var(--sub);
  background:var(--surface);cursor:pointer;transition:.15s}
.dropzone:hover,.dropzone.drag{border-color:var(--point);background:var(--point-soft);color:var(--point)}
.dropzone i[data-lucide]{width:30px;height:30px;stroke-width:1.5;margin-bottom:8px;color:var(--sub2)}
.dropzone.drag i[data-lucide]{color:var(--point)}
.dropzone .dz-h{font-weight:700;color:var(--ink);font-size:14px;margin-bottom:3px}
.dropzone .dz-s{font-size:12px}
.prog{height:6px;border-radius:4px;background:var(--surface);overflow:hidden;margin-top:10px}
.prog>i{display:block;height:100%;background:var(--point);width:0;transition:width .3s}
.same-as{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--sub);font-weight:600;cursor:pointer}

/* ─── 딜보드 카드 그리드 (v3.0) ─── */
.board-kpi{display:grid;grid-template-columns:repeat(8,1fr);gap:12px}
@media(max-width:1100px){.board-kpi{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.board-kpi{grid-template-columns:repeat(2,1fr)}}
.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:14px}
.deal-card2 .dc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:4px 0 8px;
  padding:8px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.deal-card2 .dc-metrics>div{text-align:center}
.deal-card2 .dc-metrics span{display:block;font-size:10.5px;color:var(--sub);margin-bottom:2px}
.deal-card2 .dc-metrics b{font-size:13px;font-weight:800;color:var(--ink)}
.deal-card2{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px;
  text-decoration:none;color:var(--ink);transition:.15s;box-shadow:var(--shadow-sm)}
.deal-card2:hover{border-color:var(--point);box-shadow:var(--shadow);transform:translateY(-2px)}
.deal-card2 .dc-name{font-weight:700;font-size:15px;margin:8px 0 6px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:40px}
.deal-card2 .dc-amt{font-weight:800;font-size:17px;color:var(--point);margin-bottom:8px}
.deal-card2 .kv2{display:flex;justify-content:space-between;font-size:12.5px;padding:2px 0;color:var(--sub)}
.deal-card2 .kv2 span:last-child{color:var(--ink);font-weight:600}
.deal-card2 .dc-prog{display:flex;align-items:center;gap:8px;margin-top:10px}
.deal-card2 .dc-prog .prog{flex:1}

/* ─── 딜분석 개요 스코어카드 (v3.0) ─── */
.scorecard{background:linear-gradient(160deg,var(--navy,#0E2A47),#16365C);color:#fff;border-radius:var(--r);padding:20px 22px;position:relative;overflow:hidden}
.scorecard:before{content:"";position:absolute;right:-50px;top:-50px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.22),transparent 70%)}
.scorecard .sc-head{display:flex;align-items:center;justify-content:space-between;position:relative}
.scorecard .sc-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9DB2CC;font-weight:700}
.scorecard .sc-grade{display:flex;align-items:center;gap:10px}
.scorecard .sc-grade .g{font-size:32px;font-weight:900;letter-spacing:-.03em}
.scorecard .sig{font-size:11px;font-weight:800;padding:5px 11px;border-radius:20px}
.scorecard .sig.green{background:rgba(5,150,105,.25);color:#6EE7B7}
.scorecard .sig.amber{background:rgba(217,119,6,.25);color:#FCD34D}
.scorecard .sig.red{background:rgba(220,38,38,.25);color:#FCA5A5}
.scorecard .sig.ink{background:rgba(255,255,255,.14);color:#C4D2E6}
.scorecard .sc-gauges{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px;position:relative}
.scorecard .sc-gauges>div{text-align:center;background:rgba(255,255,255,.06);border-radius:10px;padding:12px 6px}
.scorecard .sc-gauges .gv{font-size:21px;font-weight:800}
.scorecard .sc-gauges .gl{font-size:11px;color:#9DB2CC;margin-top:3px;font-weight:600}
.scorecard .sc-foot{display:flex;gap:14px;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);position:relative;flex-wrap:wrap}
.scorecard .sc-foot>div{flex:1;min-width:80px}
.scorecard .sc-foot .k{font-size:11px;color:#9DB2CC}
.scorecard .sc-foot .v{font-size:16px;font-weight:800;margin-top:3px}

/* ─── 딜분석 카드 그리드 (한 줄 5개 · 1440 폭 기준 · 깨짐 방지) ─── */
.deal-grid-5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}
@media(max-width:1280px){.deal-grid-5{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1040px){.deal-grid-5{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){.deal-grid-5{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.deal-grid-5{grid-template-columns:minmax(0,1fr)}}
.apager{display:flex;gap:4px;flex-wrap:wrap}
.apager .pg{min-width:32px;height:32px;padding:0 8px;border:1px solid var(--line);background:var(--card);
  border-radius:8px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.apager .pg:hover:not(:disabled){border-color:var(--point)}
.apager .pg.on{background:var(--point);border-color:var(--point);color:#fff}
.apager .pg:disabled{opacity:.4;cursor:default}

/* ─── 엔진 상태 모니터링 (시스템관리 > 엔진 상태) ─── */
:root{ --amber2:#EA580C; }
.eng-grid2{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1100px){.eng-grid2{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.eng-grid2{grid-template-columns:1fr}}
.eng-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 17px;
  text-decoration:none;color:var(--ink);transition:.15s;box-shadow:var(--shadow-sm)}
.eng-card:hover{border-color:var(--point);box-shadow:var(--shadow);transform:translateY(-2px)}
.eng-card .kv2{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;padding:3px 0;color:var(--sub)}
.eng-card .kv2 b,.eng-card .kv2 span:last-child{color:var(--ink);font-weight:600}
.led-dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex:none;box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.led-green{background:#16A34A;box-shadow:0 0 0 3px rgba(22,163,74,.16)}
.led-amber{background:#D97706;box-shadow:0 0 0 3px rgba(217,119,6,.16)}
.led-red{background:#DC2626;box-shadow:0 0 0 3px rgba(220,38,38,.16)}
.led-gray{background:#94A3B8;box-shadow:0 0 0 3px rgba(148,163,184,.16)}
.flex-c.gap10{gap:10px}
.flex-c.gap6{gap:6px} .gap6{gap:6px}

/* ─── 상세분석 탭 (화이트 스코어카드 · FVA/밸류 3분할 · 게이지) ─── */
.score-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.stile{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 12px;text-align:center}
.stile.grade{background:var(--ok-soft,#ECFDF5);border-color:#A7F3D0}
.stile .t-k{font-size:12px;color:var(--sub);font-weight:600}
.stile .t-v{font-size:21px;font-weight:800;margin:6px 0 8px}
.stile .t-bar{height:4px;border-radius:4px;background:var(--line);overflow:hidden}
.stile .t-bar i{display:block;height:100%;background:var(--point);border-radius:4px}
.stile .t-bar.green i{background:#16A34A}
.score-risks{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}
.rtile{text-align:center}
.rtile .r-k{font-size:12.5px;color:var(--sub)}
.rtile .r-v{font-size:18px;font-weight:800;margin:4px 0 2px}
.rtile .r-l{font-size:12px;font-weight:700}
.section-h{font-size:16px;font-weight:800;margin:18px 0 4px;display:flex;align-items:center;gap:8px}
.section-h .num{color:var(--point)}
.analyze3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:980px){.analyze3{grid-template-columns:1fr}}
.a3-h{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);font-weight:700;margin-bottom:12px}
.a3-run{display:flex;flex-direction:column}
.up-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.up-row:last-child{border-bottom:none}
.up-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;background:var(--bg)}
.up-ic.red{color:#DC2626;background:#FEF2F2} .up-ic.green{color:#16A34A;background:#ECFDF5}
.up-ic.blue{color:var(--point);background:#EFF6FF}
.up-ic i{width:17px;height:17px}
.up-info{flex:1;min-width:0}
.run-ill{width:74px;height:74px;border-radius:14px;background:var(--bg);display:grid;place-items:center;margin:8px auto 4px;color:var(--sub2,#94A3B8)}
.run-ill i{width:34px;height:34px}
.rtabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}
.rtab{padding:5px 10px;border:1px solid var(--line);background:var(--card);border-radius:7px;font-size:12px;font-weight:600;color:var(--sub);cursor:pointer}
.rtab.on{background:var(--point);border-color:var(--point);color:#fff}
.gauge-donut{width:108px;height:108px;border-radius:50%;display:grid;place-items:center;flex:none}
.gd-hole{width:78px;height:78px;border-radius:50%;background:var(--card);display:grid;place-items:center;text-align:center}
.gd-v{font-size:19px;font-weight:800} .gd-l{font-size:11px;color:var(--sub)}

/* 5칸 KPI 그리드 */
.grid.g5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1100px){.grid.g5{grid-template-columns:repeat(2,1fr)}}

/* 카드 내부 overflow 안전(좁은 폭에서도 깨지지 않게) */
.deal-grid-5 .deal-card2{min-width:0}
.deal-grid-5 .deal-card2 .flex-between>span:first-child{min-width:0;word-break:break-all}
.deal-grid-5 .deal-card2 .dc-metrics b{white-space:nowrap}

/* ─── 딜관리 입력 폼 · 완료율 ─── */
.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
@media(max-width:640px){.form-grid2{grid-template-columns:1fr}}
.comp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:760px){.comp-grid{grid-template-columns:repeat(2,1fr)}}
.comp .prog{height:7px}

/* ─── 대시보드 그리드 (KPI 6 · 하단 2단) ─── */
.g6{grid-template-columns:repeat(6,minmax(0,1fr))}
@media(max-width:1200px){.g6{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:680px){.g6{grid-template-columns:repeat(2,minmax(0,1fr))}}
.dash-2col{grid-template-columns:1.6fr 1fr}
@media(max-width:980px){.dash-2col{grid-template-columns:1fr}}
.dash-row{margin-top:16px}

/* ===== v3.2 딜관리 7탭 추가 스타일 (additive) ===== */
.savebar{position:sticky;bottom:0;margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:12px 16px;box-shadow:0 -2px 10px rgba(0,0,0,.03)}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:8px}
.photo-cell{position:relative;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:var(--surface);aspect-ratio:4/3}
.photo-cell img{width:100%;height:100%;object-fit:cover;display:block}
.photo-cell .photo-ph{width:100%;height:100%;display:grid;place-items:center;color:var(--sub2)}
.photo-cell .photo-ph i[data-lucide]{width:30px;height:30px}
.photo-cell .photo-del{position:absolute;top:6px;right:6px}
.photo-cell .photo-cap{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));
  color:#fff;font-size:11px;font-weight:600;padding:14px 8px 6px}
.import-row{gap:10px}
.import-card{display:flex}
.import-card .dropzone{width:100%;margin:0}

/* ============================================================================
   KAI Design Samples — 샘플 전용 보강 (additive · 서비스 적용 시 선택)
   ============================================================================ */
/* 로그인 좌측 비주얼라이저 (막대 애니메이션) */
.auth-viz{display:flex;align-items:flex-end;gap:8px;height:92px;margin:6px 0 28px}
.auth-viz i{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--ai),rgba(14,165,233,.25));
  animation:vizPulse 2.4s ease-in-out infinite;opacity:.9}
@keyframes vizPulse{0%,100%{transform:scaleY(.55)}50%{transform:scaleY(1)}}
.auth-viz i{transform-origin:bottom}
/* 로그인 카드 폭 살짝 확장 */
.auth-card .fields{margin-top:6px}
/* 서비스 스위처(샘플): 좌상단 브랜드 옆 작은 태그 */
.svc-tag{font-size:9.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 7px;border-radius:6px;background:var(--point-soft);color:var(--point);margin-left:6px}
/* 미니 도넛 (분석 샘플) */
.mini-donut{--p:0;width:120px;height:120px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:conic-gradient(var(--point) calc(var(--p)*1%),var(--surface) 0)}
.mini-donut .hole{width:84px;height:84px;border-radius:50%;background:var(--card);display:grid;place-items:center;text-align:center}
.mini-donut .hv{font-size:22px;font-weight:800;line-height:1}.mini-donut .hl{font-size:11px;color:var(--sub);margin-top:3px}
/* 라인 스파크라인(샘플 SVG 보조) */
.spark-svg{width:100%;height:60px;display:block}
/* 색상 팔레트 스와치(디자인 토큰 가이드용) */
.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.sw{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:var(--card)}
.sw .chip{height:54px}.sw .meta{padding:8px 10px}
.sw .meta b{font-size:12.5px;font-weight:700;display:block}.sw .meta span{font-size:11px;color:var(--sub);font-family:var(--mono)}
