:root {
    --app-primary: #0d6efd;
    --app-success: #198754;
    --app-danger: #dc3545;
    --app-secondary: #6c757d;
    --app-light-bg: #f8f9fa;
    --app-light-blue: #e7f1ff;
    --app-success-bg: #d1e7dd;
    --app-success-text: #146c43;
}

body { 
    background-color: var(--app-light-bg);
    -webkit-font-smoothing: antialiased;
}

.container-main { 
    max-width: 1300px;
    margin-left: auto;
    margin-right: auto;
}

.main-view { 
    display: none; 
}

.header-link { 
    text-decoration: none; 
    color: inherit; 
}

.accordion-body {
    padding: 1.5rem;
}

.accordion-button:not(.collapsed) { 
    background-color: var(--app-light-blue); 
    color: var(--app-primary); 
    box-shadow: none; 
}

.accordion-button:focus { 
    box-shadow: none; 
}

.accordion-button::after { 
    display: none; 
}

.step-icon { 
    width: 30px; 
    height: 30px; 
    border-radius: 50%; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: white; 
    margin-right: 15px; 
    transition: all 0.3s ease; 
}

.status-pending { 
    background-color: var(--app-secondary); 
}

.status-active { 
    background-color: var(--app-primary); 
}

.status-complete { 
    background-color: var(--app-success); 
}

.step-title { 
    font-size: 1.2rem; 
    font-weight: 500; 
}

.disabled-step .accordion-button { 
    color: var(--app-secondary); 
    background-color: var(--app-light-bg); 
    cursor: not-allowed; 
}

#step3-batch-actions {
    display: none;
}

.candidate-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, background-color 0.2s ease-in-out;
    cursor: pointer;
}

.candidate-item:hover {
    border-color: #adb5bd;
}

.candidate-item.selected {
    border-color: var(--app-primary);
    background-color: var(--app-light-blue);
    box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.25);
}

.candidate-select {
    margin-right: 1rem;
}

.candidate-select .form-check-input {
    width: 1.25em;
    height: 1.25em;
}

.candidate-info {
    flex-grow: 1;
}

.candidate-info .candidate-name {
    margin-bottom: 0.25rem;
    font-size: 1.15rem;
    font-weight: 600;
}

.candidate-info .candidate-title {
    margin-bottom: 0.5rem;
}

.candidate-info .candidate-skills {
    margin-bottom: 0.75rem;
}

.view-profile-link {
    font-weight: 500;
    text-decoration: none;
}

.score-container {
    width: 100px;
    flex-shrink: 0;
    text-align: end;
    margin-left: 1rem;
}

.score-reasoning {
    font-size: 0.8rem;
    line-height: 1.3;
    margin-top: 0.25rem;
}

.match-score { 
    font-weight: bold; 
    padding: 0.3rem 0.8rem; 
    border-radius: 50px;
}

.score-high { 
    color: var(--app-success-text); 
    background-color: var(--app-success-bg); 
}

.api-status-dot { 
    width: 10px; 
    height: 10px; 
    border-radius: 50%; 
    display: inline-block; 
    margin-right: 8px; 
    vertical-align: middle;
}

.status-not-connected { 
    background-color: var(--app-secondary);
}

.status-connected { 
    background-color: var(--app-success); 
}

.status-error {
    background-color: var(--app-danger);
}

.remove-shortlist-btn {
    color: var(--app-secondary);
    cursor: pointer;
    font-size: 1.2rem;
    padding: 0 0.5rem;
    opacity: 0.6;
    transition: opacity 0.2s;
}

.remove-shortlist-btn:hover {
    color: var(--app-danger);
    opacity: 1;
}

.or-divider {
    display: flex;
    align-items: center;
    text-align: center;
    color: var(--app-secondary);
    margin: 1.5rem 0;
}

.or-divider::before,
.or-divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #dee2e6;
}

.or-divider:not(:empty)::before {
    margin-right: .75em;
}

.or-divider:not(:empty)::after {
    margin-left: .75em;
}