/* 바른손카드 챗봇 위젯 */
/* 플로팅 버튼 */
.cb-toggle{position:fixed;bottom:104px;right:11px;width:58px;height:58px;border-radius:50%;background:#1baed4;color:#fff;border:none;font-size:20px;cursor:pointer;z-index:1000;box-shadow:0 4px 12px rgba(0,0,0,0.2);transition:all .2s}
.cb-toggle:hover{transform:scale(1.05)}

/* 챗봇 컨테이너 */
.cb-container{display:none;position:fixed;bottom:180px;right:24px;width:340px;height:620px;max-height:calc(100vh - 200px);border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,0.15);z-index:1000;overflow:hidden;flex-direction:column;background:#fff;font-family:'Noto Sans KR',-apple-system,sans-serif}
.cb-container.cb-open{display:flex}
.cb-container *,.cb-container *::before,.cb-container *::after{box-sizing:border-box;margin:0;padding:0}

/* 모바일 */
@media(max-width:480px){
  .cb-container{bottom:170px;right:12px;width:calc(100vw - 24px);max-width:320px;height:55vh}
  .cb-toggle{bottom:96px;right:10px;width:54px;height:54px;font-size:18px}
}

/* 변수 */
.cb-container{
  --bg:#f5f5f5;--chat-bg:#fff;--primary:#111;--primary-light:#333;
  --accent:#1baed4;--accent-soft:#b8e8f0;--text:#222;--text-light:#888;
  --bubble-bot:#f5f5f5;--bubble-user:#111;--border:#eee;--shadow:rgba(0,0,0,.08);
  color:var(--text);line-height:1.6;font-size:13px;
}

/* 헤더 */
.cb-header{padding:14px 16px;background:var(--primary);color:#fff;flex-shrink:0}
.cb-header h1{font-size:15px;font-weight:600;letter-spacing:-.3px;margin:0}
.cb-header p{font-size:11px;color:var(--accent-soft);margin-top:2px;font-weight:300}

/* 브레드크럼 */
.cb-bc{padding:6px 12px;background:#faf8f5;border-bottom:1px solid var(--border);flex-shrink:0;display:none;align-items:center;gap:4px;font-size:10.5px;color:var(--text-light);overflow-x:auto;white-space:nowrap}
.cb-bc.cb-on{display:flex}
.cb-bc span{cursor:pointer;transition:color .15s}
.cb-bc span:hover{color:var(--accent)}
.cb-bc span.cb-cur{color:var(--text);font-weight:500;cursor:default}
.cb-bc .cb-s{color:var(--border);cursor:default;font-size:10px}

/* 바디 (스크롤 영역) */
.cb-body{flex:1;overflow-y:auto;padding:14px 12px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.cb-body::-webkit-scrollbar{width:4px}
.cb-body::-webkit-scrollbar-track{background:transparent}
.cb-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

/* 메시지 */
.cb-msg{display:flex;gap:8px;margin-bottom:16px;animation:cbFadeUp .3s ease-out}
@keyframes cbFadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.cb-msg.cb-bot{justify-content:flex-start}
.cb-msg.cb-user{justify-content:flex-end}
.cb-av{width:26px;height:26px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;margin-top:2px;color:#fff}
.cb-bub{max-width:85%;padding:10px 12px;border-radius:14px;font-size:12.5px;line-height:1.6;word-break:keep-all;overflow-wrap:break-word}
.cb-bot .cb-bub{background:var(--bubble-bot);border:1px solid var(--border);border-top-left-radius:4px}
.cb-user .cb-bub{background:var(--bubble-user);color:#fff;border-top-right-radius:4px}

/* 카테고리 그리드 */
.cb-cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:10px}
.cb-cat-btn{display:flex;align-items:center;gap:6px;padding:9px 10px;background:#fff;border:1px solid var(--border);border-radius:10px;font-size:11.5px;font-family:inherit;color:var(--text);cursor:pointer;transition:all .15s;text-align:left;font-weight:500}
.cb-cat-btn:hover{border-color:var(--accent);background:#fffcf7}
.cb-cat-btn:active{transform:scale(.97)}

/* 서브 리스트 */
.cb-sub-list{display:flex;flex-direction:column;gap:5px;margin-top:8px}
.cb-sub-btn{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:12px;font-family:inherit;color:var(--text);cursor:pointer;transition:all .15s;text-align:left;font-weight:500}
.cb-sub-btn:hover{border-color:var(--accent);background:#fffcf7}
.cb-sub-btn:active{transform:scale(.97)}
.cb-sub-btn .cb-arr{font-size:11px;color:var(--text-light);flex-shrink:0;margin-left:8px}

/* FAQ 리스트 */
.cb-faq-list{margin-top:10px}
.cb-faq{border:1px solid var(--border);border-radius:8px;margin-bottom:5px;overflow:hidden;background:#fff;transition:border-color .2s}
.cb-faq:hover{border-color:var(--accent-soft)}
.cb-faq-q{padding:10px 12px;font-size:12px;font-weight:500;cursor:pointer;display:flex;flex-wrap:wrap;align-items:center;gap:6px;transition:background .15s;line-height:1.5}
.cb-faq-q>span:first-child{flex:1;min-width:0}
.cb-faq-q:hover{background:#faf8f5}
.cb-faq-q .cb-arr{font-size:10px;color:var(--text-light);transition:transform .25s;flex-shrink:0;margin-top:3px}
.cb-faq-q.cb-on .cb-arr{transform:rotate(180deg)}
.cb-faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s ease;font-size:11.5px;line-height:1.7;color:var(--primary-light);white-space:pre-wrap;padding:0 12px;border-top:0 solid var(--border)}
.cb-faq-a.cb-on{max-height:1200px;padding:12px;border-top:1px solid var(--border)}
.cb-faq-a a{word-break:break-all}

/* 검색 */
.cb-search-wrap{margin-top:10px;position:relative}
.cb-search-input{width:100%;padding:8px 30px 8px 32px;border:1px solid var(--border);border-radius:8px;font-size:11.5px;font-family:inherit;color:var(--text);background:#fff;outline:none;transition:border-color .15s}
.cb-search-input:focus{border-color:var(--accent)}
.cb-search-input::placeholder{color:var(--text-light)}
.cb-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-light)}
.cb-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--text-light);cursor:pointer;display:none;background:none;border:none;padding:2px}
.cb-search-clear.cb-on{display:block}

/* 액션 버튼 */
.cb-actions{display:flex;gap:6px;margin-top:10px}
.cb-act{flex:1;padding:8px;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:11.5px;font-family:inherit;color:var(--primary-light);cursor:pointer;transition:all .15s;font-weight:500;text-align:center}
.cb-act:hover{border-color:var(--accent);color:var(--primary)}
.cb-act.cb-pri{background:var(--primary);color:#fff;border-color:var(--primary)}
.cb-act.cb-pri:hover{background:var(--primary-light)}

/* 기타 */
.cb-no-result{padding:16px;text-align:center;color:var(--text-light);font-size:11.5px}
.cb-tag{font-size:9px;color:var(--accent);background:var(--accent-soft);padding:2px 6px;border-radius:4px;flex-shrink:0;white-space:nowrap;margin-left:6px}
.cb-copy-btn{display:block;margin-top:8px;padding:4px 10px;border:1px solid var(--border);border-radius:6px;font-size:10px;color:var(--text-light);cursor:pointer;background:#fff;font-family:inherit;transition:all .15s}
.cb-copy-btn:hover{border-color:var(--accent);color:var(--accent)}
.cb-typing{display:flex;gap:4px;padding:8px 0}
.cb-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-light);animation:cbBlink 1.2s infinite}
.cb-typing span:nth-child(2){animation-delay:.2s}
.cb-typing span:nth-child(3){animation-delay:.4s}
@keyframes cbBlink{0%,60%,100%{opacity:.3}30%{opacity:1}}
.cb-scroll-top{position:absolute;bottom:50px;right:12px;width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:14px;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:10}
.cb-scroll-top.cb-on{display:flex}

/* 푸터 */
.cb-footer{padding:10px 12px 12px;border-top:1px solid var(--border);flex-shrink:0;background:var(--chat-bg)}
.cb-footer p{font-size:10px;color:var(--text-light);text-align:center;line-height:1.5;margin:0}
.cb-footer a{color:var(--accent);text-decoration:none}
