.input-group {
    width: 300px;
}

.search-terms-container {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    min-height: 24px;
    width: 300px;
    margin-top: 6px !important;
}

.search-term {
    display: inline-flex;
    align-items: center;
    padding: 1px 8px;
    border-radius: 12px;
    font-size: 0.75rem;
    white-space: nowrap;
    font-weight: 500;
    line-height: 1.5;
}

/* Search term colors */
.search-term-0 { background-color: #bbdefb; color: #1565c0; }
.search-term-1 { background-color: #c8e6c9; color: #2e7d32; }
.search-term-2 { background-color: #ffe0b2; color: #ef6c00; }
.search-term-3 { background-color: #e1bee7; color: #6a1b9a; }
.search-term-4 { background-color: #ffcdd2; color: #c62828; }

/* Highlight styles */
.highlight-0,
.highlight-1,
.highlight-2,
.highlight-3,
.highlight-4 {
    padding: 0 2px;
    border-radius: 2px;
}

.highlight-0 { background-color: #bbdefb; }
.highlight-1 { background-color: #c8e6c9; }
.highlight-2 { background-color: #ffe0b2; }
.highlight-3 { background-color: #e1bee7; }
.highlight-4 { background-color: #ffcdd2; }

/* Ensure proper contrast on striped rows */
.table-striped > tbody > tr:nth-of-type(odd) .highlight-0,
.table-striped > tbody > tr:nth-of-type(odd) .highlight-1,
.table-striped > tbody > tr:nth-of-type(odd) .highlight-2,
.table-striped > tbody > tr:nth-of-type(odd) .highlight-3,
.table-striped > tbody > tr:nth-of-type(odd) .highlight-4 {
    box-shadow: 0 0 0 1px rgba(0,0,0,0.1);
} 