/* Base Container */
#hawx-coach-container {
    height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    border-left: 1px solid var(--form-background);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    flex: 1.25;
}

#hawx-coach-container.hide {
    display: none;
}

/* Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(5px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0% {
        opacity: 0;
    }

    50% {
        opacity: 0.1;
    }

    100% {
        opacity: 0;
    }
}

@keyframes pulseContent {
    0% {
        opacity: 0.6;
    }

    50% {
        opacity: 1;
    }

    100% {
        opacity: 0.6;
    }
}

/* Main Feed Area */
.main-feed {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    /* Allow container to shrink */
    background: var(--white);
    transition: margin-bottom 0.3s ease-out;
}

/* Messages Container */
.messages-container {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    gap: 0.75rem;
    display: flex;
    flex-direction: column;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    overflow-x: hidden;
}


/* Message Blocks */
.message-block {
    /* min-width: fit-content; */
    min-width: 85%;
    max-width: 85%;
    padding: 0.875rem 1rem 0.5rem;
    border-radius: 12px;
    position: relative;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    animation: fadeIn 0.2s ease-out;
}

/* Updating animation for highlighting changes */
.message-block.updating {
    animation: highlight 1s ease;
}

/* 
 * Coach SVG Icon Implementation
 * This CSS adds the Hawx Coach SVG icon to coach message blocks
 */

/* Base styling for all message block icons (only if not already implemented) */
.messages-container .message-block::before {
    content: "";
    position: absolute;
    bottom: -8px;

    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

/* Customer icon - keeping the letter "C" for now */
.messages-container .message-block.customer-block::before,
.customer-message::before {
    /* content: "C"; */
    background-color: var(--hawx-primary-color1);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M5 21C5 17.134 8.13401 14 12 14C15.866 14 19 17.134 19 21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z' stroke='%2326394a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    color: white;
    font-size: 12px;
    font-weight: bold;
    text-align: center;
    background-repeat: no-repeat;
    background-size: 20px;
    background-position: center;
    left: -8px;
}

/* Coach icon with SVG */
.messages-container .message-block.coach-block::before,
.coach-message::before {
    content: "✨";
    background-color: var(--white);
    border: 1px solid #0097e6;
    font-size: 20px;
    /* Gold color */
    /* SVG as background with the stroke color changed to white (#FFFFFF) */
    background-size: 70%;
    background-position: center;
    background-repeat: no-repeat;
    line-height: 26px;
    padding-bottom: 2px;
    height: 26px;
    right: -8px;
}

/* Agent icon */
.messages-container .message-block.agent-block::before,
.agent-message::before {
    background: var(--white);
    border: 1px solid #adebb3;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 17.5 17.5'%3E%3Cg transform='translate(0.75 0.75)'%3E%3Cg%3E%3Cpath d='M-3.339,14.3h0A3.479,3.479,0,0,0,0,10.961V6S-.257,0-5,0s-5,7-5,7' transform='translate(13 0)' fill='none' stroke='%23637675' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/path%3E%3Crect width='3' height='5' rx='1.5' stroke-width='1.5' fill='none' stroke='%23637675' stroke-miterlimit='10' transform='translate(13 5)'%3E%3C/rect%3E%3Crect width='3' height='5' rx='1.5' transform='translate(0 5)' fill='none' stroke='%23637675' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/rect%3E%3Cpath d='M1,0A1,1,0,0,0,0,1V2A1,1,0,0,0,1,3H2A1,1,0,0,0,3,2V1A1,1,0,0,0,2,0Z' transform='translate(7 13)' fill='none' stroke='%23637675' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/path%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    font-weight: bold;
    text-align: center;
    right: -8px;
    height: 26px;
    width: 26px;
    background-repeat: no-repeat;
    background-size: 20px;
    background-position: center;
}

/* Call Copilot icon */
.messages-container .message-block.call_copilot-block::before,
.call_copilot-message::before {
    content: "✨";
    background-color: var(--white);
    border: 1px solid #0097e6;
    font-size: 20px;
    /* Smaller font for two letters */
    font-weight: bold;
    text-align: center;
    line-height: 26px;
    padding-bottom: 2px;
    height: 26px;
    right: -8px;
}

/* Additional styling to ensure proper layout */
.messages-container .message-block {
    padding-bottom: 8px;
    /* Ensure space for the icon */
    position: relative;
    /* Ensure positioned elements work correctly */
}

/* Give message content padding to ensure it doesn't overlap with icon */
.messages-container .message-block .message-content {
    padding-bottom: 10px;
}

/* Make the timestamp appear above the icon when it's at the bottom right */
.message-block .timestamp {
    position: relative;
    z-index: 2;
}

/* Make sure the icon doesn't overlap with the timestamp */
.coach-block .timestamp,
.agent-block .timestamp,
.call_copilot-block .timestamp {
    margin-right: 12px;
}

@keyframes highlight {
    0% {
        background-color: rgba(255, 255, 0, 0.3);
    }

    100% {
        background-color: initial;
    }
}

.message-content .finalized-interim {
    color: #000;
    /* Fully visible */
}

.message-content .interim {
    color: #666;
    /* Slightly dimmed */
    font-style: italic;
}

.message-content .final-content {
    color: #000;
    /* Fully visible */
}

/* Add a subtle visual indicator for blocks still receiving updates */
.message-block:not(:has(.final-content)) {
    border-left: 3px solid #ccc;
}

.customer-block,
.user-block {
    align-self: flex-start;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    margin-right: 15%;
}

.coach-block,
.assistant-block {
    align-self: flex-end;
    background: #e3f2fd;
    margin-left: 15%;
    border: 1px solid rgba(33, 150, 243, 0.2);
}

/* Agent block styles */
.agent-block {
    align-self: flex-end;
    background: #cbf8cf;
    border: 1px solid #adebb3;
    margin-left: 15%;
}

/* Call Copilot block styles (similar to coach block but with different colors) */
.call_copilot-block {
    align-self: flex-end;
    background: #e3f2fd;
    /* Same as coach for now */
    margin-left: 15%;
    border: 1px solid rgba(33, 150, 243, 0.2);
}

/* Stream content styles */
.stream-content {
    color: #666;
    opacity: 0.9;
    padding-left: 0.5rem;
    border-left: 2px solid #ccc;
    animation: pulseContent 2s infinite;
}

/* Final content styles */
.final-content {
    padding-left: 0.5rem;
    border-left: 2px solid var(--primary-blue);
}

/* Timestamp styles */
.timestamp {
    font-size: 10px;
    float: right;
    margin-top: -6px;
}


/* Message Content */
.message-content {
    font-size: 0.75rem;
    line-height: 1.4;
}

.stream-content {
    color: #666;
    opacity: 0.9;
    padding-left: 0.5rem;
    border-left: 2px solid #ccc;
}


.final-content {
    padding-left: 0.5rem;
    border-left: 2px solid var(--primary-blue);
}

.agent-block .message-content .final-content {
    border-left: 2px solid #58855c;
    /* Match agent block color */
}


/* Add a subtle highlight effect when content is updated */
.message-block .message-content.updating {
    animation: highlight-update 1s ease-in-out;
}

@keyframes highlight-update {
    0% {
        background-color: rgba(255, 255, 0, 0.1);
    }

    100% {
        background-color: transparent;
    }
}

/* Action Queue Container */
.action-queue {
    /* position: absolute;
    bottom: 0;
    left: 0;
    right: 0; */
    background: #fff;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.05);
    max-height: 0;
    transition: max-height 0.3s ease-out;
    overflow: hidden;
}

/* When action queue has actions */
.action-queue.has-actions {
    max-height: 40vh;
}

/* Adjust main feed when action queue has actions */
.action-queue.has-actions+.main-feed {
    margin-bottom: 40vh;
    animation: enhancedSlideDown 0.4s ease-out forwards;
}

@keyframes enhancedSlideDown {
    0% {
        max-height: 0;
        opacity: 0;
        transform: translateY(-10px);
    }

    100% {
        max-height: 40vh;
        opacity: 1;
        transform: translateY(0);
    }
}

/* Header */
.action-queue-header {
    background: #f8f9fa;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    display: flex;
    flex-shrink: 0;
    justify-content: space-between;
    padding: var(--space-sm) var(--space-lg);
    z-index: 1;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
}

.action-queue-header h3 {
    color: var(--hawx-primary-color1);
    font-size: 14px;
    font-weight: 600;
    margin: 0;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Action Count Badge */
.action-count {
    background: var(--hawx-primary-color2);
    border-radius: 12px;
    color: white;
    font-size: 0.8125rem;
    font-weight: 500;
    min-width: 1.5rem;
    padding: 0.25rem 0.625rem;
    text-align: center;
    text-shadow: 0.25px 0.1px black;
    transition: background-color 0.4s ease;
    box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.1);
}

@keyframes attentionGlow {

    0%,
    20%,
    40%,
    60%,
    80%,
    100% {
        box-shadow: 0 0 2px 0 rgba(255, 107, 107, 0), 0 0 2px 0 rgba(0, 0, 0, 0.2);
        background-color: var(--hawx-primary-color2);
    }

    10%,
    30%,
    50%,
    70%,
    90% {
        box-shadow: 0 0 8px 4px rgba(255, 107, 107, 0.3), 0 0 2px 0 rgba(0, 0, 0, 0.2);
        background-color: rgba(255, 107, 107, 1);
    }
}

.action-count.attention {
    animation: attentionGlow 8s ease-in-out forwards;
}



/* Actions Container */
#actionItems {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 0.75rem;
    max-height: calc(100% - 70px);
}

/* Individual Action Items */
.action-item {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    display: flex;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    padding: 0.75rem;
    transition: all 0.2s ease;
    position: relative;
    min-height: 100px;
}

.action-item:last-child {
    margin-bottom: 0;
}

/* Action Content */
.action-content {
    flex: 1;
    min-width: 0;
}

.action-type {
    color: var(--hawx-primary-color1);
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 0.375rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-top: -5px;

}

.action-data {
    background: var(--form-background);
    border-radius: 4px;
    color: var(--form-color);
    font-family: monospace;
    font-size: 9px;
    line-height: 1.4;
    max-height: 120px;
    overflow: auto;
    padding: 0.625rem;
    white-space: pre-wrap;
    word-break: break-word;
}

.action-timestamp {
    color: #666;
    font-size: 10px;
    text-align: right;
    position: absolute;
    top: 2px;
    right: var(--space-md);
}

/* Action Buttons */
.action-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-width: 90px;
    align-items: center;
    justify-content: center;
}

.action-button {
    align-items: center;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    font-size: 0.875rem;
    font-weight: 500;
    justify-content: center;
    min-width: 90px;
    padding: 0.5rem 1rem;
    position: relative;
    transition: all 0.2s ease;
    height: fit-content;
}


/* Hidden field styling */
.hidden-field {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    left: -9999px !important;
    height: 0 !important;
    width: 0 !important;
    opacity: 0 !important;
}

/* Optional: Add additional styling to improve the form layout */
.action-data-form {
    position: relative;
}

/* Add a light border to distinguish form fields better */
.form-field {
    padding-bottom: 8px;
    margin-bottom: 10px;
}

.form-field:last-child {
    border-bottom: none;
}

/* Notes textarea styling */
.form-group textarea.notes-textarea {
    width: calc(100% - 16px);
    resize: vertical;
    min-height: fit-content;
    padding: 8px;
    font-family: inherit;
    font-size: 0.875rem;
    line-height: 1.4;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
    transition: all 0.2s ease;
    scrollbar-width: thin;
}

.notes-textarea:focus {
    border-color: #3498db;
    box-shadow: 0 0 0 2px rgba(52, 152, 219, 0.15);
    outline: none;
}

.notes-textarea:disabled {
    opacity: 0.5;
    background-color: #f8f9fa;
}

.notes-textarea.invalid {
    border-color: #e74c3c;
    background-color: rgba(231, 76, 60, 0.05);
}

.form-field:last-child {
    border-bottom: none;
}


.confirm-button {
    background: var(--success);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    color: white;
}

.confirm-button:hover:not(:disabled) {
    background: var(--success-hover);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

.decline-button {
    background: var(--error);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    color: white;
}

.decline-button:hover:not(:disabled) {
    background: var(--error-hover);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

.action-button:active:not(:disabled) {
    transform: translateY(0);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Button States */
.action-button:disabled {
    cursor: not-allowed;
    opacity: 0.6;
    pointer-events: none;
}

.action-button.loading {
    color: transparent !important;
    pointer-events: none;
    position: relative;
}

.action-button.loading::after {
    animation: button-loading-spinner 0.6s linear infinite;
    border: 2px solid transparent;
    border-radius: 50%;
    border-top-color: white;
    border-left-color: white;
    content: '';
    height: fit-content;
    position: absolute;
    width: 1rem;
}

@keyframes button-loading-spinner {
    from {
        transform: rotate(0turn);
    }

    to {
        transform: rotate(1turn);
    }
}

.action-button.loading {
    color: transparent !important;
    pointer-events: none;
    position: relative;
    background-color: var(--hawx-primary-color2) !important;
    /* Use your theme color */
    min-height: 32px;
}

.action-button.loading::after {
    content: '';
    position: absolute;
    width: 1rem;
    height: 1rem;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: white;
    animation: button-loading-spinner 0.8s linear infinite;
}

@keyframes button-loading-spinner {
    from {
        transform: rotate(0turn);
    }

    to {
        transform: rotate(1turn);
    }
}

/* Disabled state for non-loading button when other button is loading */
.action-button:disabled:not(.loading) {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--gray-400, #cbd5e0);
}

/* Action item with acknowledge status */
.action-item[data-status="acknowledge"] {
    background-color: #f8f9fa;
    border-left: 4px solid #6c757d;
}

/* Action form styling */
.action-data-form {
    background: rgba(250, 250, 250, 0.6);
    border-radius: 4px;
    padding: 12px;
    margin-bottom: 8px;
    max-height: 200px;
    overflow-y: auto;
    overflow-x: hidden;
    box-sizing: border-box;
    position: relative;
    padding-left: 0;
}

/* Form field styling */
.form-field {
    margin-bottom: 10px;
    display: flex;
    flex-direction: column;
}

.form-field label {
    font-size: 0.8rem;
    margin-bottom: 4px;
    color: #555;
    font-weight: 500;
    text-transform: capitalize;
}

.form-field input {
    padding: 8px 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-family: inherit;
    background-color: white;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
    transition: all 0.2s ease;
    width: calc(100% - 20px);
}

/* Input states */
.form-field input:hover {
    border-color: #bbb;
}

.form-field input.focused {
    border-color: #3498db;
    box-shadow: 0 0 0 2px rgba(52, 152, 219, 0.15);
}

.form-field input.invalid {
    border-color: #e74c3c;
    background-color: rgba(231, 76, 60, 0.05);
}

/* Nested fields styling */
.nested-label {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 4px 0 8px 0;
    color: #444;
    padding-bottom: 4px;
    border-bottom: 1px solid #eee;
}

.nested-fields {
    padding-left: 8px;
    border-left: 2px solid #f0f0f0;
    margin-bottom: 12px;
}

/* Save indicator styling */
.save-indicator {
    font-size: 12px;
    padding: 3px 8px;
    border-radius: 10px;
    margin-left: 8px;
    transition: all 0.3s ease;
    font-weight: normal;
    display: inline-block;
}

.save-indicator.editing {
    color: #f39c12;
}

.save-indicator.saving {
    color: #3498db;
    animation: pulse 1.5s infinite;
}

.save-indicator.saved {
    color: #2ecc71;
}

.save-indicator.save-error {
    color: #e74c3c;
}

/* Action header with type and save indicator */
.action-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.action-type {
    font-weight: 600;
    color: #34495e;
}

.action-data-form label.nested-label {
    display: none;
}

/* Nicer form layout */
.action-edit-form {
    border-radius: 5px;
    width: 100%;
}

/* Number input styling */
.action-data-form input[type="number"] {
    -moz-appearance: textfield;
    /* Firefox */
}

.action-data-form input:disabled {
    opacity: 0.25;
}

.action-data-form input[type="number"]::-webkit-inner-spin-button,
.action-data-form input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}


/* Acknowledge button styling */
.acknowledge-button {
    background: #6c757d;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    color: white;
    width: 100%;
    padding: 0.5rem 1rem;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
    height: fit-content;
}

.acknowledge-button:hover:not(:disabled) {
    background: #5a6268;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

.acknowledge-button:active:not(:disabled) {
    transform: translateY(0);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.acknowledge-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Loading state for acknowledge button */
.acknowledge-button.loading {
    color: transparent !important;
    pointer-events: none;
    position: relative;
    background-color: #6c757d !important;
    min-height: 32px;
}

.acknowledge-button.loading::after {
    content: '';
    position: absolute;
    width: 1rem;
    height: 1rem;
    top: 50%;
    left: 50%;
    margin: -0.5rem 0 0 -0.5rem;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: white;
    animation: button-loading-spinner 0.8s linear infinite;
}


/* System Messages */
.system-message {
    align-self: center;
    max-width: 400px;
    padding: 0.75rem 1rem;
    margin: 0.5rem auto;
    border-radius: 8px;
    font-size: 0.875rem;
    text-align: center;
    animation: fadeIn 0.3s ease-out;
}

.system-message.reconnecting {
    background: #fff3cd;
    color: var(--hawx-primary-color2);
    border: 1px solid #ffeeba;
}

.system-message.error {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}



/* Connection Status */
#keepalive-indicator {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-family: monospace;
    z-index: 9999;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    opacity: 0.1;
    pointer-events: none;
    /* Ignore pointer events */
}

#keepalive-indicator.pulse {
    animation: pulse 2s infinite;
}


.timestamp {
    font-size: 10px;
    float: right;
}

.coach-block .timestamp {
    margin-top: -6px;
}

/* Tool Call Blocks */
.tool-call-block {
    background: white;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    /* overflow: hidden; */
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(10px);
    max-width: 85%;
    align-self: center;
    z-index: 1;
    /* Lower than action queue */
}

.tool-call-block.fade-in {
    opacity: 1;
    transform: translateY(0);
}

.tool-header {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    background: var(--light-blue);
    border-bottom: 1px solid rgba(33, 150, 243, 0.2);
    gap: 12px;
}

.tool-icon {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-blue);
    border-radius: 6px;
    color: white;
}

.tool-name {
    font-weight: 600;
    color: #1976D2;
    font-size: 0.9rem;
    min-width: fit-content;
    text-wrap: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}


.tool-id {
    font-size: 0.8rem;
    color: #666;
    margin-left: auto;
    text-overflow: ellipsis;
    font-family: monospace;
    text-wrap: nowrap;
    overflow: hidden;
}

.tool-content {
    padding: 16px;
}

.tool-args {
    background: #f8f9fa;
    padding: 12px;
    border-radius: 6px;
    font-family: monospace;
    font-size: 9px;
    margin: 0;
    white-space: pre-wrap;
    color: #333;
    border: 1px solid #e0e0e0;
    /* max-height: 200px;
    overflow-y: auto; */
}

.tool-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    gap: 12px;
    background: #fafafa;
    border-top: 1px solid #eee;
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
}

.loading-text {
    font-size: 0.85rem;
    color: #666;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Add animated dots to the loading text */
.loading-text::after {
    content: '';
    animation: loadingDots 1.5s infinite;
    width: 24px;
    text-align: left;
}

@keyframes loadingDots {
    0% {
        content: '.';
    }

    33% {
        content: '..';
    }

    66% {
        content: '...';
    }

    100% {
        content: '.';
    }
}


/* Removal Animation */
.tool-call-block.removing {
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.3s ease;
}


.markdown-content em {
    font-style: italic;
}

/* Links */
.markdown-content a {
    color: #0366d6;
    text-decoration: none;
}

.markdown-content a:hover {
    text-decoration: underline;
}

/* Headings */
.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4,
.markdown-content h5,
.markdown-content h6 {
    margin-top: 1.5em;
    margin-bottom: 1em;
    font-weight: 600;
    line-height: 1.25;
}

.markdown-content h1 {
    font-size: 2em;
}

.markdown-content h2 {
    font-size: 1.5em;
}

.markdown-content h3 {
    font-size: 1.25em;
}

.markdown-content h4 {
    font-size: 1em;
}

.markdown-content h5 {
    font-size: 0.875em;
}

.markdown-content h6 {
    font-size: 0.85em;
}

/* Preserve code block formatting during updates */
.message-block .markdown-content pre,
.message-block .markdown-content code {
    transition: background-color 0.3s ease-in-out;
    display: block;
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* Ensure inline code maintains its style during updates */
.message-block .markdown-content code:not(pre code) {
    display: inline;
    padding: 0.2em 0.4em;
}

/* Handle tables during updates */
.message-block .markdown-content table {
    transition: all 0.3s ease-in-out;
    border-collapse: collapse;
    width: 100%;
}

/* Preserve list formatting during updates */
.message-block .markdown-content ul,
.message-block .markdown-content ol {
    transition: margin 0.3s ease-in-out;
    padding-left: 2em;
}

/* Handle blockquotes during updates */
.message-block .markdown-content blockquote {
    transition: border-left-color 0.3s ease-in-out;
    margin: 1em 0;
    padding-left: 1em;
    border-left: 4px solid;
}

.final-content p:first-child {
    margin-top: 0;
}

.final-content ol {
    padding-left: 1rem;
}

#chat-toggle {
    position: absolute;
    right: 16px;
    top: 4px;
    z-index: 2;
    display: flex;
    gap: 8px;
}

#chat-toggle:hover {
    opacity: 1;
}


#chat-toggle svg {
    width: 16px;
    height: 16px;
    border: 1px solid var(--hawx-primary-color1);
    border-radius: 50%;
    padding: 2px;
    cursor: pointer;
    background-color: var(--bg-light);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    opacity: 0.5;
    transition: all 0.2s ease;
}

#chat-toggle svg:hover {
    opacity: 1;
}

#chat-toggle svg.hide {
    display: none;
}

.what-to-say-toggle .loading-spinner {
    position: absolute;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    border-top-color: var(--hawx-primary-color1);
    animation: spin 0.8s linear infinite;
    top: 1px;
}

#what-to-say-toggle.disabled .toggle-icon {
    display: none;
}

#hawx-helper.hide,
.main-feed.hide,
#actionQueue.hide,
#hawx-helper-icon.hide,
#hawx-coach-icon.hide,
#clear-helper-chat-icon.hide {
    display: none;
}

/* Base container */
#hawx-helper {
    display: flex;
    flex-direction: column;
    height: 100%;
    box-sizing: border-box;
}

/* Messages container */
.helper-messages-container {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    width: 100%;
    margin-top: var(--space-md);
    padding: var(--space-sm);
    padding-bottom: var(--space-md);
    box-sizing: border-box;
}


.system-block {
    align-self: center;
    background: #fff3cd;
    border: 1px solid #ffeeba;
    color: #856404;
}

.user-block {
    align-self: flex-start;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.assistant-block {
    align-self: flex-end;
    background: #e3f2fd;
    border: 1px solid rgba(33, 150, 243, 0.2);
}

/* Input container */
.helper-input-container {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    background: var(--form-background);
    position: relative;
    margin-top: auto;
}

#helper-input {
    flex: 1;
    max-height: 32px;
    padding: var(--space-sm);
    resize: none;
    border: none;
    overflow-y: scroll;
    overflow-x: hidden;
}

#helper-input::-webkit-scrollbar {
    display: none;
    /* Hide scrollbar */
}

#helper-input:focus {
    outline: none;
    border-color: var(--hawx-primary-color1);
    box-shadow: 0 0 0 2px rgba(var(--hawx-primary-color1-rgb), 0.1);
}

/* Send button */
#helper-send-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    transition: opacity 0.2s ease;
    opacity: 0.5;
    cursor: pointer;
}

#helper-send-btn:hover,
#helper-send-btn.active {
    opacity: 1;
}

#helper-send-icon {
    width: 1.25rem;
    height: 1.25rem;
}


/* States */
.disabled:not(.appointment-option) {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

.helper-input-container.disabled::after {
    content: "Waiting for response...";
    position: absolute;
    right: 50px;
    top: 50%;
    transform: translateY(-50%);
    color: #666;
    font-size: 12px;
}


@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}


.loading-spinner {
    width: 20px;
    height: 20px;
    border: 2px solid #f3f3f3;
    border-top: 2px solid var(--primary-blue);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}


/* Manual Message Sender Styles */
.manual-message-sender {
    position: absolute;
    top: 24px;
    right: 16px;
    width: calc(100% - 32px);
    z-index: 1;
}

.toggle-manual-sender,
#what-to-say-toggle {
    background: none;
    border: 1px solid var(--hawx-primary-color1);
    border-radius: 50%;
    width: 22px;
    height: 22px;
    cursor: pointer;
    /* display: flex; */
    display: none; /* Hide buttons by default */
    align-items: center;
    justify-content: center;
    opacity: 0.5;
    transition: all 0.2s ease;
    padding: 0;
    background-color: var(--bg-light);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

#what-to-say-toggle {
    display: flex;
}

#toggle-manual-sender.hide,
#what-to-say-toggle.hide {
    display: none;
}


.toggle-manual-sender:hover,
#what-to-say-toggle:hover {
    opacity: 1;
}

.toggle-icon {
    font-size: 12px;
}

.manual-sender-form {
    position: absolute;
    top: 100%;
    right: 0;
    width: 100%;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    margin-top: 8px;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.manual-sender-form.hide {
    display: none;
}

.form-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.form-header h4 {
    margin: 0;
    font-size: 14px;
    color: var(--hawx-primary-color1);
}

.close-form {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    color: #666;
    padding: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.form-content {
    padding: 16px;
}

.form-group {
    margin-bottom: 12px;
}

.form-group label {
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    color: #666;
}

.form-group select,
.form-group textarea {
    width: 100%;
    padding: 8px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 4px;
    font-size: 13px;
}

.form-group textarea,
.form-field textarea {
    width: 100%;
    resize: vertical;
    min-height: 80px;
    max-width: calc(100% - 15px);
    scrollbar-width: thin;
    padding: var(--space-sm);
    font-family: inherit;
}


.send-message-btn {
    width: 100%;
    padding: 8px;
    background: var(--hawx-primary-color1);
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 13px;
    transition: background 0.2s ease;
}

.send-message-btn:disabled {
    background: #ccc;
    cursor: not-allowed;
}

.send-message-btn:not(:disabled):hover {
    background: var(--hawx-primary-color2);
}

/* Loading state */
.send-message-btn.loading {
    position: relative;
    color: transparent;
}

.send-message-btn.loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin: -8px 0 0 -8px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: white;
    animation: button-loading-spinner 0.8s linear infinite;
}

#message-content {
    max-width: calc(100% - 16px);
}


#chat-toggle .rating-feedback {
    background: white;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
    animation: fadeIn 0.3s ease-out;
}

#chat-toggle .rating-feedback.hide {
    display: none;
}

#chat-toggle .rating-button {
    padding: 2px;
    border-radius: 50%;
    border: 1px solid var(--hawx-primary-color1);
    cursor: pointer;
    transition: all 0.2s ease;
    /* display: flex; */
    display: none; /* Hide buttons by default */
    align-items: center;
    justify-content: center;
    background: none;
}

#chat-toggle .rating-button.positive:not(.disabled) {
    color: var(--success);
}

#chat-toggle .rating-button.negative:not(.disabled) {
    color: var(--error);
}

#chat-toggle .rating-button.positive:hover:not(.disabled) {
    background: var(--success-hover);
    color: var(--bg-light);
    stroke: var(--bg-light);
}


#chat-toggle .rating-button.negative:hover:not(.disabled) {
    background: var(--error-hover);
    color: var(--bg-light);
    stroke: var(--bg-light);
}

#chat-toggle .rating-button.disabled.positive,
#chat-toggle .rating-button.disabled.positive:hover,
#chat-toggle .rating-button.disabled.negative,
#chat-toggle .rating-button.disabled.negative:hover {
    opacity: 0.15;
    cursor: not-allowed;
}


/* ═══════════════════════════════════════════════════════════════════════════
   DARK MODE - Hawx Coach Theme Override
   ═══════════════════════════════════════════════════════════════════════════ */

/* Base Container */
[data-theme="dark"] #hawx-coach-container {
    background: var(--gray-100, #1a1a1a);
    border-left-color: var(--gray-700, #374151);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}

/* Main Feed Area */
[data-theme="dark"] .main-feed {
    background: var(--gray-100, #1a1a1a);
}

/* Messages Container */
[data-theme="dark"] .messages-container {
    background: var(--gray-100, #1a1a1a);
}

/* Message Blocks - Customer/User */
[data-theme="dark"] .customer-block,
[data-theme="dark"] .user-block {
    background: var(--gray-300, #374151);
    border-color: var(--gray-500, #6b7280);
    color: #ffffff;
}

/* Message Blocks - Coach/Assistant */
[data-theme="dark"] .coach-block,
[data-theme="dark"] .assistant-block {
    background: #1e3a5f;
    border-color: rgba(33, 150, 243, 0.3);
    color: #e3f2fd;
}

/* Message Blocks - Agent */
[data-theme="dark"] .agent-block {
    background: #1a3d1c;
    border-color: #2d5a30;
    color: #cbf8cf;
}

/* Message Blocks - Call Copilot */
[data-theme="dark"] .call_copilot-block {
    background: #1e3a5f;
    border-color: rgba(33, 150, 243, 0.3);
    color: #e3f2fd;
}

/* Stream content */
[data-theme="dark"] .stream-content {
    color: var(--gray-400, #9ca3af);
    border-left-color: var(--gray-500, #6b7280);
}

/* Final content */
[data-theme="dark"] .final-content {
    color: inherit;
}

[data-theme="dark"] .agent-block .message-content .final-content {
    border-left-color: #4caf50;
}

/* Finalized interim */
[data-theme="dark"] .message-content .finalized-interim {
    color: var(--gray-400, #9ca3af);
}

/* Timestamp */
[data-theme="dark"] .timestamp {
    color: var(--gray-500, #6b7280);
}

/* Action Queue Container */
[data-theme="dark"] .action-queue {
    background: var(--gray-100, #1a1a1a);
    border-top-color: var(--gray-700, #374151);
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.2);
}

/* Action Queue Header */
[data-theme="dark"] .action-queue-header {
    background: var(--gray-200, #242424);
    border-bottom-color: var(--gray-600, #4b5563);
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .action-queue-header h3 {
    color: var(--gray-300, #d1d5db);
}

/* Action Count Badge */
[data-theme="dark"] .action-count {
    background: var(--hawx-primary-color2, #EAB749);
    color: #1a1a1a;
    text-shadow: none;
}

/* Action Items */
[data-theme="dark"] .action-item {
    background: var(--gray-200, #242424);
    border-color: var(--gray-600, #4b5563);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .action-type {
    color: var(--gray-300, #d1d5db);
}

[data-theme="dark"] .action-data {
    background: var(--gray-300, #2d2d2d);
    color: var(--gray-100, #f3f4f6);
    border-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .action-timestamp {
    color: var(--gray-500, #6b7280);
}

/* Action Buttons */
[data-theme="dark"] .action-button {
    color: #fff;
}

[data-theme="dark"] .confirm-button {
    background: #2e7d32;
}

[data-theme="dark"] .confirm-button:hover:not(:disabled) {
    background: #388e3c;
}

[data-theme="dark"] .decline-button {
    background: #c62828;
}

[data-theme="dark"] .decline-button:hover:not(:disabled) {
    background: #d32f2f;
}

[data-theme="dark"] .acknowledge-button {
    background: #1565c0;
}

[data-theme="dark"] .acknowledge-button:hover:not(:disabled) {
    background: #1976d2;
}

/* Action Data Form */
[data-theme="dark"] .action-data-form {
    background: transparent;
}

[data-theme="dark"] .form-field {
    border-bottom-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .form-field label {
    color: var(--gray-400, #9ca3af);
}

[data-theme="dark"] .form-field input,
[data-theme="dark"] .action-data-form input {
    background: var(--gray-300, #2d2d2d);
    border-color: var(--gray-600, #4b5563);
    color: var(--gray-100, #f3f4f6);
}

[data-theme="dark"] .form-field input:focus,
[data-theme="dark"] .action-data-form input:focus {
    border-color: #1976d2;
}

[data-theme="dark"] .form-field input:disabled,
[data-theme="dark"] .action-data-form input:disabled {
    background: var(--gray-400, #3d3d3d);
    color: var(--gray-500, #6b7280);
}

/* Notes textarea */
[data-theme="dark"] .form-group textarea.notes-textarea {
    background: var(--gray-300, #2d2d2d);
    border-color: var(--gray-600, #4b5563);
    color: var(--gray-100, #f3f4f6);
}

[data-theme="dark"] .notes-textarea:focus {
    border-color: #1976d2;
    box-shadow: 0 0 0 2px rgba(25, 118, 210, 0.2);
}

[data-theme="dark"] .notes-textarea:disabled {
    background: var(--gray-400, #3d3d3d);
}

/* Nested label */
[data-theme="dark"] .nested-label {
    color: var(--gray-400, #9ca3af);
}

/* Save indicator */
[data-theme="dark"] .save-indicator {
    color: var(--gray-500, #6b7280);
}

[data-theme="dark"] .save-indicator.saved {
    color: #4caf50;
}

[data-theme="dark"] .save-indicator.save-error {
    color: #f44336;
}

/* System Messages */
[data-theme="dark"] .system-message {
    background: var(--gray-200, #242424);
    color: var(--gray-300, #d1d5db);
    border-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .system-message.reconnecting {
    background: #3d3520;
    color: #ffeeba;
    border-color: #665c3d;
}

[data-theme="dark"] .system-message.error {
    background: #3d2020;
    color: #f5c6cb;
    border-color: #5c3030;
}

/* Tool Call Blocks */
[data-theme="dark"] .tool-call-block {
    background: var(--gray-200, #242424);
    border-color: var(--gray-600, #4b5563);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .tool-header {
    background: #1e3a5f;
    border-bottom-color: rgba(33, 150, 243, 0.3);
}

[data-theme="dark"] .tool-icon {
    background: #1976d2;
}

[data-theme="dark"] .tool-name {
    color: #64b5f6;
}

[data-theme="dark"] .tool-id {
    color: var(--gray-500, #6b7280);
}

[data-theme="dark"] .tool-content {
    background: var(--gray-200, #242424);
}

[data-theme="dark"] .tool-args {
    background: var(--gray-300, #2d2d2d);
    color: var(--gray-200, #e5e7eb);
    border-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .tool-loading {
    background: var(--gray-300, #2d2d2d);
    border-top-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .loading-text {
    color: var(--gray-400, #9ca3af);
}

/* Markdown Content */
[data-theme="dark"] .markdown-content {
    color: inherit;
}

[data-theme="dark"] .markdown-content a {
    color: #64b5f6;
}

[data-theme="dark"] .markdown-content a:hover {
    color: #90caf9;
}

[data-theme="dark"] .markdown-content code:not(pre code) {
    background: var(--gray-300, #2d2d2d);
    color: #f48fb1;
}

[data-theme="dark"] .markdown-content pre {
    background: var(--gray-300, #2d2d2d);
    border-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .markdown-content blockquote {
    border-left-color: var(--gray-500, #6b7280);
    color: var(--gray-400, #9ca3af);
}

[data-theme="dark"] .markdown-content h1,
[data-theme="dark"] .markdown-content h2,
[data-theme="dark"] .markdown-content h3,
[data-theme="dark"] .markdown-content h4,
[data-theme="dark"] .markdown-content h5,
[data-theme="dark"] .markdown-content h6 {
    color: var(--gray-200, #e5e7eb);
}

/* Connection Status Indicator */
[data-theme="dark"] #keepalive-indicator {
    background: var(--gray-200, #242424);
    color: var(--gray-400, #9ca3af);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Helper Container */
[data-theme="dark"] #hawx-helper {
    background: var(--gray-100, #1a1a1a);
}

[data-theme="dark"] .helper-messages-container {
    background: var(--gray-100, #1a1a1a);
}

/* Helper Blocks */
[data-theme="dark"] .system-block {
    background: #3d3520;
    border-color: #665c3d;
    color: #ffeeba;
}

/* Helper Input */
[data-theme="dark"] .helper-input-container {
    background: var(--gray-200, #242424);
    border-top-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] #helper-input {
    background: var(--gray-200, #242424);
    color: var(--gray-100, #f3f4f6);
}

[data-theme="dark"] #helper-input::placeholder {
    color: var(--gray-500, #6b7280);
}

[data-theme="dark"] #helper-send-btn {
    color: var(--gray-400, #9ca3af);
}

[data-theme="dark"] #helper-send-btn:hover {
    color: var(--gray-200, #e5e7eb);
}

/* Manual Message Sender */
[data-theme="dark"] .manual-sender-form {
    background: var(--gray-200, #242424);
    border-color: var(--gray-600, #4b5563);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .form-header {
    border-bottom-color: var(--gray-600, #4b5563);
}

[data-theme="dark"] .form-header h4 {
    color: var(--gray-200, #e5e7eb);
}

[data-theme="dark"] .close-form {
    color: var(--gray-400, #9ca3af);
}

[data-theme="dark"] .close-form:hover {
    color: var(--gray-200, #e5e7eb);
}

[data-theme="dark"] .form-group label {
    color: var(--gray-400, #9ca3af);
}

[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea {
    background: var(--input-bg, #242424);
    border-color: var(--border-color, #2d2d2d);
    color: var(--text-primary, #f3f4f6);
}

[data-theme="dark"] .send-message-btn {
    background: #1976d2;
    color: #fff;
}

[data-theme="dark"] .send-message-btn:hover:not(:disabled) {
    background: #1e88e5;
}

[data-theme="dark"] .send-message-btn:disabled {
    background: var(--gray-600, #4b5563);
    color: var(--gray-500, #6b7280);
}

/* Toggle Buttons */
[data-theme="dark"] .toggle-manual-sender,
[data-theme="dark"] #what-to-say-toggle {
    border-color: var(--gray-500, #6b7280);
    background-color: var(--gray-200, #242424);
    color: var(--gray-300, #d1d5db);
}

[data-theme="dark"] .toggle-manual-sender:hover,
[data-theme="dark"] #what-to-say-toggle:hover {
    border-color: var(--gray-400, #9ca3af);
    background-color: var(--gray-300, #2d2d2d);
}

/* Rating Buttons */
[data-theme="dark"] #chat-toggle .rating-feedback {
    background: var(--gray-200, #242424);
    color: var(--gray-200, #e5e7eb);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] #chat-toggle .rating-button {
    border-color: var(--gray-500, #6b7280);
    background: var(--gray-200, #242424);
}

[data-theme="dark"] #chat-toggle .rating-button.positive:not(.disabled) {
    color: #4caf50;
}

[data-theme="dark"] #chat-toggle .rating-button.negative:not(.disabled) {
    color: #f44336;
}

/* Loading Spinner */
[data-theme="dark"] .loading-spinner {
    border-color: var(--gray-600, #4b5563);
    border-top-color: #1976d2;
}

/* Scrollbars */
[data-theme="dark"] .messages-container::-webkit-scrollbar,
[data-theme="dark"] #actionItems::-webkit-scrollbar,
[data-theme="dark"] .helper-messages-container::-webkit-scrollbar {
    width: 8px;
}

[data-theme="dark"] .messages-container::-webkit-scrollbar-track,
[data-theme="dark"] #actionItems::-webkit-scrollbar-track,
[data-theme="dark"] .helper-messages-container::-webkit-scrollbar-track {
    background: var(--gray-200, #242424);
}

[data-theme="dark"] .messages-container::-webkit-scrollbar-thumb,
[data-theme="dark"] #actionItems::-webkit-scrollbar-thumb,
[data-theme="dark"] .helper-messages-container::-webkit-scrollbar-thumb {
    background: var(--gray-500, #6b7280);
    border-radius: 4px;
}

[data-theme="dark"] .messages-container::-webkit-scrollbar-thumb:hover,
[data-theme="dark"] #actionItems::-webkit-scrollbar-thumb:hover,
[data-theme="dark"] .helper-messages-container::-webkit-scrollbar-thumb:hover {
    background: var(--gray-400, #9ca3af);
}

/* Message Block Icons - Dark Mode */
[data-theme="dark"] .messages-container .message-block.customer-block::before,
[data-theme="dark"] .customer-message::before {
    background-color: #546463;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M5 21C5 17.134 8.13401 14 12 14C15.866 14 19 17.134 19 21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

[data-theme="dark"] .messages-container .message-block.coach-block::before,
[data-theme="dark"] .coach-message::before {
    background-color: var(--gray-300, #d1d5db);
    border-color: #1976d2;
}

[data-theme="dark"] .messages-container .message-block.agent-block::before,
[data-theme="dark"] .agent-message::before {
    background-color: #2e7d32;
    border-color: #4caf50;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 17.5 17.5'%3E%3Cg transform='translate(0.75 0.75)'%3E%3Cg%3E%3Cpath d='M-3.339,14.3h0A3.479,3.479,0,0,0,0,10.961V6S-.257,0-5,0s-5,7-5,7' transform='translate(13 0)' fill='none' stroke='%23ffffff' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/path%3E%3Crect width='3' height='5' rx='1.5' stroke-width='1.5' fill='none' stroke='%23ffffff' stroke-miterlimit='10' transform='translate(13 5)'%3E%3C/rect%3E%3Crect width='3' height='5' rx='1.5' transform='translate(0 5)' fill='none' stroke='%23ffffff' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/rect%3E%3Cpath d='M1,0A1,1,0,0,0,0,1V2A1,1,0,0,0,1,3H2A1,1,0,0,0,3,2V1A1,1,0,0,0,2,0Z' transform='translate(7 13)' fill='none' stroke='%23ffffff' stroke-miterlimit='10' stroke-width='1.5'%3E%3C/path%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

[data-theme="dark"] .messages-container .message-block.call_copilot-block::before,
[data-theme="dark"] .call_copilot-message::before {
    background-color: var(--gray-300, #d1d5db);
    border-color: #1976d2;
}