/* ============================================================
   KI Chatbot – Frontend Widget Styles
   All rules use !important to prevent theme CSS overrides.
   ============================================================ */

/* ── POSITION ──────────────────────────────────────────────── */
#tdai-container.tdai-pos-left  { left: 20px !important; right: auto !important; }
#tdai-container.tdai-pos-right { right: 20px !important; left: auto !important; }

#tdai-launcher.tdai-btn-left  { left: 20px !important; right: auto !important; }
#tdai-launcher.tdai-btn-right { right: 20px !important; left: auto !important; }

/* ── CHAT CONTAINER ────────────────────────────────────────── */
#tdai-container {
    position: fixed !important;
    bottom: 20px !important;
    width: 360px !important;
    height: 520px !important;
    background: #ffffff !important;
    border-radius: 14px !important;
    display: none !important;
    flex-direction: column !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.08) !important;
    overflow: hidden !important;
    z-index: 99999 !important;
    transform-origin: bottom right !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #1e293b !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

#tdai-container.tdai-open {
    display: flex !important;
}

#tdai-container.tdai-pos-left {
    transform-origin: bottom left !important;
}

/* ── ANIMATIONS ────────────────────────────────────────────── */
@keyframes tdaiShrink {
    to { transform: scale(0.1); opacity: 0; }
}
.tdai-closing {
    animation: tdaiShrink 0.15s ease forwards !important;
}

@keyframes tdaiOpen {
    from { transform: scale(0.85); opacity: 0; }
    to   { transform: scale(1);    opacity: 1; }
}
.tdai-opening {
    animation: tdaiOpen 0.18s cubic-bezier(0.34, 1.56, 0.64, 1) forwards !important;
}

/* ── HEADER ────────────────────────────────────────────────── */
#tdai-header {
    color: #fff !important;
    padding: 14px 16px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    border: none !important;
    border-radius: 0 !important;
}

.tdai-header-left {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

/* Logo – full display, no crop */
.tdai-header-left img {
    max-width: 100px !important;
    max-height: 36px !important;
    width: auto !important;
    height: auto !important;
    border-radius: 6px !important;
    object-fit: contain !important;
    border: none !important;
}

.tdai-logo-placeholder {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,0.25) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
}

.tdai-logo-placeholder svg,
.tdai-header-bot-icon svg {
    display: block !important;
}

/* Header icon buttons */
.tdai-header-icons {
    display: flex !important;
    gap: 4px !important;
}

.tdai-icon-btn {
    width: 30px !important;
    height: 30px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,0.18) !important;
    border: none !important;
    color: #fff !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.18s, transform 0.12s !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    box-shadow: none !important;
    outline: none !important;
}

.tdai-icon-btn:hover {
    background: rgba(255,255,255,0.32) !important;
    transform: scale(1.1) !important;
}

.tdai-icon-btn:active {
    transform: scale(0.95) !important;
}

/* ── INFO MODAL ────────────────────────────────────────────── */
#tdai-info-modal {
    position: absolute !important;
    top: 60px !important;
    right: 12px !important;
    width: 290px !important;
    max-height: 320px !important;
    overflow-y: auto !important;
    padding: 14px 16px !important;
    background: #fff !important;
    border-radius: 12px !important;
    box-shadow: 0 6px 24px rgba(0,0,0,0.14) !important;
    display: none !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #333 !important;
    z-index: 100000 !important;
    border: none !important;
    margin: 0 !important;
}

#tdai-info-modal.tdai-modal-open {
    display: block !important;
}

#tdai-info-modal a {
    color: inherit !important;
    text-decoration: underline !important;
}

/* ── THEME BUTTON ──────────────────────────────────────────── */
/* In light mode → show moon (to switch to dark) */
#tdai-theme-btn .tdai-icon-sun  { display: none !important; }
#tdai-theme-btn .tdai-icon-moon { display: flex !important; }

/* In dark mode → show sun (to switch to light) */
#tdai-container.tdai-dark #tdai-theme-btn .tdai-icon-sun  { display: flex !important; }
#tdai-container.tdai-dark #tdai-theme-btn .tdai-icon-moon { display: none !important; }

/* ── CHAT BODY ─────────────────────────────────────────────── */
#tdai-body {
    flex: 1 !important;
    padding: 14px !important;
    overflow-y: auto !important;
    font-size: 13.5px !important;
    line-height: 1.5 !important;
    scroll-behavior: smooth !important;
    background: #fff !important;
    margin: 0 !important;
    border: none !important;
}

#tdai-body::-webkit-scrollbar { width: 4px !important; }
#tdai-body::-webkit-scrollbar-thumb { background: #ddd !important; border-radius: 4px !important; }

/* ── BUBBLES ───────────────────────────────────────────────── */
@keyframes tdaiBubble {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.bubble-bot,
.bubble-user {
    font-size: 13.5px !important;
    line-height: 1.55 !important;
    padding: 10px 13px !important;
    border-radius: 14px !important;
    max-width: 84% !important;
    margin-bottom: 10px !important;
    animation: tdaiBubble 0.22s ease !important;
    word-break: break-word !important;
    display: block !important;
    font-family: inherit !important;
}

.bubble-bot {
    color: #fff !important;
    border-top-left-radius: 4px !important;
    margin-right: auto !important;
    margin-left: 0 !important;
}

.bubble-user {
    color: #222 !important;
    border-top-right-radius: 4px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
}

/* ── MARKDOWN INSIDE BOT BUBBLES ───────────────────────────── */
.bubble-bot p  { margin: 0 0 8px !important; }
.bubble-bot p:last-child { margin-bottom: 0 !important; }

.bubble-bot h1,
.bubble-bot h2,
.bubble-bot h3,
.bubble-bot h4 {
    font-size: 14px !important;
    font-weight: 700 !important;
    margin: 10px 0 5px !important;
    color: inherit !important;
    line-height: 1.3 !important;
    border: none !important;
    padding: 0 !important;
}

.bubble-bot h1 { font-size: 15px !important; }

.bubble-bot ul,
.bubble-bot ol {
    margin: 6px 0 6px 16px !important;
    padding: 0 !important;
}

.bubble-bot li {
    margin-bottom: 4px !important;
    line-height: 1.5 !important;
}

.bubble-bot strong,
.bubble-bot b {
    font-weight: 700 !important;
    color: inherit !important;
}

.bubble-bot em,
.bubble-bot i {
    font-style: italic !important;
    color: inherit !important;
}

.bubble-bot code {
    background: rgba(0,0,0,0.18) !important;
    border-radius: 4px !important;
    padding: 1px 5px !important;
    font-family: 'SF Mono', 'Fira Code', monospace !important;
    font-size: 12px !important;
    color: inherit !important;
}

.bubble-bot pre {
    background: rgba(0,0,0,0.2) !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    margin: 8px 0 !important;
    overflow-x: auto !important;
    font-size: 12px !important;
}

.bubble-bot pre code {
    background: none !important;
    padding: 0 !important;
}

.bubble-bot hr {
    border: none !important;
    border-top: 1px solid rgba(255,255,255,0.3) !important;
    margin: 8px 0 !important;
}

.bubble-bot a { color: rgba(255,255,255,0.88) !important; text-decoration: underline !important; }

/* Clear animation */
@keyframes tdaiClear {
    from { opacity: 1; transform: translateY(0); }
    to   { opacity: 0; transform: translateY(10px); }
}
.tdai-clearing {
    animation: tdaiClear 0.28s ease forwards !important;
}

/* ── TYPING INDICATOR ──────────────────────────────────────── */
.tdai-typing {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    background: #ebebeb !important;
    padding: 10px 13px !important;
    border-radius: 14px !important;
    border-top-left-radius: 4px !important;
    width: fit-content !important;
    margin-bottom: 10px !important;
}

.tdai-typing-dot {
    width: 7px !important;
    height: 7px !important;
    border-radius: 50% !important;
    background: #999 !important;
    animation: tdaiTyping 1.3s infinite ease-in-out !important;
    display: block !important;
}

.tdai-typing-dot:nth-child(2) { animation-delay: 0.18s !important; }
.tdai-typing-dot:nth-child(3) { animation-delay: 0.36s !important; }

@keyframes tdaiTyping {
    0%   { opacity: 0.25; transform: translateY(0); }
    50%  { opacity: 1;    transform: translateY(-4px); }
    100% { opacity: 0.25; transform: translateY(0); }
}

/* ── FOOTER ────────────────────────────────────────────────── */
#tdai-footer {
    padding: 10px 12px !important;
    border-top: 1px solid #e8e8e8 !important;
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
    background: #fff !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

#tdai-input {
    flex: 1 !important;
    padding: 9px 12px !important;
    border-radius: 9px !important;
    border: 1.5px solid #e0e0e0 !important;
    font-size: 13px !important;
    outline: none !important;
    transition: border-color 0.18s !important;
    font-family: inherit !important;
    background: #fafafa !important;
    color: #1e293b !important;
    box-shadow: none !important;
    margin: 0 !important;
}

#tdai-input:focus {
    border-color: #08d8d6 !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(8,216,214,0.12) !important;
}

#tdai-send {
    border: none !important;
    color: #fff !important;
    padding: 9px 18px !important;
    border-radius: 9px !important;
    cursor: pointer !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    transition: opacity 0.18s, transform 0.12s !important;
    white-space: nowrap !important;
    box-shadow: none !important;
    outline: none !important;
    margin: 0 !important;
    line-height: 1 !important;
}

#tdai-send:hover  { opacity: 0.88 !important; }
#tdai-send:active { transform: scale(0.96) !important; }
#tdai-send:disabled { opacity: 0.5 !important; cursor: not-allowed !important; }

/* ── LAUNCHER BUTTON ───────────────────────────────────────── */
#tdai-launcher {
    position: fixed !important;
    bottom: 20px !important;
    width: 62px !important;
    height: 62px !important;
    border-radius: 50% !important;
    border: none !important;
    cursor: pointer !important;
    z-index: 99998 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: box-shadow 0.2s, transform 0.15s !important;
    color: #fff !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    outline: none !important;
    text-decoration: none !important;
}

#tdai-launcher:hover {
    box-shadow: 0 0 0 6px rgba(8,216,214,0.2) !important;
    transform: scale(1.07) !important;
}

#tdai-launcher:active { transform: scale(0.95) !important; }

@keyframes tdaiPulse {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.12); }
    100% { transform: scale(1); }
}
#tdai-launcher.tdai-pulse {
    animation: tdaiPulse 0.2s ease !important;
}

/* ── DARK MODE ─────────────────────────────────────────────── */
#tdai-container.tdai-dark {
    background: #1a1a2e !important;
    color: #e2e8f0 !important;
}

#tdai-container.tdai-dark #tdai-body {
    background: #1a1a2e !important;
    color: #e2e8f0 !important;
}

#tdai-container.tdai-dark #tdai-footer {
    background: #16213e !important;
    border-top-color: #2d3748 !important;
}

#tdai-container.tdai-dark #tdai-input {
    background: #2d3748 !important;
    border-color: #4a5568 !important;
    color: #e2e8f0 !important;
}

#tdai-container.tdai-dark #tdai-input::placeholder {
    color: #718096 !important;
}

#tdai-container.tdai-dark .tdai-typing {
    background: #2d3748 !important;
}

#tdai-container.tdai-dark .tdai-typing-dot {
    background: #718096 !important;
}

#tdai-container.tdai-dark .bubble-user {
    color: #e2e8f0 !important;
}

#tdai-container.tdai-dark #tdai-info-modal {
    background: #1e293b !important;
    color: #e2e8f0 !important;
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 480px) {
    #tdai-container,
    #tdai-container.tdai-pos-left,
    #tdai-container.tdai-pos-right {
        width: calc(100vw - 16px) !important;
        left: 8px !important;
        right: 8px !important;
        bottom: 86px !important;
        height: calc(100vh - 110px) !important;
        max-height: 520px !important;
        transform-origin: bottom center !important;
    }

    #tdai-launcher,
    #tdai-launcher.tdai-btn-left,
    #tdai-launcher.tdai-btn-right {
        bottom: 16px !important;
        right: 16px !important;
        left: auto !important;
    }
}
