/* ACCESSIBILITY */
.accessibility {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
}

/* Add Project Form */
.accessibilityAdd {
    display: flex;
    flex-direction: row;
    gap: 10px;
    align-items: center;
}

.accessibilityAdd input,
.accessibilityAdd select {
    border-radius: 4px;
    background-color: var(--black);
    color: var(--bone);
    border: 2px solid var(--faded-bone);
    padding: 10px 16px;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    transition: .3s ease;
}

.accessibilityAdd input:focus,
.accessibilityAdd select:focus {
    outline: none;
    border-color: var(--secondary);
}

.accessibilityAddDomain {
    flex: 2;
}

.accessibilityAddEmail {
    flex: 2;
}

.accessibilityAddButton {
    flex-shrink: 0;
    width: auto;
}

/* Projects List */
.accessibilityProjects {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.accessibilityProjectsEmpty {
    color: var(--faded-bone);
    padding: 20px 0;
}

/* Project Card */
.accessibilityProject {
    background-color: var(--highlight);
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

/* Scanning Progress */
.accessibilityProjectProgress {
    display: none;
    flex-direction: column;
    gap: 6px;
    padding: 0 14px 14px 14px;
}

.accessibilityProject.scanning .accessibilityProjectProgress {
    display: flex;
}

.accessibilityProjectProgressBar {
    height: 4px;
    width: 0;
    background-color: var(--secondary);
    border-radius: 2px;
    transition: width 0.5s ease;
}

.accessibilityProjectProgressText {
    font-size: 14px;
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
}

/* Project Top Bar */
.accessibilityProjectTop {
    display: flex;
    align-items: center;
}

.accessibilityProjectTopToggle {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px;
    flex: 1;
    text-align: left;
}

.accessibilityProjectTopDomain {
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    white-space: nowrap;
}

.accessibilityProjectTopCounts {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

/* Severity Count Badges */
.accessibilityBadge {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 16px;
    font-family: VCR OSD Mono, sans-serif;
}

.accessibilityBadge.critical {
    background-color: var(--red);
}

.accessibilityBadge.serious {
    background-color: #E8A838;
}

.accessibilityBadge.moderate {
    background-color: var(--yellow);
    color: var(--black);
}

.accessibilityBadge.minor {
    background-color: var(--disabled);
}

.accessibilityBadge.pass {
    background-color: var(--green);
    color: var(--black);
}

.accessibilityBadge.failed {
    background-color: var(--red);
}

/* Project Meta */
.accessibilityProjectTopMeta {
    display: flex;
    gap: 14px;
    margin-left: auto;
    color: var(--faded-bone);
    font-size: 18px;
    white-space: nowrap;
}

.accessibilityProjectTopMetaEmail {
    color: var(--secondary);
    font-size: 16px;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
}

/* Project Actions */
.accessibilityProjectTopActions {
    display: flex;
    gap: 6px;
    padding-right: 14px;
    align-items: center;
    flex-shrink: 0;
}

.accessibilityProjectTopActionsScan {
    width: auto;
    flex-shrink: 0;
}

.accessibilityProjectTopActionsEdit {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px;
    color: var(--faded-bone);
    transition: .3s ease;
    width: auto;
}

.accessibilityProjectTopActionsEdit:hover {
    color: var(--bone);
}

.accessibilityProjectTopActionsDelete {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px;
    color: var(--faded-bone);
    transition: .3s ease;
    width: auto;
}

.accessibilityProjectTopActionsDelete:hover {
    color: var(--red);
}

/* Project Accordion */
.accessibilityProjectBottom {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows ease 300ms;
}

.accessibilityProject.open .accessibilityProjectBottom {
    grid-template-rows: 1fr;
}

.accessibilityProjectBottomWrap {
    overflow: hidden;
}

.accessibilityProjectBottomContent {
    padding: 0 20px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Summary Cards */
.accessibilitySummary {
    display: flex;
    flex-direction: row;
    gap: 10px;
}

.accessibilitySummaryItem {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 14px 20px;
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 4px;
    flex: 1;
    border-top: 3px solid transparent;
}

.accessibilitySummaryItem.critical {
    border-top-color: var(--red);
}

.accessibilitySummaryItem.serious {
    border-top-color: #E8A838;
}

.accessibilitySummaryItem.moderate {
    border-top-color: var(--yellow);
}

.accessibilitySummaryItem.minor {
    border-top-color: var(--disabled);
}

.accessibilitySummaryItem.passes {
    border-top-color: var(--green);
}

.accessibilitySummaryItemCount {
    font-size: 40px;
}

.accessibilitySummaryItemLabel {
    font-size: 18px;
    color: var(--faded-bone);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* URL List */
.accessibilityUrlList {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 500px;
    overflow-y: auto;
    padding-right: 10px;
}

.accessibilityUrlList::-webkit-scrollbar {
    width: 12px;
    background: transparent;
    border-radius: 4px;
}

.accessibilityUrlList::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.15);
    cursor: ns-resize;
    border-radius: 4px;
}

.accessibilityUrlList::-webkit-scrollbar-thumb {
    background-color: var(--faded-bone);
    border-radius: 4px;
    cursor: grab;
    border: 2px solid transparent;
}

.accessibilityUrlList::-webkit-scrollbar-thumb:active {
    cursor: grabbing;
}

/* URL Row */
.accessibilityUrl {
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 4px;
}

.accessibilityUrlTop {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    width: 100%;
}

.accessibilityUrlTopToggle {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    text-align: left;
}

.accessibilityUrlTopRescan {
    flex-shrink: 0;
    width: auto;
    font-size: 14px;
    padding: 4px 10px;
}

.accessibilityUrlTopPath {
    flex: 1;
    text-align: left;
    font-family: VCR OSD Mono, sans-serif;
    font-size: 18px;
    letter-spacing: 1px;
}

.accessibilityUrlTopBadges {
    display: flex;
    gap: 4px;
}

/* URL Accordion */
.accessibilityUrlBottom {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows ease 300ms;
}

.accessibilityUrlTop.active ~ .accessibilityUrlBottom {
    grid-template-rows: 1fr;
}

.accessibilityUrlBottomWrap {
    overflow: hidden;
}

.accessibilityUrlBottomContent {
    padding: 0 14px 14px 28px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.accessibilityUrlBottomContentPass {
    color: var(--green);
    font-size: 18px;
    padding: 4px 0;
}

.accessibilityUrlBottomContentFailed {
    color: var(--red);
    font-size: 16px;
    padding: 4px 0;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
}

/* Violation Row */
.accessibilityViolation {
    background-color: rgba(0, 0, 0, 0.15);
    border-radius: 4px;
}

.accessibilityViolationTop {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    width: 100%;
}

.accessibilityViolationTopImpact {
    height: 12px;
    width: 12px;
    border-radius: 3px;
    flex-shrink: 0;
}

.accessibilityViolationTopImpact.critical {
    background-color: var(--red);
}

.accessibilityViolationTopImpact.serious {
    background-color: #E8A838;
}

.accessibilityViolationTopImpact.moderate {
    background-color: var(--yellow);
}

.accessibilityViolationTopImpact.minor {
    background-color: var(--disabled);
}

.accessibilityViolationTopName {
    flex: 1;
    text-align: left;
    font-size: 18px;
}

.accessibilityViolationTopCount {
    font-size: 16px;
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    flex-shrink: 0;
}

/* Violation Accordion */
.accessibilityViolationBottom {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows ease 300ms;
}

.accessibilityViolationTop.active ~ .accessibilityViolationBottom {
    grid-template-rows: 1fr;
}

.accessibilityViolationBottomWrap {
    overflow: hidden;
}

.accessibilityViolationBottomContent {
    padding: 0 14px 14px 28px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-size: 18px;
}

/* Violation Details */
.accessibilityViolationBottomContentDescription {
    color: var(--faded-bone);
    font-size: 16px;
}

.accessibilityViolationBottomContentTags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.accessibilityViolationBottomContentTag {
    background-color: var(--black);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 14px;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.accessibilityViolationBottomContentHelp {
    color: var(--secondary);
    text-decoration: underline;
    font-size: 16px;
    width: fit-content;
    transition: .3s ease;
}

.accessibilityViolationBottomContentHelp:hover {
    color: var(--bone);
}

/* Affected Nodes */
.accessibilityViolationBottomContentNodes {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 4px;
}

.accessibilityViolationBottomContentNodesNode {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 10px;
    background-color: var(--black);
    border-radius: 4px;
}

.accessibilityViolationBottomContentNodesNodeHtml {
    font-family: VCR OSD Mono, sans-serif;
    font-size: 14px;
    color: var(--yellow);
    word-break: break-all;
    white-space: pre-wrap;
}

.accessibilityViolationBottomContentNodesNodeTarget {
    font-size: 14px;
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
}

.accessibilityViolationBottomContentNodesNodeFix {
    font-size: 16px;
    color: var(--bone);
    white-space: pre-wrap;
}

/* States */
.accessibilityLoading {
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 10px 0;
}

.accessibilityLoadingDots::after {
    content: "";
    animation: accessibilityDots 1.2s steps(4) alternate infinite;
}

@keyframes accessibilityDots {
    0% { content: ""; }
    25% { content: "."; }
    50% { content: ".."; }
    75% { content: "..."; }
    100% { content: ""; }
}

.accessibilityError {
    color: var(--red);
    padding: 10px 0;
}

.accessibilityEmpty {
    color: var(--faded-bone);
    padding: 10px 0;
}

/* Mobile */
@media (max-width: 800px) {
    .accessibilityAdd {
        flex-direction: column;
    }

    .accessibilityAdd input,
    .accessibilityAdd select {
        width: 100%;
    }

    /* Project card — stack toggle and actions vertically */
    .accessibilityProjectTop {
        flex-wrap: wrap;
    }

    .accessibilityProjectTopToggle {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        width: 100%;
    }

    .accessibilityProjectTopDomain {
        white-space: normal;
        word-break: break-all;
    }

    .accessibilityProjectTopCounts {
        flex-wrap: wrap;
    }

    .accessibilityProjectTopMeta {
        flex-direction: column;
        margin-left: 0;
        gap: 4px;
        font-size: 16px;
        white-space: normal;
    }

    .accessibilityProjectTopMetaEmail {
        font-size: 14px;
        word-break: break-all;
    }

    .accessibilityProjectTopActions {
        width: 100%;
        padding: 0 14px 14px 14px;
    }

    /* Summary cards */
    .accessibilitySummary {
        flex-wrap: wrap;
    }

    .accessibilitySummaryItem {
        flex: 1 1 calc(50% - 5px);
    }

    .accessibilitySummaryItemCount {
        font-size: 32px;
    }

    /* URL rows */
    .accessibilityUrlList {
        max-height: none;
        padding-right: 0;
    }

    .accessibilityUrlTop {
        flex-wrap: wrap;
        gap: 6px;
        padding: 10px;
    }

    .accessibilityUrlTopToggle {
        width: 100%;
    }

    .accessibilityUrlTopPath {
        font-size: 14px;
        word-break: break-all;
    }

    .accessibilityUrlTopRescan {
        font-size: 12px;
        padding: 2px 8px;
    }

    /* Violations */
    .accessibilityViolationTopName {
        font-size: 16px;
    }

    .accessibilityViolationBottomContent {
        padding-left: 14px;
    }

    .accessibilityViolationBottomContentNodesNodeHtml {
        font-size: 12px;
    }

    .accessibilityViolationBottomContentNodesNodeFix {
        font-size: 14px;
    }

    /* Progress */
    .accessibilityProjectProgress {
        padding: 0 10px 10px 10px;
    }

    .accessibilityProjectProgressText {
        font-size: 12px;
    }

    /* Bottom content */
    .accessibilityProjectBottomContent {
        padding: 0 10px 10px 10px;
    }

    .accessibilityUrlBottomContent {
        padding: 0 10px 10px 14px;
    }
}
