.search-input {
    transition: border-color 0.2s;
}

.search-input:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.decision-card {
    transition: background-color 0.2s, transform 0.2s;
}

.decision-card:hover {
    background: #d1d5db;
    transform: scale(1.02);
}

.decision-card.active {

    background: #3b82f6;

    color: white;

}

.decision-card.active span {

    color: #e6f0ff;

}

.progress-step {

    transition: background-color 0.2s;

}

.progress-step.active {

    background-color: #3b82f6 !important;

}

.progress-step.completed {

    background-color: #10b981 !important;

}

.progress-fill {
    transition: width 0.3s ease;
}

.final-textarea {
    height: 600px;
    resize: vertical;
}

.category-toggle, .subcategory-toggle {
    transition: background-color 0.2s, border-color 0.2s;
}

.category-toggle:hover, .subcategory-toggle:hover {

    background: #e5e7eb;

    border-color: #3b82f6;

}

.category-toggle {

    background: #f3f4f6;

    border: 1px solid #d1d5db;

    border-radius: 8px;

    padding: 12px;

    font-weight: 600;

    color: #1f2937;

}

.subcategory-toggle {

    background: #f9fafb;

    border: 1px solid #e5e7eb;

    border-radius: 6px;

    padding: 10px;

    color: #374151;

}

.toggle-icon {

    transition: transform 0.3s ease;

}

.category-content, .subcategory-content {

    transition: max-height 0.3s ease, opacity 0.3s ease;

}

.category-content.hidden, .subcategory-content.hidden {

    max-height: 0;

    opacity: 0;

    overflow: hidden;

}

.category-content:not(.hidden), .subcategory-content:not(.hidden) {

    max-height: 1000px;

    opacity: 1;

}

.attention-hint {

    transition: opacity 0.3s ease;

}

.attention-hint.hidden {

    opacity: 0;

    height: 0;

    margin: 0;

    padding: 0;

    border: none;

}

.next-button, .back-button, .download-pdf, .download-word {

    transition: background-color 0.2s, transform 0.2s;

}

.next-button:hover, .download-pdf:hover, .download-word:hover {

    background-color: #2563eb;

    transform: scale(1.05);

}

.back-button:hover {

    background-color: #4b5563;

    transform: scale(1.05);

}
.back-button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.next-button.disabled:hover {

    background-color: #9ca3af;

    transform: none;

}

@media (max-width: 600px) {

    .container {

        margin-top: 1rem;

    }

    .flex.space-x-4 {

        flex-direction: column;

        space-x-0;

        gap: 1rem;

    }

}

/*Workflow-feature*/
.workflow-suggestions {
    margin-bottom: 1.5rem;
}

.workflow-card {
    transition: background-color 0.2s, transform 0.2s;
}

.workflow-card:hover {
    background: #d1d5db;
    transform: scale(1.02);
}


/* Download config button */
.download-config {
    transition: background-color 0.2s, transform 0.2s;
    border-radius: 9999px; /* Fully rounded button */
    display: flex;
    align-items: center;
    gap: 0.4rem; /* Space between icon and text */
}

.download-config:hover {
    background-color: #7e22ce !important;
    transform: scale(1.05);
}

.upload-config {
    transition: border-color 0.2s;
}

.upload-config:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.new-contract {
    transition: background-color 0.2s, transform 0.2s;
}

.new-contract:hover {
    background-color: #2563eb;
    transform: scale(1.05);
}

/* Header container for step heading and download button */
.step-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

@media (max-width: 600px) {
    /* Adjust step header for mobile */
    .step-header {
        flex-direction: row;
        gap: 0.5rem;
    }
    .download-config {
        padding: 8px 12px;
        font-size: 0.9rem;
    }
}

/* Phase tab styles */
.phase-tab {
    transition: background-color 0.2s, color 0.2s;
    color: black;
}

.phase-tab.active[data-phase="draft"] {
    background-color: #f59e0b !important; /* Yellow-500 for active Draft */
    color: white;
}

.phase-tab.active[data-phase="active"] {
    background-color: #10b981 !important; /* Green-500 for active Active */
    color: white;
}

.phase-tab.active[data-phase="archive"] {
    background-color: #ef4444 !important; /* Red-500 for active Archive */
    color: white;
}

@media (max-width: 600px) {
    .container {
        margin-top: 1rem;
    }

    .flex.space-x-4 {
        flex-direction: row;
        gap: 0.5rem;
        justify-content: space-between;
    }

    /* Larger buttons, side by side for Back and Next */
    .next-button, .back-button {
        width: 48%;
        padding: 12px;
        font-size: 1.1rem;
    }

    /* Final step buttons stacked at 100% width with margin */
    .step[data-step="4"] .flex.space-x-4 {
        flex-direction: column;
        gap: 1rem;
    }

    .step[data-step="4"] .back-button,
    .step[data-step="4"] .download-pdf,
    .step[data-step="4"] .download-word {
        width: 100%;
        padding: 12px;
        font-size: 1.1rem;
        margin-bottom: 0.5rem; /* Added margin between buttons */
    }

    /* Progress bar and smaller labels */
    .progress-container {
        padding: 0 1rem;
    }

    .progress-step {
        flex: 1;
        text-align: center;
        font-size: 0.7rem; /* Smaller font size for labels */
        padding: 8px 0;
    }

    .progress-fill {
        height: 6px;
    }

    /* Remove indentation for toggle children and align with parent */
    .category-content, .subcategory-content {
        padding-left: 0;
        margin-left: 0;
    }

    .category, .subcategory, .decision-card {
        width: 100%;
        margin-left: 0;
    }

    .category-toggle, .subcategory-toggle, .decision-card {
        margin-left: 0;
        margin-right: 0;
    }

    /* Workflow slider */
    .workflow-suggestions .grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 1rem;
        padding-bottom: 1rem;
    }

    .workflow-card {
        flex: 0 0 80%;
        scroll-snap-align: start;
    }
}