/* ====== Smart BI 챗 ====== */
.chat-view{display:flex;height:100%;min-height:0;position:relative;overflow:hidden;}
.chat-main{flex:1;min-width:0;display:flex;flex-direction:column;}
.chat-ds-bar{display:flex;align-items:center;gap:12px;padding:12px 24px;border-bottom:1px solid var(--line);background:var(--surface);}
.chat-ds-bar .lab{font-size:12px;color:var(--ink-3);font-weight:600;}
.ds-select{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;font-size:13px;font-weight:600;color:var(--ink-1);cursor:pointer;transition:.13s;}
.ds-select:hover{border-color:var(--blue-400);box-shadow:var(--sh-1);}
.ds-select .chev{display:flex;color:var(--ink-3);transition:transform .2s;}
.ds-select .chev svg{width:14px;height:14px;}
.ds-select.open .chev{transform:rotate(180deg);}
.ds-select svg{width:16px;height:16px;color:var(--blue-600);}
.ds-select .meta{font-weight:400;color:var(--ink-3);font-size:11.5px;margin-left:2px;}
.ds-select .arr{color:var(--ink-3);margin-left:2px;}

.chat-scroll{flex:1;overflow:auto;min-height:0;padding:26px 0;}
.chat-inner{max-width:760px;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;gap:22px;}

.chat-empty{max-width:680px;margin:auto;padding:40px 24px;text-align:center;}
.chat-empty .orb{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,#2E6BE0,#5B8DEF);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 24px rgba(46,107,224,.32);}
.chat-empty .orb svg{width:30px;height:30px;color:#fff;}
.chat-empty h2{font-size:22px;font-weight:700;letter-spacing:-.4px;margin:0 0 8px;}
.chat-empty p{color:var(--ink-3);font-size:14px;margin:0 0 26px;}
.suggest-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left;}
.suggest-card{display:flex;align-items:flex-start;gap:11px;padding:15px 16px;border:1px solid var(--line);border-radius:12px;background:var(--surface);transition:.14s;}
.suggest-card:hover{border-color:var(--blue-400);box-shadow:var(--sh-2);transform:translateY(-1px);}
.suggest-card .ic{width:30px;height:30px;border-radius:8px;background:var(--blue-50);color:var(--blue-600);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.suggest-card .ic svg{width:16px;height:16px;}
.suggest-card .tx{font-size:13px;color:var(--ink-1);font-weight:500;line-height:1.4;}

/* 데이터셋 원본 미리보기 (슬라이드 다운) */
.ds-preview{overflow:hidden;max-height:0;opacity:0;transition:max-height .32s cubic-bezier(.2,.8,.3,1),opacity .22s ease;background:var(--surface);border-bottom:1px solid transparent;flex:0 0 auto;}
.ds-preview.open{max-height:360px;opacity:1;border-bottom-color:var(--line);}
.ds-preview-inner{padding:14px 24px 18px;}
.ds-preview-head{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);margin-bottom:10px;}
.ds-preview-head svg{width:15px;height:15px;color:var(--blue-600);flex:0 0 auto;}
.ds-preview-head b{color:var(--ink-1);}
.ds-preview-head .meta{color:var(--ink-3);font-size:11.5px;}
.ds-preview-head .x{margin-left:auto;width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);}
.ds-preview-head .x:hover{background:var(--line-soft);color:var(--ink-1);}
.ds-preview-head .x svg{width:14px;height:14px;color:inherit;}
.ds-preview-tbl{border:1px solid var(--line);border-radius:10px;overflow:auto;max-height:248px;}

.msg{display:flex;gap:13px;}
.msg .ava{width:32px;height:32px;border-radius:9px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;}
.msg.user{flex-direction:row-reverse;}
.msg.user .bubble{background:var(--blue-600);color:#fff;border-radius:14px 14px 4px 14px;padding:11px 15px;font-size:14px;max-width:80%;}
.msg.user .ava{background:var(--navy-700);color:#fff;}
.msg.ai .ava{background:linear-gradient(135deg,#2E6BE0,#5B8DEF);color:#fff;}
.msg.ai .ava svg{width:17px;height:17px;}
.msg.ai .body{flex:1;min-width:0;}
.msg.ai .text{font-size:14px;color:var(--ink-1);line-height:1.6;}

.thinking{display:flex;align-items:center;gap:10px;color:var(--ink-3);font-size:13px;padding:4px 0;}
.thinking .dots{display:flex;gap:4px;}
.thinking .dots i{width:6px;height:6px;border-radius:50%;background:var(--blue-400);animation:bounce 1.2s infinite ease-in-out;}
.thinking .dots i:nth-child(2){animation-delay:.15s;}
.thinking .dots i:nth-child(3){animation-delay:.3s;}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.5;}30%{transform:translateY(-5px);opacity:1;}}

.result-card{margin-top:13px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--sh-1);overflow:hidden;position:relative;transition:.16s;}
.result-card:hover{box-shadow:var(--sh-2);border-color:#D3DAE6;}
.result-card-head{display:flex;align-items:center;gap:10px;padding:14px 16px 11px;}
.result-card-head .vic{width:30px;height:30px;border-radius:8px;background:var(--blue-50);color:var(--blue-600);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.result-card-head .vic svg{width:16px;height:16px;}
.result-card-head .t{font-size:14.5px;font-weight:700;color:var(--ink-1);}
.result-card-head .d{font-size:11.5px;color:var(--ink-3);margin-top:1px;}
.result-card-actions{margin-left:auto;display:flex;gap:6px;opacity:0;transform:translateY(-2px);transition:.16s;}
.result-card:hover .result-card-actions{opacity:1;transform:none;}
.result-card-body{padding:6px 18px 18px;}
.mini-view-toggle{display:flex;gap:3px;background:var(--line-soft);padding:3px;border-radius:8px;}
.mini-view-toggle button{width:28px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);}
.mini-view-toggle button svg{width:14px;height:14px;}
.mini-view-toggle button.active{background:#fff;color:var(--blue-600);box-shadow:var(--sh-1);}
.saved-flag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--pos);background:#E6F5EE;padding:4px 9px;border-radius:7px;}
.saved-flag svg{width:13px;height:13px;}

.composer{border-top:1px solid var(--line);background:var(--surface);padding:14px 24px 18px;}
.composer-inner{max-width:760px;margin:0 auto;}
.composer-box{display:flex;align-items:flex-end;gap:10px;border:1px solid var(--line);border-radius:14px;padding:10px 10px 10px 16px;background:#fff;transition:.14s;}
.composer-box:focus-within{border-color:var(--blue-400);box-shadow:0 0 0 3px var(--blue-50);}
.composer-box textarea{flex:1;border:none;resize:none;font-size:14px;line-height:1.5;max-height:120px;color:var(--ink-1);}
.composer-box textarea:focus{outline:none;}
.composer-send{width:38px;height:38px;border-radius:10px;background:var(--blue-600);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.13s;}
.composer-send:hover{background:#1750c2;}
.composer-send:disabled{background:#C3CCE0;}
.composer-send svg{width:18px;height:18px;}
.composer-hint{font-size:11px;color:var(--ink-4);text-align:center;margin-top:8px;}
.quick-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
.quick-chip{padding:6px 12px;border:1px solid var(--line);border-radius:20px;font-size:12px;color:var(--ink-2);background:#fff;transition:.12s;}
.quick-chip:hover{border-color:var(--blue-400);color:var(--blue-600);background:var(--blue-50);}

/* 우측 패널: 저장된 컴포넌트 (슬라이드 드로어) */
.chat-aside{position:absolute;top:0;right:0;bottom:0;width:320px;border-left:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;transform:translateX(103%);transition:transform .28s cubic-bezier(.2,.8,.3,1);box-shadow:-14px 0 36px rgba(16,32,64,.10);z-index:25;}
.chat-aside.open{transform:none;}
.chat-aside-head{padding:16px 18px 12px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:10px;}
.chat-aside-head .t{font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:8px;}
.chat-aside-head .t svg{width:16px;height:16px;color:var(--blue-600);flex:0 0 auto;}
.chat-aside-head .t .cnt{font-size:11px;background:var(--blue-50);color:var(--blue-600);padding:1px 8px;border-radius:10px;}
.chat-aside-head .s{font-size:11.5px;color:var(--ink-3);margin-top:3px;}
.chat-aside-head .x{margin-left:auto;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);flex:0 0 auto;}
.chat-aside-head .x:hover{background:var(--line-soft);color:var(--ink-1);}
.chat-aside-head .x svg{width:15px;height:15px;}
.chat-aside-list{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:9px;}
.lib-card{border:1px solid var(--line);border-radius:11px;padding:11px 12px;background:var(--surface);transition:.13s;cursor:pointer;text-align:left;width:100%;}
.lib-card:hover{border-color:var(--blue-400);box-shadow:var(--sh-1);}
.lib-card .top{display:flex;align-items:center;gap:8px;}
.lib-card .vic{width:26px;height:26px;border-radius:7px;background:var(--blue-50);color:var(--blue-600);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.lib-card .vic svg{width:14px;height:14px;}
.lib-card .t{font-size:12.5px;font-weight:600;color:var(--ink-1);line-height:1.3;}
.lib-card .meta{font-size:10.5px;color:var(--ink-4);margin-top:6px;display:flex;align-items:center;gap:6px;}
.lib-card .meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-4);}

/* 컴포넌트 저장 모달 / 미리보기 모달 */
.save-preview{border:1px solid var(--line);border-radius:12px;background:var(--surface-2);padding:12px 14px;height:188px;overflow:hidden;margin-bottom:18px;}
.preview-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-3);margin-bottom:14px;flex-wrap:wrap;}
.preview-meta svg{width:14px;height:14px;color:var(--blue-600);}
.preview-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-4);}
.preview-body{border:1px solid var(--line-soft);border-radius:12px;padding:14px 16px;max-height:380px;overflow:auto;background:var(--surface);}
