﻿.auth-scrim {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgb(255, 255, 255, 0.40);
    cursor: not-allowed;
    z-index: 2000;
}

.assigned-domain-card {
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

    .assigned-domain-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    }


    /* Unassign button styles */
    .assigned-domain-card .btn-outline-danger {
        border-width: 1px;
        font-size: 0.75rem;
        padding: 0.25rem 0.5rem;
        transition: all 0.2s ease;
    }

        .assigned-domain-card .btn-outline-danger:hover {
            background-color: #dc3545;
            border-color: #dc3545;
            color: white;
            transform: scale(1.05);
        }

        /* Loading state for unassign buttons */
        .assigned-domain-card .btn-outline-danger:disabled {
            opacity: 0.6;
            cursor: not-allowed;
        }

/* Bulk actions styling */
.bulk-unassign-container {
    background-color: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 0.375rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

    .bulk-unassign-container .btn-outline-warning:hover {
        background-color: #ffc107;
        border-color: #ffc107;
        color: #000;
    }

/* Animation for domain card removal */
.domain-card-removing {
    opacity: 0;
    transform: translateX(-100%);
    transition: all 0.3s ease;
}

/* Success state animation */
.domain-card-success {
    background-color: #d4edda !important;
    border-color: #c3e6cb !important;
    animation: successPulse 0.6s ease-in-out;
}

@keyframes successPulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.02);
    }

    100% {
        transform: scale(1);
    }
}

/* Error state animation */
.domain-card-error {
    background-color: #f8d7da !important;
    border-color: #f5c6cb !important;
    animation: errorShake 0.6s ease-in-out;
}

@keyframes errorShake {
    0%, 100% {
        transform: translateX(0);
    }

    25% {
        transform: translateX(-5px);
    }

    75% {
        transform: translateX(5px);
    }
}

/* Modal header styling for domain management */
#assignDomainModal .modal-title {
    font-weight: 600;
}

/* Responsive adjustments for smaller screens */
@media (max-width: 768px) {
    .assigned-domain-card .d-flex {
        flex-direction: column;
        align-items: flex-start !important;
    }

    .assigned-domain-card .ms-auto {
        margin-left: 0 !important;
        margin-top: 0.5rem;
        align-self: flex-end;
    }

    .bulk-unassign-container {
        text-align: center;
    }
}

/* Tooltip styling for unassign buttons */
.assigned-domain-card [title] {
    cursor: help;
}

/* Loading spinner in unassign button */
.assigned-domain-card .spinner-border-sm {
    width: 0.875rem;
    height: 0.875rem;
}

/* Domain count badge in modal header */
.domain-count-badge {
    font-size: 0.75rem;
    vertical-align: top;
}

/* Empty state styling */
.no-domains-message {
    color: #6c757d;
    font-style: italic;
}

    .no-domains-message i {
        opacity: 0.5;
    }


.domain-checkbox-card.selected {
    border-color: #198754 !important;
    background-color: #d1e7dd;
    box-shadow: 0 0 0 0.2rem rgba(25, 135, 84, 0.25);
}

.domain-checkbox-card {
    transition: all 0.2s ease;
    cursor: pointer;
}

    .domain-checkbox-card:hover {
        border-color: #198754 !important;
        background-color: #f8f9fa;
    }

.selection-preview {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    padding: 1rem;
    background-color: #f8f9fa;
}

/* Domain assignment modal styles */
.domain-selection-card {
    cursor: pointer;
    transition: transform 0.2s ease;
}

    .domain-selection-card:hover {
        transform: translateY(-2px);
    }

.domain-option-card {
    transition: all 0.2s ease;
    cursor: pointer;
}

    .domain-option-card:hover {
        border-color: #0d6efd !important;
        background-color: #f8f9fa;
    }

    .domain-option-card.selected {
        border-color: #0d6efd !important;
        background-color: #e7f3ff;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
    }

        .domain-option-card.selected .form-check-label {
            color: #0d6efd;
        }

/* Assigned domains display */
#assignedDomainsContainer {
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 0.375rem;
    padding: 1rem;
}

    #assignedDomainsContainer h6 {
        margin-bottom: 0.75rem;
    }

#assignedDomainsList .badge {
    font-size: 0.875rem;
    padding: 0.5rem 0.75rem;
}

/* Loading state */
.spinner-border {
    width: 2rem;
    height: 2rem;
}

/* Modal adjustments */
#assignDomainModal .modal-body {
    min-height: 400px;
}

/* All domains assigned state */
.text-success.fs-1 {
    font-size: 4rem !important;
}

.auth-scrim {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgb(255, 255, 255, 0.40);
    cursor: not-allowed;
    z-index: 2000;
}
