/* =========================================
   M365 Assessments - Quick Scan Plugin CSS
   Dashboard-style layout
   ========================================= */

.m365a-results {
    padding: var(--cg-space-lg);
    color: var(--cg-text-primary);
}

/* =========================================
   Score Bar
   ========================================= */
.m365a-score-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--cg-space-lg) var(--cg-space-xl);
    background: var(--cg-bg-card);
    border: 1px solid var(--cg-border);
    border-radius: var(--cg-radius-lg);
    margin-bottom: var(--cg-space-lg);
}

.m365a-score-main {
    display: flex;
    align-items: baseline;
    gap: var(--cg-space-sm);
}

.m365a-score-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--cg-text-primary);
    line-height: 1;
}

.m365a-score-divider {
    font-weight: 400;
    color: var(--cg-text-muted);
    margin: 0 2px;
}

.m365a-score-label {
    font-size: 0.85rem;
    color: var(--cg-text-muted);
}

.m365a-score-tag {
    display: inline-block;
    padding: 6px 16px;
    border-radius: var(--cg-radius-sm);
    font-size: 0.85rem;
    font-weight: 600;
}

/* =========================================
   Section Titles
   ========================================= */
.m365a-section-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--cg-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 var(--cg-space-md);
}

/* =========================================
   Category Cards Grid
   ========================================= */
.m365a-categories {
    margin-bottom: var(--cg-space-xl);
}

.m365a-cat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--cg-space-md);
}

.m365a-cat-card {
    text-align: center;
    padding: var(--cg-space-lg) var(--cg-space-md);
    background: var(--cg-bg-elevated);
    border-radius: var(--cg-radius-lg);
    border: 1px solid var(--cg-border);
    border-top: 3px solid transparent;
}

.m365a-cat-card.m365a-cat-ok {
    border-top-color: var(--cg-success);
}

.m365a-cat-card.m365a-cat-warn {
    border-top-color: var(--cg-warning);
}

.m365a-cat-card.m365a-cat-critical {
    border-top-color: var(--cg-danger);
}

.m365a-cat-card.m365a-cat-disabled {
    opacity: 0.4;
}

.m365a-cat-icon {
    color: var(--cg-text-muted);
    margin-bottom: var(--cg-space-sm);
}

.m365a-cat-ok .m365a-cat-icon { color: var(--cg-success); }
.m365a-cat-warn .m365a-cat-icon { color: var(--cg-warning); }
.m365a-cat-critical .m365a-cat-icon { color: var(--cg-danger); }

.m365a-cat-label {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--cg-text-primary);
    margin-bottom: 4px;
}

.m365a-cat-status {
    font-size: 0.8rem;
    font-weight: 600;
}

.m365a-cat-status.ok { color: var(--cg-success); }
.m365a-cat-status.warn { color: var(--cg-warning); }
.m365a-cat-status.critical { color: var(--cg-danger); }
.m365a-cat-status.disabled { color: var(--cg-text-muted); }

/* =========================================
   Check Cards Grid
   ========================================= */
.m365a-checkcards {
    margin-bottom: var(--cg-space-lg);
}

.m365a-check-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--cg-space-md);
    margin-bottom: var(--cg-space-md);
}

.m365a-checkcard {
    text-align: center;
    padding: var(--cg-space-lg) var(--cg-space-md);
    background: var(--cg-bg-elevated);
    border-radius: var(--cg-radius-lg);
    border: 1px solid var(--cg-border);
    border-top: 3px solid transparent;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    position: relative;
}

.m365a-checkcard:hover {
    background: var(--cg-bg-card);
}

.m365a-checkcard.active {
    border-color: var(--cg-accent);
    background: var(--cg-bg-card);
}

.m365a-checkcard-ok {
    border-top-color: var(--cg-success);
}

.m365a-checkcard-critical {
    border-top-color: var(--cg-danger);
}

.m365a-checkcard-warn {
    border-top-color: var(--cg-warning);
}

.m365a-checkcard-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    font-weight: 700;
    margin: 0 auto var(--cg-space-sm);
}

.m365a-checkcard-icon.ok {
    background: rgba(63, 185, 80, 0.15);
    color: var(--cg-success);
}

.m365a-checkcard-icon.critical {
    background: rgba(248, 81, 73, 0.15);
    color: var(--cg-danger);
}

.m365a-checkcard-icon.warn {
    background: rgba(210, 153, 34, 0.15);
    color: var(--cg-warning);
}

.m365a-checkcard-title {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--cg-text-primary);
    margin-bottom: 6px;
    line-height: 1.3;
}

.m365a-checkcard-status {
    font-size: 0.75rem;
    font-weight: 600;
}

.m365a-checkcard-status.ok { color: var(--cg-success); }
.m365a-checkcard-status.warn { color: var(--cg-warning); }
.m365a-checkcard-status.critical { color: var(--cg-danger); }

/* Info icon */
.m365a-checkcard-info {
    position: absolute;
    top: var(--cg-space-sm);
    right: var(--cg-space-sm);
    font-size: 0.8rem;
    color: var(--cg-text-muted);
    opacity: 0.3;
    transition: opacity 0.15s, color 0.15s;
}

.m365a-checkcard:hover .m365a-checkcard-info {
    opacity: 1;
    color: var(--cg-accent);
}

/* =========================================
   Modal Overlay
   ========================================= */
.m365a-modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    align-items: center;
    justify-content: center;
    padding: var(--cg-space-lg);
}

.m365a-modal-overlay.open {
    display: flex;
}

.m365a-modal-dialog {
    background: var(--cg-bg-card);
    border: 1px solid var(--cg-border);
    border-radius: var(--cg-radius-lg);
    max-width: 640px;
    width: 100%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: m365a-modal-in 0.2s ease-out;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}

.m365a-modal-dialog::-webkit-scrollbar {
    width: 6px;
}

.m365a-modal-dialog::-webkit-scrollbar-track {
    background: transparent;
}

.m365a-modal-dialog::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 3px;
}

.m365a-modal-dialog::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.25);
}

@keyframes m365a-modal-in {
    from { opacity: 0; transform: scale(0.95) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.m365a-modal-body {
    padding: var(--cg-space-lg);
}

.m365a-detail-content {
    /* container inside modal body */
}

.m365a-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--cg-space-md);
    margin-bottom: var(--cg-space-md);
    font-size: 0.95rem;
    color: var(--cg-text-primary);
}

.m365a-detail-close {
    background: none;
    border: none;
    font-size: 1.4rem;
    color: var(--cg-text-muted);
    cursor: pointer;
    padding: 0;
    line-height: 1;
    flex-shrink: 0;
}

.m365a-detail-close:hover {
    color: var(--cg-text-primary);
}

.m365a-detail-section {
    margin-bottom: var(--cg-space-md);
}

.m365a-detail-section:last-child {
    margin-bottom: 0;
}

.m365a-detail-label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--cg-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: var(--cg-space-xs);
}

.m365a-detail-text {
    font-size: 0.85rem;
    color: var(--cg-text-secondary);
    line-height: 1.6;
    margin: 0;
}

.m365a-detail-ok {
    color: var(--cg-success);
}

.m365a-detail-policies {
    margin: 0;
    padding-left: var(--cg-space-md);
    font-size: 0.85rem;
    color: var(--cg-text-secondary);
}

.m365a-detail-policies li {
    margin-bottom: 4px;
}

/* =========================================
   Detail Panel - Status Banners
   ========================================= */
.m365a-detail-banner {
    display: flex;
    align-items: center;
    gap: var(--cg-space-sm);
    padding: var(--cg-space-sm) var(--cg-space-md);
    border-radius: var(--cg-radius-md);
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: var(--cg-space-md);
}

.m365a-banner-ok {
    background: rgba(63, 185, 80, 0.1);
    color: var(--cg-success);
}

.m365a-banner-warn {
    background: rgba(210, 153, 34, 0.1);
    color: var(--cg-warning);
}

.m365a-banner-critical {
    background: rgba(248, 81, 73, 0.1);
    color: var(--cg-danger);
}

.m365a-banner-icon {
    font-size: 1rem;
    flex-shrink: 0;
}

/* =========================================
   Detail Panel - Policy Cards
   ========================================= */
.m365a-policy-card {
    background: var(--cg-bg-card);
    border: 1px solid var(--cg-border);
    border-radius: var(--cg-radius-md);
    padding: var(--cg-space-md);
    margin-bottom: var(--cg-space-sm);
}

.m365a-policy-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--cg-text-primary);
    margin-bottom: var(--cg-space-sm);
}

/* =========================================
   Detail Panel - Evidence Grid
   ========================================= */
.m365a-evidence-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--cg-space-xs) var(--cg-space-md);
}

.m365a-evidence-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.m365a-evidence-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--cg-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.m365a-evidence-value {
    font-size: 0.8rem;
    color: var(--cg-text-secondary);
}

/* =========================================
   Detail Panel - Partial Reasons
   ========================================= */
.m365a-partial-reasons {
    margin: 0;
    padding-left: var(--cg-space-md);
    font-size: 0.85rem;
    color: var(--cg-warning);
}

.m365a-partial-reasons li {
    margin-bottom: 4px;
}

/* =========================================
   Detail Panel - Risk Block
   ========================================= */
.m365a-risk-block {
    background: rgba(248, 81, 73, 0.05);
    border-left: 3px solid var(--cg-danger);
    padding: var(--cg-space-sm) var(--cg-space-md);
    border-radius: 0 var(--cg-radius-sm) var(--cg-radius-sm) 0;
}

/* =========================================
   Call to Action
   ========================================= */
.m365a-cta {
    text-align: center;
    padding: var(--cg-space-xl);
    background: var(--cg-bg-elevated);
    border-radius: var(--cg-radius-lg);
    margin-bottom: var(--cg-space-lg);
}

.m365a-cta-text {
    font-size: 0.95rem;
    color: var(--cg-text-secondary);
    margin: 0 0 var(--cg-space-md);
}

.m365a-cta-btn {
    opacity: 0.6;
    cursor: not-allowed;
}

/* =========================================
   Footer
   ========================================= */
.m365a-footer {
    text-align: center;
    padding: var(--cg-space-md);
    color: var(--cg-text-muted);
    font-size: 0.8rem;
    border-top: 1px solid var(--cg-border);
}

/* =========================================
   Error / Empty State
   ========================================= */
.m365a-error,
.m365a-no-checks {
    text-align: center;
    padding: var(--cg-space-xl);
    color: var(--cg-text-secondary);
}

/* =========================================
   Responsive
   ========================================= */
@media (max-width: 900px) {
    .m365a-cat-grid,
    .m365a-check-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .m365a-score-bar {
        flex-direction: column;
        gap: var(--cg-space-md);
        text-align: center;
    }

    .m365a-score-main {
        flex-direction: column;
        align-items: center;
    }

    .m365a-cat-grid,
    .m365a-check-grid {
        grid-template-columns: 1fr 1fr;
    }

    .m365a-modal-overlay {
        padding: var(--cg-space-sm);
    }

    .m365a-modal-dialog {
        max-height: 90vh;
    }
}

@media print {
    .m365a-cta-btn,
    .m365a-detail-close,
    .m365a-modal-overlay,
    .btn {
        display: none !important;
    }

    .m365a-checkcard-info {
        display: none;
    }
}
