/**
 * Detail Cards Enhanced Animations
 *
 * Provides smooth fade + slide transitions for application detail cards
 * Better visual experience than basic jQuery slideUp/slideDown
 */

/* Loading state for buttons */
.expand-job-details[disabled],
.expand-candidate-details[disabled] {
    opacity: 0.6;
    cursor: wait;
    pointer-events: none;
}

/* Smooth transition for detail content */
.additional-details {
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0.0, 0.2, 1);
    opacity: 1;
}

/* Expanded state */
.additional-details.expanded {
    opacity: 1;
    max-height: 2000px; /* Large enough for content */
}

/* Collapsed state */
.additional-details.collapsed {
    opacity: 0;
    max-height: 0;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Loading state animation */
.additional-details .loading-spinner {
    animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Detail rows fade in */
.expanded-job-details .detail-row,
.expanded-candidate-details .detail-row {
    animation: slideInFade 0.4s ease-out backwards;
}

/* Stagger animation for detail rows */
.expanded-job-details .detail-row:nth-child(1),
.expanded-candidate-details .detail-row:nth-child(1) {
    animation-delay: 0.05s;
}

.expanded-job-details .detail-row:nth-child(2),
.expanded-candidate-details .detail-row:nth-child(2) {
    animation-delay: 0.1s;
}

.expanded-job-details .detail-row:nth-child(3),
.expanded-candidate-details .detail-row:nth-child(3) {
    animation-delay: 0.15s;
}

.expanded-job-details .detail-row:nth-child(4),
.expanded-candidate-details .detail-row:nth-child(4) {
    animation-delay: 0.2s;
}

.expanded-job-details .detail-row:nth-child(5),
.expanded-candidate-details .detail-row:nth-child(5) {
    animation-delay: 0.25s;
}

.expanded-job-details .detail-row:nth-child(6),
.expanded-candidate-details .detail-row:nth-child(6) {
    animation-delay: 0.3s;
}

@keyframes slideInFade {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Chevron rotation animation */
.expand-job-details .fas,
.expand-candidate-details .fas {
    transition: transform 0.3s ease;
}

.expand-job-details .fas.fa-chevron-down,
.expand-candidate-details .fas.fa-chevron-down {
    transform: rotate(90deg);
}

.expand-job-details .fas.fa-chevron-right,
.expand-candidate-details .fas.fa-chevron-right {
    transform: rotate(0deg);
}

/* Button text transition */
.expand-job-details .btn-text,
.expand-candidate-details .btn-text {
    transition: opacity 0.2s ease;
}

/* Error alert animation */
.additional-details .alert {
    animation: shakeAndFade 0.5s ease-out;
}

@keyframes shakeAndFade {
    0% {
        opacity: 0;
        transform: translateX(-10px);
    }
    25% {
        transform: translateX(10px);
    }
    50% {
        transform: translateX(-5px);
    }
    75% {
        transform: translateX(5px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Retry button pulse animation - using enterprise blue */
.retry-job-load,
.retry-candidate-load {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(0, 82, 204, 0.7);
    }
    50% {
        box-shadow: 0 0 0 10px rgba(0, 82, 204, 0);
    }
}

/* Mobile touch feedback */
@media (max-width: 768px) {
    .expand-job-details:active,
    .expand-candidate-details:active {
        transform: scale(0.97);
        transition: transform 0.1s;
    }

    /* Larger touch targets */
    .expand-job-details,
    .expand-candidate-details {
        padding: 12px 20px;
        min-height: 48px;
    }
}

/* Reduced motion for accessibility */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus styles for accessibility - using enterprise blue */
.expand-job-details:focus,
.expand-candidate-details:focus {
    outline: 2px solid var(--color-primary, #0052CC);
    outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .expand-job-details:focus,
    .expand-candidate-details:focus {
        outline: 3px solid;
        outline-offset: 3px;
    }
}

/* Button group spacing for Quick Actions */
.action-buttons .btn {
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
}

/* Legacy fallback for older gap-2 implementation */
.d-flex.flex-wrap.gap-2 > * {
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
}

/* Ensure cards are properly stacked on mobile */
@media (max-width: 767px) {
    .application-view .col-md-8,
    .application-view .col-md-4 {
        width: 100%;
        margin-bottom: 1rem;
    }
}

/* Fix timeline rendering issues */
.interview-rounds-timeline {
    clear: both;
    overflow: visible;
}

/* Ensure timeline items don't overflow */
.timeline-item {
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

/* Fix card spacing */
.card + .card {
    margin-top: 1rem;
}

/* Ensure proper spacing in DetailView */
.detail-view th {
    width: 30%;
    white-space: nowrap;
}

.detail-view td {
    word-break: break-word;
}

/* Fix button wrapping on small screens */
@media (max-width: 576px) {
    .d-flex.flex-wrap.gap-2 .btn {
        width: 100%;
        margin-bottom: 0.5rem;
    }
}
